# LSI Logic Data Book <br> 1986 

融

## Bipolar and CMOS LSI/VLSI

## LSI Logic Data Book

Texas
INSTRUMENTS

## IMPORTANT NOTICE

Texas Instruments (TI) reserves the right to make changes in the devices or the device specifications identified in this publication without notice. Tl advises its customers to obtain the latest version of device specifications to verify, before placing orders, that the information being relied upon by the customer is current.
TI warrants performance of its semiconductor products, including SNJ and SMJ devices, to current specifications in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent Tl deems such testing necessary to support this warranty. Unless mandated by government requirements, specific testing of all parameters of each device is not necessarily performed.

In the absence of written agreement to the contrary, Tl assumes no liability for TI applications assistance, customer's product design, or infringement of patents or copyrights of third parties by or arising from use of semiconductor devices described herein. Nor does TI warrant or represent that any license, either express or implied, is granted under any patent right, copyright, or other intellectual property right of Tl covering or relating to any combination, machine, or process in which such semiconductor devices might be or are used.

Specifications contained in this data book supersede all data for these products published by TI in the United States before November 1985.

## INTRODUCTION

The LSI Logic Data Book presents pertinent technical information on Texas Instruments complex bipolar and CMOS LSI logic integrated circuits. The bipolar LSI products described in this volume include:

- The fastest TTL-compatible 8-bit processor slice chip set available. The chip set includes an 8-bit registered ALU, a 14 -bit microsequencer, a 16 - and 32 -bit expandable barrel shifter, and a 16 -word by 4-bit register file.
- The fastest stand-alone 32-bit error detection and correction circuit (EDAC)
- High-performance $16 \times 4$ and $16 \times 5$ "zero-fall-through" FIFOs (first in, first out) memory devices with 24-nanosecond fall-through times
- A high-speed "flash" 32-bit barrel shifter (SN74AS8838). The SN74AS8838 is the first member of the Texas Instruments 32-bit processor chip set.

Specifications on CMOS LSI products included in this volume describe the following:

- The THCT1010, which is the lowest power $16-\times 16$-bit multiplier and accumulator (MAC) available.
- Two 64 K and 256 K DRAM controllers with inputs that are TTL- and CMOS-voltage compatible.
- Two high-speed CMOS multilevel pipeline registers, which offer a reduction in power over previously available devices.

To assist you in the selection of complex MSI logic components to complement a system design, the LSI Logic Data Book contains specifications on high-performance bus transceivers, readback latches, comparators, and controllers.

Many Texas Instruments leadership bipolar LSI functions use our new advanced bipolar technology, IMPACT ${ }^{\text {m }}$ (IMPlanted Advanced Composed Technology). This unique innovation offers performance advantages in speed, power, and circuit density over preceding bipolar technologies. The process offers such features as:

- 2- $\mu \mathrm{m}$ feature size
- 7- $\mu \mathrm{m}$ metal pitch
- Walled emitters
- Ion implantation
- Oxide isolation
- Composed masks

This data book provides a functional index to all bipolar digital device types available or under development. Packaging dimensions given in the Mechanical Data section of this book are in metric measurement (and parenthetically in inches), which should simplify board layout for designers involved in metric conversion and new designs. The general information section includes an explanation of the function tables, parameter measurement information, and typical characteristics related to the products listed in this volume.

Complete technical data for any Texas Instruments semiconductor/component product is available from your nearest TI field sales office, local authorized TI distributor, or by writing direct to:

> Texas Instruments Incorporated
> P.O. Box $225012, \mathrm{MS} 308$
> Dallas, Texas 75265

We sincerely believe that you will find the new LSI Logic Data Book a meaningful addition to your technical library.
vi

Numerical Index
Glossary
Explanation of Function Tables
Parameter Measurement Information
Functional Index

## LSI Devices

Advanced Schottky Family
Error Detection and Correction
Memory Mapping
Bit-Slice Processor 8-Bit Family
Excerpt - SN74AS888, SN74AS890
Bit-Slice Processor User's Guide
Mechanical Data

ио!̣ешлодиן ןедәиәэ

| NUMERICAL INDEX |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SN54AS181A | SN74AS181A | 2-3 | SN54AS852 | SN74AS852 | 2-201 |
| SN54LS222 | SN74LS222 | 2-13 | SN54AS856 | SN74AS856 | 2-207 |
| SN54LS224 | SN74LS224 | 2-13 | SN54AS867 | SN74AS867 | 2-213 |
|  | SN74S225 | 2-21 | SN54AS869 | SN74AS869 | 2-213 |
| SN54LS227 | SN74LS227 | 2-13 | SN54AS870 | SN74AS870 | 2-219 |
| SN54LS228 | SN74LS228 | 2-13 | SN54AS871 | SN74AS871 | 2-219 |
| SN54ALS229A | SN74ALS229A | 2-27 | SN54AS877 | SN74AS877 | 2-225 |
| SN54ALS232A | SN74ALS232A | 2-33 | SN54AS881A | SN74AS881A | 2-3 |
| SN54ALS233A | SN74ALS233A | 2-37 | SN54AS882A | SN74AS882A | 2-231 |
|  | SN74AS250 | 2-43 | SN54AS885 | SN74AS885 | 2-239 |
| SN54ALS280 | SN74ALS280 | $2-47$ | SN54AS887 | SN74AS887 | 2-245 |
| SN54AS280 | SN74AS280 | $2-47$ | SN54AS888 | SN74AS888 | 2-293 |
| SN54AS286 | SN74AS286 | 2-53 | SN54AS890 | SN74AS890 | 2-343 |
| SN54LS610 | SN74LS610 | 2-59 | SN54AS895 | SN74AS895 | 2-361 |
| SN54LS611 | SN74LS611 | 2-59 | SN54AS897A | SN74AS897A | 2-411 |
| SN54LS612 | SN74LS612 | 2-59 | SN54ALS963 | SN74ALS963 | 2-429 |
| SN54LS613 | SN74LS613 | 2-59 | SN54ALS964 | SN74ALS964 | 2-429 |
| SN54ALS616 | SN74ALS616 | 2-69 |  | SN74ALS990 | 2-441 |
| SN54ALS617 | SN74ALS617 | 2-69 |  | SN74ALS991 | 2-441 |
| SN54ALS632A | SN74ALS632A | 2-81 |  | SN74ALS992 | 2-449 |
| SN54AS632 | SN74AS632 | 2-97 |  | SN74ALS993 | 2-449 |
| SN54ALS633 | SN74ALS633 | 2-81 |  | SN74ALS994 | 2-457 |
| SN54ALS634 | SN74ALS634 | 2-81 |  | SN74ALS995 | 2-457 |
| SN54AS634 | SN74AS634 | 2-97 |  | SN74ALS996 | 2-465 |
| SN54ALS635 | SN74ALS635 | 2-81 | SN54AS1181 | SN74AS1181 | 2-471 |
| SN54ALS646 | SN74ALS646 | 2-111 | SN54ALS2967 | SN74ALS2967 | 2-483 |
| SN54AS646 | SN74AS646 | 2-111 | SN54ALS2968 | SN74ALS2968 | 2-483 |
| SN54ALS647 | SN74ALS647 | 2-111 | SN54ALS6301 | SN74ALS6301 | 2-503 |
| SN54ALS648 | SN74ALS648 | 2-111 | SN54ALS6302 | SN74ALS6302 | 2-503 |
| SN54AS648 | SN74AS648 | 2-111 |  | SN74ALS8400 | 2-509 |
| SN54ALS649 | SN74ALS649 | 2-111 | SN54AS8834 | SN74AS8834 | 2-513 |
| SN54ALS651 | SN74ALS651 | 2-125 | SN54AS8838 | SN74AS8838 | 2-523 |
| SN54AS651 | SN74AS651 | 2-125 | SN54ALS29818 | SN74ALS29818. | 2-533 |
| SN54ALS652 | SN74ALS652 | 2-125 | SN54ALS29819 | SN74ALS29819. | 2-533 |
| SN54AS652 | SN74AS652 | 2-125 | SN54ALS29821 | SN74ALS29821. | 2-545 |
| SN54ALS653 | SN74ALS653 | 2-125 | SN54ALS29822 | SN74ALS29822. | 2-545 |
| SN54ALS654 | SN74ALS654 | 2-125 | SN54ALS29823 | SN74ALS29823 | 2-551 |
| SN54ALS666 | SN74ALS666 | 2-137 | SN54ALS29824 | SN74ALS29824. | 2-551 |
| SN54ALS667 | SN74ALS667 | 2-137 | SN54ALS29825 | SN74ALS29825 | 2-559 |
| SN54AS821 | SN74AS821 | 2-145 | SN54ALS29826 | SN74ALS29826 | 2-559 |
| SN54AS822 | SN74AS822 | 2-145 | SN54ALS29827 | SN74ALS29827. | 2-565 |
| SN54AS823 | SN74AS823 | 2-151 | SN54ALS29828 | SN74ALS29828. | 2-565 |
| SN54AS824 | SN74AS824 | 2-151 | SN54ALS29861 | SN74ALS29861. | 2-571 |
| SN54AS825 | SN74AS825 | 2-157 | SN54ALS29862 | SN74ALS29862. | 2-571 |
| SN54AS826 | SN74AS826 | 2-157 | SN54ALS29863 | SN74ALS29863. | 2-577 |
| SN54ALS841 | SN74ALS841 | 2-163 | SN54ALS29864 | SN74ALS29864 | 2-577 |
| SN54AS841 | SN74AS841 | 2-163 | THCT1010-160M |  | 2-583 |
| SN54ALS842 | SN74ALS842 | 2-163 |  | THCT1010-100 | 2-583 |
| SN54AS842 | SN74AS842 | 2-163 |  | THCT 1010-140E | 2-583 |
| SN54ALS843 | SN74ALS843 | 2-173 | THCT2000M | THCT2000E | 2-593 |
| SN54AS843 | SN74AS843 | 2-173 |  | THCT4502. | 2-597 |
| SN54ALS844 | SN74ALS844 | 2-173 |  | THCT29520E | 2-613 |
| SN54AS844 | SN74AS844 | 2-173 |  | THCT29520. | 2-613 |
| SN54ALS845 | SN74ALS845 | 2-181 |  | THCT29521E | 2-613 |
| SN54AS845 | SN74AS845 | 2-181 |  | THCT29521. | 2-613 |
| SN54ALS846 | SN74ALS846 | 2-181 |  | TMS2150 | 2-619 |
| SN54AS846 | SN74AS846 | 2-181 |  | TMS4500A | 2-627 |
|  | SN74AS850 | 2-191 |  |  |  |
|  | SN74AS851 | 2-191 |  |  |  |

ио!̣ешоуи Іедәәә $\rightarrow$

## GLOSSARY <br> TTL SYMBOLS, TERMS, AND DEFINITIONS

## 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 in the USA and by the International Electrotechnical Commission (IEC) for international use.

## PART I - OPERATING CONDITIONS AND CHARACTERISTICS (IN SEQUENCE BY LETTER SYMBOLS)

$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.
ICCH Supply current, outputs high
The current into* the $\mathrm{V}_{\mathrm{CC}}$ supply terminal of an integrated circuit when all (or a specified number) of the outputs are at the high level.

ICCL Supply current, outputs low
The current into* the VCC supply terminal of an integrated circuit when all (or a specified number) of the outputs are at the low level.
$I_{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} \quad$ High-level output current
The current into* an output with input conditions applied that, according to the product specification, will 1 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.

IOS Short-circuit output current
The current into* an output when that output is short-circuited to ground (or other specified potential) with input conditions applied to establish the output logic level farthest from ground potential (or other specified potential).
lOZH Off-state (high-impedance-state) output current (of a three-state output) with high-level voltage applied The current flowing into* an output having three-state capability with input conditions established that, according to the product specification, will establish the high-impedance state at the output and with a highlevel voltage applied to the output.
NOTE: This parameter is measured with other input conditions established that would cause the output to be at a low level if it were enabled.

[^0]
## GLOSSARY <br> TTL SYMBOLS, TERMS, AND DEFINITIONS


#### Abstract

IOZL Off-state (high-impedance-state) output current (of a three-state output) with low-level voltage applied The current flowing into* an output having three-state capability with input conditions established that, according to the product specification, will establish the high-impedance state at the output and with a lowlevel voltage applied to the output. NOTE: This parameter is measured with other input conditions established that would cause the output to be at a high level if it were enabled.

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.

\section*{VIK Input clamp voltage}

An input voltage in a region of relatively low differential resistance that serves to limit the input voltage swing. VIL Low-level input voltage An input voltage level 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.


VOH High-level output voltage
The voltage at an output terminal with input conditions applied that, according to the product specification, will establish a high level at the output.

## VOL Low-level output voltage

The voltage at an output terminal with input conditions applied that, according to the product specification, will establish a low level at the output.

## Access time

The time interval between the application of a specified input pulse and the availability of valid signals at an output.
$t_{\text {dis }} \quad$ Disable time (of a three-state or open-collector output)
The propagation time between the specified reference points on the input and output voltage waveforms with the output changing from either of the defined active levels (high or low) to a high-impedance (off) state.
NOTE: For 3 -state outputs, $\mathrm{t}_{\mathrm{di}}=\mathrm{tPHZ}$ or tpLZ. Open-collector outputs will change only if they are low at the time of disabling so $\mathrm{t}_{\mathrm{dis}}=\mathrm{tPLH}$.
ten Enable time (of a three-state or open-collector output)
The propagation time between the specified reference points on the input and output voltage waveforms with the output changing from a high-impedance (off) state to either of the defined active levels (high or low). NOTE: In the case of memories, this is the access time from an enable input (e.g., $\overline{\mathrm{G}}$ ). For 3 -state outputs, $t_{e n}=t_{P Z H}$ or tPZL. Open-collector outputs will change only if they are responding to data that would cause the output to go low so $\mathrm{t}_{\mathrm{en}}=\mathrm{t}$ PHL .

[^1]
## tPLH Propagation delay time, low-to-high-level output

The time between the specified reference points on the input and output voltage waveforms with the output changing from the defined low level to the defined high level.

## tpLZ Disable time (of a three-state output) from low level

The time interval between the specified reference points on the input and output voltage waveforms with the three-state output changing from the defined low level to a high-impedance (off) state.
tPZH Enable time (of a three-state output) to high level
The time interval between the specified reference points on the input and output voltage waveforms with the three-state output changing from a high-impedance (off) state to the defined high level.
tPZL Enable time (of a three-state output) to low level
The time interval between the specified reference points on the input and output voltage waveforms with the three-state output changing from a high-impedance (off) state to the defined low level.

## $t_{s r}$ <br> Sense recovery time

$t_{\mathbf{s u}}$
$t_{w}$

## Hold time

The time interval during which a signal is retained at a specified input terminal after an active transition occurs at another specified input terminal.
NOTES: 1. The hold 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 hold time may have a negative value in which case the minimum limit defines the longest interval (between the release of the signal and the active transition) for which correct operation of the digital circuit is guaranteed.

## Propagation delay time

The time between the specified reference points on the input and output voltage waveforms with the output changing from one defined level (high or low) to the other defined level. ( $\mathrm{t}_{\mathrm{Dd}}=\mathrm{tPHL}^{\text {or }} \mathrm{tPLH}^{\prime}$ ).

Propagation delay time, high-to-low-level output
The time between the specified reference points on the input and output voltage waveforms with the output changing from the defined high level to the defined low level.

Disable time (of a three-state output) from high level
The time interval between the specified reference points on the input and output voltage waveforms with the three-state output changing from the defined high level to a high-impedance (off) state.

The time interval needed to switch a memory from a write mode to a read mode and to obtain valid data signals at the output.

## Setup time

The time interval between the application of a signal at a specified input terminal 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.

## Pulse duration (width)

The time interval between specified reference points on the leading and trailing edges of the pulse waveform.

GLOSSARY
TTL SYMBOLS, TERMS, AND DEFINITIONS

## PART II - CLASSIFICATION OF CIRCUIT COMPLEXITY

## Gate Equivalent Circuit

A basic unit-of-measure of relative digital-circuit complexity. The number of gate equivalent circuits is that number of individual logic gates that would have to be interconnected to perform the same function.

Large-Scale Integration, LSI
A concept whereby a complete major subsystem or system function is fabricated as a single microcircuit. In this context a major subsystem or system, whether digital or linear, is considered to be one that contains 100 or more equivalent gates or circuitry of similar complexity.

## Medium-Scale Integration, MSI

A concept whereby a complete subsystem or system function is fabricated as a single microcircuit. The subsystem or system is smaller than for LSI, but whether digital or linear, is considered to be one that contains 12 or more equivalent gates or circuitry of similar complexity.

Small-Scale Integration, SSI
Integrated circuits of less complexity than medium-scale integration (MSI).

## Very-Large-Scale Integration, VLSI

The description of any IC technology that is much more complex than large-scale integration (LSI), and involves a much higher equivalent gate count. At this time an exact definition including a minimum gate count has not been standardized by JEDEC or the IEEE.

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 |
| $\rightarrow$ | $=$ | value/level or resulting value/level is routed to indicated destination |
| $n$ | = | 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 at inputs $A$ through $H$ respectively |
| $\mathrm{O}_{0}$ | $=$ | level of $Q$ before the indicated steady-state input conditions were established |
| $\overline{\mathrm{a}}_{0}$ | = | complement of $\mathrm{Q}_{0}$ or level of $\overline{\mathrm{Q}}$ before the indicated steady-state input conditions were established |
| $\mathrm{O}_{\mathrm{n}}$ | $=$ | level of $Q$ before the most recent active transition indicated by $\downarrow$ or $\uparrow$ |
| $\sqrt{\square}$ | $=$ | one high-level pulse |
| $\square$ | $=$ | one low-level pulse |
| TOGGLE | $=$ | 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 $H, 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 ( $H, L, Q_{0}$, or $\left.\overline{\mathrm{O}}_{0}\right)$, 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, $\square \square$ or $\square$, the pulse follows the indicated input transition and persists for an interval dependent on the circuit.)

## explanation OF Function tables

Among the most complex function tables in this book 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 |  | PARALLEL |  |  |  | $\mathbf{Q}_{\mathbf{A}}$ | $\mathbf{Q}_{\mathbf{B}}$ | $\mathrm{Q}_{\mathbf{C}}$ | $\mathbf{Q}_{\mathbf{D}}$ |
|  | S1 | S0 |  | 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 | $\mathrm{Q}_{\text {A0 }}$ | $\mathrm{Q}_{\mathrm{BO}}$ | $\mathrm{Q}_{\mathrm{CO}}$ | QD0 |
| H | H | H | $\uparrow$ | $x$ | X | a | b | c | d | a | b | c | d |
| H | L | H | $\uparrow$ | $x$ | H | x | X | X | x | H | $Q_{\text {An }}$ | $\mathrm{O}_{\mathrm{Bn}}$ | $\mathrm{Q}_{\mathrm{Cn}}$ |
| H | L | H | $\uparrow$ | X | L | $x$ | $x$ | $x$ | $x$ | L | $Q_{A n}$ | $\mathrm{O}_{\mathrm{Bn}}$ | $\mathrm{Q}_{\mathrm{Cn}}$ |
| H | H | L | 1 | H | $x$ | X | $x$ | $x$ | $x$ | $\mathrm{O}_{\mathrm{Bn}}$ | $\mathrm{Q}_{\mathrm{Cn}}$ | $\mathrm{Q}_{\mathrm{Dn}}$ | H |
| H | H | L | $\uparrow$ | L | $x$ | $x$ | $x$ | $x$ | $x$ | $\mathrm{O}_{\mathrm{Bn}}$ | $\mathrm{Q}_{\mathrm{Cn}}$ | $\mathrm{Q}_{\text {Dn }}$ | L |
| H | L | L | X | X | X | X | x | X | X | $\mathrm{Q}_{\text {A0 }}$ | $\mathrm{Q}_{\mathrm{BO}}$ | $\mathrm{Q}_{\mathrm{CO}}$ | $\mathrm{Q}_{\mathrm{DO}}$ |

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{O}_{\mathrm{B}}$, and so forth, following a low-to-high clock transition.

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 S0 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 now at $Q_{A}$, the previous levels of $Q_{C}$ and $O_{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 S0 is low and the levels at inputs $A$ through $D$ have no effect.

The last line shows that as long as both mode 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.

## PARAMETER MEASUREMENT INFORMATION



NOTE A: $C_{L}$ includes probe and jig capacitance.


NOTES: B. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
C. All input pulses have the following characteristics: PRR $\leq 1 \mathrm{MHz}, \mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=2 \mathrm{~ns}$, duty cycle $=50 \%$.
D. When measuring propagation delay times of 3-state outputs, switch S1 is closed.

## GATES AND INVERTERS



POSITIVE-NAND GATES AND INVERTERS WITH OPEN-COLLECTOR OUTPUTS

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{array}{\|l\|} \hline \text { STD } \\ \text { TTL } \end{array}$ | ALS | AS | H | L | LS | S |  |
| Hex Inverters | '05 | $\bullet$ |  |  | $\bullet$ |  | - | $\bullet$ | 2 |
|  |  |  | A |  |  |  |  |  | 3 |
|  | '1005 |  | - |  |  |  |  |  |  |
| Quadruple 2-Input Gates | '01 | $\bullet$ |  |  | $\bullet$ |  | - |  | 2 |
|  |  |  | $\bullet$ |  |  |  |  |  | 3 |
|  | '03 | - |  |  |  | $\bullet$ | - | $\bullet$ | 2 |
|  |  |  | B |  |  |  |  |  | 3 |
|  | '1003 |  | A |  |  |  |  |  |  |
| Triple 3-Input Gates | '12 | - |  |  |  |  | $\bullet$ |  | 2 |
|  |  |  | A |  |  |  |  |  | 3 |
| Dual 4-Input Gates | '22 | $\bullet$ |  |  | $\bullet$ |  | $\bullet$ | $\bullet$ | 2 |
|  |  |  | B |  |  |  |  |  | 3 |

POSITIVE-AND GATES

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{array}{\|l} \hline \text { STD } \\ \text { TTL } \end{array}$ | ALS | AS | H | LS | S |  |
| Hex 2-Input Gates | '808 |  | A | B |  |  |  | 3 |
| Quadruple 2-Input Gates | '08 | - |  |  |  | - | $\bullet$ | 2 |
|  |  |  | $\bullet$ | $\bullet$ |  |  |  | 3 |
|  | '1008 |  | A | $\bullet$ |  |  |  |  |
| Triple 3-Input Gates | '11 |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | 2 |
|  |  |  | A | $\bullet$ |  |  |  | 3 |
|  | '1011 |  | A |  |  |  |  | 3 |
| Dual 4-Input Gates | '21 |  |  |  | $\bullet$ | $\bullet$ |  | 2 |
|  |  |  | - | - |  |  |  | 3 |
| Triple 4-Input AND/NAND | '800 |  |  | $\Delta$ |  |  |  |  |


| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | H | LS | S |  |
| Quadruple 2-Input Gates | '09 | - |  |  |  | - | $\bullet$ | 2 |
|  |  |  | $\bullet$ |  |  |  |  | 3 |
| Triple 3-Input Gates | $\cdot 15$ |  |  |  | $\bullet$ | - | $\bullet$ | 2 |
|  |  |  | A |  |  |  |  | 3 |


| POSITIVE-OR GATES |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
|  |  | $\begin{array}{\|l\|} \hline \text { STD } \\ \text { TTL } \\ \hline \end{array}$ | ALS | AS | LS | S |  |
| Hex 2-Input Gates | '832 |  | A | B |  |  | 3 |
| Quadruple 2-Input Gates | '32 | - |  |  | $\bullet$ | $\bullet$ | 2 |
|  | 32 |  | $\bullet$ | $\bullet$ |  |  | 3 |
|  | '1032 |  | A | $\bullet$ |  |  |  |
| Triple 4-Input OR/NOR | '802 |  |  | A |  |  |  |

POSITIVE-NOR GATES

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \\ & \hline \end{aligned}$ | ALS | AS | L | LS | S |  |
| Hex 2-Input Gates | '805 |  | A | B |  |  |  | 3 |
| Quadruple 2-Input Gates | '02 | $\bullet$ |  |  | $\bullet$ | $\bullet$ | $\bullet$ | 2 |
|  |  |  | - | - |  |  |  | 3 |
|  | '1002 |  | A |  |  |  |  |  |
| Triple 3-Input Gates | '27 | $\bullet$ |  |  |  | $\bullet$ |  | 2 |
|  |  |  | $\bullet$ | $\bullet$ |  |  |  | 3 |
| Dual 4-Input Gates with Strobe | '25 | - |  |  |  |  |  | 2 |
| Dual 5-Input Gates | '260 |  |  |  |  |  | $\bullet$ |  |

SCHMITT-TRIGGER POSITIVE-NAND GATES AND INVERTERS

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \mathrm{STD} \\ & \mathrm{TTL} \end{aligned}$ | ALS | AS | LS | S |  |
| Hex Inverters | '14 | $\bullet$ |  |  | - |  | 2 |
|  | '19 |  |  |  | $\bullet$ |  |  |
| Octal Inverters | '619 |  |  |  | $\bullet$ |  |  |
| Dual 4-Input Positive-NAND | 13 | $\bullet$ |  |  | $\bullet$ |  |  |
|  | '18 |  |  |  | $\bullet$ |  |  |
| Triple 4-Input Positive-NAND | '618 |  |  |  | $\bullet$ |  |  |
| Quadruple 2-Input Positive-NAND | '24 |  |  |  | $\bullet$ |  |  |
|  | '132 | $\bullet$ |  |  | $\bullet$ | $\bullet$ |  |

CURRENT-SENSING GATES

| DESCRIPTION | TYPE | TECHNOLOGY |  | VOLUME |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ALS |  | LS |
|  |  |  |  |  |
| Hex | 63 |  |  | $\bullet$ | 2 |

DELAY ELEMENTS

| DESCRIPTION | TYP | TECHNOLOGY |  | VOLUME |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | AS | LS |  |  |
| Inverting and Noninverting Elements, <br> 2-Input NAND Buffers |  | 31 |  |  | $\bullet$ |

- Denotes available technology.

A Denotes planned new products.
A Denotes " $A$ " suffix version available in the technology indicated.
$B$ Denotes " $B$ " suffix version available in the technology indicated.

## FUNCTIONAL INDEX

## GATES, EXPANDERS, BUFFERS, DRIVERS, AND TRANSCEIVERS



EXPANDABLE GATES

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | H | $L$ | LS |  |
| Dual 4-Input Positive-NOR with Strobe | '23 | - |  |  |  |  |  | 2 |
| 4.Wide AND-OR | '52 |  |  |  | $\bullet$ |  |  |  |
| 4-Wide AND-OR-INVERT | 53 | - |  |  | $\bullet$ |  |  |  |
| 2-Wide AND-OR-INVERT | '55 |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ |  |
| Dual 2-Wide AND-OR-INVERT | '50 | - |  |  | $\bullet$ |  |  |  |


| EXPANDERS |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  | VOLUME |
|  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | H |  |
| Dual 4-Input | '60 | $\bullet$ |  |  | $\bullet$ |  |
| Triple 3-Input | '61 |  |  |  | $\bullet$ | 2 |
| 3-2-2-3 Input AND-OR | '62 |  |  |  | $\bullet$ |  |

BUFFER AND INTERFACE GATES WITH OPEN-COLLECTOR OUTPUTS


BUFFERS, DRIVERS, AND BUS TRANSCEIVERS WITH OPEN-COLLECTOR OUTPUTS

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \hline \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | LS | S |  |
| Noninverting Octal Buffers/Drivers | '743 |  | $\Delta$ |  |  |  | 3 |
|  | ${ }^{7} 757$ |  | $\bullet$ | $\bullet$ |  |  |  |
|  | '760 |  |  | $\bullet$ |  |  |  |
| Inverting Octal Buffers/Drivers | '742 |  | A |  |  |  |  |
|  | '756 |  |  | $\bullet$ |  |  |  |
|  | '763 |  | - | $\bullet$ |  |  |  |
| Inverting and Noninverting Octal Buffers/Drivers | '762 |  | - | - |  |  |  |
| Noninverting Quad Transceivers | '759 |  |  | $\bullet$ |  |  |  |
| Inverting Quad Transceivers | '758 |  |  | $\bullet$ |  |  |  |

[^2]$\Delta$ Denotes planned new products.
A Denotes " $A$ " suffix version available in the technology indicated.

## GATES, EXPANDERS, BUFFERS, DRIVERS, AND TRANSCEIVERS

GATES, BUFFERS, DRIVERS, AND BUS TRANSCEIVERS WITH 3-STATE OUTPUTS

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | LS | S |  |
| Noninverting 10-Bit Buffers/Drivers | '29827 |  | A |  |  |  | LSI |
| Inverting 10-Bit Buffers/Drivers | '29828 |  | 4 |  |  |  |  |
| Noninverting 10-Bit Transceivers | '29861 |  | A |  |  |  |  |
| Inverting 10-Bit Transceivers | '29862 |  | 4 |  |  |  |  |
| Noninverting 9-Bit Transceivers | '29863 |  | $\Delta$ |  |  |  |  |
| Inverting 9-Bit Transceivers | '29864 |  | A |  |  |  |  |
| Noninverting <br> Octal Buffers/Drivers | '241 |  |  |  | - | $\bullet$ | 2 |
|  |  |  | A | $\bullet$ |  |  | 3 |
|  | '244 |  |  |  | $\bullet$ | $\bullet$ | 2 |
|  |  |  | A | - |  |  | 3 |
|  | '465 |  |  |  | $\bullet$ |  | 2 |
|  |  |  | A |  |  |  | 3 |
|  | '467 |  |  |  | - |  | 2 |
|  |  |  | A |  |  |  | 3 |
|  | '541 |  |  |  | - |  | 2 |
|  |  |  | - |  |  |  | 3 |
|  | . 1241 ' |  | $\Delta$ |  |  |  |  |
|  | . $1244{ }^{\prime}$ |  | A |  |  |  |  |
| Inverting Octal Buffers/Drivers | '231 |  | $\bullet$ | - |  |  |  |
|  | '240 |  |  |  | $\bullet$ | $\bullet$ | 2 |
|  |  |  | A | $\bullet$ |  |  | 3 |
|  | '466 |  |  |  | - |  | 2 |
|  |  |  | A |  |  |  | 3 |
|  | '468 |  |  |  | $\bullet$ |  | 2 |
|  |  |  | A |  |  |  | 3 |
|  | '540 |  |  |  | $\bullet$ |  | 2 |
|  |  |  | $\bullet$ |  |  |  | 3 |
|  | '1240 ${ }^{\prime}$ |  | $\bullet$ |  |  |  | 3 |
| Inverting and Noninverting Octal Buffers/Drivers | '230 |  |  | - |  |  |  |
| Octal Transceivers | '245 |  |  |  | $\bullet$ |  | 2 |
|  |  |  | A | $\bullet$ |  |  | 3 |
|  | '1245 |  | A |  |  |  |  |
| Noninverting Hex Buffers/Drivers | '365 | A |  |  | A |  | 2 |
|  |  |  | - |  |  |  | 3 |
|  | '367 | A |  |  | A |  | 2 |
|  |  |  | $\bullet$ |  |  |  | 3 |
| Inverting <br> Hex Buffers/Drivers | '366 | A | . |  | A |  | 2 |
|  |  |  | 4 |  |  |  | 3 |
|  | '368 | A |  |  | A |  | 2 |
|  |  |  | $\triangle$ |  |  |  | 3 |
| Quad Buffers/Drivers with Independent Output Controls | 125 | $\bullet$ |  |  | A |  | 2 |
|  | '126 | $\bullet$ |  |  | A |  |  |
|  | '425 | $\bullet$ |  |  |  |  |  |
|  | 426 | $\bullet$ |  |  |  |  |  |
| Noninverting Quad Transceivers | '243 |  |  |  | $\bullet$ |  | 3 |
|  |  |  | A | $\bullet$ |  |  |  |
|  | . 12431 |  | A |  |  |  |  |
| Inverting <br> Quad Transceivers | '242 |  |  |  | $\bullet$ |  | 2 |
|  |  |  | A | $\bullet$ |  |  | 3 |
|  | $12421$ |  | - |  |  |  |  |
| Quad Transceivers with Storage | '226 |  |  |  |  | $\bullet$ | 2 |
| 12-Input NAND Gate | '134 |  |  |  |  | $\bullet$ |  |

50-OHM/75-OHM LINE DRIVERS

| DESCRIPTION |  | TECHNOLOGY |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TYPE | STD <br> TTL | ALS | AS | S |  |
| Hex 2-Input Positive-NAND | 804 |  | A | B |  |  |
| Hex 2-Input Positive-NOR | 805 |  | A | B |  | 3 |
| Hex 2-Input Positive-AND | .808 |  | A | B |  |  |
| Hex 2-Input Positive-OR | 832 |  | A | B |  |  |
| Quad 2-Input Positive-NOR | 128 | $\bullet$ |  |  |  | 2 |
| Dual 4-Input Positive-NAND | 140 |  |  |  | $\bullet$ |  |

[^3]- Denotes planned new products.
f Denotes very low power.
A Denotes " $A$ " suffix version available in the technology indicated.
B Denotes " $B$ " suffix version available in the technology indicated.


## BUFFERS, DRIVERS, TRANSCEIVERS, AND CLOCK GENERATORS

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | H | LS | S |  |
| Hex 2-Input Positive-NAND | '804 |  | A | B |  |  |  | 3 |
| Hex 2-input Positive-NOR | '805 |  | A | B |  |  |  |  |
| Hex 2-Input Positive-AND | '808 |  | A | B |  |  |  |  |
| Hex 2-Input Positive-OR | '832 |  | A | B |  |  |  |  |
| Hex Inverter | '1004 |  | $\bullet$ | - |  |  |  |  |
| Hex Buffer | '34 |  | $\bullet$ | - |  |  |  |  |
|  | '1034 |  | $\bullet$ | A |  |  |  |  |
| Quad 2-Input Positive-NAND | '37 | $\bullet$ |  |  |  | $\bullet$ | $\bullet$ | 2 |
|  |  |  | A |  |  |  |  | 3 |
|  | '1000 |  | A | - |  |  |  |  |
| Quad 2-Input Positive-NOR | '28 | $\bullet$ |  |  |  | $\bullet$ |  | 2 |
|  |  |  | A |  |  |  |  | 3 |
|  | '1002 |  | A |  |  |  |  |  |
|  | 1036 |  |  | A |  |  |  |  |
| Quad 2-Input Positive-AND | '1008 |  | A | - |  |  |  |  |
| Quad 2-Input Positive-OR | '1032 |  | A | $\bullet$ |  |  |  |  |
| Triple 3-Input Positive-NAND | '1010 |  | A |  |  |  |  |  |
| Triple 3-Input Positive-AND | '1011 |  | A |  |  |  |  |  |
| Triple 4-Input AND-NAND | '800 |  |  | 4 |  |  |  |  |
| Triple 4-Input OR-NOR | '802 |  |  | $\Delta$ |  |  |  |  |
| Dual 4-Input Positive-NAND | '40 | $\bullet$ |  |  | $\bullet$ | $\bullet$ | - | 2 |
|  |  |  | A |  |  |  |  | 3 |
|  | '1020 |  | A |  |  |  |  |  |
| Line Driver/Memory Driver with Series Damping Resistor | '436 |  |  |  |  |  | - | 2 |
| Line Driver/Memory Driver | '437 |  |  |  |  |  | $\bullet$ |  |

BI-/TRI-DIRECTIONAL BUS TRANSCEIVERS AND DRIVERS

| DESCRIPTION | TYPE OF OUTPUT | TYPE | TECHNOLOGY |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ALS | AS | LS | S |  |
| Quad with Bit Direction | 3-State | '446 |  |  | - |  | 2 |
| Controls | 3-State | '449 |  |  | - |  |  |
| Quad Tridirection | OC | '440 |  |  | $\bullet$ |  |  |
|  | OC | '441 |  |  | $\bullet$ |  |  |
|  | 3-State | '442 |  |  | $\bullet$ |  |  |
|  | 3-State | '443 |  |  | $\bullet$ |  |  |
|  | 3-State | '444 |  |  | - |  |  |
|  | OC | '448 |  |  | $\bullet$ |  |  |
| 4-Bit with Storage | 3-State | '226 |  |  |  | $\bullet$ |  |

OCTAL BUS TRANSCEIVERS/MOS DRIVERS

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | STD <br> TTL | ALS | AS | LS | S |  |
| Inverting Outputs, 3-State | $\checkmark 2620$ |  |  | - |  |  | 3 |
|  | '2640 |  |  | $\bullet$ |  |  |  |
| True Outputs, 3-State | '2623 |  |  | $\bullet$ |  |  |  |
|  | '2645 |  |  | - |  |  |  |

OCTAL BUFFERS AND LINE DRIVERS WITH INPUT/OUTPUT RESISTORS

| DESCRIPTION |  | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{array}{\|l\|} \hline \text { STD } \\ \text { TTL } \\ \hline \end{array}$ | ALS | AS | LS | S |  |
| Input Resistors | Inverting Outputs |  | ' 746 |  | - |  |  |  | 3 |
| Input Resistors | Noninverting Outputs | ' 747 |  | - |  |  |  |  |  |
| Output Resistors | Inverting Outputs | '2540 |  | $\bullet$ |  |  |  |  |  |
|  | Noninverting Outputs | '2541 |  | - |  |  |  |  |  |

OCTAL BI-/TRI-DIRECTIONAL BUS TRANSCEIVERS

| DESCRIPTION |  | TYPE OF OUTPUT | TYPE | TECHNOLOGY |  |  | volume |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | ALS |  | AS | LS |  |
| $12 \mathrm{~mA} / 24 \mathrm{~mA} / 48 \mathrm{~mA} / 64 \mathrm{~mA}$ Sink. True Outputs | Low <br> Power |  | 3 -State | '245 | A | - |  | 3 |
|  |  |  |  |  |  | - | 2 |
|  |  | OC | '621 | A | $\bullet$ |  | 3 |
|  |  |  |  |  |  | - | 2 |
|  |  | 3-State | '623 | A | $\bullet$ |  | 3 |
|  |  |  |  |  |  | $\bullet$ | 2 |
|  |  | OC, 3-State | '639 | A | - |  | 3 |
|  |  |  |  |  |  | - | 2 |
|  |  | 3-State | '652 | - | $\bullet$ |  | 3 \& LSI |
|  |  |  |  |  |  | $\bullet$ | 2 |
|  |  | OC, 3-State | '654 | 4 |  |  | 3 |
|  |  |  |  |  |  | - | 2 |
|  | Very Low <br> Power | OC | '1621 | $\wedge$ |  |  | 3 |
|  |  | 3-State | '1623 | 4 |  |  |  |
|  |  | OC, 3-State | '1639 | 4 |  |  |  |
| $12 \mathrm{~mA} / 24 \mathrm{~mA} / 48 \mathrm{~mA} / 64 \mathrm{~mA}$ Sink, Inverting Outputs | Low Power | 3.State | '620 | A | - |  | 3 |
|  |  |  |  |  |  | - | 2 |
|  |  | OC | '622 | A | - |  | 3 |
|  |  |  |  |  |  | - | 2 |
|  |  | OC, 3-State | '638 | A | - |  | 3 |
|  |  |  |  |  |  | - | 2 |
|  |  | 3-State | '651 | - | $\bullet$ |  | $3 \&$ LSI |
|  |  |  |  |  |  | - | 2 |
|  |  | OC. 3-State | 653 | 4 |  |  | 3 |
|  |  |  |  |  |  | - | 2 |
|  | Very Low Power | 3. State | '1620 | 4 |  |  | 3 |
|  |  | OC | '1622 | $\Delta$ |  |  |  |
|  |  | OC, 3-State | '1638 | 4 |  |  |  |
| $12 \mathrm{~mA} / 24 \mathrm{~mA} / 48 \mathrm{~mA} / 64 \mathrm{~mA}$ Sink, True Outputs | Low Power | OC | '641 | A | $\bullet$ |  |  |
|  |  |  |  |  |  | $\bullet$ | 2 |
|  |  | 3-State | '645 | A | - |  | 3 |
|  |  |  |  |  |  | - | 2 |
|  | Very Low Power | OC | $\cdot 1641$ | A |  |  | 3 |
|  |  | 3-State | '1645 | A |  |  |  |
| $12 \mathrm{~mA} / 24 \mathrm{~mA} / 48 \mathrm{~mA} / 64 \mathrm{~mA}$ Sink, Inverting Outputs | Low <br> Power | 3-State | '640 | A | - |  |  |
|  |  |  |  |  |  | - | 2 |
|  |  | OC | '642 | A | - |  | 3 |
|  |  |  |  |  |  | $\bullet$ | 2 |
|  | Very Low Power | 3-State | '1640 | A |  |  | 3 |
|  |  | OC | '1642 | 4 |  |  |  |
| $12 \mathrm{~mA} / 24 \mathrm{~mA} / 48 \mathrm{~mA} / 64 \mathrm{~mA}$ <br> Sink. True and Inverting Outputs | Low <br> Power | 3-State | '643 | A | - |  |  |
|  |  |  |  |  |  | - | 2 |
|  |  | OC | '644 | A | - |  | 3 |
|  |  |  |  |  |  | $\bullet$ | 2 |
|  | Very Low <br> Power | 3-State | '1643 | 4 |  |  | 3 |
|  |  | OC | '1644 | $\triangle$ |  |  |  |
| Registered with Multiplex $12 \mathrm{~mA} / 24 \mathrm{~mA} / 48 \mathrm{~mA} / 64 \mathrm{~mA}$ <br> True Outputs |  | 3-State | '646 | - | - |  | 38 LSt |
|  |  |  |  |  | - | 2 |  |
|  |  | OC | 647 | - |  |  | 3 |
|  |  |  |  |  | $\bullet$ | 2 |  |
| Registered with Multiplexed $12 \mathrm{~mA} / 24 \mathrm{~mA} / 48 \mathrm{~mA} / 64 \mathrm{~mA}$ Inverting Outputs |  |  | 3-State | '648 | - | - |  | 3 \& LSI |
|  |  |  |  |  |  | - | 2 |
|  |  | OC | '649 | - |  |  | 3 \& LSI |
|  |  |  |  |  |  | - | 2 |
| Universal Transceiver/ <br> Port Controllers |  | 3-State | 877 | . | - |  | 3 \& LSI |
|  |  | 852 |  | $\bullet$ |  |  |
|  |  | '856 |  | $\bullet$ |  |  |

- Denotes available technology.
© Denotes planned new products.
A Denotes " $A$ " suffix version available in the technology indicated.
$B$ Denotes " $B$ " suffix version available in the technology indicated.


## FLIP-FLOPS



| DESCRIPTION | $\begin{gathered} \text { No. OF } \\ \text { FFs } \end{gathered}$ | OUTPUTS | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\begin{aligned} & \hline \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | LS | S |  |
| D Type | 6 | 0 | '174 | $\bullet$ |  |  | $\bullet$ | $\bullet$ | 2 |
|  |  |  |  |  | $\bullet$ | $\bullet$ |  |  | 3 |
|  |  |  | '378 |  |  |  | $\bullet$ |  | 2 |
|  | 4 | Q, $\overline{\mathrm{Q}}$ | -171 |  |  |  | $\bullet$ |  |  |
|  |  |  | '175 | $\bullet$ |  |  | $\bullet$ | $\bullet$ |  |
|  |  |  |  |  | - | $\bullet$ |  |  | 3 |
|  |  |  | 379 |  |  |  | $\bullet$ |  | 2 |
| J.K | 4 | 0 | $\cdot 276$ | $\bullet$ |  |  |  |  |  |
|  |  |  | '376 | - |  |  |  |  |  |

- Denotes available technology.

A Denotes planned new products
$A$ Denotes " $A$ " suffix version available in the technology indicated.
$B$ Denotes " $B$ " suffix version available in the technology indicated.

## FUNCTIONAL INDEX

## LATCHES AND MULTIVIBRATORS

quad latches

| DESCRIPTION | OUTPUT | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{array}{\|l} \hline \text { STD } \\ \text { TTL } \\ \hline \end{array}$ | ALS | AS | L | LS |  |
| Dual 2-Bit <br> Transparent | 2-State | '75 | $\bullet$ |  |  | $\bullet$ | $\bullet$ | 2 |
|  | 2-State | 77 | $\bullet$ |  |  | $\bullet$ | $\bullet$ |  |
|  | 2-State | '375 |  |  |  |  | $\bullet$ |  |
| S-R | 2-State | '279 | $\bullet$ |  |  |  | A |  |



D-TYPE
OCTAL, 9-BIT, AND 10-bIT READ-BACK LATCHES

| DESCRIPTION | NO. OF BITS | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{aligned} & \hline \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | LS | S |  |
| Edge-Triggered Inverting and Noninverting, | Octal | '996 |  | 4 |  |  |  | 3 \& LSI |
| Transparent$\square$ TH0 | Octal | '990 |  | $\bullet$ |  |  |  |  |
|  | 9 -Bit | '992 |  | $\bullet$ |  |  |  |  |
|  | 10-Bit | '994 |  | - |  |  |  |  |
| Transparent Noninverting | Octal | '991 |  | $\bullet$ |  |  |  |  |
|  | 9 -Bit | '992 |  | $\bullet$ |  |  |  |  |
|  | 10-Bit | '994 |  | $\bullet$ |  |  |  |  |
| Transparent with Clear True Outputs | Octal | '666 |  | - |  |  |  |  |
| Transparent with Clear Inverting Outputs | Octal | '667 |  | - |  |  |  |  |

OCTAL, 9-BIT, AND 10-BIT LATCHES

| DESCRIPTION | $\left\|\begin{array}{c} \text { No. OF } \\ \text { BITS } \end{array}\right\|$ | OUTPUT | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\begin{array}{\|c\|} \hline \text { STD } \\ \text { TTL } \end{array}$ | ALS | AS | LS | S |  |
| Transparent | Octal | 3-State | '268 |  | : |  |  | - | 2 |
|  |  |  | '373 |  |  |  | - | - |  |
|  |  |  |  |  | $\bullet$ | $\bullet$ |  |  | 3 |
|  |  | 3-State | '573 |  | $\bullet$ | $\bullet$ |  |  |  |
| Dual 4-Bit <br> Transparent | Octal | 2-State | '100 | $\bullet$ |  |  |  |  | 2 |
|  |  | 2-State | '116 | $\bullet$ |  |  |  |  |  |
|  |  | 3-State | '873 |  | B | $\bullet$ |  |  | 3 |
| Inverting Transparent | Octal | 3-State | '533 |  | $\bullet$ | $\bullet$ |  |  |  |
|  |  | 3-State | '563 |  | A |  |  |  |  |
|  |  | 3-State | '580 |  | A | $\bullet$ |  |  |  |
| Dual 4-Bit <br> Inverting Transparent | Octal | 3-State | '880 |  | A | - |  |  |  |
| 2-Input Multiplexed | Octal | 3-State | '604 |  |  |  | $\bullet$ |  | 2 |
|  |  | OC | '605 |  |  |  | - |  |  |
|  |  | 3-State | '606 |  |  |  | $\bullet$ |  |  |
|  |  | OC | '607 | $\cdots$ |  |  | $\bullet$ |  |  |
| Addressable | Octal | 2-State | '259 | $\bullet$ |  |  | $\bullet$ |  |  |
|  |  |  |  |  | - |  |  |  | 3 |
| Multi-Mode Buffered | Octal | 3-State | '412 |  |  |  |  | $\bullet$ | 2 |
| True | Octal | 3-State | '845 |  | $\bullet$ | $\bullet$ |  |  | 3 \& LSI |
| Inverting | Octal | 3-State | '846 |  | A | $\bullet$ |  |  |  |
| True | 9-Bit | 3-State | '843 |  | $\bullet$ | $\bullet$ |  |  |  |
| Inverting | 9-Bit | 3-State | '844 |  | $\bullet$ | $\bullet$ |  |  |  |
| True | 10-Bit | 3-State | '841 |  | $\bullet$ | - |  |  |  |
| Inverting | 10-Bit | 3-State | '842 |  | $\bullet$ | $\bullet$ |  |  |  |

MONOSTABLE MULTIVIBRATORS WITH SCHMITT-TRIGGER INPUTS

|  | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DESCRIPTION |  | $\begin{aligned} & \mathrm{STD} \\ & \mathrm{TTL} \end{aligned}$ | ALS | AS | LS | S | L |  |
| Single | '121 | - |  |  |  |  | $\bullet$ | 2 |
| Dual. | 221 | $\bullet$ |  |  | $\bullet$ |  |  | 2 |

- Denotes available technology.
- Denotes planned new products.

A Denotes " $A$ " suffix version available in the technology indicated.
$B$ Denotes " $B$ " suffix version available in the technology indicated.

## REGISTERS

|  |  |  |  |  | SHI | REG | Sters |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DESCRIPTION | NO. <br> OF <br> BITS | MODES |  |  |  | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
|  |  | $\stackrel{\underset{\alpha}{x}}{\dot{\omega}}$ | $\vec{\omega}$ | $\begin{aligned} & 0 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { 号 } \\ & \text { 오 } \end{aligned}$ |  | $\begin{aligned} & \hline \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | L | LS | S |  |
| Sign-Protected |  | $x$ |  | x | $\times$ | '322 |  |  |  |  | A |  |  |
| Parailel-In, <br> Parallel-Out, <br> Bidirectional | 8 | x | $\times$ | x | x | '198 | - |  |  |  |  |  | 2 |
|  |  | x | x | x | x | '299 |  |  |  |  | - | $\bullet$ |  |
|  |  |  |  |  |  |  |  | - | 4 |  |  |  | 3 |
|  |  | x | $x$ | $x$ | x | '323 |  |  |  |  | - |  | 2 |
|  |  |  |  |  |  |  |  | - | 4 |  |  |  | 3 |
|  | 4 | x | $x$ | $x$ | $\times$ | '194 | - |  |  |  | A | $\bullet$ | 2 |
|  |  |  |  |  |  |  |  |  | $\Delta$ |  |  |  | 3 |
| Parallel-In, <br> Parallel-Out, <br> Registered <br> Outputs | 4 | $x$ | x | x | X | '671 |  |  |  |  | - |  | 2 |
|  |  | x | $x$ | x | x | '672 |  |  |  |  | - |  |  |
| Parallel-In, <br> Parallel-Out | 8 | $x$ |  | x | x | '199 | - |  |  |  |  |  |  |
|  | 5 | $\times$ |  | x |  | '96 | $\bullet$ |  |  | - | - |  |  |
|  | 4 | $\times$ | $\times$ |  | $x$ | '95 | A |  |  | - | B |  | 2 |
|  |  |  |  |  |  |  |  | $\bullet$ |  |  |  | 3 |  |
|  |  | x |  | $x$ |  |  | '99 |  |  |  | $\bullet$ |  |  | 2 |
|  |  | x |  | x | x | '178 | $\bullet$ |  |  |  |  |  |  |  |
|  |  | x |  | x | x | . 179 | - |  |  |  |  |  |  |  |
|  |  | x |  | $x$ |  | '195 | - |  |  |  | A | $\bullet$ | 2 |  |
|  |  |  |  |  |  |  |  |  | A |  |  |  | 3 |  |
|  |  | $\times$ |  | $\times$ |  | '295 |  |  |  |  | B |  | 2 |  |
|  |  | x |  | x |  | '395 |  |  |  |  | A |  | 2 |  |
|  |  |  |  | $x$ |  |  |  |  | 4 |  |  |  | 3 |  |
| Serial-In <br> Parallei-Out | 16 | x |  | x | X | '673 |  |  |  |  | - |  | 2 |  |
|  | 8 | x |  |  |  | '164 | - |  |  | $\bullet$ | $\bullet$ |  |  |  |
|  |  |  |  |  |  |  |  | 4 |  |  |  |  | 3 |  |
| Parallel-In, <br> Serial-Out | 16 | $x$ |  | $\times$ | x | 674 |  |  |  |  | $\bullet$ |  | 2 |  |
|  | 8 | $\times$ | $x$ |  | x | '165 | - |  |  |  | A |  |  |  |
|  |  |  |  |  |  |  | 4 |  |  |  |  | 3 |  |  |
|  |  | x |  | x $\times$ |  |  | '166 | - |  |  |  | A |  | 2 |
|  |  |  |  |  | $x$ |  |  | 4 |  |  |  |  | 3 |  |
| Serial-in, <br> Seriai-Out | 8 | x |  |  |  | '91 | A |  |  | $\bullet$ | - |  | 2 |  |
|  | 4 | $\times$ |  | $\times$ |  | '94 | - |  |  |  |  | . |  |  |

SHIFT REGISTERS WITH LATCHES

| DESCRIPTION | NO. OF BITS | OUTPUTS | TYPE | TECHNOLOGY |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | ALS | AS | LS |  |
| Parallel-In, Paraliel-Out with Output Latches | 4 | 3-State | '671 |  |  | $\bullet$ | 2 |
|  |  | 3-State | '672 |  |  | - |  |
| Serial-In, Parallel-Out with Output Latches | 16 | 2-State | '673 |  |  | $\bullet$ |  |
|  |  | Buffered | 594 |  |  | $\bullet$ |  |
|  | 8 | 3-State | '595 |  |  | $\bullet$ |  |
|  | 8 | OC | '596 |  |  | $\bullet$ |  |
|  |  | OC | '599 |  |  | $\bullet$ |  |
| Parallel-In, Serial-Out, with Input Latches | 8 | 2-State | '597 |  |  | $\bullet$ |  |
|  |  | 3-State | '589 |  |  | $\bullet$ |  |
| Parallel I/O Ports with Input Latches, Multiplexed Serial inputs | 8 | 3-State | '598 |  |  | - |  |


| DESCRIPTION | $\begin{gathered} \text { NO. } \\ \text { OF } \\ \text { BITS } \end{gathered}$ | MODES |  |  |  | TYPE | TECHNOLOGY |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\left\|\begin{array}{l} \dot{\alpha} \\ \dot{\omega} \end{array}\right\|$ | بَ | ¢ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ |  | ALS | AS | LS |  |
| Sign-Protected Register | 8 | x |  | $\times$ | X | '322 |  |  | A | 2 |

[^4]$\triangle$ Denotes planned new products
A Denotes " $A$ " suffix version available in the technology indicated.
$B$ Denotes " $B$ " suffix version available in the technology indicated.

## FUNCTIONAL INDEX

## COUNTERS

| DESCRIPTION | PARALLEL LOAD | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{aligned} & \hline \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | L | LS | S |  |
| Decade | Sync | '160 | $\bullet$ |  |  |  | A |  | 2 |
|  |  |  |  | B | $\bullet$ |  |  |  | 3 |
|  | Sync | '162 | $\bullet$ |  |  |  | A | $\bullet$ | 2 |
|  |  |  |  | B | - |  |  |  | 3 |
|  | Sync | '560 |  | A |  |  |  |  |  |
|  | Sync | '668 |  |  |  |  | $\bullet$ |  | 2 |
|  | Sync | $\checkmark 690$ |  |  |  |  | $\bullet$ |  |  |
|  | Sync | '692 |  |  |  |  | $\bullet$ |  |  |
| Decade Up/Down | Sync | '168 |  |  |  |  | B | $\bullet$ |  |
|  |  |  |  | B | $\bullet$ |  |  |  | 3 |
|  | Async | '190 | - |  |  |  | $\bullet$ |  | 2 |
|  |  |  |  | $\bullet$ |  |  |  |  | 3 |
|  | Async | '192 | $\bullet$ |  |  | $\bullet$ | $\bullet$ |  | 2 |
|  |  |  |  | - |  |  |  |  | 3 |
|  | Sync | '568 |  | A |  |  |  |  |  |
|  | Sync | '696 |  |  |  |  | $\bullet$ |  | 2 |
|  | Sync | '698 |  |  |  |  | $\bullet$ |  |  |
| Decade Rate $\frac{1}{\mathrm{~N} 10}$ <br> Multipler,  | Async <br> Set-to-9 | '167 | - |  |  |  |  |  |  |
| 4-Bit Binary | Sync | '161 | $\bullet$ |  |  |  | A |  |  |
|  |  |  |  | B | $\bullet$ |  |  |  | 3 |
|  | Sync | '163 | - |  |  |  | A | $\bullet$ | 2 |
|  |  |  |  | B | - |  |  |  | 3 |
|  | Sync | '561 |  | A |  |  |  |  |  |
|  | Sync | '669 |  |  |  |  | $\bullet$ |  | 2 |
|  | Sync | '691 |  |  |  |  | $\bullet$ |  |  |
|  | Sync | '693 |  |  |  |  | $\bullet$ |  |  |
| 4-Bit Binary Up/Down | Sync | '169 |  |  |  |  | B | $\bullet$ |  |
|  |  |  |  | B | $\bullet$ |  |  |  | 3 |
|  | Async | '191 | $\bullet$ |  |  |  | $\bullet$ |  | 2 |
|  |  |  |  | - |  |  |  |  | 3 |
|  | Async | '193 | $\bullet$ |  |  | $\bullet$ | $\bullet$ |  | 2 |
|  |  |  |  | $\bullet$ |  |  |  |  | 3 |
|  | Sync | '569 |  | A |  |  |  |  |  |
|  | Sync | '697 |  |  |  |  | $\bullet$ |  | 2 |
|  | Sync | '699 |  |  |  |  | $\bullet$ |  |  |
| 6 -Bit Binary  <br> Rate Multipler, $\frac{1}{\mathrm{~N} 2}$ |  | '97 | - |  |  |  |  |  |  |
| 8-Bit Up/Down | Async CLR | '867 |  |  | $\bullet$ |  |  |  | 3 \& LSI |
|  | Sync CLR | '869 |  |  | $\bullet$ |  |  |  |  |

ASYNCHRONOUS COUNTERS (RIPPLE CLOCK) - NEGATIVE-EDGE TRIGGERED

| DESCRIPTION | PARALLEL LOAD | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \\ & \hline \end{aligned}$ | ALS | AS | L | LS | S |  |
| Decade | Set-to-9 | '90 | A | . |  | - | - |  | 2 |
|  |  | '68 |  |  |  |  | $\bullet$ |  |  |
|  | Yes | '176 | - |  |  |  |  |  |  |
|  | Yes | '196 | $\bullet$ |  |  |  | $\bullet$ | $\bullet$ |  |
|  | Set-to-9 | '290 | - |  |  |  | $\bullet$ |  |  |
| 4-Bit Binary | None | '93 | A |  |  | $\bullet$ | $\bullet$ |  |  |
|  |  | '69 |  |  |  |  | $\bullet$ |  |  |
|  | Yes | '177 | $\bullet$ |  |  |  |  |  |  |
|  | Yes | '197 | $\bullet$ |  |  |  | $\bullet$ | $\bullet$ |  |
|  | None | '293 | $\bullet$ |  |  |  | - |  |  |
| Divide-by-12 | None | '92 | A |  |  |  | $\bullet$ |  |  |
| Dual Decade | None | '390 | $\bullet$ |  |  |  | $\bullet$ |  |  |
|  | Set-to-9 | 490 | $\bullet$ |  |  |  | $\bullet$ |  |  |
| Dual 4-Bit Binary | None | '393 | - |  |  |  | $\bullet$ |  |  |

8-BIT BINARY COUNTERS WITH REGISTERS

| DESCRIPTION | TYPE OF OUTPUT | TYPE | TECHNOLOGY |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ALS | AS | LS |  |
| Parallel Register | 3-State | '590 |  |  | - | 2 |
| Outputs | OC | '591 |  |  | $\bullet$ |  |
| Parallel Register Inputs | 2-State | '592 |  |  | $\bullet$ |  |
| Parallel I/O | 3-State | '593 |  |  | $\bullet$ |  |

FREQUENCY DIVIDERS, RATE MULTIPLIERS

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \\ & \hline \end{aligned}$ | ALS | AS | LS |  |
| 50-to-1 Frequency Divider | 56 |  |  |  | $\bullet$ | 2 |
| 60-to-1 Frequency Divider | '57 |  |  |  | $\bullet$ |  |
| 60-Bit Binary Rate Multiplier | '97 | $\bullet$ |  |  |  |  |
| Decade Rate Multiplier | '167 | - |  |  |  |  |

[^5]
## DECODERS, ENCODERS, DATA SELECTORS/MULTIPLEXERS AND SHIFTERS

DATA SELECTORS/MULTIPLEXERS

| DESCRIPTION | TYPE OF OUTPUT | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{aligned} & \hline \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | 1 | LS | S |  |
| 16-to-1 | 2-State | -150 | $\bullet$ |  |  |  |  |  | 2 |
|  | 3-State | '250 |  |  | - |  |  |  | 3 \& LSI |
|  | 3. State | '850 |  |  | $\bullet$ |  |  |  |  |
|  | 3-State | '851 |  |  | $\bullet$ |  |  |  |  |
| Dual 8-to- 1 | 3-State | '351 | $\bullet$ |  |  |  |  |  | 2 |
| 8-to-1 | 2-State | '151 | A |  |  |  | $\bullet$ | $\bullet$ |  |
|  |  |  |  | $\bullet$ | $\bullet$ |  |  |  | 3 |
|  | 2-State | '152 | A |  |  |  | $\bullet$ |  | 2 |
|  | 3-State | '251 | - |  |  |  | $\bullet$ | $\bullet$ |  |
|  |  |  |  | - | $\Delta$ |  |  |  | 3 |
|  | 3-State | '354 |  |  |  |  | $\bullet$ |  | 2 |
|  | 2-State | '355 |  |  |  |  | $\bullet$ |  |  |
|  | 3-State | '356 |  |  |  |  | $\bullet$ |  |  |
|  | OC | '357 |  |  |  |  | $\bullet$ |  |  |
| Dual 4-to-1 | 2-State | - 153 | $\bullet$ |  |  | $\bullet$ | $\bullet$ | $\bullet$ |  |
|  |  |  |  | - | $\bullet$ |  |  |  | 3 |
|  | 3-State | '253 |  |  |  |  | $\bullet$ | $\bullet$ | 2 |
|  |  |  |  | $\bullet$ | - |  |  |  | 3 |
|  | 2-State | '352 |  |  |  |  | $\bullet$ |  | 2 |
|  |  |  |  | - | $\bullet$ |  |  |  | 3 |
|  | 3-State | '353 |  |  |  |  | $\bullet$ |  | 2 |
|  |  |  |  | $\bullet$ | $\bullet$ |  |  |  | 3 |
| Octal 2-to-1 with Storage | 3-State | '604 |  |  |  |  | $\bullet$ |  | 2 |
|  | OC | '605 |  |  |  |  | $\bullet$ |  |  |
|  | 3-State | . 606 |  |  |  |  | $\bullet$ |  |  |
|  | OC | '607 |  |  |  |  | $\bullet$ |  |  |
| Quad 2-to-1 with Storage | 2-State | '98 |  |  |  | $\bullet$ |  |  |  |
|  | 2-State | '298 | $\bullet$ |  |  |  | $\bullet$ |  | 2 |
|  |  |  |  |  | - |  |  |  | 3 |
|  | 2-State | '398 |  |  |  |  | $\bullet$ |  | 2 |
|  | 2-State | '399 |  |  |  |  | $\bullet$ |  |  |
| Quad 2-to-1 | 2-State | '157 | $\bullet$ |  |  | $\bullet$ | $\bullet$ | $\bullet$ |  |
|  |  |  |  | - | $\bullet$ |  |  |  | 3 |
|  | 2-State | '158 |  |  |  |  | $\bullet$ | $\bullet$ | 2 |
|  |  |  |  | $\bullet$ | $\bullet$ |  |  |  | 3 |
|  | 3-State | '257 |  |  |  |  | B | $\bullet$ | 2 |
|  |  |  |  | A | $\bullet$ |  |  |  | 3 |
|  | 3-State | '258 |  |  |  |  | B | $\bullet$ | 2 |
|  |  |  |  | A | - |  |  |  | 3 |
| 6-to-1 Universal Multiplexer | 3-State | '857 |  | - | - |  |  |  | 3 |

DECODERS/DEMULTIPLEXERS

| DESCRIPTION | TYPE OF OUTPUT | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | L | LS | S |  |
| 4-to-16 | 3-State | '154 | $\bullet$ |  |  | - |  |  | 2 |
|  | OC | '159 | - |  |  |  |  |  |  |
| 4-to-10 BCD to-Decimal | 2-State | '42 | A |  |  | - | $\bullet$ |  |  |
| 4-to-10 Excess 3-to- <br> Decimal | 2-State | '43 | A |  |  | - |  |  |  |
| $\begin{aligned} & \text { 4-to-10 Excess 3-Gray } \\ & \text { to-Decimal } \end{aligned}$ | 2-State | '44 | A |  |  | - |  |  |  |
| 3.to-8 with Address Latches | 2-State | '131 |  | $\bullet$ | A |  |  |  | 3 |
|  |  | '137 |  | $\bullet$ | $\Delta$ |  |  |  |  |
|  |  |  |  |  |  |  | - |  | 2 |
| 3-to-8 | 2-State | '138 |  | $\bullet$ | A |  |  |  | 3 |
|  |  |  |  |  |  |  | $\bullet$ | $\bullet$ | 2 |
|  | 3-State | '538 |  | $\Delta$ |  |  |  |  | 3 |
| Dual 2-to-4 | 2-State | '139 |  | 4 | $\bullet$ |  |  |  |  |
|  |  |  |  |  |  |  | A | $\bullet$ | 2 |
|  | 2-State | '155 | $\bullet$ |  |  |  | A |  |  |
|  | OC | '156 | $\bullet$ |  |  |  | $\bullet$ |  |  |
| Dual 1-to-4 Decoders | 3-State | '539 |  | 4 |  |  |  |  | 3 |

CODE CONVERTERS

| DESCRIPTION | TYPCHNOLOGY | VOLUME |  |  |
| :--- | :---: | :---: | :---: | :---: |
|  |  |  | S | VOME |
| 6-Line-BCD to 6-Line Binary, or 4-Line to 4-Line <br> BCD 9's/BCD 10's Converters | 184 |  |  | 2 |
| 6-Bit-Binary to 6-Bit BCD Converters | 185 | A |  |  |
| BCD-to-Binary Converters | 484 |  | A | 4 |
| Binary-to-BCD Converters | 485 |  | A |  |

PRIORITY ENCODERS/REGISTERS

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{array}{\|l} \hline \text { STD } \\ \text { TTL } \\ \hline \end{array}$ | ALS | AS | LS |  |
| Full BCD | '147 | - |  |  | $\bullet$ | 2 |
| Cascadable Octal | '148 | $\bullet$ |  |  | $\bullet$ |  |
| Cascadable Octal with 3-State Outputs | '348 |  |  |  | $\bullet$ |  |
| 4-Bit Cascadable with Registers | '278 | $\bullet$ |  |  |  |  |

SHIFTERS

| DESCRIPTION | OUTPUT | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | L | LS | S |  |
| 4-Bit Shifter | 3-State | '350 |  |  |  |  |  | - | 2 |
| Parallel 16-Bit <br> Multi-Mode <br> Barrel Shifter | 3-State | '897 |  |  | $\bullet$ |  |  |  | LSI |
| 32-Bit Barrel Shifter | 3-State | '8838 |  |  | 4 |  |  |  |  |

[^6]A Denotes planned new products.
A Denotes " $A$ " suffix version available in the technology indicated.
$B$ Denotes " $B$ " suffix version available in the technology indicated.

## DISPLAY DECODERS/DRIVERS, MEMORY/MICROPROCESSOR CONTROLLERS, AND VOLTAGE-CONTROLLED OSCILLATORS



MEMORY/MICROPROCESSOR CONTROLLERS

| DESCRIPTION |  |  | TYPE | TECHNOLOGY |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ALS | AS | LS | S |  |
| System Controllers (Universal or for '888) |  |  |  | '890 |  | - |  |  | LSI |
| Memory <br> Refresh <br> Controllers | Transparent, | 4K, 16K | 600 |  |  | A |  | 2 |
|  | Burst Modes | 64 K | 601 |  |  | A |  |  |
|  | Cycle Steal, | 4K, 16K | '602 |  |  | A |  |  |
|  | Burst Modes | 64K | 603 |  |  | A |  |  |
| Memory Cycle Controller |  |  | '608 |  |  | - |  |  |
| Memory Mappers |  | 3-State | 612 |  |  | $\bullet$ |  | LSI |
|  |  | OC | 613 |  |  | $\bullet$ |  |  |
| Memory Mappers with Output Latches |  | 3-State | 610 |  |  | - |  |  |
|  |  | OC | 611 |  |  | $\bullet$ |  |  |
| Multi-Mode Latches (8080A Applications) |  |  | 412 |  |  |  | $\bullet$ | 2 |
| Dynamic Memory Controllers |  | $\begin{aligned} & 16 \mathrm{~K}, 64 \mathrm{~K}, \\ & 256 \mathrm{~K} \end{aligned}$ | 2967 | 4 |  |  |  | LSI |
|  |  | '2968 | A |  |  |  |  |
|  |  | $\begin{aligned} & \hline 16 \mathrm{~K}, 64 \mathrm{~K} \\ & 256 \mathrm{~K}, 1 \text { MEG } \end{aligned}$ | '6301 | $\Delta$ |  |  |  |  |
|  |  | '6302 | 4 |  |  |  |  |

Clock generator circuits

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{array}{\|c} \hline \text { STD } \\ \text { TTL } \\ \hline \end{array}$ | ALS | AS | LS | S |  |
| Quadruple Complementary-Output Logic Elements | '265 | - |  |  |  |  | 2 |
| Dual Pulse Synchronizers/Drivers | '120 | - |  |  |  |  |  |
| Crystal-Controlled Oscillators | '320 |  |  |  | $\bullet$ |  |  |
|  | 321 |  |  |  | $\bullet$ |  |  |
| Digital Phase-Lock Loop | '297 |  |  |  | $\bullet$ |  |  |
| Programmable Frequency | '292 |  |  |  | $\bullet$ |  |  |
| Dividers/Digital Timers | 294 |  |  |  | $\bullet$ |  |  |
| Triple 4-input AND/NAND Drivers | 800 |  |  | 4 |  |  | 3 |
| Triple 4-Input OR/NOR Drivers | '802 |  |  | $\Delta$ |  |  |  |
| Dual VCO | '124 |  |  |  |  | $\bullet$ | 2 |

RESULTANT DISPLAYS USING '46A, '47A, ‘48, '49, 'L46, 'L47, 'LS47, 'LS48, 'LS49, 'LS347


RESULTANT DISPLAYS USING '246, '247, '248, '249, 'LS247, 'LS248, 'LS249, 'LS447


RESULTANT DISPLAYS USING '143, '144


- Denotes available technology.

A Denotes planned new products.
A Denotes " $A$ " suffix version available in the technology indicated.

## COMPARATORS AND ERROR DETECTION CIRCUITS

4-BIT COMPARATORS

| DESCRIPTION |  |  |  |  | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| P-O | $\mathrm{P}>0$ | $\mathrm{P}<0$ | OUTPUT | OUTPUT <br> ENABLE |  | $\begin{aligned} & \hline \text { STD } \\ & T T L . \end{aligned}$ | ALS | AS | L | LS | S |  |
| Yes | Yes | No | 2.State | No | '85 | $\bullet$ |  |  | $\bullet$ | $\bullet$ | - | 2 |

8-BIT COMPARATORS

| DESCRIPTION |  |  |  |  |  |  |  | TYPE | TECHNOLOGY |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUTS | $\mathrm{P}=0$ | $\overline{\mathrm{P}=0}$ | $P>0$ | $\overline{P>0}$ | $\mathrm{P}<0$ | OUtPut | OUTPUT <br> ENABLE |  | ALS | AS | LS |  |
| $\begin{aligned} & 20 \cdot \mathrm{k} \Omega \\ & \text { Pull } \cdot U_{\mathrm{D}} \end{aligned}$ | Yes | No | No | No | No | OC | Yes | 518 | - |  |  | 3 |
|  | No | Yes | No | No | No | 2.S | Yes | 520 | $\bullet$ |  |  |  |
|  | No | Yes | No | No | No | OC | Yes | 522 | - |  |  |  |
|  | No | Yes | No | Yes | No | 2. 5 | No | '682 |  |  | $\bullet$ | 2 |
|  | No | Yes | No | Yes | No | OC | No | '683 |  |  | $\bullet$ |  |
| Standard | Yes | No | No | No | No | OC | Yes | '519 | - |  |  | 3 |
|  | No | Yes | No | No | No | 2.S | Yes | '521 | - |  |  |  |
|  | No | Yes | No | Yes | No | 2.5 | No | ${ }^{\prime} 684$ |  |  | $\bullet$ | 2 |
|  | No | Yes | No | Yes | No | OC | No | '685 |  |  | $\bullet$ |  |
|  | No | Yes | No | Yes | No | 2.S | Yes | '686 |  |  | $\bullet$ |  |
|  | No | Yes | No | Yes | No | OC | Yes | '687 |  |  | $\bullet$ |  |
|  | No |  | No |  | No | 2.5 | Yes | 688 | - |  |  | 3 |
|  |  |  | No | No | No | 2.5 | res | 68 |  |  | - | 2 |
|  |  |  |  |  |  |  |  |  | - |  |  | 3 |
|  | No | Yes | No | No | No | oc | Yes | 683 |  |  | - | 2 |
| Latched P Logic \& Arith | No | No | Yes | No | Yes | 2.S | Yes | '885 |  | $\bullet$ |  | $3 \& \mathrm{LSI}$ |
| $\begin{aligned} & \text { Latched P\&Q } \\ & \text { Logic \& Arith } \end{aligned}$ | Yes | No | Yes | No | Yes | Latched | Yes | '866 |  | $\bullet$ |  | 3 |

ADDRESS COMPARATORS

| DESCRIPTION | OUTPUT <br> ENABLE | LATCHED OUTPUT | TYPE | TECHNOLOGY |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | ALS | AS |  |
| 16-Bit to 4-Bit | Yes |  | $\cdot 677$ | $\bullet$ |  | 3 |
|  |  | Yes | '678 | $\bullet$ |  |  |
| 12-Bit to 4-Bit | Yes |  | '679 | $\bullet$ |  |  |
|  |  | Yes | '680 | - |  |  |

PARITY GENERATORS/CHECKERS,
ERROR DETECTION AND CORRECTION CIRCUITS

| DESCRIPTION |  | NO. OF BITS | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \hline \text { STD } \\ & \text { TTL } \end{aligned}$ |  | ALS | AS | LS | S |  |
| Odd/Even Parity Generators/Checkers |  |  | 8 | '180 | - |  |  |  |  | 2 |
|  |  | 9 | '280 |  |  |  | $\bullet$ | $\bullet$ |  |  |
|  |  |  |  | $\bullet$ | $\bullet$ |  |  | 3 \& LSI |  |  |
|  |  | 9 | '286 |  |  | $\bullet$ |  |  |  |  |
| Parallel Error <br> Detection/Correction <br> Circuits | 3-State |  | 8 | '636 |  |  |  | - |  | 2 |
|  | OC | 8 | '637 |  |  |  | $\bullet$ |  |  |  |
|  | 3-State | 16 | '616 |  | - |  |  |  | 3 \& LSI |  |
|  | OC | 16 | '617 |  | A |  |  |  |  |  |
|  | 3-State | 16 | '630 |  |  |  | $\bullet$ |  | 2 |  |
|  | OC | 16 | '631 |  |  |  | $\bullet$ |  |  |  |
|  | 3-State | 16 | '8400 |  | A |  |  |  | LSI |  |
|  | 3-State | 32 | '632 |  | A | $\Delta$ |  |  | 3 \& LSI |  |
|  | OC | 32 | '633 |  | $\bullet$ | $\triangle$ |  |  |  |  |
|  | 3-State | 32 | '634 |  | 4 | $\Delta$ |  |  |  |  |
|  | OC | 32 | 635 |  | $\Delta$ | $\Delta$ |  |  |  |  |

FUSE-PROGRAMMABLE COMPARATORS

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | LS | S |  |
| 16-Bit Identity Comparator | . 526 |  | $\bullet$ |  |  |  | 3 |
| 12-Bit identity Comparator | '528 |  | $\bullet$ |  |  |  |  |
| 8-Bit Identity Comparator and 4-Bit Comparator | '527 |  | - |  |  |  |  |

## - Denotes available technology.

ADenotes planned new products.
A Denotes " $A$ " suffix version available in the technology indicated.

## ARITHMETIC CIRCUITS AND PROCESSOR ELEMENTS

| DESCRIPTION |  | TYPE | TECHNOLOGY |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | H | LS | S |  |
| 1-Bit Gated |  |  | '80 | $\bullet$ |  |  |  |  |  | 2 |
| 2-Bit |  | '82 | $\bullet$ |  |  |  |  |  |  |  |
| 4-Bit |  | '83 | A |  |  |  | A |  |  |  |
|  |  | '283 | - |  |  |  | $\bullet$ | $\bullet$ |  |  |
| Dual 1-Bit Carry-Save |  | '183 |  |  |  | $\bullet$ | - |  |  |  |
| ACCUMULATORS, ARITHMETIC LOGIC UNITS, LOOK-AHEAD CARRY GENERATORS |  |  |  |  |  |  |  |  |  |  |
| DESCRIPTION |  |  | TECHNOLOGY |  |  |  |  |  | volume |  |
|  |  |  | TYPE | $\begin{array}{\|l\|} \hline \text { STD } \\ \text { TTL } \\ \hline \end{array}$ | ALS | AS | LS | S |  |  |
| 4-Bit Parallel Binary Accumulators |  |  | '281 |  |  |  |  | $\bullet$ | 2 |  |
|  |  |  | '681 |  |  |  | $\bullet$ |  |  |  |
| 4-Bit Arithmetic Logic Units/ Function Generators |  |  | '181 | - |  |  | - | $\bullet$ |  |  |
|  |  |  |  |  | A |  |  | 3 \& LSI |  |  |
|  |  |  | '1181 |  |  | $\bullet$ |  |  |  |  |
|  |  |  | '381 | - |  |  | A |  | 2 |  |
|  |  |  |  |  |  |  | - |  |  |  |
|  |  |  | '881 |  |  | A |  |  | 3 \& LSI |  |
| 4-Bit Arithmetic Logic Unit with Ripple Carry |  |  |  | '382 |  |  |  | - |  | 2 |
| Look-Ahead Carry Generators | 16-Bit |  | '182 | $\bullet$ |  |  |  | $\bullet$ | 2 |  |
|  |  |  |  |  | $\Delta$ |  |  | 3 |  |  |
|  |  |  | '282 |  |  | $\Delta$ |  |  |  |  |
|  | 32-Bit |  |  | '882 |  |  | A |  |  | $3 \& \mathrm{LSI}$ |
| Quad Serial Adder/Subtractor |  |  | '385 |  |  |  | - |  | 2 |  |

MULTIPLIERS

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | LS | S |  |
| 2-Bit-by-4-Bit Parallel Binary Multipliers | '261 |  |  |  | - |  | 2 |
| 4-Bit-by-4-Bit Parallel Binary Multipliers | '284 | - |  |  |  |  |  |
|  | '285 | - |  |  |  |  |  |
| 25-MHz 6-Bit Binary Rate Multipliers | '97 | $\bullet$ |  |  |  |  |  |
| $25-\mathrm{MHz}$ Decade Rate Multipliers | '167 | - |  |  |  |  |  |
| 8 -Bit $\times 1$-Bit 2 's Complement Multipliers | '384 |  |  |  | $\bullet$ |  |  |

OTHER ARITHMETIC OPERATORS

| DESCRIPTION | TYPE | TECHNOLOGY |  |  |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{gathered} \mathrm{STD} \\ \mathrm{TTL} \end{gathered}$ | ALS | AS | H | L | LS | S |  |
| Quad 2-Input Exclusive-OR | '86 | $\bullet$ |  |  |  | $\bullet$ | A | $\bullet$ | 2 |
| Gates with Totem-Pole |  |  | - |  |  |  |  |  | 3 |
| Outputs | '386 |  |  |  |  |  | A |  |  |
| Quad 2-Input Exclusive-OR Gates with Open-Collector | '136 | - |  |  |  |  |  | $\bullet$ | 2 |
| Outputs |  |  | $\bullet$ |  |  |  |  |  | 3 |
| Quad 2-Input Exclusive- | '266 |  |  |  |  |  | $\bullet$ |  | 2 |
| NOR Gates | '810 |  | - | 4 |  |  |  |  | 3 |
| Quad 2-Input Exclusive-NOR Gates with Open-Collector Outputs | '811 |  | - | $\wedge$ |  |  |  |  | 3 |
| Quad Exclusive OR/NOR Gates | '135 |  |  |  |  |  |  | - |  |
| 4-Bit True/Complement Element | '87 |  |  |  | - |  |  |  | 2 |

BIPOLAR BIT-SLICE PROCESSOR ELEMENTS

| DESCRIPTION | CASCADABLE <br> то N -BITS | TYPE | TECHNOLOGY |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ALS | AS | LS | S |  |
| 8-Bit Slice | No | '887 |  | - |  |  | LSI |
|  | Yes | '888 |  | $\bullet$ |  |  |  |
|  | Yes | '895 |  | 4 |  |  |  |

- Denotes available technology.

ADenotes planned new products.
$A$ Denotes " $A$ " suffix version available in the technology indicated.

## MEMORIES

USER-PROGRAMMABLE READ-ONLY MEMORIES (PROMs) STANDARD PROMs

| DESCRIPTION | TYPE | ORGANIZATION | TYPE OUTPUT | S | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 16K-Bit Arrays | TBP28S166 | $2048 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | - |  |
|  | TBP38S165 | $2048 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | - |  |
|  | TBP38S166 | $2048 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | - |  |
|  | TBP38SA 165 | 2048W $\times 8 \mathrm{~B}$ | OC | - |  |
|  | TBP38SA166 | 2048W $\times 8 \mathrm{~B}$ | OC | - |  |
|  | TBP34S162 | $4096 \mathrm{~W} \times 4 \mathrm{~B}$ | 3-State | - |  |
|  | TBP34SA162 | $4096 \mathrm{~W} \times 4 \mathrm{~B}$ | OC | 4 |  |
| 8K-Bit Arrays | TBP24S81 | 2048W $\times 4 \mathrm{~B}$ | 3-State | - |  |
|  | TBP24SA81 | 2048W $\times 4 \mathrm{~B}$ | OC | - |  |
|  | TBP28S85A | $1024 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | 4 |  |
|  | TBP28S86A | $1024 \mathrm{~W} \times 88$ | 3-State | - |  |
|  | TBP28SA86A | $1024 \mathrm{~W} \times 8 \mathrm{~B}$ | OC | - |  |
|  | TBP38S85 | $1024 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | 4 |  |
|  | TBP38S86 | $1024 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | 4 |  |
|  | TBP38SA85 | $1024 \mathrm{~W} \times 8 \mathrm{~B}$ | OC | 4 |  |
|  | TBP38SA86 | $1024 \mathrm{~W} \times 8 \mathrm{~B}$ | OC | A | 4 |
| 4K-Bit Arrays | TBP24S41 | $1024 \mathrm{~W} \times 4 \mathrm{~B}$ | 3-State | $\bullet$ |  |
|  | TBP24SA41 | $1024 \mathrm{~W} \times 4 \mathrm{~B}$ | OC | - |  |
|  | TBP28S42 | $512 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | - |  |
|  | TBP28SA42 | $512 \mathrm{~W} \times 8 \mathrm{~B}$ | OC | - |  |
|  | TBP28S46 | $512 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | - |  |
|  | TBP28SA46 | $512 \mathrm{~W} \times 8 \mathrm{~B}$ | OC | $\bullet$ |  |
| 2K-Bit Arrays | TBP38S22 | $256 \mathrm{~W} \times 8 \mathrm{~B}$ | 3.State | $\bullet$ |  |
|  | TBP38SA22 | $256 \mathrm{~W} \times 8 \mathrm{~B}$ | OC | $\bullet$ |  |
| 1K-Bit Arrays | TBP24S10 | $256 \mathrm{~W} \times 4 \mathrm{~B}$ | 3-State | $\bullet$ |  |
|  | TBP24SA10 | $256 \mathrm{~W} \times 4 \mathrm{~B}$ | OC | - |  |
|  | TBP34S10 | $256 \mathrm{~W} \times 4 \mathrm{~B}$ | 3-State | - |  |
|  | TBP34SA 10 | $256 \mathrm{~W} \times 4 \mathrm{~B}$ | OC | - |  |
| 256-Bit Arrays | TBP18S030 | $32 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | $\bullet$ |  |
|  | TBP18SA030 | $32 \mathrm{~W} \times 8 \mathrm{~B}$ | OC | - |  |
|  | TBP38S030 | $32 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | - |  |
|  | TBP38SA030 | $32 \mathrm{~W} \times 8 \mathrm{~B}$ | OC | - |  |

LOW-POWER PROMs

| DESCRIPTION | TYPE | ORGANIZATION | TYPE OUTPUT | S | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 16K-Bit Arrays | TBP28L166 | $2048 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | - | 4 |
|  | TBP38L165 | $2048 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | - |  |
|  | TBP38L166 | $2048 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | - |  |
|  | TBP34L162 | $4096 \mathrm{~W} \times 4 \mathrm{~B}$ | 3-State | 4 |  |
| 8K-Bit Arrays | TBP28L85A | $1024 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | $\triangle$ |  |
|  | TBP28L86A | $1024 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | $\bullet$ |  |
|  | TBP38L85 | $1024 \mathrm{~W} \times 88$ | 3-State | A |  |
|  | TBP38L86 | $1024 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | $\triangle$ |  |
| -Bit Arrays | TBP28L42 | $512 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | $\bullet$ |  |
| 4K-Bit Arrays | TBP28L46 | $512 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | $\bullet$ |  |
| 2K-Bit Arrays | TBP28L22 | $256 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | - |  |
|  | TBP28LA22 | $256 \mathrm{~W} \times 8 \mathrm{~B}$ | OC | - |  |
|  | TBP38L22 | $256 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | $\Delta$ |  |
| 1 K -Bit Arrays | TBP34L10 | $256 \mathrm{~W} \times 4 \mathrm{~B}$ | 3-State | $\bullet$ |  |
| 256-Bit Arrays | TBP38L030 | $32 \mathrm{~W} \times 8 \mathrm{~B}$ | 3-State | 4 |  |

REGISTERED PROMs

| DESCRIPTION | TYPE | ORGANIZATION | TYPE <br> OUTPUT | $\mathbf{S}$ | VOLUME |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  | TBP34R162 | $4096 \mathrm{~W} \times 4 \mathrm{~B}$ | 3 State | $\bullet$ |  |
|  | TBP34SR165 | $4096 \mathrm{~W} \times 4 \mathrm{~B}$ | 3 State | 4 | 4 |
|  | TBP38R165 | $2048 \mathrm{~W} \times 8 \mathrm{~B}$ | 3 State | $\bullet$ |  |

RANDOM-ACCESS READ-WRITE MEMORIES (RAMs)

| DESCRIPTION | ORGANIZATION | TYPE <br> OF <br> OUTPUT | TYPE | TECHNOLOGY |  |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\begin{aligned} & \hline \text { STD } \\ & \text { TTL } \end{aligned}$ | ALS | AS | LS | S |  |
| 256-Bit Arrays | $256 \times 1$ | 3-State | '201 |  |  |  |  | $\bullet$ | 4 |
|  |  | OC | '301 |  |  |  |  | $\bullet$ |  |
| 64-Bit Arrays | $16 \times 4$ | OC | ' 89 | - |  |  |  |  |  |
|  |  | 3-State | '189 |  |  |  | A | B |  |
|  |  | 3-State | '219 |  |  |  | A |  |  |
|  |  | OC | '289 |  |  |  | A | B |  |
|  |  | OC | '319 |  |  |  | A |  |  |
| 16-Bit Multiple-Port Register File | $8 \times 2$ | 3-State | '172 | - |  |  |  |  | 2 |
| 16-Bit Register File | $4 \times 4$ | OC | '170 | - |  |  | $\bullet$ |  |  |
|  |  | 3-State | 670 |  |  |  | $\bullet$ |  |  |
| Dual 64-Bit Register Files | $16 \times 4$ | 3-State | '870 |  |  | $\bullet$ |  |  | 3 |
|  |  |  | 871 |  |  | $\bullet$ |  |  |  |

FIRST-IN FIRST-OUT MEMORIES (FIFOS)

| DESCRIPTION |  | TYPE | TECHNOLOGY |  |  |  | VOLUME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ALS | AS | LS | S |  |
| $16 \times 4$ | 3-State | 222 |  |  | - |  | LSI |
|  | 3-State | 224 |  |  | $\bullet$ |  |  |
|  | 3-State | 227 |  |  | $\bullet$ |  |  |
|  | 3.State | 228 |  |  | $\bullet$ |  |  |
|  | 3-State | 232 | A |  |  |  | 3 \& LSI |
| $16 \times 5$ | 3-State | 225 |  |  | - | $\bullet$ | LSI |
|  | 3-State | 229 | A |  |  |  | 3 \& LSI |
|  | 3-State | 233 | A |  |  |  |  |

[^7]
## FUNCTIONAL INDEX



[^8]- Denotes available technology.
$\Delta$ Denotes planned new products.


# General Information 

Numerical Index
Glossary
Explanation of Function Tables
Parameter Measurement Information Functional Index

## LSI Devices

Application ReportsAdvanced Schottky Family Error Detection and Correction Memory Mapping
Bit-Slice Processor 8-Bit Family Excerpt - SN74AS888, SN74AS890
Bit-Slice Processor User's Guide

- Package Options Include the 'AS181A in Compact 300 -mil or Standard 600-mil DIPs. The 'AS881A is Offered in 300-mil DIPS. Both Devices are Available in Both Plastic and Ceramic Chip Carriers
- Full Look-Ahead for High-Speed Operations on Long Words
- Arithmetic Operating Modes:

Addition
Subtraction
Shift Operand A One Position
Magnitude Comparison
Plus Twelve Other Arithmetic Operations

- Logic Function Modes

Exclusive-OR
Comparator
AND, NAND, OR, NOR
'AS881A Provides Status Register Checks Plus Ten Other Logic Operations

- Dependable Texas Instruments Quality and Reliability
logic symbol


SN54AS181A . . JT OR JW PACKAGE
SN54AS881A . . . JT PACKAGE
SN74AS181A . . . NT OR NW PACKAGE SN74AS881A . . . NT PACKAGE (TOP VIEW)
$\overline{\mathrm{B}} 0 \square 1$
$\overline{\mathrm{~A} O} \square 2$

SN54AS181A, SN54AS881A . . . FK PACKAGE SN74AS181A, SN74AS881A . . FN PACKAGE (TOP VIEW)


NC - No internal connection

Pin numbers shown are JT, JW, NT, and NW packages.

TYPICAL ADDITION TIMES ( $C_{L}=15 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=280 \Omega, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )

| NUMBER OF BITS | ADDITION TIMES |  |  | PACKAGE COUNT |  | CARRY METHOD BETWEEN ALUs |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | USING 'AS881A AND'AS882 | $\begin{gathered} \hline \text { USING 'AS181A } \\ \text { AND 'AS882 } \\ \hline \end{gathered}$ | USING 'S181 AND 'S182 | ARITHMETIC LOGIC UNITS | LOOK-AHEAD CARRY GENERATORS |  |
| 1 to 4 | 5 ns | 5 ns | 11 ns | 1 |  | NONE |
| 5 to 8 | 10 ns | 10 ns | 18 ns | 2 |  | RIPPLE |
| 9 to 16 | 14 ns | 14 ns | 19 ns | 3 or 4 | 1 | FULL LOOK-AHEAD |
| 17 to 64 | 19 ns | 19 ns | 28 ns | 5 to 16 | 2 to 5 | FULL LOOK-AHEAD |

## description

The 'AS181A and 'AS881A are arithmetic logic units (ALU)/function generators that have a complexity of 75 and 77 equivalent gates, respectively, on a monolithic chip. These circuits perform 16 binary arithmetic operations on two 4-bit words as shown in Tables 1 and 2. These operations are selected by the four function-select lines (S0, S1, S2, S3) and include addition, subtraction, decrement, and straight transfer. When performing arithmetic manipulations, the internal carries must be enabled by applying a low-level voltage to the mode control input (M). A full carry look-ahead scheme is made available in these devices for fast, simultaneous carry generation by means of two cascade-outputs (pins 15 and 17) for the four bits in the package. When used in conjunction with the SN54AS882 or SN74AS882 full carry look-ahead circuits, high-speed arithmetic operations can be performed. The typical addition times shown previously illustrate the little additional time required for addition of longer words when full carry look-ahead is employed. The method of cascading 'AS882 circuits with these ALUs to provide multilevel full carry lookahead is illustrated under signal designations.

If high speed is not of importance, a ripple-carry input $\left(C_{n}\right)$ and a ripple-carry output ( $C_{n}+4$ ) are available. However, the ripple-carry delay has also been minimized so that arithmetic manipulations for small word lengths can be performed without external circuitry.
The 'AS181A and 'AS881A will accommodate active-high or active-low data if the pin designations are interpreted as follows:

| PIN NUMBER | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{2 3}$ | $\mathbf{2 2}$ | $\mathbf{2 1}$ | $\mathbf{2 0}$ | $\mathbf{1 9}$ | $\mathbf{1 8}$ | $\mathbf{9}$ | $\mathbf{1 0}$ | $\mathbf{1 1}$ | $\mathbf{1 3}$ | $\mathbf{7}$ | $\mathbf{1 6}$ | $\mathbf{1 5}$ | $\mathbf{1 7}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Active-low data (Table 1) | $\overline{\mathrm{A} O}$ | $\overline{\mathrm{~B}} 0$ | $\overline{\mathrm{~A}} 1$ | $\overline{\mathrm{~B}} 1$ | $\overline{\mathrm{~A}} 2$ | $\overline{\mathrm{~B}} 2$ | $\overline{\mathrm{~A}} 3$ | $\overline{\mathrm{~B}} 3$ | $\overline{\mathrm{~F}} 0$ | $\overline{\mathrm{~F}} 1$ | $\overline{\mathrm{~F}} 2$ | $\overline{\mathrm{~F}} 3$ | $\mathrm{C}_{\mathrm{n}}$ | $\mathrm{C}_{\mathrm{n}}+4$ | $\overline{\mathrm{P}}$ | $\overline{\mathrm{G}}$ |
| Active-high data (Table 2) | AO | BO | A 1 | B 1 | A 2 | B 2 | A 3 | B 3 | FO | F 1 | F 2 | F 3 | $\overline{\mathrm{C}}_{\mathrm{n}}$ | $\overline{\mathrm{C}}$ | $\mathrm{n}+4$ | X |

Subtraction is accomplished by 1 's complement addition where the 1 's complement of the subtrahend is generated internally. The resultant output is $A-B-1$, which requires an end-around or forced carry to provide A-B.

The 'AS181A and 'AS881A can also be utilized as a comparator. The $A=B$ output is internally decoded from the function outputs (F0, F1, F2, F3) so that when two words of equal magnitude are applied at the $A$ and $B$ inputs, it will assume a high level to indicate equality $(A=B)$. The $A L U$ must be in the subtract mode with $C_{n}=H$ when performing this comparison. The $A=B$ output is open-collector so that it can be wire-AND connected to give a comparison for more than four bits. The carry output ( $\mathrm{C}_{n}+4$ ) can also be used to supply relative magnitude information. Again, the ALU must be placed in the subtract mode by placing the function select input $S 3, S 2, S 1, S 0$ at $L, H, H, L$, respectively.

| INPUT $C_{n}$ | OUTPUT $C_{n+4}$ | ACTIVE-LOW DATA <br> (FIGURE 1) | ACTIVE-HIGH DATA <br> (FIGURE 2) |
| :---: | :---: | :---: | :---: |
| $H$ | $H$ | $\mathrm{~A} \geqslant \mathrm{~B}$ | $\mathrm{~A} \leqslant \mathrm{~B}$ |
| $H$ | L | $\mathrm{~A}<\mathrm{B}$ | $\mathrm{A}>\mathrm{B}$ |
| L | H | $\mathrm{A}>\mathrm{B}$ | $\mathrm{A}<\mathrm{B}$ |
| L | L | $\mathrm{A} \leqslant \mathrm{B}$ | $\mathrm{A} \geqslant \mathrm{B}$ |

These circuits have been designed to not only incorporate all of the designer's requirements for arithmetic operations, but also to provide 16 possible functions of two Boolean variables without the use of external circuitry. These logic functions are selected by use of the four function-select inputs (S0, S1, S2, S3) with the mode-control input (M) at a high level to disable the internal carry. The 16 logic functions are detailed in Tables 1 and 2 and include exclusive-OR, NAND, AND, NOR, and OR functions.

## description (continued)

The 'AS881A has the same pinout and same functionality as the 'AS181A except for the $\bar{P}, \bar{G}$, and $C_{n}+4$ outputs when the device is in the logic mode $(M=H)$.

In the logic mode the 'AS881A provides the user with a status check on the input words A and B, and the ouput word $F$. While in the logic mode the $\bar{P}, \bar{G}$, and $C_{n}+4$ outputs supply status information based upon the following logical combinations:
$\overline{\mathrm{P}}=\mathrm{FO}+\mathrm{F} 1+\mathrm{F} 2+\mathrm{F} 3$
$\bar{G}=H$
$C_{n+4}=P C_{n}$

FUNCTION TABLE FOR INPUT BITS EQUAL/NOT EQUAL
$S 0=S 3=H, S 1=S 2=L$, and $M=H$

| $C_{n}$ | DATA INPUTS |  |  |  | OUTPUTS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\overline{\mathbf{G}}$ | $\overline{\mathrm{P}}$ | $c_{n+4}$ |
| H | $\overline{\mathrm{A}} \mathrm{O}=\overline{\mathrm{B}} \mathrm{O}$ | $\overline{\mathrm{A}} 1=\overline{\mathrm{B}} 1$ | $\overline{\mathrm{A}} 2=\overline{\mathrm{B}} 2$ | $\overline{\mathrm{A}} 3=\overline{\mathrm{B}} 3$ | H | L | H |
| L | $\overline{\mathrm{A}} 0=\overline{\mathrm{B}} \mathrm{O}$ | $\overline{\mathrm{A}} 1=\overline{\mathrm{B}} 1$ | $\overline{\mathrm{A}} 2=\overline{\mathrm{B}} 2$ | $\overline{\mathrm{A}} 3=\overline{\mathrm{B}} 3$ | H | L | L |
| X | $\bar{A} 0 \neq \bar{B} 0$ | X | X | X | H | H | L |
| X | X | $\overline{\mathrm{A}} 1 \neq \overline{\mathrm{B}} 1$ | x | X | H | H | L |
| x | x | $x$ | $\overline{\mathrm{A}} 2 \neq \overline{\mathrm{B}} 2$ | $x$ | H | H | L |
| $\times$ | x | $\times$ | X | $\overline{\mathrm{A}} 3 \neq \overline{\mathrm{B}} 3$ | H | H | L |

FUNCTION TABLE FOR INPUT PAIRS HIGH/NOT HIGH
$S 0=S 1=S 3=L, S 2=H$, and $M=H$

| $C_{n}$ | DATA INPUTS |  |  |  | OUTPUTS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\overline{\text { G }}$ | $\overline{\mathbf{P}}$ | $\mathrm{C}_{n}+4$ |
| H | $\overline{\mathrm{A}} \mathrm{O}$ or $\overline{\mathrm{B}} \mathrm{O}=\mathrm{L}$ | $\overline{\mathrm{A}} 1$ or $\overrightarrow{\mathrm{B}} 1=\mathrm{L}$ | $\overline{\mathrm{A}} 2$ or $\overline{\mathrm{B}} 2=$ | $\overline{\mathrm{A}} 3$ or $\overline{\mathrm{B}} 3=\mathrm{L}$ | H | L | H |
| L | $\overline{\mathrm{A}} 0$ or $\overline{\mathrm{B}} \mathrm{O}=\mathrm{L}$ | $\overline{\mathrm{A}} 1$ or $\overline{\mathrm{B}} 1=$ | $\overline{\mathrm{A}} 2$ or $\overline{\mathrm{B}} 2=$ | $\stackrel{\rightharpoonup}{\mathrm{A}} 3$ or $\overrightarrow{\mathrm{B}} 3=\mathrm{L}$ | H | L | L |
| X | $\overline{\mathrm{A}} \mathrm{O}=\overline{\mathrm{B}} \mathrm{O}=\mathrm{H}$ | X | $X$ | $X$ | H | H | L |
| $x$ | $x$ | $\overline{\mathrm{A}} 1=\overline{\mathrm{B}} 1=\mathrm{H}$ | X | $x$ | H | H | L |
| $x$ | X | $X$ | $\overline{\mathrm{A}} 2=\overline{\mathrm{B}} 2=\mathrm{H}$ | X | H | H | L |
| X | X | X | X | $\overline{\mathrm{A}} 3=\overline{\mathrm{B}} 3=\mathrm{H}$ | H | H | L |

The combination of signals on the S3 through SO control lines determine the operation performed on the data words to generate the output bits $\overline{\mathrm{Fi}}$. By monitoring the $\overline{\mathrm{P}}$ and $\mathrm{C}_{\mathrm{n}}+4$ outputs, the user can determine if all pairs of input bits are equal (see table above) or if any pair of inputs are both high (see table above). The 'AS881A has the unique feature of providing an $A=B$ status while the exclusive-OR( $\oplus)$ function is being utilized. When the control inputs (S3, S2, S1, SO) equal H, L, L, H; a status check is generated to determine whether all pairs ( $\overline{\mathrm{A}} \mathrm{i}, \overline{\mathrm{B}} \mathrm{i}$ ) are equal in the following manner: $\overline{\mathrm{P}}=(\mathrm{A} 0 \oplus \mathrm{~B})+(\mathrm{A} 1 \oplus \mathrm{~B} 1)+(\mathrm{A} 2 \oplus \mathrm{~B})+(\mathrm{A} 3 \oplus \mathrm{~B} 3)$. This unique bit-by-bit comparison of the data words, which is available on the totem-pole $\bar{P}$ output, is particularly useful when cascading 'AS881s. As the $A=B$ condition is sensed in the first stage, the signal is propagated through the same ports used for carry generation in the arithmetic mode ( $\bar{P}$ and $\bar{G}$ ). Thus the $A=B$ status is transmitted to the second stage more quickly without the need for external multiplexing logic. The $A=B$ open-collector output allows the user to check the validity of the bit-by-bit result by comparing the two signals for parity.
If the user wishes to check for any pair of data inputs ( $\overline{\mathrm{A}} \mathrm{i}, \overline{\mathrm{B}} \mathrm{i}$ ) being high, it is necessary to set the control lines (S3,S2,S1,S0) to $L, H, L, L$. The data pairs will then be ANDed together and the results ORed in the following manner: $\bar{P}=\bar{A} O \bar{B} O+\bar{A} 1 \bar{B} 1+\bar{A} 2 \bar{B} 2+\bar{A} 3 \bar{B} 3$.

| S3 | S2 | S1 | So | M | $\overline{\mathrm{P}}=\mathrm{FO}+\mathrm{F} 1+\mathrm{F} 2+\mathrm{F} 3$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| L | H | L | L | H | $\overline{\mathrm{A}} 0 \overline{\mathrm{~B}} 0+\overline{\mathrm{A}} 1 \overline{\mathrm{~B}} 1+\overline{\mathrm{A}} 2 \overline{\mathrm{~B}} 2+\overline{\mathrm{A}} 3 \overline{\mathrm{~B}} 3$ |
| H | L | L | H | H | $(\mathrm{AO} \oplus \mathrm{B} 0)+(\mathrm{A} 1 \oplus \mathrm{~B} 1)+(\mathrm{A} 2 \oplus \mathrm{~B} 2)+(\mathrm{A} 3 \oplus \mathrm{~B})$ |

## signal designations

In both Figures 1 and 2, the polarity indicators ( $\Delta$ ) indicate that the associated input or output is activelow with respect to the function shown inside the symbol and the symbols are the same in both figures. The signal designations in Figure 1 agree with the indicated internal functions based on active-low data, and are for use with the logic functions and arithmetic operations shown in Table 1. The signal designations have been changed in Figure 2 to accommodate the logic functions and arithmetic operations for the activehigh data given in Table 2. The 'AS181A and 'AS881A together with 'AS882 and 'S182 can be used with the signal designation of either Figure 1 or Figure 2.


FIGURE 1 (USE WITH TABLE 1)

TABLE 1

| SELECTION | ACTIVE-LOW DATA |  |  |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{M}=\mathrm{H}$ | $\mathrm{M}=\mathrm{L}$; ARITHM | TIC OPERATIONS |
| S3 S2 S1 so | LOGIC FUNCTIONS | $\begin{gathered} C_{n}=L \\ \text { (no carry) } \\ \hline \end{gathered}$ | $\begin{gathered} C_{n}=H \\ \text { (with carry) } \end{gathered}$ |
| L L L L | $\mathrm{F}=\overline{\mathrm{A}}$ | $F=A$ MINUS 1 | $F=A$ |
| L L L H | $F=\overline{A B}$ | $F=A B$ MINUS 1 | $F=A B$ |
| L L H L | $F=\bar{A}+B$ | $F=A \bar{B}$ MINUS 1 | $F=A \bar{B}$ |
| L L H H | $\mathrm{F}=1$ | $F=$ MINUS 1 (2's COMP) | $F=Z E R O$ |
| L H L L | $F=\overline{A+B}$ | $F=A P L U S(A+\bar{B})$ | $F=A P L U S(A+\bar{B})$ PLUS 1 |
| L H L H | $F=\bar{B}$ | $F=A B P L U S(A+\bar{B})$ | $F=A B P L U S ~(A+\bar{B})$ PLUS 1 |
| L H H | $F=\overline{A ¢ B}$ | $F=A$ MINUS B MINUS 1 | $F=A$ MINUS $B$ |
| L H H H | $F=A+\bar{B}$ | $F=A+\bar{B}$ | $F=(A+\bar{B})$ PLUS 1 |
| H L L L | $F=\bar{A} B$ | $F=A P \operatorname{LUS}(A+B)$ | $F=A$ PLUS $(A+B)$ PLUS 1 |
| H L L H | $F=A \oplus B$ | $F=A P L U S B$ | $F=A$ PLUS B PLUS 1 |
| H L H L | $\mathrm{F}=\mathrm{B}$ | $F=A \bar{B} P \operatorname{LUS}(A+B)$ | $F=A \bar{B} P$ PLUS $(A+B) P$ PLUS 1 |
| H L H H | $F=A+B$ | $F=(A+B)$ | $F=(A+B) P L U S 1$ |
| H H L L | $F=0$ | $F=A$ PLUS $A^{\dagger}$ | $F=A$ PLUS A PLUS 1 |
| H H L H | $F=A \bar{B}$ | $F=A B P L U S A$ |  |
| H H H L | $F=A B$ | $F=A \bar{B} P$ PLUS $A$ | $F=A \bar{B} P L U S A P L U S ~ 1 ~$ |
| H H H H | $F=A$ | $F=A$ | $F=A P L U S 1$ |

[^9]

FIGURE 2 (USE WITH TABLE 2)

TABLE 2

| SELECTION | ACTIVE.HIGH DATA |  |  |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{M}=\mathrm{H}$ | $\mathrm{M}=$ L: ARITHME | TIC OPERATIONS |
| S3 S2 S1 S0 | LOGIC FUNCTIONS | $\begin{gathered} \overline{\mathrm{C}}_{\mathrm{n}}=\mathrm{H} \\ \text { ( } \mathrm{n} \text { ó carry) } \end{gathered}$ | $\begin{gathered} \bar{C}_{n}=\mathrm{L} \\ \text { (with carry) } \end{gathered}$ |
| L L L L | $F=\bar{A}$ | $F=A$ | $\mathrm{F}=\mathrm{APLUS} 1$ |
| L L L H | $F=\overline{A+B}$ | $F=A+B$ | $F=(A+B) P$ PUS 1 |
| L L H | $F=\bar{A} B$ | $F=A+\bar{B}$ | $F=(A+\bar{B})$ PLUS 1 |
| L L H H | $F=0$ | $F=$ MINUS 1 (2's COMPL) | $F=Z E R O$ |
| L H L L | $F=\overline{A B}$ | $F=A P L U S A \bar{B}$ | $F=A P L U S ~ A \bar{B} P L U S ~ 1 ~$ |
| L H L H | $F=\bar{B}$ | $F=(A+B) P L U S A \bar{B}$ | $F=(A+B)$ PLUS $A \bar{B}$ PLUS 1 |
| L H H L | $F=A \oplus B$ | $F=A$ MINUS B MINUS 1 | $F=A$ MINUS B |
| L H H H | $F=A \bar{B}$ | $F=A \bar{B}$ MINUS 1 | $F=A \bar{B}$ |
| H L L L | $F=\bar{A}+B$ | $F=A P L U S A B$ | $F=A$ PLUS AB PLUS 1 |
| H L L H | $F=\overline{A \oplus}$ | $F=A P L U S B$ | $F=A$ PLUS B PLUS 1 |
| H L H L | $F=B$ | $F=(A+\bar{B})$ PLUS $A B$ | $F=(A+\bar{B})$ PLUS AB PLUS 1 |
| H L H H | $F=A B$ | $F=A B$ MINUS 1 | $F=A B$ |
| H H L L | $F=1$ | $F=A P L U S A \dagger$ | $F=A$ PLUS A PLUS 1 |
| H H L H | $F=A+\bar{B}$ | $F=(A+B) P L U S A$ | $F=(A+B)$ PLUS A PLUS 1 |
| H H H L | $F=A+B$ | $F=(A+\bar{B})$ PLUS $A$ | $F=(A+\bar{B})$ PLUS A PLUS 1 |
| H H H H | $F=A$ | $F=A$ MINUS 1 | $\mathrm{F}=\mathrm{A}$ |

## SN54AS181A, SN74AS181A ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS

logic diagram (positive logic)
'AS181A


## SN54AS881A, SN74AS881A <br> ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS

logic diagram (positive logic)
'AS881A


## SN54AS181A, SN54AS881A, SN74AS181A, SN74AS881A ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| Supply voltage, VCC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V |  |  |
| :---: | :---: | :---: |
| Input voltage |  |  |
| Off-state output voltage ( $\mathrm{A}=\mathrm{B}$ output only) |  |  |
| Operating free-air temperature range | SN54AS181A, SN54AS881A | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
|  | SN74AS181A, SN74AS881A | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range |  | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions

|  |  |  |  | N54A |  |  | N74AS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX | UNIT |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | $A=B$ output only |  |  | 5.5 |  |  | 5.5 | V |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | High-level output current | All outputs except $\mathrm{A}=\mathrm{B} \text { and } \overline{\mathrm{G}}$ |  |  | -2 |  |  | -2 | mA |
|  |  | $\overline{\mathrm{G}}$ |  |  | -3 |  |  | -3 | mA |
| ${ }^{\text {IOL }}$ | Low-level output current | All outputs except $\overline{\mathrm{G}}$ |  |  | 20 |  |  | 20 | mA |
|  |  | $\overline{\mathrm{G}}$ |  |  | 48 |  |  | 48 | mA |
| $\mathrm{T}_{\text {A }}$ | Operating free-air tempera |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

SN54AS181A, SN54AS881A, SN74AS181A, SN74AS881A ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54AS' |  |  | SN74AS' |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\text { }}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $\mathrm{V}_{\mathrm{IK}}$ |  |  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{I}}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Any output except $A=B$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I} \mathrm{OH}=-2 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}{ }^{-2}$ |  |  | $\mathrm{V}_{\mathrm{CC}}{ }^{-2}$ |  |  | $\checkmark$ |
|  | $\overline{\mathrm{G}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.4 | 3.4 |  | 2.4 | 3.4 |  | V |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | $A=B$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Any output except $\overline{\mathrm{G}}$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=20 \mathrm{~mA}$ |  | 0.3 | 0.5 |  | 0.3 | 0.5 | V |
|  | $\overline{\mathrm{G}}$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=48 \mathrm{~mA}$ |  | 0.4 | 0.5 |  | 0.4 | 0.5 | V |
| 1 | M input | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=7 \mathrm{~V}$ |  |  |  | 0.1 |  |  | 0.1 | mA |
|  | Any A or B input |  |  |  |  | 0.3 |  |  | 0.3 |  |
|  | Any S input |  |  |  |  | 0.4 |  |  | 0.4 |  |
|  | Carry input |  |  |  |  | 0.6 |  |  | 0.6 |  |
| ${ }_{1 / \mathrm{H}}$ | M input | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{I}}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | Any A or B input |  |  |  |  | 60 |  |  | 60 |  |
|  | Any S input |  |  |  |  | 80 |  |  | 80 |  |
|  | Carry input |  |  |  |  | 120 |  |  | 120 |  |
| IL | $M$ input | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -2 |  |  | -2 | mA |
|  | Any A or B input |  |  |  |  | -6 |  |  | -6 |  |
|  | Any S input |  |  |  |  | -8 |  |  | -8 |  |
|  | Carry input |  |  |  |  | -12 |  |  | -12 |  |
| $10^{\ddagger}$ | All outputs except $\mathrm{A}=\mathrm{B} \text { and } \overline{\mathrm{G}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 | -45 | -112 | -30 | -45 | -112 | mA |
|  | $\overline{\mathrm{G}}$ |  |  | -165 |  |  | -165 |  |  |  |
| ${ }^{\prime} \mathrm{CC}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | 'AS181A |  | 135 | 200 |  | 135 | 200 | mA |
|  |  | 'AS881A |  | 135 | 210 |  | 135 | 210 |  |

${ }^{\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 current, los.

## SN54AS181A, SN54AS881A, SN74AS181A, SN74AS881A ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS

switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | $\begin{gathered} \text { TO } \\ \text { (OUTPUT) } \end{gathered}$ | TEST CONDITIONS | $\begin{aligned} & V_{C C}=5 \mathrm{~V}, \\ & C_{L}=15 \mathrm{pF}, \\ & R_{\mathrm{L}}=500 \Omega \\ & (280 \Omega \text { for } \mathrm{A}=\mathrm{B}) . \\ & \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \text { 'AS } 181 \mathrm{~A} \\ & \text { 'AS881A } \\ & \hline \end{aligned}$ | $\begin{aligned} & V_{C C}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V} \\ & C_{L}=50 \mathrm{pF}(15 \mathrm{pF} \text { for } A=B), \\ & R_{\mathrm{L}}=500 \Omega(280 \Omega \text { for } A=B), \\ & \mathrm{T}_{A}=\text { MIN to MAX } \end{aligned}$ |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | SN54AS181A SN54AS881A |  | SN74AS181A SN74AS881A |  |  |  |
|  |  |  |  | MIN TYP ${ }^{\dagger}$ MAX | MIN TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| ${ }^{\text {tpd }}$ | $\mathrm{C}_{n}$ | $C_{n+4}$ |  | 5 | 27 | 11 | 2 | 7 | 9 | ns |
| ${ }^{t} \mathrm{pd}$ | Any $\overline{\mathrm{A}}$ or $\overline{\mathrm{B}}$ | $C_{n+4}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=0 \mathrm{~V}, \\ & \mathrm{SO}=\mathrm{S} 3=4.5 \mathrm{~V} \text { (SUM mode) } \end{aligned}$ | 6 | 28 | 14 | 2 | 8 | 12 | ns |
| ${ }^{t} \mathrm{pd}$ | Any $\overline{\mathrm{A}}$ or $\overline{\mathrm{B}}$ | $C_{n+4}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{SO}=\mathrm{S} 3=0 \mathrm{~V}, \\ & \mathrm{~S} 1=\mathrm{S} 2=4.5 \mathrm{~V}(\overline{\mathrm{DIFF}} \text { mode }) \end{aligned}$ | 7 | 2. 8 | 20 | 2 | 8 | 16 | ns |
| ${ }^{\text {t }}$ pd | $\mathrm{C}_{\mathrm{n}}$ | Any $\overline{\mathrm{F}}$ | $\mathrm{M}=0 \mathrm{~V}$ ( $\overline{S U M}$ or $\overline{\text { DIFF }}$ mode) | 5 | 36 | 11 | 3 | 6 | 9 | ns |
| ${ }^{t} \mathrm{pd}$ | $\overline{\text { Any }} \overline{\mathrm{A}} \overline{\mathrm{~B}}$ | $\overline{\mathrm{G}}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=0 \mathrm{~V}, \\ & \mathrm{SO}=\mathrm{S} 3=4.5 \vee(\overline{\mathrm{SUM}} \text { mode }) \end{aligned}$ | 4 | 25 | 9 | 2 | 5 | 7 | ns |
| ${ }^{t} \mathrm{pd}$ | $\overline{\text { Any }} \overline{\text { or } \bar{B}}$ | $\overline{\mathrm{G}}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{SO}=\mathrm{S} 3=0 \mathrm{~V}, \\ & \mathrm{~S} 1=\mathrm{S} 2=4.5 \mathrm{~V}(\overline{\mathrm{DIFF}} \text { mode }) \end{aligned}$ | 5 | 26 | 12 | 2 | 6 | 9 | ns |
| ${ }^{t} \mathrm{pd}$ | $\begin{gathered} \text { Any } \\ \overline{\mathrm{A}} \text { or } \overline{\mathrm{B}} \end{gathered}$ | $\bar{p}$ | $\begin{aligned} & M=0 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=0 \mathrm{~V}, \\ & S 0=S 3=4.5 \mathrm{~V}(\overline{\mathrm{SUM}} \text { mode }) \end{aligned}$ | 5 | 26 | 11 | 2 | 6 | 8 | ns |
| ${ }^{t} \mathrm{pd}$ | Any <br> $\bar{A}$ or $\bar{B}$ | $\overline{\mathrm{P}}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 0=\mathrm{S} 3=0 \mathrm{~V}, \\ & \mathrm{~S} 1=\mathrm{S} 2=4.5 \mathrm{~V}(\overline{\mathrm{DIFF}} \text { mode }) \end{aligned}$ | 5 | 26 | 13 | 2 | 6 | 10 | ns |
| ${ }^{t} \mathrm{pd}$ | $\begin{gathered} \overline{\mathrm{A}} \mathrm{i} \text { or } \\ \overline{\mathrm{B}} \mathrm{i} \\ \hline \end{gathered}$ | $\overline{\mathrm{Fi}}$ | $\begin{aligned} & \mathrm{M}=0 \vee, \mathrm{~S} 1=\mathrm{S} 2=0 \mathrm{~V}, \\ & \mathrm{SO}=\mathrm{S} 3=4.5 \vee(\overline{\mathrm{SUM}} \text { mode }) \end{aligned}$ | 5 | 25 | 11 | 2 | 5 | 8 | ns |
| ${ }^{t} \mathrm{pd}$ | $\overline{\mathrm{A}} \mathrm{i}$ or $\bar{B} i$ | $\overline{\mathrm{Fi}}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{SO}=\mathrm{S} 1=0 \mathrm{~V}, \\ & \mathrm{~S} 1=\mathrm{S} 2=4.5 \mathrm{~V}(\overline{\mathrm{DIFF}} \text { mode }) \end{aligned}$ | 5 | 26 | 12 | 2 | 6 | 10 | ns |
| ${ }^{t} \mathrm{pd}$ | $\bar{A} \bar{i}$ or $\overline{\mathrm{B}} \mathrm{i}$ | $\bar{F} \mathrm{i}$ | $\mathrm{M}=4.5 \mathrm{~V}$ (LOGIC mode) | 6 | 26 | 16 | 2 | 6 | 11 | ns |
| ${ }^{t} \mathrm{pd}$ | $\begin{aligned} & \text { Any } \bar{A} \\ & \text { or } \bar{B} \end{aligned}$ | $A=B$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 0=\mathrm{S} 3=0 \mathrm{~V}, \\ & \mathrm{~S} 1=\mathrm{S} 2=4.5 \mathrm{~V}(\overline{\mathrm{DIFF}} \text { mode }) \end{aligned}$ | 12 | $4 \quad 14$ | 26 | 4 | 14 | 21 | ns |

additional 'AS881A switching characteristics involving status checks (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \\ \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}}=500 \Omega \\ \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ \hline \text { 'AS881A } \\ \hline \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}_{\mathrm{L}}=500 \Omega, \\ & \mathrm{~T}_{\mathbf{A}}=\mathrm{MIN} \text { to } \mathrm{MAX} \end{aligned}$ |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | SN54AS881A |  |  | SN74AS881A |  |  |  |
|  |  |  |  | MIN | TYP ${ }^{\text {¢ }}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| ${ }^{t} \mathrm{pd}$ | $\begin{aligned} & \text { Any } \\ & \overline{\mathrm{A}} \text { or } \overline{\mathrm{B}} \end{aligned}$ | $\bar{p}$ | $\begin{aligned} & \mathrm{C}_{\mathrm{n}}=4.5 \mathrm{~V}, \mathrm{M}=4.5 \mathrm{~V} \\ & \mathrm{~S} 0=\mathrm{S} 3=4.5 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=0 \mathrm{~V} \\ & \text { Equality }(\overline{\mathrm{A}} \mathrm{i}=\overline{\mathrm{B}} \mathrm{i} \text { or } \overline{\mathrm{A}} \mathrm{i} \neq \overline{\mathrm{B}} \mathrm{i}) \end{aligned}$ |  | 8 |  | 2 | 10 | 19 | 2 | 10 | 15 | ns |
| ${ }^{t} \mathrm{pd}$ | $\begin{aligned} & \text { Any } \\ & \bar{A} \text { or } \bar{B} \end{aligned}$ | $c_{n+4}$ | $\begin{aligned} & \mathrm{C}_{n}=4.5 \mathrm{~V}, \mathrm{M}=4.5 \mathrm{~V}, \\ & \mathrm{SO}=\mathrm{S} 3=4.5 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=0 \mathrm{~V} \\ & \text { Equality }(\overline{\mathrm{A}} \mathrm{i}=\overline{\mathrm{B}} \mathrm{i} \text { or } \overline{\mathrm{A}} \mathrm{i} \neq \overline{\mathrm{B}} \mathrm{i}) \end{aligned}$ |  | 10 |  | 2 | 12 | 24 | 2 | 12 | 18 | ns |
| ${ }^{t} \mathrm{pd}$ | Any $\vec{A}$ or $\bar{B}$ | $\overline{\mathrm{P}}$ | $\begin{aligned} & \mathrm{C}_{n}=4.5 \mathrm{~V}, \mathrm{M}=4.5 \mathrm{~V}, \\ & \mathrm{~S} 2=4.5 \mathrm{~V}, \mathrm{~S} O=\mathrm{S} 1=\mathrm{S} 3=0 \mathrm{~V}, \\ & (\overline{\mathrm{~A}} \mathrm{i}=\overline{\mathrm{B}} \mathrm{i}=\mathrm{H} \text { or } \overline{\mathrm{A}} i \text { or } \overline{\mathrm{B}} \mathrm{i}=\mathrm{L}) \end{aligned}$ |  | 8 |  | 2 | 10 | 19 | 2 | 10 | 15 | ns |
| ${ }^{t} \mathrm{pd}$ | $\overline{A n y}, \bar{B} \text { or } \bar{B}$ | $C_{n+4}$ | $\begin{aligned} & \mathrm{C}_{\mathrm{n}}=4.5 \mathrm{~V}, \mathrm{M}=4.5 \mathrm{~V}, \\ & \mathrm{~S} 2=4.5 \mathrm{~V}, \mathrm{~S} 0=\mathrm{S} 1=\mathrm{S} 3=0 \mathrm{~V}, \\ & (\overline{\mathrm{~A}} \mathrm{i}=\overline{\mathrm{B}} \mathrm{i}=\mathrm{H} \text { or } \overline{\mathrm{A} i} \text { or } \overline{\mathrm{B}} \mathrm{i}=\mathrm{L}) \end{aligned}$ |  | 11 |  | 2 | 13 | 25 | 2 | 13 | 19 | ns |

$t_{\text {pd }}=t_{P H L}$ or tPLH
${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN54AS181A, SN54AS881A, SN74AS181A, SN74AS881A ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS

PARAMETER MEASUREMENT INFORMATION

SUM MODE TEST TABLE
FUNCTION INPUTS: $\mathrm{SO}=\mathrm{S} 3=4.5 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=\mathrm{M}=0 \mathrm{~V}$

| PARAMETER |  | OTHER INPUT SAME BIT |  | OTHER DATA INPUTS |  | OUTPUT <br> UNDER <br> TEST | OUTPUT WAVEFORM (SEE NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { APPLY } \\ & 4.5 \mathrm{~V} \end{aligned}$ | APPLY GND | $\begin{gathered} \text { APPLY } \\ 4.5 \mathrm{~V} \end{gathered}$ | APPLY GND |  |  |
| tPLH | $\bar{A} i$ | $\overline{\mathrm{Bi}}$ | None | Remaining $\bar{A}$ and $\bar{B}$ | $\mathrm{C}_{\mathrm{n}}$ | $\bar{F}{ }_{i}$ | In-Phase |
| tphL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}} \mathrm{i}$ | $\overline{\mathrm{A}} \mathrm{i}$ | None | Remaining $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}$ | $\mathrm{C}_{\mathrm{n}}$ | $\overline{\mathrm{F}} \mathrm{i}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| ${ }_{\text {tPLH }}$ | $\bar{A} i$ | $\bar{B} i$ | None | None | $\begin{gathered} \text { Remaining } \\ \bar{A} \text { and } \bar{B}, C_{n} \end{gathered}$ | $\overline{\mathrm{P}}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}} \mathrm{i}$ | $\bar{A} i$ | None | None | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | $\overline{\mathrm{P}}$ | in-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\bar{A} i$ | None | $\overline{\mathrm{Bi}}$ | Remaining $\bar{B}$ | $\begin{aligned} & \text { Remaining } \\ & \bar{A}, C_{n} \end{aligned}$ | $\overline{\mathrm{G}}$ | In-Phase |
| tphL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}} \mathrm{i}$ | None | $\bar{A} i$ | $\begin{gathered} \text { Remaining } \\ \bar{B} \end{gathered}$ | $\begin{gathered} \text { Remaining } \\ \bar{A}, C_{n} \\ \hline \end{gathered}$ | $\overline{\mathrm{G}}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\mathrm{C}_{n}$ | None | None | $\overline{\mathrm{All}}$ | All$\bar{B}$ | $\begin{gathered} \text { Any } \bar{F} \\ \text { or } C_{n}+4 \end{gathered}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\bar{A} i$ | None | $\bar{B} \mathrm{i}$ | Remaining $\bar{B}$ | Remaining$\bar{A}, C_{n}$ | $C_{n+4}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}} \mathrm{i}$ | None | $\bar{A} i$ | Remaining $\bar{B}$ | Remaining$\overline{\mathrm{A}}, \mathrm{C}_{\mathrm{n}}$ | $C_{n+4}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |

DIFF MODE TEST TABLE
FUNCTION INPUTS: $\mathrm{S} 1=\mathrm{S} 2=4.5 \mathrm{~V}, \mathrm{~S} 0=\mathrm{S} 3=\mathrm{M}=0 \mathrm{~V}$

| PARAMETER |  | OTHER INPUT SAME BIT |  | OTHER DATA INPUTS |  | OUTPUT <br> UNDER <br> TEST | OUTPUT WAVEFORM (SEE NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | APPLY $4.5 \mathrm{~V}$ | APPLY GND | $\begin{gathered} \text { APPLY } \\ 4.5 \mathrm{~V} \end{gathered}$ | APPLY <br> GND |  |  |
| ${ }^{\text {tPLH }}$ | $\bar{A} i$ | None | $\overline{\mathrm{B}} \mathrm{i}$ | $\begin{gathered} \text { Remaining } \\ \bar{A} \end{gathered}$ | Remaining <br> B, $C_{n}$ | $\overline{\mathrm{Fi}}$ | In-Phase |
| tpHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}} \mathrm{i}$ | $\bar{A} i$ | None | $\begin{gathered} \text { Remaining } \\ \bar{A} \end{gathered}$ | Remaining <br> $B, C_{n}$ | $\overline{\mathrm{F}} \mathrm{i}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| tple | $\bar{A} i$ | None | $\bar{B} \mathrm{i}$ | None | $\begin{aligned} & \text { Remaining } \\ & \overline{\mathrm{A}} \text { and } \overline{\mathrm{B}}, \mathrm{C}_{\mathrm{n}} \end{aligned}$ | $\overline{\mathrm{P}}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}} \mathrm{i}$ | $\bar{A} i$ | None | None | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | $\overline{\mathrm{P}}$ | Out-of-Phase |
| tpHL |  |  |  |  |  |  |  |
| tplh | $\bar{A} i$ | $\overline{\mathrm{Bi}}$ | None | None | Remaining $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}, \mathrm{C}_{\mathrm{n}}$ | $\overline{\mathrm{G}}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tplH | $\overline{\mathrm{B}} \mathrm{i}$ | None | $\bar{A} i$ | None | Remaining $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}, \mathrm{C}_{\mathrm{n}}$ | $\overline{\mathrm{G}}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\bar{A} i$ | None | $\overline{\mathrm{B}}$ | $\begin{gathered} \text { Remaining } \\ \bar{A} \end{gathered}$ | remaining$\bar{B}, C_{n}$ | $A=B$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}} \mathrm{i}$ | $\bar{A} i$ | None | $\begin{gathered} \text { Remaining } \\ \bar{A} \\ \hline \end{gathered}$ | Remaining $\bar{B}, C_{n}$ | $A=B$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $C_{n}$ | None | None | $\overline{\text { All }} \overline{\mathrm{A}} \text { and } \bar{B}$ | None | $C_{n+4}$ <br> or any $\bar{F}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ | $\bar{A} i$ | $\overline{\mathrm{Bi}}$ | None | None | Remaining $\bar{A}, \bar{B}, C_{n}$ | $C_{n+4}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ | $\overline{B i}$ | None | $\bar{A} i$ | None | Remaining $\bar{A}, \bar{B}, C_{n}$ | $C_{n+4}$ | In-Phase |
| ${ }_{\text {tPHL }}$ |  |  |  |  |  |  |  |

[^10]SN54LS222, SN54LS224, SN54LS227, SN54LS228<br>SN74LS222, SN74LS224, SN74LS227, SN74LS228 16 X 4 SYNCHRONOUS FIRST-IN FIRST-OUT MEMORIES<br>JANUARY 1981 REVISED MARCH 1985

- Independent Synchonous Inputs and Outputs
- 16 Words of 4 Bits Each
- 3-State Outputs Drive Bus Lines Directly
- Data Rates from 0 to 10 MHz
- Fall-Through Time . . . 50 ns Typ
- Data Terminals Arranged for Optimum PC Board Layout
- Expandable Using External Gating


## description

These 64-bit memories are Low-Power Schottky memory arrays organized as 16 words of 4 bits each. They can be expanded in multiples of $15 m+1$ words or $4 n$ bits, or both, (where $n$ is the number of packages in the vertical array and $m$ is the number of packages in the horizontal array) however some external gating is required (see Figure 1). For longer words using the 'LS224 or 'LS228, the IR signals of the first-rank packages and OR signals of the last-rank packages must be ANDed for proper synchronization.

| TYPE | INPUT-READY ENABLE AND <br> OUTPUT-READY ENABLE | OUTPUT |
| :---: | :---: | :--- |
| 'LS222 | Yes | 3-State |
| 'LS224 | No | 3-State |
| 'LS227 | Yes | Open-collector |
| 'LS228 | No | Open-collector |

SN54LS222, SN54LS227 . . . J PACKAGE
SN74LS222, SN74LS227 . . J OR N PACKAGE
(TOP VIEW)


NC - No internal connection
For chip carrier information contact the factory.

## operation

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 10 MHz in a bit-parallel format, word by word. Data is written into the memory on a high-to-low transition at the load clock input (LDCK) and 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 the number of words clocked out by 16. 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 (see timing diagram) is monitored by the input ready (IR) and output ready (OR) flags that indicate "not full" and "not empty" conditions. The IR output will be high only when the memory is not full and the LDCK input is low. The OR output will be high only when the memory is not empty and UNCK is high.
A low level at the clear ( $\overline{\mathrm{CLR})}$ input resets the internal stack control counters and also sets $\operatorname{IR}$ high and OR low to indicate that old data remaining at the data outputs is invalid. Data outputs are noninverting with respect to the data inputs and are at high impedance when output enable (OE) is low. OE does not affect the IR and OR outputs.

SN54LS222, SN54LS224, SN54LS227, SN54LS228
SN74LS222, SN74LS224, SN74LS227, SN74LS228 16 X 4 SYNCHRONOUS FIRST-IN FIRST-OUT MEMORIES
functional block diagram (positive logic)

*'LS222 and 'LS224 have 3-state ( $\nabla$ ) outputs.
('LS222 and 'LS227 pin numbers)
['LS224 and 'LS228 pin numbers]
timing diagram


## SN54LS222, SN54LS224, SN54LS227, SN54LS228 SN74LS222, SN74LS224, SN74LS227, SN74LS228 16 X 4 SYNCHRONOUS FIRST-IN FIRST-OUT MEMORIES

logic symbols ${ }^{\dagger}$


$\dagger$ These symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
These symbols are functionally accurate but do not show the details of implementation; for these, see the functional block diagram. The symbol represents the memory as if it were controlled by a single counter whose content is the number of words stored at that time. Output data is invalid when the counter content is 0 .
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
$\qquad$
$\qquad$
$\qquad$
Operating free-air temperature range:
SN54LS222, SN54LS224, SN54LS227, SN54LS228 . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
SN74LS222, SN74LS224, SN74LS227, SN74LS228 . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

NOTE 1: Voltage values are with respect to network ground terminal.

WITH 3-STATE OUTPUTS
recommended operating conditions

|  |  |  | SN54LS' |  |  | SN74LS' |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| $\mathrm{V}_{1 \mathrm{H}}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.7 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current | Q |  |  | -1 |  |  | -2.6 | mA |
|  |  | IR, OR |  |  | -0.4 |  |  | -0.4 |  |
| 1 | Low-level output current | Q |  |  | 12 |  |  | 24 | mA |
| ${ }^{\text {OL }}$ | Low-level output current | IR, OR |  |  | 4 |  |  | 8 |  |
| ${ }^{\text {w }}$ w | Pulse duration | LDCK high | 60 |  |  | 60 |  |  | ns |
|  |  | LDCK low | 15 |  |  | 15 |  |  |  |
|  |  | UNCK low | 30 |  |  | 30 |  |  |  |
|  |  | UNCK high | 30 |  |  | 30 |  |  |  |
|  |  | $\overline{C L R}$ low | 20 |  |  | 20 |  |  |  |
| $\mathrm{t}_{\mathrm{su}}$ | Setup time | D to LDCK $\downarrow$ | 50 |  |  | 50 |  |  | ns |
|  |  | LDCK $\downarrow$ before UNCK $\downarrow$ | 50 |  |  | 50 |  |  |  |
|  |  | UNCK $\uparrow$ before LDCK $\uparrow$ | 50 |  |  | 50 |  |  |  |
| $t_{h}$ | Hold time | D from LDCK $\downarrow$ | 0 |  |  | 0 |  |  | ns |
| TA | Operating free-air temperature |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$ |  | SN54LS' |  |  | SN74LS' |  |  | UnNTT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MiN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $V_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Q | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{I}_{\mathrm{OH}}=\mathrm{MAX}$ | 2.4 | 3.3 |  | 2.4 | 3.4 |  | V |
|  | IR, OR | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$, | $\mathrm{I}^{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | 2.5 | 3.4 |  | 2.7 | 3.4 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Q | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{I}^{\text {OL }}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$, | $\mathrm{I}^{\mathrm{OL}}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | IR | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$, | $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  | IR | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| IOZH | Q | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IOZL | Q | $V_{C C}=$ MAX | $\mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  | -20 |  |  | -20 | $\mu \mathrm{A}$ |
| I |  | $V_{C C}=$ MAX , | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| $\mathrm{IIH}^{\text {H }}$ |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IIL |  | $V_{C C}=$ MAX . | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.4 |  |  | -0.4 | mA |
| $\mathrm{l}^{\prime} \mathrm{OS}^{\S}$ | Q | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$, |  | $-30$ |  | -130 | $-30$ |  | -130 | mA |
|  | IR, OR |  |  | $-20$ |  | -100 | -20 |  | -100 |  |
| ${ }^{1} \mathrm{CC}$ |  | $\mathrm{V}_{C C}=\mathrm{MAX}$, | Outputs high |  | 84 | 135 |  | 84 | 135 | mA |
|  |  | Outputs low |  | 87 | 155 |  | 87 | 155 |  |
|  |  | Outputs disabled |  | 89 | 155 |  | 89 | 155 |  |

$\dagger^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\S$ Not more than one output should be shorted at a time, and duration of the short-circuit should not exceed one second.

SN54LS222, SN54LS224, SN74LS222, SN74LS224 16 X 4 SYNCHRONOUS FIRST.IN FIRST-OUT MEMORIES WITH 3-STATE OUTPUTS
switching characteristics, $\mathrm{V}_{\mathrm{C}} \mathrm{C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | FROM | TO | TEST CONDITIONS | 'LS222 |  |  | 'LS224 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| ${ }^{\text {t PLH }}$ | IRE $\uparrow$ | IR | $\begin{aligned} & \mathrm{R}_{\mathrm{L}}=2 \mathrm{k} \Omega \\ & \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF} \end{aligned}$ <br> See Note 2 |  | 23 | 35 |  |  |  | ns |
| ${ }^{\text {tPHL }}$ | IRE $\downarrow$ | IR |  |  | 9 | 15 |  |  |  | ns |
| tPLH | ORE $\uparrow$ | OR |  |  | 22 | 35 |  |  |  | ns |
| ${ }^{\text {tPHL}}$ | ORE $\downarrow$ | OR |  |  | 9 | 15 |  |  |  | ns |
| tPLH | LDCK $\downarrow$ | IR |  |  | 25 | 40 |  | 25 | 40 | ns |
| tPHL | LDCK $\uparrow$ | IR |  |  | 36 | 50 |  | 36 | 50 | ns |
| ${ }^{\text {tPLH }}$ | LDCK $\downarrow$ | OR |  |  | 48 | 70 |  | 48 | 70 | ns |
| tPLH | UNCK $\uparrow$ | OR |  |  | 29 | 45 |  | 29 | 45 | ns |
| ${ }_{\text {t PHL }}$ | UNCK $\downarrow$ | OR |  |  | 28 | 45 |  | 28 | 45 | ns |
| tPLH | UNCK $\dagger$ | IR |  |  | 49 | 70 |  | 49 | 70 | ns |
| tPLH | $\overline{\text { CLR }} \downarrow$ | IR |  |  | 36 | 55 |  | 36 | 55 | ns |
| tPHL | $\overline{C L R} \downarrow$ | OR |  |  | 25 | 40 |  | 25 | 40 | ns |
| tPHL | LDCK $\downarrow$ | Q | $\begin{aligned} & R_{\mathrm{L}}=667 \Omega, \\ & C_{\mathrm{L}}=45 \mathrm{pF}, \end{aligned}$ <br> See Note 2 |  | 34 | 50 |  | 34 | 50 | ns |
| tPLH | UNCK $\uparrow$ | Q |  |  | 54 | 80 |  | 54 | 80 | ns |
| tPHL | UNCK $\uparrow$ | Q |  |  | 45 | 70 |  | 45 | 70 | ns |
| tPZL | OEf | Q |  |  | 22 | 35 |  | 22 | 35 | ns |
| ${ }^{\text {tPZH }}$ | $\mathrm{OE} \uparrow$ | Q |  |  | 21 | 35 |  | 21 | 35 | ns |
| tplZ | OE $\downarrow$ | Q | $R_{\mathrm{L}}=667 \Omega, \quad C_{\mathrm{L}}=5 \mathrm{pF},$ <br> See Note 2 |  | 16 | 30 |  | 16 | 30 | ns |
| ${ }_{\text {tPHZ }}$ | OE $\downarrow$ | Q |  |  | 18 | 30 |  | 18 | 30 | ns |

NOTE 2: Load circuits and voltage waveforms are shown in Section 1.
schematics of inputs and outputs


SN54LS227, SN54LS228, SN74LS227, SN74LS228 16 X 4 SYNCHRONOUS FIRST-IN FIRST-OUT MEMORIES
WITH OPEN-COLLECTOR OUTPUTS
recommended operating conditions

|  |  |  | SN54LS' |  |  | SN74LS' |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.7 |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | Q |  |  | 5.5 |  |  | 5.5 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current | IR, OR |  |  | -0.4 |  |  | -0.4 | mA |
| ${ }^{\text {I OL }}$ | Low-level output current | Q |  |  | 12 |  |  | 24 |  |
|  |  | IR, OR |  |  | 4 | 8 |  |  |  |
| ${ }^{\text {tw }}$ | Pulse duration | LDCK high | 60 |  |  | 60 |  |  | ns |
|  |  | LDCK low | 15 |  |  | 15 |  |  |  |
|  |  | UNCK low | 30 |  |  | 30 |  |  |  |
|  |  | UNCK high | 30 |  |  | 30 |  |  |  |
|  |  | $\overline{\mathrm{CLR}}$ low | 20 |  |  | 20 |  |  |  |
| ${ }^{\text {tsu }}$ | Setup time | D to LDCK $\downarrow$ | 50 |  |  | 50 |  |  | ns |
|  |  | LDCK $\downarrow$ before UNCK $\downarrow$ | 50 |  |  | 50 |  |  |  |
|  |  | UNCK $\uparrow$ before LDCK $\uparrow$ | 50 |  |  | 50 |  |  |  |
| $t_{h}$ | Hold time | D from LDCK $\downarrow$ | 0 |  |  | 0 |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  | $-55$ |  |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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


[^11]
## SN54LS227, SN54LS228, SN74LS227, SN74LS228 16 X 4 SYNCHRONOUS FIRST-IN FIRST-OUT MEMORIES WITH OPEN-COLLECTOR OUTPUTS

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

| PARAMETER | FROM | TO | TEST CONDITIONS | 'LS227 |  |  | 'LS228 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| tPLH | IRE $\uparrow$ | IR | $\begin{aligned} & R_{L}=2 \mathrm{k} \Omega, \\ & C_{\mathrm{L}}=15 \mathrm{pF}, \\ & \text { See Note } 2 \end{aligned}$ |  | 23 | 35 |  |  |  | ns |
| tPHL | IRE $\downarrow$ | IR |  |  | 9 | 15 |  |  |  | ns |
| tPLH | ORE $\uparrow$ | OR |  |  | 22 | 35 |  |  |  | ns |
| tPHL | ORE $\downarrow$ | OR |  |  | 9 | 15 |  |  |  | ns |
| ${ }^{\text {tPLH }}$ | LDCK $\downarrow$ | IR |  |  | 25 | 40 |  | 25 | 40 | ns |
| tPHL | LDCK $\uparrow$ | IR |  |  | 36 | 50 |  | 36 | 50 | ns |
| tPLH | LDCK $\downarrow$ | OR |  |  | 48 | 70 |  | 48 | 70 | ns |
| tPLH | UNCK $\uparrow$ | OR |  |  | 29 | 45 |  | 29 | 45 | ns |
| ${ }_{\text {tPHL }}$ | UNCK $\downarrow$ | OR |  |  | 28 | 45 |  | 28 | 45 | ns |
| tPLH | UNCK $\uparrow$ | IR |  |  | 49 | 70 |  | 49 | 70 | ns |
| tPLH | CLR $\downarrow$ | IR |  |  | 36 | 55 |  | 36 | 55 | ns |
| tPHL | CLR $\downarrow$ | OR |  |  | 25 | 40 |  | 25 | 40 | ns |
| tPHL | LDCK $\downarrow$ | Q | $\begin{aligned} & R_{\mathrm{L}}=667 \Omega, \\ & C_{\mathrm{L}}=45 \mathrm{pF}, \end{aligned}$ <br> See Note 2 |  | 34 | 50 |  | 34 | 50 | ns |
| tPLH | UNCK $\uparrow$ | Q |  |  | 54 | 80 |  | 54 | 80 | ns |
| tPHL | UNCK $\uparrow$ | Q |  |  | 45 | 70 |  | 45 | 70 | ns |
| tPLH | OE $\downarrow$ | Q |  |  | 21 | 30 |  | 21 | 30 | ns |
| ${ }^{\text {tPHL }}$ | OE $\dagger$ | Q |  |  | 20 | 35 |  | 20 | 35 | ns |

NOTE 2: Load circuits and voltage waveforms are shown in Section 1.
schematics of inputs and outputs

| EQUIVALENT OF CLEAR AND <br> OUTPUT READY ENABLE INPUTS | EQUIVALENT OF <br> OTHER INPUTS | TYPICAL OF INPUT READY AND <br> OUTPUT READY OUTPUTS |
| :---: | :---: | :---: | :---: | :---: |
| TYPICAL OF O OUTPUTS |  |  |

SN54LS222, SN54LS224, SN54LS227, SN54LS228 SN74LS222, SN74LS224, SN74LS227, SN74LS228

## 16 X 4 SYNCHRONOUS FIRST-IN FIRST-OUT MEMORIES

TYPICAL APPLICATIONS INFORMATION
OUTPUT

$\overline{\text { CLR }}$

- Independent Asynchronous Inputs and Outputs
- Organized as $\mathbf{1 6}$-Words of 5 Bits
- DC to $\mathbf{1 0 - M H z}$ Data Rate
- 3-State Data Outputs
- 20-Pin, 300-mil, High-Density Package


## description

This 80-bit active-element memory is a monolithic Schottky-clamped transistortransistor logic (STTL) array organized as 16 words of five-bits each. A memory system using the SN74S225 can easily be expanded in multiples of 16 words or of 5 bits as shown in Figure 2. The three-state outputs controlled by a single enable, $\overline{\mathrm{OE}}$, makes bus connection and multiplexing easy.

## operation

A FIFO is a memory storage device that allows data to be written into and/or read from its array at independent data rates. The 'S225 FIFO will process data at any desired clock rate from DC to 10 MHz . The data is processed in a parallel format, word by word.
Reading or writing is done independently utilizing separate asynchronous data clocks. Data may be written into the array on the low-to-high transition of either load clock input. Data may be read out of the array on the low-to-high transition of the unload clock input (normally high). Writing data into the FIFO may be accomplished in one of two manners: 1) In applications not requiring a gated clock control, best results will be achieved by applying the clock input to one of the clocks while tying the other clock input high. 2) In applications needing a gated clock, the load clock (gate control) must be high in order for the FIFO to load on the next clock pulse. The clock A and B inputs can be used interchangeably for either clock gate control or clock input.
Status of the 'S225 is provided by three outputs. Input ready monitors the status of the last word location and signifies when the memory is full. This output is high whenever the memory is available to accept any data. The unload clock output also monitors the last word location. This output generates a low-logiclevel pulse (synchronized to the internal clock pulse) when the location is vacant. The third status output, output ready, is high when the first word location contains valid data and unload clock input is high. When unload clock input goes low, output ready will go low and stay low until new valid data is in the first word position. The first word location is defined as the location from which data is provided to the outputs.
The data outputs are noninverted with respect to the data inputs and are three-state with a common control input, output enable. When output enable is low, the data outputs are enabled to function as totem-pole outputs. A high-logic-level forces each data output to a high-impedance state while all other inputs and outputs remain active.

The clear input invalidates all data stored in the memory array by clearing the control logic and setting output ready to a low-logic-level on the high-to-low transition of a low-active pulse.

## $16 \times 5$ ASYNCHRONOUS FIRST-IN FIRST-OUT MEMORY

TABLE 1 INPUT FUNCTIONS

| Input | Pin | Description |
| :--- | ---: | :--- |
| CLK A | 1 | Load Clock A |
| DO-D4 | $4-8$ | Data Inputs |
| $\overline{\text { OE }}$ | 9 | Output Enable |
| UNCK IN | 16 | Unload Clock |
| $\overline{\text { CLR }}$ | 18 | Clear |
| CLK B | 19 | Load Clock B |
| GND | 10 | Ground pin |
| $V_{C C}$ | 20 | Supply Voltage |

TABLE 2 OUTPUT FUNCTIONS

| Output | Pin | Description |
| :--- | :---: | :--- |
| IR | 2 | Input Ready |
| UNCK OUT | 3 | Unload Clock |
| Q4-DO | $11-15$ | Data Outputs |
| OR | 17 | Output Ready |

schematics of inputs and outputs

logic symbol ${ }^{\dagger}$


[^12]
## functional block diagram



```
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, VCC (see Note 1) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Input voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5. 5 V
Off-state output voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5. 5. 5 V
Operating free-air temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 000
```



NOTE 1: All voltage values are with respect to network ground terminal.
recommended operating conditions

|  |  |  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage |  | 4.75 | 5 | 5.25 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 | V |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | High-level output current | Q outputs |  |  | -6.5 | mA |
|  |  | All other outputs |  |  | -3.2 |  |
| ${ }^{\mathrm{I}} \mathrm{OL}$ | Low-level output current | Q outputs |  |  | 16 | mA |
|  |  | All other outputs |  |  | 8 |  |
| $t_{w}$ | Pulse duration | CLK A or CLK B (high) | 25 |  |  | ns |
|  |  | UNCK IN (low) | 7 |  |  |  |
|  |  | $\overline{\text { CLR }}$ (low) | 40 |  |  |  |
| ${ }^{\text {t }}$ su | Setup time before CLK A $\uparrow$ or CLK $\mathrm{B} \uparrow$ | Data (See Note 2) | -20 |  |  | ns |
|  |  | $\overline{\text { CLR }}$ inactive | 25 |  |  |  |
| $t_{\text {h }}$ | Hold time after CLK A $\uparrow$ or CLK B $\uparrow$ |  | 70 |  |  | ns |
| TA | Operating free-air temperature |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

NOTE 2: Data must be setup within 20 ns after the load clock positive transition.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS | MIN | TYP ${ }^{\dagger}$ MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIK |  | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}=-18 \mathrm{~mA}$ |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Q | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}^{\mathrm{OH}}=-6.5 \mathrm{~mA}$ | 2.4 | 2.9 | V |
|  | All others | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-3.2 \mathrm{~mA}$ | 2.4 | 2.9 |  |
| $\mathrm{VOL}^{\text {O }}$ | Q | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | $0.35 \quad 0.5$ | V |
|  | All others | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{l}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  | $0.35 \quad 0.5$ |  |
| 1 OZH |  | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  | 50 | $\mu \mathrm{A}$ |
| IOZL |  | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  | -50 | $\mu \mathrm{A}$ |
| I |  | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{1}=5.5 \mathrm{~V}$ |  | 1 | mA |
| ${ }^{1} \mathrm{H}$ | Data | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{1}=2.7 \mathrm{~V}$ |  | 40 | $\mu \mathrm{A}$ |
|  | All others |  |  | 25 |  |
| IIL | Data | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{1}=0.5 \mathrm{~V}$ |  | -1 | mA |
|  | All others |  |  | $-0.25$ |  |
| 'os ${ }^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0 \mathrm{~V}$ | $-30$ | -100 | mA |
| ICC |  | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$, (See Note 3) |  | $80 \quad 120$ | mA |

[^13]switching characteristics over recommended operating ranges of $T_{A}$ and $V_{C C}$ (unless otherwise noted)

| PARAMETERS ${ }^{\dagger}$ | FROM | TO | TEST CONDITIONS | MIN | TYP ${ }^{\ddagger}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $f_{\text {max }}$ | CLK A |  | $\begin{gathered} C_{L}=30 \mathrm{pF} \\ \text { See Note } 4 \end{gathered}$ | 10 | 20 |  | MHZ |
| $f_{\text {max }}$ | CLK B |  |  | 10 | 20 |  | MHz |
| $f_{\text {max }}$ | UNCK IN |  |  | 10 | 20 |  | MHz |
| ${ }^{\text {t }}$ w | UNCK OUT |  |  | 7 | 14 |  | ns |
| ${ }^{\text {t }}$ dis | $\overline{O E}$ | Any Q | $C_{L}=5 \mathrm{pF}$ |  | 10 | 25 | ns |
| $t_{\text {en }}$ |  |  | $C_{L}=30 \mathrm{pF}$ <br> See Note 4 |  | 25 | 40 |  |
| ${ }^{\text {tPLH }}$ | UNCK IN | Any Q |  |  | 50 | 75 | ns |
| tPHL |  |  |  |  | 50 | 75 |  |
| tPLH | $\begin{gathered} \text { CLK A } \\ \text { or } \\ \text { CLK B } \end{gathered}$ | OR |  |  | 190 | 300 | ns |
| $t_{\text {PLH }}$ | UNCK IN | OR |  |  | 40 | 60 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  |  | 30 | 45 |  |
| ${ }^{\text {tPHL }}$ | $\overline{\text { CLR }}$ | OR |  |  | 35 | 60 | ns |
| ${ }^{\text {tPHL }}$ | $\begin{gathered} \hline \text { CLK A } \\ \text { or } \\ \text { CLK B } \end{gathered}$ | UNCK OUT |  |  | 25 | 45 | ns |
| ${ }_{\text {tPHL }}$ | UNCK IN | UNCK OUT |  |  | 270 | 400 | ns |
| tPHL | $\begin{aligned} & \hline \text { CLK A } \\ & \text { or } \\ & \text { CLK B } . \end{aligned}$ | IR |  |  | 55 | 75 | ns |
| tPLH | UNCK IN | IR |  |  | 255 | 400 | ns |
| ${ }^{\text {tPLH }}$ | $\overline{\text { CLR }}$ | IR |  |  | 16 | 35 | ns |
| ${ }^{\text {tPLH }}$ | OR $\uparrow$ | Any Q |  |  | 10 | 20 | ns |

${ }^{t^{\prime}}{ }_{\text {max }} \equiv$ maximum clock frequency
$t_{w} \equiv$ pulse width (output)
$1 \downarrow \equiv$ The arrow indicates that the low-to-high (1) or high-to-low ( $\downarrow$ ) transition of the output ready (OR) output is used for reference.
tPLH $\equiv$ propagation delay time, low-to-high-level output.
tPHL $\equiv$ propagation delay time, high-to-low-level output.
$\ddagger_{\text {All typical values are at }} \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
NOTE 4: Load circuit and voltage waveforms are shown in Section 1.

TYPICAL WAVEFORMS FOR A 16-WORD FIFO


FIGURE 1. TYPICAL WAVEFORMS FOR A 16-WORD FIFO


FIGURE 2. EXPANDING THE 'S225 FIFO (48 WORDS OF 10 BITS SHOWN)

## SN54ALS229A, SN74ALS229A $16 \times 5$ ASYNCHRONOUS FIRST.IN FIRST-OUT MEMORIES

D2876, MARCH 1986-REVISED APRIL 1986

- Independent Asychronous Inputs and Outputs
- 16 Words by 5 Bits Each
- Data Rates from 0 to $30 \mathbf{M H z}$
- Fall-Through Time . . . 24 ns Typ
- 3-State Outputs


## description

These 80-bit memories utilize Advanced LowPower Schottky technology and feature high speed and fast fall-through times. They are organized as 16 words by 5 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 25 megahertz 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 will 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 EMPTY +2 output flags. The FULL output will be low whenever the memory is full, and high whenever not full. The $\overline{F U L L-2}$ output will be low whenever the memory contains 14 data words. The EMPTY output will be low whenever the memory is empty, and high whenever it is not empty. The EMPTY +2 output will be low whenever 2 words remain in memory.
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 $\overline{\text { FULL }}, \overline{F U L L}-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 $\overline{\operatorname{RST}}$ pulse or from an empty condition, will cause 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.

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


${ }^{\dagger}$ This symbot 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)


## SN54ALS229A, SN74ALS229A

## $16 \times 5$ ASYNCHRONOUS FIRST.IN FIRST.OUT MEMORIES

timing diagram

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
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: SN54ALS229A . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
SN74ALS229A . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range
$-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended operating conditions


## SN54ALS229A, SN74ALS229A $16 \times 5$ ASYNCHRONOUS FIRST-IN FIRST-OUT MEMORIES

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

| PARAMETER |  | TEST CONDITIONS |  | SN54ALS229A |  |  | SN74ALS229A |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\text { }}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Status flags | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{l}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  | Q outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ | 2.4 | 3.3 |  |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-2.6 \mathrm{~mA}$ |  |  |  | 2.43 .2 |  |  |  |
| VOL | Q outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | $\mathrm{IOL}^{\text {O }}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | $v$ |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OL}}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | Status flags | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OL}}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| Iozh |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IozL |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -20 |  |  | -20 |  |
| 1 |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| IIH |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| ILL |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.2 |  |  | -0.2 | mA |
| $10^{\ddagger}$ |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | $-30$ |  | -112 | mA |
| ICC |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  | $95 \quad 150$ |  |  | $95 \quad 140$ |  |  | mA |

${ }^{\dagger}$ All typical values are at $V_{C C}=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.
switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathbf{C}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R1}=500 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \text { 'ALS229A } \end{aligned}$ |  |  | $\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 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | SN54ALS229A |  | SN74ALS229A |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {max }}$ | LDCK |  |  |  |  | 25 |  | 30 |  | MHz |
|  | UNCK |  |  |  |  | 25 |  | 30 |  |  |
| $t_{\text {pd }}$ | LDCK $\uparrow$ | Any Q |  | 24 | 47 | 7 | 54 | 7 | 50 | ns |
| ${ }_{\text {tpd }}$ | UNCK $\uparrow$ | Any Q |  | 19 | 29 | 9 | 35 | 9 | 33 | ns |
| tPLH | LDCK $\uparrow$ | EMPTY |  | 18 | 26 | 9 | 32 | 9 | 30 | ns |
| tpHL | UNCK $\uparrow$ | EMPTY |  | 18 | 25 | 9 | 32 | 9 | 29 | ns |
| ${ }_{\text {tPHL }}$ | $\overline{\text { RST }} \downarrow$ | EMPTY |  | 15 | 21 | 6 | 26 | 6 | 24 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | LDCK $\uparrow$ | EMPTY + 2 |  | 23 | 33 | 10 | 40 | 10 | 38 | ns |
| ${ }_{\text {tpd }}$ | UNCK $\dagger$ | EMPTY +2 |  | 20 | 29 | 9 | 38 | 9 | 35 | ns |
| ${ }^{\text {tpLH }}$ | RST $\downarrow$ | EMPTY +2 |  | 20 | 28 | 9 | 35 | 9 | 33 | ns |
| ${ }^{\text {p }}$ d | LDCK $\uparrow$ | FULL-2 |  | 23 | 33 | 10 | 40 | 10 | 38 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | UNCK $\uparrow$ | FULL-2 |  | 20 | 29 | 9 | 38 | 9 | 35 | ns |
| tPLH | $\overline{\text { RST }} \downarrow$ | FULL-2 |  | 20 | 28 | 9 | 35 | 9 | 33 | ns |
| tpHL | LDCK $\uparrow$ | FULL |  | 21 | 28 | 10 | 35 | 10 | 33 | ns |
| tPLH | UNCK $\uparrow$ | FULL |  | 17 | 23 | 8 | 29 | 8 | 27 | ns |
| tPLH | $\overline{\text { RST }} \downarrow$ | FULL |  | 18 | 27 | 8 | 33 | 8 | 31 | ns |
| ${ }_{\text {t }}{ }^{\text {d }}$ | OE $\uparrow$ | Q |  | 8 | 13 | 1 | 16 | 2 | 15 | ns |
| $\mathrm{t}_{\text {dis }}$ | OE $\downarrow$ | Q |  | 8 | 14 | 2 | 20 | 2 | 17 | ns |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN54ALS232A, SN74ALS232A $16 \times 4$ ASYNCHRONOUS FIRST.IN FIRST.OUT MEMORIES

D2876, OCTOBER 1985-REVISED APRIL 1986

## - Independent Asynchronous Inputs and

 Outputs- 16 Words by 4 Bits Each
- Data Rates From 0 to $\mathbf{3 0} \mathbf{~ M H z}$
- Fall-Through Time . . . 24 ns Typ
- 3-State Outputs


## description

These 64-bit memories use Advanced LowPower Schottky technology and feature high speed and fast fall-through times. They are 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. These FIFOs are designed to process data at rates from 0 to 25 megahertz 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.

(TOP VIEW)


SN54ALS232A . . . FK PACKAGE SN74ALS232A . . . FN PACKAGE (TOP VIEW)


NC - No internal connection.

Status of the FIFO memory is monitored by the $\overline{\text { FULL }}$ and EMPTY output flags. The $\overline{\text { 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{\text { EMPTY }}$ low and sets $\overline{F U L L}$ 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, will cause 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 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.
logic symbol ${ }^{\dagger}$

$\dagger_{\text {This symbol is in accordance with ANSI/IEEE Standard 91-1984 and IEC Publication 617-12. The symbol is functionally accurate but }}^{\text {6 }}$ 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 $\mathrm{D}, \mathrm{J}$, and N packages.

## timing diagram


absolute maximum ratings over operating free-air temperature (unless otherwise noted)

| Supply voltage, $\mathrm{V}_{\text {CC }}$ | V |
| :---: | :---: |
| Input voltage | 7 V |
| Voltage applied to a disabled 3-state output | 5.5 V |
| Operating free-air temperature range: SN54ALS232A | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
| SN74ALS232A | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions


SN54ALS232A, SN74ALS232A $16 \times 4$ ASYNCHRONOUS FIRST-IN FIRST-OUT MEMORIES
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54ALS232A |  |  | SN74ALS232A |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\prime}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | FULL, EMPTY | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  | Q outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOH}^{\prime}=-1 \mathrm{~mA}$ | 2.43 .3 |  |  |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOH}=-2.6 \mathrm{~mA}$ |  |  |  | 2.4 | 3.2 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Q outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | FULL, EMPTY | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| IOZH |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IozL |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -20 |  |  | -20 | $\mu \mathrm{A}$ |
| 1 |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| 1 H |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IIL |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.2 |  |  | -0.2 | mA |
| $10^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ICC |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ |  |  | 75 | 125 |  | 75 | 125 | 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, los.
switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathbf{V}_{\mathbf{C C}}=5 \mathrm{~V}, \\ & \mathbf{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathbf{A}}=25^{\circ} \mathrm{C} \\ & \hline{ }^{\prime} \text { ALS232A } \\ & \hline \end{aligned}$ |  |  | $\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 \Omega, \\ & \mathrm{~T}_{\mathbf{A}}=\text { MIN to MAX } \\ & \hline \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | SN54ALS232A |  | SN74ALS232A |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | LDCK |  | 40 |  |  | 25 |  | 30 |  | MHz |
|  | UNCK |  | 40 |  |  | 25 |  | 30 |  |  |
| $t_{\text {pd }}$ | LDCK $\uparrow$ | Any 0 |  | 30 | 40 | 4 | 50 | 4 | 46 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | UNCK $\uparrow$ | Any 0 |  | 20 | 27 | 7 | 35 | 7 | 31 | ns |
| ${ }^{\text {tPLH }}$ | LDCK $\uparrow$ | EMPTY |  | 17 | 23 | 8 | 29 | 8 | 26 | ns |
| tpHL | UNCK $\uparrow$ | EMPTY |  | 19 | 24 | 10 | 36 | 10 | 29 | ns |
| ${ }_{\text {tPHL }}$ | $\overline{\mathrm{RST}} \downarrow$ | EMPTY |  | 13 | 18 | 5 | 23 | 5 | 20 | ns |
| tpHL | LDCK $\uparrow$ | FULL |  | 21 | 26 | 10 | 35 | 10 | 31 | ns |
| tPLH | UNCK $\uparrow$ | FULL |  | 17 | 23 | 8 | 28 | 8 | 25 | ns |
| tPLH | $\overline{\text { RST }} \downarrow$ | FULL |  | 18 | 24 | 8 | 31 | 8 | 28 | ns |
| $\mathrm{t}_{\text {en }}$ | OE¢ | 0 |  | 7 | 12 | 1 | 16 | 1 | 14 | ns |
| $\mathrm{t}_{\text {dis }}$ | OE $\downarrow$ | 0 |  | 10 | 16 | 2 | 23 | 2 | 21 | ns |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN54ALS233A, SN74ALS233A $16 \times 5$ ASYNCHRONOUS FIRST-IN FIRST-OUT MEMORIES

D2876, JANUARY 1986-REVISED APRIL 1986

- Independent Asychronous Inputs and Outputs
- 16 Words by 5 Bits Each
- Data Rates from 0 to $\mathbf{3 0} \mathbf{~ M H z}$
- Fall-Through Time . . . 24 ns Typ
- 3-State Outputs


## description

These 80-bit memories utilize Advanced LowPower Schottky technology and feature high speed and fast fall-through times. They are organized as 16 words by 5 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 25 megahertz 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 will have no effect. When the memory is empty, UNCK signals have no effect.

Status of the FIFO memory is monitored by the $\overline{F U L L}, \overline{\mathrm{EMPTY}}, \overline{\mathrm{FULL}-1}$, and EMPTY +1 output flags. The FULL output will be low whenever the memory is full, and high whenever not full. The $\overline{F U L L}-1$ output will be low whenever the memory contains 15 data words. The EMPTY output will be low whenever the memory is empty, and high whenever it is not empty. The EMPTY +1 output will be low whenever one word remains in memory.

SN54ALS233A . . . J PACKAGE
SN74ALS233A . . . DW OR N PACKAGE
(TOP VIEW)

| OE | 1.20 | $V_{C C}$ |
| :---: | :---: | :---: |
| $\overline{\text { FULL-1 }}$ | 2.19 | EMPTY +1 |
| $\overline{\text { FULL }}$ | 318 | UNCK |
| LDCK | 417 | EMPTY |
| DO | 516 | Q0 |
|  | $6 \quad 15$ | Q1 |
|  | 714 | Q2 |
|  | 813 | Q3 |
|  | $9 \quad 12$ | Q4 |
| GND | 10 | $\overline{\mathrm{RST}}$ |

SN54ALS233A . . . FK PACKAGE SN74ALS233A . . . FN PACKAGE (TOP VIEW)


## 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)


## SN54ALS233A, SN74ALS233A $16 \times 5$ ASYNCHRONOUS FIRST.IN FIRST-OUT MEMORIES

timing diagram

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
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: SN54ALS233A . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
SN74ALS233A . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended operating conditions

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


[^14]switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathbf{C C}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline{ }^{\prime} \text { ALS233A } \end{aligned}$ |  |  | $\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 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=-\mathrm{MIN} \text { to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | SN54ALS233A |  | SN74ALS233A |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ | LDCK |  | 40 |  |  | 25 |  | 30 |  | MHz |
|  | UNCK |  | 40 |  |  | 25 |  | 30 |  |  |
| $\mathrm{t}_{\mathrm{pd}}$ | LDCK $\uparrow$ | Any Q |  | 24 | 44 | 7 | 52 | 7 | 48 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | UNCK $\uparrow$ | Any Q |  | 19 | 29 | 9 | 35 | 9 | 33 | ns |
| tPLH | LDCK $\uparrow$ | EMPTY |  | 18 | 25 | 9 | 30 | 9 | 28 | ns |
| tPHL | UNCK $\uparrow$ | EMPTY |  | 18 | 25 | 9 | 33 | 10 | 30 | ns |
| tPHL | $\overline{\mathrm{RST}} \downarrow$ | EMPTY |  | 13 | 19 | 6 | 24 | 6 | 22 | ns |
| ${ }^{\text {tpd }}$ | LDCK $\uparrow$ | EMPTY +1 |  | 22 | 31 | 10 | 40 | 10 | 37 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | UNCK $\uparrow$ | EMPTY + 1 |  | 22 | 31 | 9 | 40 | 10 | 37 | ns |
| tPLH | $\overline{\mathrm{RST}} \downarrow$ | EMPTY + 1 |  | 19 | 27 | 8 | 32 | 8 | 31 | ns |
| ${ }^{\text {tpd }}$ | LDCK $\uparrow$ | FULL-1. |  | 23 | 32 | 11 | 38 | 12 | 36 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | UNCK $\uparrow$ | $\overline{\text { FULL - } 1}$ |  | 23 | 32 | 11. | 39 | 12 | 36 | ns |
| tpLH | RST $\downarrow$ | FULL-1 |  | 20 | 28 | 10 | 34 | 11 | 32 | ns |
| tPHL | LDCK $\uparrow$ | FULL |  | 21 | 28 | 10 | 35 | 12 | 33 | ns |
| tPLH | UNCK $\uparrow$ | FULL |  | 17 | 24 | 8 | 29 | 9 | 27 | ns |
| tPLH | $\overline{\mathrm{RST}} \downarrow$ | FULL |  | 18 | 27 | 8 | 32 | 9 | 30 | ns |
| $\mathrm{t}_{\text {en }}$ | OE¢ | Q |  | 8 | 13 | 1 | 16 | 2 | 15 | ns |
| $\mathrm{t}_{\text {dis }}$ | OE $\downarrow$ | 0 |  | 8 | 12 | 2 | 20 | 2 | 17 | ns |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

- 4-Line to 1-Line Multiplexer that can Select 1 and 16 Data Inputs
- Applications:


## Boolean Function Generator

Parallel-to-Serial Converter
Data Source Selector

- Buffered 3-State Bus Driver Inputs Permit Multiplexing from N Lines to One Line
- Dependable Texas Instruments Quality and Reliability


## description

The 'AS250 provides full binary decoding to select one of sixteen data sources with an inverting $\bar{W}$ output. The selected sources are buffered with symmetrical propagation delay times. This reduces the possibility of transients occurring at the output.

A buffered enable output ( $\bar{G}$ ) may be used for $n$-line-to-one-line cascading. Taking the $\bar{G}$ high will place the output in a high-impedance state. In the high-impedance state, the output neither loads nor drives the bus lines significantly.

The enable $(\bar{G})$ does not affect the internal operations of the data selector/multiplexer. New data can be set up while the outputs are disabled.

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

SN74AS250 . . . DW OR NT PACKAGE
(TOP VIEW)


NC-No internal connection

## SN74AS250

## 1-0F-16 DATA GENERATORS/MULTIPLEXERS <br> WITH 3-STATE OUTPUTS

logic symbol ${ }^{\dagger}$

2
LSI Devices
logic diagram (positive logic)


FUNCTION TABLE

| INPUT |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { G }}$ | A | B | C | D | Ei | W $\overline{\text { W }}$ |
| L | L | L | L | L | EO | EO |
| L | H | L | L | L | E1 | E1 |
| L | L | H | L | L | E2 | E2 |
| L | H | H | L | L | E3 | E3 |
| L | L | L | H | L | E4 | E4 |
| L | H | L | H | L | E5 | E5 |
| L | L | H | H | L | E6 | E6 |
| L | H | H | H | L | E7 | E7 |
| L | L | L | L | H | E8 | E8 |
| L | H | L | L | H | E9 | E9 |
| L | L | H | L | H | E10 | E10 |
| L | H | H | L | H | E11 | E11 |
| L | L | L | H | H | E12 | E12 |
| L | H | L | H | H | E13 | E13 |
| L | L | H | H | H | E14 | E14 |
| H | X | X | X | H | E15 | E15 |
| X | X | Z |  |  |  |  |

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, VCC
Input voltage
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 |
| :--- | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | Mupply voltage | 4.5 | 5 |
| $\mathrm{~V}_{\text {IH }}$ | High-level input voltage | 5.5 | V |
| $\mathrm{~V}_{\text {IL }}$ | Low-level input voltage | 2 |  |
| $\mathrm{I}_{\mathrm{OH}}$ | High-level output current | V |  |
| $\mathrm{I}_{\mathrm{OL}}$ | Low-level output current | 0.8 | V |
| $\mathrm{~T}_{\mathrm{A}}$ | Operating free-air temperature | -15 | mA |

SN74AS250

## 1-0F-16 DATA GENERATORS/MULTIPLEXERS WITH 3-STATE OUTPUTS

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

| PARAMETER | TEST CONDITIONS |  | MIN | TYP ${ }^{\dagger}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IK }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $I_{1}=-18 \mathrm{~mA}$ |  |  | $-1.2$ | V |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{OH}}=-15 \mathrm{~mA}$ |  | 2.4 | 3.3 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{\text {O }}=48 \mathrm{~mA}$ |  | 0.35 | 0.5 | V |
| IOZH | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
| IOZL | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -50 | $\mu \mathrm{A}$ |
| 1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 | mA |
| $\mathrm{IIH}^{\text {H }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| IIL | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.5 | mA |
| $10^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | $-30$ |  | -112 | mA |
| ${ }^{1} \mathrm{CC}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | Outputs high |  | 26 | 42 | mA |
|  |  | Outputs low |  | 31 | 50 |  |
|  |  | Outputs disabled |  | 30 | 48 |  |

${ }^{\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 (see Note 1)

| PARAMETER | FROM (INPUT) | то (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 \Omega, \\ & \mathrm{R} 2=500 \Omega \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \end{aligned}$ | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN TYP ${ }^{\dagger}$ MAX |  |
| ${ }^{\text {tPLH }}$ | DATA | $\bar{W}$ | 3 8 | ns |
| tPHL |  |  | $2 \quad 6$ |  |
| tPLH | SELECT | W | 4 13 | ns |
| tPHL |  |  | 4 10 |  |
| tPZH | $\overline{\mathrm{G}}$ | $\overline{\text { w }}$ | $2 \quad 7$ | ns |
| tPZL |  |  | 4 20 |  |
| tPHZ | $\overline{\mathrm{G}}$ | $\bar{W}$ | $2 \quad 6$ | ns |
| tPLZ |  |  | $2 \quad 6$ |  |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

- Generates Either Odd or Even Parity for Nine Data Lines
- Cascadable for $n$-Bits Parity
- Can Be Used to Upgrade Existing Systems Using MSI Parity Circuits
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These universal, monolithic, nine-bit parity generators/checkers utilize Advanced Schottky high-performance circuitry and feature odd and even outputs to facilitate operation of either odd or even parity application. The word-length capability is easily expanded by cascading.

These devices can be used to upgrade the performance of most systems utilizing the '180 parity generator/checker. Although the 'ALS280 and 'AS280 are implemented without expander inputs, the corresponding function is provided by the availability of an input at pin 4 and the absence of any internal connection at pin 3. This permits the 'ALS280 and 'AS280 to be substituted for the '180 in existing designs to produce an identical function even if the devices are mixed with existing '180's.
All 'AS280 inputs are buffered to lower the drive requirements.

The SN54' family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.


SN54ALS280, SN54AS280 . . . FK PACKAGE SN74ALS280, SN74AS280 . . . FN PACKAGE (TOP VIEW)


NC - No internal connection

FUNCTION TABLE

| NUMBER OF INPUTS A | OUTPUTS |  |
| :---: | :---: | :---: |
|  | $\Sigma$ EVEN | $\Sigma$ ODD |
| $0,2,4,6,8$ | H | L |
| $1,3,5,7,9$ | L | H |

logic symbol ${ }^{\dagger}$


[^15]
## SN54ALS280, SN74ALS280 9-BIT PARITY GENERATORS/CHECKERS

logic diagram



ODD

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

```
Supply voltage, VCC7 V
Input voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . }7\mathrm{ V
```



```
    SN74ALS280 . . . . . . . . . . . . . . . . . . . . . . . . 0 }\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to 70}\mp@subsup{}{}{\circ}\textrm{C
Storage temperature range
    -65 %}\textrm{C}\mathrm{ to }15\mp@subsup{0}{}{\circ}\textrm{C
```

recommended operating conditions

|  | SN54ALS280 |  |  | SN74ALS280 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC }}$ Supply voltage | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ High-level input voltage | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ High-level output current |  |  | -1 |  |  | -2.6 | mA |
| IOL Low-level output current |  |  | 12 |  |  | 24 | mA |
| $\mathrm{T}_{\mathrm{A}}$ Operating free-air temperature | $-55$ |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

## SN54ALS280, SN74ALS280 9-BIT PARITY GENERATORS/CHECKERS

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, IOS.
switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \text { ALS280 } \end{aligned}$ |  |  | $\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}_{\mathrm{L}}=500 \Omega \\ & \mathrm{~T}_{\mathrm{A}}=\mathrm{MIN} \text { to } \mathrm{MAX} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 280 | SN |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {tPLH}}$ | Any | $\Sigma$ Even |  | 12 | 16 | 3 | 24 | 3 | 20 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  | 12 | 17 | 3 | 24 | 3 | 20 |  |
| tPLH | Any | $\Sigma$ Odd |  | 12 | 16 | 3 | 24 | 3 | 20 | ns |
| tPHL |  |  |  | 13 | 18 | 4 | 26 | 4 | 22 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.
logic diagram

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ |  | 7 V |
| :---: | :---: | :---: |
| Input voltage |  | 7 V |
| Operating free-air temperature range: | SN54AS280 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
|  | SN74AS280 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range |  | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions

|  | SN54AS280 |  |  | SN74AS280 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC }}$ Supply voltage | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ High-level input voltage | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| $\mathrm{I}^{\mathrm{OH}}$ High-level output current |  |  | -2 |  |  | -2 | mA |
| IOL Low-level output current |  |  | 20 |  |  | 20 | mA |
| $\mathrm{T}_{\text {A }}$ Operating free-air temperature | $-55$ |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

SN54AS280, SN74AS280 9-BIT PARITY GENERATORS/CHECKERS
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER | TEST CONDITIONS | SN54AS280 |  |  | SN74AS280 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\text {t }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \\|=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V , $1 \mathrm{OH}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}{ }^{-2}$ |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{OL}=20 \mathrm{~mA}$ |  | 0.35 | 0.5 |  | 0.35 | 0.5 | V |
| $1 /$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| $\mathrm{IIH}^{\text {H }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IL | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.5 |  |  | -0.5 | mA |
| $\mathrm{I}^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | $-30$ |  | -112 | mA |
| ${ }^{1} \mathrm{C}$ | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$ |  | 25 | 40 |  | 25 | 35 | 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.

## switching characteristics (see Note 1)

| PARAMETER | 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}_{\mathrm{L}}=500 \Omega \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS280 |  | SN74AS280 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| tPLH | Any | $\Sigma$ Even | 3 | 13 | 3 | 12 | ns |
| ${ }_{\text {t PHL }}$ |  |  | 3 | 12.5 | 3 | 11 |  |
| tPLH | Any | $\Sigma$ Odd | 3 | 13 | 3 | 12 | ns |
| ${ }_{\text {t PHL }}$ |  |  | 3 | 12.5 | 3 | 11.5 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

SN54ALS280, SN54AS280, SN74ALS280, SN74AS280 9-BIT PARITY GENERATORS/CHECKERS

## TXPICAL APPLICATION DATA

25-LINE PARITY/GENERATOR CHECKER


Three 'ALS280/'AS280 can be used to implement a 25 -line parity generator/checker.

As an alternative, the $\Sigma$ ODD outputs of two or three parity generators/checkers can be decoded with a 2-input ('S86 or 'LS86) or 3 -input ('S135) exclusive-OR gate for 18 - or 27 -line parity applications.

81-LINE PARITY/GENERATOR CHECKER


Longer word lengths can be implemented by cascading 'ALS280/'AS280. As shown here, parity can be generated for word lengths up to 81 bits.

- Generates Either Odd or Even Parity for Nine Data Lines
- Cascadable for n-Bits Parity
- Direct Bus Connection for Parity Generation or for Checking by Using the Parity I/O Port
- Glitch-Free Bus During Power Up/Down
- Package Options Include both Plastic and Ceramic Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

The SN54AS286 and SN74AS286 universal nine-bit parity generators/checkers feature a local output for parity checking and a 48-milliampere bus-driving parity I/O port for parity generation/checking. The word-length capability is easily expanded by cascading.
The XMIT control input is implemented specifically to accommodate cascading. When $\overline{\text { XMIT }}$ is low the parity tree is disabled and PE will remain at a high logic level regardless of the input levels. When XMIT is high the parity tree is enabled. The Parity Error output will indicate a parity error when either an even number of inputs (A through I) are high and Parity I/O is forced to a low logic level, or when an odd number of inputs are high and Parity $1 / O$ is forced to a high logic level.

The I/O control circuitry was designed so that the I/O port will remain in the high-impedance state during power-up or power-down to prevent bus glitches.

The SN54AS286 is characterized for operation over the full military range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS286 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

FUNCTION TABLE

| NUMBER OF INPUTS <br> (A THRU I) THAT <br> ARE HIGH | $\overline{\text { XMIT }}$ | PARITY <br> I/O | PARITY <br> ERROR |
| :---: | :---: | :---: | :---: |
| $0,2,4,6,8$ | l | H | H |
| $1,3,5,7,9$ | l | L | H |
| $0,2,4,6,8$ | h | h | H |
|  | h | l | L |
| $1,3,5,7,9$ | h | h | L |
|  | l | H |  |

> h - high input level

I- low input level
H - high output level L - low output level
logic symbol ${ }^{\dagger}$
logic diagram (positive logic)

${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers shown are for $\mathrm{D}, \mathrm{J}$, and N packages.
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: SN54AS286 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
| SN74AS286 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature | $-65^{\circ} \mathrm{C}$ to $140^{\circ} \mathrm{C}$ |

recommended operating conditions

|  |  |  | SN54AS286 |  |  | SN74AS286 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| I | High-level output current | Parity error |  |  | -2 |  |  | -2 | mA |
| O | High-level output current | Parity 1/O |  |  | -12 |  |  | -15 |  |
| IOL | Low-level output current | Parity error |  |  | 20 |  |  | 20 | mA |
|  |  | Parity I/O |  |  | 32 |  |  | 48 |  |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  | $-55$ |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

SN54AS286, SN74AS286 9-BIT PARITY GENERATORS/CHECKER WITH BUS DRIVER PARITY I/O PORT
electrical characteristics over recommended free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54AS286 |  |  | SN74AS286 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $Y_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | All outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ |  | $\mathrm{v}_{\mathrm{CC}}{ }^{-2}$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  | Parity 1/0 | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.4 | 2.9 |  | 2.43 |  | 3 |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-12 \mathrm{~mA}$ | 2.4 |  |  |  |  |  |  |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-15 \mathrm{~mA}$ |  |  |  | 2.5 |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Parity error | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=20 \mathrm{~mA}$ |  | 0.35 | 0.5 |  | 0.35 | 0.5 | V |
|  | Parity I/O | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=32 \mathrm{~mA}$ |  |  | 0.5 |  |  |  |  |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=48 \mathrm{~mA}$ |  |  |  |  |  | 0.5 |  |
| I | Parity 1/O | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | All other inputs | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| ${ }_{\text {IH }}$ | Parity 1/0 ${ }^{\ddagger}$ | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
|  | All other inputs |  |  |  |  | 20 |  |  | 20 |  |
| ILL | Parity 1/0 ${ }^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | 0.5 |  |  | -0.5 | mA |
|  | All other inputs |  |  |  |  | 0.5 |  |  | -0.5 |  |
| $10^{5}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 | -112 |  | -30 | -112 |  | mA |
| ICC | Transmit | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  |  | 30 | 43 |  | 30 | 43 | mA |
|  | Receive |  |  |  | 35 | 50 |  | 35 | 50 |  |

${ }^{\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 $I_{I H}$ and $I_{I L}$ include the off-state current.
${ }^{\S}$ 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 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathbf{C C}}=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}_{\mathbf{A}}=\text { MIN to } \mathrm{MAX} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS286 |  | SN74AS286 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| tPLH | Any A thru 1 | Parity I/O | 3 | 17 | 3 | 15 | ns |
| tPHL |  |  | 3 | 15 | 3 | 14 |  |
| ${ }_{\text {tPLH }}$ | Any A thru I | Parity error | 3 | 20 | 3 | 16.5 | ns |
| tPHL' |  |  | 3 | 18 | 3 | 16.5 |  |
| tPLH | Parity I/O | Parity error | 3 | 10 | 3 | 9 | ns |
| tPHL |  |  | 3 | 10 | 3 | 9 |  |
| tPZH | $\overline{\text { XMIT }}$ | Parity 1/0 | 3 | 14 | 3 | 13 | ns |
| tPZL |  |  | 3 | 17 | 3 | 16 |  |
| tPHZ |  |  | 3 | 13 | 3 | 11.5 |  |
| tPLZ |  |  | 3 | 11 | 3 | 10 |  |

NOTE 1: Load circuit and voltage waveforms ar shown in Section 1.

SN54AS286, SN74AS286
9-BIT PARITY GENERATORS/CHECKER
WITH BUS DRIVER PARITY I/O PORT

TYPICAL APPLICATION DATA


FIGURE 1. 32-BIT PARITY GENERATOR/CHECKER

Figure 1 shows a 32 -bit parity generator/checker with output polarity-switching, parity error detection, and parity on every byte.

TYPICAL APPLICATION DATA


In Figure 2, a 90-bit parity generator/checker with the $\overline{\text { XMIT }}$ on the last stage is available for use with parity detection.

- Expands 4 Address Lines to 12 Address Lines
- Designed for Paged Memory Mapping
- Output Latches Provided on 'LS610 and 'LS611
- Choice of 3-State or Open-Collector Map Outputs
- Compatible with TMS9900 and Other Microprocessors

| DEVICE | OUTPUTS <br> LATCHED | MAP <br> OUTPUT TYPE |
| :---: | :---: | :---: |
| 'LS610 | Yes | 3-State |
| 'LS611 | Yes | Open-Collector |
| 'LS612 | No | 3-State |
| 'LS613 | No | Open-Collector |

## description

Each 'LS610 through 'LS613 memory-mapper integrated circuit contains a 4 -line to 16 -line decoder, a 16 -word by 12 -bit RAM, 16 channels of 2 -line to 1 -line multiplexers, and other miscellaneous circuitry on a monolithic chip. Each 'LS610 and 'LS611 also contains 12 latches with an enable control.

The memory mappers are designed to expand a microprocessor's memory address capability by eight bits. Four bits of the memory address bus (see System Block Diagram) can be used to select one of 16 map registers that contain 12 bits each. These 12 bits are presented to the system memory address bus through the map output buffers along with the unused memory address bits from the CPU. However, addressable memory space without reloading the map registers is the same as would be available with the memory mapper left out. The addressable memory space is increased only by periodically reloading the map registers from the data bus. This configuration lends itself to memory utilization of 16 pages of $2^{(n-4)}$ registers each without reloading ( $n=$ number of address bits available from CPU).


[^16] NC-No internal connection

SN54LS610 THRU SN54LS613, SN74LS610 THRU SN74LS613 MEMORY MAPPERS


## SYSTEM BLOCK DIAGRAM

These devices have four modes of operation: read, write, map, and pass. Data may be read from or loaded into the map register selected by the register select inputs (RSO thru RS3) under control of R/W whenever chip select ( $\overline{\mathrm{CS}}$ ) is low. The data I/O takes place on the data bus DO thru D7. The map operation will output the contents of the map register selected by the map address inputs (MAO thru MA3) when $\overline{\mathrm{CS}}$ is high and $\overline{M M}$ (map mode control) is low. The 'LS612 and 'LS613 output stages are transparent in this mode, while the 'LS610 and 'LS611 outputs may be transparent or latched. When $\overline{\mathrm{CS}}$ and $\overline{\mathrm{MM}}$ are both high (pass mode), the address bits on MAO thru MA3 appear at M08-M011, respectively, (assuming appropriate latch control) with low levels in the other bit positions on the map outputs.
logic diagram (positive logic)

*'LS610 and 'LS612 have 3-state ( $\nabla$ ) map outputs.
'LS611 and 'LS613 have open-collector ( $\boldsymbol{\Delta}$ ) map outputs.

## SN54LS610 THRU SN54LS613, SN74LS610 THRU SN74LS613 MEMORY MAPPERS

| PIN |  | DESCRIPTION |
| :---: | :---: | :---: |
| NO. | NAME |  |
| $\begin{gathered} 7-12 \\ 29-34 \\ \hline \end{gathered}$ | D0 thru D11 | I/O connections to data and control bus used for reading from and writing to the map register selected by RSO-RS3 when $\overline{\mathrm{CS}}$ is low. Mode controlled by R/W. |
| 36, 38, 1, 3 | RS0 thru RS3 | Register select inputs for 1/O operations. |
| 6 | R/ $\bar{W}$ | Read or write control used in I/O operations to select the condition of the data bus. When high, the data bus outputs are active for reading the map register. When low, the data bus is used to write into the register. |
| 5 | $\overline{\text { STROBE }}$ | Strobe input used to enter data into the selected map register during I/O operations. |
| 4 | $\overline{\mathrm{CS}}$ | Chip select input. A low input level selects the memory mapper lassuming more than one used) for an I/O operation. |
| 35, 37, 39, 2 | MAO thru MA3 | Map address inputs to select one of 16 map registers when in map mode ( $\overline{\mathrm{MM}}$ low and $\overline{\mathrm{CS}}$ high). |
| $\begin{aligned} & 14-19 \\ & 22-27 \end{aligned}$ | MOO thru MO11 | Map outputs. Present the map register contents to the system memory address bus in the map mode. In the pass mode, these outputs provide the map address data on MO8-MO11 and low levels on MOO-MO7. |
| 13 | $\overline{\mathrm{MM}}$ | Map mode input. When low, 12 bits of data are transferred from the selected map register to the map outputs. When high (pass mode), the 4 bits present on the map address inputs MAO-MA3 are passed to the map outputs MO8-MO11, respectively, while MO0-MO7 are set low. |
| 21 | $\overline{\mathrm{ME}}$ | Map enable for the map outputs. A low level allows the outputs to be active while a high input level puts the outputs at high impedance. |
| 28 | C | Latch enable input for the 'LS610 and 'LS611 (no internal connection for 'LS612 and 'LS613). A high level will transparently pass data to the map outputs. A low level will latch the outputs. |
| 40, 20 | $\mathrm{V}_{\text {CC }}, \mathrm{GND}$ | 5 V power supply and network ground (substrate) pins. |

SN54LS610 THRU SN54LS613, SN74LS610 THRU SN74LS613 MEMORY MAPPERS
schematics of inputs and outputs
(INPUT/OUTPUT PORTS, DO-D11
absolute maximum ratings over operating free-air temperature (unless otherwise noted)

NOTE 1: Voltage values are with respect to network ground terminal.

SN54LS610, SN54LS612, SN74LS610, SN74LS612 MEMORY MAPPERS WITH 3-STATE MAP OUTPUTS
recommended operating conditions


## SN54LS610, SN54LS612, SN74LS610, SN74LS612

 MEMORY MAPPERS WITH 3-STATE MAP OUTPUTSelectrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$. |  |  | SN54LS610 <br> SN54LS612 |  |  | SN74LS610 <br> SN74LS612 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \quad \mathrm{I}=-18 \mathrm{~mA}$ |  |  |  |  | -1.5 |  |  | $-1.5$ | V |
| VOH | MO | $\begin{aligned} & V_{C C}=M I N, \quad V_{I H}=2 \mathrm{~V}, \\ & V_{I L}=M A X \end{aligned}$ |  | $\mathrm{IOH}=-3 \mathrm{~mA}$ | 2.4 |  |  | 2.4 |  |  | V |
|  |  |  |  | $\mathrm{I}^{\mathrm{OH}}=\mathrm{MAX}$ | 2 |  |  | 2 |  |  |  |
|  | D |  |  | $1 \mathrm{OH}=\mathrm{MAX}$ | 2.4 |  |  | 2.4 |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | MO | $\begin{aligned} & V_{C C}=M I N, \quad V_{I H}=2 V, \\ & V_{I L}=M A X \end{aligned}$ |  | ${ }^{1} \mathrm{OL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  |  |  | $1 \mathrm{OL}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | D |  |  | $\mathrm{I}^{\mathrm{OL}}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  |  |  |  | $\mathrm{IOL}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| ${ }^{\text {I OZH }}$ |  | $\begin{array}{ll} V_{C C}=M A X, & V_{I H}=2 \mathrm{~V} \\ V_{I L}=M A X, & V_{O}=2.7 V \end{array}$ |  |  | 20 |  |  | 20 |  |  | $\mu \mathrm{A}$ |
| ${ }^{\text {I ORL }}$ | MO | $\begin{array}{ll} V_{C C}=M A X, & V_{I H}=2 \mathrm{~V} \\ V_{\text {IL }}=M A X, & V_{O}=0.4 V \\ \hline \end{array}$ |  |  |  |  | -20 |  |  | -20 | $\mu \mathrm{A}$ |
|  | D |  |  |  |  |  | -400 |  |  | -400 |  |
| 1 | D | $V_{C C}=M A X$ |  | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | All others |  |  | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| IIH |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IIL |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  |  |  | -0.4 |  |  | -0.4 | mA |
| los§ | MO | $V_{C C}=$ MAX |  |  | -40 |  | -225 | -40 |  | -225 | mA |
|  | D |  |  |  | -30 |  | -130 | -30 |  | -130 |  |
| ICC |  | $V_{C C}=\operatorname{MAX}$ | Outputs high |  |  | 112 | 180 | 112180 |  |  | mA |
|  |  | Outputs low |  | 112 | 180 |  | 112 | 180 |  |
|  |  | Outputs disabled |  | 150 | 230 |  | 180 | 230 |  |

$\dagger^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
${ }^{\S}$ Not more than one output should be shorted at a time, and duration of the short-circuit should not exceed one second.
switching characteristics, $\mathrm{V}_{\mathrm{C}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=45 \mathrm{pF}$ to GND

|  | PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS | 'LS610 |  |  | 'LS612 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| tCSLDV | Access (enable) time | $\overline{\mathrm{CS}} \downarrow$ | DO-11 | $\mathrm{R}_{\mathrm{L}}=2 \mathrm{k} \Omega,$ <br> See Figure 1, <br> See Notes 2 and 3 |  | 28 | 50 |  | 26 | 50 | ns |
| tWHDV | Access (enable) time | $\mathrm{R} / \overline{\mathrm{W}} \uparrow$ | D0-11 |  |  | 20 | 35 |  | 20 | 35 | ns |
| trVDV | Access time | RS | DO-11 |  |  | 49 | 75 |  | 39 | 75 | ns |
| twLDZ | Disable time | R/W/ | DO-11 |  |  | 32 | 50 |  | 30 | 50 | ns |
| ${ }^{\text {t CSSHDZ }}$ | Disable time | $\overline{\mathrm{CS}} \uparrow$ | DO-11 |  |  | 42 | 65 |  | 38 | 65 | ns |
| telov | Access (enable) time | $\overline{\text { ME }} \downarrow$ | MOO-11 | $R_{L}=667 \Omega$, <br> See Figure 2, <br> See Notes 2 and 3 |  | 19 | 30 |  | 17 | 30 | ns |
| ${ }^{\text {t CSHOV }}$ | Access time | $\overline{\mathrm{CS}} \uparrow$ | MOO-11 |  |  | 56 | 85 |  | 48 | 85 | ns |
| tMLQV | Access time | $\overline{\mathrm{MM}} \downarrow$ | MOO-11 |  |  | 25 | 40 |  | 22 | 40 | ns |
| ${ }^{\text {t }}$ CHQV | Access time | $\mathrm{C} \uparrow$ | MOO-11 |  |  | 24 | 40 |  |  |  | ns |
| tavov1 | Access time ( $\overline{\mathrm{MM}}$ low) | MA | M00-11 |  |  | 46 | 70 |  | 39 | 70 | ns |
| ${ }^{\text {t }} \mathrm{MHOV}$ | Access time | $\overline{\mathrm{MM}} \uparrow$ | MOO-11 |  |  | 24 | 40 |  | 22 | 40 | ns |
| ${ }^{\text {taVav2 }}$ | Propagation time ( $\overline{M M}$ high) | MA | M08-11 |  |  | 19 | 30 |  | 13 | 30 | ns |
| tehoz | Disable time | $\overline{\mathrm{ME}} \uparrow$ | MOO-11 |  |  | 14 | 25 |  | 14 | 25 | ns |

NOTES: 2. Access times are tested as tpLH and tpHL or tpZH or tpZL. Disable times are tested as tphZ and tpLZ.
3. Load circuits and voltage waveforms are shown in Section 1.

SN54LS611, SN54LS613, SN74LS611, SN74LS613 MEMORY MAPPERS WITH OPEN-COLLECTOR MAP OUTPUTS
recommended operating conditions


## SN54LS611, SN54LS613, SN74LS611, SN74LS613 <br> MEMORY MAPPERS WITH OPEN-COLLECTOR MAP OUTPUTS

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

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$ |  |  |  | $\begin{aligned} & \text { V54LS6 } \\ & \text { v54LS6 } \end{aligned}$ |  |  | $\begin{aligned} & \text { V74LS6 } \\ & \text { V74LS6 } \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.5 |  |  | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | D | $\begin{aligned} & \hline \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=\mathrm{MAX}, \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ |  | 2.4 |  |  | 2.4 |  |  | V |
| ${ }^{1} \mathrm{OH}$ | MO | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | MO | $\begin{array}{ll}V_{C C}=M I N, & V_{I H}=2 \mathrm{~V}, \\ V_{\mathrm{IL}}=\mathrm{MAX}\end{array}$ |  | ${ }^{1} \mathrm{OL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  |  |  | $\mathrm{I}_{\mathrm{OL}}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | D |  |  | $\mathrm{IOL}^{\prime}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  |  |  |  | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| ${ }^{\text {I OZH }}$ | D | $\begin{array}{ll} \hline V_{C C}=M A X, & V_{I H}=2 \mathrm{~V}, \\ V_{\mathrm{IL}}=M A X, & V_{\mathrm{O}}=2.7 \mathrm{~V} \end{array}$ |  |  |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| ${ }^{\text {I OZL }}$ | D | $\begin{array}{ll} \hline V_{C C}=M A X, & V_{I H}=2 \mathrm{~V}, \\ V_{O}=0.4 \mathrm{~V} & \\ \hline \end{array}$ |  |  |  |  | -0.4 |  |  | -0.4 | mA |
| 1 | D | $V_{C C}=$ MAX |  | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | All others |  |  | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| IH |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{V}_{!}=2.7 \mathrm{~V}$ |  |  |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IL |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \quad \mathrm{V}_{\mathrm{I}}=0.4 \mathrm{~V}$ | $\mathrm{I}=0.4 \mathrm{~V}$ |  | -0.4 |  |  | -0.4 |  |  | mA |
| 10s ${ }^{\text {s }}$ | D | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  |  | -30 |  | -130 | $-30$ | -130 |  | mA |
| Icc |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ | Outputs high |  |  | 100 | 170 |  | 100 | 170 |  |
|  |  | Outputs low |  | 100 | 170 |  | 100 | 170 | mA |  |
|  |  | Outputs disabled |  | 110 | 200 |  | 110 | 200 |  |  |

$\dagger^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\S$ Not more than one output should be shorted at a time, and duration of the short-circuit should not exceed one second.
switching characteristics, $\mathrm{V}_{\mathrm{C}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=45 \mathrm{pF}$ to GND

| PARAMETER |  | FROM (INPUT) | $\begin{gathered} \text { TO } \\ \text { (OUTPUT) } \end{gathered}$ | TEST CONDITIONS | 'LS611 |  |  | 'LS613 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN |  |  | TYP | MAX | MIN | TYP | MAX |  |
| tCSLDV | Access (enable) time |  | $\overline{\overline{C S}} \downarrow$ | D0-11 | $\mathrm{R}_{\mathrm{L}}=2 \mathrm{k} \Omega$ <br> See Figure 1, <br> See Notes 2 and 3 |  | 31 | 50 |  | 28 | 50 | ns |
| tWHDV | Access (enable) time | $\mathrm{R} / \overline{\mathrm{W}} \uparrow$ | D0-11 |  |  | 23 | 35 |  | 21 | 35 | ns |
| trivDV | Access time | RS | D0-11 |  |  | 51 | 75 |  | 47 | 75 | ns |
| tWLDZ | Disable time | R/ $\bar{W} \downarrow$ | D0-11 |  |  | 32 | 50 |  | 31 | 50 | ns |
| tCSHDZ | Disable time | $\overline{\mathrm{CS}} \uparrow$ | D0-11 |  |  | 41 | 65 |  | 40 | 65 | ns |
| telav | Access (enable) time | $\overline{\mathrm{ME}} \downarrow$ | MOO-11 | $\mathrm{R}_{\mathrm{L}}=667 \Omega,$ <br> See Figure 2, <br> See Notes 2 and 3 |  | 21 | 30 |  | 19 | 30 | ns |
| tcSHQV | Access time | $\overline{\mathrm{CS}} \uparrow$ | MOO-11 |  |  | 57 | 90 |  | 53 | 90 | ns |
| tMLQV | Access time | MM $\downarrow$ | MOO-11 |  |  | 25 | 40 |  | 25 | 40 | ns |
| tCHQV | Access time | $\mathrm{C} \uparrow$ | MOO-11 |  |  | 30 | 45 |  |  |  | ns |
| tAVQV1 | Access time ( $\overline{\mathrm{MM}}$ low) | MA | MOO-11 |  |  | 47 | 70 |  | 44 | 70 | ns |
| ${ }^{\text {t M }}$ HQV | Access time | $\mathrm{MM} \uparrow$ | MOO-11 |  |  | 31 | 50 |  | 31 | 50 | ns |
| tAVQV2 | Propagation time ( $\overline{\mathrm{MM}}$ high) | MA | MO8-11 |  |  | 21 | 30 |  | 20 | 30 | ns |
| tehoz | Disable time | ME $\uparrow$ | MOO-11 |  |  | 15 | 25 |  | 15 | 25 | ns |

NOTES: 2. Access times are tested as tpLH and tPHL or tPZH or tpZL. Disable times are tested as tpHZ and tpLZ.
3. Load circuits and voltage waveforms are shown in Section 1.
explanation of letter symbols
This data sheet uses a new type of letter symbol based on JEDEC Standard 100 to describe time intervals. The format is:

## tAB-CD

where: subscripts $A$ and $C$ indicate the names of the signals for which changes of state or level or establishment of state or level constitute signal events assumed to occur first and last, respectively, that is, at the beginning and end of the time interval.

Subscripts B and D indicate the direction of the transitions and/or the final states or levels of the signals represented by $A$ and $C$, respectively. One or two of the following is used:

```
H = high or transition to high
L = low or transition to low
V = a valid steady-state level
X = unknown, changing, or "don't care" level
Z = high-impedance (off) state.
```

The hyphen between the $B$ and $C$ subscripts is omitted when no confusion is likely to occur. For these letter symbols on this data sheet, the signal names are further abbreviated as follows:

| SIGNAL NAME | A AND C SUBSCRIPT | SIGNAL NAME | A AND C SUBSCRIPT |
| :---: | :---: | :---: | :---: |
| C | C | $\overline{\mathrm{ME}}$ | E |
| $\overline{\mathrm{CS}}$ | CS | $\overline{\mathrm{MM}}$ | M |
| DO-11 | D | R/ $\bar{W}$ | W |
| MAO-MA3 | A | RSO-RS3 | R |
| MOO-MO11 | Q | STROBE | S |

TIMING DIAGRAMS


FIGURE 1. WRITE AND READ MODES

## TIMING DIAGRAMS



FIGURE 2. MAP AND PASS MODES

## SN54ALS616, SN54ALS617, SN74ALS616, SN74ALS617 16-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS

- Detects and Corrects Single-Bit Errors
- Detects and Flags Dual-Bit Errors
- Built-In Diagnostic Capability
- Fast Write and Read Cycle Processing Times
- Byte-Write Capability
- Dependable Texas Instruments Quality and Reliability

| DEVICE | OUTPUT |
| :---: | :---: |
| 'ALS616 | 3-State |
| 'ALS617 | Open-Collector |

## description

The 'ALS616 and 'ALS617 are 16 -bit parallel error detection and correction circuits in 40-pin, 600 -mil packages. The EDACs use a modified Hamming code to generate a 6 -bit check word from a 16-bit data word. This check word is stored along with the data word during the memory write cycle. During memory read cycles, the 22-bit words from memory are processed by the EDACs to determine if errors have occurred in memory.

Single-bit errors in the 16 -bit data word are flagged and corrected. Single-bit errors in the 6 -bit check word are flagged, but the data word will remain unaltered. The 6 -bit error syndrome code will pinpoint the error-generating location.

Dual-bit errors are flagged but not corrected. These errors may occur in any two bits of the 22-bit word from memory. The gross-error condition of all lows or all highs from memory will be detected. Otherwise, errors in three or more bits of the 22-bit word are beyond the capabilities of these devices to detect.

Read-modify-write (byte-control) operations can be performed with the 'ALS616 and 'ALS617 EDACs by using output latch enable, $\overline{\text { LEDBO }}$, and individual $\overline{\mathrm{OEBO}} 0$ and $\overline{\mathrm{OEB}} 1$ byte control pins.

Diagnostics are performed on the EDACs by controls and internal paths that allow the user to read the contents of the DB and CB input latches. These will determine if the failure occurred in memory or in the EDAC.

SN54ALS616, SN54ALS617 . . . JD PACKAGE
SN74ALS616, SN74ALS617 . . JD OR N PACKAGE (TOP VIEW)
LEDBO
MERR
ERR
NC
NC
N
NC
3

SN74ALS616, SN74ALS617 . . FN PACKAGE (TOP VIEW)


NC-No internal connection

The SN54ALS616 and SN54ALS617 are characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74ALS616 and SN74ALS617 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

# SN54ALS616, SN54ALS617, SN74ALS616, SN74ALS617 16-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS 

TABLE 1. WRITE CONTROL FUNCTION

| MEMORY <br> CYCLE | EDAC <br> FUNCTION | CONTROL <br> S1 <br> SO | DATA I/O | DB CONTROL <br> $\overline{\text { OEBO \& } \overline{\text { OEB1 }}}$ | DB OUTPUT LATCH <br> $\overline{\text { LEDBO }}$ | CHECK I/O | CB <br> CONTROL <br> $\overline{\text { OECB }}$ | ERROR FLAGS <br> $\overline{\text { ERR }}$ <br> $\overline{M E R R ~}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write | Generate <br> check word | L | L | Input | H | X | Output <br> check bits $\dagger$ | L |

†See Table 2 for details on check bit generation.

## memory write cycle details

During a memory write cycle, the check bits (CBO thru CB5) are generated internally in the EDAC by six 8 -input parity generators using the 16 -bit data word as defined in Table 2. These six check bits are stored in memory along with the original 16 -bit data word. This 22 -bit word will later be used in the memory read cycle for error detection and correction.

TABLE 2. PARITY ALGORITHM

| CHECK WORD BIT | 16-BIT DATA WORD |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CBO |  |  | X |  | X | X | X |  |  | X |  |  | X |  | X | X |
| CB1 |  | X |  | $x$ |  | X | $x$ | X |  |  |  | X |  | X |  | X |
| CB2 | $x$ |  |  | X | X |  |  | X | X |  | X |  |  | X | $x$ |  |
| CB3 | $x$ | X | X |  |  |  | X | X |  |  | X | X | X |  |  |  |
| CB4 | X | X | X | x | X | $x$ |  |  | $x$ | $x$ |  |  |  |  |  |  |
| CB5 |  |  |  |  |  |  |  |  | X | X | X | X | X | X | X | X |

The six check bits are parity bits derived from the matrix of data bits as indicated by " $X$ " for each bit.

## error detection and correction details

During a memory read cycle, the 6 -bit check word is retrieved along with the actual data. In order to be able to determine whether the data from memory is acceptable to use as presented to the bus, the error flags must be tested to determine if they are at the high level.

The first case in Table 3 represents the normal, no-error conditions. The EDAC presents highs on both flags. The next two cases of single-bit errors give a high on $\overline{M E R R}$ and a low on $\overline{E R R}$, which is the signal for a correctable error, and the EDAC should be sent through the correction cycle. The last three cases of double-bit errors will cause the EDAC to signal lows on both $\overline{\operatorname{ERR}}$ and $\overline{M E R R}$, which is the interrupt indication for the CPU.

TABLE 3. ERROR FUNCTION

| TOTAL NUMBER OF ERRORS |  | ERROR FLAGS | DATA CORRECTION |  |
| :---: | :---: | :---: | :---: | :---: |
| 16-BIT DATA WORD | 6-BIT CHECK WORD |  |  |  |
| 0 | 0 | $H$ | H | Not applicable |
| 1 | 0 | L | H | Correction |
| 0 | 1 | L | H | Correction |
| 1 | 1 | L | L | Interrupt |
| 2 | 0 | L | L | Interrupt |
| 0 | 2 | L | L | Interrupt |

# SN54ALS616, SN54ALS617, SN74ALS616, SN74ALS617 16-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS 

| MEMORY CYCLE | EDAC FUNCTION | $\begin{array}{\|c} \hline \text { CON1 } \\ \text { S1 } \end{array}$ |  | DATA I/O | DB CONTROL <br> $\overline{\mathrm{OEB}}$ \& OEB 1 | DB OUTPUT LATCH LEDBO | CHECK 1/O |  | ERROR FLAGS ERR MERR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | Read \& flag | H | L | Input | H | X | Input | H | Enabled ${ }^{\dagger}$ |
| Read | Latch input <br> data \& check <br> bits | H | H | Latched input data | H | L | $\qquad$ | H | Enabled ${ }^{\dagger}$ |
| Read | Output corrected data and syndrome bits | H | H | Output corrected data word | L | X | Output syndrome bits ${ }^{\ddagger}$ | L | Enabled ${ }^{\dagger}$ |

[^17]Error detection is accomplished as the 6 -bit check word and the 16 -bit data word from memory are applied to the internal parity generators/checkers. If the parity of all six groupings of data and check bits are correct, it is assumed that no error has occurred and both error flags will be high.

If the parity of one or more of the check groups is incorrect, an error has occurred and the proper error flag or flags will be set low. The two-bit error is not correctable since the parity tree can only identify single-bit errors. Both error flags are set low when any two-bit error is detected.

Three or more simultaneous bit errors can cause the EDAC to believe that no error, a correctable error, or an uncorrectable error has occurred and will produce erroneous results in all three cases. It should be noted that the gross-error conditions of all highs will be detected.

As the corrected word is made available on the data I/O port (DBO thru DB15), the check word I/O port (CBO thru CB5) presents a 6-bit syndrome error code. This syndrome code can be used to locate the bad memory chip. See Table 5 for syndrome decoding.

## SN54ALS616, SN54ALS617, SN74ALS616, SN74ALS617 16-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS

TABLE 5. SYNDROME DECODING


CB $X=$ error in check bit $X$
DB $Y=$ error in data bit $Y$
2-bit $=$ double-bit error
unc $=$ uncorrectable multibit error



| SYNDORME BITS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 5 | 4 | 3 | 32 | 2 | 1 | 0 |  |
| H | H | L | L | L | L | L | 2-bit |
| H | H | L | L | L L | L | H | DB8 |
| H | H | L | L | L | H | L | unc |
| H | H | L |  |  | H | H | 2-bit |
| H | H | L |  | H | L | L | DB9 |
| H | H | L | 'H | H | L | H | 2-bit |
| H | H | $L$ | H | H | H | L | 2-bit |
| H | H | L | H | H | H | H | CB3 |
| H | H | H | H | L |  | L | unc |
| H | H | H | H | L | L |  | 2-bit |
| H | H | H | H | L H | H | L | 2-bit |
| H | H | H | H L | L | H | H | CB2 |
| H | H | H | H | H | L |  | 2-bit |
| H | H | H | H | H | L |  | CB1 |
| H | H | H | H | H | H | L | CBO |
| H | H | H | H H | H |  | H | none |

## read-modify-write (byte control) operations

The 'ALS616 and 'ALS617 devices are capable of byte-write operations. The 22-bit word from memory must first be latched into the DB and CB input latches. This is easily accomplished by switching from the read and flag mode $(S 1=H, S 0=L)$ to the latch input mode (S1 $=H, S 0=H$ ). The EDAC will then make any corrections, if necessary, to the data word and place it at the input of the output data latch. This data word must then be latched into the output data latch by taking $\overline{\text { LEDBO }}$ from a low to a high.
Byte control can now be employed on the data word through the $\overline{\mathrm{OEB}} 0$ or $\overline{\mathrm{OEB}} 1$ controls. $\overline{\mathrm{OEBO}}$ controls DBO-DB7 (byte 0), $\overline{O E B} 1$ controls DB8-DB15 (byte 1).

Placing a high on the byte control will disable the output and the user can modify the byte. If a low is placed on the byte control, then the original byte is allowed to pass onto the data bus unchanged. If the original data word is altered through byte control, a new check word must be generated before it is written back into memory. This is easily accomplished by taking control S1 and SO low. Table 6 lists the read-modify-write functions.

## SN54ALS616, SN54ALS617, SN74ALS616, SN74ALS617 16-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS

TABLE 6. READ-MODIFY-WRITE FUNCTION

| MEMORY CYCLE | EDAC FUNCTION | CONTROL s1 so | BYTEn ${ }^{\dagger}$ | $\overline{\text { OEBn }}{ }^{\dagger}$ | $\begin{aligned} & \text { DB OUTPUT } \\ & \text { LATCH } \\ & \text { LEDBO } \end{aligned}$ | CHECK I/O | CB CONTROL | ERROR FLAG <br> $\overline{E R R} \overline{M E R R}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | Read \& Flag | H L | Input | H | X | Input | H | Enabled |
| Read | Latch input data \& check bits | H H | Latched Input data | H | L | Latched input check word | H | Enabled |
| Read | Latch corrected data word into output latch | H H | Latched output data word | H | H | $-\frac{\mathrm{Hi}-\mathrm{Z}}{\text { Output }}-$ <br> Syndrome <br> bits |  | Enabled |
| Modify/ write | Modify appropriate byte or bytes \& generate new check word | L L | Input modified $-\frac{\text { BYTEO }}{\text { Output }}$ unchanged BYTEO |  | H | Output check word | L | H H |

$\dagger \overline{\mathrm{OEB}} 0$ controls DBO-DB7 (BYTEO), $\overline{\mathrm{OEB}} 1$ controls DB8-DB15 (BYTE1)

## diagnostic operations

The 'ALS616 and 'ALS617 are capable of diagnostics that allow the user to determine whether the EDAC or the memory is failing. The diagnostic function tables will help the user to see the possibilities for diagnostic control.

In the diagnostic mode ( $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{H}$ ), the checkword is latched into the input latch while the data input latch remains transparent. This lets the user apply various data words against a fixed known checkword. If the user applies a diagnostic data word with an error in any bit location, the $\overline{\text { ERR }}$ flag should be low. If a diagnostic data word with two errors in any bit location is applied, the MERR flag should be low. After the checkword is latched into the input latch, it can be verified by taking $\overline{\mathrm{OECB}}$ low. This outputs the latched checkword. The diagnostic data word can be latched into the output data latch and verified via the $\overline{\mathrm{LEDBO}}$ control pin. By changing from the diagnostic mode ( $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{H}$ ), the user can verify that the EDAC will correct the diagnostic data word. Also, the syndrome bits can be produced to verify that the EDAC pinpoints the error location. Table 7 lists the diagnostic functions.

SN54ALS616, SN54ALS617, SN74ALS616, SN74ALS617
16-bit Parallel error detection and correction circuits

TABLE 7. DIAGNOSTIC FUNCTION

| EDAC FUNCTION | $\begin{gathered} \text { CONTROL } \\ \text { s1 so } \end{gathered}$ | DATA I/O | $\begin{gathered} \hline \text { DB BYTE } \\ \text { CONTROL } \\ \overline{\text { OEBn }} \\ \hline \end{gathered}$ | $\begin{gathered} \hline \text { DB OUTPUT } \\ \text { LATCH } \\ \overline{\text { LEDBO }} \end{gathered}$ | CHECK I/O | CB CONTROL $\overline{\text { OECB }}$ | ERROR FLAGS $\overline{\text { ERR }} \overline{\text { MERR }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read \& flag | H L | Input correct data word | H | X | Input correct check bits | H | H H |
| Latch input check word while data input latch remains transparent | L H | Input diagnostic data word ${ }^{\dagger}$ | H | L | Latched input check bits | H | Enabled |
| Latch diagnostic data word into output latch | L H | Input diagnostic data word ${ }^{\dagger}$ | H | H | $\begin{aligned} & \begin{array}{l} \text { Output latched } \\ \text { check bits } \end{array} \\ & \text { Hi-Z } \end{aligned}$ | $-\frac{L}{H}$ | Enabled |
| Latch diagnostic data word into input latch | H H | Latched input diagnostic data word | H | H | Output <br> syndrome <br> bits <br> Hi-Z $---~$ |  | Enabled |
| Output diagnostic data word \& syndrome bits | H H | Output diagnostic data word | L | H | Output <br> syndrome <br> bits <br> Hi-Z -- | $\begin{gathered} L \\ - \\ \hline \end{gathered}$ | Enabled |
| Output corrected diagnostic data word \& output syndrome bits | H H | Output corrected diagnostic data word | L | L | Output syndrome bits $\mathrm{Hi}-\bar{Z}$ | $\begin{gathered} \mathrm{L} \\ \mathrm{H}^{-}- \end{gathered}$ | Enabled |

${ }^{\dagger}$ Diagnostic data is a data word with an error in one bit location except when testing the $\overline{\mathrm{MERR}}$ error flag. In this case, the diagnostic data word will contain errors in two bit locations.
logic diagram (positive logic)

*'ALS616 has 3-state ( $\nabla$ ) check-bit and data outputs.
'ALS617 has open-collector $(\Omega)$ check-bit and data outputs.

## SN54ALS616, SN54ALS617, SN74ALS616, SN74ALS617

 16-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITSabsolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ (see Note 1) 7 V
Input voltage: CB and DB 5.5 V
All others 7 V
Operating case temperature range SN54ALS616, SN54ALS617, .......... $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Operating free-air temperature range, SN74ALS616, SN74ALS617............. $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range
$-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended operating conditions


[^18]
## SN54ALS616, SN74ALS616 16-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS

'ALS616 electrical characteristics over recommended operating temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54ALS616 |  |  | SN74ALS616 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | --1.5 |  |  | -1.5 | V |
|  | All outputs | $\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$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
| $\mathrm{V}_{\mathrm{OH}}$ | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | ${ }^{1} \mathrm{OH}=-1 \mathrm{~mA}$ | 2.4 | 3.3 |  |  |  |  |  |
|  | DB or CB | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | ${ }^{\mathrm{O}} \mathrm{OH}=-2.6 \mathrm{~mA}$ |  |  |  | 2.4 | 3.2 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | $\overline{\text { ERR }}$ or $\overline{M E R R}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | $D B$ or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{OLL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{OL}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| I | So or S1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | DB or CB | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| $\mathrm{I}_{\mathrm{I}}^{\mathrm{H}}$ | So or S1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $V_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | DB or $\mathrm{CB}^{\ddagger}$ |  |  |  |  | 20 |  |  | 20 |  |
| IIL | SO or S1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{I}}=0.4 \mathrm{~V}$ |  |  |  | -0.4 |  |  | -0.4 | mA |
|  | DB or $\mathrm{CB}^{\ddagger}$ |  |  |  |  | -0.1 |  |  | -0.1 | , |
| $\mathrm{l}^{1} \mathrm{O}^{\text {§ }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | $-30$ |  | -112 | mA |
| ${ }^{1} \mathrm{CC}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | See Note 1 |  | 110 | 190 |  | 110 | 170 | mA |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
${ }^{\ddagger}$ For $1 / O$ ports, the parameters $I_{I H}$ and $I_{I L}$ include the off-state output current.
${ }^{\S}$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS. NOTE 1: ICC is measured with SO and S1 at 4.5 V and all CB and DB pins grounded.
'ALS616 switching characteristics, $\mathrm{V}_{\mathrm{C}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{T} \mathrm{C}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ for SN54ALS616, $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ for SN74ALS616

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS | SN54ALS616 |  | SN74ALS616 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {p }}$ d | DB and CB | ERR | $S 1=H, S O=L, R_{L}=500 \Omega$ | 10 | 43 | 10 | 40 | ns |
|  | DB | $\overline{\text { ERR }}$ | $S 1=L, S 0=H, R_{L}=500 \Omega$ | 10 | 43 | 10 | 40 |  |
| ${ }^{\text {tpd }}$ | DB and CB | $\overline{\text { MERR }}$ | $\mathrm{S} 1=\mathrm{H}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ | 15 | 65 | 15 | 55 | ns |
|  | DB | $\overline{\mathrm{MERR}}$ | S1 $=L, S 0=H, R_{L}=500 \Omega$ | 15 | 65 | 15 | 55 |  |
| $\mathrm{t}_{\mathrm{pd}}$ | SO $\downarrow$ and S1 $\downarrow$ | CB | $\mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 10 | 60 | 10 | 49 | ns |
| ${ }^{\text {tpd }}$ | DB | CB | $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{L}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 10 | 60 | 10 | 49 | ns |
| $t_{\text {pd }}$ | $\overline{\text { LEDBO } \downarrow}$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 7 | 35 | 7 | 30 | ns |
| $t_{\text {pd }}$ | S1ヶ | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 10 | 50 | 10 | 50 | ns |
| $t_{\text {en }}$ | $\overline{\text { OECB } \downarrow}$ | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{S} 1=\mathrm{X}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 2 | 30 | 2 | 27 | ns |
| $t_{\text {dis }}$ | $\overline{\mathrm{OECB}} \uparrow$ | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{S} 1=\mathrm{X}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 2 | 30 | 2 | 27 | ns |
| ten | $\overline{\mathrm{OEB}} 0$ and $\overline{\mathrm{OEB}} 1 \downarrow$ | DB | $S 0=H, S 1=X, R 1=R 2=500 \Omega$ | 2 | 30 | 2 | 27 | ns |
| $t_{\text {dis }}$ | $\overline{\mathrm{OEB}}$ and $\overline{\mathrm{OEB}} 1 \uparrow$ | DB | $\mathrm{SO}=\mathrm{H}, \mathrm{S} 1=\mathrm{X}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 2 | 30 | 2 | 27 | ns |

'ALS617 electrical characteristics over recommended operating temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  |  | 54ALS6 |  |  | 74ALS |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | ERR or MERR | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}^{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
| ${ }^{\mathrm{I} \mathrm{OH}}$ | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| $\mathrm{V}_{\mathrm{OL}}$. | $\overline{\text { ERR }}$ or $\overline{\text { MERR }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | ${ }^{1} \mathrm{OH}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | DB or CB | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| 1 | S0 or S1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| 1 | DB or CB | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| ${ }_{1} \mathrm{H}$ | S0 or S1 | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | DB or $\mathrm{CB}^{\ddagger}$ |  |  |  |  | 20 |  |  | 20 |  |
|  | S0 or S1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.4 |  |  | -0.4 | mA |
| IL | DB or $\mathrm{CB}^{\ddagger}$ |  |  |  |  | -0.1 |  |  | -0.1 |  |
| $1 \mathrm{I}^{8}$ | $\overline{\text { ERR }}$ or MERR | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ICC |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | See Note 1 | 110 |  |  | 110 |  |  | 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 $I_{I H}$ and $I_{I L}$ include the off-state output current.
${ }^{\S}$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS. NOTE 1: ${ }^{\mathrm{I}} \mathrm{CC}$ is measured with SO and S 1 at 4.5 V and all CB and DB pins grounded.
'ALS617 switching characteristics, $\mathrm{VCC}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{TC}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ for SN54ALS617, $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ for SN74ALS617

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS | SN54ALS617 |  |  | SN74ALS617 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\text {t }}$ | MAX |  |
| ${ }^{t} \mathrm{pd}$ | DB and CB | $\overline{\text { ERR }}$ | $S 1=H, S 0=L, R_{L}=500 \Omega$ |  | 26 |  |  | 26 |  | ns |
|  | DB | $\overline{\mathrm{ERR}}$ | $\mathrm{S} 1=\mathrm{L}, \mathrm{S} 0=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 26 |  |  | 26 |  |  |
| ${ }^{\text {p }}$ d | $D B$ and CB | $\overline{\text { MERR }}$ | $\mathrm{S} 1=\mathrm{H}, \mathrm{S0}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 40 |  |  | 40 |  | ns |
|  |  |  | S1 $==\mathrm{L}, \mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 40 |  |  | 40 |  |  |
| ${ }^{\text {p }}$ d | SO $\downarrow$ and S1 $\downarrow$ | CB | $\mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 40 |  |  | 40 |  | ns |
| ${ }_{\text {tpd }}$ | DB | CB | $\mathrm{S} 1=\mathrm{L}, \mathrm{S} 0=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 40 |  |  | 40 |  | ns |
| ${ }_{\mathrm{t} d}$ | $\overline{\text { LEDBO }} \downarrow$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 26 |  |  | 26 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | S1ヶ | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 40 |  |  | 40 |  | ns |
| ${ }_{\text {tPLH }}$ | $\overline{\text { OECB } \uparrow}$ | CB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 24 |  |  | 24 |  | ns |
| tPHL | $\overline{\text { OECB }} \downarrow$ | CB | $\mathrm{S} 1=\mathrm{X}, \mathrm{S} 0=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 24 |  |  | 24 |  | ns |
| ${ }^{\text {tPLH }}$ | $\overline{\mathrm{OEB}} 0$ and $\overline{\mathrm{OEB}} 1 \uparrow$ | DB | S1 = X, SO $=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 24 |  |  | 24 |  | ns |
| ${ }^{\text {tPHL }}$ | $\overline{\mathrm{OEB}}$ and $\overline{\mathrm{OEB}} 1 \downarrow$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 24 |  |  | 24 |  | ns |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
Additional information on these products can be obtained from the factory as it becomes available.


FIGURE 1. READ, FLAG, AND CORRECT MODE SWITCHING WAVEFORMS


FIGURE 2. READ, CORRECT, MODIFY MODE SWITCHING WAVEFORMS

SN54ALS616, SN54ALS617, SN74ALS616, SN74ALS617 16-bit Parallel error detection and correction circuits


## SN54ALS632A, SN54ALS633 THRU SN54ALS635 SN74ALS632A, SN74ALS633 THRU SN74ALS635 32-bit Parallel error detection and correction circuits

D2661, DECÉMBER 1982-REVISED DECEMBER 1985

- Detects and Corrects Single-Bit Errors
- Detects and Flags Dual-Bit Errors
- Built-In Diagnostic Capability
- Fast Write and Read Cycle Processing Times
- Byte-Write Capability . . . 'ALS632A and 'ALS633
- Dependable Texas Instruments Quality and Reliability

| DEVICE | PACKAGE | BYTE-WRITE | OUTPUT |
| :--- | :---: | :---: | :---: |
| 'ALS632A | 52 -pin | yes | 3-State |
| 'ALS633 | $52-$ pin | yes | Open-Collector |
| 'ALS634 | $48-\mathrm{pin}$ | no | 3-State |
| 'ALS635 | $48-\mathrm{pin}$ | no | Open-Collector |

## description

The 'ALS632A and 'ALS633 through 'ALS635 devices are 32-bit parallel error detection and correction circuits (EDACs) in 52-pin ('ALS632A and 'ALS633) or 48-pin ('ALS634 and 'ALS635) 600-mil packages. The EDACs use a modified Hamming code to generate a 7 -bit check word from a 32-bit data word. This check word is stored along with the data word during the memory write cycle. During the memory read cycle, the 39 -bit words from memory are processed by the EDACs to determine if errors have occurred in memory.

Single-bit errors in the 32-bit data word are flagged and corrected.

Single-bit errors in the 7-bit check word are flagged, and the CPU sends the EDAC through the correction cycle even though the 32-bit data word is not in error. The correction cycle will simply pass along the original 32-bit data word in this case and produce error syndrome bits to pinpoint the error-generating location.

Dual-bit errors are flagged but not corrected. These errors may occur in any two bits of the 39-bit data word from memory (two errors in the 32-bit data word, two errors in the 7-bit check word, or one error in each word). The gross-error condition of all lows or all highs from memory will be detected. Otherwise, errors in three or more bits of the 39 -bit word are beyond the capabilities of these devices to detect.


NC - No internal connection

Read-modify-write (byte-control) operations can be performed with the 'ALS632A and 'ALS633 EDACs by using output latch enable, $\overline{\mathrm{LEDBO}}$, and the individual $\overline{\mathrm{OEB}} \mathrm{O}$ thru $\overline{\mathrm{OEB}} 3$ byte control pins.

Diagnostics are performed on the EDACs by controls and internal paths that allow the user to read the contents of the DB and CB input latches. These will determine if the failure occurred in memory or in the EDAC.
'ALS634, 'ALS635 . . . JD PACKAGE
(TOP VIEW)

| MERR 1 | 48 | $\square V_{C C}$ |
| :---: | :---: | :---: |
| $\overline{E R R} 2$ | 47 | ¢ 1 |
| DBC 3 | 46 | ]so |
| DB1 4 | 45 | DD31 |
| DB2 5 | 44 | -dB30 |
| DB3 6 | 43 | -DB29 |
| DB4 7 | 42 | - ${ }^{\text {di28 }}$ |
| DB5 8 | 41 | - ${ }^{\text {d } 27}$ |
| $\overline{\text { OEDB }} 9$ | 40 | -1 ${ }^{\text {d }}$ 26 |
| DB6 10 | 39 | $\square \mathrm{DB25}$ |
| DB7 11 | 38 | DDB24 |
| GND 12 | 37 | $\square \mathrm{GND}$ |
| DB8 13 | . 36 | DB23 |
| DB9 14 | 35 | $\square{ }^{7}$ |
| DB10 15 | 34 | - ${ }^{\text {¢ } 21}$ |
| DB11 16 | 33 | $\square \mathrm{DB20}$ |
| DB12 17 | 32 | DB19 |
| DB13 18 | 31 | DB18 |
| DB14 19 | 30 | -DB17 |
| DB15 20 | 29 | DB16 |
| CB6 21 | 28 | ]сво |
| CB5 22 | 27 | $\square \mathrm{CB} 1$ |
| CB4 42 | 26 | CB2 |
| $\overline{O E C B}$ | 25 | - CB |

'ALS634, 'ALS635 . . . FN PACKAGE
(TOP VIEW)


NC - No internal connection

TABLE 1. WRITE CONTROL FUNCTION

| $\begin{array}{\|c} \text { MEMORY } \\ \text { CYCLE } \end{array}$ | EDAC FUNCTION | $\left\lvert\, \begin{array}{cc} \text { CONTROL } \\ \text { S1 } \end{array}\right.$ | DATA I/O | $\begin{gathered} \text { DB CONTROL } \\ \overline{\text { OEBn OR }} \\ \overline{\text { OEDB }} \end{gathered}$ | $\begin{gathered} \text { DB OUTPUT LATCH } \\ \text { ('ALS632A, 'ALS633) } \\ \overline{\text { LEDBO }} \end{gathered}$ | CHECK 1/O | CB CONTROL $\overline{\text { OECB }}$ | $\begin{array}{cc}\text { ERROR FLAGS } \\ \overline{\text { ERR }} & \overline{\text { MERR }}\end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write | Generate check word | L L | Input | H | X | Output check bits $\dagger$ | L | H H |

${ }^{\dagger}$ See Table 2 for details on check bit generation.

## memory write cycle details

During a memory write cycle, the check bits (CBO thru CB6) are generated internally in the EDAC by seven 16 -input parity generators using the 32 -bit data word as defined in Table 2 . These seven check bits are stored in memory along with the original 32 -bit data word. This 32 -bit word will later be used in the memory read cycle for error detection and correction.

## SN54ALS632A, SN54ALS633 THRU SN54ALS635 <br> SN74ALS632A, SN74ALS633 THRU SN74ALS635 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS

TABLE 2. PARITY ALGORITHM

| CHECK WORD BIT | 32-BIT DATA WORD |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 313029282 |  |  |  | 272 |  | 25 | 24 | 23 | 222 | 21 | 20 | 191 | 181 | 17 | 16 | 1514 |  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CBO | X |  | X | X |  | X |  |  |  |  | X |  | X | X | X |  |  | X |  |  | X |  | X | X | X | X |  | X |  |  |  | $X$ |
| CB1 |  |  |  | X |  | X |  | X |  | X |  | X |  | X | X | $x$ |  |  |  | X |  | X |  | $X$ |  | X |  | X |  | X | X | X |
| CB2 | X |  | X |  |  | X | X |  | X |  |  | X | X |  |  | X | X |  | X |  |  | X | X |  | X |  |  | X | X |  |  | X |
| CB3 |  |  | X | X | X |  |  |  | X | $x$ | $x$ |  |  |  | X | X |  |  | X | X | X |  |  |  | X | $x$ | $x$ |  |  |  | X | X |
| CB4 | $x$ | X |  |  |  |  |  |  | X | X | X | X | X | X |  |  | X | X |  |  |  |  |  |  | X | X | X | X | X | X |  |  |
| CB5 ${ }^{\circ}$ | $x$ | X | $x$ | X | X | X | X | $x$ |  |  |  |  |  |  |  |  | X | X | X | X | X | X | X | $x$ |  |  |  |  |  |  |  |  |
| CB6 | X | X | X | X | X | X | X | X |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | X | X | X | X | X | X | X | X |

The seven check bits are parity bits derived from the matrix of data bits as indicated by " $X$ " for each bit.

## error detection and correction details

During a memory read cycle, the 7-bit check word is retrieved along with the actual data. In order to be able to determine whether the data from memory is acceptable to use as presented to the bus, the error flags must be tested to determine if they are at the high level.
The first case in Table 3 represents the normal, no-error conditions. The EDAC presents highs on both flags. The next two cases of single-bit errors give a high on $\overline{M E R R}$ and a low on $\overline{E R R}$, which is the signal for a correctable error, and the EDAC should be sent through the correction cycle. The last three cases of double-bit errors will cause the EDAC to signal lows on both $\overline{\operatorname{ERR}}$ and $\overline{M E R R}$, which is the interrupt indication for the CPU.

TABLE 3. ERROR FUNCTION

| TOTAL NUMBER OF ERRORS |  | ERROR FLAGS |  | DATA CORRECTION |
| :---: | :---: | :---: | :---: | :---: |
| 32-BIT DATA WORD | 7-BIT CHECK WORD | ERR | $\overline{\text { MERR }}$ |  |
| 0 | 0 | $H$ | $H$ | Not applicable |
| 1 | 0 | L | H | Correction |
| 0 | 1 | L | H | Correction |
| 1 | 1 | L | L | Interrupt |
| 2 | 0 | L | L | Interrupt |
| 0 | 2 | L | L | Interrupt |

Error detection is accomplished as the 7-bit check word and the 32-bit data word from memory are applied to internal parity generators/checkers. If the parity of all seven groupings of data and check bits are correct, it is assumed that no error has occurred and both error flags will be high.

If the parity of one or more of the check groups is incorrect, an error has occurred and the proper error flag or flags will be set low. Any single error in the 32-bit data word will change the state of either three or five bits of the 7-bit check word. Any single error in the 7-bit check word changes the state of only that one bit. In either case, the single error flag ( $\overline{\mathrm{ERR}}$ ) will be set low while the dual error flag ( $\overline{\mathrm{MERR}})$ will remain high.

Any two-bit error will change the state of an even number of check bits. The two-bit error is not correctable since the parity tree can only identify single-bit errors. Both error flags are set low when any two-bit error is detected.

Three or more simultaneous bit errors can cause the EDAC to believe that no error, a correctable error, or an uncorrectable error has occurred and will produce erroneous results in all three cases. It should be noted that the gross-error conditions of all lows and all highs will be detected.
tABLE 4. READ, FLAG, AND CORRECT FUNCTION

| MEMORY CYCLE | EDAC FUNCTION | CONTROL  <br> S1 so |  | DATA I/O | $\begin{array}{\|c\|} \hline \text { DB CONTROL } \\ \overline{\text { OEBn OR }} \\ \overline{O E D B} \\ \hline \end{array}$ | DB OUTPUT LATCH <br> ('ALS632A, 'ALS633) <br> $\overline{\text { LEDBO }}$ | CHECK I/O | CB CONTROL $\overline{\text { OECB }}$ | ERROR FLAGS <br> ERR MERR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | Read \& flag | H | L | Input | H | X | Input | H | Enabled $\dagger$ |
| Read | Latch input data \& check bits | H | H | Latched input data | H | L | Latched input check word | H | Enabled $\dagger$ |
| Read | Output corrected data \& syndrome bits | H | H | Output corrected data word | L | X | Output syndrome bits $\ddagger$ | L | Enabled $\dagger$ |

$\dagger$ See Table 3 for error description.
$\ddagger$ See Table 5 for error location.
As the corrected word is made available on the data I/O port (DBO thru DB31), the check word I/O port (CB0 thru CB6) presents a 7-bit syndrome error code. This syndrome error code can be used to locate the bad memory chip. See Table 5 for syndrome decoding.

## SN54ALS632A, SN54ALS633 THRU SN54ALS635 SN74ALS632A, SN74ALS633 THRU SN74ALS635 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS

TABLE 5. SYNDROME DECODING



| SYNDROME BITS |  |  |  |  |  |  |  | ERROR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6 | 5 | 54 | 3 | 2 |  | 1 | 0 | ERROR |
| H | L | L | L | L |  | L | L | 2-bit |
| H | L | L | L | L |  | L | H | unc |
| H | L | L | L |  | H | H | L | unc |
| H | L | L | L | L |  |  | H | 2-bit |
| H | L | L | L | H |  | L | L | unc |
| H | L | L | L |  |  | L | H | 2-bit |
| H | L | L | L | H | H | H | L | 2-bit |
| H | L | L | L | H |  | H | H | unc |
| H | L | L | H | L |  |  | L | unc |
| H | L | L | H | L |  |  | H | 2-bit |
| H | L | L | H | L | H |  | L | 2-bit |
| H | 1 | L | H | L | H | H | H | DB15 |
| H | L | L | H | H |  |  | L | 2-bit |
| H | 1 | L | H | H |  | L | H | unc |
| H | L | L | H | H | H | H | L | DB14 |
| H | L | L | H | H | H | H | H | 2-bit |
| H | L | H | L | L |  |  | L | unc |
| H | L | H | L | L |  |  | H | 2-bit |
| H | L | H | L | L | H | H | L | 2-bit |
| H | L | H | L | L | H | H | H | DB13 |
| H | L | H | L |  |  |  | L | 2-bit |
| H | L | H | L | H |  | L | H | DB12 |
| H | L | H | L | H | H | H | L | DB11 |
| H | L | H | L | H | H | H | H | 2-bit |
| H | L | H | H | L |  |  | L | 2-bit |
| H | L | H | H | L |  | L | H | DB10 |
| H | L | H | H | L | H | H | L | DB9 |
| H | L | H | H | L | H | H | H | 2-bit |
| H | L | H | H | H |  |  | L | DB8 |
| H | L | H | H | H | L | L | H | 2-bit |
| H | L | H | H | H | H | H | L | 2-bit |
| H | L | H | H | H | H | H | H | CB5 |


| SYNDROME BITS |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6 | 5 | 4 | 3 | 2 |  | 1 | 0 | ERROR |
| H | H | L | L |  |  | L | L | unc |
| H | H | L | L | L |  | L | H | 2-bit |
| H | H | L | L | L | H | H | L | 2-bit |
| H | H | L | L | L |  | H | H | DB23 |
| H | H | L | L | H |  | L | L | 2-bit |
| H | H | L | L | H |  | L | H | DB22 |
| H | H | L | L | H | H | H | L | DB21 |
| H | H | L | L | H |  | H | H | 2-bit |
| H | H | L | H |  |  | L | L | 2-bit |
| H | H | L | H | L |  | L | H | DB20 |
| H | H | L | H | L | H | H | L | DB19 |
| H | H | L | H | L | H | H | H | 2-bit |
| H | H | L | H | H |  | L | L | DB18 |
| H | H | L | H | H |  | L | H | 2-bit |
| H | H | L | H | H |  | H | L | 2-bit |
| H | H | L | H | H | H | H | H | CB4 |
| H | H | H | L |  |  | L | L | 2-bit |
| H | H | H | L | L |  | L | H | DB16 |
| H | H | H | L |  | H | H | L | unc |
| H | H | H | L. | L | H | H | H | 2-bit |
| H | H | H | L |  |  | L | L | DB17 |
| H | H | H | L | H |  | L | H | 2-bit |
| H | H | H | L | H | H | H | L | 2-bit |
| H | H | H | L | H |  | H | H | CB3 |
| H | H | H | H |  |  | L | L | unc |
| H | H | H | H | L | L | L | H | 2-bit |
| H | H | H | H | L | L | H | L | 2-bit |
| H | H | H | H |  | L | H | H | CB2 |
| H | H | H | H |  |  | L | L | 2-bit |
| H | H | H | H | H | H | L | H | CB1 |
| H | H | H | H | H |  | H | L | CBO |
| H | H | H | H | H | H | H | H | none |

CB $X=$ error in check bit $X$
DB $Y=$ error in data bit $Y$
2-bit = double-bit error
unc $=$ uncorrectable multibit error

## read-modify-write (byte control) operations

The 'ALS632A and 'ALS633 devices are capable of byte-write operations. The 39-bit word from memory must first be latched into the DB and CB input latches. This is easily accomplished by switching from the read and flag mode ( $\mathrm{S} 1=\mathrm{H}, \mathrm{SO}=\mathrm{L}$ ) to the latch input mode $(\mathrm{S} 1=\mathrm{H}, \mathrm{SO}=\mathrm{H})$. The EDAC will then make any corrections, if necessary, to the data word and place it at the input of the output data latch. This data word must then be latched into the output data latch by taking $\overline{\text { LEDBO }}$ from a low to a high.
Byte control can now be employed on the data word through the $\overline{\mathrm{OEB}} 0$ through $\overline{\mathrm{OEB}} 3$ controls. $\overline{\mathrm{OEB} O}$ controls DBO-DB7 (byte 0), $\overline{\mathrm{OEB}} 1$ controls DB8-DB15 (byte 1), $\overline{\mathrm{OEB}} 2$ controls DB16-DB23 (byte 2), and $\overline{\mathrm{OEB}} 3$ controls DB24-DB31 (byte 3). Placing a high on the byte control will disable the output and the user can modify the byte. If a low is placed on the byte control, then the original byte is allowed to pass onto the data bus unchanged. If the original data word is altered through byte control, a new check word must be generated before it is written back into memory. This is easily accomplished by taking control S1 and SO low. Table 6 lists the read-modify-write functions.

TABLE 6. READ-MODIFY-WRITE FUNCTION

| MEMORY <br> CYCLE | EDAC FUNCTION | $\begin{gathered} \text { CONTROL } \\ \text { S1 so } \end{gathered}$ | BYTEn $\dagger$ | $\overline{\text { OEB }} \dagger$ | $\begin{gathered} \text { DB OUTPUT } \\ \text { LATCH } \\ \hline \text { LEDBO } \\ \hline \end{gathered}$ | CHECK I/O | CB <br> CONTROL | ERROR FLAG <br> $\overline{\text { ERR }} \overline{\text { MERR }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | Read \& Flag | H L | Input | H | X | Input | H | Enabled |
| Read | Latch input data \& check bits | 'H H | Latched Input data | H | L | Latched input check word | H | Enabled |
| Read | Latch corrected data word into output latch | H H | Latched output data word | H | H | $\begin{array}{\|c\|} \hline-\frac{\mathrm{Hi}-\mathrm{Z}}{\text { Output }} \\ \text { Syndrome } \\ \text { bits } \end{array}$ |  | Enabled |
| Modify /write | Modify appropriate byte or bytes \& generate new check word | L L | Input modified BYTEO <br> Output unchanged BYTEO | H <br> L | H | Output check word | L | H H |

$\dagger \overline{\mathrm{OEB}}$ controls DBO-DB7 (BYTEO), $\overline{\mathrm{OEB}} 1$ controls DB8-DB15 (BYTE1), $\overline{\mathrm{OEB}} 3$ controls DB16-DB23 (BYTE2), $\overline{\mathrm{OEB}} 3$ controls DB24-DB31 (BYTE3).

## diagnostic operations

The 'ALS632A and 'ALS633 thru 'ALS635 are capable of diagnostics that allow the user to determine whether the EDAC or the memory is failing. The diagnostic function tables will help the user to see the possibilities for diagnostic control.

In the diagnostic mode ( $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{H}$ ), the checkword is latched into the input latch while the data input latch remains transparent. This lets the user apply various data words against a fixed known checkword. If the user applies a diagnostic data word with an error in any bit location, the $\overline{\operatorname{ERR}}$ flag should be low. If a diagnostic data word with two errors in any bit location is applied, the $\overline{M E R R}$ flag should be low. After the checkword is latched into the input latch, it can be verified by taking $\overline{\mathrm{OECB}}$ low. This outputs the latched checkword. With the 'ALS632A and 'ALS633, the diagnostic data word can be latched into the output data latch and verified. It should be noted that the 'ALS634 and 'ALS635 do not have this pass-through capability because they do not contain an output data latch. By changing from the diagnostic mode ( $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{H}$ ) to the correction mode $(\mathrm{S} 1=\mathrm{H}, \mathrm{SO}=\mathrm{H})$, the user can verify that the EDAC will correct the diagnostic data word. Also, the syndrome bits can be produced to verify that the EDAC pinpoints the error location. Table 7 ('ALS632A and 'ALS633) and Table 8 ('ALS634 and 'ALS635) list the diagnostic functions.

# SN54ALS632A, SN54ALS633 THRU SN54ALS635 <br> SN74ALS632A, SN74ALS633 THRU SN74ALS635 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS 

TABLE 7. 'ALS632A, 'ALS633 DIAGNOSTIC FUNCTION

| EDAC FUNCTION | CONTROL s1 so | DATA I/O | $\begin{gathered} \hline \text { DB BYTE } \\ \text { CONTROL } \\ \overline{\text { OEBn }} \\ \hline \end{gathered}$ | $\begin{gathered} \hline \text { DB OUTPUT } \\ \text { LATCH } \\ \text { LEDBO } \\ \hline \end{gathered}$ | CHECK I/O | $\begin{gathered} \text { CB } \\ \text { CONTROL } \\ \overline{\mathrm{OECB}} \\ \hline \end{gathered}$ | ERROR FLAGS $\overline{\text { ERR }} \overline{\text { MERR }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read \& flag | H L | Input correct data word | H | X | Input correct check bits | H | H H |
| Latch input check word while data input latch remains transparent | L H | Input diagnostic data word ${ }^{\dagger}$ | H | L | Latched input check bits | H | Enabled |
| Latch diagnostic data word into output latch | L H | Input diagnostic data word ${ }^{\dagger}$ | H | H | Output latched check bits $\overline{\mathrm{H}} \mathrm{i}-\mathrm{Z}$ | $\stackrel{\mathrm{L}}{\mathrm{H}^{-}}-$ | Enabled |
| Latch diagnostic data word into input latch | H H | Latched input diagnostic data word | H | H | Output syndrome bits $\overline{\mathrm{Hi}-\mathrm{Z}}$ | $\begin{gathered} L \\ --\frac{1}{H}- \end{gathered}$ | Enabled |
| Output diagnostic data word \& syndrome bits | H H | Output diagnostic data word | L | H | Output syndrome $\frac{\text { bits }}{\mathrm{Hi}-\mathrm{Z}}$ | $\begin{gathered} \mathrm{L} \\ -\mathrm{H}^{-} \end{gathered}$ | Enabled |
| Output corrected diagnostic data word \& output syndrome bits | H H | Output corrected diagnostic data word | L | L | Output syndrome $\frac{\text { bits }}{\mathrm{Hi}-\mathrm{Z}}$ | $\begin{gathered} \mathrm{L} \\ - \\ \hline \end{gathered}$ | Enabled |

${ }^{\dagger}$ Diagnostic data is a data word with an error in one bit location except when testing the $\overline{\mathrm{MERR}}$ error flag. In this case, the diagnostic data word will contain errors in two bit locations.

TABLE 8. 'ALS634, 'ALS635 DIAGNOSTIC FUNCTION

| EDAC FUNCTION | $\begin{gathered} \text { con } \\ \text { s1 } \end{gathered}$ |  | DATA I/O | $\begin{aligned} & \text { DB CONTROL } \\ & \overline{\text { OEDB }} \end{aligned}$ | CHECK I/O | $\begin{aligned} & \text { DB CONTROL } \\ & \overline{\text { OECB }} \end{aligned}$ | ERROR FLAGS $\overline{\text { ERR }}$ $\overline{\text { MERR }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read \& flag | H | L | Input correct data word | H | Input correct check bits | H | H H |
| Latch input check bits while data input latch remains transparent | L | H | Input diagnostic data word ${ }^{\dagger}$ | H | Latched input check bits | H | Enabled |
| Output input check bits | L | H | Input diagnostic data word ${ }^{\dagger}$ | H | Output input check bits | L | Enabled |
| Latch diagnostic data into input latch | H | H | Latched input diagnostic data word | H | $\begin{aligned} & \text { Output } \\ & \text { syndrome bits } \\ & \hline \text { Hi-Z } \end{aligned}$ | $\begin{gathered} \mathrm{L} \\ -\mathrm{H} \end{gathered}$ | Enabled |
| Output corrected diagnostic data word | H | H | Output corrected diagnostic data word | L | $\begin{aligned} & \hline \begin{array}{l} \text { Output } \\ \text { syndrome bits } \end{array} \\ & -\frac{\mathrm{Hi}-\overline{\mathrm{Z}}}{}---- \end{aligned}$ | $-\frac{\mathrm{L}}{\mathrm{H}}-$ | Enabled |

[^19]'ALS632A, 'ALS633 logic diagram (positive logic)

'ALS634, 'ALS635 logic diagram (positive logic)


* 'ALS634 has 3-state ( $\nabla$ ) check-bit and data outputs.
'ALS635 has open-collector $(\boldsymbol{\otimes})$ check-bit and data outputs.
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ (see Note 1)
7 V

Input voltage: CB and DB 5.5 V

All others . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Operating free-air temperature range:
SN74ALS632A, SN74ALS633 thru SN74ALS635 .......... . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Operating case temperature range:
SN54ALS632A, SN54ALS633 thru SN54ALS635 . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended operating conditions

|  |  |  |  | SN54ALS632A <br> SN54ALS633 <br> THRU <br> SN54ALS635 |  |  | SN74ALS632A <br> SN74ALS633 <br> THRU <br> SN74ALS635 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC }}$ Supply voltage |  |  |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ High-level input voltage |  |  |  | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ Low-level input voltage |  |  |  |  |  | 0.8 |  |  | 0.8 | V |
| IOH High-level output current |  | $\overline{\text { ERR }}$ or MERR |  |  |  | -0.4 |  |  | -0.4 | mA |
|  |  | DB or CB | 'ALS632A, 'ALS634 |  |  | -1 |  |  | -2.6 |  |
| 1 OL | Low-level output current | $\overline{\text { ERR }}$ or $\overline{M E R R}$ |  |  |  | 4 |  |  | 8 | mA |
|  |  | DB or CB |  |  |  | 12 |  |  | 24 |  |
| $\mathrm{t}_{\mathrm{W}}$ | Pulse duration | $\overline{\text { LEDBO }}$ low |  | 25 |  |  | 25 |  |  | ns |
| $\mathrm{t}_{\mathrm{su}}$ | Setup time | (1) Data and check word before SO $\uparrow$ ( $\mathrm{S} 1=\mathrm{H}$ ) |  | 15 |  |  | 10 |  |  | ns |
|  |  | $\text { (2) } \mathrm{SO} \mathrm{hi}$ | before $\overline{\text { LEDBO }} \uparrow(\mathrm{S} 1=\mathrm{H})^{\dagger}$ | 45 |  |  | 45 |  |  |  |
|  |  | (3) $\overline{\text { EDBO }}$ high before the earlier of SOL or S1 ${ }^{\dagger}$ |  | 0 |  |  | 0 |  |  |  |
|  |  | (4) $\overline{\text { LED }}$ | high before' $\mathrm{S} 1 \uparrow(\mathrm{SO}=\mathrm{H})$ | 0 |  |  | 0 |  |  |  |
|  |  | $\text { (5) } \begin{aligned} & \text { Diagr } \\ & \text { } \\ & \text { SO }= \end{aligned}$ | stic data word before $\mathrm{S} 1 \uparrow$ | 15 |  |  | 10 |  |  |  |
|  |  | (6) Diag later | stic check word before the S1 $\downarrow$ or $\mathrm{SO} \uparrow$ | 15 |  |  | 10 |  |  |  |
|  |  | (7) Diagn LEDB | stic data word before $\uparrow(\mathrm{S} 1=\mathrm{L} \text { and } \mathrm{SO}=\mathrm{H})^{\ddagger}$ | 25 |  |  | 20 |  |  |  |
| $t_{h}$ | Hold time | (8) Read | mode, SO low and S1 high | 35 |  |  | 30 |  |  | ns |
|  |  | $\text { (9) } \begin{aligned} & \text { Data } \\ & \text { (S1 }= \end{aligned}$ | nd check word after SO $\uparrow$ ) | 20 |  |  | ${ }^{15}$ |  |  |  |
|  |  | (10) Data | ord after S $1 \uparrow(\mathrm{SO}=\mathrm{H})$ | 20 |  |  | 15 |  |  |  |
|  |  | $\begin{aligned} & \text { (11) Chec } \\ & \\ & \text { S1 } \downarrow \mathrm{c} \end{aligned}$ | word after the later of SO $\uparrow$ | 20 |  |  | 15 |  |  |  |
|  |  | (12) Diagn | stic data word after $\uparrow(S 1=L, S O=H)^{\ddagger}$ | 0 |  |  | 0 |  |  |  |
| $\mathrm{t}_{\text {corr }}$ | Correction time (see Figure 1) |  |  | 65 |  |  | 58 |  |  | ns |
| $\mathrm{T}_{\mathrm{C}}$ | Operating case temperature |  |  | -55 |  | 125 |  |  |  | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  |  |  |  |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

${ }^{\dagger}$ These times ensure that corrected data is saved in the output data latch.
$\ddagger$ These times ensure that the diagnostic data word is saved in the output data latch.

## SN54ALS632A, SN54ALS634, SN74ALS632A, SN74ALS634 32-bit Parallel error detection and correction circuits WITH 3-STATE OUTPUTS

'ALS632A, 'ALS634 electrical characteristics over recommended operating temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS | SN54ALS632A SN54ALS634 |  |  | SN74ALS632A SN74ALS634 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $V_{\text {IK }}$ |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | All outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}^{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{OH}=-1 \mathrm{~mA}$ | 2.43 .3 |  |  | 2.43 .2 |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{OH}=-2.6 \mathrm{~mA}$ |  |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | $\overline{\text { ERR }}$ or MERR | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}^{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{OL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{OL}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| I | S0 or S1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | All others | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| I'H | S0 or S1 | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | All others ${ }^{\ddagger}$ |  |  |  | 20 |  |  | 20 |  |
| IIL | SO or S1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.4 |  |  | -0.4 | mA |
|  | All others ${ }^{\ddagger}$ |  |  |  | -0.1 |  |  | -0.1 |  |
| 10 § |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | $-30$ |  | -112 | mA |
| ${ }^{\text {I CC }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, See Note 1 |  | 150 | 250 |  | 150 | 250 | $n \mathrm{n}$ A |

${ }^{\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 ${ }^{\prime} / H$ and $I^{\prime} /$ include the off-state output current.
${ }^{\S}$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los. NOTE 1: ICC is measured with SO and S 1 at 4.5 V and all CB and DB pins grounded.
'ALS632A switching characteristics, $\mathrm{VCC}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{T} \mathrm{C}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ for SN54ALS632A, $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ for SN74ALS632A

| PARAMETER | $\begin{aligned} & \hline \text { FROM } \\ & \text { (INPUT) } \end{aligned}$ | TO (OUTPUT) | TEST CONDITIONS | SN54ALS632A |  | SN74ALS632A |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {tpd }}$ | DB and CB | ERR | $\mathrm{S} 1=\mathrm{H}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ | 10 | 43 | 10 | 40 | ns |
|  | DB | $\overline{\mathrm{ERR}}$ | $S 1=L, S 0=H, R_{L}=500 \Omega$ | 10 | 43 | 10 | 40 |  |
| ${ }^{\text {tpd }}$ | DB and CB | $\overline{\text { MERR }}$ | S1 $=\mathrm{H}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ | 15 | 67 | 15 | 55 | ns |
|  | DB | $\overline{\text { MERR }}$ | $S 1=L, S 0=H, R_{L}=500 \Omega$ | 15 | 67 | 15 | 55 |  |
| ${ }^{\mathrm{t}} \mathrm{pd}$ | S0 $\downarrow$ and $\mathrm{S} 1 \downarrow$ | CB | $\mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 10 | 60 | 10 | 48 | ns |
| tpli | SO $\downarrow$ and S1 $\downarrow$ | ERR | $\mathrm{R}_{\mathrm{L}}=500 \Omega$ | 5 | 30 | 5 | 25 | ns |
| ${ }^{\mathrm{t}} \mathrm{p}$ | DB | CB | $\mathrm{S} 1=\mathrm{L}, \mathrm{S} 0=\mathrm{L}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 10 | 60 | 10 | 48 | ns |
| $t_{\text {pd }}$ | LEDBO $\downarrow$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{S} 0=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 7 | 35 | 7 | 30 | ns |
| ${ }_{\text {t }}{ }^{\text {d }}$ | S1ヶ | CB | $\mathrm{S} 0=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 10 | 60 | 10 | 50 | ns |
| ${ }^{\text {t }}$ en | $\overline{\mathrm{OECB}} \downarrow$ | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{S} 1=\mathrm{X}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 2 | 30 | 2 | 25 | ns |
| ${ }^{\text {dis }}$ | $\overline{\mathrm{OECB}} \uparrow$ | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{S} 1=\mathrm{X}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 2 | 30 | 2 | 25 | ns |
| $\mathrm{t}_{\text {en }}$ | $\overline{\text { OEB } 0 ~ t h r u ~} \overline{\text { OEB }} 3 \downarrow$ | DB | SO $=\mathrm{H}, \mathrm{S} 1=\mathrm{X}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 2 | 30 | 2 | 25 | ns |
| ${ }^{\text {d }}$ dis | $\overline{\mathrm{OEB}}$ thru $\overline{\mathrm{OEB}} 3 \uparrow$ | DB | $S 0=H, S 1=X, R 1=R 2=500 \Omega$ | 2 | 30 | 2 | 25 | ns |

SN54ALS634, SN74ALS634
32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS WITH 3-STATE OUTPUTS
'ALS634 switching characteristics, VCC $=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{TC}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ for SN54ALS634, $\mathrm{TA}_{\mathrm{A}}=\mathbf{0}^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ for SN74ALS634

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS | SN54ALS634 |  | SN74ALS634 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | MAX | MIN | MAX |  |
| ${ }^{t} \mathrm{pd}$ | DB and CB | $\overline{E R R}$ | S1 $=\mathrm{H}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ | 10 | 43 | 10 | 40 | ns |
|  |  |  | S1 = L, S0 = H, R ${ }_{L}=500 \Omega$ | 10 | 43 | 10 | 40 |  |
| $t_{\text {pd }}$ | $D B$ and CB | $\overline{\text { MERR }}$ | S1 = H, SO $=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ | 15 | 67 | 15 | 55 | ns |
|  |  |  | S1 $=\mathrm{L}, \mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ | 15 | 67 | 15 | 55 |  |
| ${ }^{\text {p }}$ d | SO $\downarrow$ and S1 $\downarrow$ | CB | $\mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 10 | 60 | 10 | 48 | ns |
| tPLH | SO $\downarrow$ and $\mathrm{S} 1 \downarrow$ | ERR | $\mathrm{R}_{\mathrm{L}}=500 \Omega$ | 5 | 30 | 5 | 25 | ns |
| $t_{\text {pd }}$ | DB | CB | $\mathrm{S} 1=\mathrm{L}, \mathrm{S} 0=\mathrm{L}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 10 | 60 | 10 | 48 | ns |
| ${ }_{\text {tpd }}$ | S1T | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 7 | 35 | 7 | 30 | ns |
| ten | $\overline{\text { OECB }} \downarrow$ | CB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 2 | 30 | 2 | 25 | ns |
| ${ }^{\text {dis }}$ | $\overline{\mathrm{OECB}} \uparrow$ | CB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 2 | 30 | 2 | 25 | ns |
| ten | $\overline{\text { OEDB } \downarrow}$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 2 | 30 | 2 | 30 | ns |
| $\mathrm{t}_{\text {dis }}$ | $\overline{\text { OEDB } \uparrow}$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{S} 0=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ | 2 | 30 | 2 | 25 | ns |

## 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS WITH OPEN-COLLECTOR OUTPUTS

'ALS633 electrical characteristics over recommended operating temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54ALS633 |  |  | SN74ALS633 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\text { }}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $V_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\boldsymbol{I}=-18 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | $\overline{\text { ERR }}$ or MERR | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V},{ }^{\mathrm{I}} \mathrm{OH}=-0.4 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
| ${ }^{1} \mathrm{OH}$ | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | $\overline{\text { ERR }}$ or $\overline{M E R R}$ | $V_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| 11 | S0 or S1 | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | All others | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{I}}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| 1 | S0 or S1 | $V_{C C}=5.5 \mathrm{~V}$, | $V_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| गH | All others ${ }^{\ddagger}$ |  |  |  |  | 20 |  |  | 20 |  |
| IIL | S0 or S1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{I}}=0.4 \mathrm{~V}$ |  |  |  | -0.4 |  |  | -0.4 | mA |
|  | All others ${ }^{\ddagger}$ |  |  |  |  | -0.1 |  |  | -0.1 |  |
| $\mathrm{l}_{0} \mathrm{O}^{\text {¢ }}$ | $\overline{\text { ERR }}$ or MERR | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | $-30$ |  | -112 | $-30$ |  | -112 | mA |
| ${ }^{\text {ICC }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | See Note 1 |  | 150 | 250 |  | 150 | 250 | 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 off-state output current.
$\S$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS. NOTE 1: ICC is measured with SO and S1 at 4.5 V and all CB and DB pins grounded.
'ALS633 switching characteristics, $\mathrm{VCC}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{TC}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ for SN54ALS633, $\mathrm{TA}_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ for SN74ALS633

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS | SN54ALS633 |  | SN74ALS633 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {tpd }}$ | DB and CB | ERR | $\mathrm{S} 1=\mathrm{H}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ | 10 | 43 | 10 | 40 | ns |
|  | DB | ERR | $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ | 10 | 43 | 10 | 40 |  |
| ${ }^{\text {tpd }}$ | DB and CB | $\overline{M E R R}$ | $\mathrm{S} 1=\mathrm{H}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ | 15 | 67 | 15 | 55 | ns |
|  |  |  | $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ | 15 | 67 | 15 | 55 |  |
| ${ }^{\text {tpd }}$ | SO $\downarrow$ and S1 $\downarrow$ | CB | $\mathrm{R}_{\mathrm{L}}=680 \Omega$ | 10 | 75 | 10 | 60 | ns |
| tpLH | SO $\downarrow$ and S1 $\downarrow$ | $\overline{\text { ERR }}$ | $\mathrm{R}_{\mathrm{L}}=500 \Omega$ | 5 | 30 | 5 | 25 | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | DB | CB | $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ | 10 | 70 | 10 | 60 | ns |
| ${ }_{\text {t }}$ d | $\overline{\text { LEDBO } \downarrow ~}$ | DB | S1 = X, S0 = H, R ${ }_{\text {L }}=680 \Omega$ | 15 | 70 | 15 | 50 | ns |
| ${ }^{\mathrm{t} p \mathrm{~d}}$ | S19 | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{P}_{\mathrm{L}}=680 \Omega$ | 10 | 60 | 10 | 45 | ns |
| tPLH | $\overline{\mathrm{OECB}} \uparrow$ | CB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ | 2 | 35 | 2 | 30 | ns |
| tPHL | $\overline{\text { OECB } \downarrow}$ | CB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ | 2 | 35 | 2 | 30 | ns |
| tPLH | $\overline{\mathrm{OEB}} 0$ thru $\overline{\mathrm{OEB}} 3 \uparrow$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=H, \mathrm{R}_{L}=680 \Omega$ | 2 | 35 | 2 | 30 | ns |
| ${ }^{\text {tPHL }}$ | ОEBO thru $\overline{\mathrm{OEB}} 3 \downarrow$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{S} 0=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ | 2 | 35 | 2 | 30 | ns |

32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS WITH OPEN-COLLECTOR OUTPUTS
'ALS635 electrical characteristics over recommended operating temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54ALS635 |  |  | SN74ALS635 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $I_{1}=-18 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | $\overline{\text { ERR }}$ or MERR | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |  | $V_{C C}-2$ |  |  | $V_{C C}-2$ |  |  | V |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | $\overline{\text { ERR }}$ or MERR | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  | DB or | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{OLL}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| リ | S0 or S1 | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  |  |  |  |  | mA |
|  | All others | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{i}}=5.5 \mathrm{~V}$ |  |  |  |  |  |  |  |
| IH | S0 or S1 | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=2.7 \mathrm{~V}$ |  |  |  |  |  |  |  | $\mu \mathrm{A}$ |
|  | All others ${ }^{\ddagger}$ |  |  |  |  |  |  |  |  |  |
| IIL | S0 or S1 | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=0.4 \mathrm{~V}$ |  |  |  |  |  |  |  | mA |
|  | All others ${ }^{\ddagger}$ |  |  |  |  |  |  |  |  |  |
| $10 \%$ | $\overline{\text { ERR }}$ or MERR | $V_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | $-30$ |  | -112 | $-30$ |  | -112 | mA |
| ${ }^{1} \mathrm{CC}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | See Note 1 | 150 |  |  | 150 |  |  | mA |

$\dagger^{\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 $I_{I H}$ and $I_{I L}$ include the off-state output current.
§ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS. NOTE 1: ICC is measured with SO and S1 at 4.5 V and all CB and DB pins grounded.
'ALS635 switching characteristics, $\mathrm{VCC}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{CL}=50 \mathrm{pF}, \mathrm{TC}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ for SN54ALS635, TA $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ for SN74ALS635

| PARAMETER | $\begin{gathered} \hline \text { FROM } \\ \text { (INPUT) } \end{gathered}$ | TO (OUTPUT) | TEST CONDITIONS | SN54ALS635 |  |  | SN74ALS635 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP ${ }^{\text {t }}$ | MAX | MIN | TYP ${ }^{\text {t }}$ | MAX |  |
| ${ }^{\text {tpd }}$ | DB and CB | ERR | $\mathrm{S} 1=\mathrm{H}, \mathrm{S} 0=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 26 |  |  | 26 |  | ns |
|  | DB | $\overline{\text { ERR }}$ | $S 1=L, S 0=H, R_{L}=500 \Omega$ |  | 26 |  |  | 26 |  |  |
| ${ }^{t} \mathrm{pd}$ | DB and CB | $\overline{\text { MERR }}$ | $\mathrm{S} 1=\mathrm{H}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 40 |  |  | 40 |  | ns |
|  |  |  | S1 = L, SO = H, R $\mathrm{R}_{\text {c }}=500 \Omega$ |  | 40 |  |  | 40 |  |  |
| $\mathrm{t}_{\mathrm{pd}}$ | SO $\downarrow$ and S1 $\downarrow$ | CB | $\mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 40 |  |  | 40 |  | ns |
| tPLH | SO $\downarrow$ and S1 $\downarrow$ | ERR | $\mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 14 |  |  | 14 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}$ | DB | CB | $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 40 |  |  | 40 |  | ns |
| ${ }^{\text {tpd }}$ | S1T | DB | SO $=H, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 40 |  |  | 40 |  | ns |
| tPLH | $\overline{\mathrm{OECB}} \uparrow$ | CB | $\mathrm{S} 1=\mathrm{X}, \mathrm{S} 0=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 24 |  |  | 24 |  | ns |
| tPHL | $\overline{\mathrm{OECB}} \downarrow$ | CB | $\mathrm{S} 1=\mathrm{X}, \mathrm{S} 0=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 24 |  |  | 24 |  | ns |
| tPLH | $\overline{\text { OEDB } \uparrow}$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{S} 0=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 24 |  |  | 24 |  | ns |
| tPHL | $\overline{\text { OEDB }}$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{S} 0=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=680 \Omega$ |  | 24 |  |  | 24 |  | ns |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## SN54ALS632A, SN54ALS633 THRU SN54ALS635 <br> SN74ALS632A, SN74ALS633 THRU SN74ALS635 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS



FIGURE 1. READ, FLAG, AND CORRECT MODE SWITCHING WAVEFORMS


FIGURE 2. READ, CORRECT, MODIFY MODE SWITCHING WAVEFORMS

SN54ALS632A, SN54ALS633 THRU SN54ALS635
SN74ALS632A, SN74ALS633 THRU SN74ALS635

## 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS



FIGURE 3. DIAGNOSTIC MODE SWITCHING WAVEFORM

## 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS

- Detects and Corrects Single-Bit Errors
- Detects and Flags Dual-Bit Errors
- Built-In Diagnostic Capability
- Fast Write and Read Cycle Processing Times
- Byte-Write Capability . . . 'AS632
- Dependable Texas Instruments Quality and Reliability

| DEVICE | PACKAGE | BYTE-WRITE | OUTPUT |
| :---: | :---: | :---: | :---: |
| 'AS632 | $52-$ pin | yes | 3-State |
| 'AS634 | $48-\mathrm{pin}$ | no | 3-State |

## description

The 'AS632 and 'AS634 devices are 32-bit parallel error detection and correction circuits (EDACs) in 52-pin ('AS632) or 48-pin ('AS634) 600 -mil packages. The EDACs use a modified Hamming code to generate a 7 -bit check word from a 32-bit data word. This check word is stored along with the data word during the memory write cycle. During the memory read cycle, the 39 -bit words from memory are processed by the EDACs to determine if errors have occurred in memory.

Single-bit errors in the 32-bit data word are flagged and corrected.

Single-bit errors in the 7-bit check word are flagged, and the CPU sends the EDAC through the correction cycle even though the 32-bit data word is not in error. The correction cycle will simply pass along the original 32-bit data word in this case and produce error syndrome bits to pinpoint the error-generating location.

Dual-bit errors are flagged but not corrected. These errors may occur in any two bits of the 39-bit data word from memory (two errors in the 32-bit data word, two errors in the 7-bit check word, or one error in each word). The gross-error condition of all lows or all highs from memory will be detected. Otherwise, errors in three or more bits of the 39-bit word are beyond the capabilities of these devices to detect.
'AS632 . . . JD PACKAGE
(TOP VIEW)

| LEDBO | 1 | 52 | $\mathrm{V}_{\mathrm{Cc}}$ |
| :---: | :---: | :---: | :---: |
| $\overline{\text { MERR }}$ | 2 | 51 | -S1 |
| ERR | 3 | 50 | -So |
| DBO | 4 | 49 | ]DB31 |
| DB1 | 5 | 48 | дDB30 |
| DB2 | 6 | 47 | Пов29 |
| DB3 | 7 | 46 | ПоB28 |
| DB4 | 8 | 45 | -DB27 |
| DB5 | 9 | 44 | ]be6 |
| OEBO | 10 | 43 | -ОEB3 |
| DB6 | 11 | 42 | ¢ D25 |
| DB7 | 12 | 41 | ]DB24 |
| GND | 13 | 40 | GND |
| DB8 | 14 | 39 | DB23 |
| DB9 | 15 | 38 | - ${ }^{\text {d } 22}$ |
| OEB1 | 16 | 37 | ] $\overline{O E B} 2$ |
| DB10 | 17 | 36 | DB21 |
| DB11 | 18 | 35 | - ${ }^{\text {d } 20}$ |
| DB12 | 19 | 34 | ]DB19 |
| DB13 | 20 | 33 | - DB 18 |
| DB14 | 21 | 32 | - ${ }^{\text {d }} 17$ |
| DB15 | 22 | 31 | дDB16 |
| CB6 | 23 | 30 | ]cbo |
| CB5 | 24 | 29 | CB1 |
| CB4 | 25 | 28 | $]^{\text {CB2 }}$ |
| $\overline{\text { OECB }}$ | 26 | 27 | -СВ3 |

'AS632 . . . FN PACKAGE (TOP VIEW)


NC - No internal connection

Read-modify-write (byte-control) operations can be performed with the 'AS632 EDAC by using output latch enable, $\overline{\mathrm{LEDBO}}$, and the individual $\overline{\mathrm{OEB}} 0$ thru $\overline{\mathrm{OEB}} 3$ byte control pins.

Diagnostics are performed on the EDACs by controls and internal paths that allow the user to read the contents of the DB and CB input latches. These will determine if the failure occurred in memory or in the EDAC.



NC - No internal connection

TABLE 1. WRITE CONTROL FUNCTION

| MEMORY <br> CYCLE | EDAC <br> FUNCTION | CONTROL <br> S1 <br> SO | DATA I/O | DB CONTROL <br> $\overline{\text { OEBn OR }}$ <br> $\overline{\text { OEDB }}$ | DB OUTPUT LATCH <br> ('AS632) <br> $\overline{\text { LEDBO }}$ | CHECK I/O | CONTROL <br> $\overline{\text { OECB }}$ | ERROR FLAGS <br> $\overline{\text { ERR }}$ <br> $\overline{M E R R}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write | Generate <br> check word | L L | Input | H | X | Output <br> check bits $\dagger$ | L | H |

${ }^{\dagger}$ See Table 2 for details on check bit generation.

## memory write cycle details

During a memory write cycle, the check bits (CBO thru CB6) are generated internally in the EDAC by seven 16 -input parity generators using the 32 -bit data word as defined in Table 2 . These seven check bits are stored in memory along with the original 32-bit data word. This 32-bit word will later be used in the memory read cycle for error detection and correction.

TABLE 2. PARITY ALGORITHM

| CHECK WORD BIT | 32-BIT DATA WORD |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CBO | X |  | X | X |  | X |  |  |  |  | X |  | $X$ | X | $x$ | - |  | X |  |  | X |  | X | X | X | X |  | X |  |  |  | $x$ |
| CB1 |  |  |  | X |  | $x$ |  | X |  | X |  | $x$ |  | X | X | $x$ |  |  |  | X |  | $x$ |  | $x$ |  | $X$ |  | X |  | X | X | $x$ |
| CB2 | $x$ |  | $x$ |  |  | $x$ | X |  | $x$ |  |  | $x$ | X |  |  | X | $x$ |  | $x$ |  |  | X | $x$ |  | $x$ |  |  | X | $x$ |  |  | $x$ |
| CB3 |  |  | X | X | X |  |  |  | $x$ | X | $x$ |  |  |  | X | X |  |  | X | X | X |  |  |  | X | $x$ | $x$ |  |  |  | X | $x$ |
| CB4 | $x$ | $x$ |  |  |  |  |  |  | X | X | X | X | X | X |  |  | $X$ | $x$ |  |  |  |  |  |  | $X$ | X | $x$ | X | X | $x$ |  |  |
| CB5 | $x$ | X | $x$ | $x$ | $x$ | X | $x$ | $x$ |  |  |  |  |  |  |  |  | X | X | X | X | X | X | X | $x$ |  |  |  |  |  |  |  |  |
| CB6 | X | X | X | X | X | X | X | X |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | X | X | $x$ | X | X | X | X | X |

The seven check bits are parity bits derived from the matrix of data bits as indicated by " $X$ " for each bit.

## error detection and correction details

During a memory read cycle, the 7 -bit check word is retrieved along with the actual data. In order to be able to determine whether the data from memory is acceptable to use as presented to the bus, the error flags must be tested to determine if they are at the high level.
The first case in Table 3 represents the normal, no-error conditions. The EDAC presents highs on both flags. The next two cases of single-bit errors give a high on $\overline{M E R R}$ and a low on $\overline{E R R}$, which is the signal for a correctable error, and the EDAC should be sent through the correction cycle. The last three cases of double-bit errors will cause the EDAC to signal lows on both ERR and MERR, which is the interrupt indication for the CPU.

TABLE 3. ERROR FUNCTION

| TOTAL NUMBER OF ERRORS |  | ERROR FLAGS | DATA CORRECTION |  |
| :---: | :---: | :---: | :---: | :---: |
| 32-BIT DATA WORD | 7-BIT CHECK WORD | ERR |  |  |
| 0 | 0 | $H$ | $H$ | Not applicable |
| 1 | 0 | L | $H$ | Correction |
| 0 | 1 | L | H | Correction |
| 1 | 1 | L | L | Interrupt |
| 2 | 0 | L | L | Interrupt |
| 0 | 2 | L | L | Interrupt |

Error detection is accomplished as the 7 -bit check word and the 32 -bit data word from memory are applied to internal parity generators/checkers. If the parity of all seven groupings of data and check bits are correct, it is assumed that no error has occurred and both error flags will be high.
If the parity of one or more of the check groups is incorrect, an error has occurred and the proper error flag or flags will be set low. Any single error in the 32 -bit data word will change the state of either three or five bits of the 7-bit check word. Any single error in the 7-bit check word changes the state of only that one bit. In either case, the single error flag ( $\overline{\mathrm{ERR}}$ ) will be set low while the dual error flag ( $\overline{\mathrm{MERR}}$ ) will remain high.

Any two-bit error will change the state of an even number of check bits. The two-bit error is not correctable since the parity tree can only identify single-bit errors. Both error flags are set low when any two-bit error is detected.

Three or more simultaneous bit errors can cause the EDAC to believe that no error, a correctable error, or an uncorrectable error has occurred and will produce erroneous results in all three cases. It should be noted that the gross-error conditions of all lows and all highs will be detected.

32-bit Parallel error detection and correction circuits

TABLE 4. READ, FLAG, AND CORRECT FUNCTION

| MEMORY CYCLE | EDAC FUNCTION | $\begin{array}{\|c\|c} \text { CON } 7 \\ \text { S1 } \end{array}$ |  | DATA I/O | DB CONTROL <br> $\overline{\text { OEBn OR }}$ <br> $\overline{O E D B}$ | $\begin{aligned} & \text { DB OUTPUT LATCH } \\ & \text { ('AS632) } \\ & \text { LEDBO } \end{aligned}$ | CHECK 1/O | $\begin{gathered} \text { CB } \\ \text { CONTROL } \\ \hline \overline{O E C B} \\ \hline \end{gathered}$ | ERROR FLAGS <br> ERR MERR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | Read \& flag | H | L | Input | H | X | Input | H | Enabled $\dagger$ |
| Read | Latch input data \& check bits | H | H | Latched input data | H | L | Latched input check word | H | Enabled $\dagger$ |
| Read | Output corrected data \& syndrome bits | H | H | Output corrected data word | L | X | Output syndrome bits $\ddagger$ | L | Enabled $\dagger$ |

${ }^{\dagger}$ See Table 3 for error description.
${ }^{\ddagger}$ See Table 5 for error location.
As the corrected word is made available on the data I/O port (DBO thru DB31), the check word I/O port (CB0 thru CB6) presents a 7-bit syndrome error code. This syndrome error code can be used to locate the bad memory chip. See Table 5 for syndrome decoding.

## SN54AS632, SN54AS634 <br> SN74AS632, SN74AS634 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS

TABLE 5. SYNDROME DECODING


|  |  | NDR | OM | ME B | BITS |  | ERROR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 5 | 4 | 32 | 21 | 1 |  |  |
|  | H | L | L | L | L |  | 2-bit |
|  | H | L | L L | L | L |  | unc |
| L | H | L | L L | L | H | L | DB7 |
|  | H | L | L | L | H | H | 2-bit |
|  | H | L | L | H | L | L | DB6 |
|  | H | L | H | H | L | H | 2-bit |
|  | H | L | H | H | H | L | 2-bit |
|  | H | L | L H | H | H | H | DB5 |
|  | H | L | H | L | L | L | DB4 |
|  | H | L | H | L L | L | H | 2-bit |
|  | H | L | H | L | H | L | 2-bit |
|  | H | L | H | L H | H | H | DB3 |
|  | H | L | H | H | L | L | 2-bit |
|  | H | L | H | H | L | H | DB2 |
|  | H | L | H | H | H | L | unc |
| L | H | L | H | H | H | H | 2-bit |
|  | H | H | L | L | L | L | DBO |
|  | H | H | L | L L | L | H | 2-bit |
|  | H | H | L L | L | H | L | 2-bit |
|  | H | H | L | L H | H | H | unc |
|  | H | H | L | H | L |  | 2-bit |
|  | H | H | L | H | L | H | DB1 |
|  | H | H | L | H | H | L | unc |
|  | H | H | L H | H | H | H | 2-bit |
|  | H | H | H | L | L | L | 2-bit |
|  | H | H | H | L | L | H | unc |
|  | H | H | H | H | H | L | unc |
| L | H | H | H. | L | H | H | 2-bit |
|  | H | H | H | H | L | L | unc |
|  | H | H | H | H | L | H | 2-bit |
| L | H | H | H | H | H | L | 2-bit |
| L | H | H | H | H | H | H | CB6 |


|  |  | YN | RO | M | B |  |  | ERROR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6 |  | 54 | 3 | 2 | 1 | 0 |  |  |
|  | L | L | L | L | L |  |  | 2-bit |
| H | L | L | L | L | L | H |  | unc |
| H |  | L | L | L | H | L |  | unc |
| H |  | L | L | L | H | H |  | 2-bit |
| H |  | L | L | H | L | L |  | unc |
| H | L | L | L | H | L | H |  | 2-bit |
| H | L | L | L | H | H | L |  | 2-bit |
| H |  | L | L | H | H | H |  | unc |
| H |  | L | H | L | L |  |  | unc |
| H |  | L | H | L | L | H |  | 2-bit |
| H | L | L | H | L | H | L |  | 2-bit |
| H |  | L | H | L | H |  |  | DB15 |
|  |  |  | H | H | L |  |  | 2-bit |
| H | L | L | H | H | L | H |  | unc |
| H |  | L | H | H | H |  |  | DB14 |
| H |  | L | H | H | H | H |  | 2-bit |
|  |  | H | L | L | L |  |  | unc |
| H |  | L | L | L | L |  |  | 2-bit |
| H |  | H | L | L | H | H |  | 2-bit |
| H |  | H | L | L | H | H |  | DB13 |
|  |  | H | L | H | L |  |  | 2-bit |
| H |  | L | L | H | L | H |  | DB12 |
| H |  | L | L | H | H | H |  | DB11 |
| H |  | L | L | H | H |  |  | 2-bit |
| H |  | L | H | L | L |  |  | 2-bit |
| H |  | L | H | L | L | H |  | DB10 |
| H |  | L | H | L | H | H |  | DB9 |
| H |  | L | H | L | H | H | H | 2-bit |
| H |  | H |  |  |  |  |  | DB8 |
| H |  | L | H | H | L |  |  | 2-bit |
| H |  | L | H | H | H |  |  | 2-bit |
| H |  | L | H |  |  |  |  | CB5 |


| SYNDROME BITS |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 5 | 4 | 3 | 2 | 2 |  |  | ERROR |
|  | H | L | L | L | L |  |  | unc |
| H | H | L | L | L | L | H |  | 2-bit |
| H | H | L | L | L | H | L |  | 2-bit |
| H | H | L | L | L | H | H |  | DB23 |
|  | H | L | L | H | H |  |  | 2-bit |
| H | H | L | L | H | H |  |  | DB22 |
| H | H | L | L | H | H | L |  | DB21 |
| H | H | L | L | H | H |  |  | 2-bit |
| H | H | L | H | L | L |  |  | 2-bit |
| H | H | L | H | L | L |  |  | DB20 |
| H | H H | L | H | L | H |  |  | DB19 |
| H | H | L | H | L | H | H |  | 2-bit |
|  | H | L | H | H | H |  |  | DB18 |
| H | H | L | H | H | H |  |  | 2-bit |
| H | H | L | H | H | H |  |  | 2-bit |
| H | H | L | H | H | H |  |  | CB4 |
| H | H | H | L | L | L |  |  | 2-bit |
| H | H H | H | L | L | L |  |  | DB16 |
| H | H H | H | L | L | H |  |  | unc |
| H | H H | H | L | L | H |  |  | 2-bit |
| H | H | H | L | H | L |  |  | DB17 |
| H | H | H | L | H | H |  |  | 2-bit |
| H | H H | H | L | H | H |  |  | 2-bit |
| H | H H | H | L | H | H |  |  | CB3 |
| H | H | H | H | L | L |  |  | unc |
| H | H H | H | H | L | L |  |  | 2-bit |
| H | H H | H | H | L | H |  |  | 2-bit |
| H | H H | H | H | L | H |  |  | CB2 |
|  | H | H | H | H | H |  |  | 2-bit |
| H | H H | + | H | H | + |  |  | CB1 |
| H | H H | H | H | H | H |  |  | CBO |
| H | H |  | H |  | H |  |  | none |

$C B X=$ error in check bit $X$
DB $Y=$ error in data bit $Y$
2-bit $=$ double-bit error
unc $=$ uncorrectable multibit error

## read-modify-write (byte control) operations

The 'AS632 is capable of byte-write operations. The 39-bit word from memory must first be latched into the DB and CB input latches. This is easily accomplished by switching from the read and flag mode ( $\mathrm{S} 1=\mathrm{H}$, $S 0=L$ ) to the latch input mode ( $S 1=\mathrm{H}, \mathrm{SO}=\mathrm{H}$ ). The EDAC will then make any corrections, if necessary, to the data word and place it at the input of the output data latch. This data word must then be latched into the output data latch by taking LEDBO from a low to a high.
Byte control can now be employed on the data word through the $\overline{\mathrm{OEB}} 0$ through $\overline{\mathrm{OEB}} 3$ controls. $\overline{\mathrm{OEB}} 0$ controls DBO-DB7 (byte 0), $\overline{\mathrm{OEB}} 1$ controls DB8-DB15 (byte 1), $\overline{\mathrm{OEB}} 2$ controls DB16-DB23 (byte 2), and $\overline{\mathrm{OEB}} 3$ controls DB24-DB31 (byte 3). Placing a high on the byte control will disable the output and the user can modify the byte. If a low is placed on the byte control, then the original byte is allowed to pass onto the data bus unchanged. If the original data word is altered through byte control, a new check word must be generated before it is written back into memory. This is easily accomplished by taking control S1 and SO low. Table 6 lists the read-modify-write functions.

## 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS

## TABLE 6. READ-MODIFY-WRITE FUNCTION

| MEMORY CYCLE | EDAC FUNCTION | $\begin{gathered} \text { CONTROL } \\ \text { S1 So } \end{gathered}$ | BYTEn $\dagger$ | $\overline{\text { OEB }}{ }^{\dagger}$ | $\begin{gathered} \text { DB OUTPUT } \\ \text { LATCH } \\ \hline \text { LEDBO } \\ \hline \end{gathered}$ | CHECK I/O | CB CONTROL | ERROR FLAG $\overline{\text { ERR }} \overline{\text { MERR }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | Read \& Flag | H L | Input | H | X | Input | H | Enabled |
| Read | Latch input data \& check bits | H H | Latched Input data | H | L | Latched input check word | H | Enabled |
| Read | Latch corrected data word into output latch | H H | Latched output data word | H | H | $\begin{gathered} \text { Hi-Z } \\ \text { Output } \\ \text { Syndrome } \\ \text { bits } \end{gathered}$ | $\begin{gathered} H \\ L \end{gathered}$ | Enabled |
| Modify /write | Modify appropriate byte or bytes \& generate new check word | L L | Input modified BYTEO <br> Output unchanged BYTEO | H <br> L | H | Output check word | L | H H |

$\dagger \overline{\mathrm{OEB}} 0$ controls DB0-DB7 (BYTEO), $\overline{\mathrm{OEB}} 1$ controls DB8-DB15 (BYTE1), $\overline{O E B} 3$ controls DB16-DB23 (BYTE2), $\overline{\mathrm{OEB}} 3$ controls DB24-DB31 (BYTE3).

## diagnostic operations

The 'AS632 and 'AS634 are capable of diagnostics that allow the user to determine whether the EDAC or the memory is failing. The diagnostic function tables will help the user to see the possibilities for diagnostic control.

In the diagnostic mode ( $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{H}$ ), the checkword is latched into the input latch while the data input latch remains transparent. This lets the user apply various data words against a fixed known checkword. If the user applies a diagnostic data word with an error in any bit location, the $\overline{E R R}$ flag should be low. If a diagnostic data word with two errors in any bit location is applied, the $\overline{M E R R}$ flag should be low. After the checkword is latched into the input latch, it can be verified by taking $\overline{\mathrm{OECB}}$ low. This outputs the latched checkword. With the 'AS632, the diagnostic data word can be latched into the output data latch and verified. It should be noted that the 'AS634 does not have this pass-through capability because they do not contain an output data latch. By changing from the diagnostic mode ( $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{H}$ ) to the correction mode ( $\mathrm{S} 1=\mathrm{H}, \mathrm{SO}=\mathrm{H}$ ), the user can verify that the EDAC will correct the diagnostic data word. Also, the syndrome bits can be produced to verify that the EDAC pinpoints the error location. Table 7 ('AS632) and Table 8 ('AS634) list the diagnostic functions.

## 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS

TABLE 7. 'AS632 DIAGNOSTIC FUNCTION

| EDAC FUNCTION | $\begin{gathered} \text { CONTROL } \\ \text { S1 S0 } \end{gathered}$ | DATA I/O | DB BYTE CONTROL $\overline{\text { OEBn }}$ | $\begin{gathered} \text { DB OUTPUT } \\ \text { LATCH } \\ \overline{\text { LEDBO }} \end{gathered}$ | CHECK 1/O | $\begin{gathered} \text { CB } \\ \text { CONTROL } \\ \overline{O E C B} \\ \hline \end{gathered}$ | ERROR FLAGS $\overline{\text { ERR }} \overline{\text { MERR }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read \& flag | H L | Input correct data word | H | X | Input correct check bits | H | H H |
| Latch input check word while data input latch remains transparent | L H | Input diagnostic data word ${ }^{\dagger}$ | H | - L | Latched input check bits | H | Enabled |
| Latch diagnostic data word into output latch | L H | Input diagnostic data word ${ }^{\dagger}$ | H | H | Output latched check bits $\mathrm{Hi}-\mathrm{Z}$ | $-\frac{L}{H}--$ | Enabled |
| Latch diagnostic data word into input latch | H H | Latched input diagnostic data word | H | H | Output syndrome $-\frac{\text { bits }}{\mathrm{Hi}-\mathrm{Z}}----$ | $\begin{gathered} L \\ --\frac{-}{H}-- \end{gathered}$ | Enabled |
| Output diagnostic data word \& syndrome bits | H H | Output diagnostic data word | L | H | Output syndrome $-\frac{\text { bits }}{\mathrm{Hi}-Z}-----$ | $\begin{gathered} L \\ ---- \end{gathered}$ | Enabled |
| Output corrected diagnostic data word \& output syndrome bits | H H | Output corrected diagnostic data word | L | L | Output syndrome $-\frac{\text { bits }}{\mathrm{Hi}-Z}-----$ |  | Enabled |


| EDAC FUNCTION | CON |  | DATA I/O | $\begin{aligned} & \text { DB CONTROL } \\ & \text { OEDB } \end{aligned}$ | CHECK I/O | $\begin{aligned} & \text { DB CONTROL } \\ & \overline{\text { OECB }} \end{aligned}$ | ERROR FLAGS <br> ERR <br> MERR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read \& flag | H | L | Input correct data word | H | Input correct check bits | H | $\mathrm{H} \quad \mathrm{H}$ |
| Latch input check bits while data input latch remains transparent | L | H | Input diagnostic data word ${ }^{\dagger}$ | H | Latched input check bits | H | Enabled |
| Output input check bits | L | H | Input diagnostic data word ${ }^{\dagger}$ | H | Output input check bits | L | Enabled |
| Latch diagnostic data into input latch | H | H | Latched input diagnostic data word | H | $\begin{aligned} & \text { Output } \\ & -\frac{\text { syndrome bits }}{\mathrm{Hi}-\mathrm{Z}} \end{aligned}$ | $\frac{\mathrm{L}}{\mathrm{H}} \mathrm{H}^{-}$ | Enabled |
| Output corrected diagnostic data word | H | H | Output corrected diagnostic data word | L | Output syndrome bits $\overline{\mathrm{Hi}}-\bar{Z}$ | $--\frac{\mathrm{L}}{\mathrm{H}^{-}-}$ | Enabled |

[^20]SN54AS632, SN74AS632
32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS
'AS632 logic diagram (positive logic)

'AS634 logic diagram (positive logic)


## 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
$\qquad$
Suply votage VCC (se Not.
Input voltage: CB and DB
All others. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Operating free-air temperature range:
SN74AS632, SN74AS634 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Operating case temperature range:
SN54AS632, SN54AS634 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended operating conditions


[^21]
## SN54AS632, SN54AS634, SN74AS632, SN74AS634 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS WITH 3-STATE OUTPUTS

'AS632, 'AS634 electrical characteristics over recommended operating temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS | SN54AS632 <br> SN54AS634 |  |  | SN74AS632 <br> SN74AS634 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| VIK |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{I}}=-18 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | All outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}^{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\text {CC }}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}^{\mathrm{OH}}=-1 \mathrm{~mA}$ | 2.4 | 3.3 |  |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{OH}=-2.6 \mathrm{~mA}$ |  |  |  | 2.4 | 3.2 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | $\overline{\text { ERR }}$ or MERR | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{OH}}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | DB or CB | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{OL}}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}^{\text {OL }}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| I | S0 or S1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | All others | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| ${ }^{\prime} \mathrm{H}$ | DB or $\mathrm{CB}^{\ddagger}$ | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | Ail others ${ }^{\ddagger}$ |  |  |  | 20 |  |  | 20 |  |
| IIL | S0 or S1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=0.4 \mathrm{~V}$ |  |  | --0.4 |  |  | -0.4 | m |
|  | All others ${ }^{\ddagger}$ |  |  |  | -0.1 |  |  | $-0.1$ | mA |
| $10^{8}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | $-30$ |  | -112 | $-30$ |  | -112 | mA |
| ${ }^{\text {I CC }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, See Note 1 |  | 150 |  |  | 150 |  | mA |

NOTE 1: ${ }^{I} \mathrm{CC}$ is measured with SO and S 1 at 4.5 V and all CB and DB pins grounded.
'AS632 switching characteristics, $\mathrm{V} C \mathrm{C}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{CL}=50 \mathrm{pF}, \mathrm{T} \mathrm{C}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ for SN54AS632, $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ for SN74AS632

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS | SN54AS632 |  |  | SN74AS632 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| ${ }_{\text {t }}^{\text {pd }}$ | DB and CB | $\overline{\text { ERR }}$ | S1 $=\mathrm{H}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 17 |  |  | 17 |  | ns |
|  | DB | $\overline{\text { ERR }}$ | $S 1=L, S 0=H, R_{L}=500 \Omega$ |  | 17 |  |  | 17 |  |  |
| ${ }^{\text {p }}$ d | $D B$ and $C B$ | $\overline{\text { MERR }}$ | $\mathrm{S} 1=\mathrm{H}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 26 |  |  | 26 |  | ns |
|  | DB | $\overline{\text { MERR }}$ | $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 26 |  |  | 26 |  |  |
| $\mathrm{t}_{\mathrm{pd}}$ | SO $\downarrow$ and S1 $\downarrow$ | CB | $\mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 26 |  |  | 26 |  | ns |
| ${ }^{\text {tPLH }}$ | SO $\downarrow$ and S1 $\downarrow$ | $\overline{\text { ERR }}$ | $R_{L}=500 \Omega$ |  | 9 |  |  | 9 |  | ns |
| ${ }_{\text {tpd }}$ | DB | CB | $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{L}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 26 |  |  | 26 |  | ns |
| ${ }^{\text {p }}$ d | $\overline{\text { LEDBO } \downarrow ~}$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 17 |  |  | 17 |  | ns |
| ${ }_{\text {tpd }}$ | S1T | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{R1}=\mathrm{R} 2=500 \Omega$ |  | 26 |  |  | 26 |  | ns |
| $\mathrm{t}_{\mathrm{en}}$ | $\overline{\mathrm{OECB}} \downarrow$ | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{S} 1=\mathrm{X}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 12 |  |  | 12 |  | ns |
| ${ }^{\text {dis }}$ | $\overline{\mathrm{OECB}} \uparrow$ | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{S} 1=\mathrm{X}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 12 |  |  | 12 |  | ns |
| $\mathrm{t}_{\mathrm{en}}$ |  | DB | $\mathrm{SO}=\mathrm{H}, \mathrm{S} 1=\mathrm{X}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 12 |  |  | 12 |  | ns |
| ${ }^{\text {d }}$ dis | $\overline{\mathrm{OEB}}$ thru $\overline{\mathrm{OEB}} 3 \uparrow$ | DB | $\mathrm{SO}=\mathrm{H}, \mathrm{S} 1=\mathrm{X}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 12 |  |  | 12 |  | ns |

${ }^{\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 $I_{I H}$ and $I_{I L}$ include the off-state output current.
$\S$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los.

SN54AS634, SN74AS634

## 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS WITH 3-STATE OUTPUTS

'AS634 switching characteristics, $\mathrm{VCC}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{TC}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ for SN54AS634, $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ for SN74AS634

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS | SN54AS634 |  |  | SN74AS634 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| ${ }^{t} \mathrm{pd}$ | $D B$ and CB | $\overline{\text { ERR }}$ | S1 $=\mathrm{H}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 17 |  |  | 17 |  | ns |
|  |  |  | $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{H}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 17 |  |  | 17 |  |  |
| ${ }^{\text {p }}$ d | DB and CB | $\overline{\text { MERR }}$ | S1 $=\mathrm{H}, \mathrm{SO}=\mathrm{L}, \mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 26 |  |  | 26 |  | ns |
|  |  |  | S1 = L, S0 = H, R ${ }_{\text {L }}=500 \Omega$ |  | 26 |  |  | 26 |  |  |
| $t_{\text {pd }}$ | SO $\downarrow$ and S1 $\downarrow$ | CB | $\mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 23 |  |  | 23 |  | ns |
| ${ }_{\text {tPLH }}$ | SO $\downarrow$ and $\mathrm{S} 1 \downarrow$ | ERR | $\mathrm{R}_{\mathrm{L}}=500 \Omega$ |  | 9 |  |  | 9 |  | ns |
| ${ }_{\text {tpd }}$ | DB | CB | $\mathrm{S} 1=\mathrm{L}, \mathrm{SO}=\mathrm{L}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 23 |  |  | 23 |  | ns |
| $t_{\text {pd }}$ | S1 $\uparrow$ | CB | $\mathrm{SO}=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 23 |  |  | 23 |  | ns |
| $t_{\text {en }}$ | $\overline{\mathrm{OECB}} \downarrow$ | CB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 12 |  |  | 12 |  | ns |
| ${ }^{\text {d }}$ dis | $\overline{\mathrm{OECB}} \uparrow$ | CB | $S 1=X, S 0=H, R 1=R 2=500 \Omega$ |  | 12 |  |  | 12 |  | ns |
| ten | $\overline{\text { OEDB }} \downarrow$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 12 |  |  | 12 |  | ns |
| $\mathrm{t}_{\text {dis }}$ | $\overline{\mathrm{OEDB}} \uparrow$ | DB | $\mathrm{S} 1=\mathrm{X}, \mathrm{SO}=\mathrm{H}, \mathrm{R} 1=\mathrm{R} 2=500 \Omega$ |  | 12 |  |  | 12 |  | ns |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## SN54AS632, SN54AS634 SN74AS632, SN74AS634 32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS



FIGURE 1. READ, FLAG, AND CORRECT MODE SWITCHING WAVEFORMS


FIGURE 2. READ, CORRECT, MODIFY MODE SWITCHING WAVEFORMS

SN54AS632, SN54AS634
SN74AS632, SN74AS634
32-BIT PARALLEL ERROR DETECTION AND CORRECTION CIRCUITS


FIGURE 3. DIAGNOSTIC MODE SWITCHING WAVEFORM

- Independent Registers for A and B Buses
- Multiplexed Real-Time and Stored Data
- Choice of True or Inverting Data Paths
- Choice of 3-State or Open-Collector Outputs
- Included Among the Package Options Are Compact 24-pin 300-mil Wide DIPs and Both 28-pin Plastic and Ceramic Chip Carriers
- Dependable Texas Instruments Quality and Reliability

| DEVICE | OUTPUT | LOGIC |
| :---: | :---: | :---: |
| 'ALS646, 'AS646 | 3-State | True |
| 'ALS647 | Open-Collector | True |
| 'ALS648, 'AS648 | 3-State | Inverting |
| 'ALS649 | Open-Collector | Inverting |

## description

These devices consist of bus transceiver circuits, with 3-state or open-collector outputs, D-type flip-flops, and control circuitry arranged for multiplexed transmission of data directly from the data bus or from the internal storage registers. Data on the A or B bus will be clocked into the registers on the low-to-high transition of the appropriate clock pin (CAB or CBA). The following examples demonstrate the four fundamental bus-management functions that can be performed with the octal bus transceivers and registers.
Enable ( $\overline{\mathrm{G}}$ ) and direction (DIR) pins are provided to control the transceiver functions. In the

SN54ALS', SN54AS' . . . JT PACKAGE SN74ALS', SN74AS' . . . DW OR NT PACKAGE

(TOP VIEW)


SN54ALS', SN54AS' . . . FK PACKAGE SN74ALS', SN74AS' . . . FN PACKAGE (TOP VIEW)

transceiver mode, data present at the high-impedance port may be stored in either register or in both. The select controls (SAB and SBA) can multiplex stored and real-time (transparent mode) data. The circuitry used for select control will eliminate the typical decoding glitch which occurs in a multiplexer during the transition between stored and real-time data. The direction control determines which bus will receive data when enable $\overline{\mathrm{G}}$ is active (low). In the isolation mode (control $\overline{\mathrm{G}}$ high), A data may be stored in one register and/or B data may be stored in the other register.

When an output function is disabled, the input function is still enabled and may be used to store and transmit data. Only one of the two buses, A or B, may be driven at a time.

The -1 versions of the SN74ALS' parts are identical to the standard versions except that the recommended maximum lOL is increased to 48 milliamperes. There are no -1 versions of the SN54ALS' parts.

The SN54' family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.


REAL-TIME TRANSFER
BUS B TO BUS A


STORAGE FROM
A, B, OR A AND B


REAL-TIME TRANSFER BUS A TO BUS B


| (21) | (3) | (1) | (23) | (2) | (22) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| G | DIR | CAB | CBA | SAB | SBA |
| L | L | X | HorL | X | H |
| L | H | HorL | X | H | X |
| TRANSFER |  |  |  |  |  |
|  | STORED DATA |  |  |  |  |
|  | TO A OR B |  |  |  |  |

## SN54ALS646 THRU SN54ALS649, SN54AS646, SN54AS648 SN74ALS646 THRU SN74ALS649, SN74AS646, SN74AS648 OCTAL BUS TRANSCEIVERS AND REGISTERS

FUNCTION TABLE

| INPUTS |  |  |  |  |  | DATA 1/O |  | OPERATION OR FUNCTION |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| G | DIR | CAB | CBA | SAB | SBA | A1 THRU A8 | B1 THRU B8 | 'ALS646, 'ALS647 AS646 | ALS648, 'ALS649 'AS648 |
| X <br> $\times$ | X X | $\uparrow$ $\times$ | X $\uparrow$ $\uparrow$ | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | X X | Input Unspecified ${ }^{\dagger}$ | Unspecified $^{\dagger}$ Input | Store A, B unspecified ${ }^{\dagger}$ <br> Store B, A unspecified ${ }^{\dagger}$ | Store A, B unspecified ${ }^{\dagger}$ <br> Store B, A unspecified ${ }^{\dagger}$ |
| H $H$ | $\begin{aligned} & x \\ & x \end{aligned}$ | H or L | Hor L | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | Input | Input | Store A and B Data Isolation, hold storage | Store A and B Data Isolation, hold storage |
| L $L$ |  | $\begin{aligned} & x \\ & x \end{aligned}$ |  | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | Output | Input | Real-Time B Data to A Bus Stored B Data to A Bus | Real-Time $\bar{B}$ Data to A Bus Stored $\bar{B}$ Data to A Bus |
| L | H H |  | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{gathered} \mathrm{L} \\ \mathrm{H} \end{gathered}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | Input | Output | Real-Time A Data to B Bus Stored A Data to B Bus | Real-Time $\bar{A}$ Data to $B$ Bus Store $\bar{A}$ Data to B Bus |

${ }^{\dagger}$ The data output functions may be enabled or disabled by various signals at the $\bar{G}$ and DIR inputs. Data input functions are always enabled, i.e., data at the bus pins will be stored on every low-to-high transition on the clock inputs.
functional block diagrams (positive logic)
'ALS646, 'AS646, 'ALS647


TO 7 OTHER CHANNELS
'ALS648, 'AS648, 'ALS649


SN54ALS646 THRU SN54ALS649, SN54AS646, SN54AS648 SN74ALS646 THRU SN74ALS649, SN74AS646, SN74AS648 OCTAL BUS TRANSCEIVERS AND REGISTERS
logic symbols ${ }^{\dagger}$
'ALS646, 'AS646

'ALS648, 'AS648

'ALS647

'ALS649

${ }^{\dagger}$ These symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers shown are for DW, JT, and NT packages.

## SN54ALS646, SN74ALS646 OCTAL BUS TRANSCEIVERS AND REGISTERS WITH 3-STATE OUTPUTS

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| Supply voltage, VCC | 7 V |
| :---: | :---: |
| Input voltage: Control inputs | 7 V |
| I/O ports | 5.5 V |
| Operating free-air temperature range: SN54ALS646 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
| SN74ALS646 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions

${ }^{\dagger}$ The extended condition applies if $\mathrm{V}_{\mathrm{CC}}$ is maintained between 4.75 V and 5.25 V .
The 48-mA limit applies for the SN74ALS646-1 only.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54ALS646 |  |  | SN74ALS646 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $\mathrm{V}_{\mathrm{IK}}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | I $=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}-2}$ |  |  | V |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.4 | 3.2 |  | 2.4 | 3.2 |  |  |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{l}_{\mathrm{OH}}=-12 \mathrm{~mA}$ | 2 |  |  |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-15 \mathrm{~mA}$ |  |  |  | 2 |  |  |  |
| $V_{\text {OL }}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \\ & \mathrm{IOL}=48 \mathrm{~mA} \end{aligned}$ | $\mathrm{IOL}=24 \mathrm{~mA}$ <br> version) |  |  |  |  | 0.35 | 0.5 |  |
| 1 | Control inputs | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | A or B ports | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| $\mathrm{IIH}^{\text {H }}$ | Control inputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | A or B ports§ |  |  |  |  | 20 |  |  | 20 |  |
|  | Control inputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=0.4 \mathrm{~V}$ |  |  |  | -0.2 |  |  | -0.2 | mA |
| IL | A or B ports ${ }^{\text {§ }}$ |  |  |  |  | -0.2 |  |  | -0.2 |  |
| 101 |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ${ }^{1} \mathrm{CC}$ |  | $V_{C C}=5.5 \mathrm{~V}$ | Outputs high |  | 47 | 76 |  | 47 | 76 | mA |
|  |  | Outputs low |  | 55 | 88 |  | 55 | 88 |  |
|  |  | Outputs disabled |  | 55 | 88 |  | 55 | 88 |  |

[^22]§For I/O ports, the parameters $I_{I H}$ and $I_{I L}$ include the off-state output current.
IThe output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los.

SN54ALS646, SN74ALS646
OCTAL BUS TRANSCEIVERS AND REGISTERS
WITH 3-STATE OUTPUTS
'ALS646 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{R} 1=500 \Omega \\ & \mathrm{R} 2=500 \Omega \\ & \mathrm{~T}_{\mathbf{A}}=25^{\circ} \mathrm{C} \\ & \hline \mathrm{ALS} 646 \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=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}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | SN54ALS646 |  | SN74ALS646 |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  |  | 50 |  | 35 |  | 40 |  | MHz |
| tplH | CBA or CAB | $A$ or $B$ |  | 2.0 | 25 | 10 | 35 | 10 | 30 | ns |
| tPHL |  |  |  | 11 | 15 | 5 | 20 | 5 | 17 | , |
| tPLH | A or B | $B$ or $A$ |  | 11 | 17 | 5 | 22 | 5 | 20 | ns |
| tPHL |  |  |  | 7.5 | 10 | 3 | 15 | 3 | 12 |  |
| tPLH | SBA or $\mathrm{SAB}^{\dagger}$ <br> (with $A$ or $B$ high) | $A$ or B |  | 24 | 32 | 15 | 40 | 15 | 35 | ns |
| tPHL |  |  |  | 13 | 17 | 5 | 23 | 5 | 20 |  |
| tPLH | SBA or SAB ${ }^{\dagger}$ (with A or B low) | $A$ or B |  | 17 | 22 | 8 | 30 | 8 | 25 | ns |
| tPHL |  |  |  | 13 | 17 | 5 | 24 | 5 | 20 |  |
| tPZH | $\overline{\mathrm{G}}$ | A or B |  | 10 | 15 | 3 | 20 | 3 | 17 | ns |
| tPZL |  |  |  | 10 | 15 | 5 | 22 | 5 | 20 |  |
| ${ }_{\text {tPHZ }}$ | $\overline{\mathrm{G}}$ | $A$ or $B$ |  | 6 | 8 | 1 | 12 | 1 | 10 | ns |
| tPLZ |  |  |  | 10 | 13 | 2 | 20 | 2 | 16 |  |
| tPZH | DIR | A or B |  | 22 | 28 | 10 | 38 | 10 | 30 | ns |
| tPZL |  |  |  | 14.5 | 20 | 5 | 30 | 5 | 25 |  |
| ${ }_{\text {tPHZ }}$ | DIR | A or B |  | 6 | 8 | 1 | 12 | 1 | 10 | ns |
| tplZ |  |  |  | 10 | 13 | 2 | 21 | 2 | 16 |  |

$\dagger$ These parameters are measured with the internal output state of the storage register opposite to that of the bus input.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN54ALS647, SN74ALS647 OCTAL BUS TRANSCEIVERS AND REGISTERS WITH OPEN-COLLECTOR OUTPUTS

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| Supply voltage, VCC |  |  |
| :---: | :---: | :---: |
| Input voltage |  |  |
| Operating free-air temperature range: SN54ALS647. . . . . . . . . . . . . . . . . . - $55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  |  |
|  | SN74ALS647 | . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range |  | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions

${ }^{\dagger}$ The extended condition applies if $\mathrm{V}_{\mathrm{CC}}$ is maintained between 4.75 V and 5.25 V .
The 48-mA limit applies for the SN74ALS647-1 only.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54ALS647 |  |  | SN74ALS647 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYp $\ddagger$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $\mathrm{V}_{\mathrm{IK}}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $H_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| ${ }^{\mathrm{IOH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=48 \mathrm{~mA} \end{aligned}$ | $\mathrm{IOL}=24 \mathrm{~mA}$ <br> versions) |  |  |  |  | 0.35 | 0.5 | v |
|  | A or B ports | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=7 \mathrm{~V}$ |  |  |  | 0.1 |  |  | 0.1 | mA |
| 1 | Control inputs | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
|  | A or ports ${ }^{\text {§ }}$ | $v_{C C}=5.5 \mathrm{~V}, \quad v_{1}=2.7 \mathrm{~V}$ |  |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IH | Control inputs |  |  |  |  | 20 |  |  | 20 |  |
|  | Control inputs | $V_{C C}=5.5 \mathrm{~V}, \quad V_{I}=0.4 \mathrm{~V}$ |  |  |  | -0.2 |  |  | -0.2 | mA |
| IL | A or B ports ${ }^{\text {§ }}$ |  |  |  |  | -0.2 |  |  | -0.2 |  |
| ${ }^{1} \mathrm{CC}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | Outputs high |  | 35 | 60 |  | 35 | 60 | mA |
|  |  | Outputs low |  | 40 | 65 |  | 40 | 65 |  |

${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$


SN54ALS647, SN74ALS647
OCTAL BUS TRANSCEIVERS AND REGISTERS
WITH OPEN-COLLECTOR OUTPUTS
'ALS647 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \\ \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}}=680 \Omega, \\ \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ \hline \text { ALS } 647 \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}_{\mathrm{L}}=680 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | SN54ALS647 |  | SN74ALS647 |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIIN | MAX |  |
| $f_{\text {max }}$ |  |  |  | 40 |  | 25 |  | 30 |  | MHz |
| tPLH | CBA or CAB | $A$ or $B$ |  | 38 | 50 | 19 | 72 | 19 | 58 | ns |
| tPHL |  |  |  | 12 | 20 | 6 | 24 | 6 | 22 | ns |
| tPLH | A or B | $B$ or $A$ |  | 35 | 39 | 17 | 70 | 17 | 54 | ns |
| tPHL |  |  |  | 10 | 13 | 4 | 19 | 4 | 16 |  |
| tPLH | SBA or SAB ${ }^{\dagger}$ (with $A$ or $B$ high) | $A$ or B |  | 40 | 51 | 20 | 72 | 20 | 60 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 12 | 17 | 6 | 26 | 6 | 22 |  |
| ${ }^{\text {tPLH }}$ | SBA or SAB ${ }^{\dagger}$ (with A or B low) | $A$ or B |  | 40 | 51 | 20 | 72 | 20 | 60 | ns |
| tPHL |  |  |  | 12 | 17 | 6 | 26 | 6 | 22 |  |
| tPLH | $\bar{G}$ | $A$ or B |  | 20 | 27 | 10 | 37 | 10 | 31 | ns |
| tPHL |  |  |  | 10 | 15 | 2 | 20 | 2 | 17 |  |
| ${ }_{\text {tPLH }}$ | DIR | $A$ or B |  | 20 | 25 | 9 | 34 | 9 | 29 | ns |
| ${ }^{\text {PPHL }}$ |  |  |  | 13 | 17 | 2 | 22 | 2 | 19 |  |

${ }^{\dagger}$ These parameters are measured with the internal output state of the storage register opposite to that of the bus input. NOTE 1: For load circuit and voltage waveforms, see page 1-12 of The TTL Data Book, Volume 3, 1984.

## SN54ALS648, SN74ALS648 OCTAL BUS TRANSCEIVERS AND REGISTERS WITH 3-STATE OUTPUTS

| Supply voltage, VCC | 7 V |
| :---: | :---: |
| Input voltage: Control inputs | 7 V |
| 1/O ports | 5.5 V |
| Operating free-air temperature range: SN54ALS648 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
| SN74ALS648 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions

${ }^{\dagger}$ The extended conditon applies if $\mathrm{V}_{\mathrm{CC}}$ is maintained between 4.75 V and 5.25 V .
The 48-mA limit applies for the SN74ALS648-1 only.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54ALS648 |  |  | SN74ALS648 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $\mathrm{V}_{\mathrm{IK}}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\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}_{\mathrm{CC}}-2$ |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.4 | 3.2 |  | 2.4 | 3.2 |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-12 \mathrm{~mA}$ | 2 |  |  |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-15 \mathrm{~mA}$ |  |  |  | 2 |  |  |  |
| $\mathrm{V}_{\text {OL }}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=48 \mathrm{~mA} \end{aligned}$ | $\mathrm{IOL}=24 \mathrm{~mA}$ ersion) |  |  |  |  | -0.35 | 0.5 |  |
| 1 | Control inputs | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | A or B ports | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| IIH | Control inputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | A or B ports§ |  |  |  |  | 20 |  |  | 20 |  |
| IIL | Control inputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.2 |  |  | -0.2 | mA |
| IIL | A or B ports ${ }^{\text {§ }}$ |  |  |  |  | -0.2 |  |  | -0.2 |  |
| 101 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | $-30$ |  | -112 | mA |
| ${ }^{\text {I C C }}$ |  | $V_{C C}=5.5 \mathrm{~V}$ | Outputs high |  | 47 | 76 |  | 47 | 76 | mA |
|  |  | Outputs low |  | 57 | 88 |  | 57 | 88 |  |
|  |  | Outputs disabled |  | 57 | 88 |  | 57 | 88 |  |

[^23]SN54ALS648, SN74ALS648
octal bus transceivers and registers
WITH 3-STATE OUTPUTS
'ALS648 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \Omega, \\ & \mathrm{R} 2=500 \Omega \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \mathrm{~A}^{\prime} \mathrm{AL} 648 \end{aligned}$ |  |  | $\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 \Omega \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  | 48 |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  |  | 50 |  | 35 |  | 40 |  | MHz |
| tPLH | CBA or CAB | A or B |  | 21 | 29 | 8 | 39 | 8 | 33 | ns |
| tPHL |  |  |  | 13 | 18 | 5 | 23 | 5 | 20 |  |
| tPLH | A or B | $B$ or $A$ |  | 10 | 15 | 3 | 20 | 3 | 17 | ns |
| ${ }^{\text {tPHL}}$ |  |  |  | 6 | 8 | 2 | 12 | 2 | 10 |  |
| ${ }^{\text {tPLH }}$ | SBA or $\mathrm{SAB}^{\dagger}$ (with $A$ or $B$ high) | $A$ or B |  | 24 | 32 | 5 | 44 | 5 | 39 | ns |
| tPHL |  |  |  | 15 | 21 | 4 | 26 | 4 | 22 |  |
| ${ }^{\text {tPLH }}$ | SBA or SAB ${ }^{\dagger}$ <br> (with A or B low) | A or B |  | 16 | 22 | 6 | 30 | 6 | 25 | ns |
| tPHL |  |  |  | 14 | 19 | 6 | 25 | 6 | 21 |  |
| tPLH | $\overline{\mathrm{G}}$ | A or B |  | 12 | 18 | 4 | 25 | 4 | 22 | ns |
| tPHL |  |  |  | 12 | 18 | 4 | 25 | 4 | 22 |  |
| tPLH | $\overline{\mathrm{G}}$ | $A$ or B |  | 5 | 8 | 1 | 12 | 1 | 10 | ns |
| tPHL |  |  |  | 7 | 12 | 2 | 21 | 2 | 15 |  |
| ${ }^{\text {P P Z }}$ H | DIR | $A$ or B |  | 14 | 22 | 4 | 35 | 4 | 27 | ns |
| ${ }^{\text {t P Z }}$ |  |  |  | 10 | 17 | 3 | 25 | 3 | 19 |  |
| ${ }^{\text {tpHz }}$ | DIR | $A$ or B |  | 7 | 12 | 1 | 17 | 1 | 14 | ns |
| tPLZ |  |  | , | 7 | 13 | 2 | 22 | 2 | 15 |  |

$\dagger$ These parameters are measured with the internal output state of the storage register opposite to that of the bus input. NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN54ALS649, SN74ALS649 octal bus transceivers and registers WITH OPEN-COLLECTOR OUTPUTS

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| Supply voltage, VCC |  |  |
| :---: | :---: | :---: |
| Input voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V |  |  |
| Operating free-air temperature range: | SN54ALS649 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
|  | SN74ALS649 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range |  | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions

|  |  | SN54ALS649 |  |  | SN74ALS649 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage |  |  | 5.5 |  |  | 5.5 | V |
| ${ }^{1} \mathrm{OL}$ | Low-level output current |  |  | 12 |  |  | 24 | mA |
|  |  |  |  |  |  |  | $48^{\dagger}$ |  |
| ${ }^{\text {f clock }}$ | Clock frequency | 0 |  | 25 | 0 |  | 30 | MHz |
| $\mathrm{t}_{\mathrm{w}}$ | Pulse duration, clocks high or low | 20 |  |  | 16.5 |  |  | ns |
| $\mathrm{t}_{\text {Su }}$ | Setup time, $A$ before $C A B \uparrow$ or $B$ before CBA $\uparrow$ | 15 |  |  | 10 |  |  | ns |
| th | Hold time, $A$ after CAB $\uparrow$ or B after CBA $\uparrow$ | 0 |  |  | 0 |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

${ }^{\dagger}$ The extended condition applies if $\mathrm{V}_{\mathrm{CC}}$ is maintained between 4.75 V and 5.25 V .
The 48-mA limit applies for the SN74ALS649-1 only.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54ALS649 |  |  | SN74ALS649 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $V_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | $-1.2$ | V |
| ${ }^{1} \mathrm{OH}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  |  |  | V |
|  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=48 \mathrm{~mA} \end{aligned}$ | $\mathrm{IOL}=24 \mathrm{~mA}$ <br> versions) |  |  |  |  | 0.35 | 0.5 |  |
| 1 | A or B ports | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | Control inputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| ${ }_{1} \mathrm{H}$ | A or ports ${ }^{\S}$ | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=2.7 \mathrm{~V}$ |  |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | Control inputs |  |  |  |  | 20 |  |  | 20 |  |
|  | Control inputs | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=0.4 \mathrm{~V}$ |  |  |  | -0.2 |  |  | -0.2 | mA |
| IL | A or B ports ${ }^{\text {® }}$ |  |  |  |  | -0.2 |  |  | -0.2 |  |
| ${ }^{1} \mathrm{CC}$ |  | $V_{C C}=5.5 \mathrm{~V}$ | Outputs high |  | 40 | 60 |  | 40 | 60 | mA |
|  |  | Outputs low |  | 45 | 70 |  | 45 | 70 |  |

[^24]SN54ALS649, SN74ALS649
OCTAL BUS TRANSCEIVERS AND REGISTERS
WITH OPEN-COLLECTOR OUTPUTS
'ALS649 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R}_{\mathrm{L}}=680 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline{ }^{\prime} \text { ALS } 649 \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R}_{\mathrm{L}}=680 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to } \mathrm{MAX} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 649 | SN7 |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  |  | 40 |  | 25 |  | 30 |  | MHz |
| tPLH | CBA or CAB | A or B |  | 40 | 52 | 19 | 77 | 19 | 62 | ns |
| tpHL |  |  |  | 12 | 18 | 6 | 22 | 6 | 20 |  |
| tPLH | A or B | $B$ or A |  | 30 | 41 | 13 | 65 | 13 | 50 | ns |
| tPHL |  |  |  | 6 | 9 | 2 | 11 | 2 | 10 |  |
| tpLH | $\begin{gathered} \text { SBA or SAB }{ }^{\dagger} \\ \text { (with } A \text { or } B \text { high) } \end{gathered}$ | A or B |  | 35 | 46 | 20 | 72 | 20 | 55 | ns |
| tpHL |  |  |  | 15 | 21 | 6 | 26 | 6 | 22 |  |
| tPLH | SBA or SAB ${ }^{\dagger}$(with $A$ or $B$ low) | $A$ or B |  | 35 | 46 | 20 | 72 | 20 | 55 | ns |
| tPHL |  |  |  | 15 | 21 | 6 | 26 | 6 | 22 |  |
| tPLH | $\overline{\mathrm{G}}$ | $A$ or $B$ |  | 16 | 22 | 8 | 28 | 8 | 25 | ns |
| tPHL |  |  |  | 13 | 18 | 2 | 23 | 2 | 20 |  |
| tPLH | DIR | A or B |  | 16 | 22 | 8 | 28 | 8 | 25 | ns |
| tPHL |  |  |  | 13 | 17 | 2 | 23 | 2 | 20 |  |

$\dagger$ These parameters are measured with the internal output state of the storage register opposite to that of the bus input.
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| Supply voltage, VCC |  | 7 V |
| :---: | :---: | :---: |
| Input voltage: Control inputs |  | 7 V |
| 1/O ports |  | 5.5 V |
| Operating free-air temperature range: | SN54AS646, SN54AS648 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
|  | SN74AS646, SN74AS648 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range |  | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

## recommended operating conditions

|  |  |  |  | N54AS N54AS |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX | UNIT |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  |  |  | -12 |  |  | -15 | mA |
| ${ }^{1} \mathrm{OL}$ | Low-level output current |  |  |  | 32 |  |  | 48 | mA |
| $f_{\text {clock }}$ | Clock frequency |  | 0 |  | 75 | 0 |  | 90 | MHz |
| ${ }_{\text {t }}$ w | Pulse duration | Clock high | 6 |  |  | 5 |  |  | ns |
|  |  | Clock high | 7 |  |  | 6 |  |  |  |
| $\mathrm{t}_{\text {su }}$ | Setup time, $A$ before $C A B \uparrow$ or $B$ before CBA |  | 7 |  |  | 6 |  |  | ns |
| $t_{\text {h }}$ | Hold time, A af | er CBA $\uparrow$ | 0 |  |  | 0 |  |  | ns |
| TA | Operating free-a |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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}$ For $1 / O$ ports, the parameters $I_{I H}$ and $I_{I L}$ include the off-state output current.
§The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los.

SN54AS646, SN54AS648, SN74AS646, SN74AS648
OCTAL BUS TRANSCEIVERS AND REGISTERS
WITH 3-STATE OUTPUTS
'AS646 switching characteristics (see Note 1)

| PARAMETER | 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 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathbf{A}}=\text { MIN to } \mathrm{MAX} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS646 |  | SN74AS646 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  | 75 |  | 90 |  | MHz |
| tPLH | CBA or CAB | $A$ or B | 2 | 9.5 | 2 | 8.5 | ns |
| ${ }^{\text {P PHL }}$ |  |  | 2 | 10 | 2 | 9 |  |
| tPLH | $A$ or B | $B$ or $A$ | 2 | 11 | 2 | 9 | ns |
| tPHL |  |  | 1 | 8 | 1 | 7 |  |
| tPLH | SBA or $S^{\text {S }}{ }^{\dagger}$ | $A$ or B | 2 | 12 | 2 | 11 | ns |
| tPHL |  |  | 2 | 10 | 2 | 9. |  |
| tPZH | $\overline{\mathrm{G}}$ | $A$ or B | 2 | 10 | 2 | 9 | ns |
| tPZL |  |  | 3 | 15 | 3 | 14 |  |
| tPHZ | $\overline{\mathrm{G}}$ | $A$ or B | 2 | 11 | 2 | 9 | ns |
| ${ }_{\text {t PLZ }}$ |  |  | 2 | 11 | 2 | 9 |  |
| ${ }_{\text {tPZ }}$ | DIR | A or B | 3 | 19 | 3 | 16 | ns |
| tPZL |  |  | 3 | 21 | 3 | 18 |  |
| tPHZ | DIR | A or B | 2 | 12 | 2 | 10 | ns |
| . tplZ |  |  | 2 | 12 | 2 | 10 |  |

'AS648 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathbf{C}}=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}_{\mathbf{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS648 |  | SN74AS648 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  | 75 |  | 90 |  | MHz |
| tPLH | CBA or CAB | $A$ or B | 2 | 9.5 | 2 | 8.5 | ns |
| tPHL |  |  | 2 | 10 | 2 | 9 |  |
| tPLH | $A$ or $B$ | B or A | 2 | 9 | 2 | 8 | ns |
| tpHL |  |  | 1 | 8 | 1 | 7 |  |
| tPLH | SBA or SAB ${ }^{\dagger}$ | $A$ or B | 2 | 12 | 2 | 11 | ns |
| tPHL |  |  | 2 | 10 | 2 | 9 |  |
| tPZH | $\overline{\mathrm{G}}$ | A or B | 2 | 10 | 2 | 9 | ns |
| tPZL |  |  | 3 | 18 | 3 | 15 | ns |
| tPHZ | $\overline{\mathrm{G}}$ | $A$ or B | 2 | 11 | 2 | 9 | ns |
| tPLZ |  |  | 2 | 11 | 2 | 9 |  |
| tPZH | DIR | A or B | 3 | 19 | 3 | 16 | ns |
| tPZL |  |  | 3 | 21 | 3 | 18 |  |
| tPHZ | DIR | A or B | 2 | 12 | 2 | 10 | ns |
| tPLZ |  |  | 2 | 12 | 2 | 10 |  |

$\dagger$ These parameters are measured with the internal output state of the storage register opposite to that of the bus input.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

- Bus Transceivers/Registers
- Independent Registers and Enables for A and B Buses
- Multiplexed Real-Time and Stored Data
- Choice of True and Inverting Data Paths
- Choice of 3-State or Open-Collector Outputs to A Bus
- Included Among the Package Options Are Compact 24-Pin 300-mil-Wide DIPs and Both 28-Pin Plastic and Ceramic Chip Carriers
- Dependable Texas Instruments Quality and Reliability

| DEVICE | A OUTPUT | B OUTPUT | LOGIC |
| :---: | :---: | :---: | :---: |
| 'ALS651,'AS65? | 3 State | 3-State | Inverting |
| 'ALS652,'AS652 | 3-State | 3-State | True |
| 'ALS653 | Open-Collector | 3-State | Invertiny |
| 'ALS654 | Open-Collector | 3-State | True |

## description

These devices consist of bus transceiver circuits, D-type flip-flops, and control circuitry arranged for multiplexed transmission of data directly from the data bus or from the internal storage registers. Enable $G A B$ and $\bar{G} B A$ are provided to control the transceiver functions. SAB and SBA . control pins are provided to select whether realtime or stored data is transferred. The circuitry used for select control will eliminate the typical decoding glitch which occurs in a multiplexer during the transition between stored and realtime data. A low input level selects real-time data, and a high selects stored data. The following examples demonstrate the four fundamental bus-management functions that can be performed with the octal bus transceivers and registers.

Data on the $A$ or $B$ data bus, or both, can be stored in the internal $D$ flip-flops by low-to-high transitions at the appropriate clock pins (CAB or CBA) regardless of the select or enable control pins. When SAB and SBA are in the real-time transfer mode, it is also possible to store data without using the internal D-type flip-flops by simultaneously enabling GAB and $\bar{G} B A$. In this configuration each output reinforces its input. Thus, when all other data sources to the two sets of bus lines are at high impedance, each set of bus lines will remain at its last state.

The -1 versions of the SN74ALS651 through SN74ALS654 are identical to the standard versions except that the recommended maximum IOL is increased to 48 milliamperes. There are no -1 versions of the SN54ALS651 through SN54ALS654.

The SN54' family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.


GAB ḠBA CAB CBA SAB SBA

REAL-TIME TRANSFER BUS B TO BUS A



GAB ḠBA CAB CBA SAB SBA

REAL-TIME TRANSFER BUS A TO BUS B


TRANSFER
STORED DATA
TO A AND/OR B

SN54ALS651 THRU SN54ALS654, SN54AS651, SN54AS652 SN74ALS651 THRU SN74ALS654, SN74AS651, SN74AS652 octal bus transceivers and registers

FUNCTION TABLE

| INPUTS |  |  |  |  |  | DATA I/O |  | OPERATION OR FUNCTION |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| GAB | GBA | CAB | CBA | SAB | SBA | A1 THRU A8 | B1 THRU B8 | 'ALS651, 'ALS653 'AS651 | 'ALS652, 'ALS654 'AS652 |
| $\begin{aligned} & L \\ & L \end{aligned}$ | H H | $H \text { or } L$ | $H \text { or } L$ | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | Input | Input | Isolation <br> Store A and B Data | Isolation Store A and B Data |
| $\begin{aligned} & \mathrm{X} \\ & \mathrm{H} \end{aligned}$ | $H$ $H$ | $\stackrel{+}{+}$ | H or L | $\begin{aligned} & x \\ & x^{\ddagger} \end{aligned}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | Input <br> Input | Unspecified $^{\dagger}$ Output | Store A, Hold B <br> Store $A$ in both registers | Store A, Hold B Store $A$ in both registers |
| $L$ $L$ | $x$ $L$ | H or L |  | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{aligned} & x \\ & x^{\ddagger} \end{aligned}$ | Unspecified ${ }^{\dagger}$ Output | Input <br> Input | Hold A, Store B <br> Store B in both registers | Hold A, Store B <br> Store B in both registers |
| $\begin{aligned} & \mathrm{L} \\ & \mathrm{~L} \end{aligned}$ | L | $\begin{aligned} & x \\ & x \\ & \hline \end{aligned}$ | X H or L | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{aligned} & L \\ & H \end{aligned}$ | Output | Input | Real-Time $\bar{B}$ Data to A Bus Stored $\bar{B}$ Data to $A$ Bus | Real-Time B Data to A Bus Stored B Data to A Bus |
| $\begin{aligned} & H \\ & H \end{aligned}$ | $H$ $H$ | $x$ <br> Hor L | $\begin{gathered} \mathrm{X} \\ \mathrm{X} \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{L} \\ & \mathrm{H} \end{aligned}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | Input | Output | Real-Time $\bar{A}$ Data to B Bus Stored $\bar{A}$ Data to B Bus | Real-Time A Data to B Bus Stored A Data to B Bus |
| H | L | H or L | H or L | H | H | Output | Output | Stored $\bar{A}$ Data to $B$ Bus and Stored $\bar{B}$ Data to $A$ Bus | Stored A Data to B Bus and Stored B Data to A Bus |

${ }^{\dagger}$ The data output functions may be enabled or disabled by various signals at the GAB or $\bar{G} B A$ inputs. Data input functions are always enabled, i.e., data at the bus pins will be stored on every low to-high transition on the clock inputs.
$\ddagger$ Select control $=$ L: clocks can occur simultaneously.
Select control $=\mathrm{H}$ : clocks must be staggered in order to load both registers.
logic diagrams (positive logic)
'ALS651, 'AS651, 'ALS653
'ALS652, 'AS652, 'ALS654


Pin numbers shown are for DW, JT, and NT packages.

## SN54ALS651 THRU SN54ALS654, SN54AS651, SN54AS652 <br> SN74ALS651 THRU SN74ALS654, SN74AS651, SN74AS652 octal bus transceivers and registers

logic symbols ${ }^{\dagger}$

'ALS652, 'AS652

'ALS654

†These symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers shown are for DW, JT, and NT packages.

## SN54ALS651, SN54ALS652, SN74ALS651, SN74ALS652 OCTAL BUS TRANSCEIVERS AND REGISTERS

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| Supply voltage, $\mathrm{V}_{\text {CC }}$ | 7 V |
| :---: | :---: |
| Input voltage: Control inputs | 7 V |
| I/O ports | 5.5 V |
| Operating free-air temperature range: SN54ALS651, SN54ALS652 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
| SN74ALS651, SN74ALS652 | . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions

${ }^{\dagger}$ The extended condition applies if $\mathrm{V}_{\mathrm{CC}}$ is maintained between 4.75 V and 5.25 V . The 48 -mA limit applies for the SN74ALS651-1 and SN74ALS652-1 only.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)


[^25]
"The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS.

## SN54ALS651, SN54ALS652, SN74ALS651, SN74ALS652 octal bus transceivers and registers

'ALS651 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathbf{R 1}=500 \Omega, \\ & \mathbf{R 2}=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \text { 'ALS651 } \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathbf{C}}=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}_{\mathbf{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | SN |  | SN |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  |  | 50 |  | 35 |  | 40 |  | MHz |
| ${ }_{\text {tPLH }}$ | CBA or CAB | $A$ or B |  | 20 | 27 | 10 | 38 | 10 | 32 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 11 | 15 | 5 | 21 | 5 | 17 |  |
| tPLH | $A$ or B | $B$ or $A$ |  | 9 | 13 | 4 | 20 | 4 | 18 | ns |
| tPHL |  |  |  | 5 | 8 | 2 | 12 | 2 | 10 |  |
| tPLH | SBA or SAB ${ }^{\dagger}$ <br> (with A or B high) | A or B |  | 24 | 31 | 13 | 45 | 13 | 38 | ns |
| tPHL |  |  |  | 13 | 18 | 7 | 25 | 7 | 21 |  |
| tPLH | SBA or SĀB ${ }^{\dagger}$ (with A or B low) | A or B |  | 15 | 20 | 8 | 30 | 8 | 25 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 13 | 18 | 7 | 25 | 7 | 21 |  |
| tPZH | $\overline{\mathrm{G}} \mathrm{BA}$ | A |  | 12 | 16 | 5 | 22 | 5 | 20 | ns |
| tPZL |  |  |  | 11 | 15 | 5 | 21 | 5 | 18 |  |
| $t_{\text {PHZ }}$ | $\overline{\mathrm{G}} \mathrm{BA}$ | A |  | 4 | 7 | 2 | 10 | 2 | 9 | ns |
| tPLZ |  |  |  | 7 | 10 | 3 | 16 | 3 | 12 |  |
| ${ }^{\text {PPZH }}$ | GAB | B |  | 14 | 19 | 7 | 25 | 7 | 22 | ns |
| tpZL |  |  |  | 13 | 18 | 7 | 25 | 7 | 21 |  |
| ${ }^{\text {tPHZ }}$ | GAB | B |  | 5 | 10 | 2 | 14 | 2 | 12 | ns |
| tplZ |  |  |  | 7 | 10 | 2 | 20 | 2 | 14 |  |

'ALS652 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathbf{C C}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathbf{R 1}=500 \Omega, \\ & \mathbf{R 2}=500 \Omega, \\ & \mathbf{T}_{\mathbf{A}}=25^{\circ} \mathrm{C} \\ & \hline \text { ALS } 652 \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathbf{C C}}=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}_{\mathbf{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | SN |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  |  | 50 |  | 35 |  | 40 |  | MHz |
| tpLH | CBA or CAB | A or B |  | 20 | 25 | 10 | 35 | 10 | 30 | ns |
| tPHL |  |  |  | 11 | 15 | 5 | 20 | 5 | 17 |  |
| tPLH | A or B | $B$ or $A$ |  | 11 | 15 | 5 | 20 | 5 | 18 | ns |
| tPHL |  |  |  | 8 | 10 | 3 | 15 | 3 | 12 |  |
| ${ }^{\text {tPLH }}$ | SBA or SAB ${ }^{\dagger}$ (with $A$ or $B$ high) | $A$ or B |  | 24 | 32 | 15 | 40 | 15 | 35 | ns |
| tPHL |  |  |  | 13 | 17 | 6 | 23 | 6 | 20 |  |
| ${ }^{\text {tPLH }}$ | SBA or SAB ${ }^{\dagger}$ (with A or B low) | A or B |  | 17 | 22 | 8 | 30 | 8 | 25 | ns |
| tPHL |  |  |  | 13 | 17 | 5 | 24 | 5 | 20 |  |
| tPZH | $\overline{\mathrm{G}} \mathrm{BA}$ | A |  | 10 | 15 | 3 | 20 | 3 | 17 | ns |
| tPZL |  |  |  | 10 | 14 | 5 | 22 | 5 | 18 |  |
| tPHZ | $\overline{\mathrm{G}} \mathrm{BA}$ | A |  | 6 | 8 | 1 | 12 | 1 | 10 | ns |
| tPLZ |  |  |  | 10 | 13 | 2 | 20 | 2 | 16 |  |
| tPZH | GAB | B |  | 15 | 20 | 8 | 25 | 8 | 22 | ns |
| ${ }^{\text {tPZL }}$ |  |  |  | 12 | 16 | 6 | 21 | 6 | 18 |  |
| tPHZ | GAB | B |  | 6 | 8 | 1 | 12 | 1 | 10 | ns |
| tPLZ |  |  |  | 10 | 13 | 2 | 21 | 2 | 16 |  |

[^26] NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

$$
\begin{aligned}
& \text { Supply voltage, VCC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . } 7 \text { V } \\
& \text { Input voltage: All inputs and A I/O ports . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . } 7 \text { V } \\
& \text { B I/O ports . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . } 5.5 \mathrm{~V} \\
& \text { Operating free-air temperature range: SN54ALS653, SN54ALS654 . . . . . . . . . . . . . . . . . . . - } 55^{\circ} \mathrm{C} \text { to } 125^{\circ} \mathrm{C} \\
& \text { SN74ALS653, SN74ALS654 . . . . . . . . . . . . . . . . . . . . . . . . } 0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\
& \text { Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . - } 65^{\circ} \mathrm{C} \text { to } 150^{\circ} \mathrm{C}
\end{aligned}
$$

## recommended operating conditions


$\dagger$ The extended condition applies if $\mathrm{V}_{\mathrm{CC}}$ is maintained between 4.75 V and 5.25 V . The $48-\mathrm{mA}$ limit applies for the SN74ALS653-1 and SN74ALS654-1 only.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

${ }^{\dagger}$ All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$.
${ }^{\ddagger}$ For $I / P$ ports, the parameters $I_{I H}$ and $I_{I L}$ include the off-state output current.
$\S$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS.

## 'ALS653 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathbf{V}_{\mathbf{C}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathbf{R}_{\mathrm{L}}=680 \Omega,(\mathrm{~A} \text { outputs) } \\ & \mathrm{R}_{1}=\text { R2 }=500 \Omega,(B \text { outputs }) \\ & \mathrm{T}_{\mathbf{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54ALS653 |  |  | SN74ALS653 |  |  |  |
|  |  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $f_{\text {max }}$ |  |  |  |  |  |  |  |  | MHz |
| tPLH | CBA | A |  | 24 |  |  | 24 |  | ns |
| tPHL |  |  |  | 15 |  |  | 15 |  |  |
| ${ }_{\text {tPLH }}$ | CAB | B |  | 11 |  |  | 11 |  | ns |
| ${ }_{\text {t PHL }}$ |  |  |  | 13 |  |  | 13 |  |  |
| tPLH | A | B |  | 10 |  |  | 10 |  | ns |
| tPHL |  |  |  | 12 |  |  | 12 |  |  |
| tPLH | B | A |  | 24 |  |  | 24 |  | ns |
| tPHL |  |  |  | 10 |  |  | 10 |  |  |
| tPLH | $\mathrm{SBA}^{\ddagger}$ | A |  | 26 |  |  | 26 |  | ns |
| tPHL | (with B high) |  |  | 15 |  |  | 15 |  |  |
| tPLH | SBA ${ }^{\ddagger}$ | A |  | 26 |  |  | 26 |  | ns |
| ${ }_{\text {t }}$ PHL | (with B low) |  |  | 15 |  |  | 15 |  |  |
| tPLH |  | B |  | 16 |  |  | 16 |  | ns |
| tPHL | (with $A$ high) |  |  | 16 |  |  | 16 |  |  |
| tPLH | $\mathrm{SAB}^{\ddagger}$ | B |  | 15 |  |  | 15 |  | ns |
| tPHL | (with A low) |  |  | 15 |  |  | 15 |  |  |
| tPLH | ḠBA | A |  | 24 |  |  | 24 |  | ns |
| tPHL |  |  |  | 17 |  |  | 17 |  |  |
| tPZH | GAB | B |  | 19 |  |  | 19 |  | ns |
| tPZL |  |  |  | 22 |  |  | 22 |  |  |
| tPHZ | GAB | B |  | 12 |  |  | 12 |  | ns |
| tPLZ |  |  |  | 14 |  |  | 14 |  |  |

${ }^{\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 1: Load circuit and voltage waveforms are shown in Section 1.

Additional information on these products can be obtained from the factory as it becomes available.
'ALS654 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R}_{\mathrm{L}}=680 \Omega,(\mathrm{~A} \text { outputs) } \\ & \mathrm{R}_{1}=\mathrm{R} 2=500 \Omega,(\mathrm{~B} \text { outputs }) \\ & \mathrm{T}_{\mathrm{A}}=\text { MIN to } \mathrm{MAX} \end{aligned}$ |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54ALS654 |  | SN74ALS654 |  |  |  |
|  |  |  | MIN TYP ${ }^{\text { }}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $f_{\text {max }}$ |  |  |  |  |  |  |  | MHz |
| tPLH | CBA | A | 24 |  |  | 24 |  | ns |
| tPHL |  |  | 15 |  |  | 15 |  |  |
| ${ }_{\text {tPLH }}$ | CAB | B | 11 |  |  | 11 |  | ns |
| ${ }^{\text {P PHL }}$ |  |  | 13 |  |  | 13 |  |  |
| tPLH | A | B | 8 |  |  | 8 |  | ns |
| tPHL |  |  | 8 |  |  | 8 |  |  |
| tPLH | B | A | 24 |  |  | 24 |  | ns |
| tPHL |  |  | 10 |  |  | 10 |  |  |
| tPLH | SBA $^{\ddagger}$(with B high) | A | 26 |  |  | 26 |  | ns |
| tPHL |  |  | 15 |  |  | 15 |  |  |
| tPLH | $\begin{gathered} \text { SBA }^{\ddagger} \\ \text { (with B low) } \end{gathered}$ | A | 26 |  |  | 26 |  | ns |
| ${ }_{\text {tPHL }}$ |  |  | 15 |  |  | 15 |  |  |
| ${ }_{\text {tPLH }}$ | SBA ${ }^{\ddagger}$ <br> (with $A$ high) | B | 16 |  |  | 16 |  | ns |
| tPHL |  |  | 16 |  |  | 16 |  |  |
| tPLH | SAB ${ }^{\ddagger}$ | B | 15 |  |  | 15 |  | ns |
| ${ }_{\text {tPHL }}$ | (with A low) |  | 12 |  |  | 12 |  |  |
| tPLH | GBA | A | 24 |  |  | 24 |  | ns |
| tPHL |  |  | 17 |  |  | 17 |  |  |
| tPZH | GAB | B | 19 |  |  | 19 |  | ns |
| tPZL |  |  | 22 |  |  | 22 |  |  |
| tPHZ | GAB | B | 12 |  |  | 12 |  | ns |
| tPLZ |  |  | 14 |  |  | 14 |  |  |

$\dagger^{\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 1: Load circuit and voltage waveforms are shown in Section 1.

Additional information on these products can be obtained from the factory as it becomes available.

## SN54AS651, SN54AS652, SN74AS651, SN74AS652 OCTAL BUS TRANSCEIVERS AND REGISTERS

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| Supply voltage, VCC | 7 V |
| :---: | :---: |
| Input voltage: Control inputs | 7 V |
| 1/O ports | 5.5 V |
| Operating free-air temperature range: SN54AS651, SN54AS652 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
| SN74AS651, SN74AS652 | . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions

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

| PARAMETER |  | TEST CONDITIONS |  | SN54AS651 <br> SN54AS652 |  |  | SN74AS651 SN74AS652 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $\mathrm{V}_{\mathrm{IK}}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| VOH |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V , | $\mathrm{IOH}^{\prime}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOH}=-3 \mathrm{~mA}$ | 2.4 | 3.2 |  | 2.4 | 3.2 |  |  |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-12 \mathrm{~mA}$ | 2 |  |  |  |  |  |  |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-15 \mathrm{~mA}$ |  |  |  | 2 |  |  |  |
| $\mathrm{V}_{\text {OL }}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{\text {O }}=32 \mathrm{~mA}$ |  | 0.25 | 0.50 |  |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.50 |  |
| 1 | Control inputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | A or B ports | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| IH | Control inputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | A or B ports ${ }^{\ddagger}$ |  |  |  |  | 70 |  |  | 70 |  |
| IL | Control inputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.5 |  |  | -0.5 | mA |
|  | A or B ports ${ }^{\ddagger}$ |  |  |  |  | -0.75 |  |  | -0.75 |  |
| $10^{8}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ${ }^{\prime} \mathrm{CC}$ | 'AS651 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | Outputs high |  | 110 | 185 |  | 110 | 185 | mA |
|  |  |  | Outputs low |  | 120 | 195 |  | 120 | 195 |  |
|  |  |  | Outputs disabled |  | 130 | 195 |  | 130 | 195 |  |
|  | 'AS652 |  | Outputs high |  | 120 | 195 |  | 120 | 195 |  |
|  |  |  | Outputs low |  | 130 | 211 |  | 130 | 211 |  |
|  |  |  | Outputs disabled |  | 130 | 211 |  | 130 | 211 |  |

[^27]
## SN54AS651, SN54AS654, SN74AS651, SN74AS652

 OCTAL BUS TRANSCEIVERS AND REGISTERS'AS651 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=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}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS651 |  | SN74AS651 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  | 75 |  | 90 |  | MHz |
| tplh | CBA or CAB | A or B | 2 | 9.5 | 2 | 8.5 |  |
| tPHL |  |  | 2 | 10 | 2 | 9 | ns |
| tPLH | A or B | $B$ or A | 2 | 9 | 2 | 8 | ns |
| tPHL |  |  | 1 | 8 | 1 | 7 | ns |
| tPLH | SBA or SAB ${ }^{\dagger}$ | A or B | 2 | 12 | 2 | 11 | s |
| tPHL |  |  | 2 | 10 | 2 | 9 | ns |
| tPZH | $\overline{\mathrm{G}} \mathrm{BA}$ | A | 2 | 11 | 2 | 10 | ns |
| tPZL |  |  | 3 | 18 | 3 | 16 |  |
| tPHZ | $\overline{\mathrm{G}} \mathrm{BA}$ | A | 2 | 10 | 2 | 9 |  |
| tPLZ |  |  | 2 | 10 | 2 | 9 | ns |
| tPZH | GAB | B | 3 | 12 | 3 | 11 | s |
| tPZL |  |  | 3 | 20 | 3 | 16 | ns |
| tPHZ | GAB | B | 2 | 11 | 2 | 10 | ns |
| tPLZ |  |  | 2 | 12 | 2 | 11 |  |

'AS652 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (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 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS652 |  | SN74AS652 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  | 75 |  | 90 |  | MHz |
| tPLH | CBA or CAB | A or B | 2 | 9.5 | 2 | 8.5 |  |
| tPHL |  |  | 2 | 10 | 2 | 9 | ns |
| tPLH | A or B | $B$ or A | 2 | 11 | 2 | 9 |  |
| ${ }_{\text {tPHL }}$ |  |  | 1 | 8 | 1 | 7 | ns |
| tPLH | SBA or SAB ${ }^{\dagger}$ | A or B | 2 | 12 | 2 | 11 | ns |
| tPHL |  |  | 2 | 10 | 2 | 9 | ns |
| tPZH | $\overline{\mathrm{G}} \mathrm{B} A$ | A | 2 | 11 | 2 | 10 | ns |
| tPZL |  |  | 3 | 18 | 3 | 16 | ns |
| tPhZ | $\overline{\mathrm{G}} \mathrm{BA}$ | A | 2 | 10 | 2 | 9 |  |
| tPLZ |  |  | 2 | 10 | 2 | 9 | ns |
| tPZH | GAB | B | 3 | 12 | 3 | 11 |  |
| tPZL |  |  | 3 | 20 | 3 | 16 | ns |
| tPHZ | GAB | B | 2 | 11 | 2 | 10 |  |
| tPLZ |  |  | 2 | 12 | 2 | 11 | ns |

${ }^{\dagger}$ These parameters are measured with the internal output state of the storage register opposite to that of the bus input. NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

3-State I/O-Type Read-Back Inputs

- Bus-Structured Pinout
- Choice of True or Inverting Logic
'ALS666 . . . True Outputs
'ALS667 . . . Inverting Outputs
- Preset and Clear Inputs
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramics DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 8-bit latches are designed specifically for storing the contents of the input data bus plus providing the capability of reading-back the stored data onto the input data bus. In addition, they provide a 3-state buffer type output and are easily utilized in bus-structured applications.
The eight latches of the 'ALS666 and 'ALS667 are transparent D-type. While the enable (C) is high, the Q outputs of the 'ALS666 will follow the data ( $D$ ) inputs. On the 'ALS667, the $\overline{\mathrm{Q}}$ outputs will provide the inverse of what is applied to its data ( $D$ ) inputs. On both devices, the Q or $\overline{\mathrm{Q}}$ output will be in the high-impedance state if either output control, $\overline{\mathrm{OE}} 1$ or $\overline{\mathrm{OE}} 2$, is at a high logic level.
Read-back is provided thru the read-back control input ( $\overline{\mathrm{OERB}}$ ). When $\overline{\mathrm{OERB}}$ is taken low, the data present at the output of the data latches will be allowed to pass back onto the input data bus. When it is taken high, the output of the data latches will be isolated from the data (D) inputs. The read-back control does not affect the internal operation of the latches; however, caution should be exercised not to create a busconflict situation.

The SN54ALS666 and SN54ALS667 are characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74ALS666 and SN75ALS667 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

SN54ALS666 . . . JT PACKAGE
SN74ALS666 . . DW OR NT PACKAGE
(TOP VIEW)


SN54ALS666 . . FK PACKAGE
SN74ALS666 . FN PACKAGE
(TOP VIEW)


NC-No internal connection.

SN54ALS666, SN54ALS667, SN74ALS666, SN74ALS667
8-BIT D-TYPE TRANSPARENT READ-BACK LATCHES
WITH 3-STATE OUTPUTS


NC-No internal connection.

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


${ }^{\dagger}$ These symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12
Pin numbers shown are for DW, JT, and NT packages.
logic diagrams (positive logic)
'ALS666

$\overline{\text { PRE }}$ (14) -O
CLR (11)


Pin numbers shown are for DW, JT, and NT packages.
'ALS667

$\overline{C L R} \frac{(11)}{(14)}$

SN54ALS666, SN54ALS667, SN74ALS666, SN74ALS667 8-BIT D-TYPE TRANSPARENT READ-BACK LATCHES
WITH 3-STATE OUTPUTS
timing diagram

$\overline{\mathrm{CLR}}=H, \overline{\mathrm{PRE}}=H, \overline{\mathrm{OE}} 1=L, \overline{\mathrm{OE}} 2=L$
*This setup time ensures the readback circuit will not create a conflict on the input data bus.
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, $V_{C C} . .$. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Input voltage (all inputs except D input) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Voltage applied to D inputs and to disabled 3-state outputs . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V
Operating free-air temperature range: SN54ALS666, SN54ALS667 . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ SN74ALS666, SN74ALS667 . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range
$-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended operating conditions

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

| PARAMETER |  | TEST CONDITIONS |  | SN54ALS666 <br> SN54ALS667 |  |  | SN74ALS666 SN74ALS667 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYPt | MAX | MIN | TYPt | MAX |  |
| $\mathrm{V}_{\mathrm{IK}}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | All outputs | $\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$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  | Q or $\overline{\mathrm{Q}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-1 \mathrm{~mA}$ | 2.4 |  |  |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-2.6 \mathrm{~mA}$ |  |  |  | 2.4 | 3.2 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | D | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | v |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OL}}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | Q or $\overline{\mathrm{Q}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| ${ }^{1} \mathrm{OZH}$ | Q or $\overline{\mathrm{Q}}$ | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IOZL |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  | -20 |  |  | -20 |  |
| 1 | D inputs | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | All others | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| Ith | D inputs ${ }^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}=2,7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | All others |  |  |  |  | 20 |  |  | 20 |  |
| IIL | D inputs ${ }^{\ddagger}$ | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.1 |  |  | -0.1 | mA |
|  | All others |  |  |  |  | -0.1 |  |  | -0.1 |  |
| $10^{8}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ${ }^{\text {ICC }}$ | 'ALS666 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \mathrm{OERB} \text { high } \end{aligned}$ | Q outputs high |  | 25 | 50 |  | 25 | 50 | mA |
|  |  |  | Q outputs low |  | 40 | 73 |  | 40 | 73 |  |
|  |  |  | Q outputs disabled |  | 30 | 55 |  | 30 | 55 |  |
|  | 'ALS667 |  | $\overline{\mathrm{O}}$ outputs high |  | 25 | 50 |  | 25 | 50 |  |
|  |  |  | $\overline{\mathrm{Q}}$ outputs low |  | 45 | 79 |  | 45 | 79 |  |
|  |  |  | $\overline{\mathrm{O}}$ outputs disabled |  | 30 | 60 |  | 30 | 60 |  |

[^28]$\ddagger$ For I/O ports, the parameters $I_{I H}$ and $I_{I L}$ include the off-state output current.
$\S$ The output conditions have been chosen to produce a current that closely approximates one half the true short-circuit output currents, IOS.

SN54ALS666, SN54ALS667, SN74ALS666, SN74ALS667
8-BIT D-TYPE TRANSPARENT READ-BACK LATCHES
WITH 3-STATE OUTPUTS
'ALS666 switching characteristics (see Figure 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \\ \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ \hline \text { ALS666 } \\ \hline \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{~T}_{\mathrm{A}}=\mathrm{MIN} \text { to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MIAX |  |
| ${ }^{\text {tPLH }}$ | D | Q |  | 7 | 10 | 3 | 18 | 3 | 14 | ns |
| tPHL |  |  |  | 11 | 15 | 4 | 22 | 4 | 18 |  |
| tPLH | C | Q |  | 12 | 16 | 6 | 25 | 6 | 21 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 16 | 21 | 8 | 32 | 8 | 27 |  |
| tPHL | $\overline{C L R}$ | Q |  | 17 | 22 | 9 | 32 | 9 | 29 | ns |
| tPHL |  | D |  | 17 | 24 | 11 | 36 | 11 | 32 |  |
| tPLH | $\overline{\text { PRE }}$ | Q |  | 13 | 18 | 7 | 28 | 7 | 22 | ns |
| tPHL |  | D |  | 17 | 22 | 9 | 35 | 9 | 28 |  |
| $\mathrm{t}_{\text {en }}$ | $\overline{\text { OERB }}$ | D |  | 11 | 17 | 4 | 25 | 4 | 21 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  |  | 6 | 11 | 1 | 18 | 1 | 14 |  |
| ${ }_{\text {t }}$ n | $\overline{\mathrm{OE}} 1, \overline{\mathrm{OE}} 2$ | Q |  | 11 | 17 | 4 | 25 | 4 | 21 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  |  | 6 | 11 | 1 | 18 | 1 | 14 |  |

'ALS667 switching characteristics (see Figure 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline{ }^{\prime} \mathrm{ALS} 667 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tPLH | D | $\overline{\mathrm{Q}}$ |  | 13 | 17 | 6 | 24 | 6 | 20 | ns |
| tPHL |  |  |  | 9 | 13 | 4 | 18 | 4 | 15 |  |
| tPLH | C | $\overline{\mathrm{Q}}$ |  | 18 | 23 | 9 | 35 | 9 | 28 | ns |
| tPHL |  |  |  | 14 | 19 | 7 | 27 | 7 | 22 |  |
| tPLH | $\overline{C L R}$ | $\overline{\mathrm{Q}}$ |  | 14 | 19 | 7 | 28 | 7 | 24 | ns |
| tPHL |  | D |  | 17 | 23 | 8 | 30 | 8 | 26 |  |
| tPHL | $\overline{\text { PRE }}$ | $\overline{\mathrm{Q}}$ |  | 17 | 23 | 8 | 30 | 8 | 25 | ns |
| tPLH |  | D |  | 18 | 25 | 9 | 35 | 9 | 28 |  |
| $t_{\text {en }}$ | $\overline{\text { OERB }}$ | D | . | 11 | 17 | 4 | 25 | 4 | 21 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  |  | 6 | 11 | 1 | 20 | 1 | 14 |  |
| $t_{\text {en }}$ | $\overline{\mathrm{OE}} 1, \overline{\mathrm{OE}} 2$ | $\overline{\mathrm{Q}}$ |  | 11 | 17 | 4 | 25 | 4 | 21 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  |  | 6 | 11 | 1 | 20 | 1 | 14 |  |

[^29]
## PARAMETER MEASUREMENT INFORMATION



FIGURE 1

SOOINOCIS] A

## SN54AS821, SN54AS822, SN74AS821, SN74AS822 10-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

D2825, DECEMBER 1983-REVISED JANUARY 1986

- Functionally Equivalent to AMD's AM29821 and AM29822
- Provides Extra Data Width Necessary for Wider Address/Data Paths or Buses with Parity
- Outputs Have Undershoot Protection Circuitry
- Power-Up High-Impedance State
- Package Options Include Both Plastic and Ceramic Carriers in Addition to Plastic and Ceramic DIPs
- Buffered Control Inputs to Reduce DC Loading Effects
- Dependable Texas Instruments Quality and Reliability


## description

These 10-bit flip-flops feature three-state outputs designed specifically for driving highlycapacitive or relatively low-impedance loads. They are particularly suitable for implementing wider buffer registers, I/O ports, bidirectional bus drivers with parity, and working registers.

The ten flip-flops are edge-triggered D-type flipflops. On the positive transition of the clock the Q outputs on the 'AS821 will be true, and on the 'AS822 will be complementary to the data input.

A buffered output-control input can be used to place the ten outputs in either a normal logic state (high or low levels) or a high-impedance state. In the high-impedance state the outputs neither load nor drive the bus lines significantly. The high-impedance state and increased drive provide the capability to drive the bus lines in a bus-organized system without need for interface or pull-up components. The output control ( $\overline{\mathrm{OC}}$ ) does not affect the internal operation of the flipflops. Old data can be retained or new data can be entered while the outputs are in the highimpedance state.

The SN54AS' family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.


NC - No internal connection

## SN54AS821, SN74AS821

10-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS
'AS821 FUNCTION TABLE (EACH FLIP-FLOP)

| INPUTS |  |  | OUTPUT |
| :---: | :---: | :---: | :---: |
| $\overline{O C}$ | CLK | D | Q |
| L | $\uparrow$ | $H$ | $H$ |
| $L$ | $\uparrow$ | $L$ | $L$ |
| $L$ | $L$ | $X$ | $Q_{0}$ |
| $H$ | $X$ | $X$ | $Z$ |

'AS821 logic symbol ${ }^{\dagger}$

${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
'AS821 logic diagram (positive logic)


Pin numbers shown are for DW, JT, and NT packages.

## SN54AS822, SN74AS822 10-BIT BUS INTERFACE FLIP.FLOPS WITH 3-STATE OUTPUTS

'AS822 FUNCTION TABLE (EACH FLIP-FLOP)

| INPUTS |  |  | OUTPUT |
| :---: | :---: | :---: | :---: |
| OC | CLK | D | Q |
| L | $\uparrow$ | $H$ | $H$ |
| L | $\uparrow$ | L | L |
| L | L | X | $\mathrm{Q}_{\mathrm{O}}$ |
| $H$ | X | X | Z |

'AS822 logic symbol ${ }^{\dagger}$

${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
'AS822 logic diagram (positive logic)


Pin numbers shown are for DW, JT, and NT packages.

## SN54AS821, SN54AS822, SN74AS821, SN74AS822 <br> 10-BIT BUS INTERFACE FLIP.FLOPS WITH 3-STATE OUTPUTS

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

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: SN54AS821, SN54AS822 ..... $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$SN74AS821, SN74AS822$0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$$-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended operating conditions

|  |  | SN54AS821 <br> SN54AS822 |  |  | SN74AS821 <br> SN74AS822 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  |  | -24 |  |  | -24 | mA |
| ${ }^{\mathrm{I}} \mathrm{OL}$ | Low-level output currrent |  |  | 32 |  |  | 48 | mA |
| $\mathrm{t}_{\mathrm{w}}$ | Pulse duration, CLK high or low | 9 |  |  | 8 |  |  | ns |
| $\mathrm{t}_{\mathrm{su}}$ | Setup time, data before CLK $\uparrow$ | 7 |  |  | 6 |  |  | ns |
| $t_{h}$ | Hold time, data after CLK $\uparrow$ | 0 |  |  | 0 |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature | -55 |  | $125-$ | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

| PARAMETER |  | TEST CONDITIONS |  | SN54AS821 <br> SN54AS822 |  |  | SN74AS821 <br> SN74AS822 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to | $1 \mathrm{OH}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}$ |  |  | $\mathrm{V}_{\mathrm{CC}}$ |  |  |  |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-15 \mathrm{~mA}$ | 2.4 | 3.2 |  | 2.4 | 3.2 |  | v |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-24 \mathrm{~mA}$ | 2 |  |  | 2 |  |  |  |
| V |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}$ |  | 0.25 | 0.5 |  |  |  | V |
| VOL |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{\text {O }}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| ${ }^{\text {I OzH }}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
| ${ }^{\text {I OZL }}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -50 |  |  | -50 | $\mu \mathrm{A}$ |
| 1 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| ${ }^{1} \mathrm{IH}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| ILL |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.5 |  |  | -0.5 | mA |
| $10^{\ddagger}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ${ }^{\text {I C C }}$ | 'AS821 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | Outputs high |  | 55 | 88 |  | 55 | 88 | mA |
|  |  |  | Outputs low |  | 68 | 109 |  | 68 | 109 |  |
|  |  |  | Outputs disabled |  | 70 | 113 | $\begin{array}{rr}70 & 113 \\ 55 & 88\end{array}$ |  |  |  |
|  | 'AS822 |  | Outputs high |  | 55 | 88 |  |  |  |  |
|  |  |  | Outputs low |  | 68 | 109 |  | 68 | 109 |  |
|  |  |  | Outputs disabled |  | 70 | 113 |  | 70 | 113 |  |

[^30]SN54AS821, SN54AS822, SN74AS821, SN74AS822 10-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS
switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (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 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=\mathrm{MIN} \text { to } \mathrm{MAX} \\ & \hline \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| tpLH | CLK | Any Q | 3.5 | 9 | 3.5 | 7.5 | ns |
| tPHL |  |  | 3.5 | 11.5 | 3.5 | 10.5 |  |
| tPZH | $\overline{O C}$ | Any 0 | 4 | 12 | 4 | 11 | ns |
| tPZL |  |  | 4 | 13 | 4 | 12 |  |
| tPHZ | $\overline{O C}$ | Any 0 | 2 | 10 | 2 | 8 | ns |
| tPZL |  |  | 2 | 10 | 2 | 8 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

- Functionally Equivalent to AMD's AM29823 and AM29824
- Provides Extra Data Width Necessary for Wider Address/Data Paths or Buses with Parity
- Outputs Have Undershoot Protection Circuitry
- Power-Up High-Impedance State
- Buffered Control Inputs to Reduce DC Loading Effects
- Package Options Include both Plastic and Ceramic Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 9-bit flip-flops feature three-state outputs designed specifically for driving highly capacitive or relatively low-impedance loads. They are particularly suitable for implementing wider buffer registers, I/O ports, bidirectional bus drivers, parity bus interfacing and working registers.

With the clock enable ( $\overline{\mathrm{CLKEN}}$ ) low, the nine Dtype edge-triggered flip-flops enter data on the low-to-high transitions of the clock. Taking CLKEN high will disable the clock buffer, thus latching the outputs. The 'AS823 has noninverting $D$ inputs and the 'AS824 has inverting $D$ inputs. Taking the $\overline{C L R}$ input low causes the nine Q outputs to go low independently of the clock.

A buffered output-control input ( $\overline{\mathrm{OC}}$ ) can be used to place the nine outputs in either normal logic state (high or low level) or a high-impedance state. In the high-impedance state the outputs neither load nor drive the bus lines significantly. The high-impedance state and increased drive provide the capability to drive the bus lines in a bus-organized system without need for interface or pull-up components. The output control does not affect the internal operation of the flip-flops. Old data can be retained or new data can be entered while the outputs are in the highimpedance state.


$$
\begin{gathered}
\text { SN54AS823 . . . FK PACKAGE } \\
\text { SN74AS823 . . FN PACKAGE } \\
\text { (TOP VIEW) }
\end{gathered}
$$



SN54AS824 . . . JT PACKAGE
SN74AS824 . . . DW OR NT PACKAGE (TOP VIEW)

| $\overline{O C} \square_{1}^{1}$ | $\mathrm{U}_{24} \mathrm{~V}_{\mathrm{CC}}$ |
| :---: | :---: |
| 1可 ${ }^{2}$ | 2310 |
| 2- ${ }^{3}$ | 22.20 |
| 3 $\overline{\mathrm{D}} \mathrm{C}_{4}$ | 21 ¢30 |
| $4 \overline{\mathrm{D}} \square^{5}$ | $20-40$ |
| $5 \overline{\text { D }}$ - 6 | $19 \bigcirc 50$ |
| $6 \overline{\text { ¢ }}$ | 18-60 |
| 7万 ¢ $\square^{8}$ | $17 \bigcirc 70$ |
| 8 $\overline{\text { - }}$ | $16 \bigcirc 80$ |
| $9 \overline{\mathrm{D}} \mathrm{H}_{10}$ | $15 \bigcirc 9$ |
| $\overline{\text { CLR }} 11$ | 14 CLKEN |
| GND 12 | 13 J CLK |

SN54AS824 . . . FK PACKAGE SN74AS824 . . . FN PACKAGE
(TOP VIEW)


SN54AS823, SN54AS824, SN74AS823, SN74AS824
9-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

The SN54AS' family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

| 'AS823 FUNCTION TABLE |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | INPUTS |  |  | OUTPUT |
| $\overline{\text { OC }}$ | $\overline{\text { CLR }}$ | $\overline{\text { CLKEN }}$ | CLK | D | Q |
| L | L | X | X | X | L |
| L | $H$ | L | $\uparrow$ | $H$ | H |
| L | $H$ | L | $\uparrow$ | L | L |
| L | $H$ | $H$ | $X$ | $X$ | $Q_{O}$ |
| H | $X$ | $X$ | $X$ | $X$ | $Z$ |

'AS823 logic symbol ${ }^{\dagger}$
$\dagger$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12
'AS823 logic diagram (positive logic)


Pin numbers shown are for DW, JT, and NT packages.

| 'AS824 FUNCTION TABLE |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INPUTS |  |  |  |  | OUTPUT |
| $\overline{\mathrm{OC}}$ | $\overline{C L R}$ | $\overline{\text { CLKEN }}$ | CLK | $\overline{\text { D }}$ | 0 |
| L | L | X | X | X | L |
| L | H | L | $\uparrow$ | H | L |
| L | H | L | $\uparrow$ | L | H |
| L | H | H | $x$ | $x$ | $\mathrm{o}_{0}$ |
| H | X | X | x | X | z |

'AS824 logic symbol ${ }^{\dagger}$

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

## 'AS824 logic diagram (positive logic)



Pin numbers shown are for DW, JT, and NT packages.

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| 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: | SN54AS823, SN54AS824 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
|  | SN74AS823, SN74AS824 | . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range |  | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions

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

| PARAMETER |  | TEST CONDITIONS |  | SN54AS823 <br> SN54AS824 |  |  | SN74AS823 <br> SN74AS824 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\text {t }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V , $\mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-15 \mathrm{~mA}$ | 2.430 |  |  | 2.43 .2 |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-24 \mathrm{~mA}$ | 2 |  |  | 2 |  |  |  |
| $\mathrm{V}_{\text {OL }}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=32 \mathrm{~mA}$ |  | 0.3 | 0.5 |  |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=48 \mathrm{~mA}$ |  |  |  | / | 0.35 | 0.5 |  |
| IOZH |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
| IOZL |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -50 |  |  | -50 | $\mu \mathrm{A}$ |
| II |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| ${ }_{\text {IH }}$ |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IIL |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.5 |  |  | -0.5 | mA |
| $10^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{O}}=2.25 \mathrm{~V}$ |  | -30 | -112 |  | -30 |  | -112 | mA |
| ICC | 'AS823 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | Outputs high |  | 49 | 80 |  | 49 | 80 | mA |
|  |  |  | Outputs low |  | 61 | 100 |  | 61 | 100 |  |
|  |  |  | Outputs disabled |  | 64 | 103 |  | 64 | 103 |  |
|  | 'AS824 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | Outputs high |  | 49 | 80 |  | 49 | 80 | mA |
|  |  |  | Outputs low |  | 61 | 100 |  | 61 | 100 |  |
|  |  |  | Outputs disabled |  | 64 | 103 |  | 64 | 103 |  |

[^31]switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=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}_{\mathbf{A}}=\text { MIN to } \mathrm{MAX} \\ & \hline \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS823 <br> SN54AS824 |  | SN74AS823 <br> SN74AS824 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| tPLH | CLK | Any 0 | 3.5 | 9 | 3.5 | 7.5 | ns |
| tPHL |  |  | 3.5 | 12 | 3.5 | 11 |  |
| tPHL | $\overline{\text { CLR }}$ | Any Q | 3.5 | 14 | 3.5 | 13 | ns |
| tpZH | $\overline{O C}$ | Any Q | 4 | 12 | 4 | 11 | ns |
| tPZL |  |  | 4 | 13 | 4 | 12 |  |
| tPHZ | $\overline{O C}$ | Any Q | 2 | 10 | 2 | 8 | ns |
| tplZ |  |  | 2 | 10 | 2 | 8 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## D flip-flop signal conventions

It is normal Tl practice to name the outputs and other inputs of a D-type flip-flop and to draw its logic symbol based on the assumption of true data (D) inputs. Then outputs that produce data in phase with the data inputs are called $Q$ and those producing complementary data are called $Q$. An input that causes a Q output to go high or a Q output to go low is called Preset; an input that causes a Q output to go high or a Q output to go low is called Clear. Bars are used over these pin names (PRE and CLR) if they are active-low.
The devices on this data sheet are second-source designs and the pin-name convention used by the original manufacturer has been retained. That makes it necessary to designate the inputs and outputs of the inverting circuit $D$ and $Q$. In some applications it may be advantageous to redesignate the inputs and outputs as $D$ and $Q$. In that case, outputs should be renamed as shown below. Also shown are corresponding changes in the graphical symbol. Arbitrary pin numbers are shown in parentheses.
Notice that Q and Q exchange names, which causes Preset and Clear to do likewise. Also notice that the polarity indicators ( $\Delta$ ) on PRE and CLR remain since these inputs are still active-low, but that the presence or absence of the polarity changes at $D, Q$, and $Q$. Of course pin $5(Q)$ is still in phase with the data input $D$, but now both are considered active high.



## SN54AS825, SN54AS826 <br> SN74AS825, SN74AS826 <br> 8-BIT BUS INTERFACE FLIP.FLOPS WITH 3-STATE OUTPUTS

D2825, JUNE 1984-REVISED JANUARY 1986

- Functionally Equivalent to AMD's AM29825 and AM29826
- Improved IOH Specifications
- Multiple Output Enables Allow Multiuser Control of the Interface
- Outputs Have Undershoot Protection Circuitry
- Power-Up High-Impedance State
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Buffered Control Inputs to Reduce DC Loading Effect
- Dependable Texas Instruments Quality and Reliability


## description

These 8-bit flip-flops feature three-state outputs designed specifically for driving highly capacitive or relatively low-impedance loads. They are particularly suitable for implementing multiuser registers, I/O ports, bidirectional bus drivers, and working registers.
With the clock enable ( $\overline{\mathrm{CLKEN}}$ ) low, the eight D type edge-triggered flip-flops enter data on the low-to-high transitions of the clock. Taking $\overline{\text { CLKEN }}$ high will disable the clock buffer, thus latching the outputs. The 'AS825 has noninverting $D$ inputs and the 'AS826 has inverting $\overline{\mathrm{D}}$ inputs. Taking the $\overline{\mathrm{CLR}}$ input low causes the eight Q outputs to go low independently of the clock.
Multiuser buffered output-control inputs ( $\overline{\mathrm{OC}} 1$, $\overline{\mathrm{OC}} 2$, and $\overline{\mathrm{OC}} 3$ ) can be used to place the eight outputs in either a normal logic state (high or low level) or a high-impedance state. In the highimpedance state the outputs neither load nor drive the bus lines significantly. The highimpedance state and increased drive provide the capability to drive the bus lines in a busorganized system without need for interface or pull-up components. The output controls do not affect the internal operation of the flip-flops. Old data can be retained or new data can be entered while the outputs are in the high-impedance state.


SN54AS826 . . . FK PACKAGE SN74AS826 . . . FN PACKAGE (TOP VIEW)


NC - No internal connection

## SN54AS825, SN54AS826, SN74AS825, SN74AS826

 8-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTSThe SN54AS' family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.
'AS825 FUNCTION TABLE

| INPUTS |  |  |  |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { OC }}^{*}$ | CLR | $\overline{\text { CLKEN }}$ | CLK | D | Q |
| L | L | X | X | X | L |
| L | H | L | $\uparrow$ | H | H |
| L | H | L | $\uparrow$ | L | L |
| L | H | H | X | X | Q $_{\text {O }}$ |
| H | X | X | X | X | Z |

$\overline{O C}^{*}=H$ if any of $\overline{O C} 1, \overline{O C} 2$, or $\overline{O C} 3$ are high.
$\overline{\mathrm{OC}}^{*}=\mathrm{L}$ if all of $\overline{\mathrm{OC}} 1, \overline{\mathrm{OC}} 2$, and $\overline{\mathrm{OC}} 3$ are low.
'AS825 logic symbol ${ }^{\dagger}$
${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
'AS825 logic diagram (positive logic)


## SN54AS826, SN74AS826 8-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

'AS826 FUNCTION TABLE

| INPUTS |  |  |  |  | $\begin{gathered} \text { OUTPUT } \\ \mathbf{o} \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OC}}$ * | $\overline{C L R}$ | CLKEN | CLK | $\overline{\mathrm{D}}$ |  |
| L | L | X | X | X | L |
| L | H | L | $\uparrow$ | H | L |
| L | H | L | $\uparrow$ | L | H |
| L | H | H | $x$ | $x$ | $\mathrm{Q}_{0}$ |
| H | X | X | X | X | Z |

$\overline{\mathrm{OC}}^{*}=\mathrm{H}$ if any of $\overline{\mathrm{OC}} 1, \overline{\mathrm{OC}} 2$, or $\overline{\mathrm{OC}} 3$ are high.
$\overline{\mathrm{OC}}^{*}=\mathrm{L}$ if all of $\overline{\mathrm{OC}} 1, \overline{\mathrm{OC}} 2$, and $\overline{\mathrm{OC}} 3$ are low.

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


${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12
'AS826 logic diagram (positive logic)


## absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

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:
SN54AS825, SN54AS826 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
SN74AS825, SN74AS826 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65 to $150^{\circ} \mathrm{C}$
recommended operating conditions

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

| PARAMETER |  | TEST CONDITIONS |  | SN54AS825 <br> SN54AS826 |  |  | SN74AS825 <br> SN74AS826 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\text {t }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{l}^{\mathrm{OH}}=-2 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-15 \mathrm{~mA}$ | 2.43 .2 |  |  | 2.43 .2 |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-24 \mathrm{~mA}$ | 2 |  |  | 2 |  |  |  |
| $\mathrm{V}_{\text {OL }}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{\prime}=32 \mathrm{~mA}$ |  | 0.3 | 0.5 |  |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| IOZH |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=2.7 \mathrm{~V}$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
| IOZL |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -50 |  |  | -50 | $\mu \mathrm{A}$ |
| 1 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| IIH |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| ILL |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{i}}=0.4 \mathrm{~V}$ |  |  | -0.5 |  |  | -0.5 | mA |
| $10^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ICC | 'AS825 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | Outputs high |  | 45 | 73 |  | 45 | 73 | mA |
|  |  |  | Outputs low |  | 56 | 90 |  | 56 | 90 |  |
|  |  |  | Outputs disabled |  | 59 | 95 |  | 59 | 95 |  |
|  | 'AS826 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | Outputs high |  | 45 | 73 |  | 45 | 73 | mA |
|  |  |  | Outputs low |  | 56 | 90 |  | 56 | 90 |  |
|  |  |  | Outputs disabled |  | 59 | 95 |  | 59 | 95 |  |

[^32]
## SN54AS825, SN54AS826, SN74AS825, SN74AS826 8-BIT BUS INTERFACE FLIP.FLOPS WITH 3-STATE OUTPUTS

switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathbf{C}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathbf{L}}=50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathbf{A}}=\text { MIN to } \mathrm{MAX} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS825 SN54AS826 |  | SN74AS825 <br> SN74AS826 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {tPLH }}$ | CLK | Any 0 | 3.5 | 9 | 3.5 | 7.5 | ns |
| ${ }^{\text {tPHL }}$ |  |  | 3.5 | 11.5 | 3.5 | 11 |  |
| ${ }^{\text {t }} \mathrm{PHL}$ | $\overline{\text { CLR }}$ | Any Q | 3.5 | 14 | 3.5 | 13 | ns |
| ${ }^{\text {tPZH }}$ | $\overline{\mathrm{OC}}$ | Any Q | 4 | 12 | 4 | 11 | ns |
| ${ }^{\text {t P Z }}$ |  |  | 4 | 13 | 4 | 12 |  |
| tPHZ | $\overline{O C}$ | Any Q | 2 | 10 | 2 | 8 | ns |
| ${ }_{\text {tPLZ }}$ |  |  | 2 | 10 | 2 | 8 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## D flip-flop signal conventions

It is normal TI practice to name the outputs and other inputs of a D-type flip-flop and to draw its logic symbol based on the assumption of true data ( D ) inputs. Then outputs that produce data in phase with the data inputs are called Q and those producing complementary data are called $\overline{\mathrm{Q}}$. An input that causes a Q output to go high or a $\overline{\mathrm{Q}}$ output to go low is called Preset; an input that causes a $\overline{\mathrm{O}}$ output to go high or a Q output to go low is called Clear. Bars are used over these pin names ( $\overline{\mathrm{PRE}}$ and $\overline{\mathrm{CLR}}$ ) if they are active-low.

The devices on this data sheet are second-source designs and the pin-name convention used by the original manufacturer has been retained. That makes it necessary to designate the inputs and outputs of the inverting circuit $\overline{\mathrm{D}}$ and Q . In some applications it may be advantageous to redesignate the inputs and outputs as D and $\overline{\mathrm{Q}}$. In that case, outputs should be renamed as shown below. Also shown are corresponding changes in the graphical symbol. Arbitrary pin numbers are shown in parentheses.
Notice that Q and $\overline{\mathrm{Q}}$ exchange names, which causes Preset and Clear to do likewise. Also notice that the polarity indicators ( $\Delta$ ) on $\overline{\text { PRE }}$ and $\overline{C L R}$ remain since these inputs are still active-low, but that the presence or absence of the polarity indicator changes at $\overline{\mathrm{D}}, \mathrm{Q}$, and $\overline{\mathrm{O}}$. Of course $\operatorname{pin} 5(\mathrm{Q})$ is still in phase with the data input $D$, but now both are considered active high.


D2910, DECEMBER 1983--REVISED OCTOBER 1985

- 3-State Buffer-Type Outputs Drive Bus-Lines Directly
- Bus-Structured Pinout
- Provide Extra Bus Driving Latches Necessary for Wider Address/Data Paths or Buses with Parity
- Buffered Controi Inputs to Reduce DC Loading
- Power-Up High-Impedance State
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 10-bit latches feature three-state outputs designed specifically for driving highly capacitive or relatively low-impedance loads. They are particularly suitable for implementing buffer registers, I/O ports, bidirectional bus drivers, and working registers.

The ten latches are transparent D-type. The 'ALS841 and 'AS841 have noninverting data (D) inputs. The 'ALS842 and 'AS842 have inverting $\overline{\mathrm{D}}$ inputs.
A buffered output control ( $\overline{\mathrm{OC}}$ ) input can be used to place the ten outputs in either a normal logic state (high or low levels) or a high-impedance state. In the high-impedance state, the outputs neither load nor drive the bus lines significantly. The high-impedance state and increased drive provide the capability to drive the bus lines in a bus-organized system without need for interface or pull-up components.

The output control does not affect the internal operation of the latches. Old data can be retained or new data can be entered while the outputs are off.

The -1 versions of the SN74ALS841 and SN74ALS842 parts are identical to the standard versions except that the recommended maximum $I_{O L}$ is increased to 48 milliamperes. There are no -1 versions of the SN54ALS841 and SN54ALS842.

SN54ALS841, SN54AS841 . . . JT PACKAGE
SN74ALS841, SN74AS841 . . . DW OR NT PACKAGE
(TOP VIEW)


SN54ALS841, SN54AS841 . . . FK PACKAGE
SN74ALS841, SN74AS841 . . . FN PACKAGE
(TOP VIEW)


SN54ALS842, SN54AS842 . . . JT PACKAGE SN74ALS842, SN74AS842 . . . DW OR NT PACKAGE (TOP VIEW)


SN54ALS842, SN54AS842 . . . FK PACKAGE
SN74ALS842, SN74AS842 . . . FN PACKAGE (TOP VIEW)


NC-No internal connection

SN54ALS841, SN54AS841, SN54ALS842, SN54AS842
SN74ALS841, SN74AS841, SN74ALS842, SN74AS842
10-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

The SN54ALS841, SN54AS841, SN54ALS842, and SN54AS842 are characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74ALS841, SN74AS841, SN74ALS842, and SN74AS842 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## FUNCTION TABLES

'ALS841, 'AS841

| INPUTS |  |  | OUTPUT |
| :---: | :---: | :---: | :---: |
| $\mathbf{O C}$ | C | D | Q |
| L | H | H | H |
| L | H | L | L |
| L | L | X | Q $_{\text {O }}$ |
| H | X | X | Z |

'ALS841, 'AS841 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 DW, JT, and NT packages.

## SN54ALS841, SN54AS841, SN54ALS842, SN54AS842 SN74ALS841, SN74AS841, SN74ALS842, SN74AS842 10-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

'ALS842, 'AS842 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 DW, JT, and NT packages.
'ALS842, 'AS842 logic diagram (positive logic)

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
$\qquad$
Input voltage7

Voltage applied to a disabled 3 -state output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V
Operating free-air temperature range:

$$
\text { SN54ALS841, SN54AS841, SN54ALS842, SN54AS842 . . . . . . . }-55^{\circ} \mathrm{C} \text { to } 125^{\circ} \mathrm{C}
$$

$$
\text { SN74ALS841, SN74AS841, SN74ALS842, SN74AS842 . . . . . . . . . . . . . . } 0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}
$$

Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

## SN54ALS841, SN74ALS841 <br> 10-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

## recommended operating conditions

|  |  | SN54ALS841 |  |  | SN74ALS841 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  |  | -1 |  |  | -2.6 | mA |
| IOL | Low-level output current |  |  | 12 |  |  | 24 | mA |
|  |  |  |  |  |  |  | $48^{\dagger}$ |  |
| $\mathrm{t}_{\mathrm{w}}$ | Pulse duration, enable $C$ high | 25 |  |  | 20 |  |  | ns |
| $\mathrm{t}_{\text {su }}$ | Setup time, data before enable C $\downarrow$ | 16 |  |  | 10 |  |  | ns |
| $t_{\text {h }}$ | Hold time, data after enable C $\downarrow$ | 7 |  |  | 5 |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

${ }^{\dagger}$ The extended limit applies only if $\mathrm{V}_{\mathrm{CC}}$ is maintained between 4.75 V and 5.25 V . The 48 mA limit applies for SN74ALS841-1 only.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

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

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathbf{C}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathbf{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=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}}=\mathrm{MIN} \text { to MAX } \end{aligned}$ |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | 4ALS | 841 |  | 4ALS |  |  |
|  |  |  | MIN | TYP | MAX | MIN | TYP | MAX | MIN | TYP | MAX |  |
| tpLH | D | Q |  | 8.5 | 11 | 2 |  | 15 | 2 |  | 13 | ns |
| tPHL |  |  |  | 8.5 | 11 | 2 |  | 15 | 2 |  | 13 |  |
| tPLH | C | $Q$ |  | 14 | 18 | 7 |  | 25 | 7 |  | 21 | ns |
| tPHL |  |  |  | 17 | 23 | 8 |  | 30 | 8 |  | 26 |  |
| tPZH | $\overline{O C}$ | 0 |  | 7.5 | 10 | 2 |  | 14 | 2 |  | 12 | ns |
| tPZL |  |  |  | 7.5 | 10 | 2 |  | 14 | 2 |  | 12 |  |
| tphz | $\overline{O C}$ | 0 |  | 6 | 8 | 2 |  | 12 | 2 |  | 10 | ns |
| tPLZ |  |  |  | 7 | 9 | 2 |  | 14 | 2 |  | 12 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

SN54ALS842, SN74ALS842
10-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS
recommended operating conditions

$\dagger$ The extended limit applies only if $V_{C C}$ is maintained between 4.75 V and 5.25 V . The 48 mA limit applies for SN74ALS841-1 only.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

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

## SN54ALS842, SN74ALS842 10-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

'ALS842 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \Omega \\ & \mathrm{R2}=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \text { ALS842 } \end{aligned}$ |  |  | $\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 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tPLH | $\overline{\mathrm{D}}$ | Q |  | 11 | 15 | 4 | 22 | 4 | 18 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 8 | 11 | 3 | 17 | 3 | 13 |  |
| ${ }^{\text {tPLH }}$ | C | Q |  | 17 | 23 | 8 | 31 | 8 | 27 | ns |
| tPHL |  |  |  | 13 | 18 | 6 | 24 | 6 | 20 |  |
| tPZH | $\overline{\mathrm{OC}}$ | Q |  | 8 | 10 | 2 | 14 | 2 | 12 | ns |
| ${ }_{\text {tPZL }}$ |  |  |  | 8 | 11 | 2 | 14 | 2 | 12 |  |
| tPHZ | $\overline{O C}$ | Q |  | 6 | 8 | 1 | 12 | 1 | 10 | ns |
| ${ }^{\text {t PLZ }}$ |  |  |  | 7 | 9 | 2 | 14 | 2 | 12 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

SN54AS841, SN54AS842
SN74AS841, SN74AS842
10-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS
recommended operating conditions

|  |  | SN54AS841 <br> SN54AS842 |  |  | SN74AS841- $\quad$ SN74AS842 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| $\mathrm{I}_{\mathrm{OH}}$ | High-level output current |  |  | -24 |  |  | -24 | mA |
| ${ }^{\text {I OL }}$ | Low-level output current |  |  | 32 |  |  | 48 | mA |
| $\mathrm{t}_{\mathrm{w}}$ | Pulse duration, enable C high | 5 |  |  | 4 |  |  | ns |
| $\mathrm{t}_{\text {su }}$ | Setup time, data before enable $\mathrm{C} \downarrow$ | 3.5 |  |  | 2.5 |  |  | ns |
| th | Hold time, data after enable C $\downarrow$ | 3.5 |  |  | 2.5 |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

| PARAMETER |  | TEST CONDITIONS |  | SN54AS841 SN54AS842 |  |  | SN74AS841 <br> SN74AS842 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\text {t }}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{I}}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| VOH |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \mathrm{t}$ | $1 \mathrm{OH}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}{ }^{-2}$ |  |  | $\mathrm{V}_{\mathrm{CC}-2}$ |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-15 \mathrm{~mA}$ | $\begin{array}{rrr}2.4 & 3.2 \\ 2\end{array}$ |  |  | 2.43 .2 |  |  | V |  |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-24 \mathrm{~mA}$ |  |  |  | 2 |  |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=32 \mathrm{~mA}$ |  | 0.25 | 0.5 |  |  |  | V |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |  |
| IOZH |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |  |
| lozL |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  | -50 |  |  | -50 | $\mu \mathrm{A}$ |  |
| II |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |  |
| IIH |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |  |
| IL |  | $\begin{array}{ll}\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}, & \mathrm{~V}_{1}=0.4 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, & \mathrm{~V}_{\mathrm{O}}=2.25 \mathrm{~V}\end{array}$ |  |  | $-112$ |  |  | $-112$ |  | $\frac{\mathrm{mA}}{\mathrm{~mA}}$ |  |
| $10^{\ddagger}$ |  |  |  | -30 |  |  | -30 |  |  |  |  |
| ICC | 'AS841 | $V_{C C}=5.5 \mathrm{~V}$ | Outputs high |  | 36 | 60 |  | 36 | 60 | mA |  |
|  |  |  | Outputs low |  | 58 | 94 |  | 58 | 94 |  |  |
|  |  |  | Outputs disabled |  | 56 | 92 |  | 56 | 92 |  |  |
|  | 'AS842 |  | Outputs high |  | 38 | 62 |  | 38 | 62 |  |  |
|  |  |  | Outputs low |  | 60 | 97 |  | 60 | 97 |  |  |
|  |  |  | Outputs disabled |  | 58 | 95 |  | 58 | 95 |  |  |

${ }^{\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.

## 'AS841 switching characteristics (see Note 1)

| PARAMETER | 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 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathbf{A}}=\text { MIN to MAX } \\ & \hline \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS841 |  | SN74AS841 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| tpLH | D | Q | 1 | 8.5 | 1 | 6.5 | ns |
| ${ }_{\text {t PHL }}$ |  |  | 1 | 10 | 1 | 9 |  |
| tPLH | C | Q | 2 | 13 | 2 | 12 | ns |
| tPHL |  |  | 2 | 13 | 2 | 12 |  |
| tpZH | $\overline{\mathrm{OC}}$ | Q | 2 | 13.5 | 2 | 10.5 | ns |
| tPZL |  |  | 2 | 15 | 2 | 13.5 |  |
| ${ }^{\text {tPHZ }}$ | $\overline{O C}$ | Q | 1 | 10 | 1 | 8 | ns |
| ${ }^{\text {tPLZ }}$ |  |  | 1 | 10 | 1 | 8 |  |

'AS842 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (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 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathbf{A}}=\text { MIN to MAX } \\ & \hline \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS842 |  | SN74AS842 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| tPLH | $\overline{\mathrm{D}}$ | 0 | 1 | 11 | 1 | 8.5 | ns |
| tpHL |  |  | 1 | 10 | 1 | 9 |  |
| tpLH | C | Q | 2 | 13 | 2 | 12 | ns |
| tPHL |  |  | 2 | 13 | 2 | 12 |  |
| tPZH | $\overline{O C}$ | Q | 2 | 14.5 | 2 | 12 | ns |
| tPZL |  |  | 2 | 15 | 2 | 12.5 |  |
| tPHZ | $\overline{\text { OC }}$ | Q | 1 | 10 | 1 | 8 | ns |
| tplz |  |  | 1 | 10 | 1 | 8 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN54ALS843, SN54AS843, SN54ALS844, SN54AS844 <br> SN74ALS843, SN74AS843, SN74ALS844, SN74AS844 <br> 9-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

D2910, DECEMBER 1983-REVISED DECEMBER 1985

- 3-State Buffer-Type Outputs Drive Bus-Lines Directly
- Bus-Structured Pinout
- Provide Extra Bus Driving Latches

Necessary for Wider Address/Data Paths or Buses with Parity

- Buffered Control Inputs to Reduce DC Loading
- Power-Up High Impedance
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 9-bit latches feature three-state outputs designed specifically for driving highly capacitive or relatively low-impedance loads. They are particularly suitable for implementing buffer registers, I/O ports, bidirectional bus drivers, and working registers.
The nine latches are transparent D-type. The 'ALS843 and 'AS843 have noninverting data (D) inputs. The 'ALS844 and 'AS844 have inverting $D$ inputs.

A buffered output control ( $\overline{\mathrm{OC}}$ ) input can be used to place the nine outputs in either a normal logic state (high or low levels) or a high-impedance state. In the high-impedance state, the outputs neither load nor drive the bus lines significantly. The high-impedance state and increased drive provide the capability to drive the bus lines in a bus-organized system without need for interface or pull-up components.

The output control ( $\overline{\mathrm{OC}}$ ) does not affect the internal operation of the flip-flops. Old data can be retained or new data can be entered while the outputs are off.

The -1 versions of the SN74ALS843 and SN74ALS844 parts are identical to the standard versions except that the recommended maximum $\mathrm{IOL}_{\mathrm{OL}}$ is increased to 48 milliamperes. There are no -1 versions of the SN54ALS843 and SN54ALS844.


SN54ALS843, SN54AS843. . . FK PACKAGE SN74ALS843, SN74AS843 . . . FN PACKAGE (TOP VIEW)


SN54ALS844, SN54AS844 . . . JT PACKAGE SN74ALS844, SN74AS844 . . . DW OR NT PACKAGE (TOP VIEW)

| $\overline{O C} \square^{1}$ | ${ }^{24} \square \mathrm{v}_{\mathrm{CC}}$ |
| :---: | :---: |
| $1 \overline{0}$ | 23 -10 |
| $2 \overline{\mathrm{D}} \mathrm{O}^{3}$ | $22-20$ |
| 3 $\bar{\square} \square^{4}$ | $21 \square 30$ |
| $4 \overline{\mathrm{D}} \mathrm{C}^{5}$ | $20 \bigcirc 40$ |
| 5 $\overline{\text { - }}$ | 19 - 50 |
| $6 \bar{\square} \square^{7}$ | 18 60 |
| $7 \overline{\text { D }}$ | 1770 |
| $8 \mathrm{D}-9$ | 16.80 |
| 9 $\square^{10}$ | 1590 |
| $\overline{\mathrm{CLR}} \mathrm{Cl}^{11}$ | $14 \bigcirc \overline{\text { PRE }}$ |
| GND ${ }_{12}$ | 13 C |

SN54ALS844, SN54AS844 . . . FK PACKAGE SN74ALS844, SN74AS844 .. . FN PACKAGE (TOP VIEW)



NC - No internal connection

The SN54ALS843, SN54AS843, SN54ALS844, and SN54AS844 are characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74ALS843, SN74AS843, SN74ALS844, and SN74AS844 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.
'ALS843, 'AS843 FUNCTION TABLE

| INPUTS |  |  |  |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { PRE }}$ | $\overline{\text { CLR }}$ | $\overline{\text { OC }}$ | C | D | Q |
| L | X | L | X | X | H |
| H | L | L | X | X | L |
| H | H | L | H | L | L |
| H | H | L | H | H | H |
| H | H | L | L | X | Q O $_{\text {O }}$ |
| X | X | H | X | X | Z |

'ALS843, 'AS843 logic symbol ${ }^{\dagger}$


[^33]'ALS843, 'AS843 logic diagram (positive logic)


## SN54ALS843, SN54AS843, SN54ALS844, SN54AS844 <br> SN74ALS843, SN74AS843, SN74ALS844, SN74AS844 9-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

ALS844, 'AS844 FUNCTION TABLE

| INPUTS |  |  |  |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { PRE }}$ | $\overline{\text { CLR }}$ | $\overline{\text { OC }}$ | C | $\overline{\mathbf{D}}$ | Q |
| L | X | L | X | X | $H$ |
| $H$ | L | L | $X$ | $X$ | $L$ |
| $H$ | $H$ | $L$ | $H$ | $L$ | $H$ |
| $H$ | $H$ | $L$ | $H$ | $H$ | $L$ |
| $H$ | $H$ | $L$ | $L$ | $X$ | $Q_{O}$ |
| $X$ | $X$ | $H$ | $X$ | $X$ | $Z$ |

'ALS844, 'AS844 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 DW, JT, and NT packages.
'ALS844, 'AS844 logic diagram (positive logic)

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

[^34]SN54ALS843, SN54ALS844
SN74ALS843, SN74ALS844
9-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-StATE OUTPUTS
recommended operating conditions

the 48-mA limit applies for SN74ALS843-1 and SN74ALS844-1 only and only if $\mathrm{V}_{\mathrm{CC}}$ is maintained between 4.75 V and 5.25 V .
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)


[^35]
## 'ALS843 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathbf{C C}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \Omega, \\ & \mathbf{R 2}=500 \Omega, \\ & \mathrm{~T}_{\mathbf{A}}=25^{\circ} \mathrm{C} \\ & \hline \text { ALS843 } \end{aligned}$ |  |  | $\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 \Omega \\ & \mathrm{~T}_{\mathrm{A}}=\mathrm{MIN} \text { to } \mathrm{MAX} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | SN54ALS843 |  | SN74ALS843 |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tPLH | D | Q |  | 7 | 11 | 2 | 15 | 2 | 13 | ns |
| tPHL |  |  |  | 11 | 15 | 4 | 20 | 4 | 18 |  |
| ${ }_{\text {tPLH }}$ | C | Q |  | 12 | 18 | 5 | 25 | 5 | 21 | ns |
| tPHL |  |  |  | 16 | 23 | 8 | 30 | 8 | 26 |  |
| tPLH | $\overline{\text { PRE }}$ | Q |  | 13 | 19 | 5 | 25 | 5 | 22 | ns |
| tPHL |  |  |  | 19 | 26 | 4 | 35 | 6 | 30 |  |
| tPLH | $\overline{C L R}$ | 0 |  | 19 | 26 | 4 | 35 | 6 | 30 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  | 14 | 21 | 6 | 27 | 6 | 23 |  |
| tPZH | $\overline{O C}$ | Q |  | 7 | 10 | 2 | 14 | 2 | 12 | ns |
| tPZL |  |  |  | 9 | 12 | 4 | 16 | 4 | 14 |  |
| ${ }_{\text {tPHZ }}$ | $\overline{O C}$ | Q |  | 6 | 9 | 2 | 12 | 2 | 10 | ns |
| tPLZ |  |  |  | 7 | 10 | 2 | 14 | 2 | 12 |  |

'ALS844 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \Omega, \\ & \mathrm{R} 2=500 \Omega \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \text { 'ALS844 }^{\prime} \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=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}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | SN54ALS844 |  | SN74ALS844 |  |  |
|  |  |  | MIN | TYP | MAX | MiN | MAX | MIN | MAX |  |
| ${ }^{\text {tPLH }}$ | $\overline{\mathrm{D}}$ | Q |  | 11 | 16 | 4 | 22 | 4 | 20 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  | 9 | 13 | 3 | 17 | 3 | 15 |  |
| tPLH | C | Q |  | 17 | 24 | 8 | 32 | 8 | 29 | ns |
| tPHL |  |  |  | 14 | 19 | 6 | 26 | 6 | 22 |  |
| tPLH | $\overline{\text { PRE }}$ | Q |  | 13 | 19 | 5 | 25 | 5 | 22 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  | 19 | 26 | 4 | 35 | 6 | 30 |  |
| tPLH | $\overline{C L R}$ | Q |  | 19 | 26 | 4 | 35 | 6 | 30 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  | 16 | 23 | 8 | 29 | 8 | 25 |  |
| tPZH | $\overline{\mathrm{OC}}$ | Q |  | 10 | 15 | 2 | 19 | 4 | 17 | ns |
| tPZL |  |  |  | 12 | 18 | 3 | 22 | 5 | 20 |  |
| ${ }_{\text {tPHZ }}$ | $\overline{\mathrm{OC}}$ | Q |  | 7 | 10 | 1 | 12 | 1 | 11 | ns |
| tPLZ |  |  |  | 5 | 9 | 1 | 14 | 1 | 12 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN54AS843, SN54AS844 <br> SN74AS843, SN74AS844 <br> 9-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

recommended operating conditions

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

| PARAMETER |  | TEST CONDITIONS |  | SN54AS843 <br> SN54AS844 |  |  | SN74AS843 <br> SN74AS844 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1{ }^{\prime}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | v |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{IOH}=-15 \mathrm{~mA}$ | 2.43 .2 |  |  | 2.43 .2 |  |  |  |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-24 \mathrm{~mA}$ | 2 |  |  | 2 |  |  |  |
| $\mathrm{V}_{\text {OL }}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=32 \mathrm{~mA}$ |  | 0.25 | 0.5 |  |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{OL}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| IOZH |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
| Iozl |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -50 |  |  | -50 | $\mu \mathrm{A}$ |
| 1 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| ${ }_{1} \mathrm{H}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IIL |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{I}}=0.4 \mathrm{~V}$ |  |  | -0.5 |  |  | -0.5 | mA |
| $10^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ICC | 'AS843 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | Outputs high |  | 37 | 62 |  | 37 | 62 | mA |
|  |  |  | Outputs low |  | 56 | 92 |  | 56 | 92 | mA |
|  |  |  | Outputs disabled |  | 56 | 92 |  | 56 | 92 |  |
|  | 'AS844 |  | Outputs high |  | 39 | 64 |  | 39 | 64. |  |
|  |  |  | Outputs low |  | 58 | 95 |  | 58 | 95 |  |
|  |  |  | Outputs disabled |  | 58 | 95 |  | 58 | 95 |  |

[^36]'AS843 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=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}_{\mathbf{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS843 |  | SN74AS843 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| tPLH | D | Q | 1 | 8.5 | 1 | 6.5 | ns |
| tPHL |  |  | 1 | 10 | 1 | 9 |  |
| tPLH | C | 0 | 2 | 13 | 2 | 12 | ns |
| tPHL |  |  | 2 | 13 | 2 | 12 |  |
| ${ }^{\text {tPLH }}$ | $\overline{\text { PRE }}$ | Q | 2 | 12 | 2 | 10 | ns |
| tPHL | $\overline{C L R}$ | Q | 2 | 14 | 2 | 13 | ns |
| ${ }^{\text {tPZH }}$ | $\overline{O C}$ | Q | 2 | 13.5 | 2 | 10.5 | ns |
| tPZL |  |  | 2 | 15 | 2 | 13.5 |  |
| tPHZ | $\overline{O C}$ | Q | 1 | 10 | 1 | 8 | ns |
| tpLZ |  |  | 1 | 10 | 1 | 8 |  |

'AS844 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=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}}=\mathrm{MIN} \text { to } \mathrm{MAX} \\ & \hline \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS844 |  | SN74AS844 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| tPLH | D | 0 | 1 | 11 | 1 | 8.5 | ns |
| tPHL |  |  | 1 | 11 | 1 | 10 |  |
| tPLH | C | 0 | 2 | 14 | 2 | 12.5 | ns |
| tPHL |  |  | 2 | 14 | 2 | 13 |  |
| tPLH | $\overline{\text { PRE }}$ | Q | 2 | 12 | 2 | 10 | ns |
| tPHL | $\overline{\mathrm{CLR}}$ | 0 | 2 | 14.5 | 2 | 13.5 | ns |
| tPZH | $\overline{O C}$ | Q | 2 | 14.5 | 2 | 12 | ns |
| tPZL |  |  | 2 | 15 | 2 | 13.5 |  |
| tPHZ | $\overline{\mathrm{OC}}$ | 0 | 1 | 10 | 1 | 8 | ns |
| tplz |  |  | 1 | 10 | 1 | 8 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN54ALS843, SN54AS843, SN54ALS844, SN54AS844 <br> SN74ALS843, SN74AS843, SN74ALS844, SN74AS844 9-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

## D latch signal conventions

It is normal TI practice to name the outputs and other inputs of a D-type latch and to draw its logic symbol based on the assumption of true data (D) inputs. Then outputs that produce data in phase with the data inputs are called Q and those producing complementary data are called $\overline{\mathrm{Q}}$. An input that causes a Q output to go high or a $\overline{\mathrm{Q}}$ output to go low is called Preset; an input that causes a $\overline{\mathrm{Q}}$ output to go high or a Q output to go low is called Clear. Bars are used over these pin names ( $\overline{\operatorname{PRE}}$ and $\overline{C L R}$ ) if they are active low. The devices on this data sheet are second-source designs and the pin-name conventions used by the original manufacturer have been retained. That makes it necessary to designate the data inputs and outputs of the inverting circuit $\overline{\mathrm{D}}$ and Q .
In some applications it may be advantageous to redesignate the inputs and outputs $\overline{\mathrm{D}}$ and $\overline{\mathrm{Q}}$ for the noninverting circuits or D and $\overline{\mathrm{Q}}$ for the inverting circuits. In that case signal names should change as shown below. Also shown are corresponding changes in the logic symbols.

Notice that Q becoming $\overline{\mathrm{Q}}$ causes $\overline{\mathrm{PRE}}$ and $\overline{\mathrm{CLR}}$ to exchange their names and their S and R function labels. The presence or absense of polarity indicators ( $\Delta$ ) changes at the data inputs and outputs, but not at $\overline{\mathrm{PRE}}, \overline{\mathrm{CLR}}$, and $\overline{\mathrm{OC}}$ since these inputs are still active-low.
'ALS843, 'AS843

'ALS844, 'AS844


## SN54ALS845, SN54AS845, SN54ALS846, SN54AS846 <br> SN74ALS845, SN74AS845, SN74ALS846, SN74AS846 8-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

- 3-State Buffer-Type Outputs Drive Bus-Lines Directly
- Bus-Structured Pinout
- Provides Extra Bus Driving Latches Necessary for Wider Address/Data Paths or Buses with Parity
- Buffered Control Inputs to Reduce DC Loading
- Power-Up High-Impedance State
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 8-bit latches feature three-state outputs designed specifically for driving highly capacitive or relatively low-impedance loads. They are particularly suitable for implementing buffer registers, I/O ports, bidirectional bus drivers, and working registers.
The eight latches are transparent D-type. The 'ALS845 and 'AS845 have noninverting data (D) inputs. The 'ALS846 and 'AS846 have inverting $\bar{D}$ inputs. Since $\overline{C L R}$ and $\overline{\text { PRE }}$ are independent of the clock, taking the $\overline{C L R}$ input low will cause the eight Q outputs to go low. Taking the $\overline{\mathrm{PRE}}$ input low will cause the eight Q outputs to go high. When both $\overline{\operatorname{PRE}}$ and $\overline{\mathrm{CLR}}$ are taken low, the outputs will follow the preset condition.

The buffered output control inputs ( $\overline{\mathrm{OC}} 1, \overline{\mathrm{OC}} 2$, and $\overline{\mathrm{OC}} 3$ ) can be used to place the eight outputs in either a normal logic state (high or low levels) or a high-impedance state. In the highimpedance state, the outputs neither load nor drive the bus lines significantly. The highimpedance state and increased drive provide the capability to drive the bus lines in a busorganized system without need for interface or pull-up components. The output controls do not affect the internal operation of the latches. Old data can be retained or new data can be entered while the outputs are in the high-impedance state.

SN54ALS845, SN54AS845 . . . JT PACKAGE SN74ALS845, SN74AS845 . . . DW OR NT PACKAGE (TOP VIEW)
$\overline{O C} 1$
$\overline{O C} 2$

SN54ALS845, SN54AS845 . . . FK PACKAGE
SN74ALS845, SN74AS845 . . . FN PACK AGE
(TOP VIEW)


SN54ALS846, SN54AS846 . . . JT PACKAGE SN74ALS846, SN74AS846 . . . DW OR NT PACKAGE (TOP VIEW)

| О $\overline{\mathrm{OC}} 1$ | $\mathrm{V}_{24} \mathrm{~V} \mathrm{CC}$ |
| :---: | :---: |
| - 2 | 23 OC3 |
| $1 \overline{\mathrm{D}} \mathrm{C}^{2}$ | 22.10 |
| $2 \overline{\mathrm{D}} \mathrm{C}_{4}$ | $21 \square 20$ |
| $3 \overline{\mathrm{D}} \mathrm{C}_{5}$ | 20.30 |
| $4 \overline{\mathrm{D}} \mathrm{C}^{6}$ | 19 - 40 |
| 5可 $\square^{7}$ | 18 10 |
| $6 \overline{\mathrm{D}} \mathrm{C}^{8}$ | 17 60 |
| $7 \overline{\text { D }}$ | $16 \bigcirc 70$ |
| 8 $\overline{\mathrm{D}} \mathrm{H}^{10}$ | 1580 |
| CLR ${ }^{11}$ | $14 \bigcirc \overline{\text { PRE }}$ |
| GND 12 | $13 \bigcirc \mathrm{C}$ |

SN54ALS846, SN54AS846 . . . FK PACKAGE SN74ALS846, SN74AS846 . . . FN PACKAGE
(TOP VIEW)



NC - No internal connection

## SN54ALS845, SN54AS845, SN54ALS846, SN54AS846 <br> SN74ALS845, SN74AS845, SN74ALS846, SN74AS846 8-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

The -1 versions of the SN74ALS845 and SN74ALS846 parts are identical to the standard versions except that the recommended maximum IOL is increased to 48 milliamperes. There are no -1 versions of the SN54ALS845 and SN54ALS846.

The SN54ALS845, SN54AS845, SN54ALS846, and SN54AS846 are characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74ALS845, SN74AS845, SN74ALS846, and SN74AS846 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

FUNCTION TABLES
'ALS845, 'AS845

| INPUTS |  |  |  |  |  |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { PRE }}$ | $\overline{\text { CLR }}$ | $\overline{\text { OC1 }}$ | $\overline{\text { OC2 }}$ | $\overline{\text { OC3 }}$ | C | D | Q |
| L | H | L | L | L | X | X | H |
| H | L | L | L | L | X | X | L |
| L | L | L | L | L | X | X | H |
| H | H | L | L | L | H | L | L |
| H | H | L | L | L | H | H | H |
| H | H | L | L | L | L | X | $Q_{O}$ |
| X | X | X | X | H | X | X | Z |
| X | X | X | H | X | X | X | Z |
| X | X | H | X | X | X | X | Z |

'ALS846, 'AS846

| INPUTS |  |  |  |  |  |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { PRE }}$ | $\overline{\text { CLR }}$ | $\overline{\text { OC }}$ 1 | $\overline{\text { OC2 }}$ | $\overline{\text { OC3 }}$ | C | $\overline{\text { D }}$ | Q |
| L | H | L | L | L | X | X | H |
| H | L | L | L | L | X | X | L |
| L | L | L | L | L | X | X | H |
| H | H | L | L | L | H | L | H |
| H | H | L | L | L | H | H | L |
| H | H | L | L | L | L | X | $Q_{O}$ |
| X | X | X | X | H | X | X | Z |
| X | X | X | H | X | X | X | Z |
| X | X | H | X | X | X | X | Z |

logic symbols ${ }^{\dagger}$
'ALS845, 'AS845

${ }^{\dagger}$ These symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers shown are for DW, JT, and NT packages.
'ALS846, 'AS846


## SN54ALS845, SN54AS845, SN54ALS846, SN54AS846 <br> SN74ALS845, SN74AS845, SN74ALS846, SN74AS846 8-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

logic diagrams (positive logic)
'ALS845, 'AS845

'ALS846, 'AS846


Pin numbers shown are for DW, JT, and NT packages.
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
$\qquad$
Supply voltage, $\mathrm{V}_{\mathrm{CC}}$
Input voltage
Voltage applied to a disabled 3 -state output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 5
Operating free-air temperature range:
SN54ALS845, SN54AS845, SN54ALS846, SN54AS846
$-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
SN74ALS845, SN74AS845, SN74ALS846, SN74AS846 . . . . . . . . . . . . . . . . . $-0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range
$-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

## SN54ALS845, SN74ALS845

8-BIT BUS INTERFACE D-TYPE LATCHES WITH 3.STATE OUTPUTS

## recommended operating conditions


${ }^{\dagger}$ The extended limit applies only if $\mathrm{V}_{\mathrm{CC}}$ is maintained between 4.75 V and 5.25 V . The 48 mA limit applies for SN74ALS845-1 only.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)


[^37]switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{R} 1=500 \Omega \\ & \mathrm{R} 2=500 \Omega \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \text { 'ALS845 } \end{aligned}$ |  |  | $\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 \Omega, \\ & \mathrm{~T}_{\mathbf{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | SN54ALS845 |  | SN74ALS845 |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tPLH | D | Q |  | 7 | 11 | 2 | 15 | 2 | 13 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  | 11 | 15 | 4 | 20 | 4 | 18 |  |
| ${ }^{\text {tPLH }}$ | C | Q |  | 12 | 18 | 5 | 25 | 5 | 21 | ns |
| tPHL |  |  |  | 16 | 23 | 8 | 30 | 8 | 26 |  |
| ${ }^{\text {tPLH }}$ | $\overline{\text { PRE }}$ | Q |  | 13 | 19 | 5 | 25 | 6 | 22 | ns |
| tPHL |  |  |  | 19 | 26 | 4 | 35 | 6 | 30 | ns |
| tPLH | $\overline{C L R}$ | Q |  | 19 | 26 | 4 | 35 | 6 | 30 | ns |
| ${ }^{\text {t PHL }}$ |  |  |  | 16 | 22 | 6 | 28 | 6 | 24 | ns |
| ${ }_{\text {t }}$ | $\overline{O C}$ | Q |  | 9 | 14 | 2 | 18 | 3 | 16 | ns |
| tPZL |  |  |  | 12 | 17 | 4. | 20 | 5 | 18 |  |
| ${ }^{\text {tPHZ }}$ | $\overline{\mathrm{OC}}$ | Q |  | 4 | 9 | 1 | 12 | 1 | 11 | ns |
| tplZ |  |  |  | 6 | 11 | 2 | 14 | 2 | 12 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN54ALS846, SN74ALS846

PRODUCT
PREVIEW

## recommended operating conditions

|  |  |  |  | 54ALS |  |  | 74ALS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX | UNIT |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voitage |  |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  |  |  | -1 |  |  | -2.6 | mA |
| ${ }^{1} \mathrm{OL}$ | Low-level output current |  |  |  | 12 |  |  | 24 | mA . |
|  | Low-level output current |  |  |  |  |  |  | $48^{\dagger}$ |  |
|  | duration | $\overline{C L R}$ or $\overline{\text { PRE }}$ low |  |  |  |  |  |  |  |
| $t_{w}$ | n | C high |  |  |  |  |  |  | ns |
| $\mathrm{t}_{\text {su }}$ | Setup time, data before enable C $\downarrow$ |  |  |  |  |  |  |  | ns |
| $t_{\text {h }}$ | Hold time, data after enable $\mathrm{C} \downarrow$ |  |  |  |  |  |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

${ }^{\dagger}$ The extended limit applies only if $V_{C C}$ is maintained between 4.75 V and 5.25 V . The 48 mA limit applies for SN74ALS846-1 only.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER | TEST CONDITIONS |  | SN54ALS846 |  |  | SN74ALS846 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \quad \mathrm{I}=-18 \mathrm{~mA}$ |  |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{l}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |  | $\mathrm{v}_{\mathrm{CC}}{ }^{-2}$ |  |  | $\mathrm{v}_{\mathrm{CC}-2}$ |  |  | $v$ |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |  | 2.43 .3 |  |  |  |  |  |  |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}^{\text {OH }}=-2.6 \mathrm{~mA}$ |  |  |  |  | 2.4 | 3,2 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, $\mathrm{I}_{\mathrm{OL}}=12 \mathrm{~mA}$ <br> $\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, $\mathrm{I}_{\mathrm{OL}}=24 \mathrm{~mA}$ <br> $\left(\mathrm{I}_{\mathrm{OL}}=48 \mathrm{~mA}\right.$ for -1 versions $)$ |  |  | 0.25 | 0.4 |  |  |  | V |
|  |  |  |  |  |  |  | 0.35 | 0.5 |  |
| IOZH | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 |  |
| IOZL | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -20 |  |  | -20 |  |
| 1 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| IIH | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IL | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.1 |  |  | -0.1 | mA |
| $10^{\S}$ | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=2.25 \mathrm{~V}$ | -30 |  |  | -30 |  |  | mA |
| ${ }^{\prime} \mathrm{CC}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | Outputs high |  |  |  |  |  |  | mA |
|  |  | Outputs low |  |  |  |  |  |  |  |
|  |  | Outputs disabled |  |  |  |  |  |  |  |

${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\S$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los.
Additional information on these products can be obtained from the factory as it becomes available.
switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ \mathrm{R} 1=500 \Omega, \\ \mathrm{R}^{2}=500 \Omega, \\ \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ \hline \text { ALS846 } \end{gathered}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=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}}=\mathrm{MIN} \text { to } \mathrm{MAX} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tPLH | D | Q |  |  |  |  |  |  |  | ns |
| tPHL |  |  |  |  |  |  |  |  |  |  |
| tPLH | C | Q |  |  |  |  |  |  |  | ns |
| tPHL |  |  |  |  |  |  |  |  |  |  |
| tPLH | $\overline{\text { PRE }}$ | Q |  |  |  |  |  |  |  | ns |
| tPHL |  |  |  |  |  |  |  |  |  | ns |
| tPLH | $\overline{C L R}$ | Q |  |  |  |  |  |  |  | ns |
| tPHL |  |  |  |  |  |  |  |  |  | ns |
| tPZH | $\overline{O C}$ | 0 |  |  |  |  |  |  |  | ns |
| tPZL |  |  |  |  |  |  |  |  |  |  |
| tPHZ | $\overline{O C}$ | Q | * |  |  |  |  |  |  | ns |
| tPLZ |  |  |  |  |  |  |  |  |  |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

Additional information on these products can be obtained from the factory as it becomes available.

SN54AS845, SN54AS846
SN74AS845, SN74AS846

## 8-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS

## recommended operating conditions

|  |  |  |  | 54AS8 <br> 54AS8 |  |  | $\begin{aligned} & \text { 174AS8 } \\ & \text { I74S8 } \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| I OH | High-level output current |  |  |  | -24 |  |  | -24 | mA |
| IOL | Low-level output current |  |  |  | 32 |  |  | 48 | mA |
|  | Pulse duration | $\overline{\mathrm{CLR}}$ or $\overline{\mathrm{PRE}}$ low | 5 |  |  | 4 |  |  |  |
| ${ }_{w}$ | se | C high | 5 |  |  | 4 |  |  | ns |
| $\mathrm{t}_{\mathrm{su}}$ | Setup time, data before enable C $\downarrow$ |  | 3.5 |  |  | 2.5 |  |  | ns |
| $t_{h}$ | Hold time, data after enable $\mathrm{C} \downarrow$ |  | 3.5 |  |  | 2.5 |  |  | ns |
|  | Recovery time | $\overline{\text { PRE }}$ | 17 |  |  | 15 |  |  |  |
| $t_{r}$ | Recovery time | $\overline{\text { CLR }}$ | 16 |  |  | 14 |  |  | ns |
| TA | Operating free-air temperature |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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.

SN54AS845, SN54AS846
SN74AS845, SN74AS846 8-BIT BUS INTERFACE D-TYPE LATCHES WITH 3-STATE OUTPUTS
'AS845 switching characteristics (see Note 1)

| PARAMETER | 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 \Omega \\ & \mathrm{R} 2=500 \Omega \\ & \mathrm{~T}_{\mathbf{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS845 |  | SN74AS845 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| tPLH | D | Q | 1 | 8.5 | 1 | 6.5 | ns |
| tPHL |  |  | 1 | 10 | 1 | 9 |  |
| tPLH | C | Q | 2 | 13 | 2 | 12 | ns |
| tPHL |  |  | 2 | 13 | 2 | 12 |  |
| tPLH | $\overline{\text { PRE }}$ | Q | 2 | 12 | 2 | 10 | ns |
| tPHL | $\overline{\text { CLR }}$ | Q | 2 | 14 | 2 | 13 | ns |
| tPHL | $\overline{O C}$ | Q | 2 | 13.5 | 2 | 10.5 | ns |
| tPZL |  |  | 2 | 15 | 2 | 13.5 |  |
| ${ }^{\text {tPHZ }}$ | $\overline{O C}$ | Q | 1 | 10 | 1 | 8 | ns |
| tPLZ |  |  | 1 | 10 | 1 | 8 |  |

'AS846 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=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}_{\mathbf{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS846 |  | SN74AS846 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {PPLH }}$ | D | Q | 1 | 11 | 1 | 8.5 | ns |
| tPHL |  |  | 1 | 11 | 1 | 10 |  |
| tPLH | C | Q | 2 | 14 | 2 | 12.5 | ns |
| ${ }^{\text {tPHL }}$ |  |  | 2 | 14 | 2 | 13 |  |
| tPLH | $\overline{\text { PRE }}$ | Q | 2 | 12 | 2 | 10 | ns |
| tPHL | $\overline{C L R}$ | Q | 2 | 14.5 | 2 | 13.5 | ns |
| ${ }^{\text {tPHL}}$ | $\overline{O C}$ | Q | 2 | 14.5 | 2 | 12 | ns |
| tPZL |  |  | 2 | 15 | 2 | 13.5 |  |
| tPHZ | $\overline{O C}$ | Q | 1 | 10 | 1 | 8 | ns |
| tPLZ |  |  | 1 | 10 | 1 | 8 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## D latch signal conventions

It is normal TI practice to name the outputs and other inputs of a D-type latch and to draw its logic symbol based on the assumption of true data (D) inputs. Then outputs that produce data in phase with the data inputs are called Q and those producing complementary data are called $\overline{\mathrm{Q}}$. An input that causes a Q output to go high or a $\overline{\mathrm{Q}}$ output to go low is called Preset; and input that causes a $\overline{\mathrm{Q}}$ output to go high or a Q output to go low is called Clear. Bars are used over these pin names ( $\overline{P R E}$ and $\overline{C L R}$ ) if they are active low. The devices on this data sheet are second-source designs and the pin-name conventions used by the original manufacturer have been retained. That makes it necessary to designate the data inputs and outputs of the inverting circuit $\overline{\mathrm{D}}$ and Q .

In some applications it may be advantageous to redesignate the inputs and outputs $\overline{\mathrm{D}}$ and $\overline{\mathrm{Q}}$ for the noninverting circuits or $\bar{D}$ and $\bar{Q}$ for the inverting circuits. In that case signal names should change as shown below. Also shown are corresponding changes in the logic symbols.
Notice that Q becoming $\overline{\mathrm{Q}}$ causes $\overline{\mathrm{PRE}}$ and $\overline{\mathrm{CLR}}$ to exchange their names and their S and R function labels. The presence or absence of polarity indicators $(\Delta)$ changes at the data inputs and outputs, but not at $\overline{\mathrm{CLR}} / \overline{\mathrm{PRE}}, \overline{\mathrm{OC}} 1, \overline{\mathrm{OC}} 2$, and $\overline{\mathrm{OC}} 3$ since these inputs are still active-low.
'ALS845, 'AS845

'ALS846, 'AS846


## SN74AS850, SN74AS851 1 OF 16 DATA SELECTORS/MULTIPLEXERS WITH 3-STATE OUTPUTS

- 4-Line to 1-Line Data Selectors/Multiplexers That Can Select 1 of 16 Data Inputs. Typical Applications:

Boolean Function Generators
Parallel-to-Serial Converters
Data Source Selectors

- Cascadable to $n$-Bits
- 3-State Bus Driver Outputs
- 'AS850 Offers Clocked Selects; 'AS851 Offers Enable-Controlled Selects
- Has a Master Output Control ( $\overline{\mathrm{G}}$ ) for Cascading and Individual Output Controls ( $\overline{\mathrm{GY}}, \mathrm{GW}$ ) for Each Output
- Package Options Include both Plastic and Ceramic Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These four-line to one-line data selectors/multiplexers provide full binary decoding to select one-of-sixteen data sources with complementary Y and W outputs. The 'AS850 has a clock-controlled select register allowing for a symmetrical presentation of the select inputs to the decoder while the 'AS851 has an enable-controlled select register allowing the user to select and hold one particular data line.

A buffered group of output controls ( $\overline{\mathrm{G}}, \overline{\mathrm{GY}}, \mathrm{GW}$ ) can be used to place the two-outputs in either a normal logic (high or low logic level) or a highimpedance state. In the high-impedance state the outputs neither load nor drive the bus lines significantly. The high-impedance third state and increased drive provide the capability to drive the bus lines in a bus-organized system without the need for interface or pull-up components.


SN74AS850, SN74AS851 . . . FN PACKAGE (TOP VIEW)

*CLK for 'AS850 or $\overline{\mathrm{SC}}$ for 'AS851

The output controls do not affect the internal operations of the data selector/multiplexer. New data can be setup while the outputs are in the high-impedance state.

The SN74AS850 and SN74AS851 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

1 OF 16 DATA SELECTORS/MULTIPLEXERS
WITH 3-STATE OUTPUTS

INPUT SELECTION TABLE

| SELECT |  |  |  | INPUTS | AS850 | AS851 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT |  |  |  |  |  |  |
|  | S2 | S1 | S0 | CLK | $\overline{\text { SC }}$ | SELECTED |
| L | L | L | L | $\uparrow$ | L | D0 |
| L | L | L | H | $\uparrow$ | L | D1 |
| L | L | H | L | $\uparrow$ | L | D2 |
| L | L | H | H | $\uparrow$ | L | D3 |
| L | H | L | L | $\uparrow$ | L | D4 |
| L | H | L | H | $\uparrow$ | L | D5 |
| L | H | H | L | $\uparrow$ | L | D6 |
| L | H | H | H | $\uparrow$ | L | D7 |
| H | L | L | L | $\uparrow$ | L | D8 |
| H | L | L | H | $\uparrow$ | L | D9 |
| H | L | H | L | $\uparrow$ | L | D10 |
| H | L | H | H | $\uparrow$ | L | D11 |
| H | H | L | L | $\uparrow$ | L | D12 |
| H | H | L | H | $\uparrow$ | L | D13 |
| H | H | H | L | $\uparrow$ | L | D14 |
| H | H | H | H | $\uparrow$ | L | D15 |
| X | X | X | X | H or L | H | Dn |

Dn $=$ the input selected before the most-recent low-to-high transition of CLK or $\overline{\mathrm{SC}}$.
logic symbols ${ }^{\dagger}$

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

OUTPUT FUNCTION TABLE

| $\overline{\mathbf{G}}$ | $\overline{G Y}$ | GW | OUTPUTS |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | Y | W |
| H | X | X | Z | Z |
| L | H | L | Z | Z |
| L | L | L | D | Z |
| L | H | H | Z | $\overline{\mathrm{D}}$ |
| L | L | H | D | $\overline{\mathrm{D}}$ |

$D=$ level of selected input DO-D15
'AS850 logic diagrams (positive logic) (see inset for 'AS851)


## SN74AS850, SN74AS851 <br> 1 OF 16 DATA SELECTORS/MULTIPLEXERS <br> WITH 3-STATE OUTPUTS

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, VCC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Input voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Operating free-air temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $\mathrm{O}^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

SN74AS850 recommended operating conditions


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

| PARAMETER |  | TEST CONDITIONS |  | MIN | TYP ${ }^{\dagger}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IK }}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\prime}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V , | $\mathrm{OH}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}{ }^{-}$ |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, . | $\mathrm{I}_{\mathrm{OH}}=-15 \mathrm{~mA}$ | 2 | 3.3 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=48 \mathrm{~mA}$ |  | 0.35 | 0.5 | V |
| ${ }^{1} \mathrm{OZH}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
| ${ }^{\text {I OZL }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  | -50 | $\mu \mathrm{A}$ |
| 1 |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 | mA |
| $1 / \mathrm{H}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| IIL | D, $\overline{\mathrm{G}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $V_{1}=0.4 \mathrm{~V}$ |  |  | -1 | mA |
|  | All others |  |  |  |  | -0.5 |  |
| $10^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | $-30$ |  | - 112 | mA |
| ${ }^{1} \mathrm{CC}$ |  | $V_{C C}=5.5 \mathrm{~V}$ | Outputs active |  | 50 | 81 | mA |
|  |  | Outputs disabled |  | 52 | 85 |  |

$\dagger^{\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 current, IOS.

SN74AS850 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (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 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |
| $f_{\text {max }}$ |  |  | 60 |  | MHz |
| tpLH | Any D | Y | 3 | 10.5 | ns |
| tPHL |  |  | 3 | 11 |  |
| tPLH | Any D | W | 3 | 8 | ns |
| tPHL |  |  | 1 | 6 |  |
| tPLH | CLK | Y | 3 | 14.5 | ns |
| tPHL |  |  | 3 | 17.5 |  |
| tPLH | CLK | W | 3 | 15 | ns |
| tPHL |  |  | 3.5 | 13 |  |
| tPZH | $\overline{\mathrm{G}}$ | Y | 2 | 8 | ns |
| tPZL |  |  | 3 | 11 |  |
| tphz | $\overline{\mathrm{G}}$ | Y | 1 | 6 | ns |
| tplz |  |  | 2 | 8 |  |
| tPZH | $\overline{\mathrm{G}}$ | W | 2 | 8 | ns |
| tPZL |  |  | 3 | 21 |  |
| tPHZ | $\overline{\mathrm{G}}$ | W | 1 | 6 | ns |
| tpLZ |  |  | 2 | 8 |  |
| tPZH | $\overline{\mathrm{GY}}$ | Y | 2 | 8 | ns |
| tPZL |  |  | 3 | 11 |  |
| tPHZ | $\overline{\mathrm{GY}}$ | Y | 1 | 6 | ns |
| tPLZ |  |  | 2 | 8 |  |
| tPZH | GW | W | 2 | 10 | ns |
| tpZL |  |  | 3 | 25 |  |
| tPHZ | GW | W | 1 | 6 | ns |
| tPLZ |  |  | 2 | 11 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN74AS851

1 OF 16 DATA SELECTORS/MULTIPLEXERS
WITH 3-STATE OUTPUTS

SN74AS851 recommended operating conditions

|  |  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\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 |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | High-level output current |  |  | -15 | mA |
| ${ }^{\text {OL }}$ | Low-level output current |  |  | 48 | mA |
| $t_{w}$ | Pulse duration, $\overline{\mathrm{SC}}$ low | 10 |  |  | ns |
| $\mathrm{t}_{\text {su }}$ | Setup time, select inputs before $\overline{\mathrm{SC}} \uparrow$ | 4.5 |  |  | ns |
|  | Hold time, select inputs after $\overline{\mathrm{SC}} \uparrow$ | 0 |  |  | ns |
| $\mathrm{T}_{\mathrm{A}}$ | Operating free-air temperature | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

| PARAMETER | TEST CONDITIONS |  | MIN TYP ${ }^{\text { }}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IK }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $I_{1}=-18 \mathrm{~mA}$ |  | -1.2 | C |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V , | $\mathrm{I}^{\mathrm{OH}}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  | V |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$. | $1 \mathrm{OH}=-15 \mathrm{~mA}$ | 23.3 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OL}}=48 \mathrm{~mA}$ | 0.35 | 0.5 | V |
| ${ }^{1} \mathrm{OZH}$ | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  | 50 | $\mu \mathrm{A}$ |
| ${ }^{\text {I OZL }}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  | -50 | $\mu \mathrm{A}$ |
| 11 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  | 0.1 | mA |
| 1 H | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  | 20 | $\mu \mathrm{A}$ |
| IIL $\mathrm{D}^{\text {, } \overline{\mathrm{G}}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $V_{1}=0.4 \mathrm{~V}$ | $\begin{array}{r} -1 \\ \hline-0.5 \end{array}$ |  | mA |
| IIL All others |  |  |  |  |  |
| $10^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 | -112 | mA |
| ${ }^{1} \mathrm{CC}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | Outputs active | 50 | 81 | mA |
|  |  | Outputs disabled | 52 | 85 |  |

[^38]SN74AS851

SN74AS851 switching characteristics (see Note 1)

| PARAMETER | 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 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN MAX |  |
| tPLH | Any D | Y | 3 10.5 | ns |
| tPHL |  |  | $3 \quad 11$ |  |
| tPLH | Any D | W | 3 8 8 | ns |
| tPHL |  |  | 1 6 |  |
| ${ }^{\text {tPLH }}$ | S0, S1, S2, S3 | Y | 3 18 | ns |
| tPHL |  |  | $3 \quad 19$ |  |
| ${ }^{\text {tPLH }}$ | S0, S1, S2, S3 | W | 3 16 | ns |
| tPHL |  |  | $3 \times 15$ |  |
| ${ }^{\text {t PLH }}$ | $\overline{\mathrm{SC}}$ | Y | 3 18 | ns |
| tPHL |  |  | $3 \quad 20$ |  |
| tPLH | $\overline{\mathrm{SC}}$ | W | $3 \times 16$ | ns |
| ${ }^{\text {tPHL }}$ |  |  | $3 \quad 15$ |  |
| ${ }^{\text {tPZH }}$ | $\overline{\mathrm{G}}$ | Y | 28 | ns |
| ${ }^{\text {t P Z }}$ |  |  | $3 \quad 11$ |  |
| ${ }^{\text {tPHZ }}$ | $\overline{\mathrm{G}}$ | Y | 1 6 | ns |
| ${ }_{\text {tPLZ }}$ |  |  | 2 8 |  |
| tPZH | $\overline{\mathrm{G}}$ | W | 28 | ns |
| tPZL |  |  | $3 \quad 21$ |  |
| ${ }^{\text {tPHZ }}$ | $\overline{\mathrm{G}}$ | W | 1 6 | ns |
| tplZ |  |  | 28 |  |
| ${ }^{\text {tPZH }}$ | $\overline{\mathrm{GY}}$ | Y | 28 | ns |
| ${ }_{\text {t PRL }}$ |  |  | $3 \ldots 11$ |  |
| ${ }^{\text {tPHZ }}$ | $\overline{\mathrm{GY}}$ | Y | 1 6 | ns |
| tPLL |  |  | 28 |  |
| ${ }_{\text {tPZ }}$ | GW | W | $2 \quad 10$ | ns |
| ${ }^{\text {t P Z }}$ |  |  | 3 L |  |
| ${ }^{\text {tPHZ }}$ | GW | W | 1 6 | ns |
| tplZ |  |  | 211 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN74AS850, SN74AS851 <br> 1 OF 16 DATA SELECTORS/MULTIPLEXERS <br> WITH 3-STATE OUTPUTS

## TYPICAL APPLICATION DATA

The 'AS850 or 'AS851 can be used as a 1-of-16 Boolean function generator. Figure 1 shows the 'AS850 in one example.


FIGURE 1. 1-of-16 BOOLEAN FUNCTION GENERATOR


FIGURE 2. 1-of-32 DATA SELECTOR/MULTIPLEXER

TYPICAL APPLICATION DATA


FIGURE 3. 1-of-64 DATA SELECTOR/MULTIPLEXER

## SN54AS852, SN74AS852 8-BIT UNIVERSAL TRANSCEIVER PORT CONTROLLERS

D2810, JUNE 1984-REVISED JANUARY 1986

- Included among the Package Options are Compact, 24-Pin, 300-mil-Wide DIPs and Both 28-Pin Plastic and Ceramic Chip Carriers
- Buffered 3-State Outputs Drive Bus Lines Directly
- Cascadable to n -Bits
- Eight Selectable Transceiver/Port Functions:
$A$ to $B$ or $B$ to $A$
Register to $A$ or $B$
Shifted to A from B or Shifted to B from A
Off-Line Shifts (A and B Ports Transceiving or in High-impedance State)
Register Clear
- Particularly Suitable for Use in Diagnostics Circuitry
- Serial Register Provides:
- Parallel Storage of Either A or B Input Data
- Serial Transmission of Data from Either A or B Port
- Dependable Texas Instruments Quality and Reliability


## description

The 'AS852 features two 8-bit I/O ports (A1-A8 and B1-B8), and 8-bit parallel-load, serial-in, parallel-out shift register, and control logic. With these features, this device is capable of performing eight selectable transceiver or port functions, depending on the state of the three select lines S0, S1, and S2. These functions include: transferring data from port A to port B or vice versa (i.e., the transceiver function), transferring data from the register to either port, serial shifting data to either port from the opposite port, performing off-line shifts (with A and B ports in high-impedance state), and clearing the register. The 'AS852 can simultaneously transfer data from $A$ to $B$ or $B$ to $A$ and perform an off-line serial shift of data in the register. Synchronous parallel loading of the internal register can be accomplished from either port on the positive transition of the clock while serially shifting data in via the SERIN input. The 'AS852 is ideally suited for applications implementing diagnostic circuitry to enhance system verification and/or fault analysis. All serial data is shifted right. All outputs are buffer-type outputs designed specifically to drive bus lines directly and all are 3-state except for Q8, which is a totem-pole output.

The SN54AS852 is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS852 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.
logic diagram (positive logic)


FOUR IDENTICAL CHANNELS NOT SHOWN INPUTS/OUTPUTS NOT SHOWN:
(6) A3 (19) B3
(7) A4 (18) B4
$\begin{array}{ll}\text { (8) } \mathrm{A5} & \text { (17) B5 }\end{array}$
$\begin{array}{ll}\text { (9) A6 } & \text { (16) B6 }\end{array}$


Pin numbers shown are for DW, JT, and NT packages.

## SN54AS852, SN74AS852 8-BIT UNIVERSAL TRANSCEIVER PORT CONTROLLERS

function table

| $\begin{gathered} \text { MODE } \\ \text { s2 S1 so } \end{gathered}$ | CLOCK | SERIN | A1 01 B1 | A2 02 B2 | A3 03 B3 | A4 04 B4 | A5 05 B5 | A6 06 B6 | A7 07 B7 | A8 08 B8 | PORT FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{lll} \mathrm{L} & \mathrm{~L} & \mathrm{~L} \\ \mathrm{~L} & \mathrm{~L} & \mathrm{~L} \end{array}$ | $\begin{gathered} \mathrm{H} \text { or } \mathrm{L} \\ \uparrow \end{gathered}$ | $x$ | $\begin{array}{lll} Z & a_{n} A 1 \\ Z & A 1 & A 1 \end{array}$ | $\begin{array}{ll} Z & Q_{n} A 2 \\ Z & A 2 \end{array}$ | $\begin{array}{lll} Z & a_{n} A 3 \\ A & A 3 & A 3 \end{array}$ | $\begin{array}{lll} Z & Q_{n} A 4 \\ Z & A 4 & A 4 \end{array}$ | $\begin{array}{ll} Z & Q_{n} A 5 \\ Z & A 5 \end{array}$ | $\begin{array}{lll} Z & Q_{n} A 6 \\ Z & A 6 & A 6 \end{array}$ | $\begin{array}{lll} Z & O_{n} A 7 \\ Z & A 7 & A 7 \end{array}$ | $\begin{array}{ll} z & Q_{n} A 8 \\ Z & A 8 \end{array}$ | A TO B |
|  | $\begin{gathered} \mathrm{H} \text { or } \mathrm{L} \\ \uparrow \end{gathered}$ | X | $\begin{array}{lll} B 1 & Q_{n} & Z \\ B 1 ~ B 1 ~ & Z \end{array}$ | $\begin{array}{lll} B 2 & Q_{n} & Z \\ B 2 & \text { B2 } & Z \end{array}$ | $\begin{aligned} & \text { B3 } Q_{n} Z \\ & \text { B3 } \mathrm{B} 3 \\ & Z \end{aligned}$ | $\begin{array}{lll} B 4 a_{n} & Z \\ \text { B4 } 44 & Z \end{array}$ | $\begin{array}{llll} \hline B 5 & Q_{n} & Z \\ B 5 & B 5 & Z \end{array}$ | $\begin{array}{lll} B 6 & a_{n} & Z \\ B 6 & \mathrm{~B} & \mathrm{Z} \end{array}$ | $\begin{array}{lll} B 7 & a_{n} & Z \\ B 7 & B 7 & Z \end{array}$ | $\begin{array}{lll} \hline \text { B8 } & O_{n} & Z \\ \text { B8 } & \text { B8 } & Z \end{array}$ | B TO A |
| $\begin{array}{lll} \hline L & H & L \\ L & H & L \end{array}$ | $\mathrm{H} \text { or } \mathrm{L}$ |  | $\begin{array}{lll} X & Q_{n} & Q 1 \\ Z & A 1 & A 1 \end{array}$ | $\begin{array}{lll} \mathrm{X} & \mathrm{O}_{\mathrm{n}} & \mathrm{Q} \\ \mathrm{Z} & \mathrm{~A} 2 & \mathrm{~A} 2 \end{array}$ | $\begin{array}{lll} X & Q_{n} & Q 3 \\ z & A 3 & A 3 \end{array}$ | $\begin{array}{lll} x & a_{n} & a_{4} \\ z & A 4 & A 4 \end{array}$ | $\begin{array}{lll} x & Q_{n} & Q 5 \\ z & A 5 & A 5 \end{array}$ | $\begin{array}{lll} \hline x & Q_{n} & Q 6 \\ z & A 6 & A 6 \end{array}$ | $\begin{array}{lll} X & Q_{n} & Q 7 \\ Z & A 7 & A 7 \end{array}$ | $\begin{array}{lll} \mathrm{X} & \mathrm{Q}_{n} \mathrm{Q8} \\ \mathrm{Z} & \mathrm{AB} & \mathrm{AB} \end{array}$ | $\mathrm{Q}_{\mathrm{N}}$ TO $\mathrm{B}_{\mathrm{N}}$ |
| $\begin{array}{lll} \mathrm{L} & \mathrm{H} & \mathrm{H} \\ \mathrm{~L} & \mathrm{H} & \mathrm{H} \end{array}$ | $\begin{gathered} \mathrm{H} \text { or } \mathrm{L} \\ \uparrow \end{gathered}$ |  | $\begin{aligned} & \mathrm{Q} 1 \mathrm{O}_{\mathrm{n}} \mathrm{X} \\ & \mathrm{~B} 1 \mathrm{~B} 1 \mathrm{Z} \end{aligned}$ | $\begin{aligned} & \hline \mathrm{O} 2 \mathrm{O}_{\mathrm{n}} \mathrm{X} \\ & \mathrm{~B} 2 \mathrm{~B} 2 \mathrm{Z} \end{aligned}$ | $\begin{array}{lll} \text { O3 } & a_{n} & X \\ \text { B3 } & \text { B } & z \end{array}$ | $\begin{array}{lll} \hline \text { Q4 } Q_{n} & X \\ \text { B4 B4 } & Z \end{array}$ | $\begin{array}{llll} \hline \mathrm{O} & \mathrm{a}_{n} & X \\ \text { B5 } & \text { B5 } & \mathrm{Z} \end{array}$ | $\begin{array}{llll} \hline 06 & a_{n} & X \\ B 6 & \text { B6 } & Z \end{array}$ | $\begin{aligned} & \text { O7 } a_{n} X \\ & \text { B7 B7 } \\ & \hline \end{aligned}$ | $\begin{array}{lll} \hline \text { O8 } Q_{n} & X \\ \text { B8 B8 } & Z \end{array}$ | $\mathrm{Q}_{\mathrm{N}}$ TO $\mathrm{A}_{\mathrm{N}}$ |
| $\begin{array}{lll} H & L & L \\ H & L & L \\ H & L & L \end{array}$ | $\begin{gathered} \hline \text { H or } L \\ \uparrow \\ \uparrow \end{gathered}$ | $\bar{x}$ | $\begin{array}{lll} Z & Q_{n} & A 1 \\ Z & H & A 1 \\ Z & L & A 1 \end{array}$ | $\begin{array}{lll} Z & O_{n} & A 2 \\ Z & \text { Q1 } & A 2 \\ Z & \text { Q1 } & A 2 \end{array}$ | $\begin{array}{ll} z & Q_{n} A 3 \\ z & \text { Q2 } A 3 \\ z & \text { Q2 } A 3 \end{array}$ | $\begin{array}{lll} z & a_{n} & A 4 \\ z & \text { Q3 } & A 4 \\ z & \text { Q3 } & A 4 \end{array}$ | $\begin{array}{lll} z & Q_{n} & A 5 \\ z & Q 4 & A 5 \\ z & Q 4 & A 5 \end{array}$ | $\begin{array}{lll} \mathrm{Z} & \mathrm{Q}_{\mathrm{n}} & \mathrm{~A} 6 \\ \mathrm{z} & 05 & \mathrm{~A} 6 \\ \mathrm{Z} & \mathrm{Q} & \mathrm{~A} 6 \end{array}$ | $\begin{array}{lll} Z & Q_{n} & A 7 \\ Z & Q 6 A 7 \\ Z & Q 6 A 7 \end{array}$ | $\begin{array}{lll} z & Q_{n} A 8 \\ z & 07 A 8 \\ z & 07 A 8 \end{array}$ | $\begin{aligned} & \text { SHIFT } \\ & \text { AND } \\ & \text { A TO B } \end{aligned}$ |
| $\begin{array}{lll} \hline H & \text { L } & H \\ H & L & H \\ H & L & H \end{array}$ | $\begin{gathered} \mathrm{H} \text { or } \mathrm{L} \\ \uparrow \\ \uparrow \end{gathered}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{H} \end{aligned}$ | $\begin{array}{lll} \mathrm{B}_{1} & \mathrm{O}_{n} & \mathrm{Z} \\ \mathrm{~B} 1 & \mathrm{H} & \mathrm{Z} \\ \mathrm{~B} 1 & \mathrm{~L} & \mathrm{Z} \end{array}$ | $\begin{array}{lll} B 2 & Q_{n} & Z \\ \text { B2 Q1 } & z \\ \text { B2 Q1 } & Z \end{array}$ | $\begin{aligned} & \text { B3 } Q_{n} \\ & \text { B3 } \\ & \text { Q2 } \\ & \text { B3 } \mathrm{Z} \\ & \text { Q } \end{aligned}$ | $\begin{array}{lll} \text { B4 } & a_{n} & z \\ \text { B4 } 43 & \text { a } \\ \text { B4 } & \text { a3 } & z \end{array}$ | $\begin{array}{lll} \hline \text { B5 } Q_{n} & Z \\ \text { B5 Q4 } & Z \\ \text { B5 Q4 } & Z \end{array}$ | $\begin{array}{lll} B 6 & a_{n} & Z \\ B 6 & \text { Q5 } & Z \\ B 6 & \text { a5 } & Z \end{array}$ | $\begin{array}{lll} B 7 & a_{n} & Z \\ \text { B7 } & \text { Q6 } & Z \\ \text { B7 } & \text { a6 } & Z \end{array}$ | $\begin{array}{lll} \text { B8 } a_{n} & Z \\ \text { B8 } \text { a7 }^{z} & Z \\ \text { B8 a7 } & Z \end{array}$ | SHIFT <br> AND <br> B TO A |
| H H L <br> H H L <br> H H L | $\begin{gathered} \text { H or L } \\ \uparrow \\ \uparrow \end{gathered}$ | $x$ | $\begin{array}{lll}Z & Q_{n} & Z \\ Z & H & Z \\ Z & L & Z\end{array}$ | $\begin{array}{llll}z & a_{n} & z \\ z & Q_{1} & z \\ z & Q_{1} & z\end{array}$ | $\begin{array}{llll}z & O_{n} & Z \\ z & \text { Q2 } & z \\ z & Q^{2} & z\end{array}$ | $\begin{array}{llll}z & a_{n} & z \\ z & \text { a3 } & z \\ z & \text { a3 } & z\end{array}$ | $\begin{array}{llll}z & Q_{n} & z \\ z & \text { Q4 } & z \\ z & \text { Q4 } & z\end{array}$ | $\begin{array}{llll}z & a_{n} & z \\ z & 05 & z \\ z & 05 & z\end{array}$ | $\begin{array}{lll} z & a_{n} & z \\ z & 06 & z \\ z & 06 & z \end{array}$ | $\begin{array}{lll} z & a_{n} & z \\ z & 07 & z \\ z & 07 & z \end{array}$ | SHIFT |
| $\begin{array}{lll}\mathrm{H} & \mathrm{H} & \mathrm{H} \\ \mathrm{H} & \mathrm{H} & \mathrm{H}\end{array}$ | $\mathrm{H} \text { or } \mathrm{L}$ $\uparrow$ | $\begin{aligned} & x \\ & x \end{aligned}$ | $\begin{array}{ccc}z & a_{n} & z \\ z & L & z\end{array}$ | $\begin{array}{llll}z & Q_{n} & \\ z & L & z\end{array}$ | $\begin{array}{lll}z & a_{n} & z \\ z & L & z\end{array}$ | $\begin{array}{lll}z & O_{n} & z \\ z & L & z\end{array}$ | $\begin{array}{llll}z & a_{n} & z \\ z & L & z\end{array}$ | $\begin{array}{llll}z & a_{n} & z \\ z & L & z\end{array}$ | $\begin{array}{ccc}z & a_{n} & z \\ z & L & z\end{array}$ | $\begin{array}{llll}z & a_{n} & z \\ z & L & z\end{array}$ | CLEAR |

$n=$ level of $Q_{n}(n=1,2, \ldots 8)$ established on the most recent $\uparrow$ transition of CLK. $Q_{1}$ through $Q 8$ are the shift register outputs; only Q 8 is available externally. The double inversions that take place as data travels from port to port are ignored in this table.

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


${ }^{\dagger}$ This symbol is in accordance with ANSIIIEEE Standard 91-1984 and IEC Publication 617-12. Pin numbers shown are for DW, JT, and NT packages.

## SN54AS852, SN74AS852 8-BIT UNIVERSAL TRANSCEIVER PORT CONTROLLERS

absolute maximum ratings over free-air temperature range

recommended operating conditions


## SN54AS852, SN74AS852 8-BIT UNIVERSAL TRANSCEIVER PORT CONTROLLERS

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

| PARAMETER |  | TEST CONDITIONS |  |  | 54AS8 |  |  | 74AS |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\text {t }}$ | MAX | MIN | TYP ${ }^{\text {t }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $I_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | A1-A8, B1-B8 | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-12 \mathrm{~mA}$ | 2.4 | 3.2 |  |  |  |  | V |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-15 \mathrm{~mA}$ |  |  |  | 2.4 | 3.3 |  |  |
|  | All outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V , $\mathrm{IOH}=-2 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | All outputs except Q8 | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}$ |  | 0.3 | 0.5 |  |  |  | V |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | Q8 | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=20 \mathrm{~mA}$ |  | 0.25 | 0.5 |  | 0.25 | 0.5 |  |
| 1 | S0, S1, S2 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.3 |  |  | 0.3 | mA |
|  | CLK and SERIN |  |  |  |  | 0.1 |  |  | 0.1 |  |
|  | A1-A8, B1-B8 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$. | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.2 |  |  | 0.2 |  |
| ${ }_{1} \mathrm{H}$ | S0, S1, S2 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 60 |  |  | 60 | $\mu \mathrm{A}$ |
|  | CLK and SERIN |  |  |  |  | 20 |  |  | 20 |  |
|  | A1-A8, B1-B8 ${ }^{\ddagger}$ |  |  |  |  | 70 |  |  | 70 |  |
|  | S0, S1, S2 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -1 |  |  | -1 | mA |
| IIL | CLK and SERIN |  |  |  |  | -0.5 |  |  | -0.5 |  |
|  | A1-A8, B1-B8 ${ }^{\ddagger}$ |  |  |  |  | -0.5 |  |  | -0.5 |  |
| $10^{\text {§ }}$ | Except 08 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{O}}=2.25 \mathrm{~V}$ |  | -30 |  | -112 | -30 |  | -112 | mA |
|  | Q8 |  |  | -20 |  | -112 | -20 |  | -112 |  |
| ${ }^{\text {ICC }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  | 136220 |  |  | 136 |  | 220 | 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 $I_{I H}$ and $I_{I L}$ include the output currents $I_{\mathrm{OZH}}$ and $I_{\mathrm{OZL}}$, respectively.
$\S_{\text {The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS. }}^{\text {I }}$
switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{R}_{\mathrm{L}}=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}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS852 |  | SN74AS852 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  | 45 |  | 50 |  | MHz |
| tPLH | Any A port | Any B port | 2 | 9 | 2 | 7.5 | ns |
| tPHL |  |  | 3 | 12.5 | 3 | 11 |  |
| tPLH | Any B port | Any A port | 2 | 9 | 2 | 7.5 | ns |
| tPHL |  |  | 3 | 12.5 | 3 | 11 |  |
| tPLH | S0, S1, S2 ${ }^{\text {d }}$ | Any A or B port | 3 | 11.5 | 3 | 10 |  |
| tPHL |  |  | 3 | 12 | 3 | 10.5 | ns |
| tPLH | CLK | Any A or B port | 2 | 11 | 2 | 9 | n |
| tPHL |  |  | 3 | 14 | 3 | 12.5 | , |
| tPLH | CLK | Q8 | 2 | 10.5 | 2 | 8 | ns |
| tPHL |  |  | 3 | 11.5 | 3 | 10 |  |
| tPHZ | S0, S1, S2 | Any A or B port | 2 | 9 | 2 | 7 | ns |
| tPLZ |  |  | 3 | 13 | 3 | 10.5 |  |
| tPZH |  |  | 2 | 9 | 2 | 7 | ns |
| tPZL |  |  | 3 | 13 | 3 | 10.5 | ns |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.
§ The positive transition of $S 1$ control pin will cause low-level data on the $A$ or $B$ bus to be invalid for 17.5 ns .

## TYPICAL APPLICATION DATA

BUS A TO BUS B OR SERIAL TRANSMISSION


SERIAL IN TO A PORT


BUS B TO BUS A OR SERIAL TRANSMISSION SERIAL IN


SERIAL IN TO B PORT
SERIAL IN


## SN54AS856, SN74AS856 8-BIT UNIVERSAL TRANSCEIVER PORT CONTROLLERS

D2814, DECEMBER 1983-REVISED MARCH 1985

- Included Among the Package Options are Compact, 24-Pin, 300-mil-Wide DIPs and Both 28-Pin Plastic and Ceramic Chip Carriers
- Buffered 3-State Outputs Drive Bus Lines Directly
- Cascadable to $n$-Bits
- Eight Selectable Transceiver/Port Functions:
- B to A
- Register to $A$ and/or $B$
- Off-Line Shifts (A and B Ports in HighImpedance State)
- Shifted to A and/or B
- Particularly Suitable for Use in Diagnostics Analysis Circuitry
- Serial Register Provides:
- Parallel Storage of Either A or B Input Data
- Serial Transmission of Data from Either A or B Port
- Readback Mode B to A
- Dependable Texas Instruments Quality and Reliability

```
SN54AS856 . . . JT PACKAGE
SN74AS856 . . . DW or NT PACKAGE
(TOP VIEW)
```



> SN54AS856 . . . FK PACKAGE
> SN74AS856 . . FN PACKAGE (TOP VIEW)


NC - No internal connection

## description

The 'AS856 features two 8-bit I/O ports (A1-A8 and B1-B8), an 8-bit parallel-load, serial-in, parallel-out shift register, and control logic. With these features, this device is capable of performing eight selectable transceiver or port functions, depending on the state of the three control lines $\overline{\mathrm{OEA}}, \overline{\mathrm{OEB}}$, and MODE. These functions include: transferring data from port $A$ to port $B$ or vice versa (i.e., the transceiver function), serial shifting data to either or both ports, and performing off-line shifts (with $A$ and $B$ ports active as transceivers in a high-impedance state). Synchronous parallel loading of the internal register can be accomplished from either port on the positive transition of the clock while serially shifting data in via the SERIN input. The 'AS856 is ideally suited for applications needing signature-analysis circuitry to enhance system verification and/or fault analysis. All serial data is shifted right. All outputs are buffer-type outputs designed specifically to drive bus lines directly and all are 3-state except for Q8, which is a totem-pole output.

The SN54AS856 is characterized for operation over the full military temperaure range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS856 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

SN54AS856, SN74AS856

## 8-BIT UNIVERSAL TRANSCEIVER PORT CONTROLLERS

logic diagram (positive logic)

(6) A3
(7) A4
(8) $A 5$
(9) A6
(19) B3
(18) B4
(17) B5
(16) B6


Texas

## SN54AS856, SN74AS856 8-BIT UNIVERSAL TRANSCEIVER PORT CONTROLLERS

FUNCTION TABLE

| MODE |  |  | CLOCK | SERIN | A1 01 B1 | A2 02 B2 | A3 03 B3 | A4 04 B4 | A5 05 B5 | A6 06 B6 | A7 07 B7 | A8 0888 | FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | H or L | X | Q1 Q1 Q1 | O2 0202 | Q3 Q3 Q3 | 040404 | 050505 | 060606 | 070707 | 080808 |  |
| L | L | L | $\uparrow$ | x | Q1 01 Q1 | 020202 | Q3 Q3 03 | Q4 Q4 Q4 | 050505 | 060606 | 070707 | 080808 | Feedback |
| L | L | H | H or L | X | B1 Q1 2 | B2 02 Z | в3 Q3 Z | B4 Q4 Z | B5 05 z | B6 06 Z | B7 07 z | B8 08 Z | $B$ to $A$ |
| L | L | H | $\uparrow$ | X | B1 B1 Z | B2 B2 | в3 в3 | B4 B4 Z | B5 B5 z | B6 B6 z | B7 B7 z | в8 в8 z | A to 0 |
| L | H | L | H or L | X | Z 0101 | z O2 02 | z Q3 Q3 | Z 0404 | z 0505 | z 0606 | Z 0707 | z 0808 | $A$ to 0 |
| L | H | L | $\uparrow$ | X | $Z$ A1 A1 | Z A2 A2 | $Z$ A3 A3 | Z A4 A4 | Z A5 A5 | Z A6 A6 | Z A7 A7 | $z$ A8 A8 | O to B |
| L | H | H | H or L | X | z Q1 z | Z Q2 z | z Q3 Z | z Q4 Z | z 05 z | z 06 | z 07 z | z 08 z |  |
| L | H | H | $\uparrow$ | x | Z A1 Z | Z A2 Z | z A3 z | z A4 Z | Z A5 Z | z A6 z | Z A7 Z | $z$ A8 z |  |
| H | L | L | H or L | X | Q1 $\mathrm{O}_{\mathrm{n}} \mathrm{Q} 1$ | Q2 $\mathrm{a}_{\mathrm{n}}$ Q2 | Q3 $\mathrm{a}_{\mathrm{n}}$ Q3 | $Q^{4} Q_{n}$ Q4 | $05 \mathrm{Q}_{\mathrm{n}}$ Q5 | $06 a_{n} 06$ | $07 \mathrm{a}_{\mathrm{n}}$ Q7 | $08 \mathrm{a}_{\mathrm{n}}$ Q8 | SHIFT |
| H | L | L | $\uparrow$ | H | H H H | Q1 0101 | O2 2202 | Q3 Q3 Q3 | Q4 O4 04 | 050505 | 060606 | 070707 | TO |
| H | L | L | $\uparrow$ | L | L L L | Q1 Q1 Q1 | O2 Q2 Q2 | Q3 Q3 Q3 | Q4 O4 04 | 050505 | 060606 | 070707 | A and B |
| H | L | H | H or L | X | Q1 $\mathrm{O}_{\mathrm{n}} \mathrm{Z}$ | Q2 $\mathrm{an}_{\mathrm{n}} \mathrm{z}$ | Q3 $\mathrm{Q}_{\mathrm{n}} \mathrm{Z}$ | $\mathrm{Q}^{\text {a }} \mathrm{n}_{\mathrm{n}} \mathrm{z}$ | $05 \mathrm{O}_{\mathrm{n}} \mathrm{z}$ | $06 a_{n} z$ | $07 \mathrm{a}_{\mathrm{n}} \mathrm{z}$ | 08 $\mathrm{an}_{\mathrm{n}} \mathrm{z}$ | SHIFT |
| H | L | H | $\uparrow$ | H | H H Z | Q1 01 z | O2 02 z | Q3 03 z | Q4 Q4 Z | 0505 z | 0606 z | 0707 z | TO |
| H | L | H | $\uparrow$ | L | L z | 0101 z | Q2 Q2 z | Q3 Q3 z | 0404 z | 0505 z | 0606 z | 0707 z | A |
| H | H | L | H or L | X | $z \mathrm{o}_{\mathrm{n}} \mathrm{Q}^{1}$ | $z \mathrm{a}_{\mathrm{n}} \mathrm{Q}^{2}$ | $z \mathrm{a}_{\mathrm{n}} \mathrm{Q}^{\text {a }}$ | $\mathrm{z} \mathrm{Q}_{\mathrm{n}}$ Q4 | $z \mathrm{O}_{n}$ Q5 | $z \mathrm{a}_{\mathrm{n}} 06$ | $z \mathrm{Q}_{\mathrm{n}} \mathrm{Q}^{\text {7 }}$ | $z \mathrm{a}_{\mathrm{n}}$ Q8 | SHIFT |
| H | H | L | $\uparrow$ | H | Z H H | z Q1 01 | 0202 | z 03 Q3 | z 0404 | z 0505 | z 0606 | $z \quad 0707$ | ro |
| H | H | L | $\uparrow$ | L | Z L L | z 0101 | z 0202 | z 0303 | z Q4 04 | z 0505 | z 0606 | z 0707 | B |
| H | H | H | H or L | X | $z \mathrm{a}_{\mathrm{n}} \mathrm{z}$ | $z a_{n} z$ | $z a_{n} z$ | $z \mathrm{a}_{\mathrm{n}} \mathrm{z}$ | $z \mathrm{O}_{\mathrm{n}} \mathrm{z}$ | $z a_{n} z$ | $z a_{n} z$ | $z a_{n} z$ |  |
| H | H | H | $\uparrow$ | H | Z H Z | z Q1 z | z 02 z | z 03 z | z 04 z | z 05 z | z 06 z | z 07 z | SHFT |
| H | H | H | $\uparrow$ | L | Z L H | z Q1 z | z 02 z | z 03 z | z 04 z | z 05 z | z 06 z | z 07 z |  |

$\mathrm{n}=$ level of $\mathrm{Q}_{\mathrm{n}}(\mathrm{n}=1,2 \ldots 8)$ established on most recent $\uparrow$ transition of CLK. Q1 through Q8 are the shift register outputs; only Q8 is available externally. The double inversions that take place as data travels from port to port are ignored in this table.

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



## SN54AS856, SN74AS856 8-BIT UNIVERSAL TRANSCEIVER PORT CONTROLLERS

## absolute maximum ratings over free-air temperature range

| Supply voltage, VCC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V |  |
| :---: | :---: |
| Input voltage: All inpu |  |
| I/O ports | 5.5 V |
| Voltage applied to a disabled 3-state output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V |  |
| Operating free-air temperature range: SN54AS856 . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  |
| SN74AS856 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions


## SN54AS856, SN74AS856 8-BIT UNIVERSAL TRANSCEIVER PORT CONTROLLERS

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

| PARAMETER |  | TEST CONDITIONS |  | SN54AS856 |  |  | SN74AS856 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\text { }}$ | MAX | MIN | TYP ${ }^{\text {t }}$ | MAX |  |
| $\mathrm{V}_{\mathrm{IK}}$ |  |  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | A1-A8 | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-12 \mathrm{~mA}$ | 2 | 3.2 |  |  |  |  | V |
|  | B1-B8 | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-15 \mathrm{~mA}$ |  |  |  | 2 | 3.3 |  |  |
|  | All outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, 1 \mathrm{OH}=-2 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}{ }^{-2}$ |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | All outputs except 08 | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=32 \mathrm{~mA}$ |  | 0.25 | 0.5 |  |  |  | V |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | 08 | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=20 \mathrm{~mA}$ |  |  | 0.5 |  |  | 0.5 |  |
| $!$ | $\overline{\text { OEB }}$, $\overline{\mathrm{OEA}}, \mathrm{MODE}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=7 \mathrm{~V}$ |  |  |  | 0.2 |  |  | 0.2 | mA |
|  | CLK and SERIN |  |  |  |  | 0.1 |  |  | 0.1 |  |
|  | A1-A8, B1-B8 | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.2 |  |  | 0.2 |  |
| ${ }_{1} \mathrm{H}$ | $\overline{\mathrm{OEB}}, \overline{\mathrm{OEA}}, \mathrm{MODE}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $V_{1}=2.7 \mathrm{~V}$ |  |  | 40 |  |  | 40 | $\mu \mathrm{A}$ |
|  | CLK and SERIN |  |  |  |  | 20 |  |  | 20 |  |
|  | A1-A8, B1-B8 ${ }^{\ddagger}$ |  |  |  |  | 70 |  |  | 70 |  |
| ILL | OEB, $\overline{O E A}, \mathrm{MODE}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -1 |  |  | -1 | mA |
|  | CLK and SERIN |  |  |  |  | -0.5 |  |  | -0.5 |  |
|  | A1-A8, B1-B8 ${ }^{\ddagger}$ |  |  |  |  | -0.5 |  |  | -0.5 |  |
| $10^{5}$ | Except 08 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
|  | Q8 |  |  | -20 |  | -112 | -20 |  | -112 |  |
| ${ }^{\text {ICC }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  |  | 118 | 200 |  | 118 | 200 | 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 $I_{I H}$ and $I_{I L}$ include the output currents $I_{O Z H}$ and $I_{O Z L}$, respectively.
${ }^{\S}$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS.
switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=\equiv 50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathbf{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS856 |  | SN74AS856 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  | 45 |  | 50 |  | MHz |
| ${ }_{\text {tPLH }}$ | Any B port | Any A port | 2 | 8 | 2 | 7 | ns |
| tPHL |  |  | 2 | 10.5 | 2 | 9.5 | ns |
| tPLH | ¢MODE ${ }^{\text {¢ }}$ | Any A or B port | 2 | 8.5 | 2 | 7.5 | ns |
| tPHL |  |  | 5 | 20 | 5 | 19 | ns |
| tPLH | $\downarrow$ MODE | Any A or B port | 2 | 8.5 | 2 | 7.5 | ns |
| tPHL |  |  | 2 | 9.5 | 2 | 8 | ns |
| tPLH | CLK | Any A or B port | 3 | 12 | 3 | 9 | ns |
| tpHL |  |  | 3 | 12 | 3 | 11 |  |
| tPLH | CLK | Q8 | 2 | 9 | 2 | 7.5 | s |
| tPHL |  |  | 2 | 10 | 2 | 9 | ns |
| tpHz | $\overline{\text { OEA }}$ or $\overline{O E B}$ | Any A or B port | 2 | 9 | 2 | 7 | ns |
| tPLZ |  |  | 2 | 12 | 2 | 9.5 |  |
| tPZH |  |  | 2 | 8 | 2 | 7 | ns |
| tPZL |  |  | 2 | 11 | 2 | 10 | ns |

[^39]
# SN54AS867, SN54AS869, SN74AS867, SN74AS869 SYNCHRONOUS 8-BIT UP/DOWN COUNTERS 

D2661, DECEMBER 1982 - AUGUST 1985

- Included among the Package Options are Compact, 24-Pin, 300-mil-Wide DIPs and 28-Pin Ceramic Chip Carriers
- Fully Programmable with Synchronous Counting and Loading
- 'AS867 Has Asynchronous Clear, 'AS869 Has Synchronous Clear
- Fully Independent Clock Circuit Simplifies Use
- Ripple Carry Output for n-Bit Cascading
- Improved Performance Compared to Schottky TTL:
- Typical Power Reduced by 38\%
- Maximum Count Frequency is $25 \%$ Higher
- Dependable Texas Instruments Quality and Reliability
SN54AS867, SN54AS869 . . . . JT PACKAGE SN74AS867, SN74AS869 . . . . DW OR NT PACKAGE
(TOP VIEW)

| So 1 | $\bigcirc_{24}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| :---: | :---: | :---: |
| S1 2 | 23 | ENP |
| - | 22 | $\mathrm{O}_{A}$ |
| - | 21 | $\mathrm{C}_{B}$ |
| C $\square^{5}$ | 20 | $\mathrm{O}_{C}$ |
| D | 19 | $Q_{D}$ |
| E | 18 | $\mathrm{a}_{E}$ |
| F $\square^{8}$ | 17 | $\mathrm{OF}_{\mathrm{F}}$ |
| G | 16 | $\mathrm{O}_{\mathrm{G}}$ |
| H 10 | 5 | $\mathrm{O}_{\mathrm{H}}$ |
| T | 14 | $\square \mathrm{CLK}$ |
| ND $\square 12$ | 13 | $\square \overline{\mathrm{RCO}}$ |

SN54AS867, SN54AS869 . . . FK PACKAGE
(TOP VIEW)


NC - No internal connection

## description

These synchronous presettable counters feature an internal carry look-ahead for cascading in high-speed counting applications. Synchronous operation is provided by having all flip-flops clocked simultaneously so that the outputs change coincident with each other when so instructed by the count-enable inputs and internal gating. This mode of operation helps eliminate the output counting spikes that are normally associated with asynchronous (ripple-clock) counters. A buffered clock input triggers the eight flip-flops on the rising (positive-going) edge of the clock waveform.

These counters are fully programmable; that is, the outputs may each be preset to either level. The load mode circuitry allows parallel loading of the cascaded counters. As loading is synchronous, selecting the load mode disables the counter and causes the outputs to agree with the data inputs after the next clock pulse.

The carry look-ahead circuitry provides for cascading counters for $n$-bit synchronous applications without additional gating. Instrumental in accomplishing this function are two count-enable inputs and a carry output. Both count enable inputs ( $\overline{\mathrm{ENP}}$ and $\overline{\mathrm{ENT}}$ ) must be low to count. The direction of the count is determined by the levels of the select inputs (see Function Table). Input $\overline{\mathrm{ENT}}$ is fed forward to enable the carry output. The ripple carry output thus enabled will produce a low-level pulse while the count is zero (all outputs low) counting down or 255 counting up (all outputs high). This low-level overflow carry pulse can be used to enable successive cascaded stages. Transitions at the enable $\overline{\mathrm{ENP}}$ and $\overline{\mathrm{ENT}}$ inputs are allowed regardless of the level of the clock input. All inputs are diode-clamped to minimize transmission-line effects, thereby simplifying system design.

## SN54AS867, SN54AS869, SN74AS867, SN74AS869 SYNCHRONOUS 8-BIT UP/DOWN COUNTERS

These counters feature a fully independent clock circuit. With the exception of the asynchronous clear on the 'AS867, changes at control inputs (S0, S1) that will modify the operating mode have no effect on the $Q$ outputs until clocking occurs. Anytime the $\overline{E N P}$ and/or $\overline{E N T}$ is taken high, $\overline{R C O}$ will either go or remain high. The function of the counter (whether enabled, disabled, loading, or counting) will be dictated solely by the conditions meeting the stable setup and hold times.

The SN54AS867 and SN54AS869 are characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS867 and SN74AS869 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

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


these symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers shown are for DW, JT, and NT packages.

FUNCTION TABLE

| S1 | S0 | FUNCTION |
| :---: | :---: | :--- |
| L | L | Clear |
| L | $H$ | Count down |
| $H$ | L | Load |
| $H$ | $H$ | Count up |

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, VCC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Input voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Operating free-air temperature range: SN54AS867, SN54AS869 . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
SN74AS867, SN74AS869 . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range
$-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$


## SN54AS867, SN74AS867 <br> SYNCHRONOUS 8-BIT UP/DOWN COUNTERS WITH ASYNCHRONOUS CLEAR

recommended operating conditions

${ }^{\dagger}$ This setup time is required to ensure stable data.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS | SN54AS867 |  |  | SN74AS867 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\text {t }}$ | MAX | MIN | TYP ${ }^{\text {t }}$ | MAX |  |
| $\mathrm{V}_{\mathrm{IK}}$ |  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}, \quad \quad \mathrm{I}=18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}{ }^{-2}$ |  |  | V |
| $\mathrm{V}_{\text {OL }}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA}$ |  | 0.34 | 0.5 |  | 0.34 | 0.5 | V |
| 1 |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| ${ }_{\text {I }}$ | ENT | CC $=5.5 \mathrm{~V} \quad \mathrm{~V}_{1}=2.7 \mathrm{~V}$ |  |  | 40 |  |  | 40 |  |
|  | Other inputs | 5.5.V, $\quad \mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | ENT |  |  |  | -4 |  |  | -4 | mA |
| IL | Other inputs | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=0.4 \mathrm{~V}$ |  |  | -2 |  |  | -2 | mA |
| $10^{5}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ${ }^{\text {ICC }}$ |  | $V_{C C}=5.5 \mathrm{~V}$ |  | 134 | 195 |  | 134 | 195 | 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, IOS.

SN54AS869, SN74AS869 SYNCHRONOUS 8-BIT UP/DOWN COUNTERS WITH SYNCHRONOUS CLEAR
recommended operating conditions

|  |  |  | SN54AS869 |  |  | SN74AS869 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | High-level output current |  |  |  | -2 |  |  | -2 | mA |
| ${ }^{\text {I OL }}$ | Low-level output current |  |  |  | 20 |  |  | 20 | mA |
| $f_{\text {clock }}$ | Clock frequency |  | 0 |  | 40 | 0 |  | 45 | MHz |
| $\mathrm{t}_{\text {w }}$ (clock) | Duration |  | 12.5 |  |  | 11 |  |  | ns |
| $\mathrm{t}_{\mathrm{su}}$ | Setup time ${ }^{\dagger}$ | Data inputs A-H | 6 |  |  | 5 |  |  | ns |
|  |  | Enable $P$ ( $\overline{\mathrm{ENP}}$ ) or Enable T (ENT) | 10 |  |  | 9 |  |  | ns |
|  |  | S0 or S1 (load) | 13 |  |  | 11 |  |  | ns |
|  |  | S0 or S1 (clear) | 13 |  |  | 11 |  |  | ns |
|  |  | S0 or S1 (count down) | 52 |  |  | 50 |  |  | ns |
|  |  | S0 or S1 (count up) | 52 |  |  | 50 |  |  | ns |
| $\mathrm{t}_{\mathrm{h}}$ | Hold time at any input with respect to clock $\dagger$ |  | 0 |  |  | 0 |  |  | ns |
| TA | Operating free-air temperature |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

${ }^{\dagger}$ This setup time is required to ensure stable data.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS | SN54AS869 |  |  | SN74AS869 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $V_{\text {IK }}$ |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \quad \mathrm{I}_{1}=18 \mathrm{~mA}$ |  |  | $-1.2$ |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}^{\mathrm{OH}}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}$ |  |  | V |
| $\mathrm{VOL}^{\text {O }}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA}$ |  | 0.34 | 0.5 |  | 0.34 | 0.5 | V |
| 1 |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| ${ }^{1} \mathrm{H}$ | ENT | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=2.7 \mathrm{~V}$ |  |  | 40 |  |  | 40 | $\mu \mathrm{A}$ |
|  | Other inputs |  |  |  | 20 |  |  | 20 |  |
| IIL | ENT | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=0.4 \mathrm{~V}$ |  |  | -4 |  |  | -4 | mA |
|  | Other inputs |  |  |  | -2 |  |  | -2 |  |
| $10^{\S}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ${ }^{1} \mathrm{CC}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  | 125 | 180 |  | 125 | 180 | mA |

[^40]SN54AS867, SN54AS869, SN74AS867, SN74AS869 SYNCHRONOUS 8-BIT UP/DOWN COUNTERS
'AS867 switching characteristics (see note 1)

| PARAMETER | FROM (INPUT | то OUTPUT | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V} \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=500 \Omega \\ & \mathrm{~T}_{\mathrm{A}}=\mathrm{MIN} \text { to } \mathrm{MAX} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS867 |  | SN74AS867 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  | 40 |  | 50 |  | MHz |
| tPLH | CLK | $\overline{\mathrm{RCO}}$ | 5 | 31 | 5 | 22 | ns |
| tPHL |  |  | 6 | 19 | 6 | 16 |  |
| tPLH | CLK | Any Q | 3 | 12 | 3 | 11 | ns |
| tPHL |  |  | 4 | 16 | 4 | 15 |  |
| ${ }^{\text {tPLH }}$ | $\overline{\text { ENT }}$ | $\overline{\mathrm{RCO}}$ | 3 | 19 | 3 | 10 | ns |
| tPHL |  |  | 5 | 21 | 5 | 17 |  |
| ${ }^{\text {tPLH }}$ | $\overline{E N P}$ | $\overline{\mathrm{RCO}}$ | 5 | 14 | 5 | 14 | ns |
| ${ }_{\text {tPHL }}$ |  |  | 5 | 21 | 5 | 17 |  |
| tPHL | Clear (SO, S1 low) | Any Q | 7 | 23 | 7 | 21 | ns |

'AS869 switching characteristics (see note 1)

| PARAMETER | 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}_{\mathrm{L}}=500 \Omega \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS869 |  | SN74AS869 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| ${ }_{f}$ max |  |  | 40 |  | 45 |  | MHz |
| ${ }^{\text {PPLH }}$ | CLK | $\overline{\mathrm{RCO}}$ | 6 | 35 | 6 | 35 | ns |
| ${ }^{\text {tPHL }}$ |  |  | 6 | 20 | 6 | 18 |  |
| ${ }^{\text {P PLH }}$ | CLK | Any Q | 3 | 12 | 3 | 11 | ns |
| ${ }^{\text {tPHL }}$ |  |  | 4 | 16 | 4 | - 15 |  |
| ${ }^{\text {PPLH }}$ | $\overline{\text { ENT }}$ | $\overline{\mathrm{RCO}}$ | 3 | 25 | 3 | 15 | ns |
| ${ }^{\text {tPHL }}$ |  |  | 6 | 21 | 6 | 17 |  |
| tPLH | $\overline{E N P}$ | $\overline{\mathrm{RCO}}$ | 5 | 27 | 5 | 19 | ns |
| ${ }^{\text {tPHL }}$ |  |  | 6 | 21 | 6 | 18 |  |

NOTE 1: Load circuit and voltage waveforms, are shown in Section 1.

- 'AS870 in 24-Pin Small Outline, 300-mil DIP and Both Plastic and Ceramic 28-Pin Chip Carriers
- 'AS871 in 28-Pin 600-mil DIP and Both Plastic and Ceramic Chip Carriers
- 3-State Buffer-Type Outputs Drive Bus Lines Directly
- Typical Access Time is 11 ns
- Each Register File Has Individual Write Enable Controls and Address Lines
- Designed Specifically for Multibus Architecture and Overlapping File Operations
- Prioritized B Input Port Prevents Write Conflicts During Dual Input Mode
- Dependable Texas Instruments Quality and Reliability


## description

These devices feature two 16 -word by 4 -bit register files. Each register file has individual write-enable controls and address lines. The 'AS870 has two 4-bit data $1 / O$ ports (DQA1-DQA4 and DQB1-DQB4). The 'AS871 has one 4-bit data I/O port (DOB1-DOB4) with the other data port having individual data inputs (DA1-DA4) and data outputs (QA1-QA4). The data I/O ports can output to Bus $A$ and Bus B; receive input from Bus $A$ and $B u s B$, receive input from Bus A and output to Bus B, or output to Bus $A$ and receive input from Bus $B$. To prevent writing conflicts in the dual-input mode, the B input port takes priority. Two select lines, SO and S1, control which port has access to which register. S2 determines whether the A ports are in the input or the output modes and S3 does likewise for the $B$ ports. The address lines (1A0-1A3 or 2A0-2A3) are decoded by an internal 1-of-16 decoder to select which register word is to be accessed. All outputs are 3-state buffer-type outputs designed specifically to drive bus lines directly.

The SN54AS870 and SN54AS871 are characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS870 and SN74AS871 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.


SN54AS871 . . . FK PACKAGE SN74AS871 . . . FN PACKAGE
(TOP VIEW)

$\mathrm{NC}-$ No internal connection
logic symbols ${ }^{\dagger}$

${ }^{\dagger}$ These symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers shown are for DW, JT, and NT packages.

logic diagram (positive logic)


FUNCTION TABLE

| File Select |  |  | INPUT/OUTPUT |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| So | S1 | FILE SEL | S2 | S3 | I/O SEL |
| L | L | 1R TOA, 1R TOB |  |  |  |
| H | L | 2R TO A, 1R TOB | L | L | A OUT, B OUT |
| L | H | 1R TO A, 2R TO B |  |  | A OUT, B OUT |
| H | H | 2R TO A, 2R TO B |  |  |  |
| L | L | A TO 1R, 1R TO B |  |  |  |
| H | L | A TO 2R, 1R TO B | H | L | A IN, B OUT |
| L | H | A TO 1R, 2R TO B |  |  | A ${ }^{\text {N, B OUT }}$ |
| H | H | A TO 2R, 2R TOB |  |  |  |
| L | L | 1R TO A, B TO 1R |  |  |  |
| H | L | 2R TO A, B TO 1R | L | H | A OUT, B IN |
| L | H | 1R TO A, B TO 2R |  |  |  |
| H | H | 2R TO A, B TO 2R |  |  |  |
| L | L | B TO 1R |  |  |  |
| H | L | A TO 2R, B TO 1R | H | H | A IN, B IN |
| L | H | A TO 1R, B TO 2R | H | H | A $\mathrm{N}, \mathrm{BIN}$ |
| H | H | B TO 2R |  |  |  |

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

Input voltage: All 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: SN54AS870, SN54AS871 . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
SN74AS870, SN74AS871 . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended operating conditions

|  |  |  | SN54AS870 <br> SN54AS871 |  |  | SN74AS870 SN74AS871 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  |  |  | -12 |  |  | -15 | mA |
| ${ }^{\mathrm{I}} \mathrm{OL}$ | Low-level ou |  |  |  | 32 |  |  | 48 | mA |
| $\mathrm{t}_{\text {w }}$ | Duration of write pulse |  | 12 |  |  | 12 |  |  | ns |
| ${ }^{\text {tsu }}$ | Setup times | Address before write $\downarrow$ | 5 |  |  | 5 |  |  | ns |
|  |  | Data before write $\uparrow$ | 15 |  |  | 15 |  |  |  |
|  |  | Select before write $\downarrow$ | 12 |  |  | 12 |  |  |  |
| $t^{\text {h }}$ | Hold times | Address after write $\uparrow$ | 0 |  |  | 0 |  |  | ns |
|  |  | Data after write $\uparrow$ | 0 |  |  | 0 |  | - |  |
|  |  | Select after write $\uparrow$ | 12 |  |  | 12 |  |  |  |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

| PARAMETER |  | TEST CONDITIONS |  | SN54AS870 |  |  | SN74AS870 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $V_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\\|_{1}=-18 \mathrm{~mA}$ |  |  | - 1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | $\mathrm{IOH}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}{ }^{2}$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-12 \mathrm{~mA}$ | 2.43 .2 |  |  |  |  |  |  |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-15 \mathrm{~mA}$ |  |  |  | 2.4 | 3.2 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=32 \mathrm{~mA}$ |  | 0.25 | 0.5 |  |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| ! | Control inputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | DQA and DQB ports | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.2 |  |  | 0.2 |  |
| ${ }_{1} \mathrm{H}$ | $1 \bar{W}$ and $2 \bar{W}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=2.7 \mathrm{~V}$ |  |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | Other control inputs |  |  |  |  | 40 |  |  | 40 |  |
|  | DQA and DQB ports ${ }^{\ddagger}$ |  |  |  |  | 50 |  |  | 50 |  |
| IIL | Control inputs | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=0.4 \mathrm{~V}$ |  |  |  | -2 |  |  | -2 | mA |
|  | DQA and DQB ports ${ }^{\ddagger}$ |  |  |  |  | -2 |  |  | -2 |  |
| $\mathrm{l}^{1}{ }^{\text {¢ }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | $-30$ |  | -112 | mA |
| ${ }^{1} \mathrm{CC}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  |  | 120 | 190 |  | 120 | 190 | mA |

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

| PARAMETER |  | TEST CONDITIONS |  | SN54AS871 |  |  | SN74AS871 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $11=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, 1 \mathrm{OH}=-2 \mathrm{~mA}$ |  | $\mathrm{V}_{\text {CC }-2}$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | v |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-12 \mathrm{~mA}$ | 2.43 .2 |  |  |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-15 \mathrm{~mA}$ |  |  |  | 2.4 | 3.2 |  |  |
| $\mathrm{V}_{\text {OL }}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=32 \mathrm{~mA}$ |  | 0.25 | 0.5 |  |  |  | V |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| IOZH | QA outputs | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
| lozL | QA outputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -50 |  |  | -50 | $\mu \mathrm{A}$ |
| 1 | Control and DA inputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | DQB ports | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.2 |  |  | 0.2 |  |
| ${ }^{1} \mathrm{H}$ | $1 \bar{W}, 2 \bar{W}$, and DA inputs | $V_{C C}=5.5 \mathrm{~V}$, | $V_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | Other control inputs |  |  |  |  | 40 |  |  | 40 |  |
|  | DOB ports ${ }^{\ddagger}$ |  |  |  |  | 50 |  |  | 50 |  |
| IIL | Control and DA inputs | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -2 |  |  | -2 | mA |
|  | DQB ports ${ }^{\ddagger}$ |  |  |  |  | -2 |  |  | -2 |  |
| $10^{8}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ICC |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  |  | 120 | 190 |  | 120 | 190 | 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 $I_{I H}$ and $I_{I L}$ include the off-state output current.
§The output conditions have been chosen to produce a current that closely approximates one-half of the true short-circuit current, loS.

SN54AS870, SN54AS871, SN74AS870, SN74AS871 DUAL 16-BY-4 REGISTER FILES
'AS870 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=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}_{\mathbf{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS870 |  | SN74AS870 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{A})$ | Any A | Any DQ | 5 | 20 | 5 | 15 | ns |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{S})$ | So | Any DQA | 3 | 15 | 3 | 13 | ns |
|  | S1 | Any DQB | 3 | 15 | 3 | 13 |  |
| ${ }^{\text {d }}$ dis | S2 | Any DQA | 3 | 12 | 3 | 11 | ns |
|  | S3 | Any DOB | 3 | 12 | 3 | 11 |  |
| ${ }^{\text {ten }}$ | S2 | Any DQA | 3 | 15 | 3 | 12 | ns |
|  | S3 | Any DQB | 3 | 15 | 3 | 12 |  |
| ${ }_{\text {tpd }}$ | $\overline{\text { w }}$ | Any DQ | 5 | 23 | 5 | 19 |  |
|  | DQA | DOB | 5 | 25 | 5 | 22 | ns |
|  | DQB | DQA | 5 | 25 | 5 | 22 |  |

'AS871 switching characteristics (see Note 1)

| PARAMETER | 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 \Omega \\ & \mathrm{R}_{2}=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS871 |  | SN74AS871 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| $t_{a}(\mathrm{~A})$ | Any A | Any QA or DQB | 5 | 20 | 5 | 16 | ns |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{S})$ | SO | Any QA | 3 | 15 | 3 | 13 | ns |
|  | S1 | Any DQB | 3 | 15 | 3 | 13 |  |
| ${ }^{\text {d }}$ dis | S2 | Any QA | 3 | 12 | 3 | 11 | ns |
|  | S3 | Any DQB | 3 | 12 | 3 | 11 |  |
| ten | S2 | Any QA | 3 | 15 | 3 | 12 | ns |
|  | S3 | Any DQB | 3 | 15 | 3 | 12 |  |
| ${ }^{t} \mathrm{pd}$ | W | Any QA or DQB | 5 | 23 | 5 | 19 |  |
|  | DA | DQB | 5 | 26 | 5 | 23 | ns |
|  | DQB | QA | 5 | 26 | 5 | 23 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN54AS877, SN74AS877 8-BIT UNIVERSAL TRANSCEIVER PORT CONTROLLERS

- Included Among the Package Options are Compact, 24-Pin, 300-mil-Wide Dips and Both 28-Pin Plastic and Ceramic Chip Carriers
- Buffered 3-State Outputs Drive Bus Lines Directly
- Cascaded to n-Bits
- Eight Selectable Transceiver/Port Functions: A to B or B to A
Register to $A$ or Register to $B$ Shifted to A or Shifted to B Off-Line Shifts (A and B Ports in HighImpedance State)
Register Clear
- Particularly Suitable for Use in SignatureAnalysis Circuitry
- Serial Register Provides: Parallel Storage of Either A or B Input Data
Serial Transmission of Data from Either A or B Port
- Dependable Texas Instruments Quality and Reliability


## description

The 'AS877 features two 8-bit I/O ports (A1-A8 and $\mathrm{B} 1-\mathrm{B} 8$ ), an 8 -bit parallel-load, serial-in, parallel-out shift register, and control logic. With these features, this device is capable of performing eight selectable transceiver or port functions, depending on the state of the three select lines S0, S1, and S2. These functions include: transferring data from port $A$ to port $B$ or vice versa (i.e., the transceiver function), transferring data from the register to either port, serial shifting data to either port, performing off-line shifts (with A and B ports in high-impedance state), and clearing the register. Synchronous parallel loading of the internal register can be accomplished from either port on the positive transition of the clock while serially shifting data in via the SERIN input. The 'AS877 is ideally suited for applications needing signature-analysis circuitry to enhance system verification and/or fault analysis. All serial data is shifted right. All outputs are buffer-type outputs designed specifically to drive bus lines directly and all are 3-state except for Q8, which is a totem-pole output.

The SN54AS877 is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS877 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

| $\begin{gathered} \text { MODE } \\ \text { S2 S1 SO } \end{gathered}$ | CLOCK | SERIN | A1 01 B1 | A2 $02 \mathrm{B2}$ | A3 03 B3 | A4 04 B4 | A5 05 B5 | A6 06 B6 | A7 07 B7 | A8 08 B8 | PORT FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L L L | H or L | X | $z \mathrm{O}_{\mathrm{n}} \mathrm{A} 1$ | $\mathrm{Z} \mathrm{On} \mathrm{A2}$ | $\mathrm{Z} \mathrm{a}_{\mathrm{n}} \mathrm{A} 3$ | $\mathrm{z} \mathrm{O} \mathrm{n}^{\text {A4 }}$ | $\mathrm{z} \mathrm{O} \mathrm{n}^{\text {A5 }}$ | $\mathrm{Z} \mathrm{Q}_{\mathrm{n}} \mathrm{A} 6$ | $\mathrm{Z} \mathrm{Q}_{\mathrm{n}} \mathrm{A} 7$ | $\mathrm{z} \mathrm{Q}_{\mathrm{n}} \mathrm{A} 8$ | A |
| L L | $\uparrow$ | X | Z A1 A1 | Z A2 A2 | Z A3 A3 | Z A4 A4 | Z A5 A5 | Z A6 A6 | Z A7 A7 | Z A8 A8 |  |
| L L | H or L | X | $\mathrm{B}_{1} \mathrm{Q}_{\mathrm{n}} \mathrm{Z}$ | $B 2 \mathrm{O}_{\mathrm{n}} \mathrm{Z}$ | B3 $\mathrm{a}_{\mathrm{n}} \mathrm{Z}$ | $B 4 \mathrm{O}_{\mathrm{n}} \mathrm{Z}$ | $B 5 \mathrm{C}_{\mathrm{n}} \mathrm{Z}$ | $\mathrm{B}_{6} \mathrm{O}_{\mathrm{n}} \mathrm{Z}$ | $B 7 \mathrm{an}_{\mathrm{n}} \mathrm{Z}$ | $\mathrm{B} 8 \mathrm{a}_{\mathrm{n}} \mathrm{Z}$ | B TO A |
| L L H | $\uparrow$ | x | B1 B1 2 | B2 B2 z | в3 в3 z | B4 B4 Z | B5 B5 Z | B6 B6 Z | B7 B7 Z | B8 B8 z |  |
| L H | H or | X | X | $\times$ | $\times \mathrm{O}$ | $\times$ | $\times$ | X | X $\mathrm{Q}_{\mathrm{n}}$ Q7 | $\times \mathrm{O}_{\mathrm{n}} \mathrm{Q8}$ |  |
| L H L | t | X | Z A1 A1 | Z A2 A2 | Z A3 A3 | Z A4 A4 | Z A5 A5 | Z A6 A6 | Z A7 A7 | Z A8 A8 |  |
| L H H | H or L | X | Q1 $\mathrm{Q}_{\mathrm{n}} \times$ | $\mathrm{O}^{2} \mathrm{a}_{\mathrm{n}} \mathrm{X}$ | Q3 $\mathrm{O}_{\mathrm{n}} \mathrm{X}$ | $\mathrm{Q}^{4} \mathrm{O}_{\mathrm{n}} \mathrm{X}$ | $\mathrm{Q}^{5} \mathrm{a}_{\mathrm{n}} \mathrm{X}$ | 06 | $07 \mathrm{C}_{\mathrm{n}} \mathrm{X}$ | $08 \mathrm{a}_{\mathrm{n}} \mathrm{X}$ |  |
| LHH | $\uparrow$ | X | B1 B1 z | B2 B2 Z | B3 B3 Z | B4 B4 Z | B5 B5 Z | B6 B6 Z | B7 B7 Z | B8 B8 Z | $\mathrm{Q}_{\mathrm{N}}$ TO AN |
| H L | H or | X | $\mathrm{ZO} \mathrm{n}^{\text {Q1 }}$ | $\mathrm{Z} \mathrm{O}_{\mathrm{n}} \mathrm{Q} 2$ | $\mathrm{Z} \mathrm{O}_{\mathrm{n}} \mathrm{Q} 3$ | $\mathrm{Zan}_{\mathrm{n}} \mathrm{O}^{4}$ | $\mathrm{Zan}_{\mathrm{n}} 05$ | $\mathrm{Z} \mathrm{O}_{\mathrm{n}} 06$ | $\mathrm{Z} \mathrm{Q}_{\mathrm{n}} 07$ | $\mathrm{Z} \mathrm{O}_{\mathrm{n}} 08$ | SHIFT |
| H L L | $\uparrow$ | H | Z H H | Z Q1 Q1 | z 0202 | z Q3 Q3 | z 0404 | z Q5 05 | z Q6 Q6 | Z 0707 | TO |
| H L | $\uparrow$ | L | Z L L | z Q1 Q1 | z Q2 Q2 | Z Q3 Q3 | z 0404 | Z 0505 | z Q6 Q6 | z 0707 | B |
| H L H | H or L | X | Q $1 \mathrm{O}_{\mathrm{n}} \mathrm{Z}$ | Q2 $\mathrm{an}_{\mathrm{n}} \mathrm{Z}$ | O3 $\mathrm{O}_{\mathrm{n}} \mathrm{Z}$ | Q4 $\mathrm{O}_{\mathrm{n}} \mathrm{Z}$ | Q5 $\mathrm{Q}_{\mathrm{n}} \mathrm{Z}$ | $06 \mathrm{a}_{\mathrm{n}} \mathrm{Z}$ | $07 \mathrm{C}_{\mathrm{n}} \mathrm{z}$ | $08 \mathrm{C}_{\mathrm{n}} \mathrm{z}$ | SHIFT |
| H L H | $\uparrow$ | H | H H Z | Q1 Q1 z | 02.02 z | Q3 Q3 Z | Q4 O4 Z | 0505 z | 0606 z | 0707 z | то |
| H L H | $\uparrow$ | L | L L Z | Q1 Q1 z | 0202 Z | 03 Q3 Z | Q4 04 Z | 0505 z | 0606 z | 0707 Z | A |
| H H L | H or | X | zan Z | $\mathrm{zan}_{\mathrm{n}} \mathrm{z}$ | $\mathrm{zan}_{\mathrm{n}} \mathrm{z}$ | zan z | $\mathrm{zan}_{\mathrm{n}} \mathrm{z}$ | zan Z | $z \mathrm{O}_{\mathrm{n}} \mathrm{z}$ | $a_{n} Z$ |  |
| H H L | $\uparrow$ | H | Z H Z | z 012 | z 02 z | z 03 z | z O4 Z | z 05 z | z 06 z | z 07 z | SHIFT |
| H H | $\uparrow$ | L | Z L Z | z 017 | Z 02 z | z 03 z | Z Q4 Z | z 05 z | z 06 z | z 07 z |  |
| HHH | H or L | X | zan Z | $z \mathrm{an}_{\mathrm{n}} \mathrm{z}$ | zan z | $z 0_{n} \mathrm{z}$ | zan Z | $z \mathrm{O}_{\mathrm{n}} \mathrm{z}$ | $\mathrm{z} \mathrm{O}_{\mathrm{n}} \mathrm{z}$ | $z \mathrm{an}_{\mathrm{n}} \mathrm{z}$ |  |
| HHH | $\dagger$ | X | Z L Z | z L Z | z L z | Z L Z | z L Z | Z L Z | Z L Z | z L | CLEAR |

$\mathrm{n}=$ level of $\mathrm{O}_{\mathrm{n}}(\mathrm{n}=1,2 \ldots 8)$ established on most recent $\uparrow$ transition of CLK. Q1 thru Q8 are the shift register outputs; only Q 8 is available externally. The double inversions that take place as data travels from port to port are ignored in this table.

## 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 DW, JT, and NT packages.
logic diagram (positive logic)



Pin numbers shown are for DW, JT, and NT packages.
absolute maximum ratings over free-air temperature range

recommended operating conditions

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

| PARAMETER |  | TEST CONDITIONS |  |  | 54AS8 | 877 |  | 74AS8 | 877 | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\text {T}}$ | MAX |  |
| $V_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | $-1.2$ |  |  | - 1.2 | V |
| VOH | A1-A8 | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-12 \mathrm{~mA}$ | 2 | 3.2 |  |  |  |  | V |
|  | B1-B8 | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-15 \mathrm{~mA}$ |  |  |  | 2 | 3.3 |  |  |
|  | All outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}^{\mathrm{OH}}=-2 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | All outputs except Q8 | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=32 \mathrm{~mA}$ |  | 0.25 | 0.5 |  |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\text {OL }}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | Q8 | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=20 \mathrm{~mA}$ |  | 0.25 | 0.5 |  | 0.25 | 0.5 |  |
| 4 | S0, S1, S2 | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=7 \mathrm{~V}$ |  |  |  | 0.3 |  |  | 0.3 | mA |
|  | CLK and SERIN |  |  |  |  | 0.1 |  |  | 0.1 |  |
|  | A1-A8, B1-B8 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.2 |  |  | 0.2 |  |
| ${ }^{1} \mathrm{H}$ | S0, S1, S2 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 60 |  |  | 60 | $\mu \mathrm{A}$ |
|  | CLK and SERIN. |  |  |  |  | 20 |  |  | 20 |  |
|  | A1-A8, B1-B8 ${ }^{\ddagger}$ |  |  |  |  | 70 |  |  | 70 |  |
| IIL | S0, S1, S2 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{I}}=0.4 \mathrm{~V}$ |  |  | -1 |  |  | - 1 | mA |
|  | CLK and SERIN |  |  |  |  | -0.5 |  |  | -0.5 |  |
|  | A1-A8, B1-B8 ${ }^{\ddagger}$ |  |  |  |  | -0.75 |  |  | -0.75 |  |
|  | Except 08 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | $-30$ |  | -112 | $-30$ |  | - 112 |  |
| $\mathrm{O}^{5}$ | Q8 |  |  | -20 |  | - 112 | $-20$ |  | -112 | mA |
| ${ }^{\text {I CC }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  | 136220 |  |  |  | 136 | 220 | 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 $I_{I H}$ and $I_{I L}$ include the output currents $I_{O Z H}$ and $I_{O Z L}$, respectively.
§The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS.
switching characteristics (see Note 1)

| PARAMETER | 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 \Omega \\ & \mathrm{R} 2=500 \Omega \\ & \mathrm{~T}_{\mathbf{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS877 |  | SN74AS877 |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  | 45 |  | 50 |  | MHz |
| ${ }_{\text {tPLH }}$ | Any A port | Any B port | 2 | 8.5 | 2 | 7 | ns |
| ${ }^{\text {tPHL }}$ |  |  | 3 | 10.5 | 3 | 9 |  |
| ${ }^{\text {tPLH }}$ | Any B port | Any A port | 2 | 9 | 2 | 7.5 | ns |
| ${ }^{\text {tPHL }}$ |  |  | 3 | 10.5 | 3 | 9 |  |
| ${ }^{\text {tPLH }}$ | SO, S1, S2 ${ }^{\text {f }}$ | Any A or B port | 3 | 11.5 | 3 | 10 | ns |
| ${ }_{\text {tPHL }}$ |  |  | 2 | 9.5 | 2 | 8 |  |
| tPLH | CLK | Any A or B port | 2 | 11 | 2 | 9 | ns |
| ${ }^{\text {tPHL }}$ |  |  | 3 | 13 | 3 | 11.5 |  |
| tPLH | CLK | QB | 2 | 10.5 | 2 | 8 | ns |
| ${ }_{\text {t PHL }}$ |  |  | 3 | 10 | 3 | 8.5 |  |
| tPHZ | S0, S1, S2 | Any A or B port | 2 | 7.5 | 2 | 6.5 | ns |
| tpLZ |  |  | 3 | 13 | 3 | 10.5 |  |
| ${ }_{\text {tPZH }}$ |  |  | 2 | 9 | 2 | 7 | ns |
| tPZL |  |  | 3 | 11.5 | 3 | 9.5 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.
IThe positive transition of S2 will cause low-level data at the A output Bus or stored in the shift register to be invalid for 12 ns .

TYPICAL APPLICATION DATA

BUS A TO BUS B OR SERIAL TRANSMISSION

SERIALIN


SERIAL IN TO A PORT
SERIAL IN


BUS B TO BUS A OR
SERIAL TRANSMISSION
SERIAL IN


SERIAL IN TO B PORT
SERIAL IN


## SN54AS882A, SN74AS882A 32-BIT LOOK-AHEAD CARRY GENERATORS

- Directly Compatible with 'AS181B, 'AS1181, 'AS881B, and 'AS1881 ALUs
- Included among the Package Options are Compact, 24-Pin, 300-mil-Wide DIPs and Both 28-Pin Plastic and Ceramic Chip Carriers
- Capable of Anticipating the Carry Across a Group of Eight 4-Bit Binary Adders
- Cascadable to Perform Look-Ahead Across n-Bit Adders
- Typical Carry Time, $C_{n}$ to Any $C_{n+i}$, is Less Than 6 ns
- Dependable Texas Instruments Quality and Reliability


## description

The 'AS882A is a high-speed look-ahead carry generator capable of anticipating the carry across a group of eight 4-bit adders permitting the designer to implement look-ahead for a 32-bit ALU with a single package or, by cascading 'AS882A's, full look-ahead is possible across $n$-bit adders.

The SN54AS882A is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS882A is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.
'AS882A LOGIC EQUATIONS
$\mathrm{C}_{\mathrm{n}}+8=\mathrm{G} 1+\mathrm{P} 1 \mathrm{G} 0+\mathrm{P} 1 \mathrm{POC}_{\mathrm{n}}$
$\mathrm{C}_{\mathrm{n}}+16=\mathrm{G} 3+\mathrm{P} 3 \mathrm{G} 2+\mathrm{P} 3 \mathrm{P} 2 \mathrm{G} 1+\mathrm{P} 3 \mathrm{P} 2 \mathrm{P} 1 \mathrm{G} 0$

+ P3P2P1POC $n$
$C_{n}+24=\mathrm{G} 5+$ P5G4 +P5P4G3 +P5P4P3G2
+P5P4P3P2G1 + P5P4P3P2P1G0
+ P5P4P3P2P1POC $_{n}$
$\mathrm{C}_{\mathrm{n}}+32=\mathrm{G} 7+\mathrm{P} 7 \mathrm{G} 6+\mathrm{P} 7 \mathrm{P} 6 \mathrm{G} 5+\mathrm{P} 7 \mathrm{P} 6 \mathrm{P} 5 \mathrm{G} 4$
+P7P6P5P4G3 + P7P6P5P4P3G2
+P7P6P5P4P3P2G1 + P7P6P5P4P3P2P1G0
+ P7P6P5P4P3P2P1P0C $n_{n}$


SN54AS882A . . . FK PACKAGE SN74AS882A . . . FN PACKAGE (TOP VIEW)

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 DW, JT, and NT packages.


Any inputs not shown in a given table are irrelevant with respect to that output.
logic diagram (positive logic)


Pin numbers shown are for DW, JT, and NT packages.

## SN54AS882A, SN74AS882A <br> 32-BIT LOOK-AHEAD CARRY GENERATORS

```
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
\begin{tabular}{|c|c|c|}
\hline Supply voltage, VCC & & 7 V \\
\hline Input voltage & & 7 V \\
\hline Operating free-air temperature range: & SN54AS882A & \(-55^{\circ} \mathrm{C}\) to \(125^{\circ} \mathrm{C}\) \\
\hline & SN74AS822A & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
\hline Storage temperature range & & \(-65^{\circ} \mathrm{C}\) to \(150^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
```

recommended operating conditions

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

| PARAMETER |  | TEST CONDITIONS | SN54AS882A |  | SN74AS882A |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  | - 1.2 | , |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, to $5.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  | $\mathrm{V}_{\mathrm{CC}}{ }^{-2}$ |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{I}^{\mathrm{OL}}=20 \mathrm{~mA}$ | 0.3 0.5 |  | 0.3 |  | 0.5 | V |
| 1 | $\mathrm{C}_{\mathrm{n}}, \overline{\mathrm{P}} 0, \overline{\mathrm{P}} 1$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=7 \mathrm{~V}$ |  | 0.4 |  |  | 0.4 | mA |
|  | $\overline{\mathrm{G}} 0, \overline{\mathrm{G}} 6$ |  |  | 0.8 |  |  | 0.8 |  |
|  | $\overline{\mathrm{G}} 1, \overline{\mathrm{G}} 2, \overline{\mathrm{G}} 4$ |  |  | 1.2 |  |  | 1.2 |  |
|  | $\overline{\mathrm{G}} 3, \overline{\mathrm{G}} 5$ |  |  | 1.5 |  |  | 1.5 |  |
|  | $\overline{\mathrm{G}} 7$ |  | 0.9 |  | 0.9 |  |  |  |
|  | $\overline{\mathrm{P}} 2, \overline{\mathrm{P}} 3$ |  |  | 0.3 |  |  | 0.3 |  |
|  | $\overline{\mathrm{P}} 4, \overline{\mathrm{P}} 5$ |  |  | 0.2 |  |  | 0.2 |  |
|  | $\overline{\mathrm{P}} 6, \overline{\mathrm{P}} 7$ |  |  | 0.1 |  |  | 0.1 |  |
| ${ }^{1} \mathrm{H}$ | $\mathrm{C}_{\mathrm{n}}, \overline{\mathrm{P}} 0, \overline{\mathrm{P}} 1$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=2.7 \mathrm{~V}$ |  | 80 |  |  | 80 | $\mu \mathrm{A}$ |
|  | Ḡ0, $\overline{\mathrm{G}} 6$ |  |  | 160 |  |  | 160 |  |
|  | $\overline{\mathrm{G}} 1, \overline{\mathrm{G}} 2, \overline{\mathrm{G}} 4$ |  |  | 240 |  |  | 240 |  |
|  | $\overline{\mathrm{G}} 3, \overline{\mathrm{G}} 5$ |  |  | 300 |  |  | 300 |  |
|  | G7 |  |  | 180 |  |  | 180 |  |
|  | $\overline{\mathrm{P}} 2, \overline{\mathrm{P}} 3$ |  |  | 60 |  |  | 60 |  |
|  | $\overline{\mathrm{P}} 4, \overline{\mathrm{P}} 5$ |  |  | 40 |  |  | 40 |  |
|  | $\overline{\mathrm{P}} 6, \overline{\mathrm{P}} 7$ |  |  | 20 |  |  | 20 |  |
| IIL | $\mathrm{C}_{\mathrm{n}}, \overline{\mathrm{P}} 0, \overline{\mathrm{P}} 1$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=0.4 \mathrm{~V}$ |  | -2 |  |  | -2 | mA |
|  | $\overline{\mathrm{G}} 0, \overline{\mathrm{G}} 6$ |  |  | -4 |  |  | -4 |  |
|  | $\overline{\mathrm{G}} 1, \overline{\mathrm{G}} 2, \overline{\mathrm{G}} 4$ |  |  | -6 |  |  | -6 |  |
|  | G33, $\overline{\mathrm{G}} 5$ |  |  | $-7.5$ |  |  | $-7.5$ |  |
|  | G7 |  |  | $-4.5$ |  |  | $-4.5$ |  |
|  | $\overline{\mathrm{P}} 2, \overline{\mathrm{P}} 3$ |  |  | $-1.5$ |  |  | -1.5 |  |
|  | $\overline{\mathrm{P}} 4, \overline{\mathrm{P}} 5$ |  |  | -1 |  |  | -1 |  |
|  | $\overline{\mathrm{P}} 6, \overline{\mathrm{P}} 7$ |  | -0.5 |  | -0.5 |  |  |  |
| $10^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | $-30$ | -130 | $-30$ |  | $-130$ | mA |
| ${ }^{\text {I CC }}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | $44 \quad 70$ |  | $44 \quad 70$ |  |  | 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.

SN54AS882A, SN74AS882A 32-BIT LOOK-AHEAD CARRY GENERATORS
switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V} . \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R}_{\mathrm{L}}=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=\mathrm{MIN} \text { to } \mathrm{MAX} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS822A |  | SN74AS882A |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| tple | $\mathrm{C}_{n}$ | Any output | 2 | 10 | 2 | 9 | ns |
| tPHL |  |  | 3 | 15 | 3 | 14 |  |
| tPLH | $\overline{\mathrm{P}}$ or $\overline{\mathrm{G}}$ | $C_{n+8}$ | 2 | 8 | 2 | 7 |  |
| tPHL |  |  | 2 | 8 | 2 | 7 |  |
| tPLH | $\overline{\mathrm{P}}$ or $\overline{\mathrm{G}}$ | $C_{n+16}$ | 2 | 8 | 2 | 7 |  |
| tPHL |  |  | 2 | 8 | 2 | 7 |  |
| tpLH | $\overline{\mathrm{P}}$ or $\overline{\mathrm{G}}$ | $C_{n+24}$ | 2 | 8 | 2 | 7 |  |
| tphL |  |  | 2 | 11 | 2 | 10 |  |
| tPLH | $\overline{\mathrm{P}}$ or $\overline{\mathrm{G}}$ | $C_{n+32}$ | 1.5 | 9 | 2 | 8 |  |
| tPHL |  |  | 2 | 13 | 2 | 12 |  |

NOTE 1: Load circuits and voltage waveforms are shown in Section 1.

The application given in Figure 1 illustrates how the 'AS882A can implement look-ahead carry for a 32-bit ALU (in this case, the popular 'AS881A) with a single package. Typical carry times shown are derived using the standard Advanced Schottky load circuit.


Likewise, Figure 2 illustrates the same 32-bit ALU using two 'AS882s. This shows the worst-case delay from LSB to MSB to be 19 ns as opposed to 25 ns in Figure 1.


FIGURE 2

## SN54AS885, SN74AS885 8-BIT MAGNITUDE COMPARATORS

- Included among the Package Options Are Compact, 24-Pin, 300-mil DIPs and Both 28-Pin Ceramic and Plastic Chip Carriers
- Latchable P Input Ports with Power-Up Clear
- Choice of Logical or Arithmetic (2's Complement) Comparison
- Data and PLE Inputs Utilize P-N-P Input Transistors to Reduce DC Loading Effects
- Approximately 35\% Improvement in AC Performance Over Schottky TTL while Performing More Functions
- Cascadable to $n$-Bits while Maintaining High Performance
- 10\% Less Power than STTL for an 8-Bit Comparison
- Dependable Texas Instruments Quality and Reliability


## description

These advanced Schottky devices are capable of performing high-speed arithmetic or logic comparisons on two 8-bit binary or two's complement words. Two fully decoded decisions about words P and Q are externally available at two outputs. These devices are fully expandable to any number of bits without external gates. The $\mathrm{P}>\mathrm{Q}$ and $\mathrm{P}<\mathrm{Q}$ outputs of a stage handling less-significant bits may be connected to the $P>Q$ and $P<Q$ inputs of the next stage handling more-significant bits to obtain comparisons of words of longer lengths. The cascading paths are implemented with only a two-gate-level delay to reduce overall comparison times for long words. Two alternative methods of cascading are shown in the typical application data.

The latch is transparent when $P$ Latch Enable (PLE) is high; the $P$ input port is latched when PLE is low. This provides the designer with temporary storage for the $P$ data word. The enable circuitry is implemented with minimal delay times to enhance performance when cascaded for longer words. The PLE and P and $Q$ data inputs utilize p-n-p input transistors to reduce the low-level current input requirement to typically - 0.25 mA , which minimizes dc loading effects.

The SN54AS885 is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS885 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## SN54AS885, SN74AS885

8-BIT MAGNITUDE COMPARATORS
logic diagram (positive logic)


Pin numbers shown are for DW, JT, and NT packages.
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 DW, JT, and NT packages.

FUNCTION TABLE

| COMPARISON | L/ $\bar{A}$ | DATA INPUTS <br> PO-P7, 00-07 | $\begin{gathered} \text { INPUT } \\ \text { P>O } \end{gathered}$ | $\begin{gathered} \text { INPUT } \\ \mathrm{P}<\mathrm{Q} \end{gathered}$ | OUTPUTS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\mathrm{P}>0$ | $\mathrm{P}<0$ |
| LOGICAL | H | $\mathrm{P}>0$ | X | X | H | L |
| LOGICAL | H | $\mathrm{P}<\mathrm{Q}$ | x | X | L | H |
| LOGICAL $\ddagger$ | H | $\mathrm{P}=0$ | H ORL | H OR L | H ORL | H ORL |
| ARITHMETIC | L | PAG Q | X | X | H | L |
| ARITHMETIC | L | Q AG P | X | X | L | H |
| ARITHMETIC ${ }^{\ddagger}$ | L | $P=0$ | H OR L | H OR L | H ORL | H OR L |

[^41]absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

recommended operating conditions

| PARAMETER |  | SN54AS885 |  |  | SN74AS885 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  |  | -2 |  |  | -2 | mA |
| ${ }^{\text {IOL}}$ | . Low-level output current |  |  | 20 |  |  | 20 | mA |
| $\mathrm{t}_{\text {su }}$ | Setup time to PLE $\downarrow$ | 2 |  |  | 2 |  |  |  |
| $t_{h}$ | Hold time after PLE $\downarrow$ | 4 |  |  | 4 |  |  | ns |
| TA | Operating free-air temperature | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

| PARAMETER |  | TEST CONDITIONS |  | SN54AS885 |  |  | SN74AS885 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\text { }}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5$ to $5.5 \mathrm{~V}, 1 \mathrm{OH}=-2 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | $1 \mathrm{OL}=20 \mathrm{~mA}$ |  | 0.35 | 0.5 |  | 0.35 | 0.5 | V |
| 1 |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | $\mu \mathrm{A}$ |
| 1 | L/ $\bar{A}$ | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 40 |  |  | 40 | $\mu \mathrm{A}$ |
| Ith | Others |  |  |  |  | 20 |  |  | 20 |  |
| IIL | $L / \bar{A}$ | $\mathrm{V}_{C C}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=0.4 \mathrm{~V}$ |  |  |  | -4 |  |  | -4 | mA |
|  | $\begin{aligned} & P>a_{i n} \\ & P<a_{i n} \end{aligned}$ |  |  |  |  | -2 |  |  | -2 |  |
|  | P, Q, PLE |  |  |  |  | -1 |  |  | -1 |  |
| $\frac{10}{10}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -20 |  | $-112$ | -20 |  | -112 | mA |
|  |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ | See Note 1 |  | 130 | 210 |  | 130 | 210 | mA |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
$\ddagger$ Fhe output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit current, IOS. NOTE 1: ${ }^{\mathrm{I}} \mathrm{CC}$ is measured with all inputs high except $L / \bar{A}$, which is low.
switching characteristics (see Note 2)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS885 |  |  | SN74AS885 |  |  |  |
|  |  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| tPLH | L/A | $\begin{aligned} & P<0 \\ & P>0 \end{aligned}$ |  | 8.5 | 14 |  | 8.5 | 13 | ns |
| tPHL |  |  |  | 7.5 | 14 |  | 7.5 | 13 |  |
| tPLH | $\begin{aligned} & \mathrm{P}<\mathrm{Q}_{\text {in }} \\ & \mathrm{P}>\mathrm{Q}_{\text {in }} \end{aligned}$ |  |  | 5 | 10 |  | 5 | 8 | ns |
| tPHL |  |  |  | 5.5 | - 10 |  | 5.5 | 8 |  |
| tPLH | Any P or Q Data Input |  |  | 13.5 | 21 |  | 13.5 | 17.5 | ns |
| tPHL |  |  |  | 10 | 17 |  | 10 | 15 |  |

$\dagger_{\text {All typical values are at }} \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
NOTE 2: Load circuit and voltage waveforms are shown in Section 1.

## SN54AS885, SN74AS885 8-BIT MAGNITUDE COMPARATORS

## TYPICAL APPLICATION DATA

The 'AS885 can be cascaded to compare words longer than 8-bits. Figure 1 shows the comparison of two 32-bit words; however, the design is expandable to $n$-bits. Figure 1 shows the optimum cascading arrangement for comparing words of 32 bits or greater. Typical delay times shown are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, and use the standard Advanced Schottky load of $R_{L}=500 \Omega, C_{L}=50 \mathrm{pF}$.


FIGURE 1. 32-BIT TO 72 (N)-BIT MAGNITUDE COMPARATOR

## TYPICAL APPLICATION DATA

The method shown in Figure 2 is the fastest cascading arrangement for comparing 16-bit or 24-bit words. Typical delay times shown are at $\mathrm{V}_{\mathrm{C}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, and use the standard Advanced Schottky load of $\mathrm{R}_{\mathrm{L}}=500 \Omega$, $C_{L}=50 \mathrm{pF}$.


FIGURE 2

- STL-AS Technology
- Parallel 8-Bit ALU with Expansion Inputs and Outputs
- 13 Arithmetic and Logic Functions
- 8 Conditional Shifts (Single and Double Length)
- 4 Instructions that Manipulate Bits
- Add and Subtract Immediate Instructions
- Absolute Value Instruction
- Signed Magnitude to/from Two's Complement Conversion
- Single- and Double-Length Normalize
- Select Functions
- Signed and Unsigned Divides with Overflow Detection; Input does not Need to be Prescaled
- Signed, Mixed, and Unsigned Multiplies
- Three-Operand, 16-Word Register File
- Full Carry Look Ahead Support
- Sign, Carry Out, Overflow, and Zero-Detect Status Capabilities
- Excess-3 BCD Arithmetic
- Internal Shift Multiplexers that Eliminate the Need for External Shift Control Parts
- ALU Bypass Path to Increase Speeds of Multiply, Divide, and Normalize Instructions and to Provide New Instructions such as Bit Set, Bit Reset, and Bit Test
- 3-Operand Register Files to Allow an Operation and a Move Instruction to be Combined
- Bit Masks that are Shared with Register Address Fields to Minimize Control Store Word Width
- 3 Data Input/Output Paths to Maximize Data Throughput


## description

These 8-bit Advanced Schottky TTL integrated circuits are designed to implement high performance digital computers or controllers. An architecture and instruction set has been chosen that supports a fast system clock, a narrow micro-code word width, and a high system throughput. The powerful instruction set allows high-speed system architecture to be implemented and also allows an existing system's performance to be upgraded while protecting software investments. These processors are non-cascadable versions of the 'AS888. They are designed for 8 -bit applications only.

The SN54AS887 is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS887 and SN74AS887-1 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

Package options include both plastic and ceramic chip carriers in addition to a 68-pin grid array ceramic package.


GB PACKAGE PIN ASSIGNMENTS

| PIN | NAME | PIN | NAME | PIN | NAME | PIN | NAME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A-2 | $\mathrm{C}_{\mathrm{n}}$ | B-9 | $\overline{O E Y}$ | F-10 | Y3 | K-4 | C2 |
| A-3 | $\overline{\mathrm{SIOO}}$ | B-10 | YO | F-11 | DB2 | K-5 | AO |
| A-4 | $\overline{\mathrm{Q} 100}$ | B-11 | Y1 | G-1 | DA2 | K-6 | A3 |
| A-5 | व107 | C-1 | 15 | G-2 | DAO | K-7 | $\overline{W E}$ |
| A-6 | $\mathrm{C}_{\mathrm{n}+8}$ | C-2 | $\mathrm{v}_{\mathrm{CC} 2}$ | G-10 | DBO | K-8 | DB7 |
| A-7 | N | C-10 | Y4 | G-11 | DB3 | K-9 | $\overline{\mathrm{OEB}}$ |
| A-8 | OVR | C-11 | Y6 | H-1 | DA3 | K-10 | EBO |
| A-9 | ZERO | D-1 | 16 | H-2 | DA1 | K-11 | EB1 |
| A-10 | TEST | D-2 | $\mathrm{V}_{\mathrm{CC} 1}$ | H-10 | DB6 | L-2 | CK |
| B-1 | 12 | D-10 | Y5 | H-11 | DB4 | L-3 | C1 |
| B-2 | 13 | D-11 | Y7 | J-1 | DA4 | L-4 | C3 |
| B-3 | 11 | E-1 | 17 | J-2 | DA5 | L-5 | A1 |
| B-4 | 10 | E-2 | $\overline{\text { OEA }}$ | J-10 | SELY | L-6 | A2 |
| B-5 | 14 | E-10 | Y2 | J-11 | DB5 | L-7 | B3 |
| B-6 | $\overline{5107}$ | E-11 | DB1 | K-1 | DA6 | L-8 | B2 |
| B-7 | SSF | F-1 | $\overline{E A}$ | K-2 | DA7 | L-9 | B1 |
| B-8 |  | F-2 | GND | K-3 | CO | L-10 | BO |


| PIN GRID ARRAY | CHIP CARRIER | NAME | 1/0 | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| A-10 | 28 | TEST | 1 | Test input pin. Connected to ground for normal operation. |
| B-7 | 29 | SSF | 1/0 | Special shift function. Used to transfer required information between packages during special instruction execution. |
| A-9 | 30 | ZERO | 1/O | Device zero detection, open collector. Input during certain special instructions. |
| A-8 | 31 | OVR | 0 | ALU overflow, low active. |
| A-7 | 32 | N | 0 | ALU negative, low active. |
| A-6 | 33 | $\mathrm{C}_{\mathrm{n}+8}$ | 0 | ALU ripple carry output. |
| B-6 | 34 | $\overline{\mathrm{SIO7}}$ | 1/0 |  |
| A-5 | 35 | $\overline{\mathrm{Q107}}$ | 1/0 |  |
| A-4 | 36 | $\overline{\mathrm{Q1OO}}$ | 1/0 | Bidirectional shift pin, low active. |
| A-3 | 37 | $\overline{\mathrm{SIOO}}$ | 1/0 |  |
| A-2 | 38 | $\mathrm{C}_{\mathrm{n}}$ | 1 | ALU carry input. |
| B-4 | 39 | 10 | 1 |  |
| B-3 | 40 | 11 | 1 |  |
| B-1 | 41 | 12 | 1 |  |
| B-2 | 42 | 13 | 1 | Instruction input |
| B-5 | 43 | 14 | 1 | Instruction input. |
| C-1 | 44 | 15 | 1 |  |
| D-1 | 45 | 16 | 1 |  |
| E-1 | 46 | 17 | 1 |  |
| C-2 | 47 | $\mathrm{V}_{\mathrm{CC} 2}$ |  | Low voltage power supply (2 V). |
| D-2 | 48 | $\mathrm{V}_{\mathrm{CC} 1}$ |  | $1 / \mathrm{O}$ interface supply voltage ( 5 V ). |
| E-2 | 49 | $\overline{\text { OEA }}$ | 1 | DA bus enable, low active. |
| F-1 | 50 | $\overline{\mathrm{EA}}$ | 1 | ALU input operand select. High state selects external DA bus and low state selects register file. |
| F-2 | 51 | GND |  | Ground pin. |
| G-2 | 52 | DAO | 1/0 |  |
| $\mathrm{H}-2$ | 53 | DA1 | 1/0 |  |
| G-1 | 54 | DA2 | 1/0 |  |
| H-1 | 55 | DA3 | 1/0 | A port data bus. Outputs register file data $(\overline{E A}=0)$ or inputs external data $(\overline{\mathrm{EA}}=1)$. |
| J-1 | 56 | DA4 | 1/0 | A port data bus. Outputs register file data (EA = O) or inputs external data (EA = 1). |
| J-2 | 57 | DA5 | 1/0 |  |
| K-1 | 58 | DA6 | 1/0 |  |
| K-2 | 59 | DA7 | 1/0 |  |
| L-2 | 60 | CK | 1 | Clocks all synchronous registers on positive edge. |
| K-3 | 61 | CO | 1 |  |
| L-3 | 62 | C1 | 1 | Register file write address select. |
| K-4 | 63 | C2 | 1 | Register file write address select. |
| L-4 | 64 | C3 | 1 |  |
| K-5 | 65 | AO | 1 |  |
| L-5 | 66 | A1 | 1 | Register file A port read address select. |
| L-6 | 67 | A2 | 1 | Register file A port read address select. |
| K-6 | 68 | A3 | 1 |  |

SN54AS887, SN74AS887
8-BIT PROCESSORS

| PIN GRID ARRAY | $\begin{gathered} \text { CHIP } \\ \text { CARRIER } \end{gathered}$ | NAME | 1/0 | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| K-7 | 1 | $\overline{\text { WE }}$ | 1 | Register file (RF) write enable. Data is written into RF when $\overline{\mathrm{WE}}$ is low and a low-to-high clock transition occurs. RF write is inhibited when $\overline{W E}$ is high. |
| L-7 | 2 | B3 | 1 |  |
| L-8 | 3 | B2 | 1 | Register file B port read address select. $(0=$ LSB). |
| L-9 | 4 | B1 | 1 | Register file B port read address select. |
| L-10 | 5 | B0 | 1 |  |
| K-10 | 6 | EBO | 1 | ALU input operand select. EBO and EB1 selects the source of data that the S multiplexer |
| K-11 | 7 | EB1 | 1 | provides for the $S$ bus. Independent control of the DB bus and data path selection allow the user to isolate the DB bus while the ALU continues to process data. |
| K-9 | 8 | $\overline{\mathrm{OEB}}$ | 1 | DB bus enable, low active. |
| K-8 | 9 | DB7 | 1/0 |  |
| H-10 | 10 | DB6 | 1/0 |  |
| J-11 | 11 | DB5 | 1/0 |  |
| H-11 | 12 | DB4 | 1/0 | B port data bus. Outputs register data ( $\overline{O E B}=0$ ) or used to input external data |
| G-11 | 13 | DB3 | 1/0 | $(\overline{O E B}=1),(0=L S B)$. |
| F-11 | 14 | DB2 | 1/0 |  |
| E-11 | 15 | DB1 | 1/0 |  |
| G-10 | 16 | DBO | 1/0 |  |
| J-10 | 17 | SELY | 1 | Y bus select, high active. |
| D-11 | 18 | Y7 | 1/0 |  |
| C-11 | 19 | Y6 | 1/0 |  |
| D-10 | 20 | Y5 | 1/0 |  |
| C-10 | 21 | Y4 | 1/0 | Y port data bus. Outputs instruction results ( $\overline{\mathrm{OEY}}=0$ ) or used to put external data into |
| F-10 | 22 | Y3 | 1/0 | register file ( $\overline{O E Y}=1$ ). |
| E-10 | 23 | Y2 | 1/0 |  |
| B-11 | 24 | Y1 | 1/0 |  |
| B-10 | 25 | Yo | 1/0 |  |
| B-9 | 26 | $\overline{\mathrm{OEY}}$ | 1 | Y bus output enable, low active. |
| F-2 | 27 | GND |  | Ground pin |

functional block diagram


## architectural elements

## 3-port register file

Working registers consist of 128 storage elements organized into sixteen 8 -bit words. These storage elements appear to the user as 16 positive edge-triggered registers. The three port addresses, one write (C) and two reads (A and B), are completely independent of each other to implement a 3-operand register file. Data is written into the register file when $\overline{W E}$ is low and a low-to-high clock transition occurs. The ADD and SUBTRACT immediate instructions require only one source operand. The B address is used as the source address, and the bits of the $A$ address are used to provide a constant field. The SET, RESET, and TEST BIT instructions use the B addressed register as both the source and destination register while the $A$ and $C$ addresses are used as masks. These instructions are explained in more detail in the instruction section.

## S multiplexer

The S multiplexer selects the ALU operand, as follows:

| EB1 | EB0 | S bus |
| :--- | :--- | :--- |
| Low | Low | RF data |
| Low | High | MO data |
| High | Low | DB data |
| High | High | MO data |

DB port
The 8-bit bidirectional DB port inputs external data to the ALU or outputs the register file. If $\overline{O E B}$ is low, the DB bus is active; if $\overline{\mathrm{OEB}}$ is high, the DB bus is in the high impedance state. Notice that the DB port may be isolated at the same time that register file data is passed to the ALU.

## R multiplexer

The R multiplexer selects the other operand of the ALU. Except for those instructions that require constants or masks, the R bus will contain DA if $\overline{E A}$ is high or the RF data pointed to by $A$ if $\overline{E A}$ is low.

DA port
The 8-bit bidirectional DA port inputs external data to the ALU or outputs the register file. If $\overline{O E A}$ is low, the DA bus is active; if $\overline{O E A}$ is high, the DA bus is in the high-impedance state.

Notice that the DA bus may be isolated while register file data is passed to the ALU.

## ALU

The shift instructions are summarized in Table 4 and illustrated in Figure 2. The ALU can perform seven arithmetic and six logical instructions on two 8-bit operands. It also supports multiplication, division, normalization, bit set, reset, test, byte operations, and excess-3 BCD arithmetic. These source operands are the outputs of the $S$ and $R$ multiplexers.

## ALU and MQ shifters

ALU and MQ shifters perform all of the shift, multiply, divide, and normalize functions. Table 4 shows the value of the $\overline{\mathrm{SIO7}}$ and $\overline{\mathrm{QIO7}}$ pins of the most significant package. The standard shifts may be made into conditional shifts and the serial data may be input or output with the aid of two three-state gates. These capabilities are discussed further in the arithmetic and logic section.

## MO register

The multiplier-quotient (MQ) register has specific functions in multiplication, division, and normalization. This register may also be used as a temporary storage register. The MQ register may be loaded if the instruction code on pins 17-10 is E1-E7 or E9-EE (See Table 1).

## $Y$ bus

The $Y$ bus contains the output of the ALU shifter if $\overline{\mathrm{OEY}}$ is low and is a high impedance input if $\overline{\mathrm{OEY}}$ is high. SELY must be low to pass the internal ALU shift bus and must be high to pass the external $Y$ bus to the register file.

## status

Four status pins are available on the most significant package, overflow (OVR), sign ( $N$ ), carry out ( $C_{n}+8$ ), and zero (ZERO). The $C_{n}+8$ line signifies the ALU result while OVR, ZERO, and $N$ refer the status after the ALU shift has occurred. Notice that the ZERO pin cannot be used to detect whether an input placed on a high impedance $Y$ bus is zero.

## divide BCD flip-flops

The multiply-divide flip-flops contain the status of the previous multiply or divide instruction. They are affected by the following instructions:

```
DIVIDE REMAINDER FIX
SIGNED DIVIDE QUOTIENT FIX
SIGNED MULTIPLY
SIGNED MULTIPLY TERMINATE
SIGNED DIVIDE INITIALIZE
SIGNED DIVIDE START
```


## SIGNED DIVIDE ITERATE UNSIGNED DIVIDE START UNSIGNED DIVIDE ITERATE UNSIGNED MULTIPLY SIGNED DIVIDE TERMINATE UNSIGNED DIVIDE TERMINATE

The excess-3 BCD flip-flops are affected by all instructions except NOP. The clear function clears these flip-flops. They preserve the carry from each nibble (4-bits) in excess-3/BCD operations.

## test pin (test)

This pin should be connected to ground.

## special shift function (SSF) pin

Conditional shifting algorithms may be implemented via control of the SSF pin. The applied voltage to this pin may be set as a function of a potential overflow condition (the two most significant bits are not equal) or any other condition (see Group 1 instructions).

## instruction set

The 'AS887 bit-slice processor uses bits 17-10 as instruction inputs. A combination of bits 13-10 (Group 1 instructions) and bits $17-14$ (Group 2-5 instructions) are used to develop the 8 -bit op code for a specific instruction. Group 1 and Group 2 instructions can be combined to perform arithmetic or logical functions plus a shift function in one instruction cycle. A summary of the instruction set is given in Table 1.

TABLE 1. INSTRUCTION SET
GROUP 1 INSTRUCTIONS

| INSTRUCTION BITS (I3-IO) HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :---: |
| $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 8 \\ & 9 \\ & 9 \\ & \mathrm{~A} \\ & \mathrm{~B} \\ & \mathrm{C} \\ & \mathrm{D} \\ & \mathrm{E} \end{aligned}$ | ADD <br> SUBR <br> SUBS <br> INCS <br> INCNS <br> INCR <br> INCNR <br> XOR <br> AND <br> OR <br> NAND <br> NOR <br> ANDNR | Accesses Group 4 instructions $\begin{aligned} & R+S+C_{n} \\ & \bar{R}+S+C_{n} \\ & R+\bar{S}+C_{n} \\ & S+C_{n} \\ & \bar{S}+C_{n} \\ & R+C_{n} \\ & \bar{R}+C_{n} \end{aligned}$ <br> Accesses Group 3 instructions <br> R XOR S <br> R AND S <br> R OR S <br> R NAND S <br> R NOR S <br> $\overline{\mathrm{R}}$ AND S <br> Accesses Group 5 instructions |
| GROUP 2 INSTRUCTIONS |  |  |
| INSTRUCTION BITS (17-14) hex Code | MNEMONIC | FUNCTION |
|  | SRA <br> SRAD <br> SRL <br> SRLD <br> SLA <br> SLAD <br> SLC <br> SLCD <br> SRC <br> SRCD <br> MIOSRA <br> MOSRL <br> MOSLL <br> MOSLC <br> LOADMQ <br> PASS | Arithmetic Right Single <br> Arithmetic Right Double <br> Logical Right Single <br> Logical Right Double <br> Arithmetic Left Single <br> Arithmetic Left Double <br> Circular Left Single <br> Circular Left Double <br> Circular Right Single <br> Circular Right Double <br> Pass ( $F \rightarrow Y$ ) and Arithmetic Right MQ <br> Pass $(F \rightarrow Y)$ and Logical Right MQ <br> Pass $(F \rightarrow Y)$ and Logical Left MQ <br> Pass $(F \rightarrow Y)$ and Circular Left MQ <br> Pass $(F \rightarrow Y)$ and Load MQ $(F=M Q)$ <br> Pass $(F \rightarrow Y)$ |

TABLE 1. INSTRUCTION SET (Continued)
GROUP 3 INSTRUCTIONS

| INSTRUCTION BITS (17-IO) hex Code | MNEMONIC | FUNCTION |
| :---: | :---: | :---: |
| 08 18 28 38 48 58 68 78 88 98 A8 $B 8$ $C 8$ $D 8$ $E 8$ $F 8$ | SET1 <br> SETO <br> TB1 <br> TBO <br> ABS <br> SMTC <br> ADDI <br> SUBI | Set Bit <br> Reset Bit <br> Test Bit (One) <br> Test Bit (Zero) <br> Absolute Value <br> Sign Magnitude/Two's Complement <br> Add Immediate <br> Subtract Immediate <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved <br> Reserved |
| GROUP 4 INSTRUCTIONS |  |  |
| INSTRUCTION BITS (17-IO) HEX CODE | MNEMONIC | FUNCTION |
| 00 10 20 30 40 50 60 70 80 90 AO $B O$ $C O$ $D O$ $E O$ FO | SEL <br> SNORM <br> DNORM <br> DIVRF <br> SDIVQF <br> SMULI <br> SMULT <br> SDIVIN <br> SDIVIS <br> SDIVI <br> UDIVIS <br> UDIVI <br> UMULI <br> SDIVIT <br> UDIVIT | Reserved <br> Select S/R <br> Single Length Normalize <br> Double Length Normalize <br> Divide Remainder Fix <br> Signed Divide Quotient Fix <br> Signed Multiply Iterate <br> Signed Multiply Terminate <br> Signed Divide Initialize <br> Signed Divide Start <br> Signed Divide Iterate <br> Unsigned Divide Start <br> Unsigned Divide Iterate <br> Unsigned Multiply Iterate <br> Signed Divide Terminate <br> Unsigned Divide Terminate |

SN54AS887, SN74AS887
8-BIT PROCESSORS

TABLE 1. INSTRUCTION SET (Concluded)
GROUP 5 INSTRUCTIONS

| INSTRUCTION BITS (17-IO) <br> HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| OF | CLR | Clear |
| $1 F$ | CLR | Clear |
| $2 F$ | CLR | Clear |
| $3 F$ | CLR | Clear |
| $4 F$ | CLR | Clear |
| $5 F$ | CLR | Clear |
| $6 F$ | CLR | Clear |
| $7 F$ | BCDBIN | BCD to Binary |
| $8 F$ |  | Reserved |
| $9 F$ | EX3C | Excess-3 Word Correction |
| AF | SDIVO | Signed Divide Overflow Check |
| BF | CLR | Clear |
| CF | CLR | Clear |
| DF | BINEX3 | Binary to Excess-3 |
| EF | CLR | Clear |
| FF | NOP | No Operation |

group 1 instructions
TABLE 2. GROUP 1 INSTRUCTIONS

| INSTRUCTION BITS (I3-IO) <br> HEX CODE | MNEMONIC | FUNCTION |
| :---: | :--- | :--- |
| 0 |  | Accesses Group 4 instructions |
| 1 | ADD | $R+S+C_{n}$ |
| 2 | SUBR | $\bar{R}+S+C_{n}$ |
| 3 | SUBS | $R+\bar{S}+C_{n}$ |
| 4 | INCS | $S+C_{n}$ |
| 5 | INCNS | $\bar{S}+C_{n}$ |
| 6 | INCR | $R+C_{n}$ |
| 7 | INCNR | $\bar{R}+C_{n}$ |
| 8 |  | Accesses Group 3 instructions |
| 9 | XOR | $R$ XOR S |
| A | AND | $R$ AND S |
| B | OR | $R$ OR S |
| C | NAND | $R$ NAND S |
| D | NOR | $R$ NOR S |
| E | ANDNR | $\bar{R}$ AND S |
| F |  | Accesses Group 5 instructions |

Group 1 instructions (excluding hex codes 0,8 , and $F$ ), shown in Table 2, may be used in conjunction with Group 2 shift instructions to perform arithmetic or logical functions plus a shift function ${ }^{\dagger}$ in one instruction cycle (hex codes 0,8 , and $F$ are used to access Group 4, 3, and 5 instructions, respectively). Each shift may be made into a conditional shift by forcing the special shift function (SSF) pin into the proper state. If the SSF pin is high or floating, the shifted ALU output will be sent to the output buffers. If the SSF pin is pulled low externally, the ALU result will be passed directly to the output buffers. Conditional shifting is useful for scaling inputs in data arrays or in signal processing algorithms.
These instructions set the BCD flip-flop for the excess-3 correct instruction. The status is set with the following results ( $C_{n}+8$ is ALU carry out and is independent of shift operation; others are evaluated after shift operation).
${ }^{\dagger}$ Double-precision shifts involve both the $A L U$ and MQ register.
Status is set with the following results:
Arithmetic

| N | $\rightarrow$ | MSB of result |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Signed arithmetic overflow |
| $\mathrm{C}_{n}+8$ | $\rightarrow$ | Carry out equal one |
| Z | $\rightarrow$ | Result equal zero |

Logic
$\mathrm{N} \quad \rightarrow \quad$ MSB of result
OVR $\rightarrow$ None (force to zero)
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow$ None (force to zero)
Z $\quad \rightarrow \quad$ Result equal zero
group 2 instructions
TABLE 3. GROUP 2 INSTRUCTIONS

| INSTRUCTION BITS (I7-I4) <br> HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| 0 | SRA | Arithmetic Right Single |
| 1 | SRAD | Arithmetic Right Double |
| 2 | SRL | Logical Right Single |
| 3 | SRLD | Logical Right Double |
| 4 | SLA | Arithmetic Left Single |
| 5 | SLAD | Arithmetic Left Double |
| 6 | SLC | Circular Left Single |
| 7 | SLCD | Circular Left Double |
| 8 | SRC | Circular Right Single |
| 9 | SRCD | Circular Right Double |
| A | MQSRA | Pass $(F \rightarrow Y)$ and Arithmetic Right MQ |
| B | MQSRL | Pass $(F \rightarrow Y)$ and Logical Right MQ |
| C | MQSLL | Pass $(F \rightarrow Y)$ and Logical Left MQ |
| D | MQSLC | Pass $(F \rightarrow Y)$ and Circular Left MQ |
| E | LOADMQ | Pass $(F \rightarrow Y)$ and Load MQ $(F=M Q)$ |
| $F$ | PASS | Pass $(F \rightarrow Y)$ |

## SN54AS887, SN74AS887 8-BIT PROCESSORS

The processor's shift instructions are implemented using Group 2 instructions (Table 3). The connections are the same on all instructions including multiply, divide, and normalization functions.

The following external connections are required:

$$
\frac{\overline{\mathrm{SIO7}} \text { to } \overline{\mathrm{SIOD}}}{}
$$

Single- and double-precision shifts are supported. Double-precision shifts assume the most significant half has come through the ALU and will be placed (if $\overline{W E}$ is low) into the register file on the rising edge of the clock and the least significant half lies in the MQ register. All Group 2 shifts may be made conditional. (see previous page)

The following definitions apply to Group 2 shift instructions:
Arithmetic right shifts copy the sign of the number if no overflow occurs from the ALU calculation; if overflow occurs, the sign bit is inverted.
Arithmetic left shifts do not retain the sign of the number if an overflow occurs. A zero is filled into the LSB if not forced externally.
Logical right shifts fill a zero in the MSB position if not forced externally.
Circular right shifts fill the LSB in the MSB position.
Circular left shifts fill the MSB in the LSB position.
Shifting left is defined as moving a bit position towards the MSB (doubling).
Shifting right is defined as moving a bit towards the LSB (halving).


FIGURE 1. SERIAL I/O

## SN54AS887, SN74AS887 8-BIT PROCESSORS

Serial input may be performed using the circuitry shown in Figure 1. A single-/or double-precision arithmetic left or logical right shift fills the complement of the data on $\overline{\mathrm{SIOO}}$ and $\overline{\mathrm{SIO7}}$ into the LSB or MSB of the data word(s). Note that if $\overline{\mathrm{SIOO}}$ and $\overline{\mathrm{SIO7}}$ are floating $(\mathrm{HI}-\mathrm{Z})$, a zero will be filled as an end condition.
Serial output may be performed with circular instructions.
The shift instructions are summarized in Table 4 and illustrated in Figure 2. In Figure 2 and all succeeding figures that illustrate instruction execution, the following definitions apply:

QBT - End fill for signed divide.
MQF - End fill for unsigned divide.
SRF - End fill for signed multiply and the arithmetic right shifts.
TABLE 4. SHIFT INSTRUCTIONS

| OP <br> CODE | SHIFT FUNCTION $\ddagger$ | SIO7 • SIOO <br> WIRED VALUE | QIO7 • QIOO <br> WIRED VALUE |
| :---: | :--- | :--- | :--- |
| ON | Arithmetic Right Single | ALU-LSB Output | - |
| 1 N | Arithmetic Right Double | MQ-LSB Output | ALU-LSB Output |
| 2 N | Logical Right Single | Input to ALU-MSB | ALU-LSB Output |
| 3 N | Logical Right Double | Input to ALU-MSB | ALU-LSB Output |
| 4 N | Arithmetic Left Single | Input to ALU-LSB | ALU-MSB Output |
| 5 N | Arithmetic Left Double | Input to MQ-LSB | MQ-MSB Output |
| 6 N | Circular Left Single | ALU-MSB Output | - |
| 7 N | Circular Left Double | ALU-MSB Output | MQ-MSB Output |
| 8 N | Circular Right Single | ALU-LSB Output | - |
| 9 N | Circular Right Double | MQ-LSB Output | ALU-LSB Output |
| AN | Arithmetic Right (MQ only) | MQ-LSB Output | MQ-LSB Output |
| BN | Logical Right (MQ only) | MQ-LSB Output | Input to MQ-MSB |
| CN | Logical Left (MQ only) | Input to MQ-LSB | MQ-MSB Output |
| DN | Circular Left (MQ only) | MQ-MSB Output | MQ-MSB Output |

${ }^{\dagger}$ Op Code $N \neq 0,8$, or $F$; these select special instruction Groups 4, 3, and 5 respectively.
${ }^{\ddagger}$ Shift I/O pins are active low. Therefore, inputs and outputs must be inverted if true logical values are required.

Status is set with the following results:
Arithmetic
$\mathrm{N} \quad \rightarrow \quad$ Result $\dot{M} S B$ equal one
OVR $\rightarrow$ Signed arithmetic overflow ${ }^{\dagger}$
$C_{n}+8 \rightarrow$ Carry out equal one
$\mathrm{Z} \quad \rightarrow \quad$ Result equal zero
Logic
$\mathrm{N} \quad \rightarrow \quad$ Result MSB equal one
OVR $\rightarrow$ Zero
$\mathrm{C}_{\mathrm{n}+8} \rightarrow$ Zero
Z $\rightarrow$ Result equal zero

[^42]

ARITHMETIC RIGHT DOUBLE


FIGURE 2. SHIFT INSTRUCTIONS


LOGICAL RIGHT DOUBLE
FILLS ZERO IF NOT FORCED


FIGURE 2. SHIFT INSTRUCTIONS (Continued)

FILLS ZERO IF NOT FORCED


ARITHMETIC LEFT DOUBLE
FILLS ZERO IF NOT FORCED


FIGURE 2. SHIFT INSTRUCTIONS (Continued)



FIGURE 2. SHIFT INSTRUCTIONS (Continued)


CIRCULAR RIGHT DOUBLE


FIGURE 2. SHIFT INSTRUCTIONS (Continued)

SERIAL DATA OUT


LOGICAL RIGHT (MQ ONLY)


FILLS ZERO IF NOT FORCED
FIGURE 2. SHIFT INSTRUCTIONS (Continued)

FILLS ZERO IF NOT FORCED


CIRCULAR LEFT (MQ ONLY)


FIGURE 2. SHIFT INSTRUCTIONS (Concluded)

## group 3 instructions

Hex code 8 of Group 1 instructions is used to access Group 3 instructions. Group 3 instructions are summarized in Table 5.

TABLE 5. GROUP 3 INSTRUCTIONS

| INSTRUCTION BITS (I7-IO) <br> OP CODE (HEX) | MNEMONIC | FUNCTION |
| :---: | :--- | :--- |
| 08 | SET1 | Set Bit |
| 18 | SETO | Reset Bit |
| 28 | TB1 | Test Bit (One) |
| 38 | TBO | Test Bit (Zero) |
| 48 | ABS | Absolute Value |
| 58 | SMTC | Sign Magnitude/Two's Complement |
| 68 | ADDI | Add Immediate |
| 78 | SUBI | Subtract Immediate |
| 88 |  | Reserved |
| 98 |  | Reserved |
| A8 |  | Reserved |
| B8 |  | Reserved |
| C8 |  | Reserved |
| D8 |  | Reserved |
| E8 |  |  |
| R8 |  |  |

## SN54AS887, SN74AS887

 8-BIT PROCESSORSset bit instruction (set 1 ): $17-10=0816$
This instruction (Figure 3) is used to force selected bits to one (any combination of zero to eight bits). The desired bits are specified by an 8-bit mask (C3-C0)::(A3-AO) ${ }^{\dagger}$ consisting of register file address ports that are not required to support this instruction. All bits that are in the same bit positions as ones in the mask are forced to a logical one. The B3-BO address field is used for both source and destination of this instruction. The S bus is the source word for this instruction. $\overline{\mathrm{SIOO}}$ must be forced low for proper operation. If $\overline{\mathrm{SIOO}}$ is high, data on the S bus is passed unaltered. The status set by the set bit instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { None (force to zero) } \\
\mathrm{OVR}^{2} & \rightarrow & \text { None (force to zero) } \\
\mathrm{C}_{n}+8 & \rightarrow & \text { None (force to zero) } \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

$\dagger$ The symbol ' $::$ ' is concatenation operator
reset bit instruction (set0): $17-10=1816$
This instruction (Figure 3) is used to force selected bits to zero. The desired bits are specified by an 8 -bit mask (C3-C0)::(A3-AO) consisting of register file address ports that are not required to support this instruction. All bits in the selected byte(s) that are in the same bit positions as ones in the mask are reset. The B3-BO address field is used for both source and destination of this instruction. The S bus is the source word for this instruction. $\overline{\mathrm{SIOO}}$ must be forced low for proper operation. If $\overline{\mathrm{SIOO}}$ is high, data on the S bus is passed unaltered. The status set by the reset bit instruction is as follows:
$\mathrm{N} \quad \rightarrow \quad$ None (force to zero)
OVR $\rightarrow$ None (force to zero)
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow$ None (force to zero)
Z $\rightarrow$ Result equal zero


NOTES: 1. Force $\overline{\mathrm{SIOO}}$ low for proper operation.
2. Bit mask (C3-CO)::(A3-AO) will set desired bits to one.

FIGURE 3. SET BIT (OR RESET BIT)
test bit (one) instruction (TB1): $17-10=2816$
This instruction (Figure 4) is used to test selected bits for ones. Bits to be tested are specified by an 8-bit mask (C3-C0)::(A3-A0) consisting of register file address ports that are not required to support this instruction. Write Enable ( $\overline{\mathrm{WE}})$ is internally disabled during this instruction. The test will pass if the selected byte has ones at all bit locations specified by the ones of the mask (Figure 5). The S bus is the source word for this instruction. $\overline{\mathrm{SIOO}}$ must be forced low for proper operation. The status set by the test bit (one) instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { None (force to zero) } \\
\text { OVR } & \rightarrow \\
\text { None (force to zero) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\mathrm{None} \text { (force to zero) } \\
\mathrm{Z} & \rightarrow
\end{array} \text { Pass }
$$



NOTES: 1. Force $\overline{\mathrm{SIOO}}$ low for proper operation.
2. Bit mask (C3-C0)::(A3-A0) will define bits for testing.
3. Pass/fail is indicated on $Z$ output.

FIGURE 4. TEST BIT
test bit (zero) instruction (TBO): 17-10 = 3816
This instruction (Figure 4) is used to test selected bits for ones. Bits to be tested are specified by an 8-bit mask (C3-C0)::(A3-A0) consisting of register file address ports that are not required to support this instruction. Write Enable ( $\overline{\mathrm{WE}})$ is internally disabled during this instruction. The test will pass if the selected byte has zeros at all bit locations specified by the ones of the mask (Figure 6). The $S$ bus is the source word for this instruction. $\overline{\mathrm{SIOO}}$ must be forced low for proper operation. The status set by the test bit (zero) instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { None (force to zero) } \\
\text { OVR } & \rightarrow \\
\text { None (force to zero) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\text { None (force to zero) } \\
\mathrm{Z} & \rightarrow
\end{array} \text { Pass }
$$



FIGURE 5. TEST BIT ONE EXAMPLES


FIGURE 6. TEST BIt ZERO EXAMPLES

## absolute value instruction (ABS): $17-10=\mathbf{4 8 1 6}$

This instruction is used to convert two's complement numbers to their positive value. The operand placed on the S bus is the source for this instruction. The 'AS887 will test the sign of the S bus and force the SSF pin to the proper value. The status set by the absolute value instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { Input MSB equal one } \\
\text { OVR } & \rightarrow & \text { Input equal } 80 \text { (hex) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow & \mathrm{~S}=0 \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

sign magnitude/two's complement instruction (SMTC): $\mathbf{1 7 - 1 0}=\mathbf{5 8 1 6}$
This instruction allows conversion from two's complement representation to sign magnitude representation, or vice-versa, in one clock cycle. The operand placed on the S bus is the source for this instruction.
When a negative zero ( 80 hex ) is converted, the result is 00 with an overflow. If the input is in two's complement notation, the overflow indicates an illegal conversion. The status set by the sign magnitude/two's complement instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { Result MSB equal one } \\
\mathrm{OVR} & \rightarrow & \text { Input equal 80 (hex) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow & \text { Input equal OO (hex) } \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

add immediate instruction (ADDI): $17-10=6816$
This instruction is used to add a specified constant value to the operand placed on the S bus. The constant will be between the values of 0 and 15 . The constant value is specified by the unused register file address (A port) not required to support this instruction. Forcing the carry input will add an additional one to the result. The status set by the add immediate instruction is as follows:
$\mathrm{N} \rightarrow$ Result MSB equal one
OVR $\rightarrow$ Arithmetic signed overflow
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow$ Carry out equal one
$Z \quad \rightarrow \quad$ Result equal zero
subtract immediate instruction (SUBI): $17-10=7816$
This instruction is used to subtract a specified constant value from the operand placed on the S bus. The constant value is specified by the unused register file address (A port) that is not required to support this instruction. The constant applied is the least significant four bits of a two's complement number. The device sign extends the constant over the entire word length. The status set by the subtract immediate instruction is as follows:

| N | $\rightarrow$ | Result MSB equal one |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Arithmetic signed overflow |
| $\mathrm{C}_{\mathrm{n}}+8$ | $\rightarrow$ | Carry out equal one |
| Z | $\rightarrow$ | Result equal zero |

## group 4 instructions

Hex code 0 of Group 1 instructions is used to access Group 4 instructions. Group 4 instructions are summarized in Table 6.

TABLE 6. GROUP 4 INSTRUCTIONS

| INSTRUCTION BITS (I7-IO) <br> OP CODE (HEX) | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| 00 |  | Reserved |
| 10 | SEL | Select S/R |
| 20 | SNORM | Single Length Normalize |
| 30 | DNORM | Double Length Normalize |
| 40 | DIVRF | Divide Remainder Fix |
| 50 | SDIVQF | Signed Divide Quotient Fix |
| 60 | SMULI | Signed Multiply Iterate |
| 70 | SMULT | Signed Multiply Terminate |
| 80 | SDIVIN | Signed Divide Initialize |
| 90 | SDIVIS | Signed Divide Start |
| AO | SDIVI | Signed Divide Iterate |
| BO | UDIVIS | Unsigned Divide Start |
| CO | UDIVI | Unsigned Divide Iterate |
| DO | UMULI | Unsigned Multiply Iterate |
| EO | SDIVIT | Signed Divide Terminate |
| FO | UDIVIT | Unsigned Divide Terminate |

select $S / R$ instruction (SEL): $17-10=1016$
This instruction is used to pass either the $S$ bus or the $R$ bus to the output depending on the state of the SSF input pin. Normally, the preceding instruction would test the two operands and the resulting status information would be used to force the SSF input pin. SSF $=0$ will output the R bus and $\operatorname{SSF}=1$ will output the $S$ bus. The status set by the select $S / R$ instruction is as follows:

single-length normalize instruction (SNORM): 17-IO $=\mathbf{2 0 1 6}$
This instruction will cause the contents of the MO register to shift toward the most significant bit. Zeros are shifted in via the $\overline{\mathrm{Q} \mid O \mathrm{O}}$ input. The number of shifts performed can be counted and stored in one of the register files by forcing a high at the $\mathrm{C}_{\mathrm{n}}$ input. When the two most significant bits are of opposite value, normalization is complete. This condition is indicated on the microcycle that completes the normalization at the OVR output.

The chip contains conditional logic that inhibits the shift function (and also inhibits the register file increment) if the number within the MQ register is already normalized at the beginning of the instruction (Figure 7). The status set by the single-length normalize instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { MSB of result } \\
\text { OVR } & \rightarrow \\
\text { MSB XOR 2nd MSB } \\
\mathrm{C}_{n}+8 & \rightarrow \\
\mathrm{Z} & \rightarrow \\
\text { Result equal zero }
\end{array}
$$



DOUBLE-LENGTH NORMALIZE

figure 7. SINgle- and double-length normalize

## double-length normalize instruction (DNORM): $\mathbf{1 7 - 1 0}=\mathbf{3 0 1 6}$

This instruction will cause the contents of a double-length word (register file contains the most significant half and the MO register contains the least significant half) to shift toward the most significant bit. Zeros are shifted in via the $\overline{\mathrm{O} O \mathrm{O}}$ input. When the two most significant bits are of opposite value, normalization is complete. This condition is indicated on the microcycle that completes the normalization at the OVR output.
The chip contains conditional logic which inhibits the shift function if the number is already normalized at the beginning of the instruction (Figure 7). The most significant half of the operand must be placed on the $S$ bus. The status set by the double-length normalize instruction is as follows:

$$
\begin{array}{lll}
\text { N } & \rightarrow & \text { MSB of result } \\
\text { OVR } & \rightarrow & \text { MSB XOR 2nd MSB } \\
\mathrm{C}_{n}+8 & \rightarrow & \text { None (force to zero) } \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

## multiply operations

The ALU performs three unique types of 8 by 8 multiplies each of which produces a 16 -bit result (Figure 8 ). All three types of multiplication proceed via the following recursion:
$\mathrm{P}(\mathrm{J}+1)=2[\mathrm{P}(\mathrm{J})+$ Multiplicand $\times \mathrm{M}(8-\mathrm{J})]$
where
$\mathrm{P}(\mathrm{J}) \quad=\quad$ partial product at iteration number J
$\mathrm{P}(\mathrm{J}+1)=$ partial product at iteration number $\mathrm{J}+1$
$J$ varies from 0 to 8
$\mathrm{M}(8-\mathrm{J})=$ mode bit (unique to multiply type)
2 denotes some type of shift (unique to multiply)
Notice that by proper choice of mode terms and shifting operations, signed, unsigned, and mixed multiplies (signed times unsigned) may be performed.
All multiplies assume that the multiplier is stored in MO before the operation begins (in the case of mixed multiply, the unsigned number must be the multiplier).

The processor has the following multiply instructions:

1. SIGNED MULTIPLY ITERATE (SMULI): $17-I 0=6016$
2. SIGNED MULTIPLY TERMINATE (SMULT): $17-10=7016$
3. UNSIGNED MULTIPLY ITERATE (UMULI): $17-10=\mathrm{DO}_{16}$

The signed multiply iterate (SMULI) instruction performs a signed times signed iteration. This instruction interprets $\mathrm{M}(8-\mathrm{J})$ as the $8-\mathrm{J}$ bit of the multiplier. The shift is a double-precision right shift one bit. This instruction is repeated 7 times for a $8 \times 8$ signed multiply. This instruction will be used 7 consecutive times for a mixed multiplication.

The signed multiply terminate (SMULT) instruction provides correct (negative) weighting of the sign bit of a negative multiplier in signed multiplication. The instruction is identical to signed multiply iterate (SMULI) except that $M(8-J)$ is interpreted as -1 if the sign bit of the multiplier is 1 , and 0 if the sign bit of the multiplier is 0 .


UMULI


FIGURE 8. MULTIPLICATION OPERATIONS

## SN54AS887, SN74AS887 <br> 8-BIT PROCESSORS

The unsigned multiply iterate (UMULI) performs an unsigned multiplication iteration. This instruction interprets $M(8-J)$ as the $8-J$ bit of the multiplier. The shift is a double-precision right shift with the carry out from the $P(J)+$ Multiplicand $\times M(8-J)$ operation forced into bit 8 of $P(J+1)$. This instruction is used in unsigned and mixed multiplication.

## signed multiplication

Signed multiplication performs a ten clock cycle, two's complement multiply. The instructions necessary to produce an algebraically correct result proceed in the following manner:

| Zero register to be used for accumulator |  |  |
| :---: | :---: | :---: |
| Load MQ with multiplier |  |  |
| SMULI (repeat 7 times) | S port <br> R port <br> F port | Accumulator Multiplicand Iteration Result |
| SMULT | $\begin{aligned} & \text { S port }= \\ & \text { R port }= \\ & \text { F port }= \end{aligned}$ | Accumulator <br> Multiplicand <br> Product (MSH) |

At completion, the accumulator will contain the 8 most significant bits and MQ will contain the 8 least significant bits of the product.

The status for the signed multiply iterate should not be used for any testing (overflow is not set by SMULI). The following status is set for the signed multiply terminate instruction:

```
N }\quad->\quad\mathrm{ Result MSB equal one
OVR 仵 Forced to zero
Cn+8 傽 Carry out equal to one
Z }->\mathrm{ Double precision result is zero
```

unsigned multiplication
Unsigned multiplication produces an unsigned times unsigned product in ten clocks. The instructions necessary to produce an algebraically correct result proceed in the following manner:

Zero register to be used for accumulator
Load MQ with multiplier
UMULI (8 times) $\quad$ S port $=$ Accumulator
R, port $=$ Multiplicand
F port $=$ Iteration result (product MSH on final result)
Upon completion, the accumulator will contain the 8 most significant bits and MQ will contain the 8 least significant bits of the product.

The status set by the unsigned multiply iteration is meaningless except on the final execution of the instruction. The status set by the unsigned multiply iteration instruction is as follows:

| N | $\rightarrow$ | Result MSB equal one |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Forced to zero |
| $\mathrm{C}_{n}+8$ | $\rightarrow$ | Carry out equal to one |
| Z | $\rightarrow$ | Double-precision result is zero |

## mixed multiplication

Mixed multiplication multiplies a signed multiplicand times an unsigned multiplier to produce a signed result in ten clocks. The steps are as follows:

Zero register used for accumulator
Load MO with unsigned multipler
SMULI (8 times) S port $=$ Accumulator
R port $=$ Multiplicand
F port $=$ Iteration result
Upon completion, the accumulator will contain the 8 most significant bits and MO will contain the 8 least significant bits of the product.

The following status is set by the last SMULI instruction:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { Result MSB equal one } \\
\mathrm{OVR} & \rightarrow \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\text { Carred to zero } \\
\mathrm{Z} & \rightarrow \\
\text { Double-precision result is zero }
\end{array}
$$

## divide operations

The divide uses a nonrestoring technique to perform both signed and unsigned division of a 16 bit integer dividend and an 8 bit integer divisor (Figure 9). It produces an 8 integer quotient and remainder.

The remainder and quotient will be such that the following equation is satisfied:

$$
\text { (Quotient) } \times \text { (Divisor })+ \text { Remainder }=\text { Dividend }
$$

The processor has the following divide instructions:

1. UNSIGNED DIVIDE START (UDIVIS): $17-10=B 016$
2. UNSIGNED DIVIDE ITERATE (UDIVI): $17-10=\mathrm{CO} 16$
3. UNSIGNED DIVIDE TERMINATE (UDIVIT): $17-I 0=$ FO16
4. SIGNED DIVIDE INITIALIZE (SDIVIN): $17-10=8016$
5. SIGNED DIVIDE OVERFLOW TEST (SDIVO): $17-10=A F_{16}$
6. SIGNED DIVIDE START (SDIVIS): $17-10=9016$
7. SIGNED DIVIDE ITERATE (SDIVI): $17-I 0=A 016$
8. SIGNED DIVIDE TERMINATE (SDIVIT): $17-10=$ EO16
9. DIVIDE REMAINDER FIX (DIVRF): $17-I 0=4016$
10. SIGNED DIVIDE QUOTIENT FIX (SDIVQF): $17-10=5016$


FIGURE 9. DIVIDE OPERATIONS


UDIVT


FIGURE 9. DIVIDE OPERATIONS (Continued)

## SN54AS887, SN74AS887 <br> 8-BIT PROCESSORS

The unsigned divide iterate start (UDIVIS) instruction begins the iterate procedure while testing for overflow. Overflow is reported when the first subtraction of the divisor from the MSH of the dividend produces carry out. The test detects quotient overflow and divide by zero.

The unsigned divide iterate terminate (UDIVIT) instruction completes the iterate procedure generating the last quotient bit.

The signed divide initialize (SDIVIN) instruction prepares for iteration by shifting the dividend and storing the sign of the dividend for use in the following instructions and overflow tests.
The signed divide overflow test (SDIVO) checks for overflow possibilities. This instruction may be deleted from the divide operation if the OVR pin is ignored. If it is removed some overflow conditions will go undetected. $\overline{W E}$ must be high (writing inhibited) when this instruction is used.

The signed divide iterate start (SDIVIS) instruction calculates the difference between the divisor and MSH of the dividend. Partial detection of overflow is also done during this instruction. Operations with like signs (positive quotient) and division by zero will overflow during this instruction (including zero divisor). Operations with unlike signs are tested for overflow during the signed divide quotient fix instruction (SDIVQF). Partial overflow results are saved and will be used during SDIVQF when overflow is reported.

The signed divide iterate (SDIVI) instruction forms the quotient and remainder through iterative subtract/addshift operations of the divisor and dividend. One quotient bit is generated on each clock.

The signed divide iterate terminate (SDIVIT) instruction completes the iterate procedure, generating the last quotient bit. It also tests for a remainder equal to zero, which determines the action to be taken in the following correction (fix) instructions.

The divide remainder fix (DIVRF) instruction corrects the remainder. If a zero remainder was detected by the previous instructions, the remainder is forced to zero. For nonzero remainder cases where the remainder and dividend have the same sign, the remainder is correct. When the remainder and dividend have unlike signs, a correction add/subtract of the divisor to the remainder is performed.

The signed divide quotient fix (SDIVQF) instruction corrects the quotient if necessary. This correction requires adding one to the incorrect quotient. An incorrect quotient results if the signs of the divisor and dividend differ and the remainder is nonzero. An incorrect quotient also results if the sign of the divisor is negative and the remainder is zero.
Overflow detection is completed during this instruction. Overflow may be generated for differing signs of the dividend and divisor. The partial overflow test result performed during SDIVIS is ORed with this test result to produce a true overflow indication.

## signed divide usage

The instructions necessary to perform an algebraically correct division of signed numbers are as follows:
Load MO with the least significant half of the dividend

| SDIVIN | $\begin{aligned} & \text { S port }=\text { MSH of dividend } \\ & \text { R port }=\text { Divisor } \\ & \text { F port }=\text { Intermediate result } \end{aligned}$ |
| :---: | :---: |
| SDIVO | $\begin{aligned} & \text { S port }=\text { Result of SDIVIN } \\ & \text { R port }=\text { Divisor } \\ & \text { F port }=\text { Test result } \\ & (\overline{W E} \text { must be high) } \end{aligned}$ |
| SDIVIS | $\begin{aligned} & \text { S port }=\text { Result of SDIVIN } \\ & \text { R port }=\text { Divisor } \\ & \text { F port }=\text { Intermediate result } \end{aligned}$ |
| SDIVI (8N-2 times) | ```S port = Result of SDIVIS (or SDIVI) R port = Divisor F port = Intermediate result``` |
| SDIVIT | $\begin{aligned} & \text { S port }=\text { Result of last SDIVI } \\ & \text { R port }=\text { Divisor } \\ & \text { F port }=\text { Intermediate result } \end{aligned}$ |
| DIVRF | $\begin{aligned} & \text { S port }=\text { Result of SDIVIT } \\ & \text { R port }=\text { Divisor } \\ & \text { F port }=\text { Remainder } \end{aligned}$ |
| SDIVQF | $\begin{aligned} & \text { S port }=\text { MQ register } \\ & \text { R port }=\text { Divisor } \\ & \mathrm{F} \text { port }=\text { Quotient } \end{aligned}$ |

The status of all signed divide instructions except SDIVIN, DIVRF, and SDIVQF is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { Forced to zero } \\
\mathrm{OVR} & \rightarrow \\
\text { Forced to zero } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\mathrm{Z} & \rightarrow \\
\text { Intermediate result is zero }
\end{array}
$$

The status of the SDIVIN instruction is as follows:

| N | $\rightarrow$ | Forced to zero |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Forced to zero |
| $\mathrm{C}_{\mathrm{n}}+8$ |  | Forced to zero |
| Z | $\rightarrow$ | Divisor is zero |

The status of the DIVRF instruction is as follows:

| N | $\rightarrow$ | Forced to zero |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Forced to zero |
| $\mathrm{C}_{\mathrm{n}}+8$ | $\rightarrow$ | Carry out equal to one |
| Z | $\rightarrow$ | Remainder is zero |

## SN54AS887, SN74AS887 <br> 8-BIT PROCESSORS

The status of the SDIVQF instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \text { Sign of quotient } \\
\text { OVR } & \rightarrow \text { Divide overflow } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \text { Carry out equal to one } \\
\mathrm{Z} & \rightarrow \text { Quotient is zero }
\end{array}
$$

The quotient is stored in the MQ register and the remainder is stored in the register file location that originally held the most significant word of the dividend. If fractions are divided, the quotient must be shifted right one bit and the remainder right three bits to obtain the correct fractional representations.

The signed division algorithm is summarized in Table 7.
TABLE 7. SIGNED DIVISION ALGORITHM

| OP <br> CODE | MNEMONIC | CLOCK <br> CYCLES | INPUT <br> S PORT | INPUT <br> R PORT | OUTPUT <br> F PORT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| E4 | LOADMQ | 1 | Dividend (LSH) | - | Dividend (LSH) |
| 80 | SDIVIN | 1 | Dividend (MSH) | Divisor | Remainder |
| AF | SDIVO | 1 | Remainder | Divisor | Test Result |
| 90 | SDIVIS | 1 | Remainder | Divisor | Remainder |
| AO | SDIVI | 7 | Remainder | Divisor | Remainder |
| EO | SDIVIT | 1 | Remainder | Divisor | Remainder (Unfixed) |
| 40 | DIVRF | 1 | Remainder (Unfixed) | Divisor | Remainder |
| 50 | SDIVQF | 1 | MQ Register | Divisor | Quotient |

unsigned divide usage
The instructions necessary to perform an algebraically correct division of unsigned numbers are as follows:
Load MQ with the least significant half of the dividend

|  | Sport $=$ MSH of dividend |
| :--- | :--- |
|  | R port $=$ Divisor |
| F port $=$ Intermediate result |  |
| UDIVI (8-1 times) | S port $=$ Result of UDIVIS (OR UDIVI) |
|  | R port $=$ Divisor |
| F port $=$ Intermediate result |  |
| UDIVIT | S port $=$ Result of last UDIVI |
|  | R port $=$ Divisor |
| F port $=$ Remainder (unfixed) |  |
| DIVRF | S port $=$ Result of UDIVIT |
|  | R port $=$ Divisor |
|  | F port $=$ Remainder |

The status of all unsigned divide instructions except UDIVIS is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { Forced to zero } \\
\mathrm{OVR}^{2} & \rightarrow & \text { Forced to zero } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow & \text { Carry out equal to one } \\
\mathrm{Z} & \rightarrow & \text { Intermediate result is zero }
\end{array}
$$

The status of the UDIVIS instruction is as follows:
$\mathrm{N} \quad \rightarrow \quad$ Forced to zero
OVR $\rightarrow$ Divide overflow
$C_{n}+8 \rightarrow$ Carry out equal to one
$\mathrm{Z} \rightarrow$ Intermediate result is zero
If fractions are divided, the remainder must be shifted right two bits to obtain the correct fractional representation. The quotient is correct as is. The quotient is stored in the MQ register at the completion of the divide.
The unsigned division algorithm is summarized in Table 8.
TABLE 8. UNSIGNED DIVISION ALGORITHM

| OP <br> CODE | MNEMONIC | CLOCK <br> CYCLES | INPUT <br> S PORT | INPUT <br> R PORT | OUTPUT <br> F PORT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| E4 | LOADMQ | 1 | Dividend (LSH) | - | Dividend (LSH) |
| BO | UDIVIS | 1 | Dividend (MSH) | Divisor | Remainder |
| CO | UDIV! | 7 | Remainder | Divisor | Remainder |
| FO | UDIVIT | 1 | Remainder | Divisor | Remainder (Unfixed) |
| 40 | DIVRF | 1 | Remainder (Unfixed) | Divisor | Remainder |

## group 5 instructions

Hex code $F$ of Group 1 instructions is used to access Group 5 instructions. Group 5 instructions are summarized in Table 9.

TABLE 9. GROUP 5 INSTRUCTIONS

| INSTRUCTION BITS (I7-IO) <br> OP CODE (HEX) | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| OF | CLR | Clear |
| $1 F$ | CLR | Clear |
| $2 F$ | CLR | Clear |
| $3 F$ | CLR | Clear |
| $4 F$ | CLR | Clear |
| $5 F$ | CLR | Clear |
| $6 F$ | CLR | Clear |
| $7 F$ | BCDBIN | BCD to Binary |
| $8 F$ |  | Reserved |
| $9 F$ | EX3C | Excess-3 Word Correction |
| AF | SDIVO | Signed Divide Overflow Check |
| BF | CLR | Clear |
| CF | CLR | Clear |
| DF | BINEX3 | Binary to Excess-3 |
| EF | CLR | Clear |
| FF | NOP | No Operation |

## clear instructions (CLR)

There are 11 clear instructions listed in Table 9. The instructions force the ALU output to be zero and the BCD flip-flops to be cleared. The status set by the clear instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { None (force to zero) } \\
\text { OVR } & \rightarrow \\
\text { None (force to zero) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\text { None (force to zero) } \\
\mathrm{Z} & \rightarrow \text { Active (one) }
\end{array}
$$

## no operation instruction (NOP): 17-IO = FF16

This instruction is identical to the clear instructions except that the BCD flip-flops retain their old value.

## excess-3 correction instructions (EX3C): 9F16

This instruction corrects excess-3 additions (subtractions). For correct excess-3 arithmetic, this instruction must follow each add/subtract. The operand must be on the $S$ port.

NOTE: The previous arithmetic overflow should be ignored.
The status set by the EX3C instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { MSB of result } \\
\text { OVR } & \rightarrow & \text { Signed overflow } \\
\mathrm{C}_{n}+8 & \rightarrow & \text { Carry out equal one } \\
\mathrm{Z} & \rightarrow & \text { None (force to one) }
\end{array}
$$

## radix conversions

Conversions between decimal and binary number representations are performed with the aid of two special instructions: BINEX3 and BCDBIN.

## $B C D$ to binary instructions (BCDBIN): 17-10 $=7 F_{16}$

This instruction (Figure 10) allows the user to convert a 2-digit BCD number to an 8-bit binary number in 12 clocks. This function sums the $R$ bus, the $S$ bus, and the $C_{n}$ bit, performs an arithmetic left shift on the ALU result, and simultaneously circular shifts the MQ left. The status set by the BCD to binary instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { MSB of result } \\
\text { OVR } & \rightarrow & \text { Signed arithmetic overflow } \\
\\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow & \text { Carry out equal one } \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

$\dagger$ Overflow may be the result of an ALU operation or the arithmetic left shift operation.

The following code illustrates the $B C D$ to binary conversion technique.
Let ACC be an accumulator register
Let NUM be the register which contains the BCD number
Let MSK be a mask register

| LOADMO NUM | ; LOAD MQ WITH BCD NUMBER |
| :---: | :---: |
| SUB ACC, ACC, SLCMO | ; CLEAR ACC AND ALIGN MQ |
| SUB, MSK, MSK, SLCMQ | ; CLEAR MSK AND ALIGN MQ |
| SLCMQ | ; ALIGN |
| SLCMQ | ; ALIGN |
| ADDI ACC, MSK, 1510 | ; MSK = 1510 |
| AND MQ, MSK, R1, SLCMQ | ; EXTRACT ONE DIGIT <br> ; ALIGN MQ |
| ADD, ACC, R1, R1, SLCMQ | $\begin{aligned} & \text {; ACC + DIGIT } \\ & \text {; IS STORED IN R1 } \\ & \text {; ALIGN MQ } \end{aligned}$ |
| BCDBIN, R1, R1, ACC | $; 4 \times(\mathrm{ACC}+\mathrm{DIGIT})$ IS STORED IN ACC ALIGN MQ |
| BCDBIN, ACC, R1, ACC | $10 \times($ ACC + DIGIT $)$ IS STORED IN ACC ALIGN MQ |
| AND MQ, MSK, R1 | ; FETCH LAST DIGIT |
| $A C C+R 1 \rightarrow A C C$ | ; ADD IN LAST DIGIT |

The previous code generates a binary number by executing the standard conversion formula for a 2-digit BCD number.

$$
A B=A \times 10+B
$$

Notice that the conversion begins with the most significant BCD digit and that the addition is performed in radix 2.

## binary to excess-3 instructions (BINEX3): $17-10=D F 16$

This instruction (Figure 11) allows the user to convert an 8-bit binary number to 2-digit excess-3 number representation in 19 clocks. The data on the $R$ and $S$ ports are summed with the MSB of the MO register. The MO register is simultaneously shifted left circularly. The status set by the binary to excess- 3 instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { MSB of result } \\
\text { OVR } & \rightarrow \\
\text { Signed arithmetic overflow } \\
\mathrm{C}_{n}+8 & \rightarrow \\
\text { Carry out equal one } \\
\mathrm{Z} & \rightarrow
\end{array} \text { Result equal zero }
$$



FIGURE 10. BCD TO BINARY
BINEX3


FIGURE 11. BINARY TO EXCESS-3

The following illustrates the binary to excess-3 conversion technique.
Let NUM be a register containing an unsigned binary number
Let ACC be an accumulator

| M1: | LOADMO NUM | ; LOAD MO WITH BINARY <br> ; NUMBER |
| :---: | :---: | :---: |
| M2: | CLEAR ACC | ; CLEAR ACC |
| M3: | SET1 ACC H/33/ | ; ACC $\rightarrow$ HEX/3333 |
| L1: | BINEX3 ACC, ACC, ACC | ; DOUBLE ACC AND ADD IN <br> ; MSB OF MQ |
|  |  | ; ALIGN MO |
| L2: | EX3C ACC, ACC | ; EXCESS 3 CORRECT |
|  |  | ; REPEAT L1 AND L2 |

The previous code generates an excess-3 number by executing the standard conversion formula for a binary number.

$$
a_{n} 2^{n}+a_{n-1} 2^{n-1}+a_{n}-2^{2 n-2}+\ldots a_{0} 2^{0}=\left[\left(2 a_{n}+a_{n}-1\right) 2+a_{n}-2\right] 2+\ldots a_{0}
$$

Notice that the conversion begins with the most significant binary bit and that the addition is performed in radix-10 (excess-3).

## decimal arithmetic

Decimal numbers are represented in excess- 3 code. Excess -3 code numbers may be generated by adding three to each digit of a Binary Coded Decimal (BCD) number. The hardware necessary to implement excess-3 arithmetic is only slightly different from binary arithmetic. Carries from one digit to another during addition in BCD occur when the sum of the two digits plus the carry-in is greater than or equal to ten. If both numbers are excess-3, the sum will be excess-6, which will produce the proper carries. Therefore, every addition or subtraction operation may use the binary adder. To convert the result from excess- 6 to excess- 3 , one must consider two cases resulting from a BCD digit add: (1) where a carry-out is produced, and (2) where a carry-out is not produced. If a carry-out is not produced, three must be subtracted from the resulting digit. If a carry is produced, the digit is correct as a $B C D$ number. For example, if $B C D 5$ is added to $B C D 6$, the excess -3 result would be $8+9=1$ (with a carry). A carry rolls the number through the illegal BCD representations into a correct BCD representation. Binary 3 must be added to digit positions that produce a carry-out to correct the result to an excess-3 representation. Every addition and subtraction instruction stores the carry generated from each 4-bit digit location for use by the excess-3 correction function. The correction instruction must be executed in the clock cycle immediately after the addition or subtraction operation.

## SN54AS887, SN74AS887

 8-BIT PROCESSORS
## recommended operating conditions

|  |  |  |  | 54AS |  |  | $\begin{aligned} & \text { 774AS } \\ & \text { 74AS8 } \end{aligned}$ | $\begin{aligned} & 387 \\ & 37-1 \end{aligned}$ | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC} 1}$ | 1/O supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {CC2 }}$ | STL internal logic supply |  | 1.9 | 2 | 2.1 | 1.9 | 2 | 2.1 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{\mathrm{I} O H}$ | High-level output current |  |  |  | -1 |  |  | -2.6 | mA |
|  |  | All output except N and ZERO |  |  | 8 |  |  | 8 |  |
| ${ }^{\mathrm{I}} \mathrm{OL}$ | Low-level output current | N |  |  | 16 |  |  | 16 | mA |
|  |  | ZERO |  |  | 48 |  |  | 48 |  |
| ${ }^{\text {T }} \mathrm{C}$ | Operating case temperature |  | -55 |  | 125 |  |  |  | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}^{\text {A }}$ | Operating free-air temperature |  |  |  |  | 0 |  | 70 |  |

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

| PARAMETER |  | TEST CONDITIONS | SN54AS887 |  | SN74AS887 <br> SN74AS887-1 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ MAX | MIN | TYP ${ }^{\text {t }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, \quad \mathrm{I}=-18 \mathrm{~mA}$ |  | -1.2 |  |  | -1.2 | V |
| VOH | All outputs except ZERO | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I} \mathrm{OH}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  | $\mathrm{V}_{\mathrm{CC}-2}$ |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ | 2.4 |  |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, \mathrm{I}^{\mathrm{OH}}=-2.6 \mathrm{~mA}$ |  |  | 2.4 |  |  |  |
| IOH | ZERO | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  | 0.1 |  |  | 0.1 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | All outputs <br> except N and ZERO <br> N <br> ZERO | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, \quad \mathrm{OL}=8 \mathrm{~mA}$ |  | 0.5 |  |  | 0.5 | V |
|  |  | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, 1 \mathrm{IOL}=16 \mathrm{~mA}$ |  | 0.5 |  |  | 0.5 |  |
|  |  | $\mathrm{V}_{\mathrm{CC1}}=4.5 \mathrm{~V}, 1 \mathrm{OL}=48 \mathrm{~mA}$ |  | 0.5 |  |  | 0.5 |  |
| I | 1/O <br> All others | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=5.5 \mathrm{~V}$ |  | 0.1 |  |  | 0.1 | mA |
|  |  | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \mathrm{~V}_{1}=7 \mathrm{~V}$ |  | 0.1 |  |  | 0.1 |  |
| $1 \mathrm{IH}^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=2.7 \mathrm{~V}$ |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| ML ${ }^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=0.5 \mathrm{~V}$ |  | -0.4 |  |  | -0.4 | mA |
| $10^{\text {§ }}$ |  | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \mathrm{~V}_{0}=2.25 \mathrm{~V}$ | -30 | -112 | $-30$ |  | -112 | mA |
| ${ }^{\text {ICC1 }}$ |  | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$ |  | 150 |  |  | 130 | mA |
| ${ }^{\text {ICC2 }}$ |  | $\mathrm{V}_{\text {CC2 }}=2.1 \mathrm{~V}$ |  | 410 |  |  | 390 | mA |

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

SN54AS887 maximum switching characteristics, $\mathrm{V} C \mathrm{C}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T} \mathrm{C}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) |  |  |  |  |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Y | $\mathrm{C}_{\mathrm{n}}+8$ | $\overline{\mathbf{G}}, \overline{\mathbf{P}}$ | $z^{\dagger}$ | N | OVR | DA | DB | $\overline{\mathbf{0 1 O}}$ | $\overline{\text { SIO }}$ |  |
| ${ }^{\text {p }}$ d | $\begin{aligned} & \mathrm{A} 3-\mathrm{AO} \\ & \mathrm{~B} 3-\mathrm{BO} \end{aligned}$ | 62 | 42 | 48 | 69 | 62 | 60 | 18 | 18 | 65 | 66 | ns |
|  | $\begin{aligned} & \text { DA7-DAO, } \\ & \text { DB7-DBO } \end{aligned}$ | 47 | 28 | 28 | 58 | 50 | 42 | - | - | 50 | 50 |  |
|  | $\mathrm{C}_{\mathrm{n}}$ | 25 | 14 | - | 32 | 24 | 18 | - | - | 32 | 32 |  |
|  | $\overline{\mathrm{EA}}$ | 54 | 32 | 35 | 62 | 52 | 52 | - | - | 58 | 58 |  |
|  | $\overline{\mathrm{EB}}$ | 54 | 32 | 35 | 62 | 52 | 52 | - | - | 58 | 58 |  |
|  | 17-10 | 58 | 32 | 32 | 62 | 52 | 41 | - | - | 58 | 58 |  |
|  | $\overline{\text { OEB }}$ | - | - | - | - | - | - | - | 14 | - | - |  |
|  | $\overline{\mathrm{OEY}}$ | 14 | - | - | - | - | - | - | - | - | - |  |
|  | $\overline{\overline{\mathrm{Q} I \mathrm{O}}}(\mathrm{n})$ <br> Shift | 15 | - | - | 24 | - | - | - | - | - | - |  |
|  | $\overline{\mathrm{SIO}}(\mathrm{n})$ <br> Shift | 15 | - | - | 24 | 22 | - | - | - | - | - |  |
|  | CK | 68 | 60 | 56 | 62 | 50 | 68 | 38 | 38 | 70 | 70 |  |
|  | $\overline{\text { OEA }}$ | - | - - | - | - | - | - | 14 | - | - | - |  |

${ }^{\dagger}$ Load resistor R1 $=100 \Omega$.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

SN74AS887 maximum switching characteristics, $\mathrm{VCC}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (see Note 1)

| PARAMETER | $\begin{gathered} \hline \text { FROM } \\ \text { (INPUT) } \end{gathered}$ | TO (OUTPUT) |  |  |  |  |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Y | $\mathrm{C}_{\mathrm{n}+8}$ | $\overline{\mathrm{G}}, \overline{\mathbf{P}}$ | $\mathbf{z}^{\dagger}$ | N | OVR | DA | DB | $\overline{\mathrm{O}} \mathrm{O}$ | $\overline{\text { SIO }}$ |  |
| ${ }^{t} \mathrm{pd}$ | $\begin{aligned} & \text { A3-AO } \\ & \text { B3-BO } \end{aligned}$ | 54 | 36 | 42 | 60 | 52 | 50 | 18 | 18 | 58 | 58 | ns |
|  | DA7-DAO, DB7-DB0 | 44 | 26 | 26 | 52 | 46 | 38 | - | - | 44 | 44 |  |
|  | $\mathrm{C}_{\mathrm{n}}$ | 25 | 8 | - | 32 | 24 | 18 | - | - | 31 | 31 |  |
|  | EA | 49 | 29 | 29 | 58 | 49 | 47 | - | - | 54 | 54 |  |
|  | $\overline{E B}$ | 49 | 29 | 29 | 58 | 49 | 47 | - | - | 54 | 54 |  |
|  | 17-10 | 55 | 30 | 30 | 60 | 49 | 39 | - | - | 54 | 54 |  |
|  | $\overline{\mathrm{OEB}}$ | - | - | - | - | - | - | - | 12 | - | - |  |
|  | OEY | 12 | - | - | - | - | - | - | - | - | - |  |
|  | $\begin{aligned} & \hline \overline{\mathrm{O} 1 \mathrm{O}}(\mathrm{n}) \\ & \text { Shift } \\ & \hline \end{aligned}$ | 15 | - | - | 24 | - | - | - | - | - | - |  |
|  | $\overline{\mathrm{SIO}}(\mathrm{n})$ Shift | 15 | - | - | 24 | 19 | - | - | - | - | - |  |
|  | CK | 58 | 55 | 52 | 61 | 52 | 62 | 35 | 35 | 60 | 60 |  |
|  | $\overline{\text { OEA }}$ | - | - | - | - | - | - | 12 | - | - | - |  |

[^43]
## SN54AS887, SN74AS887 <br> 8-BIT PROCESSORS

SN74AS887-1 maximum switching characteristics, $\mathrm{V} C \mathrm{C}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) |  |  |  |  |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Y | $C_{n+8}$ | $\overline{\mathbf{G}}, \overline{\overline{\mathbf{P}}}$ | $z^{\dagger}$ | N | OVR | DA | DB | $\overline{\mathbf{Q 1 O}}$ | $\overline{\text { SIO }}$ |  |
| ${ }^{t} \mathrm{pd}$ | $\begin{aligned} & \text { A3-A0 } \\ & \text { B3-B0 } \end{aligned}$ | 44 | 30 | 36 | 50 | 44 | 44 | 17 | 17 | 48 | 48 | ns |
|  | $\begin{aligned} & \text { DA7-DAO, } \\ & \text { DB7-DB0 } \end{aligned}$ | 36 | 24 | 24 | 46 | 41 | 32 | - | - | 40 | 40 |  |
|  | $\mathrm{C}_{\mathrm{n}}$ | 22 | 8 | - | 27 | 21 | 16 | - | - | 25 | 25 |  |
|  | $\overline{\mathrm{EA}}$ | 40 | 25 | 25 | 49 | 41 | 41 | - | - | 44 | 44 |  |
|  | $\overline{E B}$ | 40 | 25 | 25 | 49 | 41 | 41 | - | - | 44 | 44 |  |
|  | 17-10 | 46 | 27 | 27 | 50 | 42 | 35 | - | - | 45 | 45 |  |
|  | $\overline{\mathrm{OEB}}$ | - | - | - | - | - | - | - | 12 | - | - |  |
|  | $\overline{\mathrm{OEY}}$ | 12 | - | - | - | - | - | - | - | - | - |  |
|  | $\overline{\mathrm{Q} I \mathrm{O}}(\mathrm{n})$ <br> Shift | 14 | - | - | 20 | - | - | - | - | - | - |  |
|  | $\overline{\mathrm{SIO}}(\mathrm{n})$ <br> Shift | 14 | - | - | 20 | 18 | - | - | - | - | - |  |
|  | CK | 50 | 46 | 46 | 50 | 50 | 50 | 30 | 30 | 50 | 50 |  |
|  | $\overline{\text { OEA }}$ | - | - | - | - | - | - | 12 | - | - | - |  |

$\dagger$ Load resistor R1 $=100 \Omega$.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.
register file write setup and hold times

§ DB (during select instruction) through $Y$ port.
special instruction switching characteristics
The SSF pin is used internally during certain instructions. The following tables list the instructions which force the SSF pin during their execution. The propagation delay from various inputs is also shown. The parameter which limits normal system performance is indicated by a dagger.

SN54AS887 SSF PIN DELAYS AND SETUP TIMES

| MNEMONIC | $\begin{aligned} & \text { HEX } \\ & \text { CODE } \end{aligned}$ | INPUT $\rightarrow$ SSF (ns) |  |  |  | SSF SETUP <br> TIME (ns) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Cn | $1(\mathrm{n})$ | CK | $B_{(n)}$ |  |
| SNORM | 20 | - | $29^{\dagger}$ | 46 | - | 20 |
| DNORM | 30 | - | 29 | 55 | $40^{\dagger}$ | 20 |
| DIVRF | 40 | - | $29^{\dagger}$ | 46 | - | 20 |
| SDIVQF | 50 | - | $26^{\dagger}$ | - | - | 18 |
| SMULI | 60 | - | $26^{\dagger}$ | 43 | - | 0 |
| SDIVIN | 80 | - | 48 | 64 | $44^{\dagger}$ | 0 |
| SDIVIS | 90 | $26^{\dagger}$ | 51 | 64 | 55 | 0 |
| SDIVI | AO | $26^{\dagger}$ | 51 | 64 | 55 | 0 |
| UDIVIS | B0 | $18^{\dagger}$ | 45 | 64 | 46 | 0 |
| UDIVI | CO | $18^{\dagger}$ | 50 | 54 | 40 | 0 |
| UMULI | DO | - | $25^{\dagger}$ | 48 | - | 0 |
| SDIVIT | EO | $26^{\dagger}$ | 50 | 56 | 54 | 0 |
| ABX | 48 | - | 34 | 62 | $39^{\dagger}$ | 20 |
| SMTC | 58 | - | 29 | 58 | $39^{\dagger}$ | 20 |
| BINEX3 | DF | - | $29^{\dagger}$ | 58 | - | 18 |
| LOADMQ (Arith) |  | $23^{\dagger}$ | 34 | 62 | 40 | 0 |
| LOADMQ (Log) |  | - | 33 | 62 | $40^{\dagger}$ | 0 |

[^44]SN74AS887 SSF PIN DELAYS AND SETUP TIMES

| MNEMONIC | $\begin{aligned} & \text { HEX } \\ & \text { CODE } \end{aligned}$ | INPUT $\rightarrow$ SSF (ns) |  |  |  | SSF SETUP <br> TIME (ns) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{C}_{\mathrm{n}}$ | ${ }^{1}(\mathrm{n})$ | CK | $\mathrm{B}_{\text {( } \mathrm{n})}$ |  |
| SNORM | 20 | - | $26^{\dagger}$ | 40 | - | 17 |
| DNORM | 30 | - | 26 | 52 | $37^{\dagger}$ | 17 |
| DIVRF | 40 | - | $26^{\dagger}$ | 40 | - | 17 |
| SDIVGF | 50 | - | $25^{\dagger}$ | - | - | 17 |
| SMULI | 60 | - | $25^{\dagger}$ | 40 | - | 0 |
| SDIVIN | 80 | - | 38 | 60 | $40^{\dagger}$ | 0 |
| SDIVIS | 90 | $24^{\dagger}$ | 48 | 60 | 52 | 0 |
| SDIVI | AO | $24^{\dagger}$ | 48 | 60 | 52 | 0 |
| UDIVIS | B0 | $17{ }^{\dagger}$ | 43 | 60 | 45 | 0 |
| UDIVI | co | $17^{\dagger}$ | 44 | 52 | 37 | 0 |
| UMULI | DO | - | $26^{\dagger}$ | 40 | - | 0 |
| SDIVIT | EO | $25^{\dagger}$ | 46 | 52 | 49 | 0 |
| ABX | 48 | - | 32 | 60 | 38 | 17 |
| SMTC | 58 | - | 26 | 52 | $38^{\dagger}$ | 17 |
| BINEX3 | DF | - | $26^{\dagger}$ | 40 | - | 17 |
| LOADMO (Arith) |  | $22^{\dagger}$ | 32 | 50 | 38 | 0 |
| LOADMO (Log) |  | - | 32 | 50 | $38^{\dagger}$ | 0 |

[^45]SN74AS887-1 SSF PIN DELAYS AND SETUP TIMES

| MNEMONIC | HEX <br> CODE | INPUT $\rightarrow$ SSF (ns) |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{C}_{\mathbf{n}}$ | $\mathbf{I}_{\mathbf{( n )}}$ | $\mathbf{C K}$ | $\mathbf{B}_{\mathbf{( n )}}$ | TIME (ns) |  |
| SNORM | 20 | - | $23^{\dagger}$ | 28 | - | 14 |
| DNORM | 30 | - | 23 | 40 | $34^{\dagger}$ | 14 |
| DIVRF | 40 | - | $23^{\dagger}$ | 27 | - | 14 |
| SDIVOF | 50 | - | $23^{\dagger}$ | - | - | 14 |
| SMULI | 60 | - | $22^{\dagger}$ | 27 | - | 0 |
| SDIVIN | 80 | - | 35 | 46 | $35^{\dagger}$ | 0 |
| SDIVIS | 90 | $22^{\dagger}$ | 42 | 48 | 42 | 0 |
| SDIVI | AO | $22^{\dagger}$ | 42 | 46 | 42 | 0 |
| UDIVIS | BO | $16^{\dagger}$ | 42 | 46 | 38 | 0 |
| UDIVI | CO | $16^{\dagger}$ | 36 | 46 | 34 | 0 |
| UMULI | DO | - | $22^{\dagger}$ | 27 | - | 0 |
| SDIVIT | EO | $21^{\dagger}$ | 40 | 44 | 42 | 0 |
| ABX | 48 | - | 28 | 46 | $30^{\dagger}$ | 14 |
| SMTC | 58 | - | 24 | 44 | $30^{\dagger}$ | 14 |
| BINEX3 | DF | - | $23^{\dagger}$ | 27 | - | 14 |
| LOADMO (Arith) |  | $19^{\dagger}$ | 28 | 40 | 30 | 0 |
| LOADMO (Log) |  | - | 28 | 35 | $30^{\dagger}$ | 0 |

[^46]
## - STL-AS Technology

- Parallel 8-Bit ALU with Expansion Inputs and Outputs
- 13 Arithmetic and Logic Functions
- 8 Conditional Shifts (Single and Double Length)
- 9 Instructions that Manipulate Bytes
- 4 Instructions that Manipulate Bits
- Add and Subtract Immediate Instructions
- Absolute Value Instruction
- Signed Magnitude to/from Two's Complement Conversion
- Single- and Double-Length Normalize
- Select Functions
- Signed and Unsigned Divides with Overflow Detection; Input does not Need to be Prescaled
- Signed, Mixed, and Unsigned Multiplies
- Three-Operand, 16-Word Register File
- Full Carry Look Ahead Support
- Sign, Carry Out, Overflow, and Zero-Detect Status Capabilities
- Excess-3 BCD Arithmetic
- Internal Shift Multiplexers that Eliminate the Need for External Shift Control Parts
- ALU Bypass Path to Increase Speeds of Multiply, Divide, and Normalize Instructions and to Provide New Instructions such as Bit Set, Bit Reset, Bit Test, Byte Subtract, Byte Add, and Byte Logical
- 3-Operand Register Files to Allow an Operation and a Move Instruction to be Combined
- Byte Select Controlled by External 3-State Buffers that may be Eliminated if Bit and Byte Manipulation are not Needed
- Bit and Byte Masks that are Shared with Register Address Fields to Minimize Control Store Word Width
- 3 Data Input/Output Paths to Maximize Data Throughput


## description

These 8-bit Advanced Schottky TTL integrated circuits are designed to implement high performance digital computers or controllers. An architecture and instruction set has been chosen that supports a fast system clock, a narrow micro-code word width, and a high system throughput. The powerful instruction set allows high-speed system architecture to be implemented and also allows an existing system's performance to be upgraded while protecting software investments. These processors are designed to be cascadable to any word width 16 bits or greater.

The SN54AS888 is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS888 and SN74AS888-1 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

Package options include both plastic and ceramic chip carriers in addition to a 68-pin grid array ceramic package.

## SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES

SN54AS888, SN74AS888 . . . GB PACKAGE (TOP VIEW)


SN54AS888 . . . FK PACKAGE
SN74AS888 . . . FN PACKAGE
(TOP VIEW)
僉|


GB PACKAGE PIN ASSIGNMENTS

| PIN | NAME | PIN | NAME | PIN | NAME | PIN | NAME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A-2 | $\mathrm{C}_{\mathrm{n}}$ | B-9 | $\overline{\mathrm{OEY}}$ | F-10 | Y3 | K-4 | C2 |
| A-3 | $\overline{\mathrm{SIOO}}$ | B-10 | YO | F-11 | DB2 | K-5 | AO |
| A-4 | $\overline{\mathrm{QIOO}}$ | B-11 | Y 1 | G-1 | DA2 | K-6 | A3 |
| A-5 | $\overline{\mathrm{Q} 107}$ | C-1 | 15 | G-2 | DAO | K-7 | WE |
| A-6 | $\mathrm{C}_{n}+8$ | C-2 | $\mathrm{V}_{\mathrm{CC} 2}$ | G-10 | DBO | K-8 | DB7 |
| A-7 | $\overline{\mathrm{G}} / \mathrm{N}$ | C-10 | Y4 | G-11 | DB3 | K-9 | $\overline{\text { OEB }}$ |
| A-8 | $\overline{\mathrm{P}} /$ OVR | C-11 | Y6 | H-1 | DA3 | K-10 | EBO |
| A-9 | ZERO | D-1 | 16 | H-2 | DA1 | K-11 | EB1 |
| A-10 | PPP | D-2 | $\mathrm{V}_{\mathrm{CC} 1}$ | H-10 | DB6 | L-2 | CK |
| B-1 | 12 | D-10 | Y5 | H-11 | DB4 | L-3 | C1 |
| B-2 | 13 | D-11 | Y7 | $J-1$ | DA4 | L-4 | C3 |
| B-3 | 11 | E-1 | 17 | J-2 | DA5 | L-5 | A1 |
| B-4 | 10 | E-2 | $\overline{O E A}$ | J-10 | SELY | L-6 | A2 |
| B-5 | 14 | E-10 | Y2 | J-11 | DB5 | L-7 | B3 |
| B-6 | $\overline{\text { SIO7 }}$ | E-11 | DB1 | K-1 | DA6 | L-8 | B2 |
| B-7 | SSF | F-1 | $\overline{E A}$ | K-2 | DA7 | L-9 | B1 |
| B-8 |  | F-2 | GND | K-3 | CO | L-10 | B0 |

SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES

PIN FUNCTIONAL DESCRIPTION

| PIN GRID ARRAY | $\begin{array}{c\|} \text { CHIP } \\ \text { CARRIER } \end{array}$ | NAME | 1/0 | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| A-10 | 28 | PPP | 1 | Package position pin. Tri-level input used to define package significance during instruction execution. Leave open for intermediate positions, tie to $\mathrm{V}_{\mathrm{CC}}$ for most significant package, and tie to GND for least significant package. |
| B-7 | 29 | SSF | 1/0 | Special shift function. Used to transfer required information between packages during special instruction execution. |
| A-9 | 30 | ZERO | 1/0 | Device zero detection, open collector. Input during certain special instructions. |
| A-8 | 31 | ¢/OVR | 0 | ALU propagate/instruction overflow for most significant package, low active. |
| A-7 | 32 | $\overline{\mathrm{G}} / \mathrm{N}$ | 0 | ALU generate/negative result for most significant package, low active. |
| A-6 | 33 | $\mathrm{C}_{\mathrm{n}+8}$ | 0 | ALU ripple carry output. |
| B-6 | 34 | $\overline{\mathrm{SIO7}}$ | 1/0 |  |
| A-5 | 35 | $\overline{0107}$ | 1/0 |  |
| A-4 | 36 | $\overline{\mathrm{a} 100}$ | 1/0 | Bidirectional shift pin, low active |
| A-3 | 37 | SIOO | 1/0 |  |
| A-2 | 38 | $\mathrm{C}_{\mathrm{n}}$ | 1 | ALU carry input. |
| B-4 | 39 | 10 | 1 |  |
| B-3 | 40 | 11 | 1 |  |
| B-1 | 41 | 12 | 1 |  |
| B-2 | 42. | 13 | 1 | Instruction input. |
| B-5 | 43 | 14 | 1 | Instruction input. |
| C-1 | 44 | 15 | 1 |  |
| D-1 | 45 | 16 | 1 |  |
| E-1 | 46 | 17 | 1 |  |
| C-2 | 47 | $\mathrm{V}_{\mathrm{CC} 2}$ |  | Low voltage power supply (2 V). |
| D-2 | 48 | $\mathrm{V}_{\mathrm{CC} 1}$ |  | $1 / \mathrm{O}$ interface supply voltage ( 5 V ). |
| E-2 | 49 | $\overline{\text { OEA }}$ | 1 | DA bus enable, low active. |
| F-1 | 50 | $\overline{E A}$ | 1 | ALU input operand select. High state. selects external DA bus and low state selects register file. |
| F-2 | 51 | GND |  | Ground pin. |
| G-2 | 52 | DAO | 1/0 |  |
| H-2 | 53 | DA1 | 1/0 |  |
| G-1 | 54 | DA2 | 1/0 |  |
| H-1 | 55 | DA3 | $1 / 0$ | A port data bus. Outputs register file data ( $\overline{E A}=0$ ) or inputs external data ( $\overline{E A}=1$ ). |
| J-1 | 56 | DA4 | 1/0 | A port data bus. Outputs register tile data (EA $=0$ ) or inputs external data $(E A=1)$. |
| J-2 | 57 | DA5 | 1/0 |  |
| K-1 | 58 | DA6 | 1/0 |  |
| K-2 | 59 | DA7 | 1/0 |  |
| L-2 | 60 | CK | 1 | Clocks all synchronous registers on positive edge. |
| K-3 | 61 | CO | 1 |  |
| L-3 | 62 | C1 | 1 | ister file write address select. |
| K-4 | 63 | C2 | 1 | Register file write address select. |
| L-4 | 64 | C3 | 1 |  |
| K-5 | 65 | AO | 1 |  |
| L-5 | 66 | A1 | 1 |  |
| L-6 | 67 | A2 | 1 | Register file A port read address select. |
| K-6 | 68 | A3 | 1 |  |

## SN54AS888, SN74AS888 <br> 8-BIT PROCESSOR SLICES

PIN FUNCTIONAL DESCRIPTION

| PIN GRID ARRAY | CHIP CARRIER | NAME | 1/0 | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| K-7 | 1 | $\overline{\text { WE }}$ | 1 | Register file (RF) write enable. Data is written into RF when $\overline{\text { WE }}$ is low and a low-to-high clock transition occurs. RF write is inhibited when $\overline{W E}$ is high. |
| L-7 | 2 | B3 | 1 |  |
| L-8 | 3 | B2 | 1 |  |
| L-9 | 4 | B1 | 1 | Register file B port read address select. $10=$ LSB). |
| L-10 | 5 | B0 | 1 |  |
| K-10 | 6 | EBO | 1 | ALU input operand select. EBO and EB1 selects the source of data that the S multiplexer |
| K-11 | 7 | EB1 | 1 | provides for the $S$ bus. Independent control of the DB bus and data path selection allow the user to isolate the DB bus while the ALU continues to process data. |
| K-9 | 8 | $\overline{\text { OEB }}$ | 1 | DB bus enable, low active. |
| K-8 | 9 | DB7 | 1/0 |  |
| H-10 | 10 | DB6 | 1/0 |  |
| J 11 | 11 | DB5 | 1/0 |  |
| H-11 | 12 | DB4 | 1/0 | B port data bus. Outputs register data ( $\overline{\mathrm{OEB}}=0$ ) or used to input external data |
| G-11 | 13 | DB3 | 1/0 | ( $\overline{O E B}=1$ ), (0 = LSB). |
| F-11 | 14 | DB2 | 1/0 |  |
| E-11 | 15 | DB1 | 1/0 |  |
| G-10 | 16 | DBO | 1/0 |  |
| J-10 | 17 | SELY | 1 | Y bus select, high active. |
| D-11 | 18 | Y7 | 1/0 |  |
| C-11 | 19 | Y6 | 1/0 |  |
| D-10 | 20 | Y5 | 1/0 |  |
| C-10 | 21 | Y4 | 1/O | $Y$ port data bus. Outputs instruction results ( $\overline{\mathrm{OEY}}=0$ ) or used to put external data into |
| F-10 | 22 | Y3 | 1/0 | register file $\overline{\overline{O E Y}}=1)$. |
| E-10 | 23 | Y2 | 1/0 |  |
| B-11 | 24 | Y1 | 1/0 |  |
| B-10 | 25 | Y0 | 1/0 |  |
| B-9 | 26 | $\overline{\mathrm{OEY}}$ | 1 | Y bus output enable, low active. |
| F-2 | 27 | GND |  | Ground pin |

functional block diagram


## SN54AS888, SN74AS888 <br> 8-BIT PROCESSOR SLICES

## architectural elements

## 3-port register file

Working registers consist of 128 storage elements organized into sixteen 8 -bit words. These storage elements appear to the user as 16 positive edge-triggered registers. The three port addresses, one write $(C)$ and two reads ( $A$ and $B$ ), are completely independent of each other to implement a 3-operand register file. Data is written into the register file when $\overline{W E}$ is low and a low-to-high clock transition occurs. The ADD and SUBTRACT immediate instructions require only one source operand. The B address is used as the source address, and the bits of the $A$ address are used to provide a constant field. The SET, RESET, and TEST BIT instructions use the B addressed register as both the source and destination register while the $A$ and $C$ addresses are used as masks. These instructions are explained in more detail in the instruction section.

## S multiplexer

The S multiplexer selects the ALU operand, as follows:

| EB1 | EB0 | S bus |
| :--- | :--- | :--- |
| Low | Low | RF data |
| Low | High | MQ data |
| High | Low | DB data |
| High | High | MQ data |

DB port
Data is passed through the ALU or received from the register file on the 8-bit DB port. If $\overline{O E B}$ is low, the DB bus is active; if $\overline{O E B}$ is high, the DB bus is in the high impedance state. Notice that the DB port may be isolated at the same time that register file data is passed to the ALU.

## R multiplexer

The R multiplexer selects the other operand of the ALU. Except for those instructions that require constants or masks, the $R$ bus will contain DA if $\overline{E A}$ is high or the RF data pointed to by $A$ if $\overline{E A}$ is low.

DA bus
The DA bus is active (with register file data) if $\overline{O E A}$ is low. Notice that the DA bus may be isolated while register file data is passed to the ALU.

ALU
The shift instructions are summarized in Table 4 and illustrated in Figure 2. The ALU can perform seven arithmetic and six logical instructions on two 8-bit operands. It also supports multiplication, division, normalization, bit set, reset, test, byte operations, and excess-3 BCD arithmetic. These source operands are the outputs of the S and R multiplexers.

## ALU and MQ shifters

ALU and MQ shifters perform all of the shift, multiply, divide, and normalize functions. Table 4 shows the value of the $\overline{\mathrm{SIO7}}$ and $\overline{\mathrm{OIO7}}$ pins of the most significant package. The standard shifts may be made into conditional shifts and the serial data may be input or output with the aid of two three-state gates. These capabilities are discussed further in the arithmetic and logic section.

## MO register

The multiplier-quotient (MQ) register has specific functions in multiplication, division, and normalization. This register may also be used as a temporary storage register. The MO register may be loaded if the instruction code on pins 17-IO is E1-E7 or E9-EE (See Table 1).

## Y bus

The $Y$ bus contains the output of the ALU shifter if $\overline{\mathrm{OEY}}$ is low and is a high impedance input if $\overline{\mathrm{OEY}}$ is high. SELY must be low to pass the internal ALU shift bus and must be high to pass the external $Y$ bus to the register file.

## status

Four status pins are available on the most significant package, overflow (OVR), sign ( N ), carry out ( $\mathrm{C}_{\mathrm{n}}+8$ ), and zero (ZERO). The $C_{n}+8$ line signifies the ALU result while OVR, ZERO, and $N$ refer the status after the ALU shift has occurred. Notice that the ZERO pin cannot be used to detect whether an input placed on a high impedance $Y$ bus is zero.

## divide BCD flip-flops

The multiply-divide flip-flops contain the status of the previous multiply or divide instruction. They are affected by the following instructions:

DIVIDE REMAINDER FIX<br>SIGNED DIVIDE QUOTIENT FIX<br>SIGNED MULTIPLY<br>SIGNED MULTIPLY TERMINATE<br>SIGNED DIVIDE INITIALIZE<br>SIGNED DIVIDE START

SIGNED DIVIDE ITERATE<br>UNSIGNED DIVIDE START<br>UNSIGNED DIVIDE ITERATE UNSIGNED MULTIPLY<br>SIGNED DIVIDE TERMINATE<br>UNSIGNED DIVIDE TERMINATE

The excess-3 BCD flip-flops are affected by all instructions except NOP. The clear function clears these flip-flops. They preserve the carry from each nibble (4-bits) in excess-3/BCD operations.

## package position pin (PPP)

The position of the processor in the system is defined by the voltage level applied to the package position pin (PPP). Intermediate positions are selected by leaving the pin open. Tying the pin to VCC makes the processor the most significant package and tying the pin to GND makes the processor the least significant package.

## special shift function (SSF) pin

Conditional shifting algorithms may be implemented via control of the SSF pin. The applied voltage to this pin may be set as a function of a potential overflow condition (the two most significant bits are not equal) or any other condition (see Group 1 instructions).

## instruction set

The 'AS888 bit-slice processor uses bits 17-10 as instruction inputs. A combination of bits $13-10$ (Group 1 instructions) and bits 17-14 (Group 2-5 instructions) are used to develop the 8 -bit op code for a specific instruction. Group 1 and Group 2 instructions can be combined to perform arithmetic or logical functions plus a shift function in one instruction cycle. A summary of the instruction set is given in Table 1.

## TABLE 1. INSTRUCTION SET

GROUP 1 INSTRUCTIONS

| INSTRUCTION BITS (I3-IO) HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :---: |
| 0 <br> 1 <br> 2 <br> 3 <br> 4 <br> 5 <br> 6 <br> 7 <br> 8 <br> 9 <br> A <br> B <br> C <br> D <br> E <br> F | ADD <br> SUBR <br> SUBS <br> INCS <br> INCNS <br> INCR <br> INCNR <br> XOR <br> AND <br> OR <br> NAND <br> NOR <br> ANDNR | Accesses Group 4 instructions $\begin{aligned} & R+S+C_{n} \\ & \bar{R}+S+C_{n} \\ & R+\bar{S}+C_{n} \\ & S+C_{n} \\ & \bar{S}+C_{n} \\ & R+C_{n} \\ & \bar{R}+C_{n} \end{aligned}$ <br> Accesses Group 3 instructions <br> R XOR S <br> R AND $S$ <br> R OR S <br> R NAND S <br> R NOR S <br> $\bar{R}$ AND S <br> Accesses Group 5 instructions |
| GROUP 2 INSTRUCTIONS |  |  |
| INSTRUCTION BITS (17-14) HEX CODE | MNEMONIC | FUNCTION |
| 0 1 2 3 3 4 5 6 7 8 8 9 A B C D E | SRA <br> SRAD <br> SRL <br> SRLD <br> SLA <br> SLAD <br> SLC <br> SLCD <br> SRC <br> SRCD <br> MOSRA <br> MQSRL <br> MQSLL <br> MQSLC <br> LOADMO <br> PASS | Arithmetic Right Single <br> Arithmetic Right Double <br> Logical Right Single <br> Logical Right Double <br> Arithmetic Left Single <br> Arithmetic Left Double <br> Circular Left Single <br> Circular Left Double <br> Circular Right Single <br> Circular Right Double <br> Pass $(F \rightarrow Y)$ and Arithmetic Right MO <br> Pass $(F \rightarrow Y)$ and Logical Right MQ <br> Pass $(F \rightarrow Y)$ and Logical Left MQ <br> Pass $(F \rightarrow Y)$ and Circular Left MQ <br> Pass $(F \rightarrow Y)$ and Load MQ $(F=M Q)$ <br> Pass $(F \rightarrow Y)$ |

TABLE 1. INSTRUCTION SET (Continued)
GROUP 3 INSTRUCTIONS

| INSTRUCTION BITS (17-IO) HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :---: |
| 08 18 28 38 48 58 68 78 88 98 A8 B8 C8 D8 E8 F8 | SET 1 <br> SETO <br> TB1 <br> TBO <br> ABS <br> SMTC <br> ADDI <br> SUBI <br> BADD <br> BSUBS <br> BSUBR <br> BINCS <br> BINCNS <br> BXOR <br> BAND <br> BOR | Set Bit <br> Reset Bit <br> Test Bit (One) <br> Test Bit (Zero) <br> Absolute Value <br> Sign Magnitude/Two's Complement <br> Add Immediate <br> Subtract Immediate <br> Byte Add R to S <br> Byte Subtract $S$ from $R$ <br> Byte Subtract R from S <br> Byte Increment S <br> Byte Increment Negative $S$ <br> Byte XOR R and S <br> Byte $A N D R$ and $S$ <br> Byte OR R and S |
| GROUP 4 INSTRUCTIONS |  |  |
| INSTRUCTION BITS (I7-IO) heX CODE | MNEMONIC | FUNCTION |
| 00 10 20 30 40 50 60 70 80 90 AO $B O$ CO DO EO FO | SEL <br> SNORM <br> DNORM <br> DIVRF <br> SDIVQF <br> SMULI <br> SMULT <br> SDIVIN <br> SDIVIS <br> SDIVI <br> UDIVIS <br> UDIVI <br> UMULI <br> SDIVIT <br> UDIVIT | Reserved <br> Select S/R <br> Single Length Normalize <br> Double Length Normalize <br> Divide Remainder Fix <br> Signed Divide Quotient Fix <br> Signed Multiply Iterate <br> Signed Multiply Terminate <br> Signed Divide Initialize <br> Signed Divide Start <br> Signed Divide Iterate <br> Unsigned Divide Start <br> Unsigned Divide Iterate <br> Unsigned Multiply Iterate <br> Signed Divide Terminate <br> Unsigned Divide Terminate |

TABLE 1. INSTRUCTION SET (Concluded)
GROUP 5 INSTRUCTIONS

| INSTRUCTION BITS (I7-IO) <br> HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| OF | CLR | Clear |
| $1 F$ | CLR | Clear |
| $2 F$ | CLR | Clear |
| $3 F$ | CLR | Clear |
| $4 F$ | CLR | Clear |
| $5 F$ | CLR | Clear |
| $6 F$ | CLR | Clear |
| $7 F$ | BCDBIN | BCD to Binary |
| $8 F$ | EX3BC | Excess-3 Byte Correction |
| $9 F$ | EX3C | Excess-3 Word Correction |
| AF | SDIVO | Signed Divide Overflow Check |
| BF | CLR | Clear |
| CF | CLR | Clear |
| DF | BINEX3 | Binary to Excess-3 |
| EF | CLR | Clear |
| FF | NOP | No Operation |

group 1 instructions
TABLE 2. GROUP 1 INSTRUCTIONS

| INSTRUCTION BITS (I3-IO) <br> HEX CODE | MNEMONIC | FUNCTION |
| :---: | :--- | :--- |
| 0 |  | Accesses Group 4 instructions |
| 1 | ADD | $R+S+C_{n}$ |
| 2 | SUBR | $\bar{R}+S+C_{n}$ |
| 3 | SUBS | $R+\bar{S}+C_{n}$ |
| 4 | INCS | $S+C_{n}$ |
| 5 | INCNS | $\bar{S}+C_{n}$ |
| 6 | INCR | $R+C_{n}$ |
| 7 | INCNR | $\bar{R}+C_{n}$ |
| 8 |  | Accesses Group 3 instructions |
| 9 | XOR | $R$ XOR S |
| A | AND | R AND S |
| B | OR | $R$ OR S |
| C | NAND | $R$ NAND S |
| $D$ | NOR | $R$ NOR S |
| E | ANDNR | $\bar{R}$ AND S |
| F |  | Accesses Group 5 instructions |

Group 1 instructions (excluding hex codes 0,8 , and $F$ ), shown in Table 2, may be used in conjunction with Group 2 shift instructions to perform arithmetic or logical functions plus a shift function ${ }^{\dagger}$ in one instruction cycle (hex codes 0,8 , and $F$ are used to access Group 4, 3, and 5 instructions, respectively). Each shift may be made into a conditional shift by forcing the special shift function (SSF) pin into the proper state. If the SSF pin is high or floating, the shifted ALU output will be sent to the output buffers. If the SSF pin is pulled low externally, the ALU result will be passed directly to the output buffers. Conditional shifting is useful for scaling inputs in data arrays or in signal processing algorithms.

These instructions set the BCD flip-flop for the excess-3 correct instruction. The status is set with the following results ( $C_{n}+8$ is ALU carry out and is independent of shift operation; others are evaluated after shift operation).
${ }^{\dagger}$ Double-precision shifts involve both the ALU and MQ register.
condition code
Arithmetic
$\mathrm{N} \quad-\quad$ MSB of result
OVR - Signed arithmetic overflow
$C_{n}+8-$ Carry out equal one Z $\quad-\quad$ Result equal zero
Logic
N $\quad$ - MSB of result
OVR - None (force to zero)
$\mathrm{C}_{\mathrm{n}}+8 \quad-\quad$ None (force to zero)
Z $\quad-\quad$ Result equal zero
group 2 instructions
TABLE 3. GROUP 2 INSTRUCTIONS

| INSTRUCTION BITS (17-14) <br> HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| 0 | SRA | Arithmetic Right Single |
| 1 | SRAD | Arithmetic Right Double |
| 2 | SRL | Logical Right Single |
| 3 | SRLD | Logical Right Double |
| 4 | SLA | Arithmetic Left Single |
| 5 | SLAD | Arithmetic Left Double |
| 6 | SLC | Circular Left Single |
| 7 | SLCD | Circular Left Double |
| 8 | SRC | Circular Right Single |
| 9 | SRCD | Circular Right Double |
| A | MQSRA | Pass $(F \rightarrow Y)$ and Arithmetic Right MQ |
| $B$ | MQSRL | Pass $(F \rightarrow Y)$ and Logical Right MQ |
| C | MQSLL | Pass $(F \rightarrow Y)$ and Logical Left MQ |
| D | MQSLC | Pass $(F \rightarrow Y)$ and Circular Left MQ |
| E | LOADMQ | Pass $(F \rightarrow Y)$ and Load MQ $(F=M Q)$ |
| $F$ | PASS | Pass $(F \rightarrow Y)$ |

## SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES

The processor's shift instructions are implemented by a combination of Group 2 instructions (Table 3) and certain wired connections on the packages used. The following external connections are required.

On intermediate packages:
$\overline{\mathrm{SIO7}}$ is connected to $\overline{\mathrm{SIOO}}$ of the next most significant package
$\overline{\mathrm{Q} 107}$ is connected to $\overline{\mathrm{QIOO}}$ of the next most significant package
$\overline{\mathrm{SIOO}}$ is connected to $\overline{\mathrm{SIO7}}$ of the next least significant package
$\overline{\mathrm{QIOO}}$ is connected to $\overline{\mathrm{QIOF}}$ of the next least significant package
On the two end packages:
$\overline{S I O 7}$ on the most significant package is connected to $\overline{\mathrm{SIOO}}$ of the least significant package $\overline{\mathrm{QIO}}$ on the most significant package is connected to $\overline{\mathrm{QIOO}}$ of the least significant package

The connections are the same on all instructions including multiply, divide, CRC, and normalization functions.
Single- and double-precision shifts are supported. Double-precision shifts assume the most significant half has come through the ALU and will be placed (if $\overline{W E}$ is low) into the register file on the rising edge of the clock and the least significant half lies in the MQ register. All Group 2 shifts may be made conditional (see previous page).

The following definitions apply to Group 2 shift instructions:
Arithmetic right shifts copy the sign of the number if no overflow occurs from the ALU calculation; if overflow occurs, the sign bit is inverted.
Arithmetic left shifts do not retain the sign of the number if an overflow occurs. A zero is filled into the LSB if not forced externally.
Logical right shifts fill a zero in the MSB position if not forced externally.
Circular right shifts fill the LSB in the MSB position.
Circular left shifts fill the MSB in the LSB position.
Shifting left is defined as moving a bit position towards the MSB (doubling).
Shifting right is defined as moving a bit towards the LSB (halving).
Serial input may be performed using the circuitry shown in Figure 1. A single-/or double-precision arithmetic left or logical right shift fills the complement of the data on $\overline{\mathrm{SIOO}}$ and $\overline{\mathrm{SIO7}}$ into the LSB or MSB of the data word(s). Note that if $\overline{\mathrm{SIOO}}$ and $\overline{\mathrm{SIO7}}$ are floating ( $\mathrm{HI}-\mathrm{Z}$ ), a zero will be filled as an end condition.

Serial output may be performed with circular instructions.


FIGURE 1. SERIAL I/O

## SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES

The shift instructions are summarized in Table 4 and illustrated in Figure 2. In Figure 2 and all succeeding figures that illustrate instruction execution, the following definitions apply:

CRF - CRC accumulator end fill.
QBT - End fill for signed divide.
MQF - End fill for unsigned divide.
SRF - End fill for signed multiply and the arithmetic right shifts.
TABLE 4. SHIFT INSTRUCTIONS

| $\begin{gathered} \text { OP } \\ \text { CODE } \end{gathered}$ | SHIFT FUNCTION ${ }^{\ddagger}$ | $\begin{aligned} & \overline{\mathrm{SIO7}} \cdot \overline{\mathrm{SIO0}} \\ & \text { WIRED VALUE } \end{aligned}$ | $\begin{aligned} & \overline{\mathrm{Q107}} \cdot \overline{\mathrm{Q} 100} \\ & \text { WIRED VALUE } \end{aligned}$ |
| :---: | :---: | :---: | :---: |
| ON | Arithmetic Right Single | ALU-LSB Output | -- |
| 1 N | Arithmetic Right Double | MQ-LSB Output | ALU-LSB Output |
| 2 N | Logical Right Single | Input to ALU-MSB | ALU-LSB Output |
| 3N | Logical Right Double | Input to ALU-MSB | ALU-LSB Output |
| 4N | Arithmetic Left Single | Input to ALU-LSB | ALU-MSB Output |
| 5 N | Arithmetic Left Double | Input to MQ-LSB | MQ-MSB Output |
| 6N | Circular Left Single | ALU-MSB Output | - |
| 7N | Circular Left Double | ALU-MSB Output | MQ-MSB Output |
| 8N | Circular Right Single | ALU-LSB Output | - |
| 9 N | Circular Right Double | MQ-LSB Output | ALU-LSB Output |
| AN | Arithmetic Right (MQ only) | MQ-LSB Output | MQ-LSB Output |
| BN | Logical Right (MQ only) | MQ-LSB Output | Input to MQ-MSB |
| CN | Logical Left (MQ only) | Input to MQ-LSB | MQ-MSB Output |
| DN | Circular Left (MQ only) | MQ-MSB Output | MQ-MSB Output |

${ }^{\dagger}$ Op Code $N \neq 0,8$, or $F$; these select special instruction Groups 4,3 , and 5 respectively. ${ }^{\ddagger}$ Shift I/O pins are active low. Therefore, inputs and outputs must be inverted if true logical values are required.

Status is set with the following results:
Arithmetic
$\mathrm{N} \rightarrow \quad$ Result MSB equal one
OVR $\rightarrow$ Signed arithmetic overflow ${ }^{\dagger}$
$C_{n}+8 \rightarrow$ Carry out equal one
$\mathrm{Z} \quad \rightarrow \quad$ Result equal zero
Logic
$\mathrm{N} \rightarrow$ Result MSB equal one
OVR $\rightarrow$ Zero
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow$ Zero
$\mathrm{Z} \quad \rightarrow \quad$ Result equal zero
${ }^{\dagger}$ For the SLA and SLAD instructions, OVR is set if signed arithmetic overflow or if the ALU result MSB XOR MSB-1 equals one.

FIGURE 2. SHIFT INSTRUCTIONS
2

## SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES

SERIAL DATA INPUT (CRU)

FIGURE 2. SHIFT INSTRUCTIONS (Continued)
SERIAL DATA INPUT



FIGURE 2. SHIFT INSTRUCTIONS (Continued)

CIRCULAR RIGHT SINGLE

CIRCULAR RIGHT DOUBLE

FIGURE 2. SHIFT INSTRUCTIONS (Continued)

SERIAL DATA IN
FIGURE 2. SHIFT INSTRUCTIONS (Continued)
LOGICAL LEFT (MO ONLY) SERIAL DATA IN

FIGURE 2. SHIFT INSTRUCTIONS (Concluded)

## group 3 instructions

Hex code 8 of Group 1 instructions is used to access Group 3 instructions. Group 3 instructions are summarized in Table 5.

TABLE 5. GROUP 3 INSTRUCTIONS

| INSTRUCTION BITS (I7-IO) <br> OP CODE (HEX) | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| 08 | SET1 | Set Bit |
| 18 | SETO | Reset Bit |
| 28 | TB1 | Test Bit (One) |
| 38 | TBO | Test Bit (Zero) |
| 48 | ABS | Absolute Value |
| 58 | SMTC | Sign Magnitude/Two's Complement |
| 68 | ADDI | Add Immediate |
| 78 | SUBI | Subtract Immediate |
| 88 | BADD | Byte Add R to S |
| 98 | BSUBS | Byte Subtract S from R |
| A8 | BSUBR | Byte Subtract R from S |
| B8 | BINCS | Byte Increment S |
| C8 | BINCNS | Byte Increment Negative S |
| D8 | BXOR | Byte XOR R and S |
| E8 | BAND | Byte AND R and S |
| F8 | BOR | Byte OR R and S |

set bit instruction (set1): $17-10=0816$
This instruction (Figure 3) is used to force selected bits of a desired byte(s) to one (any combination of zero to eight bits). The desired bits are specified by an 8-bit mask (C3-C0)::(A3-A0) ${ }^{\dagger}$ consisting of register file address ports that are not required to support this instruction. All bits in the selected byte(s) that are in the same bit positions as ones in the mask are forced to a logical one. The B3-BO address field is used for both source and destination of this instruction. The desired byte is specified by forcing $\overline{\mathrm{SIOO}}$ to a low value. Nonselected packages pass the byte through unaltered. The $S$ bus is the source word for this instruction. The status set by the set bit instruction is as follows:

| N | $\rightarrow$ | None (force to zero) |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | None (force to zero) |
| $\mathrm{C}_{\mathrm{n}}+8$ | $\rightarrow$ | None (force to zero) |
| Z | $\rightarrow$ | Result equal zero |

$\dagger$ The symbol ' $\because$ ' is concatenation operator


FIGURE 3. SET BIT (OR RESET BIT)
NOTES: 1. Force $\overline{\mathrm{SIOO}}$ low to select byte.
2. Bit mask (C3-CO)::(A3-A0) will set desired bits to one.

## reset bit instruction $(\operatorname{set} 0)$ : $17-10=1816$

This instruction (Figure 3) is used to force selected bits of a desired byte(s) to zero (any combination of one to eight bits). The desired bits are specified by an 8-bit mask (C3-C0)::(A3-A0) consisting of register file address ports that are not required to support this instruction. All bits in the selected byte(s) that are in the same bit positions as ones in the mask are reset. The B3-BO address field is used for both source
and destination of this instruction. The desired byte is specified by forcing $\overline{\mathrm{SIOO}}$ to a low value. Nonselected packages pass the byte through unaltered. The $S$ bus is the source word for this instruction. The status set by the reset bit instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { None (force to zero) } \\
\text { OVR } & \rightarrow & \text { None (force to zero) } \\
\mathrm{C}_{n}+8 & \rightarrow & \text { None (force to zero) } \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

test bit (one) instruction (TB1): $17-10=2816$
This instruction (Figure 4) is used to test selected bits of a desired byte(s)(any combination of one to eight bits). Bits to be tested are specified by an 8 -bit mask (C3-CO)::(A3-AO) consisting of register file address ports that are not required to support this instruction. Write Enable $(\overline{\mathrm{WE}})$ is internally disabled during this instruction. The desired byte is specified by forcing $\overline{\mathrm{SIOO}}$ to a low value. The test will pass if the selected byte has ones at all bit locations specified by the ones of the mask (Figure 5). The $S$ bus is the source word for this instruction. The status set by the test bit (one) instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { None (force to zero) } \\
\text { OVR } & \rightarrow \\
\text { None (force to zero) } \\
\mathrm{C}_{n}+8 & \rightarrow \\
\mathrm{Z} & \rightarrow \\
\text { None (force to zero) }
\end{array}
$$



FIGURE 4. TEST BIT
NOTES: 1. Force $\overline{S I O O}$ low to select byte
2. Bit mask (C3-CO)::(A3-AO) will define bits for testing.
3. Pass/fail is indicated on $Z$ output.

> SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES
test bit (zero) instruction (TBO): 17-10 $=3816$
This instruction (Figure 4) is used to test selected bits of a desired byte(s) (any combination of one to eight bits). Bits to be tested are specified by an 8-bit mask (C3-CO)::(A3-AO) consisting of register file address ports that are not required to support this instruction. Write Enable ( $\overline{\mathrm{WE}}$ ) is internally disabled during this instruction. The desired byte is specified by forcing $\overline{\mathrm{SIOO}}$ to a low value. The test will pass if the selected byte has zeros at all bit locations specified by the ones of the mask (Figure 6). The S bus is the source word for this instruction. The status set by the test bit (zero) instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { None (force to zero) } \\
\text { OVR } & \rightarrow \\
\text { None (force to zero) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\mathrm{~N} \text { None (force to zero) }
\end{array}
$$



FIGURE 5. TEST BIT ONE EXAMPLES

## SN54AS888, SN74AS888 <br> 8-BIT PROCESSOR SLICES



FIGURE 6. TEST BIT ZERO EXAMPLES
absolute value instruction (ABS): $17-10=4816$
This instruction is used to convert two's complement numbers to their positive value. The operand placed on the $S$ bus is the source for this instruction. The MSP will test the sign of the S bus and force the SSF pin to the proper value. All other packages use the SSF pin as input to determine instruction execution. The status set by the absolute value instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { Input MSB equal one } \\
\text { OVR } & \rightarrow \text { Input equal } 8000 \text { (hex) } \\
\mathrm{C}_{n}+8 & \rightarrow \mathrm{~S}=0 \\
\mathrm{Z} & \rightarrow \text { Result equal zero }
\end{array}
$$

sign magnitude/two's complement instruction (SMTC): 17-10 $=5816$
This instruction allows conversion from two's complement representation to sign magnitude representation, or vice-versa, in one clock cycle. The operand placed on the $S$ bus is the source for this instruction.

When a negative zero ( 8000 hex ) is converted, the result is 0000 with an overflow. If the input is in two's complement notation, the overflow indicates an illegal conversion. The status set by the sign magnitude/two's complement instruction is as follows:

| N | $\rightarrow$ | Result MSB equal one |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Input equal 8000 (hex) |
| $\mathrm{C}_{\mathrm{n}}+8$ | $\rightarrow$ | Input equal 0000 (hex) |
| Z | $\rightarrow$ | Result equal zero |

## SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES

add immediate instruction (ADDI): $17-10=6816$
This instruction is used to add a specified constant value to the operand placed on the $S$ bus. The constant will be between the values of 0 and 15 . The constant value is specified by the unused register file address (A port) not required to support this instruction. Forcing the carry input will add an additional one to the result. The status set by the add immediate instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \text { Result MSB equal one } \\
\text { OVR } & \rightarrow \text { Arithmetic signed overflow } \\
\mathrm{C}_{n}+8 & \rightarrow \text { Carry out equal one } \\
\mathrm{Z} & \rightarrow \text { Result equal zero }
\end{array}
$$

subtract immediate instruction (SUBI): 17-10 $=7816$
This instruction is used to subtract a specified constant value from the operand placed on the $S$ bus. The constant value is specified by the unused register file address (A port) that is not required to support this instruction. The constant applied is the least significant four bits of a two's complement number. The device sign extends the constant over the entire word length. The status set by the subtract immediate instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \text { Result MSB equal one } \\
\text { OVR } & \rightarrow \text { Arithmetic signed overflow } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \text { Carry out equal one } \\
\mathrm{Z} & \rightarrow
\end{array} \text { Result equal zero }
$$

## byte instructions

There are eight byte instructions in Group 3. These instructions modify selected bytes of the operand on the S bus. A byte is selected by forcing $\overline{\mathrm{SIOO}}$ to a low value (same as SET1, SETO, TB1, and TBO instructions). Multiple bytes may be selected only if they are adjacent to one another.

NOTE: At least one byte must be nonselected during these instructions.
The nonselected bytes are passed through unaltered. Byte status is forced through the most significant package except for the sign of the result ( $N$ ), which is forced to zero (low). The status set by the byte instructions is as follows:

## (Most Significant Package)

$N \quad \rightarrow \quad$ None (force to zero)
OVR $\rightarrow$ Byte signed overflow
$C_{n}+8 \rightarrow$ Byte carry out equal one
$Z \quad \rightarrow \quad$ Byte result equal to zero
(Selected BYTES - other than MSP)
$\overline{\mathrm{G}} \quad \rightarrow \quad$ Normal generate
$\overline{\mathrm{P}} \quad \rightarrow \quad$ Normal propagate
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow$ Normal carry out
$\mathrm{Z} \quad \rightarrow \quad$ Result equal to zero
(Nonselected BYTES - other than MSP)
$\overline{\mathrm{G}} \quad \rightarrow \quad$ No generate (force to one)
$\overline{\mathrm{P}} \quad \rightarrow \quad$ Propagate (force to zero)
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow \mathrm{C}_{\mathrm{n}}$
Z $\rightarrow \quad$ None (force to one)

|  | (Most Significant Package) |
| :--- | :--- |
| N | $\rightarrow$ None (force to zero) |
| OVR | $\rightarrow$ Byte signed overflow |
| $\mathrm{C}_{\mathrm{n}}+8$ | $\rightarrow$ Byte carry out equal one |
| Z | $\rightarrow$ Byte result equal to zero |

## SN54AS888, SN74AS888 <br> 8-BIT PROCESSOR SLICES

## group 4 instructions

Hex code 0 of Group 1 instructions is used to access Group 4 instructions. Group 4 instructions are summarized in Table 6.

TABLE 6. GROUP 4 INSTRUCTIONS

| INSTRUCTION BITS (I7-IO) <br> OP CODE (HEX) | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| 00 |  | Reserved |
| 10 | SEL | Select S/R |
| 20 | SNORM | Single Length Normalize |
| 30 | DNORM | Double Length Normalize |
| 40 | DIVRF | Divide Remainder Fix |
| 50 | SDIVQF | Signed Divide Quotient Fix |
| 60 | SMULI | Signed Multiply Iterate |
| 70 | SMULT | Signed Multiply Terminate |
| 80 | SDIVIN | Signed Divide Initialize |
| 90 | SDIVIS | Signed Divide Start |
| AO | SDIVI | Signed Divide Iterate |
| BO | UDIVIS | Unsigned Divide Start |
| CO | UDIVI | Unsigned Divide Iterate |
| DO | UMULI | Unsigned Multiply Iterate |
| EO | SDIVIT | Signed Divide Terminate |
| FO | UDIVIT | Unsigned Divide Terminate |

select $S / R$ instruction (SEL): $17-10=1016$
This instruction is used to pass either the $S$ bus or the $R$ bus to the output depending on the state of the SSF input pin. Normally, the preceding instruction would test the two operands and the resulting status information would be used to force the SSF input pin. SSF $=0$ will output the R bus and $\operatorname{SSF}=1$ will output the $S$ bus. The status set by the select $S / R$ instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { Result MSB equal one } \\
\text { OVR } & \rightarrow & \text { None (force to zero) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow & \text { None (force to zero) } \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

single-length normalize instruction (SNORM): 17-10 $=\mathbf{2 0 1 6}$
This instruction will cause the contents of the MQ register to shift toward the most significant bit. Zeros are shifted in via the $\overline{\mathrm{QIOO}}$ input. The number of shifts performed can be counted and stored in one of the register files by forcing a high at the $C_{n}$ input. When the two most significant bits are of opposite value, normalization is complete. This condition is indicated on the microcycle that completes the normalization at the OVR output.

The chip contains conditional logic that inhibits the shift function (and also inhibits the register file increment) if the number within the MQ register is already normalized at the beginning of the instruction (Figure 7). The status set by the single-length normalize instruction is as follows:

$$
\begin{aligned}
& \mathrm{N} \quad \rightarrow \quad \mathrm{MSB} \text { of result } \\
& \text { OVR } \rightarrow \text { MSB XOR 2nd MSB } \\
& C_{n}+8 \rightarrow \text { Carry out equal one } \\
& \text { Z } \quad \rightarrow \quad \text { Result equal zero }
\end{aligned}
$$

SINGLE-LENGTH NORMALIZE


FIGURE 7. SINGLE- AND DOUBLE-LENGTH NORMALIZE

## SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES

double-length normalize instruction (DNORM): 17-10 $=\mathbf{3 0 1 6}$
This instruction will cause the contents of a double-length word (register file contains the most significant half and the MO register contains the least significant half) to shift toward the most significant bit. Zeros are shifted in via the $\overline{\mathrm{OOO}}$ input. When the two most significant bits are of opposite value, normalization is complete. This condition is indicated on the microcycle that completes the normalization at the OVR output.
The chip contains conditional logic which inhibits the shift function if the number is already normalized at the beginning of the instruction (Figure 7). The most significant half of the operand must be placed on the S bus. The status set by the double-length normalize instruction is as follows:

$$
\begin{array}{lll}
\text { N } & \rightarrow & \text { MSB of result } \\
\text { OVR } & \rightarrow & \text { MSB XOR 2nd MSB } \\
C_{n}+8 & \rightarrow & \text { None (force to zero) } \\
Z & \rightarrow & \text { Result equal zero }
\end{array}
$$

## multiply operations

The ALU performs three unique types of N by N multiplies each of which produces a 2 N -bit result (Figure 8 ). All three types of multiplication proceed via the following recursion:
$P(J+1)=2[P(J)+$ Multiplicand $\times M(8 N-J)]$
where
$\mathrm{P}(\mathrm{J}) \quad=\quad$ partial product at iteration number J
$\mathrm{N} \quad=$ number of 'AS888 packages that are cascaded
$\mathrm{P}(\mathrm{J}+1)=$ partial product at iteration number $\mathrm{J}+1$
$J$ varies from 0 to $8 N[N=2$ for $16 \times 16$ multiply]
$\mathrm{M}(8 \mathrm{~N}-\mathrm{J})=$ mode bit (unique to multiply type)
2 denotes some type of shift (unique to multiply)
Notice that by proper choice of mode terms and shifting operations, signed, unsigned, and mixed multiplies (signed times unsigned) may be performed.

All multiplies assume that the multiplier is stored in MQ before the operation begins (in the case of mixed multiply, the unsigned number must be the multiplier).

The processor has the following multiply instructions:

1. SIGNED MULTIPLY ITERATE (SMULI): $17-10=60_{16}$
2. SIGNED MULTIPLY TERMINATE (SMULT): $17-10=7016$
3. UNSIGNED MULTIPLY ITERATE (UMULI): $17-10=\mathrm{DO}_{16}$
SMULI, SMULT

FIGURE 8. MULTIPLICATION OPERATIONS

## SN54AS888, SN74AS888 <br> 8-BIT PROCESSOR SLICES

The signed multiply iterate (SMULI) instruction performs a signed times signed iteration. This instruction interprets $\mathrm{M}(8 \mathrm{~N}-\mathrm{J})$ as the $8 \mathrm{~N}-\mathrm{J}$ bit of the multiplier. The shift is a double-precision right shift one bit. This instruction is repeated 15 times for a $16 \times 16$ signed multiply. This instruction will be used 16 consecutive times for a mixed multiplication.

The signed multiply terminate (SMULT) instruction provides correct (negative) weighting of the sign bit of a negative multiplier in signed multiplication. The instruction is identical to signed multiply iterate (SMULI) except that $\mathrm{M}(8 \mathrm{~N}-\mathrm{J})$ is interpreted as -1 if the sign bit of the multiplier is 1 , and 0 if the sign bit of the multiplier is 0 .

The unsigned multiply iterate (UMULI) performs an unsigned multiplication iteration. This instruction interprets $\mathrm{M}(8 \mathrm{~N}-\mathrm{J})$ as the $8 \mathrm{~N}-\mathrm{J}$ bit of the multiplier. The shift is a double-precision right shift with the carry out from the $\mathrm{P}(\mathrm{J})+$ Multiplicand $\times \mathrm{M}(8 \mathrm{~N}-\mathrm{J})$ operation forced into bit 8 N of $\mathrm{P}(\mathrm{J}+1)$. This instruction is used in unsigned and mixed multiplication.

## signed multiplication

Signed multiplication performs an $8 \mathrm{~N}+2$ clock two's complement multiply. The instructions necessary to produce an algebraically correct result proceed in the following manner:

Zero register to be used for accumulator
Load MO with multiplier
SMULI (repeat $8 \mathrm{~N}-1$ times)

SMULT
S port $=$ Accumulator
R port $=$ Multiplicand
F port $=$ Iteration result
S port $=$ Accumulator
R port $=$ Multiplicand
F port $=$ Product (MSH)

At completion, the accumulator will contain the 8 N most significant bits and the MO contains the 8 N least significant bits of the product.

The status for the signed multiply iterate should not be used for any testing (overflow is not set by SMULI). The following status is set for the signed multiply terminate instruction:
$\mathrm{N} \quad \rightarrow \quad$ Result MSB equal one
OVR $\rightarrow$ Forced to zero
$\mathrm{C}_{\mathrm{n}+8} \rightarrow$ Carry out equal to one
Z $\quad \rightarrow \quad$ Double precision result is zero

## unsigned multiplication

Unsigned multiplication produces an unsigned times unsigned product in $8 \mathrm{~N}+2$ clocks. The instructions necessary to produce an algebraically correct result proceed in the following manner:

Zero register to be used for accumulator
Load MO with multiplier
UMULI ( 8 N times) $\quad$ S port $=$ Accumulator
R port $=$ Multiplicand
F port $=$ Iteration result (product MSH on final result)

Upon completion, the accumulator will contain the 8 N most significant bits and-the MQ contains the 8 N least significant bits of the product.

The status set by the unsigned multiply iteration is meaningless except on the final execution of the instruction. The status set by the unsigned multiply iteration instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { Result MSB equal one } \\
\mathrm{OVR} & \rightarrow \\
\text { Forced to zero } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\text { Carry out equal to one } \\
\mathrm{Z} & \rightarrow \\
\text { Double-precision result is zero }
\end{array}
$$

## mixed multiplication

Mixed multiplication multiplies a signed multiplicand times an unsigned multiplier to produce a signed result in $8 N+2$ clocks. The steps are as follows:

Zero register used for accumulator
Load MO with unsigned multipler
$\begin{array}{ll}\text { SMULI (8N times) } & \text { S port } \\ \text { R port } & =\text { Accumulator } \\ & \text { F port }\end{array}=$ Iteration result

Upon completion, the accumulator will contain the 8 N most significant bits and the MQ will contain the 8 N least significant bits of the product.

The following status is set by the last SMULI instruction:

| N | $\rightarrow$ |
| :--- | :--- |
| Result MSB equal one |  |
| OVR | $\rightarrow$ |
| $\mathrm{C}_{\mathrm{n}}+8$ | $\rightarrow$ |
| Z | $\rightarrow$ Carced to zero out equal to one |
| Z | Double-precision result is zero |

## divide operations

The divide uses a nonrestoring technique to perform both signed and unsigned division of a 16 N bit integer dividend and an 8 N bit integer divisor (Figure 9). It produces an 8 N integer quotient and remainder.
The remainder and quotient will be such that the following equation is satisfied:

$$
\text { (Quotient) } \times \text { (Divisor })+ \text { Remainder }=\text { Dividend }
$$

The processor has the following divide instructions:

1. UNSIGNED DIVIDE START (UDIVIS): $17-10=B 016$
2. UNSIGNED DIVIDE ITERATE (UDIVI): $17-10=\mathrm{C} 016$
3. UNSIGNED DIVIDE TERMINATE (UDIVIT): $17-10=$ F016
4. SIGNED DIVIDE INITIALIZE (SDIVIN): $17-10=8016$
5. SIGNED DIVIDE OVERFLOW TEST (SDIVO): $17-10=A F_{16}$
6. SIGNED DIVIDE START (SDIVIS): $17-I 0=9016$
7. SIGNED DIVIDE ITERATE (SDIVI): $17-10=A 016$
8. SIGNED DIVIDE TERMINATE (SDIVIT): $17-10=$ E016
9. DIVIDE REMAINDER FIX (DIVRF): $17-I O=4016$
10. SIGNED DIVIDE QUOTIENT FIX (SDIVQF): $17-10=5016$

## SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES

SDIVIN, SDIVS, SDIVI

uDIVS, UDIVI


The unsigned divide iterate start (UDIVIS) instruction begins the iterate procedure while testing for overflow. Overflow is reported when the first subtraction of the divisor from the MSH of the dividend produces carry out. The test detects quotient overflow and divide by zero.

The unsigned divide iterate terminate (UDIVIT) instruction completes the iterate procedure generating the last quotient bit.

The signed divide initialize (SDIVIN) instruction prepares for iteration by shifting the dividend and storing the sign of the dividend for use in the following instructions and overflow tests.

The signed divide overflow test (SDIVO) checks for overflow possibilities. This instruction may be deleted from the divide operation if the OVR pin is ignored. If it is removed some overflow conditions will go undetected. $\overline{W E}$ must be high (writing inhibited) when this instruction is used.

The signed divide iterate start (SDIVIS) instruction calculates the difference between the divisor and MSH of the dividend. Partial detection of overflow is also done during this instruction. Operations with like signs (positive quotient) and division by zero will overflow during this instruction (including zero divisor). Operations with unlike signs are tested for overflow during the signed divide quotient fix instruction (SDIVQF). Partial overflow results are saved and will be used during SDIVQF when overflow is reported.

The signed divide iterate (SDIVI) instruction forms the quotient and remainder through iterative subtract/addshift operations of the divisor and dividend. One quotient bit is generated on each clock.

The signed divide iterate terminate (SDIVIT) instruction completes the iterate procedure, generating the last quotient bit. It also tests for a remainder equal to zero, which determines the action to be taken in the following correction (fix) instructions.

The divide remainder fix (DIVRF) instruction corrects the remainder. If a zero remainder was detected by the previous instructions, the remainder is forced to zero. For nonzero remainder cases where the remainder and dividend have the same sign, the remainder is correct. When the remainder and dividend have unlike signs, a correction add/subtract of the divisor to the remainder is performed.

The signed divide quotient fix (SDIVQF) instruction corrects the quotient if necessary. This correction requires adding one to the incorrect quotient. An incorrect quotient results if the signs of the divisor and dividend differ and the remainder is nonzero. An incorrect quotient also results if the sign of the divisor is negative and the remainder is zero.

Overflow detection is completed during this instruction. Overflow may be generated for differing signs of the dividend and divisor. The partial overflow test result performed during SDIVIS is ORed with this test result to produce a true overflow indication.

## signed divide usage

The instructions necessary to perform an algebraically correct division of signed numbers are as follows:
Load MQ with the least significant half of the dividend

| SDIVIN | S port $=$ MSH of dividend |
| :--- | :--- |
|  | R port $=$ Divisor |
|  | F port $=$ Intermediate result |
| SDIVO | S port $=$ Result of SDIVIN |
|  | R port $=$ Divisor |
|  | F port $=$ Test result |
|  | (WE must be high) |
| SDIVIS | S port $=$ Result of SDIVIN |
|  | R port $=$ Divisor |
|  | F port $=$ Intermediate result |


| SDIVI (8N-2 times) | S port$=$ Result of SDIVIS (or SDIVI) |
| :--- | :--- |
|  | R port $=$ Divisor |
|  | F port $=$ Intermediate result |
| SDIVIT | S port $=$ Result of last SDIVI |
|  | R port $=$ Divisor |
|  | F port $=$ Intermediate result |
| DIVRF | S port $=$ Result of SDIVIT |
|  | R port $=$ Divisor |
|  | F port $=$ Remainder |
| SDIVQF | S port $=$ MQ register |
|  | R port $=$ Divisor |
|  | F port $=$ Quotient |

The status of all signed divide instructions except SDIVIN, DIVRF, and SDIVQF is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { Forced to zero } \\
\text { OVR } & \rightarrow \\
\text { Forced to zero } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\mathrm{Carry} \text { out equal to one } \\
\mathrm{Z} & \rightarrow \\
\text { Intermediate result is zero }
\end{array}
$$

$\mathrm{N} \rightarrow \quad$ Forced to zero
OVR $\rightarrow$ Forced to zero
$C_{n}+8 \rightarrow$ Carry out equal to one
Z $\rightarrow \quad$ Remainder is zero

The status of the SDIVQF instruction is as follows:
$N \quad \rightarrow \quad$ Sign of quotient
OVR $\rightarrow$ Divide overflow
$C_{n}+8 \rightarrow$ Carry out equal to one
$\mathrm{Z} \rightarrow$ Quotient is zero

The quotient is stored in the MQ register and the remainder is stored in the register file location that originally held the most significant word of the dividend. If fractions are divided, the quotient must be shifted right one bit and the remainder right three bits to obtain the correct fractional representations.

The signed division algorithm is summarized in Table 7.
TABLE 7. SIGNED DIVISION ALGORITHM

| OP <br> CODE | MNEMONIC | CLOCK <br> CYCLES | INPUT <br> S PORT | INPUT <br> R PORT | OUTPUT <br> F PORT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| E4 | LOADMQ | 1 | Dividend (LSH) | - | Dividend (LSH) |
| 80 | SDIVIN | 1 | Dividend (MSH) | Divisor | Remainder (N) |
| AF | SDIVO | 1 | Remainder (N) | Divisor | Test Result |
| 90 | SDIVIS | 1 | Remainder (N) | Divisor | Remainder (N) |
| AO | SDIVI | $8 N-2^{\dagger}$ | Remainder (N) | Divisor | Remainder (N) |
| EO | SDIVIT | 1 | Remainder (N) | Divisor | Remainder (Unfixed) |
| 40 | DIVRF | 1 | Remainder (Unfixed) | Divisor | Remainder |
| 50 | SDIVQF | 1 | MQ Register | Divisor | Quotient |

${ }^{\dagger} \mathrm{N}=$ Number of cascaded packages.

## unsigned divide usage

The instructions necessary to perform an algebraically correct division of unsigned numbers are as follows:
Load MQ with the least significant half of the dividend

UDIVIS

UDIVI (8N-1 times)

UDIVIT

DIVRF

```
S port = MSH of dividend
                                    R port = Divisor
                                    F port = Intermediate result
                                    S port = Result of UDIVIS (OR UDIVI)
                                    R port = Divisor
                                    F port = Intermediate result
                                    S port = Result of last UDIVI
                                    R port = Divisor
                                    F port = Remainder (unfixed)
                                    S port = Result of UDIVIT
                                    R port = Divisor
                                    F port = Remainder
```

The status of all unsigned divide instructions except UDIVIS is as follows:

| $N$ | $\rightarrow$ | Forced to zero |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Forced to zero |
| $C_{n}+8$ | $\rightarrow$ | Carry out equal to one |
| $Z$ | $\rightarrow$ | Intermediate result is zero |

The status of the UDIVIS instruction is as follows:
$\mathrm{N} \rightarrow \quad$ Forced to zero
OVR $\rightarrow$ Divide overflow
$C_{n}+8 \rightarrow$ Carry out equal to one
Z $\quad \rightarrow \quad$ Intermediate result is zero
If fractions are divided, the remainder must be shifted right two bits to obtain the correct fractional representation. The quotient is correct as is. The quotient is stored in the MO register at the completion of the divide.

The unsigned division algorithm is summarized in Table 8.

## TABLE 8. UNSIGNED DIVISION ALGORITHM

| OP <br> CODE | MNEMONIC | CLOCK <br> CYCLES | INPUT <br> S PORT | INPUT <br> R PORT | OUTPUT <br> F PORT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| E4 | LOADMQ | 1 | Dividend (LSH) | - | Dividend (LSH) |
| BO | UDIVIS | 1 | Dividend (MSH) | Divisor | Remainder (N) |
| C0 | UDIVI | $8 \mathrm{~N}-1^{\dagger}$ | Remainder (N) | Divisor | Remainder (N) |
| F0 | UDIVIT | 1 | Remainder (N) | Divisor | Remainder (Unfixed) |
| 40 | DIVRF | 1 | Remainder (Unfixed) | Divisor | Remainder |

${ }^{\dagger} N=$ Number of cascaded packages.

## group 5 instructions

Hex code F of Group 1 instructions is used to access Group 5 instructions. Group 5 instructions are summarized in Table 9.

TABLE 9. GROUP 5 INSTRUCTIONS

| INSTRUCTION BITS (17-10) <br> OP CODE (HEX) | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| OF | CLR | Clear |
| $1 F$ | CLR | Clear |
| $2 F$ | CLR | Clear |
| $3 F$ | CLR | Clear |
| $4 F$ | CLR | Clear |
| $5 F$ | CLR | Clear |
| $6 F$ | CLR | Clear |
| $7 F$ | BCDBIN | BCD to Binary |
| $8 F$ | EX3BC | Excess-3 Byte Correction |
| $9 F$ | EX3C | Excess-3 Word Correction |
| AF | SDIVO | Signed Divide Overflow Check |
| BF | CLR | Clear |
| CF | CLR | Clear |
| DF | BINEX3 | Binary to Excess-3 |
| EF | CLR | Clear |
| FF | NOP | No Operation |

clear instructions (CLR)
There are 11 clear instructions listed in Table 9. The instructions force the ALU output to be zero and the BCD flip-flops to be cleared. The status set by the clear instruction is as follows:

$$
\begin{array}{ll}
N & \rightarrow \\
\text { None (force to zero) } \\
\text { OVR } & \rightarrow \text { None (force to zero) } \\
C_{n}+8 & \rightarrow \\
\text { None (force to zero) } \\
Z & \rightarrow
\end{array} \text { Active (one) }
$$

## no operation instruction (NOP): 17-10 $=\mathbf{F F}_{16}$

This instruction is identical to the clear instructions except that the BCD flip-flops retain their old value.

## SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES

excess-3 correction instructions (EX3BC, EX3C)
Two excess- 3 correction instructions are available:

1. Excess-3 byte correction (EX3BC): $17-10=8 F_{16}$
2. Excess-3 word correction (EX3C): $17-10=9 F_{16}$

One instruction supports the byte mode and the other supports the word mode. These instructions correct the excess-3 additions (subtractions) in either the byte or word mode. For correct excess-3 arithmetic, this instruction must follow each add/subtract. The operand must be on the S port.

NOTE: The previous arithmetic overflow should be ignored.
The status of the EX3C instruction is as follows:

| N | $\rightarrow$ | MSB of result |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Signed overflow |
| $\mathrm{C}_{n}+8$ | $\rightarrow$ | Carry out equal one |
| Z | $\rightarrow$ | None (force to one) |

The status of the EX3BC instruction is as follows:
$\mathrm{N} \quad \rightarrow \quad$ None (force to zero)
OVR $\rightarrow$ Byte signed overflow
$\mathrm{C}_{n}+8 \rightarrow$ Carry out equal one
Z $\rightarrow \quad$ None (force to one)

## radix conversions

Conversions between decimal and binary number representations are performed with the aid of two special instructions: BINEX3 and BCDBIN.
$B C D$ to binary instructions (BCDBIN): 17-10 $=7 F_{16}$
This instruction (Figure 10) allows the user to convert an N -digit BCD number to a 4 N -bit binary number in $4(N-1)$ plus 8 clocks. This function sums the $R$ bus, the $S$ bus, and the $C_{n}$ bit, performs an arithmetic left shift on the ALU result, and simultaneously circular shifts the MQ left. The status set by the BCD to binary instruction is as follows:


The following code illustrates the $B C D$ to binary conversion technique.
Let ACC be an accumulator register
Let NUM be the register which contains the BCD number
Let MSK be a mask register

| M1: | LOADMQ NUM | ; LOAD MQ WITH BCD NUMBER |
| :--- | :--- | :--- |
| M2: | SUB ACC, ACC, SLCMQ | ; CLEAR ACC AND ALIGN MQ |
| M3: | SUB, MSK, MSK, SLCMQ | ; CLEAR MSK AND ALIGN MQ |
| M4: | SLCMQ | ; ALIGN |
| M5: | SLCMQ | ALIGN |
| M6: | ADDI ACC, MSK, 1510 | MSK $=1510$ |

; REPEAT L1 THRU L4
; $\mathrm{N}-1$ TIMES ( $\mathrm{N}=$ number of
; $B C D$ digits)
L1: AND MQ, MSK, R1, SLCMQ ; EXTRACT ONE DIGIT
; ALIGN MQ
L2: ADD, ACC, R1, R1, SLCMO
; ACC + DIGIT
; IS STORED IN R1
; ALIGN MQ
L3: $\quad$ BCDBIN, R1, R1, ACC
; $4 \times(\mathrm{ACC}+\mathrm{DIGIT})$
; IS STORED IN ACC
; ALIGN MQ
L4: $\quad B C D B I N, A C C, R 1, A C C$

M7: $\quad$ AND MQ, MSK, R1
$; 10 \times(\mathrm{ACC}+\mathrm{DIGIT})$
; IS STORED IN ACC
; ALIGN MQ

M8: $\quad$ ACC + R1 $\rightarrow$ ACC $\quad$; ADD IN LAST DIGIT
The previous code generates a binary number by executing the standard conversion formula for a $B C D$ number (shown for 32 bits).

$$
A B C D=[(A \times 10+B) \times 10+C] \times 10+D
$$

Notice that the conversion begins with the most significant BCD digit and that the addition is performed in radix 2 .

## binary to excess-3 instructions (BINEX3): $17-10=$ DF16

This instruction (Figure 11) allows the user to convert an N -bit binary number to an $\mathrm{N} / 4$-bit excess- 3 number representation in $2 N+3$ clocks. The data on the $R$ and $S$ ports are summed with the MSB of the MQ register. The MQ register is simultaneously shifted left circularly. The status set by the binary to excess- 3 instruction is as follows:

```
N }\quad->\quad\mathrm{ MSB of result
OVR }->\mathrm{ Signed arithmetic overflow
Cn+8 傽 Carry out equal one
Z }\quad->\quad\mathrm{ Result equal zero
```

SN54AS888, SN74AS888
8-BIT PROCESSOR SLICES


The following illustrates the binary to excess-3 conversion technique.
Let NUM be a register containing an unsigned binary number
Let ACC be an accumulator

| M1: | LOADMQ NUM | ; LOAD MQ WITH BINARY <br> ; NUMBER |
| :---: | :---: | :---: |
| M2: | CLEAR ACC | ; CLEAR ACC |
| M3: | SET1 ACC H/33/ | ; ACC $\rightarrow$ HEX/3333 |
| L1: | BINEX3 ACC, ACC, ACC | ; DOUBLE ACC AND ADD IN <br> ; MSB OF MQ <br> ; ALIGN MQ |
| L2: | EX3C ACC, ACC | EXCESS 3 CORRECT REPEAT L1 AND L2 N-1 TIMES |

The previous code generates an excess-3 number by executing the standard conversion formula for a binary number.

$$
a_{n} 2^{n}+a_{n}-1^{2 n-1}+a_{n}-2^{2 n-2}+\ldots a_{0} 2^{0}=\left[\left(2 a_{n}+a_{n}-1\right) 2+a_{n}-2\right] 2+\ldots a_{0}
$$

Notice that the conversion begins with the most significant binary bit and that the addition is performed in radix-10 (excess-3).

## decimal arithmetic

Decimal numbers are represented in excess-3 code. Excess- 3 code numbers may be generated by adding three to each digit of a Binary Coded Decimal (BCD) number. The hardware necessary to implement excess-3 arithmetic is only slightly different from binary arithmetic. Carries from one digit to another during addition in $B C D$ occur when the sum of the two digits plus the carry-in is greater than or equal to ten. If both numbers are excess-3, the sum will be excess-6, which will produce the proper carries. Therefore, every addition or subtraction operation may use the binary adder. To convert the result from excess-6 to excess-3, one must consider two cases resulting from a BCD digit add: (1) where a carry-out is produced, and (2) where a carry-out is not produced. If a carry-out is not produced, three must be subtracted from the resulting digit. If a carry is produced, the digit is correct as a BCD number. For example, if BCD 5 is added to BCD 6, the excess- 3 result would be $8+9=1$ (with a carry). A carry rolls the number through the illegal BCD representations into a correct $B C D$ representation. Binary 3 must be added to digit positions that produce a carry-out to correct the result to an excess-3 representation. Every addition and subtraction instruction stores the carry generated from each 4-bit digit location for use by the excess-3 correction functions. These correction instructions (word or byte) must be executed in the clock cycle immediately after the addition or subtraction operation.

Signed numbers may be represented in ten's complement form by complementing the excess-3 number. As an example, add the decimal number -423 to the decimal number 24 , which will be represented by 8AA and 357 in excess-3, respectively.

| 8AA |  |
| ---: | :--- |
| 357 |  |
| C01 | Sum |
| 011 | Carry |
| 934 | Excess-3 correct |
| $-6 C C$ | Complement |
| -399 | Excess-3 to decimal |

Complements of excess-3 numbers may be generated by subtracting the excess-3 number from an excess-3 zero followed by an excess-3 correct.

## excess-3 to USASCII conversion

Input/output devices or files represent numbers differently than high-speed central processing units. I/O devices handle all alphanumeric data similarly. CPUs handle more numeric data than alphabetic data and store numeric data in packed form to minimize calculation throughout and reduce memory requirements. To represent the cost of a shirt that was $\$ 10.96$, the I/O device would handle the six USASCII characters " $\$$ ", " 1 "," " 0 ",".",", $9 ", " 6$ ", which would require 6 bytes of storage. In packed $B C D$, this number could be stored as 1096 in two bytes of data. The 'AS888 may be programmed to perform data format conversions such as converting excess-3 BCD to USASCII.

The code below converts a packed word of excess-3 BCD to two unpacked words of USASCII code. Instruction "MAIN1" reads the input word from memory into Register 0 (RO). For illustrative purposes, suppose this data was $43 C 9$, which represents the $\$ 10.96$ shirt in excess- 3 code. "MAIN2" and "MAIN3"' generate a constant of 2D2D16, which is an offset constant to convert excess-3 numbers to USASCII. "MAIN4" copies RO into R2 to set up the subroutine parameters and calls the subroutine "UNPACK", UNPACK2" strips off the upper byte leaving OOC9 in R2. "UNPACK2" and "UNPACK3" together shift the contents of R2 one character position and places the result OC90 into R3. "UNPACK4" performs a logical OR operation to produce OCD9 in register 2. "UNPACK5" clears the most significant nibble in each byte to produce OC09 in R2. "UNPACK6" adds the constant 2D2D16 to R2 to produce 3936 the USASCII representation of the numerals 96 and returns program control to "MAIN5". "MAIN5" through "MAIN9" align the two remaining characters and call UNPACK and the process repeats. Finally the USASCII representation of 1096 is stored into memory. (Note that no attempt was made to pack the " $\$$ " or "." characters.)

Unpacking Excess-3 to USASCII:

| MAIN1: | READ, RFA(0) |
| :--- | :--- |
| MAIN2: | XOR, RFA(4), RFB(4), RFC(4) |
| MAIN3: | SET1, RFB(40), RDC(2), RFA(D), |
| MAIN4: | MSH, LSH |
|  | MOVE, RFA(0), RFC(2), JSR(UNPACK) |
| MAIN5: | MOVE, RFA(2), RFC(1) |
| MAIN6: | ADDRS, RFB(O), RFA(0), RFC(0), SLC |
| MAIN7: | ADDRS, RFB(0), RFA(0), RFC(0), SLC |
| MAIN8: | ADDRS, RFB(0), RFA(0), RFC(0), SLC |
| MAIN9: | ADDRS, RFB(0), RFA(0), RFC(0), SLC |
| MAIN10: | JSR (UNPACK) |
|  | STORE, RFA(1) |
| MAIN11: | STORE, RFA(2) |
| UNPACK1: | SETO, RFB(2), RFC(F), MSH |
| UNPACK2: | ADDRS, RFB(2), RFA(2), RFC(3), SLC |
| UNPACK3: | ADDRS, RFB(3), RFA(3), RFC(3), SLC |
| UNPACK4: | OR, RFB(2), RFA(3), RFC(2) |
| UNPACK5: | SETO, RFB(2), RFC(F), RFA(0), LSH, MSH |
|  |  |
| UNPACK6: | ADDRS, RFB(2), RFB(4), RFC(2), RTS |

; READ IN PACKED EXCESS-3
CLEAR R4
GENERATE HEXADECIMAL
2D2D16
COPY RFA(0) INTO RFA(2),
PROCEDURE CALL
TWO CHARACTERS IN R1
RO SHIFTED 2
RO SHIFTED 4
RO SHIFTED 6
RO SHIFTED 8

STORE USASCII, TWO
CHARACTERS IN R2
STORE USASCII
CLEAR MSH
SHIFT R2 TWO PLACES
SHIFT R3 TWO PLACES
OR R3 TO R2
CLEAR MOST SIGNIFICANT 4
BITS IN EACH BYTE
ADD HEX 2D, RETURN
absolute maximum rating over operating free-air temperature range (unless otherwise noted)

recommended operating conditions

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


[^47]SN54AS888 maximum switching characteristics, $\mathrm{V} C \mathrm{C}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{TC}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) |  |  |  |  |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Y | $\mathrm{C}_{\mathrm{n}+8}$ | $\overline{\mathbf{G}}, \overline{\mathbf{P}}$ | $\mathrm{z}^{\dagger}$ | N | OVR | DA | DB | $\overline{\mathrm{O}} \mathrm{O}$ | $\overline{\text { SIO }}$ |  |
| ${ }^{t} \mathrm{pd}$ | $\begin{aligned} & \text { A3-AO } \\ & \text { B3-BO } \end{aligned}$ | 62 | 42 | 48 | 69 | 62 | 60 | 18 | 18 | 65 | 66 | ns |
|  | DA7-DAO, DB7-DBO | 47 | 28 | 28 | 58 | 50 | 42 | - | - | 50 | 50 |  |
|  | $\mathrm{C}_{\mathrm{n}}$ | 25 | 14 | - | 32 | 24 | 18 | - | - | 32 | 32 |  |
|  | $\overline{E A}$ | 54 | 32 | 35 | 62 | 52 | 52 | - | - | 58 | 58 |  |
|  | $\overline{E B}$ | 54 | 32 | 35 | 62 | 52 | 52 | - | - | 58 | 58 |  |
|  | 17-10 | 58 | 32 | 32 | 62 | 52 | 41 | - | - | 58 | 58 |  |
|  | $\overline{\mathrm{OEB}}$ | - | - | - | - | - | - | - | 14 | - | - |  |
|  | $\overline{\mathrm{OEY}}$ | 14 | - | - | - | - | - | - | - | - | - |  |
|  | $\begin{aligned} & \hline \overline{\mathrm{OIO}}(\mathrm{n}) \\ & \text { Shift } \end{aligned}$ | 15 | - | - | 24 | -- | - | - | - | - | - |  |
|  | $\begin{aligned} & \hline \overline{\mathrm{SIO}}(\mathrm{n}) \\ & \text { Shift } \end{aligned}$ | 15 | - | - | 24 | 22 | - | - | - | - | - |  |
|  | CK | 68 | 60 | 56 | 62 | 50 | 68 | 38 | 38 | 70 | 70 |  |
|  | $\overline{\text { OEA }}$ | - | - | - | - | - | - | 14 | - | - | - |  |
|  | SSF ${ }^{\ddagger}$ | - | - | - | - | - | 14 | - | - | - | - |  |

$\dagger$ Load resistor R1 $=100 \Omega$.
$\ddagger$ For byte instructions only.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

SN74AS888 maximum switching characteristics, $\mathrm{VCC}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) |  |  |  |  |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Y | $\mathrm{C}_{\mathrm{n}}+8$ | $\overline{\text { G }}, \overline{\mathbf{P}}$ | $z^{\dagger}$ | N | OVR | DA | DB | $\overline{010}$ | $\overline{\text { SIO }}$ |  |
| ${ }^{\text {p }}$ d | $\begin{aligned} & \mathrm{A} 3-\mathrm{AO} \\ & \mathrm{~B} 3-\mathrm{BO} \end{aligned}$ | 54 | 36 | 42 | 60 | 52 | 50 | 18 | 18 | 58 | 58 | ns |
|  | $\begin{aligned} & \text { DA7-DAO, } \\ & \text { DB7-DB0 } \end{aligned}$ | 44 | 26 | 26 | 52 | 46 | 38 | - | - | 44 | 44 |  |
|  | $\mathrm{C}_{\mathrm{n}}$ | 25 | 8 | -- | 32 | 24 | 18 | - | - | 31 | 31 |  |
|  | $\overline{E A}$ | 49 | 29 | 29 | 58 | 49 | 47 | - | - | 54 | 54 |  |
|  | $\overline{E B}$ | 49 | 29 | 29 | 58 | 49 | 47 | - | - | 54 | 54 |  |
|  | 17-10 | 55. | 30 | 30 | 60 | 49 | 39 | - | - | 54 | 54 |  |
|  | $\overline{\mathrm{OEB}}$ | - | - | - | - | - | - | - | 12 | - | - |  |
|  | $\overline{O E Y}$ | 12 | - | - | - | - | - | - | - | - | - |  |
|  | $\begin{aligned} & \overline{\overline{\mathrm{QIO}}} \text { ( } \mathrm{n} \text { ) } \\ & \text { Shift } \end{aligned}$ | 15 | - | - | 24 | - | - | - | - | - | - |  |
|  | $\overline{\mathrm{SIO}}(\mathrm{n})$ <br> Shift | 15 | - | - | 24 | 19 | - | - | - | - | - |  |
|  | CK | 58 | 55 | 52 | 61 | 52 | 62 | 35 | 35 | 60 | 60 |  |
|  | $\overline{\text { OEA }}$ | - | - | - | - | - | - | 12 | - | - | - |  |
|  | SSF $\ddagger$ | - | - | - | - | $-$ | 12 | - | - | - | - |  |

[^48]$\ddagger$ For byte instructions only.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

SN74AS888-1 maximum switching characteristics, $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) |  |  |  |  |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $Y$ | $\mathrm{C}_{\mathrm{n}+8}$ | $\overline{\bar{G}}, \overline{\bar{P}}$ | $z^{\dagger}$ | N | OVR | DA | DB | $\overline{010}$ | $\overline{\text { SIO }}$ |  |
| ${ }^{\text {p }}$ pd | $\begin{aligned} & \mathrm{A} 3-\mathrm{AO} \\ & \mathrm{~B} 3-\mathrm{BO} \end{aligned}$ | 44 | 30 | 36 | 50 | 44 | 44 | 17 | 17 | 48 | 48 | ns |
|  | $\begin{aligned} & \text { DA7-DAO, } \\ & \text { DB7-DBO } \end{aligned}$ | 36 | 24 | 24 | 46 | 41 | 32 | - | - | 40 | 40 |  |
|  | $\mathrm{C}_{n}$ | 22 | 8 | - | 27 | 21 | 16 | --- | - | 25 | 25 |  |
|  | $\overline{E A}$ | 40 | 25 | 25 | 49 | 41 | 41 | - | - | 44 | 44 |  |
|  | $\overline{E B}$ | 40 | 25 | 25 | 49 | 41 | 41 | - | - | 44 | 44 |  |
|  | 17-10 | 46 | 27 | 27 | 50 | 42 | 35 | -- | - | 45 | 45 |  |
|  | $\overline{\mathrm{OEB}}$ | - | - | - | - | - | - | - | 12 | - | - |  |
|  | $\overline{\mathrm{OEY}}$ | 12 | - | - | - | - | -- | - | - | - | - |  |
|  | $\overline{\mathrm{QIO}}(\mathrm{n})$ <br> Shift | 14 | - | - | 20 | - | - | - | - | - | - |  |
|  | $\overline{\mathrm{SIO}}(\mathrm{n})$ <br> Shift | 14 | - | - | 20 | 18 | - | - | - | - | - |  |
|  | CK | 50 | 46 | 46 | 50 | 50 | 50 | 30 | 30 | 50 | 50 |  |
|  | $\overline{\text { OEA }}$ | - | - | - | - | - | - | 12 | - | - | - |  |
|  | SSF ${ }^{\ddagger}$ | - | - | - | - | - | 12 | - | - | - | - |  |

${ }^{\dagger}$ Load resistor R1 $=100 \Omega$.
$\ddagger$ For byte instructions only.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.
register file write setup and hold times

| PARAMETER |  | SN54AS888 |  | SN74AS888 |  | SN74AS888-1 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {tsu }}$ | C3-C0 | 8 |  | 7 |  | 6 |  | ns |
|  | DB§ | 14 |  | 12 |  | 11 |  |  |
|  | 17-14 | 16 |  | 14 |  | 13 |  |  |
|  | 13-10 | 24 |  | 22 |  | 21 |  |  |
|  | $\overline{O E Y}$ | 4 |  | 3 |  | 3 |  |  |
|  | Y7-Y0 | 2 |  | 2 |  | 2 |  |  |
|  | WE | 8 |  | 6 |  | 6 |  |  |
|  | $\overline{\mathrm{OLO}}(\mathrm{n}), \overline{\mathrm{SIO}}(\mathrm{n})$ | 6 |  | 5 |  | 5 |  |  |
|  | SELY | 8 |  | 6 |  | 6 |  |  |
| $t_{\text {h }}$ | C3-C0 | 0 |  | 0 |  | 0 |  | ns |
|  | DB§ | 0 |  | 0 |  | 0 |  |  |
|  | 17-14 | 0 |  | 0 |  | 0 |  |  |
|  | 13-10 | 0 |  | 0 |  | 0 |  |  |
|  | $\overline{\mathrm{OEY}}$ | 6 |  | 5 |  | 5 |  |  |
|  | Y7-Y0 | 10 |  | 10 |  | 10 |  |  |
|  | $\overline{\text { WE }}$ | 3 |  | 2 |  | 2 |  |  |
|  | $\overline{\mathrm{QO}}(\mathrm{n}), \overline{\mathrm{SIO}}(\mathrm{n})$ |  |  | 0 |  | 0 |  |  |
|  | SELY | 8 |  | 6 |  | 6 |  |  |

[^49]
## SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES

## special instruction switching characteristics

During various special instructions, the SSF pin is used to pass required information between the 'AS888 packages which make up a total system.

For instance, during the multiplication process, the LSB of the multiplier determines whether an ADD/SHIFT or SHIFT operation is performed. During multiplication, the SSF pin of the least significant package (LSP) becomes an output pin while all other packages become input pins.

Similarly, during normalization, the required operation depends on whether the two data MSBs are the same or different. Therefore, during normalization the SSF pin of the most significant package (MSP) becomes an output pin while all other packages become input pins.

Tables 10, 11, and 12 list the instructions which force the SSF pin during their execution. The propagation delay from various inputs is also shown. The parameter which limits normal system performance is indicated by a dagger.

TABLE 10. SN54AS888 SSF PIN DELAYS AND SETUP TIMES
TABLE 10. SNS4AS888 SSF PIN DELAYS AND SETUP TIMES

| MNEMONIC | $\begin{aligned} & \hline \text { HEX } \\ & \text { CODE } \end{aligned}$ | SSF SOURCE |  | INPUT $\rightarrow$ SSF (ns) |  |  |  | SSF SETUP <br> TIME (ns) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | LSP | MSP | $\mathrm{c}_{\mathrm{n}}$ | ${ }^{1}(\mathrm{n})$ | CK | $\mathrm{B}_{(\mathrm{n})}$ |  |
| CRC | 00 | X |  | - | 29 | 58 | $40^{\dagger}$ | 20 |
| SNORM | 20 |  | X | - | $29^{\dagger}$ | 46 | - | 20 |
| DNORM | 30 |  | x | - | 29 | 55 | $40^{\dagger}$ | 20 |
| DIVRF | 40 |  | x | - | $29^{\dagger}$ | 46 | -- | 20 |
| SDIVGF | 50 |  | x | - | $26^{\dagger}$ | - | - | 18 |
| SMULI | 60 | X |  | - | $26^{\dagger}$ | 43 | - | 0 |
| SDIVIN | 80 |  | x | - | 48 | 64 | $44^{\dagger}$ | 0 |
| SDIVIS | 90 |  | X | $26^{\dagger}$ | 51 | 64 | 55 | 0 |
| SDIVI | AO |  | x | $26^{\dagger}$ | 51 | 64 | 55 | 0 |
| UDIVIS | BO |  | x | $18^{\dagger}$ | 45 | 64 | 46 | 0 |
| UDIVI | CO |  | X | $18^{\dagger}$ | 50 | 54 | 40 | 0 |
| UMULI | DO | $x$ |  | - | $25^{\dagger}$ | 48 | - | 0 |
| SDIVIT | EO |  | x | $26^{\dagger}$ | 50 | 56 | 54 | 0 |
| ABX | 48 |  | x | - | 34 | 62 | $39^{\dagger}$ | 20 |
| SMTC | 58 |  | x | - | 29 | 58 | $39^{\dagger}$ | 20 |
| BINEX3 | DF |  | x | - | $29^{\dagger}$ | 58 | - | 18 |
| LOADMO (Arith) |  | X |  | $23^{\dagger}$ | 34 | 62 | 40 | 0 |
| LOADMO (Log) |  | X |  | - | 33 | 62 | $40^{\dagger}$ | 0 |
| BADD | 88 |  |  | $18^{\dagger}$ | 58 | 62 | 49 | - |
| BSUBS | 98 |  |  | $18^{\dagger}$ | 58 | 62 | 49 | - |
| BSUBR | A8 |  |  | $18^{\dagger}$ | 58 | 71 | 49 | - |
| BINCS | B8 |  |  | $18^{\dagger}$ | 58 | 60 | 49 | - |
| BINCNS | C8 |  |  | $18^{\dagger}$ | 58 | 71 | 49 | - |
| BXOR | D8 |  |  | - | 58 | - | - | - |
| BAND | E8 |  |  | - | 58 | - | - | - |
| BOR | F8 |  |  | - | 58 | - | - | - |
| EX3BC | 8F |  |  | - | 58 | 46 | $49^{\dagger}$ | - |

[^50]SN54AS888, SN74AS888 8-BIT PROCESSOR SLICES

TABLE 11. SN74AS888 SSF PIN DELAYS AND SETUP TIMES

| MNEMONIC | $\begin{aligned} & \hline \text { HEX } \\ & \text { CODE } \end{aligned}$ | SSF SOURCE |  | INPUT $\rightarrow$ SSF (ns) |  |  |  | $\begin{gathered} \hline \text { SSF SETUP } \\ \text { TIME (ns) } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | LSP | MSP | $\mathrm{C}_{\mathrm{n}}$ | '(n) | CK | $\mathrm{B}_{(\mathrm{n})}$ |  |
| CRC | 00 | X |  | - | 26 | 52 | $37^{\dagger}$ | 17 |
| SNORM | 20 |  | $x$ | - | $26^{\dagger}$ | 40 | - | 17 |
| DNORM | 30 |  | $\times$ | - | 26 | 52 | $37^{\dagger}$ | 17 |
| DIVRF | 40 |  | x | - | $26^{\dagger}$ | 40 | - | 17 |
| SDIVAF | 50 |  | x | - | $25^{\dagger}$ | -- | - | 17 |
| SMULI | 60 | $x$ |  | - | $25^{\dagger}$ | 40 | - | 0 |
| SDIVIN | 80 |  | $x$ | - | 38 | 60 | $40^{\dagger}$ | 0 |
| SDIVIS | 90 |  | X | $24^{\dagger}$ | 48 | 60 | 52 | 0 |
| SDIVI | AO |  | $x$ | $24^{\dagger}$ | 48 | 60 | 52 | 0 |
| UDIVIS | B0 |  | X | $17{ }^{\dagger}$ | 43 | 60 | 45 | 0 |
| UDIVI | co |  | x | $17^{\dagger}$ | 44 | 52 | 37 | 0 |
| UMULI | DO | $x$ |  | - | $26^{\dagger}$ | 40 | - | 0 |
| SDIVIT | EO |  | $x$ | $25^{\dagger}$ | 46 | 52 | 49 | 0 |
| ABX | 48 |  | x | - | 32 | 60 | 38 | 17 |
| SMTC | 58 |  | x | -- | 26 | 52 | $38^{\dagger}$ | 17 |
| BINEX3 | DF |  | x | - | $26^{\dagger}$ | 40 | - | 17 |
| LOADMO (Arith) |  | $x$ |  | $22^{\dagger}$ | 32 | 50 | 38 | 0 |
| LOADMO (Log) |  | x |  | - | 32 | 50 | $38^{\dagger}$ | 0 |
| BADD | 88 |  |  | $17{ }^{\dagger}$ | 52 | 55 | 46 | - |
| BSUBS | 98 |  |  | $17{ }^{\dagger}$ | 52 | 55 | 46 | - |
| BSUBR | A8 |  |  | $17^{\dagger}$ | 52 | 62 | 46 | - |
| BINCS | B8 |  |  | $17^{\dagger}$ | 52 | 55 | 46 | - |
| BINCNS | C8 |  |  | $17^{\dagger}$ | 52 | 62 | 46 | - |
| BXOR | D8 |  |  | - | 52 | - | - | - |
| BAND | E8 |  |  | - | 52 | - | - | - |
| BOR | F8 |  |  | - | 52 | - | - | - |
| EX3BC | 8F |  |  | - | 45 | 45 | $46^{\dagger}$ | - |

[^51]TABLE 12. SN74AS888-1 SSF PIN DELAYS AND SETUP TIMES

| MNEMONIC | HEX | SSF SOURCE |  | INPUT $\rightarrow$ SSF (ns) |  |  |  | SSF SETUP <br> TIME (ns) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | CODE | LSP | MSP | $C_{n}$ | '(n) | CK | $\mathrm{B}_{(\mathrm{n})}$ |  |
| CRC | 00 | X |  | - | 23 | 42 | $34^{\dagger}$ | 14 |
| SNORM | 20 |  | $x$ | - | $23^{\dagger}$ | 28 | - | 14 |
| DNORM | 30 |  | X | - | 23 | 40. | $34^{\dagger}$ | 14 |
| DIVRF | 40 |  | $x$ | - | $23^{\dagger}$ | 27 | - | 14 |
| SDIVOF | 50 |  | x | - | $23^{\dagger}$ | - | - | 14 |
| SMULI | 60 | x |  | - | $22^{\dagger}$ | 27 | - | 0 |
| SDIVIN | 80 |  | X | - | 35 | 46 | $35^{\dagger}$ | 0 |
| SDIVIS | 90 |  | x | $22^{\dagger}$ | 42 | 48 | 42 | 0 |
| SDIVI | AO |  | x | $22^{\dagger}$ | 42 | 46 | 42 | 0 |
| udivis | во |  | x | $16^{\dagger}$ | 42 | 46 | 38 | 0 |
| UDIVI | CO |  | x | $16^{\dagger}$ | 36 | 46 | 34 | 0 |
| UMULI | D0 | x |  | - | $22^{\dagger}$ | 27 | - | 0 |
| SDIVIT | EO |  | X | $21^{\dagger}$ | 40 | 44 | 42 | 0 |
| ABX | 48 |  | x | - | 28 | 46 | $30^{+}$ | 14 |
| SMTC | 58 |  | x | - | 24 | 44 | $30^{+}$ | 14 |
| BINEX3 | DF |  | x | - | $23^{\dagger}$ | 27 | - | 14 |
| LOADMO (Arith) |  | $x$ |  | $19^{\dagger}$ | 28 | 40 | 30 | 0 |
| LOADMO (Log) |  | X |  | - | 28 | 35 | $30^{+}$ | 0 |
| BADD | 88 |  |  | $16^{\dagger}$ | 42 | 42 | 40 | - |
| BSUBS | 98 |  |  | $16^{\dagger}$ | 42 | 40 | 40 | - |
| BSUBR | A8 |  |  | $16^{\dagger}$ | 42 | 50 | 40 | - |
| BINCS | B8 |  |  | $16^{\dagger}$ | 42 | 46 | 40 | - |
| BINCNS | C8 |  |  | $16^{\dagger}$ | 42 | 54 | 42 | - |
| BXOR | D8 |  |  | - | 42 | - | - | - |
| BAND | E8 |  |  | - | 42 | - | - | - |
| BOR | F8 |  |  | - | 42 | - | - | - |
| EX3BC | 8F |  |  | - | 42 | 42 | $42^{\dagger}$ | -- |

[^52]- 14 Bits Wide-Addresses up to 16,384

Words of Microcode with One Chip

- Selects Address from One of Eight Sources
- STL-AS Technology
- Independent Read Pointer for Aid in Microcode Diagnostics
- Supports Real-Time Interrupts
- Two Independent Loop Counters
- Supports 64 Powerful Instructions
- Dependable Texas Instruments Quality and Reliability


## description

The 'AS890 is a powerful microsequencer that is the result of the implementation of TI's Advanced Schottky and Schottky Transistor Logic. Approximately 2400 Schottky gate equivalents are used to construct this highperformance sequencer. The 'AS890 can generate an address and provide register status in only 29 ns while typically requiring only 1.8 watts of power. All internal STL logic in these devices operates on a 2 -volt power supply that must be supplied externally. The information generated by the internal STL logic is communicated in the rest of the system via 5-volt Advanced Schottky TTL-compatible I/O ports.

The microsequencers select a 14-bit microaddress from one of eight sources to provide the proper microinstruction sequence for bit-slice processor or other microcode based systems. These high-performance devices are capable of addressing 16,384 control store memory locations either sequentially or via conditional branching algorithms. This multiway branching capability, coupled with a nine-word deep FILO (first in, last out) stack, allows the microprogrammer to arrange his code in blocks so that microprograms may be structured in the same fashion as such high-level languages as ALGOL, Pascal, or Ada.

Both polled and real-time interrupt routines are supported by the 'AS890 to enhance system throughput capability. Vectored interrupts may occur during any instruction, including PUSHes and POPs.

SN74AS890 . . GB PACKAGE
(TOP VIEW)


AS890

| PIN, |  | PIN |  | PIN |  | PIN |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NO. | NAME | NO. | NAME | NO. | NAME | NO. | NAME |
| A. 2 | DRB10 | B-9 | STKWRN/RER | F. 10 | ${ }^{\text {VCC1 }}$ | K. 4 | DRA13 |
| A-3 | DRB9 | B-10 | ZERO | F-11 | MUX2 | K. 5 | DRA11 |
| A. 4 | DRB8 | B. 11 | CK | G. 1 | Y5 | K-6 | dras |
| A. 5 | DRB7 | C. 1 | Y13 | G-2 | $\overline{Y O E}$ | K 7 | DRA7 |
| A. 6 | DRB6 | C. 2 | Y10 | G. 10 | RC1 | K. 8 | drao |
| A. 7 | DRB5 | C. 10 | $\overline{C C}$ | G 11 | MUX1 | K 9 | DRA1 |
| A- 8 | DRB4 | C-11 | S1 | $\mathrm{H} \cdot 1$ | Y4 | K. 10 | DRA3 |
| A-9 | DRB3 | D-1 | Y12 | H. 2 | Y6 | K. 11 | DRA2 |
| A-10 | DRB1 | D-2 | Y9 | $\mathrm{H}-10$ | BO | L. 2 | B2 |
| B. 1 | DRB13 | D10 | S2 | H. 11 | Muxo | L. 3 | INC |
| B. 2 | INT | D. 11 | So | J. 1 | Y3 | L-4 | DRA12 |
| B. 3 | DRB12 | E. 1 | Y11 | J. 2 | Y2 | L-5 | DRA 10 |
| B. 4 | DRB11 | E. 2 | Y8 | J. 10 | RC2 | L.6 | DRA9 |
| B. 5 | B3 | E. 10 | $\mathrm{V}_{\mathrm{CC} 2}$ | J. 11 | OSEL | L-7 | $\overline{\text { RAOE }}$ |
| B. 6 | $\overline{\text { RBOE }}$ | E 11 | RCO | K-1 | Y1 | L. 8 | dra6 |
| B-7 | DRB2 | F-1 | Y7 | K. 2 | Yo | L. 9 | DRA5 |
| B. 8 | DRBO | F. 2 | GND | K.3 | 81 | L 10 | DRA4 |



## functional block diagram



## pin descriptions



## description (continued)

Two 14-bit loadable registers/counters may be used for temporary storage of data or utilized as down counters for repetitive instructions such as multiplication and division or as loop counters when iterative routines are required.

An additional feature is a 24-bit port that appends four user-definable bits to the DRA or DRB address value for support of 16 -way branches for the execution of relative branch addressing schemes.

## Y output multiplexer

The $Y$ output multiplexer of the 'AS890 is capable of selecting the next branch address from one of eight locations. Addresses may be sourced from:

1. The top of the 14 -bit by 9 -word address stack
2. An external input on the DRA port, potentially a pipeline register
3. An external input on the DRB port, potentially a pipeline register
4. Internal register/counter $A$
5. Internal register/counter $B$
6. An internal microprogram counter (MPC register)
7. An external input onto the bidirectional $Y$ output port
8. A 16-way branch -4 bits appended to DRA, DRB, register/counter $A$ or register/counter $B$.

The source of the next address is dependent upon the previous state of the microsequencer, the MUX controls (MUX2-MUXO), the condition code ( $\overline{\mathrm{CC}}$ ) input, and the state of an internal status flag (status externally available at the ZERO output) that indicates that one of the on-chip registers is being decremented to zero.
The entire instruction set may be made conditional by manipulation of the condition code ( $\overline{\mathrm{CC}}$ ) input. Allowing the $\overline{\mathrm{CC}}$ value to vary as a result of data or status provides for state-dependent or data-dependent branching. Unconditional branches may be achieved by forcing $\overline{\mathrm{CC}}$ high when selecting control store addresses. Holding this pin low will provide for conditional or unconditional branches as dictated by the state of the zero-detect flag. The required control signals for selection of the $Y$ output source are listed in Table 1. Note that the dependence of the 'AS890 on two variables for conditional branches and jumps allows a conditional branch or conditional jump to subroutine in any clock cycle. Also note that all multiplexer inputs are overridden when all of the stack control inputs are pulled low. This instruction resets the stack and read pointers to zero and places all lines of the $Y$ output bus at the low level.

TABLE 1. Y OUTPUT CONTROL


[^53]
## 14-bit by 9 -word address stack

The positive-edge-triggered 14-bit address stack supplies on-board storage of nine control store addresses that support up to nine nested levels of microsubroutine, looping, and real-time interrupt functions. The stack pointer (SP), which operates as an up-down counter, is updated after the execution of each PUSH operation and before each POP. In a PUSH operation, the address stored in the MPC register is loaded into the stack location addressed by the stack pointer, and the stack pointer is incremented. This address is available at the DRA port by enabling DRA ( $\overline{\operatorname{RAOE}}$ low and OSEL high).

A POP operation causes the stack pointer to be decremented on the first rising clock edge following the arrival of the POP instruction at the S2-SO pins. The value that was indexed by the stack pointer is effectively removed from the top of the stack. All PUSH and POP instructions are conditionally dependent upon the stack control inputs (S2-SO), the condition code ( $\overline{\mathrm{CC}}$ ), the input value, and the zero-detect status. The desired option may be selected using the stack control inputs listed in Table 2.

TABLE 2. STACK CONTROL

| STACK S2 | CONTROL |  | STACK OPERATION, $\overline{\mathrm{C}} \overline{\mathrm{C}}=\mathrm{L}$ |  |  | $\overline{\mathrm{CC}}=\mathrm{H}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | S1 | SO | OSEL | ZERO $=\mathrm{L}$ | ZERO $=\mathrm{H}$ |  |
| L | L | L | X | RESET/CLEAR | RESET/CLEAR | RESET/CLEAR |
| L | L | H | $x$ | CLEAR SP, RP | HOLD | HOLD |
| L | H | L | X | HOLD | POP | POP |
| L | H | H | $x$ | POP | HOLD | HOLD |
| H | L | L | $x$ | HOLD | PUSH | PUSH |
| H | L | H | $x$ | PUSH | HOLD | HOLD |
| H | H | L | X | PUSH | HOLD | PUSH |
| H | H | H | H | READ | READ | READ |
| H | H | H | L | HOLD | HOLD | HOLD |

The read pointer (RP) is a useful tool in debugging microcoded systems. A microprogrammer now has the ability to perform a nondestructive, sequential read of the stack contents from the DRA port. This capability provides the user with a method of backtracking through the address sequence to determine the cause of overflow without affecting program flow, the status of the stack-pointer or the internal data of the stack. Placing a high value on all of the stack inputs (S2-S0) and OSEL places the 'AS890 into the read mode. At each low-to-high clock transition, the value pointed to by the read pointer is available at the DRA port and the read pointer is decremented. Microcode diagnostics are simplified by the ability of the 'AS890 to sequentially dump the contents of its stack. The bottom of the stack is detected by monitoring the STKWRN/RER (stack warning/read error) pin. A high will appear when the stack contains one word and a READ instruction is applied to the S2-S0 pins. This signifies that the last address has been read. The stack pointer and stack contents are uneffected by the READ operation. Under normal PUSH and POP operations the read pointer is updated with the stack pointer and contains identical information.

The STKWRN/RER pin alerts the system to a potential stack overflow or underflow condition. STKWRN/RER becomes active under two additional conditions. If seven of the nine stack locations ( $0-8$ ) are full (the stack pointer is at 7) and a PUSH occurs, the STKWRN/RER pin will produce a high-level signal to warn that the stack is approaching its capacity, and will be full after one more PUSH. Knowledge that overflow potential exists allows bit-slice-based systems to continuously process real-time interrupt vectors. This signal will remain high, if HOLD, PUSH, or POP instructions occur, until the stack pointer is decremented to 7.

The user may be protected from attempting to POP an empty stack by monitoring STKWRN/RER before POP operations. A high level at this pin signifies that the last address has been removed from the stack $(S P=0)$. This condition remains until an address is pushed onto the stack and the stack pointer is incremented to one.

Clearing the stack and read pointer is accomplished by placing low levels onto the stack control lines (S2-S0). This function overrides all of the $Y$ output MUX controls and places the $Y$ bus into a low state.

## SN54AS890, SN74AS890 <br> MICROSEQUENCERS

## register/counters

Two loadable 14-bit registers extend the looping and branching capabilities. Addresses may be loaded directly into register/counter $A(R A)$ and register/counter $B$ (RB) through the direct data ports DRA13-DRA0 and DRB13-DRB0. The values stored in these registers may either be held, decremented, or read as a result of the register control inputs ( $\mathrm{RC} 2-\mathrm{RCO}$ ),$\overline{\mathrm{RAOE}}$, and $\overline{\mathrm{RBOE}}$. All combinations of these functions are supported with the exception of a simultaneous decrement of both registers. Generation of iteration routines may be accomplished by loading RA and/or RB and operating them as a down counter. Loop termination is acknowledged by the ZERO output going high to indicate that a register contains a binary one and that a decrement is about to take place. Because of this facility, a "decrement and branch on loop" termination may be executed in the same clock cycle.

The contents of RA are accessible to the DRA port when OSEL is low and the output bus is enabled by RAOE being low. Data from RB is available when DRB is enabled by $\overline{R B O E}$ being low. Note that control of the registers is maintained while an external value is active on the DRA and DRB ports. A value being directed from the DRA and DRB buses to the output will not inhibit the decrement operation.

Register/counter controls are listed in Table 3.
table 3. REGISTER CONTROL

| RC2 | RC1 | RCO | REG A | REG B |
| :---: | :---: | :---: | :---: | :---: |
| L | L | L | HOLD | HOLD |
| L | L | H | DEC | HOLD |
| L | H | L | LOAD | HOLD |
| L | H | H | DEC | LOAD |
| H | L | L | LOAD | LOAD |
| H | L | H | HOLD | DEC |
| H | H | L | HOLD | LOAD |
| H | H | H | LOAD | DEC |

## microprogram register and increment

The microprogram register (MPC) and the incrementer (INC) provide the means for generating the next microprogram address for sequential addressing operations. The MPC may be loaded with either the outgoing address on the $Y$ bus or may receive an external address for processing interrupt vectors.

The current address on the Y bus is passed to the MPC at each rising clock edge, either unaltered (INC low) for repeating statements, or incremented by one (INC high) for addressing sequential control store locations.

The MPC may also be externally loaded for subroutine and interrupt functions. Taking $\overline{\text { YOE }}$ high and forcing the new address onto the bidirectional Y bus loads the MPC with the new address at the positive clock edge. This value may also be incremented prior to storage in the MPC for sequential addressing of subroutines or interrupt routines.

## interrupts

Real-time vectored interrupt routines are supported for those applications where polling would impede system throughput. Any instruction, including PUSHes and POPs, may be interrupted. To process an interrupt, the following procedure should be followed:

1. The bidirectional $Y$ bus is placed into the high-impedance state by forcing $\overline{Y O E}$ high.
2. The interrupt entry point vector is then forced onto the $Y$ bus and incremented to become the second microinstruction of the interrupt routine. This is accomplished by making INC high.
3. At the following clock edge, the second microaddress is stored in the MPC and the interrupted address will be stored in the INT RT register which always contains the outgoing value on the $Y$ bus. This edge also causes the processor to begin execution of the first instruction of the interrupt routine. This first instruction must PUSH the address stored in the INT RT register onto the stack so that the proper return linkage is maintained. This is accomplished by making $\overline{\mathbb{N T}}$ low and performing a PUSH. If this instruction were to be interrupted, the process would be repeated and the proper return linkage preserved.

## control inputs

A listing of the response of internal elements to various control inputs is given in Table 4.

TABLE 4. RESPONSE TO CONTROL INPUTS

| PIN NAME | LOGIC LEVEL | LOW |
| :---: | :---: | :---: |
|  | HIGH | DRA output is active |
| $\overline{\text { RBOE }}$ | DRA output in high-Z state | DRB output is active |
| $\overline{Y O E}$ | DRB output in high-Z state | Y output is active |
| $\overline{\text { INT }}$ | $Y$ output in high-Z state | INT RT register to stack |
| OSEL | MPC to stack | RA to DRA buffer input |
| INC | Stack to DRA buffer input | Passes Y output to MPC unaltered |
| MUX2-MUXO | Adds one to Y output and stores in MPC | Table 1 |
| S2-SO | Table 1 | Table 2 |
| RC2-RCO | Table 2 | Table 3 |

## instruction set

Sixty-four microsequencing instructions enable the 'AS890 to generate micro-addresses for up to 16,384 locations. Any instruction can be made conditional depending upon the value of the externally applied condition code $(\overline{\mathrm{CC}})$ and the value stored in either of the internal register/counters.

The required signals for selection of the $Y$ output source were listed in Table 1. Suggested methods for implementing a few commonly used instructions are given in Table 5 and flowcharts showing execution examples are illustrated in Figure 1.

It should be noted that the term jump refers to a subroutine call that must be accompanied by a return instruction. The term branch implies that a deviation from the program flow is accomplished but no return is required.

TABLE 5. SUGGESTED CODING FOR REPRESENTATIVE INSTRUCTIONS

| FUNCTION | MNEMONIC | MUX2 | MUX1 | MUXO | S2 | S1 | So | $\overline{\mathrm{CC}}$ | FIGURE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Continue | CONT | X | H | X | H | H | H | H | 1(a) |
| Unconditional branch | BR | L | L | $X$ | H | H | H | H | 1 (b) |
| Conditional branch | CBR | H | H | X | H | H | H | V | 1 (c) |
| Three-way branch | BR2W | H | L | L | H | H | H | V | 1 (d) |
| Conditional loop on stack | LOOPS | L | L | $x$ | L | H | L | L | 1 (e) |
| Repeat | REPEAT | L | L | $x$ | H | H | H | L | 1 (f) |
| Loop on stack with exit | LSWE | L | L | $x$ | L | H | L | V | $1(\mathrm{~g})$ |
| Conditional jump to subroutine | CJSR | H | H | $x$ | H | L | H | $\checkmark$ | 1 (h) |
| Jump to subroutine | JSR | L | L | X | H | L | H | H | 1 (i) |
| Two-way jump to subroutine | JSR2W | H | L | L | H | H | L | V | 1 (j) |
| Repeat until | UNTIL | L | H | $x$ | L | H | L | V | 1 (k) |
| Return from subroutine | RTS | L | H | $X$ | L | H | H | L | 1(I) |
| Conditional return from subroutine | CRTS | L | H | $X$ | L | H | H | V | 1 (m) |
| Conditional return from subroutine or branch | CRTSB | L | H | X | L | H | H | V | 1 (n) |
| Conditional branch and PUSH | CBRP | H | H | X | H | L | H | V | 1 (o) |
| Conditional branch and POP | CBRPO | H | H | X | L | H | H | $\checkmark$ | 1 (p) |
| PUSH and continue | PUSH | L | H | $x$ | H | L | L | H | 1 (q) |
| POP and continue | POP | X | H | $X$ | L | H | L | H | 1 (r) |
| Exit from loop | EXITLP | L | L | $x$ | L | H | L | $\checkmark$ | 1 (s) |
| Reset and clear stack/read pointer | RESET | X | X | X | L | L | L | X | 1 (t) |
| 32-way branch | BR32W | H | L | H | H | H | H | V | 1 (u) |
| Execute n times | NEX | L | L | X | L | H | L | L | 1(v) |

$H=$ high level, $L=$ low level, $X=$ irrelevant, $V=$ varies (condition code value is dependent upon machine and data status and will vary accordingly).


NOTE 1: $\overline{\mathrm{CC}}$ and ZERO are completed in the same clock cycle.
FIGURE 1. INSTRUCTION SET FLOWCHARTS


(f) REPEAT ( $\overline{C C}$ FORCED, DEC DISABLED) 1

(h) CONDITIONAL. JUMP TO SUBROUTINE (DEC DISABLED) ${ }^{1}$
(g) CONDITIONAL LOOP ON STACK WITH EXIT (DEC ENABLED) ${ }^{1}$

NOTE 1: $\overline{\mathrm{CC}}$ and ZERO are completed in the same clock cycle.
FIGURE 1. INSTRUCTION SET FLOWCHARTS (continued)


FIGURE 1. INSTRUCTION SET FLOWCHARTS (continued)

(n) CONDITIONAL RETURN FROM SUBROUTINE OR BRANCH (DEC ENABLED) ${ }^{1}$

(o) CONDITIONAL BRANCH AND PUSH (DEC DISABLED)

NOTE 1: $\overline{C C}$ and ZERO are completed in the same clock cycle.
FIGURE 1. INSTRUCTION SET FLOWCHARTS (continued)


NOTE 1: $\overline{\mathrm{CC}}$ and ZERO are completed in the same clock cycle
FIGURE 1. INSTRUCTION SET FLOWCHARTS (continued)

SN54AS890, SN74AS890
MICROSEQUENCERS


NOTES: 1. $\overline{C C}$ and ZERO are completed in the same clock cycle.
2. The least significant four bits, DRA and DRB, will be stripped off and four new bits appended to them from the B3-BO port

FIGURE 1. INSTRUCTION SET FLOWCHARTS (concluded)

| absolute maximum ratings over operating temperature range (unless otherwise noted) |  |
| :---: | :---: |
| Supply voltage, $\mathrm{V}_{\text {CC1 }}$ | 7 V |
| Supply voltage, $\mathrm{V}_{\text {CC2 }}$ | 3 V |
| Input voltage: All inputs | 7 V |
| I/O ports | 5.5 V |
| Operating case temperature range, SN54AS890 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
| Operating free-air temperature range, SN74AS890 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions

|  |  |  | SN54AS890 |  |  | SN74AS890 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC} 1}$ | 1/O supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\mathrm{CC} 2}$ | STL internal logic supply voltage |  | 1.9 | 2 | 2.1 | 1.9 | 2 | 2.1 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| VIL | Low-level input voltge |  |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  |  |  | -1 |  |  | -2.6 | mA |
| ${ }^{1} \mathrm{OL}$ | Low-level output current | All outputs except Y13-Y0 |  |  | 8 |  |  | 8 | mA |
|  |  | Y13-Y0 |  |  | 12 |  |  | 12 |  |
| ${ }^{T} \mathrm{C}$ | Operating case temperatu |  | -55 |  | 125 |  |  |  | ${ }^{\circ} \mathrm{C}$ |
| ${ }^{\text {T }}$ A | Operating free air temper |  |  |  |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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


[^54]SN54AS890
MICROSEQUENCERS

SN54AS890 maximum switching characteristics: $\mathrm{V}_{\mathrm{CC}} 1=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=1.9 \mathrm{~V}$ to 2.1 V , TC $=55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ (see Note 2)

| PARAMETER | $\begin{aligned} & \text { FROM } \\ & \text { (INPUT) } \end{aligned}$ | TO (OUTPUT) |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Y | ZERO | DRA | DRB | STKWRN |  |
| ${ }^{\text {tpd }}$ | $\overline{\mathrm{CC}}$ | 32 |  |  |  |  | ns |
|  | CK | 32 |  | 30 | 30 | 30 |  |
|  |  | $53^{\dagger}$ | $42^{\dagger}$ |  |  |  |  |
|  | DRA13-DRAO | 16 |  |  |  |  |  |
|  | DRB13-DRB0 | 16 |  |  |  |  |  |
|  | MUX2-MUXO | 36 |  |  |  |  |  |
|  | RC2-RCO | 32 | 14 |  |  |  |  |
|  | S2-SO | 32 |  |  |  |  |  |
|  | B2-B0 | 22 |  |  |  |  |  |
|  | OSEL |  |  | 24 |  |  |  |
| ten | YOE | 16 |  |  |  |  | ns |
|  | RAOE |  |  | 16 |  |  |  |
|  | $\overline{\text { RBOE }}$ |  |  |  | 16 |  |  |
| ${ }^{\text {dis }}$ | $\overline{\text { YOE }}$ | 16 |  |  |  |  | ns |
|  | $\overline{\text { RAOE }}$ |  |  | 16 |  |  |  |
|  | $\overline{\mathrm{RBOE}}$ | 16 |  |  |  |  |  |

$\dagger$ Decrementing Register/Counter A or B and sensing a zero.
NOTE 2: Load circuit and voltage waveforms are shown in Section 1
SN54AS890 setup and hold times

| PARAMETER | FROM | TO (DESTINATION) | MIN | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {tsu }}$ | $\overline{\mathrm{C}}$ | Stack | 10 |  | ns |
|  | DRA13-DRAO | RCA, INT RT | 5 |  |  |
|  | DRB13-DRB0 | RCB, INT RT | 5 |  |  |
|  | INC | MPC | 10 |  |  |
|  | $\overline{\text { INT }}$ | Stack | 10 |  |  |
|  | RC2-RCO | Stack | 16 |  |  |
|  |  | RCA, RCB | 10 |  |  |
|  |  | INT RT | 14 |  |  |
|  | S2-S0 | Stack | 10 |  |  |
|  |  | * INT RT | 10 |  |  |
|  | MUX2-MUXO | INT RT | 14 |  |  |
|  | B3-80 | INT RT | 14 |  |  |
|  | Y13-Y0 | MPC | 12 |  |  |
| th | Any Input | Any Destination | 2 |  |  |

SN54AS890 minimum clock requirements (see Note 3)

| PARAMETER |  | MIN | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {WLICK }}$ | Pulse duration, clock low | 10 |  | ns |
| $\mathrm{t}_{\mathrm{WH}}$ (CK) | Pulse duration, clock high | 20 |  |  |
| ${ }^{\text {t }}$ (CK) | Clock cycle time | $55^{\dagger}$ |  |  |
|  |  | 45 |  |  |

${ }^{\dagger}$ Decrementing Register/Counter A or B and sensing a zero.
NOTE 3: The total clock period of clock high and clock low must not be less than clock cycle time. The minimum pulse durations specified are only for clock high or clock low, but not for both simultaneously.

## SN74AS890 MICROSEQUENCERS

SN74AS890 maximum switching characteristics: $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=1.9 \mathrm{~V}$ to 2.1 V , $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (see Note 2)

${ }^{\dagger}$ Decrementing Register/Counter A or B and sensing a zero.
NOTE 2: Load circuit and voltage waveforms are shown in Section 1.
SN74AS890 setup and hold times


## SN74AS890 minimum clock requirements (see Note 3)

| PARAMETER |  | MIN | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {wL }}$ (CK) | Pulse duration, clock low | 10 |  | ns |
| ${ }^{\text {w }}$ W H (CK) | Pulse duration, clock high | 20 |  |  |
| $\mathrm{t}_{\mathrm{C}}(\mathrm{CK})$ | Clock cycle time | $50^{\dagger}$ |  |  |
|  |  | 36 |  |  |

[^55]
## SN74AS890.1 <br> MICROSEQUENCERS

SN74AS890-1 maximum switching characteristics: $\mathrm{V}_{\mathrm{CC}} 1=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=1.9 \mathrm{~V}$ to 2.1 V , $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (see Note 2)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Y | ZERO | DRA | DRB | STKWRN |  |
| ${ }^{t} \mathrm{pd}$ | $\overline{\bar{C}}$ | 25 |  |  |  |  | ns |
|  | CK | 25 |  | 25 | 25 | 25 |  |
|  |  | $42^{\dagger}$ | $34{ }^{\dagger}$ |  |  |  |  |
|  | DRA13-DRAO | 14 |  |  |  |  |  |
|  | DRB13-DRB0 | 14 |  |  |  |  |  |
|  | MUX2-MUXO | 31 |  |  |  |  |  |
|  | RC2-RC0 | 26 | 12 |  |  |  |  |
|  | S2-SO | 25 |  |  |  |  |  |
|  | B2-B0 | 19 |  |  |  |  |  |
|  | OSEL | 17 |  |  |  |  |  |
| ten | YOE | 15 |  |  |  |  | ns |
|  | $\overline{\mathrm{RAOE}}$ | 15 |  |  |  |  |  |
|  | $\overline{\text { RBOE }}$ | 15 |  |  |  |  |  |
| ${ }_{\text {dis }}$ | YOE | 16 |  |  |  |  | ns |
|  | $\overline{\text { RAOE }}$ |  |  | 16 |  |  |  |
|  | $\overline{\mathrm{RBOE}}$ |  |  |  | 16 |  |  |

${ }^{\dagger}$ Decrementing Register/Counter A or B and sensing a zero.
NOTE 2: Load circuit and voltage waveforms are shown in Section 1.

## SN74AS890-1 setup and hold times

| PARAMETER | FROM | TO (DESTINATION) | MIN | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {tsu}}$ | $\overline{\mathrm{CC}}$ | Stack | 10 |  | ns |
|  | DRA13-DRAO | RCA, INT RT | 5 |  |  |
|  | DRB13-DRBO | RCB, INT RT | 5 |  |  |
|  | INC | MPC | 10 |  |  |
|  | INT | Stack | 10 |  |  |
|  |  | Stack | 14 |  |  |
|  | RC2-RCO | RCA, RCB | 10 |  |  |
|  |  | INT RT | 12 |  |  |
|  | S2-s0 | Any Destination | 10 |  |  |
|  | MUX2-MUXO | INT RT | 12 |  |  |
|  | B3-80 | INT RT | 14 |  |  |
|  | Y13-Y0 | MPC | 10 |  |  |
| $t_{\text {h }}$ | Any Input | Any Destination | 2 |  |  |

SN74AS890-1 minimum clock requirements (see Note 3)

| PARAMETER |  | MIN | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{wL}}$ (CK) | Pulse duration, clock low | 10 |  |  |
| $\mathrm{t}_{\mathrm{wH}}$ (CK) | Pulse duration, clock high | 20 |  | ns |
| $\mathrm{t}_{\mathrm{C}}(\mathrm{CK})$ | Clock cycle time | $42^{\dagger}$ |  |  |

[^56]NOTE 3: The total clock period of clock high and clock low must not be less than clock cycle time. The minimum pulse durations specified are only for clock high or clock iow, but not for both simultaneously.

## SN54AS895, SN74AS895 <br> 8-BIT MEMORY ADDRESS GENERATORS

NOVEMBER 1985-REVISED APRIL 1986

- STL-AS Technology
- Parallel 8-Bit ALU with Expansion Inputs and Outputs
- 13 Arithmetic and Logic Functions
- 8 Conditional Shifts (Single and Double Length)
- 9 Instructions that Manipulate Bytes
- 4 Instructions that Manipulate Bits
- Add and Subtract Immediate Instructions
- Absolute Value Instruction
- Signed Magnitude to/from Two's Complement Conversion
- Single- and Double-Length Normalize
- Select Functions
- Signed and Unsigned Divides with Overflow Detection; Input does not Need to be Prescaled
- Signed, Mixed, and Unsigned Multiplies
- Three-Operand, 16-Word Register File
- Full Carry Look Ahead Support
- Sign. Carry Out, Overflow, and Zero-Detect Status Capabilities
- Excess-3 BCD Arithmetic
- MQ Register is Externally Available through the DB Port
- Internal Shift Multiplexers that Eliminate the Need for External Shift Control Parts
- ALU Bypass Path to Increase Speeds of Multiply, Divide, and Normalize Instructions and to Provide New Instructions such as Bit Set, Bit Reset, Bit Test, Byte Subtract, Byte Add, and Byte Logical
- 3-Operand Register Files to Allow an Operation and a Move Instruction to be Combined
- Byte Select Controlled by External 3-State Buffers that may be Eliminated if Bit and Byte Manipulation are not Needed
- Bit and Byte Masks that are Shared with Register Address Fields to Minimize Control Store Word Width
- 3 Data Input/Output Paths to Maximize Data Throughput


## description

These 8-bit Advanced Schottky TTL integrated circuits are designed to implement high performance digital computers or controllers. An architecture and instruction set has been chosen that supports a fast system clock, a narrow micro-code word width, and a high system throughput. The powerful instruction set allows high-speed system architecture to be implemented and also allows an existing system's performance to be upgraded while protecting software investments. These processors are designed to be cascadable to any word width 16 bits or greater.

The only difference between the 'AS888 Bit-Slice Processor and the 'AS895 Memory Address Generators is the function of the DB port. The 'AS888 DB port outputs the register file. The 'AS895 DB port can be used to read the MQ' register result during the same clock cycle that the ALU result is available at the Y port.

The SN54AS895 is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS895 and SN74AS895-1 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

Package options include both plastic and ceramic chip carriers in addition to a 68-pin grid array ceramic package.


GB PACKAGE PIN ASSIGNMENTS

| PIN | NAME | PIN | NAME | PIN | NAME | PIN | NAME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A-2 | $\mathrm{C}_{n}$ | B-9 | $\overline{\mathrm{OEY}}$ | F-10 | Y3 | K-4 | C2 |
| A-3 | $\overline{\mathrm{SIOO}}$ | B-10 | YO | F-11 | DB2 | K-5 | AO |
| A-4 | $\overline{\mathrm{Q1OO}}$ | B-11 | Y1 | G-1 | DA2 | K-6 | A3 |
| A-5 | $\overline{0107}$ | C-1 | 15 | G-2 | DAO | K-7 | $\overline{W E}$ |
| A-6 | $\mathrm{C}_{\mathrm{n}}+8$ | C-2 | $\mathrm{V}_{\mathrm{CC} 2}$ | G-10 | DBO | K-8 | DB7 |
| A-7 | $\overline{\mathrm{G}} / \mathrm{N}$ | C-10 | Y4 | G-11 | DB3 | K-9 | $\overline{\mathrm{OEB}}$ |
| A-8 | $\overline{\text { P/OVR }}$ | C-11 | Y6 | H-1 | DA3 | K-10 | EBO |
| A-9 | ZERO | D-1 | 16 | H-2 | DA1 | K-11 | EB1 |
| A-10 | PPP | D-2 | $\mathrm{V}_{\mathrm{CC} 1}$ | H-10 | DB6 | L-2 | CK |
| B-1 | 12 | D-10 | Y5 | H-11 | DB4 | L-3 | C1 |
| B-2 | 13 | D-11 | Y7 | J-1 | DA4 | L-4 | C3 |
| B-3 | 11 | E-1 | 17 | J-2 | DA5 | L-5 | A1 |
| B-4 | 10 | E-2 | $\overline{\text { OEA }}$ | J-10 | SELY | L-6 | A2 |
| B-5 | 14 | E-10 | Y2 | J-11 | DB5 | L-7 | B3 |
| B-6 | $\overline{\text { S107 }}$ | E-11 | DB1 | K-1 | DA6 | L-8 | B2 |
| B-7 | SSF | F-1 | $\overline{E A}$ | K-2 | DA7 | L-9 | B1 |
| B-8 |  | F-2 | GND | K-3 | C0 | L. 10 | BO |


| PIN GRID ARRAY | CHIP <br> CARRIER | NAME | I/O | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| A-10 | 28 | PPP | 1 | Package position pin. Tri-level input used to define package significance during instruction execution. Leave open for intermediate positions, tie to $V_{C C}$ for most significant package, and tie to GND for least significant package. |
| B-7 | 29 | SSF | I/O | Special shift function. Used to transfer required information between packages during special instruction execution. |
| A.9 | 30 | ZERO | 1/0 | Device zero detection, open collector. Input during certain special instructions. |
| A. 8 | 31 | $\overline{\mathrm{P}} / \mathrm{OVR}$ | 0 | ALU propagate/instruction overflow for most significant package, low active. |
| A-7 | 32 | $\overline{\mathrm{G}} / \mathrm{N}$ | 0 | ALU generate/negative result for most significant package, low active. |
| A-6 | 33 | $C_{n+8}$ | 0 | ALU ripple carry output. |
| $\begin{aligned} & \text { B-6 } \\ & \text { A-5 } \\ & \text { A-4 } \\ & \text { A-3 } \\ & \hline \end{aligned}$ | $\begin{aligned} & 34 \\ & 35 \\ & 36 \\ & 37 \\ & \hline \end{aligned}$ | $\begin{aligned} & \overline{\mathrm{SIO7}} \\ & \overline{\mathrm{Q} 107} \\ & \overline{\mathrm{Q} 100} \\ & \hline \mathrm{SIOO} \end{aligned}$ | $\begin{aligned} & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & \hline \end{aligned}$ | Bidirectional shift pin, low active. |
| A-2 | 38 | $\mathrm{C}_{\mathrm{n}}$ | 1 | ALU carry input. |
| B-4 <br> B-3 <br> B-1 <br> B-2 <br> B-5 <br> C-1 <br> D-1 <br> E-1 | $\begin{aligned} & 39 \\ & 40 \\ & 41 \\ & 42 \\ & 43 \\ & 44 \\ & 45 \\ & 46 \end{aligned}$ | $\begin{aligned} & 10 \\ & 11 \\ & 12 \\ & 13 \\ & 14 \\ & 15 \\ & 16 \\ & 17 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Instruction input. |
| C-2 | 47 | $\mathrm{V}_{\mathrm{CC} 2}$ |  | Low voltage power supply (2 V). |
| D-2 | 48 | $\mathrm{V}_{\mathrm{CC} 1}$ |  | $1 / \mathrm{O}$ interface supply voltage ( 5 V ). |
| E-2 | 49 | $\overline{O E A}$ | 1 | DA bus enable, low active. |
| F. 1 | 50 | $\overline{E A}$ | 1 | ALU input operand select. High state selects external DA bus and low state selects register file. |
| F-2 | 51 | GND |  | Ground pin. |
| $\begin{gathered} \mathrm{G}-2 \\ \mathrm{H}-2 \\ \mathrm{G}-1 \\ \mathrm{H}-1 \\ \mathrm{~J}-1 \\ \mathrm{~J}-2 \\ \mathrm{~K}-1 \\ \mathrm{~K}-2 \end{gathered}$ | $\begin{aligned} & 52 \\ & 53 \\ & 54 \\ & 55 \\ & 56 \\ & 57 \\ & 58 \\ & 59 \end{aligned}$ | DAO <br> DA1 <br> DA2 <br> DA3 <br> DA4 <br> DA5 <br> DA6 <br> DA7 | $\begin{aligned} & 1 / O \\ & 1 / O \\ & 1 / O \\ & 1 / O \\ & 1 / O \\ & 1 / O \\ & 1 / O \\ & 1 / O \end{aligned}$ | A port data bus. Outputs register file data ( $\overline{E A}=0$ ) or inputs externat data ( $\overline{E A}=1$ ). |
| L-2 | 60 | CK | 1 | Clocks all synchronous registers on positive edge. . |
| $\begin{aligned} & \mathrm{K}-3 \\ & \mathrm{~L}-3 \\ & \mathrm{~K}-4 \\ & \mathrm{~L}-4 \end{aligned}$ | $\begin{aligned} & 61 \\ & 62 \\ & 63 \\ & 64 \end{aligned}$ | $\begin{aligned} & \mathrm{CO} \\ & \mathrm{C} 1 \\ & \mathrm{C} 2 \\ & \mathrm{C} 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Register file write address select. |
| $\begin{aligned} & \mathrm{K}-5 \\ & \mathrm{~L}-5 \\ & \mathrm{~L}-6 \\ & \mathrm{~K}-6 \\ & \hline \end{aligned}$ | $\begin{aligned} & 65 \\ & 66 \\ & 67 \\ & 68 \end{aligned}$ | $\begin{aligned} & \mathrm{A} 0 \\ & \mathrm{~A} 1 \\ & \mathrm{~A} 2 \\ & \mathrm{~A} 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Register file A port read address select. |

SN54AS895, SN74AS895
8-BIT MEMORY ADDRESS GENERATORS

| PIN GRID <br> ARRAY | $\begin{gathered} \text { CHIP } \\ \text { CARRIER } \end{gathered}$ | NAME | 1/0 | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| K-7 | 1 | $\overline{\text { WE }}$ | 1 | Register file (RF) write enable. Data is written into RF when $\overline{W E}$ is low and a low-to-high clock transition occurs. RF write is inhibited when $\overline{\mathrm{WE}}$ is high. |
| L-7 | 2 | B3 | 1 |  |
| L-8 | 3 | B2 | 1 |  |
| L-9 | 4 | B1 | 1 | Register file B port read address select. ( $0=$ LSB). |
| L-10 | 5 | B0 | 1 |  |
| K-10 | 6 | EBO | 1 | ALU input operand select. EBO and EB1 selects the source of data that the S |
| K-11 | 7 | EB1 | 1 | multiplexer provides for the $S$ bus. Independent control of the DB bus and data path selection allow the user to isolate the DB bus while the ALU continues to process data |
| K-9 | 8 | $\overline{\text { OEB }}$ | 1 | DB bus enable, low active. |
| K-8 | 9 | DB7 | 1/0 |  |
| H-10 | 10 | DB6 | 1/0 |  |
| J-11 | 11 | DB5 | 1/0 |  |
| H-11 | 12 | DB4 | 1/0 | $B$ port data bus. Outputs MO register data ( $\overline{O E B}=0$ ) or used to input external data |
| G-11 | 13 | DB3 | 1/0 | $(\overline{O E B}=1),(0=L S B)$. |
| F-11 | 14 | DB2 | 1/0 |  |
| E-11 | 15 | DB1 | 1/0 |  |
| G-10 | 16 | DBO | 1/0 |  |
| J-10 | 17 | SELY | 1 | $Y$ bus select, high active. |
| D-11 | 18 | Y7 | 1/0 |  |
| C-11 | 19 | Y6 | 1/0 |  |
| D-10 | 20 | Y5 | 1/0 |  |
| C-10 | 21 | Y4 | 1/0 | $Y$ port data bus. Outputs instruction results ( $\overline{\mathrm{OEY}}=0$ ) or used to put external data into |
| F-10 | 22 | Y3 | 1/0 | register file ( $\overline{\mathrm{OEY}}=1$ ). |
| E-10 | 23 | Y2 | 1/0 |  |
| B-11 | 24 | Y1 | 1/0 |  |
| B-10 | 25 | Yo | 1/0 |  |
| B-9 | 26 | $\overline{\mathrm{OEY}}$ | 1 | Y bus output enable, low active. |
| F-2 | 27 | GND |  | Ground pin |

SN54AS895, SN74AS895 8-BIT MEMORY ADDRESS GENERATORS
functional block diagram


## SN54AS895, SN74AS895

8-BIT MEMORY ADDRESS GENERATORS

## architectural elements

## 3-port register file

Working registers consist of 128 storage elements organized into sixteen 8 -bit words. These storage elements appear to the user as 16 positive edge-triggered registers. The three port addresses, one write $(C)$ and two reads ( $A$ and $B$ ), are completely independent of each other to implement a 3 -operand register file. Data is written into the register file when WE is low and a low-to-high clock transition occurs. The ADD and SUBTRACT immediate instructions require only one source operand. The B address is used as the source address, and the bits of the A address are used to provide a constant field. The SET, RESET, and TEST BIT instructions use the B addressed register as both the source and destination register while the A and C addresses are used as masks. These instructions are explained in more detail in the instruction section.

## S multiplexer

The S multiplexer selects the ALU operand, as follows:

| EB1 | EBO | S bus |
| :--- | :--- | :--- |
| Low | Low | RF data |
| Low | High | MQ data |
| High | Low | DB data |
| High | High | MQ data |

DB port
The 8-bit bidirectional DB port inputs external data to the ALU or outputs the MO register. If $\overline{O E B}$ is low, the DB bus is active; if $\overline{O E B}$ is high, the DB bus is in the high impedance state. Notice that the DB port may be isolated at the same time that MO register data is passed to the ALU.

## R multiplexer

The $R$ multiplexer selects the other operand of the ALU. Except for those instructions that require constants or masks, the R bus will contain DA if $\overline{E A}$ is high or the RF data pointed to by $A$ if $\overline{E A}$ is low.

## DA port

The 8-bit bidirectional DA port inputs external data to the ALU or outputs the register file. If $\overline{O E A}$ is low, the DA bus is active; if $\overline{O E A}$ is high, the DA bus is in the high-impedance state. Notice that the DA bus may be isolated while register file data is passed to the ALU.

## ALU

The shift instructions are summarized in Table 4 and illustrated in Figure 2. The ALU can perform seven arithmetic and six logical instructions on two 8-bit operands. It also supports multiplication, division, normalization, bit set, reset, test, byte operations, and excess-3 BCD arithmetic. These source operands are the outputs of the $S$ and $R$ multiplexers.

## ALU and MQ shifters

ALU and MQ shifters perform all of the shift, multiply, divide, and normalize functions. Table 4 shows the value of the $\overline{\mathrm{SIO7}}$ and $\overline{\mathrm{Q} 107}$ pins of the most significant package. The standard shifts may be made into conditional shifts and the serial data may be input or output with the aid of two three-state gates. These capabilities are discussed further in the arithmetic and logic section.

## SN54AS895, SN74AS895 <br> 8-BIT MEMORY ADDRESS GENERATORS

## MO register

The multiplier-quotient (MQ) register has specific functions in multiplication, division, and normalization. This register may also be used as a temporary storage register. The MQ register may be loaded if the instruction code on pins 17-IO is E1-E7 or E9-EE (See Table 1).

## Y bus

The $Y$ bus contains the output of the ALU shifter if $\overline{\mathrm{OEY}}$ is low and is a high impedance input if $\overline{\mathrm{OEY}}$ is high. SELY must be low to pass the internal ALU shift bus and must be high to pass the external $Y$ bus to the register file.

## status

Four status pins are available on the most significant package, overflow (OVR), sign ( $N$ ), carry out ( $C_{n}+8$ ), and zero (ZERO). The $\mathrm{C}_{\mathrm{n}}+8$ line signifies the ALU result while OVR, ZERO, and $N$ refer the status after the ALU shift has occurred. Notice that the ZERO pin cannot be used to detect whether an input placed on a high impedance Y bus is zero.

## divide BCD flip-flops

The multiply-divide flip-flops contain the status of the previous multiply or divide instruction. They are affected by the following instructions:

```
DIVIDE REMAINDER FIX
SIGNED DIVIDE QUOTIENT FIX
SIGNED MULTIPLY
SIGNED MULTIPLY TERMINATE
SIGNED DIVIDE INITIALIZE
SIGNED DIVIDE START
```

```
SIGNED DIVIDE ITERATE UNSIGNED DIVIDE START UNSIGNED DIVIDE ITERATE UNSIGNED MULTIPLY SIGNED DIVIDE TERMINATE UNSIGNED DIVIDE TERMINATE
```

The excess-3 BCD flip-flops are affected by all instructions except NOP. The clear function clears these flip-flops. They preserve the carry from each nibble (4-bits) in excess-3/BCD operations.

## package position pin (PPP)

The position of the processor in the system is defined by the voltage level applied to the package position pin (PPP). Intermediate positions are selected by leaving the pin open. Tying the pin to $\mathrm{V}_{\mathrm{CC}}$ makes the processor the most significant package and tying the pin to GND makes the processor the least significant package.

## special shift function (SSF) pin

Conditional shifting algorithms may be implemented via control of the SSF pin. The applied voltage to this pin may be set as a function of a potential overflow condition (the two most significant bits are not equal) or any other condition (see Group 1 instructions).

## instruction set

The 'AS895 bit-slice processor uses bits 17-10 as instruction inputs. A combination of bits I3-IO (Group 1 instructions) and bits 17-14 (Group 2-5 instructions) are used to develop the 8 -bit op code for a specific instruction. Group 1 and Group 2 instructions can be combined to perform arithmetic or logical functions plus a shift function in one instruction cycle. A summary of the instruction set is given in Table 1.

TABLE 1. INSTRUCTION SET

| INSTRUCTION BITS (13-10) HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :---: |
| O 1 2 2 3 4 5 6 7 7 8 9 A B C D E F | ADD <br> SUBR <br> SUBS <br> INCS <br> INCNS <br> INCR <br> INCNR <br> XOR <br> AND <br> OR <br> NAND <br> NOR <br> ANDNR | Accesses Group 4 instructions $\begin{aligned} & R+S+C_{n} \\ & \bar{R}+S+C_{n} \\ & R+\bar{S}+C_{n} \\ & S+C_{n} \\ & \bar{S}+C_{n} \\ & R+C_{n} \\ & \bar{R}+C_{n} \end{aligned}$ <br> Accesses Group 3 instructions <br> R XOR S <br> R AND S <br> R OR S <br> R NAND S <br> R NOR S <br> $\overline{\mathrm{R}}$ AND S <br> Accesses Group 5 instructions |
| GROUP 2 INSTRUCTIONS |  |  |
| INSTRUCTION BITS (17-14) HEX CODE | MNEMONIC | FUNCTION |
| 0 <br> 1 <br> 2 <br> 3 <br> 4 <br> 5 <br> 6 <br> 7 <br> 8 <br> 9 <br> A <br> B <br> C <br> D <br> E <br> F | SRA <br> SRAD SRL <br> SRLD <br> SLA <br> SLAD <br> SLC <br> SLCD <br> SRC <br> SRCD <br> MOSRA <br> MQSRL <br> MQSLL <br> MQSLC <br> LOADMO <br> PASS | Arithmetic Right Single <br> Arithmetic Right Double <br> Logical Right Single <br> Logical Right Double <br> Arithmetic Left Single <br> Arithmetic Left Double <br> Circular Left Single <br> Circular Left Double <br> Circular Right Single <br> Circular Right Double <br> Pass ( $F \rightarrow Y$ ) and Arithmetic Right MQ <br> Pass $(F \rightarrow Y)$ and Logical Right MQ <br> Pass $(F \rightarrow Y)$ and Logical Left MQ <br> Pass $(F \rightarrow Y)$ and Circular Left MQ <br> Pass $(F \rightarrow Y)$ and Load MQ $(F=M Q)$ <br> Pass ( $F \rightarrow Y$ ) |

## SN54AS895, SN74AS895 8-BIT MEMORY ADDRESS GENERATORS

TABLE 1. INSTRUCTION SET (Continued)
GROUP 3 INSTRUCTIONS

| INSTRUCTION BITS (I7-IO) HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :---: |
| 08 18 28 38 48 58 68 78 88 98 A8 $B 8$ C8 $D 8$ E8 F8 | SET1 <br> SETO <br> TB1 <br> TBO <br> ABS <br> SMTC <br> ADDI <br> SUBI <br> BADD <br> BSUBS <br> BSUBR <br> BINCS <br> BINCNS <br> BXOR <br> BAND <br> BOR | Set Bit <br> Reset Bit <br> Test Bit (One) <br> Test Bit (Zero) <br> Absolute Value <br> Sign Magnitude/Two's Complement <br> Add Immediate <br> Subtract Immediate <br> Byte Add R to S <br> Byte Subtract S from R <br> Byte Subtract R from S <br> Byte Increment S <br> Byte Increment Negative $S$ <br> Byte XOR R and S <br> Byte AND R and S <br> Byte OR R and S |
| GROUP 4 INSTRUCTIONS |  |  |
| INSTRUCTION BITS (17-IO) HEX CODE | MNEMONIC | FUNCTION |
| 00 10 20 30 40 50 60 70 80 90 AO $B O$ CO DO EO FO | SEL <br> SNORM <br> DNORM <br> DIVRF <br> SDIVQF <br> SMULI <br> SMULT <br> SDIVIN <br> SDIVIS <br> SDIVI <br> UDIVIS <br> UDIV! <br> UMULI <br> SDIVIT <br> UDIVIT | Reserved <br> Select S/R <br> Single Length Normalize <br> Double Length Normalize <br> Divide Remainder Fix <br> Signed Divide Quotient Fix <br> Signed Multiply Iterate <br> Signed Multiply Terminate <br> Signed Divide Initialize <br> Signed Divide Start <br> Signed Divide Iterate <br> Unsigned Divide Start <br> Unsigned Divide Iterate <br> Unsigned Multiply Iterate <br> Signed Divide Terminate <br> Unsigned Divide Terminate |

TABLE 1. INSTRUCTION SET (Concluded)

| INSTRUCTION BITS (17-IO) <br> HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| OF | CLR | Clear |
| 1 F | CLR | Clear |
| $2 F$ | CLR | Clear |
| $3 F$ | CLR | Clear |
| $4 F$ | CLR | Clear |
| $5 F$ | CLR | Clear |
| $6 F$ | CLR | Clear |
| $7 F$ | BCDBIN | BCD to Binary |
| $8 F$ | EX3BC | Excess-3 Byte Correction |
| $9 F$ | EX3C | Excess-3 Word Correction |
| AF | SDIVO | Signed Divide Overflow Check |
| BF | CLR | Clear |
| CF | CLR | Clear |
| DF | BINEX3 | Binary to Excess-3 |
| EF | CLR | Clear |
| FF | NOP | No Operation |

TABLE 2. GROUP 1 INSTRUCTIONS

| INSTRUCTION BITS (I3-IO) <br> HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| 0 |  | Accesses Group 4 instructions |
| 1 | ADD | $R+S+C_{n}$ |
| 2 | SUBR | $\bar{R}+S+C_{n}$ |
| 3 | SUBS | $R+\bar{S}+C_{n}$ |
| 4 | INCS | $S+C_{n}$ |
| 5 | INCNS | $\bar{S}+C_{n}$ |
| 6 | INCR | $R+C_{n}$ |
| 7 | INCNR | $\bar{R}+C_{n}$ |
| 8 |  | Accesses Group 3 instructions |
| 9 | XOR | $R$ XOR S |
| A | AND | R AND S |
| $B$ | OR | R OR S |
| C | NAND | R NAND S |
| D | NOR | R NOR S |
| E | ANDNR | $\bar{R}$ AND S |
| F |  | Accesses Group 5 instructions |

Group 1 instructions (excluding hex codes 0,8 , and $F$ ), shown in Table 2, may be used in conjunction with Group 2 shift instructions to perform arithmetic or logical functions plus a shift function ${ }^{\dagger}$ in one instruction cycle (hex codes 0,8 , and $F$ are used to access Group 4, 3, and 5 instructions, respectively). Each shift may be made into a conditional shift by forcing the special shift function (SSF) pin into the proper state. If the SSF pin is high or floating, the shifted ALU output will be sent to the output buffers. If the SSF pin is pulled low externally, the ALU result will be passed directly to the output buffers. Conditional shifting is useful for scaling inputs in data arrays or in signal processing algorithms.

These instructions set the BCD flip-flop for the excess-3 correct instruction. The status is set with the following results ( $C_{n}+8$ is ALU carry out and is independent of shift operation; others are evaluated after shift operation).
${ }^{\dagger}$ Double-precision shifts involve both the ALU and MQ register.
Status is set with the following results:

## Arithmetic

| N | $\rightarrow$ | MSB of result |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Signed arithmetic overflow |
| $\mathrm{C}_{n}+8$ | $\rightarrow$ | Carry out equal one |
| Z | $\rightarrow$ | Result equal zero |

Logic
$\mathrm{N} \quad \rightarrow \quad \mathrm{MSB}$ of result OVR $\rightarrow$ None (force to zero)
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow$ None (force to zero)
Z $\quad \rightarrow \quad$ Result equal zero

## group 2 instructions

TABLE 3. GROUP 2 INSTRUCTIONS

| INSTRUCTION BITS (17-14) <br> HEX CODE | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| 0 | SRA | Arithmetic Right Single |
| 1 | SRAD | Arithmetic Right Double |
| 2 | SRL | Logical Right Single |
| 3 | SRLD | Logical Right Double |
| 4 | SLA | Arithmetic Left Single |
| 5 | SLAD | Arithmetic Left Double |
| 6 | SLC | Circular Left Single |
| 7 | SLCD | Circular Left Double |
| 8 | SRC | Circular Right Single |
| 9 | SRCD | Circular Right Double |
| A | MQSRA | Pass $(F \rightarrow Y)$ and Arithmetic Right MQ |
| $B$ | MQSRL | Pass $(F \rightarrow Y)$ and Logical Right MQ |
| C | MQSLL | Pass $(F \rightarrow Y)$ and Logical Left MQ |
| D | MQSLC | Pass $(F \rightarrow Y)$ and Circular Left MQ |
| E | LOADMQ | Pass $(F \rightarrow Y)$ and Load MQ ( $F=M Q$ ) |
| F | PASS | Pass $(F \rightarrow Y)$ |

## SN54AS895, SN74AS895

## 8-BIT MEMORY ADDRESS GENERATORS

The processor's shift instructions are implemented by a combination of Group 2 instructions (Table 3) and certain wired connections on the packages used. The following external connections are required.

On intermediate packages:
SIO7 is connected to SIOO of the next most significant package
$\overline{0107}$ is connected to $\overline{0100}$ of the next most significant package
$\overline{S 100}$ is connected to $\overline{S 107}$ of the next least significant package
$\overline{0100}$ is connected to $\overline{0107}$ of the next least significant package
On the two end packages:
SIO7 on the most significant package is connected to SIOO of the least significant package $\overline{0107}$ on the most significant package is connected to $\overline{\mathrm{O}} \mathrm{OO}$ of the least significant package

The connections are the same on all instructions including multiply, divide, and normalization functions.
Single- and double-precision shifts are supported. Double-precision shifts assume the most significant half has come through the ALU and will be placed (if $\overline{\mathrm{WE}}$ is low) into the register file on the rising edge of the clock and the least significant half lies in the MO register. All Group 2 shifts may be made conditional (see previous page).

The following definitions apply to Group 2 shift instructions:
Arithmetic right shifts copy the sign of the number if no overflow occurs from the ALU calculation; if overflow occurs, the sign bit is inverted.
Arithmetic left shifts do not retain the sign of the number if an overflow occurs. A zero is filled into the LSB if not forced externally.
Logical right shifts fill a zero in the MSB position if not forced externally.
Logical left shifts fill a zero in the LSB position if not forced externally.
Circular right shifts fill the LSB in the MSB position.
Circular left shifts fill the MSB in the LSB position.
Shifting left is defined as moving a bit position towards the MSB (doubling).
Shifting right is defined as moving a bit towards the LSB (halving).
Serial input may be performed using the circuitry shown in Figure 1. A single-/or double-precision arithmetic left or logical right shift fills the complement of the data on $\overline{\mathrm{SIOO}}$ and $\overline{\mathrm{SIO7}}$ into the LSB or MSB of the data word(s). Note that if $\overline{\mathrm{SIOO}}$ and $\overline{\mathrm{SIOO}}$ are floating ( $\mathrm{HI}-\mathrm{Z}$ ), a zero will be filled as an end condition.

Serial output may be performed with circular instructions.


FIGURE 1. SERIAL I/O

The shift instructions are summarized in Table 4 and illustrated in Figure 2. In Figure 2 and all succeeding figures that illustrate instruction execution, the following definitions apply:

QBT - End fill for signed divide.
MQF - End fill for unsigned divide.
SRF - End fill for signed multiply and the arithmetic right shifts.
TABLE 4. SHIFT INSTRUCTIONS

| OP <br> CODE $^{\dagger}$ | SHIFT FUNCTION ${ }^{\ddagger}$ | SIO7•SIOO <br> WIRED VALUE | QIO7• QIO0 <br> WIRED VALUE |
| :---: | :--- | :--- | :---: |
| ON | Arithmetic Right Single | ALU-LSB Output | - |
| 1 N | Arithmetic Right Double | MQ-LSB Output | ALU-LSB Output |
| 2 N | Logical Right Single | Input to ALU-MSB | ALU-LSB Output |
| 3 N | Logical Right Double | Input to ALU-MSB | ALU-LSB Output |
| 4 N | Arithmetic Left Single | Input to ALU-LSB | ALU-MSB Output |
| 5 N | Arithmetic Left Double | Input to MQ-LSB | MQ-MSB Output |
| 6 N | Circular Left Single | ALU-MSB Output | - |
| 7 N | Circular Left Double | ALU-MSB Output | MQ-MSB Output |
| $8 N$ | Circular Right Single | ALU-LSB Output | - |
| $9 N$ | Circular Right Double | MQ-LSB Output | ALU-LSB Output |
| AN | Arithmetic Right (MQ only) | MQ-LSB Output | MQ-LSB Output |
| BN | Logical Right (MO only) | MQ-LSB Output | Input to MQ-MSB |
| CN | Logical Left (MQ only) | Input to MQ-LSB | MQ-MSB Output |
| DN | Circular Left (MQ only) | MQ-MSB Output | MQ-MSB Output |

${ }^{\dagger}$ Op Code $N \neq 0,8$, or $F$; these select special instruction Groups 4,3 , and 5 respectively.
${ }^{\ddagger}$ Shift I/O pins are active low. Therefore, inputs and outputs must be inverted if true logical values are required.

Status is set with the following results:
Arithmetic

| N | $\rightarrow$ | Result MSB equal one |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Signed arithmetic overflow |${ }^{\dagger}$

$\dagger$ For the SLA and SLAD instructions, OVR is set if signed arithmetic overflow or if the ALU result MSB XOR MSB-1 equals one.
ARITHMETIC RIGHT SINGLE


LOGICAL RIGHT DOUBLE

FIGURE 2. SHIFT INSTRUCTIONS (Continued)

(FILLS ZERO IF NOT FORCED)

FIGURE 2. SHIFT INSTRUCTIONS (Continued)

FIGURE 2. SHIFT INSTRUCTIONS (Continued)
CIRCULAR RIGHT SINGLE

FIGURE 2. SHIFT INSTRUCTIONS (Continued)
FIGURE 2. SHIFT INSTRUCTIONS (Continued)
ARITHMETIC RIGHT (MQ ONLY)

(FILLS ZERO IF NOT FORCED)
LOGICAL LEFT (MQ ONLY) (FILLS ZERO IF NOT FORCED)

FIGURE 2. SHIFT INSTRUCTIONS (Concluded)

## group 3 instructions

Hex code 8 of Group 1 instructions is used to access Group 3 instructions. Group 3 instructions are summarized in Table 5.

TABLE 5. GROUP 3 INSTRUCTIONS

| INSTRUCTION BITS (I7-IO) <br> OP CODE (HEX) | MNEMONIC | FUNCTION |
| :---: | :--- | :--- |
| 08 | SET1 | Set Bit |
| 18 | SETO | Reset Bit |
| 28 | TB1 | Test Bit (One) |
| 38 | TB0 | Test Bit (Zero) |
| 48 | ABS | Absolute Value |
| 58 | SMTC | Sign Magnitude/Two's Complement |
| 68 | ADDI | Add Immediate |
| 78 | SUBi | Subtract Immediate |
| 88 | BADD | Byte Add R to S |
| 98 | BSUBS | Byte Subtract S from R |
| A8 | BSUBR | Byte Subtract R from S |
| B8 | BINCS | Byte Increment S |
| C8 | BINCNS | Byte Increment Negative S |
| D8 | BXOR | Byte XOR R and S |
| E8 | BAND | Byte AND R and S |
| F8 | BOR | Byte OR R and S |

## SN54AS895, SN74AS895 <br> 8-BIT MEMORY ADDRESS GENERATORS

set bit instruction (set 1 ): $17-10=0816$
This instruction (Figure 3) is used to force selected bits of a desired byte(s) to one. The desired bits are specified by an 8-bit mask (C3-CO)::(A3-AO) ${ }^{\dagger}$ consisting of register file address ports that are not required to support this instruction. All bits in the selected byte(s) that are in the same bit positions as ones in the mask are forced to a logical one. The B3-BO address field is used for both source and destination of this instruction. The desired byte is specified by forcing $\overline{\mathrm{SIOO}}$ to a low value. Nonselected packages pass the byte through unaltered. The S bus is the source word for this instruction. The status set by the set bit instruction is as follows:

| N | $\rightarrow$ | None (force to zero) |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | None (force to zero) |
| $\mathrm{C}_{\mathrm{n}}+8$ | $\rightarrow$ | None (force to zero) |
| Z | $\rightarrow$ | Result equal zero |

$\dagger$ The symbol ' $::$ ' is concatenation operator


FIGURE 3. SET BIT (OR RESET BIT)
NOTES: 1. Force $\overline{\mathrm{SIOO}}=$ low to select byte.
2. Bit mast (C3-CO)::(A3-A0) will set desired bits to one.
reset bit instruction (set0): $17-10=1816$
This instruction (Figure 3) is used to force selected bits of a desired byte(s) to zero. The desired bits are specified by an 8 -bit mask (C3-CO)::(A3-A0) consisting of register file address ports that are not required to support this instruction. All bits in the selected byte(s) that are in the same bit positions as ones in the mask are reset. The B3-B0 address field is used for both source and destination of this instruction.

The desired byte is specified by forcing $\overline{\mathrm{SIOO}}$ to a low value. Nonselected packages pass the byte through unaltered. The S bus is the source word for this instruction. The status set by the reset bit instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { None (force to zero) } \\
\text { OVR } & \rightarrow & \text { None (force to zero) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow & \text { None (force to zero) } \\
Z & \rightarrow & \text { Result equal zero }
\end{array}
$$

test bit (one) instruction (TB1): $17-10=\mathbf{2 8 1 6}$
This instruction (Figure 4) is used to test selected bits of a desired byte(s). Bits to be tested are specified by an 8-bit mask (C3-CO): :(A3-AO) consisting of register file address ports that are not required to support this instruction. Write Enable ( $\overline{\mathrm{WE}})$ is internally disabled during this instruction. The desired byte is specified by forcing $\overline{\mathrm{SIOO}}$ to a low value. The test will pass if the selected byte has ones at all bit locations specified by the ones of the mask (Figure 5). The S bus is the source word for this instruction. The status set by the test bit (one) instruction is as follows:


Figure 4. test bit
NOTES: 1. Force $\overline{S I O O}=$ low to select byte.
2. Bit mask (C3-CO)::(A3-AO) will define bits for testing.
3. Pass/fail is indicated on $Z$ output.
test bit (zero) instruction (TBO): 17-10 $=\mathbf{3 8 1 6}$
This instruction (Figure 4) is used to test selected bits of a desired byte(s). Bits to be tested are specified by an 8-bit mask (C3-C0)::(A3-A0) consisting of register file address ports that are not required to support this instruction. Write Enable ( $\overline{\mathrm{WE}}$ ) is internally disabled during this instruction. The desired byte is specified by forcing $\overline{\mathrm{SIOO}}$ to a low value. The test will pass if the selected byte has zeros at all bit locations specified by the ones of the mask (Figure 6). The $S$ bus is the source word for this instruction. The status set by the test bit (zero) instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { None (force to zero) } \\
\text { OVR } & \rightarrow \\
\text { None (force to zero) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\text { None (force to zero) } \\
\mathrm{Z} & \rightarrow
\end{array} \text { Pass }
$$



FIGURE 5. TEST BIT ONE EXAMPLES

## 8-BIT MEMORY ADDRESS GENERATORS



FIGURE 6. TEST BIT ZERO EXAMPLES
absolute value instruction (ABS): $17-10=4816$
This instruction is used to convert two's complement numbers to their positive value. The operand placed on the S bus is the source for this instruction. The MSP will test the sign of the S bus and force the SSF pin to the proper value. All other packages use the SSF pin as input to determine instruction execution. The status set by the absolute value instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { Input MSB equal one } \\
\text { OVR } & \rightarrow & \text { Input equal } 8000 \text { (hex) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow & \mathrm{~S}=0 \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

sign magnitude/two's complement instruction (SMTC): $17-10=5816$
This instruction allows conversion from two's complement representation to sign magnitude representation, or vice-versa, in one clock cycle. The operand placed on the S bus is the source for this instruction.

When a negative zero ( 8000 hex ) is converted, the result is 0000 with an overflow. If the input is in two's complement notation, the overflow indicates an illegal conversion. The status set by the sign magnitude/two's complement instruction is as follows:

$$
\begin{array}{lll}
N & \rightarrow & \text { Result MSB equal one } \\
\text { OVR } & \rightarrow & \text { Input equal 8000 (hex) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow & \text { Input equal 0000 (hex) } \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

## SN54AS895, SN74AS895 8-BIT MEMORY ADDRESS GENERATORS

add immediate instruction (ADDI): $17-10=6816$
This instruction is used to add a specified constant value to the operand placed on the S bus. The constant will be between the values of 0 and 15 . The constant value is specified by the unused register file address (A port) not required to support this instruction. Forcing the carry input will add an additional one to the result. The status set by the add immediate instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { Result MSB equal one } \\
\mathrm{OVR} & \rightarrow & \text { Arithmetic signed overflow } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow & \text { Carry out equal one } \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

subtract immediate instruction (SUBI): $\mathbf{I 7}-\mathbf{I O}=\mathbf{7 8 1 6}$
This instruction is used to subtract a specified constant value from the operand placed on the S bus. The constant value is specified by the unused register file address (A port) that is not required to support this instruction. The constant applied is the least significant four bits of a two's complement number. The device sign extends the constant over the entire word length. The status set by the subtract immediate instruction is as follows:

| N | $\rightarrow$ | Result MSB equal one |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Arithmetic signed overflow |
| $\mathrm{C}_{\mathrm{n}}+8$ | $\rightarrow$ | Carry out equal one |
| Z | $\rightarrow$ | Result equal zero |

## byte instructions

There are eight byte instructions in Group 3. These instructions modify selected bytes of the operand on the S bus. A byte is selected by forcing $\overline{\mathrm{SIOO}}$ to a low value (same as SET1, SETO, TB1, and TBO instructions). Multiple bytes may be selected only if they are adjacent to one another.

NOTE: At least one byte must be nonselected during these instructions.
The nonselected bytes are passed through unaltered. Byte status is forced through the most significant package except for the sign of the result ( N ), which is forced to zero (low). The status set by the byte instructions is as follows:
(Most Significant Package)

|  | (Most Significant Package) |  |
| :--- | :--- | :---: |
| N | $\rightarrow$ |  |
| None (force to zero) |  |  |
| OVR | $\rightarrow$ |  |
| Byte signed overflow |  |  |
| $\mathrm{C}_{\mathrm{n}}+8$ | $\rightarrow$ |  |
| $\mathrm{Z}^{2}$ | Byte carry out equal one |  |
| Z | Byte result equal to zero |  |

## (Selected BYTES-other than MSP)

$$
\begin{array}{lll}
\mathrm{G} & \rightarrow & \text { Normal generate } \\
\mathrm{P} & \rightarrow & \text { Normal propagate } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow & \text { Normal carry out } \\
\mathrm{Z} & \rightarrow & \text { Result equal to zero }
\end{array}
$$

## (Nonselected BYTES - other than MSP)

G $\quad \rightarrow \quad$ No generate (force to one)
$\mathrm{P} \quad \rightarrow \quad$ Propagate (force to zero)
$\mathrm{C}_{\mathrm{n}+8} \rightarrow \mathrm{C}_{\mathrm{n}}$
$z \quad \rightarrow \quad$ None (force to one)

## group 4 instructions

Hex code 0 of Group 1 instructions is used to access Group 4 instructions. Group 4 instructions are summarized in Table 6.

TABLE 6. GROUP 4 INSTRUCTIONS

| INSTRUCTION BITS (I7-IO) <br> OP CODE (HEX) | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| 00 |  | Reserved |
| 10 | SEL | Select S/R |
| 20 | SNORM | Single Length Normalize |
| 30 | DNORM | Double Length Normalize |
| 40 | DIVRF | Divide Remainder Fix |
| 50 | SDIVQF | Signed Divide Quotient Fix |
| 60 | SMULI | Signed Multiply Iterate |
| 70 | SMULT | Signed Multiply Terminate |
| 80 | SDIVIN | Signed Divide Initialize |
| 90 | SDIVIS | Signed Divide Start |
| AO | SDIVI | Signed Divide Iterate |
| BO | UDIVIS | Unsigned Divide Start |
| CO | UDIVI | Unsigned Divide Iterate |
| DO | UMULI | Unsigned Multiply Iterate |
| EO | SDIVIT | Signed Divide Terminate |
| FO | UDIVIT | Unsigned Divide Terminate |

select $S / R$ instruction (SEL): $17-10=1016$
This instruction is used to pass either the $S$ bus or the $R$ bus to the output depending on the state of the SSF input pin. Normally, the preceding instruction would test the two operands and the resulting status information would be used to force the SSF input pin. SSF $=0$ will output the $R$ bus and SSF $=1$ will output the $S$ bus. The status set by the select $S / R$ instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { Result MSB equal one } \\
\text { OVR } & \rightarrow \\
\text { None (force to zero) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\mathrm{None} \text { (force to zero) } \\
\mathrm{Z} & \rightarrow \\
\text { Result equal zero }
\end{array}
$$

single-length normalize instruction (SNORM): 17-10 $=2016$
This instruction will cause the contents of the MQ register to shift toward the most significant bit. Zeros are shifted in via the $\overline{\mathrm{QIOO}}$ input. The number of shifts performed can be counted and stored in one of the register files by forcing a high at the $\mathrm{C}_{n}$ input. When the two most significant bits are of opposite value, normalization is complete. This condition is indicated on the microcycle that completes the normalization at the OVR output.

The chip contains conditional logic that inhibits the shift function (and also inhibits the register file increment) if the number within the MQ register is already normalized at the beginning of the instruction (Figure 7). The status set by the single-length normalize instruction is as follows:

$$
\begin{array}{lll}
\text { N } & \rightarrow & \text { MSB of result } \\
\text { OVR } & \rightarrow & \text { MSB XOR } 2 \text { nd MSB } \\
\mathrm{C}_{n}+8 & \rightarrow & \text { Carry out equal one } \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

SINGLE-LENGTH NORMALIZE

FIGURE 7. SINGLE-AND DOUBLE-LENGTH NORMALIZE

## double-length normalize instruction (DNORM): 17-10 $=\mathbf{3 0 1 6}$

This instruction will cause the contents of a double-length word (register file contains the most significant half and the MQ register contains the least significant half) to shift toward the most significant bit. Zeros are shifted in via the $\overline{0100}$ input. When the two most significant bits are of opposite value, normalization is complete. This condition is indicated on the microcycle that completes the normalization at the OVR output.
The chip contains conditional logic which inhibits the shift function if the number is already normalized at the beginning of the instruction (Figure 7). The most significant half of the operand must be placed on the S bus. The status set by the double-length normalize instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { MSB of result } \\
\text { OVR } & \rightarrow & \text { MSB XOR 2nd MSB } \\
\mathrm{C}_{n+8} & \rightarrow & \text { None (force to zero) } \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$

## multiply operations

The ALU performs three unique types of N by N multiplies each of which produces a 2 N -bit result (Figure 8 ). All three types of multiplication proceed via the following recursion:
$\mathrm{P}(\mathrm{J}+1)=2[\mathrm{P}(\mathrm{J})+$ Multiplicand $\times \mathrm{M}(8 \mathrm{~N}-\mathrm{J})]$
where
$\mathrm{P}(\mathrm{J})=$ partial product at iteration number J
$\mathrm{N}=$ number of 'AS888 packages that are cascaded
$\mathrm{P}(\mathrm{J}+1)=$ partial product at iteration number $\mathrm{J}+1$
J varies from 0 to $8 \mathrm{~N}[\mathrm{~N}=2$ for $16 \times 16$ multiply]
$\mathrm{M}(8 \mathrm{~N}-\mathrm{J})=$ mode bit (unique to multiply type)
2 denotes some type of shift (unique to multiply)

Notice that by proper choice of mode terms and shifting operations, signed, unsigned, and mixed multiplies (signed times unsigned) may be performed.
All multiplies assume that the multiplier is stored in MQ before the operation begins (in the case of mixed multiply, the unsigned number must be the multiplier).
The processor has the following multiply instructions:

1. SIGNED MULTIPLY ITERATE (SMULI): $17-10=6016$
2. SIGNED MULTIPLY TERMINATE (SMULT): $17-10=7016$
3. UNSIGNED MULTIPLY ITERATE (UMULI): $17-10=\mathrm{DO}_{16}$
SMULI, SMULT


## 8-BIT MEMORY ADDRESS GENERATORS

The signed multiply iterate (SMULI) instruction performs a signed times signed iteration. This instruction interprets $\mathrm{M}(8 \mathrm{~N}-\mathrm{J})$ as the $8 \mathrm{~N}-\mathrm{J}$ bit of the multiplier. The shift is a double-precision right shift one bit. This instruction is repeated 15 times for a $16 \times 16$ signed multiply. This instruction will be used 16 consecutive times for a mixed multiplication.

The signed multiply terminate (SMULT) instruction provides correct (negative) weighting of the sign bit of a negative multiplier in signed multiplication. The instruction is identical to signed multiply iterate (SMULI) except that $M(8 N-J)$ is interpreted as -1 if the sign bit of the multiplier is 1 , and 0 if the sign bit of the multiplier is 0 .

The unsigned multiply iterate (UMULI) performs an unsigned multiplication iteration. This instruction interprets $\mathrm{M}(8 \mathrm{~N}-\mathrm{J})$ as the $8 \mathrm{~N}-\mathrm{J}$ bit of the multiplier. The shift is a double-precision right shift with the carry out from the $P(J)+$ Multiplicand $\times M(8 N-J)$ operation forced into bit $8 N$ of $P(J+1)$. This instruction is used in unsigned and mixed multiplication.

## signed multiplication

Signed multiplication performs an $8 \mathrm{~N}+2$ clock two's complement multiply. The instructions necessary to produce an algebraically correct result proceed in the following manner:

Zero register to be used for accumulator
Load MQ with multiplier
SMULI (repeat $8 \mathrm{~N}-1$ times) $\quad$ S port $=$ Accumulator
R port $=$ Multiplicand
$F$ port $=$ Iteration result
S port $=$ Accumulator
R port $=$ Multiplicand
F port $=$ Product (MSH)
At completion, the accumulator will contain the 8 N most significant bits and the MQ contains the 8 N least significant bits of the product.
The status for the signed multiply iterate should not be used for any testing (overflow is not set by SMULI). The following status is set for the signed multiply terminate instruction:
$\mathrm{N} \rightarrow$ Result MSB equal one
OVR $\rightarrow$ Forced to zero
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow$ Carry out equal to one
Z $\rightarrow$ Double precision result is zero

## unsigned multiplication

Unsigned multiplication produces an unsigned times unsigned product in $8 \mathrm{~N}+2$ clocks. The instructions necessary to produce an algebraically correct result proceed in the following manner:

Zero register to be used for accumulator
Load MO with multiplier
UMULI ( 8 N times)
Sport $=$ Accumulator
R port $=$ Multiplicand
F port $=$ Iteration result (product MSH on final result)

## SN54AS895, SN74AS895 <br> 8-BIT MEMORY ADDRESS GENERATORS

Upon completion, the accumulator will contain the 8 N most significant bits and the MQ contains the 8 N least significant bits of the product.

The status set by the unsigned multiply iteration is meaningless except on the final execution of the instruction. The status set by the unsigned multiply iteration instruction is as follows:

N $\quad \rightarrow \quad$ Result MSB equal one
OVR $\rightarrow$ Forced to zero
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow$ Carry out equal to one
$\mathrm{Z} \rightarrow$ Double-precision result is zero
mixed multiplication
Mixed multiplication multiplies a signed multiplicand times an unsigned multiplier to produce a signed result in $8 N+2$ clocks. The steps are as follows:

Zero register used for accumulator
Load MO with unsigned multipler
SMULI (8N times) S port $=$ Accumulator
R port $=$ Multiplicand
F port $=$ Iteration result
Upon completion, the accumulator will contain the 8 N most significant bits and the MQ will contain the 8 N least significant bits of the product.

The following status is set by the last SMULI instruction:
$\mathrm{N} \quad \rightarrow \quad$ Result MSB equal one
OVR $\rightarrow$ Forced to zero
$C_{n+8} \rightarrow$ Carry out equal to one
Z $\rightarrow$ Double-precision result is zero

## divide operations

The divide uses a nonrestoring technique to perform both signed and unsigned division of a 16 N bit integer dividend and an 8 N bit integer divisor (Figure 9). It produces an 8 N integer quotient and remainder.

The remainder and quotient will be such that the following equation is satisfied:

$$
\text { (Quotient) } \times \text { (Divisor) }+ \text { Remainder }=\text { Dividend }
$$

The processor has the following divide instructions:

1. UNSIGNED DIVIDE START (UDIVIS): $17-10=B 016$
2. UNSIGNED DIVIDE ITERATE (UDIVI): $17-10=\mathrm{CO}_{16}$
3. UNSIGNED DIVIDE TERMINATE (UDIVIT): $17-I 0=$ F016
4. SIGNED DIVIDE INITIALIZE (SDIVIN): $17-I O=8016$
5. SIGNED DIVIDE OVERFLOW TEST (SDIVO): $17-10=A F_{16}$
6. SIGNED DIVIDE START (SDIVIS): $17-10=9016$
7. SIGNED DIVIDE ITERATE (SDIVI): $17-10=A 016$
8. SIGNED DIVIDE TERMINATE (SDIVIT): $17-I O=E 016$
9. DIVIDE REMAINDER FIX (DIVRF): $17-10=4016$
10. SIGNED DIVIDE QUOTIENT FIX (SDIVQF): $17-10=5016$
UDIVS, UDIVI

UDIVT

FIGURE 9. DIVIDE OPERATIONS (Continued)

The unsigned divide iterate start (UDIVIS) instruction begins the iterate procedure while testing for overflow. Overflow is reported when the first subtraction of the divisor from the MSH of the dividend produces carry out. The test detects quotient overflow and divide by zero.

The unsigned divide iterate terminate (UDIVIT) instruction completes the iterate procedure generating the last quotient bit.

The signed divide initialize (SDIVIN) instruction prepares for iteration by shifting the dividend and storing the sign of the dividend for use in the following instructions and overflow tests.

The signed divide overflow test (SDIVO) checks for overflow possibilities. This instruction may be deleted from the divide operation if the OVR pin is ignored. If it is removed some overflow conditions will go undetected. $\overline{W E}$ must be high (writing inhibited) when this instruction is used.

The signed divide iterate start (SDIVIS) instruction calculates the difference between the divisor and MSH of the dividend. Partial detection of overflow is also done during this instruction. Operations with like signs (positive quotient) and division by zero will overflow during this instruction (including zero divisor). Operations with unlike signs are tested for overflow during the signed divide quotient fix instruction (SDIVQF). Partial overflow results are saved and will be used during SDIVQF when overflow is reported.

The signed divide iterate (SDIVI) instruction forms the quotient and remainder through iterative subtract/addshift operations of the divisor and dividend. One quotient bit is generated on each clock.

The signed divide iterate terminate (SDIVIT) instruction completes the iterate procedure, generating the last quotient bit. It also tests for a remainder equal to zero, which determines the action to be taken in the following correction (fix) instructions.

The divide remainder fix (DIVRF) instruction corrects the remainder. If a zero remainder was detected by the previous instructions, the remainder is forced to zero. For nonzero remainder cases where the remainder and dividend have the same sign, the remainder is correct. When the remainder and dividend have unlike signs, a correction add/subtract of the divisor to the remainder is performed.

The signed divide quotient fix (SDIVQF) instruction corrects the quotient if necessary. This correction requires adding one to the incorrect quotient. An incorrect quotient results if the signs of the divisor and dividend differ and the remainder is nonzero. An incorrect quotient also results if the sign of the divisor is negative and the remainder is zero.

Overflow detection is completed during this instruction. Overflow may be generated for differing signs of the dividend and divisor. The partial overflow test result performed during SDIVIS is ORed with this test result to produce a true overflow indication.

## signed divide usage

The instructions necessary to perform an algebraically correct division of signed numbers are as follows:
Load MQ with the least significant half of the dividend
SDIVIN S port $=\mathrm{MSH}$ of dividend
R port $=$ Divisor
F port $=$ Intermediate result
SDIVO $\quad$ S port $=$ Result of SDIVIN
R port $=$ Divisor
F port $=$ Test result
(WE must be high)
SDIVIS S port $=$ Result of SDIVIN
R port $=$ Divisor
F port $=$ Intermediate result

| SDIVI (8N-2 times) | S port $=$ Result of SDIVIS (or SDIVI) |
| :--- | :--- |
|  | R port $=$ Divisor |
|  | F port $=$ Intermediate result |
| SDIVIT | S port $=$ Result of last SDIVI |
|  | R port $=$ Divisor |
|  | F port $=$ Intermediate result |
| DIVRF | S port $=$ Result of SDIVIT |
|  | R port $=$ Divisor |
| SDIVQF | F port $=$ Remainder |
|  | S port $=$ MQ register |
|  | R port $=$ Divisor |
|  | F port $=$ Quotient |

The status of all signed divide instructions except SDIVIN, DIVRF, and SDIVOF is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { Forced to zero } \\
\mathrm{OVR} & \rightarrow \\
\text { Forced to zero } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\mathrm{Z} & \rightarrow \\
\text { Carry out equal to one } \\
\mathrm{Z} & \text { Intermediate result is zero }
\end{array}
$$

The status of the SDIVIN instruction is as follows:

| N | $\rightarrow$ | Forced to zero |
| :--- | :--- | :--- |
| OVR | $\rightarrow$ | Forced to zero |
| $\mathrm{C}_{\mathrm{n}}+8$ | $\rightarrow$ | Forced to zero |
| Z | $\rightarrow$ | Divisor is zero |

The status of the DIVRF instruction is as follows:
$\mathrm{N} \rightarrow$ Forced to zero
OVR $\rightarrow$ Forced to zero
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow$ Carry out equal to one
Z $\rightarrow$ Remainder is zero
The status of the SDIVQF instruction is as follows:

| N | $\rightarrow$ |
| :--- | :--- |
| Sign of quotient |  |
| OVR | $\rightarrow$ |
| Divide overflow |  |
| $\mathrm{C}_{n}+8$ | $\rightarrow$ |
| Z | $\rightarrow$ Quotient is zero |

The quotient is stored in the $M Q$ register and the remainder is stored in the register file location that originally held the most significant word of the dividend. If fractions are divided, the quotient must be shifted right one bit and the remainder right three bits to obtain the correct fractional representations.

The signed division algorithm is summarized in Table 7.

TABLE 7. SIGNED DIVISION ALGORITHM

| OP <br> CODE | MNEMONIC | CLOCK <br> CYCLES | INPUT <br> S PORT | INPUT <br> R PORT | OUTPUT <br> F PORT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| E4 | LOADMQ | 1, | Dividend (LSH) | - | Dividend (LSH) |
| 80 | SDIVIN | 1 | Dividend (MSH) | Divisor | Remainder (N) |
| AF | SDIVO | 1 | Remainder (N) | Divisor | Test Result |
| 90 | SDIVIS | 1 | Remainder (N) | Divisor | Remainder (N) |
| AO | SDIVI | $8 N-2^{\dagger}$ | Remainder (N) | Divisor | Remainder (N) |
| EO | SDIVIT | 1 | Remainder (N) | Divisor | Remainder (Unfixed) |
| 40 | DIVRF | 1 | Remainder (Unfixed) | Divisor | Remainder |
| 50 | SDIVQF | 1 | MQ Register | Divisor | Quotient |

${ }^{\dagger} \mathrm{N}=$ Number of cascaded packages.

## unsigned divide usage

The instructions necessary to perform an algebraically correct division of unsigned numbers are as follows:
Load MO with the least significant half of the dividend

UDIVIS

UDIVI ( $8 \mathrm{~N}-1$ times)

UDIVIT

DIVRF $\quad$ S port $=$ Result of UDIVIT
R port $=$ Divisor
F port $=$ Remainder

The status of all unsigned divide instructions except UDIVIS is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { Forced to zero } \\
\mathrm{OVR}^{2} & \rightarrow & \text { Forced to zero } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow & \text { Carry out equal to one } \\
\mathrm{Z} & \rightarrow & \text { Intermediate result is zero }
\end{array}
$$

The status of the UDIVIS instruction is as follows:
$\mathrm{N} \rightarrow$ Forced to zero
OVR $\rightarrow$ Divide overflow
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow$ Carry out equal to one
Z $\rightarrow$ Intermediate result is zero
If fractions are divided, the remainder must be shifted right two bits to obtain the correct fractional representation. The quotient is correct as is. The quotient is stored in the MQ register at the completion of the divide.

The unsigned division algorithm is summarized in Table 8.

## SN54AS895, SN74AS895 8-BIT MEMORY ADDRESS GENERATORS

TABLE 8. UNSIGNED DIVISION ALGORITHM

| OP <br> CODE | MNEMONIC | CLOCK <br> CYCLES | INPUT <br> S PORT | INPUT <br> R PORT | OUTPUT <br> F PORT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| E4 | LOADMQ | 1 | Dividend (LSH) | - | Dividend (LSH) |
| BO | UDIVIS | 1 | Dividend (MSH) | Divisor | Remainder (N) |
| CO | UDIVI | $8 \mathrm{~N}-1^{\dagger}$ | Remainder (N) | Divisor | Remainder (N) |
| FO | UDIVIT | 1 | Remainder (N) | Divisor | Remainder (Unfixed) |
| 40 | DIVRF | 1 | Remainder (Unfixed) | Divisor | Remainder |

${ }^{\dagger} N=$ Number of cascaded packages.
group 5 instructions
Hex code $F$ of Group 1 instructions is used to access Group 5 instructions. Group 5 instructions are summarized in Table 9.

TABLE 9. GROUP 5 INSTRUCTIONS

| INSTRUCTION BITS (I7-IO) <br> OP CODE (HEX) | MNEMONIC | FUNCTION |
| :---: | :---: | :--- |
| OF | CLR | Clear |
| $1 F$ | CLR | Clear |
| $2 F$ | CLR | Clear |
| $3 F$ | CLR | Clear |
| $4 F$ | CLR | Clear |
| $5 F$ | CLR | Clear |
| $6 F$ | CLR | Clear |
| $7 F$ | BCDBIN | BCD to Binary |
| $8 F$ | EX3BC | Excess-3 Byte Correction |
| $9 F$ | EX3C | Excess-3 Word Correction |
| AF | SDIVO | Signed Divide Overflow Check |
| BF | CLR | Clear |
| CF | CLR | Clear |
| DF | BINEX3 | Binary to Excess-3 |
| EF | CLR | Clear |
| FF | NOP | No Operation |

## clear instructions (CLR)

There are 11 clear instructions listed in Table 9. The instructions force the ALU output to be zero and the BCD flip-flops to be cleared. The status set by the clear instruction is as follows:

$$
\begin{array}{ll}
\mathrm{N} & \rightarrow \\
\text { None (force to zero) } \\
\text { OVR } & \rightarrow \\
\text { None (force to zero) } \\
\mathrm{C}_{\mathrm{n}}+8 & \rightarrow \\
\mathrm{Z} & \rightarrow \text { None (force to zero) } \\
\mathrm{Z} & \text { Active (one) }
\end{array}
$$

no operation instruction (NOP): $17-10=$ FF16
This instruction is identical to the clear instructions except that the BCD flip-flops retain their old value.

## SN54AS895, SN74AS895 <br> 8-BIT MEMORY ADDRESS GENERATORS

excess-3 correction instructions (EX3BC, EX3C)
Two excess-3 correction instructions are available:

1. Excess -3 byte correction ( EX 3 BC ): $17-10=8 \mathrm{~F}_{16}$
2. Excess-3 word correction (EX3C): $17-10=9 F_{16}$

One instruction supports the byte mode and the other supports the word mode. These instructions correct the excess- 3 additions (subtractions) in either the byte or word mode. For correct excess- 3 arithmetic, this instruction must follow each add/subtract. The operand must be on the $S$ port.
NOTE: The previous arithmetic overflow should be ignored.
The status of the EX3C instruction is as follows:
$N \quad \rightarrow \quad$ MSB of result
OVR $\rightarrow$ Signed overflow
$C_{n}+8 \rightarrow$ Carry out equal one
$Z \quad \rightarrow \quad$ None (force to one)
The status of the EX3BC instruction is as follows:
$\mathrm{N} \quad \rightarrow \quad$ None (force to zero)
OVR $\rightarrow$ Byte signed overflow
$\mathrm{C}_{\mathrm{n}+8} \rightarrow$ Carry out equal one
$\mathrm{Z} \rightarrow \quad$ None (force to one)
radix conversions
Conversions between decimal and binary number representations are performed with the aid of two special instructions: BINEX3 and BCDBIN. (Figure 10)
$B C D$ to binary instructions (BCDBIN): $17-10=7 F_{16}$
This instruction (Figure 11) allows the user to convert an N -digit BCD number to a 4 N -bit binary number in $4(N-1)$ plus 8 clocks. This function sums the $R$ bus, the $S$ bus, and the $C_{n}$ bit, performs an arithmetic left shift on the ALU result, and simultaneously circular shifts the MQ left. The status set by the BCD to binary instruction is as follows:
$N \quad \rightarrow \quad$ MSB of result
OVR $\rightarrow$ Signed arithmetic overflow ${ }^{\dagger}$
$\mathrm{C}_{\mathrm{n}}+8 \rightarrow$ Carry out equal one
$\mathrm{Z} \rightarrow$ Result equal zero
${ }^{\dagger}$ Overflow may be the result of an ALU operation or the arithmetic left shift operation.

The following code illustrates the $B C D$ to binary conversion technique.
Let ACC be an accumulator register
Let NUM be the register which contains the BCD number
Let MSK be a mask register

| M1: | LOADMQ NUM | ; LOAD MO WITH BCD NUMBER |
| :---: | :---: | :---: |
| M2: | SUB ACC, ACC, SLCMO | ; CLEAR ACC AND ALIGN MQ |
| M3: | SUB, MSK, MSK, SLCMO | ; CLEAR MSK AND ALIGN MQ |
| M4: | SLCMO | ; ALIGN |
| M5: | SLCMQ | ; ALIGN |
| M6: | ADDI ACC, MSK, 1510 | ; $\mathrm{MSK}=1510$ |
|  |  | ; REPEAT L1 THRU L4 <br> ; $\mathrm{N}-1$ TIMES ( $\mathrm{N}=$ number of <br> ; BCD digits) |
| L1: | AND MQ, MSK, R1, SLCMQ | ; EXTRACT ONE DIGIT <br> ; ALIGN MQ |
| L2: | ADD, ACC, R1, R1, SLCMQ | $\begin{aligned} & \text {; ACC + DIGIT } \\ & \text {; IS STORED IN R1 } \\ & \text {; ALIGN MQ } \end{aligned}$ |
| L3: | BCDBIN, R1, R1, ACC | $; 4 \times(\mathrm{ACC}+\mathrm{DIGIT})$ <br> ; IS STORED IN ACC ; ALIGN MQ |
| L4: | BCDBIN, ACC, R1, ACC | $; 10 \times($ ACC + DIGIT $)$ ; IS STORED IN ACC ; ALIGN MQ |
| M7: | AND MQ, MSK, R1 | ; FETCH LAST DIGIT |
| M8: | $\mathrm{ACC}+\mathrm{R} 1 \rightarrow \mathrm{ACC}$ | ; ADD IN LAST DIGIT |

The previous code generates a binary number by executing the standard conversion formula for a BCD number (shown for 32 bits).

$$
A B C D=[(A \times 10+B) \times 10+C] \times 10+D
$$

Notice that the conversion begins with the most significant BCD digit and that the addition is performed in radix 2 .
binary to excess-3 instructions (BINEX3): $17-10=$ DF16
This instruction (Figure 12) allows the user to convert an N -bit binary number to an $\mathrm{N} / 4$-bit excess- 3 number representation in $2 N+3$ clocks. The data on the $R$ and $S$ ports are summed with the MSB of the MQ register. The MQ register is simultaneously shifted left circularly. The status set by the binary to excess- 3 instruction is as follows:

$$
\begin{array}{lll}
\mathrm{N} & \rightarrow & \text { MSB of result } \\
\text { OVR } & \rightarrow & \text { Signed arithmetic overflow } \\
\mathrm{C}_{n}+8 & \rightarrow & \text { Carry out equal one } \\
\mathrm{Z} & \rightarrow & \text { Result equal zero }
\end{array}
$$



The following illustrates the binary to excess-3 conversion technique.
Let NUM be a register containing an unsigned binary number
Let ACC be an accumulator

| M1: | LOADMO NUM | ; LOAD MQ WITH BINARY <br> ; NUMBER |
| :---: | :---: | :---: |
| M2: | CLEAR ACC | CLEAR ACC |
| M3: | SET1 ACC H/33/ | ; ACC $\rightarrow$ HEX/3333 . . |
| L1: | BINEX3 ACC, ACC, ACC | ; DOUBLE ACC AND ADD IN <br> ; MSB OF MQ <br> ; ALIGN MQ |
| L2: | EX3C ACC, ACC | ; EXCESS 3 CORRECT REPEAT L1 AND L2 N-1 TIMES |

The previous code generates an excess-3 number by executing the standard conversion formula for a binary number.

$$
a_{n} 2^{n}+a_{n-1} 2^{n-1}+a_{n}-2^{2 n-2}+\ldots a_{0} 2^{0}=\left[\left(2 a_{n}+a_{n}-1\right) 2+a_{n}-2\right] 2+\ldots a_{0}
$$

Notice that the conversion begins with the most significant binary bit and that the addition is performed in radix-10 (excess-3).

## decimal arithmetic

Decimal numbers are represented in excess-3 code. Excess -3 code numbers may be generated by adding three to each digit of a Binary Coded Decimal (BCD) number. The hardware necessary to implement excess-3 arithmetic is only slightly different from binary arithmetic. Carries from one digit to another during addition in BCD occur when the sum of the two digits plus the carry-in is greater than or equal to ten. If both numbers are excess-3, the sum will be excess-6, which will produce the proper carries. Therefore, every addition or subtraction operation may use the binary adder. To convert the result from excess-6 to excess-3, one must consider two cases resulting from a BCD digit add: (1) where a carry-out is produced, and (2) where a carry-out is not produced. If a carry-out is not produced, three must be subtracted from the resulting digit. If a carry is produced, the digit is correct as a BCD number. For example, if BCD 5 is added to BCD 6, the excess-3 result would be $8+9=1$ (with a carry). A carry rolls the number through the illegal BCD representations into a correct BCD representation. Binary 3 must be added to digit positions that produce a carry-out to correct the result to an excess- 3 representation. Every addition and subtraction instruction stores the carry generated from each 4-bit digit location for use by the excess-3 correction functions. These correction instructions (word or byte) must be executed in the clock cycle immediately after the addition or subtraction operation.

Signed numbers may be represented in ten's complement form by complementing the excess-3 number. As an example, add the decimal number -423 to the decimal number 24 , which will be represented by 8AA and 357 in excess-3, respectively.

| 8AA |  |
| ---: | :--- |
| 357 |  |
| C01 | Sum |
| 011 | Carry |
| 934 | Excess-3 correct |
| $-6 C C$ | Complement |
| -399 | Excess-3 to decimal |

Complements of excess-3 numbers may be generated by subtracting the excess- 3 number from an excess- 3 zero followed by an excess-3 correct.

## excess-3 to USASCII conversion

Input/output devices or files represent numbers differently than high-speed central processing units. I/O devices handle all alphanumeric data similarly. CPUs handle more numeric data than alphabetic data and store numeric data in packed form to minimize calculation throughout and reduce memory requirements. To represent the cost of a shirt that was $\$ 10.96$, the I/O device would handle the six USASCII characters "'\$", " 1 ","' $0^{\prime \prime}$ "'."'," 9 "," 6 "', which would require 6 bytes of storage. In packed BCD, this number could be stored as 1096 in two bytes of data. The 'AS895 may be programmed to perform data format conversions such as converting excess-3 BCD to USASCII.

The code below converts a packed word of excess-3 BCD to two unpacked words of USASCII code. Instruction "MAIN1" reads the input word from memory into Register 0 (RO). For illustrative purposes, suppose this data was 43C9, which represents the $\$ 10.96$ shirt in excess- 3 code. "MAIN2" and "MAIN3" generate a constant of 2D2D 16 , which is an offset constant to convert excess- 3 numbers to USASCII. "MAIN4' copies RO into R2 to set up the subroutine parameters and calls the subroutine "UNPACK", UNPACK2" strips off the upper byte leaving OOC9 in R2. "UNPACK2" and "UNPACK3" together shift the contents of R2 one character position and places the result OC90 into R3. "UNPACK4" performs a logical OR operation to produce OCD9 in register 2. "UNPACK5" clears the most significant nibble in each byte to produce OCO9 in R2. "UNPACK6" adds the constant 2D2D16 to R2 to produce 3936 the USASCII representation of the numerals 96 and returns program control to "MAIN5". "MAIN5" through "MAIN9" align the two remaining characters and call UNPACK and the process repeats. Finally the USASCII representation of 1096 is stored into memory. (Note that no attempt was made to pack the " $\$$ " or "." characters.)

Unpacking Excess-3 to USASCII:

| MAIN1: | READ, RFA(0) |
| :--- | :--- |
| MAIN2: | XOR, RFA(4), RFB(4), RFC(4) |
| MAIN3: | SET1, RFB(40), RDC(2), RFA(D), |
| MAIN4: | MSH, LSH |
|  | MOVE, RFA(0), RFC(2), JSR(UNPACK) |
| MAIN5: | MOVE, RFA(2), RFC(1) |
| MAIN6: | ADDRS, RFB(0), RFA(0), RFC(0), SLC |
| MAIN7: | ADDRS, RFB(0), RFA(0), RFC(0), SLC |
| MAIN8: | ADDRS, RFB(0), RFA(0), RFC(0), SLC |
| MAIN9: | ADDRS, RFB(0), RFA(0), RFC(0), SLC |
| MAIN10: | JSR (UNPACK) |
| STORE, RFA(1) |  |
| MAIN11: | STORE, RFA(2) |
| UNPACK1: | SETO, RFB(2), RFC(F), MSH |
| UNPACK2: | ADDRS, RFB(2), RFA(2), RFC(3), SLC |
| UNPACK3: | ADDRS, RFB(3), RFA(3), RFC(3), SLC |
| UNPACK4: | OR, RFB(2), RFA(3), RFC(2) |
| UNPACK5: | SETO, RFB(2), RFC(F), RFA(0), LSH, MSH |
| UNPACK6: | ADDRS, RFB(2), RFB(4), RFC(2), RTS |

> READ IN PACKED EXCESS-3
> CLEAR R4
> GENERATE HEXADECIMAL
> 2D2D16
> COPY RFA(0) INTO RFA(2), PROCEDURE CALL TWO CHARACTERS IN R1
> RO SHIFTED 2
> RO SHIFTED 4
> RO SHIFTED 6
> RO SHIFTED 8

STORE USASCII, TWO
CHARACTERS IN R2
STORE USASCII
CLEAR MSH
SHIFT R2 TWO PLACES
SHIFT R3 TWO PLACES
; OR R3 TO R2
CLEAR MOST SIGNIFICANT 4
BITS IN EACH BYTE
ADD HEX 2D, RETURN

## SN54AS895, SN74AS895 8-BIT MEMORY ADDRESS GENERATORS

absolute maximum rating over operating free-air temperature range (unless otherwise noted)

```
Supply voltage, VCC17 V
```

Supply voltage, VCC2 ..... 3 V
Input voltage ..... 7 V
High-level voltage applied to 3-state outputs ..... 5.5 V
Operating case temperature range: SN54AS895 ..... $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Operating free-air temperature range: SN74AS895, SN74AS895-1 .....  $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range ..... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

## recommended operating conditions

|  |  |  | SN54AS895 |  |  | $\begin{gathered} \text { SN74AS895 } \\ \text { SN74AS895-1 } \end{gathered}$ |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}} 1$ | 1/O supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\mathrm{CC} 2}$ | STL internal logic supply voltage |  | 1.9 | 2 | 2.1 | 1.9 | 2 | 2.1 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | - 0.8 | V |
| ${ }^{\mathrm{O}} \mathrm{OH}$ | High-level output current |  |  |  | -1 |  |  | --2.6 | mA |
| ${ }^{1} \mathrm{OL}$ | Low-level output current | All output except $\overline{\mathrm{G}}$ and ZERO |  |  | 8 |  |  | 8 | mA |
|  |  | $\overline{\mathrm{G}}$ |  |  | 16 |  |  | 16 |  |
|  |  | ZERO |  |  | 48 |  |  | 48 |  |
| $\mathrm{T}_{\mathrm{C}}$ | Operating case temperature |  | -55 |  | 125 |  |  |  | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  |  |  |  | 0 |  | 70 |  |

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

| PARAMETER |  | TEST CONDITIONS | SN54AS895 |  | SN74AS895 <br> SN74AS895-1 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $\mathrm{V}_{\mathrm{IK}}$ |  |  | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, \quad \mathrm{I}=-18 \mathrm{~mA}$ |  | -1.2 |  |  | -1.2 | V |
| V OH | All outputs except ZERO | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I} \mathrm{OH}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ | 2.4 |  |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ |  |  | 2.4 |  |  |  |
| I | ZERO | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  | 0.1 |  |  | 0.1 | mA |
| VOL | All outputs except $\overline{\mathrm{G}}$ and ZERO | $\mathrm{V}_{\mathrm{CC1}}=4.5 \mathrm{~V}, \mathrm{I}^{\mathrm{OL}}=8 \mathrm{~mA}$ |  | 0.5 |  |  | 0.5 | V |
|  | $\overline{\mathrm{G}}$ | $\mathrm{V}_{\mathrm{CC1}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  | 0.5 |  |  | 0.5 |  |
|  | ZERO | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}, \mathrm{I}^{\mathrm{OL}}=48 \mathrm{~mA}$ |  | 0.5 |  |  | 0.5 |  |
| 1 | 1/O | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=5.5 \mathrm{~V}$ |  | 0.1 |  |  | 0.1 | mA |
|  | All others | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \mathrm{~V}_{1}=7 \mathrm{~V}$ |  | 0.1 |  |  | 0.1 |  |
| ${ }_{1 / 1 H^{\ddagger}}$ |  | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \mathrm{~V}_{1}=2.7 \mathrm{~V}$ |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| $1 / L^{\ddagger}$ |  | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \mathrm{~V}_{1}=0.5 \mathrm{~V}$ |  | -0.4 |  |  | -0.4 | mA |
| $10^{8}$ |  | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 | -112 | -30 |  | -112 | mA |
| ${ }^{\text {ICC1 }}$ |  | $\mathrm{VCC1}=5.5 \mathrm{~V}$ |  | 150 |  |  | 130 | mA |
| ICC2 |  | $\mathrm{VCC2}=2.1 \mathrm{~V}$ |  | 410 |  |  | 390 | mA |

[^57]SN54AS895 maximum switching characteristics, $\mathrm{VCC}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T} \mathrm{C}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) |  |  |  |  |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Y | $\mathrm{C}_{\mathrm{n}+8}$ | $\overline{\mathbf{G}}, \overline{\mathbf{P}}$ | $z^{\dagger}$ | N | OVR | DA | DB | $\overline{\mathrm{OLO}}$ | $\overline{\text { SIO }}$ |  |
| $t_{\text {pd }}$ | $\begin{aligned} & \mathrm{A} 3-\mathrm{AO} \\ & \mathrm{~B} 3-\mathrm{BO} \end{aligned}$ | 62 | 42 | 48 | 69 | 62 | 60 | 18 | - | 65 | 66 | ns |
|  | $\begin{aligned} & \text { DA7-DAO, } \\ & \text { DB7-DB0 } \end{aligned}$ | 47 | 28 | 28 | 58 | 50 | 42 | - | - | 50 | 50 |  |
|  | $\mathrm{C}_{\mathrm{n}}$ | 25 | 14 | - | 32 | 24 | 18 | - | - | 32 | 32 |  |
|  | $\overline{\mathrm{EA}}$ | 54 | 32 | 35 | 62 | 52 | 52 | - | - | 58 | 58 |  |
|  | $\overline{\mathrm{E}} \overline{\mathrm{B}}$ | 54 | 32 | 35 | 62 | 52 | 52 | - | - | 58 | 58 |  |
|  | 17-10 | 58 | 32 | 32 | 62 | 52 | 41 | - | - | 58 | 58 |  |
|  | $\overline{\mathrm{OEB}}$ | - | - | - | - | - | - | - | 14 | - | - |  |
|  | $\overline{\mathrm{OEY}}$ | 14 | - | - | - | - | - | - | - | - | - |  |
|  | $\overline{\mathrm{Q} I \mathrm{O}}(\mathrm{n})$ <br> Shift | 15 | $\div$ | - | 24 | - | - | - | - | - | - |  |
|  | $\overline{\mathrm{SIO}}(\mathrm{n})$ <br> Shift | 15 | - | - | 24. | 22 | - | - | - | - | - |  |
|  | CK | 68 | 60 | 56 | 62 | 50 | 68 | 38 | 30 | 70 | 70 |  |
|  | $\overline{\text { OEA }}$ | - | - | - | - | - | - | 14 | - | - | - - |  |
|  | SSF ${ }^{\ddagger}$ | - | - | - | - | - | 14 | - | - | - | - |  |

${ }^{\dagger}$ Load resistor R1 $=100 \Omega$.
$\ddagger$ For byte instructions only.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

SN74AS895 maximum switching characteristics, $\mathrm{VCC}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T} A=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) |  |  |  |  |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Y | $\mathrm{C}_{n+8}$ | $\overline{\mathbf{G}}, \overline{\mathbf{P}}$ | $z^{\dagger}$ | N | OVR | DA | DB | $\overline{\mathbf{Q 1 O}}$ | $\overline{\text { SIO }}$ |  |
| $t_{p d}$ | $\begin{aligned} & \mathrm{A} 3-\mathrm{AO} \\ & \mathrm{~B} 3-\mathrm{BO} \end{aligned}$ | 54 | 36 | 42 | 60 | 52 | 50 | - | - | 58 | 58 | ns |
|  | $\begin{aligned} & \text { DA7-DAO, } \\ & \text { DB7-DBO } \end{aligned}$ | 44 | 26 | 26 | 52 | 46 | 38 | - | - | 44 | 44 |  |
|  | $\mathrm{C}_{\mathrm{n}}$ | 25 | 9 | - | 32 | 24 | 18 | - | - | 31 | 31 |  |
|  | $\overline{E A}$ | 49 | 29 | 29 | 58 | 49 | 47 | - | - | 54 | 54 |  |
|  | $\overline{E B}$ | 49 | 29 | 29 | 58 | 49 | 47 | - | - | 54 | 54 |  |
|  | 17-10 | 55 | 30 | 30 | 60 | 49 | 39 | - | - | 54 | 54 |  |
|  | $\overline{\mathrm{OEB}}$ | - | - | - | - | - | - | - | 12 | - | - |  |
|  | $\overline{\mathrm{OEY}}$ | 12 | - | - | - | - | - | - | - | - | - |  |
|  | $\overline{\mathrm{QIO}}(\mathrm{n})$ <br> Shift | 15 | - | - | 24 | - | - | - | - | - | - |  |
|  | $\overline{\mathrm{SIO}}(\mathrm{n})$ <br> Shift | 15 | - | - | 24 | 19 | - | - | - | - | - |  |
|  | CK | 58 | 55 | 52 | 61 | 52 | 62 | 35 | 25 | 60 | 60 |  |
|  | $\overline{\text { OEA }}$ | - | - | - | - | - | - | 12 | - | - | - |  |
|  | SSF ${ }^{\ddagger}$ | - | - | - | - | - | 12 | - | - | - | - |  |

[^58]$\ddagger$ For byte instructions only.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

SN74AS895-1 maximum switching characteristics, $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) |  |  |  |  |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Y | $\mathrm{C}_{\mathrm{n}+8}$ | $\overline{\mathbf{G}}, \overline{\mathbf{P}}$ | $z^{\dagger}$ | N | OVR | DA | DB | $\overline{\mathbf{0 1 O}}$ | $\overline{\text { SIO }}$ |  |
| $t_{\text {pd }}$ | $\begin{aligned} & \mathrm{A} 3-\mathrm{AO} \\ & \mathrm{~B} 3-\mathrm{BO} \end{aligned}$ | 44 | 30 | 36 | 50 | 44 | 44 | 17 | - | 48 | 48 | ns |
|  | $\begin{aligned} & \text { DA7-DAO, } \\ & \text { DB7-DB0 } \end{aligned}$ | 36 | 24 | 24 | 46 | 41 | 32 | - | - | 40 | 40 |  |
|  | $\mathrm{C}_{\mathrm{n}}$ | 22 | 8 | - | 27 | 21 | 16 | - | - | 25 | 25 |  |
|  | $\overline{E A}$ | 40 | 25 | 25 | 49 | 41 | 41 | - | - | 44 | 44 |  |
|  | $\overline{\mathrm{EB}}$ | 40 | 25 | 25 | 49 | 41 | 41 | - | - | 44 | 44 |  |
|  | 17-10 | 46 | 27 | 27 | 50 | 42 | 35 | - | - | 45 | 45 |  |
|  | $\overline{\text { OEB }}$ | - | - | - | - | - | - | - | 12 | - | - |  |
|  | $\overline{\mathrm{OEY}}$ | 12 | - | - | - | - | - | - | - | - | - |  |
|  | $\overline{\overline{\mathrm{Q} O}}(\mathrm{n})$ <br> Shift | 14 | - | - | 20 | - | - | - | - | - | - |  |
|  | $\overline{\mathrm{SIO}}(\mathrm{n})$ <br> Shift | 14 | - | - | 20 | 18 | - | - | - | - | - |  |
|  | CK | 50 | 46 | 46 | 50 | 50 | 50 | 30 | 22 | 50 | 50 |  |
|  | $\overline{\text { OEA }}$ | - | - | - | - | - | - | 12 | - | - | - |  |
|  | SSF ${ }^{\ddagger}$ | - | - | - | - | - | 12 | - | - | - | - |  |

${ }^{\dagger}$ Load resistor R1 $=100 \Omega$.
$\ddagger$ For byte instructions only.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.
register file write setup and hold times

| PARAMETER |  | SN54AS895 |  | SN74AS895 |  | SN74AS895-1 | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN |  |
| ${ }_{\text {t }}^{\text {su }}$ | C3-C0 | 8 |  | 7 |  | 6 | ns |
|  | DB§ | 14 |  | 12 |  | 11 |  |
|  | 17-14 | 16 |  | 14 |  | 13 |  |
|  | 13-10 | 24 |  | 22 |  | 21 |  |
|  | $\overline{\mathrm{OEY}}$ | 4 |  | 3 |  | 3 |  |
|  | Y7-Y0 | 2 |  | 2 |  | 2 |  |
|  | $\overline{\text { WE }}$ | 8 |  | 6 |  | 6 |  |
|  | $\overline{\mathrm{QIO}}(\mathrm{n}), \overline{\mathrm{SIO}}(\mathrm{n})$ | 6 |  | 5 |  | 5 |  |
|  | SELY | 8 |  | 6 |  | 6 |  |
| $t_{\text {h }}$ | C3-C0 | 0 |  | 0 |  | 0 | ns |
|  | DB§ | 0 |  | 0 |  | 0 |  |
|  | 17-14 | 0 |  | 0 |  | 0 |  |
|  | $13-10$ | 0 |  | 0 |  | 0 |  |
|  | $\overline{\mathrm{OEY}}$ | 6 |  | 5 |  | 5 |  |
|  | Y7-Y0 | 10 |  | 10 |  | 10 |  |
|  | $\overline{\text { WE }}$ | 3 |  | 2 |  | 2 |  |
|  | $\overline{\mathrm{OLO}}(\mathrm{n}), \overline{\mathrm{SIO}}(\mathrm{n})$ | 0 |  | 0 |  | 0 |  |
|  | SELY | 8 |  | 6 |  | 6 |  |

§DB (during select instruction) through $Y$ port.

## SN54AS895, SN74AS895

## 8-BIT MEMORY ADDRESS GENERATORS

## special instruction switching characteristics

During various special instructions, the SSF pin is used to pass required information between the 'AS888 packages which make up a total system.
For instance, during the multiplication process, the LSB of the multiplier determines whether an ADD/SHIFT or SHIFT operation is performed. During multiplication, the SSF pin of the least significant package (LSP) becomes an output pin while all other packages become input pins.

Similarly, during normalization, the required operation depends on whether the two data MSBs are the same or different. Therefore, during normalization the SSF pin of the most significant package (MSP) becomes an output pin while all other packages become input pins.

Tables 10,11 , and 12 list the instructions which force the SSF pin during their execution. The propagation delay from various inputs is also shown. The parameter which limits normal system performance is indicated by a dagger.
tAble 10. SN54AS895 SSF PIN DELAYS AND SETUP TIMES

| MNEMONIC | $\begin{gathered} \text { HEX } \\ \text { CODE } \end{gathered}$ | SSF SOURCE |  | INPUT $\rightarrow$ SSF (ns) |  |  |  | SSF SETUP <br> TIME (ns) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | LSP | MSP | $\mathrm{C}_{\mathrm{n}}$ | $1(\mathrm{n})$ | CK | $\mathrm{B}_{(\mathrm{n})}$ |  |
| SNORM | 20 |  | X | - | $29^{\dagger}$ | 46 | - | 20 |
| DNORM | 30 |  | x | - | 29 | 55 | $40^{\dagger}$ | 20 |
| DIVRF | 40 |  | X | - | $29^{\dagger}$ | 46 | - | 20 |
| SDIVGF | 50 |  | x | - | $26^{\dagger}$ | - | - | 18 |
| SMULI | 60 | x |  | - | $26^{\dagger}$ | 43 | - | 0 |
| SDIVIN | 80 |  | x | - | 48 | 64 | $44^{\dagger}$ | 0 |
| SDIVIS | 90 |  | x | $26^{\dagger}$ | 51 | 64 | 55 | 0 |
| SDIVI | AO |  | X | $26^{+}$ | 51 | 64 | 55 | 0 |
| UDIVIS | Bо |  | x | $18^{\dagger}$ | 45 | 64 | 46 | 0 |
| UDIVI | CO |  | x | $18^{\dagger}$ | 50 | 54 | 40 | 0 |
| UMULI | D0 | $x$ |  | - | $25^{\text {t* }}$ | 48 | - | 0 |
| SDIVIT | EO |  | x | $26^{\dagger}$ | 50 | 56 | 54 | 0 |
| ABS | 48 |  | $x$ | - | 34 | 62 | $39^{\dagger}$ | 20 |
| SMTC | 58 |  | x | - | 29 | 58 | $39^{\dagger}$ | 20 |
| BINEX3 | DF |  | x | - | $29^{\dagger}$ | 58 | - | 18 |
| LOADMO (Arith) |  | x |  | $23^{\dagger}$ | 34 | 62 | 40 | 0 |
| LOADMO (Log) |  | x |  | - | 33 | 62 | $40^{\dagger}$ | 0 |
| BADD | 88 |  |  | $18^{\dagger}$ | 58 | 62 | 49 | - |
| BSUBS | 98 |  |  | $18^{\dagger}$ | 58 | 62 | 49 | - |
| BSUBR | A8 |  |  | $18^{\dagger}$ | 58 | 71 | 49 | - |
| BINCS | B8 |  |  | $18^{\dagger}$ | 58 | 60 | 49 | - |
| BINCNS | C8 |  |  | $18^{\dagger}$ | 58 | 71. | 49 | - |
| BXOR | D8 |  |  | - | 58 | - | - | - |
| BAND | E8 |  |  | - | 58 | - | -- | - |
| BOR | F8 |  |  | - | 58 | - | - | - |
| EX3BC | 8F |  |  | - | 58 | 46 | $49^{\dagger}$ | - |

[^59]TABLE 11. SN74AS895 SSF PIN DELAYS AND SETUP TIMES

| MNEMONIC | $\begin{aligned} & \text { HEX } \\ & \text { CODE } \end{aligned}$ | SSF SOURCE |  | INPUT $\rightarrow$ SSF (ns) |  |  |  | SSF SETUP <br> TIME (ns) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | LSP | MSP | $\mathrm{C}_{\mathrm{n}}$ | I n ) | CK | $\mathrm{B}_{(\mathrm{n})}$ |  |
| SNORM | 20 |  | X | - | $26^{\dagger}$ | 40 | - | 17 |
| DNORM | 30 |  | x | - | 26 | 52 | $37{ }^{\dagger}$ | 17 |
| DIVRF | 40 |  | x | - | $26^{\dagger}$ | 40 | - | 17 |
| SDIVQF | 50 |  | x | - | $25^{\dagger}$ | - | - | 17 |
| SMULI | 60 | X |  | - | $25^{\dagger}$ | 40 | - | 0 |
| SDIVIN | 80 |  | x | - | 38 | 60 | $40^{\dagger}$ | 0 |
| SDIVIS | 90 |  | x | $24^{\dagger}$ | 48 | 60 | 52 | 0 |
| SDIVI | AO |  | x | $24^{\dagger}$ | 48 | 60 | 52 | 0 |
| UDIVIS | Bо |  | x | $17^{\dagger}$ | 43 | 60 | 45 | 0 |
| UDIVI | co |  | X | $17^{\dagger}$ | 44 | 52 | 37 | 0 |
| UMULI | DO | x |  | - | $26^{\dagger}$ | 40 | - | 0 |
| SDIVIT | EO |  | X | $25^{\dagger}$ | 46 | 52 | 49 | 0 |
| ABS | 48 |  | $x$ | - | 32 | 60 | 38 | 17 |
| SMTC | 58 |  | X | - | 26 | 52 | $38{ }^{\dagger}$ | 17 |
| BINEX3 | DF |  | x | - | $26^{\dagger}$ | 40 | - | 17 |
| LOADMQ (Arith) |  | x |  | $22^{\dagger}$ | 32 | 50 | 38 | 0 |
| LOADMO (Log) |  | x |  | - | 32 | 50 | $38^{\dagger}$ | 0 |
| BADD | 88 |  |  | $17^{\dagger}$ | 52 | 55 | 46 | - |
| BSUBS | 98 |  |  | $17^{\dagger}$ | 52 | 55 | 46 | - |
| BSUBR | A8 |  |  | $17^{\dagger}$ | 52 | 62 | 46 | - |
| BINCS | B8 |  |  | $17^{\dagger}$ | 52 | 55 | 46 | - |
| BINCNS | C8 | SIGN |  | $17^{\dagger}$ | 52 | 62 | 46 | - |
| BXOR | D8 |  |  | - | 52 | - | - | - |
| BAND | E8 |  |  | - | 52 | - | - | - |
| BOR | F8 |  |  | - | 52 | - | - | - |
| EX3BC | 8F |  |  | - | 45 | 45 | $46^{+}$ | - |

[^60]TABLE 12. SN74AS895-1 SSF PIN DELAYS AND SETUP TIMES

| MNEMONIC | $\begin{aligned} & \text { HEX } \\ & \text { CODE } \end{aligned}$ | SSF SOURCE |  | INPUT $\rightarrow$ SSF (ins) |  |  |  | SSF SETUP TIME (ns) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | LSP | MSP | $\mathrm{C}_{\mathrm{n}}$ | I(n) | CK | $B_{(n)}$ |  |
| SNORM | 20 |  | X | - | $23^{\dagger}$ | 28 | - | 14 |
| DNORM | 30 |  | $x$ | - | 23 | 40 | $34^{\dagger}$ | 14 |
| DIVRF | 40 |  | X | - | $23^{\dagger}$ | 27 | - | 14 |
| SDIVAF | 50 |  | X | - | $23^{\dagger}$ | - | - | 14 |
| SMULI | 60 | $x$ |  | - | $22^{\dagger}$ | 27 | - | 0 |
| SDIVIN | 80 |  | $x$ | - | 35 | 46 | $35^{\dagger}$ | 0 |
| SDIVIS | 90 |  | $x$ | $22^{\dagger}$ | 42 | 48 | 42 | 0 |
| SDIVI | AO |  | X | $22^{\dagger}$ | 42 | 46 | 42 | 0 |
| UDIVIS | BO |  | $x$ | $16^{\dagger}$ | 42 | 46 | 38 | 0 |
| UDIVI | CO |  | X | $16^{\dagger}$ | 36 | 46 | 34 | 0 |
| UMULI | DO | $x$ |  | - | $22^{\dagger}$ | 27 | - | 0 |
| SDIVIT | EO |  | $x$ | $21^{\dagger}$ | 40 | 44 | 42 | 0 |
| ABS | 48 |  | $x$ | - | 28 | 46 | $30^{\dagger}$ | 14 |
| SMTC | 58 |  | $x$ | - | 24 | 44 | $30^{\dagger}$ | 14 |
| BINEX3 | DF |  | X | - | $23^{\dagger}$ | 27 | - | 14 |
| LOADMQ (Arith) |  | $x$ |  | $19^{\dagger}$ | 28 | 40 | 30 | 0 |
| LOADMQ (Log) |  | X |  | - | 28 | 35 | $30^{+}$ | 0 |
| BADD | 88 |  |  | $16^{\dagger}$ | 42 | 42 | 40 | - |
| BSUBS | 98 |  |  | $16^{\dagger}$ | 42 | 40 | 40 | - |
| BSUBR | A8 |  |  | $16^{\dagger}$ | 42 | 50 | 40 | - |
| BINCS | B8 |  |  | $16^{\dagger}$ | 42 | 46 | 40 | - |
| BINCNS | C8 |  |  | $16^{\dagger}$ | 42 | 54 | 42 | - |
| BXOR | D8 |  |  | - | 42 | - | - | - |
| BAND | E8 |  |  | - | 42 | - | - | - |
| BOR | F8 |  |  | - | 42 | - | - | - |
| EX3BC | 8F |  |  | - | 42 | 42 | $42^{\dagger}$ | - |

[^61]
## SN54AS897A, SN74AS897A 16-BIT PARALLEL/SERIAL BARREL SHIFTERS

- High-Speed "Flash' Shift Operations
- Expandable to 32 Bits
- Hexadecimal and Binary Normalization with Leading Zero Detection
- Bit Reversal
- Merge Capabilities
- Texas Instruments Quality and Reliability


## description

The SN54AS897A and SN74AS897A are multipurpose 16-bit barrel shifters in a 68-pin ceramic pin-grid-array package. The devices are capable of several different types of shift operations, as well as other more specialized functions such as hexadecimal and binary normalization, bit replacement, and leading-zero detection.

The unique feature of all barrel shifters is how the shift function is implemented. In conventional shift registers, shift operations are controlled by the number of input clock pulses applied. With barrel shifters, the desired number of positions to be shifted is determined by an input decoder. This form of implementation does not require an input clock and results in a shift operation that is restricted only by internal propagation delays. This delay is the same regardless of the number of positions to be shifted. The result is a high-speed "flash' type of shift.

The 'AS897A offers the system designer a much broader range of capabilities than previous conventional shift registers. Normalization of data in floating-point computations, bit-reversal when generating Fast Fourier Transform (FFT) addresses, and insertion of stop/start bits in asynchronous data communications are just a few of the applications that are possible with this device.

The 'AS897A can be operated as an 'AS897 by connecting the HEX/ $\overline{\mathrm{BIN}}$ pin (J1) to ground.

## SN54AS897A, SN74AS897A <br> GB PIN-GRID ARRAY PACKAGE <br> (TOP VIEW)



PIN ASSIGNMENT TABLE

| $\begin{aligned} & \text { PIN } \\ & \text { NO. } \end{aligned}$ | $\begin{gathered} \text { PIN } \\ \text { NAME } \end{gathered}$ | $\begin{array}{\|l\|} \hline \text { PIN } \\ \text { NO. } \\ \hline \end{array}$ | $\begin{gathered} \text { PIN } \\ \text { NAME } \end{gathered}$ |
| :---: | :---: | :---: | :---: |
| A2 | ZN1 | F10 | GND |
| A3 | ZN2 | F11 | Y9 |
| A4 | ZN3 | G1 | D4 |
| A5 | GND | G2 | GND |
| A6 | $\overline{\text { NORM }}$ | G10 | Y11 |
| A7 | ZL | G11 | Y8 |
| A8 | GND | H1 | NC |
| A9 | 16B/32B | H2 | D5 |
| A10 | OP | H10 | GND |
| B1 | D14 | H11 | Y7 |
| B2 | 013 | J1 | HEX/ $\overline{\text { BIN }}$ |
| B3 | D15 | J2 | D3 |
| B4 | ZNO | J10 | GND |
| B5 | $\mathrm{V}_{\mathrm{CC} 2}$ | J11 | GND |
| B6 | ZN4 | K1 | D2 |
| B7 | IP | K2 | D1 |
| B8 | $V_{\text {CC1 }}$ | K3 | $\mathrm{V}_{\mathrm{CC} 1}$ |
| B9 | GND | K4 | M1 |
| B10 | S | K5 | GND |
| B11 | Y15 | K6 | CLK |
| C1 | D12 | K7 | GND |
| C2 | D9 | K8 | $\mathrm{V}_{\mathrm{CC} 2}$ |
| C10 | Y13 | K9 | Y6 |
| C11 | Y12 | K10 | Y4 |
| D1 | D11 | K11 | Y5 |
| D2 | D8 | L2 | DO |
| D10 | NC | L3 | M2 |
| D11 | GND | L4 | MO |
| E1 | D10 | L5 | TP |
| E2 | D7 | L6 | $\overline{\text { OEY }}$ |
| E10 | Y14 | L7 | YO |
| E11 | Y10 | L8 | Y 1 |
| F1 | GND | L.9 | Y2 |
| F2 | D6 | L10 | Y3 |

NC-No internal connection
Chip Carrier information available from factory upon request.
logic symbol ${ }^{\dagger}$

${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984.

## SN54AS897A, SN74AS897A 16-BIT PARALLEL/SERIAL BARREL SHIFTERS

functional block diagram (positive logic)


SN54AS897A, SN74AS897A
16-BIT PARALLEL/SERIAL BARREL SHIFTERS

| PIN |  | I/O | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | NO. |  |  |
| 16B/32B | A9 | 1 | When high, 16 -bit operation is selected. When low, 32-bit operation is selected. |
| CLK | K6 | 1. | Clock input. Loads the internal register on the low-to-high transition. In 16 -bit circular mode, acts as clock for the 16 -bit/ 14 -bit counter. |
| D0 | L2 | 1 |  |
| D1 | K2 | 1 |  |
| D2 | K1 | 1 |  |
| D3 | J2 | 1 |  |
| D4 | G1 | 1 |  |
| D5 | H2 | 1 |  |
| D6 | F2 | 1 |  |
| D7 | E2 | 1 | Input data bits 0 through 15 |
| D8 | D2 | 1 | Input data bits 0 through 15 |
| D9 | C2 | 1 |  |
| D10 | E1 | 1 |  |
| D11 | D1 | 1 |  |
| D12 | C1 | 1 |  |
| D13 | B2 | 1 |  |
| D14 | B1 | 1 |  |
| D15 | B3 | 1 |  |
| GND | A5 |  |  |
| GND | A8 |  |  |
| GND | B9 |  |  |
| GND | D11 |  |  |
| GND | F1 |  |  |
| GND | F10 |  |  |
| GND | G2 |  | Ground (All ground pins should be used) |
| GND | H10 |  |  |
| GND | J10 |  |  |
| GND | J11 |  |  |
| GND | K5 |  |  |
| GND | K7 |  |  |
| HEX//]IN | J1 | 1 | Controls mode of operation for leading zero detector. When low, causes the number of leading binary zeros to be counted. When high, causes the number of binary zeros in leading hexadecimal groups (binary 0000s) to be counted. When tied to ground, causes the 'AS897A to operate as an 'AS897. |
| IP | B7 | 1 | In the 16 -bit mode, controls the bit-reversal option. A high logic level causes data selected by OP to be bit-reversed before it is passed to the shifter. When IP is low, data is passed unaltered. <br> In the 32-bit mode, defines the data input position. When IP is high, D15-DO are in the most significant input position. When IP is low, D15-DO are in the least significant position. |
| MO | L4 | 1 | Shift instruction control. Determine the type of shift operation to be performed. See Table 1 for further |
| M1 | K4 | 1 | information. |
| M2 | L3 | 1 |  |
| $\mathrm{NC}$ NC | $\begin{aligned} & \text { D10 } \\ & \text { H1 } \end{aligned}$ |  | No internal connection |
| $\overline{\text { NORM }}$ | A6 | 1 | A three-state control input for ZN4-ZNO I/O ports used only in normalize instructions. When $\overline{\text { NORM }}$ is low, the number of leading zeros detected in the data present on D15-DO is output on ZN4-ZNO. When NORM is high, ZN4-ZNO act only as inputs. |

## SN54AS897A, SN74AS897A 16-BIT PARALLEL/SERIAL BARREL SHIFTERS

| PIN |  | I/O | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | NO. |  |  |
| $\overline{\text { OEY }}$ | L6 | 1 | Control input for the Y15-Y0 I/O ports. When $\overline{\mathrm{OEY}}$ is low, the Y outputs are enabled. |
| OP | A10 | I | In the 16 -bit mode, controls the source of input data. A logic high on this input selects data from the register/counter. A low selects data on the D15-D0 inputs. <br> In the 32-bit mode, defines the package output positions. When OP is high, Y15-Y0 are in the most significant output position. When OP is low, Y15-Y0 are in the least significant output position. |
| S | B10 | 1 | Specifies the logic level that will fill the bit position or positions vacated during all shift operations except 16 -bit circular. In the 16 -bit circular mode, when $S$ is high, the data latch operates as a 16 -bit binary counter. When $S$ is low, the register functions as a data latch. |
| $\overline{T P}$ | L5 | 1 | Functional testing input. When low, transforms the 16 -bit counter into four 4 -bit counters. During normal operation, $\overline{\text { TP }}$ must be maintained at a high logic level. |
| $\begin{aligned} & \mathrm{v}_{\mathrm{CC} 1} \\ & \mathrm{v}_{\mathrm{CC} 1} \end{aligned}$ | $\begin{aligned} & \mathrm{B} 8 \\ & \mathrm{~K} 3 \end{aligned}$ |  | 5 -volt supply for TTL-compatible I/O |
| $\begin{aligned} & \mathrm{v}_{\mathrm{CC} 2} \\ & \mathrm{v}_{\mathrm{CC} 2} \end{aligned}$ | $\begin{aligned} & \text { B5 } \\ & \text { K8 } \end{aligned}$ |  | 2 -volt supply for internal Schottky Transistor Logic (STL) |
| YO | L7 | 1/O |  |
| Y1 | L8 | I/O |  |
| Y2 | L9 | I/O |  |
| Y3 | L10 | 1/O |  |
| Y4 | K10 | 1/O |  |
| Y5 | K11 | 1/0 |  |
| Y6 | K9 | 1/0 |  |
| Y7 | H11 | I/O | Input/output bits 0-15. As an input, they load the data register. A an output, they present the shifted data. |
| Y8 | G11 | 1/0 |  |
| Y9 | F11 | 1/0 |  |
| Y10 | E11 | 1/O |  |
| Y11 | G10 | 1/O |  |
| Y12 | C11 | 1/0 |  |
| Y13 | C10 | I/O |  |
| Y14 | E10 | 1/0 |  |
| Y15 | B11 | 1/0 |  |
| ZL | A7 | I/O | An input/open-collector output used primarily in 32-bit applications. When the input at D15-D0 is zero, the ZL output is high. The ZL outputs of cascaded packages are connected in a wired-AND configuration to detect if all inputs are zero. A recommended pull-up resistor of 200 to $680 \Omega$ must be provided externally for proper operation in the 32-bit mode. |
| ZNO | B4 | 1/0 | A four-bit code that performs the following functions in the 16-bit mode: |
| ZN1 | A2 | 1/0 | 1. As an input in shift instructions, specifies how many bit positions are to be shifted. |
| ZN2 | A3 | 1/0 | 2. As an input in replace instructions, specifies position of the bit to be replaced. |
| ZN3 | A4 | I/O | 3. As an input to the normalize instruction, specifies the number of left shifts to be performed. <br> 4. As an output from the normalize instruction, when $\overline{\text { NORM }}=L$, specifies the number of leading zeros in the data on D15-D0. |
| ZN4 | B6 | 1/0 | ZN4 is concatenated with ZN3-ZNO for use in 32-bit shift operations as described above. In 16-bit normalization operations, ZN4 indicates when the input to the shifter is zero. In 16-bit left and right shifts and in shift and merge operations, a high on ZN4 causes all 16 -bits to be filled with the logic level on the $S$ input. |

## 16-BIT PARALLEL/SERIAL BARREL SHIFTERS

## description (continued)

## control block

The control block decodes the M2-MO instruction inputs, $16 \mathrm{~B} / \overline{32 \mathrm{~B}}$ configuration select, IP and OP data select/bit reversal options, and other control inputs and transmits the resulting control signals to the rest of the internal logic.

## instruction set

The 'AS897A can operate in any of the eight user-programmable shift modes shown in Table 1. Selection of these instructions is controlled by pins M2-MO.
table 1. instruction set

|  | M2 | M1 | M0 | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
|  | L | L | L | Shift right the number of bit positions defined by ZN3-ZNO (16-bit mode) or ZN4-ZNO (32-bit mode). Fill vacated bit positions with logic level on S input. A high on ZN 4 causes all bits in the 16 -bit mode to be filled with the logic level on S . |
|  | L | L | H | Shift left the number of bit positions defined by ZN3-ZNO (16-bit mode) or ZN4-ZNO ( 32 -bit mode). Fill vacated bit positions with logic level on S input. A high on ZN4 causes all bits in the 16 -bit mode to be filled with the logic level on S . |
| $2$ | L | H | L | Circular right shift the number or bit positions defined by ZN3-ZNO (16-bit mode) or ZN4-ZNO (32-bit mode). |
|  | L | H | H | Circular left shift the number of bit positions defined by ZN3-ZNO (16-bit mode) or ZN4-ZNO (32-bit mode). |
| $\boldsymbol{N}$ | H | L | L | Shift right the number of bit positions defined by ZN3-ZNO (16-bit mode) or ZN4-ZNO (32-bit mode). Fill vacated bit positions with logic level on S input. Merge result with data from the register/counter. A high on ZN4 causes all bits in the 16 -bit mode to be filled with the logic level on $S$. |
|  | H | L | H | Shift left the number of bit positions defined by ZN3-ZNO (16-bit mode) or ZN4-ZNO (32-bit mode). Fill vacated bit positions with logic level on S input. Merge result with data from the register/counter. A high on ZN4 causes all bits in the 16 -bit mode to be filled with the logic level on S . |
|  | H | H | L | Set the bit position defined by ZN3-ZNO (16-bit mode) or ZN4-ZNO (32-bit mode) to the logic level on the S input. |
|  | H | H | H | If $\overline{N O R M}$ is low, shift data left the number of bit positions defined by the leading-zero detector. Fill vacated bit positions with logic level on S input. Output number of leading zeros in D15-DO on ZN3-ZNO (16-bit mode) or ZN4-ZNO ( 32 -bit mode). Note: If $\overline{\text { NORM }}$ is high, this instruction performs like the left shift described above for $M 2=L, M 1=L, M O=H$. |

mode configuration
The 'AS897A can be configured to operate on 16 -bit or 32 -bit words. Configuration is controlled by $16 B / \overline{32 B}$. When $16 B / \overline{32 B}$ is high, the 'AS897A operates in 16 -bit mode.

Figure 1 illustrates the connection of four 'AS897As to provide a 32 -bit barrel shifter that can perform all Table 1 shift instructions. For 32 -bit mode operation, the $16 B / \overline{32 B}$ inputs of all 'AS897A devices must be low and should be configured as shown in Figure 1.

## SN54AS897A, SN74AS897A 16-BIT PARALLEL/SERIAL BARREL SHIFTERS



FIGURE 1. 32-BIT BARREL SHIFTER

## data input/output

Data can be input to the chip from two ports: D15-D0, which passes data to the zero detector and to the shifter via the data select and bit-reversal multiplexers, and Y15-Y0, which passes data to the register/counter. Y15-Y0 is also used to output the shift result from the chip.
Data input and output positions in the 32-bit mode are defined by IP and OP (see Table 2). When IP is high, the D15-D0 port is the most significant input position; when IP is low, the D15-D0 input port is the least significant. If $O P$ is high, the $\mathrm{Y} 15-\mathrm{YO}$ port is the most significant output position; if $O P$ is low, the $\mathrm{Y} 15-\mathrm{Y} 0$ port is the least significant position.

TABLE 2. IP AND OP CONTROLS

| SIGNAL | 16-BIT OPERATION <br> $(16 B / \overline{32 B}=H)$ | 32-BIT OPERATION <br> $(16 B / \overline{32 B}=\mathrm{L})$ |
| :---: | :--- | :---: |
| $\mathrm{IP}=\mathrm{L}$ | Bit-reversal option off | $\mathrm{D} 15-\mathrm{DO}$ is least significant input position |
| $\mathrm{IP}=\mathrm{H}$ | Bit-reversal option on | $\mathrm{D} 15-\mathrm{DO}$ is most significant input position |
| $\mathrm{OP}=\mathrm{L}$ | $\mathrm{D} 15-\mathrm{DO}$ is shifted | $\mathrm{Y} 15-\mathrm{YO}$ is least significant output position |
| $\mathrm{OP}=\mathrm{H}$ | Register/counter data <br> is shifted | Y15-YO is most significant output position |

## zero detector

The zero detector detects the number of leading zeros at the D15-D0 input port. If HEX/ $\overline{\mathrm{BIN}}$ is high, the zero detector counts only those binary zeros that are part of a leading hexadecimal zero group. For example, given the binary number 000000000001 0001, the leading-zero count will be decimal 11 if HEX/BIN is low and decimal 8 if HEX/BIN is high.

If all zeros are detected at the $D$ port, the ZL output transistor will be turned off. If the ZL output pin is pulled up through the recommended pull-up resistor (see pin description table), the resulting signal will be high. If anything other than a zero is detected on the D15-D0 inputs, the output transistor will be turned on; this will pull the ZL signal low.

## SN54AS897A, SN74AS897A 16-bIT PARALLEL/SERIAL BARREL SHIFTERS

During data normalization ( $M 2=H, M 1=H, M O=H$ ), the zero-detector outputs the leading zero count to the ZN4-ZNO I/O ports, provided $\overline{\text { NORM }}$ is low. When $\overline{\text { NORM }}$ is high, ZN4-ZNO act only as inputs in this mode. For operations other than normalization, the state of $\overline{\text { NORM }}$ is irrelevant.

In the data-normalization mode, a high logic level will be output on the ZN4 pin when the D15-D0 bus contains all lows and $\overline{\text { NORM }}$ is low (see Table 3).

TABLE 3. ZN4 I/O PORT

| SIGNAL | 1/0 | 16-BIT CONFIGURATION $(16 B / \overline{32 B}=H)$ | 32-BIT CONFIGURATION $(16 B / \overline{32 B}=L)$ |
| :---: | :---: | :---: | :---: |
| ZN4 | 1 | In shift-left, shift-right, and shift-and-merge modes, a high fills all bits with the logic level on the $S$ input. Inactive in other modes. | With ZN3-ZNO indicates number of bits to be shifted in shift operations and position of bit to be replaced in replace-bit mode. |
|  | 0 | In the normalization mode, when $\overline{\text { NORM }}=\mathrm{L}$, indicates when the input to the shifter is zero | In the normalization mode, when $\overline{\text { NORM }}=\mathrm{L}$, ZN4-ZNO indicates number of leading zeros detected in D15-DO and number of places to be shifted for normalization. |

## data selector multiplexer

The data selector multiplexer is used only in 16 -bit operation ( $16 \mathrm{~B} / \overline{32 \mathrm{~B}}=\mathrm{H}$ ). OP controls the mux and selects the data to be presented to the bit-reversal block. OP high selects the register/counter; OP low selects D15-DO (see Table 2).

## bit reversal

Bit reversal is also available only in the 16 -bit mode ( $16 \mathrm{~B} / \overline{32 \mathrm{~B}}=\mathrm{H}$ ) and is controlled by IP (see Table 2). When the bit-reversal option is selected (IP = H) , data selected by OP is bit-reversed before it is passed to the shifter: the most significant bit becomes the least significant bit, the second most significant bit becomes the second least significant bit, and so forth. When the bit-reversal option is off ( $I P=L$ ), the data presented to the shifter is not altered.

## register/counter

During most instructions, the register/counter operates as a data latch. Data on the Y15-Y0 bus is latched into the register/counter on the rising edge of the clock. Data can be input to the register/counter from the shifter $(\overline{\mathrm{OEY}}=\mathrm{L})$ or from the bidirectional $Y$ port $(\overline{\mathrm{OEY}}=\mathrm{H})$.
In the 16 -bit circular-shift mode $(16 B / \overline{32 B}=H, M 2=L, M 1=H, M O=X)$, the register counter will function as a 16 -bit counter on the rising edge of the clock when $S$ is high. Under these same conditions, the register/counter will function as four 4-bit counters when TP is low. In the 16-bit circular-shift mode, the register/counter functions as a register when $S$ is low. The counter option is not available for other instructions in the 16 -bit mode or for any instructions in the 32 -bit mode.

## shifter

The shifter performs the operations specified by the M2-MO inputs (see Table 1). The number of bits to be shifted or the position of the bit to be replaced is specified by ZN3-ZNO (16-bit operation) or ZN4-ZNO (32-bit operation).

## SN54AS897A, SN74AS897A 16-BIT PARALLEL/SERIAL BARREL SHIFTERS

## merge

During the shift and merge instruction ( $\mathrm{M} 2=\mathrm{H}, \mathrm{M} 1=\mathrm{L}, \mathrm{MO}=\mathrm{X}$ ), the merge block ORs the shift result with data from the register/counter.
$S$ or $Z$ fill
During bit replacement ( $\mathrm{M} 2=\mathrm{H}, \mathrm{M} 1=\mathrm{H}, \mathrm{MO}=\mathrm{L}$ ) in the 16 -bit mode, this block sets the bit specified on the ZN3-ZNO inputs with the logic level on the S input. This option works identically in the 32-bit mode, except that the bit to be replaced is specified on the Z4-ZO inputs. During all other instructions except circular shifts, the $S$ input specifies the logic level that will fill the bit position or positions vacated during the shift.
$Z$ fill is used in the 32-bit mode to selectively put the device outputs in a high-impedance state. This feature is necessary to properly select the correct bit locations that will combine to form the shifted output. An example of a 32-bit circular shift four positions to the right, which illustrates the Z-fill technique, is shown in Figure 2.


## SHIFT OPERATION EXAMPLES

Examples of 'AS897A shift instructions are provided in the following paragraphs. Unless otherwise specified, the examples assume a 16 -bit configuration.

## shift left or right $(M 2=L, M 1=L, M 0=X)$

When in the shift-right ( $\mathrm{MO}=\mathrm{L}$ ) or shift-left $(\mathrm{MO}=\mathrm{H})$ modes, ZN3-ZNO define the number of bit positions to be shifted. If, for example, ZN3-ZNO is equal to a decimal 10 , the data selected by OP will be shifted 10 bit positions. The positions vacated during the shift operation are filled with the logic level being applied to the $S$ input. $\overline{N O R M}$ is inactive in all shift modes except normalization and is therefore shown as a don't care. If IP is high, the data selected by OP will be bit-reversed before it is passed to the shifter.

## Example

Shift a 16-bit word on the data bus ten positions to the left and fill the least significant bits with highs.
CONTROL SIGNALS

| SHIFT <br> INSTRUCTION | NORMALIZE | NUMBER OF BITS <br> TO SHIFT | BIT <br> REVERSAL | DATA <br> SOURCE | BIT <br> FILL | CONFIGURATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| M2-MO | $\overline{\text { NORM }}$ | ZN4-ZNO | IP | OP | S | 16B/32B |
| 001 | X | 01010 | 0 | 0 | 1 | 1 |

Assume D15-D0 contains hex AF50:

|  | D15-D0 |
| :--- | :---: |
| Input Data | 1010111101010000 <br> Result |
|  | 0100001111111111 |

## Example

Shift a 32 -bit word on the data bus 20 positions to the right. Fill vacated bit positions with highs.

CONTROL SIGNALS

| SHIFT <br> INSTRUCTION | NORMALIZE | NUMBER OF BITS <br> TO SHIFT | BIT <br> REVERSAL | DATA <br> SOURCE | BIT <br> FILL | CONFIGURATION |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| M2-MO | $\overline{\text { NORM }}$ | ZN4-ZNO | IP | OP | S | 16B/32B |  |  |  |  |
| 000 | X | 10100 | See Figure 1 |  |  |  |  |  | 1 | 1 |

Assume D15-D0 contains hex 75BB FCAE:


## SN54AS897A, SN74AS897A 16-BIT PARALLEL/SERIAL BARREL SHIFTERS

## circular shift left or right ( $\mathbf{M} 2=\mathrm{L}, \mathrm{M} 1=\mathrm{H}, \mathrm{MO}=\mathrm{X}$ )

In this mode, data selected by $O P$ is circular shifted left $(M O=H)$ or right $(M O=L)$ the number of bit positions specified by ZN3-ZNO. If, for example, the device is in the circular-shift-right mode ( $\mathrm{MO}=\mathrm{L}$ ) and ZN3-ZNO contains a decimal five, the data selected by OP will be shifted right five positions.

In all shift modes except 16-bit circular, the $S$ input contains the bit used for end fill or bit replacement. In the 16-bit circular-shift mode, the $S$ input controls whether the register/counter will operate as a 16-bit counter or as a data register. When $S$ is high, the register/counter operates as a 16-bit binary counter; when $S$ is low, the register/counter operates as a 16-bit data latch. Both functions are controlled on the positive edge of the CLK input. Data on Y15-Y0 will be latched into the register/counter on the rising edge of the clock when $S$ is low.

## Example

Circular shift a 16 -bit word in the register/counter five positions to the right.
CONTROL SIGNALS

| SHIFT <br> INSTRUCTION | NORMALIZE | NUMBER OF BITS <br> TO SHIFT | BIT <br> REVERSAL | DATA <br> SOURCE | LATCH OR <br> COUNTER | CONFIGURATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| M2-M0 | $\overline{\text { NORM }}$ | ZN4-ZNO | IP | OP | S | 16B/32B |
| 010 | $X$ | X0101 | 0 | 1 | 0 | 1 |

shift and merge $(M 2=H, M 1=L, M 0=X)$
In the shift-and-merge mode, data selected by OP is shifted by OP is shifted left ( $\mathrm{MO}=\mathrm{H}$ ) or right $(\mathrm{MO}=\mathrm{L})$ the number of positions specified by ZN3-ZNO, bit positions vacated by the shift are filled by the logic level on $S$, and the result is ORed with data in the register/counter.

## Example

Shift data on the data bus six positions to the left, and fill vacated positions with zeros. Merge the shifted data with data from the data register.

CONTROL SIGNALS

| SHIFT <br> INSTRUCTION | NORMALIZE | NUMBER OF BITS <br> TO SHIFT | BIT <br> REVERSAL | DATA <br> SOURCE | END <br> FILL | CONFIGURATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| M2-MO | $\overline{\text { NORM }}$ | ZN4-ZNO | IP | OP | S | 16B/32B |
| 100 | X | 00110 | 0 | 0 | 0 | 1 |

Assume D15-DO contains hex 6174 and register/counter contains hex 320B:

|  | D15-D0 |
| :---: | :---: |
| Input Data | 0110000101110100 |
|  | Shift Result |
| Intermediate Result | 0101110100000000 |
|  | Register/Counter |
| Input Data | 0011001000001011 |
|  | Y15-Y0 |
| Result | 0111111100001011 |

## bit replacement $(M 2=H, M 1=H, M O=L)$

In the bit-replacement mode, data in the bit position specified by ZN3-ZNO is replaced by the logic level on the S input. If, for example, ZN3-ZNO contains a decimal seven and S contains a logic high, bit 7 of the data selected by OP will be set high regardless of its original state. In the following example, OP has been set high to select data from the register/counter. Because IP has been set high, the data will be bitreversed before it enters the shifter.

## Example

Bit-reverse the data in the register/counter and set bit 7 of the result to zero.
CONTROL SIGNALS

| SHIFT <br> INSTRUCTION | NORMALIZE | POSITION OF BIT <br> TO BE INSERTED | BIT <br> REVERSAL | DATA <br> SOURCE | INSERT <br> BIT | CONFIGURATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| M2-MO | $\overline{\text { NORM }}$ | ZN4-ZNO | IP | OP | S | 16B/32B |
| 110 | $X$ | X0111 | 1 | 1 | 0 | 1 |


|  | Register/Counter |
| :---: | :---: |
|  | 0110000100110100 |
|  |  |

Result after Bit-Reversal
Intermediate
Result
0010110010000110
Y15-Y0
Result
0010110000000110

## SN54AS897A, SN74AS897A <br> 16-BIT PARALLEL/SERIAL BARREL SHIFTERS

data normalization $(M 2=H, M 1=H, M O=L)$
The data-normalization mode shifts data on D15-DO to the left until a high logic level appears in the most-significant-bit position of output $\mathrm{Y} 15-\mathrm{YO}$ if $\mathrm{HEX} / \overline{\mathrm{BIN}}$ is low. If $\mathrm{HEX} / \overline{\mathrm{BIN}}$ is high, only 4 -digit groups containing leading zeros are shifted left. The number of positions shifted to accomplish this is determined by the leadingzero detector. This count will be output on ZN3-ZNO when the $\overline{\text { NORM }}$ input is low.
Since the leading-zero detector counts leading zeros in the D15-DO input, the normalization is designed to operate on data from the data bus rather than the register/counter. Therefore OP is set low in the following example. The S input is programmed low so that all bit positions vacated during the shift will be filled with zeros.

## Example

Perform a hex normalization on a 16 -bit data word from the data bus.
CONTROL SIGNALS

| SHIFT <br> INSTRUCTION | NORMALIZE | NUMBER OF BITS <br> TO BE SHIFTED | LEADING-ZERO <br> MODE | BIT <br> REVERSAL | DATA <br> SOURCE | INSERT <br> BIT | CONFIGURATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| M2-MO | $\overline{\text { NORM }}$ | ZN4-ZNO | HEX/BIN | IP | OP | S | 16B/32B |
| 111 | 0 | Outputs leading <br> zero count | 1 | 0 | 0 | 0 | 1 |

Assume D15-DO contains hex 002B:
D15-D0

| Input Data | 0000000000101011 |
| :--- | :--- |
|  | ZN3-ZNO |
| Leading-Zero | 1000 |
| Count |  |
| Result | 1010101100000000 |
|  |  |

## Example

Perform a binary normalization on a 32 -bit word from the data bus.
CONTROL SIGNALS

| SHIFT <br> INSTRUCTION | NORMALIZE | NUMBER OF BITS <br> TO SHIFT | LEADING-ZERO <br> MODE | BIT <br> REVERSAL | DATA <br> SOURCE | BIT <br> FILL | CONFIGURATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| M2-MO | NORM | ZN4-ZNO | HEX/BIN | IP | OP | S | 16B/32B |
| 111 | 0 | Outputs leading <br> zero count | 0 | See Figure 1 | 0 | 0 |  |

Assume D31-D0 contains hex 0000 3D61:


## IEEE floating-point normalization

Floating-point normalization is used to preserve number resolution after subtraction or some other floatingpoint algorithm that results in orders of magnitude reduction. Three 'AS897A devices can be configured to convert a 32-bit data word into the IEEE floating-point format shown in Figure 3.
$\square$


S - sign bit
E-8-bit exponent
F - 23-bit fraction
FIGURE 3. IEEE FLOATING-POINT FORMAT

Figure 4 shows the three-device configuration. The limitation of this application is that only 23 bits of the 32 bits are used in the significand, and the sign bit must be set from hardware. As an alternate to the IEEE floating-point format, the same hardware configuration can be used to normalize a 32 -bit data word resulting in a 32 -bit significand and a five-bit exponent.


FIGURE 4. THREE-DEVICE CONFIGURATION FOR IEEE FLOATING-POINT FORMAT

## SN54AS897A, SN74AS897A <br> 16-BIT PARALLEL/SERIAL BARREL SHIFTERS

## Example

Input data in IEEE floating point format

| Sign <br> Bit |
| :---: |
| Previous <br> Exponent |


| 1 | 0010 | 1001 | 000 | 1001 | 0001 |
| :---: | :---: | :---: | :---: | :---: | :---: |

Input mantissa concatenated with: 000000000 to D31-D0 of the 'AS897As

| D31-D16 | D15-D0 |
| :---: | :---: |
| 0001001000100010 | 0010001000000000 |

Normalize mantissa and output the leading zero count on ZN4-ZNO.

| D31-D16 | D15-DO | ZN4-ZNO |
| :---: | :---: | :---: |
| 1001000100010001 0001000000000000 00011 |  |  |

Pack result in IEEE floating point format

# Note: Exponent $=$ old exponent - ZN4-ZNO 

Sign
Bit Exponent Mantissa

| 1 | 00100110 | 00100010001000100010000 |
| :---: | :---: | :---: |

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, VCC1 ..... 7 V
Supply voltage, VCC2 ..... 3 V
Input voltage: I/O ports ..... 5.5 V
All other inputs ..... 7 V
Operating case temperature range: SN54AS897A ..... $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Operating free-air temperature range: SN74AS897A $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range ..... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

## SN54AS897A, SN74AS897A 16-BIT PARALLEL/SERIAL BARREL SHIFTERS

recommended operating conditions

${ }^{\dagger}$ These parameters only apply in the circular mode and with $16 \mathrm{~B} / \overline{32 \mathrm{~B}}$ high.
$\ddagger$ These parameters only apply in the circular mode.
electrical characteristics over recommended operating temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54AS897A |  |  | SN74AS897A |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $!=18 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| ${ }^{\mathrm{I} \mathrm{OH}}$ | ZL | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| $\mathrm{V}_{\mathrm{OH}}$ | All outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{I}^{\mathrm{OH}}=-0.4 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  | Y15-Y0 | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ | 2.43 .2 |  |  |  |  |  | V |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-2.6 \mathrm{~mA}$ |  |  |  | 2.4 | 3.2 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | ZN4-ZNO | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=8 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
|  | ZL, Y15-Y0 | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 |  |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OL}}=24 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| $!$ | 1/O ports ${ }^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | All others | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 |  |
| $\mathrm{I}_{\mathrm{IH}}$ | 1/O ports ${ }^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 40 |  |  | 40 | $\mu \mathrm{mA}$ |
|  | All others |  |  |  |  | 20 |  |  | 20 |  |
| ILL | All inputs | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.4 |  |  | -0.4 | mA |
| $10^{5}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ${ }^{\text {ICC1 }}$ |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | See Note 1 |  |  | 100 |  |  | 90 | mA |
| ICC2 |  | $\mathrm{V}_{C C}=2.1 \mathrm{~V}$, | See Note 1 |  |  | 180 |  |  | 170 | mA |

[^62]${ }^{\S}$ The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los. NOTE 1: Supply currents ICC1 and ICC2 are measured with MO, M1, M2, IP, OP, S, ZN3-ZNO, D15-DO, and $\overline{\mathrm{OEY}}$ low; $16 \mathrm{~B} / \overline{32 \mathrm{~B}}, \overline{\mathrm{NORM}}$,

SN54AS897A, SN74AS897A
16-BIT PARALLEL/SERIAL BARREL SHIFTERS
switching characteristics over recommended operating temperature range

| PARAMETER | FROM (INPUT) | то (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 \Omega, \\ & \mathrm{R} 2=500 \Omega \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54AS897A |  | SN74AS897A |  |  |
|  |  |  | MIN | MAX | MIN | MAX |  |
| ${ }^{t} \mathrm{pd}$ | D15-D0 | Y15-Y0 |  | 37 |  | 33 | ns |
|  | S | Y15-Y0 |  | 20 |  | 17 |  |
|  | ZN3-ZNO | Y15-Y0 |  | 24 |  | 22 |  |
|  | IP | Y15-Y0 |  | 33 |  | 29 |  |
|  | OP | Y15-Y0 |  | 33 |  | 29 |  |
|  | M0, M1, M2 | Y15-Y0 |  | 24 |  | 21 |  |
|  | CLK ${ }^{\dagger}$ | Y15-Y0 |  | 47 |  | 42 |  |
|  | D15-D0 | ZL |  | 28 |  | 27 |  |
|  | D15-D0 ${ }^{\ddagger}$ | ZN4-ZNO |  | 28 |  | 26 |  |
| $t_{\text {en }}$ | M0, M1, M ${ }^{\text {§ }}$ | ZN4-ZNO |  | 25 |  | 20 | ns |
|  | 168/32B | Y15-Y0 |  | 29 |  | 26 |  |
|  | $\overline{\text { NORM }}{ }^{\ddagger}$ | ZN3-ZNO |  | 26 |  | 21 |  |
|  | $\overline{\text { OEY }}$ | Y15-Y0 |  | 22 |  | 19 |  |
|  | ZN4, ZL | Y15-Y0 |  | 32 |  | 29 |  |
| ${ }^{\text {dis }}$ | M0, M1, M $2^{\text {§ }}$ | ZN4-ZNO |  | 22 |  | 20 | ns |
|  | 16B/32B | Y15-Y0 |  | 31 |  | 27 |  |
|  | $\overline{\text { NORM }}{ }^{\ddagger}$ | ZN3-ZNO |  | 14 |  | 12 |  |
|  | $\overline{\mathrm{OEY}}$ | Y15-Y0 |  | 10 |  | 9 |  |
|  | ZN4, ZL | Y15-Y0 |  | 30 |  | 26 |  |

[^63]- Serial-to-Parallel and Parallel-to-Serial Conversions
- Parallel I/O Registers
- Data Exchangeable Between I/O Register and Shift Register
- Choice of Synchronous and/or Asynchronous Clear
- Independent or Dual Register Clocking
- Functionally Similar to National Semiconductor DM74LS962
- Dependable Texas Instruments Quality and Reliability


## description

The 'ALS963 and 'ALS964 each contain an 8-bit shift register in parallel with an 8 -bit I/O register. In addition to serial-to-parallel and parallel-toserial conversions, these devices are capable of exchanging data between the shift and I/O registers. Control lines determine the mode of operation as shown in the function table.

The 'ALS963 features individual shift and I/O register clock inputs whereas the 'ALS964 features simultaneous register clocking through a single clock input. Clocking in both cases is achieved by positive transitions at the clock inputs.

The clear function for the 'ALS963 is synchronous (active high). The 'ALS964 features active-high synchronous and asynchronous clearing.

The SN54ALS963 and SN54ALS964 are characterized for operation over the full military of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74ALS963 and SN74ALS964 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.


SN54ALS963 . . . FK PACKAGE
SN74ALS963 . . . FN PACKAGE
(TOP VIEW)



SN54ALS964 . . . JT PACKAGE
SN74ALS964 . . . DW OR NT PACKAGE
(TOP VIEW)

| $\overline{O E} \square$ | U20] VCC |
| :---: | :---: |
| SERIN $\square^{2}$ | $19] \mathrm{A} / \mathrm{Q}_{A}$ |
| $\overline{\mathrm{GIN}} \square^{3}$ | 18 B/ $\mathrm{Q}_{\mathrm{B}}$ |
| $\overline{\mathrm{G} 2-1} \square_{4}$ | $\left.{ }^{17}\right] \mathrm{C} / \mathrm{Q}_{C}$ |
| SCLR 5 | $16 \square \mathrm{D} / \mathrm{Q}_{\mathrm{D}}$ |
| $\overline{\mathrm{G} 1-2} \square^{6}$ | 15 E/QE |
| $\overline{\mathrm{GSH}} \square^{7}$ | $14 \square \mathrm{~F} / \mathrm{Q}_{\mathrm{F}}$ |
| SEROUT $\square^{8}$ | ${ }^{13} \mathrm{\square} / \mathrm{Q}_{\mathrm{G}}$ |
| CLK ${ }^{-1}$ | ${ }_{12} \mathrm{H} / \mathrm{O}_{\mathrm{H}}$ |
| GND 10 | $11 . \mathrm{ACLR}$ |

SN54ALS964 . . . FK PACKAGE SN74ALS964 . . . FN PACKAGE (TOP VIEW)

'ALS963 logic symbol ${ }^{\dagger}$

${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
'ALS963 register-level logic diagram

'ALS963 gate-level logic diagram (positive logic)

'ALS963
FUNCTION TABLE

| InPUTS |  |  |  |  |  |  |  | A/QA <br> THROUGH <br> H/QH | OPERATION OR FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{O E}$ | GIN | $\overline{\text { GE-1 }}$ | G1-2 | $\overline{\text { GSH }}$ | CLK1 | CLK2 | SCLR |  |  |
| H | H | H | H | H | X | X | L | HI-Z | All data stable |
| L | H | H | H | H | x | x | L | OUTPUT | All data stable |
| X | L | H | H | H | $\uparrow$ | x | L | InPut | Enter data from I/O into Reg 1 |
| H | H | L | H | H | $\uparrow$ | X | L | Hi-Z | Copy data from Reg 2 to Reg 1 |
| L | H | L | H | H | $\uparrow$ | x | L | OUTPUT | Copy data from Reg 2 to Reg 1 |
| X | L | L | H | H | $\uparrow$ | $\uparrow$ | L | INPUT | Reg 1 ORs data from Reg 2 and I/O |
| H | H | H | L | X | X | $\uparrow$ | L | $\mathrm{HI}-\mathrm{Z}$ | Copy data from Reg 1 to Reg 2 |
| L | H | H | L | x | x | $\uparrow$ | L | OUTPUT | Copy data from Reg 1 to Reg 2 |
| X | L | H | L | X | $\uparrow$ | $\uparrow$ | L | INPUT | Copy data from Reg 1 to Reg 2, enter new data from 1/0 into Reg 1 |
| H | H | L | L | X | $\uparrow$ | $\uparrow$ | L | $\mathrm{HI}-\mathrm{Z}$ | Exchange data between registers |
| L | H | L | L | X | $\uparrow$ | $\uparrow$ | L | OUTPUT | Exchange data between registers |
| x | L | L | L | x | $\uparrow$ | $\uparrow$ | L | InPUT | Copy data from Reg 1 to Reg 2, <br> Reg 1 ORs data from Reg 2 and I/O |
| H | H | H | H | L | X | $\uparrow$ | L | Hi-Z | Shift data in Reg 2 |
| L | H | H | H | L | x | $\uparrow$ | L | OUTPUT | Shift data in Reg 2 |
| X | L | H | H | L | $\uparrow$ | $\uparrow$ | L | INPUT | Shift data in Reg 2, enter new data from I/O into Reg 1 |
| H | H | L | H | L | $\uparrow$ | $\uparrow$ | L | $\mathrm{HI}-\mathrm{Z}$ | Copy data from Reg 2 to Reg 1 , shift data in Reg 2 |
| L | H | L | H | L | $\uparrow$ | $\uparrow$ | L | OUTPUT | Copy data from Reg 2 to Reg 1 , shift data in Reg 2 |
| x | L | L | H | L | $\uparrow$ | $\uparrow$ | L | INPUT | Reg 1 ORs data from Reg 2 and $1 / \mathrm{O}$, shift data in Reg 2 |
| X | H | X | X | X | $\uparrow$ | X | H |  | Synchronously, clear Reg 1 |
| x | X | x | x | $x$ | x | $\uparrow$ | H |  | Synchronously clear Reg 2 |
| X | H | x | X | X | $\uparrow$ | $\uparrow$ | H |  | Synchronously clear both registers |
| X | L | x | x | x | $\uparrow$ | $\uparrow$ | H | INPUT | Enter data from I/O into Reg 1 and synchronously clear Reg 2 |
| X | L | x | x | x | $\uparrow$ | x | H | INPUT | Enter data from I/O into Reg 1 |

'ALS964 logic symbol ${ }^{\dagger}$

${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
'ALS964 register-level logic diagram


## SN54ALS964, SN74ALS964 <br> DUAL-RANK 8-BIT SHIFT REGISTERS WITH 3-STATE OUTPUTS

'ALS964 gate-level logic diagram (positive logic)


SN54ALS964, SN74ALS964 DUAL-RANK 8-BIT SHIFT REGISTERS WITH 3-STATE OUTPUTS

ALS964
FUNCTION TABLE

| INPUTS |  |  |  |  |  |  |  | A/QA THROUGH $\mathrm{H} / \mathrm{QH}$ | OPERATION OR FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{O E}$ | GIN | $\overline{\text { G2-1 }}$ | $\overline{\text { G1-2 }}$ | $\overline{\text { GSH }}$ | CLK | ACLR | SCLR |  |  |
| H | H | H | H | H | X | L | L | $\mathrm{HI}-\mathrm{Z}$ | All data stable |
| L | H | H | H | H | X | L | L | OUTPUT | All data stable |
| X | L | H | H | H | $\uparrow$ | L | L | INPUT | Enter data from I/O into Reg 1 |
| H | H | L | H | H | $\uparrow$ | L | L | HI-Z | Copy data from Reg 2 to Reg 1 |
| L | H | L | H | H | $\uparrow$ | L | L | OUTPUT | Copy data from Reg 2 to Reg 1 |
| X | L | L | H | H | $\uparrow$ | L | L | INPUT | Reg 1 ORs data from Reg 2 and I/O |
| H | H | H | L | X | $\uparrow$ | L | L | HI-Z | Copy data from Reg 1 to Reg 2 |
| L | H | H | L | X | $\uparrow$ | L | L | OUTPUT | Copy data from Reg 1 to Reg 2 |
| X | L | H | L | X | $\uparrow$ | L | L | INPUT | Copy data from Reg 1 to Reg 2, enter new data from I/O into Reg 1 |
| H | H | L | L | X | $\uparrow$ | L | L | $\mathrm{HI}-\mathrm{Z}$ | Exchange data between registers |
| L | H | L | L | $x$ | $\uparrow$ | L | L | OUTPUT | Exchange data between registers |
| X | L | L | L | X | $\uparrow$ | L | L | INPUT | Copy data from Reg 1 to Reg 2, <br> Reg 1 ORs data from Reg 2 and I/O |
| H | H | H | H | L | $\uparrow$ | L | $L$ | $\mathrm{HI}-\mathrm{Z}$ | Shift data in Reg 2 |
| L | H | H | H | L | $\uparrow$ | L | $L$ | OUTPUT | Shift data in Reg 2 |
| X | L | H | H | L | $\uparrow$ | L | L | INPUT | Shift data in Reg 2, enter new data from I/O into Reg 1 |
| H | H | L | H | L | $\uparrow$ | L | L | HI-Z | Copy data from Reg 2 to Reg 1 , shift data in Reg 2 |
| L | H | L | H | L | $\uparrow$ | L | L | OUTPUT | Copy data from Reg 2 to Reg 1, shift data in Reg 2 |
| X | L | L | H | L | $\uparrow$ | L | L | INPUT | Reg 1 ORs data from Reg 2 and I/O, shift data in Reg 2 |
| X | H | X | X | X | $\uparrow$ | L | H |  | Synchronously clear Reg 1 and Reg 2 |
| X | X | $x$ | $x$ | $x$ | $X$ | H | X |  | Asynchronously clear Reg 1 and Reg 2 |
| $x$ | L | X | X | X | $\uparrow$ | L | H | INPUT | Enter data from I/O into Reg 1 and synchronously clear Reg 2 |

## SN54ALS963, SN74ALS963 <br> DUAL-RANK 8-BIT SHIFT REGISTERS WITH 3-STATE OUTPUTS

## 'ALS963 typical sequence

Illustrated below is the following sequence:

1. Clear both registers to zero.
2. Input 00110011 in Reg 1.
3. Transfer 00110011 from Reg 1 to Reg 2.
4. Input 01110111 into Reg 1.
5. Shift contents of Reg 2, SERIN $=0$
6. Shift contents of Reg 2, SERIN $=1$
7. Exchange contents of Reg 1 with Reg 2.


## 'ALS964 typical sequence

Illustrated below is the following sequence:

1. Asynchronously clear Reg 1 and Reg 2 to zero, operate, then synchronously clear.
2. Input 00110011 into Reg 1.
3. Transfer 00110011 from Reg 1 to Reg 2 and input 01110111 into Reg 1.
4. Shift contents of Reg 2, SERIN $=0$
5. Shift contents of Reg 2, SERIN $=1$
6. Exchange contents of Reg 1 with Reg 2.


## SN54ALS963, SN54ALS964, SN74ALS963, SN74ALS964 DUAL-RANK 8-BIT SHIFT REGISTERS WITH 3-STATE OUTPUTS

```
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, VCC
Input voltage: All inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 7 V
    I/O ports . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 5.5 V
```



```
    SN74ALS963, SN74ALS964 . . . . . . . . . . . . . . 0 }\mp@subsup{0}{}{\circ}\textrm{C}\mathrm{ to }7\mp@subsup{0}{}{\circ}\textrm{C
Storage temperature range .............................................. . . . . - 65 % C to 150 % C
```


## 'ALS963 recommended operating conditions



## 'ALS964 recommended operating conditions



## SN54ALS963, SN54ALS964, SN74ALS963, SN74ALS964 DUAL-RANK 8-BIT SHIFT REGISTERS WITH 3-STATE OUTPUTS

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

${ }^{\dagger}{ }^{\dagger}$ ll typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$.
${ }^{\ddagger}$ For $I / O$ ports $\left(\mathrm{O}_{\mathrm{A}}\right.$ throuh $\left.\mathrm{O}_{\mathrm{H}}\right)$, the parameters $\mathrm{I}_{\mathrm{IH}}$ and $\mathrm{I}_{\mathrm{IL}}$ include the off-state output current.
§The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, los.

SN54ALS963, SN54ALS964, SN74ALS963, SN74ALS964 DUAL-RANK 8-BIT SHIFT REGISTERS WITH 3-STATE OUTPUTS
'ALS963 switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (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 \Omega \\ & \mathrm{R} 2=500 \Omega \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54ALS963 |  |  | SN74ALS963 |  |  |  |
|  |  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| $f_{\text {max }}$ | CLK1 or CLK2 | Any 0 | 25 | 30 |  | 25 | 30 |  | MHz |
| tPLH | CLK1 | Any 0 |  | 10 |  |  | 10 |  | ns |
| tPHL |  |  |  | 14 |  |  | 14 |  |  |
| tPLH | CLK2 | SEROUT |  | 10 |  |  | 10 |  | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 14 |  |  | 14 |  |  |
| tPHZ | $\overline{O E}$ | Any 0 |  | 15 |  |  | 15 |  | ns |
| tPLZ |  |  |  | 18 |  |  | 18 |  |  |
| tPZH | $\overline{\mathrm{OE}}$ | Any 0 |  | 12 |  |  | 12 |  | ns |
| tPZL |  |  |  | 12 |  |  | 12 |  |  |

'ALS964 switching characteristics (see Note 1)

| PARAMETER | 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 \Omega, \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN54ALS964 |  |  | SN74ALS964 |  |  |  |
|  |  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| $f_{\text {max }}$ | CLK | Any Q | 25 | 30 |  | 25 | 30 |  | MHz |
| tPLH | CLK | Any Q |  | 10 |  |  | 10 |  | ns |
| tPHL |  |  |  | 14 |  |  | 14 |  |  |
| tPLH | CLK | SEROUT |  | 10 |  |  | 10 |  | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 14 |  |  | 14 |  |  |
| tpHZ | ACLR | Any Q or SEROUT |  | 14 |  |  | 14 |  | ns |
| tpHz | $\overline{\mathrm{OE}}$ | Any Q |  | 15 |  |  | 15 |  | ns |
| tplZ |  |  |  | 18 |  |  | 18 |  |  |
| tPZH | $\overline{O E}$ | Any 0 |  | 12 |  |  | 12 |  | ns |
| ${ }^{\text {tPZL }}$ |  |  |  | 12 |  |  | 12 |  |  |

NOTE: Load circuit and voltage waveforms are shown in Section 1.

- 3-State I/O-Type Read-Back Inputs
- Bus-Structured Pinout
- Choice of True or Inverting Logic
'ALS990 . . . True Outputs
'ALS991 . . . Inverting Outputs
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 8-bit latches are designed specifically for storing the contents of the input data bus plus providing the capability of reading-back the stored data onto the input data bus.

The eight latches of the 'ALS990 and 'ALS991 are transparent D-type. While the enable (C) is high, the Q outputs of the 'ALS990 will follow the data ( $D$ ) inputs. For the 'ALS991, the Q outputs will provide the complement of what is applied to its data (D) inputs.

Read-back is provided through the read-back control input ( $\overline{\mathrm{OERB}}$ ). When the control is taken low, the data present at the output of the data latches will be allowed to pass back onto the input data bus. When it is taken high, the output of the data latches will be isolated from the data (D) inputs. The read-back control does not affect the internal operation of the latches; however, precautions should be taken not to create a busconflict situation.

The SN74ALS990 and SN74ALS991 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

SN74ALS990 . . . DW OR N PACKAGE
(TOP VIEW)


SN74ALS990 . . . FN PACKAGE
(TOP VIEW)


SN74ALS991 . . . DW OR N PACKAGE (TOP VIEW)

| $\overline{\text { OERB }} \square^{1}$ | $\mathrm{U}_{20} \mathrm{~V}_{\mathrm{CC}}$ |
| :---: | :---: |
| 10 2 | $19 \bigcirc 1 \overline{0}$ |
| $20 \square^{3}$ | $18 \square 2 \overline{\mathrm{Q}}$ |
| $30 \square 4$ | $17 \square 3 \bar{Q}$ |
| 4D $\square^{5}$ | $16 \square 4 \overline{\mathrm{Q}}$ |
| 50 $\square^{6}$ | $15 \square 5 \overline{\mathrm{Q}}$ |
| $6 \mathrm{D} \square$ | $14] 6 \overline{\mathrm{Q}}$ |
| 70 8 | $13 \square 7 \overline{\mathrm{Q}}$ |
| 80 9 | ${ }_{12} 8 \overline{\mathrm{Q}}$ |
| GND 10 | $11] \mathrm{C}$ |

SN74ALS991 . . FN PACKAGE (TOP VIEW)


## SN74ALS990, SN74ALS991

## 8-BIT D-TYPE TRANSPARENT READ-BACK LATCHES

logic symbols ${ }^{\dagger}$
'ALS990

'ALS991

${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
logic diagrams (positive logic)

'ALS991


## timing diagram


${ }^{\dagger}$ This setup time ensures the readback circuit will not create a conflict on the input data bus.
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

> Supply voltage, VCC
> Voltage applied to $D$ inputs
> Operating free-air temperature range SN74ALS990, SN74ALS991
> $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
> Storage temperature range
> $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended operating conditions


## SN74ALS990, SN74ALS991, 8-BIT D.TYPE TRANSPARENT READ-BACK LATCHES

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


[^64]
## SN74ALS990, SN74ALS991

## 8-BIT D-TYPE TRANSPARENT READ-BACK LATCHES

'ALS990 switching characteristics

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \end{aligned}$ <br> See Figures 1 and 2 |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}, \\ & \text { See Figures } 1 \text { and } 2 \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | MAX |  |
| tPLH | D | Q |  | 8 | 14 | 4 | 17 | ns |
| tPHL |  |  |  | 11 | 22 | 5 | 24 |  |
| tPLH | C | Q |  | 13 | 22 | 6 | 26 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 16 | 23 | 8 | 26 |  |
| $\mathrm{t}_{\text {en }}$ | $\overline{\text { OERB }}$ | D |  | 12 | 18 | 4 | 21 | ns |
| ${ }^{\text {d }}$ dis |  |  |  | 10 | 18 | 4 | 19 |  |

$t_{\text {en }}=t_{P Z L}$ or $\mathrm{t}_{\mathrm{PZ}} \mathrm{H}$
$t_{\text {dis }}=t_{P L Z}$ or $t_{P H Z}$
'ALS991 switching characteristics

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{~T}_{A}=25^{\circ} \mathrm{C} \end{aligned}$ <br> See Figures 1 and 2 |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} . \end{aligned}$ <br> See Figures 1 and 2 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | MAX |  |
| ${ }^{\text {tPLH }}$ | D | $\overline{\mathrm{Q}}$ |  | 12 | 15 | 4 | 20 | ns |
| ${ }_{\text {t }}$ PHL |  |  |  | 9 | 12 | 4 | 15 |  |
| tPLH | C | $\overline{\mathrm{Q}}$ |  | 17 | 21 | 9 | 28 | ns |
| tPHL |  |  |  | 14 | 18 | 7 | 23 |  |
| ten | $\overline{\text { OERB }}$ | D |  | 12 | 17 | 4 | 22 | ns |
| ${ }^{\text {d }}$ dis |  |  |  | 8 | 12 | 4 | 17 |  |

$t_{\text {en }}=t_{\text {PZL }}$ or tPZH
$\mathrm{t}_{\mathrm{dis}}=\mathrm{tPLZ}$ or $\mathrm{tPHZ}^{2}$

## PARAMETER MEASUREMENT INFORMATION



LOAD CIRCUIT FOR O OR $\overline{\mathbf{Q}}$ OUTPUTS

FIGURE 1


LOAD CIRCUIT FOR D OUTPUTS
FIGURE 2

NOTE A: $C_{L}$ includes probe and jig capacitance.


VOLTAGE WAVEFORMS SETUP AND HOLD TIMES


VOLTAGE WAVEFORMS PULSE WIDTHS


ENABLE AND DISABLE TIMES, THREE-STATE OUTPUTS

NOTES: B. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
C. All input pulses have the following characteristics: PRR $\leq 1 \mathrm{MHz}, \mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=2 \mathrm{~ns}$, duty cycle $=50 \%$.
D. When measuring propagation delay times of 3-state outputs, switch S 1 is open.

- 3-State I/O-Type Read-Back Inputs
- Bus-Structured Pinout
- Choice of True or Inverting Logic
'ALS992 . . . True Outputs
'ALS993 . . . Inverting Outputs
- Designed with 9 Bits for Parity Applications
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 9-bit latches are designed specifically for storing the contents of the input data bus plus providing the capability of reading-back the stored data onto the input data bus. In addition, they provide a 3-state buffer-type output and are easily implemented in parity applications.
The nine latches of the 'ALS992 and 'ALS993 are transparent D-type. While the enable (C) is high, the Q outputs of the 'ALS992 will follow the data ( D ) inputs. For the 'ALS993, the $\overline{\mathrm{Q}}$ outputs will provide the complement of what is applied to its data ( D ) inputs. On both devices, the Q or $\overline{\mathrm{Q}}$ outputs will be in the 3 -state condition when output enable $\overline{\mathrm{OEQ}}$ is high.
Read-back is provided through the read-back control input ( $\overline{\mathrm{OERB}}$ ). When the control is taken low, the data present at the output of the data latches will be allowed to pass back onto the input data bus. When it is taken high, the output of the data latches will be isolated from the data (D) inputs. The read-back control does not affect the internal operation of the latches; however, precautions should be taken not to create a busconflict situation.

The SN74ALS992 and SN74ALS993 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

SN74ALS992 . . . DW OR NT PACKAGE
(TOP VIEW)


SN74ALS992 . . FN PACKAGE
(TOP VIEW)


SN74ALS993 . . . DW OR NT PACKAGE (TOP VIEW)

| $\overline{\text { OERB }}$ | $\mathrm{U}_{24} \square \mathrm{~V}_{C C}$ |
| :---: | :---: |
| 10 2 | 23 10 |
| 20.3 | $22 . \overline{\mathrm{O}}$ |
| 30.4 | 21 ¢ 3 O |
| 40 5 | $20-7 \overline{0}$ |
| 50.6 | 19 5 $\overline{\mathrm{Q}}$ |
| 60.7 | 18 60 |
| 70 [8 | 17 7 $7 \overline{0}$ |
| 8 D | ${ }_{16} \mathrm{C}^{\text {¢ }}$ |
| $9 \mathrm{D}-10$ | 15 - 9 |
| CLR 11 | 14 OEQ |
| GND 12 | 13.7 |

SN74ALS993 . . . FN PACKAGE
(TOP VIEW)


NC-No internal connection

SN74ALS992, SN74ALS993
9-BIT D-TYPE TRANSPARENT READ-BACK LATCHES
WITH 3-STATE OUTPUTS
logic symbols ${ }^{\dagger}$
'ALS992

'ALS993

${ }^{\dagger}$ These symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers are for DW and NT packages.
logic diagrams (positive logic)

'ALS993


## timing diagram


$\overline{C L R}=H, \overline{O E Q}=L$
*This setup time ensures the readback circuit will not create a conflict on the input data bus.
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, VCC ..... 7 V
Input voltage, ( $\overline{\mathrm{OERB}}, \overline{\mathrm{OE}}, \overline{\mathrm{CLR}}$, and C inputs) ..... 7 V
Voltage applied to $D$ inputs and to disabled 3 -state outputs ..... 5.5 VOperating 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}_{\text {CC }}$ | Supply voltage |  | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voitage |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current | Q or $\overline{\mathrm{Q}}$ |  |  | -2.6 | mA |
|  |  | D |  |  | -0.4 |  |
| ${ }^{\text {IOL }}$ | Low-level output current | Q or $\overline{\mathrm{Q}}$ |  |  | 24 | mA |
|  |  | D |  |  | 8 |  |
| ${ }^{\text {tw }}$ | Pulse duration | Enable C high | 10 |  |  | ns |
|  |  | $\overline{\text { CLR }}$ low | 10 |  |  |  |
| ${ }^{\text {t }}$ su | Setup time | Data before C $\downarrow$ | 10 |  |  | ns |
|  |  | Data before $\overline{\mathrm{OERB}} \downarrow$ | 10 |  |  |  |
| th | Hold time | Data after C $\downarrow$ | 5 |  |  | ns |
| ${ }^{\text {T }}$ A | Operating free-air temperature |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

## SN74ALS992, SN74ALS993 9-BIT D-TYPE TRANSPARENT READ-BACK LATCHES WITH 3-STATE OUTPUTS

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

| PARAMETER |  | TEST CONDITIONS |  | MIN | TYP $\dagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IK }}$ |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | v |
| $\mathrm{V}_{\mathrm{OH}}$ | $\begin{gathered} \text { All outputs } \\ \text { Q or } \mathrm{Q} \end{gathered}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V , | $1 \mathrm{OH}=-0.4 \mathrm{~mA}$ | $V_{C C-2}$ |  |  |  |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-2.6 \mathrm{~mA}$ | 2.4 | 3.2 |  |  |
| VOL | D | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 | v |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=8 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
|  | 0 or $\overline{\mathrm{Q}}$ | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{\prime}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{\prime}=24 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
| Iozh | Q or $\overline{\mathrm{Q}}$ | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| IOZL |  | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -20 |  |
| 1 | D inputs | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 | mA |
|  | All other | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |
| Ith | D inputs ${ }^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
|  | All other |  |  |  |  | 20 |  |
| ILL | D inputs ${ }^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.1 | mA |
|  | All other |  |  |  |  | -0.1 |  |
| $10^{8}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | mA |
| ${ }^{\text {I CC }}$ | 'ALS992 |  | Q outputs high |  | 30 | 50 | mA |
|  |  | $V_{C C}=5.5 \mathrm{~V}, \overline{\text { OERB }}$ high | Q outputs low |  | 50 | 80 |  |
|  |  |  | Q outputs disabled |  | 35 | 55 |  |
|  | 'ALS993 | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \overline{\mathrm{OERE}} \mathrm{high}$ | $\overline{\mathrm{O}}$ outputs high |  | 30 | 50 | mA |
|  |  |  | $\overline{\mathrm{O}}$ outputs low |  | 52 | 82 |  |
|  |  |  | Qoutputs disabled |  | 40 | 60 |  |

$\dagger_{\text {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 the true short-circuit output current, IOS.

SN74ALS992, SN74ALS993
9-BIT D-TYPE TRANSPARENT READ-BACK LATCHES
WITH 3-STATE OUTPUTS
'ALS992 switching characteristics (see Figure 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & V_{C C}=5 \mathrm{~V} \\ & C_{L}=50 \mathrm{pF} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIIN | MAX |  |
| tPLH | D | Q |  | 7 | 10 | 3 | 14 | ns |
| tPHL |  |  |  | 9 | 13 | 4 | 16 |  |
| ${ }_{\text {t PLH }}$ | C | 0 |  | 12 | 15 | 6 | 20 | ns |
| tPHL |  |  |  | 15 | 19 | 8 | 25 |  |
| tPHL | $\overline{C L R}$ | Q |  | 12 | 16 | 6 | 20. | ns |
| tPHL |  | D |  | 15 | 22 | 8 | 26 |  |
| $\mathrm{t}_{\text {en }}$ | $\overline{\text { OERB }}$ | D |  | 11 | 17 | 4 | 21 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  |  | 6 | 11 | 2 | 14 |  |
| $\mathrm{t}_{\text {en }}$ | $\overline{O E Q}$ | Q |  | 11 | 16 | 4 | 18 | ns |
| ${ }^{\text {dis }}$ |  |  |  | 6 | 10 | 1 | 14 |  |

'ALS993 switching characteristics (see Figure 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | $\begin{aligned} & V_{C C}=5 \mathrm{~V} \\ & C_{L}=50 \mathrm{pF} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | MAX |  |
| tPLH | D | $\bar{\square}$ |  | 11 | 14 | 6 | 20 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  | 8 | 11 | 4 | 15 |  |
| ${ }^{\text {P PLH }}$ | C | $\overline{\mathrm{Q}}$ |  | 16 | 20 | 9 | 28 | ns |
| tPHL |  |  |  | 13 | 16 | 7 | 22 |  |
| ${ }^{\text {PPLH }}$ | $\overline{C L R}$ | Q |  | 10 | 13 | 5 | 17 | ns |
| tPLH |  | D |  | 15 | 22 | 8 | 26 |  |
| $t_{\text {en }}$ | $\overline{\text { OERB }}$ | D |  | 11 | 17 | 4 | 21 | ns |
| $t_{\text {dis }}$ |  |  |  | 6 | 11 | 2 | 14 |  |
| $\mathrm{t}_{\text {en }}$ | $\overline{O E O}$ | $\overline{\mathrm{Q}}$ |  | 11 | 16 | 4 | 20 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  |  | 6 | 10 | 1 | 12 |  |

$t_{\text {en }}=t_{P Z H}$ or $t_{P Z L}$
$\mathrm{t}_{\mathrm{dis}}=\mathrm{t}_{\mathrm{PHZ}}$ or $\mathrm{t}_{\mathrm{PLZ}}$

## SN74ALS992, SN74ALS993 <br> 9-BIT D-TYPE TRANSPARENT READ-BACK LATCHES WITH 3-STATE OUTPUTS

## PARAMETER MEASUREMENT INFORMATION



LOAD CIRCUIT FOR
Q OR $\overline{\mathbf{Q}}$ OUTPUTS


VOLTAGE WAVEFORMS SETUP AND HOLD TIMES


VOLTAGE WAVEFORMS PROPAGATION DELAY TIMES


LOAD CIRCUIT FOR D OUTPUTS


VOLTAGE WAVEFORMS PULSE WIDTHS


NOTES: A. $C_{L}$ includes probe and jig capacitance.
B. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
C. All input pulses have the following characteristics: PRR $\leq 1 \mathrm{MHz}, \mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=2 \mathrm{~ns}$, duty cycle $=50 \%$.
D. When measuring propagation delay times of 3-state outputs, switch S1 is open.

FIGURE 1

## SN74ALS994, SN74ALS995 <br> 10-BIT D-TYPE TRANSPARENT READ-BACK LATCHES

D2856, OCTOBER 1984-REVISED JANUARY 1986

- 3-State I/O-Type Read-Back Inputs


## - Bus-Structured Pinout

- Choice of True or Inverting Logic 'ALS994 . . . True Outputs 'ALS995 . . . Inverting Outputs
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 10-bit latches are designed specifically for storing the contents of the input data bus plus providing the capability of reading-back the stored data onto the input data bus.
The ten latches of the 'ALS994 and 'ALS995 are transparent $D$-type. While the enable ( $C$ ) is high, the Q outputs of the 'ALS994 will follow the data (D) inputs. For the 'ALS995, the Q outputs will provide the inverse of what is applied to its data (D) inputs.

Read-back is provided through the read-back control input ( $\overline{\mathrm{OERB}}$ ). When the control is taken low, the data present at the output of the data latches will be allowed to pass back onto the input data bus. When it is taken high, the output of the data latches will be isolated from the data (D) inputs. The read-back control does not affect the internal operation of the latches; however, precautions should be taken not to create a busconflict situation.
The SN74ALS994 and SN74ALS995 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

SN74ALS994 . . . DW OR NT PACKAGE (TOP VIEW)
OERB $\square 1$
1D $\square 24$
2D $\square V_{\mathrm{C}}$
3D $\square$

SN74ALS994 . . . FN PACKAGE (TOP VIEW)


## SN74ALS994, SN74ALS995

## 10-BIT D-TYPE TRANSPARENT READ-BACK LATCHES

SN74ALS995 . . . DW OR NT PACKAGE
(TOP VIEW)

| $\overline{O E R B} \square^{1}$ | $\bigcirc_{24}$ | $\mathrm{V}_{\mathrm{CC}}$ |
| :---: | :---: | :---: |
| 10 2 | 23 | $1{ }^{1}$ |
| 2D ${ }^{3}$ | 22 | $2 \overline{0}$ |
| 3D 4 | 21 |  |
| 4D 5 | 20 | - 4 |
| 5D 6 | 19 | $50{ }^{\circ}$ |
| $6 \mathrm{\square} 7$ | 18 | $6 \bar{\square}$ |
| 70 8 | 17 | 70 |
| 8D 9 | 16 | $8 \overline{0}$ |
| 90-10 | 15 | $9 \overline{0}$ |
| 100 11 | 14 | $10 \overline{0}$ |
| GND 12 | 13 | ] C |

NC - No internal connection

SN74ALS995 . . . FN PACKAGE (TOP VIEW)

logic symbols ${ }^{\dagger}$
‘ALS994

'ALS995

${ }^{\dagger}$ These symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers shown are for DW and NT packages.

SN74ALS994, SN74ALS995 10-BIT D-TYPE TRANSPARENT READ-BACK LATCHES


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

${ }^{\dagger}$ This setup time ensures the readback circuit will not create a conflict on the input data bus.
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
$\qquad$
Supply voltage, VCC
Voltage applied to $D$ inputs
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}_{\text {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 |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | High-level output current | Q or $\overline{\mathrm{Q}}$ |  |  | -2.6 | mA |
|  |  | D |  |  | -0.4 |  |
| ${ }^{\text {I OL }}$ | Low-level output current | Q or $\overline{\mathrm{Q}}$ |  |  | 24 | mA |
|  |  | D |  |  | 8 |  |
| $\mathrm{t}_{\mathrm{w}}$ | Pulse duration, enable C high |  | 10 |  |  | ns |
| ${ }^{\text {tsu }}$ | Setup time | Data before $\mathrm{C} \downarrow$ | 10 |  |  | ns |
|  |  | Data before $\overline{\text { OERB }} \downarrow^{\dagger}$ | 10 |  |  |  |
| th | Hold time | Input data after $\mathrm{C} \downarrow$ | 5 |  |  | ns |
| $\mathrm{T}_{\mathrm{A}}$ | Operating free-air temperature |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

${ }^{\dagger}$ This setup time ensures the readback circuit will not create a conflict on the input data bus.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)


[^65]
## SN74ALS994, SN74ALS995 <br> 10-BIT D-TYPE TRANSPARENT READ-BACK LATCHES

'ALS994 switching characteristics (see Figure 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | MAX |  |
| tpLH | D | - 0 |  | 7 | 10 | 3 | 14 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  | 11 | 15 | 4 | 18 |  |
| tPLH | C | 0 |  | 12 | 16 | 6 | 21 | ṅs |
| ${ }^{\text {tPHL }}$ |  |  |  | 16 | 21 | 8 | 27 |  |
| $\mathrm{t}_{\text {en }}$ | $\overline{\text { OERB }}$ | D |  | 11 | 17 | 4 | 21 | ns |
| ${ }^{\text {dis }}$ |  |  |  | 9 | 13 | 2 | 16 |  |

'ALS995 switching characteristics (see Figure 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | MAX |  |
| tPLH | D | $\overline{\mathrm{o}}$ |  | 12 | 16 | 6 | 20 | ns |
| tPHL |  |  |  | 9 | 12 | 4 | 15 |  |
| tPLH | C | $\overline{\mathrm{o}}$ |  | 17 | 23 | 9 | 28 | ns |
| tPHL |  |  |  | 14 | 19 | 7 | 22 |  |
| $\mathrm{t}_{\text {en }}$ | $\overline{\text { OERB }}$ | D |  | 12 | 18 | 4 | 21 | ns |
| ${ }^{\text {dis }}$ |  |  |  | 8 | 12 | 2 | 15 |  |

$t_{\text {en }}=$ tPZH or tPZL
$\mathrm{t}_{\mathrm{dis}}=\mathrm{tPHZ}^{\text {or }}$ tPLZ

## PARAMETER MEASUREMENT INFORMATION



LOAD CIRCUIT FOR Q OR $\overline{0}$ OUTPUTS


LOAD CIRCUIT FOR D OUTPUTS


VOLTAGE WAVEFORMS
SETUP AND HOLD TIMES


VOLTAGE WAVEFORMS PROPAGATION DELAY TIMES


VOLTAGE WAVEFORMS PULSE WIDTHS


VOLTAGE WAVEFORMS
ENABLE AND DISABLE TIMES, THREE-STATE OUTPUTS

NOTES: A. $C_{L}$ includes probe and jig capacitance.
B. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
C. All input pulses have the following characteristics: PRR $\leq 1 \mathrm{MHz}, \mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=2 \mathrm{~ns}$, duty cycle $=50 \%$.
D. When measuring propagation delay times of 3 -state outputs, switch S1 is open.

FIGURE 1

- 3-State I/O-Type Read-Back Inputs
- Bus-Structured Pinout
- $\mathrm{T} / \overline{\mathrm{C}}$ Determines True or Complementary Data at Q Outputs
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 8-bit registers are designed specifically for storing the contents of the input data bus plus providing the capability of reading-back the stored data onto that bus. The Q outputs are designed with bus-driving capability.

The edge-triggered flip-flops enter the data on the low-to-high transition of the clock (CLK) when enable ( $\overline{E N}$ ) is low. Data can be read-back onto the data inputs by taking the read input ( $\overline{\mathrm{RD}}$ ) low, in addition to having $\overline{E N}$ low. Whenever $\overline{E N}$ is high, both the read-back and write modes are disabled. Transitions on $\overline{E N}$ should only be made with CLK high in order to prevent false clocking.

The polarity of the Q outputs can be controlled by the polarity input $T / \overline{\mathrm{C}}$. When $\mathrm{T} / \overline{\mathrm{C}}$ is high, Q will be the same as is stored in the flip-flops. When $T / \bar{C}$ is low, the output data will be inverted. The $Q$ outputs can be placed in a highimpedance state by taking the output control ( $\overline{\mathrm{G}}$ ) high. The output control $\overline{\mathrm{G}}$ does not affect the internal operations of the register. Old data can be retained or new data can be entered while the outputs are off.

A low level at the clear input ( $\overline{\mathrm{CLR}}$ ) resets the internal registers low. The clear function is asynchronous and overrides all other register functions.

The -1 version of the SN74ALS996 is identical to the standard version except that the recommended maximum IOL is increased to 48 milliamperes.

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

## 8-BIT D-TYPE EDGE-TRIGGERED READ-BACK LATCHES

logic symbol ${ }^{\dagger}$

${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
logic diagram (positive logic)


Pin numbers shown are for DW and NT packages.


## 8-BIT D-TYPE EDGE-TRIGGERED READ-BACK LATCHES

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, $\frac{V_{C C}}{} \cdot \ldots \ldots . .$.
Input voltage ( $\overline{\mathrm{G}}, \overline{\mathrm{RD}}, \overline{\mathrm{EN}}, \mathrm{CLK}, \overline{\mathrm{CLR}}$, and $\mathrm{T} / \overline{\mathrm{C}}$ ) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Voltage applied to D inputs and to disabled 3 -state outputs . . . . . . . . . . . . . . . . . . . . . . . . . . 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 |
| ${ }^{1} \mathrm{OH}$ | High-level output current | 0 |  |  | 2.6 | mA |
|  |  | D |  |  | -0.4 |  |
| ${ }^{\text {IOL }}$ | Low-level output current | 0 |  |  | 24 | mA |
|  |  |  |  |  | $48^{\dagger}$ |  |
|  |  | D |  |  | 8 |  |
| ${ }^{\text {f clock }}$ | Clock frequency |  | 0 |  | 35 | MHz |
| ${ }^{\text {tw }}$ | Pulse duration | $\overline{\mathrm{CLR}}$ low | 10 |  |  | ns |
|  |  | CLK low | 14.5 |  |  |  |
|  |  | CLK high | 14.5 |  |  |  |
| ${ }^{\text {tsu }}$ | Setup time | Data before CLK $\uparrow$ | 15 |  |  | ns |
|  |  | $\overline{\text { EN }}$ low before CLK $\uparrow$ | 10 |  |  |  |
|  |  | CLK high before $\overline{\mathrm{EN}} \uparrow^{\ddagger}$ | 15 |  |  |  |
|  |  | $\overline{\mathrm{CLR}}$ high (inactive) before CLK $\dagger$ | 10 |  |  |  |
| $t^{\text {h }}$ | Hoid time | Data after CLK $\uparrow$ | 0 |  |  | ns |
|  |  | EN low after CLK $\uparrow$ | 5 |  |  |  |
|  |  | $\overline{\mathrm{RD}}$ high after CLK ${ }^{\text {¢ }}$ § | 5 |  |  |  |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

[^66]
## SN74ALS996 8-BIT D-TYPE EDGE-TRIGGERED READ-BACK LATCHES

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

| PARAMETER |  | TEST CONDITIONS |  | MIN | TYP ${ }^{\text {¢ }}$ | MAX | $\frac{\mathrm{UNIT}}{\mathrm{~V}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IK }}$ |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $1=-18 \mathrm{~mA}$ |  |  | -1.2 |  |
|  | All outputs | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, 1 \mathrm{OH}=-0.4 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
| $\mathrm{V}^{\text {OH }}$ | 0 | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-2.6 \mathrm{~mA}$ | 2.4 | 3.2 |  |  |
| $\mathrm{V}_{\text {OL }}$ | D | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | ${ }^{1} \mathrm{OL}=4 \mathrm{~mA}$ |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=8 \mathrm{~mA}$ |  | 0.35 | 0.5 |  |
|  | Q | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=12 \mathrm{~mA}$ |  | 0.25 | 0.4 |  |
|  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=48 \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{I} \mathrm{OL}=24 \mathrm{~mA} \\ & \text { versions) } \end{aligned}$ |  | 0.35 | 0.5 |  |
| ${ }^{1} \mathrm{OZH}$ | 0 | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
| IOZL |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -20 |  |
| 4 | D inputs | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 | mA |
|  | All others | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |
| $\mathrm{I}_{\mathrm{IH}}$ | D inputs ${ }^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \quad \mathrm{~V}_{1}=2.7 \mathrm{~V}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
|  | All others |  |  |  |  | 20 |  |
|  | D inputs ${ }^{\ddagger}$ | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=0.4 \mathrm{~V}$ |  |  |  | -0.1 | mA |
| IL | All others | $V_{C C}=5.5 \mathrm{~V}, \quad V_{1}=0.4 \mathrm{~V}$ |  |  |  | -0.1 |  |
| $10^{\S}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | mA |
| ${ }^{\prime} \mathrm{CC}$ |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \\ & \overline{\mathrm{OERB}} \text { high } \end{aligned}$ | Q outputs high |  | 35 | 55 | mA |
|  |  | Q outputs low |  | 55 | 85 |  |
|  |  | Q outputs disabled |  | 42 | 65 |  |

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

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & V_{C C}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & C_{L}=50 \mathrm{pF}, \\ & \mathrm{~T}_{A}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | MAX |  |
| $f_{\text {max }}$ |  |  |  | 40 |  | 35 |  | MHz |
| tpLH | $\begin{gathered} \text { CLK } \\ (\mathrm{T} / \overline{\mathrm{C}}=\mathrm{H} \text { or } \mathrm{L}) \end{gathered}$ | Q |  | 16 | 24 | 5 | 28 | ns |
| tPHL |  |  |  | 16 | 24 | 5 | 28 |  |
| tpliH | $\overline{\mathrm{CLR}}(\mathrm{T} / \overline{\mathrm{C}}=\mathrm{L})$ | Q |  | 15 | 23 | 7 | 27 | ns |
| ${ }^{\text {tPHL }}$ | $\overline{\mathrm{CLR}}(\mathrm{T} / \overline{\mathrm{C}}=\mathrm{H})$ |  |  | 13 | 19 | 7 | 23 |  |
| tPLH | T/ $\bar{C}$ | Q |  | 13 | 20 | 5 | 23 | ns |
| tPHL |  |  |  | 13 | 20 | 5 | 23 |  |
| tPHL | $\overline{\text { CLR }}$ | D |  | 19 | 25 | 8 | 30 | ns |
| $\mathrm{t}_{\text {en }}$ | $\overline{\mathrm{RD}}$ | D |  | 9 | 15 | 3 | 16 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  |  | 10 | 16 | 3 | 19 |  |
| $\mathrm{t}_{\text {en }}$ | EN | D |  | 9 | 14 | 3 | 16 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  |  | 10 | 16 | 3 | 19 |  |
| $\mathrm{t}_{\mathrm{en}}$ | $\overline{\mathrm{G}}$ | Q |  | 8 | 13 | 4 | 15 | ns |
| $\mathrm{t}_{\text {dis }}$ |  |  |  | 4 | 8 | 1 | 10 |  |

[^67]$t_{\text {dis }}=t^{t} \mathrm{HZ}$ or $\mathrm{t}_{\mathrm{PL}} \mathrm{Z}$

## PARAMETER MEASUREMENT INFORMATION



LOAD CIRCUIT FOR Q OUTPUTS


VOLTAGE WAVEFORMS SETUP AND HOLD TIMES


VOLTAGE WAVEFORMS PROPAGATION DELAY TIMES


LOAD CIRCUIT FOR D OUTPUTS


VOLTAGE WAVEFORMS PULSE WIDTHS


VOLTAGE WAVEFORMS
ENABLE AND DISABLE TIMES, THREE-STATE OUTPUTS

NOTES: $A . C_{L}$ includes probe and jig capacitance.
B. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
C. All input pulses have the following characteristics: PRR $\leq 1 \mathrm{MHz}, \mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=2 \mathrm{~ns}$, duty cycle $=50 \%$.
D. When measuring propagation delay times of 3-state outputs, switch S1 is open.

FIGURE 1

## SN54AS1181, SN74AS1181 ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS

- Package Options Include Compact 300-mil or Standard 600-mil DIPs and Both Plastic and Ceramic Chip Carriers
- Full Look-Ahead for High-Speed Operations on Long Words
- Arithmetic Operating Modes:

Addition
Subtraction
Shift Operand A One Position
Magnitude Comparison
Plus Twelve Other Arithmetic Operations

- Logic Function Modes

Exclusive-OR
Comparator
AND, NAND, OR, NOR

- Dependable Texas Instruments Quality and Reliability
logic symbol ${ }^{\dagger}$


SN54AS1181 . . . JT OR JW PACKAGE
SN74AS1181 . . DW, NT, OR NW PACKAGE
(TOP VIEW)


> SN54AS1181 . . FK PACKAGE SN74AS1181 . . FN PACKAGE (TOP VIEW)


NC-No internal connection
${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers shown are for DW, JT, JW, NT, and NW packages.
TYPICAL ADDITION TIMES $C_{\mathrm{L}}=15 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=280 \Omega, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| NUMBER OF BITS | ADDITION TIMES |  |  | PACKAGE COUNT |  | CARRY METHOD BETWEEN ALUs |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | USING 'AS1181 <br> AND'AS882 | USING 'AS181A <br> AND 'AS882 | USING 'S181 AND 'S182 | ARITHMETIC LOGIC UNITS | LOOK-AHEAD CARRY GENERATORS |  |
| 1 to 4 | 5 ns | 5 ns | 11 ns | 1 |  | NONE |
| 5 to 8 | 10 ns | 10 ns | 18 ns | 2 |  | RIPPLE |
| 9 to 16 | 14 ns | 14 ns | 19 ns | 3 or 4 | 1 | FULL LOOK-AHEAD |
| 17 to 64 | 19 ns | 19 ns | 28 ns | 5 to 16 | 2 to 5 | FULL LOOK-AHEAD |

## description

The 'AS1181 arithmetic logic units (ALU)/function generators have a complexity of 75 equivalent gates on a monolithic chip. These circuits perform 16 binary arithmetic operations on two 4-bit words as shown in Tables 1 and 2. These operations are selected by the four function-select lines (S0, S1, S2, S3) and include addition, subtraction, decrement, and straight transfer. When performing arithmetic manipulations, the internal carries must be enabled by applying a low-level voltage to the mode control input (M). A full carry look-ahead scheme is made available in these devices for fast, simultaneous carry generation by means of two cascade-outputs (pins 15 and 17) for the four bits in the package. When used in conjunction with the SN54AS882 or SN74AS882 full carry look-ahead circuits, high-speed arithmetic operations can be performed. The typical addition times shown previously illustrate the little additional time required for addition of longer words when full carry look-ahead is employed. The method of cascading 'AS882 circuits with these ALUs to provide multilevel full carry look-ahead is illustrated under signal designations.

If high speed is not of importance, a ripple-carry input ( $C_{n}$ ) and a ripple-carry output ( $C_{n}+4$ ) are available. However, the ripple-carry delay has also been minimized so that arithmetic manipulations for small word lengths can be performed without external circuitry.

The 'AS1181 will accommodate active-high or active-low data if the pin designations are interpreted as follows:

| PIN NUMBER | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{2 3}$ | $\mathbf{2 2}$ | $\mathbf{2 1}$ | $\mathbf{2 0}$ | $\mathbf{1 9}$ | $\mathbf{1 8}$ | $\mathbf{9}$ | $\mathbf{1 0}$ | $\mathbf{1 1}$ | $\mathbf{1 3}$ | $\mathbf{7}$ | $\mathbf{1 6}$ | $\mathbf{1 5}$ | $\mathbf{1 7}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Active-low data (Table 1) | $\overline{\mathrm{A}} 0$ | $\overline{\mathrm{~B}} 0$ | $\overline{\mathrm{~A}} 1$ | $\overline{\mathrm{~B}} 1$ | $\overline{\mathrm{~A}} 2$ | $\overline{\mathrm{~B}} 2$ | $\overline{\mathrm{~A}} 3$ | $\overline{\mathrm{~B}} 3$ | $\overline{\mathrm{~F}} 0$ | $\overline{\mathrm{~F}} 1$ | $\overline{\mathrm{~F}} 2$ | $\overline{\mathrm{~F}} 3$ | $\mathrm{C}_{n}$ | $\mathrm{C}_{n}+4$ | $\overline{\mathrm{P}}$ | $\overline{\mathrm{G}}$ |
| Active-high data (Table 2) | A 0 | B 0 | A 1 | B 1 | A 2 | B 2 | A 3 | B 3 | F 0 | F 1 | F 2 | F 3 | $\overline{\mathrm{C}}_{n}$ | $\overline{\mathrm{C}}_{\mathrm{n}}+4$ | X | Y |

Subtraction is accomplished by 1 's complement addition where the 1 's complement of the subtrahend is generated internally. The resultant output is $A-B-1$, which requires an end-around or forced carry to provide $A-B$.

The 'AS1 181 can also be utilized as a comparator. The $\mathrm{A}=\mathrm{B}$ output is internally decoded from the function outputs (F0, F1, F2, F3) so that when two words of equal magnitude are applied at the A and B inputs, it will assume a high level to indicate equality $(A=B)$. The $A L U$ must be in the subtract mode with $C_{n}=H$ when performing this comparison. The $A=B$ output is open-collector so that it can be wired-AND connected to give a comparison for more than four bits. The carry output ( $C_{n}+4$ ) can also be used to supply relative magnitude information. Again, the ALU must be placed in the subtract mode by placing the function select input S3, S2, S1, S0 at L, H, H, L, respectively.

| INPUT $\mathrm{C}_{\mathbf{n}}$ | OUTPUT $\mathrm{C}_{\mathbf{n}}+\mathbf{4}$ | ACTIVE-LOW DATA <br> (FIGURE 1) | ACTIVE-HIGH DATA <br> (FIGURE 2) |
| :---: | :---: | :---: | :---: |
| H | H | $\mathrm{A} \geq \mathrm{B}$ | $\mathrm{A} \leq \mathrm{B}$ |
| H | L | $\mathrm{A}<\mathrm{B}$ | $\mathrm{A}>\mathrm{B}$ |
| L | H | $\mathrm{A}>\mathrm{B}$ | $\mathrm{A}<\mathrm{B}$ |
| L | L | $\mathrm{A} \leq \mathrm{B}$ | $\mathrm{A} \geq \mathrm{B}$ |

These circuits have been designed to not only incorporate all of the designer's requirements for arithmetic operations, but also to provide 16 possible functions of two Boolean variables without the use of external circuitry. These logic functions are selected by use of the four function-select inputs (S0, S1, S2, S3) with the mode-control input (M) at a high level to disable the internal carry. The 16 logic functions are detailed in Tables 1 and 2 and include exclusive-OR, NAND, AND, NOR, and OR functions.

## SN54AS1181, SN74AS1181 ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS

## signal designations

In both Figures 1 and 2, the polarity indicators ( $\Delta$ ) indicate that the associated input or output is activelow with respect to the function shown inside the symbol and the symbols are the same in both figures. The signal designations in Figure 1 agree with the indicated internal functions based on active-low data, and are for use with the logic functions and arithmetic operations shown in Table 1. The signal designations have been changed in Figure 2 to accommodate the logic functions and arithmetic operations for the activehigh data given in Table 2. The 'AS1181 together with 'AS882 and 'S182 can be used with the signal designation of either Figure 1 or Figure 2.


FIGURE 1 (USE WITH TABLE 1)


FIGURE 2
(USE WITH TABLE 2)

Pin numbers shown for the 'AS1181 are for DW, JT, JW, NT, and NW packages.

TABLE 1


TABLE 2

| SELECTION |  |  |  | ACTIVE.HIGH DATA |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\begin{aligned} & M=H \\ & \text { LOGIC } \end{aligned}$ <br> FUNCTIONS | M = L; ARITHMETIC OPERATIONS |  |
| S3 S | S2 | S1 |  |  | $\overline{\mathrm{C}}_{n}=H$ <br> (no carry) | $\bar{C}_{n}=L$ <br> (with carry) |
| L | L | L | L | $F=\bar{A}$ | $F=A$ | $F=A$ PLUS 1 |
| L | L | L |  | $F=\overline{A+B}$ | $F=A+B$ | $F=(A+B)$ PLUS 1 |
| L | L | H |  | $F=\bar{A} B$ | $F=A+\bar{B}$ | $F=(A+\bar{B})$ PLUS $i^{\prime}$ |
| L | L | H |  | $F=0$ | $F=$ MINUS 1 (2's COMPL) | $F=Z E R O$ |
| L | H | L |  | $F=\overline{A B}$ | $F=A P L U S A \bar{B}$ | $F=A P L U S A \bar{B} P L U S 1$ |
| L H | H | $L$ |  | $F=\bar{B}$ | $F=(A+B) P L U S A \bar{B}$ | $F=(A+B)$ PLUS $A \bar{B}$ PLUS 1 |
| L | H | H |  | $F=A \oplus B$ | $F=A$ MINUS B MINUS 1 | $F=A$ MINUS $B$ |
| L | H | H |  | $F=A \bar{B}$ | $F=A \bar{B}$ MINUS 1 | $F=A \bar{B}$ |
|  | L | L |  | $F=\bar{A}+B$ | $F=A P L U S A B$ | $F=A$ PLUS AB PLUS 1 |
| H | $L$ | L |  | $F=A \oplus B$ | $F=A P L U S B$ | $F=A$ PLUS B PLUS 1 |
|  | $L$ | H | L | $F=B$ | $F=(A+\bar{B})$ PLUS $A B$ | $F=(A+\bar{B})$ PLUS $A B$ PLUS 1 |
| H | L | H | H | $F=A B$ | $F=A B$ MINUS 1 | $F=A B$ |
| H | H | L |  | $F=1$ | $F=A P L U S A^{\dagger}$ | $F=A$ PLU̇S A PLUS 1 |
| H | H | L |  | $F=A+\bar{B}$ | $F=(A+B) P$ PUS $A$ | $F=(A+B) P$ PLUS A PLUS 1 |
| H | H | H | L | $F=A+B$ | $F=(A+\bar{B})$ PLUS $A$ | $F=(A+\bar{B})$ PLUS A PLUS 1 |
| H | H | H | H | $F=A$ | $F=A$ MINUS 1 | $F=A$ |

${ }^{\dagger}$ Each bit is shifted to the next more significant position.
logic diagram (positive logic)
'AS1181


## SN54AS1181, SN74AS1181 ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS

## absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

Supply voltage, VCC ..... 7 V
Input voltage ..... 7 V
Off-state output voltge ( $\mathrm{A}=\mathrm{B}$ output only) ..... 7 V
Operating free-air temperature range: SN54AS1181 ..... $55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
SN74AS1181 ..... $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range ..... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

## recommended operating conditions

|  |  |  | SN54AS1181 |  |  | SN74AS1181 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltáge |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | $\mathrm{A}=\mathrm{B}$ output only |  |  | 5.5 |  |  | 5.5 | V |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | High-level output current | All outputs except $\mathrm{A}=\mathrm{B} \text { and } \overline{\mathrm{G}}$ |  |  | -2 |  |  | -2 | mA |
|  |  | $\overline{\mathrm{G}}$ output |  |  | -3 |  |  | -3 | mA |
| ${ }^{1} \mathrm{OL}$ | Low-level output current | All outputs except $\overline{\mathrm{G}}$ |  |  | 20 |  |  | 20 | mA |
|  |  | $\overline{\mathrm{G}}$ output |  |  | 48 |  |  | 48 | mA |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

SN54AS1181, SN74AS1181 ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS |  | SN54AS1181 |  |  | SN74AS1181 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $y_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| VOH | Any output except $A=B$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{l}^{\mathrm{OH}}=-2 \mathrm{~mA}$ |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  | $\overline{\mathrm{G}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA}$ | 2.4 | 3 |  | 2.4 | 3 |  | V |
| ${ }^{1} \mathrm{OH}$ | $A=8$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| $\mathrm{V}_{\mathrm{OL}}$ | Any output except $\overline{\mathrm{G}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad \mathrm{OL}=20 \mathrm{~mA}$ |  |  | 0.3 | 0.5 |  | 0.3 | 0.5 | V |
|  | $\overline{\mathrm{G}}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=48 \mathrm{~mA}$ |  | 0.4 | 0.5 |  | 0.4 | 0.5 | V |
| 1 | M input | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
|  | Any A or B input |  |  |  |  | 0.3 |  |  | 0.3 |  |
|  | Any S input |  |  |  |  | 0.4 |  |  | 0.4 |  |
|  | Carry input |  |  |  |  | 0.6 |  |  | 0.6 |  |
| IIH | M input | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $V_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | Any A or B input |  |  |  |  | 60 |  |  | 60 |  |
|  | Any S input |  |  |  |  | 80 |  |  | 80 |  |
|  | Carry input |  |  |  |  | 120 |  |  | 120 |  |
| IL | $M$ input | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.5 |  |  | -0.5 | mA |
|  | Any A or B input |  |  |  |  | -1.5 |  |  | -1.5 |  |
|  | Any S input |  |  |  |  | -2 |  |  | -2 |  |
|  | Carry input |  |  |  |  | -3 |  |  | -3 |  |
| $10^{\ddagger}$ | All outputs except $\mathrm{A}=\mathrm{B} \text { and } \overline{\mathrm{G}}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
|  | $\overline{\mathrm{G}}$ |  |  | -30 |  | -125 | -30 |  | -125 |  |
| ICC |  | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$ |  |  | 74 | 117 |  | 74 | 117 | 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.

## SN54AS1181, SN74AS1181 ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS

switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS | $\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}_{\mathrm{L}}=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | SN54AS1181 |  | SN74AS1181 |  |  |
|  |  |  |  | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {tPLH }}$ | $\mathrm{C}_{n}$ | $C_{n+4}$ |  | 3 | 9 | 3 | 8.5 | ns |
| tPHL |  |  |  | 2 | 7 | 2 | 6.5 |  |
| ${ }^{\text {tPLH }}$ | $\overline{\text { Any }}$ | $C_{n+4}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=0 \mathrm{~V}, \\ & \mathrm{SO}=\mathrm{S} 3=4.5 \vee(\overline{\mathrm{SUM}} \text { mode }) \end{aligned}$ | 3.5 | 13 | 5 | 12 | ns |
| ${ }_{\text {t }}$ PHL |  |  |  | 3.5 | 12.5 | 5 | 12 |  |
| tPLH | Any $\bar{A}$ or $\bar{B}$ | $C_{n+4}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 0=\mathrm{S} 3=0 \mathrm{~V} \\ & \mathrm{~S} 1=\mathrm{S} 2=4.5 \vee(\overline{\mathrm{DIFF}} \text { mode }) \end{aligned}$ | 5 | 14.5 | 5 | 13 | ns |
| tPHL |  |  |  | 5 | 13.5 | 5 | 12.5 |  |
| tPLH | $\mathrm{C}_{\mathrm{n}}$ | Any $\overline{\mathrm{F}}$ | $M=0 \vee(\overline{S U M}$ or $\overline{\text { DIFF }}$ mode) | 3 | 10.5 | 3 | 9 | ns |
| tPHL |  |  |  | 3 | 8 | 3 | 7.5 |  |
| tPLH | Any $\bar{A}$ or $\bar{B}$ | $\overline{\mathrm{G}}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=0 \mathrm{~V} \\ & \mathrm{SO}=\mathrm{S} 3=4.5 \vee(\overline{\mathrm{SUM}} \text { mode) } \end{aligned}$ | 3 | 8.5 | 3 | 8 | ns |
| tPHL |  |  |  | 2 | 7 | 2 | 6 |  |
| tPLH | $\overline{A n y}$ | $\overline{\mathrm{G}}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{SO}=\mathrm{S} 3=0 \mathrm{~V}, \\ & \mathrm{~S} 1=\mathrm{S} 2=4.5 \mathrm{~V}(\overline{\mathrm{DIFF}} \text { mode }) \end{aligned}$ | 3 | 10.5 | 3 | 9.5 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 2 | 9 | 2 | 7 |  |
| tPLH | $\overline{A n y} \overline{\mathrm{~A}} \text { or } \overline{\mathrm{B}}$ | $\bar{P}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=0 \mathrm{~V}, \\ & S 0=S 3=4.5 \vee(\mathrm{SUM} \text { mode }) \end{aligned}$ | 3 | 8.5 | 3 | 7.5 | ns |
| tPHL |  |  |  | 2 | 7.5 | 2 | 6 |  |
| tPLH | Any <br> $\bar{A}$ or $\bar{B}$ | $\overline{\mathrm{P}}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{SO}=\mathrm{S} 3=0 \mathrm{~V}, \\ & \mathrm{~S} 1=\mathrm{S} 2=4.5 \mathrm{~V}(\overline{\mathrm{DIFF}} \text { mode }) \end{aligned}$ | 3 | 10.5 | 3 | 9 | ns |
| tPHL |  |  |  | 3 | 8.5 | 3 | 8 |  |
| tPLH | $\begin{gathered} \overline{\bar{A} i} \mathrm{i} \text { or } \\ \overline{\mathrm{B}} \mathrm{i} \end{gathered}$ | $\overline{\mathrm{Fi}}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=\mathrm{OV}, \\ & \mathrm{~S} 0=\mathrm{S} 3=4.5 \vee(\overline{\mathrm{SUM}} \text { mode }) \end{aligned}$ | 3 | 11 | 3 | 9.5 | ns |
| tPHL |  |  |  | 3 | 9 | 3 | 7.5 |  |
| tPLH | $\begin{gathered} \overline{\mathrm{A} i} \text { or } \\ \overline{\mathrm{Bi}} \end{gathered}$ | $\overline{\mathrm{Fi}}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{SO}=\mathrm{S} 3=\mathrm{OV} \\ & \mathrm{~S} 1=\mathrm{S} 2=4.5 \vee(\overline{\mathrm{DIFF}} \text { mode }) \end{aligned}$ | 3 | 12 | 3 | 10.5 | ns |
| tPHL |  |  |  | 3 | . 11 | 3 | 9.5 |  |
| ${ }^{\text {tPLH }}$ | Any <br> $\bar{A}$ or $\bar{B}$ | Any $\overline{\mathrm{F}}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=0 \mathrm{~V}, \\ & \mathrm{SO}=\mathrm{S} 3=4.5 \mathrm{~V}(\overline{\mathrm{SUM}} \text { mode }) \end{aligned}$ | 3 | 13.5 | 3 | 12 | ns |
| tPHL |  |  |  | 3 | 13 | 3 | 11.5 |  |
| tPLH | Any $\bar{A}$ or $\bar{B}$ | Any $\overline{\mathrm{F}}$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 0=\mathrm{S} 3=0 \mathrm{~V} \\ & \mathrm{~S} 1=\mathrm{S} 2=4.5 \mathrm{~V}(\overline{\mathrm{DIFF}} \text { mode }) \end{aligned}$ | 3 | 16 | 3 | 14.5 | ns |
| tPHL |  |  |  | 3 | 13 | 3 | 12.5 |  |
| ${ }_{\text {tPLH }}$ | $\begin{gathered} \overline{\mathrm{A} i} \text { or } \\ \overline{\mathrm{B} i} \end{gathered}$ | $\overline{\mathrm{Fi}}$ | $\mathrm{M}=4.5 \mathrm{~V}$ (LOGIC mode) | 3 | 12.5 | 3 | 11 | ns |
| ${ }^{\text {t PHL }}$ |  |  |  | 3 | 10 | 3 | 9.5 |  |
| tPLH | Any $\bar{A}$ or $\bar{B}$ | $A=B$ | $\begin{aligned} & \mathrm{M}=0 \mathrm{~V}, \mathrm{~S} 0=\mathrm{S} 3=0 \mathrm{~V}, \\ & \mathrm{~S} 1=\mathrm{S} 2=4.5 \mathrm{~V}(\overline{\mathrm{DIFF}} \text { mode }) \end{aligned}$ | 4 | 19 | 4 | 17 | ns |
| tPHL |  |  |  | 5 | 18.5 | 5 | 15 |  |
| ${ }_{\text {tPLH }}$ | Any S | Any $\overline{\mathrm{F}}$ | $\mathrm{M}=0 \mathrm{~V}(\overline{\text { ARITH }}$ mode $)$ | 3 | 12.5 | 3 | 11 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  | 3 | 11.5 | 3 | 11 |  |
| tPLH | Any S | $A=B$ | $M=0 \mathrm{~V}(\overline{\text { ARITH }}$ mode $)$ | 5 | 20 | 5 | 18 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  | 5 | 21 | 5 | 18 |  |
| tPLH | Any S | $C_{n+4}$ | $\mathrm{M}=4.5 \mathrm{~V}$ (LOGIC mode) | 2 | 16.5 | 4.5 | 15.5 | ns |
| tPHL |  |  |  | 3 | 12.5 | 3 | 12 |  |
| ${ }^{\text {tPLH }}$ | Any S | $\overline{\mathrm{G}}$ | $M=0 \mathrm{~V}(\overline{\text { ARITH }}$ mode $)$ | 3 | 9.5 | 3 | 9 | ns |
| tPHL |  |  |  | 2 | 6.5 | 2 | 6 |  |
| ${ }^{\text {tPLH }}$ | Any S | $\overline{\mathrm{P}}$ | $\mathrm{M}=4.5 \mathrm{~V}$ (LOGIC mode) | 3 | 8.5 | 3 | 7.5 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  | 2 | 6.5 | 2 | 6.5 |  |
| ${ }^{\text {tPLH }}$ | M | Any $\overline{\mathrm{F}}$ | $\begin{aligned} & \mathrm{S} 1=\mathrm{S} 2=0 \mathrm{~V}, \\ & \mathrm{~S} 0=\mathrm{S} 3=4.5 \mathrm{~V} \quad(\overline{\mathrm{SUM}} \text { mode }) \end{aligned}$ | 5 | 12 | 5 | 11.5 | ns |
| tPHL |  |  |  | 5 | 12 | 5 | 11.5 |  |
| ${ }_{\text {tPLH }}$ | M | $A=B$ | $\begin{aligned} & \mathrm{S} 1=\mathrm{S} 2=0 \mathrm{~V}, \\ & \mathrm{SO}=\mathrm{S} 3=4.5 \mathrm{~V} \quad(\overline{\mathrm{SUM}} \text { mode) } \end{aligned}$ | 7 | 19 | 7 | 17.5 | ns |
| ${ }_{\text {t }}$ PHL |  |  |  | 8 | 21 | 8 | 17.5 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## PARAMETER MEASUREMENT INFORMATION

SUM MODE TEST TABLE
FUNCTION INPUTS: $\mathrm{SO}=\mathrm{S} 3=4.5 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=\mathrm{M}=0 \mathrm{~V}$

| PARAMETER | INPUT <br> UNDER <br> TEST | OTHER INPUT SAME BIT |  | OTHER DATA INPUTS |  | OUTPUT <br> UNDER <br> TEST | OUTPUT WAVEFORM (SEE NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | APPLY $4.5 \mathrm{~V}$ | APPLY GND | APPLY $4.5 \mathrm{~V}$ | APPLY GND |  |  |
| ${ }^{\text {tPLH }}$ | $\overline{\mathrm{A}} \mathrm{i}$ | $\bar{B} \mathrm{i}$ | None | Remaining $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}$ | $\mathrm{C}_{n}$ | $\overline{\mathrm{Fi}}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ | $\bar{B} i$ | $\bar{A} i$ | None | Remaining $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}$ | $\mathrm{C}_{\mathrm{n}}$ | $\overline{\mathrm{Fi}}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ | $\overline{\mathrm{A}} \mathrm{i}$ | $\overline{\mathrm{B}} \mathrm{i}$ | None | None | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | $\overline{\mathrm{P}}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}} \mathrm{i}$ | $\overline{\mathrm{A}} \mathrm{i}$ | None | None | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | $\overline{\mathrm{P}}$ | In-Phase |
| ${ }^{\text {tPHL }}$ |  |  |  |  |  |  |  |
| tPLH | $\bar{A} i$ | None | $\bar{B} i$ | Remaining $\bar{B}$ | $\begin{gathered} \text { Remaining } \\ \bar{A}, C_{n} \end{gathered}$ | $\overline{\mathrm{G}}$ | In-Phase |
| ${ }^{\text {tPHL }}$ |  |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ | $\overline{\mathrm{B}} \mathrm{i}$ | None | $\overline{\mathrm{A}} \mathrm{i}$ | Remaining $\bar{B}$ | Remaining $\bar{A}, C_{n}$ | $\overline{\mathrm{G}}$ | In-Phase |
| ${ }^{\text {tPHL }}$ |  |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ | $\mathrm{C}_{n}$ | None | None | All | $\frac{\text { All }}{\text { B }}$ | Any $\bar{F}$ <br> or $\mathrm{C}_{\mathrm{n}}+4$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\text { A }} \boldsymbol{i}$ | None | $\overrightarrow{B i}$ | Remaining $\bar{B}$ | Remaining $\bar{A}, C_{n}$ | $C_{n+4}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}} \mathrm{i}$ | None | $\overline{\mathrm{A}} \mathrm{i}$ | Remaining $\bar{B}$ | Remaining $\bar{A}, C_{n}$ | $C_{n+4}$ | Out-of-Phase |
| ${ }^{\text {P PHL }}$ |  |  |  |  |  |  |  |
| tPLH | Any $\overline{\mathrm{A}}$ | None | $\bar{B} i$ | Remaining <br> $\bar{B}, \bar{A} 3$ | Remaining $\bar{A}, C_{n}$ | Any $\bar{F}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ | Any $\bar{B}$ | None | $\bar{A} i$ | $\begin{aligned} & \text { Remaining } \\ & \bar{A}, \bar{B} 3 \end{aligned}$ | $\begin{gathered} \text { Remaining } \\ \bar{B}, C_{n} \end{gathered}$ | $\begin{gathered} \mathrm{Any} \\ \bar{F} \end{gathered}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## PARAMETER MEASUREMENT INFORMATION

$\overline{\text { DIFF }}$ MODE TEST TABLE
FUNCTION INPUTS: $\mathrm{S} 1=\mathrm{S} 2=4.5 \mathrm{~V}, \mathrm{SO}=\mathrm{S} 3=\mathrm{M}=0 \mathrm{~V}$

| PARAMETER | INPUT <br> UNDER TEST | OTHER INPUT SAME BIT |  | OTHER DATA INPUTS |  | OUTPUT UNDER TEST | OUTPUT WAVEFORM (SEE NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { APPLY } \\ & 4.5 \mathrm{~V} \end{aligned}$ | APPLY GND | $\begin{aligned} & \text { APPLY } \\ & 4.5 \mathrm{~V} \end{aligned}$ | APPLY GND |  |  |
| ${ }_{\text {tPLH }}$ | $\bar{A} i$ | None | $\overline{\mathrm{B}}$ | $\begin{gathered} \text { Remaining } \\ \bar{A} \end{gathered}$ | Remaining $\bar{B}, C_{n}$ | $\overline{F i}$ | In-Phase |
| ${ }^{\text {tPLH }}$ | $\overline{\mathrm{B}} \mathrm{i}$ | $\bar{A} i$ | None | $\begin{gathered} \text { Remaining } \\ \bar{A} \end{gathered}$ | Remaining $\bar{B}, C_{n}$ | $\overline{F i}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ | $\bar{A} i$ | None | $\overline{\mathrm{B}} \mathrm{i}$ | None | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | $\overline{\text { P }}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{Bi}}$ | $\bar{A} i$ | None | None | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | $\overline{\text { P }}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| tpLH | $\bar{A} i$ | $\overline{\mathrm{Bi}}$ | None | None | $\begin{gathered} \text { Remaining } \\ \bar{A} \text { and } \bar{B}, C_{n} \end{gathered}$ | $\overline{\mathrm{G}}$ | In-Phase |
| tpHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{Bi}}$ | None | $\bar{A} i$ | None | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | $\overline{\mathrm{G}}$ | Out-of-Phase |
| tpHL |  |  |  |  |  |  |  |
| tPLH | $\bar{A} i$ | None | $\overline{\mathrm{Bi}}$ | $\begin{gathered} \text { Remaining } \\ \bar{A} \end{gathered}$ | Remaining $\bar{B}, C_{n}$ | $A=B$ | In-Phase |
| tpHL |  |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ | $\overline{\mathrm{B}}$ | $\bar{A} i$ | None | $\bar{A}_{\bar{A}}^{\text {Remaining }}$ | $\begin{gathered} \text { Remaining } \\ \bar{B}, C_{n} \end{gathered}$ | $\mathrm{A}=\mathrm{B}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\mathrm{C}_{n}$ | None | None | $\begin{gathered} \mathrm{All} \\ \overline{\mathrm{~A}} \text { and } \overline{\mathrm{B}} \end{gathered}$ | None | $c_{n+4}$ <br> or any $\bar{F}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tpLH | $\bar{A} i$ | $\overline{\mathrm{Bi}}$ | None | None | $\begin{aligned} & \text { Remaining } \\ & \overline{\mathrm{A}}, \overline{\mathrm{~B}}, \mathrm{C}_{\mathrm{n}} \end{aligned}$ | $C_{n+4}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}}$ | None | $\bar{A} i$ | None | Remaining $\bar{A}, \bar{B}, C_{n}$ | $C_{n+4}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{A n y}$ | $\overline{\mathrm{B}}$ | None | $\overline{\text { A }} 3$ | Remaining$\overline{\mathrm{A}}, \overline{\mathrm{~B}}, \mathrm{C}_{\mathrm{n}}$ | $\begin{aligned} & \overline{A n y} \\ & \bar{F} \end{aligned}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\begin{gathered} \text { Any } \\ \bar{B} \end{gathered}$ | None | $\bar{A} i$ | A] | Remaining $\bar{A}, \bar{B}, C_{n}$ | $\begin{aligned} & \text { Any } \\ & \bar{F} \end{aligned}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## SN54AS1181, SN74AS1181 ARITHMETIC LOGIC UNITS/FUNCTION GENERATORS

## PARAMETER MEASUREMENT INFORMATION

LOGIC MODE TEST TABLE
FUNCTION INPUTS: $S 1=S 2=M=4.5 \mathrm{~V}, S 0=S 3=0 \mathrm{~V}$

| PARAMETER | INPUT <br> UNDER TEST | OTHER INPUT SAME BIT |  | OTHER DATA INPUTS |  | OUTPUT UNDER TEST | OUTPUT <br> WAVEFORM (SEE NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{gathered} \text { APPLY } \\ 4.5 \mathrm{~V} \end{gathered}$ | $\begin{gathered} \text { APPLY } \\ \text { GND } \end{gathered}$ | $\begin{gathered} \text { APPLY } \\ 4.5 \mathrm{~V} \end{gathered}$ | $\begin{aligned} & \text { APPLY } \\ & \text { GND } \end{aligned}$ |  |  |
| tPLH | $\bar{A} i$ | $\overline{\text { B }}$ | None | None | Remaining | $\overline{\mathrm{Fi}}$ | Out-of-Phase |
| tPHL |  |  |  |  | $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}, \mathrm{C}_{\mathrm{n}}$ |  |  |
| tPLH | $\overline{\mathrm{B}}$ | $\bar{A} i$ | None | None | Remaining | $\bar{F} i$ | Out-ot-Phase |
| ${ }^{\text {tPHL }}$ |  |  |  |  | $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}, \mathrm{C}_{\mathrm{n}}$ |  |  |

INPUT BITS EQUAL/NOT EQUAL TEST TABLE
FUNCTION INPUTS: $S 0=S 3=M=4.5 \mathrm{~V}, \mathrm{S1}=\mathbf{S 2}=0 \mathrm{~V}$

| PARAMETER | INPUT <br> UNDER TEST | OTHER INPUT SAME BIT |  | OTHER DATA INPUTS |  | OUTPUT UNDER TEST | OUTPUT WAVEFORM (SEE NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { APPLY } \\ & 4.5 \mathrm{~V} \\ & \hline \end{aligned}$ | APPLY GND | $\begin{aligned} & \text { APPLY } \\ & 4.5 \mathrm{~V} \end{aligned}$ | APPLY GND |  |  |
| tPLH | $\bar{A} i$ | $\overline{\mathrm{Bi}}$ | None | Remaining $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}, \mathrm{C}_{\mathrm{n}}$ | None | $\overline{\text { P }}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}}$ | $\bar{A} i$ | None | Remaining $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}, \mathrm{C}_{\mathrm{n}}$ | None | $\overline{\mathrm{P}}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\bar{A} i$ | None | $\overline{\mathrm{Bi}}$ | Remaining $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}, \mathrm{C}_{\mathrm{n}}$ | None | $\overline{\text { P }}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}} \mathrm{i}$ | None | $\bar{A} i$ | Remaining $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}, \mathrm{C}_{\mathrm{n}}$ | None | $\overline{\text { P }}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\bar{A} i$ | $\overline{\mathrm{Bi}}$ | None | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | None | $C_{n+4}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\overline{\mathrm{B}} \mathrm{i}$ | $\bar{A} i$ | None | Remaining $\overline{\mathrm{A}}$ and $\overline{\mathrm{B}}, \mathrm{C}_{\mathrm{n}}$ | None | $C_{n+4}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\bar{A} i$ | None | $\overline{\mathrm{B}}$ | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | None | $C_{n+4}$ | Out-of-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\bar{B} i$ | None | $\bar{A} i$ | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | None | $C_{n+4}$ | Out-of-Phase |
| tpHL |  |  |  |  |  |  |  |

input pairs high/not high test table
FUNCTION INPUTS: $S 2=\mathbf{M}=4.5 \mathrm{~V}, \mathbf{S O}=\mathbf{S 1}=\mathbf{S 3}=\mathbf{O V}$

| PARAMETER | INPUT <br> UNDER <br> TEST | OTHER INPUT SAME BIT |  | OTHER DATA INPUTS |  | OUTPUT UNDER TEST | OUTPUT WAVEFORM (SEE NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { APPLY } \\ & 4.5 \mathrm{~V} \end{aligned}$ | APPLY GND | $\begin{gathered} \text { APPLY } \\ 4.5 \mathrm{~V} \end{gathered}$ | APPLY GND |  |  |
| $\frac{t_{\mathrm{tPLH}}}{t_{\mathrm{PHL}}}$ | $\bar{A} i$ | $\overline{\mathrm{B}}$ | None | Remaining $\bar{A}, C_{n}$ | $\begin{gathered} \text { Remaining } \\ \bar{B} \\ \hline \end{gathered}$ | 戸 | In-Phase |
| ${ }_{\text {tPLH }}$ | $\overline{\mathrm{B}} \mathrm{i}$ | $\bar{A} i$ | None | Remaining $\bar{B}, C_{n}$ | $\begin{gathered} \text { Remaining } \\ \bar{A} \end{gathered}$ | $\overline{\text { P }}$ | In-Phase |
| ${ }_{\text {tPLH }}$ | $\bar{A} i$ | $\overline{\mathrm{B}}$ | None | $\begin{gathered} \text { Remaining } \\ \overline{\mathrm{A}}, \mathrm{C}_{\mathrm{n}} \\ \hline \end{gathered}$ | $\begin{gathered} \text { Remaining } \\ \bar{B} \end{gathered}$ | $C_{n+4}$ | Out-of-Phase |
| ${ }_{\text {tPLH }}$ | $\overline{\mathrm{B}} \mathrm{i}$ | $\overrightarrow{A l}_{i}$ | None | Remaining $\bar{B}, C_{n}$ | $\begin{gathered} \text { Remaining } \\ \bar{A} \end{gathered}$ | $c_{n+4}$ | Out-of-Phase |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## PARAMETER MEASUREMENT INFORMATION

SELECT INPUT/LOGIC MODE TEST TABLE
FUNCTION INPUTS: $M=4.5 \mathrm{~V}$

| PARAMETER | INPUT <br> UNDER <br> TEST | OTHER INPUT SAME BIT |  | OTHER DATA INPUTS |  | OUTPUT <br> UNDER <br> TEST | OUTPUT WAVEFORM (SEE NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | APPLY $4.5 \mathrm{~V}$ | APPLY GND | APPLY $4.5 \mathrm{~V}$ | APPLY GND |  |  |
| ${ }^{\text {tPLH }}$ | Any <br> S | - | - | Remaining $\bar{B}$ | $\bar{A}, \bar{B} O, C_{n}$ | $C_{n+4}$ | Out-of-Phase |
| - tPHL |  |  |  |  |  |  |  |
| tPLH | $\begin{gathered} \text { Any } \\ S \end{gathered}$ | - | - | $\bar{B}, \overline{\mathrm{~A}} 2$ | $\begin{gathered} \text { Remaining } \\ \bar{A}, C_{n} \end{gathered}$ | $\overline{\mathrm{P}}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |

SELECT INPUT/ARITH MODE TEST TABLE
FUNCTION INPUTS: $\mathbf{M}=0 \mathrm{~V}$

| PARAMETER | INPUT <br> UNDER TEST | OTHER INPUT SAME BIT |  | OTHER DATA INPUTS |  | OUTPUT UNDER TEST | OUTPUT WAVEFORM (SEE NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{gathered} \text { APPLY } \\ 4.5 \mathrm{~V} \end{gathered}$ | $\begin{aligned} & \text { APPLY } \\ & \text { GND } \end{aligned}$ | $\begin{gathered} \hline \text { APPLY } \\ 4.5 \mathrm{~V} \end{gathered}$ | $\begin{aligned} & \text { APPLY } \\ & \text { GND } \end{aligned}$ |  |  |
| tPLH | $\begin{gathered} \text { Any } \\ \text { S } \end{gathered}$ | - | - | $\begin{aligned} & \text { Remaining } \\ & \overline{\mathrm{A}} \text { and } \overline{\mathrm{B}}, \mathrm{C}_{\mathrm{n}} \end{aligned}$ | $\overline{\mathrm{A}} \mathrm{O}, \overline{\mathrm{B}} \mathrm{O}$ | $\overline{\text { Any }}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| tPLH | $\begin{gathered} \text { Any } \\ \text { S } \end{gathered}$ | - | - | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | $\overline{\mathrm{A}}$, $\overline{\mathrm{B}} 0$ | $A=B$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ | $\begin{gathered} \text { Any } \\ \text { S } \end{gathered}$ | - | - | Remaining $\bar{A}$ and $\bar{B}, C_{n}$ | $\overline{\mathrm{A}}, \overline{\mathrm{B}} 0$ | $\overline{\mathrm{G}}$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |

MODE INPUT/ $\overline{S U M}$ MODE TEST TABLE
FUNCTIION INPUTS: $S 0=S 3=4.5 \mathrm{~V}, \mathrm{~S} 1=\mathrm{S} 2=0 \mathrm{~V}$

| PARAMETER | INPUT <br> UNDER <br> TEST | OTHER INPUT SAME BIT |  | OTHER DATA INPUTS |  | OUTPUT <br> UNDER <br> TEST | OUTPUT WAVEFORM (SEE NOTE 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | APPLY $4.5 \mathrm{~V}$ | APPLY <br> GND | APPLY $4.5 \mathrm{~V}$ | APPLY GND |  |  |
| ${ }^{\text {tPLH }}$ | M | - | - | Remaining $\bar{A}$ and $\bar{B}$ | $\overline{\mathrm{B}} 2, \overline{\mathrm{~A}} 2, \mathrm{C}_{n}$ | $\stackrel{\text { Any }}{\text { F }}$ | In-Phase |
| ${ }^{\text {tPHL }}$ |  |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ | M | - | - | Remaining $\bar{A}$ and $\bar{B}$ | $\bar{B} 1, \bar{A} 1, C_{n}$ | $A=B$ | In-Phase |
| tPHL |  |  |  |  |  |  |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

- Provides Control for 16K, 64K, and 256K Dynamic RAMs
- Highest-Order Two-Address Bits Select One of Four Banks of RAMs
- Supports Scrubbing Operations and NibbleMode Access
- Separate Output Enable for Multi-Channel Access to Memory
- 48-Pin Dual-In-Line Package
- 'ALS2968 is Designed to be Interchangeable with AMD AM2968


## description

The 'ALS2967 and 'ALS2968 dynamic memory controllers (DMCs) are designed for use in today's high-performance memory systems. The DMC acts as the address controller between any processor and dynamic memory array.
Two versions are provided that help simplify interfacing to the system dynamic timing controller. The 'ALS2967 offers active-low Row Address Strobe Input ( $\overline{\mathrm{RASI}})$ and Column Address Strobe Input ( $\overline{\mathrm{CASI}}$ ), while the 'ALS2968 offers active-high Row Address Strobe Input (RASI) and Column Address Strobe Input (CASI) inputs.
Using two 9-bit address latches, the DMC will hold the row and column addresses for any DRAM up to 256 K . These latches and the two row/column refresh address counters feed into a 9-bit, 4-input MUX for output to the dynamic RAM address lines. A 2-bit bank select latch is provided to select one of the four $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ outputs. The two bits are normally obtained from the two highest-order address bits.

SN54ALS2967, SN54ALS2968 . . . JD PACKAGE SN74ALS2967, SN74ALS2968 . . . JD OR N PACKAGE (TOP VIEW)

| $\overline{\mathrm{CS}}$ | 1 | 48 | $\overline{\mathrm{CASI}}$ or $\mathrm{CASI}^{\dagger}$ |
| :---: | :---: | :---: | :---: |
| MSEL | 2 | 47 | $\square \overline{\text { RASO }}$ |
| AO 4 | 3 | 46 | $\overline{\square A S O}$ |
| A9 4 | 4 | 45 | - $\overline{\text { RAS } 1}$ |
| A1 4 | 5 | 44 | $\square \overline{C A S} 1$ |
| A10 4 | 6 | 43 | $\square \mathrm{QO}$ |
| A2 4 | 7 | 42 | $\square \mathrm{Q} 1$ |
| A11 4 | 8 | 41 | $\square \mathrm{Q} 2$ |
| A3 $\square$ | 9 | 40 | $\square$ Q3 |
| A12 4 | 10 | 39 | -04 |
| A4 4 | 11 | 38 | $\square$ GND |
| A13 4 | 12 | 37 | $\overline{O E}$ |
| GND 4 | 13 | 36 | $\square V_{C C}$ |
| LE 4 | 14 | 35 | $\square \mathrm{Q}$ |
| A5 | 15 | 34 | - Q6 |
| A14 4 | 16 | 33 | -07 |
| A6 $\square$ | 17 | 32 | $\square \mathrm{Q}$ |
| A15 | 18 | 31 | - $\overline{\mathrm{RAS}} 2$ |
| $A 74$ | 19 | 30 | ] $\overline{\mathrm{CAS}} 2$ |
| A16 | 20 | 29 | RAS3 |
| A8 | 21 | 28 | $\square \overline{\mathrm{CAS}} 3$ |
| A17 | 22 | 27 | $\overline{\mathrm{RASI}}$ or RASI ${ }^{\dagger}$ |
| SELO 4 | 23 | 26 | - MCO |
| SEL 14 | 24 | 25 | - MC1 |

†'ALS2967 has active-low inputs $\overline{\text { CASI }}$ and $\overline{\text { RASI; 'ALS2968 has }}$ active-high inputs CASI and RASI.

The 'ALS2967 and 'ALS2968 have two basic modes of operation, read/write and refresh. During normal read/write operations, the row and column addresses are multiplexed to the dynamic RAM, with the corresponding $\overline{\operatorname{RAS}}$ and $\overline{\mathrm{CAS}}$ signals activated to strobe the addresses into the RAM. In the refresh mode, the two counters cycle through the refresh addresses. If memory scrubbing is not being implemented, only the row counter is used. When memory scrubbing is being performed, both the row and column counters are used to perform read-modify-write cycles. In this mode all $\overline{R A S}$ outputs will be active (low) while only one $\overline{C A S}$ output is active at a time.

The SN54ALS2967 and SN54ALS2968 are characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74ALS2967 and SN74ALS2968 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

SN54ALS2967, SN74ALS2967, SN54ALS2968, SN74ALS2968
DYNAMIC MEMORY CONTROLLERS
logic symbols ${ }^{\dagger}$

'ALS2968

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

SN54ALS2967, SN74ALS2967, SN54ALS2968, SN74ALS2968 DYNAMIC MEMORY CONTROLLERS
logic diagram (positive logic)


SN54ALS2967, SN74ALS2967, SN54ALS2968, SN74ALS2968 DYNAMIC MEMORY CONTROLLERS

## TABLE 1. PIN FUNCTION

| PIN NAME | DESCRIPTION |
| :---: | :---: |
| AO-A17 | Address Inputs. AO-A8 are latched in as the nine-bit row address for the DRAM. These inputs drive Q0-Q8 when the DMC is in the read/write mode and MSEL is low. A9-A17 are latched in as the column address, and will drive Q0-Q8 when MSEL is high and the DMC is in the read/write mode. The addresses are latched when the Latch Enable (LE) input signal is low. |
| SELO, SEL 1 | Bank Select. These two inputs are normally the two highest-order address bits and are used in the read/write mode to select which bank of memory will be receiving the $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ signals after $\overline{\mathrm{RASI}}$ ('ALS2967) or RASI ('ALS2968) and CASI ('ALS2967) or CASI ('ALS2968) go active. |
| LE | Latch Enable. This active-high input causes the row, column, and bank select latches to become transparent, allowing the latches to accept new input data. A low input on LE latches the input data. |
| MSEL | Multiplexer Select. This input determines whether the row or column address will be sent to the memory address inputs. When MSEL is high, the column address is selected, while the row address is selected when MSEL is low. The address may come from either the address latch or refresh address counter depending on MCO and MC1 (see Mode Control Function Table). |
| $\overline{\mathrm{CS}}$ | Chip Select. This active-low input is used to enable the DMC. When $\overline{\mathrm{CS}}$ is active, the DMC operates normally in all four modes. When $\overline{\mathrm{CS}}$ goes high, the device will not enter the read/write mode. This allows other devices to access the same memory that the DMC is controlling. |
| $\overline{\mathrm{OE}}$ | Output Enable. This active-low input enables/disables the output signals. When $\overline{\mathrm{OE}}$ is high, the outputs of the DMC enter the high-impedance state. |
| MCO-MC1 | Mode Controls. These inputs determine in which of the four modes the DMC operates. The description of each of the four operating modes is given in Table 2. |
| Q0-08 | Address Outputs. These address outputs feed the DRAM address inputs and provide drive for memory systems having capacitance of up to 500 picofarads. |
| $\overline{\text { RASI }}$ or RASI | Row Address Strobe Input. During the normal memory cycles, the decoded $\overline{\mathrm{RAS}}$ n output ( $\overline{\mathrm{RAS}} 0, \overline{\mathrm{RAS}} 1, \overline{\mathrm{RAS}} 2$, or $\overline{\mathrm{RAS}} 3$ ) is forced low after receipt of an active Row Address Strobe Input signal. In either Refresh mode, all four $\overline{\mathrm{RAS}}$ outputs will be low while the Row Address Strobe Input signal is active. The $\overline{\text { RASI }}$ on the 'ALS2967 is an active-low input while on the 'ALS2968, RASI is an active-high input. (For more details see timing diagrams). |
| $\overline{\text { RAS }} 0-\overline{\mathrm{RAS}} 3$ | Row Address Strobe. Each of the Row Address Strobe outputs provides a $\overline{\mathrm{RAS}}$ signal to one of the four banks of dynamic memory. Each $\overline{\operatorname{RAS}}$ n output will go low when selected by SELO and SEL1 after $\overline{\mathrm{RASI}}$ ('ALS2967) or RASI ('ALS2968) goes active. All four go low in response to $\overline{\text { RASI ('ALS2967) or RASI ('ALS2968) while in the refresh mode. }}$ |
| $\overline{\text { CASI }}$ or CASI | Column Address Strobe Input. This input going active causes the selected $\overline{\mathrm{CAS}}$ output to be forced low. The $\overline{\mathrm{CASI}}$ input on the 'ALS2967 is active low input while on the 'ALS2968, CASI is active high input. (For more details see timing diagrams.) |
| $\overline{\text { CAS }} 0-\overline{C A S} 3$ | Column Address Strobe. During normal Read/Write cycles the two selected bits (SELO, SEL1) determine which CAS output will go active following $\overline{\mathrm{CASI}}$ ('ALS2967) or CASI ('ALS2968) going active. When memory scrubbing is being performed, only the $\overline{\mathrm{CAS}} \mathrm{n}$ signal selected will be active. For non-scrubbing cycles, all four $\overline{\mathrm{CAS}}$ outputs will remain high. |

## TABLE 2. MODE-CONTROL FUNCTION TABLE

| MC1 L | MCO L | OPERATING MODE <br> Refresh Mode without Scrubbing. Refresh cycles are performed with only the row counter being used to generate the addresses. In this mode, all four $\overline{\mathrm{RAS}}$ outputs are active while the four $\overline{\mathrm{CAS}}$ outputs remain high. |
| :---: | :---: | :---: |
| L | H | Refresh with Scrubbing/Initialize. During this mode, refresh cycles are done with both the row and column counters generating the addresses. MSEL is used to select either the row or the column counter. All four $\overline{\operatorname{RAS}}$ outputs go low in response to $\overline{R A S I}$ ('ALS2967) or RASI ('ALS2968), while only one $\overline{\mathrm{CAS}} \mathrm{n}$ output goes low in response to $\overline{\mathrm{CASI}}$ ('ALS2967) or CASI ('ALS2968). The bank counter keeps track of which $\overline{\text { CAS }}$ output goes active. This mode can also be used during system power-up so that the memory can be written with a known data pattern. |
| H | L | Read/Write. This mode is used to perform read/write cycles. Both the Row and Column addresses are multiplexed to the address output lines using MSEL. SELO and SEL1 are decoded to determine which $\overline{\operatorname{RAS}} \mathrm{n}$ and $\overline{\mathrm{CAS}} \mathrm{n}$ outputs will be active. |
| H | H | Clear Refresh Counters. This mode clears the three refresh counters (row, column, and bank) on the inactive transition of $\overline{\text { RASI ('ALS2967) or RASI ('ALS2968), putting them at start of the refresh sequence (see timing diagrams for more }}$ detail). In this mode, all four $\overline{\operatorname{RAS}}$ outputs are driven low after the active edge of $\overline{\mathrm{RASI}}$ ('ALS2967) or RASI ('ALS2968) so that DRAM wake-up cycles may also be performed. |

## SN54ALS2967, SN74ALS2967, SN54ALS2968, SN74ALS2968

 DYNAMIC MEMORY CONTROLLERSTABLE 3. ADDRESS OUTPUT FUNCTIONS

| MODE | INPUTS |  |  |  | OUTPUTS 00-08 |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MC1 | MCO | MSEL | $\overline{\text { CS }}$ |  |
| Refresh without scrubbing | L | L | X | X | Row counter address |
| Refresh with scrubbing | L | H | L | X | Row counter address |
|  |  |  | H | X | Column counter address |
| Read/write | H | L | L | L | Row address ${ }^{\dagger}$ |
|  |  |  | H | L | Column address ${ }^{\dagger}$ |
|  |  |  | X | H | All L |
| Clear refresh counter ${ }^{\ddagger}$ | H | H | X | X | All L |

TABLE 4. RAS OUTPUT FUNCTIONS

| INPUTS |  |  |  |  |  | OUTPUTS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{cc} \text { 'ALS2967 } & \text { ALS2968 } \\ \overline{\text { RASI }} & \text { RASI } \end{array}$ | MC1 | MCO | SEL1 ${ }^{\dagger}$ | SELO ${ }^{\dagger}$ | $\overline{\mathrm{CS}}$ | RASO | RAS 1 | $\overline{\text { RAS } 2}$ | $\overline{\text { RAS }} 3$ |
| L H | L | L | X | X | X | L | L | L | L |
| L H | L | H | X | X | X | L | L | L | L |
|  |  |  | L | L | L | L | H | H | H |
|  |  |  | L | H | L | H | L | H | H |
| L H | H | L | H | L | L | H | H | L | H |
|  |  |  | H | H | L. | H | H | H | L |
|  |  |  | X | X | H | H | H | H | H |
| L H | H | H | X | X | X | L | L | L | L |
| H L | X | X | X | X | X | H | H | H | H |

TABLE 5. CAS OUTPUT FUNCTIONS

| INPUTS |  |  |  |  |  |  |  | OUTPUTS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 'ALS2967 'ALS2968 | MC1 | MCO | SELI ${ }^{\dagger}$ SELO ${ }^{\dagger}$ |  | INTERNAL |  | $\overline{\mathbf{C S}}$ | $\overline{\text { CASO }}$ | $\overline{\text { CAS } 1}$ | $\overline{\text { CAS } 2 ~}$ | $\overline{\text { CAS }} 3$ |
| CASI CASI |  |  |  |  | BC1 | BCO |  |  |  |  |  |
| L H | L | L | X | X | X | X | X | H | H | H | H |
|  |  |  |  |  | L | L | X | L | H | H | H |
| 1 | L | H | X | X | L | H | X | H | L | H | H |
| L H | L | H | X | $x$ | H | L | X | H | H | L | H |
|  |  |  |  |  | H | H | X | H | H | H | L |
|  |  |  | L | L | X | X | L | L | H | H | H |
|  |  |  | L | H | X | X | L | H | L | H | H |
| L H | H | L | H | L | X | X | L | H | H | L | H |
|  |  |  | H | H | X | X | L | H | H | H | L |
|  |  |  | X | X | X | X | H | H | H | H | H |
| L H | H | H | X | X | X | X | X | H | H | H | H |
| H | X | X | X | X | X | X | X | H | H | H | H |

$\dagger^{\dagger}$ If LE is low, outputs will be the levels entered when LE was last high. If LE is high, outputs will follow address inputs as selected by MSEL.
${ }^{\ddagger}$ For 'ALS2967, clearing occurs on the low-to-high transition of RASI; for 'ALS2968, clearing occurs on the high-to-low transition of RASI.

## SN54ALS2967, SN74ALS2967, SN54ALS2968, SN74ALS2968 DYNAMIC MEMORY CONTROLLERS

## read/write operation details

During normal read/write operations, the row and column addresses are multiplexed to the dynamic RAM controlied by the MSEL input. The corresponding $\overline{\text { RAS }} \mathrm{n}$ and $\overline{\mathrm{CAS}} \mathrm{n}$ output signals strobe the addresses into memory. The block diagram in Figure 1 shows a typical system interface for a one-megaword dynamic memory. The DMC is used to control the four banks of 256 K memory.

For systems where addresses and data are multiplexed onto a single bus, the DMC uses latches, (row, column, and bank) to hold the address information. Figure 5 shows a typical timing diagram using the input latches. The twenty input latches are transparent when latch enable (LE) is high, and latch the input data whenever LE is taken low. For systems in which the processor has separate address and data buses, LE may be permanently high (see timing diagram in Figure 4).


FIGURE 1. 1-MEGAWORD X 16-BIT DYNAMIC MEMORY

## SN54ALS2967, SN74ALS2967, SN54ALS2968, SN74ALS2968 DYNAMIC MEMORY CONTROLLERS

## read/write operations (continued)

The DMC is designed with heavy-duty outputs that are capable of driving four banks of 16-bit words, including six checkbits used for error detection and correction.

In addition to heavy-duty output drivers, the outputs are designed with balanced output impedances (25 $\Omega$ both high and low). This feature optimizes the drive low characteristics, based on safe undershoot, while providing symmetrical drive high characteristics. It also eliminates the external resistors required to pull the outputs up to the MOS $\mathrm{V}_{\mathrm{OH}}$ level ( $\mathrm{V}_{\mathrm{CC}}-1.5 \mathrm{~V}$ ).


FIGURE 2. 1-MEGAWORD X 16-BIT DYNAMIC MEMORY WITH ERROR DETECTION AND CORRECTION

## SN54ALS2967, SN74ALS2967, SN54ALS2968, SN74ALS2968 DYNAMIC MEMORY CONTROLLERS

## memory expansion

With a 9-bit address path, the DMC can control up to one megaword when using 256K dynamic RAMs. If a larger memory size is desired, the DMC's chip select ( $\overline{\mathrm{CS}}$ ) makes it easy to expand the memory size by using additional DMCs. A four-megaword memory system is shown in Figure 3.

To maintain maximum performance in 32-bit applications, it is recommended that individual bus drivers be used for each bank.


FIGURE 3. 4-MEGAWORD $X$ 16-BIT DYNAMIC MEMORY

# SN54ALS2967, SN74ALS2967, SN54ALS2968, SN74ALS2968 DYNAMIC MEMORY CONTROLLERS 

## refresh operations

The two 9-bit counters in the 'ALS2967 and 'ALS2968 support 128-, 256-, and 512-line refresh operations. Transparent, burst, synchronous, or asynchronous refresh modes are all possible. The refresh counters are advanced on the low-to-high transition of $\overline{\text { RASI }}$ on the 'ALS2967, and on the high-to-low transition of RASI on the 'ALS2968. The refresh counters are reset to zero on the low-to-high transition of RASI on the 'ALS2967, and on the high-to-low transition of RASI on the 'ALS2968, if MC1 and MCO are at a low logic level. See Figure 8 for additional timing details.

When performing refresh cycles without memory scrubbing (MC1 and MCO both low), all four $\overline{\operatorname{RAS}}$ outputs go low, while all $\overline{\mathrm{CAS}}$ outputs are driven high. Typical timing for this mode of operation is shown in Figure 6.

## SN54ALS2967, SN74ALS2967, SN54ALS2968, SN74ALS2968 DYNAMIC MEMORY CONTROLLERS


recommended operating conditions

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

| PARAMETER | TEST CONDITIONS |  | SN54ALS2967 <br> SN54ALS2968 |  |  | SN74ALS2967 <br> SN74ALS2968 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\text { }}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ | 2.4 | 3.3 |  |  |  |  | V |
|  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ |  |  |  | 2.4 | 3.2 |  |  |
| $\mathrm{V}_{\text {OL }}$ | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=1 \mathrm{~mA}$ |  | 0.15 | 0.5 |  | 0.15 | 0.5 | V |
|  | $\mathrm{V}_{C C}=4.5 \mathrm{~V}$, | $\mathrm{IOL}=12 \mathrm{~mA}$ |  | 0.35 | 0.8 |  | 0.35 | 0.8 |  |
| $\mathrm{IOL}^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2 \mathrm{~V}$ | 30 |  |  | 30 |  |  | mA |
| IOZH | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IOZL | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -20 |  |  | -20 | $\mu \mathrm{A}$ |
| 1 | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| ${ }_{1} \mathrm{H}$ | $\mathrm{V}_{C C}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IL | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.1 |  |  | -0.1 | mA |
| $10^{5}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ICC | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  |  |  |  |  |  |  | mA |

[^68]
## SN54ALS2967, SN74ALS2967 <br> DYNAMIC MEMORY CONTROLLERS

'ALS2967 switching characteristics, $\mathrm{C}_{\mathrm{L}}=\mathbf{5 0} \mathbf{~ p F}$

| PARAMETER | FROM (INPUT) | T0 (OUTPUT) | TEST CONDITIONS ${ }^{\dagger}$ | SN54ALS2967 |  |  | SN74ALS2967 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP ${ }^{\text {¢ }}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $t_{\text {pd }}(1)$ | RASI | Any Q | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=\mathrm{MIN} \text { to } \mathrm{MAX} \end{aligned}$ |  | 12 |  |  | 12 |  | ns |
| $\mathrm{t}_{\mathrm{pd}(12)}$ | RASI | $\overline{\text { RAS }}$ |  |  | 10 |  |  | 10 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(3)$ | CASI | $\overline{\text { CASn }}$ |  |  | 8 |  |  | 8 |  | ns |
| ${ }^{\text {p }}$ d(4) | Any A | Any Q |  |  | 22 |  |  | 22 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(5)$ | MSEL | Any Q |  |  | 14 |  |  | 14 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(6)$ | LE¢ | Any Q |  |  | 15 |  |  | 15 |  | ns |
| $t_{\text {pd }}(7)$ | LE¢ | Any RAS |  |  | 15 |  |  | 15 |  | ns |
| ${ }^{\text {tpd }}$ (8) | LET | Any CAS |  |  | 14 |  |  | 14 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(9)$ | MCO or MC1 | Any 0 |  |  | 15 |  |  | 15 |  | ns |
| $t_{\text {pd (10) }}$ | MCO or MC1 | Any RAS |  |  | 14 |  |  | 14 |  | ns |
| $t_{\text {pd }}(11)$ | MC0 or MC1 | Any $\overline{\text { CAS }}$ |  |  | 12 |  |  | 12 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(12)$ | $\overline{\mathrm{CS}}$ | Any Q |  |  | 16 |  |  | 16 |  | ns |
| $t_{\text {pd }}(13)$ | $\overline{\text { CS }}$ | Any $\overline{\mathrm{RAS}}$ |  |  | 12 |  |  | 12 |  | ns |
| $t_{\text {pd }}(14)$ | $\overline{\text { CS }}$ | Any CAS |  |  | 11 |  |  | 11 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(15)$ | SELO or SEL1 | Any $\overline{\mathrm{RAS}}$ |  |  | 12 |  |  | 12 |  | ns |
| $t_{\text {pd }}(16)$ | SELO or SEL1 | Any $\overline{\text { CAS }}$ |  |  | 11 |  |  | 11 |  | ns |
| ten(17) | $\overline{\mathrm{O}} \downarrow$ | Any 0 |  |  | 14 |  |  | 14 |  | ns |
| ten(18) | $\overline{\mathrm{O}} \downarrow$ | Any RAS |  |  | 13 |  |  | 13 |  | ns |
| ten(19) | $\overline{\mathrm{OE}} \downarrow$ | Any CAS |  |  | 13 |  |  | 13 |  | ns |
| ${ }^{\text {dis }}$ (20) | OE¢ $\uparrow$ | Any Q |  |  | 15 |  |  | 15 |  | ns |
| ${ }^{\text {dis }}$ (21) | $\overline{\mathrm{OE}} \uparrow$ | Any RAS |  |  | 13 |  |  | 13 |  | ns |
| $t_{\text {dis }}(22)$ | $\overline{\mathrm{OE}} \uparrow$ | Any CAS |  |  | 13 |  |  | 13 |  | ns |

'ALS2967 switching characteristics, $\mathrm{CL}_{\mathrm{L}}=150 \mathrm{pF}$

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS ${ }^{\dagger}$ | SN54ALS2967 |  |  | SN74ALS2967 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP ${ }^{\text { }}$ | MAX | MIN | TYP ${ }^{\text { }}$ | MAX |  |
| $t_{\text {pd }}(1)$ | RASI | Any Q | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN to MAX } \end{aligned}$ |  | 17 |  |  | 17 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(2)$ | RASI | $\overline{\text { RAS }}$ |  |  | 15 |  |  | 15 |  | ns |
| ${ }_{\text {t }}{ }_{\text {d }}(3)$ | CASI | $\overline{\text { CAS }}$ |  |  | 14 |  |  | 14 |  | ns |
| ${ }^{\text {tpd }}$ (4) | Any A | Any Q |  |  | 27 |  |  | 27 |  | ns |
| ${ }^{\text {p }}$ d(5) | MSEL | Any Q |  |  | 19 |  |  | 19 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(6)$ | LET | Any O |  |  | 20 |  |  | 20 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(7)$ | LET | Any RAS |  |  | 20 |  |  | 20 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(8)$ | LET | Any $\overline{\mathrm{CAS}}$ |  |  | 19 |  |  | 19 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(9)$ | MCO or MC1 | Any Q |  |  | 20 |  |  | 20 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(10)$ | MCO or MC1 | Any $\overline{\mathrm{RAS}}$ |  |  | 19 |  |  | 19 |  | ns |
| $t_{p d}(11)$ | MCO or MC1 | Any CAS |  |  | 17 |  |  | 17 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(12)$ | $\overline{\overline{C S}}$ | Any O |  |  | 19 |  |  | 19 |  | ns |
| $t_{\text {pd }}(13)$ | $\overline{\mathrm{CS}}$ | Any $\overline{\text { RAS }}$ |  |  | 14 |  |  | 14 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(14)$ | $\overline{\text { CS }}$ | Any CAS |  |  | 14 |  |  | 14 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(15)$ | SELO or SEL1 | Any $\overline{\mathrm{RAS}}$ |  |  | 15 |  |  | 15 |  | ns |
| $\mathrm{t}_{\mathrm{pd}}(16)$ | SELO or SEL1 | Any CAS |  |  | 14 |  |  | 14 |  | ns |

[^69]
## SN54ALS2968, SN74ALS2968 DYNAMIC MEMORY CONTROLLERS

'ALS2968 switching characteristics, $C_{L}=50$ pF

| PARAMETER | FROM (INPUT) | то (OUTPUT) | TEST CONDITIONS ${ }^{\dagger}$ | SN54ALS2968 |  |  | SN74ALS2968 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP ${ }^{\ddagger}$ | MA'X | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| ${ }^{\text {t }}$ d (1) | RASI | Any 0 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=\mathrm{MIN} \text { to MAX } \end{aligned}$ | 5 | 12 | 20 | 5 | 12 | 20 | ns |
| ${ }^{\text {p }} \mathrm{pd}$ (2) | RASI | $\overline{\text { RAS }}$ |  | 3 | 10 | 18 | 3 | 10 | 18 | ns |
| ${ }_{\text {t }}^{\text {d }}$ ( 3 ) | CASI | $\overline{\text { CASn }}$ |  | 3 | 8 | 17 | 3 | 8 | 17 | ns |
| ${ }^{\text {pd }}$ (4) | Any A | Any Q |  | 5 | 22 | 30 | 5 | 22 | 30 | ns |
| ${ }^{\text {t }} \mathrm{pd}$ (5) | MSEL | Any Q |  | 3 | 14 | 20 | 3 | 14 | 20 | ns |
| ${ }^{\text {tpd }}$ (6) | LET | Any Q |  |  | 15 | 25 |  | 15 | 25 | ns |
| $\mathrm{t}_{\mathrm{pd}}(7)$ | LET | Any RAS |  |  | 15 | 25 |  | 15 | 25 | ns |
| $\mathrm{t}_{\mathrm{pd}}(8)$ | LET | Any CAS |  |  | 14 | 24 |  | 14 | 24 | ns |
| $\mathrm{t}_{\mathrm{pd}}(9)$ | MCO or MC1 | Any O |  | 5 | 15 | 25 | 5 | 15 | 25 | ns |
| tpd(10) | MCO or MC1 | Any $\overline{\mathrm{RAS}}$ |  | 3 | 14 | 21 | 3 | 14 | 21 | ns |
| tpd(11) | MCO or MC1 | Any $\overline{\text { CAS }}$ |  | 3 | 12 | 19 | 3 | 12 | 19 | ns |
| $\mathrm{t}_{\mathrm{pd}}(12)$ | $\overline{\text { CS }}$ | Any Q |  |  | 16 | 23 |  | 16 | 23 | ns |
| $\mathrm{t}_{\mathrm{pd}}(13)$ | CS | Any $\overline{\mathrm{RAS}}$ |  |  | 12 | 20 |  | 12 | 20 | ns |
| $\mathrm{t}_{\mathrm{pd}}(14)$ | $\overline{\text { CS }}$ | Any $\overline{\text { CAS }}$ |  |  | 11 | 19 |  | 11 | 19 | ns |
| $\mathrm{t}_{\mathrm{pd}}(15)$ | SELO or SEL1 | Any $\overline{\mathrm{RAS}}$ |  |  | 12 | 20 |  | 12 | 20 | ns |
| $\mathrm{t}_{\mathrm{pd}}(16)$ | SELO or SEL1 | Any $\overline{\text { CAS }}$ |  |  | 11 | 18 |  | 11 | 18 | ns |
| $\mathrm{t}_{\text {en( }}$ (17) | OE $\downarrow$ | Any O |  |  | 14 | 21 |  | 14 | 21 | ns |
| ten(18) | OE | Any $\overline{\text { RAS }}$ |  |  | 13 | 19 |  | 13 | 19 | ns |
| ten(19) | $\overline{\mathrm{O}} \mathrm{\square} \downarrow$ | Any CAS |  |  | 13 | 19 |  | 13 | 19 | ns |
| $\mathrm{t}_{\text {dis( }}$ (20) | $\overline{\mathrm{O}} \mathrm{E} \uparrow$ | Any Q |  |  | 15 | 22 |  | 15 | 22 | ns |
| $\mathrm{t}_{\text {dis(21) }}$ | $\overline{\mathrm{OE}} \uparrow$ | Any $\overline{\text { RAS }}$ |  |  | 13 | 20 |  | 13 | 20 | ns |
| ${ }^{\text {dis }}$ (22) | $\overline{\mathrm{O}} \uparrow$ | Any $\overline{\text { CAS }}$ |  |  | 13 | 20 |  | 13 | 20 | ns |

## 'ALS2968 switching characteristics, $C_{L}=150 \mathrm{pF}$

| PARAMETER | FROM (INPUT) | то (OUTPUT) | TEST CONDITIONS ${ }^{\dagger}$ | SN54ALS2968 |  |  | SN74ALS2968 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $\mathrm{t}_{\mathrm{pd}}$ (1) | RASI | Any Q | $\begin{aligned} & \mathrm{V}_{C C}=4.5 \mathrm{~V} \text { to } 5.5 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=\mathrm{MIN} \text { to MAX } \end{aligned}$ | 12 | 17 | 30 | 12 | 17 | 30 | ns |
| $t_{\text {pd }}(2)$ | RASI | $\overline{\mathrm{RAS}}$ |  | 9 | 15 | 23 | 9 | 15 | 23 | ns |
| $\mathrm{t}_{\mathrm{pd}}(3)$ | CASI | $\overline{\text { CASn }}$ |  | 9 | 14 | 22 | 9 | 14 | 22 | ns |
| $\mathrm{t}_{\mathrm{pd}}(4)$ | Any A | Any 0 |  | 10 | 27 | 35 | 10 | 27 | 35 | ns |
| ${ }^{\text {t }} \mathrm{pd}$ (5) | MSEL | Any Q |  | 9 | 19 | 26 | 9 | 19 | 26 | ns |
| $\mathrm{t}_{\mathrm{pd}}(6)$ | LET | Any Q |  |  | 20 | 28 |  | 20 | 28 | ns |
| $\mathrm{t}_{\mathrm{pd}}(7)$ | LET | Any $\overline{\mathrm{RAS}}$ |  |  | 20 | 28 |  | 20 | 28 | ns |
| $\mathrm{t}_{\mathrm{pd}}(8)$ | LE¢ | Any $\overline{\text { CAS }}$ |  |  | 19 | 27 |  | 19 | 27 | ns |
| ${ }^{\mathrm{p} d} \mathrm{~d}$ (9) | MC0 or MC1 | Any Q |  | 10 | 20 | 27 | 10 | 20 | 27 | ns |
| $\mathrm{t}_{\mathrm{pd}}(10)$ | MC0 or MC1 | Any $\overline{\mathrm{RAS}}$ |  | 9 | 19 | 25 | 9 | 19 | 25 | ns |
| $t_{\text {pd }}(11)$ | MC0 or MC1 | Any $\overline{\text { CAS }}$ |  | 9 | 17 | 23 | 9 | 17 | 23 | ns |
| $\mathrm{t}_{\mathrm{pd}}(12)$ | $\overline{\text { CS }}$ | Any O |  |  | 19 | 27 |  | 19 | 27 | ns. |
| $\mathrm{t}_{\mathrm{pd}}(13)$ | $\overline{\text { CS }}$ | Any $\overline{\mathrm{RAS}}$ |  |  | 14 | 22 |  | 14 | 22 | ns |
| tpd(14) | $\overline{\text { CS }}$ | Any CAS |  |  | 14 | 22 |  | 14 | 22 | ns |
| $\mathrm{t}_{\mathrm{pd}}(15)$ | SELO or SEL1 | Any $\overline{\mathrm{RAS}}$ |  |  | 15 | 23 |  | 15 | 23 | ns |
| $\mathrm{t}_{\mathrm{pd}}(16)$ | SELO or SEL1 | Any CAS |  |  | 14 | 22 |  | 14 | 22 | ns |

[^70]${ }^{\ddagger}$ All typical values at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.


FIGURE 4. READ/WRITE CYCLE TIMING (MC1, MCO $=1,0)$, $(L E=H)$
$\dagger_{\text {Parameters }} t_{S u}(A R), t_{s u}(A C)$, and $t_{h}(A R)$ are timing requirements of the dynamic RAM. Parameters $t 1, t 2$, and $t 3$ represent the minimum timing requirements at the inputs to the DMC that guarantee DRAM timing specifications and maximum system performance. The minimum requirements for $\mathrm{t} 1, \mathrm{t} 2$, and t 3 are as follows:

```
t1(min)}=\mp@subsup{t}{\mathrm{ pd(4) max }}{}+\mp@subsup{t}{\mathrm{ su( }}{(AR) min}-\mp@subsup{t}{pd(2) min}{m
t2(min)}=\mp@subsup{t}{pd(2) max }{\mathrm{ m th}
t3(min)}=\textrm{t}2\mathrm{ min}+\mp@subsup{t}{pd(5) max }{\mathrm{ m }
```

See the DRAM data sheet for applicable $t_{S u}(A R), t_{S U}(A R)$, and $t_{h}(A R)$. In addition, note that propagation delay times given in the above equations are functions of capacitive loading. The values used in these equations must relate to actual system capacitive loading.

${ }^{\dagger} t_{\text {su }}(A R), t_{s u}(A C)$, and $t_{h(A R)}$ are timing requirements of the dynamic RAM. See the DRAM data sheet for applicable specifications.


LE $]$ X
FIGURE 6. REFRESH CYCLE TIMING (MC1, MCO $=$ L, L) WITHOUT SCRUBBING
${ }^{\dagger} t_{\text {su }}(A R), t_{w}(R L)$, and $t_{w}(R H)$ are timing requirements of the dynamic RAM. See DRAM data sheet for applicable specifications.


FIGURE 7. REFRESH CYCLE TIMING (MC1, MCO = L, H) WITH MEMORY SCRUBBING
${ }^{\dagger}$ Parameters $t_{\text {Su }}(A R), t_{S u}(A C)$, and $t_{h}(A R)$ are timing requirements of the dynamic RAM. Parameters $t 2, t 3$, and $t 4$ represent the minimum timing requirements at the inputs to the DMC that guarantee DRAM timing specifications and maximum system performance. The minimum requirement for $\mathrm{t} 2, \mathrm{t} 3$, and t 4 are as follows:

```
t2(min)}=\mp@subsup{t}{pd(2)}{max}+\mp@subsup{t}{h(AR)}{min}-\mp@subsup{t}{pd(5)}{min
t3(min)}=t2\operatorname{min}+\mp@subsup{t}{pd(5) max }{m}+\mp@subsup{t}{su}{
t4(min)}=\mp@subsup{t}{pd(9) max }{\mathrm{ m }
```

See the DRAM data sheet for applicable $t_{s u}(A R), t_{s u}(A C)$, and $t_{h}(A R)$. In addition, note that propagation delay times given in the above equations are functions of capacitive loading. The values used in these equations must correspond to actual system capacitive loading. $\ddagger$ A $\overline{\mathrm{CAS}} n$ output is selected by the bank counter. All other $\overline{\mathrm{CAS}} \mathrm{n}$ outputs will remain high.



## SWITCHING TEST CIRCUIT


${ }^{*}{ }^{t_{p d}}$ specified at $C_{L}=50,150 \mathrm{pF}$
FIGURE 10. CAPACITIVE LOAD SWITCHING


FIGURE 11. THREE-STATE ENABLE/DISABLE

TYPICAL SWITCHING CHARACTERISTICS


FIGURE 12. OUTPUT DRIVE LEVELS

THREE-STATE TIMING


NOTE: Decoupling is needed for all AC tests
FIGURE 13. THREE-STATE CONTROL LEVELS

- Provides Control for 16K, 64K, 256K, and 1M Dynamic RAMs
- Highest-Order Two-Address Bits Select One of Four Banks of RAMs
- Supports Scrubbing Operations and NibbleMode Access
- Separate Output Enable for Multi-Channel Access to Memory
- 52-Pin Dual-In-Line Package


## description

The 'ALS6301 and 'ALS6302 dynamic memory controllers (DMCs) are designed for use in today's high-performance memory systems. The DMC acts as the address controller between any processor and dynamic memory array.
Two versions are provided that help simplify interfacing to the system dynamic timing controller. The 'ALS6301 offers active-low Row Address Strobe Input ( $\overline{\text { RASI })}$ and Column Address Strobe Input ( $\overline{\mathrm{CASI}}$ ), while the 'ALS6302 offers active-high Row Address Strobe Input (RASI) and Column Address Strobe Input (CASI) inputs.
Using two 10-bit address latches, the DMC will hold the row and column addresses for any DRAM up to 1 M . These latches and the two row/column refresh address counters feed into a 10-bit, 4-input MUX for output to the dynamic RAM address lines. A 2-bit bank select latch is provided to select one of the four $\overline{\text { RAS }}$ and $\overline{\text { CAS }}$ outputs. The two bits are normally obtained from the two highest-order address bits.

| SN54ALS6301, SN54ALS6302 . . JD PACKAGE |
| ---: |
| SN74ALS6301, SN74ALS6302 $\ldots$ JD OR N PACKAGE |

(TOP VIEW)
CS
A1
† 'ALS6301 has active-low inputs $\overline{\text { CASI }}$ and $\overline{\text { RASI; ' } A L S 6302 \text { has }}$ active-high inputs CASI and RASI.

The 'ALS6301 and 'ALS6302 have two basic modes of operation, read/write and refresh. During normal read/write operations, the row and column addresses are multiplexed to the dynamic RAM, with the corresponding $\overline{\operatorname{RAS}}$ and $\overline{\mathrm{CAS}}$ signals activated to strobe the addresses into the RAM. In the refresh mode, the two counters cycle through the refresh addresses. If memory scrubbing is not being implemented, only the row counter is used. When memory scrubbing is being performed, both the row and column counters are used to perform read-modify-write cycles. In this mode all $\overline{R A S}$ outputs will be active (low) while only one $\overline{\text { CAS }}$ output is active at a time.

The SN54ALS6301 and SN54ALS6302 are characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74ALS6301 and SN74ALS6302 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.
logic diagram (positive logic)


## SN54ALS6301, SN74ALS6301, SN54ALS6302, SN74ALS6302 DYNAMIC MEMORY CONTROLLERS

logic symbols ${ }^{\dagger}$

'ALS6302

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

## SN54ALS6301, SN74ALS6301, SN54ALS6302, SN74ALS6302 DYNAMIC MEMORY CONTROLLERS

## TABLE 1. PIN FUNCTION

| PIN NAME | DESCRIPTION |
| :---: | :---: |
| A0-A19 | Address Inputs. A0-A9 are latched in as the nine-bit row address for the DRAM. These inputs drive Q0-Q9 when the DMC is in the read/write mode and MSEL is low. A10-A19 are latched in as the column address, and will drive Q0-Q8 when MSEL is high and the DMC is in the read/write mode. The addresses are latched when the Latch Enable (LE) input signal is low. |
| SELO, SEL1 | Bank Select. These two inputs are normally the two highest-order address bits and are used in the read/write mode to select which bank of memory will be receiving the $\overline{\operatorname{RAS}}$ and $\overline{\mathrm{CAS}}$ signals after $\overline{\mathrm{RASI}}$ ('ALS6301) or RASI ('ALS6302) and CASI ('ALS6301) or CASI ('ALS6302) go active. |
| LE | Latch Enable. This active-high input causes the row, column, and bank select latches to become transparent, allowing the latches to accept new input data. A low input on LE latches the input data. |
| MSEL | Multiplexer Select. This input determines whether the row or column address will be sent to the memory address inputs. When MSEL is high, the column address is selected, while the row address is selected when MSEL is low. The address may come from either the address latch or refresh address counter depending on MCO and MC1 (see Mode Control Function Table). |
| $\overline{\mathrm{CS}}$ | Chip Select. This active-low input is used to enable the DMC. When $\overline{\mathrm{CS}}$ is active, the DMC operates normally in all four modes. When $\overline{C S}$ goes high, the device will not enter the read/write mode. This allows other devices to access the same memory that the DMC is controlling. |
| $\overline{\mathrm{OE}}$ | Output Enable. This active-low input enables/disables the output signals. When $\overline{\mathrm{OE}}$ is high, the outputs of the DMC enter the high-impedance state. |
| MCO-MC1 | Mode Controls. These inputs determine in which of the four modes the DMC operates. The description of each of the four operating modes is given in Table 2. |
| Q0-08 | Address Outputs. These address outputs feed the DRAM address inputs and provide drive for memory systems having capacitance of up to 500 picofarads. |
| $\overline{\text { RASI }}$ or RASI | Row Address Strobe Input. During the normal memory cycles, the decoded $\overline{\mathrm{RAS}}$ n output ( $\overline{\mathrm{RAS}} 0, \overline{\mathrm{RAS}} 1, \overline{\mathrm{RAS}} 2$, or $\overline{\mathrm{RAS}} 3$ ) is forced low after receipt of an active Row Address Strobe Input signal. In either Refresh mode, all four RAS outputs will be low while the Row Address Strobe Input signal is active. The $\overline{R A S I}$ on the 'ALS6301 is an active-low input while on the 'ALS6302, RASI is an active-high input. (For more details see timing diagrams). |
| $\overline{\text { RAS }} 0-\overline{\mathrm{RAS}} 3$ | Row Address Strobe. Each of the Row Address Strobe outputs provides a $\overline{\mathrm{RAS}}$ signal to one of the four banks of dynamic memory. Each $\overline{\operatorname{RAS}}$ n output will go low when selected by SELO and SEL1 after $\overline{\operatorname{RASI}}$ ('ALS6301) or RASI ('ALS6302) goes active. All four go low in response to $\overline{\text { RASI ('ALS6301) or RASI ('ALS6302) while in the refresh mode. }}$ |
| $\overline{\text { CASI }}$ or CASI | Column Address Strobe Input. This input going active causes the selected $\overline{C A S}$ output to be forced low. The $\overline{\text { CASI }}$ input on the 'ALS6301 is active low input while on the 'ALS6302, CASI is active high input. (For more details see timing diagrams.) |
| $\overline{\text { CAS } 0-\overline{C A S} 3}$ | Column Address Strobe. During normal Read/Write cycles the two selected bits (SELO, SEL1) determine which CAS output will go active following CASI ('ALS6301) or CASI ('ALS6302) going active. When memory scrubbing is being performed, only the $\overline{C A S} n$ signal selected will be active. For non-scrubbing cycles, all four $\overline{\text { CAS }}$ outputs will remain high. |
| $\overline{T P}$ | This active-low test input asynchronously sets the row and column input latches high, while forcing the two bank select latches low. In normal operation, $\overline{\mathrm{TP}}$ is tied high. |

## TABLE 2. MODE-CONTROL FUNCTION TABLE

| MC1 L | MCO L | OPERATING MODE <br> Refresh Mode without Scrubbing. Refresh cycles are performed with only the row counter being used to generate the addresses. In this mode, all four $\overline{\mathrm{RAS}}$ outputs are active while the four $\overline{\mathrm{CAS}}$ outputs remain high. |
| :---: | :---: | :---: |
| L | H | Refresh with Scrubbing/Initialize. During this mode, refresh cycles are done with both the row and column counters generating the addresses. MSEL is used to select either the row or the column counter. All four $\overline{\operatorname{RAS}}$ outputs go low in response to $\overline{\operatorname{RASI}}$ ('ALS6301) or RASI ('ALS6302), while only one $\overline{\mathrm{CAS}} \mathrm{n}$ output goes low in response to $\overline{\mathrm{CASI}}$ ('ALS6301) or CASI ('ALS6302). The bank counter keeps track of which $\overline{\text { CAS output goes active. This mode can }}$ also be used during system power-up so that the memory can be written with a known data pattern. |
| H | L | Read/Write. This mode is used to perform read/write cycles. Both the Row and Column addresses are multiplexed to the address output lines using MSEL. SELO and SEL1 are decoded to determine which $\overline{\operatorname{RAS}} \mathrm{n}$ and $\overline{\mathrm{CAS}} \mathrm{n}$ outputs will be active. |
| H | H | Clear Refresh Counters. This mode clears the three refresh counters (row, column, and bank) on the inactive transition of $\overline{\text { RASI ('ALS6301) or RASI ('ALS6302), putting them at start of the refresh sequence (see timing diagrams for more }}$ detail). In this mode, all four $\overline{\text { RAS }}$ outputs are driven low after the active edge of $\overline{\text { RASI ('ALS6301) or RASI ('ALS6302) }}$ so that DRAM wake-up cycles may also be performed. |

- Direct Replacement for National Semiconductor DP8400
- Fast Single- and Double-Error Detection
- Fast Single-Error Correction and Functionally Expandable to $100 \%$ Double-Error Correction Capability
- Double-Error Correction after Catastrophic Failure without Additional Check Bits or ICs
- Functionally Expandable Capability Up to Triple-Error Detection
- Expandable to and beyond 64 Bits with Additional 'ALS8400s
- Complete Error Recording
- Byte Parity Generating and Checking
- Separate Byte Controls for Data Output in Byte-Write Operation
- Syndrome I/O Port for Error Logging and Management
- Full Memory Check Diagnostic and Check Bits Simulation Diagnostics Capability
- Self-Test of 'ALS8400 on the Memory Card Under Processor Control
- Complete Memory Failure Detection
- Power-On Clears Data and Syndrome Latches



## description

The 'ALS8400 is a monolithic Advanced Low-Power Schottky error checker and corrector (ECC) integrated circuit designed to aid in system reliability and integrity by detecting errors in memory data and correcting single- or double-bit errors. The ECC has a separate syndrome I/O bus, which can be used for error logging or error management. It can also be used in BYTE-WRITE applications (for up to 72 data bits) because it has separate byte controls for the data buffers. In 16- or 32-bit systems, the 'ALS8400 will generate and check system byte parity, if required, for integrity of the data supplied from or to the processor. There are three latch controls to enable latching of data in various modes and configurations.

The 'ALS8400 is easily expandable to other data configurations. For 32-bit data bus with seven check bits, two 'ALS8400s can be used in cascade with no other ICs. Three 'ALS8400s can be used for 48 bits, and four 'ALS8400s for 64 data bits, both using eight check bits. In all these configurations, singleerror and double-error detection and single-error correction are easy to implement.
The 'ALS8400 is characterized for operation from ${ }^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

| PIN NAMES | 1/0 | DESCRIPTION |
| :---: | :---: | :---: |
| AE | 0 | Any error output. In the normal read mode, when low, AE indicates no error and when high, indicates that an error has occurred. In any write mode, AE is permanently low. |
| BPO/C7 | 1/0 | Byte parity $0 /$ check bit 7 . When XP is at 0 V , this pin is byte -0 parity $\mathrm{I} / \mathrm{O}$. In the normal write mode, BPO receives system byte- 0 parity, and in the normal read mode, outputs system byte-O parity. When the XP pin is open or at $\mathrm{V}_{\mathrm{CC}}$, the $\mathrm{BPO} / \mathrm{C} 7$ pin becomes the check bit $\mathrm{C} 7 \mathrm{I} / \mathrm{O}$, the eighth check bit for the memory check bits, for 48 -bit expansion configuration and beyond. |
| BP1/S7 | I/O | Byte parity $1 /$ syndrome bit 7 . When XP pin is at 0 V , this pin is byte 1 parity $1 / O$. In the normal write mode, BP1 receives system byte-1 parity, and in the normal read mode outputs system byte-1 parity. When the $X P$ pin is open or at $V_{C C}$, the $\mathrm{BP} 1 / \mathrm{S} 7$ pin becomes the syndrome bit $\mathrm{S} 7 / / \mathrm{O}$, the eighth syndrome bit, for 48-bit expansion configuration and beyond. |
| CSLE | I | Input check bit and syndrome latch enable. When high, the outputs of the check bit input latches follow input check bit and, if $\overline{O E S}$ is low, the outputs of the syndrome input latches follow the syndrome bit bus. |
| C0-C6 | I/O | Check-bit I/O port. A 7-bit bidirectional bus connected to the input of the check-bit input latches and the outputs of the check-bit output buffers. The check-bit output buffers are enabled whenever M2 pin is low. |
| DLE | I | Input data latch enable. When high, outputs of the data input latches follow the input data bus. When low, the data input latches store the input data. |
| DQ0-DQ15 | I/O | Data I/O port. A 16-bit bidirectional data bus connected to the input of the data input latches and the outputs of the data output buffers, with DQ8-DQ15 also connected to the check-bit input latches. |
| EO | 0 | Error $O$ output. In the normal read mode, EO is high for a single-data error and low for other conditions. In the normal write mode, EO becomes PEO and is low if a parity error exists in byte-0 as transmitted from the processor. |
| E1 | 0 | Error 1 output. In the normal read mode, E1 is high for a single-data error or a single check-bit error, and low for no error or a double error. In the normal write mode, E1 becomes PE1 and is low if a parity error exists in byte 1 as transmitted from the processor. |
| GND |  | System ground |
| MO-M2 | I | Mode control inputs. These three controls define the eight major operational modes of the ECC. Table 1 describes the modes. |
| $\overline{\mathrm{OB}} 0, \overline{\mathrm{OB}} 1$ | 1 | Output byte 0 and Output byte 1 enables. These inputs, when low, enable the outputs of the data output latches through the data output buffers onto the data bus. When $\overline{O B} 0$ and $\overline{O B} 1$ are high, the outputs of the data output buffers are placed in the high-impedance state. |
| $\overline{\text { OES }}$ | 1 | Output enable syndromes. 1/O control of the syndrome latches. When high, the outputs of the syndrome output buffers are placed in the high-impedance state and external syndromes pass through the syndrome input latches with CSLE high. When $\overline{\mathrm{OES}}$ is low, the outputs of the syndrome output buffers are enabled and the generated syndromes appear on the syndrome bus, also CSLE is inhibited internally to the syndrome input latches. |
| $\overline{\text { OLE }}$ | 1 | Output latch enable. When low, $\overline{O L E}$ enables the internally generated data to enter the data output latches, check bit output latches, and syndrome output latches. When $\overline{\mathrm{OLE}}$ is high, the latches store the data. |
| S0-S6 | 1/O | Syndrome I/O port. A 7-bit bidirectional bus connected to the input of the syndrome input latches and the outputs of the syndrome output buffers. |
| $\mathrm{V}_{\mathrm{CC}}$ | I | 5 -volt supply voltage input. |
| XP | 1 | Multiexpansion input to a three-level comparator. With XP at 0 V , only 6 or 7 check bits are available for expansion up to 40 bits, allowing byte parity capability. With XP open or at $V_{C C}$, expansion beyond 40 bits is possible, but byte-parity capability is no longer available. When $X P$ is at $V_{C C}$, check-bit generator bits 6 and 7, the internally generated upper two check bits, are set low. When XP is open, check-bit generator bits 6 and 7 are set to word parity. |

## functional description

The 'ALS8400, with its 16 -bit bidirectional data bus connected to the memory data bus, monitors data between the processor and memory. It uses an encoding matrix to generate six check bits from the 16 bits of data. In a write cycle, the data word and the corresponding check bits are written into memory. When the same location of memory is subsequently read, the ECC generates six new check bits from the memory data and compares them with the six check bits read from memory to create six syndrome bits. If there is a difference (causing some syndrome bits to go high), then that memory location contains an error and the ECC indicates the type of error with three error flags. If the error is a single-bit error, the ECC will automatically correct it.

When the memory has more than one error, or better system integrity is preferred, double-error correction can be performed. One approach requires a further write-read cycle using complemented data and check bits from the ECC. If at least one of the two errors is a hard error, the ECC will correct both errors. This implementation requires no more memory check bits or ECCs than the single-error correct configuration.

- Advanced Schottky IMPACT-X ${ }^{m}$ Process
- Three-Operand, 64-Word by 40-Bit Register File
- Supports 'AS888 and 'AS8832 Register File Expansion
- Four 10-Bit Input Ports with Individual Parity Checkers and Write Enables
- Four 10-Bit Output Ports with Individual Three-State Enables
- Two Write Address Ports
- Two Read Address Ports and Y Output Mux Permit LSH/MSH Swap Operations
- 156-Pin Package
- 8-mA Bus Drivers
- Texas Instruments Quality and Reliability


## description

The SN54AS8834 and SN74AS8834 are high speed, three-operand, 64-word register files in a 156-pin ceramic pin grid array.

The register files are designed to support register file expansion for bit-slice systems using the'AS888 or 'AS8832. Internal parity checks and a 40-bit word width support I/O operations for graphics and 32-bit error detection and correction boards.

The SN54AS8834 is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS8834 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

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



[^71]

[^72]SN54AS8834, SN74AS8834
40-BIT REGISTER FILE

| PIN |  |  | DESCPIPTION |
| :---: | :---: | :---: | :---: |
| NAME | NO. | 1/0 | DESCRIPTIO |
| AL/ $\overline{B R}$ | F15 | 1 | Output select for Y20-Y39 output data. High selects DA20-DA39; low selects DB0-DB19. |
| AR/ $\overline{B L}$ | G2 | 1 | Output select for Y0-Y10 output data. High selects DAO-DA19; low selects DA20-DA39. |
| CLK | P15 | 1 | Clocks data into register file on rising edge. |
| DO | G14 |  |  |
| D1 | G15 |  |  |
| D2 | H13 |  |  |
| D3 | H12 |  |  |
| D4 | H15 | 1 | Input data bits 0 through 9 |
| D5 | H14 | 1 | Input data bits 0 through 9 |
| D6 | $J 15$ |  |  |
| D7 | J14 |  |  |
| D8 | K15 |  |  |
| D9 | K14 |  |  |
| D10 | L15 |  |  |
| D11 | J12 |  |  |
| D12 | P12 |  |  |
| D13 | P14 |  |  |
| D14 | N11 | 1 | Input data bits 10 through 19 |
| D15 | Q15 | 1 | Input data bits 10 through 19 |
| D16 | P11 |  |  |
| D17 | Q14 |  |  |
| D18 | M10 |  |  |
| D19 | Q13 |  |  |
| D20 | N10 |  | - |
| D21 | Q12 |  |  |
| D22 | P10 |  |  |
| D23 | Q11 |  |  |
| D24 | N9 | 1 |  |
| D25 | Q10 | 1 | input data bits 20 through 29 |
| D26 | P9 |  |  |
| D27 | Q9 |  | , |
| D28 | M7 |  |  |
| D29 | Q5 |  |  |
| D30 | P7 |  |  |
| D31 | Q4 |  | , |
| D32 | P6 |  |  |
| D33 | Q3 |  |  |
| D34 | N6 |  |  |
| D35 | Q2 | 1 | Input data bits 30 through 39 |
| D36 | P5 |  |  |
| D37 | P3 |  |  |
| D38 | N5 |  | , |
| D39 | P4 |  |  |
| GND1 | E3 |  |  |
| GND1 | E13 |  |  |
| GND1 | C6 |  |  |
| GND1 | C8 |  | 5 -volt ground (All ground pins must be used.) |
| GND1 | C10 |  |  |
| GND1 | N8 |  |  |

| NAME | NO. | I/O | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| GND2 | F3 |  |  |
| GND2 | F13 |  |  |
| GND2 | J13 |  | 2-volt ground (All ground pins must be used.) |
| GND2 | K2 |  |  |
| GND2 | D3 |  |  |
| M8 | PL2 | 0 | Parity check result. High indicates odd number of high inputs on D30-D39. |
| $\overline{\mathrm{MOE}}$ | G12 | 1 | Master output enable, active low. Places Y0-Y39 and parity outputs in the high-impedance state when high. |
| NC | A2 |  |  |
| NC | A7 | . |  |
| NC | A8 |  |  |
| NC | A13 |  |  |
| NC | B14 |  |  |
| NC | C2 |  |  |
| NC | C3 |  |  |
| NC | C13 |  |  |
| NC | C15 |  | No internal connection |
| NC | D1 |  |  |
| NC | E1 |  |  |
| NC | M15 |  |  |
| NC | N1 |  | . . . |
| NC | N15 |  |  |
| NC | P1 |  |  |
| NC | Q8 |  |  |
| $\overline{\mathrm{OEL}} 1$ | F14 |  | Y20-Y29 output enable, active low |
| $\overline{\mathrm{OEL}} 2$ | D15 |  | Y30-Y39 output enable, active low |
| OER1 | F1 | I | Y0-Y9 output enable, active low |
| OER2 | G4 |  | Y10-Y19 output enable, active low |
| PL1 | P8 |  | '`arity check result. High indicates odd number of high inputs on D20-D29. |
| PL2 | M8 |  | Parity check result. High indicates odd number of high inputs on D30-D39. |
| PR1 | Q6 | 0 | Parity check result. High indicates odd number of high inputs on D0-D9. |
| PR2 | Q7 |  | Parity check result. High indicates odd number of high inputs on D10-D19. |
| RAAO | M1 |  |  |
| RAA 1 | J4 |  |  |
| RAA2 | L1 |  |  |
| RAA3 | J3 | 1 | Register file A port read address select ( $0=$ LSB) |
| RAA4 | K1 |  |  |
| RAA5 | J2 |  |  |
| RABO | J1 |  |  |
| RAB1 | H4 |  |  |
| RAB2 | H3 | 1 | Register file A port read address select ( 0 - LSB |
| RAB3 | H1 | 1 | Register file A port read address select ( $0=L S B)$ |
| RAB4 | H2 |  |  |
| RAB5 | G1 |  |  |
| TP1 | G13 |  | Functional testing input During normal operation, should be maintained high or open |
| TP2 | E15 | 1 | Functional testing input. During normal operation, should be maintained high or open. |

SN54AS8834, SN74AS8834 40-BIT REGISTER FILE

| PIN |  |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | NO. | 1/0 |  |
| $\mathrm{V}_{\text {CC1 }}$ | C5 |  |  |
| $\mathrm{V}_{\mathrm{CC} 1}$ | C11 |  | 5 -volt supply for TTL-compatible I/O |
| $\mathrm{V}_{\mathrm{CC} 1}$ | D8 |  | voit supply for TYL-compatible I/O |
| $\mathrm{V}_{\mathrm{CC} 1}$ | N7 |  |  |
| $\mathrm{V}_{\text {CC2 }}$ | G3 |  |  |
| $V_{\text {CC2 }}$ | K13 |  | 2-volt supply for internal Schottky transistor logic |
| $\mathrm{V}_{\mathrm{CC} 2}$ | L3 |  |  |
| WALO | N14 |  |  |
| WAL1 | L13 |  |  |
| WAL2 | M14 |  | Write address for D20-D39 input data |
| WAL3 | M13 | 1 | Write address for D20-D39 input data |
| WAL4 | N13 |  |  |
| WAL5 | P13 |  |  |
| WARO | L2 |  |  |
| WAR1 | P2 |  |  |
| WAR2 | M2 | 1 |  |
| WAR3 | M3 | 1 | Write address for DO-D19 input data |
| WAR4 | N2 |  |  |
| WAR5 | N3 |  |  |
| WEL1 | N12 |  | D20-D29 write enable, active low |
| WEL2 | L14 | 1 | D30-D39 write enable, active low |
| WER1 | 01 | 1 | DO-D9 write enable, active low |
| WER2 | N4 |  | D10-D19 write enable, active low |
| Yo | B15 |  |  |
| Y1 | E14 |  |  |
| Y2 | A15 |  |  |
| Y3 | D14 |  |  |
| Y4 | D13 | 0 | Output data bits 0 through 9 |
| Y5 | C14 | 0 | Output data bits 0 through 9 |
| Y6 | C12 |  |  |
| Y7 | B12 |  |  |
| Y8 | B13 |  |  |
| Y9 | B11 |  |  |
| Y10 | A14 | 0 | Output data bits 10 through 19 |
| Y11 | B10 |  |  |
| Y12 | A12 |  |  |
| Y13 | B9 |  |  |
| Y14 | A11 |  |  |
| Y15 | D9 |  |  |
| Y16 | A10 |  |  |
| Y17 | C9 |  |  |
| Y18 | A9 |  |  |
| Y19 | B8 |  |  |

SN54AS8834, SN74AS8834
40-BIT REGISTER FILE

| PIN |  |  |  |
| :--- | :--- | :--- | :--- |
| NAME | NO. | I/O |  |
| Y20 | B7 |  |  |
| Y21 | A6 |  |  |
| Y22 | C7 |  |  |
| Y23 | A5 |  |  |
| Y24 | D7 | O |  |
| Y25 | A4 |  |  |
| Y26 | B6 |  |  |
| Y27 | A3 |  |  |
| Y28 | B5 |  |  |
| Y29 | A1 |  |  |
| Y30 | B4 |  |  |
| Y31 | B2 |  |  |
| Y32 | C4 |  |  |
| Y33 | B3 |  |  |
| Y34 | D3 | O |  |
| Y35 | D2 | Output data bits 30 through 39 |  |
| Y36 | E2 |  |  |
| Y37 | B1 |  |  |
| Y38 | F2 |  |  |
| Y39 | C1 |  |  |


ALS8834 REGISTER FILE


## SN54AS8834, SN74AS8834 <br> 40-BIT REGISTER FILE

## data input/output ports

Data is input to the 'AS8834 through four 10-bit data ports: D30-D39, D20-D29, D10-D19 and D0-D9. Data is output from the register file through four 10-bit output ports: Y30-Y39, Y20-Y29, Y10-Y19 and Y0-Y9. The $Y$ ports are enabled by four active low output enables: $\overline{O E L} 2$ for Y30-Y39, $\overline{O E L} 1$ for Y20-Y29, $\overline{\mathrm{OER}} 2$ for $\mathrm{Y} 10-\mathrm{Y} 19$, and $\overline{\mathrm{OER}} 1$ for YO-Y9.

## register file addressing

Data is stored in the register file on the rising edge of the clock. Two write address ports and two read address ports operate independently to implement a 40-bit register file that supports MSH/LSH swap operations. WALO-WAL5 is the write address for D20-D39 input data; WARO-WAR5 is the write address for D0-D19 input data. These separate write addresses permit the most significant and the least significant half of a word to be stored at different addresses. Register file writes are enabled by four write enables: WEL2 for D30-D39, WEL1 for D20-D29, WER2 for D10-D19, and WER1 for DO-D9.

Two read address lines are also provided: RAAO-RAA5 and RABO-RAB5. These lines control the selection of data to be output on internal data buses DAO-DA39 and DBO-DB39 respectively. Y-output data selection is controlled by $A L / \overline{B R}$ and $A R / \overline{B L}$ as shown in Table 1.

TABLE 1. OUTPUT FUNCTION TABLE

| SIGNAL | RESULT | SIGNAL | RESULT | RESULT WHEN COMBINED |  |
| :---: | :---: | :---: | :--- | :---: | :---: |
| AL/BR | Y20-Y39 | AR/BL | YO-Y19 | Y20-Y39 | Y0-Y19 |
| H | A20-A39 | H | AO-A19 | A (MSH) | A (LSH) |
| H | A20-A39 | L | B20-B39 | A (MSH) | B (MSH) |
| L | B0-B19 | H | AO-A19 | B (LSH) | A (LSH) |
| L | B0-B19 | L | B20-B39 | B (LSH) | B (MSH) |

## parity checkers

Two parity checkers are provided for data on the $D$ input ports. A high on output signals PL2, PL1, PR2 or PR1 indicate an odd number of high signals on data inputs D30-D39, D20-D29, D10-D19 and D0-D9 respectively.

## master output enable

When high, Master Output Enable, $\overline{\text { MOE, places the four } Y \text { output ports and the four parity output ports in the }}$ high-impedance state.

## SN54AS8834, SN74AS8834 40-BIT REGISTER FILE

absolute maximum ratings over operating temperature range (unless otherwise noted)
Supply voltage, $\mathrm{V}_{\mathrm{CC}} 1$
7 V
Supply voltage, VCC2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 V
Input voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
High-level voltage applied to 3 -state outputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V
Operating case temperature range: SN54AS8834. . . . . . . . . . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Operating free-air temperature range: SN74AS8834 . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended operating conditions

| PARAMETER | SN54AS8834 |  |  | SN74AS8834 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC1 }}$ I/O supply voltage | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\mathrm{CC} 2} \mathrm{STL}$ internal logic supply voltage | 1.9 | 2 | 2.1 | 1.9 | 2 | 2.1 | V |
| $\mathrm{V}_{\text {IH }} \quad$ High-level input voltage | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }} \quad$ Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| $1 \mathrm{OH} \quad$ High-level output current |  |  | -1 |  |  | 2.6 | mA |
| IOL Low-level output current |  |  | 8 |  |  | 8 | mA |
| TC. Operating case temperature |  |  | 125 |  |  |  | ${ }^{\circ} \mathrm{C}$ |
| TA Operating free-air temperature | -55 |  |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

| PARAMETER | TEST CONDITIONS |  | SN54AS8834 |  |  | SN74AS8834 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | TYP ${ }^{\dagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{I}}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-1 \mathrm{~mA}$ | 2.4 |  |  | 2.4 |  |  | V |
|  | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-2.6 \mathrm{~mA}$ |  |  |  |  |  |  |  |
| $\mathrm{V}_{\text {OL }}$ | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=8 \mathrm{~mA}$ |  |  | 0.5 |  |  | 0.5 | V |
| ${ }^{\text {IOZH }}$ | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  |  |  |  |  | 20 | $\mu \mathrm{A}$ |
| IOZL | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{0}=0.4 \mathrm{~V}$ |  |  |  |  |  | -0.4 | mA |
| 1 | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| 1 H | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| ILL | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  | -0.4 |  |  | -0.4 | mA |
| $10^{\ddagger}$ | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 |  | -112 | -30 |  | -112 | mA |
| ICC1 | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}$ |  |  |  |  |  |  |  | mA |
| ICC2 | $\mathrm{V}_{\mathrm{CC} 2}=2.1 \mathrm{~V}$ |  |  |  |  |  |  |  | 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 the true short-circuit current, IOS.

SN54AS8834, SN74AS8834
40-BIT REGISTER FILE

## timing requirements

|  |  | PARAMETER | SN54AS8834 |  | SN74AS8834 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {t }}$ su | Setup time | WEL1-WEL2 before CLK $\uparrow$ |  |  |  |  | ns |
|  |  |  |  |  |  |  |  |
|  |  | WALO-WAL 5 before CLK $\uparrow$ |  |  |  |  |  |
|  |  | WARO-WAR5 before CLK $\uparrow$ |  |  |  |  |  |
|  |  | D0-D39 before CLK $\uparrow$ |  |  |  |  |  |
| $t_{h}$ | Hold time | $\overline{\text { WEL }} 1-\overline{\text { WEL }} 2$ after CLK $\uparrow$ |  |  |  |  | ns |
|  |  | $\overline{\text { WER1-WER2 after CLK } \uparrow ~}$ |  |  |  |  |  |
|  |  | WALO-WAL5 after CLK $\uparrow$ |  |  |  |  |  |
|  |  | WARO-WAR5 after CLK $\uparrow$ |  |  |  |  |  |
|  |  | D0-D39 after CLK $\uparrow$ |  |  |  |  |  |

switching characteristics over recommended ranges of operating temperature and supply voltage (see Note 1)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | SN54AS8834 |  | SN74AS8834 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {tpd }}$ | D30-D39 | PL2 |  |  |  |  | ns |
|  | D20-D29 | PL1 |  |  |  |  |  |
|  | D10-D19 | PR2 |  |  |  |  |  |
|  | D0-D9 | PR1 |  |  |  |  |  |
|  | RAAO-RAA5 | YO-Y39 |  |  |  |  |  |
|  | RABO-RAB5 | Y0-Y39 |  |  |  |  |  |
|  | $A L / \overline{B R}$ | Y20-Y39 |  |  |  |  |  |
|  | AR/EL | Yo-Y19 |  |  |  |  |  |
|  | CLK | Yo-Y39 ${ }^{\dagger}$ |  |  |  |  |  |
| $\mathrm{t}_{\text {en }}$ | $\overline{\text { MOE }}$ | $\begin{aligned} & \text { PL2-PL1 or } \\ & \text { PR2-PR1 } \\ & \hline \end{aligned}$ |  |  |  |  | ns |
|  | $\overline{\mathrm{MOE}}$ | Y0-Y39 |  |  |  |  |  |
|  | OEL2 | Y30-Y39 |  |  |  |  |  |
|  | OEL1 | Y20-Y29 |  |  |  |  |  |
|  | $\overline{\mathrm{OER}} 2$ | Y10-Y19 |  |  |  |  |  |
|  | OER1 | Y0-Y9 |  |  |  |  |  |
| $\mathrm{t}_{\text {dis }}$ | $\overline{\text { MOE }}$ | PL2-PL1 or PR2-PR1 |  |  |  |  | ns |
|  | $\overline{\text { MOE }}$ | YO-Y39 |  |  |  |  |  |
|  | OEL2 | Y30-Y39 |  |  |  |  |  |
|  | OEL1 | Y20-Y29 |  |  |  |  |  |
|  | $\overline{\mathrm{OER}} 2$ | Y10-Y19 |  |  |  |  |  |
|  | OER1 | Yo-Y9 |  |  |  |  |  |

$\dagger$ When read and write address are already selected.
NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

## - High-Speed "Flash" Shift Operations

- Shifts up to $\mathbf{3 2}$ Positions in Less than 25 ns
- Performs Logical, Circular, and Arithmetic Shifts
- 3-State Outputs Allow 32-Bit and 16-Bit Bus Interface
- 24-mA Bus Drivers
- 84-Pin Package
- Uses Less than 1.5 W (Max)
- Texas Instruments Quality and Reliability


## description

The SN54AS8838 and SN74AS8838 are highspeed 32 -bit barrel shifters in an 84-pin ceramic pin-grid array. The devices can shift up to 32 bits in a single instruction cycle of under 25 nanoseconds. Five basic shifts can be programmed: circular left and right, logical left and right, and arithmetic right.

Unlike conventional shift registers, whose shift operations are controlled by the number of input clock pulses applied, the number of positions to be shifted by the 'AS8838 is determined by an input decoder. This form of implementation does not require an input clock, thus, the shift operation is restricted only by internal propagation delays. The delay is the same regardless of the number of positions to be shifted, resulting in a high-speed "flash" shift.

Three-state output controls allow the devices to be interfaced with 32 - or 16 -bit data buses.

The SN54AS8838 is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS8838 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

SN54AS8838, SN74AS8838
GB PIN-GRID-ARRAY PACKAGE
(TOP VIEW)


| PIN |  | PIN |  |
| :---: | :---: | :---: | :---: |
| NO. | NAME | NO. | NAME |
| A1 | GND | F9 | YOEL |
| A2 | $\mathrm{V}_{\mathrm{CC} 2}$ | F10 | Y7 |
| A3 | Y30 | F11 | Y6 |
| A4 | Y28 | G1 | D20 |
| A5 | Y25 | G2 | D19 |
| A6 | Y23 | G3 | D18 |
| A7 | GND | G9 | Y4 |
| A8 | Y20 | G10 | Y5 |
| A9 | Y18 | G11 | GND |
| A10 | Y16 | H1 | D17 |
| A11 | GND | H2 | D16 |
| B1 | D31 | H10 | Y2 |
| B2 | GND | H11 | Y3 |
| B3 | Y31 | J1 | D15 |
| B4 | Y29 | J2 | D14 |
| B5 | Y26 | J5 | D7 |
| B6 | Y24 | J6 | D2 |
| B7 | Y22 | J7 | MUX1 |
| B8 | Y19 | J 10 | Yo |
| B9 | Y17 | $J 11$ | Y1 |
| B10 | $\mathrm{V}_{\mathrm{CC} 1}$ | K1 | $\mathrm{V}_{\mathrm{CC} 1}$ |
| B11 | Y15 | K2 | D13 |
| C1 | D29 | K3 | D11 |
| C2 | D30 | K4 | D9 |
| C5 | Y27 | K5 | D6 |
| C6 | YOEM | K6 | D3 |
| C7 | Y21 | K7 | DO |
| C10 | Y14 | K8 | SFT4 |
| C11 | Y13 | K9 | GND |
| D1 | D27 | K10 | SFT1 |
| D2 | D28 | K11 | SFTO |
| D10 | Y12 | L1 | GND |
| D11 | Y11 | L2 | D12 |
| E1 | D24 | L3 | D10 |
| E2 | D25 | L4 | D8 |
| E3 | D26 | L.5 | D5 |
| E9 | Y10 | L6 | D4 |
| E10 | Y9 | L7 | D1 |
| E11 | Y8 | L8 | MUXO |
| F1 | D23 | L9 | SFT3 |
| F2 | D22 | L10 | VCC2 |
| F3 | D21 | L11 | SFT2 |

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


${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984.

| PIN |  |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | NO. | I/O |  |
| DO | K7 | 1 | Input data bits 0 through 31 |
| D1 | L7 |  |  |
| D2 | J6 |  |  |
| D3 | K6 |  |  |
| D4 | L6 |  |  |
| D5 | L5 |  |  |
| D6 | K5 |  |  |
| D7 | J5 |  |  |
| D8 | L4 |  |  |
| D9 | K4 |  |  |
| D10 | L3 |  |  |
| D11 | K3 |  |  |
| D12 | L2 |  |  |
| D13 | K2 |  |  |
| D14 | J2 |  |  |
| D15 | J1 |  |  |
| D16 | H2 |  |  |
| D17 | H1 |  |  |
| D18 | G3 |  |  |
| D19 | G2 |  |  |
| D20 | G1 |  |  |
| D21 | F3 |  |  |
| D22 | F2 |  |  |
| D23 | F1 |  |  |
| D24 | E1 |  |  |
| D25 | E2 |  |  |
| D26 | E3 |  |  |
| D27 | D1 |  |  |
| D28 | D2 |  |  |
| D29 | C1 |  |  |
| D30 | C 2 |  |  |
| D31 | B1 |  |  |
| GND | A1 |  | Ground (All ground pins must be used.) |
| GND | A7 |  |  |
| GND | A11 |  |  |
| GND | B2 |  |  |
| GND | G11 |  |  |
| GND | K9 |  |  |
| GND | L1 |  |  |
| MUXO | L8 | 1 |  |
| MUX1 | $J 7$ | 1 | Shift instruction control. Specifies the type of shift operation to be performed. See Table 1 for further information. |
| SFTO | K11 | 1 | Shift position control. Specifies the number of bit positions to shift. See Table 1 for further information. |
| SFT1 | K10 |  |  |
| SFT2 | L11 |  |  |
| SFT3 | L9 |  |  |
| SFT4 | K8 |  |  |
|  | B10 |  | 5-Volt supply for TTL-compatible I/O |
| $\mathrm{V}_{\mathrm{CC} 1}$ | K1 |  |  |
| $\mathrm{V}_{\mathrm{CC} 2}$ | A2 |  | 2-Volt supply for internal Schottky Transistor Logic (STL) |
| $\mathrm{V}_{\mathrm{CC} 2}$ | L10 |  |  |

SN54AS8838, SN74AS8838
32-BIT BARREL SHIFTERS

| PIN |  |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NAME | NO. | 1/0 |  |
| YO | J10 |  |  |
| Y1 | J11 |  |  |
| Y2 | H10 |  |  |
| Y3 | H11 |  |  |
| Y4 | G9 |  |  |
| Y5 | G10 | 0 | Output data bits 0 through 10 |
| Y6 | F11 |  |  |
| Y7 | F10 |  |  |
| Y8 | E11 |  |  |
| Y9 | E10 |  |  |
| Y10 | E9 |  |  |
| Y11 | D11 |  | - |
| Y12 | D10 |  |  |
| Y13 | C11 |  |  |
| Y14 | C10 |  |  |
| Y15 | B11 |  |  |
| Y16 | A10 |  |  |
| Y17 | B9 |  |  |
| Y18 | A9 |  |  |
| Y19 | B8 |  |  |
| Y20 | A8 |  |  |
| Y21 | C7 | 0 | Output data bits 11 through 31 |
| Y22 | B7 |  |  |
| Y23 | A6 |  |  |
| Y24 | B6 |  |  |
| Y25 | A5 |  |  |
| Y26 | B5 |  |  |
| Y27 | C5 |  |  |
| Y28 | A4 |  |  |
| Y29 | B4 |  |  |
| Y30 | A3 |  |  |
| Y31 | B3 |  |  |
| YOEL | F9 | 1 | Control input for the Y15-Y0 output port. When YOEL is low, Y15-Y0 is enabled. |
| $\overline{\text { YOEM }}$ | C6 | 1 | Control input for the Y31-Y16 output port. When $\overline{\mathrm{YOEM}}$ is low, Y31-Y16 is enabled. |

## functional block diagram



## data input/output

Data is input to the 'AS8838 through the D31-DO data port and output through two 16-bit data ports, Y31-Y16 and Y15-Y0. Two 3-state output controls enable the Y data ports. The most significant half of the shift result is enabled when $\overline{\mathrm{YOEM}}$ is low, the least significant half when $\overline{\text { YOEL }}$ is low.

## shift control block

The shift control block decodes the MUX1-MUXO instruction inputs and the SFT4-SFTO shift position controls and transmits the resulting control signals to the shifter. MUX1-MUXO control shift instruction selection as shown in Table 1. SFT4-SFTO specify the number of bit positions to be shifted. For right shifts, the two's complement of the number of bit positions must be placed on SFT4-SFTO.

TABLE 1. INSTRUCTION SET

| MUX1 | MUXO | FUNCTION | OPERATION |
| :---: | :---: | :---: | :---: |
| L | L | Logical Left Shift | Shift left the number of bit positions defined by SFT4-SFTO. Fill vacated bit positions with zeros. |
| L | H | Logical Right Shift | Shift right the number of bit positions specified by the two's complement of SFT4-SFTO. Fill vacated bit positions with zeros. (A logical right shift with SFT4-SFTO $=0$ will fill all bits with zeros.) |
| H | L | Circular Left Shift | Circular left shift the number of bit positions defined by SFT4-SFTO. (A circular right shift can be performed by putting the two's complement of number of bits to be shifted on SFT4-SFT0.) |
| H | H | Arithmetic Right Shift | Shift right the number of bit positions defined by the two's complement of SFT4-SFTO. Fill vacated bit positions with the D31 input value (sign bit) (An arithmetic right shift with SFT4-SFTO $=0$ will fill all bits with the sign bit.). |

## SN54AS8838, SN74AS8838

32-BIT BARREL SHIFTERS

## shift operation examples

logical shift left (M1-M0 = LL)
In the shift left mode, SFT4-SFTO define the number of bit positions to be shifted. The following example shifts a 32 -bit word 8 positions to the left and fills the vacated bit positions with zeros.

CONTROL SIGNALS

| SHIFT <br> INSTRUCTION <br> M2-MO | NUMBER OF BITS <br> TO SHIFT <br> SFT4-SFTO |
| :---: | :---: |
| 00 | 01000 |

Assume D31-D0 is hex ABCD0123.

D31-D0

Input Data
10101011110011010000000100100011
logical shift right $(M 1-M O=L H)$
In the shift right mode, the two's complement of the number of bit positions to be shifted must be placed on SFT4-SFTO. The following example shifts a 32 -bit word 8 positions to the right and fills the vacated bit positions with zeros.

CONTROL SIGNALS

| SHIFT <br> INSTRUCTION <br> M2-M0 | NUMBER OF BITS <br> TO SHIFT <br> SFT4-SFTO |
| :---: | :---: |
| 01 | 11000 |

Assume D31-DO is hex ABCD0123.
D31-DO
Input Data $\quad 10101011110011010000000100100011$

Y31-Y0
Result 00000000101010111100110100000001
circular shift left ( $\mathrm{M} 1-\mathrm{MO}=\mathrm{HL}$ )
In the circular shift left mode, SFT4-SFTO define the number of bit positions to be shifted. The following example circular shifts a 32 -bit word 8 positions to the left.

CONTROL SIGNALS

| SHIFT <br> INSTRUCTION <br> M2-MO | NUMBER OF BITS <br> TO SHIFT <br> SFT4-SFTO |
| :---: | :---: |
| 10 | 01000 |

Assume D31-DO is hex ABCD0123.

D31-D0
Input Data 10101011110011010000000100100011

Y31-Y0
Result 11001101000000010010001110101011
circular shift right $(M 1-M 0=H L)$
A circular right shift can be performed by placing the two's complement of the number of bit positions. to be shifted on SFT4-SFTO and using the circular left shift mode ( $M 1-M 0=H L$ ). The following example circular shifts a 32 -bit word 8 positions to the right.

CONTROL SIGNALS

| SHIFT <br> INSTRUCTION <br> M2-MO | NUMBER OF BITS <br> TO SHIFT <br> SFT4-SFTO |
| :---: | :---: |
| 10 | 11000 |

Assume D31-DO is hex $A B C D 0123$.
D31-D0
Input Data 10101011110011010000000100100011
Y31-Y0
Result
00100011101010111100110100000001
arithmetic shift right $(\mathrm{M} 1-\mathrm{MO}=\mathrm{HH})$

In the arithmetic shift right mode, SFT4-SFTO define the number of bit positions to be shifted. The following example shifts a 32 -bit word 8 positions to the right and fills the vacated bit positions with the sign bit (D31 from the input data).

CONTROL SIGNALS

| SHIFT | NUMBER OF BITS |
| :---: | :---: |
| INSTRUCTION | TO SHIFT |
| M2-MO | SFT4-SFTO |
| 11 | 11000 |

Assume D31-D0 is hex ABCD0123.
D31-D0
Input Data

$$
10101011110011010000000100100011
$$

Result

$$
11111111101010111100110100000001
$$

## absolute maximum ratings over operating temperature range (unless otherwise noted)

$$
\text { Supply voltage, VCC1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . } 7 \text { V }
$$

Supply voltage, VCC2 ..... 3 V
Input voltage ..... 7 V
Operating case temperature range: SN54AS8838 ..... $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$Operating free-air temperature range: SN74AS8838 . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$Storage temperature range$-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

## recommended operating conditions

| PARAMETER |  | SN54AS8838 |  |  | SN74AS8838 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC1 }}$ | I/O supply voltage | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\mathrm{CC} 2}$ | STL internal logic supply voltage | 1.9 | 2 | 2.1 | 1.9 | 2 | 2.1 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  |  | -1 |  |  | 2.6 | mA |
| ${ }^{\text {IOL }}$ | Low-level output current |  |  | 12 |  |  | 24 | mA |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature | -55 |  |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |
| ${ }^{T} \mathrm{C}$ | Operating case temperature |  |  | 125 |  |  |  | ${ }^{\circ} \mathrm{C}$ |

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

| PARAMETER | TEST CONDITIONS |  | SN54AS8838 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP ${ }^{\dagger}$ MAX |  |
| $V_{\text {IK }}$ | $\mathrm{V}_{\text {CC1 }}=4.5 \mathrm{~V}$, | $\boldsymbol{I}=-18 \mathrm{~mA}$ |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}$ to 5.5 V , | $\mathrm{I}^{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  | V |
|  | $\mathrm{V}_{\text {CC1 }}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OH}}=-1 \mathrm{~mA}$ | 2.4 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{\text {CC1 }}=4.5 \mathrm{~V}$, | $\mathrm{I}^{\mathrm{OL}}=12 \mathrm{~mA}$ |  | 0.4 | V |
|  | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}$, | $\mathrm{IOL}^{\text {O }}=24 \mathrm{~mA}$ |  |  |  |
| IOZH | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  | 20 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{O}} \mathrm{OL}$ | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  | -0.4 | mA |
| $1 /$ | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  | 0.1 | mA |
| 1 IH | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  | 20 | $\mu \mathrm{A}$ |
| IIL | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  | -0.4 | mA |
| $\mathrm{I}^{\ddagger}$ | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | $-30$ | -112 | mA |
| ${ }^{1} \mathrm{CC} 1$ | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$ |  |  | 150 | mA |
| ${ }^{\text {I CC2 }}$ | $\mathrm{V}_{\text {CC2 }}=2.1 \mathrm{~V}$ |  |  | 145 | mA |

switching characteristics over recommended operating temperature range (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $$ | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN TYP ${ }^{\dagger}$ MAX |  |
| ${ }^{\text {tpd }}$ | MUX1-MUX0 | Y31-Y0 | 22 | ns |
|  | SFT4-SFTO | Y31-Y0 | 22 |  |
|  | D31-D0 | Y31-Y0 | 22 |  |
| ${ }_{\text {ten }}$ | YOEL | Y15-Y0 | 12 | ns |
|  | YOEM | Y31-Y16 | 12 |  |
| ${ }^{\text {dis }}$ | YOEL | Y15-Y0 | 6 | ns |
|  | YOEM | Y31-Y16 | 6 |  |

${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}{ }^{\text {a }}=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 the true short-circuit current, los. NOTE 1: For load circuit and voltage waveforms, see pages 1-12 of The TTL Data Book, Volume 3, 1984.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER | TEST CONDITIONS |  | SN74AS8838 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX |  |
| $\mathrm{V}_{\mathrm{IK}}$ | $\mathrm{V}_{\mathrm{CC} 1}=4.5 \mathrm{~V}$, | $1=-18 \mathrm{~mA}$ |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\text {CC1 }}=4.5 \mathrm{~V}$ to 5.5 V , | $\mathrm{IOH}^{\text {a }}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  | V |
|  | $\mathrm{V}_{\text {CC1 }}=4.5 \mathrm{~V}$, | $1 \mathrm{OH}=-1 \mathrm{~mA}$ |  |  |  |
|  | $\mathrm{V}_{\text {CC1 }}=4.5 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OH}}=-2.6 \mathrm{~mA}$ | 2.4 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{\text {CC1 }}=4.5 \mathrm{~V}$, | $1 \mathrm{OL}=12 \mathrm{~mA}$ |  | 0.4 | V |
|  | $\mathrm{V}_{\text {CC1 }}=4.5 \mathrm{~V}$, | $\mathrm{l}^{\mathrm{OL}}=24 \mathrm{~mA}$ |  | 0.5 |  |
| IOZH | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.7 \mathrm{~V}$ |  | 20 | $\mu \mathrm{A}$ |
| IOZL | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  | -0.4 | mA |
| 1 | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=7 \mathrm{~V}$ |  | 0.1 | mA |
| 1 IH | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  | 20 | $\mu \mathrm{A}$ |
| IL | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  | -0.4 | mA |
| $10^{\ddagger}$ | $\mathrm{V}_{\mathrm{CC} 1}=5.5 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.25 \mathrm{~V}$ | -30 | -112 | mA |
| ICC1 | $\mathrm{V}_{\text {CC1 }}=5.5 \mathrm{~V}$ |  |  | 150 | mA |
| ICC2 | $\mathrm{V}_{\text {CC2 }}=2.1 \mathrm{~V}$ |  |  | 145 | mA |

${ }^{\ddagger}$ The output conditions have been chosen to produce a current that closely approximates one-half the true short-circuit current, Ios.
switching characteristics (see Note 1)

| PARAMETER | FROM (INPUT) | то (OUTPUT) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{R} 1=500 \Omega \\ & \mathrm{R} 2=500 \Omega, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |  |  | $$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SN74AS8838 |  |  |  |  |  |
|  |  |  | MIN | TYP | MAX | MIN | MAX |  |
| ${ }_{t}{ }_{\text {p }}$ | MUX1-MUX0 | Y31-Y0 |  | 22 | 26 |  | 29 | ns |
|  | SFT4-SFT0 | Y31-Y0 |  | 20 | 22 |  | 25 |  |
|  | D31-D0 | Y31-Y0 |  | 22 | 26 |  | 29 |  |
| ${ }^{\text {ten }}$ | YOEL | Y15-Y0 |  | 12 | 15 |  | 17 | ns |
|  | $\overline{\text { YOEM }}$ | Y31-Y16 |  | 12 | 15 |  | 17 |  |
| ${ }^{\text {d }}$ dis | YOEL | Y15-Y0 |  | 6 | 8 |  | 10 | ns |
|  | $\overline{\text { YOEM }}$ | Y31-Y16 |  | 6 | 8 |  | 10 |  |

NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

- High-Speed 8-Bit Parallel Output Register
- Serial Shadow Register with Right-Shift Only
- 'ALS29818 Performs Parallel-to-Serial and Serial-to-Parallel Conversion
- Designed Specifically for Use in Applications such as:

Write Control Store ('ALS29818)
Serial Shadow-Register Diagnostics

- 'ALS29819 Provides Even-Parity Output
- Low Power Dissipation . . . 215 mW Typical
- 'ALS29818 is Functionally Equivalent to AMD AM29818
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

The 'ALS29818 and 'ALS29819 are 8-bit output registers with on-chip shadow register for use in applications such as write control store and shadow register diagnostics.

The output registers of the 'ALS29818 and 'ALS29819 are loaded in parallel from either the I/O port (DQ0-DQ7) or the shadow register. The shadow register of the 'ALS29818 is loaded serially from either the I/O port (YO-Y7) or the output register. The 'ALS29819 shadow register is loaded serially from the I/O port (DQ0-DQ7). In addition, the 'ALS29819 provides a ParityEven (PE) output, which monitors parity of the output register. Operation of these devices is controlled by the Mode and SDI inputs as shown in the function table.

The SN54ALS29818 and SN54ALS29819 are characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74ALS29818 and SN74ALS29819 are characterized for operation from $0^{\circ} \mathrm{C}$, to $70^{\circ} \mathrm{C}$.


SN54ALS29818 . . . FK PACKAGE SN74ALS29818 . . . FN PACKAGE (TOP VIEW)


SN54ALS29819 . . . JT PACKAGE SN74ALS29819 . . . DW OR JT PACKAGE (TOP VIEW)

| PE 1 | $\mathrm{U}_{24} \square \mathrm{v}_{\mathrm{Cc}}$ |
| :---: | :---: |
| SRCLK ${ }^{2}$ | 23 MODE |
| DOo [3 | 22 Y |
| DO1 ${ }^{\text {a }}$ | $21 . \mathrm{Y} 1$ |
| DQ2 ${ }^{5}$ | 20 Y 2 |
| D03 $\square^{6}$ | 19.15 |
| DO4 ${ }^{7}$ | 18.154 |
| DO5 [ ${ }^{8}$ | 17.75 |
| DO6 $\square^{9}$ | 16 Y 9 |
| DQ7 10 | 15 Y7 |
| SDI 11 | 14 SDO |
| GND 12 | 13 OrClk |

SN54ALS29819 . . . FK PACKAGE SN74ALS29819 . . . FN PACKAGE (TOP VIEW)


NC - No internal connection
'ALS29818 FUNCTION TABLE

| INPUTS |  |  |  |  | OUTPUT AND I/O |  |  | OPERATION OR FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MODE | $\overline{\text { OEY }}$ | SDI | SRCLK | ORCLK | SDO | Y0-Y7 | DQ0-DQ7 |  |
| L | X | X | $\uparrow$ | X | SR7 | - | HI-Z | Serial input, shift right, disable DQ0-DQ7 |
| H | H | L | $\uparrow$ | X | SDI | INPUTT | HI-Z | Parallel load shadow register from YO-Y7, disable DOO-DO7 |
| H | L | L | $\uparrow$ | No † | SDI | OUTPUT | HI-Z | Parallel load shadow register from output register, disable DQ0-DQ7 |
| L | x | x | x | $\uparrow$ | SR7 | - | INPUT ${ }^{\dagger}$ | Load output register from DOO-DO7 |
| L | X | X | $\uparrow$ | $\uparrow$ | SR7 | - | INPUT ${ }^{\dagger}$ | Load output register from DOO-DO7 while shifting shadow register |
| H | X | x | No $\uparrow$ | $\uparrow$ | SDI | - | - | Load output register from shadow register |
| H | X | X | X | X | SDI | - | - | Serial data in to serial data out |
| H | L | L | $\uparrow$ | $\uparrow$ | SDI | OUTPUT | HI-Z | Exchange data between registers, DOO-DQ7 disabled |
| H | X | H | X | X | SDI | - | - | Hold shadow register, transitions on SRCLK do not effect shadow register |
| H | X | H | $\uparrow$ | X | SDI | - | OUTPUT | Enable DOO-DO7 for parallel shadow register output |

${ }^{\dagger}$ The DOO-DQ7 outputs must be disabled before applying data to DOO-DO7.
'ALS29819 FUNCTION TABLE

| INPUTS |  |  |  | OUTPUT AND I/O |  |  | OPERATION OR FUNCTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MODE | SDI | SRCLK | ORCLK | SDO | $\begin{gathered} \mathrm{YO}-\mathrm{Y} 7 \\ \mathrm{PE} \\ \hline \end{gathered}$ | DQ0-DQ7 |  |
| L | X | $\uparrow$ | X | SR7 | OUTPUT | $\mathrm{HI}-\mathrm{Z}$ | Serial input, shift right |
| H | L | $\uparrow$ | X | $\begin{aligned} & \hline \text { SDI } \\ & (\mathrm{L}) \end{aligned}$ | OUTPUT | INPUT | Parallel load shadow register from DQ0-DQ7 |
| H | L | $\uparrow$ | $\uparrow$ | $\begin{aligned} & \hline \text { SDI } \\ & \text { (L) } \\ & \hline \end{aligned}$ | OUTPUT | INPUT | Parallel load shadow register and output register from DQ0-DQ7 |
| $\begin{aligned} & \mathrm{L} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & \uparrow \\ & \uparrow \end{aligned}$ | SR7 | OUTPUT | INPUT | Load output register from DQ0-DQ7 |
| L | X | $\uparrow$ | $\uparrow$ | SR7 | OUTPUT | INPUT | Load output register from DQ0-DQ7 while shifting shadow register |
| H | H | No $\uparrow$ | $\uparrow$ | $\begin{aligned} & \text { SDI } \\ & (\mathrm{H}) \end{aligned}$ | OUTPUT | OUTPUT | Load output register from shadow register |
| H | X | X | X | SDI | OUTPUT | - | Serial data in to serial data out |
| H | H | X | X | $\begin{aligned} & \hline \text { SDI } \\ & (\mathrm{H}) \end{aligned}$ | OUTPUT | OUTPUT HOLD | Hold shadow register, enable DQ0-DQ7, transitions on SRCLK ignored |
| L X | X L | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & x \\ & x \end{aligned}$ | - | OUTPUT | $\mathrm{HI}-\mathrm{Z}$ | Disable DOO-DQ7 outputs |

## SN54ALS29818, SN54ALS29819 <br> SN74ALS29818, SN74ALS29819 8-BIT DIAGNOSTICS/PIPELINE REGISTERS

logic symbols ${ }^{\dagger}$
'ALS29818

'ALS29819

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

SN54ALS29818, SN54ALS29819
SN74ALS29818, SN74ALS29819
8-BIT DIAGNOSTICS/PIPELINE REGISTERS
logic diagrams (positive logic)
'ALS29818

'ALS29819

'ALS29818 gate-level logic diagram (positive logic)





Pin numbers shown are for DW, JT, and NT packages.

## 8-BIT DIAGNOSTICS/PIPELINE REGISTERS

## 'ALS29819 gate-level logic diagram (positive logic)



Pin numbers shown are for DW, JT, and NT packages.
'ALS29819 gate-level logic diagram (positive logic) (continued)


SN54ALS29818, SN54ALS29819
SN74ALS29818, SN74ALS29819
8-BIT DIAGNOSTICS/PIPELINE REGISTERS

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



## recommended operating conditions


${ }^{\dagger}$ This setup time ensures that the shadow register will see stable data from the output register.
$\ddagger$ This setup time ensures that the output register will see stable data from the shadow register.

## SN54ALS29818, SN54ALS29819 <br> SN74ALS29818, SN74ALS29819 8-BIT DIAGNOSTICS/PIPELINE REGISTERS

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

${ }^{\dagger}$ For conditions shown as MIN or MAX, use appropriate value specified under recommended operating conditions.
${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

I Not more than one output should be shorted at a time and duration of the short circuit should not exceed one second.
NOTE 1: ICC is measured with all three-state outputs in the high-impedance state.

SN54ALS29818
SN74ALS29818
8-BIT DIAGNOSTICS/PIPELINE REGISTERS
'ALS29818 switching characteristics (see Note 2)

| PARAMETER |  | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS See Figure 1 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \mathrm{ALS} 29818 \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\text { MIN TO MAX, } \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN TO MAX }{ }^{\dagger} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | SN54ALS29818 |  |  |  |  |  | SN74ALS29818 |  |  |
|  |  | MIN |  |  | TYP | MAX | MIN | MAX | MIN | MAX |  |
| $f$ max | SRCLK |  |  |  |  |  | 37 |  |  |  |  |  | MHz |
|  | ORCLK |  |  |  |  |  | 37 |  |  |  |  |  |  |
| tPLH |  | MODE | SDO | $\mathrm{R}_{\mathrm{L}}=2 \mathrm{k} \Omega$ |  | 8 |  |  |  |  |  | ns |  |
| tPHL |  |  |  |  |  | 8 |  |  |  |  |  |  |  |
| tPLH |  | SDI | SDO | $\mathrm{R}_{\mathrm{L}}=2 \mathrm{k} \Omega$ |  | 8 |  |  |  |  |  | ns |  |
| tPHL |  |  |  |  |  | 8 |  |  |  |  |  |  |  |
| tPLH |  | ORCLK | YO-Y7 | $\begin{aligned} & \mathrm{R} 1=1 \mathrm{k} \Omega \\ & \mathrm{R} 2=280 \Omega \end{aligned}$ |  | 9 |  |  |  |  |  | ns |  |
| tPHL |  |  |  |  |  | 9 |  |  |  |  |  |  |  |
| tPLH |  | SRCLK | SDO | $\mathrm{R}_{\mathrm{L}}=2 \mathrm{k} \Omega$ |  | 13 |  |  |  |  |  | ns |  |
| ${ }^{\text {t PHL }}$ |  |  |  |  |  | 13 |  |  |  |  |  |  |  |
| tPLH |  | SRCLK | D00-DQ7 | $\begin{aligned} & \mathrm{R} 1=5 \mathrm{k} \Omega \\ & \mathrm{R} 2=2 \mathrm{k} \Omega \end{aligned}$ |  |  |  |  |  |  |  | ns |  |
| tPHL |  |  |  |  |  |  |  |  |  |  |  |  |  |
| tPZH |  | SRCLK | D00-DQ7 | $\begin{aligned} & \mathrm{R} 1=5 \mathrm{k} \Omega \\ & \mathrm{R} 2=2 \mathrm{k} \Omega \end{aligned}$ |  | 16 |  |  |  |  |  | ns |  |
| tPZL |  |  |  |  |  | 19 |  |  |  |  |  |  |  |
| tPHZ |  | SRCLK | DQ0-DQ7 | $\begin{aligned} & \mathrm{R} 1=5 \mathrm{k} \Omega \\ & \mathrm{R} 2=2 \mathrm{k} \Omega \end{aligned}$ |  | 16 |  |  |  |  |  | ns |  |
| tplZ |  |  |  |  |  | 19 |  |  |  |  |  |  |  |
| tPHZ |  | $\overline{O E Y}$ | YO-Y7 | $\begin{aligned} & \mathrm{R} 1=1 \mathrm{k} \Omega \\ & \mathrm{R} 2=280 \Omega \end{aligned}$ |  | 7 |  |  |  |  |  | ns |  |
| tPLZ |  |  |  |  |  | 10 |  |  |  |  |  |  |  |
| tPZH |  | $\overline{O E Y}$ | YO-Y7 | $\begin{aligned} & \mathrm{R} 1=1 \mathrm{k} \Omega \\ & \mathrm{R} 2=280 \Omega \end{aligned}$ |  | 6 |  |  |  |  |  | ns |  |
| tPZL |  |  |  |  |  | 9 |  |  |  |  |  |  |  |

$\dagger$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.

## SN54ALS29819 <br> SN74ALS29819 8-BIT DIAGNOSTICS/PIPELINE REGISTERS

'ALS29819 switching characteristics (see Note 2)

| PARAMETER |  | FROM (INPUT) | то (OUTPUT) | TEST CONDITIONS See Figure 1 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline{ }^{\prime} \mathrm{ALS29819} \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\text { MIN TO MAX }{ }^{\dagger} \\ & \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \\ & \mathrm{~T}_{\mathrm{A}}=\text { MIN TO MAX }{ }^{\dagger} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | SN |  |  |  |  |  | 819 | SN | 819 |  |
|  |  | MIN |  |  | TYP | MAX | MIN | MAX | MIN | MAX |  |
| ${ }^{\dagger}$ max | SRCLK |  |  |  |  |  | 37 |  |  |  |  |  | MHz |
|  | ORCLK |  |  |  |  |  | 37 |  |  |  |  |  |  |
| tPLH |  | MODE | SDO | $R_{L}=2 \mathrm{k} \Omega$ |  | 8 |  |  |  |  |  | ns |  |
| tPHL |  |  |  |  |  | 8 |  |  |  |  |  |  |  |
| tplH |  | SDI | SDO | $\mathrm{R}_{\mathrm{L}}=2 \mathrm{k} \Omega$ |  | 8 |  |  |  |  |  | ns |  |
| tPHL |  |  |  |  |  | 8 |  |  |  |  |  |  |  |
| tPLH |  | ORCLK | YO-Y7 | $R_{L}=2 \mathrm{k} \Omega$ |  | 9 |  |  |  |  |  | ns |  |
| tPHL |  |  |  |  |  | 9 |  |  |  |  |  |  |  |
| tPLH |  | ORCLK | PE | $\mathrm{R}_{\mathrm{L}}=2 \mathrm{k} \Omega$ |  | 9 |  |  |  |  |  | ns |  |
| tPHL |  |  |  |  |  | 5 |  |  |  |  |  |  |  |
| tplH |  | SRCLK | SDO | $\mathrm{R}_{\mathrm{L}}=2 \mathrm{k} \Omega$ |  | 13 |  |  |  |  |  | ns |  |
| ${ }^{\text {tPHL }}$ |  |  |  |  |  | 13 |  |  |  |  |  |  |  |
| tplH |  | SRCLK | D00-DQ7 | $\begin{aligned} & \mathrm{R} 1=5 \mathrm{k} \Omega, \\ & \mathrm{R} 2=2 \mathrm{k} \Omega \end{aligned}$ |  | 12 |  |  |  |  |  | ns |  |
| tPHL |  |  |  |  |  | 12 |  |  |  |  |  |  |  |
| tPZH |  | MODE <br> or SDI | DQ0-D07 | $\begin{aligned} & R 1=5 \mathrm{k} \Omega, \\ & \mathrm{R} 2=2 \mathrm{k} \Omega \end{aligned}$ |  | 7 |  |  |  |  |  | ns |  |
| tPZL |  |  |  |  |  | 9 |  |  |  |  |  |  |  |
| tPHZ |  | MODE or SD1 | D00-D07 | $\begin{aligned} & \mathrm{R} 1=5 \mathrm{k} \Omega \\ & \mathrm{R} 2=2 \mathrm{k} \Omega \end{aligned}$ |  | 7 |  |  |  |  |  | ns |  |
| tplZ |  |  |  |  |  | 9 |  |  |  |  |  |  |  |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.

## PARAMETER MEASUREMENT INFORMATION



LOAD CIRCUIT FOR BI-STATE TOTEM-POLE OUTPUTS


LOAD CIRCUIT FOR THREE-STATE OUTPUTS

SWITCH POSITION TABLE

| TEST | S1 | S2 |
| :---: | :---: | :---: |
| tPLH | Closed | Closed |
| tPHL | Closed | Closed |
| ${ }^{\text {tPZH }}$ | Open | Closed |
| tPZL | Closed | Open |
| tPHZ | Closed | Closed |
| tPLZ | Closed | Closed |



VOLTAGE WAVEFORMS
ENABLE AND DISABLE TIMES, THREE-STATE OUTPUTS

NOTES: A. $C_{L}$ includes probe and jig capacitance.
B. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
$C$. All input pulses are supplied by generators having the following characteristics: PRR $\leq 10 \mathrm{MHz}, \mathrm{Z}_{\mathrm{O}}=50 \Omega, \mathrm{t}_{\mathrm{r}} \leq 2.5 \mathrm{~ns}$, $\mathrm{t}_{\mathrm{f}} \leq 2.5 \mathrm{~ns}$.

FIGURE 1

- Functionally Equivalent to AMD's AM29821 and AM29822
- Provides Extra Data Width Necessary for Wider Address/Data Paths or Buses with Parity
- Outputs Have Undershoot Protection Circuitry
- Power-Up High-Impedance State
- Package Options Include Both Plastic and Ceramic Carriers in Addition to Plastic and Ceramic DIPs
- Buffered Control Inputs to Reduce DC Loading Effects
- Dependable Texas Instruments Quality and Reliability


## description

These 10-bit flip-flops feature three-state outputs designed specifically for driving highlycapacitive or relatively low-impedance loads. They are particularly suitable for implementing wider buffer registers, I/O ports, bidirectional bus drivers with parity, and working registers.

The ten flip-flops are edge-triggered D-type flipflops. On the positive transition of the clock the Q outputs on the 'ALS29821 will be true, and on the 'ALS29822 will be complementary to the data input.

A buffered output-control ( $\overline{\mathrm{OC}})$ input can be used to place the ten outputs in either a normal logic state (high or low levels) or a high-impedance state. In the high-impedance state the outputs neither load nor drive the bus lines significantly. The high-impedance state and increased drive provide the capability to drive the bus lines in a bus-organized system without need for interface or pull-up components. The output control does not affect the internal operation of the flip-flops. Old data can be retained or new data can be entered while the outputs are in the highimpedance state.
The SN54'family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.


SN54ALS29821 . . . FK PACKAGE SN74ALS29821 . . . FN PACKAGE (TOP VIEW)


SN54ALS29822 . . . FK PACKAGE SN74ALS29822 . . . FN PACKAGE
(TOP VIEW)



NC - No internal connection

## SN54ALS29821, SN74ALS29821 <br> 10-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

'ALS29821 FUNCTION TABLE (EACH FLIP-FLOP)

| INPUTS |  |  | OUTPUT |
| :---: | :---: | :---: | :---: |
| $\mathbf{O C}$ | CLK | $\mathbf{D}$ | $\mathbf{Q}$ |
| L | $\uparrow$ | $H$ | $H$ |
| L | $\uparrow$ | L | L |
| L | L | $X$ | $Q_{O}$ |
| $H$ | $X$ | $X$ | $Z$ |

'ALS29821 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 DW, JT, and NT packages.
'ALS29821 logic diagram (positive logic)


Pin numbers shown are for DW, JT, and NT packages.

ALS29822 FUNCTION TABLE (EACH FLIP-FLOP)

| INPUTS |  |  | OUTPUT |
| :---: | :---: | :---: | :---: |
| $\mathbf{O C}$ | CLK | $\overline{\mathbf{D}}$ | $\mathbf{Q}$ |
| $L$ | $\uparrow$ | $H$ | $L$ |
| $L$ | $\uparrow$ | $L$ | $H$ |
| $L$ | $L$ | $X$ | $Q_{O}$ |
| $H$ | $X$ | $X$ | $Z$ |

'ALS29822 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 DW, JT, and NT packages.
'ALS29822 logic diagram (positive logic)


Pin numbers shown are for DW, JT, and NT packages.

## SN54AS29821, SN54AS29822, SN74AS29821, SN74AS29822

 10-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTSabsolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| Supply voltage, VCC Input voltage |  | V |
| :---: | :---: | :---: |
| Voltage applied to a disabled 3-state | output | 5.5 V |
| Input current |  | 100 mA |
| Output current |  | -30 mA to 5 mA |
| Operating free-air temperature range: | SN54ALS29821, SN54ALS29822 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
|  | SN74ALS29821, SN74ALS29822 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range |  | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

## recommended operating conditions

|  |  | SN54ALS29821 SN54ALS29822 |  |  | SN74ALS29821 SN74ALS29822 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{\text {I OH }}$ | High-level output current |  |  | -15 |  |  | -24 | mA |
| 1 OL | Low-level output currrent |  |  | 32 |  |  | 48 | mA |
| $\mathrm{t}_{\mathrm{w}}$ | Pulse duration, CLK high or low |  |  |  |  |  |  | ns |
| $\mathrm{t}_{\text {su }}$ | Setup time, data before CLK $\uparrow$ |  |  |  |  |  |  | ns |
| $t_{\text {h }}$ | Hold time, data after CLK $\uparrow$ |  |  |  |  |  |  | ns |
| TA | Operating free-air temperature | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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


[^73]SN54ALS29821, SN54ALS29822, SN74ALS29821, SN74ALS29822 10-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS
switching characteristics

| PARAMETER | FROM (INPUT) | то (OUTPUT) | TEST CONDITIONS See Figure 1 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline{ }^{\prime} \text { ALS29821 } \\ & \text { 'ALS29822 } \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\text { MIN TO MAX, }{ }^{\dagger} \\ & \mathrm{T}_{\mathbf{A}}=\text { MIN TO MAX }{ }^{\dagger} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | SN54ALS29821 <br> SN54ALS29822 |  | SN74ALS29821 <br> SN74ALS29822 |  |  |
|  |  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tPLH | CLK | Any 0 | $C_{L}=300 \mathrm{pF}$ |  |  |  |  |  |  |  | ns |
| tPHL |  |  |  |  |  |  |  |  |  |  |  |
| tPLH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 6 |  |  |  |  |  |  |
| ${ }^{\text {tPHL }}$ |  |  |  |  | 7 |  |  |  |  |  |  |
| tPZH | $\overline{O C}$ | Any 0 | $C_{L}=300 \mathrm{pF}$ |  |  |  |  |  |  |  | ns |
| tPZL |  |  |  |  |  |  |  |  |  |  |  |
| tPZH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 12 |  |  |  |  |  |  |
| tPZL |  |  |  |  | 11 |  |  |  |  |  |  |
| tPHZ | $\overline{O C}$ | Any 0 | $C_{L}=50 \mathrm{pF}$ |  |  |  |  |  |  |  | ns |
| tPLZ |  |  |  |  |  |  |  |  |  |  |  |
| tPHZ |  |  | $C_{L}=5 \mathrm{pF}$ |  | 5 |  |  |  |  |  |  |
| tPLZ |  |  |  |  | 6 |  |  |  |  |  |  |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.

Additional information on these products can be obtained from the factory as it becomes available.

SN54AS29821, SN54AS29822, SN74AS29821, SN74AS29822 10-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

PARAMETER MEASUREMENT INFORMATION


SWITCH POSITION TABLE

| TEST | S1 | S2 |
| :---: | :---: | :---: |
| tPLH | Closed | Closed |
| tPHL | Closed | Closed |
| tPZH | Open | Closed |
| tPZL | Closed | Open |
| tpHZ | Closed | Closed |
| tpLZ | Closed | Closed |



VOLTAGE WAVEFORMS PROPAGATION DELAY TIMES

HIGH-LEVEL
PULSE

LOW-LEVEL PULSE


VOLTAGE WAVEFORMS PULSE DURATIONS


NOTES: A. $C_{L}$ includes probe and jig capacitance.
B. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
C. All input pulses are supplied by generators having the following characteristics: PRR $\leq 10 \mathrm{MHz}, Z_{o}=50 \Omega, t_{r} \leq 2.5 \mathrm{~ns}$, $\mathrm{t}_{\mathrm{f}} \leq 2.5 \mathrm{~ns}$.

FIGURE 1

- Functionally Equivalent to AMD's AM29823 and AM29824
- Provides Extra Data Width Necessary for Wider Address/Data Paths or Buses with Parity
- Outputs Have Undershoot Protection Circuitry
- Power-Up High-Impedance State
- Buffered Control Inputs to Reduce DC Loading Effects
- Package Options Include both Plastic and Ceramic Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 9-bit flip-flops feature three-state outputs designed specifically for driving highly capacitive or relatively low-impedance loads. They are particularly suitable for implementing wider buffer registers, I/O ports, bidirectional bus drivers, parity bus interfacing and working registers.
With the clock enable ( $\overline{\mathrm{CLKEN}}$ ) low, the nine D type edge-triggered flip-flops enter data on the low-to-high transitions of the clock. Taking CLKEN high will disable the clock buffer, thus latching the outputs. The 'ALS29823 has noninverting $D$ inputs and the 'ALS29824 has inverting $D$ inputs. Taking the $\overline{C L R}$ input low causes the nine $Q$ outputs to go low independently of the clock.
A buffered output-control input ( $\overline{\mathrm{OC}}$ ) can be used to place the nine outputs in either normal logic state (high or low level) or a high-impedance state. In the high-impedance state the outputs neither load nor drive the bus lines significantly. The high-impedance state and increased drive provide the capability to drive the bus lines in a bus-organized system without need for interface or pull-up components. The output control does not affect the internal operation of the flip-flops. Old data can be retained or new data can be entered while the outputs are in the highimpedance state.


SN54ALS29824 . . . FK PACKAGE SN74ALS29824 . . . FN PACKAGE (TOP VIEW)


## SN54ALS29823, SN54ALS29824, SN74ALS29823, SN74ALS29824 9-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

The SN54AS' family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74AS' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.
'ALS29823 FUNCTION TABLE

| INPUTS |  |  |  |  | OUTPUT <br> 0 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{OC}}$ | $\overline{\text { CLR }}$ | CLKEN | CLK | D |  |
| L | L | X | X | $\times$ | L |
| L | H | L | $\uparrow$ | H | H |
| L | H | L | $\uparrow$ | L | L. |
| L | H | H | X | X | $0_{0}$ |
| H | X | X | X | X | z |

'ALS29823 logic symbol ${ }^{\dagger}$
$\dagger$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12
'ALS29823 logic diagram (positive logic)


Pin numbers shown are for DW, JT, and NT packages.
'ALS29824 FUNCTION TABLE

| INPUTS |  |  |  |  | OUTPUT 0 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\mathbf{O C}}$ | $\overline{\text { CLR }}$ | CLKEN | CLK | $\bar{D}$ |  |
| L | L | X | X | X | L |
| L | H | L | $\uparrow$ | H | L |
| L | H | L | $\uparrow$ | L | H |
| L | H | H | $x$ | x | $\mathrm{o}_{0}$ |
| H | X | X | X | X | Z |

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


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

## SN54ALS29823, SN54ALS29824, SN74ALS29823, SN74ALS29824 9-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, VCC ..... 7 V
Input voltage ..... 5.5 V
Voltage applied to a disabled 3 -state output ..... 5.5 V
Input current ..... 100 mA
Output current -30 mA to 5 mA
Operating free-air temperature range: SN54ALS29823, SN54ALS29824 ..... $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
SN74ALS29823, SN74ALS29824 $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range ..... $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

## recommended operating conditions

|  |  |  | SN54ALS29823 <br> SN54ALS29824 |  |  | SN74ALS29823 <br> SN74ALS29824 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | High-level output current |  |  |  | -15 |  |  | -24 | mA |
| ${ }^{\mathrm{O}} \mathrm{OL}$ | Low-level output current |  |  |  | 32 |  |  | 48 | mA |
| ${ }^{\text {w }}$ w | Pulse duration | $\overline{\text { CLR }}$ low |  |  |  |  |  |  | ns |
|  |  | CLK high or low |  |  |  |  |  |  |  |
| ${ }^{\text {t }}$ su | Setup time before CLK $\uparrow$ | $\overline{\text { CLR }}$ inactive |  |  |  |  |  |  | ns |
|  |  | Data |  |  |  |  |  |  |  |
|  |  | $\overline{\text { CLKEN }}$ high or low |  |  |  |  |  |  |  |
| $t_{h}$ | Hold time, $\overline{\text { CLKEN }}$ or data after CLK $\uparrow$ |  |  |  |  |  |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

## SN54ALS29823, SN54ALS29824, SN74ALS29823, SN74ALS29824 9-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

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


[^74]Additional Information on these products can be obtained from the factory as it becomes available.

## SN54ALS29823, SN54ALS29824, SN74ALS29823, SN74ALS29824 9-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

## switching characteristics

| PARAMETER | FROM(INPUT) | то (OUTPUT) | TEST CONDITIONS <br> See Figure 1 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \text { 'ALS29823 } \\ & \text { 'ALS29824 } \end{aligned}$ |  |  | $\begin{aligned} \mathbf{V}_{\mathbf{C C}} & =\text { MIN TO MAX, }{ }^{\dagger} \\ \mathbf{T}_{\mathbf{A}} & =\text { MIN TO MAX } \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | SN54ALS29823 SN54ALS29824 |  | SN74ALS29823 <br> SN74ALS29824 |  |  |
|  |  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tPLH | CLK | Any 0 | $C_{L}=300 \mathrm{pF}$ |  |  |  |  |  |  |  | ns |
| tPHL |  |  |  |  |  |  |  |  |  |  |  |
| tpLiH |  |  | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 5.5 |  |  |  |  |  |  |
| tPHL |  |  |  |  | 6.5 |  |  |  |  |  |  |
| ${ }_{\text {tPHL }}$ | $\overline{C L R}$ | Any 0 | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 13 |  |  |  |  |  | ns |
| ${ }_{\text {tPZH }}$ | $\overline{\mathrm{OC}}$ | Any 0 | $\mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$ |  |  |  |  |  |  |  | ns |
| tPZL |  |  |  |  |  |  |  |  |  |  |  |
| tPZH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 12 |  |  |  |  |  |  |
| tPZL |  |  |  |  | 11 |  |  |  |  |  |  |
| ${ }^{\text {t PHZ }}$ | $\overline{O C}$ | Any 0 | $C_{L}=50 \mathrm{pF}$ |  |  |  |  |  |  |  | ns |
| tPLZ |  |  |  |  |  |  |  |  |  |  |  |
| tPHZ |  |  | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}$ |  | 5 |  |  |  |  |  |  |
| tPLZ |  |  |  |  | 5.5 |  |  |  |  |  |  |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.

Additional information on these products can be obtained from the factory as it becomes available.

## D flip-flop signal conventions

It is normal TI practice to name the outputs and other inputs of a D-type flip-flop and to draw its logic symbol based on the assumption of true data (D) inputs. Then outputs that produce data in phase with the data inputs are called Q and those producing complementary data are called Q . An input that causes a Q output to go high or a Q output to go low is called Preset; an input that causes a Q output to go high or a Q output to go low is called Clear. Bars are used over these pin names (PRE and CLR) if they are active-low.

The devices on this data sheet are second-source designs and the pin-name convention used by the original manufacturer has been retained. That makes it necessary to designate the inputs and outputs of the inverting circuit $D$ and $Q$. In some applications it may be advantageous to redesignate the inputs and outputs as $D$ and $Q$. In that case, outputs should be renamed as shown below. Also shown are corresponding changes in the graphical symbol. Arbitrary pin numbers are shown in parentheses.

Notice that Q and Q exchange names, which causes Preset and Clear to do likewise. Also notice that the polarity indicators ( $\triangle$ ) on PRE and CLR remain since these inputs are still active-low, but that the presence or absence of the polarity changes at $D, Q$, and $Q$. Of course pin $5(Q)$ is still in phase with the data input $D$, but now both are considered active high.


## SN54ALS29823, SN54ALS29824, SN74ALS29823, SN74ALS29824 9-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

PARAMETER MEASUREMENT INFORMATION



VOLTAGE WAVEFORMS SETUP AND HOLD TIMES


VOLTAGE WAVEFORMS PROPAGATION DELAY TIMES


VOLTAGE WAVEFORMS PULSE DURATIONS


VOLTAGE WAVEFORMS
ENABLE AND DISABLE TIMES, THREE-STATE OUTPUTS
B. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
C. All input pulses are supplied by generators having the following characteristics: PRR $\leq 10 \mathrm{MHz}, \mathrm{Z}_{\mathrm{O}}=50 \Omega, \mathrm{t}_{\mathrm{r}} \leq 2.5 \mathrm{~ns}$, $\mathrm{t}_{\mathrm{f}} \leq 2.5 \mathrm{~ns}$.

FIGURE 1

- Functionally Equivalent to AMD's AM29825 and AM29826
- Improved IOH Specifications
- Multiple Output Enables Allow Multiuser Control of the Interface
- Outputs Have Undershoot Protection Circuitry
- Power-Up High-Impedance State
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Buffered Control Inputs to Reduce DC Loading Effect
- Dependable Texas Instruments Quality and Reliability


## description

These 8-bit flip-flops feature three-state outputs designed specifically for driving highly capacitive or relatively low-impedance loads. They are particularly suitable for implementing multiuser registers, I/O ports, bidirectional bus drivers, and working registers.
With the clock enable ( $\overline{\mathrm{CLKEN}}$ ) low, the eight D type edge-triggered flip-flops enter data on the low-to-high transitions of the clock. Taking CLKEN high will disable the clock buffer, thus latching the outputs. The 'ALS29825 has noninverting $D$ inputs and the 'ALS29826 has inverting $\bar{D}$ inputs. Taking the $\overline{C L R}$ input low causes the eight $Q$ outputs to go low independently of the clock.
Multiuser buffered output-control inputs $\overline{\mathrm{OC}} 1$, $\overline{\mathrm{OC}} 2$, and $\overline{\mathrm{OC}} 3$ ) can be used to place the eight outputs in either a normal logic state (high or low level) or a high-impedance state. In the highimpedance state the outputs neither load nor drive the bus lines significantly. The highimpedance state and increased drive provide the capability to drive the bus lines in a busorganized system without need for interface or pull-up components. The output controls do not affect the internal operation of the flip-flops. Old data can be retained or new data can be entered while the outputs are in the high-impedance state.


SN54ALS29825 . . . FK PACKAGE SN74ALS29825 . . . FN PACKAGE (TOP VIEW)



SN54ALS29826 . . . FK PACKAGE SN74ALS29826 . . . FN PACKAGE
(TOP VIEW)


NC-No internal connection

## SN54ALS29825, SN54ALS29826 <br> SN74ALS29825, SN74ALS29826 <br> 8-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

The SN54'family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$.
The SN74' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.
'ALS29825 FUNCTION TABLE

| INPUTS |  |  |  |  | OUTPUT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { OC* }}$ | $\overline{\text { CLR }}$ | $\overline{\text { CLKEN }}$ | CLK | D | $\mathbf{Q}$ |
| $L$ | $L$ | $X$ | $X$ | $X$ | $L$ |
| $L$ | $H$ | $L$ | $\uparrow$ | $H$ | $H$ |
| $L$ | $H$ | $L$ | $\uparrow$ | $L$ | $L$ |
| $L$ | $H$ | $H$ | $X$ | $X$ | $Q_{O}$ |
| $H$ | $X$ | $X$ | $X$ | $X$ | $Z$ |

$\overline{O C}^{*}=\mathrm{H}$ if any of $\overline{\mathrm{OC}} 1, \overline{\mathrm{OC}} 2$, or $\overline{\mathrm{OC}} 3$ is high.
$\overline{\mathrm{OC}}^{*}=\mathrm{L}$ if all of $\overline{\mathrm{OC}} 1, \overline{\mathrm{OC}} 2$, and $\overline{\mathrm{OC}} 3$ are low.

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

[^75]'ALS29825 logic diagram (positive logic)


Pin numbers are for DW, JT, and NT packages.

## SN54ALS29825, SN54ALS29826 <br> SN74ALS29825, SN74ALS29826 8-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

'ALS29826 FUNCTION TABLE

| INPUTS |  |  |  |  | $\begin{gathered} \text { OUTPUT } \\ 0 \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| OC* | CLR | CLKEN | CLK | D |  |
| L | L | X | X | X | L |
| L | H | L | $\uparrow$ | H | L |
| L | H | L | $\uparrow$ | L | H |
| L | H | H | $x$ | $x$ | $\mathrm{O}_{0}$ |
| H | X | X | X | X | Z |

$\overline{O C}^{*}=\mathrm{H}$ if any of $\overline{\mathrm{OC}} 1, \overline{\mathrm{OC}} 2$, or $\overline{\mathrm{OC}} 3$ is high.
$\overline{\mathrm{OC}}^{*}=\mathrm{L}$ if all of $\overline{\mathrm{OC}} 1, \overline{\mathrm{OC}} 2$, and $\overline{\mathrm{OC}} 3$ are tow.

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


$\dagger$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers are for DW, JT, and NT packages.
'ALS29826 logic diagram (positive logic)


Pin numbers shown are for DW, JT, and NT packages.
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| Supply voltage, VCC | 7 V |
| :---: | :---: |
| Input voltage | 7 V |
| Voltage applied to a disabled 3-state output | 5.5 V |
| Input current | 100 mA |
| Output current | -30 mA to 5 mA |
| Operating free-air temperature range: |  |
| SN54ALS29825, SN54ALS29826 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
| SN74ALS29825, SN74ALS29826 | . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range | -65 to $150^{\circ} \mathrm{C}$ |

SN54ALS29825, SN54ALS29826
SN74ALS29825, SN74ALS29826
8-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS
recommended operating conditions

|  |  |  |  | $\begin{aligned} & \text { 4ALS2S } \\ & \text { 4ALS2S } \end{aligned}$ |  |  | $\begin{aligned} & \text { 4ALS2 } \\ & \text { 4ALS2 } \\ & \hline \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  |  |  | -15 |  |  | -24 | mA |
| lOL | Low-level output current |  |  |  | 32 |  |  | 48 | mA |
|  |  | CLR low |  |  |  |  |  |  |  |
| ${ }^{\text {t }}$ w | Pulse duration | CLK high |  |  |  |  |  |  | ns |
|  |  | CLK low |  |  |  |  |  |  |  |
|  |  | $\overline{\mathrm{CLR}}$ inactive |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {su }}$ | Setup time before CLK $\uparrow$ | Data |  |  |  |  |  |  | ns |
|  |  | CLKEN high or low |  |  |  |  |  |  |  |
|  |  | Data |  |  |  |  |  |  |  |
| th | Hold time, data after CLK $\uparrow$ | CLKEN |  |  |  |  |  |  | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperatu |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
${ }^{\S}$ Not more than one output should be shorted at a time and duration of the short circuit should not exceed one second.

Additional information on these products can be obtained from the factory as it becomes available.

## SN54ALS29825, SN54ALS29826 SN74ALS29825, SN74ALS29826 8-BIT BUS INTERFACE FLIP-FLOPS WITH 3-STATE OUTPUTS

switching characteristics

| PARAMETER | FROM(INPUT) | то (OUTPUT) | TEST CONDITIONS See Figure 1 | $\begin{aligned} & \mathrm{V}_{C C}=5 \mathrm{~V}, \\ & \mathrm{~T}_{A}=25^{\circ} \mathrm{C} \\ & \hline \text { 'ALS29825 } \\ & \text { 'ALS29826 } \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \mathbf{V}_{\mathbf{C C}}=\operatorname{MIN} \text { TO MAX, }{ }^{\dagger} \\ & \mathrm{T}_{\mathbf{A}}=\text { MIN TO MAX }{ }^{\dagger} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | SN54ALS29825 <br> SN54ALS29826 |  | SN74ALS29825 <br> SN74ALS29826 |  |  |
|  |  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tPLH | CLK | Any 0 | $C_{L}=300 \mathrm{pF}$ |  |  |  |  |  |  |  | ns |
| tPHL |  |  |  |  |  |  |  |  |  |  |  |
| tPLH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 6 |  |  |  |  |  |  |
| tPHL |  |  |  |  | 7 |  |  |  |  |  |  |
| tpHL | $\overline{\text { CLR }}$ | Any Q | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 13 |  |  |  |  |  | ns |
| tPZH | $\overline{\mathrm{OC}}$ | Any 0 | $C_{L}=300 \mathrm{pF}$ |  |  |  |  |  |  |  | ns |
| tPZL |  |  |  |  |  |  |  |  |  |  |  |
| tPZH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 12 |  |  |  |  |  |  |
| tPZL |  |  |  |  | 11 |  |  |  |  |  |  |
| tPHZ | $\overline{O C}$ | Any 0 | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  |  |  |  |  |  |  | ns |
| tPLZ |  |  |  |  |  |  |  |  |  |  |  |
| tPHZ |  |  | $C_{L}=5 \mathrm{pF}$ |  | 5 |  |  |  |  |  |  |
| tPLZ |  |  |  |  | 6 |  |  |  |  |  |  |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.

Additional information on these products can be obtained from the factory as it becomes available.

## D flip-flop signal conventions

It is normal TI practice to name the outputs and other inputs of a D-type flip-flop and to draw its logic symbol based on the assumption of true data ( $D$ ) inputs. Then outputs that produce data in phase with the data inputs are called Q and those producing complementary data are called $\overline{\mathrm{Q}}$. An input that causes a Q output to go high or a $\overline{\mathrm{Q}}$ output to go low is called Preset; an input that causes a $\overline{\mathrm{Q}}$ output to go high or a $\mathbf{Q}$ output to go low is called Clear. Bars are used over these pin names ( $\overline{\mathrm{PRE}}$ and $\overline{\mathrm{CLR}}$ ) if they are active-low.

The devices on this data sheet are second-source designs and the pin-name convention used by the original manufacturer has been retained. That makes it necessary to designate the inputs and outputs of the inverting circuit $\overline{\mathrm{D}}$ and Q . In some applications it may be advantageous to redesignate the inputs and outputs as D and $\overline{\mathrm{Q}}$. In that case, outputs should be renamed as shown below. Also shown are corresponding changes in the graphical symbol. Arbitrary pin numbers are shown in parentheses.

Notice that Q and $\overline{\mathrm{Q}}$ exchange names, which causes Preset and Clear to do likewise. Also notice that the polarity indicators ( $\mathbb{D}$ ) on $\overline{\operatorname{PRE}}$ and $\overline{\mathrm{CLR}}$ remain since these inputs are still active-low, but that the presence or absence of the polarity changes at $\bar{D}, Q$, and $\bar{Q}$. Of course pins $5(Q)$ is still in phase with the data input $D$, but now both are considered active high.





VOLTAGE WAVEFORMS PULSE DURATIONS


VOLTAGE WAVEFORMS
ENABLE AND DISABLE TIMES, THREE-STATE OUTPUTS

NOTES: A. $C_{L}$ includes probe and jig capacitance.
B. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
$C$. All input pulses are supplied by generators having the following characteristics: $P R R \leq 10 \mathrm{MHz}, \mathrm{Z}_{\mathrm{O}}=50 \Omega, \mathrm{t}_{\mathrm{r}} \leq 2.5 \mathrm{~ns}$, $\mathrm{t}_{\mathrm{f}} \leq 2.5 \mathrm{~ns}$.

FIGURE 1

- Functionally Equivalent to AM29827 and AM29828
- 3-State Outputs Drive Bus Lines or Buffer Memory Address Registers
- P-N-P Inputs Reduce D-C Loading
- Data Flow-Thru Pinout (All Inputs on Opposite Side from Outputs)
- Power-Up High-Impedance State
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 10-bit buffers and bus drivers provide high-performance bus interface for wide data paths or busses carrying parity.
The three-state control gate is a 2 -input NOR such that if either $\overline{\mathrm{G} 1}$ or $\overline{\mathrm{G} 2}$ is high, all ten outputs are in the high-impedance state.

The 'ALS29827 provides true data and the 'ALS29828 provides inverted data at the outputs.
The SN54' family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

SN54ALS' . . . JT PACKAGE
SN74ALS' . . DW OR NT PACKAGE (TOP VIEW)


SN54ALS' . . FK PACKAGE SN74ALS' . . . FN PACKAGE (TOP VIEW)


## SN54ALS29827, SN54ALS29828 <br> SN74ALS29827, SN74ALS29828 <br> 10-BIT BUFFERS AND BUS DRIVERS WITH 3-STATE OUTPUTS

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

'ALS29827

'ALS29828

${ }^{\dagger}$ These symbols are in accordance with ANSI/IEEE Std 91-1984. and IEC Publication 617-12.
logic diagrams (positive logic)


Pin numbers shown are DW, JT, and NT packages.

## SN54ALS29827, SN54ALS29828 <br> SN74ALS29827, SN74ALS29828 10-BIT BUFFERS AND BUS DRIVERS WITH 3-STATE OUTPUTS

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

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

## recommended operating conditions

|  |  | SN54ALS29827 <br> SN54ALS29828 |  |  | SN74ALS29827 <br> SN74ALS29828 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\mathrm{CC}}$ | Supply voltage | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  |  | -15 |  |  | -24 | mA |
| ${ }^{\text {I OL }}$ | Low-level output current |  |  | 32 |  |  | 48 | mA |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature | $-55$ |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$ |  | SN54ALS29827 <br> SN54ALS29828 |  |  | SN74ALS29827 <br> SN74ALS29828 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $\mathrm{V}_{\text {IK }}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $1=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=$ MIN to MAX, | $\mathrm{IOH}^{\prime}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-$ |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{IOH}=-15 \mathrm{~mA}$ | 2 |  |  |  |  |  | v |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $1 \mathrm{OH}=-24 \mathrm{~mA}$ |  |  |  | 2 |  |  |  |
| Vol |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $1 \mathrm{OL}=32 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{I}_{\mathrm{OL}}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| ${ }^{1} \mathrm{OZH}$ |  | $V_{C C}=M A X$, | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IozL |  | $V_{C C}=$ MAX, | $\mathrm{V}_{\mathrm{O}}=0.4 \mathrm{~V}$ |  |  | -20 |  |  | -20 | $\mu \mathrm{A}$ |
| I |  | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 0.1 |  |  | 0.1 | mA |
| ${ }^{\text {IIH }}$ |  | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IIL |  | $V_{C C}=M A X$, | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  | -0.1 |  |  | -0.1 | mA |
| $\mathrm{los}^{\text {§ }}$ |  | $V_{C C}=M A X$, | $\mathrm{V}_{\mathrm{O}}=0$ | -75 |  | -250 | -75 |  | -250 | mA |
| ICC | 'ALS29827 | $V_{C C}=$ MAX | Outputs high | 16 |  |  | 16 |  |  | mA |
|  |  |  | Outputs low | 20 |  |  | 20 |  |  |  |
|  |  |  | Outputs disabled | 19 |  |  | 19 |  |  |  |
|  | 'ALS29828 | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ | Outputs high | 12 |  |  | 12 |  |  | mA |
|  |  |  | Outputs low | 16 |  |  | 16 |  |  |  |
|  |  |  | Outputs disabled | 14 |  |  | 14 |  |  |  |

[^76]SN54ALS29827, SN54ALS29828
SN74ALS29827, SN74ALS29828
10-BIT BUFFERS AND BUS DRIVERS WITH 3-STATE OUTPUTS

## switching characteristics

| PARAMETER | $\begin{gathered} \text { FROM } \\ \text { (INPUT) } \end{gathered}$ | то (OUTPUT) | TEST CONDITIONS See Figure 1 | $\begin{array}{r} \mathrm{V}_{\mathrm{C}}=5 \mathrm{~V}, \\ \mathrm{~T}_{A}=25^{\circ} \mathrm{C} \\ \hline \text { 'ALS29827 } \\ \text { 'ALS29828 } \\ \hline \end{array}$ |  |  | $\begin{aligned} & V_{C C}=\text { MIN TO MAX, }{ }^{\dagger} \\ & T_{A}=\text { MIN TO MAX }{ }^{\dagger} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | SN54ALS29827 SN54ALS29828 |  | SN74ALS29827 <br> SN74ALS29828 |  |  |
|  |  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tPLH | A | Y | $C_{L}=300 \mathrm{pF}$ |  | 8 |  |  |  |  |  | ns |
| tPHL |  |  |  |  | 11 |  |  |  |  |  |  |
| ${ }^{\text {tPLH }}$ |  |  | $C_{L}=50 \mathrm{pF}$ |  | 5 |  |  |  |  |  |  |
| tPHL |  |  |  |  | 5 |  |  |  |  |  |  |
| tPZH | $\overline{\mathrm{G}}$ | Y | $C_{L}=300 \mathrm{pF}$ |  | 11 |  |  |  |  |  | ns |
| tPZL |  |  |  |  | 18 |  |  |  |  |  |  |
| tPZH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 7 |  |  |  |  |  |  |
| tPZL |  |  |  |  | 10 | 1 |  |  |  |  |  |
| tpHz | $\overline{\mathrm{G}}$ | Y | $C_{L}=50 \mathrm{pF}$ |  | 11 |  |  |  |  |  | ns |
| tPLZ |  |  |  |  | 5 |  |  |  |  |  |  |
| tpHz. |  |  | $C_{L}=5 \mathrm{pF}$ |  | 4 |  |  |  |  |  |  |
| tplZ |  |  |  |  | 4 |  |  |  |  |  |  |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
Additional information on these products can be obtained from the factory as it becomes available.

## SN54ALS29827, SN54ALS29828 SN74ALS29827, SN74ALS29828 10-BIT BUFFERS AND BUS DRIVERS WITH 3-STATE OUTPUTS

PARAMETER MEASUREMENT INFORMATION


NOTES: A. $C_{L}$ includes probe and jig capacitance.
B. Waveform 1 is for an output with internal conditions süch that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
C. All input pulses are supplied by generators having the following characteristics: PRR $\leq 10 \mathrm{MHz}, \mathrm{Z}_{\mathrm{o}}=50 \Omega, \mathrm{t}_{\mathrm{r}} \leq 2.5 \mathrm{~ns}$, $\mathrm{t}_{\mathrm{f}} \leq 2.5 \mathrm{~ns}$.

## FIGURE 1

- Functionally Equivalent to AM29861 and AM29862
- Choice of True or Inverting Logic
- Power-Up High-Impedance State
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 10-bit bus transceivers are designed for asynchronous two-way communication between data buses. The control function implementation allows for maximum flexibility in timing.
These devices allow data transmission from the A bus to the B bus or from the B bus to the A bus depending upon the logic levels at the enable inputs ( $\bar{G} B A$ and $\bar{G} A B$ ).

The enable inputs can be used to disable the device so that the buses are effectively isolated.

The SN54' family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

FUNCTION TABLE

| INPUTS |  | OPERATION |  |
| :---: | :---: | :---: | :---: |
| $\overline{\text { GAB }}$ | $\overline{\text { GBA }}$ | ALS29861 | ALS29862 |
| L | H | A to B | $\bar{A}$ to B |
| H | L | B to A | $\bar{B}$ to $A$ |
| H | H | Isolation | Isolation |
| L | L | Latch A and B | Latch $A$ and B |
|  |  | $(A=B)$ | $(A=\bar{B})$ |

SN54ALS' . . . JT PACKAGE
SN74ALS' . . DW OR NT PACKAGE
(TOP VIEW)


SN54ALS' . . FK PACKAGE SN74ALS' . . . FN PACKAGE (TOP VIEW)


## SN54ALS29861, SN54ALS29862

## SN74ALS29861, SN74ALS29862

## 10-BIT BUS TRANSCEIVERS WITH 3.STATE OUTPUTS

logic symbols ${ }^{\dagger}$
'ALS29861

'ALS29862

${ }^{\dagger}$ These symbols are in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
Pin numbers shown are for DW, JT, and NT packages.
logic diagrams
'ALS29861


Pin numbers shown are for DW, JT, and NT packages.
'ALS29862


## SN54ALS29861, SN54ALS29862

SN74ALS29861, SN74ALS29862
10-BIT BUS TRANSCEIVERS WITH 3-STATE OUTPUTS

\section*{absolute maximum ratings over operating free-air temperature range (unless otherwise noted) <br> | Supply voltage, VCC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V |  |  |
| :---: | :---: | :---: |
| Input voltage: All inputs and I/O ports . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 5 |  |  |
| Operating free-air temperature range: | SN54ALS29861, SN54ALS29862 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
|  | SN74ALS29861, SN74ALS29862 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range |  | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

## recommended operating conditions

|  |  | SN54ALS29861 SN54ALS29862 |  |  | SN74ALS29861 SN74ALS29862 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\mathrm{IH}}$ | High-level input voltage | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 |  |  | 0.8 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  |  | -15 |  |  | -24 | mA |
| ${ }^{1} \mathrm{OL}$ | Low-level output current |  |  | 32 |  |  | 48 | mA |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$ |  | SN54ALS29861 <br> SN54ALS29862 |  |  | SN74ALS29861 <br> SN74ALS29862 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $V_{\text {IK }}$ |  |  |  | $V_{\text {CC }}=\mathrm{MIN}$, | $\\|_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ |  | $\mathrm{V}_{\mathrm{CC}}=$ MIN to MAX, | $\mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{I}_{\mathrm{OH}}=-15 \mathrm{~mA}$ | 2 |  |  |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{IOH}^{\mathrm{OH}}$ - 24 mA |  |  |  | 2 |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $1 \mathrm{OL}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| 11 |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  |  |  |  |  | mA |
| $I_{1 H}$ | Control inputs | $V_{C C}=\mathrm{MAX}, \quad \mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | A or B ports ${ }^{\text {® }}$ |  |  |  |  | 20 |  |  | 20 |  |
| IIL | Control inputs | $V_{C C}=\mathrm{MAX}, \quad V_{1}=0.4 \mathrm{~V}$ |  |  |  | -0.1 |  |  | -0.1 | mA |
|  | A or B ports ${ }^{\text {§ }}$ |  |  |  |  | -0.1 |  |  | -0.1 |  |
| los ${ }^{1}$ |  | $V_{C C}=M A X$, | $\mathrm{V}_{0}=0$ | -75 |  | -250 | -75 |  | -250 | mA |
| ${ }^{1} \mathrm{CC}$ | 'ALS29861 | $V_{C C}=\mathrm{MAX}$ | Outputs high | 28 |  |  | 28 |  |  | mA |
|  |  |  | Outputs low |  | 38 |  |  | 38 |  |  |
|  |  |  | Outputs disabled |  | 36 |  |  | 36 |  |  |
|  | 'ALS29862 |  | Outputs high | 22 |  |  | 22 |  |  |  |
|  |  |  | Outputs low | 30 |  |  | 30 |  |  |  |
|  |  |  | Outputs disabled | 28 |  |  | 28 |  |  |  |

$\dagger$ For conditions shown as MIN or MAX, use appropriate value specified under recommended operating conditions.
$\ddagger$ All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
§ For I/O ports, the parameters $I_{I H}$ and $I_{I L}$ include the off-state output current.
I Not more than one output should be shorted at a time and duration of the short circuit should not exceed one second.

## SN54ALS29861, SN54ALS29862 <br> SN74ALS29861, SN74ALS29862 10 -BIT BUS TRANSCEIVERS WITH 3-STATE OUTPUTS

## 'ALS29861 switching characteristics

| PARAMETER | FROM (INPUT) | то (OUTPUT) | TEST CONDITIONS See Figure 1 | $\begin{aligned} & V_{C C}=5 \mathrm{~V} \\ & T_{A}=25^{\circ} \mathrm{C} \\ & \hline \text { ALS29861 } \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathbf{C C}}=\text { MIN TO MAX, }{ }^{\dagger} \\ & \mathrm{T}_{\mathbf{A}}=\text { MIN TO MAX }^{\dagger} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | SN54ALS29861 |  | SN74ALS29861 |  |  |
|  |  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tplH | A or B | B or A | $C_{L}=300 \mathrm{pF}$ |  | 8 |  |  |  |  |  | ns |
| tpHL |  |  |  |  | 11 |  |  |  |  |  |  |
| tPLH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 5 |  |  |  |  |  |  |
| tPHL |  |  |  |  | 5 |  |  |  |  |  |  |
| tPZH | $\begin{gathered} \overline{\mathrm{G}} A B \\ \text { or } \\ \overline{\mathrm{G}} \mathrm{BA} \end{gathered}$ | $A$ or B | $C_{L}=300 \mathrm{pF}$ |  | 11 |  |  |  |  |  | ns |
| tPZL |  |  |  |  | 17 |  |  |  |  |  |  |
| tPZH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 7 |  |  |  |  |  |  |
| tPZL |  |  |  |  | 10 |  |  |  |  |  |  |
| tPHZ | $\overline{\mathrm{G}} \mathrm{AB}$ or $\overline{\mathrm{G}} \mathrm{BA}$ | A or B | $C_{L}=50 \mathrm{pF}$ |  | 11 |  |  |  |  |  | ns |
| tPLZ |  |  |  |  | 5 |  |  |  |  |  |  |
| tphz |  |  | $C_{L}=5 \mathrm{pF}$ |  | 4 |  |  |  |  |  |  |
| tPLZ |  |  |  |  | 4 |  |  |  |  |  |  |

'ALS29862 switching characteristics

| PARAMETER | FROM (INPUT) | то (OUTPUT) | TEST CONDITIONS <br> See Figure 1 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline{ }^{\text {ALS29862 }} \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\text { MIN TO MAX, }{ }^{\dagger} \\ & \mathrm{T}_{\mathbf{A}}=\text { MIN TO MAX }{ }^{\dagger} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | SN54ALS29862 |  | SN74ALS29862 |  |  |
|  |  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tPLH | A or B | $B$ or A | $C_{L}=300 \mathrm{pF}$ |  | 7 |  |  |  |  |  | ns |
| tPHL |  |  |  |  | 11 |  |  |  |  |  |  |
| tPLH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 4 |  |  |  |  |  |  |
| tPHL |  |  |  |  | 5 |  |  |  |  |  |  |
| tPZH | $\bar{G} A B$ or $\overline{\mathrm{G}} \mathrm{BA}$ | A or B | $C_{L}=300 \mathrm{pF}$ |  | 11 |  |  |  |  |  | ns |
| tPZL |  |  |  |  | 17 |  |  |  |  |  |  |
| tPZH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 7 |  |  |  |  |  |  |
| tPZL |  |  |  |  | 10 |  |  |  |  |  |  |
| tPHZ | $\bar{G} A B$ or ḠBA | A or B | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 11 |  |  |  |  |  | ns |
| tPLZ |  |  |  |  | 5 |  |  |  |  |  |  |
| tphz |  |  | $C_{L}=5 \mathrm{pF}$ |  | 4 |  |  |  |  |  |  |
| tPLZ |  |  |  |  | 4 |  |  |  |  |  |  |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.

Additional information on these products can be obtained from the factory as it becomes available.

## PARAMETER MEASUREMENT INFORMATION



SWITCH POSITION TABLE

| TEST | S1 | S2 |
| :---: | :---: | :---: |
| tPLH | Closed | Closed |
| tPHL | Closed | Closed |
| tPZH | Open | Closed |
| tpZL | Closed | Open |
| tPHZ | Closed | Closed |
| tPLZ | Closed | Closed |



VOLTAGE WAVEFORMS PROPAGATION DELAY TIMES


VOLTAGE WAVEFORMS
PULSE DURATIONS


VOLTAGE WAVEFORMS
ENABLE AND DISABLE TIMES, THREE-STATE OUTPUTS

NOTES: A. $C_{L}$ includes probe and jig capacitance.
B. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
C. All input pulses are supplied by generators having the following characteristics: PRR $\leq 10 \mathrm{MHz}, \mathrm{Z}_{\mathrm{o}}=50 \Omega, \mathrm{t}_{\mathrm{r}} \leq 2.5 \mathrm{~ns}$, $\mathrm{t}_{\mathrm{f}} \leq 2.5 \mathrm{~ns}$.

FIGURE 1

- Functionally Equivalent to AM29863 and AM29864
- Choice of True or Inverting Logic
- Power-Up High-Impedance State
- Package Options Include Both Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability


## description

These 9-bit bus transceivers are designed for asynchronous two-way communication between data buses. The control function implementation allows for maximum flexibility in timing.

These devices allow data transmission from the A bus to the $B$ bus or from the $B$ bus to the $A$ bus depending upon the logic levels at the enable inputs ( $\overline{\mathrm{G}} \mathrm{BA} 1, \overline{\mathrm{G}} \mathrm{BA} 2, \overline{\mathrm{G}} \mathrm{AB} 1$, and $\overline{\mathrm{G}} \mathrm{AB} 2$ ).

The SN54' family is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The SN74' family is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

(TOP VIEW)
GBA1 $\square 1$
A1 $\square 2$

SN54ALS' . . . FK PACKAGE SN74ALS' . . . FN PACKAGE (TOP VIEW)


NC - No internal connection

FUNCTION TABLE

| ENABLE INPUTS |  |  |  | OPERATION |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { GAB1 }}$ | $\overline{\text { GAB2 }}$ | $\overline{\text { GBA1 }}$ | $\overline{\text { GBBA }}$ | 'ALS29863 | ALS29864 |
| L | L | L | L | Latch A and B | Latch A and B |
| L | L | H | X | A to B | A to $\bar{B}$ |
| L | L | X | H |  |  |
| H | X | L | L | B to A | B to $\bar{A}$ |
| X | H | L | L |  |  |
| H | X | H | X |  | Isolation |
| H | X | X | H | Isolation |  |
| X | H | X | H |  |  |
| X | $H$ | $H$ | $X$ |  |  |

## SN54ALS29863, SN54ALS29864 <br> SN74ALS29863, SN74ALS29864 <br> 9-BIT BUS TRANSCEIVERS WITH 3-STATE OUTPUTS

logic symbols ${ }^{\dagger}$
'ALS29863

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

## logic diagrams

'ALS29863

'ALS29864

'ALS29864


Pin numbers shown are for DW, JT, and NT packages.

## SN54ALS29863, SN54ALS29864 <br> SN74ALS29863, SN74ALS29864 9-BIT BUS TRANSCEIVERS WITH 3-STATE OUTPUTS

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)

| Supply voltage, VCC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V |  |  |
| :---: | :---: | :---: |
| Input voltage: All inputs and I/O ports . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V |  |  |
| Operating free-air temperature range | SN54ALS29863, SN54ALS29864 | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |
|  | SN74ALS29863, SN74ALS29864 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage temperature range |  | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |

recommended operating conditions

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

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$ |  | SN54ALS29863 SN54ALS29864 |  |  | SN74ALS29863 <br> SN74ALS29864 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\ddagger}$ | MAX | MIN | TYP ${ }^{\ddagger}$ | MAX |  |
| $\mathrm{V}_{\mathrm{IK}}$ |  |  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| VOH |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$ to MAX, | $\mathrm{I}_{\mathrm{OH}}=-0.4 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | $\mathrm{V}_{\mathrm{CC}}-2$ |  |  | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $1 \mathrm{OH}=-15 \mathrm{~mA}$ | 2 |  |  |  |  |  |  |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $1 \mathrm{OH}=-24 \mathrm{~mA}$ |  |  |  | 2 |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $1 \mathrm{OH}=-32 \mathrm{~mA}$ |  | 0.25 | 0.4 |  | 0.25 | 0.4 | V |
|  |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{IOL}=48 \mathrm{~mA}$ |  |  |  |  | 0.35 | 0.5 |  |
| 1 |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  |  |  |  |  | mA |
| $\mathrm{IIH}^{\text {H }}$ | Control inputs | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
|  | A or B ports ${ }^{\text {§ }}$ |  |  |  |  | 20 |  |  | 20 |  |
| IIL | Control inputs | $V_{C C}=$ MAX | $V_{1}=0.4 \mathrm{~V}$ |  |  | -0.1 |  |  | -0.1 | mA |
|  | A or B ports ${ }^{\text {§ }}$ |  |  |  |  | -0.1 |  |  | -0.1 |  |
| los 1 |  | $V_{C C}=M A X$, | $\mathrm{V}_{\mathrm{O}}=0$ | -75 |  | -250 | -75 |  | -250 | mA |
| ${ }^{1} \mathrm{CC}$ |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ | Outputs high | 26 |  |  | 26 |  |  | mA |
|  | 'ALS29863 |  | Outputs low |  | 35 |  |  | 35 |  |  |
|  |  |  | Outputs disabled |  | 34 |  |  | 34 |  |  |
|  | 'ALS29864 |  | Outputs high |  | 20 |  |  | 20 |  |  |
|  |  |  | Outputs low |  | 27 |  |  | 27 |  |  |
|  |  |  | Outputs disabled |  | 26 |  |  | 26 |  |  |

[^77]SN54ALS29863, SN54ALS29864
SN74ALS29863, SN74ALS29864

## 9-BIT BUS TRANSCEIVERS WITH 3-STATE OUTPUTS

'ALS29863 switching characteristics

| PARAMETER | FROM (INPUT) | то (OUTPUT) | TEST CONDITIONS <br> See Figure 1 | $\begin{aligned} & V_{C C}=5 \mathrm{~V}, \\ & T_{A}=25^{\circ} \mathrm{C} \\ & \hline{ }^{\prime} \mathrm{ALS29863} \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \mathbf{V}_{\mathbf{C C}}=\text { MIN TO MAX, }{ }^{\dagger} \\ & \mathrm{T}_{\mathbf{A}}=\operatorname{MIN} \text { TO MAX }{ }^{\dagger} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | SN | 863 | SN | 863 |  |
|  |  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| tPLH | A or B | B or A | $C_{L}=300 \mathrm{pF}$ |  | 8 |  |  |  |  |  | ns |
| tpHL |  |  |  |  | 11 |  |  |  |  |  |  |
| tPLH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 5 |  |  |  |  |  |  |
| tPHL |  |  |  |  | 5 |  |  |  |  |  |  |
| tPZH | $\overline{\mathrm{G}} \mathrm{AB}$ or GBA | A or B | $\mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$ |  | 11 |  |  |  |  |  | ns |
| tPZL |  |  |  |  | 17 |  |  |  |  |  |  |
| tPZH |  |  | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |  | 7 |  |  |  |  |  |  |
| tPZL |  |  |  |  | 10 |  |  |  |  |  |  |
| tPHZ | ḠAB or ḠBA | A or B | $C_{L}=50 \mathrm{pF}$ |  | 11 |  |  |  |  |  | ns |
| tPLZ |  |  |  |  | 5 |  |  |  |  |  |  |
| tphz |  |  | $C_{L}=5 \mathrm{pF}$ |  | 4 |  |  |  |  |  |  |
| tPLZ |  |  |  |  | 4 |  |  |  |  |  |  |

seonead ist N
'ALS29864 switching characteristics

| PARAMETER | FROM (INPUT) | то (OUTPUT) | TEST CONDITIONS See Figure 1 | $\begin{aligned} & V_{C C}=5 \mathrm{~V}, \\ & T_{A}=25^{\circ} \mathrm{C} \\ & \hline \text { ALS29864 } \end{aligned}$ |  |  | $\begin{aligned} & V_{C C}=\text { MIN TO MAX, }{ }^{\dagger} \\ & T_{A}=\text { MIN TO MAX }{ }^{\dagger} \end{aligned}$ |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | SN54ALS29864 |  | SN74ALS29864 |  |  |
|  |  |  |  | MIN | TYP | MAX | MiN | MAX | MIN | MAX |  |
| tPLH | A or B | $B$ or A | $C_{L}=300 \mathrm{pF}$ |  | 7 |  |  |  |  |  | ns |
| tPHL |  |  |  |  | 11 |  |  |  |  |  |  |
| tPLH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 4 |  |  |  |  |  |  |
| tPHL |  |  |  |  | 5 |  |  |  |  |  |  |
| tPZH | G $A B$ or ḠBA | A or B | $C_{L}=300 \mathrm{pF}$ |  | 11 |  |  |  |  |  | ns |
| tPZL |  |  |  |  | 17 |  |  |  |  |  |  |
| tPZH |  |  | $C_{L}=50 \mathrm{pF}$ |  | 7 |  |  |  |  |  |  |
| tPZL |  |  |  |  | 10 |  |  |  |  |  |  |
| tpHz | $\overline{\mathrm{G}} \mathrm{AB}$ or ḠBA | A or B | $C_{L}=50 \mathrm{pF}$ |  | 11 |  |  |  |  |  | ns |
| tPLZ |  |  |  |  | 5 |  |  |  |  |  |  |
| tpHz |  |  | $C_{L}=5 \mathrm{pF}$ |  | 4 |  |  |  |  |  |  |
| tPLZ |  |  |  |  | 4 |  |  |  |  |  |  |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.

Additional information on these products can be obtained from the factory as it becomes available.

## SN54ALS29863, SN54ALS29864 <br> SN74ALS29863, SN74ALS29864 9-BIT BUS TRANSCEIVERS WITH 3-STATE OUTPUTS

## PARAMETER MEASUREMENT INFORMATION


load circuit


VOLTAGE WAVEFORMS SETUP AND HOLD TIMES

VOLTAGE WAVEFORMS PROPAGATION DELAY TIMES



## VOLTAGE WAVEFORMS <br> PULSE DURATIONS



VOLTAGE WAVEFORMS
enable and disable times, three-state outputs

NOTES: A. $C_{L}$ includes probe and jig capacitance.
B. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.
C. All input pulses are supplied by generators having the following characteristics: PRR $\leq 10 \mathrm{MHz}, \mathrm{Z}_{\mathrm{O}}=50 \Omega, \mathrm{t}_{\mathrm{r}} \leq 2.5 \mathrm{~ns}$, $\mathrm{t}_{\mathrm{f}} \leq 2.5 \mathrm{~ns}$.

FIGURE 1

# THCT1010-160M, THCT1010-140E, THCT1010-100 <br> 16-BIT BY 16-BIT MULTIPLIERS/ACCUMULATORS 

- 16-Bit by 16-Bit Parallel Multiplication/Accumulation


## - 35-Bit-Wide Accumulator

- Inputs are TTL-Voltage Compatible
- Outputs Capable of Driving up to 10 LSTTL Loads
- Single 5-V Power Supply
- Low Power Dissipation . . . 150 mW Typical
- Pin-for-Pin Compatible with TRW TDC1010J (DIP only) and AM29510 (DIP only)
- High-Speed Twin-Well CMOS Process
- Package Options Include Ceramic and Plastic Chip Carriers and DIPs
- Dependable Texas Instruments Quality and Reliability


## description

The THCT1010 is a TTL-voltage-compatible, low-power, high-speed 16 -bit by 16 -bit multiplier/accumulator for digital signal processing, digital filters, fast Fourier transformations, array processing, and microprocessor throughput enhancement. These devices are pin-for-pin equivalent to the TRW TDC1010J but dissipate 20 times less power. The lower power dissipation causes the differences between junction and ambient temperatures to be minimized and, therefore, eliminates the heat-sink requirements and increases reliability. High speed is achieved by using a modified Booth algorithm, a feed-forward carry circuit, and a conditional sum adder that enhances the final adder stage of the multiplier.

The THCT1010 inputs consist of three registers, a 16-bit $X$ input, a 16 -bit $Y$ input, and an input control register. The 35 -bit output product register consists of a 16 -bit most-significantproduct (MSP) bus, a 16-bit least-significantproduct (LSP) bus that is shared with the 16-bit Y input bus, and a 3-bit extended-product (XTP) bus (PR32 through PR34); see the functional block diagram. The input registers are

## JD OR N DUAL-IN-LINE PACKAGE <br> (TOP VIEW)

| $\times 6 \square 1$ | $1 \cup_{64}$ | $\times 7$ |
| :---: | :---: | :---: |
| $\times 5 \square 2$ | 263 | ] $\times 8$ |
| $\times 4 \square^{3}$ | 362 | $\square \times 9$ |
| $\times 3 \square^{4}$ | 461 | $\times 10$ |
| $\times 2 \square 5$ | 560 | 1 $\times 11$ |
| $\times 1 \square^{6}$ | $6 \quad 59$ | $\times 12$ |
| XO $\square^{7}$ | $7 \quad 58$ | ] $\times 13$ |
| YO/PRO $\square_{8}^{8}$ | $8 \quad 57$ | $\square \times 14$ |
| Y1/PR1 9 | 956 | $\times 15$ |
| Y2/PR2 $\square_{1}^{10}$ | 1055 | ] OELS |
| Y3/PR3 $\square_{1}$ | 1154 | $\square \mathrm{RND}$ |
| Y4/PR4 $\square_{1}^{1}$ | $12 \quad 53$ | $\square$ SUB |
| Y5/PR5 13 | $13 \quad 52$ | $\square \mathrm{ACC}$ |
| Y6/PR6 $\square_{1}^{14}$ | $14 \quad 51$ | $\square$ CLK X |
| Y7/PR7 $]_{1}^{1}$ | 15 50 | CLK Y |
| GND $\square^{16}$ | $16 \quad 49$ | $\mathrm{V}_{\mathrm{CC}}$ |
| Y8/PR8 1 | $17 \quad 48$ | T TC |
| Y9/PR9 $\square_{1}$ | 1847 | $\square \overline{O E X}$ |
| Y10/PR10 1 | 1946 | $\square \mathrm{PREL}$ |
| Y11/PR11 ${ }^{\text {c }}$ | $20 \quad 45$ | $\square \overline{\text { OEMS }}$ |
| Y12/PR12 | 2144 | CLK PR |
| Y13/PR13 | $22 \quad 43$ | $\square \mathrm{PR} 34$ |
| Y14/PR14 | $23 \quad 42$ | $\square$ PR33 |
| Y15/PR15 ${ }^{\text {c }}$ | $24 \quad 41$ | $\square \mathrm{PR} 32$ |
| PR16 2 | $25 \quad 40$ | PR31 |
| PR17 ${ }^{\text {d }}$ | $26 \quad 39$ | $\square \mathrm{PR} 30$ |
| PR18 27 | $27 \quad 38$ | PR29 |
| PR19 2 | $28 \quad 37$ | ] PR28 |
| PR20 42 | 2936 | ] PR27 |
| PR21 30 | $30 \quad 35$ | $\square \mathrm{PR} 26$ |
| PR22 ${ }^{3}$ | $31 \quad 34$ | ] PR25 |
| PR23 3 | $32 \quad 33$ | PR24 |

FK OR FN CHIP-CARRIER PACKAGE
(TOP VIEW)



NC - No internal connection

Caution. These devices have limited built-in gate protection. The leads should be shorted together or the device placed in conductive foam during storage or handling to prevent electrostatic damage to the MOS gates.
independently controlled by CLK X and CLK Y, and the product registers are D-type positive-edge-triggered flip-flops. Separate three-state output enables are provided for each output product register. These, in combination with the independent input clocks, allow operation on a microprocessor bus.

The THCT1010 has a round control (RND) that rounds the product to the 19 most significant bits. The preload control (PREL) is used in conjunction with the output enables to initialize the contents of the output registers. The THCT1010 will perform multiplication and addition, multiplication and subtraction, or straight multiplication depending upon the states of the accumulate control (ACC) and subtractor control (SUB). The TC control provides the capability of formatting the input data to be either two's complement or unsigned magnitude.

The THCT1010-160M is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The THCT1010-140E is characterized for operation from $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$. The THCT1010-100 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$. 16-BIT BY 16-BIT MULTIPLIERS|ACCUMULATORS

| PIN |  | DESCRIPTION |
| :---: | :---: | :---: |
| NO. | NAME |  |
| 56-64, 1-7 | X15 thru X0 | $X$ data inputs, X 15 is the most-significant bit. The data is loaded into the X register on the rising edge of CLKX. |
| $8-15,17-24$ | YO/PRO thru Y15/PR15 | I/O ports for least significant product (LSP) bits of output product register, input ports for Y data. YO/PRO is the least significant bit. The mode is controlled by the PREL and OEMS pins. |
| 25-43 | PR16 thru PR34 | I/O ports for output product register bits. PR16 through PR31 are the most-significant product (MSP) bits. PR32 through PR34 are the extended product (XTP) bits. The mode is controlled by PREL, $\overline{\mathrm{OELS}}, \overline{\mathrm{OEX}}$. |
| 44 | CLK PR | Product clock input. On the low-to-high transition, latches the LSP, MSP, and XTP into the output product register. |
| 45 | OEMS | Active-low output enable for MSP output product register. When high, causes the PR31 through PR16 outputs to be in the high-impedance state. |
| 46 | PREL | Preload control. When high, the output product register's outpúts are disabled. When an output enable ( $\overline{\mathrm{OELS}}, \overline{\mathrm{OEMS}}, \overline{\mathrm{OEX}}$ ) is high, preload data can be entered into the output product register from the PR I/O lines on the rising edge of CLK PR. |
| 47 | $\overline{\text { OEX }}$ | Active-low output enable for XTP output product register. When high, causes the PR32 through PR34 outputs to be in the high-impedance state. |
| 48 | TC | Two's complement control. When TC is high, the input data is in two's complement format. When TC is low, the input data is in unsigned magnitude format. The TC signal is loaded into the control register on the rising edge of CLK $X$ or CLK $Y$. |
| 50 | CLK Y | $Y$ clock input. On the low-to-high transition, clocks data in from the $Y$ inputs. |
| 51 | CLK X | $X$ clock input. On the low-to-high transition, clocks data in from the X inputs. |
| 52 | ACC | Accumulator control. When ACC is high and SUB is low, the content of the output product register is added to the next product generated. The sum is then placed in the output product register on the rising edge of CLK PR. When ACC is low, the product is stored directly into the output register on the rising edge of CLK PR. The ACC signal is loaded into the control register at the rising edge of CLK $X$ or CLK $Y$. |
| 53 | SUB | Subtraction control. When SUB and ACC are high, the content of the output product register is subtracted from the next product generated. The result is then placed in the output product register on the rising edge of CLK PR. When SUB is low and ACC is high, the addition operation is performed instead of subtraction. When ACC is low, SUB is a "Don't Care". The SUB signal is loaded into the control register on the rising edge of CLK $X$ or CLK $Y$. |
| 54 | RND | Round control. When high, causes the product of the $X$ and $Y$ inputs to be rounded to the 19 most significant bits by adding a 1 to the MSB of the LSP. The RND signal is loaded into the control register on the rising edge of CLK X or CLK Y . |
| 55 | $\overline{\text { OELS }}$ | Active-low output enable for LSP output product register. When high, causes the PRO through PR15 outputs to be in the high-impedance state. |

Pin numbers shown are for the JD and $N$ packages.

## THCT1010-160M, THCT1010-140E, THCT1010-100 16-BIT BY 16-BIT MULTIPLIERS|ACCUMULATORS

PRELOAD FUNCTION TABLE

| PREL | $\overline{\text { OEX }}$ | $\overline{\text { OEMS }}$ | $\overline{\text { OELS }}$ | XTP | MSP | LSP |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | L | (PR32-PR34) | (PR16-PR31) | (PRO-PR15) |
| L | L | L | H | (PR32-PR34) | (PR16-PR31) | Z |
| L | L | H | L | (PR32-PR34) | Z | (PRO-PR15) |
| L | L | H | H | (PR32-PR34) | Z | Z |
| L | H | L | L | Z | (PR16-PR31) | (PRO-PR15) |
| L | H | L | H | Z | (PR16-PR31) | Z |
| L | H | H | L | Z | Z | (PRO-PR15) |
| L | H | H | H | Z | Z | Z |
| H | L | L | L | Z | Z | Z |
| H | L | L | H | Z | Z | PL |
| H | L | H | L | Z | PL | Z |
| H | L | H | H | Z | PL | PL |
| H | H | L | L | PL | Z | Z |
| H | H | L | H | PL | Z | PL |
| H | H | H | L | PL | PL | Z |
| H | H | H | H | PL | PL | PL |

PL $=$ Output buffers at high impedance or output disabled. Preload data supplied externally at output pins will be loaded into the output register on the rising edge of CLK PR.
logic symbol


Pin numbers shown are for the JD and $N$ packages.
logic diagram (positive logic)


Pin numbers shown are for the JD and N packages.
absolute maximum ratings over operating free-air temperature range ${ }^{\dagger}$
Supply voltage range, $\mathrm{V}_{\mathrm{CC}}$ -0.5 V to 7 V
Input diode current, $\mathrm{I}_{\mathrm{K}}\left(\mathrm{V}_{1}<0\right.$ or $\mathrm{V}_{1}>\mathrm{V}_{\mathrm{C}}$ ). $\pm 20 \mathrm{~mA}$
Output diode current, IOK ( $\mathrm{V}_{\mathrm{O}}<0$ or $\mathrm{V}_{\mathrm{O}}>\mathrm{V}_{\mathrm{CC}}$ ) $\pm 20 \mathrm{~mA}$
Continuous output current, Io ( $\mathrm{V}_{\mathrm{O}}=0$ to $\mathrm{V}_{\mathrm{CC}}$ ) $\pm 25 \mathrm{~mA}$
Continuous current through VCC or GND pins $\pm 50 \mathrm{~mA}$
Lead temperature $1,6 \mathrm{~mm}(1 / 16$ inch $)$ from case for 60 seconds . . . . . . . . . . . . . . . . . . . . . . $300^{\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

|  |  |  | THCT1010-160M |  |  | THCT1010-140E |  |  | THCT1010-100 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX |  |
| $\mathrm{V}_{\text {CC }}$ | Supply voltage |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V | 2 |  |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ to 5.5 V | 0 |  | 0.8 | 0 |  | 0.8 | 0 |  | 0.8 | V |
| $\mathrm{V}_{1}$ | Input voltage |  | 0 |  | VCC | 0 |  | $\mathrm{V}_{\text {CC }}$ | 0 |  | $\mathrm{V}_{\text {CC }}$ | V |
| $\mathrm{V}_{0}$ | Output voltage |  | 0 |  | $\mathrm{V}_{\text {cc }}$ | 0 |  | VCC | 0 |  | $\mathrm{V}_{\text {CC }}$ | V |
| $\mathrm{t}_{\mathrm{t}}$ | Input transition (rise and fall) times |  | 0 |  | 500 | 0 |  | 500 | 0 |  | 500 | ns |
| $\mathrm{T}_{\text {A }}$ | Operating free-air temperature |  | -55 |  | 125 | -40 |  | 85 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

## THCT1010-160M, THCT1010-140E, THCT1010-100 16-BIT BY 16-BIT MULTIPLIERS|ACCUMULATORS

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

| PARAMETER | TEST CONDITIONS | $V_{C C}$ | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  |  | THCT1010-160M |  | THCT1010-140E THCT1010-100 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| VOH | $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\text {IH }}$ or $\mathrm{V}_{\text {IL }}, \mathrm{l}_{\mathrm{OH}}=-20 \mu \mathrm{~A}$ | 4.5 V | 4.4 |  |  | 4.4 |  | 4.4 |  | V |
|  | $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\text {IH }}$ or $\mathrm{V}_{\text {IL }}, \mathrm{I}^{\text {OH }}=-4 \mathrm{~mA}$ | 4.5 V | 3.86 |  |  | 3.7 |  | 3.76 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\text {IH }}$ or $\mathrm{V}_{\text {IL }}, \mathrm{I}_{\mathrm{OL}}=20 \mu \mathrm{~A}$ | 4.5 V |  |  | 0.1 |  | 0.1 |  | 0.1 | V |
|  | $\mathrm{V}_{\mathrm{I}}=\mathrm{V}_{\text {IH }}$ or $\mathrm{V}_{\text {IL }}, \mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}$ | 4.5 V |  |  | 0.32 |  | 0.4 |  | 0.37 |  |
| 1 | $\mathrm{V}_{1}=0$ to $\mathrm{V}_{\mathrm{CC}}$ | 5.5 V |  | $\pm 5$ | $\pm 100$ |  | $\pm 1000$ |  | $\pm 1000$ | nA |
| IOZ | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\text {CC }}$ or $0, \mathrm{~V}_{\mathrm{I}}=\mathrm{V}_{\text {IH }}$ or $\mathrm{V}_{\text {IL }}$ | 5.5 V |  | $\pm 0.01$ | $\pm 0.5$ |  | $\pm 10$ |  | $\pm 5$ | $\mu \mathrm{A}$ |
| $1 \mathrm{CC}^{\dagger}$ | $V_{1}=V_{C C}$ or $0,10=0$ | 5.5 V |  |  | 0.75 |  | 2 |  | 1 | mA |
| $\mathrm{C}_{\mathrm{i}}$ |  | $\begin{aligned} & 4.5 \mathrm{~V} \\ & \text { to } \\ & 5.5 \mathrm{~V} \end{aligned}$ |  | 3 | 10 |  | 10 |  | 10 | pF |

${ }^{\dagger}$ See Figure 4.
timing requirements over recommended operating free-air temperature range (unless otherwise noted)
THCT1010-160M, THCT1010-140E


## THCT1010-100

|  |  |  | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | THCT1010-100 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | MAX | MIN | MAX |  |
| $\mathrm{t}_{\mathrm{w}}$ | Pulse duration, clocks X and Y high or low |  |  | 4.75 V | 20 |  | 25 |  | ns |
| $\mathrm{t}_{\text {su }}$ | Setup time, X input before CLK $\mathrm{X} \uparrow$ or Y input before CLK $\mathrm{Y} \uparrow$ |  | 4.75 V | 10 |  | 20 |  | ns |
| $t_{\text {h }}$ | Hold time | $X$ input after CLK $X \uparrow$ | 4.75 V | 6 |  | 10 |  | ns |
|  |  | Y input after CLK $\mathrm{Y} \uparrow$ or preload data after CLK PR $\uparrow$ | 4.75 V | 1 |  | 5 |  | ns |

## THCT1010-160M, THCT1010-140E, THCT1010-100 16-BIT BY 16-BIT MULTIPLIERS/ACCUMULATORS

switching characteristics over recommended operating free-air temperature range (unless otherwise noted), $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (see Figure 3)
THCT1010-160M, THCT1010-140E

| PARAMETER |  | $V_{C C}$ | $T_{A}=25^{\circ} \mathrm{C}$ |  | THCT1010-160M |  | THCT 1010-140E |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN TYP ${ }^{\text {f }}$ | MAX | MIN | MAX | MIN | MAX |  |
| ${ }^{\text {tpd }}$ | Propagation delay time |  | 4.5 V | 45 |  |  | 65 |  | 55 | ns |
|  |  | 5.5 V |  |  |  | 60 |  | 50 |  |  |
| ${ }^{\text {ten }}$ | Enable time | 4.5 V | 35 |  |  | 65 |  | 45 | ns |  |
|  |  | 5.5 V |  |  |  | 60 |  | 40 |  |  |
| ${ }^{\text {t }}$ dis | Disable time | 4.5 V | 35 |  |  | 60 |  | 45 | ns |  |
|  |  | 5.5 V |  |  |  | 55 |  | 40 |  |  |
| $\mathrm{t}_{\text {macc }}$ | Multiply/accumulate time | 4.5 V | 100 |  |  | 160 |  | 140 | ns |  |
|  |  | 5.5 V |  |  |  | 140 |  | 120 |  |  |


| $\mathrm{C}_{\mathrm{pd}}$ | Power dissipation capacitance | No load, $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 750 pF typ |
| :--- | :--- | :--- | :--- |

## THCT1010-100

|  |  | $V_{\text {cc }}$ | $T_{A}=25^{\circ} \mathrm{C}$ |  |  | THCT1010-100 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP ${ }^{\dagger}$ | MAX | MIN | MAX |  |
| ${ }_{\text {t }}^{\text {pd }}$ | Propagation delay time |  | 4.75 V |  | 35 |  |  | 45 | ns |
| $\mathrm{t}_{\text {en }}$ | Enable time | 4.75 V |  | 30 |  |  | 40 | ns |
| $\mathrm{t}_{\text {dis }}$ | Disable time | 4.75 V |  | 30 |  |  | 40 | ns |
| $t_{\text {macc }}$ | Multiply/accumulate time | 4.75 V |  | 90 |  |  | 100 | ns |

${ }^{\dagger}$ Typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$.

PARAMETER MEASUREMENT INFORMATION

$\ddagger$ The measurement points for enable and disable times are as shown in Figure 2.
FIGURE 1. VOLTAGE WAVEFORMS

PARAMETER MEASUREMENT INFORMATION


NOTE: Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditons such that the output is high except when disabled by the output control.

FIGURE 2. DETAILED VOLTAGE WAVEFORMS FOR ENABLE AND DISABLE TIMES


FIGURE 3. LOAD CIRCUITS
TYPICAL CHARACTERISTICS


FIGURE 4

THCT1010-160M, THCT1010-140E, THCT1010-100 16-BIT BY 16-BIT MULTIPLIERS|ACCUMULATORS

THERMAL INFORMATION
THERMAL RESISTANCE

| PACKAGE | PINS | JUNCTION-TO-CASE THERMAL RESISTANCE, R $_{\boldsymbol{\theta}}$ JC $\left({ }^{\circ} \mathrm{C} / \mathrm{W}\right)$ | JUNCTION-TO-FREE-AIR THERMAL RESISTANCE, R IJA ( ${ }^{\circ} \mathrm{C} / \mathrm{W}$ ) |
| :---: | :---: | :---: | :---: |
| FK | 68 | 8 | 36 |
| FN | 68 |  |  |
| JD | 64 | 9 | 32 |
| N | 64 |  |  |

## ORDERING INSTRUCTIONS

- 100 .. . 100 ns $t_{\text {macc }}$ (THCT1010-100 only)
- 140 ... $140 \mathrm{~ns} \mathrm{t}_{\text {macc }}$ (THCT1010-140E only)
- 160 .. . 160 ns tmacc (THCT1010-160M only)

4. Package
FK (Ceramic leadless chip carrier)
FN (Plastic leaded chip carrier)
JD (Ceramic DIP)
N. (Plastic DIP)
5. Temperature Range

$$
\begin{aligned}
\mathrm{M} & \ldots-55^{\circ} \mathrm{C} \text { to } 125^{\circ} \mathrm{C} \\
\mathrm{E} & \ldots-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \\
\text { (Blank) } & \ldots \mathrm{O}^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}
\end{aligned}
$$

- Inputs are TTL- and CMOS-Voltage Compatible
- Interfaces Mechanical Devices to Data Bus
- Identifies and Measures Forward or Backward Rotation or Direction
- Measures Pulse Duration and Frequency
- Cascadable 16-Bit Up/Down Counter
- 8-Bit Parallel 3-State Bus with Each Output Capable of Driving up to 15 LSTTL Loads
- Dependable Texas Instruments Quality and Reliability


## description

The THCT2000 direction discriminator can determine the direction and displacement of a mechanical device based on input signals from two transducers in quadrature. It can also measure a pulse duration using a known clock rate, or a frequency over a known time interval. It includes a 16-bit counter, which can be used separately. Several of these devices may be cascaded to provide accuracy greater than 16-bits.

The device may be used in many diverse applications, and is specifically designed for use in many types of microprocessor-based systems. Some of the possibilities include motor controls, robotics, tracker balls (mice), lathe or tooling machines, automobiles, and conveyer belts or other transport mechanisms.

The THCT2000M is characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$. The THCT2000E is characterized for operation from $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$.


THCT2000M . . . FK PACKAGE THCT2000E . . . FN PACKAGE (TOP VIEW)


## THCT2000M, THCT2000E

## DIRECTION DISCRIMINATORS

logic symbol ${ }^{\dagger}$


This symbol is in accordance with ANSI/IEEE Std 91-1984.
functional block diagram


## THCT2000M, THCT2000E DIRECTION DISCRIMINATORS

| PIN |  | DESCRIPTION |
| :---: | :---: | :---: |
| NAME | NUMBER |  |
| A, B | 20, 21 | Signal measurement inputs. |
| BI | 26 | Cascade input for counting down. In mode $0, \overline{\mathrm{Bl}}$ is used as the clock input for counting down. Triggering occurs on the high-to-low transition. |
| $\overline{\text { BO }}$ | 12 | Counter output underflow signal. Active (low) for a duration equal to the low level of the input clock. |
| $\overline{\mathrm{Cl}}$ | 27 | Cascade input for counting up. In mode $0, \overline{\mathrm{Cl}}$ is used as the clock input for counting up. Triggering occurs on the high-to-low transition. |
| CLK | 22 | Clock input. Used for internal synchronization and control timing. |
| $\overline{\mathrm{CO}}$ | 13 | Counter output overflow signal. Active (low) for a duration equal to the low level of the input clock. |
| $\overline{\mathrm{CS}}$ | 1 | Chip select input. This active-low input is used to enable read and write functions. For additional details, see read and write timing diagrams. |
| D0-D7 | $\begin{gathered} 3,4,5,6 \\ 8,9,10,11 \end{gathered}$ | Counter load inputs/register output data lines. |
| GND | 7, 14 | Pins 7 and 14 are both internally connected to the ground rail of the integrated circuit but both should be connected to the system ground for proper operation. |
| LSB/MSB | 23 | Byte select input. During read operations, a high level selects the least significant byte, while a low level selects the most significant byte. For write operations, this input directs the data on the bus into the least significant or most significant byte position of the counter. See write timing diagrams for additional details. |
| M0, M1, M2 | 19, 18, 17 | Mode select inputs. |
| $\overline{\mathrm{RD}}$ | 2 | Read input. When active (low) in conjunction with $\overline{\mathrm{CS}}$ low, the data stored in the output register will be present on the data bus as selected by the LSB/ $\overline{\mathrm{MSB}}$ input. See read timing diagrams for additional details. |
| $\overline{\text { READY }}$ | 16 | Ready output. When active (low), this output indicates to the processor that it may complete the read or write operation. $\overline{\text { READY }}$ is synchronous with the negative-going edge of CLK. This output requires a pullup resistor ( $1 \mathrm{k} \Omega$ nominal). |
| RESET | 24 | Counter and control logic reset. When active (low), the counter is asynchronously reset to zero while the control logic is asynchronously initialized to the proper state as determined by the mode control inputs. The output register is not affected by RESET. |
| $\overline{\text { RLI/ }} \overline{\text { RLO }}$ | 15 | Register load input/register load output (open drain). This pin can be used as an input to directly load the output register, or it can be used as an output to detect whenever the output register has been loaded. When used as an output, a pullup resistor ( $1 \mathrm{k} \Omega$ nominal) is required. See read timing diagrams for additional details. |
| $\mathrm{V}_{\text {CC }}$ | 28 | Power supply voltage. |
| $\overline{\text { WE }}$ | 25 | Write enable input. When active (low) in conjunction with $\overline{\mathrm{CS}}$ low, the data present on DO-D7 will be asynchronously loaded into the counter as selected by LSB/ $\overline{M S B}$. See write timing diagrams for additional details. |

## THCT4502 <br> DYNAMIC RAM CONTROLLER

D2905, OCTOBER 1985

- Inputs are TTL- and CMOS-Voltage Compatible
- Controls Operation of 64 K and 256 K Dynamic RAMs
- Creates Static RAM Appearance
- One Package Contains Address Multiplexer, Refresh Control, and Timing Control
- Directly Addresses and Drives Up to 2 Megabytes of Memory Without External Drivers
- Operates from Microprocessor Clock - No Crystals, Delay Lines, or RC Networks
- Eliminates Arbitration Delays
- Refresh May Be Internally or Externally Initiated
- Versatile
- Strap-Selected Refresh Rate
- Synchronous, Predictable Refresh
- Selection of Distributed, Transparent, and Cycle-Steal Refresh Modes
- Interfaces Easily to Popular Microprocessors
- Asynchronous RESET Function Provided in FK and FN Packages
- High-Performance Si-Gate CMOS Technology
- Strap-Selected Wait State Generation for Microprocessor/Memory Speed Matching
- Ability to Synchronize or Interleave Controller with the Microprocessor System (Including Multiple Controllers)
- 3-State Outputs Allow Multiport Memory Configuration
- Performance Range:

125 ns ALE low to CAS low

- Compatible with TMS4500A/B and with VTI VL4500A and VL4502
- Available in Plastic and Ceramic Chip Carriers in Addition to Plastic and Ceramic DIPs
- Dependable Texas Instruments Quality and Reliability
THCT4502 . . . JD OR N PACKAGE
(TOP VIEW)

THCT4502 . . FK OR FN PACKAGE (TOP VIEW)



NC - No internal connection

## THCT4502

DYNAMIC RAM CONTROLLER

## description

The THCT4502 is a monolithic DRAM system controller providing address multiplexing, timing, control and refresh/access arbitration functions to simplify the interface of dynamic RAMs to microprocessor systems.

The controller contains an 18-bit multiplexer that generates the address lines for the memory device from the 18 system address bits and provides the strobe signals required by the memory to decode the address. A 9 -bit refresh counter generates up to 512 row addresses required to refresh.

A refresh timer is provided to generate the necessary timing to refresh the dynamic memories and ensure data retention.

The THCT4502 also contains refresh/access arbitration circuitry to resolve conflicts between access requests and memory-refresh cycles.
The THCT4502 is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## functional block diagram



Pin numbers shown are for JD and N packages.

## THCT4502 DYNAMIC RAM CONTROLLER

## pin descriptions

| RAO-RA8 | Input | Row Address - These address inputs are used to generate the row address <br> for the multiplexer. |
| :--- | :--- | :--- |
| CAO-CA8 | Input | Column Address - These address inputs are used to generate the column <br> address for the multiplexer. |
| MAO-MA8 | Output |  |
| Memory Address - These three-state outputs are designed to drive the |  |  |
| addresses of the dynamic RAM array. |  |  |

RAS0, $\overline{\text { RAS } 1 ~ O u t p u t ~}$
RAS2, $\overline{R A S} 3$
$\overline{\mathrm{CAS}} 0, \overline{\mathrm{CAS}} 1 \quad$ Output

RDY Output

## pin descriptions (continued)

TWST Input Timing/Wait Strap - A high on this input indicates a wait state should be added to each memory cycle. In addition it is used in conjunction with FSO and FS1 to determine refresh rate and timing or initialize the controller.
FSO, FS1 Inputs Frequency Select 0; Frequency Select 1 - These are strap inputs to select Mode and Frequency of operation as shown in Table 1.
$\overline{\text { RESET }} \dagger$ $\dagger$ Input $\overline{\text { RESET }}$ - Active-low input to initialize the controller asynchronously. Refresh Address is set to IFF16, internal refresh requests, synchronizer, and frequency divider are cleared. (Note: $\overline{R E S E T}$ contains an internal pullup resistor with a nominal resistance of $100 \mathrm{k} \Omega$, which allows this pin to be left open.)
${ }^{\dagger}$ This function is available only in the FK and FN packages.
TABLE 1. STRAP CONFIGURATION

| STRAP INPUT MODES |  |  | WAIT <br> STATES FOR <br> MEMORY <br> ACCESS | REFRESH RATE | MINIMUM CLOCK FREQUENCY (MHz) | REFRESH FREQUENCY (kHz) | CLOCK <br> CYCLES <br> FOR EACH <br> REFRESH |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | $L^{\dagger}$ | 0 | EXTERNAL | - | REFREQ | 4 |
| L | L | H | 0 | EXTERNAL | - | REFREQ | 3 |
| L | H | L | 0 | CLK $\div 61$ | 3.904 | 64-95 ${ }^{\ddagger}$ | 3 |
| L | H | H | 0 | CLK $\div 91$ | 5.824 | 64-88 § | 4 |
| H | L | L | 1 | CLK $\div 61$ | 3.904 | 64-95 ${ }^{\text {+ }}$ | 3 |
| H | L | H | 1 | CLK $\div 91$ | 5.824 | 64-75 | 4 |
| H | H | L | 1 | CLK $\div 106$ | 6.784 | 64-73 ${ }^{\ddagger}$ | 4 |
| H | H | H | 1 | CLK $\div 121$ | 7.744 | 64-831 | 4 |

$\dagger$ This strap configuration resets the Refresh Timer Circuitry.
$\ddagger$ Upper figure in refresh frequency is the frequency that is produced if the minimum clock frequency of the next select state is used.
$\S$ Refresh frequency if clock frequency is 8 MHz .
IRefresh frequency if clock frequency is 10 MHz .
TABLE 2. OUTPUT STROBE SELECTION

| CONTROL INPUT |  | SELECTED OUTPUT |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| REN1 | REN0 | $\overline{\text { RAS0 }}$ | $\overline{\text { RAS1 }}$ | $\overline{\text { RAS2 }}$ | $\overline{\text { RAS3 }}$ | CAS0 |  |
| L | L | X |  |  |  | CAS1 |  |
| L | H |  | X |  |  |  |  |
| H | L |  |  |  |  |  |  |
| H | H |  |  |  |  |  |  |

NOTE: Changing the logic value of REN1 after a low-to-high transition of ALE and before $\overline{A C X}$ rises causes the other $\overline{C A S}$ to fall. Both $\overline{\mathrm{CAS}}$ signals remain low until $\overline{\mathrm{ACX}}$ rises.

## functional description

The THCT4502 consists of six basic blocks: address and select latches, refresh rate generator, refresh counter, the multiplexer, the arbiter, and the timing and control block.

## THCT4502 <br> DYNAMIC RAM CONTROLLER

## address and select latches

The address and select latches allow the DRAM controller to be used in systems that multiplex address and data on the same lines without external latches. The row address latches are transparent, meaning that while ALE is high, the output at MAO-MA8 follows the inputs RAO-RA8.

## refresh rate generator

The refresh rate generator is a counter that indicates to the arbiter that it is time for a refresh cycle. The counter divides the clock frequency according to the configuration straps as shown in Table 1. The counter is reset when a refresh cycle is requested or when TWST, FS1, and FSO are low. The configuration straps allow the matching of memories to the system access time. Upon power-up it is necessary to provide a reset signal by driving all three straps to the controller (or RESET for devices in the FK and FN packages only) low. A systems power-on reset ( $\overline{\mathrm{RESET}}$ ) can be used to do this by connecting it to those straps that are desired high during operation. During this reset period, at least four clock cycles should occur.

## refresh counter

The refresh counter contains the address of the row to be refreshed. The counter is decremented after each refresh cycle. A low-to-high transition on TWST sets the refresh counter to $1 \mathrm{FF}_{16}$ ( $\mathbf{5 1 1}_{10}$ ).

## multiplexer

The multiplexer provides the DRAM array with row, column, and refresh addresses at the proper times. Its inputs are the address latches and the refresh counter. The outputs provide up to 18 multiplexed addresses on nine lines.

## arbiter

The arbiter provides two operational cycles: access and refresh. The arbiter resolves conflicts between cycle requests and cycles in execution, and schedules the inhibited cycle when used in cycle-steal mode.

## timing and control block

The timing and control block executes the operational cycle at the request of the arbiter. It provides the DRAM array with $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ signals. It provides the CPU with a RDY signal. It controls the multiplexer during all cycles. It resets the refresh rate generator and decrements the refresh counter during refresh cycles.

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



[^78]
## THCT4502

DYNAMIC RAM CONTROLLER
recommended operating conditions

|  | MIN | NOM | MAX |
| :--- | ---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ Supply voltage | UNIT |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ High-level input voltage | 4.5 | 5 | 5.5 |
| $\mathrm{~V}_{\mathrm{IL}}$ Low-level input voltage | 2 | V |  |
| $\mathrm{~V}_{\mathrm{O}}$ Output voltage | $-0.5^{\dagger}$ | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |
| $\mathrm{t}_{\mathrm{t}}$ Input transition (rise and fall) time | -0.5 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |
| $\mathrm{~T}_{\mathrm{A}}$ Operating free-air temperature | 0 | V |  |

${ }^{\dagger}$ The algebraic convention, where the more negative (less positive) limit is designated as minimum, is used in this data sheet for logic voltage levels only.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | Vcc | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  | MIN MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN |  | TYP MAX |  |  |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | MAO-MA8, |  | ${ }^{\mathrm{I}} \mathrm{OH}=-20 \mu \mathrm{~A}$ | 4.5 V | 4.4 |  | 4.4 | V |
|  |  | $\frac{\text { RAS }- \text { KASS }}{\text { CAS }}-\overline{\text { CAS }}$ | $\mathrm{IOH}^{\prime}=-6 \mathrm{~mA}$ | 4.5 V | 3.86 |  | 3.76 |  |  |
|  |  | RDY | $\mathrm{I}^{\mathrm{OH}}=-20 \mu \mathrm{~A}$ | 4.5 V | 4.4 |  | 4.4 |  |  |
|  |  |  | $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ | 4.5 V | 3.86 |  | 3.76 |  |  |
|  |  | $\overline{\text { REFREQ }}$ | $\mathrm{I}_{\mathrm{OH}}=-20 \mu \mathrm{~A}$ | 4.5 V | 4 |  | 3.8 |  |  |
| VOL | Low-level output voltage | RDY, $\overline{\text { REFREO }}$ | $\mathrm{I}^{\mathrm{OL}}=20 \mu \mathrm{~A}$ | 4.5 V |  | 0.1 | 0.1 | V |  |
|  |  |  | $\mathrm{TOL}=4 \mathrm{~mA}$ | 4.5 V |  | 0.32 | 0.37 |  |  |
|  |  | $\begin{aligned} & \text { MAO-MA8, } \\ & \overline{\text { RAS } 0-\overline{R A S} 3,} \\ & \overline{\text { CAS } 0, ~} \overline{\mathrm{CAS}} 1 \end{aligned}$ | $\mathrm{I}^{\text {OL }}=20 \mu \mathrm{~A}$ | 4.5 V |  | 0.1 | 0.1 |  |  |
|  |  |  | $\mathrm{I}^{\mathrm{OL}}=6 \mathrm{~mA}$ | 4.5 V |  | 0.32 | 0.37 |  |  |
| IIH | High-level input current except $\overline{\text { REFREQ }}$ |  | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ | 5.5 V |  | 0.1 | 1 | $\mu \mathrm{A}$ |  |
| ILL | Low-level input current | $\overline{\text { REFREQ }}$ | $v_{1}=0$ | 5.5 V |  | -5 | -50 | $\mu \mathrm{A}$ |  |
|  |  | $\overline{\text { RESET }}$ |  |  |  | -100 | -250 |  |  |
|  |  | All others |  |  |  | -0.1 | -1 |  |  |
| $\mathrm{l}^{\prime} \mathrm{z}^{\ddagger}$ | Off-state output current (3-state outputs only) |  | $\mathrm{V}_{\mathrm{O}}=0$ to 5.5 V | 5.5 V |  | $\pm 5$ | $\pm 50$ | $\mu \mathrm{A}$ |  |
| ICC | Supply current |  | $\begin{aligned} & V_{1}=V_{C C} \text { or } 0, \\ & 10=0 \end{aligned}$ | 5.5 V |  | 5 | 15 | mA |  |
| $\Delta \mathrm{CCC}^{\text {§ }}$ | Supply current change |  | One input at 0.5 V or 2.4 V , Other inputs at 0 V or $\mathrm{V}_{\mathrm{CC}}$ | 5.5 V |  | 1.42 .4 | 3 | mA |  |
| $C_{i}$ | Input capacitance |  | $\begin{aligned} & v_{1}=0, \\ & f=1 \mathrm{MHz} \end{aligned}$ | 5.5 V |  | $5 \quad 10$ | 10 | pF |  |

[^79]
## timing requirements over recommended ranges of supply voltage and operating free-air temperature (unless otherwise noted)

| PARAMETER |  | THCT4502-125 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |
| $\mathrm{t}_{\mathrm{c}}(\mathrm{C})$ | CLK cycle time | 100 |  | ns |
| $\mathrm{t}_{\mathrm{w}}(\mathrm{CH})$ | CLK high pulse duration | 45 |  | ns |
| $\mathrm{t}_{\mathrm{w}}(\mathrm{CL})$ | CLK low pulse duration | 45 |  | ns |
| ${ }^{\text {t }}$ AEL-CL | Time delay, ALE low to CLK starting low (see Note 1) | 25 |  | ns |
| ${ }^{\text {t }}$ CL-AEL | Time delay, CLK low to ALE starting low (see Note 1) | 15 |  | ns |
| ${ }^{\text {t }}$ CL-AEH | Time delay, CLK low to ALE | 15 |  | ns |
| ${ }^{\text {W }}$ (AEH) | Pulse width ALE high | 45 |  | ns |
| ${ }^{\text {t } A V-A E L ~}$ | Time delay, address REN1, $\overline{C S}$ valid to ALE low | 10 |  | ns |
| tAEL-AX | Time delay, ALE low to address not valid | 15 |  | ns |
| ${ }^{\text {t }}$ AEL-ACL | Time delay, ALE low to $\overline{\mathrm{ACX}}$ low (see Notes 3, 4, 5, and 6) | $\operatorname{th}(\mathrm{RA})+30$ |  | ns |
| ${ }^{\text {t }} \mathrm{ACH}-\mathrm{CL}$ | Time delay, $\overline{\mathrm{ACX}}$ high to CLK low (see Notes 3 and 7) | 30 |  | ns |
| ${ }^{\text {t }} \mathrm{ACL}-\mathrm{CH}$ | Time delay, $\overline{\mathrm{ACX}}$ low to CLK starting high (to remove RDY) | 30 |  | ns |
| ${ }^{\text {t } R Q L-C L}$ | Time delay, $\overline{\text { REFREO }}$ low to CLK starting low (see Note 8) | 35 |  | ns |
| $\mathrm{t}_{\mathrm{W}}$ (RQL) | Pulse width $\overline{\text { REFREQ }}$ low | 30 |  | ns |
| $\mathrm{t}_{\mathrm{W}}(\mathrm{ACL})$ | $\overline{\text { ACX }}$ low width (see Note 9) | 120 |  | ns |
| $\mathrm{t}_{\text {reset }}$ | Power-up reset | $4 \mathrm{t}_{\text {cCLK }}$ |  | ns |

NOTES: 1. Coincidence of the trailing edge of CLK and the trailing edge of ALE should be avoided as the refresh/access occurs on the trailing CLK edge.
2. If ALE rises before $\overline{A C X}$ and a refresh request is present, the falling edge of CLK after ${ }^{\mathrm{C}} \mathrm{CL}-\mathrm{AEH}$ will output the refresh address to MAO-MA7 and initiate a refresh cycle.
3. These specifications relate to system timing and do not directly reflect device performance.
4. On the access grant cycle following refresh, the occurrence of $\overline{C A S}$ low depends on the relative occurrence of ALE low to $\overline{A C X}$ low. If $\overline{A C X}$ occurs prior to or coincident with ALE, then $\overline{C A S}$ is timed from the CLK high transition that causes $\overline{\mathrm{RAS}}$ low. If $\overline{\mathrm{ACX}}$ occurs 20 ns or more after ALE, then $\overline{\mathrm{CAS}}$ is timed from the CLK low transition following the CLK high transition causing $\overline{R A S}$ low.
5. For maximum speed access (internal delays on both access and access grant cycles), $\overline{\mathrm{ACX}}$ should occur prior to or coincident with ALE.
6. $t_{h}(R A)$ is the dynamic memory row address hold time. $\overline{A C X}$ should follow ALE by $t_{A E L}$ CEL in systems where the required th(RA) is greater than tREL-MAX minimum.
7. The minimum of 20 ns is specified to ensure arbitration will occur on falling CLK edge, $\mathrm{t} \mathrm{ACH}-\mathrm{CL}$ also affects precharge time such that the minimum $t_{A C H-C L}$ should be equal or greater than: $t_{w}(R H)-t_{w}(C L)+30 \mathrm{~ns}$ (for a cycle where $\overline{A C X}$ high occurs prior to ALE high) where $t_{w}(\mathrm{RH})$ is the DRAM RAS precharge time.
8. This parameter is necessary only if refresh arbitration is to occur on this low-going CLK edge (in systems where refresh is synchronized to external events).
9. The specification $t_{w}(A C L)$ is designed to allow a $\overline{C A S}$ pulse. This assures normal operation of the device in testing and system operation.

## THCT4502

## DYNAMIC RAM CONTROLLER

## switching characteristics over recommended supply voltage range and operating free-air temperature range (see Figure 1)

| PARAMETER |  | TEST CONDITIONS | THCT4502-125 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |
| ${ }^{\text {t }}$ EEL-REL | Time delay, ALE low to $\overline{\mathrm{RAS}}$ starting low |  | $\mathrm{C}_{\mathrm{L}}=180 \mathrm{pF}$ |  | 45 | ns |
| trav-MAV | Time delay, row address valid to memory address valid | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ |  | 50 | ns |
| taEH-MAV | Time delay, ALE high to valid memory address | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ |  | 90 | ns |
| ${ }^{\text {t }}$ AEL-RYL | Time delay, ALE to RDY starting low ITWST $=1$ or refresh in progress) | $C_{L}=40 \mathrm{pF}$ |  | 40 | ns |
| ${ }^{\text {t }}$ AEL-CEL | Time delay, ALE low to $\overline{\text { CAS }}$ starting low (see Note 10) | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ | 50 | 125 | ns |
| ${ }^{\text {t AEH-REH }}$ | Time delay, ALE high to $\overline{\text { RAS }}$ starting high | $\mathrm{C}_{\mathrm{L}}=180 \mathrm{pF}$ |  | 50 | ns |
| ${ }^{\text {t }}$ ACL-MAX | Row address valid after $\overline{\text { ACX }}$ | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ | 15 |  | ns |
| ${ }^{\text {t MAV-CEL }}$ | Time delay, memory address valid to $\overline{\text { CAS }}$ starting low | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ | 0 |  | ns |
| ${ }^{\text {t }}$ ACL-CEL | Time delay, $\overline{\overline{A C X}}$ low to $\overline{\text { CAS }}$ starting low (see Note 10) | $\mathrm{C}_{\mathrm{L}}=.360 \mathrm{pF}$ | 40 | 100 | ns |
| ${ }^{\text {t }}$ ACH-REH | Time delay, $\overline{\mathrm{ACX}}$ to $\overline{\mathrm{RAS}}$ starting high | $\mathrm{C}_{\mathrm{L}}=180 \mathrm{pF}$ |  | 55 | ns |
| ${ }^{1}$ ACH-CEH | Time delay, $\overline{\mathrm{ACX}}$ high to $\overline{\mathrm{CAS}}$ starting high | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ | 5 | 45 | ns |
| ${ }^{\text {taCH-MAX }}$ | Column address valid after $\overline{\mathrm{ACX}}$ high | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ | 10 |  | ns |
| ${ }^{\text {t }} \mathrm{CH}-\mathrm{RYH}$ | Time delay, CLK high to RDY starting high (after $\overline{\mathrm{ACX}}$ low) (see Note 11) | $C_{L}=40 \mathrm{pF}$ |  | 60 | ns |
| ${ }^{\text {traL-RFL }}$ | Time delay, $\overline{\text { REFREQ }}$ external till supported by $\overline{\text { REFREQ }}$ internal | $C_{L}=40 \mathrm{pF}$ |  | 35 | ns |
| ${ }^{\text {t }}$ CH-RFL | Time delay, CLK high till $\overline{\text { REFREO }}$ internal starting low | $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$ |  | 50 | ns |
| ${ }^{\text {t CL-MAV }}$ | Time delay, CLK low till refrefresh address valid | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ |  | 100 | ns |
| ${ }^{\text {t }}$ CH-RRL | Time delay, CLK high till refresh $\overline{\mathrm{RAS}}$ starting low | $\mathrm{C}_{\mathrm{L}}=180 \mathrm{pF}$ | 10 | 60 | ns |
| ${ }^{\text {t M AV-RRL }}$ | Time delay, refresh address valid till refresh $\overline{\mathrm{RAS}}$ low | $\mathrm{C}_{\mathrm{L}}=180 \mathrm{pF}$ | 5 |  | ns |
| ${ }^{\text {t }}$ CL-RFH | Time delay, CLK low to REFREO starting high ( 3 cycle refresh) | $C_{L}=40 \mathrm{pF}$ |  | 70 | ns |
| ${ }^{\text {t }}$ CH-RFH | Time delay, CLK high to $\overline{\text { REFREO }}$ starting high (4 cycle refresh) | $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$ |  | 70 | ns |
| ${ }^{\text {t }}$ CH-RRH | Time delay, CLK high to refresh $\overline{\mathrm{RAS}}$ starting high | $\mathrm{C}_{\mathrm{L}}=160 \mathrm{pF}$ | 5 | 60 | ns |
| ${ }^{\text {t }}$ CH-MAX | Refresh address valid after CLK high | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ | 10 |  | ns |

NOTES: 10. The falling edge of $\overline{\mathrm{CAS}}$ occurs when both ALE low to $\overline{\mathrm{CAS}}$ low time delay (t $A E L-C E L$ ) and $\overline{\mathrm{ACX}}$ low to $\overline{\mathrm{CAS}}$ low time delay ( ${ }^{A C L}$-CEL) have elapsed, i.e., if $\overline{\mathrm{ACX}}$ goes low prior to ( $\mathrm{t}_{\mathrm{AEL}}$-CEL - $\mathrm{t}_{\mathrm{ACL}}$-CEL) after the falling edge of ALE, the falling edge of CAS is measured from the falling edge of ALE ( $\mathrm{t}_{\mathrm{AEL}}$-CEL). Otherwise, the access time increases and the falling edge of $\overline{\mathrm{CAS}}$ is measured from the falling edge of $\overline{\mathrm{ACX}}$ ( $\mathrm{t} A C L-C E L$ ).
11. RDY returns high on the rising edge of CLK. If TWST $=0$, then on an access grant cycle RDY goes high on the same edge that causes access $\overline{\mathrm{RAS}}$ low. If TWST $=1$, then RDY goes to the high level on the first rising CLK edge after $\overline{\mathrm{ACX}}$ goes low on access cycles and on the next rising edge after the edge that causes access $\overline{\text { RAS }}$ low on access grant cycles (assuming $\overline{\text { ACX }}$ low).
switching characteristics over recommended supply voltage range and operating free-air temperature range (see Figure 1) (continued)

| PARAMETER |  | TEST CONDITIONS | THCT4502-125 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX |  |
| ${ }^{\text {t }}$ CH-REL | Time delay, CLK high till access $\overline{\text { RAS }}$ starting low |  | $\mathrm{C}_{\mathrm{L}}=180 \mathrm{pF}$ |  | 60 | ns |
| ${ }^{\text {t CL-CEL }}$ | Time delay, CLK low to access $\overline{\text { CAS }}$ starting low (see Note 12) | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ |  | 100 | ns |
| ${ }^{\text {t CL-MAX }}$ | Row address valid after CLK low | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ | 25 |  | ns |
| trel-max | Row address valid after $\overline{\mathrm{RAS}}$ low | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ | 25 |  | ns |
| ${ }^{\text {t }}$ AEH-MAX | Column address valid after ALE high | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ | 10 |  | ns |
| $\mathrm{t}_{\text {dis }}$ | Output disable time (3-state outputs) | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ |  | 125 | ns |
| $\mathrm{t}_{\text {en }}$ | Output enable time (3-state outputs) | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ |  | 75 | ns |
| ${ }^{\text {t CAV-CEL }}$ | Time delay, column address valid to $\overline{\mathrm{CAS}}$ starting low after refresh (see Note 12) | $C_{L}=360 \mathrm{pF}$ | 0 |  | ns |
| ${ }^{\text {t }}$ CH-CEL | Time delay, CLK high to access $\overline{\text { CAS }}$ starting low (see Note 13) | $C_{L}=360 \mathrm{pF}$ |  | 180 | ns |
| $t_{t}$ (CEL) | $\overline{\text { CAS }}$ fall time | $C_{L}=360 \mathrm{pF}$ |  | 20 | ns |
| $\mathrm{t}_{\mathrm{t} \text { (CEH) }}$ | $\overline{\mathrm{CAS}}$ rise time | $\mathrm{C}_{\mathrm{L}}=360 \mathrm{pF}$ |  | 50 | ns |
| $\mathrm{t}_{\text {t }}$ (REL) | $\overline{\text { RAS }}$ fall time | $\mathrm{C}_{\mathrm{L}}=180 \mathrm{pF}$ |  | 30 | ns |
| $\mathrm{t}_{\mathrm{t} \text { (REH) }}$ | $\overline{\mathrm{RAS}}$ rise time | $\mathrm{C}_{\mathrm{L}}=180 \mathrm{pF}$ |  | 40 | ns |
| $\mathrm{t}_{\mathrm{t}}(\mathrm{MAV})$ | Address transition time | $\mathrm{C}_{\mathrm{L}}=180 \mathrm{pF}$ |  | 40 | ns |
| $\mathrm{t}_{\mathrm{t}}(\mathrm{RY} \mathrm{L}$ ) | RDY fall time | $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$ |  | 20 | ns |
| $\mathrm{t}_{\mathrm{t} \text { (RYH) }}$ | RDY rise time | $C_{L}=40 \mathrm{pF}$ |  | 50 | ns |

NOTES:12. The occurrence of CAS low is guaranteed not to occur until the column address is valid on MAX.
13. On the access grant cycle following refresh, the occurrence of CAS low depends on the relative occurrence of ALE low to $\overline{\mathrm{ACX}}$ low. If $\overline{\mathrm{ACX}}$ occurs prior to or coincident with ALE then $\overline{\mathrm{CAS}}$ is timed from the CLK high transition that causes $\overline{\mathrm{RAS}}$ low. If $\overline{A C X}$ occurs 20 ns or more after ALE then $\overline{\mathrm{CAS}}$ is timed from the CLK low transition following the CLK high transition causing $\overline{\mathrm{RAS}}$ low. (See Refresh Cycle Timing Diagram)

## PARAMETER MEASUREMENT INFORMATION


figure 1. load circuit

THCT4502
DYNAMIC RAM CONTROLLER


NOTE 14: All transition times ( $\mathrm{t}_{\mathrm{t}}$ ) are measured between $10 \%$ and $90 \%$ points.
FIGURE 2. ACCESS CYCLE TIMING


FIGURE 3. REFRESH REQUEST TIMING
NOTE 15: All input pulses are supplied by generators having the following characteristics: $P R R \leq 1 \mathrm{MHz}, Z_{o u t}=50 \Omega, t_{r}=6 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}}=6 \mathrm{~ns}$.


VOLTAGE WAVEFORMS
NOTE 16: Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the access controls. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the access controls.

FIGURE 4. ENABLE AND DISABLE TIMES FOR 3-STATE OUTPUTS

$\dagger$ On access grant cycle following refresh, $\overline{\mathrm{CAS}}$ low and address multiplexing are timed from CLK high transition ( $\mathrm{t}_{\mathrm{C}} \mathrm{CH}-\mathrm{CEL}$ ) if $\overline{\mathrm{ACX}}$ low occurs prior to or coincident with the falling edge of ALE.
$\ddagger$ On access grant cycle following refresh, $\overline{\mathrm{CAS}}$ low and address multiplexing are timed from CLK low transition ( t CL-CEL) if $\overline{\mathrm{ACX}}$ low occurs 20 ns or more after the falling edge of ALE.
NOTE 15: All input pulses are supplied by generators having the following characteristics: $\mathrm{PRR} \leq 1 \mathrm{MHz}, \mathrm{Z}_{\mathrm{out}}=50 \Omega, \mathrm{t}_{\mathrm{r}}=6 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}}=6 \mathrm{~ns}$.
figure 5. refresh cycle timing (three cycle)

## THCT4502

DYNAMIC RAM CONTROLLER

${ }^{\dagger}$ On access grant cycle following refresh, $\overline{\mathrm{CAS}}$ low and address multiplexing are timed from CLK high transition ( $\mathrm{t} \mathrm{CH}-\mathrm{CEL}$ ) if $\overline{\mathrm{ACX}}$ low occurs prior to or coincident with the falling edge of ALE.
$\ddagger$ On access grant cycle following refresh, $\overline{\mathrm{CAS}}$ low and address multiplexing are timed from CLK low transition (tCL-CEL) if $\overline{\mathrm{ACX}}$ low occurs 20 ns or more after the falling edge of ALE.
NOTE 15: All input pulses are supplied by generators having the following characteristics: $\operatorname{PRR} \leq 1 \mathrm{MHz}, Z_{\text {out }}=50 \Omega, \mathrm{t}_{\mathrm{r}}=6 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}}=6 \mathrm{~ns}$.
FIGURE 6. REFRESH CYCLE TIMING (FOUR CYCLE)


FIGURE 7. TYPICAL ACCESS/REFRESH/ACCESS CYCLE (THREE-CYCLE, TWST IS LOW)


FIGURE 8. TYPICAL ACCESS/REFRESH/ACCESS CYCLE (FOUR-CYCLE, TWST IS LOW)



FIGURE 10. TYPICAL ACCESS/REFRESH/ACCESS CYCLE (FOUR-CYCLE, TWST IS HIGH)

${ }^{\dagger}$ Load is 360 pF for $\overline{\mathrm{CAS}}$ and MA outputs, 180 pF for all $\overline{\mathrm{RAS}}$ outputs.
figure 11.

## ORDERING INSTRUCTIONS



N, JD (Dual in-line packages)
FK, FN (Chip carrier packages)

## THCT29520, THCT29521 MULTILEVEL PIPELINE REGISTERS

- Four 8-Bit Registers
- Dual 2-Level or Single 4-Level Pipeline Registers
- Any One of Four Registers Selectable for Output
- High-Speed Low-Power CMOS Logic
- Fully TTL Compatible
- Dependable Texas Instruments Quality and Reliability


## description

The THCT29520 and THCT29521 are highspeed CMOS multilevel pipeline registers. They are interchangeable with the Advanced Micro Device bipolar AM29520 and AM29521 but dissipate a fraction of the power.
The THCT29520 and THCT29521 contain four 8-bit positive-edge-triggered registers. The registers can operate as one set of 4 -level pipeline registers or two sets of 2 -level pipeline registers. The output can be selected from any one of the four registers.

The THCT29520 and THCT29521 differ in the way data is transferred in the dual 2-level register modes ( $\quad=01$ or 10 ). For the THCT29520, new data is written into the first-level register while the old data in the first-level register is shifted into the second-level register. For the THCT29521, new data is written over the old data in the first-level register. The data in the second-level register remains unchanged.
The THCT29520 and THCT29521 are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$. The THCT29520E and THCT29521E are characterized for operation from $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$.

THCT29520 MODES


| I1 | 10 | OPERATION | A1 | A2 | B1 | B2 |
| :---: | :---: | :--- | :---: | :---: | :---: | :---: |
| L | L | SHIFT A B | D | $\mathrm{A} 1_{0}$ | $\mathrm{~A} 2_{0}$ | $\mathrm{~B} 1_{0}$ |
| L | H | SHIFT B | $\mathrm{A} 1_{0}$ | $\mathrm{~A} 2_{0}$ | D | $\mathrm{B} 1_{0}$ |
| H | L | SHIFT A | D | $\mathrm{A} 1_{0}$ | $\mathrm{~B} 1_{0}$ | $\mathrm{~B} 2_{0}$ |
| H | H | HOLD | $\mathrm{A} 1_{0}$ | $\mathrm{~A} 2_{0}$ | $\mathrm{~B} 1_{0}$ | $\mathrm{~B} 2_{0}$ |

## THCT29520, THCT29521

MULTILEVEL PIPELINE REGISTERS


OUTPUT FUNCTION TABLE

| INPUTS |  |  | OUTPUT |
| :---: | :---: | :---: | :---: |
| $\overline{\mathbf{O E}}$ | S1 | SO | $\mathbf{Y}$ |
| $L$ | $L$ | $L$ | B2 |
| L | L | $H$ | B1 |
| $L$ | $H$ | $L$ | A2 |
| $L$ | $H$ | $H$ | A1 |
| $H$ | $X$ | $X$ | $Z$ |

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

THCT29520

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

## THCT29520, THCT29521 MULTILEVEL PIPELINE REGISTERS

logic diagram (positive logic)


* The label " $0 C 4 / 2 C 4$ " means that the clock in register A2 affects the eight data inputs of that register, collectively labeled " 4 D ", only in modes 0 and $2(11, I O=L L$ and $H L$, respectively). This logic diagram applies specifically for the THCT29520. For the THCT29521, the labels marked with the asterisks in registers A2 and B2 would both be reduced to "OC4" indicating that these clocks have effect only in mode 0 in that device. Otherwise this diagram applies to both devices.
absolute maximum rating over operating free-air temperature range (see Note 1)


NOTE 1: Stress 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 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.

## THCT29520, THCT29521

MULTILEVEL PIPELINE REGISTERS
recommended operating conditions

electrical characteristics over recommended operating temperature range, $\mathrm{V}_{\mathbf{I}}=\mathrm{V}_{\mathbf{I H}}$ or $\mathrm{V}_{\mathrm{IL}}$ (unless otherwise noted)

| PARAMETER | TEST CONDITIONS | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  |  | THCT29520E <br> THCT29521E |  | $\begin{aligned} & \text { THCT29520 } \\ & \text { THCT29521 } \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{V}_{\mathrm{OH}}$ | ${ }^{1} \mathrm{OH}=-20 \mu \mathrm{~A}$ | 4.5 V | 4.4 | 4.499 |  | 4.4 |  | 4.4 |  | V |
|  | $\mathrm{IOH}^{\prime}=-8 \mathrm{~mA}$ | 4.5 V | 3.9 | 4.3 |  | 3.8 |  | 3.8 |  |  |
| VOL | $\mathrm{I}_{\mathrm{OL}}=20 \mu \mathrm{~A}$ | 4.5 V |  | 0.001 | 0.1 |  | 0.1 |  | 0.1 | $\checkmark$ |
|  | $\mathrm{I}^{\mathrm{OL}}=8 \mathrm{~mA}$ | 4.5 V |  | 0.17 | 0.26 |  | 0.33 |  | 0.33 |  |
| 1 | $\mathrm{V}_{\mathrm{i}}=0$ to $\mathrm{V}_{\mathrm{CC}}$ | 5.5 V |  | $\pm 0.1$ | +100 |  | $\pm 1000$ |  | $\pm 1000$ | nA |
| Ioz | $\mathrm{V}_{1}=0$ or $\mathrm{V}_{\mathrm{CC}}$ | 5.5 V |  | $\pm 0.01$ | $\pm 0.5$ |  | $\pm 5$ |  | $\pm 5$ | $\mu \mathrm{A}$ |
| ICC | $\begin{aligned} & \mathrm{V}_{1}<0.5 \mathrm{~V} \text { or }>2.4 \mathrm{~V}, \\ & 10=0 \end{aligned}$ | 4.5 V |  |  | 8 |  | 80 |  | 80 | $\mu \mathrm{A}$ |
| $\mathrm{C}_{\mathrm{i}}$ |  | $\begin{gathered} 4.5 \mathrm{~V} \\ \text { to } \\ 5.5 \mathrm{~V} \end{gathered}$ |  | 3 | 10 |  | 10 |  | 10 | pF |

timing requirements over recommended operating free-air temperature range

| PARAMETER |  | Vcc | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  |  | THCT29520E THCT29521E |  | THCT29520 <br> THCT29521 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| $t_{w}$ | Pulse duration, CLK high or low |  | 4.5 V |  | 6 |  | 12 |  | 12 |  | ns |
|  |  | 5.5 V |  | 5 |  | 10 |  | 10 |  |  |  |
| ${ }^{\text {s }}$ u | Setup time before CLK $\uparrow$ | 4.5 V |  | 10 |  | 15 |  | 15 |  | ns |  |
|  |  | 5.5 V |  | 8 |  | 13 |  | 13 |  |  |  |
| th | Hold time after CLK $\uparrow$ | 4.5 V |  | 0 |  | 0 |  | 0 |  | ns |  |
|  |  | 5.5 V |  | 0 |  | 0 |  | 0 |  |  |  |

THCT29520, THCT29521 MULTILEVEL PIPELINE REGISTERS
switching characteristics over recommended free-air temperature range, $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ (unless otherwise noted) See Note 2

| PARAMETER | FROM | T0 | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  |  | THCT29520E THCT29521E |  | $\begin{aligned} & \text { ТНСТ29520 } \\ & \text { ТНСТ29521 } \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP | MAX | MIN | MAX | MIN | MAX |  |
| ${ }^{t} \mathrm{pd}$ | CLK $\uparrow$ | Y | 4.5 V |  | 18 |  |  | 27 |  | 26 | ns |
|  |  |  | 5.5 V |  | 16 |  |  | 25 |  | 24 |  |
| ${ }^{\text {tpd }}$ | So, S1 | Y | 4.5 V |  | 17 |  |  | 27 |  | 26 | ns |
|  |  |  | 5.5 V |  | 15 |  |  | 25 |  | 24 |  |
| ${ }^{\text {ten }}$ | $\overline{\mathrm{OE}} \downarrow$ | Y | 4.5 V |  | 10 |  |  | 16 |  | 15 | ns |
|  |  |  | 5.5 V |  | 7 |  |  | 15 |  | 14 |  |
| ${ }^{\text {dis }}$ | $\overline{\mathrm{OE}} \uparrow$ | Y | 4.5 V |  | 14 |  |  | 20 |  | 20 | ns |
|  |  |  | 5.5 V |  | 13 |  |  | 20 |  | 20 |  |
| $t_{t}$ |  | Y | 4.5 V |  | 7 |  |  | 12 |  | 12 | ns |
|  |  |  | 5.5 V |  | 7 |  |  | 12 |  | 12 |  |


| $\mathrm{C}_{\mathrm{pd}} \quad$ Power dissipation capacitance ${ }^{\dagger}$ | No load, $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | 110 pF typ |
| :---: | :---: | :---: |

$\dagger_{\text {No load dynamic power dissipation, }} \mathrm{P}_{\mathrm{d}}=\mathrm{C}_{\mathrm{pd}} V_{C C}{ }^{2} f+I_{C C} V_{C C}$
NOTE 2: For load circuit and voltage waveforms, see page 1-14 of the High-Speed CMOS Logic Data Book, 1984.


- Fast Address to Match Valid Delay - Three

Speed Ranges: 35 ns, 45 ns, 55 ns

- $512 \times 9$ Internal RAM
- 300-Mil 24-Pin Ceramic Side-Brazed or Plastic Dual-In-Line or Small Outline Packages
- Max Power Dissipation: 660 mW
- On-Chip Parity Generation and Checking
- Parity Error Output/Force Parity Error Input
- On-Chip Address/Data Comparator
- Asynchronous, Single-Cycle Reset
- Easily Expandable
- Fully Static
- Reliable SMOS (Scaled NMOS) Technology
- TTL- and CMOS-Compatible Inputs and Outputs

DW, JD, OR NT PACKAGE
(TOP V!EW)

| RESET |  |
| ---: | :--- |
| A5 4 | 24 |
| A4 4 |  |
| A3 3 |  |

## description

This 8-bit-slice cache address comparator consists of a high-speed $512 \times 9$ static RAM array, parity generator, parity checker, and 9 -bit high-speed comparator. It is fabricated using N -channel silicon gate technology for high speed and simple interface with MOS and bipolar TTL circuits. The cache address comparator is easily cascadable for wider tag addresses or deeper tag memories. Significant reductions in cache memory component count, board area, and power dissipation can be achieved with this device.
When $\overline{\mathrm{S}}$ is low and $\bar{W}$ is high, the cache address comparator compares the contents of the memory location addressed by A0-A8 with the data on DO-D7 plus generated parity. An equality is indicated by a high level on the MATCH output. A low-level output from $\overline{P E}$ signifies a parity error in the internal RAM data. $\overline{\mathrm{PE}}$ is an $N$-channel open-drain output for easy OR-tying. During a write cycle ( $\bar{S}$ and $\bar{W}$ low), data on DO-D7 plus generated even parity are written in the 9 -bit memory location addressed by AO-A8. Also during write, a parity error may be forced by holding $\overline{\mathrm{PE}}$ low.
$A \overline{\operatorname{RESET}}$ input is provided for initialization. When $\overline{\operatorname{RESET}}$ goes low, all $512 \times 9$ RAM locations are cleared and the MATCH output is forced high.
The cache address comparator operates from a single +5 V supply and is offered in a 24-pin 300-mil ceramic side brazed or plastic dual-in-line packages. The device is fully TTL compatible and is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## MATCH OUTPUT DESCRIPTION

$$
\begin{aligned}
& \mathrm{MATCH}=\mathrm{V}_{\mathrm{OH}} \text { if: }[\text { AO-A8] }=\text { DO-D7 + parity, } \\
& \text { or: } \overline{\text { RESET }}=V_{\mathrm{IL}} \text {. } \\
& \text { or: } \overline{\mathrm{S}}=\mathrm{V}_{\mathrm{IH}} \text {, } \\
& \text { or: } \bar{W}=V_{I L} \\
& \text { MATCH }=V_{O L} \text { if: }[A O-A 8] \neq \text { DO-D7 + parity, } \\
& \text { with } \overline{\text { RESET }}=V_{I H} \text {. } \\
& \overline{\mathrm{s}}=\mathrm{V}_{\mathrm{IL}} \text {, and } \overline{\mathrm{W}}=\mathrm{V}_{\mathrm{IH}}
\end{aligned}
$$

FUNCTION TABLE

| OUTPUT |  | FUNCTION |
| :---: | :---: | :---: |
| DESCRIPTION |  |  |

Where $S=V_{I L}, W=V_{I H}$, RESET $=V_{I H}$

TMS2150

## CACHE ADDRESS COMPARATOR

functional block diagram (positive logic)


This diagram has been changed to correct errors in previous versions. No functional change has been made in the chip.

## TMS2150 CACHE ADDRESS COMPARATOR

PIN FUNCTIONAL DESCRIPTION

|  |  | DESCRIPTION |
| :---: | :---: | :---: |
| NAME | NO. |  |
| $\overline{\text { RESET }}$ | 1 | $\overline{\text { RESET }}$ input. Asynchronously clears entire RAM array and forces MATCH high when $\overline{\text { RESET }}$ is at $V_{I L}$ and $\bar{W}$ is at $V_{I H}$. |
| AO | 22 | Address inputs. Address 1 of 512 -by- 9 -bit random-access memory locations. Must be stable for the duration of the write cycle. |
| A1 | 23 |  |
| A2 | 5 |  |
| A3 | 4 |  |
| A4 | 3 |  |
| A5 | 2 |  |
| A6 | 19 |  |
| A7 | 20 |  |
| A8 | 21 |  |
| DO | 7 | Data inputs. Compared with memory location addressed by AO-A8 when $\bar{W}$ is at $V_{I H}$ and $\overline{\mathrm{S}}$ is at $V_{I L}$. Provide input data to RAM when $\bar{W}$ is at $V_{I L}$ and $\overline{\mathrm{S}}$ is at $\mathrm{V}_{\mathrm{IL}}$. |
| D1 | 8 |  |
| D2 | 9 |  |
| D3 | 6 |  |
| D4 | 17 |  |
| D5 | 18 |  |
| D6 | 15 |  |
| D7 | 16 |  |
| $\overline{\text { w }}$ | 10 | Write control input. Writes DO through D7 and generated parity into RAM and forces MATCH high when $\bar{W}$ is at $V_{\text {IL }}$ and $\bar{S}$ is at $V_{\text {IL }}$. Places selected device in compare mode if $\bar{W}$ is at $V_{I H}$. |
| $\overline{\text { PE }}$ | 11 | Parity error input/output. During write cycles, $\overline{\mathrm{PE}}$ can force a parity error into the 9-bit location specified by AO through A8 when $\overline{P E}$ is at $V_{I L}$. For compare cycles, $\overline{P E}$ at $V_{O L}$ indicates a parity error in the stored data. $\overline{\mathrm{PE}}$ is an open-drain output so an external pull-up resistor is required. |
| GND | 12 | Ground |
| $\overline{\mathrm{s}}$ | 13 | Chip select input. Enables device when $\overline{\mathrm{S}}$ is at $\mathrm{V}_{\mathrm{IL}}$. Deselects device and forces MATCH high when $\bar{S}$ is at $V_{I H}$. |
| MATCH | 14 | When MATCH output is at $\mathrm{V}_{\mathrm{OH}}$ during a compare cycle, DO through D7 plus parity equal the contents of the 9 -bit memory location addressed by AO through A8. |
| $\mathrm{V}_{\mathrm{CC}}$ | 24 | $5-\mathrm{V}$ supply voltage |

absolute maximum ratings over operating free-air temperature range (unless otherwise specified)


NOTE 1: All voltage values are with respect to GND.

## recommended operating conditions

| PARAMETER | MIN | NOM |
| :--- | ---: | ---: |
| Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5 |
| High-level input voltage, $\mathrm{V}_{\text {IH }}$ | 5.5 | V |
| Low-level input voltage, $\mathrm{V}_{\text {IL }}$ (See Note 2) | 2 | 6 |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ | -1 |  |

NOTE 2: The algebraic convention, where the more negative (less positive) limit is designated as minimum, is used in this data sheet for logic voltage levels only.

TMS2150
CACHE ADDRESS COMPARATOR
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS | TMS2150-3 |  | $\begin{aligned} & \text { TMS2150-4 } \\ & \text { TMS2150-5 } \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP MAX | MIN | TYP MAX |  |
| $\mathrm{V}_{\mathrm{OH}}(\mathrm{M})$ | MATCH high-level output voltage |  | $\mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 2.4 |  | 2.4 |  | V |
|  |  | $\mathrm{I}_{\mathrm{OH}}=-20 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 3.5 |  | 3.5 |  |  |  |
| $\mathrm{V}_{\mathrm{OL}}(\mathrm{M})$ | MATCH low-level output voltage | $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}, \quad \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |  | 0.4 |  | 0.4 | V |  |
| $\mathrm{V}_{\text {OL }}(\mathrm{PE})$ | $\overline{\mathrm{PE}}$ low-level output voltage | $\mathrm{I}_{\mathrm{OL}}=12 \mathrm{~mA}, \quad \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |  | 0.4 |  | 0.4 | V |  |
| 11 | Input current | $\mathrm{V}_{1}=0 \mathrm{~V}$ to 5.5 V |  | 10 |  | 10 | $\mu \mathrm{A}$ |  |
| IOL(PE) | $\overline{\mathrm{PE}}$ output sink current | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ | 12 |  | 12 |  | mA |  |
| IOS | Short-circuit MATCH output current | $\mathrm{V}_{\mathrm{O}}=\mathrm{GND}, \quad \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |  | $-150$ |  | -150 | mA |  |
| ${ }^{1} \mathrm{CC} 1$ | Supply current (operative) | $\overline{\text { RESET }}=\mathrm{V}_{1 H}$ |  | 145 |  | 135 | mA |  |
| ${ }^{1} \mathrm{CC} 2$ | Suply current (reset) | $\overline{\text { RESET }}=V_{\text {IL }}$ |  | 155 |  | 145 | mA |  |
| $\mathrm{C}_{\mathrm{i}}$ | Input capacitance | $\mathrm{V}_{\mathrm{I}}=0 \mathrm{~V}, \quad \mathrm{f}=1 \mathrm{MHz}$ |  | 5 |  | 5 | pF |  |
| $\mathrm{C}_{0}$ | Output capacitance | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}, \quad \mathrm{f}=1 \mathrm{MHz}$ |  | 6 |  | 6 | pF |  |

switching characteristics over recommended ranges of supply voltage and operating free-air temperature

| PARAMETER |  | TMS2150-3 |  | TMS2150-4 |  | TMS2150-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{A})$ | Access time from address to MATCH |  | 35 |  | 45 |  | 55 | ns |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{A}-\mathrm{P})$ | Access time from address to $\overline{\mathrm{PE}}$ |  | 45 |  | 55 |  | 65 | ns |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{S})$ | Access time from $\overline{\mathrm{S}}$ to MATCH |  | 20 |  | 25 |  | 35 | ns |
| ${ }^{t} p(D)$ | Propagation time, data inputs to MATCH |  | 20 |  | 35 |  | 45 | ns |
| $t_{p(R-M H)}$ | Propagation time, $\overline{\text { RESET }}$ low to MATCH high |  | 30 |  | 30 |  | 40 | ns |
| $t_{p}(S-M H)$ | Propagation time, $\overline{\mathrm{S}}$ high to MATCH high |  | 20 |  | 25 |  | 35 | ns |
| ${ }^{\text {p }}$ (W-MH) | Propagation time, $\bar{W}$ low to MATCH high |  | 20 |  | 25 |  | 35 | ns |
| $t_{p}(W-P H)$ | Propagation time, $\bar{W}$ low to $\overline{\mathrm{PE}}$ high |  | 20 |  | 25 |  | 35 | ns |
| $\mathrm{t}_{\mathrm{V} \text { (A) }}$ | MATCH valid time after change of address | 5 |  | 5 |  | 5 |  | ns |
| $t_{v}(\mathrm{~A}-\mathrm{P})$ | $\overline{\mathrm{PE}}$ valid time after change of address | 15 |  | 15 |  | 15 |  | ns |

timing requirements over recommended ranges of supply voltage and operating free-air temperature

| PARAMETER |  | TMS2150-3 |  | TMS2150-4 |  | TMS2150-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{t}_{\mathrm{c}}(\mathrm{W})$ | Write cycle time, without writing $\overline{\mathrm{PE}}$ | 30 |  | 40 |  | 50 |  | ns |
| $\mathrm{t}_{\mathrm{c} \text { PE( }}$ W) | Write cycle time, writing $\overline{\mathrm{PE}}$ (see Note 3) | 35 |  | 40 |  | 50 |  | ns |
| $\mathrm{t}_{\mathrm{c}}$ (rd) | Read cycle time | 35 |  | 45 |  | 55 |  | ns |
| $\mathrm{t}_{\mathrm{w}}(\mathrm{RL}$ ) | Pulse duration, $\overline{\text { RESET }}$ low | 35 |  | 35 |  | 45 |  | ns |
| $\mathrm{t}_{\mathrm{w}}(\mathrm{WL})$ | Pulse duration, $\bar{W}$ low, without writing $\overline{\mathrm{PE}}$ | 20 |  | 25 |  | 30 |  | ns |
| ${ }_{\text {w }}$ PEE(WL) | Pulse duration, $\bar{W}$ low, writing $\overline{\mathrm{PE}}$ (see Note 3) | 35 |  | 40 |  | 45 |  | ns |
| $\mathrm{t}_{\text {sul }}(\mathrm{A})$ | Address setup time before $\overline{\mathrm{W}}$ low | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {su }}(\mathrm{D})$ | Data setup time before $\bar{W}$ high | 20 |  | 25 |  | 30 |  | ns |
| $\mathrm{t}_{\text {su }}(\mathrm{P})$ | $\overline{\mathrm{PE}}$ setup time before $\overline{\mathrm{W}}$ high (see Note 3) | 20 |  | 25 |  | 30 |  | ns |
| $\mathrm{t}_{\text {su }}(\mathrm{S})$ | Chip select setup time before $\overline{\mathrm{W}}$ high | 20 |  | 25 |  | 30 |  | ns |
| $\mathrm{t}_{\text {su }}(\mathrm{RH})$ | $\overline{\mathrm{RESET}}$ inactive setup time before first tag cycle | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{th}_{\text {( }}(\mathrm{A})$ | Address hold time after $\overline{\mathrm{W}}$ high | 0 |  | 0 |  | 5 |  | ns |
| $t_{h(D)}$ | Data hold time after $\overline{\mathrm{W}}$ high | 5 |  | 5 |  | 10 |  | ns |
| th(P) | $\overline{\mathrm{PE}}$ hold time after $\overline{\mathrm{W}}$ high | 0 |  | 0 |  | 5 |  | ns |
| th(S) | Chip select hold time after $\overline{\mathrm{W}}$ high | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {t }} \mathrm{AVWW}$ | Address valid to write enable high | 30 |  | 40 |  | 50 |  | ns |

NOTE 3: Parameters $t_{w P E(W L)}$ and $t_{s u}(P)$ apply only during the write cycle time when writing a parity error, $t_{c} P E(W)$.

## ac test conditions

| Input pulse levels | GND to 3 V |
| :---: | :---: |
| Input rise and fall times | 5 ns |
| Input timing reference levels. | 1.5 V |
| Output timing reference level | 1.5 V |
| Output loading | ures 1 and 2 |

## CACHE ADDRESS COMPARATOR

## PARAMETER MEASUREMENT INFORMATION



FIGURE 1. PE OUTPUT LOAD CIRCUIT


FIGURE 2. MATCH OUTPUT LOAD CIRCUIT
compare cycle timing (see Note 4)


NOTE 4: Input pulse levels are 0 V and 3 V , with rise and fall times of 5 ns . The timing reference levels on the input pulses are 0.8 V and 2.0 V . The timing reference level for output pulses is 1.5 V . See Figures 1 and 2 for output loading.

## PARAMETER MEASUREMENT INFORMATION

write cycle timing (see Note 4)

reset cycle timing (see Note 4)


NOTES: 3. Parameters $t_{w P E}(W L)$ and $t_{S u}(P)$ apply only during the write cycle time when writing a parity error, $t_{c} P E(W)$.
4. Input pulse levels are 0 V and 3 V , with rise and fall times of 5 ns . The timing reference levels on the input pulses are 0.8 V and 2.0 V . The timing reference level for output pulses is 1.5 V . See Figures 1 and 2 for output loading.

- Controls Operation of $8 \mathrm{~K}, 16 \mathrm{~K}, 32 \mathrm{~K}$, and 64K Dynamic RAMs
- Creates Static RAM Appearance
- One Package Contains Address Multiplexer, Refresh Control, and Timing Control
- Directly Addresses and Drives Up to 256K Bytes of Memory Without External Drivers
- Operates from Microprocessor Clock
- No Crystals, Delay Lines, or RC Networks
- Eliminates Arbitration Delays
- Refresh May Be Internally or Externally Initiated
- Versatile
- Strap-Selected Refresh Rate
- Synchronous, Predictable Refresh
- Selection of Distributed, Transparent, and Cycle-Steal Refresh Modes
- Interfaces Easily to Popular Microprocessors
- Strap-Selected Wait-State Generation for Microprocessor/Memory Speed Matching
- Ability to Synchronize or Interleave Controller with the Microprocessor System (including Multiple Controllers)
- 3-State Outputs Allow Multiport Memory Configuration
- Performance Ranges of 150 ns, 200 ns, or 250 ns


## description

The TMS4500A is a monolithic DRAM system controller designed to provide address multiplexing, timing, control and refresh/access arbitration functions to simplify the interface of dynamic RAMs to microprocessor systems.

TMS4500A . . . NL PACKAGE
(TOP VIEW)


TMS 4500 A . . . FN PACKAGE (TOP VIEW)


The controller contains a 16-bit multiplexer that generates the address lines for the memory device from the 16 system address bits and provides the strobe signals required by the memory to decode the address. An 8-bit refresh counter generates the 256-row addresses required for refresh.

A refresh timer is provided that generates the necessary timing to refresh the dynamic memories and assure data retention.

The TMS4500A also contains refresh/access arbitration circuitry to resolve conflicts between memory access requests and memory refresh cycles. The TMS4500A is offered in a 40-pin, 600-mil dual-in-line plastic package and 44-pin, 650-mil square plastic chip carrier package. It is characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

## BLOCK DIAGRAM


pin descriptions

| RAO-RA7 | Input | Row Address - These address inputs are used to generate the row <br> address for the multiplexer. |
| :--- | :--- | :--- |
| Column Address - These address inputs are used to generate the column |  |  |
| address for the multiplexer. |  |  |

## TMS4500A <br> DYNAMIC-RAM CONTROLLER

## pin descriptions (continued)

| REN1 | Input |
| :--- | :--- |
| $\overline{\text { ACR, ACW }}$ | Input |
| CLK |  |
| $\overline{\text { REFREQ }}$ | Input |


| $\overline{\text { RASO }}, \overline{\text { RAS } 1}$ | Output |
| :--- | :--- |
| $\overline{\text { CAS }}$ | Output |
| RDY | Output |
|  |  |
| TWST | Input |
| FSO, FS1 | Input |

RAS Enable 1 - This input is used to select one of two banks of RAM via the $\overline{\text { RAS }} 0$ and $\overline{\text { RAS }} 1$ outputs when chip select is present. When it is low, $\overline{\operatorname{RAS} 0}$ is selected; when it is high, $\overline{\operatorname{RAS}} 1$ is selected.

Access Control, Read; Access Control, Write - A low on either of these inputs causes the column address to appear on MAO-MA7 and the column address strobe. The rising edge of $\overline{\mathrm{ACR}}$ or $\overline{\mathrm{ACW}}$ terminates the cycle by ending $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ strobes. When $\overline{\mathrm{ACR}}$ and $\overline{\mathrm{ACW}}$ are both low, MAO-MA7, $\overline{\operatorname{RAS}} 0, \overline{R A S} 1$, and $\overline{\mathrm{CAS}}$ go into a high-impedance (floating) state.

System Clock - This input provides the master timing to generate refresh cycle timings and refresh rate. Refresh rate is determined by the TWST, FS1, FS0 inputs.
Refresh Request - (This input should be driven by an open-collector output.) On input, a low-going edge initiates a refresh cycle and will cause the internal refresh timer to be reset on the next falling edge of the CLK. As an output, a low-going edge signals an internal refresh request and that the refresh timer will be reset on the next low-going edge of CLK. $\overline{\text { REFREQ }}$ will remain low until the refresh cycle in progress and the current refresh address is present on MAO-MA7. (Note: $\overline{\text { REFREQ }}$ contains an internal pull-up resistor with a nominal resistance of 10 kilohms.)
Row Address Strobe - These three-state outputs are used to latch the row address into the bank of DRAMs selected by REN1. On refresh both signals are driven.
Column Address Strobe - This three-state output is used to latch the column address into the DRAM array.
Ready - This totem-pole output synchronizes memories that are too slow to guarantee microprocessor access time requirements. This output is also used to inhibit access cycles during refresh when in cycle-steal mode.

Timing/Wait Strap - A high on this input indicates a wait state should be added to each memory cycle. In addition it is used in conjunction with FSO and FS1 to determine refresh rate and timing.
Frequency Select 0; Frequency Select 1 - These are strap inputs to select Mode and Frequency of operation as shown in Table 1.

TABLE 1. STRAP CONFIGURATION

| STRAP INPUT MODES |  |  | WAIT <br> STATES <br> FOR <br> MEMORY <br> ACCESS | REFRESH RATE | MINIMUM CLK FREQ. ( MHz ) | $\begin{aligned} & \text { REFRESH } \\ & \text { FREQ. (kHz) } \end{aligned}$ | CLOCK <br> FOR EACH <br> FOR EACH <br> REFRESH |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | $L^{\dagger}$ | 0 | EXTERNAL | - | REFREQ | 4 |
| L | L | H | 0 | CLK $\div 31$ | 1,984 | 64-95 ${ }^{\ddagger}$ | 3 |
| L | H | L | 0 | CLK $\div 46$ | 2,944 | 64-85 ${ }^{\ddagger}$ | 3 |
| L | H | H | 0 | CLK $\div 61$ | 3,904 | 64-82§ | 4 |
| H | L | L | 1 | CLK $\div 46$ | 2,944 | $64-85^{\ddagger}$ | 3 |
| H | L | H | 1 | CLK $\div 61$ | 3,904 | 64-80 ${ }^{\text {+ }}$ | 4 |
| H | H | L | 1 | CLK +76 | 4,864 | 64-77 $\ddagger$ | 4 |
| H | H | H | 1 | CLK -91 | 5,824 | 64-88 | 4 |

$\dagger$ This strap configuration resets the Refresh Timer circuitry.
$\ddagger$ The highest frequency in the refresh frequency column is the frequency that is produced if the minimum CLK frequency of the next select state is used.
§ The highest frequency in the refresh column is the refresh frequency if the CLK frequency is 5 MHz .
IThe highest frequency in the refresh column is the refresh frequency if the CLK frequency is 8 MHz .
functional description
TMS4500A consists of six basic blocks; address and select latches, refresh rate generator, refresh counter, the multiplexer, the arbiter, and timing and control block.

## address and select latches

The address and select latches allow the DRAM controller to be used in systems that multiplex address and data on the same lines without external latches. The row address latches are transparent, meaning that while ALE is high, the output at MAO-MA7 follows the inputs RAO-RA7.

## refresh rate generator

The refresh rate generator is a counter that indicates to the arbiter that it is time for a refresh cycle. The counter divides the clock frequency according to the configuration straps as shown in Table 1. The counter is reset when a refresh cycle is requested or when TWST, FS1 and FSO are low. The configuration straps allow the matching of memories to the system access time.

Upon Power-Up it is necessary to provide a reset signal by driving all three straps to the controller low to initialize internal counters. A system's low-active, power-on reset ( $\overline{R E S E T}$ ) can be used to accomplish this by connecting it to those straps that are desired high during operation. During this reset period, at least four clock cycles should occur.

## refresh counter

The refresh counter contains the address of the row to be refreshed. The counter is decremented after each refresh cycle. [A low-to-high transition on TWST sets the refresh counter to FF16 (25510).]

## multiplexer

The multiplexer provides the DRAM array with row, column, and refresh addresses at the proper times. Its inputs are the address latches and the refresh counter. The outputs provide up to 16 multiplexed addresses on eight lines.

## TMS4500A DYNAMIC-RAM CONTROLLER

## arbiter

The arbiter provides two operational cycles: access and refresh. The arbiter resolves conflicts between cycle requests and cycles in execution, and schedules the inhibited cycle when used in cycle-steal mode.

## timing and control block

The timing and control block executes the operational cycle at the request of the arbiter. It provides the DRAM array with $\overline{\operatorname{RAS}}$ and $\overline{\mathrm{CAS}}$ signals. It provides the CPU with a RDY signal. It controls the multiplexer during all cycles. It resets the refresh rate generator and decrements the refresh counter during refresh cycles.

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

Supply voltage range, VCC (see Note 1) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . - 1.5 V to 7 V
Input voltage range (any input) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . - 1.5 V to 7 V

Continuous power dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.2 W
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}$
† 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 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: Voltage values are with respect to the ground terminal.
recommended operating conditions

| PARAMETER | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ | 4.5 | 5 | 5.5 | V |
| High-level input voltage, $\mathrm{V}_{\mathrm{IH}}$ | 2.4 |  | 6 | V |
| Low-level input voltage, $\mathrm{V}_{\mathrm{IL}}$ | $-1 \ddagger$ |  | 0.8 | V |
| High-level output current, $\mathrm{IOH}^{\text {OH}}$ |  |  | -1 | mA |
| Low-level output current, IOL |  |  | 4 | mA |
| Short-circuit output current, $\mathrm{IOS}^{\text {§ }}$ |  |  | -50 | mA |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

$\ddagger$ The algebraic convention, where the less positive (more negative) limit is designated as minimum, is used in this data sheet for logic voltage levels only.
$\S$ Not more than one output should be shorted at a time.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | MIN | TYP MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | MAO-MA7, RDY | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \quad{ }^{1} \mathrm{OH}=-1 \mathrm{~mA}$ | 2.4 |  | V |
|  |  | $\overline{\mathrm{RAS}} 0, \overline{\mathrm{RAS}} 1, \overline{\mathrm{CAS}}$ |  | 2.7 |  |  |
|  |  | REFREQ | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ | 2.4 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Low-level output voltage |  | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}$, $\mathrm{I}^{\mathrm{OL}}=4 \mathrm{~mA}$ |  | 0.4 | V |
| $\mathrm{I}_{\mathrm{IH}}$ | High-level input current except $\overline{\text { REFREQ }}$ |  | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  | 10 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | $\overline{\text { REFREQ }}$ | $V_{1}=0$ |  | $-1.25$ | mA |
|  |  | All others |  |  | -10 | $\mu \mathrm{A}$ |
| loz | Off-state output current |  | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0$ to 4.5 V |  | $\pm 50$ | $\mu \mathrm{A}$ |
| ${ }^{\text {I CC }}$ | Operating supply current |  | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |  | $100 \quad 140$ | mA |
| $\mathrm{C}_{i}$ | Input capacitance |  | $\mathrm{V}_{1}=0, \quad \mathrm{f}=1 \mathrm{MHz}$ |  | 5 | pF |
| $\mathrm{C}_{0}$ | Output capacitance |  | $\mathrm{V}_{\mathrm{O}}=0, \quad \mathrm{f}=1 \mathrm{MHz}$ |  | 6 | pF |

I All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
timing requirements over recommended supply voltage range and operating free-air temperature (unless otherwise noted)

| PARAMETER |  | TMS4500A-15 |  | TMS4500A-20 |  | TMS4500A-25 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| $\mathrm{t}_{\mathrm{c}}(\mathrm{C})$ | CLK cycle time | 100 |  | 120 |  | 140 |  | ns |
| ${ }^{\text {w }}$ ( CH$)$ | CLK high pulse duration | 40 |  | 40 |  | 40 |  |  |
| ${ }^{\text {w }}$ (CL) | CLK low pulse duration | 40. |  | 45 |  | 45 |  |  |
| $\mathrm{t}_{\mathrm{t}}$ | Transition time, all inputs |  | 50 |  | 50 |  | 50 |  |
| ${ }^{\text {t }}$ AEL-CL | Time delay, ALE low to CLK starting low (see Note 1) | 10 |  | 10 |  | 15 |  |  |
| ${ }^{\text {t }}$ CL-AEL | Time delay, CLK low to ALE starting low (see Note 1) | 10 |  | 10 |  | 15 |  |  |
| ${ }^{t} \mathrm{CL}$-AEH | Time delay, CLK low to ALE starting high (see Note 2) | 15 |  | 20 |  | 20 |  |  |
| $\mathrm{t}_{\mathrm{w}}$ (AEH) | Pulse duration, ALE high | 50 |  | 60 |  | 60 |  |  |
| ${ }^{t}$ AV-AEL | Time delay, address REN1, $\overline{\mathrm{CS}}$ valid to ALE low | 5 |  | 10 |  | 15 |  |  |
| ${ }^{\text {t AEL-AX }}$ | Time delay, ALE low to address not valid | 10 |  | 10 |  | 10 |  |  |
| ${ }^{\text {t }} \mathrm{AEL}$-ACL | Time delay, ALE low to $\overline{\mathrm{ACX}}$ low (see Notes 3, 4, 5, and 6) | $\left.\mathrm{th}_{\mathrm{L}} \mathrm{RA}\right)+30$ |  | $t_{h(R A)}+40$ |  | $\left.\mathrm{th}_{(\mathrm{RA}}\right)^{+50}$ |  |  |
| ${ }^{\text {t }} \mathrm{ACH}-\mathrm{CL}$ | Time delay, $\overline{A C X}$ high to CLK low (see Notes 3 and 7) | 20 |  | 20 |  | 20 |  |  |
| ${ }^{\text {t }} \mathrm{ACL}-\mathrm{CH}$ | Time delay, $\overline{\mathrm{ACX}}$ low to CLK starting high (to remove RDY) | 30 |  | 30 |  | 30 |  |  |
| ${ }_{\text {tral-CL }}$ | Time delay, $\overline{\text { REFREO}}$ low to CLK starting low (see Note 8) | 20 |  | 20 |  | 20 |  |  |
| $\mathrm{t}_{\text {w (RQL) }}$ | Pulse duration, $\overline{\text { REFREQ }}$ low | 20 |  | 20 |  | 20 |  |  |
| $\mathrm{t}_{\mathrm{w}}(\mathrm{ACL})$ | $\overline{\mathrm{ACX}}$ low duration (see Note 9) | 110 |  | 140 |  | 175 |  |  |

NOTES: 1. Coincidence of the trailing edge of CLK and the trailing edge of ALE should be avoided as the refresh/access occurs on the trailing CLK edge. A trailing edge of CLK should occur during the interval from $\overline{A C X}$ high to ALE low.
2. If ALE rises before $\overline{\mathrm{ACX}}$ and a refresh request is present, the falling edge of CLK after $\mathrm{TCL}-\mathrm{AEH}$ will output the refresh address to MAO-MA7 and initiate a refresh cycle.
3. These specifications relate to system timing and do not directly reflect device performance.
4. On the access grant cycle following refresh, the occurrence of $\overline{\mathrm{CAS}}$ low depends on the relative occurrence of ALE low to $\overline{A C X}$ low. If $\overline{A C X}$ occurs prior to or coincident with ALE then $\overline{\text { CAS }}$ is timed from the CLK high transition that causes $\overline{\text { RAS }}$ low. If $\overline{\mathrm{ACX}}$ occurs 20 ns or more after ALE then $\overline{\mathrm{CAS}}$ is timed from the CLK low transition following the CLK high transition causing $\overline{R A S}$ low.
5. For maximum speed access (internal delays on both access and access grant cycles), $\overline{\mathrm{ACX}}$ should occur prior to or coincident with ALE.
6. $t_{h(R A)}$ is the dynamic memory row address hold time. $\overline{A C X}$ should follow ALE by $t_{A E L}$-CEL in systems where the required $t_{h}(R A)$ is greater than treL-MAX minimum.
7. The minimum of 20 ns is specified to ensure arbitration will occur on falling CLK edge, t ACH - CL also affects precharge time such that the minimum $t_{A C H}-\mathrm{CL}$ should be equal or greater than: $\mathrm{t}_{\mathrm{w}}(\mathrm{RH})-\mathrm{t}_{\mathrm{w}}(\mathrm{CL})+30$ ns (for a cycle where $\overline{\mathrm{ACX}}$ high occurs prior to ALE high) where $\mathrm{t}_{\mathrm{w}}(\mathrm{RH})$ is the DRAM $\overline{\text { RAS }}$ precharge time.
8. This parameter is necessary only if refresh arbitration is to occur on this low-going CLK edge (in systems where refresh is synchronized to external events).
9. The specification $\mathrm{t}_{\mathrm{w}}(\mathrm{ACL})$ is designed to allow a $\overline{\mathrm{CAS}}$ pulse. This assures normal operation of the device in testing and system operation.

## TMS4500A DYNAMIC-RAM CONTROLLER

switching characteristics over recommended supply voltage range and operating free-air temperature range (see Figure 1)


NOTES: 10. The falling edge of $\overline{\mathrm{CAS}}$ occurs when both ALE low to $\overline{\mathrm{CAS}}$ low time delay (t AEL -CEL) and $\overline{\mathrm{ACX}}$ low to $\overline{\mathrm{CAS}}$ low time delay ( $t_{A C L}$ CEL) have elapsed, i.e., if $\overline{A C X}$ goes low prior to ( $t_{A E L}$-CEL - $t_{A C L-C E L}$ ) after the falling edge of ALE, the falling edge of $\overline{\mathrm{CAS}}$ is measured from the falling edge of ALE ( t AEL-CEL). Otherwise, the access time increases and the falling edge of $\overline{\mathrm{CAS}}$ is measured from the falling edge of $\overline{\mathrm{ACX}}$ ( $\mathrm{t} A C L-C E L$ ).
11. RDY returns high on the rising edge of CLK. If TWST $=0$, then on an access grant cycle RDY goes high on the same edge that causes access $\overline{\mathrm{RAS}}$ low. If TWST $=1$, then RDY goes to the high level on the first rising CLK edge after $\overline{\mathrm{ACX}}$ goes low on access cycles and on the next rising edge after the edge that causes access $\overline{\mathrm{RAS}}$ low on access grant cycles (assuming $\overline{\mathrm{ACX}}$ low)

## TMS4500A

DYNAMIC-RAM CONTROLLER
switching characteristics over recommended supply voltage range and operating free-air temperature range (see Figure 1) (continued)


NOTE 12: On the access grant cycle following refresh, the occurrence of $\overline{C A S}$ low depends on the relative occurrence of ALE low to $\overline{A C X}$ low. If $\overline{A C X}$ occurs prior to or coincident with ALE then $\overline{C A S}$ is timed from the CLK high transition that causes $\overline{\operatorname{RAS}}$ low. If $\overline{\mathrm{ACX}}$ occurs 20 ns or more after ALE then $\overline{\mathrm{CAS}}$ is timed from the CLK low transition following the CLK high transition causing $\overline{R A S}$ low. (See Refresh Cycle Timing Diagram)

## PARAMETER MEASUREMENT INFORMATION



FIGURE 1 - LOAD CIRCUIT
access cycle timing

refresh request timing


TMS4500A
DYNAMIC-RAM CONTROLLER
ready timing (ACX during CLK high) (see notes 13 thru 16)


RDY starting high is timed from $\overline{\mathrm{ACX}}$ low ( $\mathrm{t} A C L-\mathrm{RYH}$ ) for the condition $\overline{\mathrm{ACX}}$ going low while CLK high.
ready timing (ACX during CLK low) (see notes 13 thru 16)


RDY starting high is timed from CLK high ( $\mathrm{t}_{\mathrm{C}} \mathrm{H}-\mathrm{RYH}$ ) for the condition ACX going low while CLK low.
NOTES: 13. For RDY high transition (during normal access) to be timed from the rising edge of CLK, $\overline{\mathrm{ACX}}$ must occur t CL-ACL after the falling edge of CLK.
14. For $\overline{A C X}$ prior to the falling edge of CLK by $t_{A C L-C L}$, the RDY high transition will be $t_{A C L}$ RYH.
15. ${ }^{t} A C L-C L$ is a limiting parameter for control of RDY to be dependent upon $\overline{A C X}$ low.
16. During the interval for $\mathrm{t}_{\mathrm{ACL}}$-CL $<$ MINIMUM to $\mathrm{t}_{\mathrm{CL}}-\mathrm{ACL}>$ MINIMUM, the control of RDY may vary between the rising clock edge or falling edge of $\overline{\mathrm{ACX}}$.
output 3-state timing

refresh cycle timing (three-cycle)

${ }^{\dagger}$ On access grant cycle following refresh, $\overline{\text { CAS }}$ low and address multiplexing are timed from CLK high transition ( $\mathrm{t} \mathrm{CH}-\mathrm{CEL}$ ) if $\overline{\mathrm{ACX}}$ low occurs prior to or coincident with the falling edge of ALE.
$\ddagger$ On access grant cycle following refresh, $\overline{C A S}$ low and address multiplexing are timed from CLK low transition (t CL-CEL) if $\overline{\operatorname{ACX}}$ low occurs. 20 ns or more after the falling edge of ALE.

## TMS4500A

DYNAMIC-RAM CONTROLLER
typical access/refresh/access cycle (three-cycle, TWST is low)

typical access/refresh/access cycle
(four-cycle, TWST is low)


## DYNAMIC-RAM CONTROLLER

typical access/refresh/access cycle (three-cycle, TWST is high)

typical access/refresh/access cycle
(four-cycle, TWST is high)


## 2 <br> 

## General Information

Numerical Index
Glossary
Explanation of Function Tables
Parameter Measurement Information
Functional Index

## LSI Devices

## Application Reports

Advanced Schottky Family
Error Detection and Correction
Memory Mapping
Bit-Slice Processor 8-Bit Family
Excerpt - SN74AS888, SN74AS890
Bit-Slice Processor User's Guide

# Advanced Schottky Family 

## IMPORTANT NOTICE

Texas Instruments reserves the right to make changes at any time in order to improve design and to supply the best product possible.

Texas Instruments assumes no responsibility for infringement of patents or rights of others based on Texas Instruments applications assistance or product specifications, since TI does not possess full access to data concerning the use or applications of customer's products. TI also assumes no responsibility for customer product designs.

## Advanced Schottky Family (ALS/AS) Application

## Contents

Title Page
INTRODUCTION TO ADVANCED SCHOTTKY FAMILY ..... 3-9
Speed-Power Slots Filled By Advanced Schottky TTL ..... 3-9
Additional Advantages Offered by 'ALS and 'AS Devices ..... 3-9
Concepts of Defining 'ALS and 'AS ..... 3-10
Compatibility With Other TTL ..... 3-10
Fanout ..... 3-10
Using the Schottky Barrier-Diode ..... 3-10
Analysis of Schottky-Clamped Transistor ..... 3-10
Analysis of 'ALS and 'AS NAND Gates ..... 3-13
Circuit Parameters ..... 3-16
Transfer Characteristics ..... 3-16
Input Characteristics ..... 3-17
Low-Level Input Current ..... 3-17
Input Clamping Diode Test ..... 3-18
High-Level Input Current ..... 3-18
Input Breakdown Test ..... 3-18
Output Characteristics ..... 3-18
High-Level Output Characteristics ..... 3-18
Low-Level Output Characteristics ..... 3-19
Switching Speed ..... 3-19
DC Noise Margins ..... 3-20
Specified Logic Levels and Thresholds ..... 3-22
Noise Rejection ..... 3-22
GUIDELINES FOR SERIES 'ALS/'AS TTL SYSTEM DESIGN ..... 3-24
Power Supply Regulation ..... 3-25
Supply Voltage Ripple ..... 3-27
Noise Considerations ..... 3-28
Noise Types and Control Methods ..... 3-28
Shielding ..... 3-29
Grounding and Decoupling ..... 3-29
Cross Talk ..... 3-34
Back-Panel Interconnections ..... 3-34
Printed Circuit Card Conductors ..... 3-36
Transmission-Line Driving Reflections ..... 3-37
APPENDIXES
A Normalized Load Factors ..... 3-45
B Letter Symbols, Terms, and Definitions ..... 3-46

# List of Illustrations 

Figure Title Page
1 Speed-Power Relationships of Digital Integrated Circuits ..... 3-10
2 Series 54/74 TTL Family Compatible Levels Showing DC Noise Margins ..... 3-11
3 Fanout Capability ..... 3-11
4 Baker Clamp ..... 3-11
5 Schottky Clamped-Transistor ..... 3-11
6 Schottky Barrier-Diode ..... 3-12
7 Schottky Barrier-Diode Energy Diagrams ..... 3-12
8 Metal-N Diode Current-Voltage Characteristics ..... 3-12
9 Difference Between P-N and Schottky Barrier-Diodes ..... 3-13
10 Standard Process ('LS/'S) ..... 3-13
11 Advanced Process ('ALS/'AS) ..... 3-13
12 'ALS00A NAND Gate Schematic ..... 3-14
13 'ASO0 NAND Gate Schematic ..... 3-15
14 Input Voltage vs Output Voltage 'ALS/'AS ..... 3-16
15 Input Current vs Input Voltage for TTL Families ..... 3-17
16 Low-Level Input Current vs High-Level Input Voltage. ..... 3-18
17 DC Equivalent Input Circuit for Series 'ALS Gates ..... 3-18
18 Equivalent Output Circuit for 'ALS/'AS Gates ..... 3-19
19 High-Level Output Voltage vs High-Level Output Current ..... 3-19
20 Low-Level Output Circuit for 'ALS/'AS Gates ..... 3-20
21 Low-Level Output Voltage vs Low-Level Output Current ..... 3-20
22 High- to Low-Level Propagation Delay vs Load Capacitance ..... 3-21
23 Low- to High-Level Propagation Delay vs Load Capacitance ..... 3-21
24 Power Dissipation per Gate vs Frequency ..... 3-22
25 Stray Coupling Capacitance ..... 3-23
26 Evaluations of Gate Response to Fast Input Pulses ..... 3-23
27 Theoretical Required Pulse Width vs Pulse Amplitude for 'ALS and 'AS Inputs ..... 3-24
28 Parameter Measurement Information ..... 3-25
29 Effect of Source Impedance on Input Noise ..... 3-28
30 Spurious Output Produced by Supply Voltage Ripple ..... 3-28
31 Effect of Ground Noise on Noise Margin ..... 3-28
32 Typical Logic Circuit with Noisy Input ..... 3-28
33 Diagram Representing a Gate Driving a Transmission Line ..... 3-29
34 Noise Generation Caused by Poor Transmission-Line Return ..... 3-29
35 Ideal Transmission-Line Current Handling ..... 3-30
36 Circuit with Effective Capacitive Loading ..... 3-30
37 Supply Current Transient Comparisons ..... 3-31
38 Transmission-Line Power Buses ..... 3-33
39 Capacitive Storage Supply Voltage System. ..... 3-33
40 Commonly Used Power Distribution and Decoupling System ..... 3-33
41 Equivalent Circuit for Sending Line ..... 3-34
42 Equivalent Circuit for Cross Talk ..... 3-34
43 Capacitive Cross Talk Between Two Signal Lines ..... 3-35
44 Coupling Impedances Involved in Cross Talk ..... 3-35
45 Equivalent Cross-Talk Network ..... 3-35
46 Microstrip Line ..... 3-36
47 Strip Line ..... 3-36
48 Line Spacing Versus Cross-Talk Constant ..... 3-37
49 TTL Bergeron Diagram ..... 3-37
50 'ALS/'AS Driving Twisted Pair ..... 3-37

## List of Illustrations (Continued)

Figure Title ..... Page
51 'AS - ve Transition Bergeron Diagram ..... 3-38
52 'AS - ve Voltage/Time Plot ..... 3-38
53 'AS + ve Transition Bergeron Diagram ..... 3-39
54 'AS + ve Voltage/Time Plot ..... 3-39
55 'ALS - ve Transition Bergeron Diagram ..... 3-40
56 'ALS - ve Voltage/Time Plot ..... 3-40
57 'ALS + ve Transition Bergeron Diagram ..... 3-41
58 'ALS + ve Voltage/Time Plot ..... 3-41
59 Oscilloscope Photograph of 'AS00 - ve Transition Using 50-Ohm Line ..... 3-42
60 Oscilloscope Photograph of 'AS00 + ve Transition Using 50-Ohm Line ..... 3-42
61 Oscilloscope Photograph of 'AS00 - ve Transition Using 25-Ohm Line ..... 3-42
62 Oscilloscope Photograph of 'AS00 + ve Transition Using 25-Ohm Line ..... 3-42
63 Oscilloscope Photograph of 'ALS00A - ve Transition Using 50-Ohm Line ..... 3-42
64 Oscilloscope Photograph of 'ALS00A + ve Transition Using 50-Ohm Line ..... 3-42
65 Oscilloscope Photograph of 'ALS00A - ve Transition Using 25-Ohm Line ..... 3-43
66 Oscilloscope Photograph of 'ALS00A + ve Transition Using 25-Ohm Line ..... 3-43
List of Tables
Table Title ..... Page
1 Typical Performance Characteristics by TTL Series ..... 3-10
2 Worst-Case Output Parameters ..... 3-22
3 Guidelines for Systems Design for Advanced Schottky TTL ..... 3-26
4 Guidelines for Printed Circuit Board Layout Advanced Schottky TTL ..... 3-26
5 Guidelines for General Usage of Advanced Schottky TTL ..... 3-27
6 Guidelines for Gates and Flip-Flops Using Advanced Schottky TTL ..... 3-27
7 Typical Impedance of Microstrip Lines ..... 3-36
8 Typical Impedance of Strip Lines ..... 3-36
A-1 Normalized Input Currents ..... 3-45
A-2 Fanout Capability ..... 3-46

## INTRODUCTION

The purpose of this Application Report is to assist the designers of high-performance digital logic systems in the use of the new series of Advanced Schottky-clamped* TTL integrated circuits.

Detailed electrical characteristics of these devices are provided and, if available, tables have been included that compare specific parameters of the devices with those of other logic families. In addition, interfamily information is provided to allow system designers to mix logic families in the same circuit. This allows the designer to use the relative merits of each logic family in high preformance state-of-theart designs.

The major subject areas covered in this Application Report are as follows:

- Advanced Schottky process
- Fanouts
- Transfer characteristics
- Input and output parameters
- Speed and power information
- Noise margins
- Power supply considerations
- Noise sources and their abatement
- Back panel and printed circuit wiring guidelines
- Line driving and receiving


## INTRODUCTION TO ADVANCED SCHOTTKY-CLAMPED TTL

Series 54/74 transistor-transistor logic (TTL) has, since its introduction in 1965, become the most popular digital integrated circuit logic family ever offered. Its popularity has allowed the development of high-volume production techniques which have made it the most economical approach to the implementation of major portions of medium-to-high performance digital logic systems. These systems range from simple decision making to highly complex real-time computer installations that handle worldwide data processing.

The proliferation of and economical impact of these digital logic systems has created a demand for constant improvement in efficiency. In response to demand, Texas Instruments examined the advantages gained by Schottky clamping. An increase in speed and performance was discovered in the use of Schottky barrier-diode clamping. The process was patented in the United States and the Schottky series 54S/74S catalog parts were made available in the early 1970s. A series 54LS/74LS was introduced later. The series 54LS/74LS was slower that the 54S/74S series but had a much lower power consumption.

[^80]Recent innovations in integrated circuit design have made it possible to develop two new families: the Advanced Schottky (54AS/74AS) series and the Advanced Low-Power Schottky (54ALS/74ALS) series. The 'ALS and 'AS series provide considerable higher speeds than the 'LS and 'S series, respectively. The 'ALS series offers a substantial reduction in power consumption over the 'LS series, and the 'AS series offers a substantial reduction in power consumption over the 'S series. The 'ALS/'AS series is pin-to-pin compatible with the 'LS/'S series.

## SPEED-POWER SLOTS FILLED BY 'ALS AND 'AS TTL

Digital integrated circuits have historically been characterized for both speed and power. The series $54 \mathrm{~S} / 74 \mathrm{~S}$ devices contain 19 mW NAND gates and $125-\mathrm{MHz}$ flip-flops and the series $54 \mathrm{LS} / 74 \mathrm{LS}$ devices contain $2-\mathrm{mW}$ NAND gates and $45-\mathrm{MHz}$ flip-flops. Either of these logic families could be used to design a $2-\mathrm{MHz}$ system, therefore categorization strictly on the basis of power and speed is inconclusive with respect to system efficiency. To provide a means of measuring the overall circuit efficiency and performance, a speed-power product efficiency index for integrated circuits was developed. The rating of an integrated circuit is obtained by multiplying the gate propagation delay by the gate power dissipation.

Table 1 provides propagation delay times, power dissipation, and speed-power product for the Texas Instruments TTL series. In addition, it provides flip-flop frequency for each family as an indicator of system performance. The speed-power product rating system (measured in picojoules) is divided into circuits where speed is the prime factor and circuits where low-power is the prime factor. The 'ALS series speed-power product is approximately 4 times less than that of the 'LS series and the 'AS series speed-power product is approximately 4 times less than the 'S series. Figure 1 is a graphic analysis of the speed-power points for the various TTL families.

## ADDITIONAL ADVANTAGES OFFERED BY 'ALS AND 'AS DEVICES

The 'ALS and 'AS devices offer the following additional advantages:

1. TTL compatible with $54 / 74,54 \mathrm{~S} / 74 \mathrm{~S}, 54 \mathrm{~L} / 74 \mathrm{~L}$, $54 \mathrm{LS} / 74 \mathrm{LS}$, and $54 \mathrm{H} / 74 \mathrm{H}$ series gates for selectively upgrading existing systems
2. Suppresses the effects of line ringing and significantly reduces undershoot
3. Higher thresholds (noise immunity) and better stability across operating free-air temperature range
4. Input current requirement reduced by up to $50 \%$

Table 1. Typical Performance Characteristics by TTL Series

|  | MINIMIZING POWER |  |  |  |  | MINIMIZING DELAY TIME |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CIRCUIT TECHNOLOGY | FAMILY | PROP DELAY <br> (ns) | $\begin{aligned} & \text { PWR } \\ & \text { DISS } \\ & (\mathrm{mW}) \end{aligned}$ | SPD/PWR PRODUCT (pJ) | MAXIMUM FLIP-FLOP FREO ( MHz ) | FAMILY | $\begin{gathered} \text { PROP } \\ \text { DELAY } \\ \text { (ns) } \\ \hline \end{gathered}$ | $\begin{aligned} & \text { PWR } \\ & \text { DISS } \\ & (\mathrm{mW}) \end{aligned}$ | SPD/PWR PRODUCT (pJ) | MAXIMUM FLIP-FLOP FREQ (MHz) |
| Gold Doped | TTL | 10 | 10 | 100 | 35 | TTL | 10 | 10 | 100 | 35 |
| Dop | L TTL | 33 | 1 | 33 | 3 | H TTL | 6 | 22 | 132 | 50 |
|  | LS TTL | 9 | 2 | 18 | 45 | S TTL | 3 | 19 | 57 | 125 |
|  | 'ALS | 4 | 1.2 | 4.8 | 70 | 'AS | 1.7 | 8 | 13.6 | 200 |



Figure 1. Speed-Power Relationships of Digital Integrated Circuits
5. Fanout is doubled
6. Terminated lines or controlled impedance circuit boards are normally not required.
7. The 'AS series offers shorter propagation delays and higher clock frequencies with relatively low power consumption.
8. The maximum flip-flop frequency has been increased to 200 MHz .

## CONCEPTS OF DEFINING SERIES 'AS AND 'ALS

Both the 'ALS and 'AS series are electrically and pinout compatible with existing TTL series. The 'ALS series is suitable for replacing all TTL families except in the very highest frequency applications. Replacement with 'ALS will result in lower power consumption, smaller power supply current spikes, and, in some cases, better noise immunity than the other families. In those cases where a very high operating frequency is required, the 'AS series can be used. The 'AS devices require less than one-half of the supply current of the ' S series and has approximately twice the clocking frequency. The 'ALS devices are ideal for improving effeciency at the lower speeds. The 'AS devices
are ideal for replacement of high-speed logic families including ECL 10 K series.

## Compatibility With Other TTL Families

To ensure complete electrical compatibility in systems using or intending to use a mixture of existing TTL families and the new 'ALS/'AS families, specific guidelines have been implemented. These guidelines ensure the continuation of desirable characteristics and incorporate newer techniques to improve performance and/or simplify the use of TTL families. Figure 2 illustrates the comparison of essential parameters of each family and shows that complete compatibility is maintained throughout the 54/74 families.

## Fanout

The compatible ratings for fanout simplify the implementation of logic and provide a freedom of choice in the use of any of the seven performance ranges to design a digital logic system. Any of the Texas Instruments TTL series gates can be used to drive any other gate without the use of an interface or level-shifting circuit. The use of totem-pole-(push-pull) type output stages provides a low output impedance and the capability for both sourcing and sinking current. The output is easily adapted for driving MOS and CMOS circuits as well as the interface circuits between the output and the devices it controls. Figure 3 illustrates fanout capability.

## USING THE SCHOTTKY BARRIER DIODE

The Advanced Schottky Family has been developed from two earlier concepts: the Baker Clamp and the Schottky Barrier-Diode (SBD). The use of the Baker Clamp and SBD concepts resulted in the Schottky Clamped Transistor. The Schottky clamped transistor produced the increased switching speed associated with the S series integrated circuits. The additional advances that have led to the development of 'ALS and 'AS gates and the actual gates are discussed later.

## Analysis of the Schottky Clamped Transistor

The use of the Baker Clamp, shown in Figure 4, is a method of avoiding saturation of a discrete transistor. The diode forward voltage is 0.3 V to 0.4 V as compared to 0.7 V for the base-emitter junction diode. When the transistor is turned on, base current drives the transistor toward


Figure 2. Series 54/74 TTL Family Compatible Levels Showing DC Noise Margins


Figure 3. Fanout Capability


Figure 4. Baker Clamp
saturation. The collector voltage drops, the germanium diode begins to conduct forward current, and excess base drive is diverted from the base-collector junction of the transistor. This causes the transistor to be held out of deep saturation, the excess base charge to not be stored, and the turn-off time to be dramatically reduced.

A germanium diode cannot be incorporated into a monolithic silicon integrated circuit. Therefore, the germanium diode must be replaced with a silicon diode which


MONOLITHIC COMPOSITION
SYMBOL FOR MONOLITHIC SBD-CLAMPED TRANSISTOR

Figure 5. The Schottky-Clamped Transistor
has a lower forward voltage drop than the base-collector junction of the transistor. A normal p-n diode will not meet this requirement. The SBD illustrated in Figure 5 can be used to meet the requirement.

The SBD illustrated in Figure 6 is a rectifying metalsemiconductor contact formed between a metal and a highly doped N semiconductor.


Figure 6. Schottky Barrier-Diode
The qualitative physics of an SBD is illustrated in Figure 7. The valence and conduction bands in a metal overlap make available a large number of free-energy states. The free-energy states can be filled by any electrons which are injected into, the conduction band. A finite number of electrons exist in the conduction band of a semiconductor. The number of electrons depends mainly upon the thermal energy and the level of impurity atoms in the material. When a metal-semiconductor junction is formed, free electrons flow across the junction from the semiconductor, via the conduction band, and fill the free-energy states in the metal. This flow of electrons builds a depletion potential across the barrier. This depletion potential opposes the electron flow and, eventually, is sufficient to sustain a balance where there is no net electron flow across the barrier.

Under forward bias (metal positive), there are many electrons with enough thermal energy to cross the barrier potential into the metal. This forward bias is called "hot injection." Because the barrier width is decreased as forward bias $\mathrm{V}_{\mathrm{F}}$ increases, forward current will increase rapidly with an increase in $\mathrm{V}_{\mathrm{F}}$.

When the SBD is reverse biased, electrons in the semiconductor require greater energy to cross the barrier. However, electrons in the metal see a barrier potential from the side essentially independent of the bias voltage and a small net reverse current will flow. Since this current flow is relatively independent of the applied reverse bias, the reverse current flow will not increase significantly until avalanche breakdown occurs.

A simple metal-n semiconductor collector contact is an ohmic contact while the SBD contact is a rectifying contact. The difference is controlled by the level of doping in the semiconductor material. As the doping is increased, the contact becomes more ohmic. Figure 8 illustrates the currentvoltage characteristics according the doping applied.

Current in the SBD is carried by majority carriers. Current in the $\mathrm{p}-\mathrm{n}$ junction is carried by minority carriers. The resultant minority carrier storage causes the switching


Figure 8. Metal-N Diode Current-Voltage Characteristics


Figure 7. Schottky Barrier-Diode Energy Diagrams
time of a p-n junction to be limited when switched from forward bias to reverse bias. A p-n junction is inherently slower than an SBD even when doped with gold.

Another major difference between the SBD and p-n junction is the forward voltage drop. For diodes of the same surface area, the SBD will have a larger forward current at the same forward bias regardless of the type of metal used. The SBD forward voltage drop is lower at a given current than a p-n junction. Figure 9 illustrates the current carriers and forward current-voltage characteristics differences between the SBD and p-n junction. The SBD meets the requirements of a silicon diode which will clamp a silicon n-p-n transistor out of saturation.


Figure 9. Differences Between P-N and Schottky Barrier-Diodes

The Advanced Schottky process differs from the Schottky process in that it uses ion implantation of impurities instead of diffusion. Ion implantation gives greater control on the depth of doping and resolution. Because of a thinner epitaxial layer and smaller all around geometries, smaller parasitic capacitances are encountered. The performance of the SBD is also enhanced by the use of oxide isolation of the transistors. This reduces the collector-substrate capacitance. Figure 10 illustrates the 'LS/'S process which consists of conventional masks, junction isolation, and a


Figure 10. Standard Process ('LS/'S)


Figure 11. Advanced Process ('ALS/'AS)
standard metal system and Figure 11 illustrates the 'ALS/'AS process which consists of composed masks, ion implantation, oxide isolation, and a standard metal system.

## Analysis of 'ALS and 'AS NAND Gates

The 'ALS and 'AS NAND gates in Figures 12 and 13 combine the desirable features of improved TTL circuits with the technological advantages of full Schottky clamping, ion implantation, and oxide isolation to achieve very fast switching times at a reduced speed-power product. The improvements and advantages are as follows:

1. Full Schottky clamping of all saturating transistors virtually eliminates storing excessive base charge and significantly enhances turn-off time of the transistors.
2. Elimination of transistor storage time provides stable switching times across the temperature range.
3. An active turn-off is added to square up the transfer characteristic and provide an improved high-level noise immunity.


Figure 12. 'ALS00A NAND Gate Schematic
4. Input and output clamping is implemented with Schottky diodes to reduce negative-going excursions on the inputs and outputs. Because of its lower forward voltage drop and fast recovery time, the Schottky input diode provides improved clamping action over a conventional p-n junction diode.
5. The ion implantation process allows small geometries giving less parasitic capacitances so that switching times are decreased.
6. The reduction of the epi-substrate capacitance using oxide isolation also decreases switching times.
A key feature of the 'ALS and 'AS families is the improvement in typical input-threshold voltage. Figure 12 is a schematic diagram of the 'ALSOOA NAND gate. Figure 13 is a schematic diagram of the 'AS00 NAND gate. The input threshold voltage of the devices is determined by the equation:

$$
\begin{align*}
\mathrm{VT}= & \mathrm{V}_{\mathrm{BE}} \text { of } \mathrm{Q} 2+\mathrm{V}_{\mathrm{BE}} \text { of } \mathrm{Q} 3 \\
& +\mathrm{V}_{\mathrm{BE}} \text { of } \mathrm{Q} 5-\mathrm{V}_{\mathrm{BE}} \text { of } \mathrm{Q1A} \\
& \left(\text { or } \mathrm{V}_{\mathrm{BE}} \text { of } \mathrm{Q} 1 \mathrm{~B}\right) \tag{1}
\end{align*}
$$

From Eq. (1) it can be determined that the input threshold voltage is two times $\mathrm{V}_{\mathrm{BE}}$ or approximately 1.4 V . Low-level input current $\mathrm{I}_{\mathrm{IL}}$ is reduced in the 'ALS00A/'AS00 gates because of the improved input circuits. Buffering by transistors Q1A (or Q1B) and Q2 causes a significant reduction in low-level input current. Lowlevel input current is determined by the equation:

$$
\begin{align*}
\mathrm{I}_{\mathrm{IL}}= & V_{C C}-V_{\text {BE }} \text { of Q1A } \\
& -V_{\mathrm{I}} /\left[\mathrm{R}\left(\mathrm{~h}_{\mathrm{FE}} \text { of Q1A }+1\right)\right] \tag{2}
\end{align*}
$$

By using Eq. (2) low-level input current is reduced by at least the factor of $\mathrm{h}_{\mathrm{FE}}$ of Q1A +1 and is typically $-10 \mu \mathrm{~A}$ for the 'ALSO0A and $-50 \mu \mathrm{~A}$ for the 'ASOO. Highlevel output voltage $\mathrm{V}_{\mathrm{OH}}$ is determined primarily by $\mathrm{V}_{\mathrm{CC}}$,


Figure 13. 'AS00 NAND Gate Schematic
resistors R4 and R7, and transistors Q6 and Q7. With no load, the high-level output voltage is approximately equal to $\mathrm{V}_{\mathrm{CC}}-\mathrm{V}_{\mathrm{BE}}$ of Q 6 because the voltage across resistor R4 is 0 V . For medium-level currents, the high-level output voltage is equal to $\mathrm{V}_{\mathrm{CC}}-\mathrm{V}_{\mathrm{BE}}$ of $\mathrm{Q} 6-\mathrm{V}_{\mathrm{BE}}$ of Q 7 because of the Darlington gain of transistors Q6 and Q7. The current through resistor R3 is typically less than $1 \mu \mathrm{~A}$ and, therefore, the voltage drop is negligible. As conduction through transistors Q6 and Q7 is increased, the voltage drop across limiting resistor R7 will increase until the Schottky clamping diode of transistor Q6 starts to become forward biased. At this point, the current through resistor R3 (and the voltage drop) is no longer negligible and the high-level output voltage is determined by:

$$
\begin{align*}
\mathrm{V}_{\mathrm{OH}}= & \mathrm{V}_{\mathrm{CC}}-\mathrm{I}_{\mathrm{OH}} \text { through } \mathrm{R} 7 \times \mathrm{R} 7 \\
& -\mathrm{V}_{\mathrm{CE}} \text { of } \mathrm{Q} 6-\mathrm{V}_{\mathrm{BE}} \text { of } \mathrm{Q} 7 \tag{3}
\end{align*}
$$

Low-level output voltage $\mathrm{V}_{\mathrm{OL}}$ is determined by the turning on of transistor Q5. When the input is high and transistor

Q2 is turned on, high-current transistor Q5 is turned on by a current path through transistor Q3 and resistor R3. Sufficient base drive is supplied to keep transistor Q5 fully turned on at an apparent output resistance of $14 \Omega$ for 'ALS and $6 \Omega$ for 'AS.

The fanout is up to 40 for a '54ALS device that is driving a '54ALS device and up to 80 for a ' 74 ALS device, that is driving a ' 74 ALS device and provides a guaranteed low-level output current of 4 mA and 8 mA , respectively.

The increase in speed-power product of '54ALS/'74ALS devices, a factor four times better than '54LS/'74LS devices, is due to the design consideration of the quiescent and switching operations of the circuit. In the quiescent state, transistor Q2 allows the use of a reduced low-level input current. This reduces the fanout and reduces the overall quiescent current requirements.

The design of diodes D2 and D3 (or transistor Q8) and transistor Q4 enhances the speed-power product of the device. Transistor Q4 reduces the turn-off time and consequently the current transients caused by conduction
overlap of transistor Q5. The same principle is used by diodes D2 and D3 and transistor Q3 in turning off transistor Q7. In addition, the active turn-off design produces a square transfer characteristic.

The 'AS00 gate has additional circuits not on the 'ALS00A gate. The circuits are added to enhance the throughput of the 'AS Family.

Transistor Q10 has been added as a discharge path for the base-collector capacitance of transistor Q5. Without transistor Q10, rising voltages at the collector of transistor Q5 would force current, via the base-collector capacitance, into the base of transistor Q5 causing it to turn on. However, diode D10 causes transistor Q10 to turn on (during rising voltage) and keeps transistor Q5 turned off. Diodes D6 and D9 serve as a discharge path for capacitor-diode D10.

## CIRCUIT PARAMETERS

Worst-case testing of 'ALS/'AS devices provides a margin of safety. [All dc limits shown on the data sheet are guaranteed over the entire temperature range $\left(-55^{\circ} \mathrm{C}\right.$ to $125^{\circ} \mathrm{C}$ ) for series $54 \mathrm{ALS} / 54 \mathrm{AS}$ and $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ for series $74 \mathrm{ALS} / 74 \mathrm{AS})]$. In addition, the dc limits are guaranteed over the entire supply voltage range ( 4.5 V to 5.5 V ).

## Transfer Characteristics

Since the most common application for a logic gate is to drive a similar logic gate, the input and output logic levels
must be compatible. The input and output logic levels for 'ALS/'AS devices are as follows:
$\mathrm{V}_{\mathrm{IL}}$ - The voltage value required for a low-level input voltage that guarantees operation
$\mathrm{V}_{\mathrm{IH}}$ - The voltage value required for a high-level input voltage that guarantees operation
$\mathrm{V}_{\mathrm{OL}}$ - The guaranteed maximum low-level output voltage of a gate
$\mathrm{V}_{\mathrm{OH}}$ - The guaranteed minimum high-level output voltage of a gate.
With the exception of high-level ouput voltage (which is a direct function of supply voltage), these values remain virtually unchanged over the temperature range and under normal operating conditions of the device.

Analysis of the input and output response characteristics of 'ALS/'AS TTL gates is necessary to understand the operation of these devices in most system applications. The dc response characteristics can best be depicted by an input voltage $\mathrm{V}_{\mathrm{I}}$ versus output voltage $\mathrm{V}_{\mathrm{O}}$ transfer plot.

Figure 14 plots the 'ALS/'AS characteristics as compared with members of other TTL logic families.

As shown in Figure 14, the 'ALS and 'AS devices exhibit a much better output savings when compared with standard TTL devices. The better high-level output voltage is primarily because of the active turn off of the low-level output transistor. The diode voltage drop in the normal output is replàced by a low-current $\mathrm{V}_{\mathrm{BE}}$ voltage drop. This provides


Figure 14. Input Voltage vs Output Voltage of 'ALS/'AS
a better high-level noise immunity in 'ALS and and 'AS over standard TTL devices.

## Input Characteristics

To use 'ALS/'AS devices fully, a knowledge of the input and output characteristics is required. This is particularly true when a device interfaces with a device not in the same TTL series. In addition, knowledge of voltage and current relationships for all elements is important for proper design.

Figure 15 illustrates a typical plot for input current $\mathrm{I}_{\mathrm{I}}$ versus input voltage, $\mathrm{V}_{\mathrm{I}}$, characteristics for 'ALS/'AS gate inputs during normal operation. A typical series 54/74 characteristic plot is also shown for reference. Any device used to drive a TTL gate must source and sink current. Conventionally, current flowing toward a device input terminal is designated as positive and current flowing out
of a device input terminal is designated as negative. Lowlevel input current is negative current because it flows out of the input terminal. High-level input current is a positive current because it flows into the input terminal.

For transmission line conditions, a more accurate plot of the reverse bias section of these curves is required. These curves, Figure 16, are characteristic of the input clamping diode.

## Low-Level Input Current

Figure 17 illustrates the de equivaient of a standard 'ALS/'AS input circuit and shows the input current paths during a low-level input state. The low-level input current is primarily determined by resistor R1. However, low-level input current is also a function of the supply voltage, the ambient temperature, and the low-level input voltage. To


Figure 15. Input Current vs Input Voltage for TTL Families


Figure 16. Low-Level Input Current vs High-Level Input Voltage for TTL Families ${ }^{\wedge}$
assure desired device operation under all possible conditions, the worst-case test is performed on all devices. Supply voltage is taken to the highest allowable value to cause the low-level input current to be at a maximum. With the exception of the input under test, all unused inputs are taken to a high level. This enhances any contribution of these inputs to the low-level input current of the emitter under test.

## Input Clamping Diode Test

The quality of the input clamping SBD (D2 in Figure 17) is tested by ensuring that the forward voltage drop is not


Figure 17. DC Equivalent Input Circuit for Series 'ALS Gate
greater than -1.2 V for 'AS and -1.5 V for 'ALS with a forward current of 18 mA . These values are guaranteed at minimum supply voltage and are valid across the operating temperature range. The characteristic of the input diode is illustrated in Figure 16.

## High-Level Input Current

Another input parameter that must be measured and controlled is high-level input current. To ensure desired device operation under all possible conditions, the worst-case test is performed with all unused inputs grounded and supply voltage at its maximum value. This provides the highest value of low-level input current. Those devices with a high-level input current of sufficient magnitude to cause a degradation of high-level output voltage at an output must be screened out.

## Input Breakdown Test

An additional high-level input current test is performed to check for base-emitter breakdown under the application of the full range of input voltages. This test is performed under the worst-case supply voltage conditions and is important because the base-emitter junction is small and can easily be overdissipated during the breakdown conditions.

## Output Characteristics

The most versatile TTL output configuration is the pushpull (totem-pole) type. The totem-pole output has a low output impedance drive capability at both high and low logic levels. Both 'ALS and 'AS families use this configuration and have fanouts of 40 in both the high- and low-level states.

## High-Level Output Characteristics

The ability of the totem-pole output to supply high-level output current is parametrically tested by applying a highlevel input current value during measurement of high-level output voltage. However, the quality of the output stage is best indicated by parametrically measuring its current sourcing IOS capability when connected to ground. Figure 18 shows the equivalent output circuit under high-level output conditions.

Figure 19 illustrates typical high-level characteristics. When measuring worst-case high-level output voltage, minimum supply voltage is used. A worst-case low-level
input voltage is applied to an input and all unused inputs are tied to supply voltage.

'ALS


Figure 18. Equivalent Output Circuit for 'ALS/'AS Gates

## Low-Level Output Characteristics

Figure 20 shows that section of the output drive circuit which produces a low-level output voltage $\mathrm{V}_{\mathrm{OL}}$. This characteristic is also tested at minimum supply voltage. Figure 21 illustrates the typical curve.

## Switching Speed

Two switching-speed parameters are guaranteed on Series 'ALS and 'AS gates: propagation delay time for a high-level to a low-level at the output tpHL, and a low-level to high-level transition time tPLH. Both parameters are specified with respect to the input pulse using standard test conditions as follows:

$$
\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}_{\mathrm{L}} & =500 \\
\mathrm{~T}_{\mathrm{A}} & =\text { MIN to MAX }
\end{aligned}
$$

Under these conditions, times in the order of 4 ns for 'ALS and 1.7 ns for 'AS are typical. Figures 22 and 23 illustrate how the propagation delay time for 'ALS and 'AS devices vary with load capacitance.

Most current in the output stage is drawn when both output transistors are on (i.e., during output transitions, the average power dissipation of a gate with a totem-pole output increases with operating frequency). This is caused by more high-current transitions per second at the output as the frequency increases. Figure 24 illustrates the effect for both 'ALS and 'AS devices.


Figure 19. High-Level Output Voltage vs High-Level Output Current

## DC Noise Margins

Noise margin is a voltage specification which guarantees the static dc immunity of a circuit to adverse operating conditions. Noise margin is defined as the difference between the worst-case input logic level $\left(\mathrm{V}_{\mathrm{IH}}\right.$ minimum or $\mathrm{V}_{\mathrm{IL}}$
maximum) and the guaranteed worst-case output ( $\mathrm{V}_{\mathrm{OH}}$ minimum or $\mathrm{V}_{\mathrm{OL}}$ maximum) specified to drive the inputs. Table 2 lists the worst-case output limits for the 'AS and 'ALS families.


Figure 20. Low-Level Output Circuit for 'ALS/'AS Gates


Figure 21. Low-Level Output Voltage vs Low-Level Output Current


Figure 22. High- to Low-Level Propagation Delay vs Load Capacitance


Figure 23. Low- to High-Level Propagation Delay vs Load Capacitance


Figure 24. Power Dissipation per Gate vs Frequency

## Specified Logic Levels and Thresholds

The high-level noise margin is obtained by subtracting $\mathrm{V}_{\mathrm{OH}}$ minimum from $\mathrm{V}_{\mathrm{IH}}$ minimum. The low-level noise margin is obtained by subtracting $\mathrm{V}_{\mathrm{IL}}$ maximum from $\mathrm{V}_{\mathrm{OL}}$ maximum. The worst-case high-level noise margin is guaranteed to be at least 500 mV for both 'AS and 'ALS devices and at least 300 mV for low-level noise immunity across the operating free-air temperature ranges.

The usefulness of noise margins at the system design level is the ability of a device to be impervious to noise spikes at the input. The input voltage falls into one of three categories: low-logic state (between ground and 0.8 V ), threshold region (between 0.8 V and 2 V ), or high-logic state (between 2 V and $\mathrm{V}_{\mathrm{CC}}$ ). If an input voltage remains exclusively in the low-logic or high-logic state, it can undergo
any excursions within that state. A level change from 5.5 V to 2 V or from ground to 0.8 V should not affect the output state of the device. To guarantee an expected output level change, the appropriate input has to undergo a change from one input state to the other input state (i.e., a transition through the threshold region). If a device will not remain in the correct state when voltage excursions on the input are occurring, it is violating its truth table.

## Noise Rejection

The ability of a logic element to operate in a noise environment involves more than the dc or ac noise margins previously discussed. To present a problem, an externally generated noise pulse must be received into the system and cause a malfunction. Stable logic systems with no storage

Table 2. Worst Case Output Parameters

| PARAMETER <br> (V) | $\begin{gathered} \text { 'AS } \\ \left(0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}\right) \end{gathered}$ | 'ALS $\left(0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$ | $\begin{gathered} \text { 'AS } \\ \left(-55^{\circ} \mathrm{C} \text { to } 125^{\circ} \mathrm{C}\right) \end{gathered}$ | $\begin{gathered} \text { 'ALS } \\ \left(-55^{\circ} \mathrm{C} \text { to } 125^{\circ} \mathrm{C}\right) \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}(\mathrm{MIN})$ | 2 | 2 | 2 | 2 |
| $\mathrm{V}_{\text {IL }}$ (MAX) | 0.8 | 0.8 | 0.8 | 0.8 |
| $\mathrm{V}_{\mathrm{OH}}(\mathrm{MIN}) @ \mathrm{CC}=4.5 \mathrm{~V}^{*}$ | 2.5 | 2.5 | 2.5 | 2.5 |
| $\mathrm{V}_{\mathrm{OL}}$ (MAX) | 0.5 | 0.5 | 0.5 | 0.4 |
| High Level Noise <br> Margin $\left(\mathrm{V}_{\mathrm{OH}}-\mathrm{V}_{\mathrm{IH}}\right)$ | 0.5 | 0.5 | 0.5 | 0.5 |
| Low Level Noise Margin ( $\mathrm{V}_{\mathrm{IL}}-\mathrm{V}_{\mathrm{OL}}$ ) | 0.3 | 0.3 | 0.3 | 0.4 |

*Actual specification for $\mathrm{V}_{\mathrm{OH}(\min )}$ is $\mathrm{V}_{\mathrm{CC}}-2 \mathrm{~V}$.
elements are practically impervious to ac noise. However, large dc voltages could cause noise problems. Systems with triggerable storage elements or those operating fast enough for the noise to appear as a signal are much more susceptible to noise.

The noise voltage must be radiated or coupled into the circuit. The amount of noise required to develop a given voltage is a function of the circuit impedance. Because of the low output impedance of TTL circuits, noise immunity is improved. Noise is transferred from the source (with some arbitrary impedance) through a coupling impedance to the impedance of the circuit under consideration.

Figure 25 shows a circuit where the coupling impedance is stray capacitance and the load impedance is provided by the gates. The relatively tight coupling of this circuit and the loading effect on the driving source is significant enough


Figure 25. Stray Coupling Capacitance
to be considered. However, since the source effect is difficult to assess and is in a direction to improve rather than degrade the noise rejection, its effects are ignored. This results in a worst-case type of response indication. In the case of radiated noise, the source resistance is a definite factor in noise coupling and essentially replaces the reactive coupling impedance.

By ignoring the driving source impedance to make conditions more nearly standard, it is possible to determine a set of curves relating the developed noise pulse to the noise source amplitude, the noise rise or fall time, the coupling impedance, and the load impedance. Curves have been developed ${ }^{1}$ for several different input waveforms. Since the 'ALS waveform is essentially a ramp with a dv/vt of $1 \mathrm{~V} / \mathrm{ns}$ (approximately $2.5 \mathrm{~V} / \mathrm{ns}$ for 'AS), the most applicable curve is that for a ramp input.

Figure 26(a) shows the equivalent circuit from which the ramp response plot in Figure 26(b) was developed. The input pulse shown in Figure 26(c) is a ramp input.

$$
\mathrm{e}_{\mathrm{i}}(\mathrm{t})=\frac{\mathrm{E}_{\mathrm{i}}}{\mathrm{~T}} \mathrm{t}
$$

where

$$
\begin{aligned}
\mathrm{E}_{\mathrm{i}} & =\text { Maximum input voltage and } \\
\mathrm{T} & =\text { Total rise time of input voltage }
\end{aligned}
$$

The output pulse is represented analytically by

$$
\begin{aligned}
& \mathrm{e}_{0}(\mathrm{t})=\frac{\mathrm{E}_{\mathrm{i}}}{\mathrm{~T}} \mathrm{RC}\left(1-\mathrm{e}^{-\frac{\mathrm{t} / \mathrm{T}}{\mathrm{RC} / \mathrm{T}}}\right) \\
& \mathrm{e}_{0}(\mathrm{i})=\mathrm{E}_{\mathrm{i}} \tau\left(1-\mathrm{e}^{-\mathrm{i} / \tau}\right)
\end{aligned}
$$

where

$$
\begin{aligned}
\tau & =\frac{\mathrm{RC}}{\mathrm{~T}} \\
\theta(\mathrm{i}) & =\tau\left(1-\mathrm{e}^{-\mathrm{i} / \tau}\right) \\
\theta(\mathrm{i}) & =\frac{\mathrm{e}_{0}(\mathrm{i})}{\mathrm{E}_{\mathrm{i}}}
\end{aligned}
$$

with holding for unit time. This is followed by an exponentially decaying voltage with a time constant $\tau$. Values of $\tau$ and i on the figure are normalized by the value of the total rise time of the stimulated noise pulse $e_{i}$. Using Figure 26(b), the pulse width and amplitude of the coupled noise pulse can be estimated.

As an example, using the circuit shown in Figure 25, apply a noise pulse of 3 V in amplitude and rising at $1 \mathrm{~V} / \mathrm{ns}$

with gate 2 at a high-logic state. Assume a nominal output impedance of $58 \Omega$ ( $30 \Omega$ for 'AS) and coupling capacitance of 10 pF . Use the following formula:

Total rise time $\mathrm{T}=\frac{3 \mathrm{~V}}{1 \mathrm{~V} / \mathrm{ns}^{* *}}=3 \mathrm{~ns}^{\dagger}$

$$
\begin{aligned}
\tau & =\frac{\mathrm{RC}}{\mathrm{~T}}=\frac{\left(10 \times 10^{-12}\right)(58)}{3} \\
& =\frac{0.58 \times 10^{-9}}{3}=0.19 \mathrm{~ns}
\end{aligned}
$$

**2.5 V/ns for 'AS
${ }^{+} 1.2$ ns for 'AS

To convert the normalized values of $\tau$ and i in Figure 26(b) to actual values, multiply by 3 ns . The output voltage scale will be multiplied by 3 V . Using the $\tau=0.19$ curve gives a peak $\mathrm{e}_{\mathrm{O}}$ of $0.57 \mathrm{~V}(0.19 \times 3)$ and a pulse width of 3 ns at the $50 \%$ points. To determine whether this pulse will cause interference, enter these values ( 0.57 V and 3 ns ) on the graph shown in Figure 27. Since the gates have approximately 1.8 V of noise immunity at this point, they should not be affected.

If an open-collector gate is used with a passive $1 \mathrm{k} \Omega$ pullup resistor, the situation would change. Use the following formula:

Total rise time $=\frac{3 \mathrm{~V}}{1 \mathrm{~V} / \mathrm{ns}^{* *}}=3 \mathrm{~ns}^{\dagger}$

$$
\begin{aligned}
\tau & =\frac{\left(10 \times 10^{-12}\right)\left(1 \times 10^{3}\right)}{3} \\
& =\frac{10 \times 10^{-9}}{3}=\frac{10}{3} \mathrm{~ns}
\end{aligned}
$$

**2.5 V/ns for 'AS
${ }^{\dagger} 1.2 \mathrm{~ns}$ for ${ }^{\prime} \mathrm{AS}$

Now the amplitude (from the curves) approaches 2.58 V $(0.86 \times 3)$ and the pulse width at the $50 \%$ points is approximately $8.52 \mathrm{~ns}(2.84 \times 3)$. The next gate will propagate this pulse.

This example is an oversimplification. The coupling impedances are complex (but resolvable into RLC series coupling elements) and the gate output impedance changes with load. Our purpose is to show why and how the low impedance of the active TTL output rejects noise and to make a comparison with a passive pull-up.

The ability to operate in a noisy environment is an interaction of the built-in operating margins, the time required for the device to react, and the ease with which a noise voltage is developed. In all cases, except the ability to react to short noise pulses, the TTL design has emhasized noise rejection.

Nothing has been discussed concerning noise in devices other than gate circuits. Many MSI devices are complex gate
networks and, because of their small size, are more superior in a noisy environment operation than their discrete gate equivalents. Noise tolerance of latching devices is implied in the setup times, hold times, clock pulse width, data pulse widths, and similar parameters. Output impedances and input noise margins are quite similar to those of the gates and may be treated in a similar manner. If a latching device does become noise triggered, the effective error is stored and does not disappear with the noise.

Parameter measurement information is shown in Figure 28.


Figure 27. Theoretical Required Pulse Width vs Pulse Amplitude for 'AS and 'ALS Inputs

## GUIDELINES FOR SERIES 'ALS/'AS TTL SYSTEM DESIGN

System layout and design requirements for Advanced Schottky TTL circuits are essentially the same as those guidelines which have previously been established and are applicable for all high-performance digital systems. Tables 3 through 6 provide a brief summary of the solutions to most design decisions needed to implement systems using Advanced Schottky TTL. Supplementary data which may be useful for developing specific answers to unique problems is provided later.


NOTES: 1. $C_{L}$ includes probe and jig capacitance.
2. All input pulses have the following characteristics PRR $\leq 1 \mathrm{MHz}, \mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}}=2 \mathrm{~ns}$, duty cycle $=50 \%$.
3. When measuring propagation delay times of 3 -state outputs, switch S 1 is open.
4. Waveform 1 is for an output with internal conditions such that the output is low except when disabled by the output control. Waveform 2 is for an output with internal conditions such that the output is high except when disabled by the output control.

Figure 28. Parameter Measurement Information

## POWER SUPPLY REGULATION

Power supply regulation cannot be treated as if it is an independent characteristic of the device involved. Power supply regulation, along with temperature range, affects noise margins, fanout, switching-speed, and several other parameters. The characteristics most affected are noise
margin and fanout. When these two parameters are within the specified limits, the power-supply regulation will normally be within specified limits. However, on a device where auxiliary parameters are more critically specified, a more restrictive power-supply regulation is normally required. When power-supply regulation is slightly outside the specified limits for TTL devices, the device may still
operate satisfactorily. However, if high ambient-noise levels and extreme temperatures are encountered, failures may occur.

Application of a supply voltage above 7 V (absolute maximum rating) will result in damage to the circuit.

Since power dissipation in the package is directly related to supply voltage, the maximum recommended supply voltage for TTL devices is specified at 5.5 V . This provides an adequate margin to ensure that functional capability and long-term reliability are not jeopardized.

High-level output voltage is almost directly proportional to supply voltage (i.e., a drop in supply voltage causes a drop in high-level output voltage and an increase in supply voltage
results in an increase in high-level output voltage). Because of this relationship, high-level output voltage for 'ALS/'AS devices is specified as supply voltage $-2 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{CC}}-2 \mathrm{~V}\right)$.

Since high-level output voltage is directly related to supply voltage, the output current of the device is also directly related. The output current value is established by choosing output conditions to produce a current that is approximately one-half of the true short-circuit current.

It is advantageous to regulate or clamp the maximum supply voltage at 5.5 V including noise ripple and spikes. When this conditions exists, unused AND and NAND gates can be connected directly to the supply voltage.

Table 3. Guidelines for Systems Design for Advanced Schottky TTL

| ITEM | GUIDELINE |
| :---: | :---: |
| Single wire connections | Wire lengths up to approximately 12 inches may be used. A form of ground plane is desirable. Use point-to-point routing rather than parallel. If the wire is longer than 12 inches, use either a dense ground plane with the wire routed as close to it as possible, or use a twisted-pair cable. |
| Coaxial and twisted-pair cables | Design around approximately $80 \Omega$ to $100 \Omega$ of characteristic impedance. Cross talk increases at higher impedances. Use a coaxial cable of $93 \Omega$ impedance (e.g., Microdot 293-3913). For twistedpair cable, use number 26 or number 28 wire with the insulation twisted at the rate of 30 turns per foot. |
| Transmission-line-ground | Ensure that transmission-line ground returns are carried through at both transmitting and receiving ends. $V_{\text {CC }}$ decoupling ground, device ground, and transmission-line ground should have a common tie point. |
| Cross talk | Use point-to-point back-panel wiring to minimize noise pickup between lines. Avoid long unshielded parallel runs. However, if they must be used, they should carry signals that propagate in the same direction. |
| Reflections | Reflections occur when data interconnects become long enough that 2 -line propagation delays are pulse transition times. For series TTL, reflections are normally of no importance for lines shorter than 12 inches. |
| Resistive pull-up | If fanout of driving output permits, use approximately $300 \Omega$ of resistive pull-up at the receiving end of long cables. This provides added noise margin and more rapid rise times. |

Table 4. Guidelines for Printed Circuit Board Layout for Advanced Schottky TTL

| ITEM | GUIDELINE |
| :--- | :--- |
| Signal connections | Whenever possible, distribute loads along direct connections. Signal leads should be kept as short as possible. <br> However, lead lengths of up to 15 inches will perform satisfactorily. This is especially for large boards that <br> use a ground plane, ground, and/or $V_{C C}$ plane. In addition, it will perform satisfactorily for small boards using <br> ground mesh or grid. In high-frequency applications, avoid radial fanouts and stubs. If they must be used to <br> drive some loads, reduce lead length proportionally and avoid sharp bends. Normal on-board fanouts and <br> interconnections do not require terminations. Response of lines driving large numbers or highly capacitive loads <br> can be improved with terminations of $300 \Omega$ to $V_{C C}$ and $600 \Omega$ to ground in parallel with the last load if fanout <br> of the driving output permits. |
| Conductor widths | Signal-line widths down to 0.015 inch are adequate for most signal leads. <br> Signal-lead spacing on any layer down to 0.015 inch can be used especially if care is taken to avoid adjacent <br> use of maximum length and minimum spacing. Increase spacing wherever layout permits. Pay particular attention <br> to clock and/or other sensitive signals. |
| Insulator material | Thickness of insulation material used for a multilayer board is not critical. If ground and $V_{C C}$ planes or meshes <br> are used, their capacitive proximity can be used to reduce the number of decoupling capacitors needed and <br> this also supplements the supply bypass capacitor. |

Table 5. Guidelines for General Usage of Advanced Schottky TTL

| ITEM | GUIDELINE |
| :--- | :--- |
| Power supply | For RF bypass supply primary, maintain ripple and regulation at less than or equal to $10 \%$. <br> Decouple every 2 to 5 packages with RF capacitors of 0.01 to $0.1 \mu \mathrm{~F}$. Capacitors should be located as near <br> as possible to the decoupled devices. Decouple line driving or receiving devices separately with $0.1 \mu \mathrm{~F}$ capacitors <br> between $V_{C C}$ and the ground pins. |
| System grounding | A ground plane is essential when the PCB is relatively large (over 12 inches). Smaller boards will work with <br> ground and/or $V_{C C}$ mesh or grid. |
| Try to simulate bus bars with a width to thickness ratio greater than or equal to 4. This can be accomplished <br> by multiple parallel wires or by using flat braid. Performance will be enhanced when a copper or silver-copper <br> bus is used. The width to thickness ratio required will vary between systems, but greater than or equal to 4 <br> will satisfy most systems. |  |

Table 6. Guidelines for Gates and Flip-Flops Using Advanced Schottky TTL

| ITEM | GUIDELINE |
| :--- | :--- |
| Data input rise and fall times | Reduce input rise and fall times as driver output impedance increases. Rise and fall times should <br> be equal to or less than $15 \mathrm{~ns} / \mathrm{V}$ and essentially free of noise ripple. |
| Unused input of AND and NAND <br> gates and unused preset and <br> clear inputs of flip-flops | Tie the unused input of AND and NAND gates and the unused preset and/or clear inputs of <br> flip-flops as follows: <br> 1. Directly to $V_{C C}$, if the input voltage rating of 5.5 V maximum is not exceeded. <br> 2. Through a resistor equal to or greater than $1 \mathrm{k} \Omega$ to $V_{\text {CC. Several inputs can be tied to one }}$ <br> resistor. <br> 3. Directly to a used input of the same gate, if maximum fanout of driving device will not be <br> exceeded. Only the high-level loading of the driver is increased. |
| 4. Directly to an unused gate output, if the gate is wired to provide a constant high-level output. |  |
| Input voltage should not exceed 5.5 V. |  |

## SUPPLY VOLTAGE RIPPLE

Ripple in the supply voltage is generally considered a part of the supply voltage regulation. However, when combined with other effects (e.g., slow rise times), ripple voltage is more significant.

The effect of ripple voltage $V_{R}$ can appear on either the supply voltage $\mathrm{V}_{\mathrm{CC}}$ or the ground supply GND. When ripple appears on the supply voltage, it causes modulation of the input signal. The extent of the effect depends upon circuit parameters and source impedance.

The turning on of transistor Q5, shown in Figures 12 and 13 , is controlled by the voltage at the base of transistor Q2 with respect to ground in accordance with the formula:

$$
V_{B}=V_{B E} \text { of } Q 2+V_{B E} \text { of } Q 3+V_{B E} \text { of } Q 5
$$

When ripple voltage is modulated onto the input voltage, the amplitude depends on the source impedance (Figure 29). The amplitude can be determined by the following equation:

$$
\begin{aligned}
\Delta \mathrm{V}_{\mathrm{R}} & =\mathrm{V}_{\mathrm{R}}\left(\frac{\mathrm{R} 1 / \beta}{\mathrm{R} 1 / \beta+\mathrm{R} 2}\right) \\
& =\mathrm{V}_{\mathrm{R}}\left(\frac{\mathrm{R} 1}{\mathrm{R} 1+\beta \mathrm{R} 2}\right)
\end{aligned}
$$

where $R 1=$ source impedance

$$
\beta=\text { gain of transistor Q1. }
$$

Ripple voltage has the effect of adding extra pulses to the input signal (Figure 30). When ripple voltage appears in the ground supply, the threshold voltage is modulated and extra pulses occur (Figure 31).

Although decreasing the source impedance will reduce the effects of ripple voltage, it cannot be eliminated entirely because the emitter-base junction has an apparent resistance of approximately $30 \Omega$. Because of cancellation between the driving gate and the driven gate, low-frequency ripple is not a problem.


Figure 29. Effect of Source Impedance on Input Noise


Figure 30. Spurious Output Produced by Supply Voltage Ripple


Figure 31. Effect of Ground Noise on Noise Margin

## NOISE CONSIDERATIONS

Extraneous voltages and currents (called noise) introduced into a digital logic circuit are discussed in the following paragraphs. Figure 32(a) is a typical digital logic


Figure 32. Typical Logic Circuit with Noisy Input
circuit consisting of a NAND gate and a J-K flip-flop. When a small noise pulse is coupled onto the clock input [(Figure 32(b)], the flip-flop does not respond and the Q output is correct. However, when a large noise pulse is coupled onto the clock input [(Figure 32(c)], the flip-flop sees the pulse as a clock transition and an erroneous $Q$ output occurs. Therefore, it is essential to protect digital logic circuits from noise.

## Noise Types and Control Methods

The noise types encountered in digital logic systems, their source, and the method of controlling them are as follows:

1. External noise - External noises radiated into the system. The sources include circuit breakers, motor brushes, arcing relay contacts, and magnetic-field-generating. The methods of controlled to be considered are shielding, grounding, or decoupling.
2. Power-line noise - Noise coupled through the ac or dc power distribution system. The initial sources and controlling methods are the same as for external noise.
3. Cross talk - Noise induced into signal lines from adjacent signal lines. Controlling methods to consider are shielding, grounding, decoupling, and, where possible, increasing the distance between the signal lines.
4. Signal-current noise - Noise generated in stray impedances throughout the circuit. The controlling methods to consider are shielding, grounding, decoupling, and, where possible, reduction of stray capacitance in the circuit.
5. Transmission-line reflections - Noise from unterminated transmission lines that cause ringing and overshoot. The method of control is to use, where possible, terminated transmission lines.
6. Supply-current spikes - Noise caused by switching several digital loads simultaneously. The controlling method is to design, where possible, the system so that digital loads are not switched simultaneously.

## Shielding

In addition to its own internally generated noise, electrical equipment must operate in an extremely noisy environment. Noise pulses, which may come from a number of sources, consist of an electrostatic field, and electromagnetic field, or both. The noise waveform must be prevented from entering the equipment. This is accomplished by shielding. Since the noise fields are usually changing at a rapid rate, the shield required to exclude them may be very small. For effective exclusion, the sensitive circuits must be completely shielded.

Aluminum or similar materials are effective in stopping electrostatic noise. However, only a ferrous metal can successfully protect equipment against magnetic fields. While it is helpful to connect the system to earth ground, the shield system must be complete and must be grounded to the system ground to prevent the shield from coupling noise into the system.

External noise may be conducted into the system by the power lines. Decoupling and filtering of these lines should be standard design procedure.

## Grounding and Decoupling

The total propagation delay is of secondary importance in generation of internal noise. The actual transition time determines the amplitude and frequency spectrum of the generated signal at the higher harmonics. Application of the Fourier integral to series 'ALS/'AS waveforms shows frequency components of significant amplitude that exceed 100 MHz . Because of the frequency spectrum generated when an 'ALS/'AS device switches, a system using these devices must consider problems caused by radio frequency (RF) even though the repetition rates may be only a few megahertz. The transient currents generated by charging capacitors, changes in the levels of dc, line driving, etc., must be considered. In Figure 33 for example, a gate driving a transmission line is represented by a voltage source E , having an output impedance $Z_{S}$ connected to an impedance $\mathrm{Z}_{0}$, and loaded with a resistance $\mathrm{R}_{\mathrm{L}}$.

Until after a reflected pulse returns from the termination of the transmitting device, line termination is not a factor in drive current. In a practical TTL circuit, the line termination must be high relative to the line impedance. For


Figure 33. Diagram Representing a Gate Driving a Transmission Line
explanation purposes, assume that the source voltage is 5 V in amplitude, the output impedance of the source is $50 \Omega$ and the line impedance is $50 \Omega$. When the source voltage makes the transition from 0 V to 5 V , the voltage across the input of the line $\mathrm{V}_{\mathrm{I}}$ is determined by the following equation:

$$
\mathrm{V}_{\mathrm{I}}=\mathrm{E} \frac{\mathrm{Z}_{0}}{\mathrm{Z}_{\mathrm{S}}+\mathrm{Z}_{0}}=2.5 \mathrm{~V}
$$

where

$$
\begin{aligned}
\mathrm{E} & =\text { source voltage } \\
\mathrm{Z}_{0} & =\text { line impedance } \\
\mathrm{Z}_{\mathrm{S}} & =\text { source impedance }
\end{aligned}
$$

For the $50 \Omega$ line to become charged, the current that must flow onto the line is determined by the following equation:

$$
\text { I line } \frac{\mathrm{V}_{\mathrm{in}}}{\mathrm{Z}_{0}}=\frac{2.5}{50}=50 \mathrm{~mA}
$$

In addition, this current flows in the ground return, which, in this case, is the transmission-line ground. If the line and return are originated and terminated close to the driving and receiving devices, there is no discontinuity in the line. Where the ground is poorly returned, the current flow sees the discontinuity in the cable as a high impedance and a noise spike is generated (i.e., the ground current sees a low impedance and a current cancellation if the ground is properly carried through and, if not, it sees a high impedance). Figure 34 presents a specific example. Assume that the gate driving the line is switched from the high to low state. Current flow is indicated by the arrow marked with an I. Since the line is improperly returned to the driver, a pulse is developed across the impedance. A possible consequence is the false output of gate 3 (G3).

If the ground return is properly connected, the proper results are obtained. The impedance discontinuity is eliminated and current cancellation occurs at the ground point. Undesirable voltage spikes are then eliminated. Two empirical rules to reduce transmission-line currents have been established and have been found to be effective (Figure 35).

1. Carry all returns, including twisted pair and coaxial cables, to a good ground termination. Ground line returns close to the driving and receiving devices.


Figure 34. Noise Generation Caused by Poor Transmission-Line Return
*Impedance of poor ground return
2. Decouple the supply voltage of line-driving and line-receiving gates with a $0.1-\mu \mathrm{F}$ disk ceramic capacitor.
As the devices change state, current levels change because of the different device currents required in each state, the external loading, the transients caused by charging and discharging capacitive loads, and the conduction overlap in the totem-pole output stage. When a gate changes states, its internal supply current changes from high to low (these values are stated on the data sheet for each device). In addition, any capacitance, stray or otherwise, must be charged or discharged for a logic state change. The capacitance must be charged by a current determined by

$$
\begin{equation*}
\mathrm{I}=\mathrm{C} \frac{\mathrm{dv}}{\mathrm{dt}} \tag{4}
\end{equation*}
$$

If the total stray capacitance on a gate output, the logic-level voltage excursion, and the associated rise or fall times are known, then the ideal-case instantaneous current during the transition can be calculated.


Broken arrow shows path of line-charging current
Figure 35. Ideal Transmission-Line Current Handling

From Eq. (4) it can be determined that the current transient for charging load capacitance will increase with higher speed TTL circuits. Therefore, the Series 54ALS/74ALS devices will have lower transient current than the Series 54AS/74AS devices. Another parameter that should be considered is the value of R7 (shown in Figures 12 and 13). Resistor R7 acts as a limit on the charging current.

The current required for charging load capacitance $C_{L}$ (Figure 36) is supplied by the supply voltage when the transition is from logic low to logic high at the output of gate $1(\mathrm{Gl})$. When the output of G1 goes from high to low,

$C_{L}$ includes all capacitance: stray, device, etc.
Figure 36. Circuit with Effective Capacitive Loading
the load capacitance is shorted to ground by transistor Q5 (shown in Figures 12 and 13) and has no effect on supply current.

A characteristic common to all TTL totem-pole output stages contributes an additional current transient when the output changes from a logic low to a logic high. This transient, or spike, is caused by the overlap in conduction of the output transistors Q7 and Q5 (shown in Figures 12 and 13). The situation arises because transistor Q7 can turn on faster than transistor Q5 can turn off. This places a direct circuit consisting of transistors Q7 and Q5 and resistor R4 between supply voltage and ground. For all series 'ALS TTL circuits, the maximum possible peak current can be determined by

$$
\mathrm{I}_{\mathrm{CC}} \max =\frac{\mathrm{V}_{\mathrm{CC}}-\mathrm{V}_{\mathrm{CEQ}}-\mathrm{V}_{\mathrm{BEQ} 7}-\mathrm{V}_{\mathrm{CEQ} 5}}{\mathrm{R} 7}
$$

However, due to the active turnoff circuit (consisting of R5, R6, and Q4), Q5 will be only slightly in the linear region and the current spike will be less.

The total supply-current switching transient is then a combination of three major effects: the difference in highlevel and low-level supply current, the charging of load capacitance, and the conduction overlap. Tests were performed to demonstrate these effects. The results are shown in Figure 37. Six types of series TTL devices were tested with no load (i.e., the oscilloscope was connected to the output only when measuring $\mathrm{V}_{\mathrm{O}}$ and the photographs were double exposed). This was to approximate the effects of conduction overlap isolated from the transient caused by charging load capacitance. Different vertical scales were used on some of the photographs.

The results are almost as predicted. The low-power devices have the lower transients. Since it is the fastest circuit, the SN74AS00 device should be highest. However, a decrease is shown, and the reason for the decrease is explained (Figure 39). The additional circuits to reduce conduction overlap of the output transistors result in a smaller transient even though the typical switching time is 1.7 ns compared to 9 ns for the Series 54/74LS.

The second series of tests shown in Figure 37 cover a capacitive load of 50 pF . For this test, all of the supply current transient peaks increase in amplitude and width.

Because of the larger transient currents, voltage spikes on the supply voltage measured at the IC package are also increased.

From these tests, it can be concluded that the condition to be avoided (the only one that can be avoided) is unnecessary stray capacitance in circuit wiring. The charging of load capacitance, in most cases, overshadows the other two effects with respect to noise produced on the supply voltage line by switching current transients.

The flow paths of these currents have been investigated to determine the grounding and decoupling necessary to counteract their effects. Supply voltage decoupling may be accomplished by one of two methods. Maintaining low impedance from the individual circuit supply voltage to



Figure 37(b). Supply-Current Transient Comparisons
ground is common to both methods. In the first method, the supply voltage line may be considered as a transmission line back to a low impedance supply. The positive bus can be laminated with a ground bus to form a strip transmission line of extremely low impedance. This line can be electrically approximated with lumped capacitances as shown in Figure 38. The inductances are usually a distributed component which must be minimized to lower the line impedance.


Figure 38. Transmission-Line Power Buses
The second method is to consider the supply voltage bus as a dc connecting element only and to provide a lowimpedance path near the devices for the transient currents to be grounded (Figure 39).


Figure 39. Capacitive Storage Supply Voltage System

For effective filtering and decoupling, the capacitors must be able to supply the change in current for a period of time greater than the pulse width of this current. Since the problem is essentially one of dc changes due to logic state coupled with high-frequency transients associated with the changes, two different values of time constant must be considered. Capacitors combining the high capacitance required for long periods with the low series reactance required for fast transients are prohibitive in cost and size. A good compromise is the arrangement shown in Figure 40.

The typical component values may be found for the RF capacitor C1 by assuming that the parameters have common values as follows:

$$
\begin{aligned}
\Delta \mathrm{I}_{\mathrm{CC}} & =50 \mathrm{~mA} \\
\Delta \mathrm{~V} & =0.1 \mathrm{~V} \\
\Delta \mathrm{~T} & =20 \mathrm{~ns}
\end{aligned}
$$

Then the equation is as follows:

$$
\begin{aligned}
\mathrm{C} 1 & =\frac{\Delta \mathrm{I}_{\mathrm{CC}}}{\Delta \mathrm{~V} / \Delta \mathrm{T}}=\frac{(50)(20) \times 10^{-12}}{0.1 /\left(20 \times 10^{-9}\right)} \\
& =\frac{50 \times 10^{-3}}{0.1}=10,000 \times 10^{-12} \\
& =0.01 \mu \mathrm{~F}
\end{aligned}
$$

The same method may be used for the low-frequency capacitor C 2 . However, the factor $\Delta \mathrm{T}$, which was a worstcase transient time for calculating C 2 , now becomes a bit ambiguous. An analysis of the current cycling on a statistical basis is the best method in all but the simplest systems. The recommended procedure is to decouple using $10 \mu \mathrm{~F}$ to $50 \mu \mathrm{~F}$ capacitors.


Figure 40. Commonly Used Power Distribution and Decoupling System

A discrete inductance of $2 \mu \mathrm{H}$ to $10 \mu \mathrm{H}$ is sometimes used for additional decoupling. However, its benefits are questionable and its usefulness should be evaluated for the individual system. The low-pass filter formed must be capable of keeping the transients confined and off the distribution bus. The possibility of resonance in the inductor or LC combination must be considered.

Noise spikes on the supply voltage line that do not force the gate output below the threshold level do not present a serious problem. Downward spikes as large as 3 V can be tolerated on the supply voltage line without propagating through the logic system. The system designer can be confident that supply voltage noise can be handled even with minimal consideration.

Ground noise, however, cannot be treated lightly. Pulses on a high-impedance ground line can easily exceed the noise threshold. Only if a good ground system is maintained can this problem be overcome. If proper attention is paid to the ground system, noise problems can be minimized.

The concept of a common-ground-plane structure as used in RF and high-speed digital systems is quite different from the concept of the common-ground point as used in lowfrequency circuits. The more closely the chassis and ground can approach to being an integral unit, the better the noise suppression characteristics of the system. Consequently, all
parts of the chassis and ground bus system must be bound tightly together both electrically and mechanically. Floating or poorly grounded sections not only break the integrity of the ground system, but may actually act as a noise distribution system.

For grounds and decoupling on printed circuit boards, the most desirable arrangement is a double-clad or multilayer board with a solid ground plane or a mesh. Where component density prohibits this, the ideal should be relaxed only as far as necessary. Cross talk and ground noise can be reduced on large boards with a ground plane. Some suggestions for board grounds where a plane is not practical are as follows:

1. Use as wide a ground strap as possible.
2. Form a complete loop around the board by bringing both sides of the board through separate pins to the system ground.
The supply voltage line can provide part of the ground mesh on the board, provided it is properly decoupled. For a TTL system, a good guideline is $0.01 \mu \mathrm{~F}$ per synchronously driven gate and at least $0.1 \mu \mathrm{~F}$ for each 20 gates, regardless of synchronization. This capacitance may be lumped, but is more effective if distributed over the board. A good rule is to permit no more than 5 inches of wire between any two package supply-voltage points. Radio-frequency-type capacitors must be used for decoupling. Disk ceramics are best. It is sometimes a good practice to decouple the board from the external supply-voltage line with a $2.2 \mu \mathrm{~F}$ capacitor. However, this is optional and the RF capacitors are still required. In addition, it is recommended that gates driving long lines have the supply voltage decoupled at the gate supply voltage terminal and that the capacitor ground, device ground, and transmission-line ground be connected to a common point.

## Cross Talk

When currents and voltages are impressed on a connecting line in a system, it is impossible for adjacent lines to remain unaffected. Static and magnetic fields interact and opposing ground currents flow, creating linking magnetic fields. These cross-coupling effects are lumped together and called cross talk.

## Back-Panel Interconnections

Interconnecting signal lines can be grouped into three broad categories: coaxial lines, twisted-pair lines, and straight wire lines. Because of the low impedance and shielding characteristics of coaxial cable, its cross talk is minimal and is not a problem with TTL.

Figure 41 illustrates a practical type of signal transmission line. The mutual reactances $L_{m}$ and $C_{m}$ which form the noise coupling paths and the line parameters $\mathrm{L}_{\mathrm{s}}$ and $\mathrm{C}_{\mathrm{g}}$ which govern the line impedance, will vary with the type of line used. Since cross talk is a function of the ratio of the mutual impedances to the line characteristic impedances, the selection of transmission-line type must be at least partially a factor in cross-talk considerations.


Figure 41. Equivalent Circuit for Sending Line
The use of direct-wired connections is the simplest and lowest cost method, but they are also the poorest for noise rejection. If the lead is not cabled tightly together with similar leads, direct leads up to 12 inches in length can be used.

When the length of the signal line is increased, the line impedance is seen by the driving and receiving gates. As shown in Figure 42, a pulse sent along the sending line G3 and $G 4$ will be coupled via the coupling impedance $Z_{c}$ onto the receiving line G1 and G2, which can be in either of the two logic states. The extent to which cross talk will occur depends on the type of lines used and their relationship to each other.

$\left(Z_{C}\right)$ - COUPLING IMPEDANCE
Figure 42. Equivalent Circuit for Cross Talk
The voltage impressed on the sending line by gate G3 is determined by the equation:

$$
\begin{equation*}
\mathrm{v}_{\mathrm{SL}}=\frac{\mathrm{v}_{\mathrm{G} 3} \mathrm{Z}_{0}}{\mathrm{R}_{\mathrm{S} 3}+\mathrm{Z}_{0}} \tag{5}
\end{equation*}
$$

where
$\mathrm{V}_{\mathrm{G} 3}=$ open-circuit logic voltage swing generated by gate G3
$\mathrm{R}_{\mathrm{S} 3}=$ output impedance of gate G3
$\mathrm{Z}_{0}=$ line impedance
$\mathrm{V}_{\mathrm{SL}}=$ voltage impressed on the sending line.
The relationship for the equation is illustrated in Figures 43 and 44.

The coupling from the sending line to the receiving line can be represented by taking coupling impedance $Z_{c}$ into


Figure 43. Capacitive Cross Talk Between Two Signal Lines
account. An equivalent circuit to represent the coupling from the sending line to the receiving line is shown in Figure 44.

As the voltage impressed on the sending line propagates farther along the line, it can be represented as voltage source $\mathrm{V}_{\mathrm{SL}}$ with a source impedance of $\mathrm{Z}_{01}$ (Figure 45 ). $\mathrm{V}_{\mathrm{SL}}$ is then coupled to the receiving line via the coupling capacitance, where the impedance looking into the line is line impedance in both directions. Therefore the equation becomes

$$
\mathrm{V}_{\mathrm{RL}}=\mathrm{v}_{\mathrm{SL}} \frac{\frac{\mathrm{Z}_{0}}{2}}{\left(1.5 \mathrm{Z}_{0}+\mathrm{Z}_{\mathrm{c}}\right)}
$$

The voltage impressed on the receiving line ( $\mathrm{V}_{\mathrm{RL}}$ ) then propagates along the receiving line to gate G 2 which can be considered as an open circuit and voltage doubling occurs. Therefore:

$$
\mathrm{V}_{\mathrm{in}(2)}=2 \mathrm{~V}_{\mathrm{RL}}=\mathrm{V}_{\mathrm{G} 3}\left(\frac{1}{1.5+\frac{\mathrm{Z}_{\mathrm{c}}}{\mathrm{Z}_{0}}}\right)\left(\frac{\mathrm{Z}_{0}}{\mathrm{RS} 3+\mathrm{Z}_{0}}\right)
$$

In the switching period, the transistor has a very low output impedance. Then $\mathrm{R}_{\mathrm{S} 3} \ll \mathrm{Z}_{0}$ and $\mathrm{V}_{\mathrm{in}(2)}$ can be simplified to the following:

$$
\mathrm{V}_{\mathrm{in}(2)}=\mathrm{V}_{\mathrm{G} 3}\left(\frac{1}{1.5+\frac{\mathrm{Z}_{\mathrm{C}}}{\mathrm{Z}_{0}}}\right)
$$

The term $\mathrm{V}_{\mathrm{in}(2) / \mathrm{V}_{\mathrm{G} 3}}$ can be defined as the cross-talk coupling constant.

The worst-case for signal line cross talk occurs when sending and receiving lines are close together but widely separated from a ground return path. The lines then have a high characteristic impedance and a low coupling impedance.

For example, if we assume a coupling impedance of 50 pF at 150 MHz with a line impedance of approximately $200 \Omega$ then:

$$
\frac{\mathrm{V}_{\mathrm{in}(2)}}{\mathrm{V}_{\mathrm{G} 3}}=0.62
$$

This level is unsatisfactory because none of the very highspeed logic circuits has a guaranteed noise margin greater than one-third of the logic swing. Such potential cross talk can be avoided by not using the close spacing of conductors.


Figure 45. Equivalent Cross-Talk Network
Mutual coupling can be reduced by using coaxial cable or shielded twisted pairs. When mutual inductance and capacitance are decreased, line capacitance is increased and imposes restrictions on the driver. Coaxial cable combines very high mutual impedance with low characteristic impedance and shielding. It effectively eliminates cross talk, but is necessary in only the noisiest environments. Twisted pairs are adequate for most applications and are typically less expensive and easier to use.


Figure 44. Coupling Impedances Involved in Cross Talk

## Printed Circuit Card Conductors

Signal interconnections on a two-sided or multilayer printed circuit card can be grouped into two general categories: microstrip lines and strip lines. The microstrip line (Figure 46) consists of a signal conductor separated from a ground plane by a dielectric insulating material. A strip line (Figure 47) consists of a signal conductor within a dielectric insulating material and the conductor being centered between two parallel conductor planes. The important features of these type of printed circuit conductors are that the impedances are highly predictable, can be closely controlled, and the process is relatively inexpensive because standard printed circuit board manufacturing techniques are used. Typical impedances of these types of conductors with respect to their physical size and relative spacings are shown in Tables 7 and 8.

Table 7. Typical Impedance of Microstrip Lines

| Dimensions |  | Line Impedance <br> $\mathbf{Z O}_{\mathbf{O}}(\Omega)$ | Capacitance <br> per Foot (pF) |
| :---: | :---: | :---: | :---: |
| $\mathbf{H}$ (mils) | $\mathbf{W}$ (mils) | 35 | 40 |
| 6 | 20 | 40 | 35 |
| 6 | 15 | 56 | 30 |
| 15 | 20 | 66 | 26 |
| 15 | 15 | 80 | 20 |
| 30 | 20 | 89 | 18 |
| 30 | 15 | 105 | 16 |
| 60 | 20 | 114 | 14 |
| 60 | 15 | 124 | 13 |
| 100 | 20 | 132 | 12 |
| 100 | 15 |  |  |

Table 8. Typical Impedance of Strip Lines

| Dimensions |  | Line Impedance <br> $\mathbf{Z}_{\mathbf{O}}(\mathbf{\Omega})$ | Capacitance <br> per Foot (pF) |
| :---: | :---: | :---: | :---: |
| $\mathbf{H} \mathbf{a}=\mathbf{H}^{\prime} \mathbf{b}=$ <br> (mils) | $\mathbf{W}$ (mils) | (p) |  |
| 6 | 20 | 27 | 80 |
| 6 | 15 | 32 | 70 |
| 10 | 20 | 34 | 67 |
| 10 | 15 | 40 | 56 |
| 12 | 20 | 37 | 57 |
| 12 | 15 | 43 | 48 |
| 20 | 20 | 44 | 48 |
| 20 | 15 | 51 | 42 |
| 30 | 20 | 55 | 39 |
| 30 | 15 | 61 | 35 |

Relative dielectric constant $\approx 5$, and $\mathrm{H}^{\prime} \mathrm{a}=\mathrm{H}^{\prime} \mathrm{b}$
Cross talk on a printed circuit board is also a function of the mutual reactances and the line parameters which govern the line impedance. A microstrip line and a strip line are, by definition, conductors placed relatively close to a ground plane. Therefore, they have at least one inherent property which tends to reduce cross talk. In addition, the thickness $(\mathrm{H})$ of the dielectric and the spacing (S) of the conductors can be implemented selectively to reduce the amount of possible cross talk. The effects of these two dimensions on cross talk have been evaluated and are shown graphically in Figure 48. The data shown can be used to estimate the maximum crosstalk which will be encountered under the most unfavorable conditions.

Figure 46. Microstrip Line


Figure 47. Strip Line


Figure 48. Line Spacing Versus
Cross-Talk Constant

## Transmission-Line Driving Reflections

When the interconnections used to transfer digital information become long enough so that line propagation delay is equal to or greater than the pulse transition times, the effects of reflections must be considered. These reflections are created because most TTL interconnections are not terminated in their characteristic impedance. Reflections lead to reduced noise margins, excessive delays, ringing, and overshoot. Some method must be used to analyze these reflections. Because neither the gate input nor output impedance is linear, basic transmission-line equations are applicable but unwieldy. Transmission-line characteristics of TTL interconnections can be analyzed by using a simple graphic technique.

Figure 49 shows piecewise linear plots of a gate input and both (logic-high and logic-low) states of the output for a typical TTL device. The output curves are plotted with positive slopes. The input is inverted because it is at the receiving end of a transmission line. The logic-high and logiclow intersections are indicated on the plot. These points are the steady-state values which will be observed on a lossless transmission line (Figure 50).

Figure 50 shows a typical TTL interconnection using a twisted-pair cable which, in this example, has a characteristic impedance of approximately $30 \Omega$. To evaluate a logic-high to logic-low 'AS transition see Figures 51 and 52. The equation $-1 / Z_{0}\left(Z_{0}=30 \Omega\right)$, which represents the transmission line, is superimposed on the output characteristic curves in the Bergeron plot. Since evaluation of a logic-high to logic-low transition is desired, the $-1 / \mathrm{Z}_{0}$ line starts at the point of intersection of the impedance curves of the input and output for a logic-high state. The slope $-1 / Z_{0}$ then proceeds toward the logic-low output curve. At time $t_{0}$, the driver output voltage is determined by the intersection of


Figure 49. TTL Bergeron Diagram


Figure 50. 'ALS/'AS Driving Twisted Pair
$-1 / \mathrm{Z}_{0}$ and the logic-low output curve ( 1.2 V ). The transmission-line slope now becomes $1 / \mathrm{Z}_{0}$ and is drawn toward the input curve. At time $t_{1}\left[t_{(n+1)}-t_{n}=\right.$ time delay of line], the receiving gate sees -0.7 V . Now the line slope changes back to $-1 / \mathrm{Z}_{0}$ and the output curve for a logic low is approached. This action continues until the logic-low intersection is reached. Figure 52 plots driver and receiver voltages versus time for this example.

A logic-low to logic-high transition is treated in approximately the same manner (Figure 53). The Bergeron line $-1 / Z_{0}$ starts at the intersection for a logic low. At time $\mathrm{t}_{0}$, the driver output rises to 2.2 V and, at time $\mathrm{t}_{1}$, the receiving gate input goes to approximately 4.35 V . Both output and input voltages are plotted in Figure 54.

Figures 55 through 58 illustrate 'ALS transitions and are treated in the same manner as the 'AS.

The scope photographs in Figures 59 through 66 show the effectiveness of the graphic techniques. In most cases, the calculated and experimental values of voltage steps agree within reason. The ringing that appears for the open wire is not immediately obvious. This is because the input and output curves in this region lie practically along the positive horizontal axis. At the scale used for graphic analysis, it is difficult to go much beyond the first few reflections. The graphic analysis is idealized and stray capacitance and inductance are not considered.


Figure 51. 'AS - ve Transition Bergeron Diagram


Figure 52. 'AS - ve Voltage/Time Plot


Figure 53. 'AS + ve Transition Bergeron Diagram


Figure 54. 'AS + ve Voltage/Time Plot


Figure 55. 'ALS - ve Transition Bergeron Diagram


Figure 56. 'ALS - ve Voltage/Time Plot


Figure 57. 'ALS + ve Transition Bergeron Diagram


Figure 58. 'ALS + ve Voltage/Time Plot


Figure 59. Oscilloscope Photograph of 'AS001 - ve Transition Using $\mathbf{5 0 - O h m}$ Line


TRANSITION $(\mathbf{0} \rightarrow \mathbf{1 )}$
Figure 60. Oscilloscope Photograph of 'AS00 + ve Transition Using 50-Ohm Line


TRANSITION $(1 \rightarrow 0)$
Figure 61. Oscilloscope Photograph of 'AS00-ve Transition Using $\mathbf{2 5 - O h m}$ Line


Figure 62. Oscilloscope Photograph of 'ASOO + ve Transition Using 25-Ohm Line


TRANSITION (1 $\rightarrow 0$ )
Figure 63. Oscilloscope Photograph of 'ALS00A - ve Transition Using $\mathbf{5 0}$-Ohm Line


TRANSITION $(0 \rightarrow 1)$
Figure 64. Oscilloscope Photograph of 'ALS00A + ve Transition Using 50-Ohm Line


Figure 65. Oscilloscope Photograph of 'ALS00A - ve Transition Using 25-Ohm Line


Figure 66. Oscilloscope Photograph of 'ALS00A + ve Transition Using 25-Ohm Line

## References

1. W.C. Elmore and M. Sands, Electronics Experimental Techniques, McGraw-Hill Book Co., New York, 30ff. (1949).
2. M. Williams and S. Miller, Series 54ALS/74ALS Schottky TTL Applications B215, Texas Instruments Limited, Bedford, England, August 1982.

## Acknowledgment

This application report is an updated version of Reference 2 with significant contributions by the technical engineering staff at Texas Instruments and particularly by Rock Cozad, Rich Moore, and Bob Strong.

## Appendix A <br> Normalized Load Factors

Normalizing output drive capability and input current requirements can be very useful to designers of systems using two or more of the TI TTL series of devices. It provides a set of load factors (input cuurent requirements in Table A-1), which can be summed and compared directly to the fanout capability (see Table A-2) of the output being considered. The load factor values shown are valid for any input rated at one unit load.

The loading of these type of outputs can be checked from any column. However, most designs use one of the series as the basic building block and, since the tables cover each series individually, the designer has the choice of working from the column containing the normalized fanout. As an example, the designers of a system using series 'AS as the basic circuit will probably find that the use of the 'AS00 and 'AS1000 columns will suit best because both fanout and load factors are expressed for these series of devices.

The use of these simple and easy-to-remember numbers was developed within each series to make the verification of output loading a matter of counting the number of inputs connected to a particular output. When mixtures of series are used, a common denominator (normalized factor) becomes useful.

## USE OF TABLES A-1 AND A-2

Every possible combination of the seven $54 / 74$ TTL families is included in these tables. If, for example, the existing system used 74 S series logic and it is desired that some of it be replaced by series 74 ALS logic, a quick check should be made on whether the 'ALS can be supplied with sufficient input current. By taking the 74 S row and 'ALS, column figures of 2.5 and 20 are obtained for high- and low-level loads, respectively (see Table A-1). This indicates that, for high logic levels, two and one-half 'ALS gates can be driven for each 'S series gate removed. However, if more 74S series gates are being driven by this 'ALS device, the fanout between 'ALS and 'S series gate is required, you can now use Table A-2.

The 'ALS row and the 'S column are chosen. The figures are 8 for the high-logic level and 4 for the low-logic level. In this case the lowest figure is taken so that the interconnection is reliable for both logic states. So each 'ALS gate inserted will drive 4 'S series gates.

Table A-1. Normalized Input Currents

| SERIES | 1/0 | INPUT CURRENT (mA) | INPUT CURRENT NORMALIZED |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | '00 | 'H00 | ${ }^{\prime} \mathbf{L O O}$ | 'LSOO | 'S00 | 'AS00 | 'ALSOOA | 'AS1000 | 'ALS 1000A |
| 54/7400 | HI | 0.04 | 1 | 0.8 | 4 | 2 | 0.8 | 2 | 2 | 2 | 2 |
| 54/7400 | LO | 1.6 | 1 | 0.8 | 8.89 | 4 | 0.8 | 3.2 | 16 | 3.2 | 16 |
| $54 \mathrm{H} / 74 \mathrm{H0O}$ | HI | 0.05 | 1.25 | 1 | 5 | 2.5 | 1 | 2.5 | 2.5 | 2.5 | 2.5 |
| $54 \mathrm{H} / 74 \mathrm{HOO}$ | 10 | 2 | 1.25 | 1 | 11.11 | 5 | 1 | 4 | 20 | 4 | 20 |
| 54/74LO0 | HI | 0.01 | 0.25 | 0.2 | 1 | 0.5 | 0.2 | 0.5 | 0.5 | 0.5 | 0.5 |
| 54/74L00 | LO | 0.18 | 0.11 | 0.09 | 1 | 0.45 | 0.09 | 0.36 | 1.8 | 0.36 | 1.8 |
| 54LS/74LS00 | HI | 0.02 | 0.5 | 0.4 | 2 | 1 | 0.4 | 1 | 1 | 1 | 1 |
| 54LS/74LS00 | LO | 0.4 | 0.25 | 0.2 | 2.22 | 1 | 0.2 | 0.8 | 4 | 0.8 | 4 |
| 54S/74S00 | HI | 0.05 | 1.25 | 1 | 5 | 2.5 | 1 | 2.5 | 2.5 | 2.5 | 2.5 |
| 54S/74S00 | LO | 2 | 1.25 | 1 | 11.11 | 5 | 1 | 4 | 20 | 4 | 20 |
| 54AS/74AS00 | HI | 0.02 | 0.5 | 0.4 | 2 | 1 | 0.4 | 1 | 1 | 1 | 1 |
| 54AS/74AS00 | LO | 0.5 | 0.31 | 0.25 | 2.78 | 1.25 | 0.25 | 1 | 5 | 1 | 5 |
| 54ALS/74ALS00A | HI | 0.02 | 0.5 | 0.4 | 2 | 1 | 0.4 | 1 | 1 | 1 | 1 |
| 54ALS/74ALSOOA | LO | 0.1 | 0.06 | 0.05 | 0.56 | 0.25 | 0.05 | 0.2 | 1 | 0.2 | 1 |
| 54AS1000 | HI | 0.02 | 0.5 | 0.4 | 2 | - 1 | 0.4 | 1 | 1 | 1 | 1 |
| 54AS1000 | LO | 0.5 | 0.31 | 0.25 | 2.78 | 1.25 | 0.25 | 1 | 5 | 1 | 5 |
| 54ALS1000A | HI | 0.02 | 0.5 | 0.4 | 2 | 1 | 0.4 | 1 | 1 | 1 | 1 |
| 54ALS1000A | LO | 0.1 | 0.06 | 0.05 | 0.56 | 0.25 | 0.05 | 0.2 | 1 | 0.2 | 1 |

Table A-1 is normally used (in combination with Table A-2) when replacing one logic family with another in an existing system.

Table A-2 is normally used when originally designing a system which employs several TTL families to optimize performance.

Table A-2. Fanout Capability (Output Currents Normalized to Input Currents)

| SERIES | 1/0 | OUTPUT <br> CURRENT <br> (mA) | OUTPUT DRIVE NORMALIZED |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | '00 | 'H00 | 'L00 | 'LS00 | 'S00 | 'AS00 | 'ALSO00A | 'AS1000 | 'ALS 1000A |
|  |  |  | * HI 0.04 | 0.05 | 0.01 | 0.02 | 0.05 | 0.02 | 0.02 | 0.02 | 0.02 |
|  |  |  | tlo 1.6 | 2 | 0.18 | 0.4 | 2 | 0.5 | 0.1 | 0.5 | 0.1 |
| 54/7400 | HI | 0.4 | 10 | 8 | 40 | 20 | 8 | 20 | 20 | 20 | 20 |
| 54/7400 | LO | 16 | 10 | 8 | 88.89 | 40 | 8 | 32 | 160 | 32 | 160 |
| 54H/74HOO | HI | 0.5 | 12.5 | 10 | 50 | 25 | 10 | 25 | 25 | 25 | 25 |
| 54H/74H00 | LO | 20 | 12.5 | 10 | 111.11 | 50 | 10 | 40 | 200 | 40 | 200 |
| 54 LOO | HI | 0.1 | 2.5 | 2 | 10 | 5 | 2 | 5 | 5 | 5 | 5 |
| 54 LOO | LO | 2 | 1.25 | 1 | 11.11 | 5 | 1 | 4 | 20 | 4 | 20 |
| 74L00 | HI | 0.2 | 5 | 4 | 20 | 10 | 4 | 10 | 10 | 10 | 10 |
| 74L00 | LO | 3.6 | 2.25 | 1.8 | 20 | 9 | 1.8 | 7.2 | 36 | 7.2 | 36 |
| 54LS/74LS00 | HI | 0.4 | 10 | 8 | 40 | 20 | 8 | 20 | 20 | 20 | 20 |
| 54LSOO | LO | 4 | 2.5 | 2 | 22.22 | 10 | 2 | 8 | 40 | 8 | 40 |
| 74LSOO | LO | 8 | 5 | 4 | 44.44 | 20 | 4 | 16 | 80 | 16 | 80 |
| 54S/74S00 | H! | 1 | 25 | 20 | 100 | 50 | 20 | 50 | 50 | 50 | 50 |
| 54S/74S00 | LO | 20 | 12.5 | 10 | 111.11 | 50 | 10 | 40 | 200 | 40 | 200 |
| 54AS/74ASOO | Hi | 2 | 50 | 40 | 200 | 100 | 40 | 100 | 100 | 100 | 100 |
| 54AS/74AS00 | LO | 20 | 12.5 | 10 | 111.11 | 50 | 10 | 40 | 200 | 40 | 200 |
| 54ALS/74ALS00A | HI | 0.4 | 10 | 8 | 40 | 20 | 8 | 20 | 20 | 20 | 20 |
| 54ALSOOA | LO | 4 | 2.5 | 2 | 22.22 | 10 | 2 | 8 | 40 | 8 | 40 |
| 74ALSOOA | LO | 8 | 5 | 4 | 44.44 | 20 | 4 | 16 | 80 | 16 | 80 |
| 54AS1000 | HI | 40 | 1000 | 800 | 4000 | 2000 | 800 | 2000 | 2000 | 2000 | 2000 |
| 54AS1000 | LO | 40 | 25 | 20 | 222.22 | 100 | 20 | 80 | 400 | 80 | 400 |
| 74AS1000 | HI | 48 | 1200 | 960 | 4800 | 2400 | 960 | 2400 | 2400 | 2400 | 2400 |
| 74AS1000 | LO | 48 | 30 | 24 | 266.67 | 120 | 24 | 96 | 480 | 96 | 480 |
| 54ALS1000A | HI | 1 | 25 | 20 | 100 | 50 | 20 | 50 | 50 | 50 | 50 |
| 54ALS1000A | LO | 12 | 7.5 | 6 | 66.67 | 30 | 6 | 24 | 120 | 24 | 120 |
| 74ALS1000A | HI | 2 | 65 | 52 | 260 | 130 | 52 | 130 | 130 | 130 | 130 |
| 74ALS1000A | LO | 24 | 15 | 12 | 133.33 | 60 | 12 | 48 | 240 | 48 | 240 |

*Input Current HI
${ }^{\dagger}$ Input Curent LO

# Appendix $B$ 

Letter Symbols, Terms, and Definitions

These symbols, terms, and definitions are in accordance with those currently agreed upon by the JEDEC Council of the Electronics Industries Association (EIA) for use in the USA and by the International Electrotechnical Commission (IEC) for international use. The definitions are grouped into sections applying to voltages, currents, switching characteristics, and classification of circuit complexity.

## VOLTAGES

VIH High-level input voltage An input voltage level within the more positive (less negative) of the two ranges of values used to represent the binary variables. A minimum value is specified which is the least-positive (most-negative) value of high-level input voltage for which operation of the logic element within specification limits is guaranteed.
VIL Low-level input voltage
An input voltage level within the less positive (more negative) of the two ranges of values used to represent the binary variables. A maximum value is specified which is the most-positive (least-negative) value of low-level input voltage for which operation of the logic element within specification limits is guaranteed.
VT $+\quad$ Positive-going threshold voltage
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}}-$.
VT - Negative-going threshold voltage
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}}+$.
VOH High-level output voltage
The voltage at an output terminal for a specified output current $\mathrm{I}_{\mathrm{OH}}$ with input conditions applied that according to the product specification will establish a high level at the output.

## VOL Low-level output voltage

The voltage at an output terminal for a specified output current IOL with input conditions applied that according to the product specification will establish a low level at the output.

## VO(on) On-state output voltage

The voltage at an output terminal for a specified output current with input conditions applied that according to the product specification will cause the output switching element to be in the on state.

Note: This characteristic is usually specified only for outputs not having internal pull-up elements.

## $\mathbf{V O}$ (off) Off-state output voltage

The voltage at an output terminal for a specified output current with input conditions applied that according to the specification will cause the output switching element to be in the off state.
Note: This characteristic is usually specified only for outputs not having internal pull-up elements.

## CURRENT

IIH High-level input current
The current flowing into* an input when a specified high-level voltage is applied to that input.
IIL Low-level input current
The current flowing into* an input when a specified low-level voltage is applied to that input.

[^81]
## IOH High-level output current

The current flowing into* the output with a specified high-level output voltage $\mathrm{V}_{\mathrm{OH}}$ applied.
Note: This parameter is usually specified for open-collector outputs intended to drive other logic circuits.

## IO(off) Off-state output current

The current flowing into* an output with a specified output voltage applied and input conditions applied that according to the product specification will cause the output switching element to be in the off state.

Note: This parameter is usually specified for open-collector outputs intended to drive devices other than logic circuits or for three-state outputs.

## IOS Short-circuit output current

The current flowing into* an output when that output is short-circuited to ground (or other specified potential) with input conditions applied to establish the output logic level farthest from ground potential (or other specified potential).
ICCH Supply current, output(s) high
The current flowing into* the $\mathrm{V}_{\mathrm{CC}}$ supply terminal of a circuit when the reference output(s) is (are) at a high-level voltage.

ICCL Supply current, output(s) low
The current flowing into ${ }^{*}$ the $V_{C C}$ supply terminal of a circuit when the reference output(s) is (are) at a low-level voltage.

## DYNAMIC CHARACTERISTICS

$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 a change of output state with each clock pulse.
tHZ Output disable time (of a three-state output) from high level The time between the specified reference points on the input and output voltage waveforms with the three-state output changing from the defined high level to a high-impedance (off) state.
${ }^{\mathbf{t}} \mathrm{LZ} \quad$ Output disable time (of a three-state output) from low level The time between the specified reference points on the input and output voltage waveforms with the three-state output changing from the defined low level to a high-impedance (off) state.
tPLH Propagation delay time, low-to-high-level output
The time between the specified reference points on the input and output voltage waveforms with the output changing from the defined low level to the defined high level.

## tPHL Propagation delay time, high-to-low-level output

The time between the specified reference points on the input and output voltage waveforms with the output changing from the defined high level to the defined low level.
tTLH Transition time, low-to-high-level output
The time between a specified low-level voltage and a specified high-level voltage on a waveform that is changing from the defined low level to the defined high level.

## tTHL Transition time, high-to-low-level output

The time between a specified high-level voltage and a specified low-level voltage on a waveform that is changing from the defined high level to the defined low level.
$t_{w} \quad$ Average pulse width
The time between $50 \%$ amplitude points (or other specified reference points) on the leading and trailing edges of a pulse.

[^82]
## th Hold time

The time interval for which a signal or pulse is retained at a specified input terminal after an active transition occurs at another specified input terminal.

## trelease

Release time
The time interval between the release from a specified input terminal of data intended to be recognized and the occurrence of an active transition at another specified input terminal.

Note: When specified, the interval designated "release time" falls within the setup interval and constitutes, in effect, a negative hold time.
$\mathbf{t}_{\text {su }} \quad$ Setup time
The time interval for which a signal is applied and maintained at a specified input terminal before an active transition occurs at another specified input terminal.
tZH Output enable time (of a three-state output) to high level
The time between the specified reference points on the input and output voltage waveforms with the three-state output changing from a high-impedance (off) state to the defined high level.
tZL Output enable time (of a three-state output) to low level
The time between the specified reference points on the input and output voltage waveforms with the three-state output changing from a high-impedance (off) state to the defined low level.

## CLASSIFICATION OF CIRCUIT COMPLEXITY

Gate equivalent circuit
A basic unit-of-measure of relative digital-circuit complexity. The number of gate equivalent circuits is that number of individual logic gates that would have to be interconnected to perform the same function.

## LSI Large-scale integration

A concept whereby a complete major subsystem or system function is fabricated as a single microcircuit. In this context a major subsystem or system, whether logical or linear, is considered to be one that contains 100 or more equivalent gates or circuitry of similar complexity.

MSI Medium-scale integration
A concept whereby a complete subsystem or system function is fabricated as a single microcircuit. The subsystem or system is smaller than for LSI, but whether digital or linear, is considered to be one that contains 12 or more equivalent gates or circuitry of similar complexity.

SSI Small-scale integration
Integrated circuits of less complexity than medium-scale integration (MSI).

[^83]
# Error Detection and Correction Using SN54/74ALS632A, SN54/74ALS633 through SN54/74ALS635 

Robert Breuninger<br>Contributors<br>W.T. Greer, Jr., David Mondeel, Jay Maxey

## IMPORTANT NOTICE

Texas Instruments (TI) reserves the right to make changes in the devices or the device specifications identified in this publication without notice. TI advises its customers to obtain the latest version of device specifications to verify, before placing orders, that the information being relied upon by the customer is current.

TI warrants performance of its semiconductor products, including SNJ and SMJ devices, to current specifications in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent TI deems such testing necessary to support this warranty. Unless mandated by government requirements, specific testing of all parameters of each device is not necessarily performed.

In the absence of written agreement to the contrary, TI assumes no liability for TI applications assistance, customer's product design, or infringement of patents or copyrights of third parties by or arising from use of semiconductor devices described herein. Nor does TI warrant or represent that any license, either express or implied, is granted under any patent right, copyright, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor devices might be or are used.

## INTRODUCTION

## NEED FOR ERROR CORRECTION

With memory systems continuing to expand and the expectation of 256 K DRAMs in the near future, it has become increasingly important that system designers consider error detection and correction. Generally, the larger the chip density, the greater the probability for device errors. It is easy to recognize this probability when one considers that a 32 -bit $\times 64 \mathrm{~K}$ memory, using 64 K DRAMs, equates to approximately 2.1 million bits of information. This expands to 8.4 million bits of information when using 256 K DRAMs. For memory sizes larger than $1 / 2$ million bits, it is generally considered that error detection and correction is required to guarantee high reliability.

The SN54/74ALS632A, SN54/74ALS633 through SN54/74ALS635 provide a simple solution to these requirements in 32 -bit machines. In addition, the 'ALS632A and ALS633 provide the necessary hardware to perform bytewrite operations which are typically used in the more advanced systems. To ensure the integrity of the error detection and correction circuit itself, diagnostic capabilities have been provided in all four devices.

The 'ALS632A series devices are not limited to only 32 -bit systems. They can easily be implemented in 16 - or 24 -bit systems. In the case of 16 -bit systems, the additional memory needed for holding the check bits can be reduced when compared to conventional 16-bit EDAC's.

The pin function table and mechanical data for the 'ALS632A, ALS633 through 'ALS635 are shown respectively as Table 1 and Figure 1.

## OPERATIONAL DESCRIPTION

## WRITE MODE

During a memory write cycle, the EDAC is required to generate a 7 -bit check word to accompany the 32 -bit data word before being written into memory. To place the 'ALS632A, 'ALS633 through 'ALS635 in the write mode, simply take S1 and S0 low. Output enable controls $\overline{\mathrm{OEB}} 0$ through $\overline{\mathrm{OEB}} 3$ for the 'ALS632A, 'ALS633, or $\overline{\mathrm{OEDB}}$ for the 'ALS634, 'ALS635, must be taken high before the data word can be applied. Output enable control $\overline{\text { OECS }}$ must be taken low to pass the check word to the external bus.

The check word will be generated in not more than 48 ns * after the data word has been applied. The 'ALS632A series EDACs can be made to appear transparent to memory, during the write mode, because typical write times of most DRAMs are much larger than the propagation delay of data to check word.

## READ-FLAG-CORRECT OPERATION

During a memory read cycle, the function of the 'ALS632A series EDACs is to compare the 32-bit data word against the 7 -bit check word previously stored in memory. It will then flag and correct any single-bit error which may have occurred. Single bit errors will be detected through the $\overline{\mathrm{ERR}}$ flag and double bit errors will be detected through the $\overline{\text { MERR }}$ flag. Figure 2 shows a typical timing diagram of the read-flag-correct operation.

When SO is taken high, the EDAC will internally begin the correction process, although it should be noted that the error flags are enabled while in the read mode. For many applications, the simplest operation can be obtained by always executing the correction cycle, regardless if a single-bit error has occurred.

## IMPORTANT TIMING CONSIDERATIONS FOR READ-FLAG-CORRECT MODE

The most frequently asked question for an EDAC is how fast can a correction cycle be executed. Before S0 can be taken high, the data and check word must be set up at least $10 \mathrm{ns*}$. In addition, the data and check word must be held for at least $15 \mathrm{~ns} *$ after S 0 goes high. This ensures the data and check word is saved in the EDAC's input latches. After the hold time has been satisfied, the source which is driving the data bus can be placed in high impedance and the EDAC's output drivers can be enabled. This is accomplished by taking $\overline{\mathrm{OEB}} 0$ through $\overline{\mathrm{OEB}} 3$ ('ALS632A, 'ALS633) or $\overline{\mathrm{OEDB}}$ ('ALS634, 'ALS635) low.

If the minimum data set up time is used as a reference, and the output drivers are enabled after the minimum data hold time, then correction will be accomplished in not more than $58 \mathrm{~ns}^{*}$.

## READ MODIFY-WRITE OPERATIONS

The'ALS632A and 'ALS633 contain the necessary hardware to perform byte-write operations. The 'ALS634 and 'ALS635 are not capable of byte-write operations because they do not contain an output data latch or individual byte controls. When performing a read-modifywrite function, typically the user would first want to perform the read-flag-correct cycle as discussed before, and shown in Figure 2. This ensures that corrected data is used at the start of the modity-write operation.

The corrected data is then latched into the output data latch by taking $\overline{\text { LEDBO }}$ from low to high. Upon completing this, modifying any byte or bytes is easily accomplished by taking the appropriate byte control $\overline{\mathrm{OEB}} 0$ through $\overline{\mathrm{OEB}} 3$ high. This allows the user to place the modified byte or bytes back onto the data bus while retaining the other byte or bytes. An example of a read-

[^84]
## ceramic packages－side－braze（JD suffix）

This is a hermetically sealed ceramic package with a metal cap and side－brazed tin－plated leads．

| ${ }^{\prime} A L S 632 A, A I$ |  | VIEW | JD PACKAGE ） |
| :---: | :---: | :---: | :---: |
| LEDB0 |  | $\bigcirc_{52}$ | V̌cc |
| MERR | 2 | 51 | ¢ s1 |
| $\overline{E R R}$ | 3 | 50 | 1 50 |
| DBO | 4 | 49 | D D 31 |
| DB1 | 5 | 48 | －DB30 |
| DB2 | 6 | 47 | D D 29 |
| DB3 | 7 | 46 | D DB28 |
| DB4 | 8 | 45 | D DB27 |
| DB5 | 9 | 44 | 万 DB26 |
| OEB0 | 10 | 43 | 万OEB3 |
| DB6 | 11 | 42 | 万DB25 |
| DB7 | 12 | 41 | 万DB24 |
| GND | 13 | 40 | $f$ GND |
| DB8 | 14 | 39 | －DB23 |
| D89 | 15 | 38 | －DB22 |
| OEB1 | 16 | 37 | 万 $\overline{O E B} 2$ |
| DB10 | 17 | 36 | 万 DB21 |
| DB11 | 18 | 35 | ¢ DB20 |
| DB12 | 19 | 34 | 7 DB 19 |
| DB13 | 20. | 33 | 万DB18 |
| DB14 | 21 | 32 | －DB17 |
| DB15 | 22 | 31 | ¢DB16 |
| CB6 | 23 | 30 | －CBo |
| CB5 ${ }^{-}$ | 24 | 29 | －CB1 |
| CB4 | 25 | 28 | －CB2 |
| $\overline{O E C B}$ | 26 | 27 | $\square \mathrm{CB3}$ |

＇ALS634，＇ALS635 ．．．．JD PACKAGE （TOP VIEW）

| ERR | 1 | $\mathrm{O}_{48}$ | Vcc |
| :---: | :---: | :---: | :---: |
| ERR | 2 | 47 | S1 |
| DB0 | 3 | 46 | $\square \mathrm{so}$ |
| DB1 | 4 | 45 | 〕DB3 |
| DB2 | 5 | 44 | －DB30 |
| B3 | 6 | 43 | ］DB29 |
| DB4 | 7 | 42 | －DB28 |
| DB5 | 8 | 41 | DB2 |
| OEDB | 9 | 40 | $\square \mathrm{DB26}$ |
| DB6 | 10 | 39 | DB25 |
| B7 | 11 | 38 | $\square \mathrm{DB24}$ |
| GND | 12 | 37 | $\square \mathrm{GND}$ |
| DB8 | 13 | 36 | －DB23 |
| DB9 | 14 | 35 | ］DB22 |
| DB10 | 15 | 34 | ］DB2 |
| DB11 | 16 | 33 | $\square$ DB20 |
| DB12 | 17 | 32 | D DB19 |
| DB13 | 18 | 31 | $\square \mathrm{DB18}$ |
| DB14 | 19 | 30 | DB17 |
| DB15 | 20 | 29 | $\square \mathrm{DB16}$ |
| CB6 | 21 | 28 | 乙сво |
| CB5 | 22 | 27 | －CB1 |
| CB4 | 23 | 26 | 乙св2 |
| OECB | 24 | 25 | －CB3 |


（See Note a）

| DIM | 48 | 52 |
| :--- | :---: | :---: |
| $A \pm 0,25 \cdot(0.010)$ | $15,24(0.600)$ | $15,24(0.600)$ |
| B MAX | $62,2(2.45)$ | $67,3(2.65)$ |
| C NOM | $15,0(0.590)$ | $15,0(0.590)$ |

ALL DIMENSIONS ARE IN MILLIMETERS AND PARENTHETICALLY IN INCHES

NOTE：a．Each pin centerline is located within $0,25(0.010)$ of its true longitudinal position．
Figure 1．Mechanical Data for＇ALS632A，＇ALS633 through＇ALS635

Table I. Pin Function for 'ALS632A, ‘ALS633 through 'ALS635

| PIN NAME | DESCRIPTION |
| :---: | :---: |
| S1, S0 | Selects the operating mode of the EDAC |
| DB0 through DB31 | 1/O port for entering or outputing data |
| $\overline{\mathrm{OEB}} 0$ through $\overline{\mathrm{OEB}} 3$ (ALS632A, 'ALS633) | Three state control for the data I/O port. A high allows data to be entered, and low outputs the data. Each pin controls 8 data I/O ports (or one byte). $\overline{O E B} 0$ controls DB0 through DB7, $\overline{\mathrm{OEB}} 1$ controls DB8 through DB15, $\overline{\mathrm{OEB}} 2$ controls DB16 through DB23, and $\overline{\text { OEB3 }}$ controls DB24 through DB31. |
| $\begin{aligned} & \overline{\text { OEDB }} \\ & \text { (ALS634, ALS635) } \end{aligned}$ | Three state control for the data $1 / \mathrm{O}$ port. When low allows data to outputed and a high allows data to be entered. |
| $\overline{\text { LEDB0 }}$ | Controls the dataword output latch. When low, the data output latch is transparent. When high, the latch stores whatever data was setup at its inputs when the last low to high transistion occured on the pin. |
| CS0 through CS6 | I/O Port for entering or outputing the checkword. It is also used to output the syndrome error code during the error correction mode. |
| $\overline{\text { OECS }}$ | Three state control for the checkword I/O port. A high allows data to be entered and a low allows either the checkword or syndrome code (depending on EDAC mode) to be outputed. |
| ERR | Single error output flag, a low indicates at least a single bit error. |
| $\overline{M E R R}$ | Multiple error output flag, when low indicates two or more errors present |



Figure 2. Read-Flag-Correct Timing Diagram
modify-write for byte 0 is shown in Figure 3. Since the check word is no longer valid for the modified data word, a new one is easily generated by taking S0 and S1 low. After the appropriate propagation delay, the new check word will be available.

## IMPORTANT TIMING CONSIDERATIONS FOR READMODIFY WRITE OPERATIONS

$\overline{\text { LEDB0 }}$ should not be brought from low to high until 45 ns * after S0 goes high. This will ensure that corrected data is latched into the data output latches. On the other hand, $\overline{\text { LEDB } 0}$ should be brought high no later than 0 ns *
before S0 and S1 goes low. Again, this is to ensure that the corrected data is stored into the data output latches. Also of importance is the new check word will be available no later than $48 \mathrm{~ns} *$ after S0 and S1 goes low.

## DIAGNOSTIC MODE OPERATION

The purpose of the diagnostic mode is to provide the user with the capability of easily detecting when the EDAC or memory is failing. There are several possibilities as to how a user might employ this feature, but Figure 4 shows a typical timing diagram of some diagnostics which can be performed with these devices. Generally, the user would first place the EDAC in the read mode $(\mathrm{SO}=\mathrm{L}, \mathrm{S} 1=\mathrm{H})$, then apply a valid check word and data word. A valid check word is one in which the user knows what the associated data word. The user would next place the EDAC into the diagnostic mode by taking S0 high, and S1 low. This latches the valid check word into its input latches but leaves the data input latches transparent. To verify that the valid check word was latched properly, $\overline{\text { OECS }}$ can be taken low causing the valid check word to be placed back onto the bus. Since the data input latches remain transparent, this allows the user to apply various diagnostic data words
against the valid check word. A diagnostic data word is one in which either a single or double bit error exists. In either case, the error flags should respond. The output data latch can be verified by taking $\overline{\text { LEDBO }}$ high and confirming the stored diagnostic data word is the same. This is made possible because error correction is disabled while in the diagnostic mode ( $\mathrm{S} 0=\mathrm{H}, \mathrm{S} 1=\mathrm{L}$ ). Taking S1 high and $\overline{\text { LEDBO }}$ low will verify that the EDAC will correct the data word. Also, the error syndrome code can be verified by taking OECS low. It should be noted that only the 'ALS632A and 'ALS633 are capable of this pass through verification of the diagnostic data word. The 'ALS634 and 'ALS635 do not have the output data latch required to perform this function.

## 16-BIT SYSTEMS USING THE ALS632A SERIES EDACs

The 'ALS632A series EDACs can reduce the memory size required in 16 -bit systems where conventional 16 -bit EDACs ( 6 check bits, 16 data bits) are presently used. Figure 5 shows the typical system architecture for the 16-bit EDAC. In this system, 88 devices would be required for the 22 -bit $\times 256 \mathrm{~K}$ memory array, assuming 64 K DRAMs are used. It is easy to see that $27.3 \%$, or 24 devices, are


Figure 3. Read-Modify-Write Operation
required for storing the check bits. When using the'ALS632A series EDACs, the memory required for the check bits can be reduced to $17.9 \%$, or only 14 devices. This reduces the total number of DRAMs required by 10 devices. Figure 6 shows the architecture when using the 32-bit EDAC. The
four 'LS646s are used to group two 16 -bit data words into one 32-bit data word. In addition, this type of system can be used in byte-write operations where the other system cannot.


Figure 4. Diagnostic Mode Timing Diagram


Figure 5. 16-Bit System using Conventional 16-Bit EDAC


Figure 6. 16-Bit System using 32-Bit EDAC

Texas Instruments assumes no responsibility for infringement of patents or rights of others based on Texas Instruments applications assistance or product specifications, since TI does not possess full access to data concerning the use or applications of customer's products. TI also assumes no responsibility for customer product designs.

# MEMORY MAPPING USING SN54/74LS610 THRU SN54/74LS613 

Author<br>Thomas J. Tyson<br>Contributors<br>Deene Ogden, Jim Gallia and Dennis Frailey<br>Low Power Schottky Applications Group

## INTRODUCTION

Microprocessors, due to the advent of high density semiconductor memories (i.e., 64 K or larger), are being used more and more in systems featuring memory structures larger than 64 K bytes. The majority of the microprocessors in use or available today have a 16 -bit address bus, with a maximum addressing capability of 64 K words. Due to this limitation, some sort of memory mapping is necessary to adapt these microprocessors to applications where large memory structures are required.

The memory mappers (SN54/74LS610 through SN54/74LS613) from TI were designed to alleviate this addressing limitation. These devices employ a paged memory mapping technique in expanding the system memory address bus by 8 bits, thus effectively increasing the system addressing capability by a factor of $2^{8}$ or 256 . For microprocessors with a 16 -bit address bus (such as the Z-80, the 8085 and the 6800), this results in an increase in the maximum addressing capability from 64 K bytes to 16 M bytes and for the TMS 9900 (which has a 15 -bit address bus), the result is an increase from 32 K words to 8 M words (word = 2 bytes).

In the mapping operation, the four MSBs of the microprocessor address word are used to access one of the sixteen 12-bit registers of the memory mapper's $16 \times 12$-bit RAM array. Each mapper register is capable of holding a 12 -bit address which will be termed the page address and will be used as the 12 MSBs of the memory address bus. The remaining 12 bits ( 11 in the case of the TMS9900) of the microprocessor address bus will be transferred directly to memory from the microprocessor and will be used to address the memory locations within each page. (See Figure 1)

The memory will be organized into $2^{x}$ pages (where $x$ equals the number of bits of the page address) with $2^{n-4}$ words or bytes (where $n$ is the bit length of the microprocessor address bus) per page. Once loaded, the mapper can access only 16 pages or 64 K bytes ( 32 K words in the

TMS9900 case). In order to access more pages, the memory mapper RAM array must be reloaded with 16 new page addresses. This is done by the microprocessor via the data bus with the mapper in the WRITE mode. (A more detailed description of the modes of operation will be given later in this report.)

## FUNCTIONAL DESCRIPTION

A functional block diagram of the SN54/74LS610 memory mapper, which consists mainly of: a 4-bit 2 -to-1 multiplexer, a $16 \times 12$-bit RAM array, a 12 -bit 2 -to- 1 multiplexer, 243 -state buffers, control logic and in the case of 'LS610 and 'LS611, a 12-bit transparent latch, as shown in Figure 2. Table I lists the functional differences between the 'LS610, 'LS611, 'LS612, and 'LS613. Table II lists the function of each pin.

Depending on the state of the input control signals (i.e., $\overline{\mathrm{CS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{STROBE}}, \overline{\mathrm{MM}}$, and $\overline{\mathrm{ME}}$ ), the mapper can be operated in three basic modes of operation, I/O (READ or WRITE), MAP and PASS. An explanation of each mode and the control signals necessary to achieve that mode of operation is given below: (Refer to Table III)

## Input/Output Mode

In this mode a page address can be loaded either into a mapper register or can be read from a memory mapper register depending on the state of the R/W (READ/ WRITE) input. This input signal controls either the READ or WRITE function of the I/O Mode.

## WRITE Mode

One of the sixteen 12-bit registers is loaded with a page address via the D0-D11 I/O ports from the microprocessor. The address of the selected register is inputted via the RSO-RS3 inputs and is usually the four LSBs of the microprocessor address word. The chip select ( $\overline{\mathrm{CS}}$ ), the strobe ( $\overline{\text { STROBE }}$ ) and $\mathrm{R} / \overline{\mathrm{W}}$ controls should all be low.


Figure 1. Mapping Operation


Figure 2. Logic Diagram of the Memory Mapper 'LS610

Table I. Device Comparison

| Device | Map Outputs <br> Latched | Map <br> Output Type |
| :---: | :---: | :---: |
| SN54/74LS610 | Yes | 3-State |
| SN54/74LS611 | Yes | Open-collector |
| SN54/74LS612 | No | 3-State |
| SN54/74LS613 | No | Open-collector |

## READ Mode

The contents of one of the sixteen 12 -bit registers is read from the mapper via the D0-D11 I/O ports. As in the WRITE mode, the mapper register is selected by the address on the RSO-RS3 inputs. Again chip select ( $\overline{\mathrm{CS}}$ ) should be low, while the $R / \bar{W}$ should be kept high.

## MAP Mode

The contents of one of the sixteen 12 -bit memory mapper registers is outputted to the system address bus via the MO0-MO11 outputs. The address on MA0-MA3 selects the mapper register and is usually the four MSBs of the microprocessor address word. The chip select ( $\overline{\mathrm{CS}}$ ) must be inactive (high), the map mode ( $\overline{\mathrm{MM}}$ ) control and the map enable ( $\overline{\mathrm{ME}}$ ) must both be active (low). The $\mathrm{n}-4$ LSBs, where $n$ equals the microprocessor address bit length, of the microprocessor address bus will be transferred directly to memory from the microprocessor, while the remaining 12 MSBs of the system address bus will be driven onto the bus by the memory mapper.

Table II. Pin Functions

| Pin | Pin Name | Functional Description |
| :---: | :---: | :---: |
| $\begin{gathered} 7-12 \\ 29-34 \end{gathered}$ | D0 thru D11 | I/O connections to data and control bus used for reading from and writing to the map register selected by RSO-RS3 when $\overline{\mathrm{CS}}$ is low. Mode controlled by R/W . (DO corresponds to MOO and is the most significant bit.) |
| 36, 38, 1, 3 | RSO thru RS3 | Register select inputs for 1/O operations. (RS3 is the least significant bit.) |
| 6 | $R \bar{W}$ | Read or write control used in I/O operations to select the condition of the data bus. When high, the data bus outputs are active for reading the map register. When low, the data bus is used to write into the register. |
| 5 | STROBE | Strobe input used to enter data into the selected map register during I/O operations. |
| 4 | $\overline{\text { CS }}$ | Chip select input. A low input level selects the memory mapper (assuming more than one used) for an I/O operation. |
| 35, 37, 39, 2 | MAO thru MA3 | Map address inputs to select one of 16 map registers when in map mode ( $\overline{\mathrm{MM}}$ low and $\overline{\mathrm{CS}}$ high). (MA3 is the least significant bit.) |
| $\begin{aligned} & 14-19 \\ & 22-27 \end{aligned}$ | MO0 thru MO11 | Map outputs. Present the map register contents to the system memory address bus in the map mode. In the pass mode, these outputs provide the map address data on MO8-MO11 and low levels on MO0-MO7. (MO11 is the least significant bit.) |
| 13 | $\overline{M M}$ | Map mode input. When low, 12 bits of data are transferred from the selected map register to the map outputs. When high (pass mode), the four bits present on the map address inputs are passed to the map outputs. |
| 21 | $\overline{M E}$ | Map enable for the map outputs. A low level allows the outputs to be active while a high input level puts the outputs at high impedance. |
| 28 | C | Latch enable input for the 'LS610 and 'LS611 (no internal connection for 'LS612 and 'LS613). A high level will transparently pass data to the map outputs. A low level will latch the outputs. |
| 40,20 | $V_{\text {CC }}$, GND | Power supply ( 5 V ) and network ground (substrate) pins. |

Table III. Modes of Operation

| MAPPER INPUTS | 1/0 |  | MAP | PASS |
| :---: | :---: | :---: | :---: | :---: |
|  | WRITE (LOAD) | READ (VERIFY) |  |  |
| $\overline{\text { CS }}$ | Active (Low) | Active (Low) | Inactive (High) | Inactive (High) |
| $\overline{\text { STROBE }}$ | Active (Low) | Don't Care | Don't Care | Don't Care |
| R/W | Low | High | Don't Care | Don't Care |
| $\overline{M M}$ | Don't Care | Don't Care | Active (Low) | Inactive (High) |
| $\overline{M E}$ | Inactive (High) | Inactive (High) | Active | Active |
| RSO-RS3 | Address of Selected Register | Address of Selected Register | Don't Care | Don't Care |
| MAO-MA3 | Don't Care | Don't Care | Address of Selected Register | Address of Selected Register |
| MO0-MO11 | High Impedance | High Impedance | Valid Address | Valid Address |
| D0-D11 | Register contents to be loaded (input) | Register contents to be read (output) | Input Mode | Input Mode |

## PASS Mode

The four LSBs (MO8-MO11) of the memory mapper address bus (MO0-MO11) will be the same as the address on the MAO-MA3 input bus, while the remaining eight MSBs of the memory mapper address bus will all be low. The chip select ( $\overline{\mathrm{CS}}$ ) and the map mode ( $\overline{\mathrm{MM}}$ ) should both the inactive (high); map enable ( $\overline{\mathrm{ME}}$ ) should be active. In other words, the address on the system address bus will be the same as the address outputted by the microprocessor, and the memory mapper becomes transparent to the system.

## SYSTEMS INTEGRATION

The flexibility of the memory mapper is such that it can be used with microprocessors that have either an 8-bit or a 16 -bit data bus. In order to use the memory mapper to its fullest potential (i.e., expand the address bus by eight bits) with an 8 -bit microprocessor, the 12 -bit page address must be multiplexed into the mapper via the 8 -bit data bus. This means that the time it normally takes to load or read the memory mapper will be at least doubled and extra external circuitry will be necessary. If the requirement of the system is such that the address bus needs to be increased by only four bits, then there is no need for multiplexing in the page address. Of course this means that the address bus is expanded to only 20 bits resulting in a 1 -megabyte addressing capability. Next in this report, we will look at two 8 -bit systems utilizing the 'LS612 memory mapper.

## TMS9995-Based System

Figure 3 shows a TMS9995-based system using the 'LS612 to expand the address bus by four bits. The TMS9995 is an 8-bit microprocessor with a 16 -bit address bus. This system employs the Programmable System Interface (TMS9901) to control the operation of the mapper. The control of the mapper is software programmable via
the I/O ports of the TMS9901. Since the mapper registers are viewed as part of the logical memory space, an address decode (ADO) of the 12 MSBs is gated with a CRU bit to select the mapper for a READ or WRITE operation. The specific mapper register is then selected by the four LSBs of the microprocessor address bus (A15-A12) via the RS0-RS3 inputs of the mapper. Table IV shows the state of the three control signals P0, P1 and AD0 and the corresponding mode of operation of the mapper. When placed in the I/O mode, the READ or WRITE operation is then controlled by memory signals from the microprocessor (i.e., $\overline{\mathrm{WE}} /$ $\overline{\text { CRUCLK }}, \overline{M E M E N}$, and $\overline{\mathrm{DB} \mathrm{IN}}$ ). On POWER-UP and RESET, the I/O ports of the ' 9901 are put into the input mode. The pull-up resistors R1 and R2 will ensure the mapper is placed in the pass mode during POWER-UP and RESET. The resultant address bus is 20 bits wide, and SA19 is the LSB.

## Z-80-Based System

Figure 4 shows another 8 -bit (Z-80-based) system using the TI memory mapper. In this case, the control of the mapper is implemented by two flip-flops feeding $\overline{\mathrm{MM}}$ and $\overline{\mathrm{CS}}$. These flip-flops are programmed by the Z-80 and are addressed by the data bus, D0-D1. Table $V$ shows the necessary states of D0 and D1 to set the mapper in its proper mode of operation. Again during POWER-UP or RESET, the flip-flops are both cleared by $\overline{\text { RST, which is }}$ supplied by the system and which puts the mapper in the pass mode.

Table IV.TMS9900/'LS610 Control Signals

| MEMORY MAPPER | CONTROL SIGNALS |  |  |
| :---: | :---: | :---: | :---: |
| MODE OF OPERATION | P1 | PO | AD0 |
| MAP | L | H | L |
| PASS | H | H | L |
| I/O | H | L | L |



Figure 3. TMS9995 with Memory Mapper


Figure 4. Z-80 with Memory Mapper

Table V. Z-80/LS'610 Control Signals

| CONTROL SIGNALS |  |  | MEMORY MAPPER |  |
| :---: | :---: | :---: | :---: | :---: |
| DO | D1 | (ADO) $\overline{\text { IORQ }}$ | MODE OF OPERATION |  |
| L | L | $\uparrow$ | PASS |  |
| H | L | $\uparrow$ | MAP |  |
| L | H | $\uparrow$ | I/O |  |

## TMS9900-Based System

One of the limitations of using an 8 -bit microprocessor with the memory mapper, without multiplexing the page address, is that the address bus can only be expanded four bits. In a 16 -bit system, one based on a 16 -bit microprocessor like the TMS9900, no extra circuitry is necessary to load the mapper with the full 12 -bit address. Figure 5
shows a TMS9900 with an SN54/74LS612 for memory mapping. The control of the mapper is implemented in the same fashion as the system using the TMS9995 mentioned previously in the report. The resultant addressing capability is eight megawords. These TI microprocessors have set aside address space for RESET, XOP and INTERRUPT VECTORS, which are addressed when the microprocessor performs a context switch. During a context switch, the microprocessor must be able to address these locations which are part of the logical address (i.e., locations that are capable of being addressed by the microprocessor independently). One method, besides placing the mapper into the pass mode, is to load the memory mapper register whose 4-bit address is $\mathrm{O}_{\mathrm{H}}$ with the address of the first page of physical memory. This, like the pass mode, will effectively make the memory mapper appear to be transparent.


Figure 5. TMS9900 with Memory Mapper

Another point worth noting is that in all three of the previously mentioned systems, the $\overline{\mathrm{ME}}$ input was always connected to ground. This caused the mapper address buffers to be enabled during all modes of operation of the mapper. This is only a problem during the $\mathrm{I} / \mathrm{O}$ mode where, when loading the mapper register, other memory locations are also being written into. The method used to avoid destroying data already in memory was to put the mapper into the pass mode during the I/O operation. This was accomplished simply by pulling $\overline{\mathrm{MM}}$ input high, thus making the system address equal to the microprocessor address.

## Multimapper Systems

In a system employing a single memory mapper, the maximum active addressing capability is only 16 pages, if increased addressing capabilities are needed, the mapper must be reloaded. To avoid this procedure, another mapper may be added to the system. This will not increase the overall addressing capability of the system, but it will double the amount of active pages and will also afford twice the active addressing capability. Even though the control of two mappers is a little more detailed than the control of one, the same basic methods employed in the systems with one mapper can be used here.

## TIMING

The subject of how the mapper affects the critical timing parameters of the memory READ/WRITE cycles and what changes, if any, are needed to accommodate the mapper, have not been discussed in this report. First, looking at the I/O mode of operation where the mapper registers are either loaded or read from, it is seen that the mapper registers can be regarded as standard common I/O, static RAMs, with maximum access times (RS to valid $\mathrm{MO}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ ) of 75 ns . Once the I/O mode is set ( $\overline{\mathrm{CS}}=$ low $)$, the only two signals necessary to read or write into the mapper are $\overline{\text { STROBE }}$ and $R / \bar{W}$. As shown in the previously mentioned system, these signals were supplied directly from the microprocessor with no wait states necessary to perform either function. This will be the case with most microprocessors.

In the MAP and PASS mode, the main concern is the maximum access time (MA to MO). This access time is specified at a maximum of 70 ns , which, depending on the timing of the microprocessor and the memory used, may or may not cause any problems. In the Z-80-based system, no wait states were introduced by the mapper because the memory control signals become active 95 ns after the microprocessor address bus became valid. This gives the address bus sufficient time to settle down.

In conclusion, it can be said that for most microprocessors and memory available at the time of this writing, the operation of the mapper does not adversely affect the memory cycle timing and is flexible enough to be used with almost all microprocessors.

## SUMMARY

The possible uses of the memory mapper and the various techniques that can be employed to control its operation are numerous and only some examples were shown in this report. Some of the other possible applications of the mapper include: (1) achieving system addressing capability greater than 16 megabytes is accomplished by reducing the number of mapper registers used by a factor of 2 , thus increasing the size of each page by the same factor of 2 without affecting the total amount of pages; (2) being used in systems employing DMA; (3) memory protection which can be accomplished by sacrificing one or two bits of the page address, and gating these bits with the memory control signals.

Another technique that may be employed in controlling the modes of operation of the mapper is to use PROMs. for customer product designs.

# Bit-Slice Processor Applications 8-Bit Family 

Frank Laczko, Bob Myers, Richard Nawrocki, Rick Noblitt, and Sally Towlen<br>VLSI Systems Engineering<br>214/995-4720

## IMPORTANT NOTICE

Texas Instruments (TI) reserves the right to make changes in the devices or the device specifications identified in this publication without notice. Tl advises its customers to obtain the latest version of device specifications to verify, before placing orders, that the information being relied upon by the customer is current.

In the absence of written agreement to the contrary, TI assumes no liability for TI applications assistance, customer's product design, or infringement of patents or copyrights of third parties by or arising from use of semiconductor devices described herein. Nor does TI warrant or represent that any license, either express or implied, is granted under any patent right, copyright, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor devices might be or are used.

## Contents

$$
\begin{array}{cc}
\text { Title } & \text { Page } \\
\text { Section 1 } \\
\text { Introduction } &
\end{array}
$$

INTRODUCTION ..... 3-73
Section 22910 Microprogram Controller Emulation Using the 'AS890 Microsequencer
2910 MICROPROGRAM CONTROLLER EMULATION USING THE 'AS890 MICROSEQUENCER ..... 3-75
Emulator Configuration ..... 3-75
Microinstruction Conversion ..... 3-75
2910 Emulation Differences ..... 3-75
Loop Counts ..... 3-75
Register Loading ..... 3-76
Stack Full Indication ..... 3-76
Data Path Widths ..... 3-76
Section 3
Minimum Cycle Time Delay Calculations for a 16-Bit System
MINIMUM CYCLE TIME DELAY CALCULATIONS FOR A 16-BIT SYSTEM ..... 3-93
16-Bit Computer System Design ..... 3-93
Benchmark I: Comparison of Am2903A/2910A with 'AS888-1/'AS890-1 ..... 3-94
Benchmark II: Comparison of Am2901C/2910A with 'AS888-1/'AS890-1 ..... 3-94
Summary of Results ..... 3-94
32-Bit CPU Design with the 'AS888/'AS890
32-BIT CPU DESIGN WITH THE 'AS888/'AS890 ..... 3-101
Designing a 32 -Bit System ..... 3-101
Construction of the ALU ..... 3-101
Construction of the CCU ..... 3-103
Tracing Through a 32 -Bit Computer ..... 3-104
Defining the Macrocode Instruction Format. ..... 3-107
Tracing a Macrocode Instruction ..... 3-107
System Enhancements ..... 3-109
Timing and System Throughput ..... 3-111
Fetch Analysis ..... 3-111
Multiplication Analysis ..... 3-111
Section 5
An Adaptive Clock Generator to Increase 'AS888 System Speed
AN ADAPTIVE CLOCK GENERATOR TO INCREASE 'AS888 SYSTEM SPEED ..... 3-113
Circuit Description ..... 3-113
PROM Program ..... 3-113
Section 6Floating-Point System Design Using the 'AS888/'AS890
FLOATING-POINT SYSTEM DESIGN USING THE 'AS888/'AS890 ..... 3-125
Step 1: Choose a Floating-Point Number System ..... 3-125
Step 2: Choose an Algorithm for $\operatorname{Sin}(x)$ ..... 3-126
Step 3: Make 'AS888 Register Assignments ..... 3-126
Step 4: Substitute Registers for Variables in the Algorithm ..... 3-127
Step 5: Decompose Steps in the Algorithm into Simple Operations ..... 3-127
Step 6: Translate into 'AS888/890 Instructions; Identify Subroutines ..... 3-128
Step 7: Expand Subroutines into 'AS888/890 Operations ..... 3-129
Floating-Point Multiplication ..... 3-129
Floating-Point Addition ..... 3-131
Step 8: Evaluate Trade-Offs and Block Diagram the Hardware ..... 3-133
Step 9: Define Microinstruction Fields During Detailed Hardware Design ..... 3-134
Step 10: Assemble the Microprogram ..... 3-134
List of Illustrations
Figure Title Page
2-1 2910 Emulator Block Diagram ..... 3-76
3-1 16-Bit Computer System ..... 3-93
3-2 Am2903-Based 16-Bit Computer System ..... 3-97
3-3 'AS888-Based 16-Bit Computer System ..... 3-98
3-4 ALU Path for Multiplication and Division in the Am2903A System ..... 3-98
3-5 ALU Path for Multiplication and Division in the 'AS888 System ..... 3-99
3-6 Am2901C-Based 16-Bit Computer System ..... 3-99
3-7 Modified Design of Am2901C-Based System ..... 3-100
4-1 System Design Approach ..... 3-101
4-2 CCU Block Diagram ..... 3-102
4-3 ALU Block Diagram ..... 3-102
4-4 Cascaded 'AS888 Packages ..... 3-103
5-1 Adaptive Clock Generator Circuit ..... 3-114
5-2 Adaptive Clock Generator Timing Diagram ..... 3-115
5-3 Propagation Delay Without Carry and Without Shift ..... 3-118
5-4 Propagation Delay Without Carry and With Shift ..... 3-119
5-5 Propagation Delay With Carry and Without Shift ..... 3-120
5-6 Propagation Delay With Carry and With Shift ..... 3-121
5-7 PROM Data ..... 3-124
6-1 Block Diagram of Floating-Point Processor ..... 3-134
List of Programs
Program Title Page
2-1 Logic Equations Used to Generate Emulator PAL 1 ..... 3-78
2-2 Expanded Product Terms, Symbol Table and Fuse Plot for Emulator PAL 1 ..... 3-79
2-3 Simulation Results for Emulator PAL 1 ..... 3-82
2-4 JEDEC Printout for Emulator PAL 1 ..... 3-83
2-5 Logic Equations Used to Generate Emulator PAL 2 ..... 3-84
2-6 Expanded Product Terms, Symbol Table and Fuse Plot for Emulator PAL 2 ..... 3-85
2-7 Simulation Results for Emulator PAL 2 ..... 3-88
2-8 JEDEC Printout for Emulator PAL 2 ..... 3-91
5-1 BASIC Program to Generate PROM Data ..... 3-122

## List of Tables

Table Title Page
2-1 Typical Switching Characteristics ..... 3-75
2-2 'AS890 Encodings for Am2910 Instructions ..... 3-77
2-3 Effect of Table 2-2 Encodings on 'AS890 Control Signals ..... 3-77
3-1 Am2903A/Am2910A Timings for Addition ..... 3-94
3-2 'AS888-1/'AS890-1 Timings for Addition ..... 3-94
3-3 Am2903A/Am2910A Timings for Addition with Shift ..... 3-95
3-4 'AS888-1/'AS890-1 Timings for Addition with Shift ..... 3-95
3-5 Am2903A/Am2910A Timings for Multiplication ..... 3-95
3-6 Am2903A/Am2910A Timings for Division ..... 3-95
3-7 'AS888-1/'AS890-1 Timings for Multiplication and Division ..... 3-96
3-8 Am2901C/Am2910A Timings for Addition ..... 3-96
3-9 Am2901C/Am2910A Timings for Addition with Shift ..... 3-96
3-10 Summary of Results ..... 3-96
4-1 Microcode Definition ..... 3-105
4-2 Functional Listing of Fetch ..... 3-106
4-3 Assembler Listing of Fetch ..... 3-106
4-4 Microcode Listing of Fetch ..... 3-107
4-5 Possible Instruction Formats ..... 3-107
4-6 Functional Listing of Multiply ..... 3-107
4-7 Assembler Code of Multiply ..... 3-108
4-8 Microcode Listing of Multiply ..... 3-109
4-9 Critical Delay Path Analysis ..... 3-110
4-10 Fetch Timing Comparison ..... 3-110
4-11 Multiply Timing Comparison ..... 3-110
5-1 'AS888-1 Timing Characteristics ..... 3-115
5-2 Shift and Carry as a Function of I7-I0 ..... 3-116
5-7 PROM Data ..... 3-123
6-1 Floating Point $\operatorname{Sin}(x)$ Microprogram ..... 3-135

## Section 1

## Introduction

Bit-slice technology has gained widespread acceptance among CPU designers over the past several years as a means of increasing system speed and reducing the discrete logic needed for CPU construction. TI's recent entries on the market, the SN74AS888 8-bit processor slice and its companion microsequencer, the SN74AS890, increase processing throughput per unit area to an extent never before realized in bit-slice systems, making them well suited to the construction of high-speed systems with flexible instruction sets.

This is the first in a series of application books addressed to users of TI's bit-slice products. It discusses ways to take advantage of the 'AS888/'AS890's increased speed in the areas of CPU design and floating point processing, compares their performance with similar products, and presents a means of achieving optimum speed by adding an adaptive clock circuit to an 'AS888/'AS890 system. Also included is a 2910 emulator, which allows users to take advantage of the 'AS890's increased speed and greatly expanded addressing range, while still retaining existing 2910 software. Brief abstracts of the papers in this volume are given below.

Section 2, " 2910 Microprogram Controller Emulation using the 'AS890 Microsequencer,' converts the 16 instructions of the 2910 into 'AS890 commands, using programmable array logic (PALs) for fast emulation. By using the emulator, accessible microcode store can be quadrupled from 4,096 to 16,384 memory locations, and advantage can be taken of the 'AS890's deeper stack.

Section 3, 'Minimum Cycle Time Delay Calculations for a 16-Bit System," examines some timings for systems using TI's 'AS888-1/'AS890-1, AMD's Am2901C/2910A,
and AMD's Am2903A/2910A. Four cases are considered: addition, addition followed by a shift of the result, unsigned integer multiplication and unsigned integer division.

Section 4, "32-Bit CPU Design with the 'AS888/'AS890,', takes a look at constructing a central processing unit by cascading four 'AS888s to form a 32 -bit ALU and the 'AS890 sequencer to address a control store containing the system microcode. Microcode and assembly code are given for an instruction fetch routine and for unsigned multiplications.

Section 5, "An Adaptive Clock Generator to Increase 'AS888 System Speed,'' uses an adaptive circuit to generate clock pulses for an 'AS888-based system. The clock cycle length is optimally matched to the propagation delay of the 'AS888 for each individual instruction, further increasing the speed of the system. The circuit is linked to the 'AS888 with a PROM that decodes 888 instructions into cycle lengths. A BASIC program calculates instruction lengths and generates a file that can be transmitted to a Data I/O PROM programmer.

Section 6, "Floating Point Design using the 'AS888/'AS890,' provides a model for floating point system design, illustrating the step by step development of a utility to compute $\sin (\mathrm{x})$. By developing a $\sin (\mathrm{x})$ algorithm, a microprogram is generated and hardware requirements are identified in an interactive manner.

The application notes in this volume were prepared by the following members of VLSI Systems Engineering:

Bob Myers (Sections 3 and 4)
Richard Nawrocki (Section 2)
Rick Noblitt (Sections 5 and 6)
Please contact the authors at 214/995-4720 if you need additional information.

## Section 2

## 2910 Microprogram Controller Emulation using the 'AS890 Microsequencer

The 'AS890 microsequencer, with its powerful instruction set, can be microprogrammed to emulate the popular 2910 microprogram controller. By converting the 16 instructions of the 2910 into the appropriate 'AS890 commands, 2910 users can both quadruple accessible microcode store from 4,096 to 16,384 memory locations and take advantage of the 'AS890's deeper stack, while retaining existing microprograms and preserving prior investments in software without loss of system performance. Programmable Read Only Memory (PROM) can be used to implement the system, or TI's Programmable Array Logic PAL ${ }^{\circledR}$ can be selected for faster emulation.

## EMULATOR CONFIGURATION

The DRB inputs of the 'AS890 are used as the 2910 emulator's D (direct data) inputs. JSRP and JRP (2910 instructions 5 and 7) conditionally select the counter/register, requiring the counter/register contents to be available through the Y-output multiplexer. The 'AS890 does not directly support this function, but it can be accomplished by enabling either the DRA or DRB ports as an output and selecting the appropriate path through the Y-multiplexer.

JSRP and JRP also require that direct data input and existing register/counter contents be available at the Ymultiplexer concurrently. The emulator uses direct data port DRA and register/counter A for this purpose. Two '74AS244 buffers are used to isolate DRA from DRB so that register/counter A can be loaded from the Direct Data input and DRA can be used to send the register/counter's contents to the Y-multiplexer.

Figure 2-1 shows the configuration of the 2910 emulator. To provide fast propagation delays, two TIBPAL16L8-15s, with a maximum propagation delay of 15 ns , are used for the control PALs. Because the TIBPAL16L8-15 will only accommodate seven product
terms and eight were required for the condition code input to the 'AS890, it is driven by two outputs of the control PAL. These outputs are selectively enabled using the CCEN input (see Programs 2-1 and 2-5 for detailed PAL equations).

Typical switching delays for the 2910 emulator are summarized in Table 2-1.

## MICROINSTRUCTION CONVERSION

Table 2-2 lists Y-multiplexer, stack and register control encodings that can be used to convert the 2910 instruction set into 'AS890 microinstructions. The effect of these encodings on the Y-multiplexer, stack and register controls is shown in Table 2-3. Data from Table 2-2 was used as input to a universal program logic compiler to produce the emulator's two control PALs. Files generated for each PAL by the compiler include:

1. a logic description file
2. a listing of expanded product terms and fuse map
3. simulation results
4. a JEDEC file.

These are reproduced at the end of this application note. The CUPLTM software used to develop the PALs is available from Texas Instruments or from Assisted Technology, Inc., San Jose, CA.

## 2910 EMULATION DIFFERENCES

The architecture of the 'AS890 does not lend itself to a complete emulation of the 2910 controller. Differences are noted below.

## Loop Counts

The 2910 register/counter is tested for a zero value prior to decrementing and branching on conditional loops. The counter is usually loaded with a value that is one less

Table 2-1. Typical Switching Characteristics

| SET-UP AND HOLD TIMES |  |  | COMBINATIONAL DELAYS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INPUT | Ts | Th | FROM | то |  |  |
|  |  |  |  | $\mathbf{Y}$ | PL,MAP VECT | FULL |
| $\mathrm{D} \rightarrow \mathrm{R}$ (Inst. $=5,7$ ) | 15 | 0 | D0-D13 (Inst. $=5,7$ ) | 15 |  |  |
| $D \rightarrow R$ (Inst. $\neq 5,7)$ | 8 | 0 | DO-D13 (Inst. $=5,7$ ) | 8 |  |  |
| $\mathrm{D} \rightarrow$ Pc (Inst. $=5,7$ ) | 28 | 0 | $10-13$ (Inst. $=5,7,9$ ) | 27 | 10 |  |
| $D \rightarrow P \mathrm{Pc}$ (Inst. $\neq 5,7)$ | 20 | 0 | $10-13$ (Inst. $\neq 5,7,9$ ) | 22 | 10 |  |
| 13-10 | 36 | 0 | $\overline{\text { CC }}$ | 22 |  |  |
| $\overline{\mathrm{CC}}$ | 36 | 0 | CCEN | 22 |  |  |
| $\overline{C C E N}$ | 36 | 0 | CP | 18 |  | 25 |
| Cl | 12 | 0 | $C P(I=8,9, F \& C N T R=2)$ | 24 |  | 25 |
| RLD | 36 | 0 | OE | 8 |  |  |



Figure 2-1. 2910 Emulator Block Diagram
than the desired loop count. The 'AS890 tests for a one prior to decrementing. Therefore, the 2910 emulator requires that the actual loop count, rather than loop count minus one, be loaded into the register/counter.

Three of the 2910 instructions (RFCT, RPCT, and TWB) execute once and terminate the counter decrement when a zero is found in the register/counter. The emulator requires a one in the register/counter to execute these instructions and terminate the counter decrement. Loading a zero into the register/counter before decrementing will cause the emulator to loop 16,384 times.

## Register Loading

Using the 2910's register load (RLD) input during a JSRP or JRP instruction allows external data to be input to the register/counter while the current value in the register/counter is output on the Y-bus. This is not the case with the 'AS890, where an external value placed on DRA for input to the register/counter will also be sent to the Y-
multiplexer outputs. A register load using the emulator must therefore be implemented independently of the JSRP or JRP instructions.

## Stack Full Indication

The 'AS890 stack is nine levels deep, compared to the 2910's five-level stack. The 2910 signals that all five levels of the stack are used by setting FULL low. The emulator's FULL signal is set to zero when its eighth stack location is used, indicating that only one location remains available. A low value will also appear at the FULL output when a stack POP is to be executed and the stack is empty.

## Data Path Widths

Because the 'AS890 supports 14-bit data paths instead of the 2910's 12 -bit paths, the number of address locations that can be accessed by the emulator can be expanded from 4,096 to 16,634 locations.

PAL is a registered trademark of Monolithic Memories Inc.

Table 2-2. 'AS890 Encodings for Am2910 Instructions

| 13-10 | MNEMONIC | NAME | $\overline{\mathbf{C C E N}}=$ LOW and $\overline{\mathbf{C C}}=$ HIGH |  |  |  | $\overline{\mathrm{CCEN}}=\mathrm{HIGH}$ or $\overline{\mathbf{C C}}=$ LOW . |  |  |  | ENABLE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\overline{\text { CCOUT }}$ | RC | S | MUX | CCOUT | RC | S | MUX |  |
| 0 | JZ | JUMP ZERO | H | LLL | LLL | HHH | H | LLL | LLL | HHH | PL |
| 1 | CJS | COND JSB PL | H | LLL | HLH | HHH | L | LLL | HLH | HHH | PL |
| 2 | JMAP | JUMP MAP | H | LLL | HHH | HLL | H | LLL | HHH | HLL | MAP |
| 3 | CJP | COND JUMP PL | H | LLL | HHH | HHH | L | LLL | HHH | HHH | PL |
| 4 | PUSH | PUSH/COND LD CNTR | H | LLL | HHL | HHH | H | LHL | HHL | HHH | PL |
| 5 | JSRP | COND JSB R/PL | L | LLL | HHL | HLL | H | LLL | HHL | HLL | PL |
| 6 | CJV | COND JUMP VECTOR | H | LLL | HHH | HHH | L | LLL | HHH | HHH | VECT |
| 7 | JRP | COND JUMP R/PL | L | LLL | HHH | HLL | H | LLL | HHH | HLL | PL |
| 8 | RFCT | RPT LOOP, CNTR $=0$ | L | LLH | LHL | LLH | L | LLH | LHL | LLH | PL |
| 9 | RPCT | RPT LOOP, CNTR $\neq 0$ | L | LLH | HHH | HLL | L | LLH | HHH | HLL | PL |
| A | CRTN | COND RTN | H | LLL | LHH | LHH | L | LLL | LHH | LHH | PL |
| B | CJPP | COND JUMP PL \& POP | H | LLL | LHH | HHH | L | LLL | LHH | HHH | PL |
| C | LDCT | LD CNTR 7 CONTINUE | H | LHL | HHH | HHH | H | LHL | HHH | HHH | PL |
| D | LOOP | TEST END LOOP | L | LLL | LHL | LHH | H | LLL | LHL | LHH | PL |
| E | CONT | CONTINUE | H | LLL | HHH | HHH | H | LLL | HHH | HHH | PL |
| F | TWB | THREE-WAY BRANCH | L | LLH | LHL | LHH | H | LLH | LHL | LHH | PL |

Table 2-3. Effect of Table 2-2 Encodings on 'AS890 Control Signals

| 13-10 | MNEMONIC | NAME | ZERO | $\overline{\text { CCEN }}=$ LOW and $\overline{\mathrm{CC}}=\mathrm{HIGH}$ |  |  |  | $\overline{\text { CCEN }}=\mathbf{H I G H}$ or $\overline{\mathrm{CC}}=$ LOW |  |  |  | ENABLE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\overline{\text { CCOUT }}$ | RC | S | MUX | ccout | RC | S | MUX |  |
| 0 | JZ | JUMP ZERO |  | H | Hold | Reset | 0 | H | Hold | Reset | 0 | PL |
| 1 | CJS | COND JSB PL |  | H | Hold | Hold | MPC | L | Hold | Push | DRB | PL |
| 2 | JMAP | JUMP MAP |  | H | Hold | Hold | DRB | H | Hold | Hold | DRB | MAP |
| 3 | CJP | COND JUMP PL |  | H | Hold | Hold | MPC | L | Hold | Hold | DRB | PL |
| 4 | PUSH | PUSH/COND LD CNTR |  | H | Hold | Push | MPC | H | LoadA | Push | MPC | PL |
| 5 | JSRP | COND JSB R/PL |  | L | Hold | Push | DRA | H | Hold | Push | DRB | PL |
| 6 | CJV | COND JUMP VECTOR |  | H | Hold | Hold | MPC | L | Hold | Hold | DRB | VECT |
| 7 | JRP | COND JUMP R/PL |  | L | Hold | Hold | DRA | H | Hold | Hold | DRB | PL |
| 8 | RFCT | RPT LOOP, CNTR $\neq 0$ | L | L | DecA | Hold | STK | L | DecA | Hold | STK | PL |
|  |  |  | H | L | DecA | Pop | MPC | L | DecA | Pop | MPC | PL |
| 9 | RPCT | RPT LOOP, CNTR $=0$ | L | L | DecA | Hold | DRA | L | DecA | Hold | DRA | PL |
|  |  |  | H | L | DecA | Hold | MPC | L. | DecA | Hold | MPC | PL |
| A | CRTN | COND RTN |  | H | Hold | Hold | MPC | L | Hold | Pop | STK | PL |
| B | CJPP | COND JUMP PL \& POP |  | H | Hold | Hold | MPC | L | Hold | Pop | DRB | PL |
| C | LDCT | LD CNTR 7 CONTINUE |  | H | LoadA | Hold | MPC | H | LoadA | Hold | MPC | PL |
| D | LOOP | TEST END LOOP |  | L | Hold | Hold | STK | H | Hold | Pop | MPC | PL |
| E | CONT | CONTINUE |  | H | Hold | Hold | MPC | H | Hold | Hold | MPC | PL |
| F | TWB | THREE-WAY BRANCH |  | L | DecA | Hold | STK | H | DecA | Pop | MPC | PL |
|  |  |  |  | L | DecA | Pop | DRB | H | Hold | Pop | MPC |  |

## Program 2-1. Logic Equations Used to Generate Emulator PAL 1



Program 2-2. Expanded Product Terms, Symbol Table and Fuse Plot for Emulator PAL 1


Program 2-2. Expanded Product Terms, Symbol Table and Fuse Plot for Emulator PAL 1 (Continued)

Symbol Table


Pin \#19
0000

0064 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx

0128 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0160 xxxxXxXXXXXXXXXXXXXXXXXXXXXXXXXX

0224 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX Pin \#18
0256

0320 x--x-x---x-
0352 -xx--x--x-

0416 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0448 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx


Pin \#17
0512
0544
$0576-x--x-x$ x-
0608 x--x-x---x
$0640 \times x \times x \times x \times x \times x \times x \times x \times x \times x \times x \times x \times x \times x \times x \times x \times x$
0672 xXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0704 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
0736 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Pin \#16
0768
0800
$0832-x-x--x-\cdots-1$

0896 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
0928 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
0960 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx


Program 2-2. Expanded Product Terms, Symbol Table and Fuse Plot for Emulator PAL 1 (Continued)

```
Pin #l5
    1024
    1056 -xx-x-----------------------------------
    1088 -x-x------x--------------------------
    1120 --x-x---x-
    1152 -x-x-x
    1184 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
    1216 x XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
    1248 x x XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
Pin #14
    1280
    1312 -x---x---x--------------------------
    1344 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
    1376 xXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
    1408 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
    1440 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
    1472 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
    1504 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
Pin \#15
1024
-x
\(1120--x-x--x\)
1152 -x-x-x
1184 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
```



```
1248 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
Pin \#14
1312 -x---x---x
1344 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
1376 xxXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
1408 XxXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
440 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
```



Pin \#l3
1536

$1600-x-x-x$ -
1632 - 16 -x---x
664 XXXXXXXXXXX
1695 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
1778 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
1728 xxxxxxxxxxxxxxxxxxxxxxxxxxyxxxxxx
1760 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
PIN \#l2
1792
1824

1888

1952 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx 1984 xxXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
2016 xxxXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

LEGEND $x$ : fuse NOT blown

- : FUSE BLOWN

Program 2-3. Simulation Results for Emulator PAL 1


## Simulation Results



Program 2-4. JEDEC Printout for Emulator PAL 1

*V0026 0011 OXXXXNXLHHHAHN
*V0027 10111XXXXNXL HLL HHHN
*V0028 10110XXXXNXLLHLLHHHN
*V0029 01111XXXXNXLHHHHHHHN

Program 2-5. Logic Equations Used to Generate Emulator PAL 2

CUPL Version 2.02a Copyright (c) 1983, 84,85 Assisted Technology, Inc. -- LISTING
Source File: B:2910EMI Device: pl6l8


Program 2-6. Expanded Product Terms, Symbol Table and Fuse Plot for Emulator PAL 2

CUPL
Device
Partno
Name
Revision
Date
Designer
Company
Assembly
Location
2.02A

P16L8 DLIB-C-18-5
2910EMI
74AS890/2910 EMULATOR PAL 2
01
04/04/85
RICHARD D. NAWROCKI
TEXAS INSTRUMENTS
00001
Ul01

## Expanded Product Terms

| $\text { CC_OUTO } \quad \overrightarrow{ }$ | $\mathrm{RCO}_{1}^{\mathrm{OE}} \rightarrow$ |
| :---: | :---: |
| \# 10 \& ! 12 \& ! 13 |  |
| \# ! IO \& I1 \& I2 \& ! I3 | $\underset{1}{\mathrm{RCl} . \mathrm{OE}} \rightarrow$ |
| $\begin{gathered} \text { CC_OUTO.OE } \\ \text { CCEN } \end{gathered}$ | $\mathrm{RC} 2.0 \mathrm{E}->$ |
| $\begin{array}{rlll} \text { CC_OUT1 } & \overrightarrow{-} \\ \#!C C & \& & I 2 & \& \\ \hline 11 & \& & I 2 & \& \\ \hline \end{array}$ | $\text { VECT. }_{1} \text { oE }$ |
| \# CC \& 10 \& 12 <br> \# ! CC \& IO \& ! I2 \& ! I 3 <br> \# ! CC \& ! IO \& I1 \& I2 \& ! I 3 |  |
| $\underset{\text { CC_OUTI.OE }}{\text { CCEN }} \rightarrow$ |  |
| COUNTER -> <br> RC2 , RCl , RCO |  |

INSTRUCTION $\rightarrow$
I3, I2 , I1 , 10


| RCO | $\overrightarrow{10}$ |  |
| :---: | :---: | :---: |
| \# |  | \& 12 |
| \# | I1 | \& ! 12 |
| \# | ! 13 |  |
| \# | !RLD |  |

$\mathrm{RCl} \stackrel{->}{10}$ \& RLD
\# ! I2 \& RLD
\# !CCEN \& CC \& ! I 3 \& RLD
RC2 ${ }_{1}^{->}$
$\stackrel{\mathrm{VECT}}{!10}$ \& 11 \& 12 \& $!13$
MAP.oe ->
PL.OE $->$

Program 2-6. Expanded Product Terms, Symbol Table and Fuse Plot for Emulator PAL 2 (Continued)

Symbol Table


Fuse Plot

## 

Pin \#19
0000
0032


0064
0096 $-x-x-x-x$


 0160 xXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX 0192 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx 0224 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX PIN.\#18
0256




 0480 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
Pin \#17
0512
0544
0576 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx 0608 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
0640 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX 0672 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX 0704 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX



Program 2-6. Expanded Product Terms, Symbol Table and Fuse Plot for Emulator PAL 2 (Continued)

| $\begin{gathered} \text { Pin \#13 } \\ 1536 \end{gathered}$ |  |
| :---: | :---: |
|  |  |
| 1568 |  |
| 1600 x |  |
| $1632 \times$ |  |
| 1664 X | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| 1696 x | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| 1728 x | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| 1760 x |  |
| Pin\#12 |  |
| 1792 |  |
| 1824 x--xx |  |
| 1856 x |  |
| 1888 x |  |
| 1920 x |  |
| 1952 x | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |
| 1984 | ${ }^{X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X}$ |
|  |  |

LEGEND $x$ : FUSE NOT BLOWN - : FUSE BLOWN

Program 2－7．Simulation Results for Emulator PAL 2

| $1:$ | NAME | ＇74AS890／2910 EMULATOR PAL 2 |
| :---: | :---: | :---: |
| 2： | DATE | 04／04／85 ； |
| 3 ： | REV | 01 ； |
| 4： | DESIGNER | RICHARD D．NAWROCKI |
| 5： | COMPANY | TEXAS INSTRUMENTS ； |
| 6： | ASSEMBLY | 00001 ； |
| 7： | LOCATION | Ul01； |
| 8： |  |  |
| 9：／＊＊＊＊＊ | ＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊） | ＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊／ |
| 10：／＊＊ | HIS DEVICE GENERATE | CONTROL SIGNALS FOR THE＊／ |
| 11：／＊ | 74 AS890 EMULATOR OF | THE 2910 Microprogram SEQuENCER．＊／ |
| 12：／＊＊＊＊＊ | ＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊ | ＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊＊／ |
| 13： |  |  |
| 14：ORDER： |  |  |
| 15：I3， | \％2，I2，\％2，I1，\％2 | IO，\％2， |
| 16： | CC，\％2，CCEN，\％2， | RLD， 22. |
| 17： | PL，\％2，MAP，\％2， | VECT，\％2， |
| 18： | CC＿OUT1，\％2，CC＿O | UTO，\％2， |
| 19： | RC2，\％2，RC1，${ }^{2} 2$ ， | RCO ； |
| 20： |  |  |

## Simulation Results



INSTRUCTION 0

## 0001： 0002： 0003 0004： $0005:$ 0006： 0007： 0008：

| 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 0 |
| INSTRUCTION |  |  |  | $0009:$

$0010:$
$0011:$
$0012:$
$0013:$
$0014:$
$0015:$
$0016:$ 0017： 0018： 0019 0020： 0 0021 0023： 0024 $0025:$
$0026:$
$0027:$
$0028:$
$0029:$
$0030:$
$0031:$
$0032:$ 0
0
0
0
0
0
0
0 0 INS
0
0 $\begin{array}{cccc}\text { NSTRUCTION } & 2 \\ 0 & 1 & 0 & 1 \\ 0 & 1 & 0 & 1 \\ 0 & 1 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 1 & 0 & 1 \\ 0 & 1 & 0 & 1 \\ 0 & 1 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ \text { NSTRUCTION } & 3 \\ 0 & 1 & 1 & 1 \\ 0 & 1 & 1 & 1 \\ 0 & 1 & 1 & 0 \\ 0 & 1 & 1 & 0 \\ 0 & 1 & 1 & 1 \\ 0 & 1 & 1 & 1 \\ 0 & 1 & 1 & 0 \\ 0 & 1 & 1 & 0\end{array}$

 Orororor oromoror omomomom omomomor

 $H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$
$H$ NNNNエエエエ $Z$
$Z$
$Z$
$Z$
$H$
$H$
$H$
$H$ rrrrrrrr $\begin{array}{ll}L & L \\ H & L \\ L & L \\ H & L \\ H & L \\ H & L \\ H & L\end{array}$ NNNN」ـ」 ェイエアェロェー IIIINNNN
 $L$
$H$
$H$
$H$
$H$
$H$
$H$ $L$
$L$
$L$
$L$
$L$
$L$ NNNNTrエI －rTrNNNN rrrrrrrr －rrrerro

Program 2-7. Simulation Results for Emulator PAL 2 (Continued)


## 3 Application Reports

Program 2－7．Simulation Results for Emulator PAL 2 （Continued）

0089 ：
$00990:$
$0091:$
$0092:$
$0093:$
$0094:$
$0095:$
$0096:$
ートトートートーヲ
 0
$0>$ $\rightarrow$ カ円 $<$ ஈーఁロ1のn －－1coinn Nのס
ーกォ ono


0122 ：
$0123:$
$0124:$ 0126 0127： 0128：

0097 ： 0098 ： 0100： 0101 ： $0102:$ 0104：

0105： 0106 ： 0107： 0109 ： 0110： 0112：
$0113:$ 0114 ： 0116： 0117 ： 0118 ： 0119： 0120： ゅトトமートート ゅமーローローロー ーートローロート ○○ート○○ート レーロー0000 OーOーOーOー「ーローrーrr エエエエエエエエ エエエエエエエエ NNNNエIr「 エIIエNNNN「ーローゥーナー エアエアエトエト「エアエアエアェ


Program 2-8. JEDEC Printout for Emulator PAL 2 (Continued)
*V0028 $1100000 \times X N X H H L L H L L Z N ~$
*V0029 1100111 XXNXHHLLLLZLN
*V0030 $1100011 \times X N X H H L L H L Z L N$
*V0031 1100101 XXNXHHLLLLZLN
*V0032 1100001 XXNXHHLLHLZLN
*V0033 $0010110 \times \times N X H H L L L L H Z N$
*V0034 $0010010 \times$ XNXHHLLHLHZN
*V0035 0010100XXNXHHLLHLHZN
*V0036 $0010000 \times$ XNXHHLLHLHZN
*V0037 0010111XXNXHHLLHLZHN
*V0038 $0010011 \times X N X H H L L H L Z H N ~$
*V0039 0010101 XXNXHHLLHLZHN
*V0040 0010001 XXNXHHLLHLZHN
*V0041 $1010110 \times \times N X H H L L L L L Z N$
*V0042 $1010010 \times$ XNXHHLLHLLZN
*V0043 $1010100 \times$ XNXHHLLLLHZN
*V0044 $1010000 \times$ XNXHHLLHLHZN
*V0045 $1010111 \times X N X H H L L L L Z H N$
*V0046 $1010011 \times$ XNXHHLLHLZHN
*V0047 $1010101 \times$ XNXHHLLLLZHN
*V0048 $1010001 \times$ XNXHHLLHLZHN
*V0049 $0110110 \times$ XNXLHHLLLHZN
*V0050 0110010XXNXLHHLHLHZN
*V0051 0110100XXNXLHHLLLLZN
*V0052 0110000XXNXLHHLHLLZN
*V0053 0110111XXNXLHHLLLZLN
*V0054 0110011XXNXLHHLHLZLN
*V0055 0110101XXNXLHHLLLLZLN
*V0056 0110001XXNXLHHLHLZLN
*V0057 1110110XXNXHHLLLLLZN
*V0058 1110010XXNXHHLLHLLZN
*V0059 1110100XXNXHHLLLLHZN
*V0060 $1110000 \times$ XNXHHLLHLHZN
*V0061 $1110111 \times X N X H H L L L L Z H N$
*V0062 1110011XXNXHHLLHLZHN
*V0063 1110101XXNXHHLLLLLZHN
*V0064 1110001 XXNXHHLLHLZHN
*V0065 0001110XXNXHHLHLLLZN
*V0066 $0001010 \times$ XNXHHLLHLLZN
*V0067 $0001100 \times$ XNXHHLHLLLZN
*V0068 $0001000 \times$ XNXHHLLHLLZN
*V0069 0001111 XXNXHHLHLLZLN
*V0070 0001011 XXNXHHLLHLZLN
*V0071 0001101 XXNXHHLHLLZLN
*V0072 0001001 XXNXHHLLHLZLN
*V0073 $1001110 \times X N X H H L H L L L Z N$
*V0074 $1001010 \times X N X H H L L H L L Z N ~$
*V0075 $1001100 \times X N X H H L H L L L Z N ~$
*V0076 $1001000 \times$ XNXHHLLHLLZN
*V0077 $1001111 \times X N X H H L . H L L Z L N$
*V0078 $1001011 \times X N X H H L L H L Z L N$
*V0079 1001101 XXNXHHLHLLZZLN
*V0080 1001001 XXNXHHLLHLZLN
*V0081 $0101110 \times X N X H H L L L L H Z N$
*V0082 0101010XXNXHHLLHLHZN
*V0083 0101100XXNXHHLLLLLZN
*V0084 0101000XXNXHHLLHLLZN
*V0085 0101111XXNXHHLLLLZLN
*V0086 0101011XXNXHHLLHLZLN
*V0087 0101101XXNXHHLLLLZLN
*V0088 0101001XXNXHHLLHLZLN
*V0089 1101110XXNXHHLLLLLHZN
*V0090 1101010XXNXHHLLHLHZN
*V0091 $1101100 \times$ XNXHHLLLLLZN
*V0092 $1101000 \times$ XNXHHLLHLLZN
*V0093 $1101111 \times X N X H H L L L L Z L N$
*V0094 $1101011 \times X N X H H L L H L Z L N$
*V0095 $1101101 \times X N X H H L L L L Z L N$
*V0096 1101001 XXNXHHLLHLZLN
*V0097 0011110XXNXHHLLHLHZN
*V0098 0011010XXNXHHLLHLHZN
*V0099 $0011100 \times$ XNXHHLLHLHZN
*V0100 $0011000 \times X N X H H L L H L H Z N ~$
*V0101 $0011111 \times X N X H H L L H L Z H N$
*V0102 0011011XXNXHHLLHLZHN
*V0103 0011101XXNXHHLLHLZHN
*V0104 0011001XXNXHHLLHLZHN
*V0105 $1011110 \times$ XNXHHLLLLLZN
*V0106 $1011010 \times X N X H H L L H L L Z N$
*V0107 1011100XXNXHHLLLLHZN
*V0108 $1011000 \times X N X H H L L H L H Z N$
*V0109 $1011111 \times X N X H H L L L L Z H N$
*V0110 1011011XXNXHHLLHLZHN
*V0111 $1011101 \times X N X H H L L L L Z H N$
*V0112 $1011001 \times X N X H H L L H L Z H N$
*V0113 0111110XXNXHHLLLLHZN
*VO114 0111010XXNXHHLLHLHZN
*V0115 0111100XXNXHHLLLLHZN
*V0116 0111000XXNXHHLLHLHZN
*VO117 0111111XXNXHHLLLLZHN
*V0118 0111011XXNXHHLLHLZHN
*V0119 0111101XXNXHHLLLLZHN
*V0120 0111001XXNXHHLLHLZHN
*VO121 $1111110 \times \times N \times H H L H L L L Z N$
*VO122 $1111010 \times X N X H H L L H L L Z N ~$
*V0123 $1111100 \times X N X H H L H L L H Z N$
*V0124 $1111000 \times \times N X H H L L H L H Z N ~$
*V0125 $1111111 \times \times N X H H L H L L Z H N$
*V0126 1111011XXNXHHLLHLZHN
*V0127 1111101XXNXHHLHLLZHN
*V0128 1111001XXNXHHLLHLZHN
*A128

## Section 3

## Minimum Cycle Time Delay Calculations for a 16-Bit System

This article examines some timings for a typical 16-bit computer system using a bit-slice processor and microsequencer. Comparative data for systems using TI's 'AS888-1/'AS890-1, AMD's Am2901C/2910A, and AMD's Am2903A/2910A are presented. Timing calculations are based on data from TI SN74AS888/890 family data sheets and from the AMD2900 Family Bipolar Microprocessor Logic and Interface 1985 Data Book.

## 16-BIT COMPUTER SYSTEM DESIGN

Figure 3-1 shows a basic design for a 16-bit computer system. The computer control unit (CCU), shown on the left side of the dotted line, executes microcode from the microprogram memory (also known as the control store). A one-level pipeline design is used to speed data processing,
allowing the address and contents of the next instruction to be fetched while the current instruction is being executed. The arithmetic logic unit, consisting of the bit-slice processor chips and any other logic needed to process the data, is shown on the right side of the figure.

This section compares the time required to perform the following functions, using TI's SN74AS888-1/890-1, AMD's Am2901C/2910A and AMD's Am2903A/2910A bitslice products:

1. addition
2. addition with a shift
3. unsigned integer multiplication
4. unsigned integer division.

Cases 3 and 4 are not included in the Am2901C/Am2910A discussion, since the Am2901C does not incorporate internal multiplication or division algorithms.


Figure 3-1. 16-Bit Computer System

## Benchmark I: Comparison of Am2903A/2910A with 'AS888-1/'AS890-1

Design of a 16-bit system that is Am2903A-based is presented in Figure 3-2. The same system implemented with the 'AS888-1 and 'AS890-1 is shown in Figure 3-3. These systems are used to calculate timings for the four cases discussed in this section. Timings for the control path are given in the first test case and remain constant for the remaining three cases.

Tables 3-1 and 3-2 contain timing results for addition using the two chip sets; Tables 3-3 and 3-4 analyze the add with shift combination. It can be seen that the TI system runs $36 \%$ faster for addition and $32 \%$ faster for addition followed by a shift of the result.

Figures 3-4 and 3-5 show the ALU data paths used for multiplication and division by the two systems. Tables 3-5, 3-6 and 3-7 display timings for the critical path calculations for these operations. Increases in speed using the TI parts are even more significant here, where multiplication is faster by $42 \%$ and division faster by $37 \%$.

## Benchmark II: Comparison of Am2901C/2910A with 'AS888-1/'AS890-1

The same 16 -bit system can be constructed with Am2901C slices. Since the Am2901C has a smaller instruction set than the Am2903A or the 'AS888-1, multiplication and division must be emulated using external add with shift hardware and bit testing. For this reason, the comparison for this benchmark is restricted to the cases of addition and addition with shift.

The basic system for these two cases using the Am2901C is shown in Figure 3-6; timing calculations for the control and data paths are listed in Table 3-8. These can be compared directly with the 'AS888 design and calculations shown previously in Figure 3-3 and Table 3-2. Addition is $13 \%$ faster using the AS888-1.

To implement the shift function, two multiplexers and an exclusive-OR gate are needed. A modified design is shown in Figure 3-7, along with timing calculations in Table 3-9. A comparison of these with Figure 3-3 and data in Table 3-4 shows that the TI system performs an addition with shift $25 \%$ faster than the Am2901C equivalent.

## SUMMARY OF RESULTS

Table 3-10 summarizes the timings of the various cases implemented with the TI and AMD parts. It can be seen that the TI 'AS888-1/'AS890-1 system runs faster than the others in all cases. Addition using the TI parts can be performed $26 \%$ faster than with the system using the Am2901C and $36 \%$ faster than that using the Am2903A. Addition with a
shift is $25 \%$ faster on the TI system than the Am2901C system and $32 \%$ faster than the Am2903C. An even wider variance occurs with the more complicated algorithms: multiplication is $42 \%$ faster using the TI chip; division is $37 \%$ faster.

Table 3-1. Am2903A/Am2910A Timings for Addition

| COMPONENT | DATA PATH | TIME (NS) |
| :---: | :---: | :---: |
| Data Loop |  |  |
| Pipeline register | Clock to output | 9 |
| Am2903A | A, B to $\bar{G}, \bar{P}$ | 52 |
| Am2902A | $\overline{\mathrm{GO}}, \overline{\mathrm{PO}}$ to $\mathrm{C}_{\mathrm{n}+\mathrm{z}}$ | 7 |
| Am2903A | $C_{n}$ to $C_{n+4}$, OVR, $Z, Y$ | 35 |
| Am2903A | Setup time | 5 |
|  | Total for data loop | 108 |
| Control Loop |  |  |
| Pipeline register | Clock to output | 9 |
| MUX | Select to output | 13 |
| Am2910A | $\overline{\mathrm{CC}}$ to output | 30 |
| PROM | Access time | 20 |
| Pipeline register | Setup time | 2 |
|  | Total for control loop | 74 |
| Critical path for Am2903 addition |  | 108 |

Table 3-2. 'AS888-1/'AS890-1 Timings for Addition

| COMPONENT | DATA PATH | TIME (NS) |
| :---: | :---: | :---: |
| Data Loop |  |  |
| Pipeline register | Clock to output | 9 |
| 'AS888-1 | $A, B$ to $C_{n+8}$ | 30 |
| 'AS888-1 | $C_{n}$ to $C_{n+8}$, OVR, $Z, Y$ | 27 |
| Register | Setup time | 2 |
|  | Total for data loop | 68 |
| Control Loop |  |  |
| Pipeline register | Clock to output | 9 |
| MUX | Select to output | 13 |
| 'AS890-1 | $\overline{\mathrm{CC}}$ to output | 25 |
| PROM | Access time | 20 |
| Pipeline register | Setup time | 2 |
|  | Total Control Loop | 69 |
| Critical path for 'AS888 addition |  | 69 |

Table 3-3. Am2903A/Am2910A Timings for Addition with Shift

| COMPONENT | DATA PATH | TIME (NS) |
| :---: | :---: | :---: |
| Data Loop |  |  |
| Pipeline register | Clock to output | 9 |
| Am2903A | A, B to $\overline{\mathrm{G}}, \overline{\mathrm{P}}$ | 52 |
| Am2902A | $\overline{\mathrm{GO}}, \overline{\mathrm{PO}}$ to $\mathrm{C}_{\mathrm{n}+2}$ | 7 |
| Am2903A | $\mathrm{C}_{\mathrm{n}}$ to $\mathrm{C}_{n+4}, \overline{\mathrm{SIOO}}$ | 23 |
| Am2903A | $\overline{S I O(n)}$ shift to $Y$ | 23 |
| Am2903A | RAM setup | 5 |
|  | Total for data loop | 119 |
| Control Loop |  |  |
| Pipeline register | Clock to output | 9 |
| MUX | Select to output | 13 |
| Am2910A | $\overline{\mathrm{CC}}$ to output | 30 |
| PROM | Access time | 20 |
| Pipeline register | Setup time | 2 |
|  | Total for control loop | 74 |
| Critical path for AM2903 addition |  |  |

Table 3-4. 'AS888-1/'AS890-1 Timings for Addition with Shift

| COMPONENT | DATA PATH | TIME (NS) |
| :---: | :---: | :---: |
| Data Loop |  |  |
| Pipeline register | Clock to output | 9 |
| 'AS888-1 | A, B to $C_{n+8}$ | 30 |
| 'AS888-1 | $\mathrm{C}_{\mathrm{n}}$ to $\mathrm{C}_{\mathrm{n}+8}, \overline{\mathrm{SIOO}}$ | 25 |
| 'AS888-1 | $\overline{\mathrm{SIO}(\mathrm{n})}$ shift to $Y$ | 14 |
| 'AS888-1 | Register file setup time | 2 |
|  | Total for data loop | 80 |
| Control Loop |  |  |
| Pipeline register | Clock to output | 9 |
| MUX | Select to output | 13 |
| 'AS890-1 | $\overline{\mathrm{CC}}$ to output | 25 |
| PROM | Access time | 20 |
| Pipeline register | Setup time | 2 |
|  | Total for control loop | 69 |
| Critical path for | 888 addition with shift | 80 |

Table 3-5. Am2903A/Am2910A Timings for Multiplication

| COMPONENT | DATA PATH | TIME (NS) |
| :---: | :---: | :---: |
| Data Loop |  |  |
| Am 2918 | Clock to output | 27 |
| Am2903A | 18-10 to $\overline{\mathrm{G}}, \overline{\mathrm{P}}$ | 71 |
| Am2902A | $\overline{\mathrm{GO}}, \overline{\mathrm{PO}}$ to $\mathrm{C}_{\mathrm{n}+\mathrm{z}}$ | 7 |
| Am2903A | $C_{n}$ to $C_{n+4}, \overline{\text { SIOO }}$ | 23 |
| Am2903A | $\overline{\text { SIO(n) }}$ shift to Y | 23 |
|  | Total for data loop | 151 |
| Control Loop |  |  |
| Pipeline register | Clock to output | 9 |
| MUX | Select to output | 13 |
| Am2910A | $\overline{\mathrm{CC}}$ to output | 30 |
| PROM | Access time | 20 |
| Pipeline register | Setup time | 2 |
|  | Total for control loop | 74 |
| Critical path for Am2903 multiplication |  | 151 |

Table 3-6. Am2903A/Am2910A Timings for Division

| COMPONENT | DATA PATH | TIME (NS) |
| :---: | :---: | :---: |
| Data Loop |  |  |
| Am2918 | Clock to output | 27 |
| Am2903A | $18-10$ to $\bar{G}, \bar{P}$ | 50 |
| Am2902A | $\overline{\mathrm{GO}}, \overline{\mathrm{PO}}$ to $\mathrm{C}_{\mathrm{n}+2}$ | 7 |
| Am2903A | $\mathrm{C}_{\mathrm{n}}$ to $\mathrm{C}_{\mathrm{n}+4}, \overline{\mathrm{SIOO}}$ | 32 |
| Am2903A | $\overline{\mathrm{SIO}(\mathrm{n})}$ shift to Y | 23 |
|  | Total for data loop | 139 |
| Control Loop |  |  |
| Pipeline register | Clock to output | 9 |
| MUX | Select to output | 13 |
| Am2910A | $\overline{\mathrm{CC}}$ to output | 30 |
| PROM | Access time | 20 |
| Pipeline register | Setup time | 2 |
|  | Total for control loop | 74 |
| Critical path for Am2903 division |  | 139 |

Table 3-7. 'AS8888-1/'AS890-1 Timings for Multiplication and Division

| COMPONENT | DATA PATH | TIME (NS) |
| :---: | :---: | :---: |
| Data Loop |  |  |
| 'AS888-1 | Clock to $\mathrm{C}_{\mathrm{n}+8}$ | 46 |
| 'AS888-1 | $\mathrm{C}_{\mathrm{n}}$ to $\overline{\mathrm{SIO}}$ | 25 |
| 'AS888-1 | $\overline{\text { SIO(n) }}$ shift to $Y$ | 14 |
| 'AS888-1 | Register file setup time | 2 |
|  | Total for data loop | 87 |
| Control Loop |  |  |
| Pipeline register | Clock to output | 9 |
| MUX | Select to output | 13 |
| 'AS890-1 | $\overline{\mathrm{CC}}$ to output | 25 |
| PROM | Access time | 20 |
| Pipeline register | Setup time | 2 |
|  | Total Control Loop | 69 |
| Critical path for 'AS888 multiplication |  |  |

Table 3-8. Am2901C/Am2910A Timings for Addition

| COMPONENT | DATA PATH | $\begin{aligned} & \text { TIME } \\ & \text { (NS) } \end{aligned}$ |
| :---: | :---: | :---: |
| Data Loop |  |  |
| Pipeline register | Clock to output | 9 |
| Am2901C | A, B to $\bar{G}, \bar{P}$ | 37 |
| Am2902A | $\overline{\mathrm{GO}}$, $\overline{\mathrm{PO}}$ to $\mathrm{C}_{\mathrm{n}+\mathrm{z}}$ | 7 |
| Am2901C | $\begin{aligned} & C_{n} \text { to } C_{n+4}, \text { OVR, F3, } \\ & F=0, Y \end{aligned}$ | 25 |
| Register | Setup time | 2 |
|  | Total for data loop | 80 |
| Control Loop |  |  |
| Pipeline register | Clock to output | 9 |
| MUX | Select to output | 13 |
| Am2910A | $\overline{\mathrm{CC}}$ to output | 30 |
| PROM | Access time | 20 |
| Pipeline register | Setup time | 2 |
|  | Total for control loop | 74 |
| Critical path for Am2901C addition |  | 80 |

Table 3-9. Am2901C/Am2910A Timings for Addition with Shift

| COMPONENT | DATA PATH | TIME (NS) |
| :---: | :---: | :---: |
| Data Loop |  |  |
| Pipeline register | Clock to output | 9 |
| Am2901C | A, B to $\overline{\mathrm{G}}, \overline{\mathrm{P}}$ | 37 |
| Am2902A | $\overline{\mathrm{GO}}, \overline{\mathrm{PO}}$ to $\mathrm{C}_{\mathrm{n}+\mathrm{z}}$ | 7 |
| Am2901C | $\mathrm{C}_{\mathrm{n}}$ to F3, OVR | 22 |
| XOR and MUX |  | 21 |
| Am2901C | RAM3 setup | 12 |
|  | Total for data loop | 108 |
| Control Loop |  |  |
| Pipeline register | Clock to output | 9 |
| Mux | Select to output | 13 |
| Am2910A | $\overline{\mathrm{CC}}$ to output | 30 |
| PROM | Access time | 20 |
| Pipeline register | Setup time | 2 |
|  | Total for control loop | 74 |
| Critical path for A with shift | 2903 addition | 108 |

Table 3-10. Summary of Results

| Operation | CALCULATED TIMINGS |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | DATA PATHS |  |  | CONTROL PATHS |  |  | SYSTEM CLOCK |  |  |
|  | Am2901C | Am2903A | 'AS888-1 | Am2901C | Am2903A | 'AS888-1 | Am2901C | Am2903A | 'AS888-1 |
| Addition | 80 | 108 | 68 | 74 | 74 | 69 | 80 | 108 | 69 |
| Addition with Shift | 108 | 119 | 80 | 74 | 74 | 69 | 108 | 119 | 80 |
| Multiplication | - | 151 | 87 | - | 74 | 69 | - | 151 | 87 |
| Division | - | 139 | 87 | - | 74 | 69 | - | 139 | 87 |




Figure 3-3. 'AS888-Based 16-Bit Computer System


Figure 3-4. ALU Path for Multiplication and Division in the Am2903A System


Figure 3-5. ALU Path for Multiplication and Division in the 'AS888 System



Figure 3-7. Modified Design of Am2901C-Based System

## Section 4

## 32-Bit CPU Design With the 'AS888/'AS890

Microprogramming and bit slice technology have made possible the development of powerful systems using flexible instructions sets and wide address/data buses to access more than one gigaword of physical main memory. This section discusses one design approach to such a system, using 'AS888 bit slice and 'AS890 microsequencer components.

A structured approach to system design, such as that illustrated in Figure 4-1, is recommended in developing custom bit-slice designs. The product specification gives a starting point or basis for the project. In this example, four 'AS888 bit slices are used to implement the 32-bit arithmetic portion of the CPU, and an 'AS890 microsequencer is used for ALU and system control. A group of PROMs stores the microinstructions; a writable control store could also be implemented using additional control logic and components to load and modify the microprogram memory. The system is designed to access more than one gigaword of memory.

Since speed is a concern, carry look-ahead rather than ripple-through logic is recommended. If ripple-through logic were used, the system clock would need to be slowed down to allow the propagation of the carry bits through the various 'AS888 stages. By using carry look-ahead, the amount of time needed for the data to stabilize is greatly reduced by anticipating the carry across the 'AS888 packages.

So that the scratchpad area can be used for address calculations and mathematical computations, the 'AS888's internal register file is dedicated for system functions. To provide the system user with a macrolevel equivalent of register locations, a 16-word external register file is also included. Access to the external register file is under microprogram control, allowing address selection to come from the microcode itself or from one of the three operand fields of the instruction register.

PROMs eliminate the use of main memory as a source for constants used in initialization or table look-up functions. Accessing main memory for table values would require time and slow system throughput; by placing fixed values in fast PROMs, access time is kept to a minimum and system throughput is not altered.

Control, data and address buses shared by the system are accessed by three-state registers. The control register supplies the non-CPU part of a computer system with control signals. The data bus allows the ALU to supply data for the rest of the system and can also be a source of data for the ALU; this is accomplished by using three-state registers to drive the bidirectional data bus, along with registers to sample the bus. The address bus uses one of the external register file locations to maintain a program counter, thus allowing a 32-bit address bus capable of addressing about 4 gigawords


Figure 4-1. System Design Approach
of main memory. Using three-state drivers for this bus enables other subsystems to take control of the system buses.

A pipeline register supplies the microsequencer and the ALU with both data and instructions. To get macrocode into the system, an instruction register and a mapping PROM are used to convert the opcode to a microprogram routine address. The condition code signal, used for testing various conditions, is supplied by a register-input-based PAL. PAL inputs can be fixed values or combinations of the status signals coming from the ALU. The read address select pins for the 'AS888's internal B register can be sourced from the microword itself or from three nibbles of the macroword, to provide offsets for the N -way branches to various microcode routines.

## DESIGNING A 32-BIT SYSTEM

A typical 32-bit system block diagram using the 'AS888 Bit-Slice and 'AS890 Microsequencer is shown in Figures 4-2 and 4-3. It can be broken down into two sections, the ALU (arithmetic logic unit) and the CCU (computer control unit). The ALU section performs all manipulation of data both to and from main memory, such as arithmetic and logical operations. The CCU section controls instruction (macro-code) flow and any miscellaneous control operations, such as fetching instructions or supplying addresses for main memory access.

## Construction of the ALU

To cascade the four 'AS888s to obtain the 32-bit arithmetic unit shown in Figure 4-4, the shift multiplex $\overline{\text { SIO0 }}$


Figure 4-2. CCU Block Diagram


Figure 4-3. ALU Block Diagram


Figure 4-4. Cascaded 'AS888 Packages
and $\overline{\mathrm{QIO} 0}$ terminals are connected to the $\overline{\mathrm{SIO} 7}$ and $\overline{\mathrm{QIO} 7}$ terminals of adjacent packages, and the least significant package's signals are connected to the most-significant package's. Optionally, the SN74ALS240 inverting gates can be connected to the $\overline{\mathrm{SIO}}-\overline{\mathrm{SIO}} 7$ terminals and the byte inputs to implement byte and bit control. Another chip, the SN74AS182 look-ahead carry generator, provides a ripplecarry function, to help system throughput.

The design includes a 16 -word register file, the SN74AS870 (see Figure 4-3). This allows the user to access 16 working areas for temporary data storage or address calculations such as indexing. In this design example, the 'AS888's internal register file is not accessible directly by the user; it is reserved for microcode operations, such as address computation and temporary storage for arithmetic operations. Addressing the register files is permitted through the microprogram or from the macrocode instruction register under microcode control. The transfer register connected to the 'AS888's Y and DB buses allows for feedback into the 'AS888 under microprogram control. Since the constant PROMs and the external register file share the A bus, they cannot be accessed at the same time. The transfer register enables data from the external register file to be transmitted to the B bus, making possible the addition of operands from the constant PROMs and the external register file, for example.

Constant PROMs are also included to simplify the programming and operation of the ALU by supplying fixed data for various operations, such as:

1. Clearing the system register files for initialization. This brings the system up to a known state.
2. Supplying a correction value to the offset in a branch instruction,i.e., converting a 16 -bit offset to a true 32 -bit address.
3. Table look-up for fixed mathematical operations, such as computing sines and cosines.

## Construction of the CCU

Sequencing and branching operations at speeds compatible with the 'AS888 are supplied by the 'AS890, a microprogrammed controller working as a powerful microsequencer. Features of the 'AS890 include:

1. Stack capability. The 9 -word stack can be accessed by using a stack pointer or a read pointer; the latter is designed for nondestructive dumping of the stack contents.
2. Register/counter facility. Two registers, DRA and DRB, can be used for latching data from the external data buses or as counters for loops.

A ZERO signal is generated when the decremented counter reaches a zero value.
3. Interrupt control. A register for temporarily holding the return address is supplied; upon entering the interrupt routine, the contents of the return register must be pushed onto the stack for later use.
4. Next address generation. The $Y$ output multiplexer offers a selection of same or incremented address, address from DRA or DRB buses, address from stack, or a concatenation of DRA13-DRA4 and B3-B0.
A microprogram memory/pipeline register supplies the microsequencer and the rest of the system with instructions (see Figure 4-2). The memory might consist of ROMs, or it could be a writable-control store with support logic to allow loading or updating of the control store. For a general purpose machine with a fixed instruction set, ROMs would be more economic.

Some 'AS890 instructions are influenced by the $\overline{\mathrm{CC}}$ input. Many are variations of branch and jump instructions. To form and supply $\overline{\mathrm{CC}}$, a register can be used to latch the state of the 'AS888 and supply inputs to a PAL for decoding, based upon the microcode's needs. Combinatorial logic in the PAL allows multiple or single events to be selected or provides a fixed value of " 1 '" or " 0 '" for forced conditions.

To supply the microsequencer with the proper address of the microcode-equivalent version of the macrocode instruction, an instruction register and mapping PROM are needed. Under microprogram control, the instruction register samples the data bus to get the macrocode instruction. The opcode portion is passed to the mapping PROM to form an address to the microcode routine. When the microcode is ready to jump to the routine, it turns off the $Y$ bus output of the 'AS890 and enables the output of the mapping PROM. An optional means of altering the address uses B3-B0 inputs of the 'AS890 to implement an N -way branch routine. In this method, the ten most significant address bits of DRA or DRA are concatenated with the B3-B0 bits to supply an address.

Control information is supplied to the rest of the system via the control register and bus. By setting various bits within the control register, information can be passed to other subsystems, such as memory and I/O peripherals. Bit 0 could represent the read/write control line while bit 1 could select memory or I/O for the read/write. Bit 2 might function to enable interrupts and bit 3 to indicate when the system should enter a "wait" state for slow memory. The remaining control bits can be programmed by the system designer to indicate additional condition states of the 'macrosystem'.

Addressing of the register files, both 'AS888 internal and 'AS870 external, is done through the use of two 1-of-2 selector banks. The first bank selects address source; this design offers a choice for operand processing of fixed values from the microcode or values from the macroinstruction latched in the instruction register. The second bank selects the first or second operand as an address source for port 0 of the external register file; port 1 uses the third operand
as an address source. It should be noted that the design presented in Figure 4-2 is a one-level pipeline that is instruction-data based. The address and contents of the next instruction are being fetched while the current instruction is being executed. Tracing through the data flow, the following can be observed:

1. The pipeline register contains the current instruction being executed
2. The ALU has just executed its instruction, and has the current status ready at its output pins
3. The status register that is attached to the ALU contains the previous instruction's resulting status
4. The contents of the next microprogram word are being fetched at the same time that the current instruction is being executed.

## TRACING THROUGH A 32-BIT COMPUTER

With the 'AS888 and 'AS890 as foundation chips, the typical 32-bit supermini of Figures 4-2 and 4-3 can now be functionally traced. First, note that the data of the main program is handled separately from that of the microcodeeach on its own bus. The system is initialized by setting the "clear" signal high-this causes a forced jump to the beginning of the microcode memory. Instructions carried out by the microcode at this point might run system diagnostics, clear all registers throughout the 'AS888-based system, and set up the initial macrocode program address. In this design, the first program address to fetch an instruction from main memory comes from a fixed value in the microcode memory; it is possible to allow the address to be retrieved from a permanent location in main memory or from either a front panel or console, by modifying the microcode program slightly.

Table 4-1 illustrates the microcode format for this design. Note that it contains control signals for all chips involved in the design. Some of these, such as $\overline{\text { TRANSLATCH }}$ and MARLATCH, are used with the system clock to provide controlled loading of the various holding registers. Others supply necessary addressing information, directing input from either the main data bus or from the microcode word itself.

The FETCH routine is shown in functional, assembler and microcoded forms in Tables 4-2, 4-3 and 4-4. First, the program counter is read from the external register file and stored into the memory address register. After the program counter is placed on the address bus, the program counter is updated and stored while the data from memory is allowed to settle down to a stable condition. The data is then latched in both the instruction register and data-in register.

The opcode field of the instruction register is passed through the mapping PROM to convert the opcode to an equivalent microcode routine address. When YOE is forced high by the microcode, the 'AS890 is three-stated from the Y bus and the mapping PROM's output is taken out of the three-state mode to supply an address to the control store (microprogram memory); a forced jump is made to the microcode routine to perform the instruction.

Table 4-1. Microcode Definition

| MICROCODE FIELD | PIN NAME | INPUT TO | FUNCTION |
| :---: | :---: | :---: | :---: |
| 0-13 | DRA13-DRA0 | 'AS890 | Used for next-address branches |
| 14-27 | DRB13-DRB0 | 'AS890 | Used for loading counter |
| 28-30 | RC2-RC0 | 'AS890 | Register/counter controls |
| 31-33 | S2-S0 | 'AS890 | Stack control |
| 34-36 | MUX2-MUX0 | 'AS890 | MUX control of Y output bus |
| 37 | $\overline{\text { INT }}$ | 'AS890 | Interrupt control |
| 38 | $\overline{\text { RAOE }}$ | 'AS890 | Enables DRA output |
| 39 | $\overline{\text { RBOE }}$ | 'AS890 | Enables DRB output |
| 40 | OSEL | 'AS890 | Mux control for DRA source |
| 41 | INC | 'AS890 | Incrementer control |
| 42 | $\overline{\text { YOE }}$ | 'AS890 | Enables Y output bus |
| 43-50 | 17-10 | 'AS888 | Instruction inputs |
| 51 | $\overline{\text { OEA }}$ | 'AS888 | DA bus enable |
| 52 | $\overline{E A}$ | 'AS888 | ALU input operand select |
| 53 | $\overline{O E B}$ | 'AS888 | DB bus enable |
| 54 | OEY | 'AS888 | $Y$ bus output enable |
| 55 | SELY | 'AS888 | Y bus select |
| 56-57 | EB1-EB0 | 'AS888 | ALU input operand selects |
| 58 | $\overline{W E}$ | 'AS888 | Register file write enable |
| 59 | $\overline{\mathrm{MAP}}$ | PROM | Enables mapping PROM to 'AS890 Y bus |
| 60 | $\overline{\mathrm{IR}}$ | Latch | Latches data bus to instruction register |
| 61 | $\overline{\mathrm{CR}}$ | Latch | Latches control data to bus |
| 62-69 | CTRL7-CTRLO | Latch | Data for control latch |
| 70-71 | BSEL1-BSELO | Multiplexer | Selects data for 'AS890 |
| 72-75 | B3-B0 | Multiplexer | Microcode data to switch |
| 76 | CONDCD | Latch | Controls latch of 'AS888 status |
| 77-80 | SELC3-SELC0 | PAL | Selects combination of 'AS888 status |
| 81 | DTALATCHI | Latch | Controls latching of data-in |
| 82 | DTAIN | Latch | Enables data-in output to bus |
| 83 | DTALATCHO | Latch | Controls latching of data-out |
| 84 | DTAOUT | Latch | Enables data-out output to DB bus |
| 85 | $\overline{\text { MARLATCH }}$ | Latch | Controls latching of address |
| 86 | $\overline{\text { MAR }}$ | Latch | Enables MAR output to address bus |
| 87 | $\overline{\text { CONSTPROM }}$ | PROM | Enables PROM to DA bus |
| 88-99 | A11-A0 | PROM | Address of constant in PROM |
| 100 | SWITCH2 | Multiplexer | Selects microcode or Instruction Register data |
| 101 | SWITCH1 | Multiplexer | Selects microcode or Instruction Register data |
| 102-105 | A3-A0 | Multiplexer | Register file address ('AS888) |
| 106-109 | B3-B0 | Multiplexer | Register file address ('AS888) |
| 110-113 | C3-C0 | Multiplexer | Register file address ('AS888) |
| 114 | REGUWR | Register File | Port 0 write enable |
| 115 | REGLWR | Register File | Port 1 write enable |
| 116 | $\overline{\text { REGU }}$ | Register File | Chip enable on port 0 |
| 117 | $\overline{\text { REGL }}$ | Register File | Chip enable on port 1 |
| 118 | TRANSLATCH | Latch | Controls latch between Y and DB bus |
| 119 | TRANS | Latch | Enables output to DB bus |
| 120 | SELCN2 | Multiplexer | Supplies carry input to 'AS888 |
| 121 | SELCN1 | Multiplexer | Supplies carry input to 'AS888 |
| 122 | REGUB | Multiplexer | Selects address for external register file |
| 123-126 | $\overline{\text { BYTE3 - }}$ BYTE0 | Three-state | Enables data for byte/bit operations |

Table 4-2. Functional Listing of Fetch

$$
\begin{aligned}
\text { FETCH: } \quad & M A R=P C, \text { Enable MAR output } \\
& P C=P C+1 \\
& \mathbb{R}=D I R=\text { data bus, Disable 'AS890 } Y \text { bus, } \\
& \text { Enable mapping PROM to } Y \text { bus }
\end{aligned}
$$

Table 4-3. Assembler Listing of Fetch

| FETCH: OP890 ,.,111,10;INC; | Set 'AS890 for continue |
| :--- | :--- |
| OP888 NOP,GROUP5,10,.,1111; | Perform NOP and read external register 15 |
| OEY;SELY; | Enable Y bus output |
| CR;CTRL 00000011; | Generate external control bus signals |
| SELC 01; | Select fixed CC value to 'AS890 |
| MARLATCH;MAR; | Latch value on Y bus and enable output |
| SWITCH 00;REGL; | Select address source and enable port |
| TRANSLATCH | Latch Y bus for transfer to B bus |
| OP890 ,.,111,10;INC; | Set 'AS890 for continue |
| OP888 PASS,INCS,00,.,1111; | Increment program counter |
| OEB;OEY; | Enable Y bus output |
| SELC 01; | Select fixed CC value to 'AS890 |
| MAR; | Output address to address bus |
| REGLWR;REGL; | Update program counter in register file |
| TRANS; | Enable transfer latch output to B bus |
| SELCN 01 | Select carry input to LSP to be " 1 " |
| OP890 ,.,111,10; | Set 'AS890 for continue |
| OP888 NOP,GROUP5,10; | Perform NOP |
| MAP; | Enable mapping PROM to 'AS890 Y bus |
| IR; | Latch data bus to get macrolevel code |
| SELC 01 | Select fixed CC value to 'AS890 |
| DTALATCHI; | Put data bus also in data register |
| MAR | Output address to address bus |
|  |  |

## Key to Table 4-3

OP888 a,b,c,d,e,f where:

| $a=$ upper bits of instruction, 17-14 | $d=A$ address of register files |
| :--- | :--- |
| $b=$ lower bits of instruction, 13-10 | $e=B$ address of register files |
| $c=$ value of EB1-EB0 | $f=C$ address of register files |

OP890 v,w,x,y,z
where:

| $v=$ DRA value, 14-bits | $y=$ S2-S0 |
| :--- | :--- |
| $w=$ DRB value, 14-bits | $z=$ MUX2-MUX0 |
| $x=R C 2-R C 0$ |  |

After the routine is complete, a jump is made back to the FETCH routine by using the next-address supplied by the microprogram. It is up to the system designer/ programmer to make sure that all system housekeeping is performed, so that nothing causes a fatal endless loop.

## DEFINING THE MACROCODE INSTRUCTION FORMAT

Since this is a 32-bit design, a variety of instruction formats are available. The size of the opcode along with the types of addressing used, will affect both system size and performance. The formats shown in Table 4-5 will be used for discussion.

All Table 4-5 formats have an opcode field of 11 bits and source/destination fields of 7 bits; the first three bits of the latter designate the address type, and the remaining four
bits are used for register access. The opcode length allows 2,048 macrocoded instructions to be mapped to equivalent microcoded routines. The address fields can specify any of the following modes: register, relative, autoincrement/ autodecrement, indexed, absolute, and deferred. The offset used in the Type 0 instruction can be used for branch-based instructions, for an offset range of $\pm 32727$.

## TRACING A MACROCODE INSTRUCTION

Microcode for a Type 3 multiplication instruction is shown in Table 4-6, using the following assumptions:

1. Code for retrieving the operands will not be shown. Jumps will be made to routines that will place the temporary operands into internal register locations 2 and 3 of the 'AS888, after being fetched from main memory.

Table 4-4. Microcode Listing of Fetch

| DRA13DRAO | DRB13DRBO |  | $\begin{aligned} & \dot{8} \\ & \dot{\sim} \end{aligned}$ |  |  | 17-10 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00000000000000 | 00000000000000 | 000 | 111 | 010 | 111010 | 11111111 | 11101101 | 110 |
| 00000000000000 | 00000000000000 | 000 | 11.1 | 010 | 111010 | 11110100 | 11000001 | 111 |
| 00000000000000 | 00000000000000 | 000 | 111 | 010 | 111001 | 11111111 | 01111101 | 001 |

Table 4-4. Microcode Listing of Fetch (Continued)

| CTRL7. <br> CTRLO |  | $\begin{aligned} & \text { O} \\ & \text { ¢ © } \end{aligned}$ | $\left\lvert\, \begin{array}{l\|} 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \end{array}\right.$ |  |  | A11-A0 |  | $\stackrel{\text { ¢ }}{\dot{<}}$ | $\begin{aligned} & \text { O} \\ & \text { M } \\ & \text { M } \end{aligned}$ |  |  | \|o |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00000011 | 00 | 0000 | 1 | 0001 | 1111001 | 000000000000 | 00 | 0000 | 0000 | 1111 | 111001000 | 1111 |
| 00000000 | 00 | 0000 | 1 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 1111 | 101010010 | 1111 |
| 00000000 | 00 | 0000 | 1 | 0001 | 01111101 | 000000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |

Table 4-5. Possible Instruction Formats
TYPE 0 - OPCODE +16 -BIT OFFSET

| $0-10$ | $11-15$ <br> Not Used | $16-31$ <br> Offset |
| :---: | :---: | :---: |

TYPE 1 - OPCODE + DESTINATION

| $0-10$ | $11-24$ | $25-31$ |
| :---: | :---: | :---: |
| Opcode | Not used | Destination |

TYPE 2 - OPCODE + SOURCE + DESTINATION

| $0-10$ | $11-17$ <br> Not used | $18-24$ <br> Source | $25-31$ <br> Destination |
| :---: | :---: | :---: | :---: |

TYPE 3 - OPCODE + SOURCE1 + SOURCE2 + DESTINATION

| $0-10$ <br> Opcode | $11-17$ <br> Source | $18-24$ <br> Source | $25-31$ <br> Destination |
| :---: | :---: | :---: | :---: |

Table 4-7. Assembler Code of Multiply

```
UMULI3:
    OP890 SOURCE1,.,110,110;
    INC;YOE;
    OP888 NOP;GROUP5;
    SELC 0001;
    MAR
    OP890 SOURCE2,00000000100000,110,110,110; Perform subroutine branch and load B
    counter
    Increment microaddress and enable Y bus
    Tell 'AS888 to do nothing during jump
    Set CC to "1" to set up 'AS890 continue
    Maintain address on main address bus
    Perform a continue instruction
    Increment microaddress and enable Y bus
    Zero out register file accumulator
    Enable writing to register file
    Set CC to "1" to set up 'AS890 continue
    Maintain address on main address buss
    Perform a continue instruction
    Increment microaddress and enable Y bus
    Load MQ register with S + Cn, from external
    register file
    Maintain address on main address bus
    Decrement B and loop til ZERO = 1
    Increment microaddress and enable Y bus
    Perform unsigned multiply on accumulator
    Update register file accumulator
    Maintain address on main address bus
    Perform a continue instruction
    Increment microaddress and enable }Y\mathrm{ bus
    Put S + Cn in temporary register file
    Allow updating of register file
    Maintain address on main address bus
    Perform a subroutine branch
    Increment microaddress and enable Y bus
    Tell 'AS888 to do nothing during jump
    Set CC to "1" for set up 'AS890 continue
    Maintain address on main address bus
    Perform a branch to FETCH routine
    Increment microaddress and enable Y bus
    Tell 'AS888 to do nothing during jump
    Set CC to "1" for 'AS890 continue
```

Perform a subroutine branch
Increment address and enable $Y$ bus
Tell 'AS888 to do nothing during jump
Set CC to " 1 " to set up 'AS890 continue
Maintain address on main address buss
OP890 SOURCE2,00000000100000,110,110,110; Perform subroutine branch and load B counter
Increment microaddress and enable $Y$ bus
Tell 'AS888 to do nothing during jump
Set CC to " 1 " to set up 'AS890 continue
Maintain address on main address bus
Perform a continue instruction
Increment microaddress and enable $Y$ bus
Zero out register file accumulator
Enable writing to register file
continue

Perform a continue instruction
Increment microaddress and enable $Y$ bus
Load MQ register with $S+C n$, from external
register file
Maintain address on main address bus

Decrement B and loop til ZERO = 1
Increment microaddress and enable $Y$ bus
Perform unsigned multiply on accumulator
Update register file accumulator
Maintain address on main address bus
Perform a continue instruction
Increment microaddress and enable $Y$ bus
Put $\mathrm{S}+\mathrm{Cn}$ in temporary register file
Allow updating of register file
Maintain address on main address bus
Perform a subroutine branch
Increment microaddress and enable $Y$ bus
Tell 'AS888 to do nothing during jump
Set CC to " 1 " for set up 'AS890 continue
Maintain address on main address bus
Perform a branch to FETCH routine
Increment microaddress and enable Y bus
'AS888 to do nothing during jump
Set CC to " 1 " for 'AS890 continue

NC:YOE:
OP888 NOP,GROUP5;
SELC 0001 ;
MAR
OP890 ,,,111,110;
INC;YOE;
OP888 CLEAR,GROUP5,,.,1001;
WE:
0001

OP890 LOOP,,,111,110;
INC;YOE;
OP888 LOADMQ,INCS,,,0010;

MAR

P890 LOOP,,101,111,100
INC;YOE;
OP888 UMULI,GROUP4,01,0011,,1001;
WE;
MAR
OP890 ,,,111,110;
INC; YOE;
OP888 PASS,INCS,,,,1000;
WE;
MAR
OP890 STORPSW,,,110,110;
INC; YOE;
OP888 NOP,GROUP5;
SELC 0001;
MAR
OP890 FETCH,,,111;
INC;YOE;
OP888 NOP,GROUP5;
SELC 0001

Key to Table 4-7.

OP888 a,b,c,d,e,f
where:
$\mathrm{a}=$ upper bits of instruction, 17-14
$b=$ lower bits of instruction, 13-10
$c=$ value of EB1-EB0
$\mathrm{d}=\mathrm{A}$ address of register files
$\mathrm{e}=\mathrm{B}$ address of register files
$f=C$ address of register files
-

OP890 v,w,x,y,z
where:
$v=$ DRA value, 14 -bits
$w=$ DRB value, 14 -bits
$x=R C 2-R C 0$
$\mathrm{y}=\mathrm{S} 2-\mathrm{SO}$
$z=$ MUX2-MUXO

Table 4－8．Microcode Listing of Multiply

| DRA13－ DRAO | DRB13－ DRB0 | $\begin{aligned} & \text { O} \\ & \text { Uָ } \\ & \text { N} \\ & \text { U్జ } \end{aligned}$ | $\begin{aligned} & \text { O் } \\ & \text { N } \end{aligned}$ |  |  | 17－10 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00000000001100 | 00000000000000 | 000 | 110 | 110 | 111010 | 11111111 | 11110001 | 111 |
| 00000000010000 | 00000000100000 | 110 | 110 | 110 | 111010 | 11111111 | 11110001 | 111 |
| 00000000000000 | 00000000000000 | 000 | 111 | 110 | 111010 | 11110000 | 11100000 | 111 |
| 00001000001000 | 00000000000000 | 000 | 111 | 110 | 111010 | 11100100 | 11100001 | 111 |
| 00001000001000 | 00000000000000 | 101 | 111 | 100 | 111010 | 11010000 | 11100010 | 111 |
| 00000000000000 | 00000000000000 | 000 | 111 | 101 | 111010 | 11111111 | 11100010 | 111 |
| 00000000010100 | 00000000000000 | 000 | 110 | 110 | 111010 | 111111111 | 11110001 | 1111 |
| 00000000011000 | 00000000000000 | 000 | 110 | 110 | 111010 | 11111111 | 11110001 | 111 |
| 00000000000011 | 00000000000000 | 000 | 111 | 000 | 111010 | 11111111 | 11110001 | 111 |

Table 4－8．Microcode Listing of Multiply（Continued）

| CTRL7－ CTRLO |  | $\begin{aligned} & \text { O} \\ & \text { M } \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 2 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { O} \\ & \text { 山్ } \\ & \text { S } \\ & \text { SU } \\ & \text { 心 } \end{aligned}$ |  | A11－A0 |  | $\begin{aligned} & \stackrel{\circ}{\dot{\alpha}} \\ & \dot{̣} \end{aligned}$ | $\begin{aligned} & \text { O} \\ & \text { ìm } \end{aligned}$ |  | 品品范 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00000000 | 00 | 0000 | 1 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |
| 00000000 | 00 | 0000 | 1 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |
| 00000000 | 00 | 0000 | 1 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 1001 | 111111000 | 11111 |
| 00000000 | 00 | 0000 | 0 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0010 | 0000 | 110111000 | 1111 |
| 00000000 | 00 | 0000 | 0 | 0001 | 1111101 | 000000000000 | 00 | 0011 | 0000 | 1001 | 101011000 | 1111 |
| 00000000 | 00 | 0000 | 0 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 1000 | 101011000 | 1111 |
| 00000000 | 00 | 0000 | 0 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |
| 00000000 | 00 | 0000 | 1 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |
| 00000000 | 00 | 0000 | 1 | 0001 | 1111111 | 000000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |

2．A jump to a routine to store the product in the destination will be handled similarly．
3．Multiplication will be unsigned；the result will be placed in two temporary locations of the ＇AS888．
4．An update to the program status word，which the user can access at the macrocode level，must also be performed but is not shown．
Assembler code is shown in Table 4－7；a microcode listing is given in Table 4－8．The first two lines of microcode are subroutine jumps to opcode fetching routines，which store the operands in register files 2 and 3 in the＇AS888．The next two instructions load up the＇AS890 with a counter constant for the multiply loop，load the MQ register of the＇AS888 with the multiplier and clear the register that is temporarily used for the accumulator．

A loop is then entered to perform the multiply instruction 32 times to form the product，with the multiplicand coming from the internal register file of the ＇AS888．Upon exiting the loop，the MQ register is stored
in a temporary register location in the＇AS888．The MQ register now contains the least significant bits of the result and the temporary accumulator the most significant bits．A subroutine jump is made to the program status word update routine；this will take the status flags of the last multiplication iteration and change the macrolevel status word．The next subroutine jump is to a destination routine，which is followed by a branch to the FETCH routine to get the next macroinstruction to be executed．

## SYSTEM ENHANCEMENTS

The above example provides a broad overview of 32－bit system design using the＇AS888 and＇AS890．Certain additional options may enhance system performance．These include：

1．Status latching．The design does not take into account changes that need to be examined at the microlevel while retaining macrolevel status information．One solution would be to include another register in parallel to the status latch
and provide control to choose between the two to form the condition code value.
2. Interrupts. To efficiently use a computer system, interrupts are used to alter program flow in the case of I/O programming and realtime applications (involving hardware timers). To include this capability, external hardware must be included and the microcode modified accordingly.
3. Control store. One way of implementing microprogram memory is to use a ROM-based design. It is becoming more common to design a writable control store, a completely RAMbased or part RAM, part ROM storage system, that can be altered by system operation, such as initialization from a floppy disk subsystem, or by the user to optimize or implement new macrolevel instructions. The cost of implementation must be weighed with the risks involved in changing instructions which may not be supported by other sites.
4. Instruction word definitions. Changing the instruction word definitions will have an effect on both system design and performance. Removing Type 3 instructions from the design, for example, will have an effect on both
hardware and software: the external register file addressing must be changed and the 1-of-2 selector removed. Likewise, changing the opcode length may restrict the instruction address capability and also cause either an increase or decrease in the microcode size.
5. Dynamic memory access (DMA). The above system does not support dynamic memory access. To include this function requires a change in the address output control, along with support circuitry for the type of DMA selected. Some error detection and correction logic for main memory might also be included.
6. Computer control unit. The design presented here shows a one-level pipeline architecture that is instruction-data based. System throughput may be increased by converting to a pipeline of greater depth, or using another variety of one-level pipeline, such as instruction-address based or address-data based. Care must be taken when increasing the size of the pipeline, especially when handling branch/jump situations. The reader is advised to carefully research this area before implementing any design.

Table 4-9. Critical Delay Path Analysis

| CONTROL LOOP |  |  | DATA LOOP |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| COMPONENT | DATA PATH | TIME (NS) | COMPONENT | DATA PATH | TIME (NS) |
| Pipeline register <br> MUX <br> 'AS890-1 <br> PROM <br> Pipeline register | Clock to output <br> Select to output <br> $\overline{\mathrm{CC}}$ to output <br> Access time <br> Setup time | $\begin{array}{r} 9 \\ 13 \\ 25 \\ 20 \\ \hline 2 \\ \hline 69 \end{array}$ | $\begin{aligned} & \text { 'AS888-1 } \\ & \text { 'AS182 } \\ & \text { 'AS888-1 } \\ & \text { 'AS888-1 } \end{aligned}$ | Clock to $\mathrm{C}_{\mathrm{n}}$ <br> $C_{n}$ to $C_{n+z}$ <br> $\mathrm{C}_{\mathrm{n}}$ to $\overline{\mathrm{SIO}}$ <br> $\overline{\mathrm{SIO}}$ to Y | $\begin{array}{r} 46 \\ 5 \\ 25 \\ 14 \\ \hline 90 \end{array}$ |

Table 4-10. Fetch Timing Comparison

|  | 'AS888 |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| FETCH | 32-BIT | Z8001 | $\mathbf{8 0 8 6 - 1}$ | $\mathbf{8 0 2 8 6}$ | $\mathbf{6 8 0 0 0 L}$ |
| Data width | 32 | 16 | 16 | 16 | 16 |
| No. of cycles | 4 | 3 | 4 | 4 | 4 |
| Clock rate | 11.11 MHz | 4 MHz | 10 MHz | 10 MHz | 8 MHz |
| Total time | 360 ns | 750 ns | 400 ns | 400 ns | 600 ns |

Table 4-11. Multiply Timing Comparison

|  | 'AS888 | 'AS888 |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| MULTIPLY | $\mathbf{3 2 - B I T}$ | $\mathbf{1 6 - B I T}$ | $\mathbf{Z 8 0 0 1}$ | $\mathbf{8 0 8 6 - 1}$ | $\mathbf{8 0 2 8 6}$ | $\mathbf{6 8 0 0 0 L}$ |
| Size | $32 \times 32$ | $16 \times 16$ | $16 \times 16$ | $16 \times 16$ | $16 \times 16$ | $16 \times 16$ |
| No. of cycles | 35 | 19 | 70 | 128 | 21 | $\leq 74$ |
| Clock rate | 11.11 MHz | 10.98 MHz | 4 MHz | 10 MHz | 10 MHz | 8 MHz |
| Total time | $3.150 \mu \mathrm{~s}$ | $1.729 \mu \mathrm{~s}$ | $17.5 \mu \mathrm{~s}$ | $12.8 \mu \mathrm{~s}$ | $2.1 \mu \mathrm{~s}$ | $\leq 9.25 \mu \mathrm{~s}$ |

## TIMING AND SYSTEM THROUGHPUT

A critical path analysis was undertaken to determine the maximum clock rate for the proposed system. The longest delay path is the multiplication data path, which involves the internal register file and the shift function of the 'AS888. Table 4-9 contains the critical delay calculations for both the ALU and CCU. Since both portions of the system must be satisfied, a clock rate of 90 ns was selected for the following comparisons.

## FETCH ANALYSIS

Most microprocessors perform an instruction fetch in a pipeline mode; the next instruction is fetched while the current instruction is executing. The fetch code shown earlier requires a minimum of four cycles: three to issue the code and one to break the pipeline for processing the batch. This results in a total time of 360 ns , based on a 90 ns cycle time. Fetch times for the representative microprocessors have been estimated from data books and are shown in Table 4-10; wait states for slow memory are not included. As can be seen from the table, the 'AS888 design example is estimated to run from 1.1 to 2.1 times faster than the 16 -bit microprocessors.

## MULTIPLICATION ANALYSIS

This analysis assumes that multiplication is unsigned integer and register to register based. No account is taken of time needed for instruction fetch or operand fetch or store.

The basic loop for the multiply takes 35 cycles: 2 for accumulator and multiplier setup, 32 for actual multiply loop and 1 to store the least significant bits in an internal register file. Given a cycle time of 90 ns , a 32 by 32 bit multiplication can be implemented in 2.275 microseconds. A 16-bit multiply requires 16 iterations of the inner loop; both timings are included in Table 4-11 for comparison. Values for the 16-bit multiplies of the representative microprocessors have been estimated from data books.

As shown in Table 4-11, the 16 by 16 multiply can be performed with the 'AS888 at a faster rate than the 16 -bit microprocessors. Even comparing the 32 by 32 multiply of the application design, one can see that the 'AS888 based system has a better macroinstruction execution speed. Using the 'AS888 and 'AS890 in a system design will allow high throughput and a flexible architecture."

## Section 5

## An Adaptive Clock Generator To Increase 'AS888 System Speed

'AS888-1 instructions execute within 50 to 90 ns ; over half execute in less than 60 ns . It is therefore possible to enhance the speed of an 'AS888 system using an adaptive clock generator that spaces clock pulses according to the time required to complete each operation. The advantage of using this circuit is that the system can process each instruction in almost exactly the time it takes the desired results to reach steady-state. The alternative is to use a periodic 90 ns clock and waste use of 'AS888 "idle time." Just how fast the system will run with the adaptive clock is a function of the statistical distribution of microinstructions within any given microprogram.

The time required for an 'AS888 instruction depends on whether shift, carry, register file read, ZERO status test and/or N status test are used. These operations require varying lengths of time to execute, depending on the number of 'AS888 internal delays involved. Whether shift and/or carry are used is determined by the 'AS888 instruction field. ALU source operands can originate from the register file or the DA and DB buses; this is determined by the state of the $\overline{\mathrm{EA}}$ and EB1-EB0 inputs. Whether or not ZERO or N status are tested depends on other system signals, such as a status select field in the microinstruction to select ALU status during conditional branching. Depending on the system architecture, the pipelining scheme used and the flexibility of the microprogram, the designer may wish to ensure that test ZERO and test N signals be made available during the cycle in which ZERO or N are generated in order to better match clock pulse spacing to processing delay. By also providing a register file read signal, the clock spacing will be optimally matched to the processing delay.

## CIRCUIT DESCRIPTION

A diagram of the adaptive clock circuit is given in Figure 5-1. The circuit consists of a PROM decoder and a programmable oscillator. The PROM contains a table of cycle length codes as a function of the 'AS888 instruction field, register file read (RFRD), ZERO test (ZTST) and N test (NTST). These signals are connected to the PROM address inputs from the control store outputs as shown. If the RFRD, ZTST and NTST signals are not available, these inputs can be tied high, or a smaller PROM can be used.

The cycle length codes residing in PROM are used to select one of nine delays in the programmable delay line oscillator. The selected delay provides the phase shift required for oscillation. Two progammable delay lines (Data Delay Devices PDU-1613-5) are needed; they must be alternately switched into the feedback loop so that each has
time to empty. The programmable delay lines establish the timing from leading edge to leading edge of the clock for an overall error of only $\pm 3.5$ ns. The delays for various fixed-length delay lines are indicated by the numbers in the numbered boxes in Figure 5-1.

Timing for this circuit is shown in Figure 5-2. RST initializes the circuit. When RST releases, the open collector output of U4a provides an initial rising edge from which all successive rising edges are regenerated. Toggle flip-flop U3a switches between the two halves of the oscillator. Latches U6a and U6b are alternately enabled by the Q and $\overline{\mathrm{Q}}$ outputs of U3b. In this manner only one delay line at a time is selected to receive a pulse. U3a generates $\overline{\mathrm{OE} 1}$ and $\overline{\mathrm{OE} 2}$ which select the available delay line for output. The pulse width regulation is also initiated by U3a. TQ and TQ serve as references for edge detectors U5a-U5d. The fixed delay lines shape $\overline{\mathrm{OC1}}$, CLR1, $\overline{\mathrm{OC} 2}$, and CLR2. The output control $\overline{\mathrm{OC} 1}$ (or $\overline{\mathrm{OC} 2}$ ) on U6a (or U6b) turns off several nanoseconds after a rising transition in TQ (or $\overline{\mathrm{TQ}}$ ) has occurred thereby holding Q 1 (or Q2) high. This stretches the on-time of the pulse to nearly 50 ns . U6a (or U6b) is cleared 10 ns later. After another 10 ns the output control turns on again, allowing the Q which was just cleared to establish the falling edge of the stretched pulse. This stretched pulse then enters the selected delay line, U7 (or U8), exiting at a time established by the cycle length code. The delay line output enable, $\overline{\mathrm{OE} 1}$ (or $\overline{\mathrm{OE} 2}$ ) switches in the delay line before its pulse is ready to exit. In this manner, the width of the previous pulse is regulated to within 20 to 30 ns .

## PROM PROGRAM

The cycle lengths are defined by analyzing the propagation delays from the 'AS888 data sheet given in Table 5-1. Variations in cycle lengths depend on whether shift, carry, register file read, ZERO test or N test are used. The algorithm for determining cycle length is flowcharted in Figures 5-3-5-6. Total cycle length is found by adding up all the contributing delays for each possible case. Sums less than 50 ns must be adjusted to 50 ns since this is the minimum clock cycle length specified in the data sheet. Seven nanoseconds is used as the propagation time for $\overline{\mathrm{G}} / \mathrm{P}$ to Cn ; this assumes an 'AS182 lookahead carry generator is used with the 'AS888. Each total delay is rounded up to the nearest integer multiple of 5 ns , which gives nine possible outcomes.

Use of the shifters or carry is inherent in each instruction as shown in Table 5-2. Cycle length codes can be generated by looking up Table 5-2 for each instruction, performing the algorithm in Figures 5-3-5-6, and encoding


Figure 5－1．Adaptive Clock Generator Circuit


Figure 5-2. Adaptive Clock Generator Timing Diagram

Table 5-1. 'AS888-1 Timing Characteristics

| PARAMETER | FROM (INPUT) | TO (OUTPUT) |  |  |  |  |  |  |  |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Y | $C_{n}+8$ | $\overline{\mathbf{G}, \overline{\mathbf{P}}}$ | Z* | N | OVR | DA | DB | $\overline{\mathbf{0 1 0}}$ | $\overline{\text { sio }}$ |  |
| ${ }^{\text {tpd }}$ | A3-AO, B3-в0 | 44 | 30 | 36 | 50 | 44 | 44 | 17 | 17 | 48 | 48 | ns |
|  | DA7-DA0, DB7-DB0 | 36 | 24 | 24 | 46 | 41 | 32 | - | - | 40 | 40 |  |
|  | $\mathrm{C}_{\mathrm{n}}$ | 22 | 8 | - | 27 | 21 | 16 | - | - | 25 | 25 |  |
|  | $\overline{E A}$ | 40 | 25 | 25 | 49 | 41 | 41 | - | - | 44 | 44 |  |
|  | EB | 40 | 25 | 25 | 49 | 41 | 41 | - | - | 44 | 44 |  |
|  | 17-10 | 46 | 27 | 27 | 50 | 42 | 35 | - | - | 45 | 45 |  |
|  | OEB | - | - | - | - | - | - | - | 12 | - | - |  |
|  | $\overline{\text { OEY }}$ | 12 | - | - | - | - | - | - | - | - | - |  |
|  | OIO (n) <br> Shift | 14 | - | - | 20 | - | - | - | - | - | - |  |
|  | $\begin{aligned} & \hline \overline{\text { SIO (n) }} \\ & \text { Shift } \end{aligned}$ | 14 | - | - | 20 | 18 | - | - | - | - | - |  |
|  | CK | 50 | 46 | 46 | 50 | 50 | 50 | 30 | 30 | 50 | 50 |  |
|  | $\overline{\text { OEA }}$ | - | - | - | - | - | - | 12 | - | - | - |  |
|  | SSF** | - | - | - | - | - | 9 | - | - | - | - |  |

*Load resistor R1 $=100$
**For byte instructions only.
NOTE 1: For load circuit and voltage waveforms, see page 1-12 of The TTL Data Book, Volume 3, 1984.
each of the nine possible time delays with a number from 0 to 8. A BASIC program which follows this procedure and generates the PROM data in Data I/O hex-ASCII format is shown in Program 5-1. Program lines 147-149 look up carry. and shift for each instruction. Once carry and shift are known, the program solves the total delay algorithm in Figures

5-3-5-6 for all cases of ZTST, NTST, and RFRD as shown in program lines 163-184. At this point the actual time to process the microinstruction for the given conditions is solved. The time values are then encoded from 0 to 8 in program lines 188-195. The output is listed in Figure 5-7.

Table 5-2. Shift and Carry as a Function of 17-I0

| GROUP 1 INSTRUCTIONS |  |  |  |
| :---: | :---: | :---: | :---: |
| INSTRUCTION BITS (I3-IO) HEX CODE | MNEMONIC | CARRY | SHIFT |
| 0 <br> 1 <br> 2 <br> 3 <br> 4 <br> 5 <br> 6 <br> 7 <br> 8 <br> 9 <br> A <br> B <br> C <br> D <br> E <br> F | ADD <br> SUBR <br> SUBS <br> INCS <br> INCNS <br> INCR <br> INCNR <br> XOR <br> AND <br> OR <br> NAND <br> NOR <br> ANDNR | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \end{aligned}$ |  |
| GROUP 2 Instructions |  |  |  |
| INSTRUCTION BITS (17-I4) HEX CODE | MNEMONIC | CARRY | SHIFT |
| 0 1 2 3 4 5 6 7 8 9 A B C D E F | SRA <br> SRAD <br> SRL <br> SRLD <br> SLA <br> SLAD <br> SLC <br> SLCD <br> SRC <br> SRCD <br> MOSRA <br> MOSRL <br> MOSLL <br> MOSLC <br> LOADMQ <br> PASS |  |  |

Table 5-2. Shift and Carry as a Function of 17-10 (Continued)

| GROUP 3 Instructions |  |  |  |
| :---: | :---: | :---: | :---: |
| INSTRUCTION BITS (17-IO) HEX CODE | MNEMONIC | CARRY | SHIFT |
| O8 18 28 38 48 58 68 78 88 98 A8 B8 C8 D8 E8 F8 | SET1 SETO TB1 TB0 ABS SMTC ADDI SUBI BADD BSUBS BSUBR BINCS BINCNS BXOR BAND BOR | $\begin{aligned} & r \\ & r \\ & r \\ & r \\ & r \end{aligned}$ |  |
| GROUP 4 INSTRUCTIONS |  |  |  |
| $\begin{aligned} & 00 \\ & 10 \\ & 20 \\ & 30 \\ & 40 \\ & 50 \\ & 60 \\ & 70 \\ & 80 \\ & 90 \\ & \text { AO } \\ & \text { BO } \\ & \text { CO } \\ & \text { DO } \\ & \text { EO } \\ & \text { FO } \end{aligned}$ | $\begin{gathered} \text { CRC } \\ \text { SEL } \\ \text { SNORM } \\ \text { DNORM } \\ \text { DIVRF } \\ \text { SDIVOF } \\ \text { SMULI } \\ \text { SMULT } \\ \text { SDIVIN } \\ \text { SDIVIS } \\ \text { SDIVI } \\ \text { UDIVIS } \\ \text { UDIVI } \\ \text { UMULI } \\ \text { SDIVIT } \\ \text { UDIVIT } \end{gathered}$ | $\begin{aligned} & r \\ & r \\ & r \\ & r \\ & r \\ & r \\ & r \\ & r \end{aligned}$ | $\begin{aligned} & r \\ & r \\ & r \\ & r \end{aligned}$ |
| GROUP 5 INSTRUCTIONS |  |  |  |
| OF <br> 1F <br> $2 F$ <br> 3F <br> 4F <br> 5F <br> 6F <br> 7F <br> 8 F <br> 9F <br> AF <br> BF <br> CF <br> DF <br> EF <br> FF | $\begin{gathered} \text { CLR } \\ \text { CLR } \\ \text { CLR } \\ \text { CLR } \\ \text { CLR } \\ \text { CLR } \\ \text { CLR } \\ \text { BCDBIN } \\ \text { EX3BC } \\ \text { EX3C } \\ \text { SDIVO } \\ \text { CLR } \\ \text { CLR } \\ \text { BINEX3 } \\ \text { CLR } \\ \text { NOP } \end{gathered}$ |  | $r$ |



Figure 5-3. Propagation Delay Without Carry and Without Shift


Figure 5-4. Propagation Delay Without Carry and With Shift


Figure 5-5. Propagation Delay With Carry and Without Shift


Figure 5-6. Propagation Delay With Carry and With Shift

DEF INT $A-Z$
DIM TABLE (4096)
DEFINE TRANSMISSION CONTROL CHARACTERS
STX $\$=C H R \$(2)$
ETX $\$=$ CHR $\$(3)$
$C R \$=C H R \$(13)+C H R \$(10)$
$T X \$=S T X \$$
$B S \$=C H R \$(8)$
118
119
infut user's PROM data file name and open the file
PRINT:INPUT "PROM DATA OUTPUT FILE NAME";OF\$ : PRINT
OPEN "O",\#1,OF\$ : PRINT "WRITING CYCLE LENGTH CODES TO ";OF\$;"...": PRINT
SET UP DATA I/O PROGRAMMER FOR HEX-ASCII (COMMA) FORMAT
PRINT \#l,"53A"
FOR EACH 'AS888 INSTRUCTION (BITS I7-I0), DETERMINE IF
SHIFT AND/OR CARRY ARE USED
FOR I7I4 $=0$ TO 15
FOR I3IO $=0$ TO 15
140

```
DEFINE THE 8-BIT INSTRUCTION FIELD AND IDENTIFY WHICH GROUP(S)
THE INSTRUCTION BELONGS TO
I7IO = 17I4 * 16 + 13I0
GROUPl = (I3I0<>0) AND (I3I0<>8) AND (I3I0<>15)
GROUP2 = GROUP1
GROUP3 = (1310 = 8)
GROUP4 = (I3IO = 0)
GROUP5 = (I3I0 = 15)
DETERMINE WHETHER THE INSTRUCTION USES SHIFT AND/OR CARRY
CARRY = (GROUPI AND (I7I4<8))
OR (GROUP3 AND (I7I 4>3) AND (I7I4<13))
OR (GROUP4 AND (I7I4<>0) AND (I7I4<>3) AND (I7I4<>8))
OR (GROUP5 AND ( (I7I4>7) AND (I7I4<11) OR (I7I4 = 13)))
SHIFT = 
```

GIVEN WHETHER SHIFT AND/OR CARRY ARE USED, FIND THE WORST CASE DELAY
( in increments of 5 NS) if register file read, ZERO test and/or $N$ test
also occur
FOR RF $=0$ TO -1 STEP -1
FOR $z=0$ TO -1 STEP -1
FOR $N=0$ TO -1 STEP -1
SOLVE PROPAGATION DELAY USING 'AS888 DATA SHEET; ROUND UP TO NEAREST
5 NS INCREMENT
IF NOT CARRY AND NOT SHIFT THEN TIME $=50$
IF NOT CARRY AND SHIFT AND NOT RF AND $Z \quad$ THEN TIME $=60$
NOT CARRY AND

```
167 IF NOT CARRY AND
168 IF NOT CARRY AND
169 IF NOT CARRY AND
170 IF NOT CARRY AND
1 7 1
172
173 I
174 I
175
176 IF
177 IF
178
179 IF CARRY AND
180
181
182
183 I
184 I
185
186
187
188 IF TIME = 50 THEN CODE = 0
189 IF TIME = 55 THEN CODE = 1
190 IF TIME = 60 THEN CODE = 2
191 IF TIME = 65 THEN CODE = 3
192 IF T.IME = 70 THEN CODE = 4
193 IF TIME = 75 THEN CODE = 5
194 IF TIME = 80 THEN CODE = 6
196 IF TIME = 90 THEN CODE = 8
197
198', WRITE THE SELECT CODE TO THE OUTPUT FILE
199, IN DATA I/O HEX ASCII (COMMA) FORMAT
200
201 IF ADDR=4095 THEN TX$=ETX$
202 IF ADDR/16=INT(ADDR/16) THEN PRINT #l,TX$;"$A";RIGHT$("000"+HEX$(ADDR),4);".
"; ELSE PRINT #l,",";
203 PRINT #1,"0";RIGHT$(STR$(CODE),1);
204 ADDR=ADDR+1
205 TX$=ETX$+CR$+STX$
206 NEXT:NEXT:NEXT
207 PRINT STRING$(14,8);INT(100*ADDR/4096);"%";TAB(6);" COMPLETE.";
208 NEXT:NEXT
209 CLOSE I:PRINT"PROM DATA FILE ";OF$;" IS READY.":SYSTEM
210
211
2l2
```



53A
$\$ A 0000.01,02,02,02,03,04,04,04,07,08,08,08,04,05,06,06$ $\$ A 0010.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 0020.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ 40030.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 0040.00,00,00,00,00,00,00,00,07,08,08,08,04,05,06,06$ \$A0050.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$ A 0060.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ 40070.07,08,08,08,04,05,06,06,00,00,00,00,00,00,00,00$ $\$ A 0080.03,03,04,04,01,01,02,02,07,08,08,08,04,05,06,06$ $\$ 40090.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ \$A00A0.07, 08, 08, 08, 04, 05,06,06,07,08, 08, 08,04, 05,06,06 \$A00B0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$ A 00 C 0.00,00,00,00,00,00,00,00,07,08,08,08,04,05,06,06$ \$A00D0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 \$A00E0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$$ \$00F0.07,08,08,08,04,05,06,06,00,00,00,00,00,00,00,00 $\$ A 0100.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 0110.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 0120.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 0130.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 0140.00,00,00,00,00,00,00,00,07,08,08,08,04,05,06,06$ \$A0150.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 \$A0160.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$ A 0170.07,08,08,08,04,05,06,06,00,00,00,00,00,00,00,00$ \$A0180.01,02,02,02,03,04,04,04,07,08,08,08,04,05,06,06 $\$ A 0190.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 01 A 0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ \$A01B0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$ A 01 C 0.00,00,00,00,00,00,00,00,07,08,08,08,04,05,06,06$ \$A01D0.07,08,08,08,04, 05,06,06,07,08,08,08,04,05,06,06 \$A01E0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$ A 01 F 0.07,08,08,08,04,05,06,06,00,00,00,00,00,00,00,00$ $\$ A 0200.03,03,04,04,01,01,02,02,07,08,08,08,04,05,06,06$ $\$ 40210.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ \$A0220.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 \$A0230.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$ A 0240.03,03,04,04,01,01,02,02,07,08,08,08,04,05,06,06$ \$A0250.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$ A 0260.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 0270.07,08,08,08,04,05,06,06,00,00,00,00,00,00,00,00$ $\$ A 0280.03,03,04,04,01,01,02,02,07,08,08,08,04,05,06,06$ \$A0290.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 \$A02A0.07, $08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ \$A02B0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$ A 02 \mathrm{C} 0.03,03,04,04,01,01,02,02,07,08,08,08,04,05,06,06$ \$AO2DO.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$ A 02 \mathrm{E} 0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 02 F 0.07,08,08,08,04,05,06,06,00,00,00,00,00,00,00,00$ $\$ A 0300.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ \$A0310.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$ 40320.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ \$A0330.07,08, 08,08,04,05,06,06,07,08,08,08,04,05,06,06 \$A0340.03,03,04,04,01,01,02,02,07,08,08,08,04,05,06,06 $\$ 40350.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 0360.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 0370.07,08,08,08,04,05,06,06,00,00,00,00,00,00,00,00$ $\$ A 0380.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ $\$ A 0390.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ \$A0 3A0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 $\$ A 03 B 0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06$ \$AO3C0.03,03,04,04,01,01,02,02,07,08,08,08,04,05,06,06 \$A03D0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 \$A03E0.07,08,08,08,04,05,06,06,07,08,08,08,04,05,06,06 \$A03F0.07,08,08,08,04,05,06,06,01,02,02,02,03,04,04,04
\$A0400.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 $\$ A 0410.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ \$A0420.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 \$A0430.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 $\$ A 0440.03,03,04,04,01,01,02,02,01,02,02,02,03,04,04,04$ $\$ 40450.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ $\$ A 0460.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ $\$ A 0470.01,02,02,02,03,04,04,04,03,03,04,04,01,01,02,02$ $\$ A 0480.07,08,08,08,04,05,06,06,01,02,02,02,03,04,04,04$ $\$ A 0490.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ \$A04AO.01, 02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 $\$ A 04 \mathrm{BO} .01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ $\$ A 04 \mathrm{CO} 03,03,04,04,01,01,02,02,01,02,02,02,03,04,04,04$ $\$ A 04 D 0.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ \$AO LE0.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 $\$ A 04 F 0.01,02,02,02,03,04,04,04,03,03,04,04,01,01,02,02$ \$A0500.07,08,08,08,04,05,06,06,01,02,02,02,03,04,04,04 $\$ A 0510.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ $\$ A 0520.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ $\$ A 0530.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ $\$ A 0540.03,03,04,04,01,01,02,02,01,02,02,02,03,04,04,04$ $\$ A 0550.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ \$A0560.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 \$A0570.01,02,02,02,03,04,04,04,03,03,04,04,01,01,02,02 \$A0580.07,08,08,08,04,05,06,06,01,02,02,02,03,04,04,04 $\$ 40590.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ \$A05AO.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 \$A05B0.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 \$A05C0.03,03,04,04,01,01,02,02,01,02,02,02,03,04,04,04 \$A05D0.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 \$A05E0.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 \$A05F0.01,02,02,02,03,04,04,04,00,00,00,00,00,00,00,00 $\$ A 0600.07,08,08,08,04,05,06,06,01,02,02,02,03,04,04,04$ $\$ 40610.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ $\$ 40620.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ \$A0630.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 \$A0640.03,03,04,04,01,01,02,02,01,02,02,02,03,04,04,04 \$A0650.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 $\$ 40660.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ $\$ A 0670.01,02,02,02,03,04,04,04,00,00,00,00,00,00,00,00$ \$A0680.07,08,08,08,04,05,06,06,01,02,02,02,03,04,04,04 $\$ 40690.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04$ \$A06A0.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 \$A06B0.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 $\$ A 06 C 0.00,00,00,00,00,00,00,00,01,02,02,02,03,04,04,04$ \$A06D0.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 \$A06E0.01,02,02,02,03,04,04,04,01,02,02,02,03,04,04,04 \$A06F0.01,02,02,02,03,04,04,04,07,08,08,08,04,05,06,06 $\$ 40700.07,08,08,08,04,05,06,06,00,00,00,00,00,00,00,00$ $\$ 40710.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ $\$ 40720.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ $\$ 40730.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ $\$ 40740.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ $\$ 40750.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ $\$ A 0760.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ $\$ 40770.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ \$A0780.07,08,08,08,04,05,06,06,00,00,00,00,00,00,00,00 $\$ 40790.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ $\$ A 07 A 0.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ $\$ A 07 B 0.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ $\$ A 07 C 0.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ \$A07D0. $00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ \$A07E0. $00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$ $\$$ AOTF $0.00,00,00,00,00,00,00,00,00,00,00,00,00,00,00,00$

Figure 5-7. PROM Data

## Section 6

## Floating-Point System Design Using the 'AS888/'AS890

Bit-slice processor architecture addresses the problem of optimizing system performance while allowing the user to balance hardware complexity against software flexibility. Bit-slice systems usually operate at or near the speed of the most primitive of programmable processors, the PROM state sequencer. Of course, bit-slice architecture incorporates circuitry dedicated not only to sequencing, but also data processing (ALU) operations. In keeping with the trend of these programmable devices to track the speed of fast discrete hardware, the 'AS888 8-bit slice ALU and 'AS890 microsequencer have been produced in Advanced Schottky bipolar technology. In addition to sheer speed, the components feature greater density ( 2 micron geometry) for greater functionality (more special purpose circuitry on board). The impact will be faster, more powerful systems in applications which previously pushed the limits of bit-slice processors.

Consider an application in which bit-slice architecture has dominated for years: CPU design. The microprogrammed CPU itself spans a spectrum of uses ranging from general purpose minicomputers to compact airborne computers. A specific example which illustrates various facets of design using the 'AS888 and 'AS890 is a CPU with a floating-point utility to compute $\sin (x)$.

The design process can be subject to many influences, including personal preference, available development tools, peculiarities of the application, and constraints from the user, customer or manufacturing environment. No hard and fast design rules could be applied universally, but most designers will start with a specific plan in mind.

The goal of this example is to produce the hardware and microprogram which will implement the $\sin (x)$ function in floating-point arithmetic. Before the microprogram can be assembled, the hardware must be defined since the fields of
the microinstruction are dedicated to specific hardware once the microinstruction register is hardwired to the devices it controls. Since the final architecture chosen depends on tradeoffs between implementing certain operations in hardware or software, critical applications will require that a cursory analysis of the software be made before the hardware is cast in concrete. Attempting to develop microcode for a tentative architecture will force the issue on which operations are better suited for hardware. Before the architecture or the microprogram requirements can be known, the algorithms which describe the application processes must be defined. Once an algorithm is formulated it can be broken down into operations involving variable and constant quantities. The variables can be assigned to registers and then the algorithm can be translated into a microprogram. The following steps illustrate the plan for this CPU design example incorporating a floating-point $\sin (\mathrm{x})$ utility:

Step 1: Choose a floating-point number system
Step 2: Choose an algorithm for approximating $\sin (x)$
Step 3: Make 'AS888 register assignments
Step 4: Substitute registers for variables in the algorithm
Step 5: Decompose steps of the algorithm into simple operations
Step 6: Translate into 'AS888/890 operations; identify subroutines
Step 7: Expand subroutines into 'AS888/890 operations
Step 8: Evaluate trade-offs and block diagram the hardware
Step 9: Define microinstruction fields during detailed hardware design
Step 10: Assemble the microprogram

## STEP 1: CHOOSE A FLOATING-POINT NUMBER SYSTEM

An IEEE floating-point format will be chosen for this example for portability of data and software. It is important to note that the IEEE defines many standards in arithmetic processing, but for simplicity this example will encompass only number format. Furthermore, while several formats are IEEE compatible, only the basic single-precision format will be considered.

The IEEE basic single-precision format is defined as a 32-bit representation in which the component fields are a 1-bit sign $s$, an 8-bit biased exponent $e$ and a 23-bit fraction $f$ which are assembled in the following order:


The quantity is evaluated as $(-1)^{s} 2^{e}-127(1 . f)$. Not-a-number, zero and infinity have special representations. The one preceding the binary point is implied and is called the implicit one or implicit bit. It coincides with the fact that the digits are normalized (left justified).

## STEP 2: CHOOSE AN ALGORITHM FOR $\operatorname{Sin}(x)$

Many algorithms are discussed in the literature for approximating useful quantities like $\sin (x)$. Literature research is a good place to start to familiarize oneself with various algorithms and trade-offs for a particular application. Computer simulation is also useful to compare algorithms for speed and accuracy. R.F. Ruckdeschel in BASIC Scientific Subroutines, Vol. 1 (BYTE, McGraw-Hill Publications Co., New York, N.Y., 1981, pp. 159-191) discusses trade-offs and provides a simulation in BASIC for a $\sin (x)$ algorithm. An adaptation of this material has been chosen for this example:
A) Reduce angle range to first quadrant. $(0 \leq x \leq \pi / 2)$
B) Compute $\sin (\mathrm{x})=\sum_{\mathrm{n}=0}^{6} \mathrm{~A}_{\mathrm{n}} \mathrm{x}^{2 \mathrm{n}-1}$. The coefficients are:

Coefficient

## Decimal

| $\mathrm{A}_{0}$ | 1.000000 |
| :--- | :---: |
| $\mathrm{~A}_{1}$ | -0.1666667 |
| $\mathrm{~A}_{2}$ | 0.008333333 |
| $\mathrm{~A}_{3}$ | -0.0001984127 |
| $\mathrm{~A}_{4}$ | 0.000002755760 |
| $\mathrm{~A}_{5}$ | -0.00000002507060 |
| $\mathrm{~A}_{6}$ | 0.0000000001641060 |

IEEE hex
3F80 0000
BE2A AAAD
3C08 8888
B950 0D01
3638 EF99
B2D7 5AD5
2F34 6FBC

The algorithm can be implemented in the following steps:
A) Reduce angle range to first quadrant. $(0 \leq \mathrm{x} \leq \pi / 2)$

1) $\operatorname{SIGN}=\operatorname{SGN}(x)$
2) $\mathrm{ABSX}=\|x\|$
3) $\mathrm{XNEW}=\mathrm{ABSX}-2 \pi \times \mathrm{INT}(\mathrm{ABSX} / 2 \pi)$
4) If XNEW $>\pi$ then SIGN $=-$ SIGN and XNEW $=$ XNEW $-\pi$
5) If XNEW $>\pi / 2$ then XNEW $=\pi-$ XNEW
where

$$
\begin{aligned}
& \operatorname{SGN}(x)=\left\{\begin{array}{l}
+1 \text { if } x \geq 0 \\
-1 \text { if } x<0
\end{array}\right. \\
& \operatorname{INT}(x)=\text { integer function }
\end{aligned}
$$

B) Compute $\sin (\mathrm{x}) \simeq \sum_{\mathrm{n}=0}^{6} \mathrm{~A}_{\mathrm{n}} \mathrm{x}^{2 \mathrm{n}-1}$.

1) Let $\mathrm{XSQR}=\mathrm{XNEW}{ }^{2}$; INITIALIZE SINX $=0$
2) Do $i=6$ to 1 step -1

$$
\operatorname{SINX}=\mathrm{XSQR} \times \operatorname{SINX}+\mathrm{A}(\mathrm{i})
$$

Enddo
3) $\operatorname{SINX}=$ SIGN $\times$ XNEW $\times$ SINX

Step B-2 computes the summation in a geometric series for economy. The major difference between steps A and B is that A requires more diverse ALU operations while B uses only multiplication and addition recursively.

## STEP 3: MAKE 'AS888 REGISTER ASSIGNMENTS

Just as in assembly language programming, registers must be allocated for variables. Using Rn to denote the 'AS888 register whose address is n , where $0 \leq \mathrm{n} \leq \mathrm{F}$ (hex), the following register assignments can be made:

```
R0 = X
R1 = SIGN
R2 = ABSX
R3 = XNEW
R4 = XSQR
R5 = SINX
```

The following constants can also be defined:

| Constant | Decimal | IEEE hex |
| :--- | ---: | :--- |
| PI $=\pi$ | 3.141593 | 4059 0FDB |
| PIOVR2 $=\pi / 2$ | 1.570797 | 3FC9 OFDB |
| 2PI $=2 \pi$ | 6.283185 | 40C9 0FDB |
| IOVR2PI $=1 / 2 \pi$ | 0.159155 | 3E22 F981 |

## STEP 4: SUBSTITUTE REGISTERS FOR VARIABLES IN THE ALGORITHM

Now the algorithm can be rewritten with registers replacing variables:
A) Reduce angle range to first quadrant $(0 \leq \mathrm{x} \leq \pi / 2)$.

1) $\mathrm{Rl}=\mathrm{SGN}(\mathrm{R} 0)$
2) $R 2=\|R 0\|$
3) $\mathrm{R} 3=\mathrm{R} 2-2 \pi \times \operatorname{INT}(\mathrm{R} 2 / 2 \pi)$
4) If $\mathrm{R} 3>\pi$ then $\mathrm{Rl}=-\mathrm{R} 1 ; \mathrm{R} 3=\mathrm{R} 3-\pi$
5) If $\mathrm{R} 3>\pi / 2$ then $\mathrm{R} 3=\pi-\mathrm{R} 3$
B) Compute $\sin (\mathrm{x}) \simeq \sum_{\mathrm{n}=0}^{6} \mathrm{~A}_{\mathrm{n}} \mathrm{x}^{2 \mathrm{n}-1}$.
6) Let $\mathrm{R} 4=\mathrm{R} 0^{2}$; INITIALIZE R5 $=0$
7) Do $\mathrm{i}=6$ to 1 step -1

$$
\mathrm{R} 5=\mathrm{R} 4 \times \mathrm{R} 5+\mathrm{A}(\mathrm{i})
$$

Enddo
3) R5 $=\mathrm{R} 1 \times \mathrm{R} 0 \times \mathrm{R} 5$

Since various references to constants are made, it is probably best to load constants as needed rather than attempt to allocate registers for them. Constants can be loaded from a constant field in the microinstruction or from ROM. The trade-off is 32 bits by 16 K of micromemory versus 32 bits by the number of constants (typically less than 16 K ). For this example, it will be assumed that a constant field in the microinstruction is acceptable.

## STEP 5: DECOMPOSE STEPS IN THE ALGORITHM INTO SIMPLE OPERATIONS

The $\sin (x)$ function can be microprogrammed as a subroutine; let FSIN be its entry address. R0 would be loaded with $x$ before FSIN was called. Upon return, R5 would contain $\sin (x)$. Now decompose the steps in the algorithm into simple arithmetic and logical operations. Other operations can be left as functions to be defined later.

FSIN: SUBROUTINE
A) Reduce angle range to first quadrant. $(0 \leq x \leq \pi / 2)$

```
R1 = SGN(R0) ; 1) Let R1 = Sign of R0
R2 = ABS(R0) ; 2) R2 = |R0|
R3 = R2 * 1OVR2PI ; 3) R3 = R2 - 2\pi* INT(R2/2\pi)
R3 = INT(R3)
R3 = R3*2PI
R3 = R2 - R3
Y = R3 - PI ; 4) If R3 > \pi,
Jump if Negative to Step A-5
R1 = - Rl
R3 = R3 - PI ; R3 = R3 - \pi
Y = PIOVR2 - R3
Jump if Negative to Step B-1
R3 = PI - R3
    then R1 = - R1;
5) If R3>\pi/2
```

B) Compute $\sin (x) \simeq \sum_{n=0}^{6} A_{n} x^{2 n-1}$

```
R4 = R0 * R0
R5 = 0
R5 = R4 * R5
R5 = R5 + A6
R5 = R4 * R5
R5 = R5 + A5
R5 = R4 * R5
R5 = R5 + A4
R5 = R4*R5
R5 = R5 + A3
R5 = R4*R5
R5 = R5 + A2
R5 = R4*R5
R5 = R5 + A1
R5 = R4 * R5
R5 = R5 + A0
R5 = R0*R5 ; ;
3)R5=R1 }\times\textrm{R}0\times\textrm{R}
```


## END SUBROUTINE

## STEP 6: TRANSLATE INTO 'AS888/890 INSTRUCTIONS; IDENTIFY SUBROUTINES

The simplified steps of the algorithm can be represented fairly easily as 'AS888/890 instructions. Necessary functions (and suggested names) can be identified by inspection as:

1) FMUL - Floating-point multiplication
2) FADD - Floating-point addition
3) FINT - Floating-point integer conversion
4) FINV - Floating-point additive inverse (to subtract using FADD)
5) FABS - Floating-point absolute value
6) FSGN - Floating-point sign test
7) FCHS - Floating-point change of sign (to multiply by SIGN)
"Function" in this context refers to a special operation regardless of how it is coded. In fact, FMUL and FADD are fairly complex and require detailed explanation. FINV, FABS, FSGN and FCHS are single instruction operations that mask or mask and test. FINT requires several inline instructions or a subroutine and will be left to the interested reader as an exercise. Now the steps of the algorithm can be translated into 'AS888/890 operations which include references to these functions.

## FSIN: SUBROUTINE

; A) Reduce angle range to first quadrant. ( $0 \leq \mathrm{x} \leq \pi / 2$ )

```
    R1 = FSGN(R0)
    ; Get sign bit (MSB)
    R2 = FABS(R0) ; Take absolute value (clear MSB)
    R3 = FMUL(R2,1OVR2PI) ; Multiply register and constant
    R3 = FINT(R3) ; Floating-point integer conversion
R3 = FMUL(R3,2PI) ; Multiply register and constant
R3 = FADD(R2,INV(R3)) ; Subtract registers by adding inverse
Y = FADD(R3,NEGPI) : TEST NEG; Subtract by adding negative constant
JT SIN1 ; Jump if true (jump if negative)
R1 = FINV(R1) ; Complement sign of R1
R3 = FADD(R3,NEGPI) ; Subtract by adding negative constant
SIN1:Y = PIOVR2 - R3 : TEST NEG ; Subtract to compare (don't store)
    JT SIN2 ; Jump if true (jump if negative)
    R3 = FADD(PI,FINV(R3)) ; Subtract by adding negative register
```

$$
\begin{aligned}
& \text {; B) Compute } \sin (x)=\sum_{n=0}^{6} A_{n} X^{2 n-1} \\
& \text { SIN2: R4 }=\text { FMUL(R0,R0) ; Square by multiplying } \\
& \text { R5 = A6 ; Initialize series } \\
& \text { R5 }=\text { FMUL(R4,R5) ; Multiply registers } \\
& \text { R5 }=\text { FADD (R5,A5) ; Add coefficient } \\
& \text { R5 }=\text { FMUL(R4,R5) ; Multiply registers } \\
& \mathrm{R} 5=\mathrm{FADD}(\mathrm{R} 5, \mathrm{~A} 4) \quad \text {; Add coefficient } \\
& \text { R5 }=\text { FMUL }(\text { R4, R5 }) \quad \text {; Multiply registers } \\
& \text { R5 }=\mathrm{FADD}(\mathrm{R} 5, \mathrm{~A} 3) \quad \text {; Add coefficient } \\
& \text { R5 }=\text { FMUL(R4,R5) ; Multiply registers } \\
& \text { R5 }=\text { FADD (R5,A2) ; Add coefficient } \\
& \text { R5 }=\text { FMUL(R4,R5) ; Multiply registers } \\
& \text { R5 }=\operatorname{FADD}(\text { R5, A } 1) \quad \text {; Add coefficient } \\
& \text { R5 }=\text { FMUL }(\text { R4, R5) } \quad \text {; Multiply registers } \\
& \text { R5 }=\text { FADD }(\text { R5,A0) ; Add coefficient } \\
& \text { R5 }=\operatorname{FMUL}(\mathrm{R} 0, \mathrm{R} 5) \quad \text {; Multiply registers } \\
& \text { R5 }=\operatorname{FCHS}(\mathrm{R} 5, \mathrm{R} 1): \text { RETURN ; Change MSB of R5 to MSB of R1 }
\end{aligned}
$$

## END SUBROUTINE

This contrived language has a syntax which may be suitable for a source program. For the sake of illustration, it can be assumed that the microassembler recognizes this particular syntax. The series was computed inline instead of using a loop since it is relatively short. If a loop were used, a means of indexing the constants would be required.

## STEP 7: EXPAND SUBROUTINES INTO 'AS888/890 OPERATIONS

FMUL and FADD algorithms can now be expanded. Since they are called extensively from FSIN, they are more critical to the efficiency of the final design. Wherever possible, it is desirable to reduce the execution time of both in order to maintain efficiency.

## Floating-Point Multiplication

Let M1 be the multiplier and M2 be the multiplicand whose product is P. Let the sign, exponent and fraction fields of their IEEE representation be:

$$
\begin{array}{r}
\mathrm{M} 1:|\mathrm{S} 1| \mathrm{E} 1|\mathrm{~F} 1| \\
\mathrm{M} 2:|\mathrm{S} 2| \mathrm{E} 2|\mathrm{~F} 2| \\
\mathrm{P}:|\mathrm{S} 3| \mathrm{E} 3|\mathrm{~F} 3|
\end{array}
$$

P is found by multiplying mantissas (fraction plus implicit one) and adding exponents. Since M1 and M2 are normalized, the range of $1 . \mathrm{F} 1 \times 1 . \mathrm{F} 2$ is

$$
1.00 \ldots 0 \leq 1 . \mathrm{F} 1 \times 1 . \mathrm{F} 2 \leq 11.1 \ldots 10
$$

The implicit bit may "overflow" into bit position 24. This type of overflow must be detected so that the result can be normalized. Normalization requires right shifting the result of 1.F1 $\times 1 . \mathrm{F} 2$ and incrementing E3. The implicit bit is then cleared when S3, E3 and M3 are packed to form P. The floating-point multiplication algorithm may then be defined as follows:

1) Unpack M1 into signed fraction (SF1) and exponent (E1)
2) Set the implicit bit in SF1
3) Unpack M2 into signed fraction (SF2) and exponent (E2)
4) Set the implicit bit in SF2
5) Perform $\mathrm{SF} 3=\mathrm{SF} 1 \times \mathrm{SF} 2$ using signed integer multiplication
6) Perform $\mathrm{E} 3=\mathrm{E} 1+\mathrm{E} 2$
7) Test SF3 for overflow into bit 24
8) If true, then increment E3 and right shift SF3
9) Clear the implicit bit in SF3
10) Pack E3 and SF3 to get P

As before, the steps of this algorithm can be broken down into simpler operations:

1) Unpack M1 into signed fraction (SF1) and exponent (E1)

$$
\mathrm{El}=\operatorname{FEXP}(\mathrm{M} 1)
$$

$\mathrm{SF} 1=\mathrm{FRAC}(\mathrm{M} 1)$
2) Set the implicit bit in SF1
$\mathrm{SF} 1=\mathrm{SF} 1$ OR BIT23
3) Unpack M2 into signed fraction (SF2) and exponent (E2)
$\mathrm{E} 2=\mathrm{FEXP}(\mathrm{M} 2)$
$\mathrm{SF} 2=$ FRAC (M2)
4) Set the implicit bit in SF2
$\mathrm{SF} 2=\mathrm{SF} 2$ OR BIT23
5) Perform $\mathrm{SF} 3=\mathrm{SF} 1 \times \mathrm{SF} 2$ using signed integer multiplication $\mathrm{SF} 3=\mathrm{IMUL}(\mathrm{SF} 1, \mathrm{SF} 2)$
6) Perform $\mathrm{E} 3=\mathrm{E} 1+\mathrm{E} 2$
$\mathrm{E} 3=\mathrm{E} 1+\mathrm{E} 2$
7) Test SF3 for overflow into bit 24

TEST (SF3 AND BIT24)
JUMP IF FALSE to step 9
8) If true, then increment E3 and right shift SF3

INC E3
SF3 $=$ RSHFT (SF3)
9) Clear the implicit bit in SF3. SF3 $=$ SF3 AND NOT_BIT23
10) Pack E3 and SF3 to get $P$

$$
\mathrm{P}=\mathrm{SF} 3 \mathrm{OR} \mathrm{E} 3
$$

FEXP, FRAC, testing bit 24 and setting/clearing bit 23 are all mask operations that translate into single 'AS888 instructions. The integer multiplication (IMUL) is simply the multiplication algorithm supported by the 'AS888 instruction set. No significant hardware features are required to do floating-point multiplication, nor are any subroutines required to support it.

Register assignments can now be made as before. Since FSIN uses registers in the lower half of the register file, it might be preferable to restrict FMUL to the upper registers. For example:

$$
\begin{aligned}
& \mathrm{RF}=\mathrm{P} \\
& \mathrm{RE}=\mathrm{M} 1, \mathrm{~F} 1, \mathrm{SF} 1 \\
& \mathrm{RD}=\mathrm{M} 2, \mathrm{~F} 2, \mathrm{SF} 2 \\
& \mathrm{RC}=\mathrm{E} 1 \\
& \mathrm{RB}=\mathrm{E} 2
\end{aligned}
$$

RE and RD can share variables that need not be preserved. Using this assignment, FMUL computes RF = FMUL(RE,RD). RE and RD must be loaded prior to calling FMUL and RF must be stored upon return. By substituting registers for variables and reorganizing operations in the FMUL algorithm to better fit 'AS888/890 operations the following source program may be created:

FMUL: SUBROUTINE

$$
\begin{array}{ll}
\mathrm{RC}=\mathrm{FEXP}(\mathrm{RE}) & \text {; Unpack M1 into exponent } \\
\mathrm{RE}=\mathrm{FRAC}(\mathrm{RE}) & \text { and fraction } \\
\mathrm{RE}=\mathrm{RE} \text { OR BIT23 } & \text {; Set implicit bit } \\
\mathrm{MQ}=\text { SMTC(RE) } & \text {; Prepare to multiply } \\
\mathrm{RB}=\text { FEXP(RD) } & \text {; Unpack M2 into exponent } \\
\mathrm{RD}=\text { FMAG(RD) } & \text {; and fraction } \\
\mathrm{RD}=\mathrm{RD} \text { OR BIT23 } & \text {; Set implicit bit } \\
\mathrm{RD}=\text { SMTC(RD) } & \text {; Prepare to multiply }
\end{array}
$$

```
    RE = 0: RCA = #22d ; Initialize to multiply
    RE = SMULI RD : LOOP RCA ; Integer multiplication iteration
    RE = SMULT RD ; Final step in signed multiply
    Y = TB0(RE,BIT1):BYTE = #0100b:TEST Z ; Test 'overflow"
    JF FMUL1 ; Jump if false (exponent ok)
    INEX(RC) ; Increment exponent: add 00800000
    RE = SRA(RE) ; Shift fraction to normalize
FMULI:RC = RC + RB : TEST CARRY ; Add exponents and test carry
    JT ERROR ; Jump if carry true to handler
    RE = SMTC(RE) ; Get sign magnitude fraction
    RE = RE AND # 807F__FFFFh ; Clear implicit bit
    RF = RE OR RC: RETURN ; Pack fraction and exponent
```


## Floating-Point Addition

The floating-point addition algorithm (FADD) is slightly more complex than FMUL, since the two addends will usually not have the same exponent. Therefore the smaller (absolute value) addend must first be chosen by comparing exponents. Then it must be denormalized to align its digits with the digits of the larger addend. In other words, the two addends must have the same exponent before their fractions can be added. This process can be described by the following algorithm:

1) Unpack Al to get SF1 and E1
2) Set implicit bit in SF1
3) Unpack A2 to get SF2 and E2
4) Set implicit bit in SF2
5) If E2 $>$ E1 then go to step 9 $(\|\mathrm{A} 1\| \leq\|\mathrm{A} 2\|)$
6) Let DIFF $=\mathrm{E} 1-\mathrm{E} 2$
7) Do $i=1$ to DIFF SF2 $=$ RSHFT(SF2) (Arithmetic right shift) Enddo
8) Let E3 = E1, go to step 12 $(\|\mathrm{A} 2\|>\|\mathrm{A} 1\|)$
9) Let DIFF = E2 - E1
10) Do $\mathrm{i}=1$ to DIFF

SF1 $=$ RSHFT(SF1) (Arithmetic right shift)
Enddo
11) Let E3 = E2
12) $\mathrm{SF} 3=\mathrm{SF} 1+\mathrm{SF} 2$
13) Test "overflow'" into bit 24
14) Jump if false to step 17
15) Increment exponent E3
16) Normalize signed fraction with right arithmetic shift
17) Clear implicit bit
18) Pack: $\mathrm{SUM}=\mathrm{SF} 3$ or E 3
19) Return

Register assignments for variables must now be made. Since FSIN uses registers in the lower half of the 'AS888 register file, it is necessary to use the upper registers:

```
RF = SUM
RE = Al, Fl, SFl
RD = A2, F2, SF2
RC = EI
RB}=\textrm{E}
```

By slightly reorganizing the sequence to better fit 'AS888/890 operations, the following microprogram to perform FADD can be created:

## FADD: SUBROUTINE

; 1) Unpack Al to get SFl and E1
$\mathrm{RC}=\mathrm{FEXP}(\mathrm{RE}) \quad$; Get exponent $(\mathrm{E} 1)$
RE $=$ FRAC (RE) ; Get signed fraction (SF1)
; 2) Set implicit bit in SF1

| $\mathrm{MQ}=$ RE OR BIT23 | ; Set implicit bit |
| :--- | :--- |
| $\mathrm{RE}=\operatorname{SMTC}(\mathrm{RE})$ | ; Convert to two's complement |

; 3) Unpack A2 to get SF2 and A2
$\mathrm{RB}=\mathrm{FEXP}(\mathrm{RD}) \quad$; Get exponent (E2)
$\mathrm{RD}=\mathrm{FRAC}(\mathrm{RD}) \quad$; Get signed fraction (SF2)
; 4) Set implicit bit in SF2

| RD $=$ RD OR BIT23 | ; Set implicit bit |
| :--- | :--- |
| RD $=$ SMTC(RD) | ; Convert to two's complement |

; 5) If E2 $>$ E1 then go to step 9
$\mathrm{RF}=\mathrm{RC}-\mathrm{RB}:$ TEST NEGATIVE; Compare A2 from A1
JT FADD1 : RCA $=\# 8 \quad$; Jump if E2 $>$ E1; set up loop count
; 6) Let DIFF $=\mathrm{E} 1-\mathrm{E} 2$.
$\mathrm{Y} / \mathrm{RF}=\mathrm{SLC}(\mathrm{RF}):$ LOOP RCA ; Rotate 8 times to get difference
RCA $=\mathrm{Y} / \mathrm{RF} \quad$; Load difference in loop counter
; 7) Do i $=1$ to DIFF
; $\quad \mathrm{SF} 2=\operatorname{RSHFT}(\mathrm{SF} 2)$
; Enddo RD $=\operatorname{SRA}(R D):$ LOOP RCA ; Orient digits of smaller addend
; 8) Let $\mathrm{E} 3=\mathrm{E} 1$, go to step 12 RB $=$ RC : JUMP FADD2 ; Swap registers and branch
; 9) Let DIFF = E2 - E1
FADD1: RF $=\mathrm{NOT}(\mathrm{RF}) \quad$; Complement result of E1 - E2 $\mathrm{Y} / \mathrm{RF}=\operatorname{SLC}(\mathrm{RF}):$ LOOP RCA ; Shift 8 times to get DIFF $\mathrm{RCA}=\mathrm{Y} / \mathrm{RF}$; Load DIFF in loop counter
;10) Do $\mathrm{i}=1$ TO DIFF
SF1 $=$ RSHFT(SF1) Enddo $\mathrm{RE}=\mathrm{SRA}(\mathrm{RE}):$ LOOP RCA ; Align SF1 with SF2
;11) Let E3 = E2 (no instruction required - RB already has E2 in it)
;12) $\mathrm{SF} 3=\mathrm{SF} 1+\mathrm{SF} 2$
FADD2: $\mathrm{RF}=\mathrm{RD}+\mathrm{RE}$; Add $\mathrm{RF}=\mathrm{SMTC}(\mathrm{RF}) \quad$; Convert to sign-magnitude
;13) Test "overflow" into bit 24
RF $=$ TB0 (RF, BIT24) ; Check for normalization
;14) Jump if false to step 17 JF FADD3 ; If so, finish and exit
;15) Else increment exponent INC RB: TEST NEG ; Test for exponent overflow
;16) Normalize signed fraction $R F=\operatorname{SRA}(R F):$ JT ERROR ; Jump to error handler if overflow
;17) Clear implicit bit
FADD3: RF $=$ SET0 (RF, BIT23) ; Reset bit 23 of RF
;18) Pack: $\mathrm{SUM}=\mathrm{SF} 3$ OR E3 RF $=$ RF OR RB: RETURN ; OR signed fraction and exponent

There is an important consequence of FADD which impacts the hardware. Since the number of shifts required to denormalize the small addend is data dependent (computed in the ALU), it is necessary to provide a path between the ALU Y bus and the 'AS890 DRA bus. All the other operations are simple 'AS888/890 instructions, including the FRAC and FEXP mask operations discussed during the development of FMUL. ERROR is a floating-point overflow error handler.

## STEP 8: EVALUATE TRADE-OFFS AND BLOCK DIAGRAM THE HARDWARE

A rough estimate of the FSIN worst case execution time can be arrived at by making the following observations about FSIN, FMUL and FADD:

```
FMUL
    integer recursion }\simeq22\mathrm{ cycles
    other instructions }\simeq18\mathrm{ cycles
    total }~40\mathrm{ cycles
FADD
    denormalization }\simeq23\mathrm{ cycles
    other instructions }\simeq25\mathrm{ cycles
    total }\simeq50\mathrm{ cycles
FSIN
    number of calls to FMUL = 12
    number of calls to FADD = 11
    number of other cycles }\simeq1
```

Approximate worst case total $=10+(12 \times 40)+(11 \times 50)=1040$ cycles. At 50 nanoseconds per cycle, this requires approximately 52 microseconds. There are few improvements that could be made in hardware to speed this time, except perhaps the addition of a flash multiplier which would reduce the integer computation by about 20 cycles (an overall reduction of about two percent). A barrel shifter could have the same benefit during floating-point addition for a total reduction of about 4 percent. For the sake of simplicity, it will be assumed that 52 microseconds is acceptable for the $\sin (\mathrm{x})$ computation.

Another issue which must be considered is the problem of loading the 'AS888 and 'AS890 with constants. A slight materials cost reduction might be realized by storing constants in table PROMs rather than in control store memory. An interesting use of the DRA and DRB ports on the 'AS890 would be to use the output of RCA or RCB to index data in the constant PROM. This would allow long series to be implemented in loop form rather than the inline method used in FSIN. Once again, the constant PROM will not be implemented for the sake of simplicity.

Now the architecture can be designed to meet the requirements identified throughout this analysis:

1) A path between the 'AS888 Y bus and the 'AS890 DRA bus.
2) A path between the microinstruction register and the 'AS890 DRA bus for loading loop counts and branch addresses.
3) A path between the microinstruction register and the 'AS888 Y bus for loading constants.
4) Independent control of $\overline{\text { SIOO }}$ in each 'AS888 slice to allow bit/byte instructions.
5) A status register to store 'AS888 status for testing.
6) A status mux to test the 'AS888 status, bit 23 of the 'AS888 Y bus, bit 24 of the 'AS888 Y bus and hardwired 0 and 1 .

A system having these features is illustrated in Figure 6-1.

## STEP 9: DEFINE MICROINSTRUCTION FIELDS DURING DETAILED HARDWARE DESIGN

The detailed hardware design will produce a wiring diagram that fixes the position within the microinstruction of each of the various control signals that are connected from the microinstruction register to the 'AS888, 'AS890, status mux and any other special hardware. Once this design is complete it is possible for the assembler to sort the control bits of each instruction properly so that they will be properly oriented when the microprogram is installed in the target system.

STEP 10: ASSEMBLE THE MICROPROGRAM
TI is currently developing an 'AS888/890 microassembler. Several microassemblers are commercially available, and many users prefer to write their own. The microprogram shown in Table 6-1 was hand-assembled, but has a syntax that is suitable for interpretation by a user-written assembler.


Figure 6-1. Block Diagram of Floating-Point Processor

Table 6.1. Floating Point $\operatorname{Sin}(\mathbf{x})$ Microprogram

| 0000 SIN: | $\begin{aligned} * R 1 & =\text { FSGN(RO) } \\ \text { R1 } & =\text { R0 AND \#8000 0000h } \end{aligned}$ |
| :---: | :---: |
|  | * R2 $=$ FABS(R0) |
| 0001 | R2 $=$ R0 |
| 0002 | R2 = R0 SETO \#80h : BYTE = \#1000b |
|  | * R3 = FMUL(R2,10VR2PI) |
| 0003 | $\mathrm{RE}=\mathrm{R} 2$ |
| 0004 | RD $=$ \#3EA2 F984h |
| 0005 | JSR FMUL |
| 0006 | R3 $=$ RF |
|  | * R3 $=$ FINT(R3) |
| 0007 | $\mathrm{RF}=\mathrm{R} 3$ |
| 0008 | JSR FINT [EXERCISE FOR READER] |
| 0009 | $\mathrm{R} 3=\mathrm{RF}$ |
|  | * R3 = FMUL(R3,2PI) |
| 000A | $\mathrm{RE}=\mathrm{R} 3$ |
| 0008 | RD $=$ \#40C9 0FDBh |
| 000 C | JSR FMUL |
| 0000 | R3 $=$ RF |
|  | * R3 $=$ FADD(R2,INV(R3)) |
| OOOE | $\mathrm{RE}=\mathrm{R} 2$ |
| 000F | RD = R5 XOR \#8000 0000h |
| 0010 | JSR FADD |
| 0011 | $\mathrm{R} 3=\mathrm{RF}$ |
|  | * $Y$ = FADD(R2,NEGPI) |
| 0012 | $\mathrm{RE}=\mathrm{R} 2$ |
| 0013 | RD = \#C059 OFDBh |
| 0014 | JSR FADD |
| 0015 | $\mathrm{Y}=$ RF : TEST NEG |
| 0016 | JT SIN 1 |
|  | * R1 = FiNV(R1) |
| 0017 | R1 $=$ R1 XOR \#8000 0000h |
|  | * R3 $=$ FADD(R3,NEGPI) |
| 0018 | $\mathrm{RE}=\mathrm{R} 3$ |
| 0019 | RD = \#C059 OFDBh |
| 001A | JSR FADD |
| 0018 | $\mathrm{R} 3=\mathrm{RF}$ |
| * SIN1: | Y = FADD (PIOVR2,INV(R3)) : TEST NEG |
| O01C SIN1: | RE = \#3FC9 OFDBh |
| 0010 | RD = R3 XOR *8000 0000h |
| 001E | JSR FADD |
| $001 F$ | $Y=$ RF : TEST NEG |
| 0020 | JT SIN2 |
|  | * R3 = FADD (P1,FINV(R3)) |
| 0021 | RE = \#4059 OFDBh |
| 0022 | RD = R3 XOR \#8000 0000h |
| 0023 | JSR FADD |
| 0024 | R3 $=$ RF |
| - SIN2: | R4 $=$ FMUL(RO,RO) |
| 0025 SIN2: | $\mathrm{RE}=\mathbf{R O}$ |
| 0026 | RD $=$ RO |
| 0027 | JSR FMUL |
| 0028 | R4 $=$ RF |


|  | 32-bit <br> Constant |  |  | $\begin{gathered} \text { DRB13- } \\ \text { DRBO } \\ \hline \end{gathered}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $00 \times 10211100 \mathrm{FA}$ | 8000000 | 1111 | $027 x$ | x $\times \times \times 1111$ | 7 |
| $00 \times 20 \times 11100 \mathrm{~F}$ | $\times \times \times \times \times \times \times$ | 1911 | $027 x$ | X $\times \times \times \times 1111$ | 7 |
| 0028001110018 | X X X X X X ${ }^{\text {¢ }}$ | 1110 | 027 X | X $\times \times \times 1 \begin{array}{llll}1 \\ 1\end{array}$ | 7 |
| $02 \times \mathrm{O}$ O 11100 F 6 | X X X X X X X | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 x$ | x $\times \times \times 1 \begin{array}{llll}1 & 1\end{array}$ | 7 |
| $0 \times \times \mathrm{CXX} 1111 \mathrm{XFF}$ | 3 EA2F984 | 11111 | $027 x$ | X $\times \times \times \times 1$1 | 7 |
| $1 \times \times \times \times \times 111 \times \times F \mathrm{~F}$ | XXXXXXXX | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | 0140 | 0060111 | 7 |
| $0 \mathrm{FX} 30 \times 11100 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $027 x$ | X $\times \times \times 1111$ | 7 |
| $03 \times \mathrm{O}$ | $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | $027 x$ | X $\times \times \times 1 \begin{array}{llll}1 & 1\end{array}$ | 7 |
| $1 \times \times \times \times \times 111 \times \times F$ | $\times \times \times \times \times \times \times \times$ | 1 111111 | 014. | . . . 1111 | 7 |
| $0 \mathrm{FX} 30 \times 11100 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $027 \times$ | $\times \times \times \times 1111$ | 7 |
| $03 \times \mathrm{OX} 11100 \mathrm{~F} 6$ | X $\times \times \times \times \times \times \mathrm{X}$ | 1111 | $027 x$ | $\times \times \times \times \times 1$ | 7 |
| $0 \times \times \mathrm{CXX11} 10 \times \mathrm{FF}$ | 40 C 90 FDB | 1111 | $027 \times$ | X $\times \times \times \times 1111$ | 7 |
| $1 \times \times \times \times \times 111 \times \times F \mathrm{~F}$ | $\times \times \times \times \times \times \times$ | 1 111111 | 0140 | 00601111 | 7 |
| $0 \mathrm{FX3} 0 \times 11100 \mathrm{~F} 6$ | XXXXXXXX | 1111 | $027 \times$ | ¢ $\times \times \times 1$1 1 | 7 |
| $02 \times \mathrm{O} \times 11100 \mathrm{~F} 6$ | $\mathrm{x} \times \times \times \times \times \times \times$ | 1111 | $027 \times$ | X $\times \times \times \times 1111$ | 7 |
| $05 \times \mathrm{O}$ | 800000000 | 11111 | $027 \times$ | $\mathbf{X} \times \times \times \times 1111$ | 7 |
| $1 \times \times \times \times 111 \times \times F \mathrm{~F}$ | X $\times \times \times \times \times \times \times$ | 111111 | 0140 | 0074111 | 7 |
| $0 \mathrm{FX} 30 \times 11100 \mathrm{~F} 6$ | X $\times \times \times \times \times \times \times$ | $1 \begin{array}{lllll}1 & 1 & 1\end{array}$ | $027 \times$ | $\mathbf{X} \times \times \times 1111$ | 7 |
| $02 \times E 0 \times 11100 F 6$ | $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | $027 x$ | x $\times \times \times \times 1$1 | 7 |
| OXXDXX1110XFF | C 0590 F D B | 11111 | $027 \times$ | $\times \times \times \times 1111$ | 7 |
| $1 \times \times \times \times \times 111 \times \times F F$ | X $\times \times \times \times \times \times \mathrm{X}$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | 0140 | 0074111 | 7 |
| 1 FXXOX 11000 F 6 | X $\times \times \times \times \times \times \mathrm{x}$ | 1 111111 | $027 x$ | X $\times \times \times 1111$ | 2 |
| $1 \times \times \times \times \times 111 \times \times F \mathrm{~F}$ | $\times \times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | 0170 | 0000111 | 7 |
| $01 \times 10211100 \mathrm{Fg}$ | 8000000 | 1111 | $027 x$ | X $\times \times \times 111$ | 7 |
| $03 \times \mathrm{O} \times 11100 \mathrm{~F} 6$ | X X X X X X X | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | $027 x$ |  | 7 |
| $03 \times \mathrm{CXX1111} \mathrm{\times FF}$ | C 0590 FD B | 11111 | $027 x$ | $\times \times \times \times 111$ | 7 |
| $1 \times \times \times \times \times 111 \times \times F$ ¢ | X X X X $\times \times \times \mathrm{X}$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | 0140 | 0074111 | 7 |
| $0 \mathrm{FX} 30 \times 11100 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times$ | 11111 | $027 \times$ | X $\times \times \times 111$ | 7 |
| $0 \times \times \mathrm{EXX1} 1110 \mathrm{~F} 6$ | 35 C 90 FDB | 1111 | $027 x$ | x $\times \times \times 1111$ | 7 |
| $03 \times \mathrm{O} 211100 \mathrm{~F} 9$ | 80000000 | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 x$ | $\mathbf{x} \times \times \times \times 1111$ | 7 |
| $1 \times \times \times \times \times 111 \times \times F$ | $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | 0140 | 0074111 | 7 |
| $1 \mathrm{~F} \times \times 0 \times 11000 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $027 \times$ | $\mathbf{x} \times \times \times 1111$ | 2 |
| $1 \times \times \times \times \times 111 \times \times F$ | $\mathrm{x} \times \times \times \times \times \times \mathrm{x}$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | 0170 | 0000111 | 7 |
| $0 \times \times \mathrm{EX} 11110 \mathrm{~F}$ ¢ | 40590 FD B | 1111 | $027 x$ | x $\times \times \times 1$ | 7 |
| $03 \times \mathrm{O} 211100 \mathrm{~F} 9$ | 80000000 | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 x$ | $\mathbf{x} \times \times \times 1111$ | 7 |
| $1 \times \times \times \times \times 111 \times \times F$ | $\times \times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | 0140 | 0074111 | 7 |
| $0 \mathrm{FX} 30 \times 11100 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $027 \times$ | $\times \times \times \times 111$ | 7 |
| $00 \times 10 \times 11100$ F6 | $\times \times \times \times \times \times \times \times$ | 11111 | $027 x$ | x $\times \times \times \times 1111$ | 7 |
| $00 \times 00 \times 11100 F 6$ | $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 x$ | X $\times \times \times \times 1111$ | 7 |
| $1 \times \times \times \times \times 111 \times \times F$ | $\mathbf{X X X X X X X X}$ | 11111 | 0140 | 0060111 | 7 |
| $0 \mathrm{FX40} \mathrm{\times 11100F61}$ | $\times \times \times \times \times \times \times$ | 1111 | $027 \times$ | $\times \times \times \times 1111$ |  |

Table 6.1. Floating Point $\operatorname{Sin}(\mathbf{x})$ Microprogram (Continued)



Table 6.1. Floating Point $\operatorname{Sin}(\mathbf{x})$ Microprogram (Continued)

|  | * $\mathrm{R} 5=\mathrm{FADD}(\mathrm{R} 5, \mathrm{~A} 0)$ |
| :---: | :---: |
| 0056 | $\mathrm{RE}=\mathrm{R5}$ |
| 0057 | RD $=$ \#3F80 0000h |
| 0058 | JSR FADD |
| 0059 | $\mathrm{R} 5=\mathrm{RF}$ |
|  | * R5 = FMUL (R0,R5) |
| 005A | $R E=R 0$ |
| 005B | $\mathrm{RD}=\mathrm{R} 5$ |
| 005C | JSR FMUL |
| 005D | $\mathrm{R} 5=\mathrm{RF}$ |
|  | * R5 = FCHS(R5,R1) : RETURN |
| 005E | R1 = R1 OR \#7FFF FFFFh |
| 005F | R5 = R5 XOR R1: RETURN |
|  | * RC $=$ FEXP(RE) |
| 0060 FMUL: | RC $=$ RE AND \#7F80 0000h |
|  | * RE $=$ FRAC(RE) |
| 0061 | RE $=$ RE AND \#807F FFFFh |
|  | * RE = RE OR bit23 |
| 0062 | RE = RE OR \#0080 0000h |
|  | * MQ = SMTC(RE) |
| 0063 | $R E=S M T C(R E)$ |
| 0064 | LOADMQ : PASS |
|  | * $\mathrm{RB}=\mathrm{FEXP}(\mathrm{RD})$ |
| 0065 | RB $=$ RD AND \#7F80 0000h |
|  | * $\mathrm{RD}=\mathrm{FRAC}(\mathrm{RD})$ |
| 0066 | RD $=$ RD AND \#807F FFFFh |
| 0067 | $R D=R D$ OR bit 23 |
| 0068 | RD $=$ SMTC(RD) |
| 0069 | $\mathrm{RE}=0: \mathrm{RCB}=\# 22 \mathrm{D}$ |
| 006A | RE $=$ SMULI RD : LOOP RCB |
| 006B | RE $=$ SMULT RD |
| 006C | TBO(RE,bit 1$):$ BYTE $=$ \#0100b $:$ TEST Z |
| 006D | JT FMUL1 |
|  | * INEX RC |
| 006E | $R C=R C$ ADD \#0080 0000h |
| 006F | $R E=S R A(R E)$ |
| $\begin{aligned} & 0070 \text { FMUL1: } \\ & 0071 \end{aligned}$ | $R C=R C$ ADD RB : TEST CARRY JT ERROR |
| 0072 | $R E=S M T C(R E)$ |
| 0073 | RE $=$ RE AND \#807F FFFFh |
| * FADD: | $\mathrm{RC}=\mathrm{FEXP}(\mathrm{RE})$ |
| 0074 FADD: | RC $=$ RC AND \#7F80 0000 |
|  | * RE $=$ FRAC(RE) |
| 0075 | RE = RE AND \#807F FFFFh |
| 0076 | $M \mathrm{M}=$ RE OR bit23 |
| 0077 | $R E=S M T C(R E)$ |
|  | * $\mathrm{RB}=\mathrm{FEXP}(\mathrm{RD})$ |
| 0078 | $R B=$ RD AND \#7F80 0000 |


|  | $\begin{gathered} \text { 32-bit } \\ \text { Constant } \end{gathered}$ |  |  | DRB13DRBO |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $05 \times \mathrm{E} 0 \times 11100 \mathrm{~F} 6$ | $\mathrm{x} \times \times \times \times \times \times \mathrm{x}$ | 1111 | 027 X | $x \times \times \times 11$ | 7 |
| $0 \times \times \mathrm{D} \times 1111 \times \mathrm{F}$ | 3 F 800000 | 11111 | $027 \times$ | $\times \times \times \times \times 111$ | 7 |
| $1 \times \times \times \times \times 111 \times \times F F$ | $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | 0140 | 0074111 | 7 |
| OFX50X11100F6 | $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $027 . x$ | $\mathrm{x} \times \times \times 1111$ | 7 |
| $00 \times \mathrm{E} 0 \times 11100 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times \times$ | 1111 | $027 x$ | $\begin{array}{llll}\times \times \times \times 1 & 1 & 1\end{array}$ | 7 |
| $05 \times \mathrm{D} 0 \times 11100 \mathrm{~F} 6$ | X $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | 027 X | X $\times \times \times \times 1111$ | 7 |
| $1 \times \times \times \times \times 111 \times \times F$ | $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | 0140 | 00601111 | 7 |
| $0 \mathrm{FX} 50 \times 11100 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $027 \times$ | $\times \times \times \times 1 \begin{array}{lll}1 & 1\end{array}$ | 7 |
| $01 \times 10211100 \mathrm{FB}$ | B 7 FFFFFF | 1111 | $027 \times$ | $\times \times \times \times 11$ | 7 |
| 05150011100 F | $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | 022 X | 人 $\times \times \times 11111$ | 7 |
| OEXCO211100FA | 7 F 800000 | 111 | $027 x$ | X $\times \times \times 111$ | 7 |
| OEXEO211100FA | 807 FFFFF | 1111 | $027 x$ | 人 $\times \times \times 111$ | 7 |
| OEXFO211100FB | 00800000 | 1111 | $027 \times$ | $\times \times \times \times 1111$ | 7 |
| OXEEX 011111058 | $x \times \times \times \times \times \times$ | 1111 | $027 x$ | $x \times \times \times 1$ | 7 |
| $1 \mathrm{EXX} 0 \times 11110 \mathrm{E} 6$ | $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1\end{array}$ | $027 \times$ | XXXX 1111 | 7 |
| ODXBO211100FA | 7 F 800000 | 1111 | $027 x$ | $\times \times \times \times 111$ | 7 |
| ODXD0211100FA | 807 FFFFF | 1111 | $027 x$ | $x \times \times \times 111$ | 7 |
| $0 \mathrm{D} \times \mathrm{D} 0211100 \mathrm{FB}$ | 00800000 | 1111 | 027 x | $\times \times \times \times \times 11$ | 7 |
| $0 \times \mathrm{D} \times 01111 \mathrm{D} 58$ | X $\times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 \times$ | $x \times \times \times 1$ | 7 |
| OEEEOO11110F9 | 00000016 | 11111 | 617 X | $x \times \times \times 1$ 1 11 | 4 |
| O DEE 00011111060 | $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | 5670 | 006 A 111 | 4 |
| O DEE 000111100070 | $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | $067 \times$ | X $\times \times \times 1111$ | 7 |
| O OFO 00011111038 | $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 0 & 1 & 1\end{array}$ | 027 x | $x \times \times \times 1$ <br> $\times \times 11$ | 4 |
| $1 \times \times \times \times \times \times 11 \times F$ | X $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | 017 X | XXXX11111 | 7 |
| OCXCO211100F1 | 00800000 | 1111 | 027 x | XXXX1111 | 7 |
| OEXEOX1110006 | X $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 \times$ | $x \times \times \times 1111$ | 7 |
| 0 C B C 0011100 F 1 | $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | $027 x$ | $x \times \times \times 1111$ | 0 |
| $1 \times \times \times \times \times 111 \times \times F \mathrm{~F}$ | $x \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | 017 X | $x \times \times \times \times 111$ | 7 |
| $0 \times E E \times 01111058$ | $\times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1\end{array}$ | $027 \times$ |  | 7 |
| OEXEO211100FA | 807 FFFFF | 1111 | 027 X | $x \times \times \times 1111$ | 7 |
| 0 CXC 0211100 FA | 7 F 800000 | 1111 | 027 X | X X X X 1111 | 7 |
| OEXEO211100FA | 807 FFFFF | 1111 | $027 x$ | X $\times \times \times \times 1111$ | 7 |
| $1 \mathrm{E} \times \times 0111100 \mathrm{~EB}$ | 00800000 | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 x$ | $x \times \times \times 111$ | 7 |
| OEXEO211100FA | 807 F F F F F | 11111 | 027 X | $\mathrm{x} \times \times \times 1111$ | 7 |
| 0 DXB 211100 FA | 7 F 800000 | 1111 | $027 \times$ | $\times \times \times 111$ | 7 |

Table 6.1. Floating Point $\operatorname{Sin}(x)$ Microprogram (Continued)

|  | * $\mathrm{RD}=\mathrm{FRAC}(\mathrm{RD})$ |
| :---: | :---: |
| 0079 | RE $=$ RE AND \#807F FFFFh |
| 007A | RD $=$ RD OR bit23 |
| 007B | RD $=$ SMTC(RD) |
| 007C | RF $=$ RC - RB : $\mathbf{C O}=0$ : TEST NEG |
| 007D | JT FADD1 : RCB = \#8 |
| 007E | Y/RF $=$ SLC(RF) : LOOP RCB |
| 007F | $Y=R F: R C A=Y$ |
| 0080 | RD $=$ SRA(RD) : $\operatorname{LOOP}$ RCA |
| 0081 | $\mathrm{RB}=\mathrm{RC}$ : JUMP FADD2 |
| 0082 FADD1: | $\mathrm{RF}=\mathrm{NOT}$ RF |
| 0083 | Y/RF $=$ SLC(RF) : $\operatorname{LOOP}$ RCB |
| 0084 | $Y=R F: R C A=Y$ |
| 0085 | RE $=$ SRA(RE) : $\operatorname{LOOP}$ RCA |
| 0086 FADD2: | $R F=R D+R E$ |
| 0087 | $\mathrm{RF}=\mathrm{SMTC}$ (RF) |
| 0088 | RF = TBO (RF, bit24) : TEST Z |
| 0089 | JF FADD3 |
| 008A | INC RB : TEST NEG |
| 008B | $R F=S R A(R F): ~ J T E R R O R$ |
| 008C FADD3: | RF $=$ SETO (RF, bit23) |
| 008D | RF = RF OR RB : RETURN |


|  | $\begin{gathered} \text { 32-bit } \\ \text { Constant } \end{gathered}$ | Bio io biod |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| OEXEO211100FA | 807 |  |  |  |  |
| ODXD0211100FB | 0080000 |  |  |  |  |
| $0 \times \mathrm{D} \times 01111058$ |  |  |  |  |  |
| 0 CBF 00 | x $\times$ x $\times$ x $\times$ x | 11 | 02 | xxxx 11 |  |
| $1 \times$ |  | 11 | 61 | x |  |
| X | X | 11 | 5 | 07 |  |
| $1 \times \mathrm{XXXX} 1100 \times$ |  | 11 | 27 | 0080 |  |
| X D 0 | X | 1111 | 1 | 0 |  |
| CXB0X11100 |  | 1111 | 02 | $\times \times x$ |  |
| OFXFOX11100F7 |  | 1111 | 02 | $x \times$ |  |
| OFXFOX11000 | X $\times$ | 1111 | 61 | X X X |  |
| $1 \mathrm{XXXXX} 1100 \times$ | x $\times$ | 1111 | 56 | 008 |  |
| OEXEOX1110 |  | 11111 | 277 | 008611 |  |
| ODEFOO11100 |  | 11111 | 02 | XXX |  |
| $0 \times \mathrm{FFX} 0111111005$ |  | $\begin{array}{llllll}1 & 1 & 1 & 1\end{array}$ | 027 | x $\times \times \times 1$ |  |
| OOFOOO11110 | X | 0111 | 02 | x $\times$ x |  |
| 1 XXXXX 111 XX | X | 1111 | 047 | X $\times$ X |  |
| OBXB0X11111 |  | 1111 | 027 | XXX |  |
| OF7FOX 1111000 | X $\times$ | 11 | 017 | x |  |
| 07FO0001111018 |  | 1011 | 0 |  |  |
| OFBFO011100F | $\times \times \times$ | 11 | 02 | x $\times$ x 111 |  |

# Excerpt from SN74AS888, SN74AS890 Bit-Slice Processor User's Guide 



## IMPORTANT NOTICE

Texas Instruments (TI) reserves the right to make changes in the devices or the device specifications identified in this publication without notice. TI advises its customers to obtain the latest version of device specifications to verify, before placing orders, that the information being relied upon by the customer is current.
TI warrants performance of its semiconductor products to current specifications in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent TI deems such testing necessary to support this warranty. Unless mandated by government requirements, specific testing of all parameters of each device is not necessarily performed.

In the absence of written agreement to the contrary, Tl assumes no liability for TI applications assistance, customer's product design, or infringement of patents or copyrights of third parties by or arising from use of semiconductor devices described herein. Nor does TI warrant or represent that any license, either express or implied, is granted under any patent right, copyright, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor devices might be or are used.

## 4. 32-Bit CPU Design Methodology

Microprogramming and bit-slice technology have made possible the development of powerful systems using flexible instructions sets and wide address/data buses to access more than one Gigaword of physical main memory. This section discusses one design approach to such a system, using 'AS888 bit-slice and 'AS890 microsequencer components.

A structured approach to system design, such as that illustrated in Figure 4-1, is recommended in developing custom bit-slice designs. The product specification gives a starting point or basis for the project. In this example, four 'AS888 bit slices are used to implement the 32-bit arithmetic portion of the CPU, and an 'AS890 microsequencer is used for ALU and system control. A group of PROMs stores the microinstructions; a writable control store could also be implemented using additional control logic and components to load and modify the microprogram memory. The system is designed to access more than one Gigaword of memory.


Figure 4-1. System Design Approach

Since speed is a concern, carry look-ahead rather than ripple-through logic is recommended. If ripple-through logic were used, the system clock would need to be slowed down to allow the propagation of the carry bits through the various 'AS888 stages. By using carry look-ahead, the amount of time needed for the data to stabilize is greatly reduced by anticipating the carry across the 'AS888 packages.

So that the scratchpad area can be used for address calculations and mathematical computations, the 'AS888's internal register file is dedicated for system functions. To provide the system user with a macrolevel equivalent of register locations, a 16 -word external register file is also included. Access to the external register file will be under microprogram control, allowing address selection to come from the microcode itself or from one of the three operand fields of the instruction register.

PROMs eliminate the use of main memory as a source for constants used in initialization or table look-up functions. Accessing main memory for table values would require time and slow system throughput; by placing fixed values in fast PROMs, access time is kept to a minimum and system throughput is not altered.

Control, data and address buses shared by the system are accessed by three-state registers. The control register, as explained in section 4.1.2, supplies the non-CPU part of a computer system with control signals. The data bus allows the ALU to supply data for the rest of the system and can also be a source of data for the ALU; this is accomplished by using three-state registers to drive the bi-directional data bus, along with registers to sample the bus. The address bus uses one of the external register file locations to maintain a program counter, thus allowing a 32-bit address bus capable of addressing about four Gigawords of main memory. Using three-state drivers for this bus enables other subsystems to take control of the system buses.

A pipeline register supplies the microsequencer and the ALU with both data and instructions. To get macrocode into the system, an instruction register and a mapping PROM are used to convert the opcode to a microprogram routine address. The condition code signal, used for testing various conditions, is supplied by a registerinput based PAL. PAL inputs can be fixed values or combinations of the status signals coming from the ALU. The read address select pins for the 'AS888's internal B register can be sourced from the microword itself or from three nibbles of the macroword, to provide offsets for the N -way branches to various microcode routines.

### 4.1 Designing a 32-Bit System

A typical 32-bit system block diagram using the 'AS888 bit-slice and 'AS890 microsequencer is shown in Figures 4-2 and 4-3. It can be broken down into two sections, the ALU (arithmetic logic unit) and the CCU (computer control unit). The ALU section performs all manipulation of data both to and from main memory, such as arithmetic and logical operations. The CCU section controls instruction (macrocode) flow and any miscellaneous control operations, such as fetching instructions or supplying addresses for main memory access.

### 4.1.1 Construction of the ALU

To cascade the four 'AS888s to obtain the 32-bit arithmetic unit shown in Figure 4-4, the shift multiplex $\overline{\mathrm{SIOO}}$ and $\overline{\mathrm{QIOO}}$ terminals are connected to the $\overline{\mathrm{SIO7}}$ and $\overline{\mathrm{QIOF}}$ terminals of adjacent packages, and the least significant package's signals are connected to the most-significant package's. Optionally, SN74ALS240 inverting gates can be connected to the $\overline{\mathrm{SIOO}}-\overline{\mathrm{SIO}}$ terminals and the byte inputs to implement byte and bit control. Another chip, the SN74AS182 look-ahead carry generator, provides a ripple-carry function, to help system throughput.

The design includes a 16 -word register file, the SN74AS870 (see Figure 4-3). This allows the user to access 16 working areas for temporary data storage or address calculations such as indexing. In this design example, the 'AS888's internal register file is not accessible directly by the user; it is reserved for microcode operations, such as address computation and temporary storage for arithmetic operations. Addressing the register files is permitted through the microprogram or from the macrocode instruction register under microcode control.

The transfer register connected to the 'AS888's $Y$ and DB buses allows for feedback into the 'AS888 under microprogram control. Since the constant PROMs and the external register file share the A bus, they cannot be accessed at the same time. The transfer register enables data from the external register file to be transmitted to the $B$ bus, making possible the addition of operands from the constant PROMs and the external register file, for example.

Constant PROMs are also included to simplify the programming and operation of the ALU by supplying fixed data for various operations, such as:

1) Clearing the system register files for initialization. This will bring the system up to a known state.
2) Supplying a correction value to the offset in a branch instruction, i.e., converting a 16 -bit offset to a true 32 -bit address.
3) Table look-up for fixed mathematical operations, such as computing sines and cosines.

### 4.1.2 Construction of the CCU

Sequencing and branching operations at speeds compatible with the 'AS888 are supplied by the 'AS890, a microprogrammed controller working as a powerful microsequencer (see Figure 3-1). Features of the 'AS890 include:

1) Stack capability. The 9 -word stack can be accessed by using a stack pointer or a read pointer; the latter is designed for non-destructive dumping of the stack contents.
2) Register/counter facility. Two registers, DRA and DRB, can be used for latching data from the external data buses or as counters for loops. A ZERO signal is generated when the decremented counter reaches a zero value.
3) Interrupt control. A register for temporarily holding the return address is supplied; upon entering the interrupt routine, the contents of the return register must be pushed onto the stack for later use.
4) Next address generation. The $Y$ output multiplexer offers a selection of same or incremented address, address from DRA or DRB buses, address from stack, or a concatenation of DRA13-DRA4 and B3-B0.

A microprogram memory/pipeline register supplies the microsequencer and the rest of the system with instructions (see Figure 4-2). The memory might consist of ROMs, or it could be a writable-control store with support logic to allow loading or updating of the control store. For a general purpose machine with a fixed instruction set, ROMs would be more economic.

Some 'AS890 instructions are influenced by the $\overline{\mathrm{CC}}$ input. Many are variations of branch and jump instructions. To form and supply $\overline{C C}$, a register can be used to latch the state of the 'AS888 and supply inputs to a PAL for decoding, based upon the microcode's needs. Combinatorial logic in the PAL allows multiple or single events to be selected or provides a fixed value of " 1 " or " 0 " for forced conditions.
To supply the microsequencer with the proper address of the microcode-equivalent version of the macrocode instruction, an instruction register and mapping PROM are needed. Under microprogram control, the instruction register samples the data bus to get the macrocode instruction. The opcode portion is passed to the mapping PROM to form an address to the microcode routine. When the microcode is ready to jump to the routine, it turns off the $Y$ bus output of the 'AS890 and enables the output of the mapping PROM. An optional means of altering the address uses B3-BO inputs of the 'AS890 to implement a N-way branch routine. In this method, the ten most significant address bits of DRA or DRA are concatenated with the B3-BO bits to supply an address.

Control information is supplied to the rest of the system via the control register and bus. By setting various bits within the control register, information can be passed to other subsystems, such as memory and I/O peripherals. Bit $O$ could represent the read/write control line while bit 1 could select memory or I/O for the read/write. Bit 2 might function to enable interrupts and bit 3 to indicate when the system should enter a "wait" state for slow memory. The remaining control bits can be programmed by the system designer to indicate additional condition states of the "macrosystem".


Figure 4－2．CCU Block Diagram


Figure 4－3．ALU Block Diagram

Addressing of the register files, both the 'AS888 internal and the 'AS870 external, is done through the use of two 1 -of- 2 selector banks. The first bank selects address source; this design offers a choice for operand processing of fixed values from the microcode or values from the macroinstruction latched in the instruction register. The second bank selects the first or second operand as an address source for port 0 of the external register file; port 1 uses the third operand as an address source.

It should be noted that the design presented in Figure 4-2 for the computer control unit is a one-level pipeline that is instruction-data based.The address and contents of the next instruction are being fetched while the current instruction is being executed. Tracing through the data flow, the following can be observed:

1) The pipeline register contains the current instruction being executed;
2) The ALU has just executed its instruction, and has the current status ready at its output pins;
3) The status register that is attached to the ALU contains the previous instruction's resulting status;
4) The contents of the next microprogram word are being fetched at the same time that the current instruction is being executed.

### 4.2 Tracing through a 32-Bit Computer

With the 'AS888 and 'AS890 as foundation chips, the typical 32-bit supermini of Figures 4-2 and 4-3 can now be functionally traced. First, note that the data of the main program is handled separately from that of the microcode - each on its own bus. The system is initialized by setting the "clear" signal high - this causes a forced jump to the beginning of the microcode memory. Instructions carried out by the microcode at this point might run system diagnostics, clear all registers throughout the 'AS888-based system, and set up the initial macrocode program address. In this design, the first program address to fetch an instruction from main memory comes from a fixed value in the microcode memory; it is possible to allow the address to be retrieved from a permanent location in main memory or from either a front panel or console, by modifying the microcode program slightly.

Table 4-1 illustrates the microcode format for this design. Note that it contains control signals for all chips involved in the design. Some of these, such as TRANSLATCH and MARLATCH, are used with the system clock to provide controlled loading of the various holding registers. Others supply necessary addressing information, directing input from either the main data bus or from the microcode word itself.

The FETCH routine is shown in functional, assembler and microcoded forms in Tables $4-2,4-3$ and 4-4. First, the program counter is read from the external register file and stored into the memory address register. After the program counter is placed on the address bus, the program counter is updated and stored while the data from memory is allowed to settle down to a stable condition. The data is then latched in both the instruction register and data-in register.

The opcode field of the instruction register is passed through the mapping PROM to convert the opcode to an equivalent microcode routine address. When YOE is forced high by the microcode, the 'AS890 is tri-stated from the $Y$ bus, and the mapping PROM's output is taken out of the tri-state mode to supply an address to the control store (microprogram memory); a forced jump is made to the microcode routine to perform the instruction.

After the routine is complete, a jump is made back to the FETCH routine using the next-address supplied by the microprogram. It is up to the system designer/programmer to make sure that all system housekeeping is performed so that nothing causes a fatal endless loop.


Figure 4－4．Cascaded＇AS888 Packages

Table 4-1. Microcode Definition

| MICROCODE FIELD | PIN NAME | INPUT TO | FUNCTION |
| :---: | :---: | :---: | :---: |
| 0-13 | DRA13-DRA0 | 'AS890 | Used for next-address branches |
| 14-27 | DRB13-DRB0 | 'AS890 | Used for loading counter |
| 28-30 | RC2-RC0 | 'AS890 | Register/counter controls |
| 31-33 | S2-S0 | 'AS890 | Stack control |
| 34-36 | MUX2-MUX0 | 'AS890 | MUX control of Y output bus |
| 37 | $\overline{\mathrm{INT}}$ | 'AS890 | Interrupt control |
| 38 | $\overline{\text { RAOE }}$ | 'AS890 | Enables DRA output |
| 39 | $\overline{\text { RBOE }}$ | 'AS890 | Enables DRB output |
| 40 | OSEL | 'AS890 | Mux control for DRA source |
| 41 | INC | 'AS890 | Incrementer control |
| 42 | YOE | 'AS890 | Enables Y output bus |
| 43-50 | 17-10 | 'AS888 | Instruction inputs |
| 51 | $\overline{\text { OEA }}$ | 'AS888 | DA bus enable |
| 52 | $\overline{E A}$ | 'AS888 | ALU input operand select |
| 53 | $\overline{O E B}$ | 'AS888 | DB bus enable |
| 54 | OEY | 'AS888 | $Y$ bus output enable |
| 55 | SELY | 'AS888 | $Y$ bus select |
| 56-57 | EB1-EB0 | 'AS888 | ALU input operand selects |
| 58 | $\overline{W E}$ | 'AS888 | Register file write enable |
| 59 | $\overline{\text { MAP }}$ | PROM | Enables mapping PROM to 'AS890 Y bus |
| 60 | $\overline{\mathrm{R}}$ | Latch | Latches data bus to instruction register |
| 61 | $\overline{C R}$ | Latch | Latches control data to bus |
| 62-69 | CTRL7-CTRLO | Latch | Data for control latch |
| 70-71 | BSEL1-BSELO | Multiplexer | Selects data for 'AS890 |
| 72-75 | B3-B0 | Multiplexer | Microcode data to switch |
| 76 | CONDCD | Latch | Controls latch of 'AS888 status |
| 77-80 | SELC3-SELC0 | PAL | Selects combination of 'AS888 status |
| 81 | DTALATCHI | Latch | Controls latching of data-in |
| 82 | DTAIN | Latch | Enables data-in output to bus |
| 83 | DTALATCHO | Latch | Controls latching of data-out |
| 84 | DTAOUT | Latch | Enables data-out output to DB bus |
| 85 | $\overline{\text { MARLATCH }}$ | Latch | Controls latching of address |
| 86 | $\overline{\text { MAR }}$ | Latch | Enables MAR output to address bus |
| 87 | CONSTPROM | PROM | Enables PROM to DA bus |
| 88-99 | A11-A0 | PROM | Address of constant in PROM |
| 100 | SWITCH2 | Multiplexer | Selects microcode or Instruction Register data |
| 101 | SWITCH1 | Multiplexer | Selects microcode or Instruction Register data |
| 102-105 | A3-A0 | Multiplexer | Register file address ('AS888) |
| 106-109 | B3-B0 | Multiplexer | Register file address ('AS888) |
| 110-113 | C3-C0 | Multiplexer | Register file address ('AS888) |
| 114 | REGUWR | Register File | Port 0 write enable |
| 115 | REGLWR | Register File | Port 1 write enable |
| 116 | $\overline{\text { REGU }}$ | Register File | Chip enable on port 0 |
| 117 | $\overline{\text { REGL }}$ | Register File | Chip enable on port 1 |
| 118 | TRANSLATCH | Latch | Controls latch between Y and DB bus |
| 119 | TRANS | Latch | Enables output to DB bus |
| 120 | SELCN2 | Multiplexer | Supplies carry input to 'AS888 |
| 121 | SELCN1 | Multiplexer | Supplies carry input to 'AS888 |
| 122 | REGUB | Multiplexer | Selects address for external register file |
| 123-126 | BYTE3 - $\overline{\text { BYTE0 }}$ | Three-state | Enables data for byte/bit operations |

## Table 4-2. Functional Listing of Fetch

```
FETCH: }\quad\mathrm{ MAR = PC, Enable MAR output
    PC = PC + 1
    IR = DIR = data bus, Disable 'AS890 Y bus,
    Enable mapping PROM to Y bus
```

Table 4-3. Assembler Listing of Fetch

FETCH: OP890 ,,,111,10; INC;
OP888 NOP,GROUP5,10,.,1111;
OEY;SELY;
CR;CTRL 00000011;
SELC 01;
MARLATCH;MAR;
SWITCH 00;REGL;
TRANSLATCH
OP890 ,,,111,10;INC;
OP888 PASS,INCS,00,.,1111;
OEB;OEY;
SELC 01;
MAR;
REGLWR;REGL;
TRANS;
SELCN 01
OP890 ,,,111,10;
OP888 NOP,GROUP5,10;
MAP;
IR;
SELC 01
DTALATCHI;
MAR

Set 'AS890 for continue
Perform NOP and read external register 15
Enable $Y$ bus output
Generate external control bus signals
Select fixed CC value to 'AS890
Latch value on $Y$ bus and enable output
Select address source and enable port
Latch $Y$ bus for transfer to $B$ bus
Set 'AS890 for continue
Increment program counter
Enable Y bus output
Select fixed CC value to 'AS890
Output address to address bus
Update program counter in register file
Enable transfer latch output to $B$ bus
Select carry input to LSP to be " 1 "
Set 'AS890 for continue
Perform NOP
Enable mapping PROM to 'AS890 Y bus
Latch data bus to get macrolevel code
Select fixed CC value to 'AS890
Put data bus also in data register
Output address to address bus

## Key to Table 4-3

OP888 a,b,c,d,e,f
where:
$a=$ upper bits of instruction, 17-14
$\mathrm{b}=$ lower bits of instruction, 13-10
$c=$ value of EB1-EB0
$\mathbf{d}=A$ address of register files
$\mathrm{e}=\mathrm{B}$ address of register files
$f=C$ address of register files

OP890 v,w,x,y,z
where:
$v=$ DRA value, 14 -bits
$w=$ DRB value, 14 -bits
$x=R C 2-R C 0$
$y=S 2-S 0$
$z=$ MUX2-MUX0
Table 4-4. Microcode Listing of Fetch

| DRA13DRAO | DRB13DRBO | ¢ | $\begin{aligned} & \text { ஜ் } \\ & \text { ஸ゙ } \end{aligned}$ |  |  | 17-10 |  | ¢ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0000000000000 | 000000000000 | 000 | 1.11 | 010 | 111010 | 11111111 | 11101101 | 110 |
| 00000000000000 | 0000000000000 | 000 | 111 | 010 | 111010 | 11110100 | 11000001 | 11 |
| 0000000000000 | 000000000000 | 000 | 111 | 010 | 111001 | 11111111 | 01111101 | 001 |

Table 4-4. Microcode Listing of Fetch (continued)

| CTRL7CTRLO |  | $\begin{aligned} & \text { ั. } \\ & \text { Mめm } \end{aligned}$ | $10$ |  |  | A11-A0. | 도 Un N N N N N |  | $\begin{aligned} & \text { \% } \\ & \text { ஸim } \end{aligned}$ |  |  | \| |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00000011 | 00 | 0000 | 1 | 0001 | 1111001 | 00000000000 | 00 | 0000 | 0000 | 1111 | 111001000 | 1111 |
| 00000000 | 00 | 0000 | 1 | 0001 | 1111101 | 00000000000 | 00 | 0000 | 0000 | 1111 | 101010010 | 1111 |
| 0000000 | 00 | 0000 | 1 | 0001 | 0111101 | 0000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |

### 4.3 Defining the Macrocode Instruction Format

Since this is a 32 -bit design, a variety of instruction formats are available. The size of the opcode, along with the types of addressing used, will affect both system size and performance. The formats shown in Table 4-5 will be used for discussion.

All Table 4-5 formats have an opcode field of 11 bits and source/destination fields of 7 bits; the first three bits of the latter designate the address type, and the remaining four bits are used for register access. The opcode length allows 2,048 macrocoded instructions to be mapped to equivalent microcoded routines. The address fields can specify any of the following modes: register, relative, autoincrement/autodecrement, indexed, absolute, and deferred. The offset used in the Type 0 instruction can be used for branch-based instructions, for an offset range of $\pm 32727$.

Table 4-5. Possible Instruction Formats

TYPE 0 - OPCODE + 16-BIT OFFSET

| $0-10$ <br> Opcode | $11-15$ <br> Not Used | $16-31$ <br> Offset |
| :---: | :---: | :---: |

TYPE 1 - OPCODE + DESTINATION

| $0-10$ | $11-24$ | $25-31$ |
| :---: | :---: | :---: |
| Opcode | Not used | Destination |

TYPE 2 - OPCODE + SOURCE + DESTINATION
$\left.\begin{array}{|c|c|c|c|}\hline 0-10 & 11-17 & 18-24 & 25-31 \\ \text { Opcode } & \text { Not used }\end{array} \quad \begin{array}{c}\text { Source }\end{array}\right]$

TYPE 3 - OPCODE + SOURCE1 + SOURCE2 + DESTINATION

| $0-10$ | $11-17$ <br> Source | $18-24$ <br> Source | $25-31$ <br> Destination |
| :---: | :---: | :---: | :---: |

### 4.4 Tracing a Macrocode Instruction

Microcode for a Type 3 multiplication instruction is shown in Table 4-6, using the following assumptions:

1) Code for retrieving the operands will not be shown. Jumps will be made to routines that will place the temporary operands into internal register locations 2 and 3 of the 'AS888, after being fetched from main memory.
2) A jump to a routine to store the product in the destination will be handled similarly.
3) Multiplication will be unsigned; the result will be placed in two temporary locations of the 'AS888.
4) An update to the program status word, which the user can access at the macrocode level must also be performed, but is not shown.

Assembler code is shown in Table 4-7; a microcode listing is given in Table 4-8. The first two lines of microcode are subroutine jumps to opcode fetching routines, which store the operands in register files 2 and 3 in the 'AS888. The next two instructions load up the 'AS890 with a counter constant for performing the multiply loop, load the MO register of the 'AS888 with the multiplier and clear the register that is temporarily used for the accumulator.

# Table 4-6. Functional Listing of Multiply 

UMULI3:<br>JUMPSUB SOURCE1<br>JUMPSUB SOURCE2,<br>BCOUNT $=32$<br>REG $9=0$<br>MO = REG 2<br>LOOP:<br>UMULI WITH REG 3 DECREMENT BCOUNT, BRANCH TO LOOP IF NOT ZERO, LATCH 'AS888 STATUS, REG $9=$ ALU<br>REG $8=$ MQ<br>JUMPSUB STORPSW<br>JUMPSUB MDEST<br>JUMP FETCH

A loop is then entered to perform the multiply instruction 32 times to form the product, with the multiplicand coming from the internal register file of the 'AS888. Upon exiting the loop, the MQ register is stored in a temporary register location in the 'AS888. The MQ register now contains the least-significant bits of the result and the temporary accumulator the most significant bits. A subroutine jump is made to the program status word update routine; this will take the status flags of the last multiplication iteration and change the macrolevel status word. The next subroutine jump is to a destination routine, which is followed by a branch to the FETCH routine to get the next macro instruction to be executed.

### 4.5 System Enhancements

The above example provides a broad overview of 32 -bit system design using the 'AS888 and 'AS890. Certain additional options may enhance system performance. These include:

1) Status latching. The design does not take into account changes that need to be examined at the microlevel while retaining macrolevel status information. One solution would be to include another register in parallel to the status latch and provide control to choose between the two to form the condition code value.
2) Interrupts. To efficiently use a computer system, interrupts are used to alter program flow in the case of I/O programming and real-time applications (involving hardware timers). To include this capability, external hardware must be included and the microcode modified accordingly. Information on interrupt implementation is given in section 3.
3) Control store. One way of implementing microprogram memory is to use a ROMbased design. It is becoming more common to design a writable control store, a completely RAM-based or part RAM, part ROM storage system, that can be altered by system operation, such as initialization from a floppy disk subsystem, or by the user to optimize or implement new macrolevel instructions. The cost of implementation must be weighed with the risks involved in changing instructions which may not be supported by other sites.
4) Instruction word definitions. Changing the instruction word definitions will have an effect on both system design and performance. Removing Type 3 instructions from the design, for example, will have an effect on both hardware and software: the external register file addressing must be changed and the 1-of-2 selector

Table 4-7. Assembler Code of Multiply

## UMULIS:

OP890 SOURCE1,,,110,110;
INC; YOE;
OP888 NOP;GROUP5;
SELC 0001;
MAR
OP890 SOURCE $2,00000000100000,110,110,110$; P
INC;YOE;
OP888 NOP,GROUP5;
SELC 0001;
MAR
OP890 ,,,111,110;
INC;YOE;
OP888 CLEAR,GROUP5,,,,1001;
WE;
SELC 0001;
MAR
OP890 LOOP,,,111,110;
INC;YOE;
OP888 LOADMQ,INCS,,,0010;

MAR
LOOP:
OP890 LOOP,,101,111,100;
INC;YOE;
OP888 UMULI,GROUP4,01,0011,,1001;
WE;
MAR
OP890 ,.,111,110;
INC;YOE;
OP888 PASS,INCS,,,,1000;
WE;
MAR
OP890 STORPSW,,,110,110;
INC;YOE;
OP888 NOP,GROUP5;
SELC 0001;
MAR
OP890 FETCH,,,111;
INC;YOE;
OP888 NOP,GROUP5;
SELC 0001

Perform a subroutine branch Increment address and enable $Y$ bus Tell 'AS888 to do nothing during jump
Set CC to " 1 " to set up 'AS890 continue
Maintain address on main address buss counter
Increment microaddress and enable $Y$ bus
Tell 'AS888 to do nothing during jump
Set CC to " 1 " to set up 'AS890 continue
Maintain address on main address bus
Perform a continue instruction
Increment microaddress and enable $Y$ bus
Zero out register file accumulator
Enable writing to register file
Set CC to "1" to set up 'AS890 continue
Maintain address on main address buss
Perform a continue instruction
Increment microaddress and enable $Y$ bus
Load MO register with $\mathrm{S}+\mathrm{Cn}$, from external register file
Maintain address on main address bus
Decrement $B$ and loop til ZERO $=1$
Increment microaddress and enable $Y$ bus Perform unsigned multiply on accumulator
Update register file accumulator
Maintain address on main address bus
Perform a continue instruction
Increment microaddress and enable $Y$ bus
Put $\mathrm{S}+\mathrm{Cn}$ in temporary register file
Allow updating of register file
Maintain address on main address bus Perform a subroutine branch Increment microaddress and enable $Y$ bus Tell 'AS888 to do nothing during jump Set CC to " 1 " for set up 'AS890 continue Maintain address on main address bus Perform a branch to FETCH routine Increment microaddress and enable $Y$ bus Tell 'AS888 to do nothing during jump Set CC to " 1 " for 'AS890 continue

## Key to Table 4-7.

OP888 a,b,c,d,e,f
where:
$a=$ upper bits of instruction, 17-14
$b=$ lower bits of instruction, 13-10
$c=$ value of EB1-EBO
$d=A$ address of register files
$\mathbf{e}=\mathbf{B}$ address of register files
$f=C$ address of register files

OP890 $v, w, x, y, z$
where:
$v=$ DRA value, 14 -bits
$w=$ DRB value, 14 -bits
$x=R C 2-R C 0$
$y=S 2-S 0$
$z=M U X 2-M U X 0$
removed. Likewise, changing the opcode length may restrict the instruction address capability and also cause either an increase or decrease in the microcode size.
5) Dynamic memory access (DMA). The above system does not support dynamic memory access. To include this function requires a change in the address output control, along with support circuitry for the type of DMA selected. Some error detection and correction logic for main memory might also be included.
6) Computer control unit. The design presented here shows a one-level pipeline architecture that is instruction-data based. System throughput may be increased by converting to a pipeline of greater depth, or using another variety of onelevel pipeline, such as instruction-address based or address-data based. Care must be taken when increasing the size of the pipeline, especially when handling branch/jump situations. The reader is advised to carefully research this area before implementing any design.

### 4.6 Timing and System Throughput

A critical path analysis was undertaken to determine the maximum clock rate for the proposed system. The longest delay path is the multiplication data path, which involves the internal register file and the shift function of the 'AS888. Table 4-9 contains the critical delay calculations for both the ALU and CCU. Since both portions of the system must be satisfied, a clock rate of 90 ns was selected for the following comparisons.

### 4.6.1 Fetch Analysis

Most microprocessors perform an instruction fetch in a pipeline mode; the next instruction is fetched while the current instruction is executing. The fetch code shown earlier requires a minimum of four cycles: three to issue the code and one to break the pipeline for processing the branch. This results in a total time of 360 ns , based on a 90 ns cycle time. Fetch times for the representative microprocessors have been estimated from data books and are shown in Table 4-10; wait states for slow memory are not included. As can be seen from the table, the 'AS888 design example is estimated to run from 1.1 to 2.1 times faster than the 16 -bit microprocessors.

### 4.6.2 Multiplication Analysis

This analysis assumes that multiplication is unsigned integer and register to register based. No account is taken of time needed for instruction fetch or operand fetch or store.

The basic loop for the multiply takes 35 cycles: 2 for accumulator and multiplier set up, 32 for actual multiply loop and 1 to store the least-significant bits in an internal register file. Given a cycle time of 90 ns , a 32 by 32 bit multiplication can be implemented in 2.275 microseconds. A 16-bit multiply requires 16 iterations of the inner loop; both timings are included in Table 4-11 for comparison. Values for the 16 -bit multiplies of the representative microprocessors have been estimated from data books.

As shown in Table 4-11, the 16 by 16 multiply can be performed with the 'AS888 at a faster rate than the 16 -bit microprocessors. Even comparing the 32 by 32 multiply of the application design, one can see that the 'AS888 based system has a better macroinstruction execution speed. Using the 'AS888 and 'AS890 in a system design will allow high throughput and permit a flexible architecture.
Table 4-8. Microcode Listing of Multiply

| DRA13DRAO | DRB13DRBO | ¢ | $\begin{aligned} & \text { ¢ } \\ & \text { ஸ் } \end{aligned}$ |  |  | 17-10 |  | 좆의 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0000000001100 | 0000000000000 | 000 | 110 | 110 | 111010 | 11111111 | 11110001 | 11 |
| 0000000010000 | 00000000100000 | 110 | 110 | 110 | 111010 | 11111111 | 11110001 | 11 |
| 0000000000000 | 0000000000000 | 000 | 111 | 110 | 111010 | 11110000 | 11100000 | 11 |
| 00001000001000 | 0000000000000 | 000 | 111 | 110 | 111010 | 11100100 | 11100001 | 11 |
| 00001000001000 | 0000000000000 | 101 | 111 | 100 | 111010 | 11010000 | 11100010 | 11 |
| 00000000000000 | 0000000000000 | 000 | 111 | 101 | 111010 | 11111111 | 11100010 | 11 |
| 0000000010100 | 0000000000000 | 000 | 110 | 110 | 111010 | 111111111 | 11110001 | 11 |
| 0000000011.000 | 0000000000000 | 000 | 110 | 110 | 111010 | 11111111 | 11110001 | 111 |
| 0000000000011 | 0000000000000 | 000 | 111 | 000 | 111010 | 11111111 | 11110001 | 11 |

Table 4-8. Microcode Listing of Multiply (continued)

| CTRL7- <br> CTRLO |  | $\begin{aligned} & \text { ö } \\ & \text { ìm } \end{aligned}$ | $\left\|\begin{array}{l} 0 \\ 0 \\ 0 \\ 0 \\ 0 \\ 0 \end{array}\right\|$ | $\begin{aligned} & \text { B } \\ & \text { H } \\ & \text { 0 } \\ & \text { §ु } \\ & \text { 山 } \end{aligned}$ |  | A11-A0 |  | $\begin{aligned} & \text { 을 } \\ & \text { \& } \end{aligned}$ | $\begin{aligned} & \text { oi } \\ & \dot{\oplus} \\ & \text { M } \end{aligned}$ | $\begin{aligned} & \text { O} \\ & \text { ஸु } \end{aligned}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00000000 | 00 | 0000 | 1 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |
| 00000000 | 00 | 0000 | 1 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |
| 00000000 | 00 | 00.00 | 1 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 1001 | 111111000 | 1111 |
| 00000000 | 00 | 0000 | 0 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0010 | 0000 | 110111000 | 1111 |
| 00000000 | 00 | 0000 | 0 | 0001 | 1111101 | 000000000000 | 00 | 0011 | 0000 | 1001 | 101011000 | 1111 |
| 00000000 | 00 | 0000 | 0 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 1000 | 101011000 | 1111 |
| 00000000 | 00 | 0000 | 0 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |
| 00000000 | 00 | 0000 | 1 | 0001 | 1111101 | 000000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |
| 00000000 | 00 | 0000 | 1 | 0001 | 1111111 | 000000000000 | 00 | 0000 | 0000 | 0000 | 111111000 | 1111 |

Table 4-9. Critical Delay Path Analysis

| CONTROL PATH |  |  | DATA PATH |  |  |
| :--- | :--- | :---: | :--- | :--- | ---: |
| Pipeline Reg. | Clock to Output | 9 | 'AS888-1 | Clock to $C_{n}$ | 46 |
| MUX | Select to Output | 13 | 'AS182 | C $_{n}$ to $C_{n+z}$ | 5 |
| 'AS890-1 | CC to Output | 25 | 'AS888-1 | C $_{n}$ to SIO | 25 |
| PROM | Access Time | 20 | 'AS888-1 | SIO to $Y$ | $\frac{14}{90} \mathrm{~ns}$ |
| Pipeline Reg. | Setup Time | $\underline{2}$ |  |  |  |

Table 4-10. Fetch Timing Comparison

| FETCH | 'AS888 <br> $32-B I T$ | $\mathbf{Z 8 0 0 1}$ | $\mathbf{8 0 8 6 - 1}$ | $\mathbf{8 0 2 8 6}$ | $\mathbf{6 8 0 0 0 \mathrm { L }}$ |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Data width | 32 | 16 | 16 | 16 | 16 |
| No. of cycles | 4 | 3 | 4 | 4 | 4 |
| Clock rate | 11.11 MHz | 4 MHz | 10 MHz | 10 MHz | 8 MHz |
| Total time | 360 ns | 750 ns | 400 ns | 400 ns | 600 ns |

Table 4-11. Multiply Timing Comparison

|  | 'AS888 | 'AS888 |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| MULTIPLY | $32-$ BIT | $16-$ BIT | Z8001 | $8086-1$ | 80286 | 68000 L |
| Size | $32 \times 32$ | $16 \times 16$ | $16 \times 16$ | $16 \times 16$ | $16 \times 16$ | $16 \times 16$ |
| No. of cycies | 35 | 19 | 70 | 128 | 21 | $\leqslant 74$ |
| Clock rate | 11.11 MHz | 10.98 MHz | 4 MHz | 10 MHz | 10 MHz | 8 MHz |
| Total time | $3.150 \mu \mathrm{~S}$ | $1.729 \mu \mathrm{~s}$ | $17.5 \mu \mathrm{~s}$ | $12.8 \mu \mathrm{~s}$ | $2.1 \mu \mathrm{~s}$ | $\leqslant 9.25 \mu \mathrm{~s}$ |

## 5. Floating-Point System Design

Bit-slice processor architecture addresses the problem of optimizing system performance while allowing the user to balance hardware complexity against software flexibility. Bit-slice systems usually operate at or near the speed of the most primitive of programmable processors, the PROM state sequencer. Of course, bit-slice architecture incorporates circuitry dedicated not only to sequencing, but also data processing (ALU) operations. In keeping with the trend of these programmable devices to track the speed of fast discrete hardware, the 'AS888 8-bit slice ALU and 'AS890 microsequencer have been produced in Advanced Schottky bipolar technology. In addition to sheer speed, the components feature greater density ( 2 micron geometry) for greater functionality (more special purpose circuitry on board). The impact will be faster, more powerful systems in applications which previously pushed the limits of bit-slice processors.

Consider an application in which bit-slice architecture has dominated for years: CPU design. The microprogrammed CPU itself spans a spectrum of uses ranging from general purpose minicomputers to compact airborne computers. A specific example which illustrates various facets of design using the 'AS888 and 'AS890 is a CPU with a floating-point utility to compute $\sin (x)$.

The design process can be subject to many influences, including personal preference, available development tools, peculiarities of the application, and constraints from the user, customer or manufacturing environment. No hard and fast design rules could be applied universally, but most designers will start with a specific plan in mind.

The goal of this example is to produce the hardware and microprogram which will implement the $\sin (x)$ function in floating-point arithmetic. Before the microprogram can be assembled, the hardware must be defined since the fields of the microinstruction are dedicated to specific hardware once the microinstruction register is hardwired to the devices it controls. Since the final architecture chosen depends on tradeoffs between implementing certain operations in hardware or software, critical applications will require that a cursory analysis of the software be made before the hardware is cast in concrete. Attempting to develop microcode for a tentative architecture will force the issue on which operations are better suited for hardware. Before the architecture or the microprogram requirements can be known, the algorithms which describe the application processes must be defined. Once an algorithm is formulated it can be broken down into operations involving variable and constant quantities. The variables can be assigned to registers and then the algorithm can be translated into a microprogram. The following steps illustrate the plan for this CPU design example incorporating a floating-point $\sin (x)$ utility:

[^85]
### 5.1 Choose a Floating-Point Number System

An IEEE floating-point format will be chosen for this example for portability of data and software. It is important to note that the IEEE defines many standards in arithmetic processing, but for simplicity this example will encompass only number format. Furthermore, while several formats are IEEE compatible, only the basic single-precision format will be considered.

The IEEE basic single-precision format is defined as a 32 -bit representation in which the component fields are a 1 -bit sign $s$, an 8 -bit biased exponent $e$ and a 23-bit fraction $f$ which are assembled in the following order:


31
0

The quantity is evaluated as $(-1)^{s} 2 e-127$ (1.f). Not-a-number, zero and infinity have special representations. The one preceding the binary point is implied and is called the implicit one or implicit bit. It coincides with the fact that the digits are normalized (left justified).

### 5.2 Choose an Algorithm for $\operatorname{Sin}(x)$

Many algorithms are discussed in the literature for approximating useful quantities like $\sin (x)$. Literature research is a good place to start to familiarize oneself with various algorithms and tradeoffs for a particlar application. Computer simulation is also useful to compare algorithms for speed and accuracy. R.F. Ruckdeschel in BASIC Scientific Subroutines, Vol. 1 (BYTE, McGraw-Hill Publications Co. New York, N.Y., 1981, pp. 159-191 discusses tradeoffs and provides a simulation in BASIC for a $\sin (x)$ algorithm. An adaptation of this material has been chosen for this example:
A) Reduce angle range to first quadrant. ( $0 \leq x \leq \pi / 2$ )
B) Compute $\sin (x) \simeq \sum_{n=0}^{6} A_{n} x^{2 n-1}$. The coefficients are:
Coefficient Decimal IEEE hex

| $\mathrm{A}_{0}$ | 1.000000 | $3 F 800000$ |
| :--- | :---: | :--- |
| $\mathrm{~A}_{1}$ | -0.1666667 | BE2A AAAD |
| $\mathrm{A}_{2}$ | 0.008333333 | $3 C 088888$ |
| $\mathrm{~A}_{3}$ | -0.0001984127 | B950 0D01 |
| $\mathrm{A}_{4}$ | 0.000002755760 | 3638 EF99 |
| $\mathrm{A}_{5}$ | -0.00000002507060 | B2D7 5AD5 |
| $\mathrm{A}_{6}$ | 0.0000000001641060 | 2F34 6FBC |

The algorithm can be implemented in the following steps:
A) Reduce angle range to first quadrant. ( $0 \leq x \leq \pi / 2$ )

1) $\operatorname{SIGN}=\operatorname{SGN}(x)$
2) $\mathrm{ABS} X=\|x\|$
3) $\mathrm{XNEW}=\mathrm{ABSX}-2 \pi \times \operatorname{INT}(\mathrm{ABSX} / 2 \pi)$
4) If XNEW $>\pi$ then SIGN $=-$ SIGN and XNEW $=$ XNEW $-\pi$
5) If XNEW $>\pi / 2$ then XNEW $=\pi-$ XNEW
where

$$
\begin{aligned}
& \operatorname{SGN}(x)=\left\{\begin{array}{l}
+1 \text { if } x \geq 0 \\
-1 \text { if } x<0
\end{array}\right. \\
& \operatorname{INT}(x)=\text { integer function }
\end{aligned}
$$

B) Compute $\sin (x) \simeq \sum_{n=0}^{6} A_{n} x^{2 n-1}$.

1) Let $X$ SQR $=X N E W 2$; INITIALIZE SINX $=0$
2) Do $i=6$ to 1 step -1

$$
\operatorname{SINX}=X S Q R \times \operatorname{SINX}+A(i)
$$

Enddo
3) $\operatorname{SINX}=$ SIGN $\times X$ NEW $\times$ SINX

Step B-2 computes the summation in a geometric series for economy. The major difference between steps $A$ and $B$ is that $A$ requires more diverse ALU operations while $B$ uses only multiplication and addition recursively.

### 5.3 Make 'AS888 Register Assignments

Just as in assembly language programming, registers must be allocated for variables. Using Rn to denote the 'AS888 register whose address is $n$, where $0 \leq n \leq F$ (hex), the following register assignments can be made:

$$
\begin{aligned}
& \text { RO }=\mathrm{X} \\
& \mathrm{R} 1=\mathrm{SIGN} \\
& \mathrm{R} 2=\mathrm{ABSX} \\
& \mathrm{R} 3=\text { XNEW } \\
& \text { R4 }=\text { XSQR } \\
& \text { R5 }=\text { SINX }
\end{aligned}
$$

The following constants can also be defined:

| Constant | Decimal | IEEE hex |
| :--- | :---: | :---: |
| PI $=\pi$ | 3.141593 | 4059 OFDB |
| PIOVR $2=\pi / 2$ | 1.570797 | 3FC9 OFDB |
| $2 P I=2 \pi$ | 6.283185 | 40C9 OFDB |
| 1 OVR2PI $=1 / 2 \pi$ | 0.159155 | 3E22 F981 |

### 5.4 Substitute Registers for Variables in the Algorithm

Now the algorithm can be rewritten with registers replacing variables:
A) Reduce angle range to first quadrant ( $0 \leq x \leq \pi / 2$ ).

1) $R 1=S G N(R O)$
2) $R 2=\|R O\|$
3) $\mathrm{R} 3=\mathrm{R} 2-2 \pi \times \mathrm{INT}(\mathrm{R} 2 / 2 \pi)$
4) If R3 $>\pi$ then R1 $=-\mathrm{R} 1$; R3 $=\mathrm{R} 3-\pi$
5) If R3 $>\pi / 2$ then R3 $=\pi-\mathrm{R} 3$
B) Compute $\sin (x) \simeq \sum_{n=0}^{6} A_{n} x^{2 n-1}$.
6) Let $R 4=R O^{2}$; INITIALIZE R5 $=0$
7) Do $i=6$ to 1 step -1
$R 5=R 4 \times R 5+A(i)$
Enddo
8) $R 5=R 1 \times R 0 \times R 5$

Since various references to constants are made, it is probably best to load constants as needed rather than attempt to allocate registers for them. Constants can be loaded from a constant field in the microinstruction or from ROM. The tradeoff is 32 bits by 16 K of micromemory versus 32 bits by the number of constants (typically less than 16 K ). For this example, it will be assumed that a constant field in the microinstruction is acceptable.

### 5.5 Decompose Steps in the Algorithm into Simple Operations

The $\sin (x)$ function can be microprogrammed as a subroutine; let FSIN be its entry address. RO would be loaded with $x$ before FSIN were called. Upon return, R5 would contain $\sin (x)$. Now decompose the steps in the algorithm into simple arithmetic and logical operations. Other operations can be left as functions to be defined later.

FSIN: SUBROUTINE
; A) Reduce angle range to first quadrant. ( $0 \leq x \leq \pi / 2$ )

| $\mathrm{R} 1=\mathrm{SGN}(\mathrm{RO})$ | 1) Let R1 = Sign of RO |
| :---: | :---: |
| $\mathrm{R} 2=\mathrm{ABS}(\mathrm{RO})$ | 2) $\mathrm{R} 2=\\|\mathrm{RO}\\|$ |
| $\mathrm{R} 3=\mathrm{R} 2 *$ 10VR2PI | 3) $\mathrm{R} 3=\mathrm{R} 2-2 \pi * \operatorname{INT}(\mathrm{R} 2 / 2 \pi)$ |
| $\mathrm{R} 3=\mathrm{INT}(\mathrm{R} 3)$ |  |
| $\mathrm{R} 3=\mathrm{R} 3 * 2 \mathrm{PI}$ | , |
| $\mathrm{R} 3=\mathrm{R} 2-\mathrm{R} 3$ |  |
| $Y=R 3-\mathrm{PI}$ | 4) If R3 $>\pi$, |
| Jump if Negative to Step A-5 |  |
| $\mathrm{R} 1=-\mathrm{R} 1$ | then R1 $=-\mathrm{R} 1$; |
| $\mathrm{R} 3=\mathrm{R} 3-\mathrm{Pl}$ | $\mathrm{R} 3=\mathrm{R} 3-\pi$ |
| $\mathrm{Y}=$ PIOVR2 -R 3 |  |
| Jump if Negative to Step B-1 | 5) If R3> $>/ 2$ |
| $\mathrm{R} 3=\mathrm{PI}-\mathrm{R} 3$ | then R3 $=\pi-$ R3 |

B) Compute $\sin (x)=\sum_{n=0}^{6} A_{n} x^{2 n-1}$

$$
\begin{aligned}
& R 4=R 0 * R 0 \quad \text {; 1) Let } R 4=R 0^{2} \text {. Let } R 5=0 \\
& \text { R5 }=0 \text {; } \\
& \text { R5 = R4 * R5 } \\
& R 5=R 5+\mathrm{A} 6 \\
& R 5=R 4 * R 5 \\
& R 5=R 5+\mathrm{A} 5 \\
& R 5=R 4 * R 5 \\
& R 5=R 5+\mathrm{A} 4 \\
& R 5=R 4 * R 5 \\
& R 5=R 5+\mathrm{A} 3 \\
& R 5=R 4 * R 5 \\
& R 5=R 5+R 2 \\
& R 5=R 4 * R 5 \\
& R 5=R 5+\mathrm{A} 1 \\
& R 5=R 4 * R 5 \\
& R 5=R 5+A 0 \\
& R 5=R 0 \text { * R5 } \\
& \text { 3) } \mathrm{R} 5=\mathrm{R} 1 \times \mathrm{RO} \times \mathrm{R} 5 \\
& \text { R5 = R5 * R1 : RETURN }
\end{aligned}
$$

## END SUBROUTINE

### 5.6 Translate into 'AS888/890 Instructions; Identify Subroutines

The simplified steps of the algorithm can be represented fairly easily as 'AS888/890 instructions. Necessary functions (and suggested names) can be identified by inspection as:

1) FMUL - Floating-point multiplication
2) FADD - Floating-point addition
3) FINT - Floating-point integer conversion
4) FINV - Floating-point additive inverse (to subtract using FADD)
5) FABS - Floating-point absolute value
6) FSGN - Floating-point sign test
7) FCHS - Floating-point change of sign (to multiply by SIGN)
"Function" in this context refers to a special operation regardless of how it is coded. In fact, FMUL and FADD are fairly complex and require detailed explanation. FINV, FABS, FSGN and FCHS are single instruction operations that mask or mask and test. FINT requires several inline instructions or a subroutine and will be left to the interested reader as an exercise. Now the steps of the algorithm can be translated into 'AS888/890 operations which include references to these functions.

## FSIN: SUBROUTINE

; A) Reduce angle range to first quadrant. ( $0 \leq x \leq \pi / 2$ )

| R1 $=$ FSGN(RO) | ; Get sign bit (MSB) |
| :--- | :--- |
| R2 $=$ FABS(RO) | ; Take absolute value (clear MSB) |
| R3 $=$ FMUL(R2,1OVR2PI) | ; Multiply register and constant |
| R3 $=$ FINT(R3) | ; Floating-point integer conversion |
| R3 $=$ FMUL(R3,2PI) | ; Multiply register and constant |
| R3 $=$ FADD(R2,INV(R3)) | ; Subtract registers by adding inverse |
| Y $=$ FADD(R3,NEGPI) : TEST NEG | ; Subtract by adding negative constant |
| JT SIN1 | ; Jump if true (jump if negative) |
| R1 $=$ FINV(R1) | ; Complement sign of R1 |
| R3 $=$ FADD(R3,NEGPI) | ;Subtract by adding negative constant |
| $: Y=$ PIOVR2 - R3 : TEST NEG | ; Subtract to compare (don't store) |
| JT SIN2 | Jump if true (jump if negative) |
| R3 $=$ FADD(PI,FINV(R3)) | ;Subtract by adding negative register |

; B) Compute $\sin (x) \simeq \sum_{n=0}^{6} A_{n} \times 2 n-1$
SIN2

| R4 $=$ FMUL(R0,R0) | ; Square by multiplying |
| :--- | :--- |
| R5 $=$ A6 | ; Initialize series |
| R5 $=$ FMUL(R4,R5) | Multiply registers |
| R5 $=$ FADD(R5,A5) | ; Add coefficient |
| R5 $=$ FMUL(R4,R5) | Multiply registers |
| R5 $=$ FADD(R5,A4) | ; Add coefficient |
| R5 $=$ FMUL(R4,R5) | Multiply registers |
| R5 $=$ FADD(R5,A3) | ; Add coefficient |
| R5 $=$ FMUL(R4,R5) | Multiply registers |
| R5 $=$ FADD(R5,A2) | ; Add coefficient |
| R5 $=$ FMUL(R4,R5) | ; Multiply registers |
| R5 $=$ FADD(R5,A1) | ; Add coefficient |
| R5 $=$ FMUL(R4,R5) | ; Multiply registers |
| R5 $=$ FADD(R5,AO) | ; Add coefficient |
| R5 $=$ FMUL(R0,R5) | ; Multiply registers |
| R5 $=$ FCHS(R5,R1) :RETURN | ;Change MSB of R5 to MSB of R1 |

## END SUBROUTINE

This contrived language has a syntax which may be suitable for a source program. For the sake of illustration, it can be assumed that the microassembler recognizes this particular syntax. The series was computed inline instead of using a loop since it is relatively short. If a loop were used, a means of indexing the constants would be required.

### 5.7 Expand Subroutines into 'AS888/890 Operations

FMUL and FADD algorithms can now be expanded. Since they are called extensively from FSIN, they are more critical to the efficiency of the final design. Wherever possible, it is desirable to reduce the execution time of both in order to maintain efficiency.

### 5.7.1 Floating-Point Multiplication

Let M 1 be the multiplier and M 2 be the multiplicand whose product is P . Let the sign, exponent and fraction fields of their IEEE representation be:

```
M1: |S1|E1|F1|
M2: |S2|E2|F2
    P: |S3|E3|F3
```

$P$ is found by multiplying mantissas (fraction plus implicit one) and adding exponents. Since M1 and M2 are normalized, the range of 1.F1 $\times 1$.F2 is

$$
1.00 \ldots 0 \leq 1 . \mathrm{F} 1 \times 1 . \mathrm{F} 2 \leq 11.1 \ldots 10
$$

The implicit bit may "overflow" into bit position 24. This type of overflow must be detected so that the result can be normalized. Normalization requires right shifting the result of 1.F1 $\times 1$. F2 and incrementing E3. The implicit bit is then cleared when S3, E3 and M3 are packed to form P. The floating-point multiplication algorithm may then be defined as follows:

1) Unpack M1 into signed fraction (SF1) and exponent (E1)
2) Set the implicit bit in SF1
3) Unpack M2 into signed fraction (SF2) and exponent (E2)
4) Set the implicit bit in SF2
5) Perform SF3 $=$ SF1 $\times$ SF2 using signed integer multiplication
6) Perform E3 = E1 + E2
7) Test SF3 for overflow into bit 24
8) If true, then increment E3 and right shift SF3
9) Clear the implicit bit in SF3
10) Pack E3 and SF3 to get $P$

As before, the steps of this algorithm can be broken down into simpler operations:

1) Unpack M1 into signed fraction (SF1) and exponent (E1)
$\mathrm{E} 1=\mathrm{FEXP}(\mathrm{M} 1)$
SF1 $=\operatorname{FRAC}(\mathrm{M} 1)$
2) Set the implicit bit in SF1

SF1 = SF1 OR BIT23
3) Unpack M2 into signed fraction (SF2) and exponent (E2) $\mathrm{E} 2=\mathrm{FEXP}(\mathrm{M} 2)$ SF2 = FRAC (M2)
4) Set the implicit bit in SF2 SF2 = SF2 OR BIT23
5) Perform SF3 $=$ SF1 $\times$ SF2 using signed integer multiplication SF3 = IMUL (SF1, SF2)
6) Perform E3 $=E 1+E 2$ $E 3=E 1+E 2$
7) Test SF3 for overflow into bit 24

TEST (SF3 AND BIT24) JUMP IF FALSE to step 9
8) If true, then increment E3 and right shift SF3 INC E3 SF3 $=$ RSHFT (SF3)
9) Clear the implicit bit in SF3.

SF3 = SF3 AND NOT_BIT23
10) Pack E3 and SF3 to get $P$

$$
P=S F 3 \text { OR E3 }
$$

FEXP, FRAC, testing bit 24 and setting/clearing bit 23 are all mask operations that translate into single 'AS888 instructions. The integer multiplication (IMUL) is simply the multiplication algorithm supported by the 'AS888 instruction set. No significant hardware features are required to do floating-point multiplication, nor are any subroutines required to support it.

Register assignments can now be made as before. Since FSIN uses registers in the lower half of the register file, it might be preferable to restrict FMUL to the upper registers. For example:

```
\(R F=P\)
\(\mathrm{RE}=\mathrm{M} 1, \mathrm{~F} 1, \mathrm{SF} 1\)
\(R D=M 2, F 2, S F 2\)
\(R C=E 1\)
\(R B=E 2\)
```

RE and RD can share variables that need not be preserved. Using this assignment, FMUL computes RF $=$ FMUL(RE,RD). RE and RD must be loaded prior to calling FMUL and RF must be stored upon return. By substituting registers for variables and reorganizing operations in the FMUL algorithm to better fit 'AS888/890 operations the following source program may be created:
FMUL: SUBROUTINE
$R C=F E X P(R E) \quad$; Unpack $M 1$ into exponent
$R E=F R A C(R E)$; and fraction
RE $=$ RE OR BIT23 ; Set implicit bit
$M O=$ SMTC(RE) ; Prepare to multiply
$R B=\operatorname{FEXP}(R D) \quad$; Unpack M2 into exponent
RD $=$ FMAG(RD) ; and fraction
RD = RD OR BIT23 ; Set implicit bit
$R D=S M T C(R D) \quad$; Prepare to multiply
RE $=0: R C A=\# 22 d$; Initialize to multiply
RE $=$ SMULI RD : LOOP RCA ; Integer multiplication iteration
RE $=$ SMULT RD $\quad$; Final step in signed multiply
$\mathrm{Y}=\mathrm{TBO}(\mathrm{RE}, \mathrm{BIT} 1): \mathrm{BYTE}=\# 0100 \mathrm{~b}:$ TEST Z ; Test "overflow'"
JF FMUL1 ; Jump if false (exponent ok)
INEX(RC) ; Increment exponent: add 00800000
$R E=S R A(R E) \quad$; Shift fraction to normalize
FMUL1:RC $=\mathrm{RC}+\mathrm{RB}:$ TEST CARRY ; Add exponents and test carry
JT ERROR ; Jump if carry true to handler
RE $=$ SMTC(RE) ; Get sign magnitude fraction
RE = RE AND \#807F_FFFFh ; Clear implicit bit
RF $=$ RE OR RC : RETURN ; Pack fraction and exponent

### 5.7.2 Floating-Point Addition

The floating-point addition algorithm (FADD) is slightly more complex than FMUL, since the two addends will usually not have the same exponent. Therefore the smaller (absolute value) addend must first be chosen by comparing exponents. Then it must be denormalized to align its digits with the digits of the larger addend. In other words, the two addends must have the same exponent before their fractions can be added. This process can be described by the following algorithm:

1) Unpack A1 to get SF1 and E1
2) Set implicit bit in SF1
3) Unpack A2 to get SF2 and E2
4) Set implicit bit in SF2
5) If E2 $>$ E1 then go to step 9
$(\|A 1\| \leq\|A 2\|)$
6) Let DIFF $=\mathrm{E} 1-\mathrm{E} 2$
7) Do i $=1$ to DIFF

SF2 $=$ RSHFT(SF2) (Arithmetic right shift)
Enddo
8) Let $\mathrm{E} 3=\mathrm{E} 1$, go to step 12
$(\|A 2\|>\|A 1\|)$
9) Let DIFF = E2 - E1
10) Do $i=1$ to DIFF

SF1 = RSHFT(SF1) (Arithmetic right shift)
Enddo
11) Let $\mathrm{E} 3=\mathrm{E} 2$
12). $\mathrm{SF} 3=\mathrm{SF} 1+\mathrm{SF} 2$
13) Test "overflow" into bit 24
14) Jump if false to step 17
15) Increment exponent E3
16) Normalize signed fraction with right arithmetic shift
17) Clear implicit bit
18) Pack: SUM $=$ SF3 or E3
19) Return

Register assignments for variables must now be made. Since FSIN uses registers in the lower half of the 'AS888 register file, it is necessary to use the upper registers:

$$
\begin{aligned}
& \mathrm{RF}=\mathrm{SUM} \\
& \mathrm{RE}=\mathrm{A} 1, \mathrm{~F} 1, \mathrm{SF} 1 \\
& \mathrm{RD}=\mathrm{A} 2, \mathrm{~F} 2, \mathrm{SF} 2 \\
& \mathrm{RC}=\mathrm{E} 1 \\
& \mathrm{RB}=\mathrm{E} 2
\end{aligned}
$$

By slightly reorganizing the sequence to better fit 'AS888/890 operations, the following microprogram to perform FADD can be created:

## FADD: SUBROUTINE

; 1) Unpack $A 1$ to get SF1 and E1
$\mathrm{RC}=\mathrm{FEXP}(\mathrm{RE})$
; Get exponent (E1)
RE $=$ FRAC(RE)
; Get signed fraction (SF1)
; 2) Set implicit bit in SF1
$\mathrm{MQ}=$ RE OR BIT23
; Set implicit bit
RE $=$ SMTC(RE) ; Convert to two's complement

| 3) Unpack A2 to get SF2 and A2 $\begin{aligned} & R B=F E X P(R D) \\ & R D=F R A C(R D) \end{aligned}$ | ; Get exponent (E2) <br> ; Get signed fraction (SF2) |
| :---: | :---: |
| ; 4) Set implicit bit in SF2 |  |
| RD $=$ RD OR BIT23 | ; Set implicit bit |
| $R D=S M T C(R D)$ | ; Convert to two's complement |
| ; 5) If E2 $>$ E1 then go to step 9 |  |
| RF $=$ RC - RB: TEST NEGATIVE | ; Compare A2 from A1 |
| JT FADD1 : RCA $=$ \#8 | ; Jump if E2 $>$ E1; set up loop count |
| ; 6) Let DIFF $=$ E1 - E2. |  |
| Y/RF $=$ SLC(RF) : LOOP RCA | ; Rotate 8 times to get difference |
| $\mathrm{RCA}=\mathrm{Y} / \mathrm{RF}$ | ; Load difference in loop counter |
| ; 7) Do i $=1$ to DIFF |  |
| SF2 $=$ RSHFT(SF2) |  |
| Enddo |  |
| RD $=$ SRA(RD) : LOOP RCA | ; Orient digits of smaller addend |
| 8) Let $\mathrm{E} 3=\mathrm{E} 1$, go to step 12 |  |
| RB $=$ RC : JUMP FADD2 | ; Swap registers and branch |
| 9) Let DIFF $=$ E2 - E1 |  |
| FADD1: RF $=$ NOT(RF) | ; Complement result of E1 - E2 |
| Y/RF $=$ SLC(RF) : LOOP RCA | ; Shift 8 times to get DIFF |
| $\mathrm{RCA}=\mathrm{Y} / \mathrm{RF}$ | ; Load DIFF in loop counter |
| ;10) Do i $=1$ TO DIFF |  |
| SF1 = RSHFT(SF1) |  |
| Enddo |  |
| RE $=$ SRA(RE) : LOOP RCA | ; Align SF1 with SF2 |
| ;11) Let E3 $=E 2$ (no instruction required | - RB already has E2 in it) |
| ;12) SF3 $=$ SF1 + SF2 |  |
| FADD2: $\mathrm{RF}=\mathrm{RD}+\mathrm{RE}$ | ; Add |
| $R F=S M T C(R F)$ | ; Convert to sign-magnitude |
| ;13) Test "overflow" into bit 24 |  |
| RF $=$ TBO (RF, BIT24) | ; Check for normalization |
| ;14) Jump if false to step 17 |  |
| JF FADD3 | ; If so, finish and exit |
| ;15) Else increment exponent |  |
| INC RB : TEST NEG | ; Test for exponent overflow |
| ;16) Normalize signed fraction |  |
| $\mathrm{RF}=\mathrm{SRA}(\mathrm{RF}): \mathrm{JT}$ ERROR | ; Jump to error handler if overflow |
| ;17) Clear implicit bit |  |
| FADD3: RF $=$ SETO (RF, BIT23) | ; Reset bit 23 of RF |
| ;18) Pack: SUM $=$ SF3 OR E3 |  |
| RF $=$ RF OR RB : RETURN | ; Or signed fraction and exponent |

There is an important consequence of FADD which impacts the hardware. Since the number of shifts required to denormalize the small addend is data dependent (computed in the ALU) it is necessary to provide a path between the ALU $Y$ bus and the 'AS890 DRA bus. All the other operations are simple 'AS888/890 instructions, including the FRAC and FEXP mask operations discussed during the development of FMUL. ERROR is a floating-point overflow error handler.

### 5.8 Evaluate Tradeoffs and Block Diagram the Hardware

A rough estimate of the FSIN worst case execution time can be arrived at by making the following observations about FSIN, FMUL and FADD:

$$
\begin{aligned}
& \text { FMUL } \\
& \text { integer recursion } \simeq 22 \text { cycles } \\
& \text { other instructions } \simeq 18 \text { cycles } \\
& \text { total } \simeq 40 \text { cycles }
\end{aligned}
$$

```
FADD
    denormalization \simeq 23 cycles
    other instructions }\simeq25\mathrm{ cycles
    total }\simeq50\mathrm{ cycles
FSIN
    number of calls to FMUL = 12
    number of calls to FADD = 11
    number of other cycles }\simeq1
```

Approximate worst case total $=10+(12 \times 40)+(11 \times 50)=1040$ cycles. At 50 nanoseconds per cycle, this requires approximately 52 microseconds. There are few improvements that could be made in hardware to speed this time, except perhaps the addition of a flash multiplier which would reduce the integer computation by about 20 cycles (an overall reduction of about two percent). A barrel shifter could have the same benefit during floating-point addition for a total reduction of about 4 percent. For the sake of simplicity, it will be assumed that 52 microseconds is acceptable for the $\sin (x)$ computation.

Another issue which must be considered is the problem of loading the 'AS888 and 'AS890 with constants. A slight materials cost reduction might be realized by storing constants in table PROMs rather than in control store memory. An interesting use of the DRA and DRB ports on the 'AS890 would be to use the output of RCA or RCB to index data in the constant PROM. This would allow long series to be implemented in loop form rather than the inline method used in FSIN. Once again, the constant PROM will not be implemented for the sake of simplicity.

Now the architecture can be designed to meet the requirements identified throughout this analysis:

1) A path between the 'AS888 $Y$ bus and the 'AS890 DRA bus.
2) A path between the microinstruction register and the 'AS890 DRA bus for loading loop counts and branch addresses.
3) A path between the microinstruction register and the 'AS888 $Y$ bus for loading constants.
4) Independent control of $\overline{\mathrm{SIOO}}$ in each 'AS888 slice to allow bit/byte instructions.
5) A status register to store 'AS888 status for testing.
6) A status mux to test the 'AS888 status, bit 23 of the 'AS888 Y bus, bit 24 of the 'AS888 Y bus and hardwired 0 and 1.

A system having these features is illustrated in Figure 5.1.


Figure 5-1. Block Diagram of Floating-Point Processor

### 5.9 Define Microinstruction Fields During Detailed Hardware Design

The detailed hardware design will produce a wiring diagram that fixes the position within the microinstruction of each of the various control signals that are connected from the microinstruction register to the 'AS888, 'AS890, status mux and any other special hardware. Once this design is complete it is possible for the assembler to sort the control bits of each instruction so that they will be properly oriented when the microprogram is installed in the target system.

### 5.10 Assemble the Microprogram

TI is currently developing an 'AS888/890 microassembler. Several microassemblers are commercially available, and many users prefer to write their own. The microprogram shown in Table 5-1 was hand-assembled, but has a syntax that is suitable for interpretation by a user-written assembler.

* $\mathrm{R} 1=\mathrm{FSGN}(\mathrm{RO})$

R1 $=$ R0 AND \#8000 0000h

* $\mathrm{R} 2=\mathrm{FABS}(\mathrm{RO})$
$R 2=R 0$
R2 $=$ RO SETO \#80h $: B Y T E=\# 1000 \mathrm{~b}$
* $\mathrm{R} 3=\mathrm{FMUL}(\mathrm{R} 2,10 \mathrm{VR} 2 \mathrm{PI})$
$R E=R 2$
RD $=$ \#3EA2 F984h JSR FMUL
$\mathrm{R} 3=\mathrm{RF}$
* R3 $=$ FINT(R3)
$R F=R 3$
0007 JSR FINT [EXERCISE FOR READER] R3 $=$ RF
* $\mathrm{R} 3=\mathrm{FMUL}(\mathrm{R} 3,2 \mathrm{PI})$ $R E=R 3$
RD $=$ \#40C9 0FDBh
JSR FMUL
$R 3=R F$
* $\mathrm{R} 3=\mathrm{FADD}(\mathrm{R} 2, \mathrm{INV}(\mathrm{R} 3))$
$R E=R 2$
$R D=R 5 X O R \# 80000000 \mathrm{~h}$
000F
0010
0011 JSR FADD
$R 3=R F$

Table 5.1. Floating Point Sin(x) Microprogram


Table 5．1．Floating Point $\operatorname{Sin}(x)$ Microprogram（continued）

0012
0013
0014
0015 0016 0017

0018
001A 001A 1B 01C
001D
001E
001F 0020
$R 4=\operatorname{FMUL}(R 0, R 0)$
0025
0026
0027
0028 RE $=$ R2 $R D=\# C 0590 F D B h$ JSR FADD Y＝RF ：TEST NEG JT SIN1
＊ $\mathrm{R} 1=\operatorname{FINV}(\mathrm{R} 1)$ R1＝R1 XOR \＃8000 0000h
＊ $\mathrm{R} 3=\mathrm{FADD}(\mathrm{R} 3, \mathrm{NEGPI})$ $R E=R 3$
RD $=$ \＃C059 0FDBh
JSR FADD
$R 3=R F$ $\mathrm{RE}=$ \＃3FC9 0FDBh RD $=$ R3 XOR \＃8000 0000h JSR FADD
$Y=$ RF ：TEST NEG JT SIN2
＊ $\mathrm{R} 3=\mathrm{FADD}(\mathrm{PI}, \mathrm{FINV}(\mathrm{R} 3))$ RE $=$ \＃4059 OFDBh RD $=$ R3 XOR \＃8000 0000h JSR FADD $R 3=R F$
$R E=R O$
$R D=R 0$
JSR FMUL
$R 4=R F$
＊$Y=$ FADD（R2，NEGPI）

SIN1：$\quad Y=$ FADD（PIOVR2，INV（R3））：TEST NEG

|  | 32－bit <br> Constant |  |  | DRB13－ DRB0 | 耑 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $02 \mathrm{XE} 0 \times 11100 \mathrm{~F} 6$ | X $\times \times \times \times \times \times \times$ | 1111 | $027 x$ | X $\times$ X $\times 1111$ | 7 |
|  | C 0590 FD B | 1111 | $027 x$ | X $\times \times \times \times 1 \begin{array}{lllll}1 & 1\end{array}$ | 7 |
|  | $\times \times \times \times \times \times \times$ | 1111 | 0140 | 0074111 | 7 |
| $1 \mathrm{FXX} 0 \times 11000 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times \times$ | 1111 | $027 \times$ | X $\times \times \times 111$ | 2 |
|  | X $\times$ X $\times$ X $\times$ X X | 1111 | 017 | 0000111 | 7 |
| $01 \times 10211100 \mathrm{~F} 9$ | 80000000 | 1111 | 027 | X $\times \times \times 111$ | 7 |
| $03 \times \mathrm{E} 0 \times 1100 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times$ | 1111 | $027 \times$ | 人 $\times \times \times \times 1111$ | 7 |
| $03 \times \mathrm{DXX1111} \mathrm{\times FF}$ | C 0590 FDB | 11111 | $027 \times$ | X $\times \times \times 1 \begin{array}{llll}1 & 1\end{array}$ | 7 |
| $1 \mathrm{XXXXX} 111 \mathrm{XX} \times \mathrm{F}$ | X $\times \times \times \times \times \times \mathrm{X}$ | 11111 | 0140 | 00741111 | 7 |
| $0 \mathrm{FX} 30 \times 11100 \mathrm{~F} 6$ | X $\times \times \times \times \times \times \mathrm{X}$ | 1111 | $027 \times$ | X X X 1111 | 7 |
| $0 \times \mathrm{XEXX} 111110 \mathrm{~F} 6$ | 35 C 90 FD B | 11111 | $027 x$ | X $\times \times \times \times 1 \begin{array}{llll}1 & 1\end{array}$ | 7 |
| 03 X D 0211100 F 9 | 80000000 | 11111 | $027 x$ | X X X X 1111 | 7 |
| $1 \times \times \mathrm{XXX} 111 \mathrm{XXFF}$ | X X X X X X X | 11111 | 0140 | 00744111 | 7 |
| $1 \mathrm{FXX} 0 \times 11000 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1\end{array}$ | $027 \times$ | X $\times \times \times 1111$ | 2 |
| $1 \times \times \times \times 111 \times \times F F$ | X $\times \times \times \times \times \times \times$ | 1111 | 0170 | 0000111 | 7 |
| $0 \times \mathrm{XEXX} 11110 \mathrm{~F} 6$ | 40590 F D B | 11111 | $027 \times$ | 人 $\times \times \times \times 1 \begin{array}{lll}1 & 1\end{array}$ | 7 |
| 03 X D 0111100 F 9 | 80000000 | 11111 | $027 \times$ | X $\times \times \times \times 111$ | 7 |
|  | X $\times \times \times \times \times \times \times$ | 11111 | 0140 | 0074111 | 7 |
| $0 \mathrm{~F} \times 30 \times 11100 \mathrm{~F} 6$ | X $\times \times \times \times \times \times \times$ | 1111 | $027 \times$ | X $\times \times \times 11$ | 7 |
| $00 \times \mathrm{E} 0 \times 11100 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times \times$ | 1111 | $02.7 x$ | $\times \times \times \times 11$ | 7 |
| $00 \times \mathrm{D} 0 \times 11100 \mathrm{~F} 6$ | X $\times \times \times \times \times \times \mathrm{X}$ | 1111 | $027 x$ | X $\times \times \times 11$ | 7 |
|  | $\times \times \times \times \times \times \times \times$ | 1111 | 0140 | $\begin{array}{llllll}0 & 6 & 0 & 1\end{array}$ | 7 |
| $0 \mathrm{FX} 40 \times 11100 \mathrm{~F} 6$ | $\times \times \times \times \times \times \times$ | 111 | $027 x$ | $\times \times \times 1$ | 7 |

Table 5.1. Floating Point $\operatorname{Sin}(x)$ Microprogram (continued)

* $\mathrm{R} 5=\mathrm{A} 6$

R5 $=$ \#2F34 6FBCh

* $\mathrm{R} 5=\mathrm{FMUL}(\mathrm{R} 4, \mathrm{R} 5)$
$R E=R 4$
$R D=R 5$
JSR FMUL
$R 5=R F$
* R5 = FADD(R5,A5) $R E=R 5$ $\mathrm{RD}=$ \#B2D75AD5h JSR FADD $\mathrm{R} 5=\mathrm{RF}$
* $\mathrm{R} 5=\mathrm{FM} \operatorname{LI}(\mathrm{R} 4, \mathrm{R} 5)$
$R E=R 4$
$R D=R 5$ JSR FMUL
$R 5=R F$
* R5 = FADD(R5,A4) $\mathrm{RE}=\mathrm{R} 5$
RD $=$ \#3638 EF99h JSR FADD
$R 5=R F$
* $R 5=$ FMUL(R4,R5)
$R E=R 4$
$R D=R 5$
JSR FMUL
$R 5=R F$


Table 5.1. Floating Point $\operatorname{Sin}(x)$ Microprogram (continued)

* R5 $=\operatorname{FADD}(\mathrm{R5}, \mathrm{~A} 3)$ $R E=R 5$ RD = \#B950 0D01h JSR FADD
R5 $=$ RF
* R5 = FMUL(R4,R5) $R E=R 4$ $\mathrm{RD}=\mathrm{R} 5$ JSR FMUL R5 $=R F$
* R5 = FADD(R5,A2) RE $=$ R5 RD $=$ \#3C08 8888h JSR FADD
R5 = RF
* R5 = FMUL(R4,R5) $R E=R 4$
$R D=R 5$
JSR FMUL
R5 = RF
* R5 $=$ FADD (R5,A1) $R E=R 5$
$R D=\# B E 2 A$ AAADh
JSR FADD
R5 = RF
* R5 = FMUL(R4,R5)
$R E=R 4$
$R D=R 5$
JSR FMUL R5 = RF

|  | $\begin{gathered} \text { 32-bit } \\ \text { Constant } \end{gathered}$ |  |  | DRB13DRB0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $05 \times \mathrm{E} 0 \times 11100 \mathrm{~F} 6$ | x $\times$ x $\times$ x $\times \mathrm{x}$ | 1111 | $027 \times$ | x $\times$ x $\times 1111$ | 7 |
| $0 \mathrm{XXDXX1111} \mathrm{XFF}$ | B 9500001 | 11111 | $027 \times$ | x $\times$ x $\times 1 \begin{array}{lll}1 \\ 1\end{array}$ | 7 |
| 1 XXXXX 111 XXFF | $\mathrm{x} \times \mathrm{x} \times \mathrm{x} \times \mathrm{x}$ | 11111 | 0140 | 0074111 |  |
| OFX50X11100F6 | $\mathrm{x} \times \mathrm{XXXXXX}$ | 11111 | $027 \times$ | x $x \times \times 1111$ | 7 |
| $04 \times \mathrm{E} 0 \times 11100 \mathrm{~F} 6$ |  | 11111 | $027 \times$ |  | 7 |
| $05 \times 00 \times 11100 \mathrm{~F}$ | x $6 \times x \times x \times x$ | 1 1111 | $027 \times$ | XXXXX1111 |  |
| 1 XXXXX 111 XXFF | $\mathrm{x} \times \times \times \times \times \mathrm{x}$ | $11 \begin{array}{llllll} \\ 1\end{array}$ | 0140 | 0 06601111 |  |
| OFX50X11100F6 | $\mathrm{x} \times \mathrm{x} \times \mathrm{x} \times \mathrm{x}$ | 1111 | $027 \times$ | x $\times$ x $\times 111$ | 7 |
| $05 \mathrm{XE} 0 \times 11100 \mathrm{~F} 6$ | x $\times$ XXXXXX | 1111 | $027 \times$ | x $\times$ x $\times 1 \begin{array}{lll}1 & 1\end{array}$ | 7 |
| 0 XXDXX 1111 XFF | 3C088888 | 1111 | $027 \times$ |  |  |
| 1 XXXXX 111 XXFF |  | 1 11111 | 0140 | 0007411111 |  |
| $0 \mathrm{FX} 50 \times 11100 \mathrm{~F} 6$ | $\mathrm{x} \times \times \mathrm{XXXX}$ | 11111 | $027 \times$ |  | 7 |
| $04 \mathrm{XEOX11100F6}$ | x $\times$ x $x \times x$ x | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 \times$ |  | 7 |
| $05 \times \mathrm{D} 0 \times 11100 \mathrm{~F} 6$ |  | 1 1 1 | $027 \times$ | x |  |
| 1 XXXXX 111 XXFF | x $\times$ x $\times$ x $\times$ | $1 \begin{array}{lllll}1 \\ 1\end{array}$ | 0140 | 0060111 |  |
| OFX50X11100F6 | $\mathrm{x} \times \mathrm{XXXXX}$ | 1111 | $027 \times$ | x $\times$ x $\times 111$ |  |
| $05 \times \mathrm{EX} 11100 \mathrm{~F} 6$ | x $\times$ x $\times$ x $\times$ x | 11111 | $027 \times$ |  | 7 |
| 0 XXDXX 11111 FF | BE 2 AAAAD | 11111 | $027 \times$ | X $\mathrm{XXXX} \mathbf{1} 111$ |  |
| 1 XXXXX 111 XXFF | x $\times$ x $\times$ x $\times$ | 11111 | 0140 | 0074111 |  |
| OFX50X11100F6 | $\mathrm{x} \times \mathrm{x} \times \mathrm{x} \times \mathrm{x}$ | 1111 | 027 X | x $\mathrm{x} \times \mathrm{x} 11111$ |  |
| $04 \times \mathrm{E} 0 \times 11100 \mathrm{~F} 6$ | x $\times$ x $\times$ x $\times$ x | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 \times$ | x $\times$ x $\times 1 \begin{array}{llll}1 & 1 & 1\end{array}$ | 7 |
| 05 X D 0 X 11100 F 6 | x $\times$ XXXXX | 11111 | $027 \times$ |  |  |
| 1 XXXXX 111 XXFF | $\mathrm{x} \times \times \times \mathrm{x} \times \mathrm{x}$ | (111111 | 0140 | 0060111 | 7 |
| 0 FX 50 X 11100 F 6 | $\mathrm{x} \times \mathrm{XX} \times \mathrm{x} \times$ | 1111 | $027 \times$ | x $\times \times \times 111$ |  |

Table 5.1. Floating Point Sin(x) Microprogram (continued)

| 0066 | * $\mathrm{RD}=\mathrm{FRAC}(\mathrm{RD})$ <br> RD = RD AND \#807F FFFFh |
| :---: | :---: |
| 0067 | $\mathrm{RD}=\mathrm{RD}$ OR bit23 |
| 0068 | RD $=$ SMTC(RD) |
| 0069 | $\mathrm{RE}=0: \mathrm{RCB}=\# 22 \mathrm{D}$ |
| 006A | RE $=$ SMULI RD : LOOP RCB |
| 006B | RE $=$ SMULT RD |
| 006C | TBO(RE,bit1) : BYTE = \#0100b : TEST Z |
| 006D | JT FMUL1 |
|  | * INEX RC |
| 006E | $\mathrm{RC}=\mathrm{RC} \mathrm{ADD} \mathrm{\# 0080} \mathrm{0000h}$ |
| 006F | $\mathrm{RE}=\mathrm{SRA}(\mathrm{RE})$ |
| $\begin{aligned} & 0070 \text { FMUL1: } \\ & 0071 \end{aligned}$ | $R C=R C$ ADD RB : TEST CARRY JT ERROR |
| 0072 | RE $=$ SMTC(RE) |
| 0073 | RE = RE AND \#807F FFFFh |
| * FADD: | $\mathrm{RC}=\mathrm{FEXP}(\mathrm{RE})$. |
| 0074 FADD: | RC = RC AND \#7F80 0000 |
|  | * RE $=$ FRAC(RE) |
| 0075 | RE = RE AND \#807F FFFFh |
| 0076 | MO $=$ RE OR bit23 |
| 0077 | RE $=$ SMTC(RE) |
|  | * $\mathrm{RB}=\mathrm{FEXP}(\mathrm{RD})$ |
| 0078 | RB = RD AND \#7F80 0000 |


|  | 32-bit <br> Constant | Bo |  | 岕 |
| :---: | :---: | :---: | :---: | :---: |
| 0 DXD 021100 FA | 807 F F F F F | 1111 | $027 \times \times \times \times 111$ | 7 |
| $0 \mathrm{D} \times \mathrm{D} 211100 \mathrm{FB}$ | 00800000 | 1111 | $027 \times \times \times \times 111$ | 7 |
| $0 \times \mathrm{D} \times 01111 \mathrm{D} 58$ | X $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 \times \times \times \times 111$ | 7 |
| OEEEO 0111110 F 9 | 00000016 | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $617 \times \times \times \times 111$ | 4 |
| O DEE 00011111110060 | X $\times \times \times \times \times \times \mathrm{X}$ | $1 \begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | 567006 A 1111 | 4 |
| O DEE 000111100070 | $\times \times \times \times \times \times \times$ | 11111 | $067 \times \times \times \times 111$ | 7 |
| 00 F | X $\times \times \times \times \times \times \mathrm{X}$ | $1 \begin{array}{llll}1 & 0 & 1 & 1\end{array}$ | $027 \times \times \times \times 111$ | 4 |
| $1 \times \mathrm{XXXXX111} \mathrm{\times FF}$ | X $\times \times \times \times \times \times \times$ | 11111 | $017 \times \times \times \times 111$ | 7 |
| 0 CXCO 211100 F 1 | 008000000 | 1111 | $027 \times \times \times \times 111$ | 7 |
| OEXEOX1110006 | $\mathrm{X} \times \times \times \times \times \times \mathrm{x}$ | 1111 | $027 \times \times \times \times 111$ | 7 |
| OCBCOCOL1100.F1 | x $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 \times \times \times \times 111$ | 0 |
| $1 \times \mathrm{XXXX1} 11 \times \mathrm{CFF}$ | XXXXXXXX | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $017 \times \times \times \times 111$ | 7 |
| OXEEX 01111058 | $X \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 \times \times \times \times 1111$ | 7 |
| OEXEO211100FA | 8.07 F F F F F | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 \times \times \times \times 111$ | 7 |
| 0 CXCO 211100 FA | 7 F 800000 | 1111 | $027 \times \times \times \times 111$ | 7 |
| OEXEO211100FA | 807 FFFFF | 11111 | $027 \times \times \times \times 111$ | 7 |
| $1 \mathrm{EXX} \times 111100 \mathrm{E}$ ¢ | 00800000 | 111.11 | $027 \times \times \times \times 111$ | 7 |
| OEXEO211100FA | 807 FFFFF | 11111 | $027 \times \times \times \times 111$ | 7 |
| $0 \mathrm{D} \times \mathrm{B} 211100 \mathrm{FA}$ | 7 F 800000 | 1111 | $027 \times \times \times 111$ | 7 |

Table 5.1. Floating Point $\operatorname{Sin}(x)$ Microprogram (continued)

|  | 32-bit <br> Constant |  |  | DRB13DRB0 | 岕 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| OEXEO211100FA | 807 FFFFF | 1111 | $027 \times$ | x $\times \times \times 111$ | 7 |
| O D X 0 2 1 1 1 0 F F | 008800000 | 11111 | $027 x$ | $\begin{aligned} & \mathrm{X}\end{aligned} \mathrm{X} \times \times \times 1 \begin{array}{lll}1 & 1\end{array}$ | 7 |
| $0 \times \mathrm{D} \times 01111058$ | X $\times \times \times \times \times \times \mathrm{X}$ | 1111 | $027 x$ | XXXX 1111 | 7 |
| 0 C B F 0011100 F 3 | $\times \times \times \times \times \times \times \times$ | 111 | $027 x$ | x $\times \times \times \times 1 \begin{array}{llll}1 & 1\end{array}$ | 2 |
| $1 \times \times \times \times 1111 \times \mathrm{F}$ ¢ 1 | X $\times$ X X X $\times 8$ | 1111 | $617 \times$ | X $\times \times \times 1 \times 11$ | 4 |
| 0 F X F OX $110 \times 066$ | X X X X X X X | 111 | 5670 | 007 E 1111 | 4 |
| $1 \times \mathrm{XXXX} 1100 \times \mathrm{F}$ | X $\times \times \times \times \times \times \mathrm{X}$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | 2770 | 00800111 | 7 |
| $0 \mathrm{D} \times \mathrm{D} 0 \times 1110006$ | $\times \times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | 1670 | 007 E 1111 | 4 |
| 0 C X B O X $1110 \times \mathrm{F}$ | $\mathrm{X} \times \times \mathrm{X} \times \times \mathrm{X}$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $027 \times$ | X $\times \times \times \times 1 \begin{array}{llll}1 & 1\end{array}$ | 7 |
| $0 \mathrm{FXFOX11} 00 \mathrm{~F} 7$ | P $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $027 \times$ | $\times \times \times \times \times 1$ | 7 |
| 0 F X F $0 \times 1100066$ | $\times \times \times \times \times \times \times$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | 617 X | X $\times \times \times \times 1111$ | 4 |
| $1 \times \times \times \times \times 1100 \times \mathrm{FF}$ | $\times \times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | 5670 | 0084111 | 4 |
| OEXEOX1110006 | $\times \times \times \times \times \times \times \times$ | $\begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | 2770 | 0086111 |  |
| ODEFO 011100 F 1 | X $\times \times \times \times \times \times \times$ | 111 | $027 \times$ | $\times \times \times \times 11$ | 7 |
| $0 \times \mathrm{FF} \times 0 \times 1111110058$ | X $\times \times \times \times \times \times \times$ | $1 \begin{array}{lllll}1 & 1 & 1 & 1\end{array}$ | $027 \times$ | - $\times \times \times \times \times 1 \begin{array}{llll}1 & 1\end{array}$ | 7 |
|  | $\times \times \times \times \times \times \times \times$ | $\begin{array}{lllll}0 & 1 & 1 & 1\end{array}$ | $027 \times$ | $\mathrm{x} \times \times \times \times 1 \begin{array}{llll}1 & 1\end{array}$ |  |
| $1 \times \mathrm{X} \times \mathrm{X} 111 \mathrm{X} \times \mathrm{F}$ F | X X X X X X X | 11111 | $047 \times$ | $\times \times \times \times \times 11$ | 7 |
| O B X B O X 111111 F 6 | X X X X X X X ${ }^{\text {¢ }}$ | 11111 | $027 \times$ | X $\times$ X $\times 1 \begin{array}{lll}1 & 1\end{array}$ |  |
| 0 F 7 F 0 X 11110006 | X X X X X X X ${ }^{\text {¢ }}$ | $1 \begin{array}{llll}1 & 1 & 1\end{array}$ | $017 \times$ | X $\times$ X $\times 1 \begin{aligned} & 1 \\ & 1\end{aligned}$ | 7 |
| 07 F 000011111018 | X $\times \times \times \times \times \times \mathrm{X}$ | 101 | $027 \times$ | X $\times \times \times \times 1111$ | 7 |
| 0 F B F 00111100 F B | X X X X X X X | 111 | 022 X | X×××111 | 7 |

## General Information

Numerical Index
Glossary
Explanation of Function Tables
Parameter Measurement Information
Functional Index

LSI Devices
2

## Application Reports

Advanced Schottky Family Error Detection and Correction
Memory Mapping
Bit-Slice Processor 8-Bit Family
Excerpt - SN74AS888, SN74AS890
Bit-Slice Processor User's Guide

Mechanical Data

## ORDERING INSTRUCTIONS

Electrical characteristics presented in this data book, unless otherwise noted, apply for 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.


MUST CONTAIN TWO TO FOUR LETTERS


## 3 PEP processing, level 3 ( $N$ or NT packages only)

†These circuits in dual-in-line and "small outline" packages are shipped in one of the carriers shown below. Unless a specific method of shipment is specified by the customer (with possible additional costs), circuits will be shipped in the most practical carrier. Please contact your TI sales representative for the method that will best suit your particular needs.
"Small Outline" (D, DW)
Dual-in-Line (J, JD, JG, JT, N, NT, NW, P, W)

- A-Channel Plastic Tubing
- Tape and Reel
- Barnes Carrier (W only)


## D 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.


## D 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. Body dimensions do not include mold flash or protrusion.
B. Mold flash or protrusion shall not exceed $0,15(0.006)$.
C. Leads are within $0,25(0.010)$ radius of true position at maximum material dimension.
D. Lead tips to be planar within $\pm 0,051(0.002)$ exclusive of solder.

## DW 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.

## 20-PIN DW PACKAGE



NOTES: A. Body dimensions do not include mold flash or protrusion.
B. Mold flash or protrusion shall not exceed 0,15 (0.006).
C. Leads are within $0,25(0.010)$ radius of true position at maximum material dimension.
D. Lead tips to be planar within $\pm 0,051(0.002)$ exclusive of solder.

ALL LINEAR DIMENSIONS ARE IN MILLIMETERS AND PARENTHETICALLY IN INCHES

## DW 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. Body dimensions do not include mold flash or protrusion.
B. Mold flash or protrusion shall not exceed $0,15(0.006)$.
C. Leads are within $0,25(0.010)$ radius of true position at maximum material dimension.
D. Lead tips to be planar within $\pm 0,051(0.002)$ exclusive of solder.

ALL LINEAR DIMENSIONS ARE IN MILLIMETERS AND PARENTHETICALLY IN INCHES

## MECHANICAL DATA

FK ceramic chip carrier packages
Each of these hermetically sealed chip carrier packages has a three-layer ceramic base with a metal lid and braze seal. The packages are intended for surface mounting on solder lands on 1,27 ( 0.050 -inch) centers. terminals require no additional cleaning or processing when used in soldered assembly.

FK package terminal assignments conform to JEDEC Standards 1 and 2.


## FN plastic chip carrier package

Each of these chip carrier 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 packages are intended for surface mounting on solder lands on 1,27 (0.050) centers. Leads require no additional cleaning or processing when used in soldered assembly.

FN PLASTIC CHIP CARRIER PACKAGE
(28-terminal package used for illustration)



| JEDEC OUTLINE | NO. OF TERMINALS | A |  | B |  | C |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |
| MO 047AA | 20 | $\begin{gathered} 9.78 \\ (0385) \end{gathered}$ | $\begin{gathered} 10.03 \\ (0.395) \end{gathered}$ | $\begin{gathered} 8,89 \\ (0.350) \end{gathered}$ | $\begin{gathered} 9.04 \\ 10.3561 \end{gathered}$ | $\begin{gathered} 7.87 \\ (0.310) \end{gathered}$ | $\begin{gathered} 8.38 \\ (0.330) \end{gathered}$ |
| MO 047AB | 28 | $\begin{gathered} 12.32 \\ (0.485) \end{gathered}$ | $\begin{gathered} 12.57 \\ (0.495) \end{gathered}$ | $\begin{gathered} 11.43 \\ (0.450) \end{gathered}$ | $\begin{gathered} 11.58 \\ \{0.456\} \end{gathered}$ | $\begin{gathered} 10.41 \\ (0.410) \end{gathered}$ | $\begin{gathered} 10.92 \\ (0.430) \end{gathered}$ |
| MO 047AC | 44 | $\begin{gathered} 17.40 \\ (0.685) \end{gathered}$ | $\begin{gathered} 17.65 \\ (0.695) \end{gathered}$ | $\begin{gathered} 16.51 \\ (0.650) \end{gathered}$ | $\begin{gathered} 16.66 \\ (0.656) \end{gathered}$ | $\begin{gathered} 15,49 \\ (0.610) \end{gathered}$ | $\begin{gathered} 16.00 \\ (0.630) \end{gathered}$ |
| MO 047AE | 68 | $\begin{gathered} 25.02 \\ 10.985) \end{gathered}$ | $\begin{gathered} 25.27 \\ (0.995) \end{gathered}$ | $\begin{gathered} 24.13 \\ 10.950) \end{gathered}$ | $\begin{array}{r} 24.33 \\ 10.9561 \end{array}$ | $\begin{gathered} 23.11 \\ 10.9101 \end{gathered}$ | $\begin{gathered} 23.62 \\ (0930) \end{gathered}$ |

All dimensions and notes for the specified JEDEC outline apply.
NOTES: A. Centerline of center pin each side is within $0,10(0.004)$ of package centerline as determined by dimension B . B. Location of each pin is within $0,127(0.005)$ of true position with respect to center pin on each side.
C. The lead contact points are planar within $0,10(0.004)$.

ALL LINEAR DIMENSIONS ARE IN MILLIMETERS AND PARENTHETICALLY IN INCHES

## MECHANICAL DATA

## 68-pin GB pin grid array ceramic package

This is a hermetically sealed ceramic package with metal cap and gold-plated pins.


NOTE A: Pins are located within $0,127(0.005)$ radius of true position relative to each other at maximum material condition and within $0,254(0.010)$ radius relative to the center of the ceramic.

ALL LINEAR DIMENSIONS ARE IN MILLIME'TERS AND PARENTHETICALLY IN INCHES

## MECHANICAL DATA

## J ceramic packages (including JD, JT, and JW dual-in-line packages)

Each of these hermetically sealed dual-in-line packages consists of a ceramic base, ceramic cap, and a lead frame. Hermetic sealing is accomplished with glass. The packages are intended for insertion in mounting-hole rows on $7,62(0.300)$ or $15,24(0.600)$ centers. Once the leads are compressed and inserted sufficient tension is provided to secure the package in the board during soldering. Tin-plated ("brightdipped' ${ }^{\prime \prime}$ ) leads require no additional cleaning or processing when used in soldered assembly.

NOTE: For the 14-, 16-, and 20-pin packages, the letter J is used by itself since these packages are available only in the $7,62(0.300)$ row spacing. For the 24-pin packages, if no second letter or row spacing is specified, the package is assumed to have $15,24(0.600)$ row spacing.


NOTE A: Each pin centerline is located within $0,25(0.010)$ of its true longitudinal position.

## MECHANICAL DATA

## J ceramic dual-in-line packages (continued)



24-PIN JT CERAMIC, 0.300 -INCH ROW SPACING


ALL LINEAR DIMENSIONS ARE IN MILLIMETERS AND PARENTHETICALLY IN INCHES

NOTE A: Each pin centerline is located within $0,25(0.010)$ of its true longitudinal position.

## J ceramic dual-in-line packages (continued)



NOTE A: Each pin centerline is located within $0,25(0.010)$ of its true longitudinal position.

## MECHANICAL DATA

## J ceramic dual-in-line packages (continued)

This is a hermetically sealed ceramic package with a metal cap and side-brazed tin-plated leads.

## JD CERAMIC-SIDE BRAZE



| PINS (N) | 16 | 18 | 20 | 22 | 24 |
| :--- | :---: | :---: | :---: | :---: | :---: |
| DIM $+0.51(+0.020)$ | 7,62 | 7,62 | 7.62 | 7,62 | 7.62 |
| $-0,25(-0.010)$ | $(0.300)$ | $(0.300)$ | $(0.300)$ | $(0.300)$ | $(0.300)$ |
| B (MAX) | 20.57 | 23.11 | 25,65 | 27,94 | 30,86 |
|  | $(0.810)$ | $(0.910)$ | $(1.010)$ | $(1.100)$ | $(1.215)$ |
| C (NOM) | 7.37 | 7.37 | 7.37 | 9.91 | 7.37 |
|  | $(0.290)$ | $(0.290)$ | $(0.290)$ | $(0.390)$ | $(0.290)$ |


| DIM | 24 | 28 | 40 | 48 | 52 | 64 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| A $+0,51(+0.020)$ | 15,24 | 15,24 | 15,24 | 15,24 | 15,24 | 22,86 |
| $-0,25(-0.010)$ | $(0,600)$ | $(0.600)$ | $(0.600)$ | $(0.600)$ | $(0.600)$ | $(0.900)$ |
| B (MAX) | 31,8 | 36,8 | 52,1 | 62,2 | 67,3 | 82,6 |
|  | $(1.250)$ | $(1,450)$ | $(2.050)$ | $(2.450)$ | $(2.650)$ | $(3.250)$ |
| C (NOM) | 15,0 | 15,0 | 15,0 | 15,0 | 15,0 | 22,6 |
|  | $(0.590)$ | $(0.590)$ | $(0.590)$ | $(0.590)$ | $(0.590)$ | $(0.890)$ |

ALL LINEAR DIMENSIONS ARE IN MILLIMETERS AND PARENTHETICALLY IN INCHES

NOTE A: Each pin centerline is located within $0,25(0.010)$ of its true longitudinal position.

N plastic packages (including NT and NW dual-in-line packages)
Each of these dual-in-line packages consists of a circuit mounted on a lead frame and encapsulated within an electrically nonconductive plastic compound. The compound will withstand soidering temperature with no deformation, and circuit performance characteristics will remain stable when operated in high-humidity conditions. The packages are intended for insertion in mounting-hole rows on $7,62(0.300), 15,24(0.600)$, or $22,86(0.900)$ centers. 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.

NOTE: For all except 24-pin packages, the letter $N$ is used by itself since only the 24-pin package is available in more than one row-spacing. For the 24-pin package, the $7,62(0.300)$ version is designated NT; the $15,24(0.600)$ version is designated NW. If no second letter or row-spacing is specified, the package is assumed to have $15,24(0.600)$ row-spacing.



NOTES: A. Each pin centerline is located within $0,25(0.010)$ of its true longitudinal position.
B. For solder-dipped leads, this dimension applies from the lead tip to the standoff.

## MECHANICAL DATA

N plastic dual-in-line packages (continued)

## 20-PIN N PACKAGE



Parts may be supplied in accordance with the alternate side view at the option of TI. European-manufactured parts may have pin 1 as shown in view A. Alternate-side-view parts manufactured outside of the USA may have a maximum package length of 26,7 (1.050).

NOTES: A. Each pin centerline is located within $0,25(0.010)$ of its true longitudinal position.
B. For solder-dipped leads, this dimension applies from the lead tip to the standoff.
C. Parts may be supplied with a draft angle of $7^{\circ}$ typical at the option of TI .

## $\mathbf{N}$ plastic dual-in-line packages (continued)



NOTES: A. Each pin centerline is located within 0,25 (0.010) of its true longitudinal position.
B. For solder-dipped leads, this dimension applies from the lead tip to the standoff.

## MECHANICAL DATA

$\mathbf{N}$ plastic dual-in-line packages (continued)


NOTES: A. Each pin centerline is located within $0,25(0.010)$ of its true longitudinal position.
B. For solder-dipped leads, this dimension applies from the lead tip to the standoff.

## $\mathbf{N}$ plastic dual-in-line packages (continued)



48-PIN, 52-PIN, AND 64-PIN N PLASTIC


|  | PINS (N) | 48 | 52 |
| :--- | :---: | :---: | :---: |
| DIM |  | 64 |  |
| A $\pm 0,25(0.010)$ | $15,24(0.600)$ | $15,24(0.600)$ | $22,86(0.900)$ |
| B MAX | $62,2(2.45)$ | $67,3(2.65)$ | $81,3(3.20)$ |

ALL LINEAR DIMENSIONS ARE IN MILLIMETERS AND PARENTHETICALLY IN INCHES
NOTES: A. Each pin centerline is located within $0,25(0.010)$ of its true longitudinal position.

## TI Sales Offices

ALABAMA: Huntsville (205) 837-7530.
ARIZONA: Phoenix (602) 995-1007;
Tucson (602) 624-3276.
CALIFORNIA: Irvine (714) 660-8187;
Sacramento (916) 929-1521;
Sacramento (916) 929-1521:
San Diego (619) (408) 980-9000;
Santa Clara
Torrance (213) 217-7010;
Woodland Hills (818) 704-7759.
COLORADO: Aurora (303) 368-8000. CONNECTICUT: Wallingford (203) 269-0074.
FLORIDA: Ft. Lauderdale (305) 973-8502; Maitland (305) 660-4600; Tampa (813) 870-6420.
GEORGIA: Norcross (404) 662-7900.
ILLINOIS: Arlington Heights (312) 640-2925.
INDIANA: Ft. Wayne (219) 424-5174; Indianapolis (317) 248-8555.
IOWA: Cedar Rapids (319) 395-9550
MARYLAND: Baltimore (301) 944-8600
MASSACHUSETTS: Waltham (617) 895-9100.
MICHIGAN: Farmington Hills (313) 553 1500;
Grand Rapids (616) 957-4200.
MINNESOTA: Eden Prairie (612) 828-9300.
MISSOURI: Kansas City (816) 523-2500;
St. Louis (314) 569-7600.
NEW JERSEY: Iselin (201) 750-1050.
NEW MEXICO: Albuquerque (505) 345-2555.
NEW YORK: East Syracuse (315) 463-9291; Endicott (607) 754-3900; Melville (516) 454-6600;
Pittsford (716) 385-6770;
Poughkeepsie (914) 473-2900.
NORTH CAROLINA: Charlotte (704) 527-0930; Raleigh (919) 876-2725.
OHIO: Beachwood (216) 464-6100;
Dayton (513) 258-3877.
OREGON: Beaverton (503) 643-6758.
PENNSYLVANIA: Ft. Washington (215) 643-6450; Coraopolis (412) 771-8550.
PUERTO RICO: Hato Rey (809) $753-8700$
TEXAS: Austin (512) 250-7655;
Houston (713) 778-6592; Richardson (214) 680-5082 San Antonio (512) 496-1779.
UTAH: Murray (801) 266-8972.
VIRGINIA: Fairfax (703) 849-1400. WASHINGTON: Redmond (206) 881-3080. WISCONSIN: Brookfield (414) 785-7140.
CANADA: Nepean, Ontario (613) 726-1970;
Richmond Hill, Ontario (416) 884-918
St. Laurent, Quebec (514) 335-8392.

## TI Regional Technology Centers

CALIFORNIA: Irvine (714) 660.8140, Santa Clara (408) 748-2220. GEORGIA: Norcross (404) 662-7945. ILLINOIS: Arlington Heights (312) 640-2909. MASSACHUSETTS: Waltham (617) 895-9197. TEXAS: Richardson (214) 680-5066. CANADA: Nepean, Ontario (613) 726-1970

## Customer

## Response Center

TOLL FREE: (800) 232.3200
OUTSIDE USA: (214) 995.6611

## TI Distributors

TI AUTHORIZED DISTRIBUTORS IN USA

Arrow Electronics
Diplomat Electronics
General Radio Supply. Company
Graham Electronics
Kierulff Electronics
Marshall Industries
Milgray Electronics
Newark Electronics
Time Electronics
R.V. Weatherford Co.

Wyle Laboratories
Zeus Component, Inc. (Military)

## TI AUTHORIZED DISTRIBUTORS IN

 CANADAArrow Electronics Canada
Future Electronics
TI AUTHORIZED DISTRIBUTORS IN USA

- OBSOLETE PRODUCT ONLY-

Rochester Electronics, Inc.
Newburyport, Massachusetts
(617) 462.9332

ALABAMA: Arrow (205) 837-6955;
Kierulff (205) 883-6070; Marshall (205) 881.9235.
ARIZONA: Arrow (602) 968-4800;
Kierulff (602) 437-0750; Marshall (602) 968-6181; Wyle (602) 866-2888.
CALIFORNIA: Los Angeles/Orange County:
Arrow (818) 701.7500, (714) 838-5422;
Kierulff (213) 725-0325, (714) 731-5711, (714) 220-6300; Marshall (818) 999-5001, (818) 442-7204,
(714) 660-0951; R.V. Weatherford (714)' $966-1447$, (213) 849-3451, Wyle (213) 322-8100, (818) 880-9001; 714) 863-9953; Zeus (714) 632-6880;

Sacramento: Arrow (916) 925-7456;
Marshall (916) 635-9700; Wyle (916) 638-5282; San Diego: Arrow (619) 565 -4800
Kierulff (619) 278-2112; Marshall (619) 578-9600;
Nyle (619) 565-9171
San Francisco Bay Area: Arrow (408) 745-6600;
(415) 487-4600; Kierulff (408) $971-2600$

Marshall (408) 943-4600; Wyle (408) 727-2500 Zeus (408) 998-5121.
COLORADO: Arrow (303) 696-1111; Kierulff (303) 790-4444; Wyle (303)'457-9953.
CONNECTICUT: Arrow (203) 265-7741; Diplomat (203) 797-9674; Kierulff (203) 265-1115; Marshall (203) 265-3822; Milgray (203) 795-0714.
FLORIDA: Ft. Lauderdale: Arrow (305) 429-8200; Diplomat (305) 974-8700; Kierulff (305) 486-4004; Orlando: Arrow (305) 725-1480;
Marshall (305) 841-1878; Milgray (305) 647-5747
Zeus (305) $365-3000$; Tampa: Arrow (813) 576-899
Diplomat (813) 443-4514; Kierulff (813) 576-1966.

## Texas

InsTRUMENTS
Creating useful products and services for you.

GEORGIA: Arrow (404) 449-8252 Kierulff (404) 447-5252; Marshall (404) 923-5750.
ILLINOIS: Arrow (312) 397.3440;
Diplomat (312) 595-1000; Kierulff (312) 250-0500; Marshall (312) 490-0155; Newark (312) 784-5100
INDIANA: Indianapolis: Arrow (317) 243-9353; Graham (317) 634-8202; Marshall (317) 297-0483; Ft. Wayne: Graham (219) 423-3422.
IOWA: Arrow (319) 395-7230.
KANSAS: Kansas City: Arrow (913) 642.0592; Marshall (913) 492-3121.
MARYLAND: Arrow (301) 995-0003 Dipiomat (301) 995-1226; Kierulff (301) 636-5800; Diplomat (301) 995-1226; Kierulff (301) 636-5800;
Milgray (301) 995-6169; Marshall (301) 840.9450; Zeus (301) 997-1118.
MASSACHUSETTS: Arrow (617) $933-8130$
Diplomat (617) 935-6611; Kierulff (617) 667-8331; Marshall (617) 272-8200; Time (617) 532-6200; Zeus (617) 863-8800.
MICHIGAN: Detroit: Arrow (313) 971-8220; Marshall (313) 525-5850; Newark (313) 967.0600 ; Grand Rapids: Arrow (616) 243-0912.
MINNESOTA: Arrow (612) 830-1800; Kierulff (612) 941-7500; Marshali (612) 559-2211. MISSOURI: St. Louis: Arrow (314) 567-6888; Kierulff (314) 739-0855.
NEW HAMPSHIRE: Arrow (603) 668-6968.
NEW JERSEY: Arrow (201) 575-5300, (609) 596-8000;
Diplomat (201) 785-1830;
General Radio (609) 964-8560; Kierulff (201) 575-6750; (609) 235-1444; Marshall (201) 882-0320, (609) 234-9100; Milgray (609) 983-5010.

NEW MEXICO: Arrow (505) 243-4566.
NEW YORK: Long Island: Arrow (516) 231.1000 Diplomat (516) 454-6400; Marshall (516) 273-2053; Milgray (516) 420-9800; Zeus (914) 937-7400, Rochester: Arrow (716) 427-0300,
Marshall (716) 235.7620
Syracuse: Arrow (315) 652-1000;
Diplomat (315) 652-5000; Marshall (607) 798-1611.
NORTH CAROLINA: Arrow (919) 876-3132,
(919) 725-8711; Kierulff (919) 872-8410; Marshall (919) 878-9882.
OHIO: Cleveland: Arrow (216) 248-3990 Kierulff (216) 587-6558; Marshall (216) 248-1788 Columbus: Arrow (614) 885-8362 Dayton: Arrow (513) 435-5563; Graham (513) 435-8660; Kierulff (513) 439-0045; Marshall (513) 236-8088.

OKLAHOMA: Arrow (918) 665-7700; Kierulff (918) 252-7537.
OREGON: Arrow (503) 684-1690;
Kierulff (503) 641.9153; Wyle (503) 640-6000 Marshall (503) 644-5050.

PENNSYLVANIA: Arrow (412) 856-7000, (215) 928-1800; General Radio (215) 922-7037.

RHODE ISLAND: Arrow (401) 431-0980
TEXAS: Austin: Arrow (512) $835-4180$
Kierulff (512) 835-2090; Marshall (512) 837.1991
Wyle (512) 834-9957; Dallas: Arrow (214) 380-6464
Kierulff (214) 343-2400; Marshall (214) 233-5200
Wyle (214) 235-9953; Zeus (214) 783-7010;
Houston: Arrow (713) 530-4700;
Marshall (713) 789-6600;
Kierulff (713) 530-7030; Wyle (713) 879.9953.
UTAH: Diplomat (801) 486-4134;
Kierulff (801) 973-6913; Wyle (801) 974-9953.
WASHINGTON: Arrow (206) 643-4800;
Kierulff (206) 575-4420; Wyle (206) 453-8300; Marshall (206) 747.9100.
WISCONSIN: Arrow (414) 792-0150; Kierulff (414) 784-8160; Marshall (414) 797-8400.

CANADA: Calgary: Future (403) 235-5325;
Edmonton: Future (403) 438-2858;
Montreal: Arrow Canada (514) 735-5511;
Future (514) 694-7710;
Ottawa: Arrow Canada (613) 226-6903;
Future (613) 820-8313,
Quebec City: Arrow Canada (418) 687.4231
Toronto: Arrow Canada (416) 661 -0220;
Vancouver: Future (604) 294-1166.

## TI Worldwide Sales Offices

ALABAMA: Huntsville: 500 Wynn Drive, Suite 514, Huntisville, AL 35805, (205) 837.7530 .
ARIZONA: Phoenix: 8825 N. 23rd Ave., Phoenix, AZ 85021, (602) 995-1007.
CALIFORNIA: Irvine: 17891 Cartwright Rd., Irvine CA 92714, (714) 660-8187; Sacramento: 1900 Poin West Way, Suite 171, Sacramento, CA 95815 , (916) 929.1521; San Diego: 4333 View Ridge Ave. Suite B. San Diego, CA 92123, (619) 278-9601; Santa Clara: 5353 Betsy Ross Dr., Santa Clara, CA 95054, (408) 980-9000; Torrance: 690
Woodland Hills: 21220 Erwin St., Woodland Hills, CA 91367, (818) 704-7759.
COLORADO: Aurora: 1400 S . Potomac Ave., Suite 101, Aurora, CO 80012, (303) 368-8000.
CONNECTICUT: Wallingford: 9 Barnes Industrial Park Rd., Barnes Industrial Park, Wallingford, CT 06492, (203) 269-0074.
FLORIDA: Ft. Lauderdale: 2765 N.W. 62 nd St., Ft. Lauderdale, FL 33309, (305) 973-8502; Maitland: 2601 Maitland Center Parkway Maitland, FL 32751, (305) 660-4600;
Tampa: 5010 W . Kennedy Blvd, Suite 101,
Tampa, FL 33609 , (813) 870.6420.
GEORGIA: Norcross: 5515 Spalding Drive, Norcross, GA 30092, (404) 662-7900
ILLINOIS: Arlington Heights: 515 W. Algonquin, Arlington Heights, IL 60005, (312) 640-2925. INDIANA: Ft. Wayne: 2020 Inwood Dr., Ft. Wayne, IN 46815, (219) 424-5174;
Indianapolis: 2346 S. Lynhurst, Suite J-400, Indiánapolis, IN 46241, (317) 248-8555.
IOWA: Cedar Rapids: 373 Collins Rd. NE, Suite 200, Cedar Rapids, IA 52402, (319) 395-9550.

MARYLAND: Baltimore: 1 Rutherford PI., 7133 Rutherford Rd., Baltimore, MD 21207, (301) 944-8600.

MASSACHUSETTS: Waltham: 504 Totten Pond Rd., Waltham, MA 02154, (617) 895.9100.
MICHIGAN: Farmington Hills: 33737 W. 12 Mile Rd., Farmington Hills, Mi 48018, (313) 553-1500.
MINNESOTA: Eden Prairie: 11000 W. 78th St., Eden Prairie, MN 55344 (612) 828-9300.
MISSOURI: Kansas City: 8080 Ward Pkwy., Kansas
City, MO 64114, (816) 523-2500;
St. Louis: 11816 Borman Drive,. St. Louis,
MO 63146, (314) 569-7600.
NEW JERSEY: Iselin: 485E U.S. Route 1 South, Parkway Towers, Iselin, NJ 08830 (201) $750-1050$
NEW MEXICO: Albuquerque: 2820-D Broadbent Pkwy NE, Albuquerque, NM 87107, (505) 345-2555.
NEW YORK: East Syracuse: 6365 Collamer Dr., East Syracuse, NY 13057, (315) 463-9291;
Endicott: 112 Nanticoke Ave., P.O. Box 618, Endicott, NY 13760, (607) 754-3900; Melville: 1 Huntington Quadrangle, Suite 3C10, P.O. Box 2936, Melville, NY 11747, (516) 454-6600; Pittsford: 2851 Clover'St., Pittsford, NY 14534, (716) 385-6770; Poughkeepsie: 385 South Rd., Poughkeepsie, NY 12601, (914) 473-2900.
NORTH CAROLINA: Charlofte: 8 Woodlawn Green, Woodlawn Rd., Charlotte, NC 28210, (704) 527.0930; Raleigh: 2809 Highwoods Blvd., Suite 100, Raleigh

OHIO: Beachwood: 23408 Commerce Park Rd. Beachwood, OH 44122, (216) 464-6100;
Beachwo Kingsley BIdg., 4124 Linden Ave., Dayton,
Dayton:
OH 45432, (513) 258-3877.
OREGON: Beaverton: 6700 SW 105th St., Suite 110 , Beaverton, OR 97005, (503) 643-6758.

PENNSYLVANIA: Ft. Washington: 260 New York Dr.,
Ft. Washington, PA 19034, (215) 643-6450; Coraopolis: 420 Rouser Rd., 3 Airport Office Park Coraopolis, PA 15108, (412) 771-8550.
PUERTO RICO: Hato Rey: Mercantil Plaza Bidg., Suite 505, Hato Rey, PR 00919, (809) 753-8700.
TEXAS: Austin: P.O. Box 2909, Austin, TX 78769, 512) 250.7655; Richardson: 1001 E. Campbell Rd. Richardson, TX 75080
(214) 680-5082; Houston: 9100 Southwest Frwy., Suite 237, Houston, TX 77036, (713) 778-6592 San Antonio: 1000 Central Parkway South
San Antonio, TX 78232 , (512) 496-1779.

UTAH: Murray: 5201 South Green SE, Suite 200, Murray, UT 84107, (801) 266-8972.
VIRGINIA: Fairfax: 2750 Prosperity, Fairfax, VA 22031. (703) 849-1400.

WASHINGTON: Redmond: 5010 148th NE, Bldg B Suite 107, Redmond, WA 98052, (206) 881-3080.
WISCONSIN: Brookfield: 450 N. Sunny Slope, Suite 150, Brookfield, WI 53005, (414) 785-7140.

CANADA: Nepean: 301 Moodie Drive, Mailorn Center, Nepean, Ontario, Canada, K2H9C4, 613) 726:1970. Richmond Hili: 280 Centre St. E., Richmond Hill L4C1B1, Ontario, Canada 416) 884-9181; St. Laurent: Vilie St. Laurent Quebec, 9460 Trans Canada Hwy., St. Laurent, Quebec, Canada H4S1R7, (514) 335-8392.

ARGENTINA: Texas Instruments Argentina S.A.I.C.F.: Esmeralda 130, 15th Floor, 1035 Buenos Aires, Argentina, $1+394-3008$.
AUSTRALIA (\& NEW ZEALAND): Texas Instruments Australia Ltc.: 6-10 Talavera Rd., North Ryde (Sydney), New South Wales, Austratia 2113, $2+887-1122 ;$ Sth Foor, 418 St. Kilda Road,
Melbourne, Victoria, Australia $3004,3+267.4677$ 171 Philip Highway, Elizabeth, South Australia 5112, 171 Philip Higg
$8+255-2066$.

AUSTRIA: Texas Instruments Ges.m.b.H.. Industriestrabe B/16, A-2345 Brunn/Gebirge 2236-846210.
BELGIUM: Texas instruments N.V. Belgium S.A.: Mercure Centre, Raketstraat 100, Rue de la Fusee, 1130 Brussels, Belgium, 2/720.80.00.

BRAZIL: Texas Instruments Electronicos do Brasil Ltda.: Rua Paes Leme, 524-7 Andar Pinheiros, 05424 Sao Paúio, Brazil, 0815-6166.
DENMARK: Texas Instruments A/S, Mairelundvej 46E, DK-2730 Herlev, Denmark, 2-91 7400.
FINLAND: Texas instruments Finland OY: Teollisuuskatu 19D 00511 Helsinki 51, Finland, (90) 701-3133.
FRANCE: Texas Instruments France: Headquarters and Prod. Plant, BP 05, 06270 Villeneuve-Loubet, 93) 20-01-01; 'Paris Office, BP 67 8-10 Avenue Morane-SauInier, 78141 Velizy-Villacoublay (3) 946-97-12; Lyon Sales Office, L'Oree D'Écully, Batiment B, Chemin de la Forestiere, 69130 Ecully, 7) 833-04-40; Strasbourg Sales Office, Le Sebastopol 3, Quai Kieber, 67055 Strasbourg Cedex, (88) 22-12.66; Rennes, 23-25 Rue du Puits Mauger, 35100 Rennes, (99) 31-54-86; Toulouse Sales Office, Le Peripole-2, Chemin du Pigeonnier de la Cepiere, 31100 Toulouse, (61) 44-18-19; Marseilie Sales Office, Noilly Paradis-146 Rue Paradis, 13006 Marseille (91) 37-25-30.


## Texas <br> InsTRUMENTS

Creating useful products and services for you

GERMANY (Fed. Republic of Germany): Texas Instruments Deutschland GmbH: Haggertystrasse 1 D. 8050 Freising, $8161+80-4591$; Kurfuerstendamm 195/196, D-1000 Berlin 15, 30 + 882-7365; III, Hagen 43/Kibbelstrasse, .19, D-4300 Essen, 201-24250, Frankfurter Altee 6-8, D-6236 Eschborm $06196+8070 ;$ Hamburgerstrasse 11, D-2000 Hamburg
$76,040+220-1154$, Kircersherstrasse 2 D 3000 76, $040+220-1154$, Kirchhorsterstrasse 2, D-3000 Hannover $51,511+648021 ;$ Maybachstrabe 11,
D.7302 Ostfildern 2 .Nelingen $711+547001$. Mixikoring 19, D-2000 Hamburg $60,40+637+0061$; Moxikoring 19, Roonstrasse 16, D-5400 Koblenz, $261+35044$.
HONG KONG (+ PEOPLES REPUBLIC OF CHINA): Texas Instruments Asia Ltd., 8th Floor, Worid Shipping Ctr., Harbour City, 7 Canton Rd., Kowloon, Hong Kong, $3+722-1223$.
IRELAND: Texas Instruments (Ireland) Limited: Brewery Rd., Stillorgan, County Dublin, Eire, Brewery
1831311.
ITALY: Texas Instruments Semiconduttori Italia Spa: Viale Delle Scienze, 1, 02015 Cittaducale (Riéti), Italy, 746694.1 ; Via Salaria KM 24 (Palazzo Cosma), Monterotondo Scalo (Rome), Italy, 6+9003241; Viale Europa, 38-44, 20093 Cologno Monzese (Milano), 11 774545; Via J. Barozzi 6, 40100 Bologna, Italy, 51 117745
355851.
JAPAN: Texas Instruments Asia Ltd.: 4F Aoyama Fuji Bldg., 6-12, Kita Aoyama 3-Chome, Minato-ku, Tokyo, Japan 107, 3-498-2111; Osaka Branch, 5F, Nissho Iwai BIdg., 30 Imabashi 3-Chome, Higashi-ku, Osáka, Japan 541, 06-204-1881; Nagoya Branch, 7F Daini Toyota West Bidg., 10-27, Meieki 4-Chome, Nakamura-ku Nagoya, Japan
450, 52-583-8691.

KOREA: Texas Instruments Supply Co.: 3rd Floor, Samon Bldg., Yuksam-Dong, Gangnamiku, 135 Seoul, Korea, 2+462-8001.
MEXICO: Texas Instruments de Mexico S.A.: Mexico City, AV Reforma No. 450-10th Floor, Mexico, D.F., $06600,5+514 \cdot 3003$

MIDDLE EAST: Texas Instruments: No. 13, 1st Floor Mannai Bldg., Diplomatic Area, P.O. Box 26335, Manama Bahrain, Arabian Gulf, $973+274681$.
NETHERLANDS: Texas Instruments Holland B.V., P.O. Box 12995, (Bullewilk) 1100 CB Amsterdam, Zuid-Oost, Holland $20+5602911$.
NORWAY: Texas Instruments Norway A/S: PB106, Refstad 131, Oslo 1, Norway, (2) 155090.
PHILIPPINES: Texas Instruments Asia Ltd.: 14th Floor, Ba-Lepanto Bidg., 8747 Paseo de Roxas, Makati, Metro Manila, Philippines, $2+8188987$.
PORTUGAL: Texas Instruments Equipamento Electronico (Portugal), Lda.: Rua Eng. Frederico Uirich, 2650 Moreira Da Maia, 4470 Maia, Portugal, 2-948-1003.
SINGAPORE (+ INDIA, INDONESIA, MALAYSIA, THAILAND): Texas Instruments Asia Ltd.: 12 Lorong Bakar Batu, Unit 01-02, Kolam Ayer Industrial Estate, Republic of Singapore, 747-2255.
SPAIN: Texas instruments Espana, S.A.: C/Jose Lazaro Galdiano No. 6, Madrid 16, $1 / 458.14 .58$.

SWEDEN: Texas Instruments International Trade Corporation (Sverigefilialen): Box 39103, 10054 Stockholm, Sweden, 8-235480.
SWITZERLAND: Texas Instruments, inc., Reidstrasse 6, CH-8953 Dietikon (Zuerich) Switzerland 1.740 2220.

TAIWAN: Texas Instruments Supply Co.: Room 903, 205 Tun Hwan Rd.; 71 Sung-Kiang Road, Taipei, Taiwan, Republic of China, $2+521-9321$.
UNITED KINGDOM: Texas Instruments Limited: Manton Lane, Bedford, MK41 7PA, England, 0234 Stockport, SK4 2RT, England, $61+442.7162$.


[^0]:    *Current out of a terminal is given as a negative value.

[^1]:    *Current out of a terminal is given as a negative value.

[^2]:    - Denotes available technology.

[^3]:    - Denotes available technology.

[^4]:    - Denotes available technology.

[^5]:    - Denotes available technology.

    A Denotes " $A$ " suffix version available in the technology indicated.
    $B$ Denotes " $B$ " suffix version available in the technology indicated.

[^6]:    - Denotes available technology.

[^7]:    - Denotes available technology.

    A Denotes planned new products.
    A Denotes " $A$ " suffix version available in the technology indicated.
    $B$ Denotes " $B$ " suffix version available in the technology indicated.

[^8]:    * PAL is a registered trademark of Monolithic Memories Incorporated.

[^9]:    $\dagger^{\dagger}$ Each bit is shifted to the next more significant position.

[^10]:    NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

[^11]:    ${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
    ${ }^{\ddagger}$ All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    ${ }^{\S}$ Not more than one output should be shorted at a time, and duration of the short-circuit should not exceed one second.

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

[^13]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    $\ddagger$ Duration of the short circuit should not exceed one second.
    NOTE 3: ICC is measured with all inputs grounded and the output open.

[^14]:    ${ }^{\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.

[^15]:    ${ }^{\dagger}$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12.
    Pin numbers shown are for $\mathrm{D}, \mathrm{J}$, and N packages.

[^16]:    $\dagger$ This pin has no internal connection on 'LS612 and 'LS613

[^17]:    ${ }^{\dagger}$ See Table 3 for error description.
    ${ }^{\ddagger}$ See Table 5 for error location.

[^18]:    ${ }^{\dagger}$ These times ensure that corrected data is saved in the output data latch.
    $\ddagger$ These times ensure that the diagnostic data word is saved in the output data latch.

[^19]:    ${ }^{\dagger}$ Diagnostic data is a data word with an error in one bit location except when testing the $\overline{\mathrm{MERR}}$ error flag. In this case, the diagnostic data word will contain errors in two bit locations.

[^20]:    ${ }^{\dagger}$ Diagnostic data is a data word with an error in one bit location except when testing the $\overline{M E R R}$ error flag. In this case, the diagnostic data word will contain errors in two bit locations.

[^21]:    ${ }^{\dagger}$ These times ensure that corrected data is saved in the output data latch.
    ${ }^{\ddagger}$ These times ensure that the diagnostic data word is saved in the output data latch.

[^22]:    ${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, T_{\mathrm{A}}=25^{\circ} \mathrm{C}$

[^23]:    ${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
    SFor I/O ports, the parameters $I_{I H}$ and $I_{I L}$ include the off-state output current.
    IThe output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS.

[^24]:    ${ }^{\ddagger}$ All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$
    

[^25]:    ${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

[^26]:    $\dagger$ These parameters are measured with the internal output state of the storage register opposite to that of the bus input.

[^27]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
    $\ddagger_{\text {For }} / / O$ ports, the parameters $I_{I H}$ and $I_{\mathrm{IL}}$ include the off-state output current.
    §The output conditions have been chosen to produce a current that closely approximates one half of the true short-circuit output current, IOS

[^28]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

[^29]:    $t_{e n}=t_{P Z H}$ or tPZL
    $\mathrm{t}_{\mathrm{dis}}=\mathrm{tPHZ}$ or $\mathrm{t}_{\mathrm{PLZ}}$

[^30]:    ${ }^{\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.

[^31]:    ${ }^{\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.

[^32]:    ${ }^{\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.

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

    Pin numbers shown are for DW, JT, and NT packages.

[^34]:    Supply voltage, $\mathrm{V}_{\mathrm{CC}}$
    Input voltage
    Voltage applied to a disabled 3-state output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V
    Operating free-air temperature range: SN54ALS', SN54AS' . . . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
    SN74ALS', SN74AS'
    $.0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
    Storage temperature range
    $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$

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

[^36]:    ${ }^{\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.

[^37]:    ${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{C}}=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.

[^38]:    ${ }^{\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 current, IOS.

[^39]:    IThe positive transition of the MODE control will cause low-level data at the $A$ output Bus or stored in $Q$ to be invalid for 12 ns . NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

[^40]:    ${ }^{\ddagger}$ 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, IOS

[^41]:    $\ddagger$ In these cases the $\mathrm{P}>\mathrm{Q}$ output will follow the $\mathrm{P}>\mathrm{Q}$ input, and the $\mathrm{P}<\mathrm{Q}$ output will follow the $\mathrm{P}<\mathrm{Q}$ input.
    AG - arithmetically greater than

[^42]:    $\dagger$ For the SLA and SLAD instructions, OVR is set if signed arithmetic overflow or if the ALU result MSB XOR MSB- 1 equals one.

[^43]:    $\dagger$ Load resistor R1 $=100 \Omega$.
    NOTE 1: Load circuit and voltage waveforms are shown in Section 1.

[^44]:    $\dagger$ This parameter limits normal system performance.

[^45]:    $\dagger$ This parameter limits normal system performance.

[^46]:    $\dagger$ This parameter limits normal system performance.

[^47]:    ${ }^{\dagger}$ All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    ${ }^{\ddagger}$ For $I / O$ ports, the parameters $I_{I H}$ and $I_{I L}$ include the off-state current.
    SThe output conditions have been chosen to produce a current that closely approximates one-half the true short-circuit current, los.

[^48]:    $\dagger$ Load resistor R1 $=100 \Omega$.

[^49]:    § DB (during select instruction) through Y port.

[^50]:    $\dagger$ This parameter limits normal system performance.

[^51]:    $\dagger$ This parameter limits normal system performance.

[^52]:    ${ }^{\dagger}$ This parameter limits normal system performance.

[^53]:    $H=$ high level, $L=$ low level, $X=$ irrelevant.
    *Reset command is implemented by setting $\mathrm{S} 2-\mathrm{SO}=\mathrm{LLL}$.

[^54]:    ${ }^{\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 $I_{I H}$ and $I_{I L}$ include output current $I^{\circ} \mathrm{OZL}$ and $\mathrm{I}_{\mathrm{OZL}}$, respectively.
    §The output conditions have been chosen to produce a current that closely approximates one-half of the true short-circuit current, IOS.

[^55]:    ${ }^{\dagger}$ Decrementing Register/Counter A or B and sensing a zero.
    NOTE 3: The total clock period of clock high and clock low must not be less than clock cycle time. The minimum pulse durations specified are only for clock high or clock low, but not for both simultaneously.

[^56]:    ${ }^{\dagger}$ Decrementing Register/Counter $A$ or $B$ and sensing a zero.

[^57]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    ${ }^{\ddagger}$ For $\mathrm{I} / \mathrm{O}$ ports, the parameters $\mathrm{I}_{\mathrm{IH}}$ and $\mathrm{I}_{\mathrm{IL}}$ include the off-state current.
    §The output conditions have been chosen to produce a current that closely approximates one-half the true short-circuit current, IOS.

[^58]:    $\dagger$ Load resistor R1 $=100 \Omega$.

[^59]:    ${ }^{\dagger}$ This parameter limits normal system performance.

[^60]:    ${ }^{\dagger}$ This parameter limits normal system performance.

[^61]:    ${ }^{\dagger}$ This parameter limits normal system performance.

[^62]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    $\ddagger$ For $1 / O$ ports, the parameters $I_{I H}$ and $I_{I L}$ include the offstate output current. and CLK high; and Y15-YO, ZL, and ZN4 open.

[^63]:    ${ }^{\dagger}$ This parameter applies only to the circular mode with $S$ high and OP high.
    $\ddagger$ These parameters apply only to the normalization mode.
    ${ }^{\S}$ These parameters apply only to the 32 -bit mode $(16 \mathrm{~B} / \overline{32 \mathrm{~B}}=\mathrm{L})$.

[^64]:    ${ }^{\dagger}$ All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    ${ }^{\ddagger}$ For I/O ports, the parameters $I_{I H}$ and $I_{I L}$ include the off-state output current.
    §The output conditions have been chosen to produce a current that closely approximates one half the true short-circuit output current, IOS.

[^65]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    $\ddagger$ For $1 / O$ ports, the parameters $I_{H}$ and $I_{I}$ include the off-state output current.
    $\S$ The output conditions have been chosen to produce a current that closely approximates one-half the true short-circuit output current, los.

[^66]:    $\dagger$ The $48-\mathrm{mA}$ limit applies for the SN74ALS966-1 only and only if $\mathrm{V}_{\mathrm{CC}}$ is maintained between 4.75 V and 5.25 V .
    ${ }^{\ddagger}$ This setup time guarantees that $\overline{E N}$ will not false clock the data register.
    §This hold time ensures there will be no conflict on the input data bus.

[^67]:    $t_{\text {en }}=t_{P Z H}$ or $t_{P Z L}$

[^68]:    ${ }^{\dagger}$ All typical values are at $\mathrm{V}_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    $\ddagger$ Not more than one output should be tested at a time, and duration should not exceed 1 second.
    ${ }^{\S}$ The output conditions have been chosen to produce a current that closely approximates one half the true short-circuit output current, IOS.

[^69]:    ${ }^{\dagger}$ See Figures 10, 11, 12, and 13 for test circuit and switching waveforms.
    $\ddagger$ All typical values at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

[^70]:    ${ }^{\dagger}$ See Figures $10,11,12$, and 13 for test circuit and switching waveforms.

[^71]:    $\dagger$ This symbol is in accordance with ANSI/IEEE Std 91-1984.

[^72]:    NC-No internal connection

[^73]:    ${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
    ${ }^{\ddagger}$ All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    ${ }^{\S}$ Not more than one output should be shorted at a time and duration of the short circuit should not exceed one second.
    Additional information on these products can be obtained from the factory as it becomes available.

[^74]:    ${ }^{\dagger}$ For conditions shown as MIN or MAX, use appropriate value specificed under recommended operating conditions.
    $\ddagger$ All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$.
    § Not more than one output should be shorted at a time and duration of the short circuit should not exceed one second.

[^75]:    $\dagger$ This symbol is in accordance with ANSI/IEEE Std 91-1984 and IEC Publication 617-12
    Pin numbers shown are for DW, JT, and NT packages.

[^76]:    ${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
    $\ddagger$ All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    § Not more than one output should be shorted at a time and duration of the short circuit should not exceed one second.

    Additional information on these products can be obtained from the factory as it becomes available.

[^77]:    ${ }^{\dagger}$ For conditions shown as MIN or MAX, use appropriate value specified under recommended operating conditions.
    ${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
    
    I Not more than one output should be shorted at a time and duration of the short circuit should not exceed one second.

[^78]:    $\dagger$ Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is 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: Voltage values are with respect to network ground.

[^79]:    ${ }^{\ddagger}$ This parameter, IOZ, the high impedance-state output current, applies only for three-state outputs and transceiver I/O pins.
    §This is 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}}$.

[^80]:    *Integrated Schottky-Barrier-diode-clamped transistor is patented by Texas Instruments Incorporated, U.S. Patent Number 3,463,975.

[^81]:    *Current flowing out of a terminal is a negative value.

[^82]:    * Current flowing out of a terminal is a negative value.

[^83]:    *Current flowing out of a terminal is a negative value.

[^84]:    *These times are based on SN74ALS632A data.

[^85]:    Step 1: Choose a floating-point number system
    Step 2: Choose an algorithm for approximating $\sin (x)$
    Step 3: Make 'AS888 register assignments
    Step 4: Substitute registers for variables in the algorithm
    Step 5: Decompose steps of the algorithm into simple operations
    Step 6: Translate into 'AS888/890 operations; identify subroutines
    Step 7: Translate subroutines into 'AS888/890 operations
    Step 8: Evaluate tradeoffs and block diagram the hardware
    Step 9: Define microinstruction fields during detailed hardware design
    Step 10: Assemble the microprogram

