

DECEMBER 1977

TExas Instruments

## The Bipolar Microcomputer Components Data Book <br> for <br> Design Engineers

DECEMBER 1977

<br>Texas Instruments<br>INCORPORATED

## IMPORTANT NOTICES

Texas Instruments reserves the right to make changes at any time in order to improve design and to supply the best product possible.

TI cannot assume any responsibility for any circuits shown or represent that they are free from patent infringement.

Second Printing, December 1977

Copyright © 1977
Texas Instruments Incorporated

# THE BIPOLAR MICROCOMPUTER COMPONENTS DATA BOOK 

## TI worldwide sales offices



## THE BIPOLAR MICROCOMPUTER COMPONENTS DATA BOOK

This data book describes a series of high complexity bipolar digital building blocks designed specifically for implementing high performance computer or controller systems. The series offers a system designer the maximum flexibility for achieving cost-effective hardware designs from dedicated, highly specialized unique systems with tailored instructions to generalpurpose computers capable of emulating existing machine instructions, or programs, without loss of software investment.

In addition to a choice between the high-performance Schottky ${ }^{\dagger}$ TTL 4-bit slice processor element, the unique performance flexibility of an 12 L 4-bit slice processor element, or a 16 -bit computer central processing unit (CPU), the system designer can pick from a full family of Schottky TTL memories (RAMs, PROMs and ROMs), and state-of-the-art support functions needed to meet all control and interface requirements.

The SN74S481, with a typical clock cycle time of 90 ns , and the SN54LS481/SN74LS481 at 120 ns , are the industry's highest complexity Schottky TTL processor elements, and the only bipolar micro/macroprogrammable elements featuring automatically sequenced iterative multiply and divide and cyclical-redundancy algorithms.

The SBP0400A and the SBP0401A, integrated injection logic ( 12 L ) bit slices with complete TTL/MOS compatibility, can operate at a constant speed-power product over a wide range of supply current therein offering an unmatched level of performance flexibility.

The SBP 9900 microprocessor, a ruggedized monthlithic parallel 16 -bit ( ${ }^{2} \mathrm{~L}$ ) central processing unit (CPU), combines an advanced memory-to-memory architecture, a powerful minicomputer instruction set, user-programmable speed/power performance with the simplicity of a single power supply and static logic with a single phase clock to thrust its capabilities beyond those of existing microprocessors.

The family of high-performance Schottky TTL memories offers a wide variety of organizations providing efficient solutions for virtually any size microcontrol or program memory.

System control is simplified to a very low package count with the expandable SN54S/74S482 4-bit slice controller performing next-address generation functions coupled with system status decoding performed by the industry's most versatile field-programmable logic arrays.

A number of advanced high-complexity $1 / O$ and interface circuits have been added to the series. Most of these $1 / O$ and interface functions as well as a number of the other processor support functions are offered in space saving 20 -pin packages which reduce package count and enhance system density.

Although this volume offers design and specification data only for bipolar computer components, complete technical data for any TI semiconductor/component product are available from your nearest Tl field sales office, local authorized TI distributor, or by writing direct to: Marketing and Information Services, Texas Instruments Incorporated, P. O. Box 5012, MS 308, Dallas, Texas 75222.

We sincerely hope you will find the Bipolar Microcomputer Components Data Book a meaningful addition to your technical library.

[^0]NOTICE
Some products described in this document are in the developmental stage, and Texas Instruments reserves the right to change these specifications in any manner, without notice.

| TYPE NUMBERS | SECTION | PAGE | TYPE NUMBERS | SECTION | PAGE |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SBP 0400AM, SBP 0400AC | . 2 | 1 | SN74S314 | . . 4 | 27 |
| SBP 0401AM, SBP 0401AC | . 2 | 1 | SN74LS315 | . . 4 | 27 |
| SBP 8316M, SBP 8316C | . 4 | 16 | SN74S330. | . . . 5 | 13 |
| SBP 9818M, SBP 9818C | . 4 | 16 | SN74S331 | . . . 5 | 13 |
| SBP 9900M, SBP 9900E. | . 3 | 1 | SN54S370, SN74S370. | . . . 4 | 9 |
| SN5488A, SN7488A | . . 4 | 9 | SN54S371, SN74S371. | . . 4 | 9 |
| SN54187, SN74187 | . 4 | 9 | SN54S373, SN74S373 | . 5 | 26 |
| SN54S188, SN74S188. | . . 4 | 1 | SN54S374, SN74S374 | . 5 | 26 |
| SN54S189, SN74S189. | . 4 | 20 | SN54S387, SN74S387 | . . . 4 | 1 |
| SN74S201 | . 4 | 24 | SN54S412, SN74S412 | . 5 | 30 |
| SN74LS207 | . 4 | 33 | SN74S428. | . . 5 | 35 |
| SN74S207 | . 4 | 33 | SN74S438 | . 5 | 35 |
| SN74LS208 | . 4 | 33 | SN54S450, SN74S450 | . . 4 | 7 |
| SN74S208 | . 4 | 33 | SN54S451, SN74S451 | . . 4 | 7 |
| SN74LS214 | . 4 | 27 | SN54S470, SN74S470 | . . 4 | 1 |
| SN74S214 | . . 4 | 27 | SN54S471, SN74S471 | . . 4 | 1 |
| SN74LS215 | . 4 | 27 | SN54S472, SN74S472 | . . . 4 | 1 |
| SN74S225 | . 4 | 39 | SN54S473, SN74S473 | . . 4 | 1 |
| SN54S226, SN74S226 | . 5 | 1 | SN54S474, SN74S474 | . 4 | 1 |
| SN54S240, SN74S240. | . . . 5 | 5 | SN54S475, SN74S475 | . . 4 | 1 |
| SN54S241, SN74S241 | . . 5 | 5 | SN54S476, SN74S476 | . . 4 | 7 |
| SN54S270, SN74S270. | . . . 4 | 9 | SN54S477, SN74S477 | . . . 4 | 7 |
| SN54S271, SN74S271. | . . 4 | 9 | SN54S478, SN74S478. | . . . 4 | 7 |
| SN54S287, SN74S287. | . . 4 | 1 | SN54S479, SN74S479 | . . 4 | 7 |
| SN54S288, SN74S288. | . . 4 | 1 | SN54LS481, SN74LS481 | . . 1 | 1 |
| SN54S289, SN74S289. | . . 4 | 20 | SN74S481 | . . 1 | 1 |
| SN54S299, SN74S299. | . . . 5 | 9 | SN54S482, SN74S482 | . . 5 | 41 |
| SN74S301. | . . 4 | 24 | SN54S2708, SN74S2708 | . . . 4 | 7 |
| SN74LS314 | . . 4 | 27 | SN54S3708, SN74S3708 | . . . 4 | 7 |

## INTRODUCTION

This glossary consists of two parts: (1) general concepts for digital circuits including types of bipolar memories, and (2) operating conditions and characteristics (including letter symbols). The terms, symbols, abbreviations, and definitions used with memory integrated circuits have not, as yet, been standardized. All are currently under consideration by the EIA/JEDEC (Electronic Industries Association) and the IEC (International Electrotechnical Commission). The following are as consistent with the past and future work of these organizations as is possible to anticipate at this time.

## PART I - GENERAL CONCEPTS INCLUDING TYPES OF BIPOLAR MEMORIES

## Chip-Enable Input

A control input that when active permits operation of the integrated circuit for input, internal transfer, manipulation, refreshing, and/or output of data and when inactive causes the integrated circuit to be in a reduced-power standby mode.
NOTE: See "chip-select input".

## Chip-Select Input

A gating input that when inactive prevents input or output of data to or from an integrated circuit. NOTE: See "chip-enable input".

## Dynamic (Read/Write) Memory

A read/write memory in which the cells require the repetitive application of control signals in order to retain stored data.
NOTES: 1. The words "read/write" may be omitted from the term when no misunderstanding will result.
2. Such repetitive application of the control signals is normally called a refresh operation.
3. A dynamic memory may use static addressing or sensing circuits.
4. This definition applies whether the control signals are generated inside or outside the integrated circuit.

## First-In First-Out (FIFO) Memory

A memory from which data bytes or words can be read in the same order, but not necessarily at the same rate, as that of the data entry.

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

## Mask-Programmed Read-Only Memory

A read-only memory in which the data content of each cell is determined during manufacture by the use of a mask, the data content thereafter being unalterable.

## GLOSSARY <br> TTL TERMS AND DEFINITIONS

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

## Memory Cell

The smallest subdivision of a memory into which a unit of data has been or can be entered, in which it is or can be stored, and from which it can be retrieved.

## Memory Integrated Circuit

An integrated circuit consisting of memory cells and usually including associated circuits such as those for address selection, amplifiers, etc.

## Output-Enable Input

A gating input that when active permits the integrated circuit to output data and when inactive causes the integrated circuit output(s) to be at a high impedance (off).

## Programmable Read-Only Memory (PROM)

A read-only memory that after being manufactured can have the data content of each memory cell altered once only.

## Random-Access Memory (RAM)

A memory that permits access to any of its address locations in any desired sequence with similar access time for each location.
NOTE: The term RAM, as commonly used, denotes a read/write memory.

## Read-Only Memory (ROM)

A memory in which the contents are not intended to be altered during normal operation.
NOTE: Unless otherwise qualified, the term "read-only memory" implies that the content is unalterable and defined by construction.

## Read/Write Memory

A memory in which each cell may be selected by applying appropriate electronic input signals and the stored data may be either (a) sensed at appropriate output terminals, or (b) changed in response to other similar electronic input signals.

## Small-Scale Integration, SSI

Integrated circuits of less complexity than medium-scale integration (MSI).

## Very-Large-Scale Integration, VLSI

A concept whereby a complete system function is fabricated as a single microcircuit. In this context, a system, whether digital or linear, is considered to be one that contains 1000 or more gates or circuitry of similar complexity.

## Volatile Memory

A memory the data content of which is lost when power is removed.

## PART II - OPERATING CONDITIONS AND CHARACTERISTICS (INCLUDING LETTER SYMBOLS)

The symbols for quantities involving time use upper and lower case letters according to the following historically evolved principles:
a. Time itself, is always represented by a lower case $t$.
b. Subscripts are lower case when one or more letters represent single words, e.g., d for delay, su for setup, rd for read, wr for write.
c. Multiple subscripts are upper case when each letter stands for a different word, e.g., SR for sense recovery and PLH for propagation delay from low to high.

## Access Time (of a memory)

The time between the application of a specified input pulse during a read cycle and the availability of valid data signals at an output.

Example symbology:

| $\mathrm{t}_{\mathrm{a}(\mathrm{ad})}$ | Access time from address |
| :--- | :--- |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{E})$ | Access time from chip enable |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{S})$ | Access time from chip select |

## Clock Frequency

Maximum clock frequency, $f_{\text {max }}$
The highest rate at which the clock input of a bistable circuit can be driven through its required sequence while maintaining stable transistions of logic level at the output with input conditions established that should cause changes of output logic level in accordance with the specification.

## Current

High-level input current, $I_{1 H}$
The current into* an input when a high-level voltage is applied to that input.
High-level output current, I OH
The current into* an output with input conditions applied that according to the product specification will establish a high level at the output.

## Low-level input current, IIL

The current into* an input when a low-level voltage is applied to that input.

## Low-level output current, IOL

The current into* an output with input conditions applied that according to the product specification will establish a low level at the output.

## Off-state output current, IO(off)

The current flowing into* an output with 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.

[^1]Off-state (high-impedance-state) output current (of a three-state output), IOZ
The current into* an output having three-state capability with input conditions applied that according to the product specification will establish the high-impedance state at the output.

## Short-circuit output current, IOS

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

Supply current, ICC
The current into* the VCC supply terminal of an integrated circuit.

## Cycle Time

Read cycle time, $\mathbf{t}_{\mathbf{c}}(\mathrm{rd})$ (see note)
The time interval between the start and end of a read cycle.

## Read-write cycle time, $\mathrm{t}_{\mathbf{c}}(\mathrm{rd}, \mathrm{wr})$ (see note)

The time interval between the start of a cycle in which the memory is read and new data are entered, and the end of that cycle.

Write cycle time, $\mathrm{t}_{\mathbf{c}}(\mathrm{wr})$ (see note)
The time interval between the start and end of a write cycle.
NOTE: The read, read-write, or write cycle time is the actual interval between two impulses and may be insufficient for the completion of operations within the memory. A minimum value is specified that is the shortest time in which the memory will perform its read and/or write function correctly.

## Hold Time

Hold time, $t_{h}$
The 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 between two events and may be insufficient to accomplish the intended result. A minimum value is specified that is the shortest interval for which correct operation of the logic element 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 data and the active transition) for which correct operation of the logic element is guaranteed.

## Output Enable and Disable Time

Output enable time (of a three-state output) to high level, tPZH (or low level, tPZL )
The propagation delay 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 (or low) level.

Output enable time (of a three-state output) to high or low level, tPZX
The propagation delay 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 either of the defined active levels (high or low).

Output disable time (of a three-state output) from high level, tPHZ (or low level, tPLZ)
The propagation delay time between the specified reference points on the input and output voltage waveforms with the three-state output changing from the defined high (or low) level to a high-impedance (off) state.
*Current out of a terminal is given as a negative value.

## GLOSSARY

## TTL TERMS AND DEFINITIONS

Output disable time (of a three-state output) from high or low level, tPXZ
The propagation delay time between the specified reference points on the input and output voltage waveforms with the three-state output changing from either of the defined active levels (high or low) to a high-impedance (off) state.

## Propagation Time

Propagation delay time, tPD
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.

Propagation delay time, low-to-high-level output, tPL.H
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.

Propagation delay time, high-to-low-level output, tPHL
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.

## Pulse Width

## Pulse width, $\mathrm{t}_{\mathrm{w}}$

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

| $t_{w}(c i r)$ | Clear pulse width |
| :--- | :--- |
| $t_{w}(w r)$ | Write pulse width |

## Recovery Time

Sense Recovery time, tsR
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.

## Release Time

## Release time, $\mathrm{t}_{\text {release }}$

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.

## Setup Time

## Setup time, $\mathrm{t}_{\mathrm{su}}$

The time interval between the application of a signal that is maintained at a specified input terminal and a consecutive active transition at another specified input terminal.
NOTES: 1. The setup time is the actual time between two events and may be insufficient to accomplish the setup. A minimum value is specified that is the shortest interval for which correct operation of the logic element 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 logic element is guaranteed.

# GLOSSARY TTL TERMS AND DEFINITIONS 

## Transition Time

Transition time, low-to-high-level, tTLH
The time between a specified low-leve! voltage and a specified high-level voltage on a waveform that is changing from the defined low level to the defined high level.

Transition time, high-to-low-level, tTHL
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.

## Voltage

High-level input voltage, $\mathrm{V}_{1} \mathrm{H}$
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.

## High-level output voltage, $\mathrm{V}_{\mathrm{OH}}$

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

Input clamp voltage, $V_{I K}$
An input voltage in a region of relatively low differential resistance that serves to limit the input voltage swing.
Low-level input voltage, VIL
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.

## Low-level output voltage, $\mathrm{V}_{\mathrm{OL}}$

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

Negative-going threshold voltage, $\mathrm{V}_{\mathrm{T}}$ -
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}+\text {. }}$

## Off-state output voltage, $\mathrm{V}_{\mathrm{O}}$ (off)

The voltage at an output terminal with input conditions applied that according to the product 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.

On-state output voltage, $\mathrm{V}_{\mathrm{O}}(\mathrm{on})$
The voltage at an output terminal 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.
Positive-going threshold voltage, $\mathrm{V}_{\mathrm{T}+}$
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}}$..

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 |
| $\curvearrowleft$ | $=$ value/level is re-entered |
| X | $=$ irrelevant (any input, including transitions) |
| a. h | $=$ the level of steady-state inputs at inputs A through $H$ respectively |
| $\mathrm{Q}_{0}$ | $=$ level of Q before the indicated steady-state input conditions were established |
| $\overline{\mathrm{Q}}_{0}$ | $=$ complement of $\mathrm{Q}_{0}$ or level of $\overline{\mathrm{Q}}$ before the indicated steady-state input conditions were established |
| $\mathrm{Q}_{\mathrm{n}}$ | $=$ level of Q before the most recent active transition indicated by $\downarrow$ or $\uparrow$ |
| $\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 |



NOVEMBER 1976
REVISED DECEMBER 1977

Information contained in this publication is believed to be accurate and reliable. However, responsibility is assumed neither for its use nor for any infringement of patents or rights of others that may result from its use. No license is granted by implication or otherwise under any patent or patent right of Texas Instruments or others.

## TABLE OF CONTENTS

1. INTRODUCTION
1.1 Architectural Features ..... 1
1.2 Operational Features ..... 1
1.3 Mechanical Features ..... 1
2. DETAILED FUNCTIONAL DESCRIPTIONS
2.1 Micro-Decoding Logic Array ..... 4
2.2 Relative Position Control (POS) ..... 4
2.3 Clock ..... 5
2.4 Latched Data Input Ports ..... 5
2.5 A and B Operand Sources ..... 6
2.6 Arithmetic/Logic Unit (ALU) ..... 8
2.7 ALU Magnitude and Carry Functions ..... 9
2.7.1 Equal (EQ, See Figure 5) ..... 9
2.7.2 Logically-Greater Than (LG, See Figure 6) ..... 9
2.7.3 Arithmetically-Greater-Than (AG, See Figure 7) ..... 10
2.8 Operand Overflow ..... 11
2.9 Sum' Bus Multiplexer ..... 12
2.10 B-Input/Output Control ..... 13
2.11 Working Register ..... 14
2.12 Working Register Multiplexer (WR MUX) ..... 14
2.13 Extended Working Register ..... 15
2.14 Extended Working Register Multiplexer (XWR MUX) ..... 15
2.14.1 $\Sigma$-Bus, WR, XWR MSB Shift Transfer Multiplexers ..... 16
2.14.2 WRLFT, XWRLFT Multiplexers ..... 16
2.14.3 WRLFT', XWRLFT' Multiplexers ..... 16
2.14.4 WR, XWR LSB Shift Transfer Multiplexers ..... 16
2.14.5 WRRT Multiplexer, XWRRT Buffer ..... 17
2.14.6 WRRT', XWRRT' Multiplexers ..... 17
2.15 Shift Functions ..... 20
2.15.1 Circulate (Shift) Functions (Microprogrammable) ..... 20
2.15.2 Arithmetic Shift Functions (Microprogrammable) ..... 20
2.15.3 Logical Shift Functions (Microprogrammable) ..... 22
2.16 Data-Out Port Multiplexer (DO MUX) ..... 22
2.17 Memory and Program Counters ..... 22
2.18 Address-Out Port Multiplexer (AO MUX) ..... 26
2.19 Expanding the Word Length ..... 27
3. OPERATIONAL DESCRIPTIONS
3.1 Micro/Macro-Operations ..... 27
3.2 Operation Form I - Add/Subtract $\rightarrow$ Register ..... 30
3.3 Operation Form II - Add/Subtract with Double-Precision Shift ..... 32
3.4 Operation Form III - Add with Single-Precision Shift ..... 32
3.5 Operation Form IV - Al Shifted $\rightarrow \Sigma^{\prime}$ Bus ..... 33
3.6 Operation Form V - Single-Length Shift ..... 34
3.7 Operation Form VI - Double-Precision Shifts ..... 35
3.8 Operation Form VII - Compare ( $\mathrm{A}: \mathrm{B}$ or $\mathrm{B}: \mathrm{A}$ ) ..... 35
3.9 Operation Form VIII - Logical Functions ..... 35
3.9.1 NOR/AND Logical Operations ..... 37

## TABLE OF CONTENTS (Continued)

3.9.2 OR/NAND Logical Operations ..... 38
3.9.3 Exclusive-OR/Exclusive-NOR Logical Operations ..... 39
3.10 Operation Form IX ..... 40
3.11 Operation Form X - Cyclic Redundancy Character Accumulation ..... 40
3.12 Operation Form XI - Signed Integer Divide ..... 41
3.13 Operation Form XII - Unsigned Divide ..... 41
3.14 Operation Form XIII - Unsigned Multiply ..... 41
3.15 Operation Form XIV - Signed Integer Multiply ..... 46
4. SPECIFICATIONS ..... 48
MECHANICAL DATA ..... Section 6

## LIST OF ILLUSTRATIONS

Figure 1 Functional Block Diagram ..... 3
Figure 2 Clock Cycle ..... 5
Figure 3 Input Latches Setup/Hold Times ..... 6
Figure 4 ALU Operand Sources ..... 7
Figure 5 Equal Output ..... 9
Figure 6 MSP Logically-Greater-Than (LG) Output ..... 10
Figure 7 MSP Arithmetically-Greater-Than (AG) Output ..... 11
Figure 8 Sum Bus Multiplexer ..... 12
Figure 9 B-Input/Output Control ..... 13
Figure 10 Working Register (WR) and WR Multiplexer ..... 14
Figure 11 Extended Working Register (XWR) and XWR Multiplexer ..... 15
Figure 12 Sum-Bus, WR, XWR MSB Shift Transfer Multiplexers ..... 17
Figure 13 Sum-Bus, WR, XWR LSB Shift Transfer Multiplexers ..... 19
Figure 14 Circulate Functions ..... 21
Figure 15 Arithmetic Shift Functions ..... 23
Figure 16 Logical Shift Functions ..... 24
Figure 17 Data-Out Port Multiplexer (DO MUX) ..... 25
Figure 18 Program and Memory Counter Functions ..... 26
Figure 19 Address-Out Port Multiplexer (AO MUX) ..... 27
Figure 20 Typical 16-Bit Processor ..... 28
Figure 21 Form 1 - Arithmetic Operations: A Plus B Plus ALUCIN $\rightarrow\left\{\begin{array}{c}\Sigma^{\prime} \text { Bus } \\ \text { Register }\end{array}\right\}$ ..... 30
Figure 22 'S481 Operation with Single-Port Register File ..... 31
Figure 23 Form II - Arithmetic with Double-Precision Shift ..... 32
Figure 24 Form III - Arithmetic With Single-Precision Shift ..... 33
Figure 25 Form IV - AI Shifted $\rightarrow \Sigma^{\prime}$ Bus ..... 34
Figure 26 Form $V:\left\{\begin{array}{c}W R \\ X W R\end{array}\right\}$ Shifted $\rightarrow\left\{\begin{array}{c}W R \\ X W R\end{array}\right\}$ ..... 34
Figure 27 Form VI - Double-Precision Shifts:(WR, XWR)Shifted $\rightarrow(W R, X W R)$ ..... 35

## LIST OF ILLUSTRATIONS (Continued)

Figure 28 Form VII-Compare: $\left\{\begin{array}{l}A: B \\ B: A\end{array}\right\}$ ..... 36
Figure 29 Form VIII - Logical Operations: A $\left\{\begin{array}{c}\text { NOR } \\ \text { OR } \\ \times-O R\end{array}\right\} B \rightarrow$ Register ..... 36
Figure 30 Form VIIIA - NOR/AND Logical Operations ..... 37
Figure 31 Form VIIIB - OR/NAND Logical Operations ..... 38
Figure 32 Form VIIIC - EXCLUSIVE-OR/EXCLUSIVE-NOR Operations ..... 39
Figure 33 Form IX - No Operation: Zero $\rightarrow \Sigma^{\prime}$ Bus ..... 40
Figure 34 Cyclic Redundancy Character Accumulation ..... 40
Figure 35 Form XI - Signed Integer Divide ..... 42,43
Figure 36 Form XII - Unsigned Divide ..... 44,45
Figure 37 Form XIII - Unsigned Multiply ..... 46
Figure 38 Form XIV - Signed Integer Multiply ..... 47
Figure 39 Pin Assignments ..... 49
Figure 40 Switching Times - Voltage Waveforms ..... 50
LIST OF TABLES
Table 1 Functional Descriptions ..... 2,3
Table 2 MSP OP8 and OP9 Iterative Function Summary ..... 4
Table 3 Position Control Functions ..... 4
Table 4 Dual-Function Logic I/O Pins ..... 5
Table 5 'S481 ALU and Logic Functions ..... 8
Table 6 Extended ALU Functions of 'S481 ..... 8
Table 7 MSP Logically-Greater-Than (LG) Output ..... 10
Table 8 ALU Carry and MSP Arithmetically-Greater-Than (AG) Outputs ..... 11
Table 9 MSP Overflow (OV) Output ..... 12
Table 10 B-Input/Output Control ..... 13
Table 11 Working Register Bit Transfers to WRLFT/WRRT ..... 18
Table 12 Sum-Bus Bit Transfers to WRLFT/WRRT ..... 18
Table 13 Extended Working Register Bit Transfers to XWRLFT/XWRRT ..... 18
Table 14 Sum-Bus Bit Transfers to WRLFT (MSP) ..... 19
Table 15 Microprogrammable Shift Functions ..... 20
Table 16 Data-Out Port Control ..... 25
Table 17 Address-Out Port Control ..... 26
Table 18 Operation Form, Command Format, and Test Outputs ..... 29
Table 19 Recommended Operating Conditions ..... 48
Table 20 Electrical Characteristics ..... 48
Table 21 Switching Characteristics ..... 49

## 1. INTRODUCTION

These Schottky TTL 4-bit expandable parallel binary micro/macroprogrammable processor element building blocks are designed specifically for implementing high-performance digital computers/controllers. With the ability to efficiently emulate existing systems, they can be used to upgrade hardware performance with full compatibility to protect software investments.

Two performance ranges are available:
a. The SN74S481, Schottky TTL performs typically at a clock cycle time of 90 nanoseconds at 345 milliamperes of supply current.
b. The SN54LS/74LS481, low-power Schottky TTL performs typically at a clock cycle time of $\mathbf{1 2 0}$ nanoseconds at $\mathbf{2 2 0}$ milliamperes of supply current.

### 1.1 ARCHITECTURAL FEATURES

Designed with full parallel dual input/output ports, the memory-to-memory architecture provides a new dimension in interrupt processing or program context switching flexibilities. Static bipolar logic performs each microinstruction within a single clock cycle.

Primary among the architectural features are:

- Microprogrammable, bit-slice design is expandable in 4-bit multiples
- Full parallel dual input/output ports for use in advanced memory-to-memory architecture
- Full-function ALU with carry look-ahead, magnitude, and overflow decision capabilities
- Double-length accumulator with full shifting capability and sign-bit handling
- Dual memory address generators on-chip.


### 1.2 OPERATIONAL FEATURES

The functional capabilities, characterized by the 24,780 unique operations, coupled with the macroprogrammable multiply and divide algorithms, make these processor elements particularly attractive for implementing advanced high performance computers and controllers.

In addition to the full parallel data bus structure, the 'S481 architecture also features asynchronous access to data routing and counter updating controls which, when combined with the most versatile instruction set available (see operational description) maximizes flexibility, efficiency, and performance. Simultaneous compound operations in the form of an ALU function with shift, plus destination selection with address/iteration updating, plus address and present data to memory can be accomplished in a single microcyle. Some other operational features are:

- Simultaneous one-clock compound operations, with status, can reduce microcycles and improve throughput
- Pre-programmed CRG and double-precision multiply/divide algorithms
- Double length accumulator with full bidirectional single/double precision arithmetic/logical/circulate shift capabilities include sign protection
- Full micro-operational control is provided for programming: address updating, data and address source selection, and direct transfer of data to working register or working memory
- Relative position control defines bit-slice rank and sign handling in N -bit applications.


### 1.3 MECHANICAL FEATURES

These processor elements are supplied in either a high-density quad-in-line ceramic package or a plastic dual-in-line package. The high-density 48 -pin ceramic package has quad pin rows formed on 600 - and 800 -mil centers. Within each of the four rows, the pin spacing is 100 mils, center-to-center. The plastic dual-in-line package has standard $100-\mathrm{mil}$ spacing on 600 -mil centers. Outline drawings are provided in Section 6 of this data book.

NOTE: Functional and operational descriptions through this data manual which reference the 'S481 are applicable to both the SN74S481 and the SN54LS/74LS481 processor elements.

TABLE 1
FUNCTIONAL DESCRIPTIONS

| PIN NUMBER | PIN NAME | PIN FUNCTION | INPUT, OUTPUT, OR INPUT/OUTPUT |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & 46,47 \\ & 1,2 \end{aligned}$ | $\begin{aligned} & \mathrm{BI} / \mathrm{OO}, \mathrm{BI} / \mathrm{O} 1 \\ & \mathrm{BI} / \mathrm{O} 2, \mathrm{BI} / \mathrm{O} 3 \end{aligned}$ | 4-bit parallel data input port to the B latch, or 4 -bit parallel data output for the $\dot{-}$-bus when not being used as an input. | Inputs/Outputs |
| $\begin{aligned} & 6,5 \\ & 4,3 \end{aligned}$ | $\begin{aligned} & \mathrm{A} I 0, \mathrm{Al1} \\ & \mathrm{~A} I 2, \mathrm{Al3} \end{aligned}$ | 4-bit parallel data input port to the A latch and WR. | Inputs |
| $\begin{aligned} & 7,8 \\ & 9,10 \\ & 17,14 \\ & 13,11 \\ & 15,16 \\ & \hline \end{aligned}$ | OPO, OP1 <br> OP2, OP3 <br> OP4, OP5 <br> OP6, OP7 <br> OP8, OP9 | OPO through OP9 serve as a 10-bit parallel operation-select input to the micro-decode logic array. In the most-significant position, OP8 and OP9 additionally serve as open-collector outputs during multiply and divide algorithms. In the least-significant position, OP9 serves as an open-collector output during the CRC algorithm. | Inputs |
| 12 | $\mathrm{V}_{\mathrm{CC}}$ | Single 5-volt power-supply terminal. | Supply Voltage Pin |
| 18 | CIN | Receives low-active ripple carry input data. | Input |
| 19 | POS | Directs internal and input/output end-conditions required to define the relative position of each bit-slice when N-SN74S481's are cascaded to implement $\mathrm{N} \times 4$-bit word lengths. When biased at 2.4 volts, the package operates as the least-significant (LSP) slice; when grounded, it functions as an intermediate (IP) slice; and when high, 5 volts, it functions as the most-significant (MSP) slice. | Input |
| 20 | Y/AG | In least-significant and intermediate positions outputs arithmetic carry generate ( Y ) for use with look-ahead. In most-significant position outputs true arithmetically-greater-than signal. | Output |
| 21 | X/LG | In least-significant and intermediate positions outputs arithmetic carry propagate ( X ) for use with look-ahead. In most-significant position outputs true logically-greater-than signal. | Output |
| 22 | $\overline{\text { COUT }}$ | Outputs low-active ripple carry data. | Output |
| 23 | EQ | Outputs true (active-high) equality of $\Sigma^{\prime \prime}$ bus equals zero for each 4-bit slice. The open-collector output permits wire-AND to achieve $\mathrm{N} \times 4$-bit equality output. | Open-Collector-Output |
| 24 | LDWR | When low, data applied at the AI port coincident with the $\uparrow$ clock transition is loaded into the WR. | Input |
| $\begin{aligned} & 26 \\ & 25 \end{aligned}$ | WRRT, WRLFT | Working register and $\Sigma$-bus shift interconnectivity pins. WRRT receives left-shift and outputs right-shift (true) data. WRLFT receives right-shift and outputs left-shift (true) data. Shift can be single-precision, double-precision, signed or unsigned. | Bidirectional 1/O |
| $\begin{aligned} & 28 \\ & 27 \end{aligned}$ | XWRRT, XWRLFT | Extended working register shift interconnectivity pins. XWRRT receives left-shift and outputs right-shift (true) data. XWRLFT receives right-shift and outputs left-shift (true) data. Shift can be single-precision, double-precision, signed or unsigned. | Bidirectional 1/O |
| $\begin{aligned} & 29 \\ & 30 \end{aligned}$ | $\begin{aligned} & \mathrm{D} 0 \\ & \mathrm{D} 1 \end{aligned}$ | Selects one of three DOP sources (WR, XWR, or $\Sigma$-bus) or places the DOP outputs in a high-impedance state. | Inputs |
| $\begin{aligned} & 34 \\ & 33 \\ & 32 \\ & 31 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { DOP0 } \\ & \text { DOP1 } \\ & \text { DOP2 } \\ & \text { DOP3 } \end{aligned}$ | 4-bit parallel, data-out port. DOPO is LSB. | 3-state outputs |
| 35 | INCMC | When low, enables the MC to increment as directed by $\overline{\mathrm{CCI}}$ on the next $\uparrow$ clock transition. When high, inhibits MC to hold mode. As $\overline{C C O}$ is common to MC and PC, the MC should be inhibited when PC is enabled. | Input |
| 36 | GND | Common or ground terminal for the supply voltage. |  |
| 37 | CCO/OV | In least-significant and intermediate positions a low-level output indicates that either the PC or MC is at maximum count. As $\overline{\mathrm{CCO}}$ is common for both PC and MC ambiguous carry can be avoided if one or both counters is/are disabled by the INCPC and/or INCMC inputs. In the most-significant position, a high-level output, depending on the operation selected, indicates that the WR, XWR, or ALU will overflow (OV) on the next clock. | Output |



FIGURE 1 - FUNCTIONAL BLOCK DIAGRAM

TABLE 1 (Continued)

| PIN NUMBER | PIN NAME | PIN FUNCTION | INPUT, OUTPUT, OR INPUT/OUTPUT |
| :---: | :---: | :---: | :---: |
| $\begin{array}{r} 38,39 \\ 40,41 \\ \hline \end{array}$ | AOPO, AOP1 AOP2, AOP3 | 4-bit parallel address-out port. | Outputs |
| 42 | A0 | Selects one of two AOP sources (PC or MC). | Input |
| 43 | $\overline{\text { INCPC }}$ | When low, enables the PC to increment as directed by $\overline{\mathrm{CCl}}$ on the next $\uparrow$ clock transition. When high, inhibits PC to hold mode. As $\overline{\mathrm{CCO}}$ is common to PC and MC, the PC should be inhibited when MC is enabled. | Input |
| 44 | $\overline{\mathrm{CCl}}$ | In least-significant position, a low input directs enabled PC or enabled MC to increment by one on next $\uparrow$ clock transition. in the LSP, a high directs enabled PC or enabled MC to increment by 2. In other positions, a low is a carry input and a high inhibits the counter. | Input |
| 45 | CK | When high, enables the transparency of $A$ and $B$ input latches. When low, latches $A$ and $B$ input data. Clocks synchronous registers and counters on the positive transition. | Input |
| 48 | BI/O SEL | When low, enables $\mathrm{BI} / \mathrm{O}$ to output $\dot{2}$-bus data. When high, the $\mathrm{BI} / \mathrm{O}$ output drivers are placed in a high-impedance state permitting $\mathrm{BI} / \mathrm{O}$. to be used as data inputs. | Input |

## 2. DETAILED FUNCTIONAL DESCRIPTIONS

### 2.1 MICRO-DECODING LOGIC ARRAY

The micro-decoding logic array is a dedicated 11 input PLA decoding 73 product terms to generate 24 control lines needed to implement the 14 operation forms. The eleven inputs consist of the ten operation select lines (OPO through OP9) and the ALU carry input. The carry input, utilized as an additional operation select line during operation forms not performing arithmetic functions, maximizes system pin efficiency and functional density.

In an expanded word-length system (two or more 'S481's), operation select inputs 8 (OP8) and 9 (OP9) assume an input/output capability in the most-significant or least-significant package as a result of the position control and the type of operation being performed. During microprogrammable operation forms I through IX, OP8 and OP9 function simply as another input; but, during the macroprogrammable operations of forms $X$ through XIV one or both become an output during iterations. Table 2 summarizes by operation form the control (output) package and the operation lines which are used as an output.

TABLE 2
MSP OP8 and OP9 ITERATIVE FUNCTION SUMMARY

| OP. FORM | ALGORITHM | CONTROL PACKAGE | OPERATION SELECT I/O |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | OP8 | OP9 |
| 1 thru IX | All | None | INPUT | INPUT |
| X | CRC ACCUMULATION | LSP | INPUT | OUTPUT |
| XI | SIGNED DIVIDE | MSP | OUTPUT | OUTPUT |
| XII | UNSIGNED DIVIDE | MSP | INPUT | OUTPUT |
| XIII | UNSIGNED MULTIPLY | MSP | INPUT | OUTPUT |
| XIV | SIGNED MULTIPLY | MSP | OUTPUT | OUTPUT |

If the macroinstructions are to be used in an expanded word length, OP8 and OP9 select lines of the MSP and the OP9 line of the LSP should be driven from either a 3 -state output (which can be placed in high-impedance state) or an open-collector output (which can be wire-OR'ed with the OP select I/O lines). During an iterative function for which the OP line is designated as an open-collector output, the OP line driver should be placed in a high-impedance or off state permitting the output function to drive similar OP lines in the remaining packages.

The output state of OP8 or OP9 is a function of on-chip status decoder as enumerated in the flow diagrams illustrating the five algorithms.

### 2.2 RELATIVE POSITION CONTROL (POS)

The single line position control, with the ability of decoding one of three input logic states, provides each 'S481 in an expanded word length system with the capability of identifying its relative position. The relative positions, with the corresponding input logic levels are enumerated in Table 3.

TABLE 3
POSITION CONTROL FUNCTIONS

| POS INPUT <br> LOGIC LEVEL | RELATIVE POSITION |
| :---: | :---: |
| $\geqslant 3.6 \mathrm{~V}$ | MOST-SIGNIFICANT POSITION (MSP) |
| 1.8 V to 3 V |  |
| $\leqslant 0.8 \mathrm{~V}$ | LEAST-SIGNIFICANT POSITION (LSP) |
| INTERMEDIATE POSITION (IP) |  |

This relative position identification dictates how each 'S481 in the system handles the multi-purpose $1 / 0$ accommodations and ALU sign and magnitude functions. See Table 4. Shift/Circulate interconnectivity bit transfers are explained in detail under shift/circulate transfer multiplexers.

TABLE 4
DUAL-FUNCTION LOGIC I/O PINS

| PIN | MSP | IP | LSP |
| :---: | :---: | :---: | :---: |
| X/LG | LG (OUT) | X | X |
| Y/LG | AG (OUT) | Y | Y |
| $\overline{\text { CCO/OV }}$ | OVERFLOW (OUT) | $\overline{\mathrm{CCO}}$ (OUT) | $\overline{\mathrm{CCO}}$ (OUT) |

X AND Y ARE CARRY LOOK-AHEAD FUNCTIONS

### 2.3 CLOCK

The clock synchronizes the entry or change of data in the 'S481 registers and counters, and it controls the status of the $A$ and $B$ input latches. A typical clock cycle is illustrated in Figure 2. The low-to-high transition of the clock input is the clocking edge for any combination of either the working register, extended working register, flag flip-flops, and the program counter or the memory counter activated by the resident operation. During the low-level portion of the clock input, both input latches are latched ensuring data stability at the positive clock transition. After the clock has gone to a high level, the input latches are placed in a transparent mode to accept the next set of input data.


FIGURE 2 - CLOCK CYCLE
2.4 LATCHED DATA INPUT PORTS

The SN54S/74S481 features dual input ports combined with data flow paths which are designed specifically to reduce the number of system clock cycles needed to enter operands and/or data. Both the $A$ and $B$ input ports are latched, eliminating the need for external registers, to simplify interfacing directly with system data bus paths.

The $A$ input port data is made available to both the input latch and the working register which allows $A$ data to be loaded into the working register directly.

The B port is configured to serve as an input/output data path providing the capability to:
a. Input data to the B latch
b. Output sum-bus data.

This I/O port is designed specifically to simplify implementation of data transfers to the external working memory.
Both the A and B latches are transparent when the 'S481 clock input is high. Data applied at the A and B inputs should be stable anytime prior to or at least coincident with the falling edge of the clock input (see Figure 3). After the clock falling edge, the data inputs should be held steady for thold(data) or longer to facilitate the on-chip clock buffers to latch the data.


FIGURE 3 - INPUT LATCHES SETUP/HOLD TIMES
The $A$ input port latch data is routed to the $A$ input multiplexers, and the $B$ input port latch data is sourced to both the $A$ and $B$ input multiplexers.

## A AND B OPERAND SOURCES

The $A$ and $B$ input multiplexers source the $A L U A^{\prime}$ and $B^{\prime}$ ports through true/complement conditional inverter circuits. Data routing for each, illustrated and listed in Figure 4, provides the ALU with access to the true or complement of:

## ALU A' PORT

1. A input latch
2. B input latch
3. Working Register
4. Low logic level inputs (force zeros)

## ALU B' PORT

1. $B$ input latch
2. Sum bus
3. Working register
4. Extended working register
5. Program counter
6. Low logic level inputs
(force zeros)

The $A$ and $B$ multiplexers and true complement circuits, under control of the resident operation code, are selectable at the microprogram level. The number of $A$ or $B$ multiplexer sources available depend upon the specific operation being performed by the 'S481. Operation form descriptions contain detailed microprogramming.

The $A$ and $B$ input multiplexers, with selectable true and complement operand sources, maximizes the processing power of the ' S 481 by minimizing the active components needed to achieve both the simple but highly flexible data routing tasks and full ALU capabilities.

## A OPERAND SOURCES




B INPUT/OUTPUT SELECTIONS

$$
\begin{aligned}
& B I N \rightarrow B^{\prime} \\
& \bar{B} I N \rightarrow B^{\prime} \\
& \text { LOGIC ONE'S } \rightarrow B^{\prime} \\
& \text { LOGIC ZERO'S } \rightarrow B^{\prime} \\
&(B I N) \cdot(W R) \rightarrow B^{\prime} \\
& \overline{(B I N) \cdot(W R)} \rightarrow B^{\prime} \\
& W R \rightarrow B^{\prime} \\
& \overline{W R} \rightarrow B^{\prime} \\
&(B I N) \cdot(X W R) \rightarrow B^{\prime} \\
&(B I N) \cdot(X W R) \rightarrow B^{\prime} \\
& X W R \rightarrow B^{\prime} \\
& \overline{X W R} \rightarrow B^{\prime} \\
&(B I N) \cdot(P C) \rightarrow B^{\prime} \\
&(B I N) \cdot(P C) \rightarrow B^{\prime} \\
& \overline{P C} \rightarrow B^{\prime} \\
& P C \rightarrow B^{\prime}
\end{aligned}
$$

FIGURE 4 - ALU OPERAND SOURCES

The 4-bit, parallel, binary arithmetic/logic unit provides the arithmetic/Boolean operand combination/modification mechanism including magnitude and overflow status. The ALU performs, as directed by the resident operation form, one of four basic functions which, when combined with the operand selections at the $A$ and $B$ multiplexers, extends the arithmetic/logic capabilities to that of a full 16 -function ALU.

When compared to other bit-slice processor elements, unique to the ' S 481 arithmetic architecture are the parallel input ports and fully microprogrammable symmetry for all ALU functions within the selections of the $A$ and $B$ input multiplexers.

Logical and arithmetic operation forms for the 'S481 are shown in Table 5. The full functional power of the 'S481 can be visualized only if it is understood that although both ALU's have parallel A and B input ports, the 'S481 architecture not only provides access to multiple sources but has the capability to route true or complement of any source to the $A$ and B ALU port. This means that for a subtract operation, the subtrahend may be either an A or B input. In addition to maximizing data routing capabilities of the 'S481 at minimum logic/gate levels, this architecture permits fully symmetrical operations to be performed on the $A$ or $B$ sources within the selections offered by these 'S481 arithmetic/logical operation forms.

TABLE 5
'S481 ALU AND LOGIC FUNCTIONS

| DATA INPUT |  | TWO'S COMPLEMENT INTEGER ARITHMETIC OP'S |  | LOGICAL OP'S (FORM VIII) $\overline{C I N}=H O R L$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A PORT | B PORT | $\overline{\mathrm{CIN}}=\mathrm{L}$ | $\overline{\mathrm{CIN}}=\mathrm{H}$ | OR | NOR | EX-NOR |
| ZEROS | ZEROS | 1 | 0 | ZEROS | ONES | ONES |
| ZEROS | ONES | 0 | MINUS 1 | ONES | ZEROS | ZEROS |
| ONES | ZEROS | 0 | MINUS 1 | ONES | ZEROS | ZEROS |
| ONES | ONES | MINUS 1 | MINUS 2 | ONES | ZEROS | ONES |
| A | ZEROS | A PLUS 1 | A | A | $\overline{\mathrm{A}}$ | $\overline{\text { A }}$ |
| A | ONES | A | A MINUS 1 | ONES | ZEROS | A |
| $\bar{A}$ | ZEROS | MINUS A | MINUS A MINUS 1 | $\bar{A}$ | A | A |
| $\bar{A}$ | ONES | MINUS A MINUS 1 | MINUS A MINUS 2 | ONES | ZEROS | $\bar{A}$ |
| ZEROS | B | B PLUS 1 | B | B | $\bar{B}$ | $\bar{B}$ |
| ONES | B | B | B MINUS 1 | ONES | ZEROS | B |
| ZEROS | $\bar{B}$ | MINUS B | MINUS B MINUS 1 | $\bar{B}$ | B | B |
| ONES | $\bar{B}$ | MINUS B MINUS 1 | MINUS B MINUS 2 | ONES | ZEROS | $\bar{B}$ |
| A | B | A PLUS B PLUS 1 | A PLUS B | $A+B$ | $\overline{\mathrm{A}} \cdot \overline{\mathrm{B}}$ | $\overline{A \oplus B}$ |
| A | $\bar{B}$ | A MINUS B | A MINUS B MINUS 1 | $A+\bar{B}$ | $\bar{A} \cdot \mathrm{~B}$ | $A \oplus B$ |
| $\bar{A}$ | B | B MINUS A | B MINUS A MINUS 1 | $\overline{\mathrm{A}}+\mathrm{B}$ | A. $\bar{B}$ | $A \oplus B$ |
| $\bar{A}$ | $\bar{B}$ | MINUS A MINUS B MINUS 1 | MINUS A MINUS B MINUS 2 | $\bar{A}+\bar{B}$ | A. B | $\overline{A \oplus B}$ |

Some unique one-clock arithmetic/iterative capabilities of the 'S481 are listed in Table 6.
TABLE 6
EXTENDED ALU FUNCTIONS OF 'S481

| FORM NO. |  |
| :---: | :---: |
| 1 | FUNCTION |
|  | A (ALU) B • WR |
|  | A (ALU) B • XWR |
| $I I$ | A (ALU) B PC DOUBLE-PRECISION SHIFTED LOGICAL LEFT OR RIGHT |
| III | A (ALU) B SINGLE-PRECISION SHIFTED LOGICAL OR ARITHMETIC |
|  | LEFT OR RIGHT |

Table 5 also indicates the 16 logical combinations of two Boolean variables which are selectable for the OR, NOR, and exclusive-NOR functions. Full symmetry of the ALU and the ability to select the complement of input data extends the logic functions for performance of:
a. NAND
b. AND
c. Exclusive-OR
d. Mixed combinations of each
e. Transfer functions for true or inverted data
f. All ones or all zeros.

### 2.7 ALU MAGNITUDE AND CARRY FUNCTIONS

The 'S481 ALU is fully decoded on chip to generate three magnitude outputs (status lines) and both ripple and look-ahead carry functions. The magnitude outputs and their status indications are as follows:

### 2.7.1 Equal (EQ, See Figure 5)

The results of the resident ALU operation are compared at the sum-bus for all bits high during subtract and left-shift arithmetic operations, or for all bits low during other operations.


FIGURE 5 - EQUAL OUTPUT

### 2.7.2 Logically-Greater Than (LG, See Figure 6)

In the most-significant package (MSP) the $X$ look-ahead function from the ALU is inhibited and the logically-greater-than (LG) output is enabled. See Figure 6. The MSP LG output is active during arithmetic and shift operation forms to provide a status indication that can be used when it is desirable to compare two unsigned integer numbers. The specific status for each operation form is listed in Table 7.


FIGURE 6 - MSP LOGICALLY-GREATER-THAN (LG) OUTPUT
TABLE 7
MSP LOGICALLY-GREATER-THAN (LG) OUTPUT

| OP FORM | TYPE OF OP | LG = H INDICATES |
| :---: | :---: | :---: |
| I or II (ARITH) | ALL | $\Sigma$ - BUS $\neq$ ZERO $(E Q=L)$ |
| III (ARITH WITH SHIFT) | LSL, RSL | $\Sigma \cdot \mathrm{BUS} \neq$ ZERO ( $\mathrm{EQ}=\mathrm{L}$ ) |
|  | LSA or RSA | ADDER C-OUT |
| IV, V, or VI (SHIFTS) | ALL | AI $\neq \mathrm{ZERO}(\mathrm{EQ}=\mathrm{L}$ ) |
| VII (COMPARE) | A: B | A IS LG THAN B |
|  | B: A | B IS LG THAN A |
| VIII (LOGICAL) | ALL | $\Sigma$-BUS $\neq$ ZERO ( $E Q=L$ ) |
| IX (NO OP) | ZERO E -BUS | $L G=L(E Q=H)$ |
| X THRU XIV | HARDWIRED ALGORITHMS | SEE OPERATION FORM DESCRIPTION |

### 2.7.3 Arithmetically-Greater Than (AG, See Figure 7)

In the most-significant package (MSP) the $Y$ look-ahead function from the ALU is inhibited and the arithmetically-greater-than (AG) output is enabled. The MSP AG output is active during arithmetic and shift operation forms to provide a status indication that can be used when it is desirable to compare two signed integer numbers. The specific status for each operation form is listed in Table 8.


FIGURE 7 - MSP ARITHMETICALLY-GREATER-THAN (AG) OUTPUT

TABLE 8
ALU CARRY AND MSP ARITHMETICALLY-GREATER-THAN (AG) OUTPUTS

| OPERATION FORM | LSP AND IP |  |  |  | MSP |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | X | Y | EQ | $\overline{\text { C-OUT }}$ | LG | AG | EQ | $\overline{\text { C-OUT }}$ |
| LOGICAL OPERATIONS | L | H | $\Sigma-B \cup S=0$ | $\overline{\mathrm{C-IN}}$ | $\Sigma$-BUS $\neq 0$ | $\Sigma$-BUS $>0$ | $\Sigma$-BUS $=0$ | $\overline{\mathrm{C}-\mathrm{IN}}$ |
| ARITHMETIC OPERATIONS: COMPARE | X | Y | $A=B$ | $\overline{\mathrm{COUT}}$ | $\begin{gathered} \text { A LG B } \\ \text { or } \\ \text { B LG A } \end{gathered}$ | $\begin{gathered} \text { A LG B } \\ \text { or } \\ \text { B LG A } \end{gathered}$ | $A=B$ | $\overline{\text { C-OUT }}$ |
| ALL OTHER ARITHMETIC | X | Y | $\Sigma-B \cup S=0$ | $\overline{\mathrm{C}-\mathrm{OUT}}$ | $\Sigma$-BUS $\neq 0$ | $\Sigma$-BUS $>0$ | E-BUS AG 0 | $\overline{\text { C-OUT }}$ |

$X$ and $Y$ are carry look-ahead functions.

### 2.8 OPERAND OVERFLOW

In the most-significant package (MSP) the counter-carry output ( $\overline{\mathrm{CCO}}$ ) function from the program/memory counter is inhibited and the overflow (OV) output is enabled. The MSP OV output is active during arithmetic and shift operation forms to provide a status indication that the result of the operation cannot be correctly represented with the number of bit positions available. When the OV output goes high, it indicates that the next clock will:
a. During arithmetic operations, cause the ALU to overflow.
b. During left-shift arithmetic operations, cause the shifted register to overflow.

Table 9 enumerates the specific indicators generated.

TABLE 9
MSP OVERFLOW (OV) OUTPUT

| OP FORM | TYPE OF OP | OV = H INDICATES |
| :---: | :---: | :--- |
| I or II (ARITH) | ADD or SUB | ALU OVERFLOW |
|  | LSL, RSL | ALU OVERFLOW |
|  | RSA | OV = L |
| IV, V, Or VI (SHIFTS) | LSA | NEXT CLOCK WILL CAUSE |
| SHIFT OVERFLOW |  |  |

$H=$ high level, $L=$ low level

## SUM' BUS MULTIPLEXER

The sum'-bus multiplexer, sourced by the ALU, provides a means for accomplishing a shift operation on the ALU operand without affecting the contents of WR, XWR, PC or MC (See Figure 8). Functionally, this multiplexer can be used to:
a. Shift the operand left or right (one bit position) arithmetic, logical, or circulate
b. Pass the operand without shift to the $\Sigma^{\prime}$ bus.


FIGURE 8 - SUM BUS MULTIPLEXER

Full sign protection and fill-in is provided in the MSP and LSP under control of the relative position inputs.
Information on the $\Sigma^{\prime}$ bus can be accessed during some operations through the 3 -state $\Sigma^{\prime}$ bus control buffer at the B input/output port.

The parallel data input ports and the $I / O$ capability of the $B$ port, combined with the $\Sigma$-bus access, provides considerable flexibility for performing simple shifts or combinations of operation-and-shift on data or operands resident in the external working memory locations.

B-INPUT/OUTPUT CONTROL

The B-input/output port is isolated from the sum' bus by a 3 -state control buffer when the buffer outputs are at a high-impedance. Enabling the buffer routes the sum' bus data to the B-port. The low-current inputs of the $B$ port latch minimizes loading effects, and the buffers can source 6.5 mA or sink 10 mA of drive current in the output mode. During the output mode, the 'bus data can be latched in the $B$ input latch. Enabling or disabling is accomplished by the I/O control input. See Table 10 and Figure 9.

TABLE 10
B-INPUT/OUTPUT CONTROL

| I/O CONTROL | I/O BUFFER OUTPUT |
| :---: | :--- |
| L | SUM' BUS DATA |
| H | HIGH-IMPEDANCE |



FIGURE 9 - B-INPUT/OUTPUT CONTROL

The working register (WR) is a 4-bit D-type register which functions as an accumulator during iterative arithmetic operations or as a temporary holding register for intermediate operands (see Figure 10). It is sourced by the WR multiplexer. Storage of setup data, under control of the resident operation forms which permit the WR to be a destination, occurs on the positive transition of the clock. WR shifting capabilities are implemented in the WR multiplexer. The working register can be selected to source the data-out port multiplexer (DO MUX), A-input multiplexer ( $A$ MUX), or B-input multiplexer (B MUX). The MSB of the WR is sourced to the WRLFT MUX, and the LSB of the WR is sourced to the WRRT MUX to facilitate expansion.


TO: DO MUX, A MUX, B MUX

FIGURE 10 - WORKING REGISTER (WR) AND WR MULTIPLEXER
An asynchronous control line, $\overline{L D W R}$, is available to facilitate loading the working register directly from the $A$ input port in combination with the resident micro-operation.

### 2.12 WORKING REGISTER MULTIPLEXER (WR MUX)

The working register multiplexer provides source selection, including the bidirectional shifting capability, for the working register. See Figure 10. Under direction of the resident operation, the WR MUX asynchronously selects either:
a. A input port for direct loading
b. $\quad \Sigma^{\prime}$ bus for ALU operand results
c. Hold mode for no change
d. Shift left
e. Shift right

End conditions for both shift left and shift right operations are routed to or from WR MSB (WR3) or WRLSB (WRO) to the WRLFT/WRLFT' multiplexers or to the WRRT/WRRT' multiplexers respectively.

EXTENDED WORKING REGISTER

The extended working register (XWR) is a 4-bit D-type register which functions primarily as an extension of the working register to provide the double-precision operation capabilities needed for iterative multiply and divide routines (see Figure 11). Additionally, the storage capabilities of the XWR are available for use as another temporary holding register for intermediate operands during a number of the single-precision operation forms. It is sourced by the XWR multiplexer. Storage of setup data, under control of resident operation forms which permit the XWR to be a destination, occurs on the positive transition of the clock. XWR shifting capabilities are implemented in the XWR multiplexer. The XWR can be selected to source the data-out port multiplexer ( $D O$ MUX), B-input multiplexer ( $B$ $M U X$ ), or the XWR multiplexer (XWR MUX). The MSB of the XWR is sourced to the XWRLFT'MUX, and the LSB of the XWR is sourced to the XWRRT' MUX to facilitate expansion.


FIGURE 11 - EXTENDED WORKING REGISTER (XWR) AND XWR MULTIPLEXER

### 2.14 EXTENDED WORKING REGISTER MULTIPLEXER (XWR MUX)

The extended working register multiplexer provides source selection, including the bidirectional shifting capability, for the extended working register (see Figure 11). Under direction of the resident operation, the XWR MUX asynchronously selects either:
a. $\quad \Sigma^{\prime}$ bus for ALU operand results
b. Hold mode for no change

## c. Shift left

d. Shift right.

End conditions for both shift left and shift right operations are routed to or from XWR MSB (XWR3) or XWR LSB (XWRO) to the XWRLFT/XWRLFT' multiplexers or to the XWRRT/XWRRT' multiplexers respectively.

### 2.14.1 之-Bus, WR, XWR MSB Shift Transfer Multiplexers

The MSB shift transfers are accomplished by the WRLFT, XWRLFT input/output multiplexers and the WRLFT', XWRLFT' sum-bus/register MSB input multiplexers. All four multiplexers, and the impedance of the 3 -state $1 / O$ lines of the WRLFT and XWRLFT multiplexer outputs are under control of the resident operation code and the relative position control (POS). Data paths of the multiplexers are illustrated in Figure 12, and bit transfers with respect to each of the shift operations are enumerated in Tables 11 through 14.

### 2.14.2 WRLFT, XWRLFT Multiplexers

The WRLFT, XWRLFT input/output multiplexers facilitate routing of the working register, extended working register, or sum bus MSB out the WRLFT, XWRLFT I/O's during output modes. In an input mode, the three-state output is at a high impedance permitting the WRLFT and/or the XWRLFT pins to be used as inputs.

### 2.14.3 WRLFT', XWRLFT' Multiplexers

The WRLFT' multiplexer selects the source for either the sum bus or working register MSB. Sign bit protection and right-shift bit-fill functions are all handled on-chip by these multiplexers under control of the operation code and relative position. The WRLFT' sources are:
a. WRLFT (input)
b. ALU carry out (for sign-fill)
c. Low level (for zero-fill)
d. XWRLFT input
e. $\quad$ XWR MSB
f. WR MSB (sign-fill in for RSA)
g. $\quad$ Sign fill in for RSA (see Figure 12)

The XWRLFT multiplexer selects the source for XWR MSB and provides sign-bit protection and right-shift-fill functions for the XWR. The XWRLFT sources are:
a. XWRLFT (input)
b. WRLFT
c. XWR MSB (sign-fill in for RSA)

### 2.14.4 WR, XWR LSB Shift Transfer Multiplexers

The LSB shift transfers are accomplished by the WRRT, XWRRT input/output multiplexers and the WRRT', XWRRT' sum-bus/register LSB input multiplexers. All four multiplexers, and the impedance of the 3 -state I/O lines of the WRRT and XWRRT multiplexer outputs, are under control of the resident operation code and the relative position control (POS). Data paths of the multiplexers are illustrated in Figure 13.

### 2.14.5 WRRT Multiplexer, XWRRT Buffer

The WRRT input/output multiplexer facilitates routing of sum-bus or working register LSB out the WRRT I/O during output modes. The XWRRT I/O buffer can access and source the XWR LSB. In an input mode, the three-state output is at a high impedance permitting the WRRT and/or XWRRT pins to be used as inputs.

### 2.14.6 WRRT', XWRRT' Multiplexers

The WRRT' multiplexer selects either the WRRT input or a low logic level (fill) input as the LSB source for either the working register or the sum-bus. The XWRRT' multiplexer selects between the XWRRT input and low logic level (fill) input as the XWR LSB source.


FIGURE 12 - SUM-BUS, WR, XWR MSB SHIFT TRANSFER MULTIPLEXERS

TABLE 11
WORKING REGISTER BIT TRANSFERS TO WRLFT／WRRT

| SHIFT | MOST－SIGNIFICANT POSITION |  |  |  | INTERMEDIATE POSITION |  |  |  | LEAST－SIGNIFICANT POSITION |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MODE | WRLFT | WRLFT＇ | WRRT＇ | WRRT | WRLFT | WRLFT＇ | WRRT＇ | WRRT | WRLFT | WRLFT＇ | WRRT＇ | WRRT |
| LSL（SP） | Z | $x$ | WRRT | $z$ | WR3 | $x$ | WRRT | $z$ | WR3 | $x$ | WRRT | $z$ |
| LSL（DP） | XWR3 | $x$ | WRRT | $z$ | WR3 | $x$ | WRRT | 2 | WR3 | $x$ | WRRT | 2 |
| LSA（SP） | WR3 | $x$ | WRRT | Z | WR3 | X | WRRT | 2 | WR3 | X | L | 2 |
| LSA（DP） | XWR3 | $x$ | WRRT | $z$ | WR3 | $x$ | WRRT | z | WR3 | $x$ | WRRT | Z |
| LCIR（SP） | WR3 | X | WRRT | Z | WR3 | X | WRRT | Z | WR3 | X | WRRT | Z |
| LCIR（DP） | XWR3 | $\times$ | WRRT | Z | WR3 | $\times$ | WRRT | $z$ | WR3 | X | WRRT | z |
| RSL（SP） | Z | WRLFT | X | WRO | Z | WRLFT | $\times$ | WRO | Z | WRLFT | X | Z |
| RSL（DP） | Z | L | $x$ | WRO | z | WRLFT | $x$ | WRO | $z$ | WRLFT | $x$ | WRO |
| RSA（SP） | Z | WR3 | X | WRO | Z | WRLFT | $\times$ | WRO | Z | WRLFT | X | WRO |
| RSA（DP） | Z | WR3 | $x$ | WRO | Z | WRLFT | $x$ | WRO | Z | WRLFT | $\times$ | WRO |
| RCIR（SP） | Z | WRLFT | X | WRO | Z | WRLFT | $\times$ | WRO | z | WRLFT | X | WRO |
| RCIR（DP） | Z | WRLFT | $x$ | WRO | z | WRLFT | X | WRO | z | WRLFT | x | WRO |

TABLE 12
SUM－BUS BIT TRANSFERS TO WRLFT／WRRT

| SHIFT | MOST－SIGNIFICANT POSITION |  |  |  | INTERMEDIATE POSITION |  |  |  | LEAST－SIGNIFICANT POSITION |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MODE | WRLFT | WRLFT＇ | WRRT＇ | WRRT | WRLFT | WRLFT＇ | WRRT＇ | WRRT | WRLFT | WRLFT＇ | WRRT＇ | WRRT |
| LSL（SP） | 2 | $x$ | WRRT | $z$ | 23 | $x$ | WRRT | Z | さ3 | $x$ | WRRT | Z |
| LSL（DP） | XWR3 | $x$ | WRRT | 2 | 23 | $x$ | WRRT | z | 23 | $x$ | WRRT | Z |
| LSA（SP） | 23 | X | WRRT | Z | 23 | X | WRRT | Z | こ3 | X | L | Z |
| LSA（DP） | XWR3 | $x$ | WRRT | 2 | こ3 | $x$ | WRRT | z | こ3 | X | WRRT | Z |
| LCIR（SP） | こ3 | X | WRRT | Z | $\Sigma 3$ | X | WRRT | Z | ご3 | X | WRRT | Z |
| LCIR（DP） | XWR3 | $\times$ | WRRT | Z | 23 | X | WRRT | Z | ご3 | X | WRRT | Z |
| RSL（SP） | Z | WRLFT | X | 20 | Z | WRLFT | $\times$ | 20 | Z | WRLFT | X | г0 |
| RSL（DP） | 2 | C－OUT | X | 20 | $z$ | WRLFT | $x$ | こ0 | z | WRLFT | X | こ0 |
| RSA（SP） | Z | ＊ | X | こ0 | Z | WRLFT | X | こ0 | Z | WRLFT | X | 200 |
| RSA（DP） | z | ＊ | X | $\Sigma 0$ | Z | WRLFT | $x$ | 20 | Z | WRLFT | $x$ | 50 |
| RCIR（SP） | Z | WRLFT | X | 20 | Z | WRLFT | X | 20 | Z | WRLFT | X | 20 |
| RCIR（DP） | Z | XWRLFT | X | 20 | Z | WRLFT | $\times$ | 20 | z | WRLFT | X | こ0 |

＊VARIABLE $=(\Sigma 3 \cdot A L U$ OVERFLOW $)+(C-O U T \cdot A L U$ OVERFLOW $)$

TABLE 13
EXTENDED WORKING REGISTER BIT TRANSFERS TO XWRLFT／XWRRT

| SHIFT | MOST－SIGNIFICANT POSITION |  |  |  | INTERMEDIATE POSITION |  |  |  | LEAST－SIGNIFICANT POSITION |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MODE | XWRLFT | XWRLFT＇ | XWRRT＇ | XWRRT | XWRLFT | XWRLFT ${ }^{\text {＇}}$ | XWRRT＇ | XWRRT | XWRLFT | XWRLFT＇ | XWRRT＇ | XWRRT |
| LSL（SP） | $z$ | $x$ | XWRRT | $z$ | XWR3 | $x$ | XWRRT | z | XWR3 | $x$ | XWRRT | $z$ |
| LSL（DP） | z | x | XWRRT | z | XWR3 | $\times$ | XWRRT | Z | XWR3 | $x$ | XWRRT | z |
| LSA（SP） | XWR3 | X | XWRRT | Z | XWR3 | X | XWRRT | z | XWR3 | X | L | z |
| LSA（DP） | WR3 | X | XWRRT | $z$ | XWR3 | $x$ | XWRRT | z | XWR3 | $x$ | L | 2 |
| LCIR（SP） | XWR3 | X | XWRRT | z | XWR3 | X | XWRRT | z | XWR3 | X | XWRRT | 2 |
| LCIR（DP） | WR3 | x | XWRRT | z | XWR3 | $\times$ | XWRRT | z | XWR3 | x | XWRRT | 2 |
| RSL．（SP） | Z | XWRLFT | x | XWRO | Z | XWRLFT | $\times$ | xWRO | Z | XWRLFT | x | 2 |
| RSL（DP） | z | WRLFT | x | XWRO | z | XWRLFT | x | XWRO | z | XWRLFT | X | XWRO |
| RSA（SP） | Z | XWR3 | x | XWRO | z | XWRLFT | x | XWRO | z | XWRLFT | X | XWRO |
| RSA（DP） | z | WRLFT | $x$ | XWRO | $z$ | XWRLFT | x | XWRO | $z$ | XWRLFT | $x$ | XWRO |
| RCIR（SP） | z | XWRLFT | X | XWRO | z | XWRLFT | X | XWRO | z | XWRLFT | X | XWRO |
| RCIR（DP） | z | WRLFT | x | XWRO | Z | XWRLFT | x | xWRO | z | XWRLFT | X | XWRO |

TABLE 14
SUM-BUS BIT TRANSFERS TO XWRLFT (MSP)

| SHIFT <br> MODE | MOST-SIGNIFICANT POSITION |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | XWRLFT | XWRLFT' | XWRRT' | XWRRT |
| LSL (SP) | 2 | $x$ | XWRRT | z |
| LSL (DP) | z | X | XWRRT | Z |
| LSA (SP) | XWR3 | X | XWRRT | z |
| LSA (DP) | $\Sigma 3$ | X | XWRRT | $z$ |
| LCIR (SP) | XWR3 | X | XWRRT | Z |
| LCIR (DP) | 23 | $x$ | XWRRT | $z$ |
| RSL (SP) | Z | XWRLFT | X | XWRO |
| RSL (DP) | $z$ | WRLFT | x | XWRO |
| RSA (SP) | Z | XWR3 | X | XWRO |
| RSA (DP) | z | WRLFT | $x$ | XWRO |
| RCIR (SP) | z | XWRLFT | X | XWRO |
| RCIR (DP) | $z$ | WRLFT | X | XWRO |

NOTE: Intermediate and Least-Significant Positions are the same as shown in Table 13.


FIGURE 13 - SUM-BUS, WR, XWR LSB SHIFT TRANSFER MULTIPLEXERS

### 2.15 SHIFT FUNCTIONS

The 'S481 contains the necessary controls and data paths to perform single or double length logical, arithmetic, or circulate bidirectional shift functions in a single clock cycle. Each of the six shift functions implemented are selectable by a single microinstruction; and, additionally two single clock operation forms are included which provide the capability of performing an add/subtract in conjunction with a shift. The six shift functions and the basic operation forms offering them are enumerated in Table 15.

TABLE 15
MICROPROGRAMMABLE SHIFT FUNCTIONS

| FUNCTION | OPERATION FORMS |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | SIMPLE SHIFT |  | ADD/SUBTRACT WITH SHIFT |  |
|  | SINGLE <br> LENGTH | DOUBLE <br> LENGTH | SINGLE <br> LENGTH | DOUBLE <br> LENGTH |
| LEFT CIRCULATE (LCIR) | IV, V | VI |  |  |
| LEFT SHIFT ARITHMETIC (LSA) | IV, V | VI | III |  |
| LEFT SHIFT LOGICAL (LSL) | IV, V | VI | III | 11 |
| RIGHT CIRCULATE (RCIR) | IV, V | VI |  |  |
| RIGHT SHIFT ARITHMETIC (RSA) | IV, V | VI | III |  |
| RIGHT SHIFT LOGICAL (RSL) | IV, V | VI | 111 | 11 |

### 2.15.1 CIRCULATE (SHIFT) FUNCTIONS (MICROPROGRAMMABLE)

Operation forms IV and V provide the system designer with the capability of programming a single precision circulate (or rotate) of the $\Sigma^{\prime}$ bus, working register, or extended working register and operation form VI provides the capability of circulating or rotating a double-length word resident in the WR/XWR. A single-bit-position left or right circulate is accomplished on each clock without the loss of any bits as the shift transfer multiplexers, under control of the resident operation and position input, interconnect the bus or register as illustrated in Figure 14.

The remaining end conditions are handled on chip by the shift transfer multiplexers to interconnect the bit transfer mechanisms for MSB $\rightarrow$ LSB for single precision circulates and for transfers to or from the $\Sigma^{\prime}$ bus or working register and the extended working register during double-precision circulates. Data flow between packages in an expanded word-length system is via the interconnected WRRT/WRLFT and XWRRT/XWRLFT terminals.

### 2.15.2 ARITHMETIC SHIFT FUNCTIONS (MICROPROGRAMMABLE)

Operation forms III, IV, V and VI provide the system designer with the capability of programming the following arithmetic shifts.

Form III - A single-precision arithmetic left or sign-protected right shift of the sum or difference of the A and B operands destined for either the WR or XWR.

Form IV - A single-precision arithmetic left or sign-protected right shift of the A operand destined for the $\Sigma^{\prime}$ bus.

Form V - A single-precision arithmetic left or sign-protected right shift of the WR or XWR contents.
Form VI - A double-precision arithmetic left or sign-protected right shift of the WR and XWR contents.

SN74S481 4-BIT-SLICE SCHOTTKY PROCESSOR ELEMENT


FIGURE 14 - CIRCULATE FUNCTIONS

A single-bit-position shift is accomplished on each clock with right-shift sign-protection and left shift LSB zero-fill operations controlled by the shift transfer multiplexers under direction of the resident operation and the position input. See Figure 15.

The remaining end conditions are handled on chip by the shift transfer multiplexers to interconnect the bit transfer mechanisms for transfers to or from the $\Sigma^{\prime}$ bus or working register and the extended working register during double-precision arithmetic shifts. Data flow between packages in an expanded word-length system is via the interconnected WRRT/WRLFT and XWRRT/XWRLFT terminals.

### 2.15.3 LOGICAL SHIFT FUNCTIONS (MICROPROGRAMMABLE)

Operation Forms II, III, IV, V and VI provide the system designer with the capability of programming the following logical shifts:

Form II - A double-precision left or right shift of the sum or difference of the $A$ and $B$ operands destined for the WR in conjunction with the XWR.

Form III - A single-precision left or right logical shift of the sum or difference of the $A$ and $B$ operands destined for the WR or the XWR.

Form IV - A single-precision left or right logical shift of the A operand destined for the $\Sigma^{\prime}$ bus.

Form V - A single-precision left or right logical shift of the WR or XWR contents.

Form VI - A double-precision left or right logical shift of the WR and XWR contents.
A single-bit-position shift is accomplished on each clock with MSB and LSB fill operations controlled by the shift transfer multiplexers under direction of the resident operation and the position input. See Figure 16.

The remaining end conditions are handled on chip by the shift transfer multiplexers to interconnect the bit transfer mechanisms for transfers to and from the $\Sigma^{\prime}$ bus or working register and the extended working register during double-precision logical shifts. Data flow between packages in an expanded word length system is via the interconnected WRRT/WRLFT and XWRRT/XWRLFT terminals.

### 2.16 DATA-OUT PORT MULTIPLEXER (DO MUX)

The data-out port multiplexer, Figure 17, provides selection for routing the contents of either the sum'-bus, working register, or extended working register to the parallel output port. Additionally, the multiplexer is equipped with 3 -state outputs providing the capability to isolate the 'S481 from the system data bus. Source selections and high-impedance controls are detailed in Table 16.

Each data output is capable of sourcing 6.5 and sinking 10 milliamperes of drive current.

### 2.17 MEMORY AND PROGRAM COUNTERS

Dual counters provide the system designer with a processor element containing both an iteration counter and the capability of generating and/or storing locations of operands/data.

Either counter can be loaded or preset to any value or result from the sum bus in operations forms as follows:

## SELECTABLE AS

DESTINATION

| OP FORM | PC | MC |
| :---: | :--- | :---: |
| I | Yes | Yes |
| III | No | Yes |
| VIII | Yes | No |

SN74S481 4-BIT-SLICE SCHOTTKY PROCESSOR ELEMENT



DOUBLE PRECISION


FIGURE 16 - LOGICAL SHIFT FUNCTIONS


FIGURE 17 - DATA-OUT PORT MULTIPLEXER (DO MUX)

Under control of the position (POS) input and the resident operation code, the $\overline{\mathrm{CCO}} / \mathrm{OV}$ output facilitates cascading the program and memory counters. In the least-significant and intermediate positions, the $\overline{\mathrm{CCO}}$ pins of lesser significant packages are connected to the $\overline{\mathrm{CCl}}$ pins of more significant packages to complete the counter interconnections to the bit-size of the processor element.

TABLE 16
DATA-OUT PORT CONTROL

| CONTROL <br> INPUTS |  | SOURCE OR FUNCTION |  |
| :--- | :--- | :--- | :---: |
| D1 | DO |  |  |
| L | L |  |  |
| L | $H$ | L'-BUS |  |
| $H$ | L | EXTENDED WORKING REGISTER |  |
| $H$ | $H$ | WORKING REGISTER |  |
|  |  |  |  |

The functionally identical program and memory counters, sharing a common counter carry input ( $\overline{\mathrm{CCI}}$ ) control pin and a common counter carry output ( $\overline{\mathrm{CCO}}$ ) pin, feature individual control lines ( $\overline{\mathrm{NCP} \overline{P C}, \overline{I N C} M C}$ ) which can be used to instruct either (but normally not both) or neither counter to increment on the next clock transition in any of the 14 operation forms. Additionally, the counter in the LSP, under command of the POS input, has the capability of incrementing its value by one or by two to facilitate the generation of even or odd address locations in a single clock cycle. Contents of the counters can be read out from the address out port asynchronously under control of the address output multiplexer (AO MUX) select input.

Typical counter functions with respect to package relative positions are shown in Figure 18.
In the MSP, the $\overline{\mathrm{CCO}} / \mathrm{OV}$ output, as a result of the position (POS) control, becomes the ALU/shift overflow (OV) status output.


| INPUTS |  |  | CK | COUNTER VALUE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INC PC | INC MC | CCl |  | LSP MC | LSP PC | MSP, IP MC | MSP, IP PC |
| H | H | X | 4 | NO CHG | NO CHG | NO CHG | NO CHG |
| L | H | L | 4 | NO CHG | +1 | NO CHG | +1 |
| L | H | H | 1 | NO CHG | +2 | NO CHG | NO CHG |
| H | L | L | 4 | +1 | NO CHG | +1 | NO CHG |
| H | L | H | 4 | +2 | NO CHG | NO CHG | NO CHG |
| X | X | X | L | NO CHG | NO CHG | NO CHG | NO CHG |
| $X$ | X | $X$ | H | NO CHG | NO CHG | NO CHG | NO CHG |

$H=H$ IGH LEVEL, L=LOW LEVEL, $X=I$ RRELEVANT,$~ \uparrow=$ LOW-TO-HIGH TRANSITION

FIGURE 18 - PROGRAM AND MEMORY COUNTER FUNCTIONS

### 2.18 ADDRESS-OUT PORT MULTIPLEXER (AO MUX)

Fhe address-out port multiplexer, Figure 19, provides for direct parallel access to the contents of either the program or memory counter contents. A single line controls selection as shown in Table 17.

TABLE 17
ADDRESS-OUT PORT CONTROL

| CONTROL <br> INPUT AO | COUNTER SELECTED |
| :---: | :---: |
| L | MEMORY |
| H | PROGRAM |



FIGURE 19 - ADDRESS-OUT PORT MULTIPLEXER (AO MUX)

### 2.19 EXPANDING THE WORD LENGTH

The 'S481 processor element contains on-chip personality circuitry designed specifically to minimize the external discrete components required to cascade 4 -bit slices to form larger word lengths. At the processor-element level, three external resistors are all that is required: one to pull-up the open-collector outputs and two to establish the position control input voltage at the LSP. Figure 20 shows a typical 16 -bit processor element and illustrates the parallel bus arrangements for $1 / O$ and control with an SN74S182 performing ALU look-ahead across the 16 -bit word. Interconnectivity for the shift, arithmetic, and counter functions is accomplished by hardwiring the functions as shown.

At the system level, standard techniques commonly employed for power-supply bypass, termination of unused pins, and system grounding of high-performance Schottky TTL systems are recommended.

## 3. OPERATIONAL DESCRIPTIONS

### 3.1 MICRO/MACRO-OPERATIONS

The micro/macro-operations resident in the micro-decode logic array can be accessed with an eleven-bit operation-select word. Operational flexibility is maximized by the fact that the op-select word format has been defined individually for each of the 14 different operation forms.

Operation Forms I, II, and III are primarily ALU functions. Forms II and III combine logical or arithmetic shifting functions with the ALU result. Form II can be used for double-precision shifting. Sources, specific ALU function, shift format, and destinations are detailed for each op-select word format.

Forms IV, V, and VI perform either logical or arithmetic, bidirectional shifting of the single- and doubleprecision buses and registers.

Form VII can be used to compare the magnitude of $A$ source to $B$ source, or $B$ source to $A$ source.
Form VIII provides the capability to logically combine the values of the $A$ and $B$ sources.
Form IX zeros the $\Sigma^{\prime}$ bus with the effect of providing no operation.

Forms X through XIV are macroprogrammable operations which provide:
a. CRC partial sum update (normally $\frac{\mathrm{N}}{2}$ clocks)
b. Signed Divide ( $\mathrm{N}+3$ clocks)
c. Unsigned Divide ( $\mathrm{N}+1$ clocks)
d. $\quad \mathrm{N}$-bit-by- N -bit double-precision unsigned multiply ( N clocks)
e. $\quad \mathrm{N}$-bit-by- N -bit double-precision signed multiply ( N clocks)

The 14 operation forms, symbols, and number of unique operations are detailed in Table 18.


FIGURE 20 - TYPICAL 16-BIT PROCESSOR

TABLE 18 - OPERATION FORM, COMMAND FORMAT, AND TEST OUTPUTS


Operation Form I is designed specifically to perform the addition or symmetrial subtraction of two operands. The operation form shown in Figure 21, is composed of two distinct capabilities:


FIGURE 21 - FORM I-ARITHMETIC OPERATIONS: A PLUS B PLUS ALUCIN $\rightarrow\left\{\begin{array}{c}\Sigma^{\prime} \text { BUS } \\ \text { REGISTER }\end{array}\right\}$
a. Form IA provides the capability of adding or subtracting two operands and routing the results to the $\Sigma^{\prime}$ bus. Symbolically, this operation can be expressed as:

A $\left\{\begin{array}{l}\text { PLUS } \\ \text { MINUS }\end{array}\right\} \quad$ B PLUS ALUCIN $\rightarrow \Sigma^{\prime}$ BUS
This form provides the capability of choosing from any one of the $A$ and any one of the $B$ sources listed in Figure 21 as the operands to accomplish the add/subtract. The example illustrated in Figure 22 utilizes the I/O capability of the B input/output port. Input data at the AI or $\mathrm{BI} / \mathrm{O}$ is setup and then latched into the 'S481 A or B input latch on the negative transition of the 'S481 clock.

During Form IA operations, the contents of the extended working register are not changed and the working register may be saved or loaded directly. The program or memory counters under control of the asynchronous increment, inhibit, and LSP $\overline{\mathrm{CCI}}$ can be saved or either may be incremented by one or two. Sources for the DOP and AOP are also selectable.


= irrelevant

FIGURE 22 - 'S481 OPERATION WITH SINGLE-PORT REGISTER FILE

The overflow and magnitude status lines are active as enumerated in Figure 21.
b. Form IB provides the capability of adding or subtracting two operands and routing the results to one of the four 'S481 storage destinations: the working register (WR), the extended working register (XWR), the program counter (PC), or the memory counter (MC). Symbolically, this operation can be expressed as:

$$
\text { A } \left.\left\lvert\, \begin{array}{l}
\text { PLUS } \\
\text { MINUS }
\end{array}\right.\right\} \text { B PLUS ALUCIN } \rightarrow \text { REGISTER }
$$

This form provides the capability of choosing from any one of the $A$ and any one of the $B$ sources listed in Figure 21 as the operands to accomplish the add/subtract.

Operation Form II is designed specifically to perform one of two classical iterations used frequently to implement microprogrammed multiply and divide algorithms. This form provides the system designer with the capability of selecting a single microinstruction which will complete both the add-and-shift or subtract-and-shift functions in a single clock cycle. Available microinstructions are illustrated in Figure 23. Symbolically, Form II operations can be represented as:
(A PLUS B PLUS ALUCIN)
SHIFTED $\rightarrow$ WR, XWR
(B MINUS A MINUS 1)
SHIFTED $\rightarrow$ WR, XWR

Hardwired algorithms for double-precision multiply and divide routines can be selected in operation forms XI, XII, XIII, or XIV.

During Form II operations the status, overflow, and asynchronous controls are the same as described for Form I.


## FIGURE 23 - FORM II-ARITHMETIC WITH DOUBLE-PRECISION SHIFT

$$
\left\{\begin{array}{l}
A \\
B
\end{array}\right\} \text { PLUS }\left\{\begin{array}{l}
B \\
A
\end{array}\right\} \text { PLUS CARRY SHIFTED } \rightarrow \text { WR, XWR }
$$

(MULTIPLY AND DIVIDE SHIFT OPERATIONS WITHOUT AUTOMATIC CONTROL)
OPERATION FORM III - ADD WITH SINGLE-PRECISION SHIFT
Operation Form III is a universal microinstruction providing the designers with the capability of performing an add-and-shift function in a single clock cycle. Sources and destinations are shown in Figure 24. Also enumerated are the shift functions which are selectable as part of the microinstruction.

Magnitude and overflow status indicators are active as enumerated in Figure 24. Form III can be represented symbolically as:

$$
(\text { A PLUS B PLUS ALUCIN) SHIFTED } \rightarrow \text { XWR, OR MC }
$$

During Form III operation the contents of the working register are not changed unless an asynchronous load is selected. If not selected as the destination, the extended working register will be saved. The memory counter can be the operand destination, or it and the program counter can be saved, or one can be incremented by one or two on selection. Sources for the DOP and AOP are also selectable.


ASYNCHRONOUS CONTROLS:


FIGURE 24 - FORM III-ARITHMETIC WITH SINGLE-PRECISION SHIFT
(A PLUS B PLUS ALUCIN) SHIFTED $\rightarrow$ XWR OR MC

### 3.5 OPERATION FORM IV - AI SHIFTED $\rightarrow \Sigma^{\prime}$ BUS

Operation Form IV is designed specifically for performing a single bit-position logical, arithmetic, or circular shift of the data applied at the A input port. This single clock operation can be used to shift information residing in any of the external working memory register locations simply by enabling the output capability of the $\mathrm{BI} / \mathrm{O}$ port and writing the shifted word back into the same (or any other selected) memory location.

Asynchronous controls are the same as described for Operation Form IA, and the magnitude status lines are active and overflow is active during left-shift arithmetic (LSA) operation as enumerated in Figure 25.

## ASYNCHRONOUS CONTROLS:

SEL B INPUT/OUTPUT
SEL DOB SOURCE
SEL AOB SOURCE
INCREMENT PC OR MC
INHIBIT PC AND/OR MC
LOAD WR
$H=H I G H$ LEVEL, L = LOW LEVEL

1. $\overline{\mathrm{COUT}}=\overline{\mathrm{CIN}}$
2. $\operatorname{OVFL}(M S P=H)$

Indicates that LSA operation in process will cause shift overflow. For all other operations, $O V F L=L$.
3. MAGNITUDE: Al is compared to ZERO. Resultant outputs are:

$$
\begin{aligned}
& A G=H(A I>Z E R O) \\
& L G=H(A I \neq Z E R O) \\
& E Q=H(A I=Z E R O)
\end{aligned}
$$

FIGURE 25 - FORM IV-AI SHIFTED $\rightarrow \Sigma^{\prime}$ BUS

### 3.6 OPERATION FORM V - SINGLE-LENGTH SHIFT

Operation Form V performs a single-bit position, logical, arithmetic, or circular shift of either the working register or extended working register. Magnitude status indicators are active and overflow is active during left-shift arithmetic (LSA) operations as enumerated in Figure 26. Asynchronous controls are the same as described for Operation Form IA.


ASYNCHRONOUS CONTROLS:
SEL B INPUT/OUTPUT
SEL DOB SOURCE
SEL AOB SOURCE INCREMENT PC OR MC INHIBIT PC AND/OR MC LOAD WR

WR SHIFTED $\rightarrow$ WR
$\times W R$ SHIFTED $\rightarrow$ XWR

1. $\overline{\mathrm{COUT}}=\overline{\mathrm{CIN}}$
2. OVFL (MSP - H) Indicates that LSA operation in process will cause shift overflow. For all other operations, OVFL $\equiv \mathrm{L}$.
3. MAGNITUDE: Al is compared to ZERO. Resultant outputs are:
$A G=H(A I>Z E R O)$
$L G=H(A I \neq Z E R O)$
$E Q=H(A I=Z E R O)$

FIGURE 26 - FORM V: $\left\{\begin{array}{c}\text { WR } \\ \text { XWR }\end{array}\right\}$ SHIFTED $\rightarrow\left\{\begin{array}{c}\text { WR } \\ \text { XWR }\end{array}\right\}$

### 3.7 OPERATION FORM VI - DOUBLE-PRECISION SHIFTS

Operation Form VI performs a double-precision logical, arithmetic, or circular shift of a double-length word residing in the working register and extended working register. Magnitude status indicators are active and overflow is active during left-shift arithmetic (LSA) operations as enumerated in Figure 27. Asynchronous controls are the same as described for operation form IA.

ASYNCHRONOUS CONTROLS:
SEL B INPUT/OUTPUT
SEL DOB SOURCE
SEL AOB SOURCE
INCREMENT PC OR MC
INHIBIT PC AND/OR MC
LOAD WR
$H=H I G H$ LEVEL, L = LOW LEVEL

1. $\overline{\text { COUT }}=\overline{\mathrm{CIN}}$
2. $O V F L(M S P=H)$

Indicates that LSA operation in process will cause shift overflow. For all other operations, $\mathrm{OVFL} \equiv \mathrm{L}$.
3. MAGNITUDE: AI is compared to ZERO. Resultant outputs are:
$A G=H(A I>Z E R O)$
$L G=H(A I \neq Z E R O)$
$E Q=H(A \mid=Z E R O)$

FIGURE 27 - FORM VI-DOUBLE-PRECISION SHIFTS: (WR, XWR)SHIFTED $\rightarrow$ (WR, XWR)

OPERATION FORM VII - COMPARE (A:B OR B:A)
Operation Form VII is designed specifically to provide the system designer with the capability of symmetrically comparing either operands A-to-B or operands B-to-A. The operands selectable are enumerated in Figure 28 as the A source select or B source select. The carry output, overflow, and magnitude status lines decode and indicate the logical and arithmetic relationship of the operands being compared as shown in Figure 28. Asynchronous controls are the same as described for Operation Form IA.

## OPERATION FORM VIII - LOGICAL FUNCTIONS

The ALU with its carry circuit functionally inactivated in Form VIII operations can be microprogrammed in conjunction with the source operands to perform any of the possible combinatorial Boolean functions on two binary variables. See Figure 29. Simple transfer functions are performed with the arithmetic operations in Form I, and combinatorial transfer and shift operations are available in Form III.

As with the arithmetic operations, a highly flexible source selection extends performance of single clock combinatorial logical operations between two (external) operands applied at the $A$ and $B$ input ports, or combinations of resident data in 'S481 registers or counters can be combined logically with another register or external source. The specific combinations selectable are enumerated in the following paragraphs.


### 3.9.1 NOR/AND Logical Operations

Operation Form VIIIA can be used to perform the NOR or AND logical combination of two selectable operands and route the results to one of four destinations. The operation microcode is:

$H=H I G H$ LEVEL, L=LOW LEVEL
As shown above, the $A$ and $B$ sources are selectable by the $A 1, B 1$, and $B 2$ bits in their true or complementary form (bits $A O, B O$ ) to facilitate performing the NOR, mixed NOR/AND, and the AND functions. As irnplemented, see Figure 30, the NOR function is performed when the sources are both true, mixed NOR/AND functions are performed with one source complemented, and the AND function is performed when both sources are selected in their complement form. Both implementation and other/equal logic symbols are shown in Figure 30. Also provided are the function tables and Boolean equations.


FIGURE 30 - FORM VIIIA NOR/AND LOGICAL OPERATIONS

### 3.9.2 OR/NAND Logical Operations

Operation Form VIIIB can be used to perform the OR or NAND logical combination of two selectable operands and route the results to one of four destinations. The operation microcode is:


H=HIGH LEVEL, L=LOW LEVEL

As shown above, the $A$ and $B$ sources are selectable by the $A 1, B 1$, and $B 2$ bits in their true or complementary form (bits $A O, B O$ ) to facilitate performing the OR, mixed OR/NAND, and the NAND functions. As implemented, see Figure 31, the OR function is performed when the sources are both true, mixed OR/NAND functions are performed with one source complemented, and the NAND function is performed when both sources are selected in their complement form. Both implementation and other/equal logic symbols are shown in Figure 31. Also provided are the function tables and Boolean equations.


FIGURE 31 - FORM VIIIB OR/NAND LOGICAL OPERATIONS

### 3.9.3 Exclusive-OR/Exclusive-NOR Logical Operations

Operation Form VIIIC can be used to perform the exclusive-OR/exclusive-NOR logical combination of two selectable operands and route the results to one of four destinations. The operation microcode is:


$$
H=H I G H \text { LEVEL, L = LOW LEVEL }
$$

As shown above, the $A$ and $B$ sources are selectable by the $A 1, B 1$, and $B 2$ bits in their true or complementary form (bits $\mathrm{AO}, \mathrm{BO}$ ) to facilitate both exclusive-OR and exclusive-NOR operations. As implemented, see Figure 32, the exclusive-NOR function is performed when the sources are both true or both complemented. When either the $A$ or the $B$ source (not both) are complemented, the exclusive-OR function is performed. Both implementation and other/equal logic symbols are shown in Figure 32. Also provided are the function tables and Boolean equations.

|  | all true or all COMPLEMENT SOURCES | ONE SOURCE COMPLEMENTED |
| :---: | :---: | :---: |
| IMPLEMENTATION |  |  |
| function tables ( $\mathrm{H}=\mathrm{HIGH}$ LEVEL, L = LOW LEVEL) | $A$ $B$ $L^{\prime}$ <br> $L$ $L$ $H$ <br> $H$ $L$ $L$ <br> $L$ $H$ $L$ <br> $H$ $H$ $H$ <br> OP8 $=$ OP9 $=\mathrm{L}$ | $A$ $\bar{A}$ $B$ $Z^{\prime}$ <br> $L$ $H$ $L$ $L$ <br> $H$ $L$ $L$ $H$ <br> $L$ $H$ $H$ $H$ <br> $H$ $L$ $H$ $L$$B$ $\bar{B}$ $A$ - <br> $L$ $H$ $L$ $L$ <br> $L$ $H$ $H$ $H$ <br> $H$ $L$ $L$ $H$ <br> $H$ $L$ $H$ $L$ <br> OP8 $=\mathrm{H}, \mathrm{OP9}=\mathrm{L}$ <br> OP8 $=\mathrm{L}, \mathrm{OP9}=\mathrm{H}$ |
| other or equal symbols |  |  |
| BOOLEAN FUNCTIONS | $\begin{aligned} & \Sigma^{\prime}=A \odot B \\ & \Sigma^{\prime}=\overline{A \oplus B} \end{aligned}$ | $\Sigma^{\prime}=A \oplus B \quad \Sigma^{\prime}=A \oplus B$ |

FIGURE 32 - FORM VIIIC EXCLUSIVE-OR/EXCLUSIVE-NOR OPERATIONS

Operation Form IX is designed specifically to clear the $\Sigma^{\prime}$ bus force AG and LG low, and force EQ high; and, during this operation form data in the 'S481 registers, counters and latches remain unchanged unless directed to do otherwise by the asynchronous control inputs as shown in Figure 33.

The memory or program counter can be incremented (by one or two) on each clock transition, or the working register can be loaded on each clock. Additionally, the B input/output can be specified, as well as sources for the address or data out ports. States of the carry and overflow outputs are not interrupted.

$H=$ HIGH LEVEL, $L=$ LOW LEVEL, $X=$ IRRELEVANT

ASYNCHRONOUS CONTROLS:
SEL B INPUT/OUTPUT
SEL DOB SOURCE $\quad A G=$ ZERO
SEL AOB SOURCE
INCREMENT PC OR MC
INHIBIT PC AND/OR MC

$$
L G=Z E R O
$$

$$
\mathrm{EQ}=\mathrm{HIGH}
$$

### 3.11 OPERATION FORM X - CYCLIC REDUNDANCY CHARACTER ACCUMULATION

Operation Form X is a macroinstruction which can be used to update a 16 -bit cyclic redundancy character (CRC) partial sum in eight clock cycles, assuming 8 -bit data characters. The updated CRC partial sum resides in the working register. The flow diagram of this algorithm is illustrated in Figure 34.


FIGURE 34 - CYCLIC REDUNDANCY CHARACTER ACCUMULATION

Setup conditions include the existence or placement of the previous CRC partial sum in the working register, the CRC polynomial at the A input port, and the data character in the eight least significant bits of the extended working register. All decisions after setup are decoded on chip for each of the eight iterations. Microcontrol open-collector output OP9 of the LSP assumes control during the iterations to generate one of two microinstructions requires to accomplish the CRC update.

### 3.12 OPERATION FORM XI - SIGNED INTEGER DIVIDE

Operation Form XI consists of the micro/macroinstructions needed to perform the signed division of a double length dividend by an N -bit divisor in $\mathrm{N}+3$ clock times. After the division routine the quotient will reside in the extended working register (XWR) and the remainder will be in the working register (WR). Negative results are in two's complement. The flow diagram of this algorithm is illustrated in Figure 35.

Setup conditions include the existence or placement of the double length dividend in the WR, XWR and application of the divisor at the A input port. To obtain a legitimate result, the divisor must not be arithmetically zero as indicated during the start command by the EO output being low. The dividend must be of a nature that it could be generated by a signed multiply and add operation on the divisor. Status outputs LG, AG, C-OUT and OV are undefined, as is EQ after the start command.

After setup, all decisions are decoded on chip for start, iterate, iteration finish, fix remainder, and adjust quotient. The iterate macroinstruction (Form XIB) internally decodes the status of the stored signs, carry out, and working register and the OPS and OP9 microcontrol open-collector outputs of the MSP assume control generating one of four microinstructions required to accomplish the signed divide.

### 3.13 OPERATION FORM XII - UNSIGNED DIVIDE

Operation Form XII consists of micro/macroinstructions needed to perform the unsigned division of a double length dividend by an N -bit divisor in $\mathrm{N}+1$ clock times. After the division routine the binary magnitude quotient will reside in the extended working register (XWR) and the binary magnitude remainder will be in the working register (WR). The flow diagram of this algorithm is illustrated in Figure 36.

Setup conditions include the existence or placement of the double length dividend in the WR, XWR; application of the divisor at the A input port and that the last operation was not a divide command. To obtain a legitimate result, the N -bit divisor must be logically greater than the most-significant N -bits resident in the working register. A direct status on the arithmetically-greater-than (AG) output indicates that a valid (start) [AG $=\mathrm{H}]$, or invalid (abort) [ $A G=L$ ] setup condition exists.

After setup, all decisions are decoded on chip for start, iterate and finish. The iterate macroinstruction (Form XIIB) internally decodes the status of C-OUT or FORCE LOAD FLAG and the OP9 microcontrol open-collector output of the MSP assumes control generating one of two microinstructions required to accomplish the unsigned divide.

### 3.14 OPERATION FORM XIII - UNSIGNED MULTIPLY

Operation Form XIII consists of a macroinstruction which performs the unsigned multiplication of two N -bit words in N clock times. After the multiply routine the double length product is residing in the working register (most-significant N -bits) and the extended working register (least-significant N -bits). The flow diagram of this algorithm is illustrated in Figure 37.

Setup conditions include clearing the working register to all zeros, loading (not shifting) the multiplier into the extended working register, and applying the multiplicand at the A input port. Arithmetic shift commands must not occur between multiplier load and the first iteration. Status outputs (EQ, AG, LG, C-OUT and OV) are undefined during this algorithm.


FIGURE 35 - FORM XI-SIGNED INTEGER DIVIDE (SHEET 1 OF 2)


FIGURE 35 - FORM XI-SIGNED INTEGER DIVIDE (SHEET 2 OF 2)


FIGURE 36 - FORM XII-UNSIGNED DIVIDE (SHEET 1 OF 2)


FIGURE 36 - FORM XII-UNSIGNED DIVIDE (SHEET 2 OF 2)


## FIGURE 37 - FORM XIII-UNSIGNED MULTIPLY

The iterate macroinstruction internally decodes the status of the XWR LSB and the OP9 microcontrol open-collector output of the MSP assumes control generating one of two microinstructions required to accomplish the unsigned multiply.
3.15 OPERATION FORM XIV - SIGNED INTEGER MULTIPLY

Operation Form XIV consists of a macroinstruction which performs the signed multiplication of two N -bit signed integers in N clock times. After the multiply routine, the double precision signed product resides in the working register (most-significant N -bits) and the extended working register (least-significant N -bits). Negative products are in two's complement. The flow diagram of this algorithm is illustrated in Figure 38.

Setup conditions include clearing the working register to all zeros, loading (not shifting) the multiplier into the extended working register, and applying the multiplicand at the A input port. Arithmetic shifts must not occur between multiplier load and the first iteration. Status outputs (EO, AG, LG, C-OUT, and OV) are undefined during this algorithm.

The iterate macroinstruction internally decodes the status of the multiplier (XWR) sign-bit flag, the multiplier LSB, and the multiplier LSB flag and the OP8 and OP9 microcontrol open-collector outputs of the MSP assume control generating one of four microinstructions required to accomplish the signed multiply.


FIGURE 38 - FORM XIV-SIGNED INTEGER MULTIPLY

## 4. SPECIFICATIONS

Recommended operating conditions, electrical characteristics, and switching characteristics are provided in Tables 19 through 21.

TABLE 19
RECOMMENDED OPERATING CONDITIONS

|  |  | SN54LS481 |  |  | SN74LS481 |  |  | SN74S481 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voltage, $\mathrm{V}_{\text {CC }}$ |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 | V |
| High-level output voltage at EQ, OP8, OP9; $\mathrm{V}_{\mathrm{O}}$ |  |  |  | 5.5 |  |  | 5.5 |  |  | 5.5 | V |
| Low-level output current, IOL | AOP, BI/O, DOP, $\overline{\mathrm{CCO}} / \mathrm{OV}, \overline{\mathrm{COUT}}$ |  |  | 10 |  |  | 10 |  |  | 10 | mA |
|  | EQ, OP8, OP9 |  |  | 8 |  |  | 8 |  |  | 8 |  |
|  | WRLFT, WRRT, XWRLFT, XWRRT |  |  | 4 |  |  | 4 |  |  | 4 |  |
|  | X/LG, Y/AG |  |  | 16 |  |  | 16 | 16 |  |  |  |
| High-level output current, I OH | $B I / O, D O P$ <br> All other outputs or I/O except EQ, OP8, OP9 | 2 |  |  | 6.5 |  |  | 6.5 |  |  | mA |
| Width of clock pulse, $\mathrm{t}_{\mathrm{w}}$ | High logic level | 35 |  |  | 35 |  |  | 35 |  |  | ns |
|  | Low logic level | 25 |  |  | 25 |  |  | 25 |  |  |  |
| Clock frequency |  |  |  | 7 |  |  | 8 |  |  | 10 | MHz |
| Setup time, $\mathrm{t}_{\text {su }}$ | AI, BI/O Latch | 25 $\downarrow$ |  |  | 20】 |  |  | 15 $\downarrow$ |  |  | ns |
|  | $\mathrm{Al} \rightarrow$ WR | $25 \uparrow$ |  |  | 251 |  |  | $15 \uparrow$ |  |  |  |
|  | $\mathrm{AI}, \mathrm{BI} / \mathrm{O} \rightarrow \mathrm{ALU} \rightarrow \mathrm{MC}, \mathrm{PC}, \mathrm{WR}$, | $90 \uparrow$ |  |  | $80 \uparrow$ |  |  | $65 \uparrow$ |  |  |  |
|  | $\overline{\overline{C C I}, \overline{I N C M C}}$, $\overline{\text { INCPC, }} \overline{\text { LDWR }}$ | $50 \uparrow$ |  |  | $40 \uparrow$ |  |  | $30 \uparrow$ |  |  |  |
|  | OPO thru OP9 | $140 \uparrow$ | 90 |  | 1201 | 90 |  | $90 \uparrow$ | 60 |  |  |
|  | $\overline{\mathrm{CIN}}$ | $60 \uparrow$ |  |  | $50 \uparrow$ |  |  | $40 \uparrow$ |  |  |  |
|  | WRLFT, WRRT, XWRLFT, XWRRT | $40 \uparrow$ |  |  | $40 \uparrow$ |  |  | $30 \uparrow$ |  |  |  |
| Hold time, th | $\mathrm{Al}, \mathrm{BI} / \mathrm{O} \rightarrow$ Latch | 5 $\downarrow$ |  |  | $5 \downarrow$ |  |  | 10 $\downarrow$ |  |  | ns |
|  | $\mathrm{Al} \rightarrow$ WR | $10 \uparrow$ |  |  | $10 \uparrow$ |  |  | $10 \uparrow$ |  |  |  |
|  | $\mathrm{Al}, \mathrm{BI} / \mathrm{O} \rightarrow \mathrm{ALU} \rightarrow \mathrm{MC}, \mathrm{PC}, W \mathrm{R}, \mathrm{XWR}$ |  |  | $-20 \uparrow$ |  |  | $-20 \uparrow$ |  |  | $-20 \uparrow$ |  |
|  | CCI, INCMC, INCPC, LDWR | 01 |  |  | 01 |  |  | $10 \uparrow$ |  |  |  |
|  | OPO thru OP9 |  |  | $-10 \uparrow$ |  |  | $-10 \uparrow$ | $0 \uparrow$ |  |  |  |
|  | CIN |  |  | $-5 \uparrow$ | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  |  |
|  | WRLFT, WRRT, XWRLFT, XWRRT | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | $5 \uparrow$ |  |  |  |
| Operating free-air temperature range, $T_{A}$ |  | 55 | 25 | 125 | 0 | 25 | 70 | 0 | 25 | 70 | ${ }^{\circ} \mathrm{C}$ |

$\uparrow \downarrow$ The arrow indicates the transition of the clock input used for reference; $\uparrow$ for the low-to-high transition, $\downarrow$ for the high-to-low transition.

TABLE 20
ELECTRICAL CHARACTERISTICS OVER RECOMMENDED OPERATING FREE-AIR TEMPERATURE RANGE (UNLESS OTHERWISE NOTED)

| PARAMETER |  |  | TEST CONDITIONS $\dagger$ |  | MIN | $\begin{aligned} & \text { 'LS481 } \\ & \text { TYP } \ddagger \text { MAX } \end{aligned}$ | MIN | $\begin{aligned} & \mathrm{S} 481 \\ & \mathrm{YP} \ddagger \end{aligned}$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage (any input except POS) |  |  |  | 2 |  | 2 |  |  | V |
| VIL | Low-level input voltage (any input except POS) |  |  |  |  | 0.8 |  |  | 0.8 | V |
| VIK | Input clamp voltage |  | $V_{C C}=M 1 N, I_{1}=-18 \mathrm{~mA}$ |  |  | $-1.2$ |  |  | $-1.2$ | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | Any I/O or output | $\begin{aligned} & V_{C C}=\mathrm{MIN}, \mathrm{~V}_{I H}=2 \mathrm{~V} \\ & V_{I L}=0.8 \mathrm{~V}, \mathrm{IOH}=\mathrm{MAX} \end{aligned}$ | $54 S^{\prime}$ |  | 3.4 |  |  |  | V |
|  |  | except EQ, OP8, OP9 |  | 74S' | 2.7 | 3.4 | 2.7 | 3.4 |  |  |
| VOL Low-level output voltage |  |  | $\begin{aligned} & V_{C C}=\mathrm{MIN}, V_{I H}=2 \mathrm{~V} \\ & V_{I L}=0.8 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ |  |  | 0.5 |  |  | 0.5 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current | EQ, OP8, OP9 | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  |  | 100 |  |  | 100 | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage | POS | $V_{C C}=M A X, V_{1}=V_{C C}$ |  |  | 1 |  |  | 1 | mA |
|  |  | Any Other | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 |  |  | 1 |  |
| I/H | High-level input current | OPO, OP1, OP2, OP3, $\overline{\mathrm{CIN}}$ Any other except POS | $V_{C C}=M A X, V_{1}=2.7 \mathrm{~V}$ |  |  | 200 |  |  | 200 | $\mu \mathrm{A}$ |
|  |  |  |  |  |  | 100 |  |  | 100 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | OPO, OP1, OP2, OP3, $\overline{\mathrm{CIN}}$ | $\begin{aligned} & V_{C C}=M A X, \\ & V_{1}=0.5 V \end{aligned}$ |  |  | -4 |  |  | -8 | mA |
|  |  | WRRT, WRLFT, XWRRT, XWRLFT, $\overline{\text { CCI, CLOCK }}$ |  |  |  | -2 |  |  | -4 |  |
|  |  | Any Other |  |  |  | -1 |  |  | -2 |  |
| los | Short-circuit output current § | Any output or 1/O except EQ, OP8, OP9 | $V_{C C}=\mathrm{MAX}$ |  | $-30$ | -100 | $-30$ |  | -100 | mA |
| ICC | Supply current |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$ |  |  | $220 \quad 325$ |  | 345 | 425 | mA |

$\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}_{A}=25^{\circ} \mathrm{C}$.
§ Not more then one output should be shorted at a time.

## DESIGN GOAL

This document provides tentative information on a product in the development stage. Texas Instruments reserves the right to change or

TABLE 21
SWITCHING CHARACTERISTICS (OVER OPERATING RANGE OF VCC AND TA)

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | OPERATION ROUTING | SN54LS481 <br> TYP MAX |  | $\begin{gathered} \text { SN74LS481 } \\ \text { TYP MAX } \end{gathered}$ |  | SN74S481 <br> TYP MAX |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPD | AI, BI/O | DOP | $\begin{aligned} & \text { LATCH } \rightarrow \text { ALU } \\ & \text { DOP } \\ & \hline \end{aligned}$ | 56 | 100 | 56 | 80 | 42 | 65 | ns |
|  |  | $\mathrm{X}, \mathrm{Y}$ | LATCH $\rightarrow$ ALU | 40 | 65 | 40 | 55 | 32 | 45 | ns |
|  |  | $\overline{\text { COUT }}$ | LATCH $\rightarrow$ ALU | 35 | 65 | 35 | 55 | 30 | 40 | ns |
|  |  | EQ | LATCH $\rightarrow$ ALU | 55 | 100 | 55 | 85 | 45 | 65 | ns |
|  |  | OV | LATCH $\rightarrow$ ALU | 45 | 75 | 45 | 65 | 35 | 45 | ns |
|  |  | AG, LG | LATCH $\rightarrow$ ALU | 73 | 125 | 73 | 105 | 60 | 80 | ns |
|  |  | WRLFT,WRRT, XWRLFT, XWRRT | LATCH $\rightarrow$ ALU | 60 | 105 | 60 | 85 | 45 | 65 | ns |
| tPD | OPO thru OP9 | WRLFT,WRRT, XWRLFT, XWRRT |  | 100 | 160 | 100 | 140 | 75 | 105 | ns |
|  |  | X,Y, $\overline{C O U T}, \mathrm{EQ}$ |  | 75 | 130 | 75 | 115 | 55 | 80 | ns |
|  |  | OV |  | 75 | 135 | 75 | 120 | 60 | 90 | ns |
|  |  | AG, LG |  | 100 | 165 | 100 | 135 | 75 | 105 | ns |
|  |  | DOP |  | 90 | 150 | 90 | 130 | 70 | 100 | ns |
| tPD | AI,BI/O | BI/O | LATCH $\rightarrow$ ALU | 75 | 120 | 75 | 100 | 50 | 70 | ns |
| tPD | $\overline{C I N}$ | $\overline{\text { COUT }}$ |  | 35 | 60 | 35 | 50 | 30 | 40 | ns |
| tPD | $\overline{\mathrm{CCl}}$ | $\overline{\mathrm{CCO}}$ |  | 55 | 90 | 55 | 70 | 37 | 50 | ns |
| tPD | AO | AOP |  | 20 | 45 | 20 | 40 | 15 | 30 | ns |
| tPD | D0, D1 | DOP |  | 20 | 45 | 20 | 40 | 15 | 30 | ns |
| tpXZ | BI/O SEL or D0,D1 | BI/O or DOP |  | 20 | 35 | 20 | 30 | 15 | 30 | ns |
| tpxZ | OPO thru OP9 | WRLFT,WRRT,XWRLFT,XWRRT |  | 60 | 120 | 60 | 100 | 45 | 80 | ns |
| tpZX | BI/O SEL or DO,D1 | BI/O or DOP |  | 20 | 35 | 20 | 30 | 15 | 30 | ns |
| tpZX | OPO thru OP9 | WRLFT,WRRT, XWRLFT, XWRRT |  | 55 | 120 | 55 | 100 | 45 | 80 | ns |
| tPD | CLOCK | AOP, DOP | NO SHIFT | 32 | 70 | 32 | 60 | 26 | 40 | ns |
|  |  | WRLFT,WRRT, XWRLFT, XWRRT | [WR, XWR, <br> IBUS] <br> $\rightarrow$ SHIFTED <br> [WR,XWR,PC] $\rightarrow$ <br> ALU $\rightarrow$ SHIFTED | 50 | 90 | 50 | 85 | 40 | 65 | ns |
|  |  | AOP, DOP |  | 40 | 60 | 40 | 55 | 35 | 45 | ns |
|  |  | DOP, BI/O |  | 50 | 90 | 50 | 85 | 40 | 65 | ns |
|  |  | OV |  | 75 | 125 | 75 | 100 | 50 | 70 | ns |
|  |  | $\stackrel{\text { CCO }}{ }$ |  | 35 | 65 | 35 | 55 | 25 | 45 | ns |
|  |  | COUT |  | 60 | 105 | 60 | 85 | 47 | 65 | ns |
|  |  | OP8, OP9 |  | 85 | 140 | 85 | 120 | 75 | 90 | ns |
| tPD | $\overline{\mathrm{CIN}}$ | DOP |  | 56 | 100 | 56 | 75 | 42 | 60 | ns |

${ }^{\text {tPD }} \equiv$ Propogation delay
$t_{P \times Z} \equiv$ Disable time to $\mathrm{Hi}-\mathrm{Z}$
tpZX $\equiv$ Enable time ( $\mathrm{Hi}-\mathrm{Z}-\mathrm{To}$-Enable)


FIGURE 39 - PIN ASSIGNMENTS
DESIGN GOAL
This document provides tentative information on a product in the developmental stage. Texas Instruments reserves the right to change or discontinue this product without notice.


NOTE: Input pulses are supplied by a generator having the following characteristics: $t_{r} \leqslant 5 \mathrm{~ns}, \mathrm{tp} \leqslant 5 \mathrm{~ns}$, PRR $\geqslant 1 \mathrm{MHz}, Z O U T \approx 50 \Omega$

FIGURE 40. - SWITCHING TIMES - VOLTAGE WAVEFORMS


OCTOBER 1976

Information contained in this publication is believed to be accurate and reliable. However, responsibility is assumed neither for its use nor for any infringement of patents or rights of others that may result from its use. No license is granted by implication or otherwise under any patent or patent right of Texas Instruments or others.

Copyright © 1977
Texas Instruments Incorporated

## TABLE OF CONTENTS

1. INTRODUCTION
1.1 Architectural Features ..... 1
1.2 Operational Features ..... 1
1.3 Additional Features ..... 1
1.4 Technological Features ..... 2
2. FUNCTIONAL PIN DESCRIPTIONS ..... 3
3. DETAILED FUNCTIONAL DESCRIPTION
3.1 Programmable Logic Array ..... 4
3.1.1 PLA Description ..... 4
3.1.2 PLA Factory Programming ..... 4
3.2 SBP0400A Operation Register (OR) ..... 4
3.3 Status Outputs ..... 5
3.4 Arithmetic/Logic Unit (ALU) Description ..... 5
3.4.1 ALU Function Selection ..... 5
3.4.2 ALU Arithmetic Mode ..... 5
3.4.3 ALU Logical (Boolean) Mode ..... 6
3.4.4 ALU Carry and Look-Ahead Generator Functions ..... 6
3.5 Relative Position Control (POS1, POSO) ..... 7
3.6 Register File (RF0 $\rightarrow$ RF7) ..... 8
3.6.1 RF General Description ..... 8
3.6.2 RF Source/Destination Operands ..... 8
3.7 Program Counter (PC) - Register File Seven (RF7) ..... 10
3.7.1 General Description ..... 10
3.7.2 PC Configurations ..... 10
3.7.3 PC Count Sequences ..... 12
3.8 Address-Out Multiplexer (ADR MUX) ..... 12
3.9 A Bus ..... 12
3.10 B Bus ..... 12
3.11 Working Register (WR) ..... 12
3.11.1 General Description ..... 12
3.11.2 WR Source/Destination Operands ..... 12
3.11.3 WR Sourcing of ADR MUX ..... 14
3.12 Extended Working Register (XWR) ..... 14
3.12.1 XWR General Description ..... 14
3.12.2 XWR Source/Destination Operands ..... 15
3.12.3 XWR Sourcing of ADR MUX ..... 16
3.13 Data-Out Multiplexer (DO MUX) ..... 16
3.13.1 DO MUX General Description ..... 16
3.13.2 DO MUX Shift Accommodations ..... 17
3.14 Data-Out I-Multiplexer (DO IMUX) ..... 17
3.15 Data-Out J-Multiplexer (DO JMUX) ..... 18
3.16 Extended Working Register Multiplexer (XWR MUX) ..... 18
3.16.1 XWR MUX General Description ..... 18
3.16.2 XWR MUX Shift Accommodations ..... 18
3.17 Extended Working Register K-Multiplexer (XWR KMUX) ..... 19
3.18 Extended Working Register L-Multiplexer (XWR LMUX) ..... 20
3.19 Working Register Multiplexer (WR MUX) ..... 20

## TABLE OF CONTENTS (Continued)

4. SHIFT/CIRCULATE OPERATIONS
4.1 WR Single-Precision Shifts/Circulates ..... 20
4.1.1 (WR Plus ALUCIN) RSL $\rightarrow$ WR ..... 21
4.1.2 (WR Plus ALUCIN) LSL $\rightarrow$ WR ..... 21
4.1.3 (WR Plus ALUCIN) RSA $\rightarrow$ WR ..... 22
4.1.4 (WR Plus ALUCIN) LSA $\rightarrow$ WR ..... 22
4.1.5 (WR Plus ALUCIN) RCIR $\rightarrow$ WR ..... 22
4.1.6 (WR Plus ALUCIN) LCIR $\rightarrow$ WR ..... 23
4.2 WR,XWR Double-Precision Shifts/Circulates ..... 23
4.2.1 (WR Plus ALUCIN, XWR) RSL $\rightarrow$ WR,XWR ..... 24
4.2.2 (WR Plus ALUCIN, XWR) LSL $\rightarrow$ WR,XWR ..... 24
4.2.3 (WR Plus ALUCIN, XWR) RSA $\rightarrow$ WR,XWR ..... 25
4.2.3.1 Single-Signed Double-Precision RSA (MSP POSO=H) ..... 25
4.2.3.2 Double-Signed Double-Precision RSA (MSP POSO=L) ..... 25
4.2.4 (WR Plus ALUCIN, XWR) LSA $\rightarrow$ WR,XWR ..... 26
4.2.4.1 Single-Signed Double-Precision LSA (MSP POSO=H) ..... 26
4.2.4.2 Double-Signed Double-Precision (LSA (MSP POSO=L) ..... 26
4.2.5 (WR Plus ALUCIN, XWR) RCIR $\rightarrow$ WR, XWR ..... 27
4.2.6 (WR plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR ..... 27
4.3 Compound-Function WR,XWR Double-Precision Shifts/Circulates ..... 28
5. OPERATION SET (MICROINSTRUCTION SET) ..... 28
5.1 SBP0400A Microinstruction Overlap ..... 29
5.2 Operation-Select Word ..... 29
5.2.1 D-Fieid, Operation-Select Word ..... 29
5.2.1.1 D-Field $=$ LL ..... 29
5.2.1.2 D-Field = LH ..... 30
5.2.1.3 D-Field $=H L$ ..... 30
5.2.1.4 D-Field $=H H$ ..... 30
5.2.2 OP-Field, Operation-Select Word ..... 31
5.2.2.1 OP-Field ALU Function (Micro-Operation) Selection ..... 31
5.2.2.2 OP-Field Operand-Source/ALU Function/Operation-Result- Destination Selection ..... 34
5.2.3 S-Field, Operation-Select Word ..... 34
5.3 Index To Microinstructions By Operation Form ..... 34
5.3.1 Operation - Form I ..... 35
5.3.2 Operation - Form II ..... 35
5.3.3 Operation - Form III ..... 35
5.3.4 Operation - Form IV ..... 36
5.3.5 Operation - Form V ..... 36
5.3.6 Operation - Form VI ..... 37
5.4 Index To Microinstructions By Source Operands ..... 37
6. INTERFACING
6.1 Input Circuit ..... 40
6.1.1 Sourcing Inputs ..... 41
6.1.2 Terminating Unused Inputs ..... 41
6.2 Output Circuit ..... 41
6.2.1 $R_{L(\max )}$ Calculation for Output Source Current ..... 42
6.2.2 $\quad \mathrm{R}_{\mathrm{L}}(\min )$ Calculation for Output Source Current ..... 44
6.3 Bidirectional Input/Output Circuit ..... 44

## TABLE OF CONTENTS (Continued)

7. POWER SOURCE ..... 44
8. ELECTRICAL AND MECHANICAL SPECIFICATIONS
8.1 Recommended Operating Conditions ..... 46
8.2 Electrical Characteristics ..... 46
8.3 SBP0400A and SBP0401A Switching Characteristics ..... 47
8.4 SBP0401A Operation Select Switching Characteristics ..... 47
8.5 Ordering Information ..... 51

## LIST OF ILLUSTRATIONS

Figure 1 Functional Block Diagram ..... 2
Figure 2 Single-Level ALU Carry Look-Ahead and Bit-Slice Relative Positions ..... 6
Figure 3 64-Bit System With ALU Full-Carry Look-Ahead ..... 7
Figure 4 Execution of Typical ALU Operation ..... 7
Figure 5 Typical Operation Executions ..... 9
Figure 6 16-Bit Program Counter ..... 11
Figure 7 12-Bit Program Counter ..... 11
Figure 8 Right-Shift Logical - Single Precision (RSL - SP) ..... 21
Figure 9 Left Shift Logical - Single Precision (LSL - SP) ..... 21
Figure 10 Right Shift Arithmetic - Single Precision (RSA - SP) ..... 22
Figure 11 Left Shift Arithmetic - Single Precision (LSA - SP) ..... 22
Figure 12 Right Circulate - Single Precision (RCIR - SP) ..... 22
Figure 13 Left Circulate - Single Precision (LCIR - SP) ..... 23
Figure 14 Right Shift Logical - Double Precision (RSL - DP) ..... 24
Figure 15 Left Shift Logical - Double Precision (LSL - DP) ..... 24
Figure 16 Right Shift Arithmetic - Single Sign/Double Precision (RSA - SS/DP) ..... 25
Figure 17 Right Shift Arithmetic - Double Sign/Double Precision (RSA - DS/DP) ..... 25
Figure 18 Left Shift Arithmetic - Single Sign/Double Precision (LSA - SS/DP) ..... 26
Figure 19 Left Shift Arithmetic - Double Sign/Double Precision (LSA - DS/DP) ..... 26
Figure 20 Right Circulate - Double Precision (RCIR - DP) ..... 27
Figure 21 Left Circulate - Double Precision (LCIR - DP) ..... 27
Figure 22 Typical 16-Bit Machine ..... 40
Figure 23 Schematics of Equivalent Inputs, Outputs, Inputs/Outputs ..... 41
Figure 24 Typical Input Characteristics ..... 41
Figure 25 Typical Output Characteristics ..... 42
Figure 26 Output Load Resistor Calculations ..... 43
Figure 27 Injector Current Calculations ..... 45
Figure 28 Injector-Node Voltage Vs. Free-Air Temperature ..... 45
Figure 29 Injector-Node Voltage Vs. Injector Current ..... 45
Figure 30 Propagation Delay Times - SBP0400A Synchronous Operations ..... 48
Figure 31 Propagation Delay Times - Asynchronous Operations ..... 49
Figure 32 Propagation Delay Times - Asynchronous Operations ..... 49
Figure 33 Switching Times Load Circuits ..... 50
Figure 34 Typical Switching Characteristics ..... 50
Figure 35 Plastic Dual-In-Line Package ..... 51
Figure 36 Ceramic Dual-In-Line Package ..... 51

## LIST OF TABLES

Table 1 ALU Function-Select Table ..... 6
Table 2 Typical Add Times (DIB Plus WR) From $\uparrow$ Clock To DOB ..... 7
Table 3 Position Control Functions ..... 8
Table 4 RF Source Operands ..... 8
Table 5 RF Destination Operands ..... 9
Table 6 Program Counter Incrementation ..... 10
Table 7 Working Register Source Operands ..... 13
Table 8 Working Register Destination Operands ..... 14
Table 9 Extended Working Register Source Operands ..... 15
Table 10 Working Register Destination Operands ..... 15
Table 11 DO MUX Transfers ..... 16
Table 12 DO IMUX Transfers To WRLFT ..... 17
Table 13 DO JMUX Transfers to WRRT ..... 18
Table 14 XWR MUX Transfers ..... 19
Table 15 XWR KMUX Transfers To XWRLFT ..... 19
Table 16 XWR LMUX Transfers To XWRRT ..... 20
Table 17 WR Single-Precision Shifts/Circulates ..... 21
Table 18 WR, XWR Double-Precision Shifts/Circulates ..... 23
Table 19 Compound-Function WR, XWR Double-Precision Shifts/Circulates ..... 28
Table 20 D-Field = HL ..... 30
Table 21 D-Field $=\mathrm{HH}$ ..... 31
Table 22 ALU Function (Micro-Operation Select) ..... 32
Table 2316 Function ALU Operations ..... 32
Table 24 Register Transfer Operations ..... 33
Table 25 Register Clear and Preset Operations ..... 34
Table 26 RF Selection ..... 34
Table 27 Operation Form I ..... 35
Table 28 Operation Form II ..... 35
Table 29 Operation Form III ..... 35
Table 30 Operation Form IV ..... 36
Table 31 Operation Form V ..... 36
Table 32 Operation Form VI ..... 37
Table 33 DIP Source Operands ..... 37
Table 34 RF Source Operands ..... 38
Table 35 XWR Source Operands ..... 38
Table 36 WR Source Operands ..... 39
Table 37 Sourcing SBPO400 Inputs ..... 42
Table 38 Terminating Unused Inputs ..... 42
Table 39 Output Load Resistor Values ( $R_{L}$ ) ..... 44
Table 40 Injector Current Limiting Resistor Values ..... 45

## 1. INTRODUCTION

The SBP0400A and SBP0401A are 4-bit expandable parallel binary processor elements, each monolithically integrating 1660 functional gates. These controller/processor building blocks combine the unique properties of Integrated Injection Logic ( 12 L ) with a microprogrammable bit-slice architecture to offer a high degree of performance and design flexibility. Each can provide the basis for efficient, low-cost solutions to a wide range of applications, from basic sequential controllers to advanced multiprocessor systems for either industrial or military environments.

### 1.1 ARCHITECTURAL FEATURES

Primary among the SBP0400A and SBP0401A architectural features are:

- Microprogrammable, bit-slice design expandable in 4-bit multiples
- Separate data-in, data-out, address-out and control ports provide flexible parallel device access
- 16 -function arithmetic/logic unit (ALU) with symmetrical subtraction and fully carry look-ahead capability
- 8-word general register file including program counter with independent incrementor
- Two 4-bit working registers for both single- and double-length operations
- Dual scaled-shifters with on-chip handling of end conditions
- Versatile factory programmable logic array (PLA) generates on-chip control transformation
- The SBP0400A features an on-chip pipelining operation register
- The SBP0401A, with asynchronous microinstruction decode, is designed for use in externally pipelined systems


### 1.2 OPERATIONAL FEATURES

The functional power of the SBP0400A or SBP0401A is characterized by their ability to perform, within a single clock cycle, any one of a repertoire of 512 standard operations:

- Operand modifications or combinations via eight arithmetic or eight Boolean functions of the ALU
- Double length accumulator with full bidirectional single/double precision arithmetic/logical/circulate shift capabilities, including sign protection
- Single clock ALU/shift combinations simplify implementation of iterative multiple and non-restore divide algorithms
- Special select operations and transfers


### 1.3 ADDITIONAL FEATURES

When provided with external control for sequencing of its operation set, either an SBP0400A or SBP0401A based system design can efficiently emulate a large number of existing systems with full software compatibility and no loss of software investment. Or complete application-tailoring of custom instructions may be accomplished for any design. Additional features are:

- Independent program counter with independent access controls (and the internal operation register of the SBP0400A) provide instruction look-ahead capability (pipelining)
- Relative position control defines bit-slice rank in N -bit applications


## tentative data sheet

This document provides tentative information on a new product. Texas Instruments reserves
the right to change specifications for this

- Serial and parallel access to or from working registers
- Word or byte incrementation of program counter
- ALU bypass for direct register-file access

TECHNOLOGICAL FEATURES
These processor elements, fabricated with Integrated Injection Logic ( $\left.\right|^{2}$ L), feature an extremely wide performance range.

- Constant speed-times-power performance over an injector current range covering three orders of magnitude ( $10^{3}$ )
- Operates from a single dc power source capable of 1.1 volt minimum at desired injector current
- ALU/shift operation time . . . 240 nanoseconds typical at 200 mW nominal power
- Fully TTL compatible at nominal injector current
- $\quad$ Static operation with positive ( $\uparrow$ ) edge-triggered storage
- SBP0400AC and SBP0401AC operate over $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ industrial temperature range
- SBP0400AM and SBP0401AM operate over full $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ military temperature range


FIGURE 1 - FUNCTIONAL BLOCK DIAGRAM

## 2. FUNCTIONAL PIN DESCRIPTIONS

| PIN NUMBER | PIN NAME | PIN FUNCTION | INPUT, OUTPUT, OR INPUT/OUTPUT |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & 1 \\ & 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { D1 } \\ & \text { D0 } \\ & \hline \end{aligned}$ | 2-bit, " $D$ ' field of the Operation-Select Word. | Input Input |
| $\begin{aligned} & 3 \\ & 4 \\ & 5 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{S} 2 \\ & \mathrm{~S} 1 \\ & \mathrm{So} \\ & \hline \end{aligned}$ | 3-bit, " S " field of the Operation-Select Word designates, in general, a particular RF as an operand source/destination. | Input Input Input |
| 6 | XWRLFT | Bidirectional I/O, low active, shift accommodation for the XWR. Receives double-precision right-shift data; outputs double-precision left-shift data. Becomes XWRLFT (high active) internally. | Bidirectional Input/output |
| 7 | XWRRT | Bidirectional I/O, low active, shift accommodation. Receives double-precision left-shift data; outputs double-precision right-shift data. Becomes XWRRT (high active) internally. | Bidirectional Input/output |
| 8 | XWR <br> MSB/LSB | MSB of the input to the XWR if in the most-significant 4 bit slice position (MSP) and LSB input to the XWR if in the least-significant 4-bit slice position (LSP). | Output |
| 9 | $\overline{\text { WRRT }}$ | Bidirectional I/O, low-active, shift accommodation for ALU output data. Receives left-shift data. Outputs right-shift data. Becomes WRRT (high active) internally. | Bidrectional Input/output |
| 10 | $\overline{\text { WRLFT }}$ | Bidirectional I/O, low-active, shift accommodation for ALU output data. Receives right-shift data; outputs left-shift data. Becomes WRLFT (high active) internally. | Bidirectional Input/output |
| 11 | ALUCIN | Receives, high-active, ALU ripple carry-in data. | Input |
| $\begin{aligned} & 12 \\ & 13 \\ & 14 \\ & 15 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { DOP0 } \\ & \text { DOP1 } \\ & \text { DOP2 } \\ & \text { DOP3 } \\ & \hline \end{aligned}$ | 4-bit, parallel, high active, data-out port. (DOP3 $\rightarrow$ DOPO) | Output <br> Output <br> Output <br> Output |
| $\begin{aligned} & 16 \\ & 17 \\ & 24 \\ & 25 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { DIP3 } \\ & \text { DIP2 } \\ & \text { DIP1 } \\ & \text { DIP0 } \end{aligned}$ | 4-bit, parallel, high active, data-in port (DIP3 $\rightarrow$ DIPO) | Input <br> Input <br> Input <br> Input |
| 18 | $\overline{\text { PCCIN }}$ | In all positions, directs the program counter to increment by 1 or 2 , depending on the level applied to ENINCBY2, on the next low-to-high clock transition. | Input |
| 19 | $\begin{aligned} & \hline \overline{\text { PCCOUT// }} \\ & \text { BMSB } \end{aligned}$ | In any position but MSP, PCCOUT is the program counter output applied to the next more significant package PCCIN. In the MSP, outputs the MSB of the " $B$ " bus. | Output |
| 20 | GND | Common or ground terminal. | Supply Common |
| $\begin{aligned} & 21 \\ & 22 \end{aligned}$ | $\begin{aligned} & \text { POSO } \\ & \text { POS1 } \end{aligned}$ | Directs internal and input/output end-conditions required to define the relative position of each SBP0400A/SBP0401A when a number is cascaded to implement $>4$-bit word lengths. See double-precision shift data flow. | Input Input |
| 23 | $\begin{aligned} & \text { ENINCBY2/ } \\ & \text { AMSB } \end{aligned}$ | In the least-significant 4-bit slice position (LSP), ENINCBY2 $=\mathrm{H}$ in conjunction with PCCIN $=L$ directs the PROGRAM COUNTER to increment by a displacement of 2 on the next clock. In the most-significant 4-bit slice position (MSP), outputs the MSB of the " $A$ " bus. | Bidirectional Input/output (LSP) (MSP) |
| 26 | CLOCK | Clocks all synchronous registers on positive transition. | Input (Edge-triggered) |
| 27 | ALU $=0$ | Active high open-collector output indicates that the four ALU outputs are low (equal zero). | Output |
| $\begin{aligned} & 28 \\ & 29 \\ & 31 \\ & 32 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { AOP3 } \\ & \text { AOP2 } \\ & \text { AOP1 } \\ & \text { AOPO } \\ & \hline \end{aligned}$ | 4-bit, parallel, high-active, address-out port. (AOP3 $\rightarrow$ AOPO) | Output <br> Output <br> Output <br> Output |
| 30 | $\begin{aligned} & \text { PC } \\ & \text { PRIORITY } \end{aligned}$ | Selects program counter to the address-out port (high active). Overrides internal direction of address-out port. | Input |
| 33 | $\overline{\mathrm{P}}$ | ALU Carry-propagate | Output |
| 34 | G | ALU Carry-generate | Output |
| 35 | ALUCOUT | Outputs, high active, ALU ripple carry-out data. | Output |
| $\begin{aligned} & 36 \\ & 37 \\ & 38 \\ & 39 \\ & \hline \end{aligned}$ | OP3 <br> OP2 <br> OP1 <br> OPO | This 4-bit "OP' field of the Operation-Select Word designates in general, 1 of 16 ALU functions. | Input <br> Input <br> Input <br> Input |
| 40 | INJECTOR | Supply current source. | Supply input |

## 3. DETAILED FUNCTIONAL DESCRIPTION

The SBP0400A and SBP0401A architectures are formed by the various functional blocks and interconnecting data/control paths shown in Figure 1. Parallel data/control flow to/from the processor element is accomplished through 1) the data-in port (DIP) via the 4-bit data-in bus (DIB), 2) the data-out port (DOP) via the 4-bit data-out bus (DOB), 3) the address-out port (AOP) via the 4 -bit address-out bus (AOB), and 4) the operation-select port (OSP) via the nine operation-select inputs. The format of the op-select word is:

9-BIT OPERATION-SELECT WORD


The SBPO400A contains a 20 -bit operation register which stores, on the clock positive transition, the present (resident) operation decoded by the transformation PLA. The SBP0401A, containing the identical operation decode 20 -output PLA, derives the present (resident) operation from the steady-state input at the nine op-select inputs. The '0401A is designed specifically for use in systems utilizing the SN54S/74S482 control element which, in addition to generating next control-memory addresses and storing interrupt/subroutine addresses, contains an on-chip control memory address register to assist with the system pipelining functions. Thus, the need for an operation register in the SBP0401A processor element is eliminated.

### 3.1 PROGRAMMABLE LOGIC ARRAY (PLA)

### 3.1.1 PLA Description

The programmable logic array (PLA) is a factory-programmable block of combinational logic which forms the control operation transformation center. Nine bits of encoded microinstruction data are presented to the PLA via the 9 -bit operation-select word input lines. The PLA decodes/translates this encoded data to generate a 20 -bit internal microinstruction. The various micro-operation fields of this microinstruction condition the appropriate functional blocks and buses for microinstruction execution.

On the positive going ( $\uparrow$ ) transition at the clock input, this 20 -bit microinstruction is stored in the operation register (OR) of the SBP0400A.

### 3.1.2 PLA Factory Programming

The standard factory PLA program provides a flexible, universal, repertoire of 459 unique operations. However, the PLA can be factory programmed to provide, within the constraint of 62 AND terms and 20 OR terms, a personality tailored to meet custom requirements.

### 3.2 SBP0400A OPERATION REGISTER (OR)

The 20 -bit operation register (OR) of the SBP0400A is a D-type edge-triggered register which, on each positive transition at the clock input, loads the present PLA output. The OR, as loaded, continuously enables the various
'0400A functional blocks for execution of the "present" microinstruction while the PLA may be simultaneously decoding/translating the "next" microinstruction.

### 3.3 STATUS OUTPUTS

Status outputs for the operation in process are designed specifically to simplify system implementation by providing direct access to those status bits used with the classical and highly efficient multiply and divide algorithms. The status outputs consist of:
a. AMSB and BMSB - In the MSP these outputs provide direct access to the sign bits of data/operands entering the ALU.
b. XWR MUX MSB - In the MSP this output provides direct access to the data bit which can become the XWR sign bit during left-shift operations. It is useful for determining overflow (impending change of the XWR sign bit) in double-signed arithmetic operations, shifting operations, or fix-up routines in iterative sign-magnitude divide algorithms.
c. XWR MUX LSB - In the LSP this output provides direct access to the data bit which can become the XWR LSB during right-shift operations. It is useful for looking ahead during iterative multiply and divide routines to setup the next micro-operation.
d. $\quad$ ALU $=0-\operatorname{In}$ the LSP, IP, and MSP this output provides a direct indication that all four of the ALU outputs are low. In an expanded word length system all of the ALU = 0 outputs can be dot-AND connected to provide, on a single-line, an indication that all of the ALU outputs are low (equal zero).
e. ALUCOUT - In the LSP, IP, and MSP this output provides a direct carry out from each of the 4-bit slices. In the MSP the ALUCOUT can be used for determining ALU overflow.

### 3.4 ARITHMETIC/LOGIC UNIT (ALU) DESCRIPTION

The 4-bit parallel, binary, arithmetic/logic unit (ALU) is the operand combination/modification mechanism. Under direction of the present micro-operation, the ALU performs 1 of 16 arithmetic/Boolean operations on either or both of two operands present at it's $A$ and $B$ input ports. Operand sources which may access the $A$ input port of the ALU via the $A$ multiplexer are the register file (RF) and data-in port (DIP); operand sources which may access the $B$ input port of the ALU via the B multiplexer are the data-in port (DIP), working register (WR), and extended working register (XWR).

### 3.4.1 ALU Function Selection

In general, an ALU function is specified via the 4-bit OP-field (OP3 $\rightarrow$ OPO) of the operation-select word as shown in Table 1. This field is presented to the PLA via the operation-select word input lines. The PLA translates OP3, OP2, OP1, OPO into a 4-bit micro-operation field which ultimately selects the ALU mode. The OP3 bit functions similarly to an ALU mode control in that 1) a low-logic level places the ALU in an arithmetic mode, and 2 ) a high-logic level places the ALU in a logic mode. OP2 $\rightarrow$ OPO selects a particular function within the specified ALU mode.

### 3.4.2 ALU Arithmetic Mode

Functionally similar to the popular TTL ALU's, such as the SN54S/74S181 and SN54S/74S281, the arithmetic functions (see Table 1) include symmetrical subtraction whereby either A minus B or B minus A may be employed to simplify data flow. Other arithmetic-type functions include simple $A$ plus $B, A$ plus $B$ plus carry-in, preset all high, clear all low, and direct symmetrical generation of complements ( 1 's or 2 's) for either $A$ or $B$.

TABLE 1
ALU FUNCTION-SELECT TABLE


### 3.4.3 ALU Logical (Boolean) Mode

Functionally similar to the popular ALUs such as the SN54S/74S181 and SN54S/74S281, the ALU logical functions (see Table 1) include AND, OR, exclusive OR, exclusive NOR, and four symmetrical mixed combinational functions of the ALU's A and B operands.

### 3.4.4 ALU Carry and Look-Ahead Generator Functions

These processor elements have accommodations for ALU ripple carry-in (ALUCIN) and ALU ripple carry-out (ALUCOUT); and in order to facilitate look-ahead carry generation across expanded word sizes, each has output accommodations for ALU carry-generate data ( $\bar{G}$ ) and ALU carry-propagate data $(\bar{P})$. When these accommodations are utilized in conjunction with SN54/74182 look-ahead carry generators, ALU add/subtract times may be significantly improved over those times where only ripple-carry techniques are employed. Only one SN54/74182 (Figure 2) is required to provide look-ahead carry generation across an expanded system of from two to four 4-bit slice processor elements. A second level of look-ahead carry generation may be employed (Figure 3) for systems expanded up to 64 bits. Typical ALU add times are shown in Table 2, and are illustrated in Figure 4.


FIGURE 2 - SINGLE-LEVEL ALU CARRY LOOK-AHEAD AND BIT-SLICE RELATIVE POSITIONS


FIGURE 3-64-BIT SYSTEM WITH ALU FULL-CARRY LOOK-AHEAD

TABLE 2
TYPICAL SBP0400A ADD TIMES (DIP PLUS WR) FROM $\uparrow$ CLOCK TO DOB

| TYPE OF CARRY | TWO 4-BIT <br> WORDS | TWO 8-BIT <br> WORDS | TWO 16-BIT <br> WORDS | TWO 32-BIT <br> WORDS | TWO 64-BIT <br> WORDS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| RIPPLE | 240 ns | 285 ns | 405 ns | 645 ns | $1.1 \mu \mathrm{~s}$ |
| SINGLE-LEVEL LOOK-AHEAD* | NA | 300 ns | 300 ns | 405 ns | 525 ns |
| SECOND-LEVEL LOOK-AHEAD* | NA | NA | NA | 315 ns | 315 ns |

*LOOK-AHEAD IS SN54/74182, AND INJECTOR CURRENT IS 200 mA .


FIGURE 4 - EXECUTION OF TYPICAL ALU MICRO-OPERATION
3.5 RELATIVE POSITION CONTROL (POS1, POS0)

The 2-bit relative position control (POS1, POSO) encodes the relative positional rank of each individual processor element in an expanded word length system. As shown in Figure 2, the three positional rank possibilities are: 1) most significant position/ package (MSP), 2) intermediate position/package (IP), and 3) least significant position/package (LSP).

Consequent to encoded positional rank, the relative position control (POS1, POS0), as shown in Table 3 dictates for each individual 4 -bit slice in an expanded word length system: 1) the manner in which data shifts/circulates are to be accomplished, and 2) a particular assignment for each individual multifunction I/O accommodation.

TABLE 3
POSITION CONTROL FUNCTIONS

| INPUTS |  |  |  | MULTIFUNCTION I/O <br> POS1 |  | POSO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

### 3.6 REGISTER FILE (RF0 $\rightarrow$ RF7)

### 3.6.1 RF General Description

The register file (RF) is an 8 -word by 4 -bit set of D-type edge-triggered registers. Any one of the eight registers may be selected as an operand source and/or operation-result destination. Register selection is accomplished via the 3-bit, $S$-field (S2 $\rightarrow$ SO) of the operation-select word. This field is presented to the PLA via the operation-select word input lines. The PLA translates S2, S1, S0 into a 3-bit micro-operation field which ultimately selects a particular register within the file.

### 3.6.2 RF Source/Destination Operands

Register file source and destination operands are listed in Tables 4 and 5 respectively. When the register file is used as a destination, the source data is recognized only when a low-level condition exists at the clock input. As shown in Figure 5 , source data can change during the low-level clock condition as long as the setup time prior to the low-to-high transition of the clock input is satisfied.

TABLE 4
RF SOURCE OPERANDS

| OPERATION | OP FORM | OP-FIELD $\text { OP3 } \rightarrow \text { OPO }$ | $\begin{aligned} & \text { D-FIELD } \\ & \text { D1 } \rightarrow \text { D0 } \end{aligned}$ | $\begin{aligned} & \text { S-FIELD } \\ & \text { S2 } \rightarrow \text { SO } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & R F \rightarrow D O P \\ & R F \rightarrow X W R \\ & R F A L \cup W R \rightarrow R F \\ & R F A L \cup W R \rightarrow W R \end{aligned}$ | 111 b <br> IIIc <br> la <br> Ib | LLLL <br> LLLH <br> LLLL $\rightarrow \mathrm{HHHH}$ <br> LLLL $\rightarrow$ HHHH | HL <br> HL <br> LL <br> LH | LLL $\rightarrow \mathrm{HHH}$ <br> LLL $\rightarrow$ HHH <br> LLL $\rightarrow$ HHH <br> LLL $\rightarrow \mathrm{HHH}$ |
| RF plus DIP plus ALUCIN $\rightarrow$ RF <br> RF plus DIP plus ALUCIN $\rightarrow$ WR <br> RF plus DIP plus ALUCIN $\rightarrow$ XWR <br> (RF plus WR plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | IId <br> $11 b$ <br> IIc <br> IVd | LHHH <br> LHLL <br> LHLH <br> HLLH | HL HL HL HL | $\begin{aligned} & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \end{aligned}$ |
| (RF plus WR plus ALUCIN,XWR) RSA $\rightarrow$ WR, XWR <br> RF plus WR plus ALUCIN $\rightarrow$ XWR <br> RF plus XWR plus ALUCIN $\rightarrow$ WR <br> RF plus XWR plus ALUCIN $\rightarrow$ XWR | IVi <br> Ila <br> Ile <br> III | HLHH <br> LLHH <br> HHLL <br> HHLH | HL HL HL HL | $\begin{aligned} & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \end{aligned}$ |

NOTE: When PC priority is low WR $\rightarrow$ AOP

TABLE 5
RF DESTINATION OPERANDS

| OPERATION | OP FORM | OP-FIELD OP3 $\rightarrow$ OPO | $\begin{aligned} & \text { D.FIELD } \\ & \text { D1 } \rightarrow \text { DO } \end{aligned}$ | $\begin{aligned} & \text { S.FIELD } \\ & \text { S2 } \rightarrow \text { SO } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| DIP $\rightarrow$ RF | 1110 | HHHH | HL | LLL $\rightarrow$ HHH |
| XWR plus ALUCIN $\rightarrow$ RF | 119 | HHHL | HL | $L L L \rightarrow \mathrm{HHH}$ |
| RF ALU WR $\rightarrow$ RF | 1 a | LLLL $\rightarrow$ HHHH | LL | LLL $\rightarrow$ HHH |
| RF plus DIP plus ALUCIN $\rightarrow$ RF | 11 d | LHHH | HL | LLL $\rightarrow$ HHH |

NOTE: When PC priority is low WR $\rightarrow$ AOP


NOTE: THE SAME CLOCK(1)THAT EXECUTES OPERATION(1)LOADS OPERATION(2)INTO THE 'O4OOA OR.


FIGURE 5-TYPICAL OPERATION EXECUTIONS

### 3.7 PROGRAM COUNTER (PC) - REGISTER FILE SEVEN (RF7)

### 3.7.1 General Description

RF7 of the register file features the added flexibility of performing as a program counter (PC). Independent of the "present" microinstruction, RF7 may be incremented by a displacement of 1 or 2 . Incrementation is accomplished synchronously with the clock and selected, as shown in Table 6, via the multifunction $\overline{\mathrm{PCCIN}}$ and ENINCBY2 inputs as defined by the relative-position control (see Table 3). For cascading purposes, RF7 overflow is provided via the $\overline{\text { PCCOUT }}$ output. Furthermore, RF7 features an independent output bus which allows direct access at the AOP via the ADR multiplexer. When the PC PRIORITY input is taken to a high-logic level, operation select control of the ADR multiplexer is overridden allowing the PC to source the AOP.

TABLE 6

## PROGRAM COUNTER INCREMENTATION

| RELATIVE POSITION |  |  | PC IS <br> INCREMENTED |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| LSP | IP | MSP | INPUT | ON NEXT CLOCK |
| BY |  |  |  |  |

Instruction look-ahead techniques may be employed to boost the system-level efficiency. While the internal operation register of the SBP0400A is directing execution of the "present" microinstruction, the PC may be independently updated to address/fetch data for the "next" microinstruction. In this manner, when the "next" microinstruction becomes the "present" microinstruction as evidenced by its residence in the 0400A OR, steps will have already been taken to fetch an associated data operand.

The SBP0401A, designed for use with the SN54S/74S482 control element, can employ the control memory address register of the 'S482 and other system registers to implement instruction look-ahead or overlap.

### 3.7.2 PC Configurations

Typical configurations for use of the program counter in an expanded wordlength system are illustrated in Figures 6 and 7. The BMSB/(PCCOUT multifunction output may be time multiplexed (see Figure 6) to provide both BMSB and PC overflow (maximum count) status. Under direction of the relative position control (POS1, POS0), the BMSB is available (see Table 3) when POS1 is high, but if POS1 is taken low, $\overline{\text { PCCOUT }}$ is available. After time $t_{0}$ the PC contents of the most significant (MSP) will persist until the next L-to-H clock transition. Thus, the BMSB, then $\overline{\text { PCCOUT }}$ data may both be obtained within a single microcycle ( 1 clock period).

The PC technique shown in Figure 7 may be employed if the required PC wordlength is 4 -bits shorter than the processor wordlength. In this situation, the PC's maximum count status is available from the PCCOUT output of the next-to-MSP (IP) package.


FIGURE 6-16-BIT PROGRAM COUNTER


FIGURE 7-12-BIT PROGRAM COUNTER

### 3.7.3 PC Count Sequences

PC count sequences initiated at the $\overline{\text { PCCIN }}$ and ENINCBY2 inputs of the LSP of an expanded wordlength system are shown in Figure 7. An increment-by- 1 command ( $\overline{\mathrm{PCCIN}}=\mathrm{L}$, ENINCBY2 $=\mathrm{L}$ ) advances the PC from 4088 to 4089 synchronously with the $t_{2}$ clock; an increment-by- 2 command ( $\overline{\mathrm{PCCIN}}=\mathrm{L}$, ENINCBY2 $=\mathrm{H}$ ) advances the PC from 4089 to 4091 synchronously with the $t_{3}$ clock; a PC disable-increment command ( $\overline{P C C I N}=H$ ) retains the PC at its present count status. When the PC is at maximum count, an increment-by-1 command ( $\overline{\mathrm{PCCIN}}=\mathrm{L}$, ENINCBY2 $=\mathrm{H}$ ) conditions the $\overline{P C C O U T} / \overline{P C C I N}$ interpackage carry accommodations such that the PC will increment to zero synchronously with the $\mathrm{t}_{8}$ clock; when the PC is at maximum-count-minus-1 ( $\mathrm{N}-1$ ), an increment-by- 2 command $(\overline{\text { PCCIN }}=\mathrm{L}$, ENINCBY2 $=\mathrm{H})$ conditions the $\overline{\mathrm{PCCOUT}} / \overline{\mathrm{PCCIN}}$ interpackage carry accommodations such that the PC will increment to zero synchronously with the $t_{9}$ clock. A maximum count output will be generated at $\mathrm{N}-1$ if the PC is instructed to count by two. This is shown in the supplementary state table of Figure 7.

### 3.8 ADDRESS-OUT MULTIPLEXER (ADR MUX)

The address-out multiplexer (ADR MUX) is a multiport multiplexer which selects either the WR, XWR, or program counter (PC) for transfer to the address-out port (AOP) via the address-out bus (AOB). When the PC PRIORITY input is logic-level low, ADR MUX transfer of the WR or XWR is selected by the resident operation; when the PC PRIORITY input is logic-level high, resident operation direction of the ADR MUX is overridden allowing the PC to source the AOP.

### 3.9 A BUS

In addition to 4-bit parallel data transfers, the most significant bit (MSB) of the A bus is available at the multifunction AMSB output if the SBP0400A or SBP0401A is in the most significant position (MSP) as defined by the relative-position control. The AMSB output may be used to monitor the sign-bit of A bus data, or in conjunction with the BMSB and DOP3 (MSP) outputs, to detect an impending ALU overflow condition.
3.10 B BUS

In addition to 4 -bit parallel data transfers, the most significant bit (MSB) of the $B$ bus is available at the multifunction BMSB output in the most significant-position (MSP) as defined by the relative-position control. When used with shifts or circulates, this output may be used to extract B-bus data serially from the selected source. The BMSB output may be used to monitor the sign-bit of B bus data, or in conjunction with the AMSB and DOP3 (MSP) outputs, to detect an impending ALU overflow condition.

### 3.11 WORKING REGISTER (WR)

### 3.11.1 General Description

The 4-bit working register (WR) is a D-type edge-triggered register which functions as an accumulator for intermediate operands. The WR sources the ALU via the B multiplexer and the address-out-port (AOP) via the ADR multiplexer; the WR is a destination, via the WR multiplexer, for either the data-out bus (DOB) or data-in port (DIP).

### 3.11.2 WR Source/Destination Operands

Working register source and destination operands are listed in Tables 7 and 8 respectively. When the WR is used as a destination, the source data is recognized only when a low-level condition exists at the clock input. As shown in Figure 5, the source data may change during the low-level clock condition as long as the setup time prior to the low-to-high transition of the clock input is satisfied.

TABLE 7
WORKING REGISTER SOURCE OPERANDS

| OPERATION | OP FORM <br> (See 5.3) | OP FIELD OP3 $\rightarrow$ OPO | D-FIELD $\text { D1 } \rightarrow \text { D0 }$ | S-FIELD $\mathbf{S 2} \rightarrow \mathbf{s} \mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: |
| *WR ALU DIP $\rightarrow$ DOP <br> *WR ALU DIP $\rightarrow$ WR <br> WR ALU DIP $\rightarrow$ XWR <br> WR ALU RF $\rightarrow$ RF | Ic <br> ld <br> If <br> la | LLLL $\rightarrow \mathrm{HHHH}$ <br> LLLL $\rightarrow \mathrm{HHHH}$ <br> LLLL $\rightarrow \mathrm{HHHH}$ <br> LLLL $\rightarrow \mathrm{HHHH}$ | $\mathrm{HH}$ <br> HH <br> HH <br> LL | LLL <br> LLH <br> HLL <br> LLL $\rightarrow \mathrm{HHH}$ |
| WR ALU RF $\rightarrow$ WR <br> (WR minus DIP minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR,XWR (WR minus DIP minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR (WR minus RF minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | Ib <br> IVa <br> IVf <br> IVc | LLLL $\rightarrow \mathrm{HHHH}$ <br> HLLL <br> LLHL <br> HLLL | LH <br> HH <br> HH <br> HL | $\begin{aligned} & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LHL} \\ & \mathrm{LHL} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \end{aligned}$ |
| (WR minus RF minus 1 plus ALUCIN,XWR) RSA $\rightarrow$ WR, XWR (WR plus ALUCIN) RSA $\rightarrow$ WR, XWR <br> $(W R$ plus ALUCIN) RSA $\rightarrow$ WR,XWR <br> (WR plus ALUCIN) LCIR $\rightarrow$ WR | IVh <br> IVe <br> IVe <br> Vd | LLHL <br> HLHL <br> HLHL <br> LLHH | HL <br> HL <br> HH <br> HH | $\begin{aligned} & \text { LLL } \rightarrow \text { HHH } \\ & \text { XXX } \\ & \text { LHL } \\ & \text { HLH } \end{aligned}$ |
| (WR plus ALUCIN) LCIR $\rightarrow$ WR (WR plus ALUCIN) LSA $\rightarrow$ WR $(W R$ plus $A L U C I N)$ LSL $\rightarrow$ WR (WR plus ALUCIN) RCIR $\rightarrow$ WR | $\begin{aligned} & \mathrm{Vd} \\ & \mathrm{Vc} \\ & \mathrm{Vf} \\ & \mathrm{Vb} \end{aligned}$ | HLHH <br> LLHL <br> HLHL <br> LLLH | HH <br> HH <br> HH <br> HH | HLH <br> HLH <br> HLH <br> HLH |
| (WR plus ALUCIN) RCIR $\rightarrow$ WR (WR plus ALUCIN) RSA $\rightarrow$ WR $(W R$ plus ALUCIN) RSL $\rightarrow$ WR (WR plus ALUCIN,XWR) LCIR $\rightarrow$ (WR,XWR) | $\begin{aligned} & \mathrm{Vb} \\ & \mathrm{Va} \\ & \mathrm{Ve} \\ & \mathrm{VId} \end{aligned}$ | HLLH <br> LLLL <br> HLLL <br> HHHH | HH <br> HH <br> HH <br> HH | HLH <br> HLH <br> HLH <br> HLH |
| (WR plus ALUCIN,HWR) LCIR $\rightarrow$ (WR,XWR) (WR plus ALUCIN,XWR) LSA $\rightarrow$ (WR,XWR) (WR plus ALUCIN,XWR) LSL $\rightarrow$ (WR,XWR) (WR plus ALUCIN,XWR) RCIR $\rightarrow$ (WR,XWR) | VId <br> VIc <br> VIf <br> VIb | LHHH <br> LHHL <br> HHHL <br> HHLH | HH <br> HH <br> HH <br> HH | HLH <br> HLH <br> HLH <br> HLH |
| (WR plus ALUCIN,XWR) RCIR $\rightarrow$ (WR,XWR) (WR plus ALUCIN,XWR) RSA $\rightarrow$ (WR,XWR) (WR plus ALUCIN,XWR) RSL $\rightarrow$ (WR,XWR) WR plus DIP plus ALUCIN $\rightarrow$ DOP | VIb <br> VIa <br> Vle <br> IIi | LHLH <br> LHLL <br> HHLL <br> LHHH | HH <br> HH <br> HH <br> HH | HLH <br> HLH <br> HLH <br> LHL |
| WR plus DIP plus ALUCIN $\rightarrow$ XWR <br> (WR plus DIP plus ALUCIN) LCIR $\rightarrow$ WR, XWR (WR plus DIP plus ALUCIN) RSA $\rightarrow$ WR, XWR WR plus RF plus ALUCIN $\rightarrow$ XWR | IIh IVb IVg Ila | LLHH <br> HLLH <br> HLHH <br> LLHH | HH <br> HH <br> HH <br> HL | LHL <br> LHL <br> LHL <br> LLL $\rightarrow$ HHH |
| (WR plus RF plus ALUCIN) LCIR $\rightarrow$ WR,XWR (WR plus RF plus ALUCIN) RSA $\rightarrow$ WR,XWR | $\begin{aligned} & \mathrm{IVd} \\ & \mathrm{IVi} \end{aligned}$ | HLLH <br> HLHH | $\begin{aligned} & \mathrm{HL} \\ & \mathrm{HL} \end{aligned}$ | $\begin{aligned} & \text { LLL } \rightarrow \mathrm{HHH} \\ & \text { LLL } \rightarrow \mathrm{HHH} \end{aligned}$ |

NOTE: When PC priority is low WR $\rightarrow$ AOP

- XWR $\rightarrow$ AOP

TABLE 8
WORKING REGISTER DESTINATION OPERANDS

| OPERATION | OP FORM (See 5.3) | $\begin{aligned} & \text { OP-FIELD } \\ & \text { OP3 } \rightarrow \text { OPO } \end{aligned}$ | D-FIELD <br> D1 $\rightarrow$ D0 | S-FIELD $\mathbf{S} 2 \rightarrow \mathbf{S O}$ |
| :---: | :---: | :---: | :---: | :---: |
| WR ALU RF $\rightarrow$ WR <br> (WR minus DIP minus 1 plus ALUCIN,XWR) LCIR $\rightarrow$ WR,XWR <br> (WR minus DIP minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR,XWR <br> (WR minus RF minus 1 plus ALUCIN,XWR) LCIR $\rightarrow$ WR, XWR | lb IVa IVd IVc | $\begin{aligned} & \text { LLLL } \rightarrow \text { HHHH } \\ & \text { HLLL } \\ & \text { LLHL } \\ & \text { HLLL } \end{aligned}$ | LH <br> HH <br> HH <br> HL | $\begin{aligned} & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LHL} \\ & \mathrm{LHL} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \end{aligned}$ |
| (WR minus RF minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR $($ WR plus ALUCIN) RSA $\rightarrow$ WR, XWR (WR plus ALUCIN) RSA $\rightarrow$ WR, XWR $($ WR plus ALUCIN) LCIR $\rightarrow$ WR | IVh <br> IVe <br> IVe <br> Vd | LLHL <br> HLHL <br> HLHL <br> LLHH | HL HL HH HH | $\begin{aligned} & \text { LLL } \rightarrow \text { HHH } \\ & X X X \\ & \text { LHL } \\ & \text { HLH } \end{aligned}$ |
| $($ WR plus ALUCIN) LCIR $\rightarrow$ WR (WR plus ALUCIN) LSA $\rightarrow$ WR $($ WR plus ALUCIN) LSL $\rightarrow$ WR (WR plus ALUCIN) RCIR $\rightarrow$ WR | Vd <br> Vc <br> Vf <br> Vb | HLHH <br> LLHL <br> HLHL <br> LLLH | HH <br> HH <br> HH <br> HH | HLH <br> HLH <br> HLH <br> HLH |
| (WR plus ALUCIN) RCIR $\rightarrow$ WR <br> (WR plus ALUCIN) RSA $\rightarrow$ WR <br> (WR plus ALUCIN) RSL $\rightarrow$ WR <br> (WR plus ALUCIN, XWR) LCIR $\rightarrow$ (WR, XWR) | Vb <br> Va <br> Ve <br> VId | HLLH <br> LLLL <br> HLLL <br> HHHH | HH <br> HH <br> HH <br> HH | HLH <br> HLH <br> HLH <br> HLH |
| (WR plus ALUCIN, XWR) LCIR $\rightarrow$ (WR, XWR) (WR plus ALUCIN, XWR) LSA $\rightarrow$ (WR, XWR) (WR plus ALUCIN, XWR) LSL $\rightarrow$ (WR, XWR) (WR plus ALUCIN, XWR) RCIR $\rightarrow$ (WR, XWR) | VId <br> VIc <br> VIf <br> VIb | LHHH <br> LHHL <br> HHHL <br> HHLH | HH <br> HH <br> HH <br> HH | HLH <br> HLH <br> HLH <br> HLH |
| $(W R$ plus ALUCIN, XWR) RCIR $\rightarrow$ (WR, XWR) (WR plus ALUCIN, XWR) RSA $\rightarrow$ (WR,XWR) (WR plus ALUCIN, XWR) RSL $\rightarrow$ (WR, XWR) | VIb <br> VIa <br> Vle | LHLH <br> LHLL <br> HHLL | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | HLH <br> HLH <br> HLH |
| (WR plus DIP plus ALUCIN) LCIR $\rightarrow$ WR, XWR (WR plus DIP plus ALUCIN) RSA $\rightarrow$ WR, XWR | $\begin{aligned} & \hline \mathrm{IVb} \\ & \mathrm{IVg} \\ & \hline \end{aligned}$ | HLLH HLHH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \\ & \hline \end{aligned}$ | LHL LHL |
| (WR plus RF plus ALUCIN) LCIR $\rightarrow$ WR, XWR (WR plus RF plus ALUCIN) RSA $\rightarrow$ WR, XWR | $\begin{aligned} & \mathrm{IVd} \\ & \mathrm{IVi} \end{aligned}$ | $\begin{aligned} & \text { HLLH } \\ & \text { HLHH } \end{aligned}$ | $\begin{aligned} & H L \\ & H L \end{aligned}$ | $\begin{aligned} & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \end{aligned}$ |

NOTE: When PC PRIORITY is IOW WR $\rightarrow$ AOP

* XWR $\rightarrow$ AOP


### 3.11.3 WR Sourcing of ADR MUX

The resident operation directs the WR to source the AOP via the ADR multiplexer during 427 of the 459 possible unique operations. In the cases of operation form-type Ic and Id (see Table 27) which represent the remaining 32 of the 459 possible unique operations, the resident operation directs the XWR to source the AOP via the ADR. When the PC PRIORITY input is at a high-logic level, resident operation direction of the ADR multiplexer is overridden allowing the PC to source the AOP.

### 3.12 EXTENDED WORKING REGISTER (XWR)

### 3.12.1 XWR General Description

The 4-bit extended working register (XWR) is a D-type edge-triggered register which functions as 1 ) an accumulator during address derivations and 2) a WR extension during operations where double-length operands are present/
accumulated (iterative non-restoring divide, double-precision shifts/circulates, iterative multiply, etc.). The XWR sources 1) the ALU via the B multiplexer, 2) the AOP via the ADR multiplexer, or 3 ) itself shifted right or left via the XWR multiplexer. The XWR is a destination via the XWR multiplexer for either the DOB or the XWR, itself, shifted right or left.

### 3.12.2 XWR Source/Destination Operands

Extended working register source and destination operands are listed in Tables 9 and 10 respectively.
TABLE 9
EXTENDED WORKING REGISTER SOURCE OPERANDS

| OPERATION | OP FORM (See 5.3) | $\begin{aligned} & \text { OP-FIELD } \\ & \text { OP3 } \rightarrow \text { OPO } \end{aligned}$ | D.FIELD <br> D1 $\rightarrow$ D0 | S-FIELD $\mathbf{S} 2 \rightarrow \mathbf{S 0}$ |
| :---: | :---: | :---: | :---: | :---: |
| XWR ALU DIP $\rightarrow$ DOP | Ih | LLLL $\rightarrow$ HHHH | HH | HHH |
| XWR ALU DIP $\rightarrow$ WR | le | LLLL $\rightarrow$ HHHH | HH | LHH |
| XWR ALU DIP $\rightarrow$ XWR | 1 g | LLLL $\rightarrow$ HHHH | HH | HHL |
| XWR plus ALUCIN $\rightarrow$ DOP | 111 | HHHL | HH | LHL |
| XWR plus ALUCIN $\rightarrow$ RF | IIj | HHHL | HL | LLL $\rightarrow \mathrm{HHH}$ |
| XWR plus DIP plus ALUCIN $\rightarrow$ WR | 11 k | HHLL | HH | LHL |
| XWR plus DIP plus ALUCIN $\rightarrow$ XWR | IIf | HHLH | HH | LHL |
| XWR plus RF plus ALUCIN $\rightarrow$ WR | He | HHLL | HL | LLL $\rightarrow \mathrm{HHH}$ |

NOTE: When PC PRIORITY is low WR $\rightarrow$ AOP
TABLE 10
WORKING REGISTER DESTINATION OPERANDS

| OPERATION | OP FORM (See 5.3) | OP FIELD $\mathrm{OP3} \rightarrow \mathrm{OPO}$ | D-FIELD <br> D1 $\rightarrow$ D0 | $\begin{aligned} & \text { S-FIELD } \\ & -\mathbf{S} 2 \rightarrow \mathbf{S O} \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| DIP ALU XWR $\rightarrow$ XWR | Ig | LLLL $\rightarrow$ HHHH | HH | HHL |
| WR ALU DIP $\rightarrow$ XWR | If | LLLL $\rightarrow$ HHHH | HH | HLL |
| (WR minus DIP minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR $(W R$ minus DIP minus 1 plus ALUCIN, XWR) RSA $\rightarrow W R, X W R$ (WR minus RF minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | IVa <br> IVf <br> IVc | HLLL <br> LLHL <br> HLLL | HH <br> HH <br> HL | $\begin{aligned} & \mathrm{LHL} \\ & \mathrm{LHL} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \end{aligned}$ |
| (WR minus RF minus 1 plus ALUCIN, XWR) RSA WR, XWR (WR plus ALUCIN) RSA $\rightarrow$ WR, XWR (WR plus ALUCIN) RSA $\rightarrow$ WR, XWR | IVh <br> IVe <br> IVe | LLHL HLHL HLHL | $\begin{aligned} & \mathrm{HL} \\ & \mathrm{HL} \\ & \mathrm{HH} \end{aligned}$ | $\begin{aligned} & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{XXX} \\ & \mathrm{LHL} \end{aligned}$ |
| (WR plus ALUCIN, XWR) LCIR $\rightarrow$ (WR, XWR) | VId | HHHH | HH | HLH |
| (WR plus ALUCIN, XWR) LCIR $\rightarrow$ (WR, XWR) (WR plus ALUCIN, XWR) LSA $\rightarrow$ (WR, XWR) (WR plus ALUCIN, XWR) LSL $\rightarrow$ (WR, XWR) (WR plus ALUCIN, XWR) RCIR $\rightarrow$ (WR, XWR) | VId <br> VIc <br> Vif <br> VIb | LHHH <br> LHHL <br> HHHL <br> HHLH | HH <br> HH <br> HH <br> HH | HLH <br> HLH <br> HLH <br> HLH |
| (WR plus ALUCIN, XWR) RCIR $\rightarrow$ (WR, XWR) <br> (WR plus ALUCIN, XWR) RSA $\rightarrow$ (WR, XWR) <br> (WR plus ALUCIN, XWR) RSL $\rightarrow$ (WR, XWR) | $\begin{aligned} & \text { VIb } \\ & \text { VIa } \\ & \text { Vle } \end{aligned}$ | LHLH <br> LHLL <br> HHLL | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \\ & \mathrm{HH} \\ & \hline \end{aligned}$ | HLH <br> HLH <br> HLH |
| WR plus DIP plus ALUCIN $\rightarrow$ XWR <br> (WR plus DIP plus ALUCIN) LCIR $\rightarrow$ WR, XWR (WR plus DIP plus ALUCIN) RSA $\rightarrow$ WR, XWR WR plus RF plus ALUCIN $\rightarrow$ XWR | 11 h. <br> IVb <br> IVg <br> Ha | LLHH <br> HLLH <br> HLHH <br> LLHH | HH <br> HH <br> HH <br> HL | $\begin{aligned} & \text { LHL } \\ & \text { LHL } \\ & \text { LHL } \\ & \text { LLL } \rightarrow \text { HHH } \end{aligned}$ |
| (WR plus RF plus ALUCIN) LCIR $\rightarrow$ WR, XWR (WR plus RF plus ALUCIN) RSA $\rightarrow$ WR, XWR | $\begin{aligned} & \mathrm{IVd} \\ & \mathrm{IVi} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { HLLH } \\ & \text { HLHH } \end{aligned}$ | $\begin{aligned} & \mathrm{HL} \\ & \mathrm{HL} \end{aligned}$ | $\begin{aligned} & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \end{aligned}$ |
| DIP plus XWR plus ALUCIN $\rightarrow$ XWR DIP $\rightarrow$ XWR | $\begin{aligned} & \mathrm{IIk} \\ & \mathrm{IHe} \end{aligned}$ | HHLH LLLH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | LHL LHL |

[^2]When the XWR is used as a destination, the source data is recognized only when a low-level condition exists at the clock input. As shown in Figure 5, the source data can change during the low-level clock condition as long as the setup time prior to the low-to-high transition of the clock input is satisfied.

### 3.12.3 XWR Sourcing of ADR MUX

Operation form-type Ic and Id (see Table 27) represent 32 of the 459 possible unique operations. During these operations the resident operation directs the XWR to source the AOP via the ADR multiplexer. During the remaining 427 of the 459 possible operations, the resident operation directs the WR to source the AOP via the ADR multiplexer. When the PC PRIORITY input is at a high-logic level, resident operation direction of the ADR multiplexer is overridden allowing the PC to source the AOP.

### 3.13 DATA-OUT MULTIPLEXER (DO MUX)

### 3.13.1 DO MUX General Description

The data-out multiplexer (DO MUX) is a multi-port, special purpose multiplexer which provides scaled shifting of the ALU output, and direct transfer of the A bus to the data-out bus, bypassing the ALU. The output port of the DO MUX provides, in accordance with Table 11, ALU output data not shifted, ALU output data shifted right one bit position, ALU output data shifted left one bit position, and A bus data not shifted. Control for the DO MUX is provided by the resident operation in conjunction with the relative position control.
table 11
DO MUX TRANSFERS

| OPERATION TYPE |  | DO MUX OUTPUT |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 3 | 2 | 1 | 0 |
|  | RIGHT SHIFT ARITHMETIC <br> RIGHT SHIFT LOGICAL <br> RIGHT CIRCULATE <br> ALU OUT BUS $\rightarrow$ DATA-OUT BUS <br> A BUS $\rightarrow$ DATA-OUT BUS <br> LEFT SHIFT ARITHMETIC <br> LEFT SHIFT LOGICAL <br> LEFT CIRCULATE | WRLFT WRLFT WRLFT <br> ALU3 <br> ABUS3 <br> ALU2 <br> ALU2 <br> ALU2 | $\begin{aligned} & \text { ALU3 } \\ & \text { ALU3 } \\ & \text { ALU3 } \\ & \text { ALU2 } \\ & \text { ABUS2 } \\ & \text { ALU1 } \\ & \text { ALU1 } \\ & \text { ALU1 } \end{aligned}$ | ALU2 <br> ALU2 <br> ALU2 <br> ALU1 <br> ABUS1 <br> ALUO <br> ALUO <br> ALUO | ALU1 ALU1 ALU1 ALUO ABUSO WRRT WRRT WRRT |
| $\begin{aligned} & \text { MOST SIGNIFICANT } \\ & \text { POSITION (MSP) } \end{aligned}$ | RIGHT SHIFT ARITHMETIC <br> RIGHT SHIFT LOGICAL <br> RIGHT CIRCULATE <br> ALU OUT BUS $\rightarrow$ DATA-OUT BUS <br> A BUS $\rightarrow$ DATA-OUT BUS <br> LEFT SHIFT ARITHMETIC <br> LEFT SHIFT LOGICAL <br> LEFT CIRCULATE | WR3 <br> WRLFT <br> WRLFT <br> ALU3 <br> ABUS3 <br> ALU2 <br> ALU2 <br> ALU2 | ALU3 <br> ALU3 <br> ALU3 <br> ALU2 <br> ABUS2 <br> ALU1 <br> ALU1 <br> ALU1 | ALU2 <br> ALU2 <br> ALU2 <br> ALU1 <br> ABUS1 <br> ALUO <br> ALUO <br> ALUO | ALU1 <br> ALU1 <br> ALU1 <br> ALUO <br> ABUSO <br> WRRT <br> WRRT <br> WRRT |

### 3.13.2 DO MUX Shift Accommodations

Special bidirectional shift accommodations are provided to or from each end of the DO MUX to facilitate interpackage data shifts in expanded word length systems. The direction of these shift accommodations is selected by the resident operation. Bit 3 (MSB) of the DO MUX for each processor element receives interpackage right shift data and transmits interpackage left shift data via the bidirectional shift accommodation WRLFT; bit 0 (LSB) receives interpackage left shift data and transmits interpackage right shift data via the bidirectional shift accommodation $\overline{W R R T}$. Both WRLFT and WRRT, low-active signals at the package terminals, become WRLFT and WRRT, respectively, high-active signals within the processor element.
3.14 DATA-OUT I-MULTIPLEXER (DO IMUX)

The data-out I-multiplexer (DO IMUX) is a special purpose multiplexer which outputs, in accordance with Table 12, appropriate left-shift data via the bidirectional shift accommodation WRLFT. Control for the DO IMUX is provided by the resident operation in conjunction with the relative position control.

TABLE 12
DO IMUX TRANSFERS TO WRLFT

|  | OPERATION TYPE | DO IMUX OUTPUT TO WRLFT |
| :---: | :---: | :---: |
|  | LEFT SHIFT ARITHMETIC <br> LEFT SHIFT LOGICAL <br> LEFT CIRCULATE | $\frac{\overline{\overline{A L U 3}}}{\overline{\mathrm{ALU3}}} \overline{\overline{\mathrm{ALU3}}}$ |
|  | LEFT SHIFT ARITHMETIC <br> LEFT SHIFT LOGICAL <br> LEFT CIRCULATE | $\begin{aligned} & \mathrm{HIGH} \\ & \mathrm{HIGH} \\ & \overline{\text { ALU3 }} \end{aligned}$ |
|  | LEFT SHIFT ARITHMETIC <br> LEFT SHIFT LOGICAL <br> LEFT CIRCULATE | $\begin{aligned} & \overline{\text { XWR3 }} \\ & \overline{\text { XWR3 }} \\ & \overline{\text { XWR3 }} \end{aligned}$ |
|  | LEFT SHIFT ARITHMETIC <br> LEFT SHIFT LOGICAL <br> LEFT CIRCULATE | $\begin{aligned} & \overline{X W R 2} \\ & \overline{X W R 3} \\ & \overline{X W R 3} \end{aligned}$ |

### 3.15 DATA-OUT J-MULTIPLEXER (DO JMUX)

The data-out J-multiplexer (DO JMUX) is a special purpose multiplexer which outputs, as per Table 13, appropriate right shift data via the bidirectional shift accommodation WRRT. Control for the DO JMUX is provided by the resident operation in conjunction with the relative position control.

TABLE 13
DO JMUX TRANSFERS TO WRRT

|  | OPERATION TYPE | DO JMUX OUTPUT To WRRT |
| :---: | :---: | :---: |
|  | RIGHT SHIFT ARITHMETIC <br> RIGHT SHIFT LOGICAL <br> RIGHT CIRCULATE | $\overline{A L U 0}$ $\overline{\text { ALUO }}$ $\overline{A L U O}$ |
|  | RIGHT SHIFT ARITHMETIC <br> RIGHT SHIFT LOGICAL <br> RIGHT CIRCULATE | $\begin{aligned} & \text { HIGH } \\ & \text { HIGH } \\ & \overline{\text { ALUO }} \end{aligned}$ |
|  | RIGHT SHIFT ARITHMETIC <br> RIGHT SHIFT LOGICAL <br> RIGHT CIRCULATE |  |

### 3.16 EXTENDED WORKING REGISTER MULTIPLEXER (XWR MUX)

### 3.16.1 XWR MUX General Description

The extended working register multiplexer (XWR MUX) is a multi-port, special purpose multiplexer which provides scaled shifting of the XWR outputs and direct transfer of the data-out bus to the XWR input. The output port of the XWR MUX provides, in accordance with Table 14, XWR output data shifted left one bit position, XWR output data shifted right one bit position, and data-out bus data not shifted. The XWR MUX also sources the XWR MSB/LSB output. Under control of the relative position inputs, in the MSP the XWR MUX MSB (Bit 3) is available at the XWR MSB output and in the LSP the XWR MUX LSB (Bit 0 ) is available at the XWR LSB output. Control for the XWR $M U X$ is provided by the resident operation in conjunction with the relative position control.

### 3.16.2 XWR MUX Shift Accommodations

Special bidirectional shift accommodations are provided to or from each end of the XWR MUX to facilitate interpackage data shifts when the processor element is used in expanded word length systems. Bit 3 (MSB) or bit 2 of the XWR MUX is selected by the resident operation in conjunction with the relative position control to receive double-precision interpackage right shift data or transmit double-precision interpackage left shift data via the bidirectional shift accommodation XWRLFT; bit 0 (LSB) receives double-precision interpackage left shift data and

TABLE 14
XWVR MUX TRANSFERS

| OPERATION TYPE (DOUBLE-PRECISION) |  | XWR MUX OUTPUT |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 3 | 2 | 1 | 0 |
|  | RIGHT SHIFT ARITHMETIC SINGLE-SIGNED RIGHT SHIFT ARITHMETIC DOUBLE-SIGNED <br> RIGHT SHIFT LOGICAL <br> RIGHT CIRCULATE <br> DATA-OUT-BUS $\rightarrow$ XWR <br> LEFT SHIFT ARITHMETIC SINGLE-SIGNED <br> LEFT SHIFT ARITHMETIC DOUBLE-SIGNED <br> LEFT SHIFT LOGICAL <br> LEFT CIRCULATE | XWRLFT <br> XWR3 <br> XWRLFT <br> XWRLFT <br> DOB3 <br> XWR2 <br> ALU2 <br> XWR2 <br> XWR2 | XWR3 <br> XWRLFT <br> XWR3 <br> XWR3 <br> DOB2 <br> XWR1 <br> XWR1 <br> XWR1 <br> XWR1 | XWR2 <br> XWR2 <br> XWR2 <br> XWR2 <br> DOB1 <br> XWRO <br> XWRO <br> XWRO <br> XWRO | XWR1 <br> XWR1 <br> XWR1 <br> XWR1 <br> DOBO <br> XWRRT <br> XWRRT <br> XWRRT <br> XWRRT |
|  | RIGHT SHIFT ARITHMETIC SINGLE-SIGNED <br> RIGHT SHIFT ARITHMETIC DOUBLE-SIGNED <br> RIGHT SHIFT LOGICAL <br> RIGHT CIRCULATE <br> DATA-OUT-BUS $\rightarrow$ XWR <br> LEFT SHIFT ARITHMETIC SINGLE-SIGNED <br> LEFT SHIFT ARITHMETIC DOUBI.E-SIGNED <br> LEFT SHIFT LOGICAL <br> LEFT CIRCULATE | XWRLFT <br> XWRLFT <br> XWRLFT <br> XWRLFT <br> DOB3 <br> XWR2 <br> XWR2 <br> XWR2 <br> XWR2 | XWR3 <br> XWR3 <br> XWR3 <br> XWR3 <br> DOB2 <br> XWR1 <br> XWR1 <br> XWR1 <br> XWR1 | XWR2 <br> XWR2 <br> XWR2 <br> XWR2 <br> DOB1 <br> XWRO <br> XWRO <br> XWRO <br> XWRO | XWR1 <br> XWR1 <br> XWR1 <br> XWR1 <br> DOBO <br> XWRRT <br> XWRRT <br> XWRRT <br> XWRRT |

transmits interpackage right shift data via the bidirectional shift accommodation XWRRT. Both XWRLFT and $\overline{\text { XWRRT, low-active signals at the package terminals, become XWRLFT and XWRRT, respectively, high-active signals }}$ within the processor element.
3.17 EXTENDED WORKING REGISTER K-MULTIPLEXER (XWR KMUX)

The extended working register K-multiplexer (XWR KMUX) is a special purpose multiplexer which outputs, in accordance with Table 15, appropriate double-precision left-shift data via the bidirectional shift accommodation $\overline{\text { XWRLFT. Control for the XWR KMUX is provided by the resident operation in conjunction with the relative position }}$ control.

TABLE 15
XWR KMUX TRANSFERS TO XWRLFT

|  | OPERATION TYPE (DOUBLE-PRECISION) | $\begin{gathered} \text { XWR KMUX OUTPUT } \\ \text { TO XWRLFT } \end{gathered}$ |
| :---: | :---: | :---: |
|  | LEFT SHIFT ARITHMETIC SINGLE-SIGNED <br> LEFT SHIFT ARITHMETIC DOUBLE-SIGNED <br> LEFT SHIFT LOGICAL <br> LEFT CIRCULATE | $\begin{aligned} & \overline{X W R 3} \\ & \overline{X W R 3} \\ & \overline{X W R 3} \\ & \overline{X W R 3} \end{aligned}$ |
|  | LEFT SHIFT ARITHMETIC SINGLE-SIGNED <br> LEFT SHIFT ARITHMETIC DOUBLE-SIGNED <br> LEFT SHIFT LOGICAL <br> LEFT CIRCULATE | $\begin{aligned} & \text { HIGH } \\ & \text { HIGH } \\ & \text { HIGH } \\ & \hline \text { ALU3 } \end{aligned}$ |

The extended working register $L$ multiplexer (XWR LMUX) is a special purpose multiplexer which outputs, in accordance with Table 16, appropriate double-precision right shift data via the bidirectional shift accommodation $\overline{X W R R T}$. Control for the XWR LMUX is provided by the resident operation in conjunction with the relative position control.

TABLE 16
XWR LMUX TRANSFERS TO XWRRT

|  | OPERATION TYPE (DOUBLE-PRECISION) | XWR LMUX OUTPUT TO XWRRT |
| :---: | :---: | :---: |
|  | RIGHT SHIFT ARITHMETIC SINGLE-SIGNED RIGHT SHIFT ARITHMETIC DOUBLE-SIGNED RIGHT SHIFT LOGICAL RIGHT CIRCULATE | $\begin{aligned} & \overline{X W R O} \\ & \overline{X W R O} \\ & \overline{X W R O} \\ & \overline{X W R O} \end{aligned}$ |
|  | RIGHT SHIFT ARITHMETIC SINGLE-SIGNED RIGHT SHIFT ARITHMETIC DOUBLE-SIGNED RIGHT SHIFT LOGICAL <br> RIGHT CIRCULATE | $\overline{\text { ALUO }}$ $\overline{\text { ALUO }}$ $\overline{\text { ALUO }}$ $\overline{A L U O}$ |

### 3.19 WORKING REGISTER MULTIPLEXER (WR MUX)

The working register multiplexer (WR MUX) is a multi-port multiplexer which, under control of the resident operation, selects either data-in port data or data-out bus data for direct transfer to the WR.

## 4. SHIFT/CIRCULATE OPERATIONS

The SBP0400A and the SBP0401A uses the DO MUX in conjunction with the DO IMUX and DO JMUX to accomplish single-bit WR shift/circulate operations; the XWR MUX in conjunction with the XWR KMUX and XWR LMUX to accomplish single-bit XWR shift/circulate operations. While single-precision shift/circulate operations involve the WR only, double-precision shift/circulate operations involve the WR in conjunction with the XWR. The standard operation set does not include single-precision XWR shift/circulate operations.

### 4.1 WR SINGLE-PRECISION SHIFTS/CIRCULATES

WR single-precision shift/circulate operations are directed by the resident operation with expanded wordlength "end" conditions handled by the relative position controls. These single-precision operations may best be represented by the generalized symbol:

$$
\text { (WR plus ALUCIN) SHIFTED/CIRCULATED } \rightarrow \text { WR }
$$

Within a single microcycle (1 clock period), each of six possible WR single-precision shift/circulate operations is capable of 1) asynchronously summing the WR with the ALUCIN input, then 2 ) asynchronously shifting/circulating the sum one bit position to the right/left, and finally 3) synchronously storing the shifted/circulated result back into the WR. The six WR single-precision shift/circulate possibilities, with data flow paths for expanded wordlengths, are listed in Table 17.

TABLE 17
WR SINGLE-PRECISION SHIFTS/CIRCULATES

| SHIFT/CIRCULATE OPERATION | SHIFT/CIRCULATE FUNCTION | EXPANDED WORDLENGTH DATA FLOW PATHS |  | OP-FIELD $\mathrm{OP3} \rightarrow \mathrm{OPO}$ | D.FIELD $\text { D1 } \rightarrow \text { D0 }$ | $\begin{gathered} \text { S-FIELD } \\ \text { S2 } \rightarrow \text { SO } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (WR plus ALUCIN) RSL $\rightarrow$ WR | RIGHT-SHIFT-LOGICAL (RSL) | Figure 8 | Ve | HLLL | HH | HLH |
| $($ WR plus ALUCIN) LSL $\rightarrow$ WR | LEFT-SHIFT-LOGICAL (LCL) | Figure 9 | Vf | HLHL | HH | HLH |
| (WR plus ALUCIN) RSA $\rightarrow$ WR | RIGHT-SHIFT-ARITHMETIC (RSA) | Figure 10 | Va | LLLL | HH | HLH |
| $($ WR plus ALUCIN) LSA $\rightarrow$ WR | LEFT-SHIFT-ARITHMETIC (LSA) | Figure 11 | Vc | LLHL | HH | HLH |
| $($ WR plus ALUCIN) RCIR $\rightarrow$ WR | RIGHT-CIRCULATE (RCIR) | Figure 12 | Vb | LLLH | HH | HLH |
| $($ WR plus ALUCIN) LCIR $\rightarrow$ WR | LEFT-CIRCULATE (LCIR) | Figure 13 | Vd | LLHH | HH | HLH |

### 4.1.1 (WR Plus ALUCIN) RSL $\rightarrow$ WR

The WR single-precision logical right-shift operation, shown in Figure 8, displaces the entire contents of the WR one bit position to the right. In an expanded wordlength system, a logic-level low is automatically right-shifted into the WR's most-significant-bit (MSB) of the most-significant-package (MSP) as the WR's contents are displaced to the right. This logic-level low, sourced by the least-significant-package (LSP), exits the LSP via the bidirectional shift accommodation WRRT and enters the MSP via the bidirectional shift accommodation WRLFT. During each WR RSL operation, the WR's displaced LSB of the LSP is discarded.


NOTE: WRRT, WRLFT, ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.
FIGURE 8 - RIGHT SHIFT LOGICAL - SINGLE PRECISION (RSL - SP)

### 4.1.2 (WR Plus ALUCIN) LSL $\rightarrow$ WR

The WR single-precision logical left-shift operation, shown in Figure 9, displaces the entire contents of the WR one bit position to the left. In an expanded wordlength system, a logic-level low is automatically left-shifted into the WR's LSB of the LSP as the WR's contents are displaced to the left. This logic-level low, sourced by the MSP, exits the MSP via the bidirectional shift accommodation WRLFT and enters the LSP via the bidirectional shift accommodation $\overline{W R R T}$. During each WR LSL operation, the WR's displaced MSB of the MSP is discarded.


NOTE: WRRT, WRLFT, ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.
FIGURE 9: - LEFT SHIFT LOGICAL - SINGLE PRECISION (LSL - SP)

### 4.1.3 (WR Plus ALUCIN) RSA $\rightarrow$ WR

The WR single-precision arithmetic right-shift operation, shown in Figure 10, displaces the entire contents of the WR one bit position to the right. The MSB of the MSP is designated as a sign-bit. As the entire contents of the WR is displaced to the right, the sign-bit does not change. Rather the sign-bit is duplicated to the right. The displaced LSB of the LSP exits the LSP via the bidirectional shift accommodation $\overline{W R R T}$.


NOTE: WRRT, WRLFT, ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.
FIGURE 10 - RIGHT SHIFT ARITHMETIC - SINGLE PRECISION (RSA - SP)

### 4.1.4 (WR Plus ALUCIN) LSA $\rightarrow$ WR

The WR single-precision arithmetic left-shift operation, shown in Figure 11, is functionally identical to the WR single-precision logical left-shift operation. The WR's MSB of the MSP, although designated as a sign-bit, is discarded as the entire contents of the WR is displaced one bit position to the left. As each WR LSA operation is performed, the BMSB output (WR. sign bit) may be compared to the MSB of the MSP's DOP (data displacing into WR sign bit) to detect an impending change in WR sign-bit polarity.


NOTE: WRRT, WRLFT, ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.
FIGURE 11 - LEFT SHIFT ARITHMETIC - SINGLE PRECISION (LSA - SP)
4.1.5 (WR Plus ALUCIN) RCIR $\rightarrow$ WR

The WR single-precision right-circulate operation, shown in Figure 12, displaces the entire contents of the WR one bit position to the right. The displaced LSB of the LSP replaces the displaced MSB of the MSP. The displaced LSB of the LSP exits the LSP via the bidirectional shift accommodation WRRT and enters the MSP via the bidirectional shift accommodation WRLFT.


NOTE: WRRT, WRLFT, ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.

FIGURE 12 - RIGHT CIRCULATE - SINGLE PRECISION (RCIR - SP)

### 4.1.6 (WR Plus ALUCIN) LCIR $\rightarrow$ WR

The WR single-precision left-circulate operation, shown in Figure 13, displaces the entire contents of the WR one bit position to the left. The displaced MSB of the MSP replaces the displaced LSB of the LSP. The displaced MSB of the MSP exits the MSP via the bidirectional shift accommodation WRLFT and enters the LSP via its bidirectional shift accommodation WRRT.


NOTE: WRRT, WRLFT, ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.

FIGURE 13 - LEFT CIRCULATE - SINGLE PRECISION (LCIR - SP)

### 4.2 WR,XWR DOUBLE-PRECISION SHIFTS/CIRCULATES

WR, XWR double-precision shift/circulate operations are directed by the resident operation with expanded wordlength "end" conditions handled by the relative position controls. The double-precision shift/circulate operations may best be represented by the generalized symbol:

$$
\text { (WR plus ALUCIN, XWR) SHIFTED/CIRCULATED } \rightarrow \text { WR,XWR }
$$

Within a single microcycle, each of eight possible WR,XWR double-precision shift/circulate operations is capable of 1) asynchronously summing the WR with the ALUCIN input, then 2) asynchronously double-precision shifting/ circulating the sum with the WR and XWR considered as one double-length register, and finally 3 ) synchronously storing the shifted/circulated result into the double-length register formed by WR in conjunction with the XWR. The eight WR, XWR double-precision shift/circulate possibilities, with data flow paths for expanded wordlengths, are listed in Table 18.

TABLE 18
WR, XWR DOUBLE-PRECISION SHIFTS/CIRCULATES

| SHIFT/CIRCULATE OPERATION | SHIFT/CIRCULATE FUNCTION | EXPANDED WORDLENGTH DATA FLOW PATHS |  | OP-FIELD <br> OP3 $\rightarrow$ OPO | D-FIELD $\mathrm{D} 1 \rightarrow \mathrm{D} 0$ | S-FIELD $\mathbf{S} 2 \rightarrow \mathbf{s} 0$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (WR plus ALUCIN, XWR) RSL $\rightarrow$ WR, XWR (WR plus ALUCIN, XWR) LSL $\rightarrow$ WR, XWR | RIGHT-SHIFT-LOGICAL (RSL) LEFT.SHIFT-LOGICAL (LSL) | Figure 14 <br> Figure 15 | VIe VIf | HHLL <br> HHHL | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | $\begin{aligned} & \text { HLH } \\ & \text { HLH } \end{aligned}$ |
| (WR plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR (WR pius ALUCIN, XWR) LSA $\rightarrow$ WR, XWR | RIGHT-SHIFT-ARITHMETIC (RSA) LEFT-SHIFT-ARITHMETIC (LSA) | Figure 16, 17 <br> Figure 18, 19 | Vla VIc | LHLL LHHL | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | HLH <br> HLH |
| (WR plus ALUCIN, XWR) RCIR $\rightarrow$ WR, XWR (WR plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | RIGHT-CIRCULATE (RCIR) <br> LEFT-CIRCULATE (LCIR) | Figure 20 <br> Figure 21 | $\begin{aligned} & \text { VIb } \\ & \text { VI3 } \end{aligned}$ | L.HLH <br> LHHH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | HLH HLH |

### 4.2.1 (WR Plus ALUCIN, XWR) RSL $\rightarrow$ WR,XWR

The WR,XWR double-precision logical right-shift operation, shown in Figure 14, displaces the entire contents of the double-length register, formed by the WR in conjunction with the XWR, one bit position to the right. In an expanded wordlength system, the WR's displaced LSB of the LSP exits the LSP via the bidirectional shift accommodation $\overline{\text { XWRRT }}$ and enters the XWR's MSB of the MSP via the bidirectional shift accommodation XWRLFT. A logic-level low is automatically right-shifted into the WR's MSB of the MSP. This logic-level low, sourced by the LSP, exits the LSP via the bidirectional shift accommodation WRRT and enters the MSP via the bidirectional shift accommodation WRLFT. During each WR, XWR RSL operation, the XWR's displaced LSB of the LSP is discarded.


NOTE: WRRT, WRLFT, XWRRT, XWRLFT ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTERPACKAGE.
FIGURE 14 - RIGHT SHIFT LOGICAL - DOUBLE PRECISION (RSL - DP)

### 4.2.2 (WR Plus ALUCIN, XWR) LSL $\rightarrow$ WR, XWR

The WR, XWR double-precision logical left-shift operation, shown in Figure 15, displaces the entire contents of the double length register, formed by the WR in conjunction with the XWR, one bit position to the left. In an expanded wordlength system, the XWR's displaced MSB of the MSP exits the MSP via the bidirectional shift accommodation $\overline{\text { WRLFT }}$ and enters WR's LSB of the LSP via the bidirectional shift accommodation WRRT. A logic-level low is automatically left-shifted into the XWR's LSB of the LSP. This logic-level low, sourced by the MSP, exits the MSP via the bidirectional shift accommodation XWRLFT and enters the LSP via the bidirectional shift accommodation $\overline{X W R R T}$. During each WR,XWR LSL operation, the WR's displaced MSB is discarded.


NOTE: WRRT, WRLFT, XWRRT, XWRLFT ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.
FIGURE 15 - LEFT SHIFT LOGICAL - DOUBLE PRECISION (LSL - DP)

### 4.2.3 (WR Plus ALUCIN, XWR) RSA $\rightarrow$ WR,XWR

The WR,XWR double-precision arithmetic right-shift operations, shown in Figures 16 and 17, displace the entire contents of the double-length register, formed by the WR in conjunction with the XWR, one bit position to the right. In an expanded wordlength system, the WR's displaced LSB of the LSP exits the LSP via the bidirectional shift accommodation XWRRT and enters either the XWR's MSB or MSB-minus-1 of the MSP (see 4.2.3.1 and 4.2.3.2). The polarity of the MSP's relative position control input POSO selects between single-signed and double-signed double-precision arithmetic right-shift operations.

### 4.2.3. 1 Single-Signed Double-Precision RSA (MSP POSO $=H$ )

For the single-signed WR,XWR double-precision right-shift operation, shown in Figure 16, the WR's MSB of the MSP only is designated as a sign-bit. As the entire contents of the WR,XWR is displaced one bit position to the right, the sign-bit does not change. Rather, the sign-bit is duplicated to the right. The WR's displaced LSB of the LSP exits the LSP via the bidirectional shift accommodation XWRRT and enters the XWR's MSB of the MSP via the bidirectional shift accommodation XWRLFT. The XWR's displaced LSB of the LSP is discarded.


NOTE: WRRT, WRLFT, XWRRT, XWRLFT ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.
FIGURE 16 - RIGHT SHIFT ARITHMETIC - SINGLE SIGN/DOUBLE PRECISION (RSA - SS/DP)

### 4.2.3.2 Double-Signed Double-Precision RSA (MSP POSO=L)

For the double-signed WR, XWR double-precision right-shift operation, shown in Figure 17, both the WR's and XWR's MSB of the MSP are designated as a sign-bit. As the entire contents of the WR, XWR is displaced one bit position to the right, the sign-bits do not change. Rather, the WR's sign-bit is duplicated to the right while the XWR's sign-bit is held stationary. The WR's displaced LSB of the LSP exits the LSP via the bidirectional shift accommodation XWRRT and enters the XWR's MSB-minus-1 of the MSP via the bidirectional shift accommodation XWRLFT. The XWR's displaced LSB of the LSP is discarded.


NOTE: WRRT, WRLFT, XWRRT, XWRLFT ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.
FIGURE 17 - RIGHT SHIFT ARITHMETIC - DOUBLE SIGN/DOUBLE PRECISION (RSA - DS/DP)

### 4.2.4 (WR Plus ALUCIN, XWR) LSA $\rightarrow$ WR,XWR

The WR,XWR double-precision arithmetic left-shift operations, shown in Figures 18 and 19, displace the entire contents of the double-length register, formed by the WR in conjunction with the XWR, one bit position to the left. In an expanded wordlength system, either the XWR's displaced MSB or MSB-minus-1 of the MSP exits the MSP via the bidirectional shift accommodation WRLFT and enters the WR's LSB of the LSP via the bidirectional shift accommodation WRRT. The polarity of the MSP's relative position control input POSO selects between single-signed and double-signed double-precision arithmetic left-shift operations.

### 4.2.4.1 Single-Signed Double-Precision LSA (MSP POSO $=H$ )

The single-signed WR,XWR double-precision arithmetic left-shift operation, shown in Figure 18, is functionally identical to the WR, XWR double-precision logical left-shift operation. The WR's MSB of the MSP, although designated as a sign-bit, is discarded as the entire contents of the double-length WR,XWR register is displaced one bit position to the left. As each WR, XWR LSA operation is performed, the BMSB output (WR sign bit) may be compared to the MSB of the MSP's DOP (data displacing into WR sign bit) to detect an impending change in WR sign bit polarity.


NOTE: WRRT, WRLFT, XWRRT, XWRLFT ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.
FIGURE 18 - LEFT SHIFT ARITHMETIC - SINGLE SIGN/DOUBLE PRECISION (LSA - SS/DP)
4.2.4.2 Double-Signed Double-Precision LSA (MSP POSO=L)

The double-signed WR,XWR double-precision arithmetic left-shift operation shown in Figure 19 is, with one exception, functionally identical to the WR,XWR double-precision left-shift operation. The exception is, the XWR's sign-bit is automatically forced to the polarity of the MSP's ALU2 output. As each double-signed double-precision LSA operation is performed, the WR's sign-bit is discarded. Consequently the BMSB output (WR sign bit) may be compared to the MSB of the MSP's DOP (ALU2 data displacing into WR sign bit) to detect an impending change in WR sign bit polarity.


NOTE: WRRT, WRLFT, XWRRT, XWRLFT ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.
FIGURE 19 - LEFT SHIFT ARITHMETIC - DOUBLE SIGN/DOUBLE PRECISION (LSA - DS/DP)

### 4.2.5 (WR Plus ALUCIN, XWR) RCIR $\rightarrow$ WR,XWR

The WR, XWR double-precision right-circulate operation, shown in Figure 20, displaces the entire contents of the double-length register, formed by the WR in conjunction with the XWR, one bit position to the right. In an expanded wordlength system, the WR's displaced LSB of the LSP exits the LSP via the bidirectional shift accommodation *XWRRT and enters the XWR's MSB of the MSP via the bidirectional shift accommodation XWRLFT. The XWR's LSB of the LSP exits the LSP via the bidirectional shift accommodation WRRT and enters the WR's MSB of the MSP via the bidirectional shift accommodation WRLFT.


NOTE: WRRT, WRLFT, XWRRT, XWRLFT ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.

$$
\text { FIGURE } 20 \text { - RIGHT CIRCULATE - DOUBLE PRECISION (RCIR - DP) }
$$

### 4.2.6 (WR Plus ALUCIN, XWR) LCIR $\rightarrow$ WR,XWR

The WR,XWR double-precision left-circulate operation, shown in Figure 21, displaces the entire contents of the double-length register, formed by the WR in conjunction with the XWR, one bit position to the left. In an expanded wordlength system, the WR's displaced MSB of the MSP exits the MSP via the bidirectional shift accommodation $\overline{\text { XWRLFT }}$ and enters the XWR's LSB of the LSP via the bidirectional shift accommodation XWRRT. The XWR's MSB of the MSP exits the MSP via the bidirectional shift accommodation WRLFT and enters the WR's LSB of the LSP via the bidirectional shift accommodation $\overline{W R R T}$.


NOTE: WRRT, WRLFT, XWRRT, XWRLFT ARE HIGH-ACTIVE INTRA-PACKAGE AND LOW-ACTIVE (INVERSE POLARITY) INTER-PACKAGE.

FIGURE 21 - LEFT CIRCULATE - DOUBLE PRECISION (LCIR - DP)

### 4.3 COMPOUND-FUNCTION WR,XWR DOUBLE-PRECISION SHIFTS/CIRCULATES

Compound-function WR,XWR double-precision shift/circulate operations extend the processing power of the basic double-precision RSA and LCIR operations to boost systems-level efficiency in the assembly of iterative macro-instructions such as multiply and non-restoring divide. These compound-function shift/circulate operations, directed by the resident operation with expanded wordlength "end" conditions handled by the relative position controls, may best be represented by the generalized symbol:

$$
\begin{gathered}
\text { (WR plus/minus A plus ALUCIN, XWR) RSA/LCIR } \rightarrow \text { WR,XWR } \\
\text { where A is either the DIP or RF }
\end{gathered}
$$

Within a single microcycle, each of eight possible compound-function WR,XWR double-precision shift/circulate operations is capable of 1) asynchronously summing/subtracting either the RF or DIP with/from the WR, then 2) asynchronously adding the result to the ALUCIN input, then 3) asynchronously double-precision shifting/circulating (RSA/LCIR) the result with the WR and XWR considered as one double-length register, and finally 4) synchronously storing the shifted/circulated result into the double-length register formed by the WR in conjunction with the XWR. The eight compound-function WR,XWR double-precision shift/circulate possibilities, with data flow paths for expanded wordlengths, are listed in Table 19.

TABLE 19
COMPOUND-FUNCTION WR, XWR
DOUBLE-PRECISION SHIFTS/CIRCULATES

| SHIFT/CIRCULATE OPERATION | SHIFT/CIRCULATE FUNCTION | EXPANDED WORDLENGTH DATA FLOW PATHS | FORM <br> (See 5.3) | OP-FIELD OP3 $\rightarrow$ OPO | D-FIELD $\mathrm{D} 1 \rightarrow \mathrm{D} 0$ | S-FIELD $\mathbf{S 2} \rightarrow \mathbf{S 0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (WR minus DIP minus 1 pius ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR (WR minus RF( n ) minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | LEFT-CIRCULATE (LCIR) LEFT-CIRCULATE (LCIR) | Figure 21 <br> Figure 21 | $\mathrm{IVa}$ IVc | HLLL <br> HLLL | $\mathrm{HH}$ HL | LHL <br> $L L L \rightarrow H H H$ |
| (WR plus DIP plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR (WR plus RF( n ) plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | LEFT-CIRCULATE (LCIR) LEFT-CIRCULATE (LCIR) | Figure 21 <br> Figure 21 | $\begin{aligned} & \mathrm{IVb} \\ & \text { IVd } \end{aligned}$ | HLLH <br> HLLH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HL} \end{aligned}$ | LHL <br> LLL $\rightarrow \mathrm{HHH}$ |
| (WR minus DIP minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR $(W R$ minus $R F(n)$ minus 1 plus $A L U C I N, X W R)$ RSA $\rightarrow$ WR, XWR | RIGHT-SHIFT-ARITHMETIC (RSA) RIGHT-SHIFT-ARITHMETIC (RSA) | Figure 16 Figure 16 | $i v f$ IVh | LLHL LLHL | $\mathrm{HH}$ $\mathrm{HL}$ | LHL <br> $\mathrm{LLL} \rightarrow \mathrm{HHH}$ |
| (WR plus DIP plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR (WR plus RF $(n)$ plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR | RIGHT-SHIFT-ARITHMETIC (RSA) RIGHT-SHIFT-ARITHMETIC (RSA) | Figure 16 <br> Figure 16 | $\mathrm{IVg}$ IVi | HLHH HLHH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HL} \end{aligned}$ | LHL <br> LLL $\rightarrow \mathrm{HHH}$ |

## 5. OPERATION SET (MICROINSTRUCTION SET)

The SBP0400A and SBP0401A are supplied with an identical set of 459 non-redundant standard factory-defined operations (microinstructions). The only difference between the SBP0400A and the SBP0401A is the presence and absence of the operation register (OR):
a. The SBP0400A contains a 20 -bit operation register. After the 9 -bit operation code is applied (and setup), the positive-going clock transition causes the resident operation to be stored in the OR. See Figure 5 and microinstruction overlap, paragraph 5.1.
b. The SBP0401A, without the OR, derives its resident operation from a steady-state 9-bit code applied at the operation select inputs. See Figure 5.

### 5.1 SBPO400A MICROINSTRUCTION OVERLAP

Within a single microcycle (1 clock period), any one of the '0400A's 459 unique operations may be both selected and executed. While the "present" microinstruction is directing the '0400A's functional blocks and data paths from the OR, the "next" microinstruction may be setup for entry into the OR. As the results of the "present" microinstruction are synchronously stored at their appointed destination, the "next" microinstruction simultaneously enters the OR where it becomes the "present" microinstruction. This technique of overlapping microinstruction setup with microinstruction execution (Figure 5) allows a string of successive microinstructions to be executed, one each, during successive microcycles.

### 5.2 OPERATION-SELECT WORD

Each of the 459 operations is selected by presenting 9 -bits of encoded microinstruction data to the operation-select input lines which is then asynchronously decoded/translated by the PLA. In the SBP0400A this decoded/translated microinstruction enters the OR synchronous with the completion of the previous microinstruction (positive transition of the clock) to become the resident operation. In the SBP0401A this decoded/translated microinstruction is distributed directly from the 20 outputs of the PLA as the resident operation.

The 9-bit operation-select word is partitioned, as shown below, into three interacting fields: 1) the 2-bit D-field, 2) the 4 -bit OP-field, and 3 ) the 3 -bit $S$-field.

OPERATION-SELECT WORD

5.2.1 D-Field, Operation-Select Word

This 2-bit D-field (D1 $\rightarrow$ D0) of the operation-select word governs the manner in which the OP-field and S-field are interpreted to specify the operations. Four D-field possibilities exist. They are: LL, LH, HL, and HH.

### 5.2.1.1 D-Field $=L L$

When the D-field is "LL", the RF and WR, as shown below, are designated as operand sources with the RF also designated as the operation-result destination.


The 3 -bit S-field is interpreted to select 1 of 8 RF locations both as an operand source and an operation-result destination; the 4-bit OP-field is interpreted to select one of 16 ALU functions (micro-operations) as the operand combination/modification mechanism.

### 5.2.1.2D-Field $=L H$

When the D-field is "LH", the RF and WR, as shown below, are designated as operand sources with the WR also designated as the operation-result destination.


The 3-bit S-field is interpreted to select 1 of 8 RF locations as an operand source; the 4-bit OP-field is interpreted to select one of 16 ALU functions (micro-operations) as the operand combination/modification mechanism.

### 5.2.1.3D-Field $=H L$

When the D-field is " $H L$ ", the $A L U$ functions (micro-operations) available for the combination/modification of operands are limited to 1 ) plus, 2) minus, or 3 ) unconditional ALU-bypass (no ALU function).

As shown in Table 20, the 3-bit S-field is primarily interpreted to select one of eight RF locations as an operand source and/or operation-result destination; the 4-bit OP-field is interpreted to select a limited ALU function in conjunction with an operand source and/or operand-result destination.

TABLE 20
D-FIELD = HL

|  | OP3 | OP2 | OP1 | OPO | D1 | D0 | S2 | S1 | So |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $R F \rightarrow$ DOP | L | L | L | L | H | L | RF: | LLL | HHH |
| $R F \rightarrow X W R$ | L | L | L | H | H | L | RF: | LLL | HHH |
| (WR minus RF minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR | L | L | H | L | H | L. | RF: | LLL | HHH |
| RF plus WR plus ALUCIN $\rightarrow$ XWR | L | L | H | H | H | L | RF: | LLL | HHH |
| RF plus DIP plus ALUCIN $\rightarrow$ WR | L | H | L | L | H | L | RF: | LLL | HHH |
| RF pius DIP plus ALUCIN $\rightarrow$ XWR | L | H | L | H | H | L | RF: | LLL | HHH |
| DIP $\rightarrow$ WR | L | H | H | L | H | L |  | $\begin{gathered} \hline \text { t Care } \\ \times \end{gathered}$ |  |
| RF plus DIP plus ALUCIN $\rightarrow$ RF | L | H | H | H | H | L | RF: | LLL | HH |
| (WR minus RF minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | H | L | L | L | H | L | RF: | LLL | HHH |
| (WR plus RF plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | H | L | L | H | H | L | RF: | LLL | HHH |
| (WR plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR | H | L | H | L | H | L | Don <br> $\times$ | $\begin{gathered} \hline \text { t Care } \\ \times \\ \hline \end{gathered}$ |  |
| (WR plus RF plus ALUCIN) RSA $\rightarrow$ WR, XWR | H | L | H | H | H | L | RF: | LLL | HH |
| RF plus XWR plus ALUCIN $\rightarrow$ WR | H | H | L | L | H | L | RF: | LLL | HHH |
| RF plus XWR plus ALUCIN $\rightarrow$ XWR | H | H | L | H | H | L | RF: | LLL | HHH |
| $X$ WR plus ALUCIN $\rightarrow$ RF | H | H | H | L | H | L | RF: | LLL | HH |
| $\mathrm{DIP} \rightarrow \mathrm{RF}$ | H | H | H | H | H | L | RF: | LLL | HH |
|  | OP3 | OP2 | OP1 | OPO | D1 | Do | S2 | S1 | So |

### 5.2.1.4 D-Field $=\mathrm{HH}$

When the D-field is " HH ", the RF is neither used as an operand source nor an operation-result destination. Rather, two S-field possibilities (LHL, HLH) are, as shown in Table 21, interpreted to extend the 4-bit OP-field to select one of 32 non-RF operations. The extended OP-field is interpreted to select a limited ALU function in conjunction with an operand source(s) and an operation-result destination.

TABLE 21
D-FIELD $=H H$

$$
\begin{aligned}
& \mathrm{DIP} \rightarrow \mathrm{DOP} \\
& \mathrm{DIP} \rightarrow X W R
\end{aligned}
$$

(WR minus DIP minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR DIP plus WR plus ALUCIN $\rightarrow$ XWR DIP plus WR plus ALUCIN $\rightarrow$ DOP DIP $\rightarrow$ WR
DIP plus WR plus ALUCIN $\rightarrow$ DOP
$(W R$ minus DIP minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR (WR plus DIP plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR (WR plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR (WR plus DIP plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR DIP plus $X W R$ plus ALUCIN $\rightarrow$ WR DIP plus XWR plus ALUCIN $\rightarrow$ XWR

$$
\text { XWR plus ALUCIN } \rightarrow \text { DOP }
$$

OP3 OP2 OP1 OPO D1 D0 S2 S1 S0

$$
\mathrm{DIP} \rightarrow \mathrm{DOP}
$$

| L | L | L | L | H | H | L | H | L |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | H | H | H | L | H | L. |
| L | L | H | L | H | H | L | H | L |
| L | L | H | H | H | H | L | H | L |
| L | H | L | L | H | H | L | H | L |
| L | H | L | H | H | H | L | H | L |
| L | H | H | L | H | H | L | H | L |
| L | H | H | H | H | H | L | H | L |
| H | L | L | L | H | H | L | H | L |
| H | L | L | H | H | H | L | H | L |
| H | L | H | L | H | H | L | H | L |
| H | L | H | H | H | H | L | H | L |
| H | H | L | L | H | H | L | H | L |
| H | H | L | H | H | H | L | H | L |
| H | H | H | L | H | H | L | H | L |
| H | H | H | H | H | H | L | H | L |
| OP3 | OP2 | OP1 | OPO | D1 | DO | S2 | S1 | So |


| L | L | L | L | H | H | H | L | H |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | L | L | H | H | H | H | L | H |
| L | L | H | L | H | H | H | L | H |
| L | L | H | H | H | H | H | L | H |
| L | H | L | L | H | H | H | L. | H |
| L | H | L | H | H | H | H | L | H |
| L | H | H | L | H | H | H | L | H |
| L | H | H | H | H | H | H | L | H |
| H | L | L | L | H | H | H | L | H |
| H | L | L | H | H | H | H | L | H |
| H | L | H | L | H | H | H | L | H |
| H | L | H | H | H | H | H | L | H |
| H | H | L | L | H | H | H | L | H |
| H | H | L | H | H | H | H | L | H |
| H | H | H | L | H | H | H | L | H |
| H | H | H | H | H | H | H | L | H |

OP3 OP2 OP1 OP0 D1 D0 $\quad$ S2 $\quad$ S1 $\quad$ S0

### 5.2.2 OP-Field, Operation-Select Word

The 4-bit OP-field (OP3 $\rightarrow$ OPO) of the operation-select word interacts with the D-field and S-field to specify an ALU function as the operand combination/modification mechanism for operations (microinstructions).

### 5.2.2.1 OP-Field ALU Function (Micro-Operation) Selection

The most consistent utilization of the OP-field is realized when specifying one of 16 ALU functions, listed in Table 22, as the operand combination/modification mechanism for those particular operations listed in Table 23. For those

TABLE 22

## ALU FUNCTION (MICRO-OPERATION SELECT)

|  |  |  |  | ACTIV | GH DATA |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | ELD |  | ALUCIN $=\mathrm{H}$ | ALUCIN = L |
| OP3 | OP2 | OP1 | OPO | (WITH CARRY) | (NO CARRY) |
| L | L | L | L | $\mathrm{F}_{\mathrm{n}}=\mathrm{L}$ | $\mathrm{F}_{\mathrm{n}}=\mathrm{H}$ |
| L | L | L | H | $F \mathrm{n}=\mathrm{B}$ minus A | $F \mathrm{~F}=\mathrm{B}$ minus A minus 1 |
| L | L | H | L | $F \mathrm{n}=\mathrm{A}$ minus B | $F \mathrm{~F}=\mathrm{A}$ minus B minus 1 |
| L | L | H | H | $\mathrm{Fn}=\mathrm{A}$ plus B plus 1 | $F \mathrm{~F}=\mathrm{A}$ plus B |
| L | H | L | L | $\mathrm{Fn}=\mathrm{B}$ plus 1 | $F \mathrm{~F}=\mathrm{B}$ |
| L | H | L | H | $\mathrm{Fn}=\overline{\mathrm{B}}$ plus 1 | $\mathrm{F}=\overline{\mathrm{B}}$ |
| L | H | H | L | $\mathrm{Fn}=\mathrm{A}$ plus 1 | $\mathrm{F}_{\mathrm{n}}=\mathrm{A}$ |
| L | H | H | H | $\mathrm{F}_{\mathrm{n}}=\overline{\mathrm{A}}$ plus 1 | $F_{n}=\bar{A}$ |
| H | L | L. | L | $F \mathrm{~F}=\mathrm{AnBn}$ |  |
| H | L | L | H | $F n=A n \oplus B n$ |  |
| H | L | H | L | $F_{n}=\overline{A n} \oplus \mathrm{~A}^{(1)}$ |  |
| H | L | H | H | $F \mathrm{~F}=\overline{\mathrm{A}} \mathrm{nBn}$ |  |
| H | H | L | L | $F_{n}=A n \bar{B} n$ |  |
| H | H | L | H | $F n=A n+\bar{B} n$ |  |
| H | H | H | L | $F n=\bar{A}_{n}+B n$ |  |
| H | H | H | H | $F \mathrm{n}=\mathrm{An}+\mathrm{Bn}$ |  |




An OP-field choice of "LLLH" would automatically interchange the operands and specify the operation WR minus DIP $\rightarrow$ DOP. In fact, any of eight arithmetic or eight Boolean ALU functions may be selected from Table 22 and impressed upon any operation in Table 23.

Although the ALU generally accepts two operand sources simultaneously as inputs, certain ALU functions may be selected from Table 22 which only consider one operand source. These ALU functions, when impressed upon the operations of Table 23, specify the register transfer operations of Table 24. These register transfer operations allow: 1) unconditioned transfers, $X \rightarrow Y$ with the LSP's ALUCIN $=L, 2$ ) incrementing transfers, $X$ plus $1 \rightarrow Y$ with the LSP's ALUCIN $=H, 3$ ) one's-complement transfers, $\bar{X} \rightarrow Y$ with the LSP's ALUCIN $=L$, and 4) two's-complement transfers, $\bar{X}$ plus $1 \rightarrow Y$ with the LSP's ALUCIN $=H$.

TABLE 24 REGISTER TRANSFER OPERATIONS

WR plus ALUCIN $\rightarrow$ RF RF plus ALUCIN $\rightarrow$ WR WR plus ALUCIN $\rightarrow$ XWR XWR plus ALUCIN $\rightarrow$ WR DIP plus ALUCIN $\rightarrow$ WR DIP plus ALUCIN $\rightarrow$ XWR DIP plus ALUCIN $\rightarrow$ DOP XWR plus ALUCIN $\rightarrow$ DOP * DIP plus ALUCIN $\rightarrow$ DOP *WR plus ALUCIN $\rightarrow$ DOP DIP plus ALUCIN $\rightarrow$ WR
$\overline{W R}$ plus $A L U C I N \rightarrow$ RF
$\overline{\mathrm{RF}}$ plus ALUCIN $\rightarrow$ WR
$\overline{W R}$ plus ALUCIN $\rightarrow$ XWR
$\overline{\text { XWR plus ALUCIN } \rightarrow \text { WR }}$
$\overline{\text { DIP }}$ plus ALUCIN $\rightarrow$ WR
$\overline{\text { DIP plus ALUCIN } \rightarrow X W R}$
DIP plus ALUCIN $\rightarrow$ DOP
$\overline{\text { XWR plus ALUCIN } \rightarrow \text { DOP }}$

* $\overline{\text { DIP }}$ plus ALUCIN $\rightarrow$ DOP
* $\overline{W R}$ plus ALUCIN $\rightarrow$ DOP
* $\overline{\text { DIP }}$ plus ALUCIN $\rightarrow$ WR

| OP3 | OP2 | OP1 | OPO | D1 | DO |  | S2 S1 So |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L | H | L | L | L | L | RF: | LLL $\rightarrow$ HHH |
| L | H | H | L | L | H | RF: | LLL $\rightarrow$ HHH |
| L | H | L | L | H | H |  | $H L L$ |
| L | H | L | L | H | H |  | L H H |
| L | H | H | L | H | H |  | L H H |
| L | H | H | L | H | H |  | H L L |
| L | H | H | L | H | H |  | H H H |
| L | H | L | L | H | H |  | HHH |
| L | H | H | L | H | H |  | L L L |
| L | H | L | L | H | H |  | L L L |
| L | H | H | L | H | H |  | L L H |
| OP3 | OP2 | OP1 | OPO | D1 | DO |  | S2 S1 S0 |
| L | H | L | H | L | L | RF: | LLL $\rightarrow \mathrm{HHH}$ |
| L | H | H | H | L | H | RF: | LLL $\rightarrow$ HHH |
| L | H | L | H | H | H |  | H L L |
| L | H | L | H | H | H |  | L H H |
| L | H | H | H | H | H |  | L H H |
| L | H | H | H | H | H |  | H L L |
| L | H | H | H | H | H |  | HHH |
| L | H | L | H | H | H |  | HHH |
| L | H | H | H | H | H |  | L L L |
| L | H | L | H | H | H |  | $L L L$ |
| L | H | H | H | H | H |  | L L H |
| OP3 | OP2 | OP1 | OPO | D1 | D0 |  | S2 S1 S0 |

* $X W R \rightarrow A O P$, otherwise $W R \rightarrow$ AOP. PC PRIORITY overrides.

Certain ALU functions may be selected from Table 22 to facilitate register "clear" (all logic-level LOWs) and register "preset" (all logic-level HIGHs) operations. These ALU functions, when impressed upon the operations of Table 23, specify the register "clear" and "preset" operations of Table 25.

TABLE 25
REGISTER CLEAR AND PRESET OPERATIONS
LOW $\rightarrow$ RF, ALUCIN = HIGH
LOW $\rightarrow$ WR, ALUCIN = HIGH
*LOW $\rightarrow$ WR, ALUCIN = HIGH
LOW $\rightarrow$ XWR, ALUCIN = HIGH
LOW $\rightarrow$ DOP, ALUCIN = HIGH
*LOW $\rightarrow$ DOP, ALUCIN = HIGH $\quad$ L L L

* $X W R \rightarrow A O P$, otherwise $W R \rightarrow A O P$. PC PRIORITY $=H$ HIGH overrides


### 5.2.2.2 OP-Field Operand-Source/ALU Function/Operation-Result-Destination Selection

The 4-bit OP-field also interacts with the D-field and S-field to specify the operations of Tables 22 and 23 . For these operations, the ALU functions available for operand combination/modification are limited to: 1) plus, 2) minus, and 3) unconditioned ALU-bypass (no ALU functions).

### 5.2.3 S-Field, Operation-Select Word

The 3 -bit $S$-field ( $\mathrm{S} 2 \rightarrow \mathrm{~S} 0$ ) of the operation-select word either: 1) specifies one of eight RF locations, shown in Table 26, as an operand source and/or operation-result destination, or 2) extends the 4-bit OP-field to select one of 32 non-RF operations as listed in Table 23.
5.3 INDEX TO MICROINSTRUCTIONS BY OPERATION FORM

The operation (microinstruction) set may be sectioned into six operation-forms as described in Tables 27 through 32. Each operation-form may, in turn, be

TABLE 26 RF SELECTION

| RF <br> LOCATION | S2 | S1 | s0 |
| :---: | :---: | :---: | :---: |
| RF0 | L | L | L |
| RF1 | L | L | $H$ |
| RF2 | L | $H$ | L |
| RF3 | L | $H$ | $H$ |
| RF4 | $H$ | L | L |
| RF5 | $H$ | L | $H$ |
| RF6 | $H$ | $H$ | L |
| RF7 (PC) | $H$ | $H$ | $H$ |

NOTE: D-FIELD is LL, LH, or HL subsequently sectioned into a group of operation-types. In general, for each operation type, the WR is automatically selected by the OR to source the AOP via the ADR MUX. The exception to this statement is realized in operation-form $I$, operation-types $a$ and $b$ where the XWR is automatically selected by the OR to source the AOP via the ADR MUX. Of course, when the PC PRIORITY input is taken to a logic-level high, OR selection of the ADR MUX is overridden. In this situation, the PC is prioritized to source the AOP via the ADR MUX.

In general, the execution results of most operations may be monitored at the DOP whether the result destination is the RF, WR, XWR or DOP itself. The only exceptions are realized when the DOB is not involved in operation execution. These exceptions include the DIP $\rightarrow$ WR transfer of operation-form III operation-type $d$, and the XWR portion of the double-precision shift/circulates involved throughout operation-forms IV and VI.

### 5.3.1 Operation - Form I

TABLE 27
OPERATION FORM I
Operation form I may be utilized to perform one of 16 ALU functions, selected by the Operation-Select Word OP-field, on two of four operand sources, (RF, WR, XWR, DIP). The result is transferred to one of four operation-result destinations (RF, WR, XWR, DOP).

### 5.3.2 Operation - Form II

Operation form II may be utilized to arithmetically sum one or two operand sources (RF, WR, XWR, DIP) and a ripple-carry-in (ALUCIN). The operationresult is transferred to one of four destinations (RF, WR, XWR, DOP).

### 5.3.3 Operation - Form III

Operation form 111 may be utilized to transfer one or two operand sources (RF, $D(P)$ to one of four destinations (RF, WR, XWR, DOP).

TABLE 29
OPERATION FORM III

| III | OPERATION TYPE | OP3 $\rightarrow$ OPO | D1 | DO | S2 | S1 | S0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| a. | DIP $\rightarrow$ RF | HHHH | H | L | RF: LLL $\rightarrow$ HHH |  |  |
| b. | RF $\rightarrow$ DOP | L L L L | H | L | RF: LLL $\rightarrow \mathrm{HHH}$ |  |  |
| c. | $\mathrm{RF} \rightarrow \mathrm{XWR}$ | L L L H | H | L | RF: | LLL $\rightarrow$ HHH |  |
| d. | DIP $\rightarrow$ WR | L H H L | H | L | X | X | X |
|  |  | L H H L | H | H | L | H | L |
| e. | DIP $\rightarrow$ XWR | L L L H | H | H | L | H | L |
| f. | DIP $\rightarrow$ DOP | HHHH | H | H | L | H | L |
|  | $\xrightarrow{\text { d }} \rightarrow$ DOP | L L L L | H | H | L | H | L |

NOTE: When PC PRIORITY is LOW, WR $\rightarrow$ AOP

| III | OPERATION TYPE | $\mathrm{OP} 3 \rightarrow \mathrm{OPO}$ | D1 | DO | S2 | S1 | So |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| a. | RF plus WR plus ALUCIN $\rightarrow$ XWR | L L H H | H | L | RF: LLL $\rightarrow$ HHH |  |  |
| b. | RF plus DIP plus ALUCIN $\rightarrow$ WR | L HLL | H | L | RF: LLL $\rightarrow \mathrm{HHH}$ |  |  |
| c. | RF plus DIP plus ALUCIN $\rightarrow$ XWR | L H L H | H | L | RF: LLL $\rightarrow \mathrm{HHH}$ |  |  |
| d. | RF plus DIP plus ALUCIN $\rightarrow$ RF | L H H H | H | L | RF: LLL $\rightarrow$ HHH |  |  |
| e. | RF plus XWR plus ALUCIN $\rightarrow$ WR | H H L L | H | L | RF: LLL $\rightarrow$ HHH |  |  |
| f. | RF plus XWR plus ALUCIN $\rightarrow$ XWR | H H L H | H | L | RF: LLL $\rightarrow \mathrm{HHH}$ |  |  |
| g. | XWR plus ALUCIN $\rightarrow$ RF | H H H L | H | L | RF: LLL $\rightarrow$ HHH |  |  |
| h. | DIP plus WR plus ALUCIN $\rightarrow$ XWR | L L H H | H | H | L | H | L |
| i. | DIP plus WR plus ALUCIN $\rightarrow$ DOP | L H H H | H | H | L | H | L |
| j. | DIP plus XWR plus ALUCIN $\rightarrow$ WR | H H L L | H | H | L | H | L |
| k. | DIP plus XWR plus ALUCIN $\rightarrow$ XWR | H H L H | H | H | L | H | L |
| 1. | XWR plus ALUCIN $\rightarrow$ DOP | H H H L | H | H | L | H | L |

NOTE: When PC PRIORITY is LOW, WR $\rightarrow$ AOP

### 5.3.4 Operation - Form IV

Operation form IV may be utilized to either:

- arithmetically sum the WR and the ripple carry-in (ALUCIN) with one of two operand sources (RF, DIP), arithmetically double-precision shift the result to the right, and transfer the shifted result to the WR and XWR;
- arithmetically sum the WR and the ripple carry-in (ALUCIN) with one of two operand sources (RF, DIP), double-precision circulate the result to the left, and transfer the circulated result to the WR and XWR;
- arithmetically subtract one of two operand sources (RF, DIP) and -1 from the WR, arithmetically add the ripple carry-in (ALUCIN), double-precision circulate the result to the left, and transfer the circulated result to the WR and XWR;
- arithmetically subtract one of two operand sources (RF, DIP) and -1 from the WR, arithmetically add the ripple carry-in (ALUCIN), arithmetically double-precision shift the result to the right and transfer the shifted result to the WR and XWR.

TABLE 30
OPERATION FORM IV

| IV | OPERATION TYPE | OP3 |  |  | OPO | D1 | D0 | S2 | S1 | S0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| a. | (WR minus DIP minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | H | L | L | L | H | H | L | H | L |
| b. | (WR plus DIP plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | H | L | L | H | H | H | L | H | L |
| c. | (WR minus RF minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | H | L | L | L | H | L |  | LLL | HHH |
| d. | (WR plus RF plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | H | L | L | H | H | L | RF: | LLL | HHH |
| e. | (WR plus ALALUCIN , XWR) RSA $\rightarrow$ XWR | H | L | H | L | H | L | X | $\times$ | X |
| e. | (WR plus ALALUCIN, XWR) RSA $\rightarrow$ XWR | H | L | H | L | H | H | L | H | L |
| f. | (WR minus DIP minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR | L | L | H | L | H | H | L | H | L |
| g. | (WR plus DIP plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR | H | L | H | H | H | H | L | H | L |
| h. | (WR minus RF minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR | L | L | H | L | H | L |  | LLL | HHH |
| i. | (WR plus RF plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR | H | L | H | H | H | L | RF: | LLL | HHH |

NOTE: When PC PRIORITY is LOW, WR $\rightarrow$ AOP

### 5.3.5 Operation - Form V

Operation form V may be utilized to perform singleprecision shifts on the contents of the WR, placing the result in the WR. The WR may be logically shifted left or right (LSL, RSL), arithmetically shifted left or right (LSA, RSA), or circulated left or right (LCIR, RCIR).

As the WR is passed through the ALU during form V and VI, the ALUCIN is active and should be held at a low logic level for true shifts.

TABLE 31 OPERATION FORM V

| V | OPERATION TYPE | OP3 $\rightarrow$ OPO | D1 | DO | S2 | S1 | So |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| a. | $(W R$ plus ALUCIN) RSA $\rightarrow$ WR | $L L L L$ | H | H | H | L | H |
| b. | (WR plus ALUCIN) RCIR $\rightarrow$ WR | L L L H | H | H | H | L | H |
|  |  | $H L L$ | H | H | H | L | H |
| c. | (WR plus ALUCIN) LSA $\rightarrow$ WR | L L H L | H | H | H | L | H |
| d. | $($ WR plus ALUCIN) LCIR $\rightarrow$ WR | L L H H | H | H | H | L | H |
|  |  | H L H H | H | H | H | L | H |
| e. | (WR plus ALUCIN) RSL $\rightarrow$ WR | $H L L$ | H | H | H | L | H |
| f. | $($ WR plus ALUCIN) LSL $\rightarrow$ WR | H L H L | H | H | H | $L$ | H |

NOTE: When PC PRIORITY is LOW, WR $\rightarrow$ AOP

TABLE 32

Operation form VI may be utilized to perform doubleprecision shifts on the contents of WR in conjunction with XWR. The WR in conjunction with the XWR may be:

- logically shifted left or right (LSL, RSL);
- arithmetically shifted left or right (LSA, RSA) single- or doublesigned;
- circulated left or right (LCIR, RCIR).


## OPERATION FORM VI



NOTE: When PC PRIORITY is LOW, WR $\rightarrow$ DOP

### 5.4 INDEX TO MICROINSTRUCTIONS BY SOURCE OPERANDS

When the source operand is known, tables 33 through 36 can be used to obtain the form/type and microcode of the possible operations for that source operand.

TABLE 33
DIP SOURCE OPERANDS

| OPERATION | OP FORM/TYPE | OP3 $\rightarrow$ OPO <br> OP FIELD | $\begin{aligned} & \text { D1 D0 } \\ & \text { D-FIELD } \end{aligned}$ | $\mathbf{S} 2 \rightarrow \mathbf{S 0}$ <br> S-FIELD |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{DIP} \rightarrow \mathrm{DOP} \\ & \mathrm{DIP} \rightarrow \mathrm{DOP} \\ & \mathrm{DIP} \rightarrow \mathrm{RF} \\ & \mathrm{DIP} \rightarrow \text { WR } \end{aligned}$ | IIIf <br> IIIf <br> IIla <br> Illd | HHHH <br> LLLL <br> HHHH <br> LHHL | HH <br> HH <br> HL <br> HL | LHL <br> LHL <br> LLL $\rightarrow$ HHH <br> XXX |
| $\begin{aligned} & \text { DIP } \rightarrow \text { WR } \\ & \text { DIP } \rightarrow \text { XWR } \\ & \text { *DIP ALU WR } \rightarrow \text { DOP } \\ & \text { *DIP ALU WR } \rightarrow \text { WR } \end{aligned}$ | Illd <br> HIe <br> Ic <br> Id | LHHL <br> LLLH <br> LLLL $\rightarrow$ HHHH <br> LLLL $\rightarrow$ HHHH | HH <br> HH <br> HH <br> HH | LHL LHL LLL LLH |
| DIP ALU WR $\rightarrow$ XWR DIP ALU XWR $\rightarrow$ DOP DIP ALU XWR $\rightarrow$ WR DIP ALU XWR $\rightarrow$ XWR | $\begin{aligned} & \hline \text { If } \\ & \text { Ih } \\ & \text { le } \\ & \text { lg } \end{aligned}$ | LLLL $\rightarrow \mathrm{HHHH}$ <br> LLLL $\rightarrow$ HHHH <br> LLLL $\rightarrow \mathrm{HHHH}$ <br> LLLL $\rightarrow$ HHHH | HH <br> HH <br> HH <br> HH | HLL <br> HHH <br> LHH <br> HHL |
| (DIP plus WR plus ALUCIN) LCIR $\rightarrow$ WR, XWR (DIP plus WR plus ALUCIN) RSA $\rightarrow$ WR, XWR DIP plus RF plus ALUCIN $\rightarrow$ RF <br> DIP plus RF plus ALUCIN $\rightarrow$ WR | IVb <br> IVq <br> IId <br> 11 b | HLLH <br> HLHH <br> LHHH <br> LHLL | HH <br> HH <br> HL <br> HL | $\begin{aligned} & \text { LHL } \\ & \text { LHL } \\ & \text { LLL } \rightarrow \mathrm{HHH} \\ & \text { LLL } \rightarrow \mathrm{HHH} \end{aligned}$ |
| DIP plus RF plus ALUCIN $\rightarrow$ XWR <br> DIP plus WR plus ALUCIN $\rightarrow$ DOP <br> DIP plus WR plus ALUCIN $\rightarrow$ XWR <br> DIP plus XWR plus ALUCIN $\rightarrow$ WR | IIc $\mathrm{Ili}, \mathrm{Illh}$ <br> IIh <br> IIj | LHLH <br> LHHH <br> LLHH <br> HHLL | HL HH <br> HH <br> HH | $\begin{aligned} & \text { LLL } \rightarrow \text { HHH } \\ & \text { LHL } \\ & \text { LHL } \\ & \text { LHL } \end{aligned}$ |
| DIP plus XWR plus ALUCIN $\rightarrow$ XWR | IIk | HHLH | HH | LHL |

* XWR $\rightarrow$ AOP, otherwise $W R \rightarrow$ AOP. PC PRIORITY $=$ HIGH overrides.

TABLE 34
RF SOURCE OPERANDS

| OPERATION | OP FORM/TYPE | $\mathrm{OP} 3 \rightarrow \mathrm{OPO}$ OP FIELD | D1 D0 D-FIELD | $\mathbf{S} 2 \rightarrow \mathbf{S} 0$ <br> S-FIELD |
| :---: | :---: | :---: | :---: | :---: |
| $R F \rightarrow D O P$ <br> $R F \rightarrow X W R$ <br> RF ALU WR $\rightarrow$ RF <br> RF ALU WR $\rightarrow$ WR | 111 b <br> IIIc <br> la <br> lb | LLLL <br> LLLH <br> LLLL $\rightarrow \mathrm{HHHH}$ <br> LLLL $\rightarrow \mathrm{HHHH}$ | HL HL LL LH | LLL $\rightarrow \mathrm{HHH}$ <br> $L L L \rightarrow \mathrm{HHH}$ <br> $L L L \rightarrow \mathrm{HHH}$ <br> $L L L \rightarrow \mathrm{HHH}$ |
| RF plus DIP plus ALUCIN $\rightarrow$ RF <br> RF plus DIP plus ALUCIN $\rightarrow$ WR <br> RF plus DIP plus ALUCIN $\rightarrow$ XWR <br> (RF plus WR plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | IId <br> IIb <br> IIc <br> IVd | LHHH <br> LHLL <br> LHLH <br> HLLH | HL HL HL HL | $\begin{aligned} & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \end{aligned}$ |
| (RF plus WR plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR <br> RF plus WR plus ALUCIN $\rightarrow X W R$ <br> RF plus XWR plus ALUCIN $\rightarrow$ WR <br> RF plus XWR plus ALUCIN $\rightarrow$ XWR | IVi <br> IIa <br> IIe <br> IIf | HLHH <br> LLHH <br> HHLL <br> HHLH | HL HL HL HL | $L L L \rightarrow \mathrm{HHH}$ <br> $L L L \rightarrow \mathrm{HHH}$ <br> $L L L \rightarrow \mathrm{HHH}$ <br> $L L L \rightarrow \mathrm{HHH}$ |

NOTE: When PC PRLORITY is LOW, WR $\rightarrow$ AOP.

TABLE 35
XWR SOURCE OPERANDS

| OPERATION | OP FORM/TYPE | OP3 $\rightarrow$ OPO <br> OP FIELD | D1 D0 D-FIELD | $\mathbf{S} 2 \rightarrow \mathbf{S} 0$ <br> S-FIELD |
| :---: | :---: | :---: | :---: | :---: |
| XWR ALU DIP $\rightarrow$ DOP XWR ALU DIP $\rightarrow$ WR XWR ALU DIP $\rightarrow$ XWR XWR plus ALUCIN $\rightarrow$ DOP | $\begin{aligned} & \mathrm{lh} \\ & \mathrm{le} \\ & \mathrm{lg} \\ & \mathrm{III} \end{aligned}$ | LLLL $\rightarrow$ HHHH <br> LLLL $\rightarrow \mathrm{HHHH}$ <br> LLLL $\rightarrow$ HHHH <br> HHHL | HH <br> HH <br> HH <br> HH | HHH <br> LHH <br> HHL <br> LHL |
| XWR plus ALUCIN $\rightarrow$ RF <br> XWR plus DIP plus ALUCIN $\rightarrow$ WR <br> XWR plus DIP plus ALUCIN $\rightarrow$ XWR <br> $X$ WR plus RF plus ALUCIN $\rightarrow$ WR | IIj <br> IIk <br> Ile <br> IIf | HHHL <br> HHLL <br> HHLH <br> HHLL | HL <br> HH <br> HH <br> HL | $\begin{aligned} & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LHL} \\ & \mathrm{LHL} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \end{aligned}$ |
| XWR plus RF plus ALUCIN $\rightarrow$ XWR |  | HHLH | HL | LLL $\rightarrow$ HHH |

NOTE: When PC PRIORITY is LOW, WR $\rightarrow$ AOP.

TABLE 36
WR SOURCE OPERANDS

| OPERATION | OP FORM/TYPE | OP3 $\rightarrow$ OPO OP-FIELD | D1 D0 D-FIELD | $\mathbf{S} 2 \rightarrow \mathbf{S} 0$ <br> S-FIELD |
| :---: | :---: | :---: | :---: | :---: |
| *WR ALU DIP $\rightarrow$ DOP <br> *WR ALU DIP $\rightarrow$ WR <br> WR ALU DIP $\rightarrow$ XWR <br> WR ALU RF $\rightarrow$ RF | Ic <br> Id <br> If <br> la | LLLL $\rightarrow \mathrm{HHHH}$ <br> LLLL $\rightarrow$ HHHH <br> LLLL $\rightarrow \mathrm{HHHH}$ <br> LLLL $\rightarrow \mathrm{HHHH}$ | HH <br> HH <br> HH <br> LL | LLL <br> LLH <br> HLL <br> LLL $\rightarrow \mathrm{HHH}$ |
| WR ALU RF $\rightarrow$ WR <br> (WR minus BIP minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR $(W R$ minus DIP minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR (WR minus RF minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | Ib <br> IVa <br> IVf <br> IVc | $L L L L \rightarrow H H H H$ <br> HLLL <br> LLHL <br> HLLL | LH <br> HH <br> HH <br> HL | $\begin{aligned} & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{LHL} \\ & \mathrm{LHL} \\ & \mathrm{LLL} \rightarrow \mathrm{HHH} \end{aligned}$ |
| (WR minus RF minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR (WR plus ALUCIN) RSA $\rightarrow$ WR, XWR <br> (WR plus ALUCIN) RSA $\rightarrow$ WR, XWR <br> (WR plus ALUCIN) LCIR $\rightarrow$ WR | IVh <br> IVe <br> IVe <br> Vd | LLHL HLHL HLHL LLHH | $\begin{aligned} & \mathrm{HL} \\ & \mathrm{HL} \\ & \mathrm{HH} \\ & \mathrm{HH} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { LLL } \rightarrow \text { HHH } \\ & \mathrm{XXX} \\ & \text { LHL } \\ & \text { HLH } \\ & \hline \end{aligned}$ |
| (WR plus ALUCIN) LCIR $\rightarrow$ WR (WR plus ALUCIN) LSA $\rightarrow$ WR (WR plus ALUCIN) LSL $\rightarrow$ WR (WR plus ALUCIN) RCIR $\rightarrow$ WR | Vd <br> Vc <br> Vf <br> Vb | HLHH <br> LLHL <br> HLHL <br> LLLH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \\ & \mathrm{HH} \\ & \mathrm{HH} \\ & \hline \end{aligned}$ | HLH <br> HLH <br> HLH <br> HLH |
| (WR plus ALUCIN) RCIR $\rightarrow$ WR (WR plus ALUCIN) RSA $\rightarrow$ WR (WR plus ALUCIN) RSL $\rightarrow$ WR (WR plus ALUCIN, XWR) LCIR $\rightarrow(W R, X W R)$ | Vb <br> Va <br> Ve <br> VId | HLLH <br> LLLL <br> HLLL <br> HHHH | HH <br> HH <br> HH <br> HH | HLH <br> HLH <br> HLH <br> HLH |
| (WR plus ALUCIN, XWR) LCIR $\rightarrow(W R, X W R)$ (WR plus ALUCIN, XWR) LSA $\rightarrow$ (WR,XWR) (WR plus ALUCIN, XWR) LSL $\rightarrow$ (WR, XWR) (WR plus ALUCIN, XWR) RCIR $\rightarrow$ (WR, XWR) | VId <br> VIc <br> VIf <br> VIb | LHHH <br> LHHL <br> HHHL <br> HHLH | HH <br> HH <br> HH <br> HH | HLH <br> HLH <br> HLH <br> HLH |
| (WR plus ALUCIN, XWR) RCIR $\rightarrow$ (WR, XWR) (WR plus ALUCIN, XWR) RSA $\rightarrow$ (WR, XWR) (WR plus ALUCIN, XWR) RSL $\rightarrow$ (WR,XWR) WR plus DIP plus ALUCIN $\rightarrow$ DOP | VIb <br> VIa <br> Vle <br> IIi | LHLH LHLL HHLL LHHH | $\mathrm{HH}$ <br> HH <br> HH <br> HH | HLH <br> HLH <br> HLH <br> LHL |
| WR plus DIP plus ALUCIN $\rightarrow$ XWR (WR plus DIP plus ALUCIN) LCIR $\rightarrow$ WR, XWR (WR plus DIP plus ALUCIN) RSA $\rightarrow$ WR, XWR WR plus RF plus ALUCIN $\rightarrow$ XWR | IIh IVb IVc Ila | LLHH <br> HLLH <br> HLHH <br> LLHH | HH <br> HH <br> HH <br> HL | LHL <br> LHL <br> LHL <br> LLL HHH |
| (WR plus RF plus ALUCIN) LCIR $\rightarrow$ WR, XWR (WR plus RF plus ALUCIN) RSA $\rightarrow$ WR, XWR | $\begin{aligned} & \mathrm{IVd} \\ & \mathrm{IVi} \end{aligned}$ | HLLH HLHH | $\begin{aligned} & \mathrm{HL} \\ & \mathrm{HL} \end{aligned}$ | LLL HHH LLL HHH |

* XWR $\rightarrow$ AOP, otherwise WR $\rightarrow$ AOP. PC PRIORITY $=$ HIGH overrides.


## 6. INTERFACING

The input/output (I/O) accommodations of these processor elements have been designed for TTL and/or MOS compatibility. Direct interfacing, supportable by the entire families of catalog devices, is shown in Figure 22. Typical data/address flow and microcontrol are illustrated for an expanded wordlength system.


FIGURE 22 - TYPICAL 16-BIT MACHINE

### 6.1 INPUT CIRCUIT

The input circuit used on the '0400A/'0401A is basically an RTL configuration which has been modified for TTL/MOS compatibility as shown in Figure 23A. An input-clamping diode is incorporated to limit negative excursions (ringing) when the '0400A/'0401A is on the receiving end of a transmission line; an input switching threshold of nominally +1.5 volts has been specified for improved noise immunity. This threshold is achieved via two 10 K ohm resistors which function as a voltage divider to increase the one $V_{B E}$ threshold of the 12 L input transistor to +1.5 volts. Since this input circuit is independent of injector current, input threshold compatibility is maintained over the entire speed X power performance spectrum.

The input circuit characteristics for input current versus input voltage are shown in Figure 24 . The 10 K and 20 K ohm load lines and threshold knee at +1.5 volts provide a high-impedance characteristic to reduce input loading and improve the low-logic level input noise immunity over some standard TTL inputs. Full compatibility is maintained with virtually all 5 volt logic families even when the '0400A/'0401A is powered down (injector current reduced).
A. EQUIVALENT OF EACH INPUT

CLOCK OR $\overline{\text { PCCIN }}: \mathbf{R}$ eq. $=5 \mathrm{~K} \Omega$ ALL OTHERS : Req . $=\mathbf{1 0 K} \Omega$

FIGURE 23 - SCHEMATICS OF EQUIVALENT INPUTS, OUTPUTS, INPUTS/OUTPUTS

### 6.1.1 Sourcing Inputs

The inputs may be sourced directly by most 5 volt logic families. Five volt functions which feature internal pull-up resistors at their outputs require no external interface components; five volt functions which feature opencollector outputs generally require external pull-up resistors which may be specified as shown in Table 37.

### 6.1.2 Terminating Unused Inputs

Inputs which are selected to be hardwired to a logic-level low may be connected directly to ground. Inputs which are selected to be hardwired to a logic-level high must be tied, via a current limiting (pull-up) resistor, to a logic-level-high low-impedance voltage source such as $V_{C C}$. A single transient protecting resistor, specified as shown in Table 38, may be utilized common to ( N ) inputs.
6.2 OUTPUT CIRCUIT

The output circuit selected for the '0400A/


FIGURE 24 - TYPICAL INPUT CHARACTERISTICS '0401A is an injected open-collector transistor shown in Figure 23B. Since this transistor is injected, output sourcing capability is directly related to injector current. In other words, the number of loads which may be sourced by an '0400A/'0401A output is directly reduced as injector current is reduced.

The output circuit characteristic for logic-level low output voltage ( $V_{O L}$ ) versus logic-level low output current (IOL) is shown in Figure 25. At rated injector current; the '0400A/'0401A output circuit offers a low-level output voltage of typically 65 mV .

TABLE 37
SOURCING SBP0400 INPUTS

|  | CLOCK OR PCCIN | ALL OTHER INPUTS |
| :---: | :---: | :---: |
| SOURCED BY OPEN-COLLECTOR TTL, CMOS | $\mathrm{R}_{\mathrm{p}}=\frac{\mathrm{V}_{\mathrm{CC}}-3.3}{.0005(\mathrm{~N})}$ | $R_{p}=\frac{V_{C C}-3.3}{.00025(N)}$ |
| SOURCED BY MOS, CMOS: LOW-THRESHOLD <br> HIGH-THRESHOLD | $R_{B}=\frac{v_{C C}-2.4}{1 \mathrm{OH}-.0005(\mathrm{~N})}$ <br> NOT RECO | $R_{\mathrm{B}}=\frac{\mathrm{V}_{\mathrm{CC}}-2.4}{\mathrm{I}_{\mathrm{OH}}-.00025(\mathrm{~N})}$ |
| SOURCED BY TTL WITH 5 V ACTIVE PULL-UP | DRIVE DIRECTLY |  |

TABLE 38
TERMINATING UNUSED INPUTS

|  | $\overline{\text { PCCIN INPUT }}$ | ALL OTHER INPUTS |
| :---: | :---: | :---: |
| HARDWIRE TO $V_{I H}$ | $R_{p}=\frac{V_{C C}-3.3}{.0005(N)}$ | $R_{p}=\frac{V_{C C}-3.3}{.00025(N)}$ |

The output circuit characteristics for 1) logic-level high output voltage ( $\mathrm{VOH}_{\mathrm{OH}}$ ) and current $\left(\mathrm{I}_{\mathrm{OH}}\right)$, 2) rise times, and 3) next stage input noise immunity, are a function of the load circuit being sourced. The load circuit may be either:
A) the direct input, if no source current is required, of a five-volt logic family function,
or, for greater noise immunity and improved rise times,
B) the direct input of a five-volt logic family function in conjunction with a discrete pull-up resistor.

When a discrete pull-up resistor ( $R_{L}$ ) is utilized, the fanout requirements placed on a particular '0400A/ '0401A output restrict both the maximum and minimum value of $R_{L}$. Techniques for calculating $R_{L}(\max )$ and $R_{L(\min )}$ respectively are explained in Figure 26. Table 39 provides $R_{L(\max )}$ and $R_{L}(\min )$ values for one, five, nine, or ten loads for the more popular five-volt logic families.


FIGURE 25 - TYPICAL OUTPUT CHARACTERISTICS

### 6.2.1 $\mathrm{R}_{\mathrm{L}(\max )}$ Calculation for Output Source Current

The maximum load register $R_{L(\max )}$ value insures: 1) that sufficient current is available to satisfy both the fanout and logic-level-high output current requirements, and 2) that the voltage drop across $R_{L}$ itself is insufficient to reduce the logic-level-high output voltage below 2.4 volts. $R_{L(\max )}$ can be calculated as shown in Figure 26A.

## HIGH-LEVEL (OFF-STATE) CIRCUIT CALCULATIONS

The allowable voltage drop across the load resistor $\left(V_{R L}\right)$ is the difference between the pull-up source and the $\mathrm{V}_{\mathrm{OH}}$ level required at the load:

$$
V_{R L}=V_{\text {source }}-V_{O H \text { min }}
$$

The total current through the load resistor ( ${ }_{\mathrm{RL}}$ ) is the sum of the load current and the high-level output current ( $(\mathrm{OH})$ :
$I_{R L}=$ Load Current (into the load inputs $+I \mathrm{OH}$ where: ${ }^{\prime} \mathrm{OH}=375 \mu \mathrm{~A}$ max

Therefore, calculations for the maximum value of $R_{L}$ would be:
$R_{L(\text { max })}$ in ohms $=\frac{V_{\text {source }}-V_{\text {OH min }}}{\text { Amperes of Load Current }+.000375}$

$I_{1 H}=5(50 u A)=0.000250 A$

$$
\begin{aligned}
\text { Assume: } V_{\text {source }} & =5 \mathrm{~V} \text { and } \mathrm{V}_{\mathrm{OH}(\min )}=2.4 \mathrm{~V} \\
\mathrm{R}_{\mathrm{L}(\max )} & =\frac{\mathrm{V}_{\text {source }}-\mathrm{V}_{\mathrm{OH}}}{I_{\text {load }}+0.000375} \\
R_{\mathrm{L}(\max )} & =\frac{5-2.4}{0.00025+0.000375} \Omega=\frac{2.6}{0.000625} \Omega=4160
\end{aligned}
$$

A. $R_{L}$ MAXIMUM CALCULATIONS

LOW-LEVEL (ON-STATE) CIRCUIT CALCULATIONS

The maximum current through the load resistor when the output is on, plus the amount of current from the low-level input load, must be limited to the ${ }^{\prime}$ OL capability of the output. Therefore, the equation is:

$$
R_{L(\min )}=\frac{V_{\text {source }}-V_{O L \text { max }}}{I_{O L} \text { capability }-I_{\text {load }}}
$$



Assume: $\mathrm{V}_{\text {source }}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V}$, and $\mathrm{I}_{\mathrm{OL}}$ capability $=20 \mathrm{~mA}$

$$
\begin{aligned}
& R_{L(\min )}=\frac{V_{\text {source }}-V_{O L}}{I_{O L} \text { capability }-I_{I L}} \\
& R_{L(\min )}=\frac{5-.4}{0.02-0.01} \Omega=\frac{4.6}{0.01} \Omega=460 \Omega
\end{aligned}
$$

B. $R_{L}$ MINIMUM CALMCLATIONS

TABLE 39
OUTPUT LOAD RESISTOR VALUES ( $R_{L}$ )

| SBP0400 OUTPUT TYPE | DRIVING <br> 1 Load |  | DRIVING <br> 5 Loads |  | DRIVING 10 Loads |  | TYPE OF LOGIC |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RL(MIN) | RL (MAX) | RL (MIN) | RL(MAX) | RL (MIN) | RL (MAX) |  |
|  | $234 \Omega$ | 6190 S | 252 S2 | 5200 s | $280 \Omega$ | $4333 \Omega$ | 54LS/74LS |
| 20 mA | $250 \Omega$ | 5909 ת | 383 s2 | $4333 \Omega$ | $1150 \Omega$ | $3250 \Omega$ | 54/74 |
| SINK | $256 \Omega$ | 5777 S | 460 S | $4160 \Omega$ | 2300 S | 2888 ת | 54S/74S |
| OUTPUTS | $230 \Omega$ | 6341 S2 | 230 s2 | $5777 \Omega$ | 231 S | $5200 \Omega$ | MOS |
|  | $230 \Omega$ | $6500 \Omega$ | 230 s | 6500 s | 231 S | 6498 S | C-MOS |
|  |  |  |  |  | TYPE OF LOGIC |  |  |
|  | 477 S2 | $6190 \Omega$ | 560 s | 5200 s | 54LS/74LS |  |  |
| 10 mA | 547 ת | $5909 \Omega$ | $2300 \Omega$ | 4333 ת | 54/74 |  |  |
| SINK | $575 \Omega$ | $5777 \Omega$ | 4000 s | 4000 s | 54S/74S |  |  |
| OUTPUTS | $464 \Omega$ | $6341 \Omega$ | $462 \Omega$ | 5777 ת | MOS |  |  |
|  | $460 \Omega$ | $6500 \Omega$ | 460 S2 | 6500 s | C-MOS |  |  |

Specific designs can be tailored for minimum power or maximum performance by making the individual calculations as described in Figure 26.

## CONDITIONS:

| $\mathrm{V}_{\text {source }}=5 \mathrm{~V}$ |  |  |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ (Satisfies most 5 V logic) |  |  |
| $\mathrm{V}_{\text {OL }}=0.4 \mathrm{~V}$ (Based on max noise margin provided by SBP0400A/SBP0401A |  |  |
| $1 \mathrm{OH}=375 \mu \mathrm{~A}$ (Maximum leakage of SBP0400A/SBP0401A) |  |  |
| 1 OL as specified ( $20 \mathrm{~mA}, 10 \mathrm{~mA}$ ) |  |  |
| And unit loads of: | IIL $=$ | $\mathrm{I}_{1} \mathrm{H}=$ |
| 54LS/74LS | 0.36 mA | $10 \mu \mathrm{~A}$ |
| 54/74 | 1.6 mA | $40 \mu \mathrm{~A}$ |
| 54S/74S | 2 mA | $50 \mu \mathrm{~A}$ |
| N-MOS | $10 \mu \mathrm{~A}$ | $10 \mu \mathrm{~A}$ |
| C-MOS | 10 pA | 10 pA |

### 6.2.2 $R_{L(\min )}$ Calculation for Output Source Current

The minimum load resistor $R_{L}(\min )$ value insures that the arithmetic sum of the current through $R_{L}$ itself plus the sink currents from the various loads will not exceed the low-level current rating ( $I_{\mathrm{OL}}$ ) of the particular output being utilized. $R_{L(\min )}$ may be calculated as shown in Figure 26B.

### 6.3 BIDIRECTIONAL INPUT/OUTPUT CIRCUIT

The bidirectional input/output circuit, shown in Figure 23C, is simply a "marriage" of the separate input and output circuits, with the respective electrical characteristics described above.

## 7. POWER SOURCE

12 L is a current-injected logic. When placed across a curve tracer, the processor element will resemble a silicon switching diode. Any voltage or current source capable of supplying the desired current at the injector node voltage
required will suffice (see Table 40). A dry-cell battery, a 5 -volt TTL power supply, a programmable current supply (for power-up/power-down operation) - literally whatever power source is convenient can be used for most cases. For example, if a 5 -volt TTL power supply is to be used, a series dropping resistor would be connected between the 5 -volt supply and the injector pins of the I2L device, as illustrated in Figure 27, to select the desired operating current. In expanded systems using multiple 4 bit slices, an individual dropping resistor is required for each SBPO400A/ SBP0401A.

Figures 28 and 29 show the typical injector node voltages which occur across the temperature and injector current ranges. Table 40 provides the approximate resistor values for various combinations of supply voltages and operating injector currents.

TABLE 40
INJECTOR CURRENT LIMITING RESISTOR VALUES

| Injector <br> Current | 0.01 mA | 0.1 mA | 1 mA | 10 mA | 100 mA | 200 mA | Supply Voltage |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1.1M | 114K | 11K | 1.1 K | 110 | 56 | 12 V |
|  | 840K | 84 K | 8.4 K | 830 | 82 | 41 | 9 V |
|  | 540K | 54 K | 5.4 K | 530 | 52 | 26 | 6 V |
|  | 440K | 44K | 4.4 K | 430 | 42 | 21 | 5 V |
|  | 390K | 39K | 3.9K | 380 | 37 | 18 | 4.5 V |
|  | 240K | 24K | 2.4 K | 230 | 22 | 11 | 3 V |
|  | 90K | 9K | 960 | 82 | 7 | 3.25 | 1.5 V |
|  | 63K | 6K | 550 | 50 | 4 | 1.75 | 1.2 V |



FIGURE 27 - INJECTOR CURRENT CALCULATIONS


FIGURE 28 - INJECTOR-NODE VOLTAGE
VS. FREE-AIR TEMPERATURE


FIGURE 29 - INJECTOR-NODE VOLTAGE
VS. INJECTOR CURRENT

## 8. ELECTRICAL AND MECHANICAL SPECIFICATIONS

8.1 RECOMMENDED OPERATING CONDITIONS, UNLESS OTHERWISE NOTED ICC = 200 mA

|  |  | SBP0400AM |  |  | SBP0400AC |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply current, ICC |  |  | 200 | 300 |  | 200 | 300 | mA |
| High-level output voltage, $\mathrm{VOH}^{\text {O }}$ |  |  |  | 5.5 |  |  | 5.5 | V |
| Low-level output current, IOL | Any AOP, X, Y, ALUCOUT, DOP, or XWR MSB/LSB |  |  | 20 |  |  | 20 | mA |
|  | $\overline{\text { XWRLFT, }} \overline{\text { XWRRT }}, \overline{\text { WRRT }}, \overline{\text { WRLFT }}$, $\overline{\text { PCCOUT/BMSB, ENINCBY 2/AMSB }}$ |  |  | 10 |  |  | 10 |  |
| Width of clock pulse, $\mathrm{t}_{\mathrm{w}}$ | High | 255 |  |  | 230 |  |  | ns |
|  | Low | 50 |  |  | 45 |  |  |  |
| Setup time, $\mathrm{t}_{\text {su }}$ <br> (See Figure 30) | OPERATION SELECT (0400A ONLY) |  | 78 |  |  | 70 |  | ns |
|  | $\overline{\text { PCCIN }}$ |  | 28 |  |  | 25 |  |  |
|  | DIP $\rightarrow$ RF, WR, XWR |  | 110 |  |  | 100 |  |  |
|  | DIP THRU ALU |  | 200 |  |  | 180 |  |  |
|  | ALUCIN |  | 132 |  |  | 120 |  |  |
| Hold time, th (any input) |  | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | ns |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

$\uparrow$ Rising edge of clock pulse is reference.
8.2 ELECTRICAL CHARACTERISTICS (OVER RECOMMENDED OPERATING FREE-AIR TEMPERATURE RANGE, UNLESS OTHERWISE NOTED)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | SBP0400AM |  |  | SBP0400AC |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $V_{\text {IH }}$ | High-level input voltage |  |  |  |  |  | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.8 |  |  | 0.8 | V |
| $V_{\text {IK }}$ | Input clamp voltage |  | $\mathrm{I}^{\prime} \mathrm{CC}=200 \mathrm{~mA}$, | $I_{1}=-12 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  | $\begin{aligned} & \mathrm{ICC}=200 \mathrm{~mA}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V} \end{aligned}$ |  |  | 400 |  |  | 250 | $\mu \mathrm{A}$ |
| VOL | Low-level output voitage |  | $\begin{aligned} & \mathrm{I}_{\mathrm{CC}}=200 \mathrm{~mA}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{1 H}=2 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=\mathrm{MAX} \end{aligned}$ |  |  | 0.4 |  |  | 0.4 | V |
| $1 /$ | Input current | Clock, PCCIN | ${ }^{1} \mathrm{CC}=200 \mathrm{~mA}, \quad \mathrm{~V}_{1}=2.5 \mathrm{~V}$ |  | 500 |  |  | 500 |  |  | $\mu \mathrm{A}$ |
|  |  | All other inputs |  |  | 250 |  |  | 250 |  |  |  |

${ }^{\dagger}$ For conditions shown as MAX, use the appropriate value specified under recommended operating conditions.
$\ddagger$ All typical values are at ${ }^{\prime} \mathrm{CC}=200 \mathrm{~mA}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

### 8.3 SBP0400A AND SBP0401A SWITCHING CHARACTERISTICS ( ${ }^{1} \mathrm{CC}=200 \mathrm{~mA}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )

 SEE FIGURES 30 THROUGH 34| PARAMETER | FROM | то | TEST CONDITIONS | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH or tPHL | DIP | DOP | VIA A BUS, BYPASS ALU | 85 |  | ns |
| tPLH or tPHL | DIP | DOP | VIA A BUS, THRU ALU | 155 |  | ns |
| tPLH or tPHL | DIP | DOP | VIA B BUS, THRU ALU | 155 |  | ns |
| tPLH or tPHL | PC PRIORITY | AOP |  | 70 |  | ns |
| tPLH or tPHL | ALUCIN | ALUCOUT |  | 60 |  | ns |
| tPLH or tPHL | DIP | ENINCBY2/AMSB | POS0 $=X, \quad$ POS1 $=H$ | 80 |  | ns |
| tPLH or TPHL | DIP | $\overline{\text { PCCOUT/BMSB }}$ | POSO $=X, \quad$ POS1 $=H$ | 80 |  | ns |
| tPLH or tPHL | POS0, or POS1 | ENINCBY2/AMSB or PCCOUT/BMSB |  | 95 |  | ns |
| tPLH or tPHL | PCCIN | PCCOUT |  | 35 |  | ns |
| tPLH or tPHL | ALUCIN | DOP |  | 105 |  | ns |
| tPLH or tPHL | CLOCK | PCCOUT/BMSB | POSO $=\mathrm{X}, \quad$ POS1 $=\mathrm{H}$ | 140 |  | ns |
| tPLH or tPHL | CLOCK | DOP | VIA A BUS, BYPASS ALU | 155 |  | ns |
| ${ }^{\text {tPLH }}$ or TPHL | CLOCK | DOP | VIA A BUS, THRU ALU | 240 |  | ns |
| tPLH or tPHL | CLOCK | ENINCBY2/AMSB | POS0 $=\mathrm{X}, \quad$ POS1 $=\mathrm{H}$ | 155 |  | ns |
| tPLH or TPHL | CLOCK | DOP | VIA B BUS, THRU ALU | 225 |  | ns |
| tPLH or tPHL | CLOCK | $\overline{\text { P.G. or ALUCOUT }}$ | VIA A OR B BUS, THRU ALU | 180 |  | ns |
| tPLH or tPHL | CLOCK | AOP |  | 105 |  | ns |
| tPLH or TPHL | CLOCK | $\overline{W R L F T}, \overline{W R R T}, \overline{X W R L F T}$, or XWRRT |  | 240 |  | ns |
| tPLH or tPHL | CLOCK | XWR MUX MSB | POS0 $=\mathrm{H}, \quad \mathrm{POS1}=\mathrm{H}$ | 130 |  | ns |
| tPLH or tPHL | CLOCK | XWR MUX LSB | $\mathrm{POSO}=\mathrm{H}, \quad \mathrm{POS1}=\mathrm{L}$ | 130 |  | ns |
| tPLH Or TPHL | CLOCK | ALU $=0$ |  | 215 |  | ns |

### 8.4 SBP0401A OPERATION SELECT SWITCHING CHARACTERISTICS ( ${ }^{\prime} \mathrm{CC}=200 \mathrm{~mA}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ ) SEE FIGURES 31 THROUGH 34

| PARAMETER | FROM | TO | TEST CONDITIONS | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {tPLH }}$ or tPHL | OP SEL | XWR MUX MSB | POS0 $=\mathrm{H}_{\text {, }} \quad$ POS1 $=\mathrm{H}$ | 175 |  | ns |
| ${ }^{\text {tPLH }}$ or ${ }^{\text {TPHL }}$ | OP SEL | XWR MUX LSB | POS0 $=H, \quad$ POS1 $=L$ | 175 |  | ns |
| tPLH or tPHL | OP SEL | AOP |  | 130 |  | ns |
| tPLH or tPHL | OP SEL | ALU $=0$ |  | 215 |  | ns |
| tPLH or tPHL | OP SEL | $\overline{\mathrm{P}}, \overline{\mathrm{G}}$, or ALUCOUT | Via A or B bus, thru ALU | 180 |  | ns |
| tPLH or tPHL | OP SEL | DOP | Via A or B bus, thru ALU | 235 |  | ns |
| tPLH or tPHL | OP SEL | AMSB | POS0 $=X, \quad$ POS1 $=H$ | 140 |  | ns |
| tPLH or tPHL | OP SEL | BMSB | POSO $=X, \quad$ POS1 $=H$ | 175 |  | ns |



SETUP, HOLD, AND PROPAGATION DELAY TIMES FOR TYPICAL SBPO400A STORE OPERATION


SETUP, HOLD, AND PROPAGATION DELAY TIMES FOR TYPICAL SBPO400A ADD AND SHIFT OPERATION

FIGURE 30 - PROPAGATION DELAY TIMES - SBP0400A SYNCHRONOUS OPERATIONS


PC PRIORITY IS HIGH
FIGURE 31 - PROPAGATION DELAY TIMES - ASYNCHRONOUS OPERATIONS



| REF. | OUTPUTS | MAXIMUM CURRENT RATING | $R_{L}$ VALUE | $\mathrm{C}_{\mathrm{L}}$ VALUE |
| :---: | :---: | :---: | :---: | :---: |
| 1 | ANY AOB, DOB, $\overline{\mathrm{P}}, \overline{\mathrm{G}}, \mathrm{ALUCOUT}$ OR XWR MSB/LSB | 20 mA | $280 \Omega$ | 50 PF |
| 2 | $\overline{\bar{X} W R L F T}, \overline{X W R R T}, \overline{W R R T}, \overline{W R L F T}$, $\overline{\mathrm{PCCOUT}} / \mathrm{BMSB}, ~ E N I N C B Y 2 / A M S B$ | 10 mA | $560 \Omega$ | 25 PF |

FIGURE 33 - SWITCHING TIMES LOAD CIRCUITS



FIGURE 35 - PLASTIC DUAL-IN-LINE PACKAGE


FIGURE 36 - CERAMIC DUAL-IN-LINE PACKAGE
8.5 ORDERING INFORMATION

| PACKAGE | OPERATING <br> TEMPERATURE | PART NUMBERS |
| :---: | :---: | :---: |
| PLASTIC DIP | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | SBP0400ACN or SBP0401ACN |
| CERAMIC DIP | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | SBP0400ACJ or SBP0401ACJ |
|  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | SBP0400AMJ or SBP0401AMJ |

The Engineering Staff of
TEXAS INSTRUMENTS INCORPORATED
Semiconductor Group


OCTOBER 1976

TEXAS Instruments

Information contained in this publication is believed to be accurate and reliable. However, responsibility is assumed neither for its use nor for any infringement of patents or rights of others that may result from its use. No license is granted by implication or otherwise under any patent or patent right of Texas Instruments or others.

## TABLE OF CONTENTS

1. INTRODUCTION
1.1 Description ..... 1
1.2 Key Features ..... 1
2. ARCHITECTURE
2.1 Registers and Memory ..... 3
2.2 Interrupts ..... 5
2.3 I/O Interface Communications-Register-Unit (CRU) ..... 6
2.4 Single-Bit CRU Operations ..... 7
2.5 Multiple-Bit CRU Operations ..... 7
2.6 External Instructions ..... 9
2.7 Load Function ..... 10
2.8 SBP 9900 Pin Description ..... 11
2.9 SBP 9900 Timing ..... 13
2.9.1 SBP 9900 Memory ..... 13
2.9.2 SBP 9900 Hold ..... 14
2.9.3 SBP 9900 CRU ..... 14
3. $\quad 9900$ INSTRUCTION SET
3.1 Definition ..... 16
3.2 Addressing Modes ..... 16
3.2.1 Workspace Register Addressing R ..... 16
3.2.2 Workspace Register Indirect Addressing *R ..... 16
3.2.3 Workspace Register Indirect Auto Increment Addressing *R+ ..... 16
3.2.4 Symbolic (Direct) Addressing @ Label ..... 17
3.2.5 Indexed Addressing @ Table (R) ..... 17
3.2.6 Immediate Addressing ..... 17
3.2.7 Program Counter Relative Addressing ..... 17
3.2.8 CRU Relative Addressing ..... 17
3.3 Terms and Definitions ..... 18
3.4 Status Register ..... 18
3.5 Instructions ..... 19
3.5.1 Dual Operand Instructions with Multiple Addressing Modes for Source and Destination Operand ..... 19
3.5.2 Dual Operand Instructions with Multiple Addressing Modes for the Source Operand and Workspace Register Addressing for the Destination ..... 20
3.5.3 Extended Operation (XOP) Instruction ..... 21
3.5.4 Single Operand Instructions ..... 21
3.5.5 CRU Multiple-Bit Instructions ..... 22
3.5.6 CRU Single-Bit Instructions ..... 23
3.5.7 Jump Instructions ..... 23
3.5.8 Shift Instructions ..... 24
3.5.9 Immediate Register Instructions ..... 24
3.5.10 Internal Register Load Immediate Instructions ..... 24
3.5.11 Internal Register Store Instructions ..... 25
3.5.12 Return Workspace Pointer (RTWP) Instruction ..... 25
3.5.13 External Instructions ..... 25
3.6 Microinstruction Cycle ..... 26
3.7 SBP 9900 Instruction Execution Times ..... 26

## TABLE OF CONTENTS (Continued)

4. INTERFACING
4.1 Input Circuit ..... 29
4.1.1 Sourcing Inputs ..... 29
4.1.2 Terminating Unused Inputs ..... 29
4.2 Output Circuit ..... 30
5. POWER SOURCE ..... 30
6. ELECTRICAL AND MECHANICAL SPECIFICATIONS
6.1 SBP 9900 Recommended Operating Conditions ..... 32
6.2 SBP 9900 Electrical Characteristics ..... 33
6.3 SBP 9900 Switching Characteristics ..... 33
6.4 Clock Frequency Vs. Temperature ..... 35
7. MECHANICAL DATA ..... 35
8. SBP 9900 PROTOTYPING SYSTEM
8.1 Hardware ..... 36
8.2 System Console ..... 36
8.3 Software ..... 36
LIST OF ILLUSTRATIONS
Figure 1 Architecture ..... vi
Figure 29900 CPU Flow Chart ..... 2
Figure 3 Word and Byte Formats ..... 3
Figure 4 Memory Map ..... 4
Figure 5 Memory-to-Memory Workspace Concept ..... 5
Figure 69900 Interrupt Interface ..... 7
Figure 79900 Single-Bit CRU Address Development ..... 8
Figure 8 9900 LDCR/STCR Data Transfers ..... 8
Figure 9 9900 16-Bit Input/Output Interface ..... 9
Figure 10 External Instruction Decode Logic ..... 10
Figure 11 SBP 9900 Pin Assignments ..... 11
Figure 12 SBP 9900 Memory Bus Timing ..... 13
Figure 13 SBP 9900 Hold Timing ..... 15
Figure 14 SBP 9900 CRU Interface Timing ..... 15
Figure 15 Minimum SBP 9900 System ..... 28
Figure 16 Schematics of Equivalent Inputs, Outputs, Inputs/Outputs ..... 29
Figure 17 Typical Input Characteristics ..... 29
Figure 18 Typical Output Characteristics ..... 30
Figure 19 Injector Current Calculations ..... 31
Figure 20 Switching-Regulator Injector Source ..... 31
Figure 21 Clock Period Vs. Injector Current ..... 31
Figure 22 Injector-Node Voltage Vs. Free-Air Temperature ..... 32
Figure 23 Injector-Node Voltage Vs. Injector Current ..... 32

## LIST OF ILLUSTRATIONS (Continued)

Figure 24 Switching Times-Voltage Waveforms ..... 34
Figure 25 Switching Times Load Circuits ..... 34
Figure 26 A-C Performance Vs. Temperature ..... 35
LIST OF TABLES
Table 1 Interrupt Level Data ..... 6
Table 2 External Instructions ..... 10
Table 39900 Pin Assignments and Functions ..... 11
Table 4 Term Definitions ..... 18
Table 5 Status Register Bit Definitions ..... 19
Table 6 Instruction Execution Times ..... 27


FIGURE 1 - SBP 9900 ARCHITECTURE

## 1. INTRODUCTION

### 1.1 DESCRIPTION

The SBP 9900 microprocessor is a ruggedized monolithic parallel 16-bit Central Processing Unit (CPU) fabricated with Integrated Injection Logic ( 12 L ) technology. The SBP 9900 combines the properties of 12 L technology with a 16 -bit word length, an advanced memory to memory architecture, and a full minicomputer instruction set to extend the end application reach of Texas Instruments 9900 microprocessor family into those applications requiring efficient, stable, reliable performance in severe operating environments. 12L technology enables the SBP9900 to operate over a very wide ambient temperature range from a d-c power source with user selectable speed/power performance. Static Logic is used throughout with directly TTL compatible I/O permitting use with standard logic and memory devices and thereby eliminating the need for special clock and interface functions. The SBP 9900 is software compatible with other 9900 microprocessor family members and shares a common body of hardware/software with Texas Instruments 990 minicomputer family.

### 1.2 KEY FEATURES

- Parallel 16-Bit Word Length
- Full Minicomputer Instruction Set Includes Multiply and Divide
- Directly Addresses Up to 65,536 Bytes/32,768 Words of Memory
- Advanced Memory-To-Memory Architecture
- Multiple 16-Word Register Files (Work Spaces) Reside in Memory
- Separate I/O, Memory and Interrupt Bus Structures
- 16 Prioritized Hardware Interrupts
- 16 Software Interrupts (XOPS)
- Programmed and DMA I/O Capability
- Serial I/O Via Communications-Register-Unit (CRU)
- 64-Pin Package
- Software Compatible with TI 9900 Microprocessor/990 Minicomputer Family
- $\mathrm{I}^{2} \mathrm{~L}$ Technology:
- User Selectable Speed/Power Operation
- $\quad 2.6 \mathrm{MHz}$ Nominal Clock at 500 mW
- Single d-c Power Supply
- Fully Static Operation
- Single Phase Clock
- Directly TTL. Compatible I/O (Including Clock)
- Operates Over Wide Temperature Range:
$-\quad-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ for SBP 9900M, SBP 9900N (883 B)
$-\quad-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ for SBP 9900E


FIGURE 2-9900 CPU FLOW CHART

## 2. ARCHITECTURE

The memory word of the 9900 is 16 bits long. Each word is also defined as 2 bytes of 8 bits. The instruction set of the 9900 allows both word and byte operands. Thus, all memory locations are on even address boundaries and byte instructions can address either the even or odd byte. The memory space is 65,536 bytes or 32,768 words. The word and byte formats are shown in Figure 3.


FIGURE 3 - WORD AND BYTE FORMATS

### 2.1 REGISTERS AND MEMORY

The 9900 employs an advanced memory-to-memory architecture. Blocks of memory designated as workspace replace internal-hardware registers with program-data registers. The 9900 memory map is shown in Figure 4. The first 32 words are used for interrupt trap vectors. The next contiguous block of 32 memory words is used by the extended operation (XOP) instruction for trap vectors. The last two memory words, FFFC 16 and $\mathrm{FFFE}_{16}$, are used for the trap vector of the LOAD signal. The remaining memory is then available for programs, data, and workspace registers. If desired, any of the special areas may also be used as general memory.

Three internal registers are accessible to the user. The program counter (PC) contains the address of the instruction following the current instruction being executed. This address is referenced by the processor to fetch the next instruction from memory and is then automatically incremented. The status register (ST) contains the present state of the processor and will be further defined in Section 3.4. The workspace pointer (WP) contains the address of the first word in the currently active set of workspace registers.

A workspace-register file occupies 16 contiguous memory words in the general memory area (see Figure 4). Each workspace register may hold data or addresses and function as operand registers, accumulators, address registers, or index registers. During instruction execution, the processor addresses any register in the workspace by adding the register number to the contents of the workspace pointer and initiating a memory request for the word. The relationship between the workspace pointer and its corresponding workspace is shown in Figure 5.

The workspace concept is particularly valuable during operations that require a context switch which is a change from one program environment to another (as in the case of an interrupt) or to a subroutine. Such an operation, using a conventional multi-register arrangement, requires that at least part of the contents of the register file be stored and reloaded. A memory cycle is required to store or fetch each word. By exchanging the program counter, status register, and workspace pointer in the 9900 concept accomplishes a complete context switch withonly three store cycles and three fetch cycles. See Figure 5. After the switch the workspace pointer contains the starting address of a new 16 -word workspace in memory for use in the new routine. A corresponding time saving occurs when the original context is restored. Instructions in the 9900 that result in a context switch include:


FIGURE 4 - MEMORY MAP


FIGURE 5 - MEMORY-TO-MEMORY WORKSPACE CONCEPT

1. Branch and Load Workspace Pointer (BLWP)
2. Return from Subroutine (RTWP)
3. Extended Operation (XOP).

Device interrupts, $\overline{\mathrm{RESET}}$, and $\overline{\mathrm{LOAD}}$ also cause a context switch by forcing the processor to trap to a service subroutine.

### 2.2 INTERRUPTS

The 9900 employs 16 interrupt levels with the highest priority level 0 and lowest level 15 . Level 0 is reserved for the $\overline{R E S E T}$ function and all other levels may be used for external devices. The external levels may also be shared by several device interrupts, depending upon system requirements.

The 9900 continuously compares the interrupt code (ICO through IC3) with the interrupt mask contained in status-register bits 12 through 15 . When the level of the pending interrupt is less than or equal to the enabling mask level (higher or equal priority interrupt), the processor recognizes the interrupt and initiates a context switch following completion of the currently executing instruction. The processor fetches the new context WP and PC from the interrupt vector locations. Then, the previous context WP, PC, and ST are stored in workspace registers 13, 14, and 15 , respectively, of the new workspace. The 9900 then forces the interrupt mask to a value that is one less than
the level of the interrupt being serviced. This allows only interrupts of higher priority to interrupt a service routine. The processor also inhibits interrupts until the first instruction of the service routine has been executed. All interrupt requests should remain active until recognized by the processor in the device-service routine. The individual service routines must reset the interrupt requests before the routine is complete.

If a higher priority interrupt occurs, a second context switch occurs to service the higher priority interrupt. When that routine is complete, a return instruction (RTWP) restores the first service routine parameters to the processor to complete processing of the lower-priority interrupt. All interrupt subroutines should terminate with the return instruction to restore original program parameters. The interrupt-vector locations, device assignment, enabling-mask value, and the interrupt code are shown in Table 1.

TABLE 1
INTERRUPT LEVEL DATA

| Interrupt Level | Vector Location (Memory Address In Hex) | Device Assignment | Interrupt Mask Values To Enable Respective Interrupts (ST12 thru ST15) | Interrupt Codes ICO thru IC3 |
| :---: | :---: | :---: | :---: | :---: |
| (Highest priority) 0 | 00 | Reset | 0 through $\mathrm{F}^{*}$ | 0000 |
| 1 | 04 | External device | 1 through F | 0001 |
| 2 | 08 |  | 2 through F | 0010 |
| 3 | OC |  | 3 through F | 0011 |
| 4 | 10 |  | 4 through F | 0100 |
| 5 | 14 |  | 5 through F | 0101 |
| 6 | 18 |  | 6 through F | 0110 |
| 7 | 1 C |  | 7 through F | 0111 |
| 8 | 20 |  | 8 through F | 1000 |
| 9 | 24 |  | 9 through F | 1001 |
| 10 | 28 |  | A through F | 1010 |
| 11 | 2 C |  | B through F | 1011 |
| 12 | 30 |  | C through ' $F$ | 1100 |
| 13 | 34 |  | D through F | 1101 |
| 14 | 38 | $\checkmark$ | $E$ and $F$ | 1110 |
| (Lowest priority) 15 | 3 C | External device | Fonly | 1111 |

*Level 0 can not be disabled.

The 9900 interrupt interface utilizes standard TTL components as shown in Figure 6. Note that for eight or less external interrupts a single SN54/74148 is required and for one external interrupt INTREQ is used as the interrupt signal with a hard-wired code ICO through IC3.

### 2.3 I/O INTERFACE COMMUNICATIONS-REGISTER-UNIT (CRU)

The SBP 9900 communications-register-unit (CRU) is a versatile, direct command-driven serial I/O interface. The CRU may directly address, in bit-fields of one to sixteen, up to 4096 peripheral input bits and up to 4096 peripheral output bits. The SBP 9900 executes three single-bit and two multiple-bit CRU instructions. The single-bit instructions include TEST BIT (TB), SET BIT TO ONE (SBO), and SET BIT TO ZERO (SBZ); the multiple-bit instructions include LOAD CRU (LDCR) and STORE CRU (STCR).

The SBP 9900 employs three dedicated I/O signals CRUIN, CRUOUT, CRUCLK, and the least significant twelve bits of the address bus to support the CRU interface. CRU interface timing is shown in Section 2.9.


FIGURE 6-9900 INTERRUPT INTERFACE

## SINGLE-BIT CRU OPERATIONS

The 9900 performs three single-bit CRU functions: test bit (TB), set bit to one (SBO), and set bit to zero (SBZ). To identify the bit to be operated upon, the 9900 develops a CRU-bit address and places it on the address bus, A3 to A14.

For the two output operations (SBO and SBZ), the processor also generates a CRUCLK pulse, indicating an output operation to the CRU device, and places bit 7 of the instruction word on the CRUOUT line to accomplish the specified operation (bit 7 is a one for SBO and a zero for SBZ). A test-bit instruction transfers the addressed CRU bit from the CRUIN input line to bit 2 of the status register (EQUAL).

The 9900 develops a CRU-bit address for the single-bit operations from the CRU-base address contained in workspace register 12 and the signed displacement count contained in bits 8 through 15 of the instruction. The displacement allows two's complement addressing from base minus 128 bits through base plus 127 bits. The base address from W12 is added to the signed displacement specified in the instruction and the result is loaded onto the address bus. Figure 7 illustrates the development of a single-bit CRU address.

MULTIPLE-BIT CRU OPERATIONS

The 9900 performs two multiple-bit CRU operations: store communications register (STCR) and load communications register (LDCR). Both operations perform a data transfer from the CRU-to-memory or from memory-to-CRU as illustrated in Figure 8. Although the figure illustrates a full 16-bit transfer operation, any number of bits from 1 through 16 may be involved. The LDCR instruction fetches a word from memory and right-shifts it to serially transfer it to CRU output bits. If the LDCR involves eight or fewer bits, those bits come from the right-justified field within the addressed byte of the memory word. If the LDCR involves nine or more bits, those bits come from the right-justified field within the whole memory word. When transferred to the CRU interface, each successive bit receives an address that is sequentially greater than the address for the previous bit. This addressing mechanism results


FIGURE 7 - 9900 SINGLE-BIT CRU ADDRESS DEVELOPMENT


FIGURE 8 - 9900 LDCR/STCR DATA TRANSFERS
in an order reversal of the bits; that is, bit 15 of the memory word (or bit 7) becomes the lowest addressed bit in the CRU and bit 0 becomes the highest addressed bit in the CRU field.

An STCR instruction transfers data from the CRU to memory. If the operation involves a byte or less transfer, the transferred data will be stored right-justified in the memory byte with leading bits set to zero. If the operation involves from nine to 16 bits, the transferred data is stored right-justified in the memory word with leading bits set to
zero. When the input from the CRU device is complete, the first bit from the CRU is the least-significant-bit position in the memory word or byte.

Figure 9 illustrates how to implement a 16 -bit input and a 16 -bit output register in the CRU interface. CRU addresses are decoded as needed to implement up to 256 such 16 -bit interface registers. In system application, however, only the exact number of interface bits needed to interface specific peripheral devices are implemented. It is not necessary to have a 16 -bit interface register to interface an 8 -bit device.


FIGURE 9 - 9900 16-BIT INPUT/OUTPUT INTERFACE

## 2.6

## EXTERNAL INSTRUCTIONS

The 9900 has five external instructions that allow user-defined external functions to be initiated under program control. These instructions are CKON, CKOF, RSET, IDLE, and LREX. These mnemonics, except for IDLE, relate to functions implemented in the 990 minicomputer and do not restrict use of the instructions to initiate various user-defined functions. IDLE also causes the 9900 to enter the idle state and remain until an interrupt, $\overline{\text { RESET, or }}$ $\overline{\text { LOAD }}$ occurs. When any of these five instructions are executed by the 9900 , a unique 3 -bit code appears on the most-significant 3 bits of the address bus (AO through A2) along with a CRUCLK pulse. When the 9900 is in an idle state, the 3 -bit code and CRUCLK pulses occur repeatedly until the idle state is terminated. The codes are shown in Table 2.

Figure 10 illustrates typical external decode logic to implement these instructions. Note that a signal is generated to inhibit CRU decodes during external instructions.
tABLE 2
EXTERNAL INSTRUCTIONS

| EXTERNAL INSTRUCTION | A0 | A1 | A2 |
| :---: | :---: | :---: | :---: |
| LREX | H | $H$ | $H$ |
| CKOF | $H$ | $H$ | L |
| CKON | $H$ | L | $H$ |
| RSET | L | $H$ | $H$ |
| IDLE | L | $H$ | L |



FIGURE 10 - EXTERNAL INSTRUCTION DECODE LOGIC

### 2.7 LOAD FUNCTION

The LOAD signal allows cold-start ROM loaders and front panels to be implemented for the 9900 . When active, LOAD causes the 9900 to initiate an interrupt sequence immediately following the instruction being executed. Memory location FFFC is used to obtain the vector (WP and PC). The old PC, WP and ST are loaded into the new workspace and the interrupt mask is set to 0000 . Then, program execution resumes using the new PC and WP.

### 2.8 SBP 9900 PIN DESCRIPTION

Table 3 describes the function of each SBP 9900 pin, and Figure 11 illustrates their assigned locations.

TABLE 3
9900 PIN ASSIGNMENTS AND FUNCTIONS


TABLE 3 (CONTINUED)

| SIGNATURE | PIN | 1/0 | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| CRUCLK | 60 | OUT | COMMUNICATIONS-REGISTER-UNIT (CRU) CLOCK. When active (pulled to logic level HIGH), CRUCLK indicates to the external interface logic the presence of output data on CRUOUT, or the presence of an encoded external instruction on A0 through A2. |
| CRUIN | 31 | IN | CRU DATA IN. CRUIN, normally driven by 3-state or open-collector devices, receives input data from the external interface logic. When the SBP 9900 executes a STCR or TB instruction, it samples CRUIN for the level of the CRU input bit specified by the address bus (A3 through A14). |
| CRUOUT | 30 | OUT | CRU DATA OUT. CRUOUT outputs serial data when the SBP 9900 executes a LDCR, SBZ, SBO instruction. The data on CRUOUT should be sampled by the external interface logic when CRUCLK goes active (pulled to logic level HIGH). |
|  |  |  | INTERRUPT CONTROL |
| $\overline{\text { INTREQ }}$ | 32 | IN | INTERRUPT REQUEST. When active (logic level LOW), INTREO indicates that an external interrupt is requesting service. If $\overline{\text { INTREQ }}$ is active, the SBP 9900 loads the data on the interrupt-code input-lines ICO through IC3 into the internal interrupt-code storage register. The code is then compared to the interrupt mask bits of the status register. If equal or higher priority than the enabled interrupt level (interrupt code equal or less than status register bits 12 through 15), the SBP 9900 initiates the interrupt sequence. If the comparison fails, the SBP 9900 ignores the interrupt request. In that case, INTREQ should be held active. The SBP 9900 will continue to sample ICO through IC3 until the program enables a sufficiently low interrupt-level to accept the requesting interrupt. |
| ICO (MSB) | 36 | IN | INTERRUPT CODES. ICO (MSB) through IC3 (LSB), receiving an interrupt identity code, are sampled by the SBP 9900 when INTREX is active (logic level LOW). When ICO through IC3 are LLLH, the highest priority external interrupt is requesting service; when HHHH , the lowest priority external interrupt is |
| IC3 (LSB) | 33 | IN |  |

## MEMORY CONTROL

When active (logic level LOW), HOLD indicates to the SBP 9900 that an external controller (e.g., DMA device) desires to use both the address bus and data bus to transfer data to or from memory. In response, the SBP 9900 enters the hold state after completion of its present memory cycle. The SBP 9900 then allows its address bus, data bus, $\overline{W E}, \overline{M E M E N}$, DBIN, and HOLDA facilities to be pulled to the logic level HIGH state. When HOLD is deactivated, the SBP 9900 returns to normal operation from the point at which it was stopped.

HOLD ACKNOWLEDGE. When active (pulled to logic level HIGH), HOLDA indicates that the SBP 9900 is in the hold state and that its address bus, data bus, $\bar{W} E, \overline{M E M E N}$, and DBIN facilities are pulled to the logic level HIGH state.

When active (logic level HIGH), READY indicates that the memory will be ready to read or write during the next clock cycle. When not-ready is indicated during a memory operation, the SBP 9900 enters a wait state and suspends internal operation until the memory systems activate READY.

When active (pulled to logic level HIGH), WAIT indicates that the SBP 9900 has entered a wait state in response to a not-ready condition from memory.

## TIMING AND CONTROL

INSTRUCTION ACQUISITION. IAQ is active (pulled to logic level HIGH) during any SBP 9900 initiated instruction acquisition memory cycle. Consequently, IAQ may be used to facilitate detection of illegal op codes.

CYCLE END. When active (logic level LOW), CYCEND indicates that the SBP 9900 will initiate a new machine cycle on the low-to-high transition of the next CLOCK.

When active (logic level LOW), $\overline{\text { LOAD causes the SBP } 9900 \text { to execute a nonmaskable interrupt with }}$ memory addresses FFFC 16 and FFFE 16 containing the associated trap vectors (WP and PC). The load sequence is initiated after the instruction being executed is completed. $\overline{\text { LOAD }}$ will also terminate an idle state. If $\overline{L O A D}$ is active during the time $\overline{\operatorname{RESET}}$ is active, the $\overline{\text { LOAD }}$ trap will occur after the RESET function is completed. $\overline{L O A D}$ should remain active for one instruction execution period (IAQ may be

TABLE 3 (CONCLUDED)

| SIGNATURE | PIN | I/O | DESCRIPTION |
| :--- | :--- | :--- | :--- |
| $\overline{\text { LOAD (Cont.) }}$ |  |  | used to monitor instruction boundaries). $\overline{\text { LOAD may be used to implement cold-start ROM loaders. }}$ <br> Additionally, front-panel routines may be implemented using CRU bits as front-panel-interface signals, <br> and software-control routines to direct the panel operations. |
| $\overline{\text { RESET }}$ | 6 | IN | When active (logic level LOW), $\overline{R E S E T}$ causes the SBP 9900 to reset itself and inhibit $\overline{W E}$ and CRUCLK. <br> When $\overline{R E S E T}$ is released, the SBP 9900 initiates a level-zero interrupt sequence acquiring the WP and PC <br> trap vectors from memory locations 0000 <br> and then fetches the first instruction of the reset program environment. RESET must be held active for a <br> minimum of three CLOCK cycles. |

### 2.9 SBP 9900 TIMING

### 2.9.1 SBP 9900 MEMORY

The SBP 9900 basic memory timing for a memory-read cycle with no wait states, and a memory-write cycle with one wait state, is as shown in Figure 12. During each memory-read or memory-write cycle, MEMEN becomes active (logic level LOW) along with valid memory-address data appearing on the address bus (A0 through A14).


FIGURE 12 - SBP 9900 MEMORY BUS TIMING

In the case of a memory-read cycle, DBIN becomes active (pulled to logic level HIGH) at the same time memory-address data becomes valid; the memory write strobe $\overline{W E}$ remains inactive (pulled to logic level HIGH). If the memory-read cycle is initiated for acquisition of an instruction, IAQ becomes active (pulled to logic level HIGH) at the same time $\overline{M E M E N}$ becomes active. At the end of a memory-read cycle, $\overline{M E M E N}$ and DBIN together become inactive. At that time, though the address may change, the data bus remains in the input mode until terminated by the next high-to-low transition of the clock.

In the case of a memory-write cycle, $\overline{W E}$ becomes active (logic level LOW) with the first high-to-low transition of the clock after $\overline{M E M E N}$ becomes active; DBIN remains inactive. At the end of a memory-write cycle, $\bar{W} E$ and $\overline{M E M E N}$ together become inactive.

During either a memory-read or a memory-write operation, READY may be used to extend the duration of the associated memory cycle such that the speed of the memory system may be coordinated with the speed of the SBP 9900. If READY is inactive (logic level LOW) during the first low-to-high transition of the clock after MEMEN becomes active, the SBP 9900 will enter a wait state suspending further progress of the memory cycle. The first low-to-high transition of the clock after READY becomes active terminates the wait state and allows normal completion of the memory cycle.

### 2.9.2 SBP 9900 HOLD

The SBP 9900 hold facilities allow both the '9900 and external devices to share a common memory. To gain memory-bus control, an external device requiring direct memory access (DMA) sends a hold request (पOLD) to the SBP 9900. When the next available non-memory cycle occurs, the SBP 9900 enters a hold state and signals its surrender of the memory-bus to the external device via a hold acknowledge (HOLDA). Receiving the hold acknowledgement, the external device proceeds to utilize the common memory. After its memory requirements have been satisfied, the external device returns memory-bus control to the SBP 9900 by releasing HOLD.

When $\overline{H O L D}$ becomes active (logic level LOW), the SBP 9900 enters a hold state at the beginning of the next available non-memory cycle as shown below. Upon entering a hold state, HOLDA becomes active (pulled to logic level HIGH) with the following signals pulled to a HIGH logic level by the individual pull-up resistors tied to each respective open-collector output: DBIN, MEMEN, WE, AO through A14, and DO through D15. When $\overline{H O L D}$ becomes inactive, the SBP 9900 exits the hold state and regains memory-bus control. If HOLD becomes active during a CRU operation, the SBP 9900 uses an extra clock cycle after the deactivation of HOLD to reassert the CRU address thereby providing the normal setup time for the CRU-bit transfer.

### 2.9.3 SBP 9900 CRU

The transfer of two data-bits from memory to a peripheral CRU device, and the transfer of one data-bit from a peripheral CRU device to memory, is shown in Figure 14. To transfer a data-bit to a peripheral CRU device, the SBP 9900 outputs the corresponding CRU-bit-address on address bus bits A3 through A14 and the respective data-bit on CRUOUT. During the second clock cycle of the operation, the SBP 9900 outputs a pulse, on CRUCLK, indicating to the peripheral CRU device the presence of a data-bit. This process is repeated until transfer of the entire field of data-bits specified by the CRU instruction has been accomplished. To transfer a data-bit from a peripheral CRU device, the SBP 9900 outputs the corresponding CRU-bit-Address on address bus bits A3 through A14 and receives the respective data-bit on CRUIN. No CRUCLK pulses occur during a CRU input operation.


FIGURE 13 - SBP 9900 HOLD TIMING


FIGURE 14 - SBP 9900 CRU INTERFACE TIMING

## 3. 9900 INSTRUCTION SET

### 3.1 DEFINITION

Each 9900 instruction performs one of the following operations:

- Arithmetic, logical, comparison, or manipulation operations on data
- Loading or storage of internal registers (program counter, workspace pointer, or status)
- Data transfer between memory and external devices via the CRU
- Control functions.


### 3.2 ADDRESSING MODES

The 9900 instructions contain a variety of available modes for addressing random-memory data (e.g., program parameters and flags), or formatted memory data (character strings, data lists, etc.). The following figures graphically describe the derivation of the effective address for each addressing mode. The applicability of addressing modes to particular instructions is described in Section 3.5 along with the description of the operations performed by the instruction. The symbols following the names of the addressing modes [ $R,{ }^{*} R,{ }^{*} R+$, @ LABEL, or @ TABLE (R)] are the general forms used by 9900 assemblers to select the addressing mode for register $R$.

### 3.2.1 WORKSPACE REGISTER ADDRESSING

Workspace Register R contains the operand.


### 3.2.2 WORKSPACE REGISTER INDIRECT ADDRESSING *R

Workspace Register R contains the address of the operand.


### 3.2.3 WORKSPACE REGISTER INDIRECT AUTO INCREMENT ADDRESSING *R+

Workspace Register R contains the address of the operand. After acquiring the operand, the contents of workspace register R are incremented.


### 3.2.4 SYMBOLIC (DIRECT) ADDRESSING @ LABEL

The word following the instruction contains the address of the operand.


### 3.2.5 INDEXED ADDRESSING @ TABLE (R)

The word following the instruction contains the base address. Workspace register R contains the index value. The sum of the base address and the index value results in the effective address of the operand.


### 3.2.6 IMMEDIATE ADDRESSING

The word following the instruction contains the operand.


### 3.2.7 PROGRAM COUNTER RELATIVE ADDRESSING

The 8 -bit signed displacement in the right byte (bits 8 through 15) of the instruction is multiplied by 2 and added to the updated contents of the program counter. The result is placed in the PC.


### 3.2.8 CRU RELATIVE ADDRESSING

The 8 -bit signed displacement in the right byte of the instruction is added to the CRU base address (bits 3 through 14 of the workspace register 12). The result is the CRU address of the selected CRU bit.


### 3.3 TERMS AND DEFINITIONS

The terms used in describing the instructions of the 9900 are defined in Table 4.

TABLE 4
TERM DEFINITIONS

| TERM | DEFINITION |
| :---: | :---: |
| B | Byte indicator (1=byte, $0=$ word) |
| C | Bit count |
| D | Destination address register |
| DA | Destination address |
| IOP | Immediate operand |
| LSB( n ) | Least significant (right most) bit of (n) |
| MSB(n) | Most significant (left most) bit of ( n ) |
| N | Don't care |
| PC | Program counter |
| Result | Result of operation performed by instruction |
| S | Source address register |
| SA | Source address |
| ST | Status register |
| STn | Bit n of status register |
| $T_{\text {D }}$ | Destination address modifier |
| ${ }^{\text {T }}$ S | Source address modifier |
| W | Workspace register |
| WRn | Workspace register n |
| ( $n$ ) | Contents of $n$ |
| $a \rightarrow b$ | $a$ is transferred to b |
| $\|n\|$ | Absolute value of $n$ |
| + | Arithmetic addition |
| - | Arithmetic subtraction |
| AND | Logical AND |
| OR | Logical OR |
| $\oplus$ | Logical exclusive OR |
| $\bar{\square}$ | Logical complement of $n$ |

### 3.4 STATUS REGISTER

The status register contains the interrupt mask level and information pertaining to the instruction operation. Table 5 explains the bit indications.

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { STO } \\ & \text { L } \end{aligned}$ | $\begin{gathered} \text { ST1 } \\ \text { A> } \end{gathered}$ | ST2 $=$ | $\begin{gathered} \text { ST3 } \\ \mathrm{C} \end{gathered}$ | $\begin{gathered} \text { ST4 } \\ 0 \end{gathered}$ | $\begin{gathered} \text { ST5 } \\ \text { P } \end{gathered}$ | $\begin{gathered} \text { ST6 } \\ \text { X } \end{gathered}$ |  | not used ( $=0$ ) |  |  |  | ST12 ST13 ST14 ST15 Interrupt Mask |  |  |  |

TABLE 5
STATUS REGISTER BIT DEFINITIONS

| BIT | NAME | INSTRUCTION | CONDITION TO SET BIT TO 1 |
| :---: | :---: | :---: | :---: |
| STO | LOGICAL GREATER THAN | $\mathrm{C}, \mathrm{CB}$ <br> Cl <br> ABS <br> All Others | ```If MSB(SA) = 1 and MSB(DA) =0, or if MSB(SA) = MSB(DA) and MSB of [(DA)-(SA)] =1 If MSB(W)=1 and MSB of IOP = 0, or if MSB (W) = MSB of IOP and MSB of [IOP-(W)] =1 If (SA) }\not= If result }\not=``` |
| ST1 | ARITHMETIC GREATER THAN | $\mathrm{C}, \mathrm{CB}$ <br> Cl <br> ABS <br> All Others | ```If MSB(SA) = 0 and MSB(DA) = 1, or if MSB(SA) =MSB(DA) and MSB of [(DA)-(SA)] = 1 If MSB(W)=0 and MSB of IOP = 1, or if MSB(W) =MSB of IOP and MSB of [IOP-(W)] =1 If MSB(SA) = 0 and (SA) =0 If MSB of result =0 and result }\not=``` |
| ST2 | EQUAL | $\begin{aligned} & \mathrm{C}, \mathrm{CB} \\ & \mathrm{C} 1 \\ & \mathrm{COC} \\ & \mathrm{CZC} \\ & \mathrm{~TB} \\ & \mathrm{ABS} \\ & \text { All Others } \end{aligned}$ | If $(S A)=(D A)$ <br> If $(W)=1 O P$ <br> If $(S A)$ and $(\overline{D A})=0$ <br> If $(S A)$ and $(D A)=0$ <br> If CRUIN = 1 <br> If $(S A)=0$ <br> If result $=0$ |
| ST3 | CARRY | $\begin{aligned} & \text { A, AB, ABS, AI, DEC, } \\ & \text { DECT, INC, INCT, } \\ & \text { NEG, S, SB } \\ & \text { SLA, SRA, SRC, SRL } \end{aligned}$ | If CARRY OUT $=1$ <br> If last bit shifted out $=1$ |
| ST4 | OVERFLOW | $A, A B$ <br> AI <br> S, SB <br> DEC, DECT <br> INC, INCT <br> SLA <br> DIV <br> ABS, NEG | ```If MSB(SA) = MSB(DA) and MSB of result }\not=\mathrm{ MSB(DA) If MSB(W) = MSB of IOP and MSB of result }\not==\mathrm{ MSB(W) If MSB(SA) }=\mathrm{ MSB(DA) and MSB of result }\not=\mathrm{ MSB(DA) If MSB(SA) = 1 and MSB of result =0 If MSB(SA) = 0 and MSB of result = 1 If MSB changes during shift If MSB(SA) = 0 and MSB(DA) = 1, or if MSB(SA) = MSB(DA) and MSB of [(DA)-(SA)] = 0 If (SA) = 800016``` |
| ST5 | PARITY | $\begin{aligned} & \text { CB, MOVB } \\ & \text { LDCR, STCR } \\ & \text { AB, SB, SOCB, SZCB } \end{aligned}$ | If (SA) has odd number of 1's <br> If $1 \leqslant C \leqslant 8$ and (SA) has odd number of 1 's If result has odd number of 1 's |
| ST6 | XOP | XOP | If XOP instruction is executed |
| ST12-ST15 | INTERRUPT MASK | LIMI RTWP | If corresponding bit of IOP is 1 If corresponding bit of WR15 is 1 |

### 3.5 INSTRUCTIONS

3.5.1 Dual Operand Instructions with Multiple Addressing Modes for Source and Destination Operand

General format: | OP CODE | B | $T_{D}$ | $D$ | $T_{S}$ | S |
| :---: | :---: | :---: | :---: | :---: | :---: |

If $B=1$ the operands are bytes and the operand addresses are byte addresses. If $B=0$ the operands are words and the operand addresses are word addresses.

The addressing mode for each operand is determined by the $T$ field of that operand.

| TS OR TD | S OR D | ADDRESSING MODE | NOTES |
| :---: | :--- | :--- | :---: |
| 00 | $0,1, \ldots 15$ | Workspace register | 1 |
| 01 | $0,1, \ldots 15$ | Workspace register indirect |  |
| 10 | 0 | Symbolic | 4 |
| 10 | $1,2, \ldots 15$ | Indexed | 2,4 |
| 11 | $0,1, \ldots 15$ | Workspace register indirect auto-increment | 3 |

NOTES: 1. When a workspace register is the operand of a byte instruction (bit $3=1$ ), the left byte (bits 0 through 7 ) is the operand and the right byte (bits 8 through 15) is unchanged.
2. Workspace register 0 may not be used for indexing.
3. The workspace register is incremented by 1 for byte instructions (bit $3=1$ ) and is incremented by 2 for word instructions (bit $3=0$ ).
4. When $T_{S}=T_{D}=10$, two words are required in addition to the instruction word. The first word is the source operand base address and the second word is the destination operand base address.

| MNEMONIC | OP CODE |  |  | $\begin{aligned} & \text { B } \\ & 3 \end{aligned}$ | MEANING | ```RESULT COMPARED TO O``` | STATUS BITS AFFECTED | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 |  |  |  |  |  |
| A | 1 | 0 | 1 | 0 | Add | Yes | 0-4 | $(\mathrm{SA})+(\mathrm{DA}) \rightarrow(\mathrm{DA})$ |
| $A B$ | 1 | 0 | 1 | 1 | Add bytes | Yes | 0-5 | $(S A)+(D A) \rightarrow(D A)$ |
| C | 1 | 0 | 0 | 0 | Compare | No | 0-2 | Compare (SA) to (DA) and set appropriate status bits |
| CB | 1 | 0 | 0 | 1 | Compare bytes | No | 0-2,5 | Compare (SA) to (DA) and set appropriate status bits |
| S | 0 | 1 | 1 | 0 | Subtract | Yes | 0-4 | $(D A)-(S A) \rightarrow(D A)$ |
| SB | 0 | 1 | 1 | 1 | Subtract bytes | Yes | 0-5 | $(D A)-(S A) \rightarrow(D A)$ |
| SOC | 1 | 1 | 1 | 0 | Set ones corresponding | Yes | 0-2 | $(\mathrm{DA}) \mathrm{OR}(\mathrm{SA}) \rightarrow(\mathrm{DA})$ |
| SOCB | 1 | 1 | 1 | 1 | Set ones corresponding bytes | Yes | 0-2,5 | $(\mathrm{DA})$ OR $(S A) \rightarrow(D A)$ |
| SZC | 0 | 1 | 0 | 0 | Set zeroes corresponding | Yes | 0-2 | $(\mathrm{DA}) \mathrm{AND}(\overline{S A}) \rightarrow(\mathrm{DA})$ |
| SZCB | 0 | 1 | 0 | 1 | Set zeroes corresponding bytes | Yes | 0-2,5 | $(\mathrm{DA})$ AND $(\overline{S A}) \rightarrow(\mathrm{DA})$ |
| MOV | 1 | 1 | 0 | 0 | Move | Yes | 0-2 | $(S A) \rightarrow(D A)$ |
| MOVB | 1 | 1 | 0 | 1 | Move bytes | Yes | 0-2,5 | $(S A) \rightarrow(D A)$ |

3.5.2 Dual Operand Instructions with Multiple Addressing Modes for the Source Operand and Workspace Register Addressing for the Destination


The addressing mode for the source operand is determined by the $T_{S}$ field.

| TS | $\mathbf{S}$ | ADDRESSING MODE | NOTES |
| :--- | :--- | :--- | :---: |
| 00 | $0,1, \ldots 15$ | Workspace register |  |
| 01 | $0,1, \ldots 15$ | Workspace register indirect |  |
| 10 | 0 | Symbolic | 1 |
| 10 | $1,2, \ldots 15$ | Indexed | 1 |
| 11 | $0,1, \ldots 15$ | Workspace register indirect auto increment | 2 |

NOTES: 1. Workspace register 0 may not be used for indexing.
2. The workspace register is incremented by 2 .

| MNEMONIC | OP CODE | MEANING | RESULT COMPARED TO 0 | STATUS BITS <br> AFFECTED | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 012345 |  |  |  |  |
| COC | 001000 | Compare ones corresponding | No | 2 | Test (D) to determine if 1 's are in each bit position where 1's are in (SA). If so, set ST2. |
| CZC | 001001 | Compare zeros corresponding | No | 2 | Test ( $D$ ) to determine if 0 's are in each bit position where 1's are in (SA). If so, set ST2. |
| XOR | 001010 | Exclusive OR | Yes | 0-2 | $(\mathrm{D}) \oplus(S A) \rightarrow(D)$ |
| MPY | 001110 | Multiply | No |  | Multiply unsigned (D) by unsigned (SA) and place unsigned 32 -bit product in $D$ (most significant) and $D+1$ (least significant). If WR15 is D, the next word in memory after WR15 will be used for the least significant half of the product. |
| DIV | 0001111 | Divide | No | 4 | If unsigned ( $S A$ ) is less than or equal to unsigned (D), perform no operation and set ST4. Otherwise divide unsigned ( $D$ ) and ( $D+1$ ) by unsigned $(S A)$. Quotient $\rightarrow(D)$, remainder $\rightarrow(D+1)$. If $D=15$, the next word in memory after WR 15 will be used for the remainder. |

### 3.5.3 Extended Operation (XOP) Instruction

General format:

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | 0 | 1 | 1 |  | D |  | $\mathrm{T}_{\mathrm{S}}$ |  | S |  |  |

The $T_{S}$ and $S$ fields provide multiple mode addressing capability for the source operand. When the XOP is executed, ST6 is set and the following transfers occur:

$$
\begin{aligned}
& \left(40_{16}+4 D\right) \rightarrow(W P) \\
& (4216+4 D) \rightarrow(P C) \\
& S A \rightarrow(\text { new WR11) } \\
& (\text { old } W P) \rightarrow(\text { new WR 13) } \\
& (\text { old } P C) \rightarrow(\text { new WR14) } \\
& \text { (old } S T) \rightarrow(\text { new WR } 15)
\end{aligned}
$$

The 9900 does not test interrupt requests ( $\overline{\text { INTREQ }}$ ) upon completion of the XOP instruction.

### 3.5.4 Single Operand Instructions

General format:

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | $O P$ OODE |  |  |  |  | $T_{S}$ |  | $S$ |  |  |  |  |  |  |  |

The $T_{S}$ and $S$ fields provide multiple mode addressing capability for the source operand.

| MNEMONIC | OP CODE | MEANING | RESULT COMPARED TO 0 | STATUS BITS AFFECTED | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0123456789 |  |  |  |  |
| B | $\begin{array}{llllllllll} 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 1 \\ 0 & 0 & 0 & 0 & 0 & 1 & 1 & 0 & 1 & 0 \\ 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 \end{array}$ | Branch <br> Branch and link <br> Branch and load workspace pointer | No | - | $S A \rightarrow(P C)$ |
| BL |  |  | No | - | $(P C) \rightarrow(W R 11) ; S A \rightarrow(P C)$ |
| BLWP |  |  | No | - | $(S A) \rightarrow(W P) ;(S A+2) \rightarrow(P C)$ |
|  |  |  |  |  | (old WP) $\rightarrow$ (new WR 13); <br> (old PC) $\rightarrow$ (new WR14); |
|  |  |  |  |  | (old ST) $\rightarrow$ (new WR15); |
|  |  |  |  |  | the interrupt input (INTREQ) is not tested upon completion of the |
|  |  |  |  |  | BLWP instruction. |
| CLR | 000000100011 | Clear operand | No | - | $0 \rightarrow$ (SA) |
| SETO | 00000111100 | Set to ones | No | - | $\mathrm{FFFF}_{16} \rightarrow$ (SA) |
| INV | 0000010101 | Invert | Yes | 0-2 | $(\overline{S A}) \rightarrow(S A)$ |
| NEG | 00000100100 | Negate | Yes | 0-4 | $-(S A) \rightarrow(S A)$ |
| ABS | 000000111101 | Absolute value* | No | 0-4 | $\|(S A)\| \rightarrow(S A)$ |
| SWPB | 000000110011 | Swap bytes | No | - | (SA), bits 0 thru $7 \rightarrow$ (SA), bits |
|  |  |  |  |  | 8 thru 15; (SA), bits 8 thru $15 \rightarrow$ (SA), bits 0 thru 7. |
| INC | 00000100110 | Increment | Yes | 0-4 | $(S A)+1 \rightarrow(S A)$ |
| INCT | 000000100111 | Increment by two | Yes | 0-4 | $(S A)+2 \rightarrow(S A)$ |
| DEC | 0000011000 | Decrement | Yes | 0-4 | $(S A)-1 \rightarrow(S A)$ |
| DECT | 0000001110001 | Decrement by two | Yes | 0.4 | $(S A)-2 \rightarrow(S A)$ |
| $\mathrm{X}^{\dagger}$ | 0000010010 | Execute | No | - | Execute the instruction at SA. |

* Operand is compared to zero for status bit.
${ }^{\dagger}$ If additional memory words for the execute instruction are required to define the operands of the instruction located at SA, these words will be accessed from PC and the PC will be updated accordingly. The instruction acquisition signal (IAQ) will not be true when the 9900 accesses the instruction at SA. Status bits are affected in the normal manner for the instruction executed.


### 3.5.5 CRU Multiple-Bit Instructions

|  | 0 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| General format: |  |  |  |  |  |  |  |  |  | T |  |  |  |  |  |

The $C$ field specifies the number of bits to be transferred. If $C=0,16$ bits will be transferred. The CRU base register (WR12, bits 3 through 14) defines the starting CRU bit address. The bits are transferred serially and the CRU address is incremented with each bit transfer, although the contents of WR12 is not affected. TS and S provide multiple mode addressing capability for the source operand. If 8 or fewer bits are transferred ( $\mathrm{C}=1$ through 8 ), the source address is a byte address. If 9 or more bits are transferred ( $C=0,9$ through 15 ), the source address is a word address. If the source is addressed in the workspace register indirect auto increment mode, the workspace register is incremented by 1 if $\mathrm{C}=1$ through 8 , and is incremented by 2 otherwise.

| MNEMONIC | OP CODE | MEANING | RESULT COMPARED TO 0 | STATUS | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 012345 |  |  | BITS <br> AFFECTED |  |
| LDCR | $001100$ | Load communcation register | Yes | 0-2,5 ${ }^{+}$ | Beginning with LSB of (SA), transfer the specified number of bits from (SA) to the CRU. |
| STCR | 001101 | Store communcation register | Yes | 0-2,5 ${ }^{\dagger}$ | Beginning with LSB of (SA), transfer the specified number of bits from the CRU to (SA). Load unfilled bit positions with 0 . |

${ }^{\dagger}$ ST5 is affected only if $1 \leqslant C \leqslant 8$.
3.5.6 CRU Single-Bit Instructions

General format:

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 |
| :--- | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: | ---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

CRU relative addressing is used to address the selected CRU bit.


### 3.5.7 Jump Instructions

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

General format:

Jump instructions cause the PC to be loaded with the value selected by PC relative addressing if the bits of ST are at specified values. Otherwise, no operation occurs and the next instruction is executed since PC points to the next instruction. The displacement field is a word count to be added to PC. Thus, the jump instruction has a range of -128 to 127 words from memory-word address following the jump instruction. No ST bits are affected by jump instruction.


### 3.5.8 Shift Instructions

General format: $\quad$| OP CODE | C | w |
| :---: | :---: | :---: |

If $\mathrm{C}=0$, bits 12 through 15 of WRO contain the shift count. If $\mathrm{C}=0$ and bits 12 through 15 of $\mathrm{WRO}=0$, the shift count is 16 .

| MNEMONIC | OP CODE |  |  |  |  |  |  |  | MEANING | RESULTCOMPAREDTO 0 | STATUSBITSAFFECTED | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 |  | 5 | 6 |  |  |  |  |  |  |
| SLA | 0 | 0 | 0 |  | 0 | 1 |  |  | Shift left arithmetic | Yes | 0.4 | Shift (W) left. Fill vacated bit positions with 0 . |
| SRA |  | 0 | 0 |  | 0 | 0 |  |  | Shift right arithmetic | Yes | 0-3 | Shift (W) right. Fill vacated bit positions with original MSB of (W). |
| SRC | 0 | 0 | 0 |  |  |  |  |  | Shift right circular | Yes | 0-3 | Shift (W) right. Shift previous LSB into MSB. |
| SRL | 0 | 0 | 0 |  |  |  |  |  | Shift right logical | Yes | 0-3 | Shift (W) right. Fill vacated bit positions with 0's. |

### 3.5.9 Immediate Register Instructions



| MNEMONIC | OP CODE | MEANING | RESULT | STATUS | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 012345678910 |  | $\text { то } 0$ | BITS <br> AFFECTED |  |
| Al | 00000010001 | Add immediate | Yes | 0-4 | $(W)+I O P \rightarrow(W)$ |
| ANDI | 00000010010 | AND immediate | Yes | 0.2 | (W) AND IOP $\rightarrow$ (W) |
| Cl | 00000010100 | Compare immediate | Yes | 0-2 | Compare (W) to IOP and set appropriate status bits |
| LI | 000000010000 | Load immediate | Yes | 0-2 | $1 O P \rightarrow(W)$ |
| ORI | 00000010011 | OR immediate | Yes | 0.2 | $(W)$ OR $1 O P \rightarrow(W)$ |

### 3.5.10 Internal Register Load Immediate Instructions

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| General format: | OP CODE |  |  |  |  |  |  |  |  |  |  |  |  | N |  |  |
|  | IOP |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |


| MNEMONIC | OP CODE |  |  |  |  |  |  |  |  |  |  | - MEANING |  | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |  |  |  |
| LWPI |  | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | Load workspace pointer immediate Load interrupt mask |  | IOP $\rightarrow$ (WP), no ST bits affected IOP, bits 12 thru $15 \rightarrow$ ST12 thru ST15 |
| LIMI | 0 | 0 | 0 | 0 | 0 | 0 | 1 |  | 0 | 0 | 0 |  |  |  |

3.5.11 Internal Register Store Instructions


No ST bits are affected.

| MNEMONIC | OP CODE |  |  |  |  |  |  |  |  |  |  | MEANING | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |  |  |
| STST | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | Store status register | $(\mathrm{ST}) \rightarrow(\mathrm{W}$. |
| STWP | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | Store workspace pointer | $(W P) \rightarrow(W)$ |

### 3.5.12 Return Workspace Pointer (RTWP) Instruction

General format:

| 0 | 1 | $\mathbf{2}$ | $\mathbf{3}$ | $\mathbf{4}$ | $\mathbf{5}$ | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | $\mathbf{1 4} 15$

The RTWP instruction causes the following transfers to occur:

$$
\begin{aligned}
& (\text { WR15 }) \rightarrow(S T) \\
& (W R 14) \rightarrow(P C) \\
& (W R 13) \rightarrow(W P)
\end{aligned}
$$

### 3.5.13 External Instructions

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| General format: |  |  |  |  |  | OP |  |  |  |  |  |  |  | N |  |  |

External instructions cause the three most-significant address lines (A0 through A2) to be set to the below-described

| MNEMONIC | OP CODE |  |  |  |  |  |  |  |  |  |  |  | MEANING | STATUS BITS <br> AFFECTED | DESCRIPTION | ADDRESS BUS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1 | 2 | 34 | 5 | 56 | 7 | 78 | 9 |  |  |  |  |  | A0 | A1 | A2 |
| IDLE | 0 |  | 0 |  | 00 | 0 | 1 | 1 | 0 | 1 |  | 0 | Idle | - | Suspend TMS 9900 <br> instruction execution until an interrupt, $\overline{\text { LOAD }}$, or RESET occurs | L | H | L |
| RSET | 0 |  | 0 | 0 | 00 | 0 | 0 | 1 | 10 | 1 | 1 | 1 | Reset | 12-15 | $0 \rightarrow$ ST12 thru ST15 | L | H | H |
| CKOF | 0 | 0 | 0 | 0 | 00 | 0 | 01 | 1 | 11 | 1 |  | 0 | User defined |  | --- | H | H | L |
| CKON | 0 |  | 0 | 0 | 00 | 0 | 1 | 1 | 1 | 0 |  |  | User defined |  | --- | H | L | H |
| LREX | 0 | , | 0 | 0 | 00 | 0 | 0 | 1 | 1 | 1 |  | 1 | User defined |  | ---- | H | H | H |

The SBP 9900 includes circuitry which will indicate the completion of a microinstruction cycle. Designated as the CYCEND function, it provides CPU status that can simplify system design. The CYCEND output will go to a low logic level as a result of the low-to-high transition of each clock pulse which initiates the last clock of a microinstruction.
3.7 SBP 9900 INSTRUCTION EXECUTION TIMES

Instruction execution times for the SBP 9900 are a function of:

1) Clock cycle time, $t_{c}$
2) Addressing mode used where operands have multiple addressing mode capability
3) Number of wait states required per memory access.

The following Table 6 lists the number of clock cycles and memory accesses required to execute each SBP 9900 instruction. For instructions with multiple addressing modes for either or both operands, the table lists the number of clock cycles and memory accesses with all operands addressed in the workspace-register mode. To determine the additional number of clock cycles and memory accesses required for modified addressing, add the appropriate values from the referenced tables. The total instruction-execution time for an instruction is:

$$
T=t_{c}(C+W \cdot M)
$$

where:
$\mathrm{T}=$ total instruction execution time;
$\mathrm{t}_{\mathrm{C}}=$ clock cycle time;
C = number of clock cycles for instruction execution plus address modification;
W = number of required wait states per memory access for instruction execution plus address modification;
$M=$ number of memory accesses.

TABLE 6
INSTRUCTION EXECUTION TIMES

| INSTRUCTION | CLOCK CYCLES C | MEMORY ACCESS M | ADDRESS MODIFICATION ${ }^{\dagger}$ |  | INSTRUCTION | CLOCK <br> CYCLES <br> C | $\begin{gathered} \text { MEMORY } \\ \text { ACCESS } \\ M \\ \hline \end{gathered}$ | ADDRESS MODIFICATION ${ }^{\dagger}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | SOURCE | DEST |  |  |  | SOURCE | DEST |
| A | 14 | 4 | A | A | LWPI | 10 | 2 | - | - |
| $A B$ | 14 | 4 | B | B | MOV | 14 | 4 | A | A |
| ABS ( $M S B=0)$ | 12 | 2 | A | - | MOVB | 14 | 4 | B | B |
| $(\mathrm{MSB}=1)$ | 14 | 3 | A | - | MPY | 52 | 5 | A | - |
| AI | 14 | 4 | - | - | NEG | 12 | 3 | A | - |
| ANDI | 14 | 4 | - | - | ORI | 14 | 4 | - | - |
| B | 8 | 2 | A | - | RSET | 12 | 1 | - | - |
| BL | 12 | 3 | A | - | RTWP | 14 | 4 | - | - |
| BLWP | 26 | 6 | A | - | S | 14 | 4 | A | A |
| C | 14 | 3 | A | A | SB | 14 | 4 | B | B |
| CB | 14 | 3 | B | B | SBO | 12 | 2 | - | - |
| Cl | 14 | 3 | - | - | SBZ | 12 | 2 | - | - |
| CKOF | 12 | 1 | - | - | SETO | 10 | 3 | A | - |
| CKON | 12 | 1 | - | - | Shift ( $C \neq 0$ ) | $12+2 \mathrm{C}$ | 3 | - | - |
| CLR | 10 | 3 | A | - | ( $\mathrm{C}=0$, Bits 12-15 |  |  |  |  |
| COC | 14 | 3 | A | - | of WRO=0) | 52 | 4 | - | - |
| CZC | 14 | 3 | A | - | ( $\mathrm{C}=0$, Bits 12-15 |  |  |  |  |
| DEC | 10 | 3 | A | - | of WRP $=\mathrm{N} \neq 0$ ) | $20+2 N$ | 4 | - | - |
| DECT | 10 | 3 | A | - | SOC | 14 | 4 | A | A |
| DIV (ST4 is set) | 16 | 3 | A | -- | SOCB | 14 | 4 | B | B |
| DIV (ST4 is reset) | 92.124 | 6 | A | - | STCR ( $\mathrm{C}=0$ ) | 60 | 4 | A | - |
| IDLE | 12 | 1 | - | - | $(1 \leqslant C \in 7)$ | 42 | 4 | B | - |
| INC | 10 | 3 | A | - | ( $\mathrm{C}=8$ ) | 44 | 4 | B | - |
| INCT | 10 | 3 | A | - | $(9 \in C \in 15)$ | 58 | 4 | A | - |
| INV | 10 | 3 | A | - | STST | 8 | 2 | - | - |
| Jump (PC is |  |  |  |  | STWP | 8 | 2 | - | - |
| changed) | 10 | 1 | - | - | SWPB | 10 | 3 | A | - |
| (PC is not |  |  |  |  | SZC | 14 | 4 | A | A |
| changed) | 8 | 1 | - | - | SZCB | 14 | 4 | B | B |
| $\operatorname{LDCR}(\mathrm{C}=0)$ | 52 | 3 | A | - | TB | 12 | 2 | - | - |
| $(1 * C * 8)$ | $20+2 \mathrm{C}$ | 3 | B | - | X ** | 8 | 2 | A | - |
| (9*C*15) | $20+2 \mathrm{C}$ | 3 | A | - | XOP | 36 | 8 | A | - |
| LI | 12 | 3 | - | - | XOR | 14 | 4 | A | - |
| LIMI | 14 | 2 | - | - |  |  |  |  |  |
| I_REX | 12 | 1 | - | - |  |  |  |  |  |
| $\overline{\text { RESET }}$ function | 26 | 5 | - | - | Undefined op codes |  |  |  |  |
| $\overline{\text { LOAD function }}$ | 22 | 5 | - | - | 0000-01FF,0320- | 6 | 1 | - | - |
| Interrupt context switch | 22 | 5 | - | - | $\begin{aligned} & 033 \mathrm{~F}, 0 \mathrm{C} 00-0 \mathrm{FFF} \\ & 0780-07 \mathrm{FF} \end{aligned}$ |  |  |  |  |

*Execution time is dependent upon the partial quotient after each clock cycle during execution.

* Execution time is added to the execution time of the instruction located at the source address minus 4 clock cycles and 1 memory access time.
${ }^{\dagger}$ The letters A and B refer to the respective tables that follow.


## ADDRESS MODIFICATION - TABLE A

| ADDRESSING MODE | $\begin{gathered} \hline \text { CLOCK } \\ \text { CYCLES } \\ \mathrm{C} \\ \hline \end{gathered}$ | MEMORY ACCESSES M |
| :---: | :---: | :---: |
| WR ( $T_{S}$ or $\left.T_{D}=00\right)$ | 0 | 0 |
| WR indirect ( $T_{S}$ or $T_{D}=01$ ) | 4 | 1 |
| WR indirect autoincrement ( $T_{S}$ or $T_{D}=11$ ) | 8 | 2 |
| Symbolic ( $T_{S}$ or $T_{D}=10$, S or D = 0) | 8 | 1 |
| Indexed ( $T_{S}$ or $T_{D}=10$, $S$ or $D \neq 0$ ) | 8 | 2 |

ADDRESS MODIFICATION - TABLE B

| ADDRESSING MODE | $\begin{gathered} \hline \text { CLOCK } \\ \text { CYCLES } \\ \mathrm{C} \\ \hline \end{gathered}$ | MEMORY <br> ACCESSES <br> M |
| :---: | :---: | :---: |
| WR ( $T_{S}$ or $T_{D}=00$ ) | 0 | 0 |
| WR indirect ' $T_{S}$ or $T_{D}=01$ ) | 4 | 1 |
| WR indirect autoincrement ( $T_{S}$ or $T_{D}=11$ ) | 6 | 2 |
| Symbolic ( $T_{S}$ or $T_{D}=10$, $S$ or $D=0$ ) | 8 | 1 |
| $\text { Indexed }\left(T_{S} \text { or } T_{D}=10,\right.$ $S \text { or } D \neq 0)$ | 8 | 2 |

As an example, the instruction MOVB is used in a system with $\mathrm{t}_{\mathrm{C}}=0.5 \mu \mathrm{~s}$ and no wait states are required to access memory. Both operands are addressed in the workspace register mode:

$$
T=t_{c}(C+W \cdot M)=0.5(14+0.4) \mu \mathrm{s}=7 \mu \mathrm{~s}
$$

If two wait states per memory access were required, the execution time is:

$$
\mathrm{T}=0.5(14+2 \cdot 4) \mu \mathrm{s}=11 \mu \mathrm{~s}
$$

If the source operand was addressed in the symbolic mode and two wait states were required:

$$
\begin{aligned}
& \mathrm{T}=\mathrm{t}_{\mathrm{C}}(\mathrm{C}+\mathrm{W} \cdot \mathrm{M}) \\
& \quad \mathrm{C}=14+8=22 \\
& \mathrm{M}=4+1=5 \\
& \mathrm{~T}=0.5(22+2 \cdot 5) \mu \mathrm{s}=16 \mu \mathrm{~s} .
\end{aligned}
$$

## 4. INTERFACING

The input/output (I/O) accommodations have been designed for TTL compatibility. Direct interfacing, supportable by the entire families of catalog devices, is shown in Figure 15.


FIGURE 15 - MINIMUM SBP 9900 SYSTEM

### 4.1 INPUT CIRCUIT

The input circuit used on the SBP 9900 is basically an RTL configuration which has been modified for TTL compatibility as shown in Figure 16A. An input-clamping diode is incorporated to limit negative excursions (ringing) when the SBP 9900 is on the receiving end of a transmission line; an input switching threshold of nominally +1.5 volts has been specified for improved noise immunity. This threshold is achieved via two resistors which function as a voltage divider to increase the one $V_{B E}$ threshold of the 12 L input transistor to +1.5 volts. Since this input circuit is independent of injector current, input threshold compatibility is maintained over the entire speed/power performance range.


FIGURE 16 - SCHEMATICS OF EQUIVALENT INPUTS, OUTPUTS, INPUTS/OUTPUTS

The input circuit characteristics for input current versus input voltage are shown in Figure 17. The 10 K and 20 K ohm load lines and threshold knee at +1.5 volts provide a high-impedance characteristic to reduce input loading and improve the low-logic level input noise immunity over some standard TTL inputs. Full compatibility is maintained with virtually all 5 volt logic families even when the SBP 9900 is powered down (injector current reduced).

### 4.1.1 Sourcing Inputs

The inputs may be sourced directly by most 5 volt logic families. Five volt functions which feature internal pull-up resistors at their outputs require no external interface components; five volt functions which feature opencollector outputs generally require external pull-up resistors.

### 4.1.2 Terminating Unused Inputs

Inputs which are selected to be hardwired to a logic-level low may be connected directly to


FIGURE 17 - TYPICAL INPUT CHARACTERISTICS
ground. Inputs which are selected to be hardwired to a logic-level high must be tied, via a current limiting (pull-up) resistor, to a logic-level-high low-impedance voltage source such as $\mathrm{V}_{\mathrm{CC}}$. A single transient protecting resistor may be utilized common to ( N ) inputs.

### 4.2 OUTPUT CIRCUIT

The output circuit selected for the SBP 9900 is an injected open-collector transistor shown in Figure 16B. Since this transistor is injected, output sourcing capability is directly related to injector current. In other words, the number of loads which may be sourced by an SBP 9900 output is directly reduced as injector current is reduced.

The output circuit characteristic for logic-level low output voltage (VOL) versus logic-level low output current ( 1 OL ) is shown in Figure 18. At rated injector current, the SBP 9900 output circuit offers a low-level output voltage of typically 220 mV .

The output circuit characteristics for 1) logic-level high output voltage ( VOH ) and current $(1 \mathrm{OH}), 2$ ) rise times, and 3) next stage input noise immunity, are a function of the load circuit being sourced. The load circuit may be either:
A) the direct input, if no saurce current is required, of a five-volt logic family function,
or, for greater noise immunity and improved rise times,
B) the direct input of a five-volt logic family function in conjunction with a discrete pull-up resistor.

When a discrete pull-up resistor ( $\mathrm{R}_{\mathrm{L}}$ ) is utilized, the fanout requirements placed on a particular SBP 9900


FIGURE 18 - TYPICAL OUTPUT CHARACTERISTICS output restrict both the maximum and minimum value of $R_{L}$. Techniques for calculating $R_{L(\max )}$ and $R_{L(\min )}$ respectively are explained in the SBP 0400A, SBP 0401A data manual in Chapter 2 of this data book.

## 5. POWER SOURCE

$1^{2} \mathrm{~L}$ is a current-injected logic. When placed across a curve tracer, the processor will resemble a silicon switching diode. Any voltage or current source capable of supplying the desired current at the injector node voltage required will suffice. A dry-cell battery, a 5 -volt TTL power supply, a programmable current supply (for power-up/power-down operation) - literally whatever power source is convenient can be used for most cases. For example, if a 5 -volt TTL power supply is to be used, a series dropping resistor would be connected between the 5 -volt supply and the injector pins of the $\mathrm{I}^{2} \mathrm{~L}$ device, as illustrated in Figure 19, to select the desired operating current.


GENERAL FORMULA (OHM'S LAW)

$$
R_{\text {DROP }}=\frac{V_{\text {SUPPLY }}-V_{C C}}{I_{C C}}
$$

EXAMPLE FOR $V_{S U P P L Y}=\mathbf{5 V}$, AND $\mathbf{I}_{\mathbf{C C}}=\mathbf{5 0 0} \mathbf{m A}$ :

$$
R_{\text {DROP }}=\frac{5-1.05}{0.5}=\frac{3.95}{0.5}=7.9 O H M S
$$

FIGURE 19 - INJECTOR CURRENT CALCULATIONS

Operating from a constant current power source, the SBP 9900 may be powered-up/powered-down with complete maintenance of data integrity to execute instructions over a speed/power range spanning several orders of user-selectable injector-supplycurrent range as illustrated in Figure 21.

Figures 22 and 23 show the typical injector node voltages which occur across the temperature and injector current ranges.


FIGURE 20 - INJECTOR CURRENT SOURCE


FIGURE 21 - SBP 9900 CLOCK PERIOD VS. INJECTOR CURRENT


FIGURE 22 - INJECTOR-NODE VOLTAGE VS. FREE-AIR TEMPERATURE


FIGURE 23 - INJECTOR-NODE VOLTAGE vs. INJECTOR CURRENT
6. ELECTRICAL AND MECHANICAL SPECIFICATIONS
6.1 SBP 9900 RECOMMENDED OPERATING CONDITIONS, UNLESS OTHERWISE NOTED ICC $=500 \mathrm{~mA}$

|  |  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply current, ICC |  | 450 | 500 | 550 | mA |
| High-level output voltage, $\mathrm{V}_{\mathrm{OH}}$ |  |  |  | 5.5 | V |
| Low-level output current, IOL |  |  |  | 20 | mA |
| Clock frequency, folock |  | 0 |  | 2 | MHz |
| Width of clock pulse, $\mathrm{t}_{\mathrm{w}}$ | High (67\%) ( $\mathrm{V}_{\mathrm{IH}}=2.5 \mathrm{~V}$ max) | 330 |  |  | ns |
|  | Low (33\%) | 170 |  |  |  |
| Clock rise time, $\mathrm{t}_{\mathrm{r}}$ |  | 10 |  |  | ns |
| Clock fall time, $\mathrm{t}_{f}$ |  | 10 |  |  | ns |
| Setup time, $\mathrm{t}_{\text {su }}$ (see Figure 24) | $\overline{\text { HOLD }}$ | $210 \uparrow$ |  |  | ns |
|  | READY | $140 \uparrow$ |  |  |  |
|  | D0-D15 | $85 \uparrow$ |  |  |  |
|  | CRUIN | $65 \uparrow$ |  |  |  |
|  | INTREQ | $25 \uparrow$ |  |  |  |
|  | ICO-IC3 | $25 \uparrow$ |  |  |  |
| Hold time, $\mathrm{t}_{\text {\% }}$ (see Figure 24) | HOLD | $25 \uparrow$ |  |  | ns |
|  | READY | $65 \uparrow$ |  |  |  |
|  | D0-D15 | $65 \uparrow$ |  |  |  |
|  | CRUIN | $55 \uparrow$ |  |  |  |
|  | INTREQ | $90 \uparrow$ |  |  |  |
|  | ICO-IC3 | $90 \uparrow$ |  |  |  |
| Operating free-air temperature, $\mathrm{TA}_{\mathrm{A}}$ | SBP $9900 \mathrm{M} / \mathrm{N}$ | -55 |  | 125 | ${ }^{\circ} \mathrm{C}$ |
|  | SBP 9900E | -40 |  | 85 |  |

$\uparrow$ Rising edge of clock pulse is reference.

## tentative data sheet

### 6.2 SBP 9900 ELECTRICAL CHARACTERISTICS (OVER RECOMMENDED OPERATING FREE-AIR

 TEMPERATURE RANGE, UNLESS OTHERWISE NOTED)| PARAMETER |  |  | TEST CONDITIONS ${ }^{\text {+ }}$ | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIH | High-level input voltage |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  | 0.8 | V |
| VIK | Input clamp voltage |  | $I_{C C}=$ MIN, $\quad I_{1}=-12 \mathrm{~mA}$ |  |  | -1.5 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current |  | $\begin{array}{ll} \mathrm{I}_{\mathrm{CC}}=500 \mathrm{~mA}, & \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V} \\ V_{I L}=0.8 \mathrm{~V}, & V_{O H}=5.5 \mathrm{~V} \end{array}$ |  |  | 400 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Low-level output voltage |  | $\begin{array}{ll} I_{C C}=500 \mathrm{~mA}, & V_{I H}=2 \mathrm{~V} \\ V_{I L}=0.8 \mathrm{~V}, & I_{\mathrm{OL}}=20 \mathrm{~mA} \end{array}$ |  |  | 0.4 | V |
| 11 | Input current | Clock | $\mathrm{I}^{\prime} \mathrm{CC}=500 \mathrm{~mA}, \quad \mathrm{~V}_{1}=2.4 \mathrm{~V}$ |  | 480 | 600 | $\mu$ |
|  |  | All other inputs |  |  | 240 | 300 |  |

$\dagger$ For conditions shown as MAX, use the appropriate value specified under recommended operating conditions.
$\ddagger$ All typical values are at $I_{C C}=500 \mathrm{~mA}, T_{A}=25^{\circ} \mathrm{C}$.
6.3 SBP 9900 SWITCHING CHARACTERISTICS, ICC $=500 \mathrm{~mA}$, (OVER RECOMMENDED OPERATING FREE-AIR TEMPERATURE RANGE UNLESS OTHERWISE NOTED) SEE FIGURES 24 AND 25.

| PARAMETER | FROM | TO | TEST CONDITIONS | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $f_{\text {max }}$ | MAXIMUM CLOCK FREQUENCY |  | $C_{L}=150 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=280 \Omega$ | 2 |  |  | MHz |
| ${ }^{\text {tPLH }}$ or tPHL | CLOCK | ADDRESS BUS (A0 - A14) |  |  | 170 | 225 | ns |
| tPLH or tPHL | CLOCK | DATA BUS (D0 - D15) |  |  | 170 | 265 | ns |
| tPLH or tPHL | CLOCK | WRITE ENABLE (WE) |  |  | 220 | 295 | ns |
| tPLH or tPHL | CLOCK | CYCLE END (CYCEND) |  |  | 170 | 225 | ns |
| tPLH or tPHL | CLOCK | DATA BUS IN (DBIN) |  |  | 190 | 250 | ns |
| tPLH or tPHL | CLOCK | MEMORY ENABLE (MEMEN) |  |  | 155 | 205. | ns |
| tPLH or tPHL | CLOCK | CRU CLOCK (CRUCK) |  |  | 187 | 280 | ns |
| tPLH or tPHL | CLOCK | CRU DATA OUT (CRUOUT) |  |  | 210 | 265 | ns |
| tPLH or tPHL | CLOCK | HOLD ACKNOWLEDGE (HLDA) |  |  | 320 | 410 | ns |
| tPLH or tPHL | CLOCK | WAIT |  |  | 155 | 210 | ns |
| ${ }^{\text {tPLH }}$ or TPHL | CLOCK | INSTRUCTION ACQUISITION (1AQ) |  |  | 155 | 210 | ns |

$\ddagger$ All typical values are at $25^{\circ} \mathrm{C}$.


FIGURE 24 - SWITCHING TIMES-VOLTAGE WAVEFORMS


FIGURE 25 - SWITCHING TIMES LOAD CIRCUITS

Stability of the operational frequency over the full temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ is illustrated in Figure 26 .


FIGURE 26 - A-C PERFORMANCE VS. TEMPERATURE
7. MECHANICAL DATA


NOTE A. Each pin centerline is located within 0.010 of its true longitudinal position.

## 8. SBP 9900 PROTOTYPING SYSTEM

### 8.1 HARDWARE

The TMS 9900 prototyping system enables the user to generate and debug software and to debug I/O controller interfaces. The prototyping system consists of:

- 990/4 computer with TMS 9900 microprocessor
- 1024 bytes of ROM containing the bootstrap loader for loading prototyping system software, the front-panel and maintenance utility, and the CPU self-testing feature
- 16,896 bytes of RAM with provisions for expansion up to 57,334 bytes of RAM
- Programmable-write-protect feature for RAM
- Interface for Texas Instruments Model 733 ASR* Electronic Data Terminal with provisions for up to five additional interface moculdes
* Requires remote device control and 1200 baud EIA interface option on 733 ASR.
- Available with Texas Instruments Model 733 ASR Electronic Data Terminal
- 7-inch-high table-top chassis
- Programmer's front panel with controls for run, halt, single-instruction execute, and entering and displaying memory or register contents
- Power supply with the following voltages:

$$
\begin{gathered}
5 \mathrm{~V} \text { dc@ } 20 \mathrm{~A} \\
12 \mathrm{~V} \text { dc@ } 2 \mathrm{~A} \\
-12 \mathrm{~V} \text { dc @ } 1 \mathrm{~A} \\
-5 \mathrm{~V} \text { dc @ } 0.1 \mathrm{~A}
\end{gathered}
$$

- Complete hardware and software documentation.


### 8.2 SYSTEM CONSOLE

The system console for the prototyping system is the 733 ASR, which provides keyboard entry, 30 -character-per-second thermal printer, and dual cassette drives for program loading and storage.

### 8.3 SOFTWARE

The following software is provided on cassette for loading into the prototyping system:

- Debug Monitor - Provides full control of the prototyping system during program development and includes single instruction, multiple breakpoints, and entry and display capability for register and memory contents for debugging user software under 733 ASR console control.
- One-Pass Assembler - Converts source code stored on cassette to relocatable object on cassette and generates program listing. (Object is upward compatible with other 990 series assemblers).
- Linking Loader - Allows loading of absolute and relocatable object modules and links object modules as they are loaded.
- Source Editor - Enables user modification of both source and object from cassette with resultant storage on cassette.
- Trace Routine - Allows user to monitor status of computer at completion of each instruction.
- PROM Programming/Documentation Facility - Provides documentation for ROM mask generation, or communicates directly with the optional PROM Programmer Unit.


SEPTEMBER 1977

## Texas Instruments

FIELD PROGRAMMABLE READ-ONLY MEMORY (PROM) LINE SUMMARY (SEE PAGES 1 AND 6)

## MASK-PROGRAMMED READ-ONLY MEMORY (ROM) LINE SUMMARY

| TYPE NUMBER | TYPE OF OUTPUT(S) | BIT SIZE (ORGANIZATION) | TYPICAL PERFORMANCE |  | $\begin{gathered} \text { SEE } \\ \text { PAGE } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ADDRESS ACCESS TIME | POWER DISSIPATION |  |
| SN54/7488A | Open-Collector | $\begin{gathered} 256 \text { Bits } \\ (32 \mathrm{~W} \times 8 \mathrm{~B}) \end{gathered}$ | 26 ns | 320 mW | 9 |
| SN54/74187 | Open-Collector | $\begin{gathered} 1024 \text { Bits } \\ (256 \mathrm{~W} \times 4 \mathrm{~B}) \end{gathered}$ | 40 ns | 460 mW | 9 |
| SN54S/74S270 | Open-Collector | 2048 Bits | 45 ns | 525 mW | 9 |
| SN54S/74S370 | 3-State | (512 W $\times 4 \mathrm{~B}$ ) |  |  |  |
| SN54S/74S271 | Open-Collector | 2048 Bits | 45 ns | 525 mW | 9 |
| SN54S/74S371 | 3-State | ( $256 \mathrm{~W} \times 8 \mathrm{~B}$ ) |  |  |  |
| SBP 8316M/C | $0-\mathrm{C}$ or $10 \mathrm{k} \Omega$ pullup | $\begin{gathered} 16.384 \\ (2048 W \times 8 B) \end{gathered}$ | $\geqslant 350 \mathrm{~ns}$ | $\leqslant 500 \mathrm{~mW}$ | 16 |
| SBP 9818M/C | Open-Collector |  | $\geqslant 150 \mathrm{~ns}$ | $\leqslant 500 \mathrm{~mW}$ |  |

## READ/WRITE MEMORY (RAM) LINE SUMMARY

| TYPE NUMBER | BIT SIZE <br> (ORGANIZATION) | OUTPUT CONFIGURATION | TYPICAL PERFORMANCE |  | SEE <br> PAGE |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | ADDRESS ACCESS TIME | POWER DISSIPATION |  |
| $\begin{aligned} & \text { SN54S/74S189(J,N) } \\ & \text { SN54S/74S289(J,N) } \end{aligned}$ | $\begin{gathered} 64 \text { bits } \\ (16 \mathrm{~W} \times 4 \mathrm{~B}) \\ \hline \end{gathered}$ | Three-state Open-Collector | 25 ns | 375 mW | 20 |
| SN74S201 (J,N) | 256 bits | Three-State | 42 ns | 500 mW | 24 |
| SN74S301(J,N) | (256W $\times 18$ ) | Open-Collector | 42 ns | 500 mW |  |
| SN74S214(J,N) | $\begin{gathered} 1024 \text { bits } \\ (1024 \mathrm{~W} \times 1 \mathrm{~B}) \end{gathered}$ | Three-State | 40 ns | 550 mW | 27 |
| SN74LS214(J,N) |  |  | 65 ns | 200 mW |  |
| SN74LS215(J,N) |  |  | 75 ns | 200/100* mW |  |
| SN74S314(J,N) |  | Open-Collector | 40 ns | 550 mW |  |
| SN74LS314(J,N) |  |  | 75 ns | 200 mW |  |
| SN74S314(J,N) |  |  | 75 ns | 200/100*mW |  |
| SN74S207(J,N) | $\begin{gathered} 1024 \text { bits } \\ (256 \mathrm{~W} \times 4 \mathrm{~B}) \end{gathered}$ | Three-State | 40 ns | 600 mW | 33 |
| SN74LS207(J,N) |  |  | 75 ns | 200 mW |  |
| SN74S208(J,N) |  |  | 40 ns | 600 mW |  |
| SN74LS208(J,N) |  |  | 75 ns | 200 mW |  |

## FIRST-IN/FIRST-OUT (FIFO) MEMORY

| TYPE NUMBER | bit Size (ORGANIZATION) | TYPICAL PERFORMANCE |  |  |  | $\begin{gathered} \text { SEE } \\ \text { PAGE } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | DATA RATES |  | FALL THROUGH | POWER DISSIPATION |  |
|  |  | INPUT | OUTPUT |  |  |  |
| SN74S225 | $\begin{gathered} 80 \text { bits } \\ (16 \mathrm{~W} \times 5 \mathrm{~B}) \end{gathered}$ | $\mathrm{d}-\mathrm{c}$ to 10 MHz | $\mathrm{d}-\mathrm{c}$ to 10 MHz | 190 ns | 400 mW | 39 |

## SERIES 54S/74S <br> PROGRAMMABLE READ-ONLY MEMORIES

- Titanium-Tungsten (Ti-W) Fuse Links for Fast, Low-Voltage, Reliable Programming
- All Schottky-Clamped PROM's Offer:

Fast Chip Select to Simplify System Decode
Choice of Three-State or Open-Collector Outputs P-N-P Inputs for Reduced Loading on System Buffers/Drivers

- Full Decoding and Chip Select Simplify System Design
- Applications Include:

Microprogramming/Firmware Loaders Code Converters/Character Generators Translators/Emulators<br>Address Mapping/Look-Up Tables

| TYPE NUMBER (PACKAGES) |  | BIT SIZE <br> (ORGANIZATION) | OUTPUT CONFIGURATION | TYPICAL PERFORMANCE |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  | ADDRESS ACCESS TIME | POWER DISSIPATION |
| SN54S188(J, W) | SN74S188(J, N) | 256 bits | open-collector |  |  |
| SN54S288(J, W) | SN74S288(J, N) | ( $32 \mathrm{~W} \times 8 \mathrm{~B}$ ) | three-state | 25 ns | 400 mW |
| SN54S287(J, W) | SN74S287(J, N) | 1024 bits | three-state | 42 | 500 mW |
| SN54S387(J, W) | SN74S387(J, N) | (256 W $\times 4 \mathrm{~B}$ ) | open-collector | 42 ns | 500 mW |
| SN54S470(J) | SN74S470(J, N) | 2048 bits | open-collector | 50 ns | 550 mW |
| SN54S471(J) | SN74S471(J, N) | ( $256 \mathrm{~W} \times 8 \mathrm{~B}$ ) | three-state | 50 ns | 550 mW |
| SN54S472(J) | SN74S472(J, N) | 4096 bits | three-state | 55 | 600 |
| SN54S473(J) | SN74S473(J, N) | ( $512 \mathrm{~W} \times 8 \mathrm{~B}$ ) | open-collector | 55 | 600 mW |
| SN54S474(J, W) | SN74S474(J, N) | 4096 bits | three-state | 55 n | 600 mw |
| SN54S475(J, W) | SN74S475(J, N) | (512 W $\times 8$ B) | open-collector |  | 600 mW |

256 BITS
1024 BITS
2048 BITS 32 WORDS BY 8
'S188, 'S288
'S287, 'S387



4096 BITS
2 WORDS BY 8 BITS)
'S472, ‘S473


Pin assignments for all of these memories are the same for all packages.

4096 BITS
( 512 WORDS BY 8 BITS) 'S474, 'S475


## description

These monolithic TTL programmable read-only memories (PROM's) feature titanium-tungsten (Ti-W) fuse links with each link designed to program with a 100 microsecond pulse. These PROM's offer considerable flexibility for upgrading existing designs or improving new designs as they feature full Schottky clamping for improved performance, low-current MOS-compatible p-n-p inputs, choice of bus-driving three state or open-collector outputs, and improved chip-select access times.

The high-complexity 2048- and 4096-bit 20-pin PROM's can be used to significantly improve system density for fixed memories as all are offered in dual-in-line packages having pin-row spacings of 0.300 inch.

Integrated Schottky-Barrier diodeclamped transistor is patented by Texas Instruments. U. S. Patent Number 3,463,975

## SERIES 54S/74S

## PROGRAMMABLE READ-ONLY MEMORIES

## description (continued)

Data can be electronically programmed, as desired, at any bit location in accordance with the programming procedure specified. All PROM's, except the 'S287 and 'S387 are supplied with a low-logic-level output condition stored at each bit location. The programming procedure open-circuits Ti-W metal links, which reverses the stored logic level at selected locations. The procedure is irreversible; once altered, the output for that bit location is permanently programmed. Outputs never having been altered may later be programmed to supply the opposite output level. Operation of the unit within the recommended operating conditions will not alter the memory content.
Active level(s) at the chip-select input(s) enables all of the outputs. An inactive level at any chip-select input causes all outputs to be off.
The three-state output offers the convenience of an open-collector output with the speed of a totem-pole output; it can be bus-connected to other similar outputs yet it retains the fast rise time characteristic of the TTL totem-pole output. The open-collector output offers the capability of direct interface with a data line having a passive pull-up.
schematics of inputs and outputs
'S188, 'S287, 'S288, 'S387, 'S470, 'S471, 'S472, 'S473, 'S474, 'S745

'S188, 'S387, ‘S470
S743, 'S475

'S287, ‘S288, 'S471,
'S472, 'S474

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage (see Note 1)
Input voltage.
recommended conditions for programming the 'S188, 'S287, ‘S288, 'S387, 'S470 through 'S475

|  |  | SN54S', SN74S' |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX |  |
| Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ (see Note 1 ) | Steady state | 4.75 | 5 | 5.25 | V |
|  | Program pulse | 10 | 10.5 | $11^{\dagger}$ |  |
| Input voltage | High level, $\mathrm{V}_{1} \mathrm{H}$ | 2.4 |  | 5 | V |
|  | Low level, VIL | 0 |  | 0.5 |  |
| Termination of all outputs except the one to be programmed |  | See load circuit (Figure 1) |  |  |  |
| Voltage applied to output to be programmed, $\mathrm{V}_{\mathrm{O}(\mathrm{pr})}$ (see Note 2) |  | 0 | 0.25 | 0.3 | V |
| Duration of $\mathrm{V}_{\text {CC }}$ programming pulse Y (see Figure 2 and Note 3) |  | 98 | 100 | $10^{3}$ | $\mu \mathrm{s}$ |
| Programming duty cycle |  |  | 25 | 35 | \% |
| Free-air temperature |  | 0 |  | 55 | ${ }^{\circ} \mathrm{C}$ |

[^3]
## SERIES 54S/74S <br> PROGRAMMABLE READ-ONLY MEMORIES

## step-by-step programming procedure for the ‘S188, ‘S287, 'S288, ‘S387, ‘S470 through ‘S475

1. Apply steady-state supply voltage ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ ) and address the word to be programmed.
2. Verify that the bit location needs to be programmed. If not, proceed to the next bit.
3. If the bit requires programming, disable the outputs by applying a high-logic-level voltage to the chip-select input(s).
4. Only one bit location is programmed at a time. Connect each output not being programmed to 5 V through $3.9 \mathrm{k} \Omega$ and apply the voltage specified in the table to the output to be programmed. Maximum current out of the programming output is 150 mA . This current flows from the programmer into the PROM output.
5. Step $V_{C C}$ to 10.5 V nominal. Maximum supply current required during programming is 750 mA .
6. Apply a low-logic-level voltage to the chip-select input(s). This should occur between $1 \mu \mathrm{~s}$ and 1 ms after $V_{\mathrm{CC}}$ has reached its $10.5-\mathrm{V}$ level. See programming sequence of Figure 2.
7. After the $X$ pulse time is reached, a high logic level is applied to the chip-select inputs to disable the outputs.
8. Within $1 \mu$ s to 1 ms after the chip-select input(s) reach a high logic level, $\mathrm{V}_{\mathrm{CC}}$ should be stepped down to 5 V at which level verification can be accomplished.
9. The chip-select input(s) may be taken to a low logic level (to permit program verification) $1 \mu \mathrm{~s}$ or more after $\mathrm{V}_{\mathrm{CC}}$ reaches its steady-state value of 5 V .
10. At a $Y$ pulse duty cycle of $35 \%$ or less, repeat steps 1 through 8 for each output where it is desired to program a bit.

NOTE: Only one programming attempt per bit is recommended.


LOAD CIRCUIT FOR EACH OUTPUT NOT BEING PROGRAMMED OR FOR PROGRAM VERIFICATION

FIGURE 1 - LOAD CIRCUIT


PROGRAMMABLE READ-ONLY MEMORIES WITH 3-STATE OUTPUTS
recommended operating conditions

| PARAMETER |  | 'S287, 'S471 |  |  | 'S288 |  |  | 'S472, 'S474 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ | Series 54S | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
|  | Series 74S | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 |  |
| High-level output current, 1 OH | Series 54S |  |  | -2 |  |  | -2 |  |  | -2 | mA |
|  | Series 74S |  |  | -6.5 |  |  | -6.5 |  |  | -6.5 |  |
| Low-level output current, IOL |  |  |  | 16 |  |  | 20 |  |  | 12 | mA |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ | Series 54S | -55 |  | 125 | -55 |  | 125 | -55 |  | 125 | ${ }^{\circ} \mathrm{C}$ |
|  | Series 74S | 0 |  | 70 | 0 |  | 70 | 0 |  | 70 |  |

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

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$ |  | SN54S' |  |  | SN74S' |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  |  |  |  | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  | 0.8 |  |  | 0.8 | V |
| $V_{\text {IK }}$ | Input clamp voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| VOH | High-level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{1 H}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ | 2.4 | 3.4 |  | 2.4 | 3.2 |  | V |
| VOL | Low-level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{1 H}=2 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OL}}=\mathrm{MAX} \end{aligned}$ |  |  | 0.5 |  |  | 0.5 | V |
| IOZH | Off-state output current, high-level voltage applied | $\begin{aligned} & V_{C C}=\mathrm{MAX}, \\ & \mathrm{~V}_{\mathrm{O}}=2.4 \mathrm{~V} \end{aligned}$ | $V_{I H}=2 \mathrm{~V},$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
| IOZL | Off-state output current, low-level voltage applied | $\begin{aligned} & V_{C C}=\mathrm{MAX} ; \\ & V_{O}=0.5 \mathrm{~V} \end{aligned}$ | $V_{I H}=2 V,$ |  |  | -50 |  |  | -50 | $\mu \mathrm{A}$ |
| Ii | Input current at maximum input voltage | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 |  |  | 1 | mA |
| IIH | High-level input current | $V_{C C}=M A X$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 25 |  |  | 25 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | $V_{C C}=M A X$ |  |  |  | -250 |  |  | -250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current § |  |  | $-30$ |  | -100 | $-30$ |  | -100 | mA |
| ${ }^{1} \mathrm{CC}$ | Supply current | $V_{C C}=M A X,$ <br> Chip select(s) at $0 V$, <br> Outputs open, <br> See Note 4 | 'S287 |  | 100 | 135 |  | 100 | 135 | mA |
|  |  |  | 'S288 |  | 80 | 110 |  | 80 | 110 |  |
|  |  |  | 'S471 |  | 110 | 155 |  | 110 | 155 |  |
|  |  |  | 'S472, 'S474 |  | 120 | 155 |  | 120 | 155 |  |

switching characteristics over recommended ranges of $T_{A}$ and $V_{C C}$ (unless otherwise noted)

| TYPE | TEST CONDITIONS | $t_{a}(\mathrm{ad})$ ( ns ) Access time from address |  |  | $t_{a}(\bar{S})(\mathrm{ns})$ <br> Access time from chip select (enable time) |  |  | tpXZ (ns) <br> Disable time from high or low level |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| SN54S287 |  |  | 42 | 75 |  | 15 | 40 |  | 12 | 40 | ns |
| SN74S287 |  |  | 42 | 65 |  | 15 | 35 |  | 12 | 35 | ns |
| SN54S288 |  |  | 25 | 50 |  | 12 | 30 |  | 8 | 30 | ns |
| SN74S288 | $t_{a}(a d)$ and $t_{a}(\bar{S})$ <br> 5 pF for tpXZ ; |  | 25 | 40 |  | 12 | 25 |  | 8 | 20 | ns |
| SN54S471 | $\begin{aligned} & R_{\mathrm{L}}=300 \Omega \\ & \text { See Figure } 2, \end{aligned}$ |  | 50 | 80 |  | 20 | 40 |  | 15 | 35 | ns |
| SN74S471 |  |  | 50 | 70 |  | 20 | 35 |  | 15 | 30 | ns |
| SN54S472, SN54S474 | Page 13 |  | 55 | 85 |  | 20 | 45 |  | 15 | 40 | ns |
| SN74S472, SN74S474 |  |  | 55 | 75 |  | 20 | 40 |  | 15 | 35 | ns |

[^4]recommended operating conditions

| PARAMETER |  | 'S188 |  |  | 'S387, 'S470 |  |  | 'S473, 'S475 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voltage, $\mathrm{V}_{\text {CC }}$ | Series 54S | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
|  | Series 74S | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 |  |
| High-level output voltage, $\mathrm{V}_{\mathrm{OH}}$ |  |  |  | 5.5 |  |  | 5.5 |  |  | 5.5 | $\checkmark$ |
| Low-level output current, IOL |  |  |  | 20 |  |  | 16 |  |  | 12 | mA |
| Operating free-air temperature, $T_{\text {A }}$ | Series 54S | -55 |  | 125 | -55 |  | 125 | -55 |  | 125 | ${ }^{\circ} \mathrm{C}$ |
|  | Series 74S | 0 |  | 70 | 0 |  | 70 | 0 |  | 70 |  |

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

| PARAMETER |  | TEST CONDITIONS ${ }^{\text {+ }}$ |  | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  | 0.8 | V |
| $\mathrm{V}_{\text {IK }}$ | Input clamp voltage | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$, | $I_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\text {IH }}=2 \mathrm{~V}, \end{aligned}$ | $\mathrm{VOH}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
|  |  | $V_{I L}=0.8 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 100 |  |
| VOL | Low-level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=\mathrm{MAX} \end{aligned}$ |  |  | 0.5 | V |
| 11 | Input current at maximum input voltage | $\mathrm{V}_{C C}=\mathrm{MAX}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 | mA |
| 1/H | High-level input current | $V_{C C}=M A X$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | $V_{C C}=M A X$, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  | -250 | $\mu \mathrm{A}$ |
| ICC | Supply current | $V_{C C}=M A X,$ <br> Chip select(s) at 0 V , <br> Outputs open, <br> See Note 4 | 'S188 |  | 80 | 110 | mA |
|  |  |  | 'S387 |  | 100 | 135 |  |
|  |  |  | 'S470 |  | 110 | 155 |  |
|  |  |  | 'S473; 'S475 |  | 120 | 155 |  |

switching characteristics over recommended ranges of $T_{A}$ and $V_{C C}$ (unless otherwise noted)

| TYPE | TEST CONDITIONS | $t_{a}(a d)$ <br> Access time from address |  |  | $t_{a}(\mathbf{S})$ <br> Access time from chip select (enable time) |  |  | tPLH <br> Propagation delay time, low-to-high-level output from chip select (disable time) |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| SN54S188 | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L} 1}=300 \Omega, \\ & \mathrm{R}_{\mathrm{L} 2}=600 \Omega, \\ & \text { See Figure } 1, \\ & \text { Page } 13 \end{aligned}$ |  | 25 | 50 |  | 12 | 30 |  | 12 | 30 | ns |
| SN74S188 |  |  | 25 | 40 |  | 12 | 25 |  | 12 | 25 | ns |
| SN54S387 |  |  | 42 | 75 |  | 15 | 40 |  | 15 | 40 | ns |
| SN74S387 |  |  | 42 | 65 |  | 15 | 35 |  | 15 | 35 | ns |
| SN54S470 |  |  | 50 | 80 |  | 20 | 40 |  | 15 | 35 | ns |
| SN74S470 |  |  | 50 | 70 |  | 20 | 35 |  | 15 | 30 | ns |
| SN54S473, SN54S475 |  |  | 55 | 85 |  | 20 | 45 |  | 15 | 40 | ns |
| SN74S743, SN74S475 |  |  | 55 | 75 |  | 20 | 40 |  | 15 | 35 | ns |

[^5]- Titanium-Tungsten (Ti-W) Fuse Links for Fast Low-Voltage Reliable Programming
- Full Decoding and Chip Select Simplify System Design
- Power-Down Versions ('S450, 'S451) Can Reduce System Power Requirements
- Fast Chip Select to Simplify System Decode
- Choice of Three-State or Open Collector Outputs
- PNP Inputs for Reduced Loading on System Buffers/Drivers
- Applications Include:

Microprogramming/Firmware Loaders Code Converters/Character Generators Translators/Emulators
Address Mapping/Look-Up Tables

| TYPE NUMBER (PACKAGES) |  | $\begin{gathered} \text { BIT SIZE } \\ \text { (ORGANIZATION) } \end{gathered}$ | OUTPUT CONFIGURATION | TYPICAL PERFORMANCE |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  | ACCESS TIMES |  | POWER DISSIPATION |
|  |  |  |  | ADDRESS | SELECT |  |
| SN54S450(J) | SN74S450(J,N) | 8192 bits | three-state | 45 ns | 20 ns | 600/100 ${ }^{\dagger} \mathrm{mW}$ |
| SN54S451 (J) | SN74S451 (J,N) | 1024 W $\times 8$ B | open-collector |  |  |  |
| SN54S478(J) | SN74S478(J,N) | 8192 bits | three-state | 45 ns | 20 ns | 600 mW |
| SN54S479(J) | SN74S479(J,N) | 1024 W $\times 8$ B | open-collector |  |  |  |
| SN54S2708(J) | SN74S2708(J,N) | 8192 bits | three-state | 45 ns | 20 ns | 600 mW |
| SN54S3708(J) | SN74S3708(J,N) | $1024 \mathrm{~W} \times 8 \mathrm{~B}$. | open-collector |  |  |  |
| SN54S476(J) | SN74S476(J,N) | $\begin{gathered} 4096 \text { bits } \\ 1024 \mathrm{~W} \times 4 \mathrm{~B} \end{gathered}$ | three-state | 35 ns | 15 ns | 475 mW |
| SN54S477(J) | SN74S477(J,N) |  | open-collector |  |  |  |

$\dagger$ Power down
SN54S/74S476 3-S OUTPUTS
SN54S/74S477 0-C OUTPUTS 4096 BITS
(1024 WORDS BY 4 BITS) 'S476, 'S477


MAXIMUM DELAY TIMES

| TYPE | ADDRESS | EN | DISABLE |
| :---: | :---: | :---: | :---: |
| SN54S | 75 ns | 40 ns | 40 ns |
| SN74S | 60 ns | 30 ns | 30 ns |

SN54S/74S478 3-S OUTPUTS SN54S/74S2708 3-S OUTPUTS SN54S/74S479 0-C OUTPUTS SN54S/74S3708 0-C OUTPUTS 8192 BITS (1024 WORDS BY 8 BITS)
'S478, 'S479


8192 BITS
(1024 WORDS BY 8 BITS) 'S2708, 'S3708


SN54S/74S450 3-S OUTPUTS SN54S/74S451 0-C OUTPUTS 8192 BITS (1024 WORDS BY 8 BITS) 'S450, 'S451

description

These monolithic TTL programmable read-only memories (PROM's) features titanium-tungsten (Ti-W) fuse links with each link designed to program with a 100 microsecond pulse. They offer considerable flexibility for upgrading existing designs or improving new designs as they feature full Schottky clamping for improved performance, low-current MOS-compatible p-n-p inputs, and choice of bus-driving three-state or open-collector outputs. Additionally, the 'S450, 'S451 features dual enable/disable inputs which power-down or power-up the PROM providing additional cost effectiveness in power-sensitive applications. The power-down and power-up functions are sequenced to occur with the outputs at a high impedance.

Data can be electrically programmed, as desired, at any bit location in accordance with the programming procedure specified. These new PROM's are supplied with a high logic-level output condition stored at each bit location. The programming procedure open-circuits Ti-W metal links, which reverses the stored logic level at selected locations. The

TEXAS INSTRRUMENTS POST OFFICE BOX 5012 - DALLAS, TEXAS 75222

[^6] 3,463,975.

## SERIES 54S/74S PROGRAMMABLE READ-ONLY MEMORIES

procedure is irreversible. Once altered, the output for that bit location is permanently programmed. Outputs never having been altered may later be programmed to supply the opposite output level. Operation of the unit within the recommended operating conditions will not alter the memory content. Active level(s) at the chip-select(s) or memory enable ( $E$ ) input(s) activates all of the outputs, and the 'S450, 'S451 memory enable will initiate a power-up sequence. An inactive level at any chip-select or memory enable input causes all outputs to be off, and the memory enable will initiate a power-down sequence. The three-state output offers the convenience of an open-collector output with the speed of a totem-pole output; it can be bus-connected to other similar outputs yet it retains the fast rise time characteristic of the TTL totem-pole output. The open-collector output offers the capability of direct interface with a data line having a passive pull-up.

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


recommended conditions for programming

${ }^{\dagger}$ Absolute maximum ratings.
\#This minimum rise time applies only for the $V_{O(p r)}$ ramp.
NOTES: 1. Voltage values are with respect to network ground terminal.
2. All bit locations contain a high logic level and programming a bit changes the output of the bit to low logic level.
3. Programming is guaranteed if the pulse applied is $98 \mu \mathrm{~s}$ in duration.

## step-by-step programming procedure

1. Apply steady-state supply voltage and address the word to be programmed.
2. Enable the PROM and verify that the bit location needs to be programmed. If not, proceed to the next bit.
3. If the bit requires programming, increase $\mathrm{V}_{\mathrm{CC}}$ by 1 volt (minimum current capability should be 200 mA ) and disable the outputs by applying 10 volts to chip-select inputs. Minimum chip-select input current capabilities should be 5 mA .
4. Only one bit location is programmed at a time. Connect each output not being programmed to a 0 to 0.5 volt source. Apply the $\mathrm{V}_{\mathrm{O}}(\mathrm{pr})$ voltage pulse specified in the table to the output to be programmed. Minimum current capability of the programming output supply (during programming) should be 200 mA . See programming sequence of Figure 1.
5. After the X pulse is completed, disconnect the output that was programmed. Then, remove the 0 to 0.5 volt source from the remaining outputs.

## SERIES 54S/74S

## PROGRAMMABLE READ-ONLY MEMORIES

6. The chip-select inputs may be taken to a low logic level (to permit program verification).
7. One microsecond after the chip select input(s) reach low logic level $\mathrm{V}_{\mathrm{CC}}$ should be decreased 1 V at which verification can be accomplished by measuring $V_{O L}$ at the programmed output.
8. At a $Y$ pulse duty cycle of $35 \%$ or less, repeat steps 1 through 7 for each output where it is desired to program a bit.

NOTE: Only one programming attempt per bit is recommended.


| PARAMETER |  | ${ }^{\prime}$ S450 |  |  | ${ }^{\text {'S451 }}$ |  |  | 'S478, 'S2708 |  |  | 'S479, 'S3708 |  |  | ${ }^{\text {'S476 }}$ |  |  | 'S477 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voltage,$\mathrm{V}_{\mathrm{CC}}$ | SN54S | 5.8 | 6 | 6.5 | 5.8 | 6 | 6.5 | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | V |
|  | SN74S | 5.8 | 6 | 6.25 | 5.8 | 6 | 6.25 | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 |  |
| High-level output current, ${ }^{1} \mathrm{OH}$ | SN54S |  |  | -2 |  |  |  |  |  | -2 |  |  |  |  |  | -2 |  |  |  | mA |
|  | SN74S |  |  | -3.2 |  |  |  |  |  | -3.2 |  |  |  |  |  | -3.2 |  |  |  |  |
| Low-level output current, IOL |  |  |  | 12 |  |  | 12 |  |  | 12 |  |  | 12 |  |  | 16 |  |  | 16 | mA |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ | SN54S | -55 |  | 125 | -55 |  | 125 | $-55$ |  | 125 | -55 |  | 125 | -55 |  | 125 | -55 |  | 125 | ${ }^{\circ} \mathrm{C}$ |
|  | SN74S | 0 |  | 70 | 0 |  | 70 | 0 |  | 70 | 0 |  | 70 | 0 |  | 70 | 0 |  | 70 |  |

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

|  | PARAMETER | TEST CONDITIONS ${ }^{\dagger}$ |  | 'S450, 'S476, 'S478, 'S2708 | $\begin{aligned} & \hline \text { 'S451, 'S477 } \\ & \text { 'S479, 'S3708 } \end{aligned}$ | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN TYP $\ddagger$ MAX | MIN TYP $\ddagger$ MAX |  |
| $\mathrm{V}_{1}$ | High-level input voltage |  |  | 2 | 2 | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  | 0.8 | 0.8 | V |
| VIK | Input clamp voltage | $V_{C C}=$ MIN, | $I_{1}=-18 \mathrm{~mA}$ | -1.2 | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | $\begin{aligned} & V_{C C}=\mathrm{MIN}, \\ & V_{\text {IL }}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ | $2.4 \quad 3.4$ |  | V |
| VOL | Low-level output voltage | $\begin{aligned} & V_{C C}=M I N \\ & V_{\text {IL }}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & V_{I H}=2 \mathrm{~V} \\ & I_{O L}=M A X \end{aligned}$ | 0.5 | 0.5 | V |
| $\begin{aligned} & \mathrm{I} \mathrm{OZH}, \\ & \mathrm{IOH} \\ & \hline \end{aligned}$ | Off-state output current, high-level voltage applied | $V_{C C}=$ MAX | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ | 50 | 50 | $\mu \mathrm{A}$ |
|  |  | $V_{1 H}=2 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  | 100 |  |
| IOZL | Off-state output current, low-level voltage applied | $\begin{aligned} & V_{C C}=M A X \\ & V_{O}=0.5 \mathrm{~V} \end{aligned}$ | $V_{1 H}=2 \mathrm{~V}$ | -50 |  | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage | $V_{C C}=$ MAX , | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ | 1 | 1 | mA |
| IIH | High-level input current | $V_{C C}=M A X$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ | 25 | 25 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | $V_{C C}=M A X$, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ | -250 | -250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current § | $V_{C C}=M A X$ | SN54S' | $-20 \quad-100$ |  | mA |
|  |  |  | SN74S' | -15 - -100 |  |  |
| ${ }^{\text {I CC }}$ | Supply current | $V_{C C}=\mathrm{MAX}$ | 4096-BIT PROM | $95 \quad 140$ | $95 \quad 140$ | mA |
|  |  |  | 8192-BIT PROM | 120 | 120 |  |

[^7]
## '88A



1024 BITS (256 WORDS BY 4 BITS) '187

| TYPE NUMBER (PACKAGES) |  | TYPE OF OUTPUT(S) | $\begin{gathered} \text { BIT SIZE } \\ \text { (ORGANIZATION) } \end{gathered}$ | TYPICAL ACCESS TIMES |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  | CHIP-SELECT | ADDRESS |
| SN5488A(J, W) | SN7488A(J, N) | Open-Collector | $\begin{gathered} 256 \text { Bits } \\ (32 \mathrm{~W} \times 8 \mathrm{~B}) \end{gathered}$ | 22 ns | 26 ns |
| SN54187(J, W) | SN74187(J, N) | Open-Collector | $\begin{gathered} 1024 \text { Bits } \\ (256 \mathrm{~W} \times 4 \mathrm{~B}) \end{gathered}$ | 20 ns | 40 ns |
| SN54S270(J) | SN74S270(J, N) | Open-Collector | 2048 Bits | 15 | 45 |
| SN54S370(J) | SN74S370(J, N) | 3-State | ( $512 \mathrm{~W} \times 4 \mathrm{~B}$ ) | 15 |  |
| SN54S271(J) | SN74S271(J, N) | Open-Collector | 2048 Bits | 15 ns | 45 ns |
| SN54S371(J) | SN74S371(J, N) | 3-State | (256W $\times 8 \mathrm{~B}$ ) | 15 ns |  |

## description

These monolithic TTL custom-programmed read-only memories (ROMs) are particularly attractive for applications requiring medium to large quantities of the same bit pattern. Plug-in replacements can be obtained for most of the popular TTL PROMs.

The high-complexity 2048 -bit ROMs can be used to significantly improve system bit density for fixed memory as all are offered in compact 16- or 20 -pin dual-in-line packages having pin-row spacings of 0.300 -inch.

The Schottky-clamped versions offer considerable flexibility for upgrading existing designs or improving new designs as they feature improved performance; plus, they offer low-current MOS-compatible p-n-p inputs, choice of bus-driving three-state or open-collector outputs, and improved chip-select access times.
Data from a sequenced deck of data cards punched according to the specified format are permanently programmed by the factory into the monolithic structure for all bit locations. Upon receipt of the order, Texas Instruments, will assign a special identifying number for each pattern programmed according to the order. The completed devices will be marked with the appropriate TI special device number. It is important that the customer specify not only the output levels desired at all bit locations, but also the other information requested under ordering instructions.

The three-state outputs offer the convenience of an open-collector output with the speed of a totem-pole output: they can be bus-connected to other similar outputs yet they retain the fast rise time characteristic of the TTL totem-pole output. The open-collector outputs offer the capability of direct interface with a data line having a passive pull-up.
Word-addressing is accomplished in straight positive-logic binary and the memory may be read when all $\overline{\mathrm{S}}$ inputs are low. A high at any $\overline{\mathrm{S}}$ input causes the outputs to be off.

Pin assignments for all of these memories are the same for all packages.
functional block diagrams


Same as SN54S270, SN74S270 except outputs are as shown below:

word addressing
'88A
WORD ADDRESS TABLE

| WORD | INPUTS |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | E | D | C | B | A |
| 0 | L | L | L | L | L |
| 1 | L | L | L | L | H |
| 2 | L | L | L | H | L |
| 3 | L | L | L | H | H |
| 4 | L | L | H | L | L |
| 5 | L | L | H | L | H |
| 6 | L | L | H | H | L |
| 7 | L | L | H | H | H |
| 8 | L | H | L | L | L |
|  |  | Words 9 thru |  |  |  |
| 27 |  | 26 | omitted |  |  |
| 28 | H | H | L | H | L |
| 29 | H | H | H | L | H |
| 30 | $H$ | H | H | H | L |
| 31 | $H$ | H | H | H | H |

'187, 'S271, 'S371
WORD ADDRESS TABLE



SN54187, SN74187

Same as SN54S271, SN74S271 except
outputs are as shown below:

'S270, 'S370
WORD ADDRESS TABLE

| WORD | INPUTS |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1 | H | G | F | E | D | C | B |  | A |
| 0 | L | L | L | L | L | L | L | L |  | L |
| 1 | L | L | L | L | L | L | L | L |  | H |
| 2 | L | L. | L | L | L | L | L | H |  | L |
| 3 | L | L | L | L | L | L | L | H |  | H |
| 4 | L | L | L | L | L | L | H | L |  | L |
| 5 | L. | L | L | L | L | $L$ | H | L |  | H |
| 6 | L | L | L | L | L | L | H | H |  | L |
| 7 | L | L | L | L | L | L | H | H |  | H |
| 8 | L. | L | L | L | L | H | L | L |  | L |
|  |  | Wor | ds | 9 th | u | 506 | om | itt |  |  |
| 507 | H | H | H | H | H | H | L | H |  | H |
| 508 | H | H | H | H | H | H | H | L |  | L |
| 509 | H | H | H | H | H | H | H | L |  | H |
| 510 | H | H | H | H | H | H | H | H |  | L |
| 511 | H | H | H | H | H | H | H | H |  | H |

Word selection is accomplished in a conventional positive-logic binary code with the $A$ address input being the least-significant bit progressing alphabetically through the address inputs to the most-significant bit.
schematics of inputs and outputs

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

recommended operating conditions


NOTES: 1. Voltage values are with respect to network ground terminal.
2. An SN54187 in the $W$ package operating at free-air temperatures above $111^{\circ} \mathrm{C}$ requires a heat sink that provides a thermal resistance from case-to-free-air, $\mathrm{R}_{\theta \mathrm{CA}}$, of not more than $46^{\circ} \mathrm{C} / \mathrm{W}$.

## SERIES 54S/74S

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

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$ |  | 'S270, 'S271 |  |  | 'S370, 'S371 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  |  |  |  | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  | 0.8 |  |  | 0.8 | V |
| $V_{\text {IK }}$ | Input clamp voltage | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ |  |  |  | 2.4 |  |  | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |  |  | 50 |  |  |  | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 100 |  |  |  | $\mu \mathrm{A}$ |
| V OL | Low-level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=\mathrm{MAX} \end{aligned}$ |  |  | 0.5 |  |  | 0.5 | V |
| ${ }^{1} \mathrm{OZH}$ | Off-state output current, high-level voltage applied | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{MAX}, \\ & \mathrm{~V}_{\mathrm{O}}=2.4 \mathrm{~V} \end{aligned}$ | $V_{I H}=2 V$ |  |  |  |  |  | 50 | $\mu \mathrm{A}$ |
| 'OZL | Off-state output current low-level voltage applied | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \\ & \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V} \end{aligned}$ | $V_{I H}=2 V,$ |  |  |  |  |  | -50 | $\mu \mathrm{A}$ |
| $1 /$ | Input current at maximum input voltage | $V_{C C}=M A X$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 |  |  | 1 | mA |
| IIH | High-level input current | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 25 |  |  | 25 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | $V_{C C}=M A X$, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  | -0.25 |  |  | -0.25 | mA |
| Ios | Short-circuit output current $\S$ | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$ |  |  |  |  | -30 |  | -100 | mA |
| ${ }^{1} \mathrm{CC}$ | Supply current | $\mathrm{V}_{C C}=\mathrm{MAX}$, | See Note 4 |  | 105 | 155 |  | 105 | 155 | mA |
| $\mathrm{C}_{0}$ | Off-state output capacitance | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=5 \mathrm{~V}$ |  | 6.5 |  |  | 6.5 |  | pF |

$\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.
NOTE 4: With outputs open and $\overline{C S}$ input(s) grounded, ${ }^{\prime} \mathrm{CC}$ is measured first by selecting a word that contains the maximum number of programmed high-level outputs; then by selecting a word that contains the maximum number of programmed low-level outputs.
switching characteristics over recommended ranges of $T_{A}$ and VCC (unless otherwise noted)

| PARAMETER | TEST CONDITIONS | SN54S270 <br> SN54S271 |  | $\begin{aligned} & \text { SN74S270 } \\ & \text { SN74S271 } \end{aligned}$ |  | $\begin{aligned} & \text { SN54S370 } \\ & \text { SN54S371 } \end{aligned}$ |  | $\begin{aligned} & \hline \text { SN74S370 } \\ & \text { SN74S371 } \\ & \hline \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX |  |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{ad})$ Access time from address | $R_{L 1}=300 \Omega,$ <br> See Figure 1 | 45 | 95 | 45 | 70 |  |  |  |  | ns |
| $\mathrm{t}_{\mathrm{a}}$ ( S ) Access time from chip select (enable time) |  | 15 | 45 | 15 | 30 |  |  |  |  | ns |
| Propagation delay time,  <br> tPLH low-to-high-level output <br> from chip select (disable time) |  | 15 | 40 | 15 | 25 |  |  |  |  | ns |
| $\mathrm{ta}_{\mathrm{a}}$ (ad) Access time from address | $C_{L}=30 \mathrm{pF},$ <br> See Figure 2 |  |  |  |  | 45 | 95 | 45 | 70 | ns |
| $\mathrm{t}_{\mathrm{a}}(\overline{\mathrm{S}})$ Access time from chip select (enable time) |  |  |  |  |  | 15 | 45 | 15 | 30 | ns |
| tPXZ Disable time from high or low level | $C_{L}=5 \mathrm{pF},$ <br> See Figure 2 |  |  |  |  | 10 | 40 | 10 | 25 | ns |

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

## SERIES 54/74 <br> READ-ONLY MEMORIES

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

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$ |  | '88A |  |  | '187 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $V_{\text {IH }}$ | High-level input voltage |  |  |  |  | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  | 0.8 |  |  | 0.8 | V |
| $V_{\text {IK }}$ | Input clamp voltage | $V_{C C}=\mathrm{MIN}$, | $I_{1}=-12 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | High-level output current | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V} \end{aligned}$ |  |  | 40 |  |  | 40 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {OL }}$ | Low-level output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V} \end{aligned}$ | $\mathrm{I}^{\mathrm{OL}}=12 \mathrm{~mA}$ |  | 0.2 | 0.4 |  |  | 0.4 | V |
|  |  |  | $\mathrm{I}^{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  |  |  |  | 0.45 |  |
| 11 | Input current at maximum input voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  |  | 1 |  |  | 1 | mA |
| $\mathrm{I}_{\mathrm{IH}}$ | High-level input current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{V}_{1}=2.4 \mathrm{~V}$ |  |  |  | 25 |  |  | 40 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  |  | -1 |  |  | -1 | mA |
| ICC | Supply current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \quad$ See Note 3 |  |  | 64 | 80 |  | 92 | 130 | mA |
| $\mathrm{C}_{0}$ | Off-state output capacitance | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \quad \mathrm{~V}_{\mathrm{O}}=5 \mathrm{~V}, \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |  |  | 6.5 |  |  | 6.5 |  | pF |

${ }^{\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}$.
NOTE 3: With outputs open and $\overline{C S}$ input(s) grounded, ${ }^{\prime} \mathrm{CC}$ is measured first by selecting a word that contains the maximum number of programmed high-level outputs, then by selecting a word that contains the maximumnumber of programmed low level outputs.
switching characteristics, $\mathrm{V}_{\mathrm{CC}}=\mathbf{5 V}, \mathrm{T}_{\mathrm{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS | '88A |  | '187 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP | MAX | TYP | MAX |  |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{ad})$ | Access time from address |  | $\begin{aligned} \mathrm{C}_{\mathrm{L}}= & 30 \mathrm{pF}, \\ \mathrm{R}_{\mathrm{L} 1}= & 400 \Omega\left({ }^{\prime} 88 \mathrm{~A}\right) \\ & 300 \Omega(\prime 187) \\ R_{\mathrm{L} 2}= & 600 \Omega, \end{aligned}$ <br> See Figure 1 | 26 | 45 | 40 | 60 | ns |
| $\mathrm{t}_{\mathrm{a}}(\bar{S}$ ) | Access time from chip select (enable time) | 22 |  | 35 | 20 | 30 | ns |
| tPLH | Propagation delay time, low-to-high-level output from chip select (disable time) | 22 |  | 35 | 20 | 30 | ns |

parameter measurement information


# SERIES 54/74, 54S/74S <br> TTL READ-ONLY MEMORIES 

## ORDERING INSTRUCTIONS

Programming instructions for these read-only memories are solicited in the form of a sequenced deck of standard 80 -column data cards providing the information requested under "data card format," accompanied by a properly sequenced listing of these cards, and the supplementary ordering data. Upon receipt of these items, a computer run will be made from the deck of cards which will produce a complete function table for the requested part. This function table, showing output conditions for each of the words, will be forwarded to the purchaser as verification of the input data as interpreted by the computerautomated design (CAD) program. This single run also generates mask and test program data; therefore, verification of the function table should be completed promptly.

Each card in the data deck prepared by the purchaser identifies the words specified and describes the levels at the outputs for each of those words. All addresses must have all outputs defined and columns designated as "blank" must not be punched. Cards should be punched according to the data card format shown.

## SUPPLEMENTARY ORDERING DATA

Submit the following information with the data cards:
a) Customer's name and address
b) Customer's purchase order number
c) Customer's drawing number.

The following information will be furnished to the customer by Texas Instruments:
a) Tl part number
b) TI sales order number
c) Date received.

## '88A DATA CARD FORMAT (32 CARDS)

| Column |  |
| :---: | :---: |
| 1.2 | Punch a right-justified integer representing the positive-logic binary input address (00-31) for the word described on the card. |
| 3-4 | Blank |
| 5 | Punch " $H$ " or " $L$ " for output Y8. $H=$ high voltage-level output, L = low-voltage-level output |
| 6-9 | Blank |
| 10 | Punch " H " or "L' for output DO 7. |
| 11-14 | Blank |

positive-logic binary input address (00-31) for the word described on the card.
-4 Blank
5 Punch " $H$ " or " $L$ " for output Y8. $H=$ high-voltage-level output, $\mathrm{L}=$ low-voltage-level output

6-9 Blank

11-14 Blank

15 Punch "H" or "L" for output DO 6.
16-19 Blank
20 Punch " H " or " L " for output DO 5.
21-24 Blank
25 Punch " $H$ " or " L " for output DO 4.
26-29 Blank
30 Punch " $H$ " or "L' for output DO 3.
31-34 Blank
35 Punch "H" or "L" for output DO 2.
36-39 Blank
40 Punch " H " or "L" for output DO 1.
41-49 Blank
50-51 Punch a right-justified integer representing the current calendar day of the month.

52 Blank
53-55 Punch an alphabetic abbreviation representing the current month.

56 Blank
57-58 Punch the last two digits of the current year.
59 Blank
60-61 Punch "SN"'
62-66 Punch a left-justified integer representing the Texas Instruments part number. This is supplied by the factory through a TI sales representative.

67-68 Blank
69-80 Preferably these columns should be punched to reflect the customer's part or specification-control number. This information is not essential.

## '187 DATA CARD FORMAT (32 CARDS)

## Column

1. 3 Punch a right-justified integer representing the binary input address $(000-248)$ for the first set of outputs described on the card.

4 Punch a "-." (Minus sign)
5. 7 Punch a right-justified integer representing the binary input address (007-255) for the last set of outputs described on the card.

8-9 Blank

## SERIES 54/74, 54S/74S TTL READ-ONLY MEMORIES

## ORDERING INSTRUCTIONS

| 10-13 | Punch "H", "L", or "X" for bits four, three, two, and one (outputs DO 4, DO 3, DO 2 and DO 1 in that order) for the first set of outputs specified on the card. $H=$ high-voltage-level output, $L=$ low-voltage-level output, $X=$ output level irrelevant. |
| :---: | :---: |
| 14 | Blank |
| 15-18 | Punch " $H$ ", " $L$ ", or " $X$ " for the second set of outputs. |
| 19 | Blank |
| 20.23 | Punch "H". " $L$ ", or " $X$ " for the third set of outputs. |
| 24 | Blank |
| 25-28 | Punch " $H$ " " $L$ ", or " $X$ " for the fourth set of outputs. |
| 29 | Blank |
| 30-33 | Punch " $H$ ", " $L$ ", or " $X$ " for the fifth set of outputs. |
| 34 | Blank |
| $35 \cdot 38$ | Punch " $H$ ", " $L$ ", or " $X$ " for the sixth set of outputs. |
| 39 | Blank |
| 40.43 | Punch "H", "L", or "X" for the seventh set of outputs. |
| 44 | Blank |
| 45.48 | Punch " $H$ ", " $L$ ", or " $X$ " for the eighth set of outputs. |
| 49 | Blank |
| 50.51 | Punch a right-justified integer representing the current calendar day of the month. |
| 52 | Blank |
| 53.55 | Punch an alphabetic abbreviation representing the current month. |
| 56 | Blank |
| 57-58 | Punch the last two digits of the current year. |
| 59 | Blank |
| 60-61 | Punch 'SN" |
| $62 \cdot 66$ | Punch a left-justified integer representing the Texas Instruments part number. This is supplied by the factory through a TI sales representative. |
| $67 \cdot 68$ | Blank |

69-80 Preferably these columns should be punched to reflect the customer's part or specification-control number. This information is not essential.
'S270, 'S370 DATA CARD FORMAT (64 CARDS)
Column
1-3 Punch a right-justified integer representing the binary input address $(000-504)$ for the first set of outputs described on the card.
4 Punch a "-" (Minus sign)
5-7 Punch a right-justified integer representing the binary input address (007-511) for the last set of outputs described on the card.

8-80 Same as the '187 data card format.
'S271, ‘S371 DATA CARD FORMAT (64 CARDS)

## Column

1. 3 Punch a right-justified integer representing the binary input address $(000-252)$ for the first set of outputs described on the card.

4 Punch a "-" (Minus sign)
5. 7 Punch a right-justified integer representing the binary input address (003-255) for the last set of outputs described on the card.

8- 9 Blank
10-17 Punch " $H$ ", " $L$ ", or " $X$ " for bits eight, seven, six, five, four, three, two, and one (outputs DO 8, DO 7, DO 6, DO 5, DO 4, DO 3, DO 2, and DO 1 in that order) for the first set of outputs specified on the card. $H=$ high-voltage-level output, $L=$ low. voltage-level output, $X=$ output level irrelevant.

18 Blank
19-26 Punch " $H$ ", " $L$ ", or " $X$ " for the second set of outputs.

27 Blank
28-35 Punch " $H$ ", " $L$ ", or "X" for the third set of outputs.

36 Blank
37-44 Punch " $H$ ", " $L$ ", or " $X$ " for the fourth set of outputs.

45-49 Blank
50-80 Same as the '187 data card format.

- Mask Programmable 12L ROM
- Fully TTL Compatible Inputs/Outputs
- Programmable Options Include:
- User Selectable Speed/Power Operation:
- Wide Range for Injector Current Supply Operation (SBP 9818)
- Resistor Options for 5-Volt Supply Operation (SBP 8316)
- Choice of Outputs:
- Open-Collector for VCC or INJ Operation
- Internal 10K $\Omega$ Pull-Up Resistors to VCC (SBP 8316)
- Choose Any Combination of Up to 3 Boolean Variables for Chip Select or 2 Boolean Variables with Latched Outputs
- Industry Standard Pin Assignments in 24-Pin Plastic or C-DIP Packages
- Choice of Temperature Ranges:
- SBP 8316CN, SBP 9818CN for 0 to $70^{\circ} \mathrm{C}$ Applications
- SBP 8316MJ, SBP 9818MJ for $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ Applications
description


FIGURE 1 ADDRESS ACCESS TIMING vs.

ier. - injector current

These integrated injection logic ( 12 L ) 16,384-bit mask programmable read-only memories are organized as 2048 -words of 8 -bit length. They offer a system designer the highest degree of selectivity with respect to speed/power/performance and a wide choice of programmable options in a single monolithic ROM function. These flexible, high density, bipolar ROM's can provide the basis for cost-effective solutions to a wide range of applications especially large, fixed macroand microprogram memory having a capacity which may include code converters, constants, character generators, and look-up tables.

These ROM's feature a unique capability of being dedicated at programming to become either:

- Pure $I^{2}$ L, SBP 9818, for operation from an injector (INJ) current source with user selectable speed/power performance and open-collector outputs. This option is injector-source compatible with other user selectable speed/power ${ }^{2}$ L products such as the SBP 9900, SBP 0400A, and SBP 0401A. See Figure 1 and schematic of outputs.
- Or, the SBP 8316, with a fixed voltage source ( $\mathrm{V}_{\mathrm{CC}}$ ) in the range of 1.5 to 5 volts, has on-chip supply current resistor supplied and output pull-up resistors available. See Figure 1 and schematic of outputs. This option is VCC compatible with Schottky TTL or low-threshold MOS and can eliminate the need for external resistors.

In addition to the data bits, other programmable selections available are:

- To include or eliminate latches for the outputs which are controllable from the strobe input (G). If latches are selected, the strobe being high will make the latches transparent, and when low the addressed data is latched.


# TYPES SBP 8316, SBP 9818 16,384-BIT IL READ-ONLY MEMORIES 

- Active high or active low chip selects (S). Two inputs are dedicated as chip selects and if output latches are not used, a third chip-select input is available. Each can be specified active high or low providing the flexibility of selecting the ROM with any Boolean combination of up to three inputs.

The SBP 8316 M and SBP 9818 M are characterized for operation over the full military temperature range of $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ and the SBP 8316 C and SBP 9818 C are characterized for operation from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.
schematics of inputs and outputs


SBP 9818

SBP 8316

functional block diagram


NOTE: ............ INDICATES PROGRAMMABLE OPTIONS

TYPES SBP 8316, SBP 9818
16,384-BIT I²L READ-ONLY MEMORIES
recommended operating conditions

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

| PARAMETER |  |  | TEST CONDITIONS |  | SBP 8316 |  |  | SBP 9818 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| $V_{\text {IH }}$ | High-level input voltage |  |  |  |  |  | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.8 |  |  | 0.8 | V |
| VIK | Input clamp voltage |  | $\begin{aligned} & \mathrm{I}_{\mathrm{CC}}=3 \mathrm{~mA} \text { or } \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \\ & \mathrm{I}_{1}=-12 \mathrm{~mA} \end{aligned}$ |  |  |  | -1.5 |  |  | -1.5 | V |
| ${ }^{1} \mathrm{OH}$ | High-level <br> output <br> current | Open-collector | ${ }^{1} \mathrm{CC}=300$ to 500 mA or | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 200 |  |  | 200 | $\mu \mathrm{A}$ |
|  |  | outputs | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  |  | 400 |  |  | 400 |  |
|  |  | $10 \mathrm{k} \Omega$ Pull- <br> up Resistors | $\begin{array}{ll} \hline V_{C C}=5 \mathrm{~V}, & \mathrm{R}_{\mathrm{VCC}}=40 \Omega \\ \mathrm{~V}_{\mathrm{O}}=2.4 \mathrm{~V} & \\ \hline \end{array}$ |  |  | $-310$ |  |  |  |  |  |
| $\mathrm{VOL}_{\text {OL }}$ | Low-level output voltage |  | $\begin{aligned} & V_{C C}=\mathrm{MIN}, \\ & V_{I H}=2 \mathrm{~V}, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\mathrm{I}^{\mathrm{OL}}=5.6 \mathrm{~mA}$ |  |  | 0.4 |  |  | 0.4 |  |
|  |  |  | $I^{\prime} C C=300 \mathrm{~mA}$ | $\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |  |  | 0.4 |  |  | 0.4 |  |
|  |  |  | ${ }^{1} \mathrm{CC}=500 \mathrm{~mA}$ | $\mathrm{I}^{\mathrm{OL}}=20 \mathrm{~mA}$ |  |  | 0.5 |  |  | 0.5 |  |
| 11 | Input current |  | $\mathrm{V}_{1}=2.4 \mathrm{~V}$ |  | 340 |  |  | 340 |  |  | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ |
|  |  |  | $\mathrm{V}_{1}=0.4 \mathrm{~V}$ |  | 25 |  |  | 25 |  |  |  |
| ICC |  |  | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | RVCC $=40 \Omega$ | 100 |  |  |  |  |  | mA |

typical switching characteristics, $\mathrm{TA}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$

| PARAMETER | SBP 8316 | SBP 9818 |  |
| :---: | :---: | :---: | :---: |
|  |  | RVCC $^{*}=40 \Omega$ | $I_{C C}=300 \mathrm{~mA}$ |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{ad})$ | Access time from address | 350 ns | 200 ns |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{S})$ | Access time from chip select | 175 ns | 75 ns |

# TYPES SBP 8316, SBP 9818 16,384-BIT I²L READ-ONLY MEMORIES 

## ORDERING INSTRUCTIONS

TO BE CONIPLETED BY REQUESTOR

```
COMPANY:
ADDRESS:
POSTAL ZIP CODE: CONTACT(NAME):
``` \(\qquad\)
``` (NO.)
PHONE: (Area Code)
CUSTOMER PURCHASE ORDER NO:
CUSTOMER PRINT OR I.D. NO:
CUSTOMER PART NO:
SYMBOLIZE AS PART NO:
ROM POWER-SUPPLY OPTIONS (Choose A or B):
A.
```

```INJECTOR-SUPPLY VERSION
(outputs are open-collector)
B.
\(\square\) 5V-SUPPLY VERSION
(choose one
pullup resistor option):
B1. OUTPUT COLLECTOR
PULLUPS (check one)
ROM MEMORY-ENABLE OPTIONS
(Choose one option for each pin):
```

A. PIN 18
$\square \mathrm{H}=$ true enable
(Check one)$\mathrm{L}=$ true enable
B. PIN 20
$\square \mathrm{H}=$ true enable
(Choose one) $\square \mathrm{L}=$ true enable
$\qquad$
$\qquad$
$\qquad$
$\qquad$
$\qquad$
$\qquad$
$\qquad$


NOTES: 1. L = True enable pins will be logically true if left open.
2. All memory enable pins must be true to enable the outputs.

ROM LATCH/ENABLE OPTIONS
(Choose one option):
A. [] TRANSPARENT LATCH FOR EACH OUTPUT
(Pin $21=H$ for transparency, $L$ for storing)
B.NO LATCHES (Choose memory-enable option for pin 21):
B1. PIN 21 (Choose one)
$\square \mathrm{H}=$ true enable$L$ = true enable

## BIT PROGRAMMING INSTRUCTIONS

Programming instructions for each bit location of these read-only memories are solicited in the form of a sequenced deck of standard 80 -column data cards providing the information requested below, and accompanied by a properly sequenced listing of these cards. Upon receipt of these items, a computer run will be made from the deck of cards which will produce a complete function table for the requested part. This function table, showing output conditions for each of the words, will be forwarded to the purchaser as verification of the input data as interpreted by the computer-automated design (CAD) program. This single run also generates mask and test program data; therefore, verification of the function table should be completed promptly.

Each card in the data deck prepared by the purchaser identifies the words specified and describes the levels at the outputs for each of those words. All addresses must have all outputs defined and columns designated as "blank" must not be punched. The 512 cards should be punched according to the following data card format:

Column
1-3 Punch a right-justified integer representing the binary input address $(000-2044)$ for the first set of outputs described on the card.

4 Punch a "-" (Minus sign)
5-7 Punch a right-justified integer representing the binary input address (003-2047) for the last set of outputs described on the card.

8-9
Blank
10-17 Punch " $H$ ", " $L$ ", or " $X$ " for bits eight, seven, six, five, four, three, two, and one (outputs DO 8, DO 7, DO 6, DO 5, DO 4, DO 3, DO 2, and DO 1 in that order) for the first set of outputs specified on the card. (See note 1.)

18 Blank
19-26 Punch " $H$ ", " $L$ ", or " $X$ " for the second set of outputs.

27 Blank
28-35 Punch " $H$ ", " $L$ ", or " $X$ " for the third set of outputs.
36 Blank
37-44 Punch " $H$ ", " $L$ ", or " $X$ " for the fourth set of outputs.
45-49 Blank

50-80 Same as the ' 187 data card format, page 15.

## TO BE COMPLETED BY TI

SPECIAL DEVICE NO: $\qquad$
SALES ORDER NO: $\qquad$ LOCATION: $\qquad$
CONTACT (NAME): PHONE EXT

- Static Fully Decoded Ram's Organized as 16 Words of Four Bits Each
- Schottky-Clamped for High Speed:

Read Cycle Time . . . 25 ns Typical
Write Cycle Time . . . 25 ns Typical

- Choice of Three-State or Open-Collector Outputs
- Compatible with Most TTL and $\mathrm{I}^{2}$ L Circuits
- Chip-Select Input Simplifies External Decoding


## description

These 64-bit active-element memories are monolithic Schottky-clamped transistor-transistor logic (TTL) arrays organized as 16 words of four bits each. They are fully decoded and feature a chip-select input to simplify decoding required to achieve expanded system organization. The memories feature $\mathrm{p}-\mathrm{n}-\mathrm{p}$ input transistors that reduce the low-level input current requirement to a maximum of -0.25 milliamperes, only one-eighth that of a Series $54 \mathrm{~S} / 74 \mathrm{~S}$ standard load factor. The chip-select circuitry is implemented with minimal delay times to compensate for added system decoding.

## write cycle

The information applied at the data input is written into the selected location when the chip-select input and the write-enable input are low. While the write-enable input is low, the 'S189 output is in the high-impedance state and the 'S289 output is off. When a number of outputs are bus-connected, this high-impedance or off state will neither load nor drive the bus line, but it will allow the bus line to be driven by another active output or a passive pull-up.

## read cycle

The stored information (complement of information applied at the data input during the write cycle) is available at the output when the write-enable input is high and the chip-select input is low. When the chip-select input is high, the 'S189 output will be in the high-impedance state and the 'S289 output will be off.

FUNCTION TABLE

| FUNCTION | INPUTS |  | 'S189 | 'S289 |
| :---: | :---: | :---: | :---: | :---: |
|  | CHIP SELECT | WRITE ENABLE |  | OUTPUT |
| Write | L | L | High Impedance | Off |
| Read | L | H | Complement of Data Entered | Complement of Data Entered |
| Inhibit | H | X | High Impedance | Off |

[^8]TEXAS INSTRUMENTS

## functional block diagram


schematics of inputs and outputs

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


## 64-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

## recommended operating conditions


$\uparrow \downarrow$ The arrow indicates the transition of the write-enable input used for reference: $\uparrow$ for the low-to-high transition, $\downarrow$ for the high-to-low transition.
electrical characteristics over recommended operating free-air temperature range (otherwise noted)

| PARAMETER | TEST CONDITIONS ${ }^{\dagger}$ |  | 'S189 |  |  | 'S289 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{V}_{1 \mathrm{H}} \quad$ High-level input voltage |  |  | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ Low-level input voltage |  |  |  |  | 0.8 |  |  | 0.8 | V |
| $\mathrm{V}_{\text {IK }} \quad$ Input clamp voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \quad \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.2 |  |  | -1.2 | V |
| V OH High-level output voltage | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, & \mathrm{~V}_{I H}=2 \mathrm{~V}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{array}$ | SN54S' | 2.4 | 3.4 |  |  |  |  | V |
|  |  | SN74S' | 2.4 | 3.2 |  |  |  |  |  |
| ${ }^{\prime} \mathrm{OH} \quad$ High-level output current | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \quad \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V} & \\ \end{array}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  |  |  | 40 | $\mu \mathrm{A}$ |
|  |  | $\mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  |  |  |  |  | 100 |  |
| VOL Low-level output voltage | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, & \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{array}$ | SN54S' |  | 0.35 | 0.5 |  | 0.35 | 0.5 | V |
| OL Low-level output volage |  | SN74S' |  | 0.35 | 0.45 |  | 0.35 | 0.45 |  |
| IOZHOff-state output current, <br> high-level voltage applied | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, & \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ \hline \end{array}$ |  |  |  | 50 |  |  |  | $\mu \mathrm{A}$ |
| IOZLOff-state output current, <br> low-level voltage applied | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, & \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & \mathrm{~V}_{\mathrm{OL}}=0.4 \mathrm{~V} \end{array}$ |  |  |  | -50 |  |  |  | $\mu \mathrm{A}$ |
| IIInput current at maximum input <br> voltage | $V_{C C}=\mathrm{MAX}, \quad \mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  |  | 1 |  |  | 1 | mA |
| $I_{\text {IH }}$ High-level input current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  |  | 25 |  |  | 25 | $\mu \mathrm{A}$ |
| IIL Low-level input current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  |  | -250 |  |  | -250 | $\mu \mathrm{A}$ |
| IOS Short-circuit output current § | $V_{C C}=$ MAX |  | $-30$ |  | -100 |  |  |  | mA |
| ICC Supply current | $V_{C C}=$ MAX, See Note 2 |  |  | 75 | 110 |  | 75 | 105 | mA |

[^9]NOTES: 1. Voltage values are with respect to network ground terminal.
2. ICC is measured with the read/write and chip-select inputs grounded. All other inputs at 4.5 V , and the outputs open.

## 64-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

${ }^{\prime}$ S189 switching characteristics over recommended operating ranges of $\mathrm{T}_{\mathrm{A}}$ and $\mathrm{V}_{\mathrm{C}}$ (unless otherwise noted)

| PARAMETER |  | TEST CONDITIONS $\begin{aligned} & C_{L}=30 \mathrm{pF}, \\ & R_{L}=300 \Omega \end{aligned}$ <br> See Note 3 | SN54S189 |  | SN74S189 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP ${ }^{\text {¢ }}$ | MAX | TYP $\ddagger$ | MAX |  |
| Access time from address |  |  | 25 | 50 | 25 | 35 | ns |
| Access time from chip select (enable time) |  |  | 12 | 25 | 12 | 17 | ns |
| Sense recovery time |  |  | 22 | 40 | 22 | 35 | ns |
| tPXZ Disable time from high or low level | from $\bar{S}$ |  | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}, \\ & \mathrm{R}_{\mathrm{L}}=300 \Omega, \end{aligned}$ <br> See Note 3 | 12 | 25 | 12 | 17 | ns |
|  | from $\bar{W}$ | 12 |  | 30 | 12 | 25 |  |  |

'S289 switching characteristics over recommended operating ranges of $\mathrm{T}_{\mathrm{A}}$ and $\mathrm{V}_{\mathrm{C}}$ (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS$\begin{aligned} & \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}, \\ & \mathrm{R}_{\mathrm{L} 1}=300 \Omega, \\ & \mathrm{R}_{\mathrm{L} 2}=600 \Omega, \\ & \text { See Note } 3 \end{aligned}$ | SN54S289 |  | SN74S289 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | TYP ${ }^{\text {¢ }}$ | MAX | TYP $\ddagger$ | MAX |  |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{ad})$ | Access time from address |  |  | 25 | 50 | 25 | 35 | ns |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{S})$ | Access time from chip select (enable time) |  |  | 12 | 25 | 12 | 17 | ns |
| ${ }_{\text {t }} \mathrm{SR}$ | Sense recovery time |  |  | 22 | 40 | 22 | 35 | ns |
| tPLH | Propagation delay time, low-to-high-level output (disable time) | from $\overline{\mathbf{S}}$ |  | 12 | 25 | 12 | 17 | ns |
|  |  | from $\bar{W}$ |  | 12 | 30 | 12 | 25 |  |

\#All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
NOTES: 3. Load circuit and voltage wave forms are shown in Appendix A, page 44.

- Static Fully Decoded RAM's Organized as 256 Words of One Bit Each
- Schottky-Clamped for High Performance
- Choice of Three-State or Open-Collector Outputs
- Compatible with Most TTL and $\mathrm{I}^{\mathbf{2}} \mathrm{L}$ Circuits
- Chip-Select Inputs Simplify External Decoding
- Typical Performance:

Read Access Time . . . . . . . . . . . . . 42 ns
Power Dissipation . . . . . . . . . . . 500 mW

## description

SN74S201, SN74S301 . . J OR N PACKAGE (TOP VIEW)


Pin assignments are same for all packages.

These 256-bit active-element memories are monolithic transistor-transistor logic (TTL) arrays organized as 256 words of one bit. They are fully decoded and have three chip-select inputs to simplify decoding required to achieve expanded system organizations.

## write cycle

The information applied at the data input is written into the selected location when the three chip-select inputs and the write-enable input are low. While the write-enable input is low, the 'S201 outputs are in the high-impedance state and the 'S301 outputs are off. When a number of outputs are bus-connected, this high-impedance or off state will neither load nor drive the bus line, but it will allow the bus line to be driven by another active output or a passive pull-up.

## read cycle

The stored information (complement of information applied at the data input during the write cycle) is available at the output when the write-enable input is high and the three chip-select inputs are low. When any one of the chip-select inputs are high, the 'S201 outputs will be in the high-impedance state and the 'S301 outputs will be off.

## FUNCTION TABLE

| FUNCTION | INPUTS |  | $\begin{gathered} \text { 'S201 } \\ \text { OUTPUT (DO) } \end{gathered}$ | $\begin{gathered} \text { 'S301 } \\ \text { OUTPUT (DO) } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
|  | CHIP ENABLE (Ei) OR SELECT ( $\overline{\mathrm{S}} \mathrm{i}$ ) | WRITE ENABLE (W) |  |  |
| Write | L | L | High Impedance | Off |
| Read | L | H | Complement of Data Entered | Complement of Data Entered |
| Inhibit | H | X | High Impedance | Off |

[^10]$\ddagger_{\text {For chip-select: } L} \equiv$ all $\bar{S}$ i inputs low, $H \equiv$ one or more $\bar{S} \bar{i}_{i}$ inputs high Texas Instruments. U. S. Patent Number 3,463,975.
schematics of inputs and outputs

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


```
Input voltage ..................................................................................................... . . . . . . . . . . . V
Off-State output voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 . V
Operating free-air temperature range .............................................................. . . . . . C to 70 . . C
Storage temperature range . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . - 65 . C to 150年 C
```

recommended operating conditions

$\uparrow \downarrow$ The arrow indicates the transition of the write input used for references: $\uparrow$ for the low-to-high transition, $\downarrow$ for the high-to-low transition.

[^11]
## 256-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

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

|  | PARAMETER | TEST CONDITIONS ${ }^{\boldsymbol{+}}$ | 'S201 |  |  | 'S301 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  | 0.8 |  |  | 0.8 | V |
| VIK | Input clamp voltage | $V_{C C}=\mathrm{MIN}, \quad \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| V OH | High-level output voltage | $\begin{array}{ll} V_{C C}=M I N, & V_{I H}=2 \mathrm{~V}, \\ V_{I L}=08 \mathrm{~V}, & I_{O H}=M A X \end{array}$ | 2.4 |  |  |  |  |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Low-level output voltage | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \quad \mathrm{V}_{\text {IH }}=2 \mathrm{~V}$, |  |  | 0.45 |  |  | 0.45 | V |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | High-level output current | $\begin{array}{ll\|l} \hline V_{\mathrm{CC}}=\mathrm{MIN}, & \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, & \mathrm{~V}_{\mathrm{O}}=2.4 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V} & & V_{\mathrm{O}}=5.5 \mathrm{~V} \\ \hline \end{array}$ |  |  |  |  |  | 40 | $\mu \mathrm{A}$ |
| ${ }^{\prime} \mathrm{OZH}$ | Off-state output current, high-level voltage applied | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, & \mathrm{~V}_{\text {IH }}=2 \mathrm{~V}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \end{array}$ |  |  | 40 |  |  |  | $\mu \mathrm{A}$ |
| IOZL | Off-state output current, low-level voltage applied | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, & \mathrm{~V}_{1 \mathrm{H}}=2 \mathrm{~V}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & \mathrm{~V}_{\mathrm{OL}}=0.5 \mathrm{~V} \end{array}$ |  |  | -40 |  |  |  | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage | $V_{C C}=M A X, \quad V_{1}=5.5 \mathrm{~V}$ |  |  | 1 |  |  | 1 | mA |
| 1 IH | High-level input current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 25 |  |  | 25 | $\mu \mathrm{A}$ |
| 1 IL | Low-level input current | $\mathrm{V}_{C C}=\mathrm{MAX}, \quad \mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  | -250 |  |  | -250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current § | $V_{C C}=M A X$ | -30 |  | -100 |  |  |  | mA |
| ${ }^{\text {I CC }}$ | Supply current | $V_{C C}=M A X, ~ S e e ~ N o t e ~ 2 ~$ |  | 100 | 140 |  | 100 | 140 | mA |

${ }^{\dagger}$ For conditions shown as MIN or MAX use the appropriate value specified under recommended operation conditions.
$\ddagger$ These typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
§Duration of the short circuit should not exceed one second.
NOTE: 2. I CC is measured with all chip-select inputs grounded, all other inputs at 4.5 V , and the output open
'S201 switching characteristics over recommended operating ranges of $T_{A}$ and $V_{C C}$ (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{ad})$ | Access time from address |  | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$, |  | 42 | 65 | ns |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{S})$ | Access time from chip select (select time) |  | $R_{L}=300 \Omega$, |  | 13 | 30 | ns |
| ${ }^{\text {t }}$ SR | Sense recovery time |  | See Note 3 |  | 20 | 40 | ns |
| tPXZ | Disable time from high or low level | From $\bar{S}$ | $C_{L}=5 \mathrm{pF},$ |  |  | 20 | ns |
|  |  | From W | See Note 3 |  | 9 | 20 | ns |

'S301 switching characteristics over recommended operating ranges of $\mathrm{T}_{\mathrm{A}}$ and $\mathrm{V}_{\mathrm{C}}$ (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{ad})$ | Access time from address |  | $\begin{aligned} & C_{L}=30 \mathrm{pF}, \\ & R_{\mathrm{L} 1}=300 \Omega, \\ & R_{\mathrm{L} 2}=600 \Omega, \end{aligned}$ |  | 42 | 65 | ns |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{S})$ | Access time from chip enable (enable time) |  |  |  | 13 | 30 | ns |
| ${ }^{\text {t }}$ SR | Sense recovery time |  |  |  | 20 | 40 | ns |
| tPLH | Propagation delay time, low-to-high-level output (disable time) | From $\bar{S}$ | See Note 3 |  |  | 20 |  |
|  |  | From $\bar{W}$ |  |  | 15 | 35 | ns |

\$All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
NOTE: 3. Load circuit and voltage waveforms are shown in Appendix A, page 44.

- Static Fully Decoded RAM's Organized 1024

Words of One Bit Each

- Schottky-Clamped for High Performance
- Choice of Three-State or Open-Collector Outputs
- Compatible with Most TTL and $\mathrm{I}^{2} \mathrm{~L}$ Circuits
- Chip-Enable/Select Inputs Simplify External Decoding
- Typical Performance

| TYPES | READ <br> ACCESS TIMES | POWER <br> DISS |
| :--- | :---: | :---: |
| 'S214/'S314 | 40 ns | 550 mW |
| 'LS214/'LS314 | 75 ns | 200 mW |
| 'LS215/'LS315 | 75 ns | 200 mW |
| 'LS215/'LS315 <br> POWER DOWN | 75 ns <br> (to power-up) | 125 mW |

SN74LS214, SN74LS314
SN74LS215, SN74LS315
SN74S214, SN74S314 . . . J OR N PACKAGE
(TOP VIEW)
E/S 1

Pin assignments are same for all packages.
$\bar{E}=$ Chip-Enable for 'LS215, 'LS315
$\overline{\mathbf{S}}=$ Chip-Select for 'LS214, 'LS314, 'S214, 'S314

## description

These 1024-bit active-element memories are monolithic transistor-transistor logic (TTL) arrays organized as 1024 words of one bit. They are fully decoded and have a chip-enable or chip-select input to simplify decoding required to achieve expanded system organizations. When the 'LS215/'LS315 is disabled, all read and write functions are in a power-down mode, that is, turned off.

## write cycle

The information applied at the data input is written into the selected location when the chip-enable/select input and the write-enable input are low. While the write-enable input is low, the 'S214, 'LS214, and 'LS215 outputs are in the high-impedance state and the 'S314, 'LS314, and 'LS315 outputs are off. When a number of outputs are bus-connected, this high-impedance or off state will neither load nor drive the bus line, but it will allow the bus line to be driven by another active output or a passive pull-up.

## read cycle

The stored information is available at the output when the write-enable input is high and the chip-enable/select input is low. When the chip-enable/select input is high, the 'S214, 'LS214, or 'LS215 output will be in the high-impedance state, the'S314,'LS314, or'LS315 output will be off, and 'LS215 or 'LS315 will be in a power-down mode.

## 1024-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

| FUNCTION TABLE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| FUNCTION | INPUTS |  | 'S214 | 'S314 |
|  | CHIP ENABLE (E) OR SELECT (S) | WRITE ENABLE (W) | $\begin{gathered} \text { 'LS214 } \\ \text { 'LS215 } \\ \text { OUTPUT (DO) } \end{gathered}$ | $\begin{gathered} \text { ‘LS314 } \\ \text { ‘LS315 } \\ \text { OUTPUT (DO) } \\ \hline \end{gathered}$ |
| Write | L | L | High Impedance | Off |
| Read | L | H | Stored Data | Stored Data |
| Inhibit | H | X | High Impedance | Off |

$H \equiv$ high level, $L \equiv$ low level, $X \equiv$ irrelevant
schematics of inputs and outputs

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


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

## 'S214 recommended operating conditions

|  | SN74S214 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | NOM | MAX |  |
| Supply voltage, $\mathrm{V}_{\text {CC }}$ (see Note 1) | 4.75 | 5 | 5.25 | V |
| High-level output current, $\mathrm{I}^{\mathrm{OH}}$ |  |  | -10.3 | mA |
| Low-level output current, IOL |  |  | 16 | mA |
| Width of write pulse (write enable low), $t_{w}$ (wr) | 50 |  |  | ns |
| Setup Address before write pulse, $\mathrm{t}_{\text {sulad) }}$ | $15 \downarrow$ |  |  | ns |
| time Data before end of write pulse, $\mathrm{t}_{\text {su }}$ (da) | $55 \uparrow$ |  |  |  |
|  | $55 \uparrow$ |  |  |  |
| Hold ${ }^{*}$ Address after write pulse, $\mathrm{th}_{\mathrm{h}(\mathrm{ad})}$ | $20 \uparrow$ |  |  | ns |
|  | $5 \uparrow$ |  |  |  |
|  | $5 \uparrow$ |  |  |  |
| Operating free-air temperature, $\mathrm{TA}_{\mathrm{A}}$ | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

## 'S314 recommended operating conditions

|  | SN74S314 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | NOM | MAX |  |
| Supply voltage, $\mathrm{V}_{\text {CC }}$ (see Note 1) | 4.75 | 5 | 5.25 | V |
| High-level output voltage, $\mathrm{V}_{\mathrm{OH}}$ |  |  | 5.5 | V |
| Low-level output current, IOL |  |  | 16 | mA |
| Width of write pulse (write enable low), $\mathrm{t}_{\mathrm{w}}(\mathrm{wr})$ | 50 |  |  | ns |
| Setup Address before write pulse, $\mathrm{t}_{\text {su }}(\mathrm{ad})$ | 15 $\downarrow$ |  |  | ns |
| time ${ }^{\text {Setup }}$ Data before end of write pulse, $\mathrm{t}_{\text {su }}(\mathrm{da})$ | $55 \uparrow$ |  |  |  |
|  | $55 \uparrow$ |  |  |  |
| $\mathrm{H}_{*}^{*}$ Hold ${ }^{\text {Address after write pulse, } \mathrm{th}(\mathrm{ad})}$ | $20 \uparrow$ |  |  | ns |
|  | $5 \uparrow$ |  |  |  |
|  | $5 \uparrow$ |  |  |  |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

$\uparrow \downarrow$ The arrow indicates the transition from the read/write input used for reference: $\uparrow$ for the low-to-high transition, $\downarrow$ for the high-to-low transition.
NOTE: 1. Voltage values are with respect to network ground terminal.

## 1024-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

'LS214, 'LS314, 'LS215, 'LS315 recommended operating conditions

|  |  |  | $\begin{aligned} & \text { 174LS2 } \\ & \text { 174LS3 } \end{aligned}$ |  |  | $\begin{aligned} & \text { 174LS2 } \\ & \text { 174LS3 } \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply Voltage, $\mathrm{V}_{\text {CC }}$ ( see Note 1) |  | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 | V |
| High-l |  |  |  | 5.5 |  |  | 5.5 | V |
| High-level output current, IOH ${ }^{\text {I }}$ (LS215 |  |  |  | -5.2 |  |  | -5.2 | mA |
| Low-level output current, IOL |  |  |  | 16 |  |  | 16 | mA |
| Width of write pulse (write enable low), ${ }^{t} w(w r)$ |  | 60 |  |  | 60 |  |  | ns |
| Setup time | Address before write pulse, ${ }^{t}$ su(ad) | $20 \downarrow$ |  |  | $20 \downarrow$ |  |  | ns |
|  | Data before end of write pulse, ${ }^{t}$ su(da) | $75 \uparrow$ |  |  | $75 \uparrow$ |  |  |  |
|  | Chip-select/enable before end of write pulse, $\mathrm{t}_{\text {su }}(\overline{\mathrm{E}}), \mathrm{t}_{\text {su }}(\overline{\mathrm{S}})$ | $75 \uparrow$ |  |  | $110 \uparrow$ |  |  |  |
| Hold time | Address after write pulse, $\mathrm{th}(\mathrm{ad})$ | $15 \uparrow$ |  |  | $15 \uparrow$ |  |  | ns |
|  | Data after write pulse, th (da) | $15 \uparrow$ |  |  | 154 |  |  |  |
|  | Chip-select/enable after write pulse $\mathrm{t}_{\mathrm{h}}(\overline{\mathrm{E}}), \mathrm{t}_{\mathrm{h}}(\overline{\mathbf{S}})$ | 15 $\uparrow$ |  |  | $15 \uparrow$ |  |  |  |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ |  | 0 |  | 70 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

'S214, 'S314 electrical characteristics over recommended operating free-air temperature range (otherwise noted)

| PARAMETER | TEST CONDITIONS ${ }^{\dagger}$ |  | 'S214 |  | 'S314 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ MAX | MIN | TYP $\ddagger$ MAX |  |
| $\mathrm{V}_{\text {IH }}$ High-level input voltage |  |  | 2 |  | 2 |  | V |
| VIL Low-level input voltage |  |  |  | 0.8 |  | 0.8 | V |
| $V_{\text {IK }}$ Input clamp voltage | $V_{C C}=$ MIN, $I_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$High-level <br> output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ |  | 2.4 | 2.9 |  |  | V |
| VOLLow-level <br> output voltage | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=\mathrm{MAX} \end{aligned}$ |  |  | 0.45 |  | 0.45 | V |
| IOH High-level | $\begin{aligned} & V_{C C}=M I N, V_{I H}=2 \mathrm{~V}, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| $\mathrm{OH}^{\text {OHentput current }}$ |  | $\mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| $\mathrm{I}^{\prime} \mathrm{OZH} \begin{aligned} & \text { Off-state output current, } \\ & \text { high-level voltage applied }\end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \end{aligned}$ |  |  | 50 |  |  | $\mu \mathrm{A}$ |
| $\begin{array}{\|cc\|} \hline \text { IOZL } \begin{array}{l} \text { Off-state output current, } \\ \text { low-level voltage applied } \end{array} \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.5 \mathrm{~V} \end{aligned}$ |  |  | -50 |  |  | $\mu \mathrm{A}$ |
| II Input current at maximum <br> input voltage | $V_{C C}=M A X, V_{1}=5.5 \mathrm{~V}$ |  |  | 1 |  | 1 | mA |
| I/H High-level input current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 25 |  | 25 | $\mu \mathrm{A}$ |
| IIL Low-level input current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  | -250 |  | -250 | $\mu \mathrm{A}$ |
| IOS Short-circuit output current § | $V_{C C}=$ MAX |  | -30 | -100 |  |  | mA |
| Supply current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$, See Note 2 | $\mathrm{T}_{\mathbf{A}}=0^{\circ} \mathrm{C}$ |  | 155 |  | 155 |  |
|  |  | $\mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ |  | 130 |  | 130 | mA |

${ }^{\dagger}$ For conditions shown as MIN or MAX use the appropriate value specified under recommended operating conditions.
$\ddagger$ These typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
§Duration of the short circuit should not exceed one second.
NOTES: 1. Voltage values are with respect to network ground terminal.
2. ICC is measured with all inputs grounded and the output open.
'LS214, 'LS314, 'LS215, 'LS315 electrical characteristics over recommended operating free-air temperature range (otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | SN74 ${ }^{\prime}$ |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | High-level input voltage |  |  |  |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.8 | V |
| VIK | Input clamp voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \quad 11=-18 \mathrm{~mA}$ |  |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | $\begin{aligned} & \hline \text { LS214, } \\ & \cdot \text { LS215 } \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \\ & \hline \end{aligned}$ |  | 2.4 | 3.3 |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Low-level output voltage |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=\mathrm{MAX} \\ & \hline \end{aligned}$ |  |  |  | 0.5 | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current | 'LS314, | $\begin{aligned} & V_{C C}=M I N, V_{I H}=2 \mathrm{~V}, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
|  |  | 'LS315 |  | $\mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  |  | 100 |  |
| ${ }^{1} \mathrm{OZH}$ | Off-state output current, high-level voltage applied | $\begin{aligned} & \text { 'LS214, } \\ & \text { 'LS215 } \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \end{aligned}$ |  |  |  | 50 | $\mu \mathrm{A}$ |
| IOZL | Off-state output current, low-level voltage applied | $\begin{aligned} & \hline \text { 'LS214, } \\ & \text { 'LS215 } \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.5 \mathrm{~V} \end{aligned}$ |  |  |  | -50 | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  |  | 1 | mA. |
| $1_{1 H}$ | High-level input current |  | $\mathrm{V}_{C C}=\mathrm{MAX}, \mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  |  | 25 | $\mu \mathrm{A}$ |
| I/L | Low-level input current |  | $V_{C C}=M A X, V_{1}=0.5 \mathrm{~V}$ |  |  |  | -250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current $\S$ | 'LS214, 'LS215 | $V_{C C}=M A X$ |  | -20 |  | -100 | mA |
| ICC | Supply current |  | $\mathrm{V}_{\text {CC }}=$ MAX, See Note 2 |  |  | 40 | 58 | mA |
| ${ }^{\text {I CC }}$ | Supply current - Power down | $\left\lvert\, \begin{aligned} & \text { LS215 } \\ & \text { 'LS315 }\end{aligned}\right.$ | $V_{C C}=M A X, \bar{E}=2.4 \mathrm{~V}$ |  |  | 25 | 30 | mA |

${ }^{\dagger}$ For conditions shown as MIN or MAX use the appropriate value specified under recommended operating conditions.
$\ddagger$ These typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
§Duration of the short circuit should not exceed one second.
NOTE: 2. I CC is measured with all inputs grounded and the output open.
‘S214, 'LS214 switching characteristics over recommended operating ranges of TA and VCC (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | SN74S214 |  |  | SN74LS214 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{ad})$ | Access time from address |  |  | $C_{L}=30 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=400 \Omega$ <br> See Note 3 |  | 40 | 70 |  | 75 | 95 | ns |
| $t_{a}(\bar{S})$ | Access time from chip select (select time) |  |  |  | 15 | 40 |  | 30 | 50 | ns |
| ${ }^{\text {t }}$ SR | Sense recovery time |  |  |  | 25 | 50 |  | 35 | 65 | ns |
| tPXZ | Disable time from high or low level | from $\overline{\mathrm{S}}$ | $C_{L}=5 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=400 \Omega,$ <br> See Note 3 |  | 20 | 40 |  | 30 | 40 | ns |
|  |  | from $\bar{W}$ |  |  | 20 | 40 |  | 35 | 50 | , |

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

## 1024-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

'S314 and 'LS315 switching characteristics over recommended operating ranges of TA and VCC (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | SN74S314 |  |  | SN74LS314 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{ad})$ | Access time from address |  |  | $\begin{aligned} & C_{L}=30 \mathrm{pF}, \mathrm{R}_{\mathrm{L} 1}=300 \Omega \\ & R_{\mathrm{L} 2}=600 \Omega, \text { See Note } 3 \end{aligned}$ |  | 40 | 70 |  | 75 | 95 | ns |
| $\mathrm{ta}_{\mathbf{a}}(\bar{S})$ | Access time from chip select (select time) |  |  |  | 15 | 40 |  | 35 | 50 | ns |
| ${ }^{\text {t }}$ RR | Sense recovery time |  |  |  | 25 | 50 |  | 35 | 50 | ns |
| tPLH | Propagation delay time, low-to-high-level output (disable time) | $\overline{\mathrm{s}}$ |  |  | 20 | 40 |  | 45 | 60 | ns |
|  |  | $\bar{W}$ |  |  | 25 | 40 |  |  | 50 |  |

$\ddagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
'LS215 switching characteristics over recommended operating ranges of $\mathrm{T}_{\mathrm{A}}$ and $\mathrm{V}_{\mathrm{CC}}$ (unless otherwise noted)

|  | otherwise note |  |  |  | N74LS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | PARAMETER |  | TEST CONDITIONS | MIN | TYP $\ddagger$ | MAX | UNIT |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{ad})$ | Access time from address |  | $\mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}$, |  | 75 | 95 | ns |
| $\mathrm{t}_{\mathrm{a}}(\overline{\mathrm{E}})$ | Access time from chip enable (enab | ime) | $\mathrm{R}_{\mathrm{L}}=400 \Omega$, |  | 75 | 95 | ns |
| ${ }^{\text {t }}$ SR | Sense recovery time |  | See Note 5 |  | 35 | 65 | ns |
|  |  | from E | $C_{L}=5 \mathrm{pF},$ |  | 30 | 40 |  |
| tPXZ | igh | from $\bar{W}$ | See Note 3 |  | 35 | 50 | ns |
| ${ }^{\text {t }}$ EPD | Chip power-down time |  | See Figure 1 |  | 40 | 65 | ns |

'LS315 switching characteristics over recommended operating ranges of $T_{A}$ and VCC
(unless otherwise noted)

|  | herwise |  |  | SN74LS315 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PARAMETER |  |  | TEST CONDITIONS | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{ad})$ | Access time from address |  | $\begin{aligned} & C_{L}=15 \mathrm{pF}, \\ & R_{L 1}=400 \Omega, \\ & R_{L 2}=600 \Omega, \end{aligned}$ <br> See Note 3 |  | 75 | 95 | ns |
| $\mathrm{ta}_{\mathrm{a}}(\overline{\mathrm{E}})$ | Access time from chip enable (enable time) |  |  |  | 75 | 95 | ns |
| ${ }^{\text {t }}$ SR | Sense recovery time |  |  |  | 35 | 50 | ns |
| tPLH | Propagation delay time, low-to-high level output (disable time) | from $\overline{\mathrm{E}}$ |  |  | 30 | 60 | ns |
|  |  | from W |  |  | 35 | 50 | ns |
| tePD | Chip power-down time |  | See Figure 1 |  | 40 | 65 | ns |

$\ddagger$ All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
NOTE: 3. Load circuit and voltage waveforms are shown in Appendix A, page 44.


FIGURE 1. POWER-DOWN WAVEFORMS

- Static Fully Decoded RAM's Organized as 256 Words of Four Bits Each
- Schottky-Clamped for High Performance
- Edge-Triggered Write Control
- 'S207 Data and Address are Same Pins as 1 K PROM's ('S287, 'S387)
- High-Density Dual-in-Line Packages have Pin-Row Spacing of 0.300-Inch
- Three-State Output for Driving Bus-Organized Systems and/or Highly Capacitive Loads
- Compatible with Most TTL and I2L Circuits
- Typical Performance:

| TYPES | ACCESS TIMES |  | POWER |
| :---: | :---: | :---: | :---: |
|  | WRITE | READ |  |
| 'S207/'S208 | 35 ns | 40 ns | 600 mW |
| 'LS207/'S208 | 65 ns | 75 ns | 200 mW |

## description

These 1024 -bit active-element memories are monolithic transistor-transistor logic (TTL) arrays organized as 256 words of four bits each. They are fully decoded with output enable inputs to simplify decoding required to achieve the desired system organization. Read and write times are virtually equal, which simplifies control implementation.
schematics of inputs and outputs


| SN74LS207,SN74S207 . . . J OR N PACKAGE(TOP VIEW) |  |  |  |
| :---: | :---: | :---: | :---: |
|  |  |  |  |
| AD G | 15 | 16 | $V_{\text {cc }}$ |
| AD F | 25 | 15 | AD H |
| ADE | 35 | 14 | W |
| AD D | 45 | 13 | $\overline{O E}$ |
| AD A | 52 | 12 | I/O 1 |
| AD B | 65 | 11 | I/O 2 |
| AD C | 75 | 10 | 1/0 3 |
| GND | 85 | 9 | 1/0 4 |

SN74LS208,SN74S208 . . . J OR N PACKAGE


Pin assignments are same for all packages.


## write cycle

While the output-enable input, $\overline{\mathrm{OE}}$, of the 'LS207, 'S207 is high, data applied to the input/output ( $1 / \mathrm{O}$ ) is written into the selected location on a positive transition at the write input. Information at the data input of the 'LS208, 'S208 memory is written into the selected location on a positive transition at the write input regardless of the state of the output-enable input. While the output-enable input of either is high, the output is in the high-impedance state. When a number of outputs are bus-connected, this high-impedance output state will neither load nor drive the bus line, but it will allow the bus line to be driven by another active output or a passive pull-up if desired.
read cycle
The stored information is available at the output when the output-enable input is low.

[^12]
## 1024-BIT EDGE-TRIGGERED RANDOM-ACCESS MEMORIES

'LS207, 'S207 functional block diagram

'LS208,‘S208 functional block diagram

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


NOTE 1: All vol tage values are with respect to network ground terminal.
'S207, 'S208 recommended operating conditions

$\uparrow$ The arrow indicates that the rising transition of the write input is used for reference.
'S207,'S208 electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | SN74S' |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ MAX |  |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  |  |  |  |  | 2 |  | V |
| VIL | Low-level input voltage |  |  |  |  | 0.8 | V |
| $\mathrm{V}_{\text {IK }}$ | Input Clamp voltage |  | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$, | $1_{1}=-18 \mathrm{~mA}$ |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 V \\ & I_{O H}=M A X \end{aligned}$ | 2.4 | 3.2 | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Low-level output voltage |  | $\begin{aligned} & \mathrm{V}_{C C}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{aligned}$ |  | 0.5 | V |
| IOZH | Off-state output current high-level voltage applied | 'S207 | $\begin{aligned} & V_{C C}=\mathrm{MAX} \\ & V_{O}=2.4 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{1 \mathrm{H}}=2 \mathrm{~V}$, |  | 100 | $\mu \mathrm{A}$ |
|  |  | 'S208 |  |  |  | 50 |  |
| IOZL | Off-state output current low-level voltage applied | 'S207 | $\begin{aligned} & V_{C C}=M A X \\ & V_{O}=0.5 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{1 H}=2 \mathrm{~V}$, |  | -250 | $\mu \mathrm{A}$ |
|  |  | 'S208 |  |  |  | -50 |  |
| 11 | Input current at maximum input voltage |  | $V_{C C}=M A X$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  | 1 | mA |
| ${ }_{1} \mathrm{H}$ | High-level input current | 'S207 | $V_{C C}=M A X$, | $\mathrm{V}_{1}=2.4 \mathrm{~V}$ |  | 100 | $\mu \mathrm{A}$ |
|  |  | 'S208 |  |  |  | 25 |  |
| $I_{1 L}$ | Low-level input current |  | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  | -250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current § |  | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  | -30 | -100 | mA |
| ICC | Supply current | 'S207 | $V_{C C}=M A X$, | See Note 2 | 120 |  | mA |
|  |  | 'S208 |  |  | 120 |  |  |

## 1024-BIT EDGE-TRIGGERED RANDOM-ACCESS MEMORIES

'LS207, 'LS208 recommended operating conditions

$\uparrow$ The arrow indicates that the rising transition of the write input is used for reference.
'LS207, 'LS208 electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  |  | N74LS' |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ MAX |  |
| $V_{\text {IH }}$ | High-level input voltage |  |  |  |  |  | 2 |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  | 0.8 | V |
| $V_{\text {IK }}$ | Input Clamp voltage |  | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$, | $1_{1}=-18 \mathrm{~mA}$ |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{I H}=2 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ | 2.4 | 3.2 | V |
| VOL | Low-level output voltage |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{aligned}$ |  | 0.5 | V |
| IOZH | Off-state output current high-level voltage applied | 'LS207 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} \\ & \mathrm{~V}_{\mathrm{O}}=2.4 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\text {IH }}=2 \mathrm{~V}$, |  | 100 | $\mu \mathrm{A}$ |
|  |  | 'LS208 |  |  |  | 50 |  |
| IOZL | Off-state output current low-level voltage applied | 'LS207 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \\ & \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\text {IH }}=2 \mathrm{~V}$, |  | -250 | $\mu \mathrm{A}$ |
|  |  | 'LS208 |  |  |  | -50 |  |
| 11 | Input current at maximum input voltage |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  | 1 | mA |
| IIH | High-level input current | 'LS207 | $V_{C C}=M A X$, | $V_{1}=2.4 \mathrm{~V}$ |  | 100 | $\mu \mathrm{A}$ |
|  |  | 'LS208 |  |  |  | 25 |  |
| IIL | Low-level input current |  | $V_{C C}=M A X$, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  | -250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current § |  | $V_{C C}=M A X$ |  | -20 | -100 | mA |
| ${ }^{\prime} \mathrm{Cc}$ | Supply current | ${ }^{\text {LSS207 }}$ | $V_{C C}=M A X, ~ S e e ~ N o t e ~ 2 ~$ |  | 40 |  | mA |
|  |  | 'LS208 |  |  | 40 |  |  |

$\dagger^{\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}, T_{A}=25^{\circ} \mathrm{C}$.
§Duration of the short-circult shouid not exceed one second.
NOTES: 1. All voltage values are with respect to network ground terminal
2. I CC is measured with the write input high, output enable input grounded, all other inputs at 4.5 V , and all outputs open.
switching characteristics at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER |  |  | TEST CONDITIONS | 'S207, 'S208 |  | 'LS207,'LS208 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | TYP | MAX | TYP | MAX |  |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{ad})$ | Access time from address |  |  | $C_{L}=30 \mathrm{pF}, \quad \mathrm{R}_{\mathrm{L}}=300 \Omega,$ <br> See Figures 1 thru 5 | 40 |  | 75 |  | ns |
| $\mathrm{ta}_{\mathrm{a}}(\overline{\mathrm{OE}})$ | Access time from output enable (enable time) |  | 15 |  |  | 20 |  | ns |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{wr})$ | Access time from write | 'LS208, 'S208 | 25 |  |  | 50 |  | ns |
| tPXZ | Disable time from high or low level (see Note 4) | from OE § | $\mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}, \quad \mathrm{R}_{\mathrm{L} 1}=300 \Omega,$ <br> See Figures 3 and 5 | 15 |  | 20 |  | ns |
|  |  | from W |  | 15 |  | 20 |  |  |

§This parameter defines the delay for the I/O port to enter the input mode.

## PARAMETER MEASUREMENT INFORMATION


$C_{L}$ includes probe and jig capacitance.
All diodes are 1 N3064
FIGURE 1 - LOAD CIRCUIT

ADDRESS INPUTS (see Note A)

OUTPUT
(S1 and S2 closed)


FIGURE 2 - ACCESS TIME FROM ADDRESS INPUTS
VOLTAGE WAVEFORMS
NOTE A. When measuring delay times from address inputs, the output-enable and write inputs are low.

## 1024-BIT EDGE-TRIGGERED RANDOM-ACCESS MEMORIES



FIGURE 3 - 'LS207, 'S207 WRITE AND READ VOLTAGE WAVEFORMS


FIGURE 4 - 'LS208, 'S208 WRITE WHILE READ VOLTAGE WAVEFORMS (OUTPUT ENABLE IS LOW)


## FIGURE 5 - ACCESS (ENABLE) TIME AND DISABLE TIME FROM OUTPUT ENABLE VOLTAGE WAVEFORMS

NOTES: B. When measuring delay times from the output-enable input, the address inputs are steady-state and the write/read input is low.
C. Waveform 1 is for the output with internal conditions such that the output is low except when disabled, Waveform 2 is for the output with internal conditions such that the output is high except when disabled.
D. Input waveforms are supplied by the pulse generators having the following characteristics: $\mathrm{t}_{\mathrm{r}} \leqslant 2.5 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leqslant 2.5 \mathrm{~ns}, \mathrm{PRR} \leqslant 1 \mathrm{MHz}$, and $Z_{\text {out }} \approx 50 \Omega$.

- Independent Synchronous Inputs and Outputs
- Organized as 16 -Words of 5 Bits
- DC to 10 MHz 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 transistor-transistor logic (STTL) array organized as 16 words of five-bits each. The 'S225 can easily be expanded to 16 N -words of 5 N -bits in length and features a single enable control for all 3-state data outputs.


Pin assignments are same for all packages

## operation

A FIFO is a memory storage device which allows data to be written into and/or read from its array at independent data rates. The 'S225 is a FIFO which 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 synchronous 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). When writing data into the FIFO one of the load clock inputs must be held high while the other strobes in the data. This arrangement allows either load clock to function as an inhibit for the other.

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-logic-level 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 is low, output ready will be low. 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. The data outputs do not change as a result of the clear input; however, the output ready at a low-logic-level signifies invalid data. product in any manner without notice.

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

FUNCTION TABLES

Table 1 - Input Functions

| Input | Pin | Description |
| :--- | ---: | :--- |
| CK A | 1 | Load Clock A |
| DI 1 - DI 5 | $4-8$ | Data Inputs |
| $\overline{\text { OE }}$ | 9 | Output Enable |
| CK IN | 16 | Unload Clock Input |
| $\overline{C L R}$ | 18 | Clear |
| CK B | 19 | Load Clock B |
| GND | 10 | Ground pin |
| VCC | 20 | Supply Voltage |

Table 2 - Output Functions

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

sohematics of inputs and outputs


## functional block diagram



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

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


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

|  |  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage, $\mathrm{V}_{\mathrm{CC}}$ |  | 4.75 | 5 | 5.25 | V |
| High-level output current, I OH | All Outputs Except Data |  |  | -3.2 | mA |
|  | Data Outputs |  |  | -6.5 |  |
| Low-level output current, IOL | All Outputs Except Data |  |  | 8 | mA |
|  | Data Outputs |  |  | 16 |  |
| Pulse Width | Load Clock A or B, $\mathrm{t}_{w}$ ( high) | 25 |  |  | ns. |
|  | Unload Clock Input, $\mathrm{t}_{\text {w }}$ (low) | 7 |  |  |  |
|  | Clear, $\mathrm{t}_{\text {w }}$ (low) | 40 |  |  |  |
| Setup Time | Data to Load Clock, $\mathrm{t}_{\text {su }}$ (Dli) See Note 2 | -20个 |  |  | ns |
|  | Clear Release to Load Clock, ${ }_{\text {su }}$ | $25 \uparrow$ |  |  |  |
| Hold Time, Data from Load Clock, $\mathrm{th}_{\mathrm{h}}$ (DII) |  | $70 \uparrow$ |  |  | ns |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

NOTE 2: Data must be setup within 15 ns after the load clock positive transition.
$\dagger \equiv$ The arrow indicates that the low-to-high transition of the load clock is used for reference.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | MIN | TYP $\ddagger$ | max | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.8 | V |
| $\mathrm{V}_{1 \mathrm{~K}}$ | Input clamp voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ | 2.4 | 2.9 |  | v |
| $\mathrm{V}_{\text {OL }}$ | Low-level output voltage |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{IOL}_{\mathrm{OL}}=\mathrm{MAX} \end{aligned}$ |  | 0.35 | 0.50 | v |
| 'OZH | Off-state output current, high-level voltage applied |  | $\begin{aligned} & V_{C C}=\mathrm{MAX}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 \mathrm{~V}, \\ & V_{\mathrm{O}}=2.4 \mathrm{~V} \end{aligned}$ |  |  | 50 | $\mu \mathrm{A}$ |
| 'OZL | Off-state output current, low-level voltage applied |  | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}}=\mathrm{MAX}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V} \end{aligned}$ |  |  | -50 | $\mu \mathrm{A}$ |
| $1 /$ | Input current at maximum input voltage |  | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 | mA |
| $\mathrm{IIH}^{\text {H }}$ | High-level input current | Data In | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 40 | $\mu \mathrm{A}$ |
|  |  | All Inputs Except Data In |  |  |  |  | 25 |  |
| IIL | Low-level input current | Data In | $v_{C C}=M A X$, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  | -1 | mA |
|  |  | All Inputs Except Data In |  |  |  |  | -250 | $\mu \mathrm{A}$ |
| los | Short-circuit output current § |  | $\mathrm{V}_{C C}=$ MAX |  | -30 |  | -100 | mA |
| ICC | Supply Current |  | $V_{C C}=$ MAX, | See Note 3 |  | 80 | 120 | mA |

[^13]switching characteristics over recommended operating ranges of TA and $^{\text {VCC }}$ (unless otherwise noted)

| PARAMETERS $\uparrow$ | FROM | TO | TEST CONDITIONS | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $f_{\text {max }}$ | CK A |  | $\begin{gathered} C_{L}=30 \mathrm{pF} \\ R_{L}=300 \Omega \\ \text { See Note } 4 \end{gathered}$ | 10 | 20 |  | MHz |
| $f_{\text {max }}$ | CK B |  |  | 10 | 20 |  | MHz |
| $f_{\text {max }}$ | CK IN |  |  | 10 | 20 |  | MHz |
| $t_{w}$ | CK OUT |  |  | 7 | 14 |  | ns |
| tPXZ | $\overline{O E}$ | DOi | $C_{L}=5 \mathrm{pF}$ |  | 10 | 25 | ns |
| tPZX |  |  | $\begin{gathered} C_{L}=30 \mathrm{pF} \\ \mathrm{R}_{\mathrm{L}}=300 \Omega, \\ \text { See Note } 4 \end{gathered}$ |  | 10 | 25 |  |
| tPLH | CK IN | DOi |  |  | 50 | 75 | ns |
| tPHL |  |  |  |  | 50 | 75 |  |
| tPLH | $\begin{gathered} \text { CK A } \\ \text { or } \\ \text { CK B } \\ \hline \end{gathered}$ | OR |  |  | 190 | 300 | ns |
| tPLH | CK IN | OR |  |  | 40 | 60 |  |
| tPHL |  |  |  |  | 30 | 45 | ns |
| tPHL | $\overline{\text { CLR }}$ | OR |  |  | 35 | 60 | ns |
| tPHL | $\begin{gathered} \text { CK A } \\ \text { or } \\ \text { CK B } \end{gathered}$ | CK OUT |  |  | 25 | 50 | ns |
| tPHL | CK IN | CK OUT |  |  | 270 | 400 | ns |
| tPHL | CK A or CK B | IR |  |  | 55 | 75 | ns |
| tPLH | CK IN | IR |  |  | 255 | 400 | ns |
| tPLH | $\overline{\mathrm{CLR}}$ | IR |  |  | 16 | 35 | ns |
| tPLH | OR $\uparrow$ | DOi |  |  | 10 | 20 | ns |
| tPHL | OR $\downarrow$ |  |  |  | 10 | 20 |  |

If $f_{\text {max }} \equiv$ maximum clock frequency.
$\mathrm{t}_{\mathbf{w}} \equiv$ pulse width (output)
$\uparrow \downarrow \equiv$ The arrow indicates that the low-to-high ( $\uparrow$ ) or high-to-low ( $\downarrow$ ) transition of the output ready (OR) output is used for reference.
$t_{\text {PLH }} \equiv$ propagation delay time, low-to-high level output.
tPHL $\equiv$ propagation delay time, high-to-low-level output.
$\ddagger$ 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 Appendix $A$.

TYPICAL WAVEFORMS


EXPANDING THE S225 FIFO
( 48 WORDS OF 10 BITS SHOWN )


## APPENDIX A



NOTES: A. When measuring access times from address inputs, the enable/select input (s) is (are) low and the read/write input is high.
B. Waveform shown is for the output with internal conditions such that the output is low except when disabled.
C. When measureing access and disable times from enable/select input (s), the address inputs are steady-state and the read/write input is high.
D. Input waveforms are supplled by pulse generators having the following characteristics
and $Z_{\text {out }} \approx 50 \Omega$.
TESTING RAM's WITH 3-STATE OUTPUTS


LOAD CIRCUIT


ACCESS TIME FROM ADDRESS INPUTS VOLTAGE WAVEFORMS


WRITE CYCLE VOLTAGE WAVEFORMS


ACCESS (ENABLE) TIME AND DISABLE TIME FROM CHIP ENABLE VOLTAGE WAVEFORMS

NOTES: A. When measuring access times from address inputs, the enable/select input (s) is (are) low and the read/write input is high.
B. Waveform shown is for the output with internal conditions such that the output is low except when disabled.
C. When measureing access and disable times from enable/select input ( $s$ ), the address inputs are steady-state and the read/write input is high.
D. Input waveforms are supplied by pulse generators having the following characteristics

TESTING RAM's WITH OPEN-COLLECTOR OUTPUTS

The Engineering Staff of
TEXAS INSTRUMENTS INCORPORATED
Semiconductor Group


DECEMBER 1976
REVISED DECEMBER 1977

## Texas Instruments <br> INCORPORATED

INDEX TO
BIPOLAR MICROCOMPUTER SUPPORT FUNCTIONS

| TYPE NUMBER (PACKAGES) |  | FUNCTION | $\begin{aligned} & \text { SEE } \\ & \text { PAGE } \end{aligned}$ |
| :---: | :---: | :---: | :---: |
| $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  |
| SN54S226(J) | SN74S226(J,N) | 4-BIT PARALLEL LATCHED BUS TRANSCEIVERS | 1 |
| SN54S240(J) | SN74S240(J,N) | OCTAL INVERTING BUS BUFFER DRIVERS/RECEIVERS |  |
| SN54S241(J) | SN74S241(J,N) | OCTAL BUS BUFFER DRIVER/RECEIVERS |  |
| SN54S299(J) | SN74S299(J,N) | OCTAL UNIVERSAL SHIFT/STORAGE REGISTERS | 9 |
| SN54S330(J) | SN74S330(J,N) | 12-INPUT, 50-TERM, 6-OUTPUT FIELD- |  |
| SN54S331 (J) | SN74S331(J,N) | PROGRAMMABLE LOGIC ARRAYS (FPLA) |  |
| SN54S373(J) | SN74S373(J,N) | OCTAL D-TYPE TRANSPARENT LATCHES |  |
| SN54S374(J) | SN74S374(J,N) | OCTAL D-TYPE FLIP-FLOPS |  |
| SN54S412(J) | SN74S412(J,N) | OCTAL MULTIMODE BUFFERED LATCHES | 30 |
|  | SN74S428(N) | CONTROLLERS AND BUS DRIVERS | 35 |
|  | SN74S438(N) | FOR 8080A SYSTEMS | 35 |
| SN54S482(J) | SN74S482(J,N) | 4-BIT-SLICE EXPANDABLE CONTROL ELEMENTS | 41 |

- Universal Transceivers for Implementing System Bus Controllers
- Dual-Rank 4-Bit Transparent Latches Provide
- Exchange of Data Between 2 Buses In One Clock Pulse
- Bus-to-Bus Isolation
- Rapid Data Transfer
- Full Storage Capability
- Hysteresis at Data Inputs Enhances Noise Rejection
- Separate Output Control Inputs Provide Independent Enable/Disable for Either Bus Output
- 3-State Outputs Drive Bus Lines Directly


## description

These high-performance Schottky TTL quadruple bus transceivers employ dual-rank bidirectional four-bit transparent latches and feature three-state outputs designed specifically for driving highly-capacitive or relatively low-impedance loads. The bus-management functions implemented and the high-impedance controls offered provide the designer with a controller/ transceiver that interfaces and drives system busorganized lines directly. They are particularly attractive for implementing:

Bidirectional bus transceivers<br>Data-bus controllers

The bus-management functions, under control of the function-select (S1,S2) inputs, provide complete data integrity for each of the four modes described in the function table. Directional transparency provides for routing data from or to either bus, and the dual store and dual readout capabilities can be used to perform the exchange of data between the two bus lines in the equivalent of a single clock pulse. Storage of data is accomplished by selecting the latch function, setting up the data, and taking the appropriate strobe input low. As long as the strobe is held low, the data is latched for the selected function. Further control is offered through the availability of independent output controls that can be used to enable or

SN54S226 . . . J PACKAGE
SN74S226 . . . J OR N PACK AGE

functional block diagram


BUS-MANAGEMENT FUNCTION TABLE

| OPERATION | S2 | S1 | LATCH FUNCTIONS |
| :--- | :---: | :---: | :--- |
| DRIVE BUS A | L | L | Pass Bus B Data to Bus A |
| DRIVE BUS B | H | L | Pass Bus A Data to Bus B |
| EXCHANGE | H | H | Store Bus A and Bus B Data |
| BUS A AND B | L | H | Readout Stored Data |

OUTPUT-CONTROL FUNCTION TABLE

| OCAB | OCBA | OUTPUT FUNCTION |
| :---: | :---: | :--- |
| L | X | Disable Bus B Outputs (Hi-Z) |
| H | X | Enable Bus B Outputs |
| X | L | Disable Bus A Outputs (Hi-Z) |
| X | H | Enable Bus A Outputs |

disable the outputs as shown in the output-control function table, regardless of the latch function in process. Store operations can be performed with the outputs disabled to a high impedance ( $\mathrm{Hi}-\mathrm{Z}$ ). In the $\mathrm{Hi}-\mathrm{Z}$ state the inputs/outputs neither load nor drive the bus lines significantly. The p-n-p inputs feature typically 400 millivolts of hysteresis to enhance noise rejection.
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)


NOTES: 1. Voltage values are with respect to network ground terminal.
2. An SN54S226 in the J package operating at temperatures above $113^{\circ} \mathrm{C}$ requires a heat-sink that provides a thermal resistance from case to free air, $R_{\theta C A}$, of not more than $48^{\circ} \mathrm{C} / \mathrm{W}$.

## TYPES SN54S226, SN74S226 <br> 4-BIT PARALLEL LATCHED BUS TRANSCEIVERS

## recommended operating conditions

|  |  |  | N54S22 |  |  | N74S226 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX | UNIT |
| Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| High-level output voltage, $\mathrm{V}_{\mathrm{OH}}$ |  |  |  | 5.5 |  |  | 5.5 | V |
| High-level output current, ${ }^{1} \mathrm{OH}$ |  |  |  | -6.5 |  |  | -10.3 | mA |
| Data setup time, $\mathrm{t}_{\text {su }}$ | Data (A or B) | 0 $\downarrow$ |  |  | $0 \downarrow$ |  |  | ns |
|  | Select | 0 $\downarrow$ |  |  | O $\downarrow$ |  |  |  |
| Data hold time, th | Data (A or B) | $30 \downarrow$ |  |  | 30 $\downarrow$ |  |  | ns |
|  | Select | $30 \downarrow$ |  |  | 30 $\downarrow$ |  |  |  |
| Operating free-air temperature, $\mathrm{TA}_{\mathbf{A}}$ (see Note 2) |  | -55 | 125 |  | 0 | 70 |  | ${ }^{\circ} \mathrm{C}$ |

$\downarrow$ The arrow indicates that the high-to-low transition of the enable input is used for reference.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\text {t }}$ |  | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.8 | V |
| VIK | Input clamp voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \quad \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | SN54S226 | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, & \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{array}$ | SN54S226 | 2.4 | 3.3 |  | V |
|  |  | SN74S226 |  | SN74S226 | 2.4 | 2.9 |  |  |
| VOL | Low-level output voltage |  | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, & \mathrm{~V}_{I \mathrm{H}}=2 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA} \end{array}$ |  |  |  | 0.5 | V |
| IOZH | Off-state output current, high-level voltage applied |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{O}}=2.4 \mathrm{~V} \end{aligned}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| IOZL | Off-state output current, low-level voltage applied |  | $\begin{aligned} & V_{C C}=M A X, \quad V_{I H}=2 V, \\ & V_{O}=0.5 \mathrm{~V} \end{aligned}$ |  |  |  | -100 | $\mu \mathrm{A}$ |
| $1 /$ | Input current at maximum input voltage |  | $V_{C C}=M A X, V_{1}=5.5 \mathrm{~V}$ |  |  |  | 1 | mA |
| IIH | High-level input current |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| IIL | Low-level input current |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  |  | -380 | $\mu \mathrm{A}$ |
| IOS | Short-circuit output current § |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$ |  | $-50$ |  | -180 | mA |
| ICC | Supply current |  | $\mathrm{V}_{\text {CC }}=$ MAX, See Note 3 |  |  | 125 | 185 | mA |

${ }^{\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}$.
§Not more than one output should be shorted at a time and duration of the short-circuit should not exceed one second.
NOTES: 2. An SN54S226 in the J package operating at temperatures above $113^{\circ} \mathrm{C}$ requires a heat-sink that provides a thermal resistance from case to free air, $\mathrm{R}_{\theta \mathrm{CA}}$, of not more than $48^{\circ} \mathrm{C} / \mathrm{W}$.
3. ' CC is measured with all inputs (and outputs) grounded.

## TYPES SN54S226, SN74S226 <br> 4-BIT PARALLEL LATCHED BUS TRANSCEIVERS

REVISED AUGUST 1977
switching characteristics, $V_{C C}=5 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS |  | MIN TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | A or B | B or A | $C_{L}=50 \mathrm{pF}$, | $R_{L}=280 \Omega$, | 20 | 30 | ns |
| tPHL |  |  |  |  | 15 | 30 | ns |
| tPLH | Select | Any |  |  | 25 | 37 | ns |
| tPHL |  |  |  |  | 19 | 30 |  |
| tPLH | Strobe GBA or GAB | A or B |  |  | 25 | 37 | ns |
| tPHL |  |  |  |  | 19 | 30 |  |
| tPZH | Output Control OCBA or OCAB | $A$ or B |  |  | 12 | 20 | ns |
| tPZL |  |  |  |  | 12 | 20 |  |
| tPHZ | Output Control OCBA or OCAB | A or B | $C_{L}=5 \mathrm{pF}$, | $R_{L}=280 \Omega$, | 10 | 15 | ns |
| tPLZ |  |  |  |  | 10 | 15 |  |

$t_{\text {PLH }} \equiv$ propagation delay time, low-to-high-level output
$\mathbf{t P H L} \equiv$ propagation delay time, low-to-high-level output
${ }^{\mathbf{t}} \mathbf{Z H} \equiv$ output enable time to high level
${ }^{\text {t }}$ LL $~ \equiv$ output enable time to low level
$t_{H Z} \equiv$ output disable time from high level
$t_{L Z} \equiv$ output disable time from low level

## applications

The following examples demonstrate four fundamental bus-management functions that can be performed with the 'S226. Exchange of data on the two bus lines can be accomplished with a single high-to-low transition at S2 when S1 is high.


## features:

- High-Performance Schottky TTL Line Drivers and/or Receivers in a High-Density 20-Pin Package
- 3-State Outputs Drive Bus Lines Directly
- P-N-P Inputs Reduce D-C Loading on Bus Lines
- Hysteresis at Inputs Improve Noise Margins
- 'S241 Can Be Interconnected With No External Components to Perform as Bi-directional Bus Transceiver
typical characteristics:
- Fan-Out: $I_{\text {OL }}$ (Sink Current) $\quad \frac{64 \mathrm{~mA}}{48 \mathrm{~mA}}$ $I_{\mathrm{OH}}$ (Source Current) - $15 \mathrm{~mA}-12 \mathrm{~mA}$
- Typical Propagation Delay Times:

Data-to-Output:
‘S240 (Inverting) . . . 4.5 ns
'S241 (Noninverting) . . . 6 ns

- Enable-to-Output . . . 9 ns


## description

These buffers/line drivers are designed specifically to improve both the performance and p-c board density of 3 -state buffers/drivers employed as memory-address drivers, clock drivers, and bus-oriented transmitters/receivers. Featuring 400 millivolts of hysteresis at each low-current p-n-p data-line input, they provide improved noise rejection and high-fan-out outputs to restore Schottky TTL levels completely, or the SN74S' versions can be used to drive terminated lines down to $133 \Omega$.

Typically, the 'S240 can replace the equivalent of six SN54S04, SN74S04 inverters or four SN54S130, SN74S140 line drivers at their rated drive capabilities with the added benefits of input hysteresis and 3-state outputs. The 'S241 offers the same complexity and drive capability but is designed for use in non-inverting applications.

In bus-organized systems, the 'S241 can be connected with no external components to perform as a non-inverting input/output bus transceiver. With complementing enable inputs, the control function can be connected directly to both enable inputs while the two 4 -line data paths can be connected lat adjacent pins) input-to-output on both sides to form the asynchronous transceiver/buffer.
Unused inputs must not be left open, or used inputs must not experience driving impedances of $\geqslant 40 \mathrm{k} \Omega$.

SN54S240 . . . J PACKAGE
SN74S240 . . J OR N PACKAGE
(TOP VIEW)

logic: $\quad 1 Y=1 \bar{A}$ when $1 \bar{G}$ is low $2 \mathrm{Y}=2 \mathrm{~A}$ when $\mathbf{2 G}$ is low
When $1 \overline{\mathrm{G}}$ is high 1 Y outputs are at a high impedance When $\mathbf{2} \bar{G}$ is high 2 Y outputs are at a high impedance

SN54S241...J PACKAGE SN74S241...J OR N PACKAGE (TOP VIEW)

'S241 BUS TRANSCEIVER

BUS 1


BUS 2

CONTROL
L. . . RECEIVE BUS 1 DRIVE BUS 2 H... RECEIVE BUS 2 DRIVE BUS 1 Texas Instruments. U.S. Patent Number 3,463,975.

## TYPES SN54S240, SN54S241, SN74S240, SN74S241 OCTAL BUFFERS/LINE DRIVERS/LINE RECEIVERS WITH 3-STATE OUTPUTS

## recommended operating conditions

| PARAMETER | SN54S' |  |  | SN74S' |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ (see Note 1) | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| High-level output current, 1 OH |  |  | -12 |  |  | -15 | mA |
| Low-level output current, IOL |  |  | 48 |  |  | 64 | mA |
| Operating free-air temperature, $\mathrm{T}_{A}$ (see Note 2) | -55 |  | 125 | 0 |  | 70 | C |

NOTES: 1. These voltage values are with respect to network ground terminal.
2. An SN54S241J operating at free-air temperature above $116^{\circ} \mathrm{C}$ requires a heat sink that provides a thermal resistance from case to free-air, $R_{\theta C A}$, of not more than $40^{\circ} \mathrm{C} / \mathrm{W}$.
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | 'S240 |  |  | 'S241 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  |  |  |  |  | 2 |  |  | 2 |  |  | V |
| VIL | Low-level input voltage |  |  |  |  |  | 0.8 |  |  | 0.8 | V |
| VIK | Input clamp voltage |  | $\mathrm{V}_{C C}=\mathrm{MIN}$, | $I_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
|  | Hysteresis ( $\mathrm{V}_{\mathrm{T}_{+}--\mathrm{V}_{\mathrm{T}_{-}} \text {) }}$ |  | $\mathrm{V}_{\mathrm{CC}}=$ MIN |  | 0.2 | 0.4 |  | 0.2 | 0.4 |  |  |
| VOH | High-level output voltage |  | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \\ 1 \mathrm{OH}=-3 \mathrm{~mA} & \\ \hline \end{array}$ |  | 2.4 | 3.4 |  | 2.4 | 3.4 |  | $v$ |
|  |  |  | $\begin{array}{ll} V_{\mathrm{CC}}=\mathrm{MIN}, & V_{\mathrm{IL}}=0.5 \mathrm{~V}, \\ \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{array}$ |  | 2 |  |  | 2 |  |  |  |
| VOL | Low-level output voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \quad \mathrm{IOL}=\mathrm{MAX}$ |  | 0.55 |  |  | 0.55 |  |  | V |
| IOZH | Off-state output current, high-level voltage applied |  | $\begin{aligned} & V_{C C}=M A X \\ & V_{I H}=2 V \\ & V_{I L}=0.8 V \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
| IOZL | Off-state output current, low-level voltage applied |  |  | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -50 |  |  | -50 |  |
| 11 | Input current at maximum input voltage |  | $V_{C C}=$ MAX, $\quad V_{1}=5.5$ |  |  |  | 1 |  |  | 1 | mA |
| 1/H | High-level input current, any input |  | $\mathrm{V}_{C C}=\mathrm{MAX}$, |  |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | Any A |  |  |  |  | -400 |  |  | -400 | $\mu \mathrm{A}$ |
|  |  | Any G | $V_{C C}=M A X$, | $\mathrm{V}_{\mathrm{IL}}=0.5 \mathrm{~V}$ |  |  | -2 |  |  | -2 | mA |
| 10 S | Short-circuit output current \$ |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  | -50 |  | -225 | -50 |  | -225 | mA |
| ${ }^{\text {I C C }}$ | Supply current | Total, | $V_{C C}=M A X$ <br> Outputs open | SN54S' |  | 80 | 123 |  | 95 | 147 | mA |
|  |  | outputs high |  | SN74S' |  | 80 | 135 |  | 95 | 160 |  |
|  |  | Total, |  | SN54S' |  | 100 | 145 |  | 120 | 170 |  |
|  |  | outputs low |  | SN74S' |  | 100 | 150 |  | 120 | 180 |  |
|  |  | Outputs at $\mathrm{Hi}-\mathrm{Z}$ |  | SN54S' |  | 100 | 145 |  | 120 | 170 |  |
|  |  |  |  | SN74S' |  | 100 | 150 |  | 120 | 180 |  |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recammended operating conditions.
$\ddagger$ All typical values are at $V_{C C}=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.
switching characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | TEST CONDITIONS | ${ }^{\text {s }}$ S240 |  |  | 'S241 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| tPLH $\begin{array}{l}\text { Propagation delay time, } \\ \text { low-to-high-level output }\end{array}$ | $C_{L}=50 p F, \quad R_{L}=90 \Omega,$ <br> See Note 3 |  | 4.5 | 7 |  | 6 | 9 | ns |
| tPHL Propagation delay time, <br> high-to-low-level output |  |  | 4.5 | 7 |  | 6 | 9 | ns |
| $\mathrm{t}_{\mathrm{ZL}} \quad$ Output enable time to low level |  |  | 10 | 15 |  | 10 | 15 | ns |
| IZH Output enable time to high level |  |  | 6.5 | 10 |  | 8 | 12 | ns |
| tLZ Output disable time from low level | $C_{L}=5 \mathrm{pF}, \quad \mathrm{R}_{\mathrm{L}}=90$ |  | 10 | 15 |  | 10 | 15 | ns |
| ${ }^{\text {t H }}$ O Output disable time from high level |  |  | 6 | 9 |  | 6 | 9 | ns |


'S241's USED AS REPEATER/LEVEL RESTORER

'S240 USED AS SYSTEM AND/OR MEMORY BUS DRIVER-4-BIT ORGANIZATION CAN BE APPLIED TO HANDLE BINARY OR BCD


INDEPENDENT 4-BIT BUS DRIVERS/RECEIVERS
IN A SINGLE PACKAGE

TEXASINSTRRUMENTS
INCORPORATED
POST OFFICE BOX 5012 - DALLAS. TEXAS 75222

- Multiplexed Inputs/Outputs Provide Improved Bit Density
- Four Modes of Operation:

| Hold (Store) | Shift Left |
| :--- | :--- |
| Shift Right | Load Data |

- Operates with Outputs Enabled or at High Z
- 3-State Outputs Drive Bus Lines Directly
- Can be cascaded for N-Bit Word Lengths
- Applications:

Stacked or Push-Down Registers, Buffer Storage, and
Accumulator Registers

```
SN54S299 . . . J PACKAGE
SN74S299 . . . J OR N PACKAGE (TOP VIEW)
```



## description

These Schottky TTL eight-bit universal registers feature multiplexed inputs/outputs to achieve full eight bit data handling in a single 20 -pin package. Two function-select inputs and two output-control inputs can be used to choose the modes of operation listed in the function table.

Synchronous parallel loading is accomplished by taking both function-select lines, S0 and S1, high. This places the three-state outputs in a high-impedance state, which permits data that is applied on the input/output lines to be clocked into the register. Reading out of the register can be accomplished while the outputs are enabled in any mode. A direct overriding input is provided to clear the register whether the outputs are enabled or off.

FUNCTION TABLE

| MODE | INPUTS |  |  |  |  |  |  |  | INPUTS/OUTPUTS |  |  |  |  |  |  |  | OUTPUTS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | CLEAR | FUNCTION SELECT |  | OUTPUT CONTROL |  | CLOCK | SERIALSL SR |  | $\mathrm{A}^{\prime} \mathrm{O}_{\mathrm{A}}$ | $B / Q_{B}$ | c/OC | D/Q $\mathbf{D}_{\text {D }}$ | $E / Q_{E}$ | $\mathrm{F}^{\prime} \mathrm{O}_{\mathrm{F}}$ | G/0 $\mathbf{Q}_{\mathbf{G}}$ | $\mathbf{H} / \mathbf{Q}_{\mathbf{H}}$ | $\mathbf{Q}_{\mathbf{A}^{\prime}} \mathbf{O}_{\mathbf{H}^{\prime}}$ |
|  |  | S1 | SO | $\overline{\mathrm{G}}{ }^{+}$ | $\overline{\mathbf{G} 2}{ }^{\dagger}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| Clear | L | X | L | L | L | X |  | X | L | L | L | L | L | L | L | L | L |
|  | L | L | H | L | L | X | X | $x$ | L | L | L | L | L | L | L | L | L L |
| Hold | H | L | L | L | L | X | X | X | $\mathrm{Q}_{\text {A0 }}$ | $\mathrm{Q}_{\mathrm{BO}}$ | $\mathrm{Q}_{\mathrm{CO}}$ | $\mathrm{Q}_{\mathrm{D} 0}$ | $\mathrm{Q}_{\text {EO }}$ | $\mathrm{Q}_{\mathrm{FO}}$ | $\mathrm{Q}_{\mathrm{G} 0}$ | $\mathrm{Q}_{\mathrm{HO}}$ | $\mathrm{Q}_{\mathrm{AO}} \mathrm{Q}_{\mathrm{HO}}$ |
|  | H | X | $\times$ | L | L | L | x | x | $Q_{A 0}$ | $\mathrm{Q}_{\mathrm{BO}}$ | $\mathrm{Q}_{\mathrm{CO}}$ | $\mathrm{Q}_{\mathrm{DO}}$ | $\mathrm{Q}_{\text {E0 }}$ | $\mathrm{Q}_{\mathrm{FO}}$ | $\mathrm{Q}_{\mathrm{GO}}$ | $\mathrm{O}_{\mathrm{HO}}$ | $\mathrm{Q}_{\mathrm{AO}} \mathrm{Q}_{\mathrm{HO}}$ |
| Shift Right | H | L | H | L | L | $\uparrow$ | X | H | H | $Q_{\text {An }}$ | $\mathrm{O}_{\mathrm{Bn}}$ | $\mathrm{Q}_{\mathrm{Cn}}$ | $\mathrm{Q}_{\text {Dn }}$ | $\mathrm{Q}_{\mathrm{En}}$ | $\mathrm{O}_{\mathrm{Fn}}$ | $\mathrm{Q}_{\mathrm{Gn}}$ | $\mathrm{H} \mathrm{Q}_{\mathrm{Gn}}$ |
|  | H | L | H | L | L | $\uparrow$ | X | L | L | $\mathrm{O}_{\text {An }}$ | $\mathrm{O}_{\mathrm{Bn}}$ | $\mathrm{Q}_{\mathrm{Cn}}$ | $\mathrm{Q}_{\text {Dn }}$ | $\mathrm{Q}_{\mathrm{En}}$ | $\mathrm{Q}_{\mathrm{Fn}}$ | $\mathrm{Q}_{\mathrm{Gn}}$ | $L \mathrm{Q}_{\mathrm{Gn}}$ |
| Shift Left | H | H | L | L | L | $\uparrow$ | H | X | $\mathrm{O}_{8 n}$ | $\mathrm{O}_{\mathrm{Cn}}$ | Q ${ }_{\text {n }}$ | $\mathrm{Q}_{\mathrm{En}}$ | $\mathrm{Q}_{\mathrm{Fn}}$ | $\mathrm{Q}_{\mathrm{Gn}}$ | $\mathrm{Q}_{\mathrm{Hn}}$ | H | $\mathrm{O}_{\mathrm{Bn}} \mathrm{H}$ |
|  | H | H | L | L | L | $\uparrow$ | L | X | $\mathrm{Q}_{\mathrm{Bn}}$ | $\mathrm{Q}_{\mathrm{Cn}}$ | $\mathrm{Q}_{\text {D }}$ | $Q_{\text {En }}$ | $\mathrm{Q}_{\mathrm{Fn}}$ | $\mathrm{O}_{\mathrm{Gn}}$ | $\mathrm{O}_{\mathrm{Hn}}$ | L | $\mathrm{O}_{\mathrm{Bn}} \mathrm{L}$ |
| Load | H | H | H | X | $\times$ | $\uparrow$ | X | X | a | b | c | d | e | $f$ | g | h | a h |
| tWhen one or both output controls are high the eight input/output terminals are disabled to the high-impedance state; however, sequential operation or clearing of the register is not affected. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

[^14]

## TYPES SN54S299, SN74S299 8-BIT UNIVERSAL SHIFT/STORAGE REGISTERS

schematics of inputs and outputs

| EQUIVALENT OF CLOCK OR |
| :---: | :---: | :---: |
| CLEAR INPUTS |
| AND G2 INPUTS | | EQUIVALENT OF A THRU H ${ }^{\dagger}$, SO, S1, |
| :---: |
| SHIFT RIGHT, AND SHIFT LEFT INPUTS |

TYPICAL OF OUTPUTS
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, V CC (see Note 1)
Input Voltage
Off-state output voltage.

NOTES 1: Voltage values are with respect to network ground terminal.
recommended operating conditions


[^15]electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\text { }}$ |  | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.8 | V |
| VIK | Input clamp voltage |  | $\mathrm{V}_{C C}=\mathrm{MIN}$, | $I_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| $\mathrm{VOH}_{\mathrm{OH}}$ | High-level output voltage | $\mathrm{Q}_{A}$ thru $\mathrm{Q}_{\mathrm{H}}$ | $\begin{aligned} & V_{C C}=\mathrm{MIN}, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{1 H}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ | 2.4 | 3.2 |  | V |
|  |  | $\mathrm{Q}_{\mathrm{A}^{\prime}}$ or $\mathrm{Q}_{H^{\prime}}$ |  |  | 2.7 | 3.4 |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Low-level output voltage |  | $\begin{aligned} & V_{C C}=\mathrm{MIN}, \\ & V_{\mathrm{IL}}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & V_{I H}=2 V \\ & I_{O L}=M A X \end{aligned}$ |  |  | 0.5 | V |
| ${ }^{1} \mathrm{OZH}$ | Off-state output current, high-level voltage applied | $\mathrm{Q}_{\mathrm{A}}$ thru $\mathrm{Q}_{\mathrm{H}}$ | $\begin{aligned} & V_{C C}=M A X, \\ & V_{O}=2.4 V \end{aligned}$ | $\mathrm{V}_{\text {IH }}=2 \mathrm{~V}$, |  |  | 100 | $\mu \mathrm{A}$ |
| IOZL | Off-state output current low-level voltage applied | $\mathrm{Q}_{\mathrm{A}}$ thru $\mathrm{Q}_{\mathrm{H}}$ | $\begin{aligned} & V_{C C}=M A X, \\ & V_{O}=0.5 V \end{aligned}$ | $V_{I H}=2 \mathrm{~V}$ |  |  | -250 | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage |  | $V_{C C}=M A X$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 | mA |
| 11 H | High-level input current | A thru H, S0, S1 | $V_{C C}=M A X$, | $V_{1}=2.7 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
|  |  | Any other |  |  |  |  | 50 |  |
| IIL | Low-level input current | Clock or clear | $V_{C C}=M A X$, | $V_{1}=0.5 \mathrm{~V}$ |  |  | -2 | mA |
|  |  | Any other |  |  |  |  | -250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current § | $\mathrm{Q}_{A}$ thru $\mathrm{A}_{H}$ | $V_{C C}=M A X$ |  | -40 |  | -100 |  |
|  |  | $\mathrm{Q}_{A^{\prime}}$ or $\mathrm{Q}_{H^{\prime}}$ |  |  | -20 |  | -100 | mA |
| ICC | Supply current |  | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  |  | 140 | 225 | mA |

${ }^{\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}_{A}=25^{\circ} \mathrm{C}$.
§Not more than one output should be shorted at a time and duration of the short-circuit test should not exceed one second.
switching characteristics, $\mathrm{V}_{\mathrm{C}}=5 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

$\|_{f_{\text {max }}} \equiv$ maximum clock frequency
$\mathbf{t}_{\text {PLH }} \equiv$ propagation delay time, low-to-high-level output
tPHL $\equiv$ propagation delay time, high-to-low-level output
tPZH $\equiv$ output enable time to high level
t PZL $\equiv$ output enable time to low level
tPHZ $\equiv$ output disable time from high level
tPLZ $\equiv$ output disable time from low level
NOTE 2: For testing $f_{\text {max }}$, all outputs are loaded simultaneously, each with $C_{L}$ and $R_{L}$ as specified for the propagation times.

- Field-Programmable Logic Array

Organized 12-Inputs/50-Product Terms/6-Outputs

- Programmable Options Include:
- Active High or Low Inputs/Outputs
- Choice of Dedicated Enable Input or Automatic Enable by True Product Terms
- Number of Inputs, Outputs, and Product Terms are Expandable
- High Density 20-Pin Package
- Full Schottky Clamping for HighPerformance:
- 30 ns Typical Data Delay Time
- 20 ns Typical Enable Time
- Reliable TI-W Fuse Links for Fast, Low-Voltage Programming
- Choice of 3-State ('S330) or $2.5 \mathrm{k} \Omega$ Passive-Pull-up ('S331) Outputs


## description

These high-performance, Schottky-clamped 12 -input, 6 -output logic arrays can be field programmed to provide 50 product terms derived from the 12 inputs and sum the 50 products onto 6 -output lines. They feature a programmable option which permits the FPLA outputs to be automatically enabled by a true product term or, to dedicate during programming, input ( $L / \overline{O E}$ ) to serve as an output enable $(\overline{O E})$. Either option makes the FPLA expandable with respect to product terms. Other options permit use of both dedicated or automatic enable or no disable.

For every product term, 12 input variables can be programmed as high or low. Logic flexibility is further enhanced by the feature that the six outputs can be programmed individually to be active high or low.

The 'S330 is implemented with bus-driving 3 -state outputs and can be connected directly to similar outputs in a busorganized system. The 'S331 is implemented with a $2.5 \mathrm{k} \Omega$ passive pull-up resistor on each output meaning that:
a. The output can be combined with other similar or open-collector outputs to perform the logical wire-AND or a simple enable/disable function.
b. The 'S331 outputs are also rated at $\mathrm{V}_{\mathrm{OH}}=3.7$ minimum for direct interface with MOS input thresholds.

The TI-W fuse links, used in the ‘S330/‘S331, feature the same low-voltage programming characteristics and proven reliability which Texas Instruments PROM's have demonstrated over a number of years.

[^16]

WHERE:
$F_{i}=F_{0}, F_{1}, F_{2}, F_{3}, F_{4}$, or $F_{5}$
(ABC . . . . L $)_{i}=12$ PROGRAMMABLE INPUTS ( $H=$ TRUE OR L = TRUE) FOR EACH OF 50 PRODUCT TERMS

# TYPES SN74S330, SN74S331 EXPANDABLE 12-INPUT, 50-TERM FIELD-PROGRAMMABLE LOGIC ARRAYS 

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, $\mathrm{V}_{\mathrm{CC}}($ see $\operatorname{Note} 1)$
Input voltage.

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

|  |  | SN74S | 30, SN | 74S331 |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | UNIT |
| Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ |  | 4.75 | 5 | 5.25 | V |
| High-level output current, ${ }^{1} \mathrm{OH}$ | 'S330 (T-S) |  |  | -6.5 | mA |
| High-level output current, OH | 'S331 (2.5 k $\Omega$ Pullup) |  |  | -0.25 | mA |
| Operating free-air temperature, $\mathrm{T}_{\text {A }}$ |  | 0 |  | 70 | C |

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

| PARAMETER |  |  | TEST CONDITIONS ${ }^{+}$ |  | SN74S330, SN74S331 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  |  |  |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.8 | V |
| $V_{\text {IK }}$ | Input clamp voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \quad \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | V |
| VOH | High-level output voltage | 'S330 | $\begin{aligned} & V_{C C}=\mathrm{MIN}, \\ & V_{I H}=2 \mathrm{~V} \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\mathrm{I}^{\mathrm{OH}}=\mathrm{MAX}$ | 2.4 | 3.1 |  | V |
|  |  | 'S331 |  | $\mathrm{I}_{\mathrm{OH}}=\mathrm{MAX}$ | 3.7 | 4.4 |  |  |
| VOL | Low-level output voltage |  | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, & \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & I_{\mathrm{OL}}=12 \mathrm{~mA} \end{array}$ |  |  |  | 0.5 | V |
| 1 OZH | Off-state output current, high-level voltage applied | 'S330 | $\mathrm{V}_{C C}=\mathrm{MAX}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
| Ioff |  | 'S331 |  | $\mathrm{V}_{\mathrm{O}}=\mathrm{V}_{\mathrm{CC}}$ |  |  | 150 |  |
| IOZL | Off-state output current, low-level voltage applied | 'S330 | $V_{C C}=$ MAX , | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -50 | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage |  | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 | mA |
| $\mathrm{IIH}^{\text {H }}$ | High-level input current |  | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
| IIL | Low-level input current |  | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  | -0.25 | mA |
| Ios | Short-circuit output current $\S$ | 'S330 | $\mathrm{V}_{\text {CC }}=$ MAX |  | -30 |  | -100 | mA |
|  |  | 'S331 |  |  | -1.4 |  | -4.4 |  |
| ${ }^{1} \mathrm{Cc}$ | Supply current | 'S331 | $V_{C C}=$ MAX, | See Note 2 |  | 110 | 155 | mA |

${ }^{\top}$ 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}_{A}=25^{\circ} \mathrm{C}$.
$\S$ Not more than one output of the ' S 330 should be shorted at a time.
NOTE 2: I CC is measured with all outputs open and all inputs grounded.
switching characteristics over recommended operating ranges of $T_{A}$ and $V_{C C}$ (unless otherwise noted)

| PARAMETER |  | FROM | TO | TEST CONDITIONS |  | 'S330 |  |  | 'S331 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 'S330 | 'S331 |  |  | 'S330 | 'S331 | MIN | TYP | MAX | MIN | TYP | MAX |  |
| tPLH | tPLH | Any data input | Any output | $C_{L}=30 \mathrm{pF}$ <br> See Figure 2, <br> Section 4, page 13 | $\begin{aligned} & R_{\mathrm{L} 1}=300 \Omega, \\ & \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}, \end{aligned}$ <br> See Figure 1, <br> Section 4, page 13 |  | 35 | 60 |  | 35 | 60 | ns |
| tPHL | tPHL |  |  |  |  |  | 35 | 60 |  | 35 | 60 |  |
| t ZL | tPHL | $\overline{O E}$ | Any output |  |  |  | 20 | 35 |  | 20 | 35 | ns |
| t ZH |  |  |  |  |  |  | 20 | 35 |  |  |  |  |
| thz |  | $A E$ or $\overline{O E}$ | Any output | $C_{L}=5 \mathrm{pF},$ <br> See Figure 2, <br> Section 4, page 13 | $\begin{aligned} & R_{\mathrm{L} 1}=300 \Omega, \\ & \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}, \end{aligned}$ <br> See Figure 1, <br> Section 4, page 13 |  | 15 | 30 |  |  |  | ns |
| ${ }_{\text {t }}^{\text {L }}$ L | tPL.H |  |  |  |  |  | 15 | 30 |  | 15 | 30 | , |
| tZL | tPHL | Any data input (AE) | Any output |  |  |  | 40 | 70 |  |  |  | ns |
| tZH |  |  |  |  |  |  | 40 | 70 |  | 40 | 70 |  |

## programming the FPLA

The 'S330 and 'S331 are fabricated to include reliable low-voltage programmable Ti-W fuse links which have identical fusing characteristics with those used for most of TI's PROM's; however, the AND-OR combinational logic performed by an FPLA requires that sequential programming be employed which establishes the AND term including the data/enable L/ $\overline{O E}$ input before the OR term. Programming the automatic enable feature active and the data/enable
 level of the outputs should be performed last.
recommended conditions for programming

|  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| Supply voitage, $\mathrm{V}_{\text {cc }}$ (see Note 1) | 4.75 | 5 | 5.75 | V |
| Program pulse voltage, $\mathrm{V}_{(\text {pr) }}$ (see Note 1) | 10 | 10.5 | $11^{\dagger}$ | V |
| Program pulse rise time |  | 100 |  | ns |
| Input voltage (see Note 1) | 2.4 |  | 5 | V |
|  | 0 |  | 0.5 |  |
| Voltage applied to output for OR programming, $\mathrm{V}_{\mathrm{O}}(\mathrm{pr})$ (see Figure 4) | 0 | 0.25 | 0.3 | V |
| Duration of programming pulse Y (see Figures 1, 3, 4, and Note 2) | 98 | 100 | $10^{3}$ | $\mu \mathrm{s}$ |
| Programming duty cycle |  | 25 | 35 | \% |
| Free-air temperature | 0 |  | 55 | ${ }^{\circ} \mathrm{C}$ |

${ }^{\dagger}$ Absolute maximum ratings.
NOTES: 1. Voltage values are with respect to the GND terminal.
2. Programming is guaranteed if the pulse applied is $98 \mu \mathrm{~s}$ in duration.
table I - ADDresses for programming enables and output levels

| ADDRESS APPLIED TO OUTPUTS |  |  |  |  |  | PRODUCT TERM ADDRESSED | PROGRAMS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{F}_{5}$ | $\mathrm{F}_{4}$ | $F_{3}$ | $\mathrm{F}_{2}$ | $\mathrm{F}_{1}$ | $\mathrm{F}_{0}$ |  |  |
| H | H | L | L | H | L | 502 | Output $\mathrm{F}_{5}$ true low |
| H | H | L | L | H | H | $51_{2}$ | Output $F_{4}$ true low |
| H | H | L | H | L | L | 522 | Output $\mathrm{F}_{3}$ true low PROGRAM |
| H | H | L | H | L | H | 532 | Output $F_{2}$ true low $\}$ LAST |
| H | H | L | H | H | L | 542 | Output $F_{1}$ true low |
| H | H | L | H | H | H | $55_{2}$ | Output $F_{0}$ true low |
| H | H | H | L | L | L | 562 | $L / \overline{O E}=L$ input |
| H | H | H | L | L | H | 572 | Automatic output enable active |

TABLE II - OUTPUT ENABLE OPTIONS

| TERM FUSED | PROGRAMS |
| :--- | :--- |
| Neither $56_{2}$ nor $57_{2}$ | " $\mathrm{L} / \overline{\mathrm{OE} "}$ as " $\overline{\mathrm{OE} " \text { " (L Must be Programmed "don't care") }}$ |
| $56_{2}$ (See Note 3) | Outputs to be Continously Enabled (L/ $\overline{\mathrm{OE}}$ as L input) |
| $57_{2}$ | $\mathrm{L} / \overline{\mathrm{OE}}$ as $\overline{\mathrm{OE}}$ and Automatic Enable (AE) Active ( $\mathrm{F}_{\mathrm{i}}=\overline{\mathrm{OE}} \bullet \mathrm{AE}$, <br> Where: $\mathrm{AE}=$ True Product Term Addressed) |
| $56_{2}$ and $57_{2}$ (See Note 3) | Automatic Enable (AE) Active ( $\mathrm{F}_{\mathrm{i}}=\mathrm{AE}$ ) |

NOTE 3: If the L/ $\overline{O E}$ input is not used as an enabie input, programming the fuse at address $56_{2}$ will cause the outputs to be continously enabled. This function can be used to simplify verification during programming even if address $57_{2}$ is fused subsequently to activate the automatic enable.

# TYPES SN74S330, SN74S331 <br> EXPANDABLE 12-INPUT, 50-TERM <br> FIELD-PROGRAMMABLE LOGIC ARRAYS 

## programming the automatic enable (AE) to be active

The 'S330 and 'S331 are supplied with a fuse link disabling the automatic enable circuit. When a true product term is not present at the inputs this circuit is designed to automatically disable the six outputs [high-impedance (Z) for 'S330, high (H) for 'S331]. Fusing one link (See Table I) activates the automatic enabling circuit resulting in the six outputs being enabled for any true input term.

The fuse is programmed by addressing term 572 and fusing in accordance with the step-by-step procedure. See Table II above for options available.

## programming the $L / \overline{O E}$ input

The $\mathrm{L} / \overline{\mathrm{OE}}$ input must be programmed either to function as a dedicated enable or to function as the 12 th data input.
If it is to become the 12th data input a single fuse, at term 562 (see Table 1), should be programmed in accordance with steps 1 through 5 below; then, input $L$ is programmed logically into each AND/AND product term.
If input $L / \overline{O E}$ is to function as an output enable, term 562 is not fused: however, both AND/ $\overline{A N D}$ fuse links at each of the 50 product term addresses must be fused as outlined in the step-by-step procedures for the AND matrix creating a "don't care" for input L. This causes the input to become an overriding output disable for the package. See Table II for other output enable options.

## step-by-step programming procedure for enable options and output polarity

1. Apply steady-state supply voltage ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ ) and disable the outputs by applying 10.5 volts to the 12 data inputs. See Figure 1.
2. For output polarity, verify that the fuse link needs to be programmed. If not, proceed to the next term.
3. Only one fuse link is programmed at a time. Address the term to be programmed by applying $\mathrm{V}_{\text {IH }}$ and $\mathrm{V}_{\text {IL }}$ to the outputs in accordance with Table 1 and recommended conditions for programming.
4. Step $V_{C C}$ to 10.5 V nominal. Maximum supply current required during programming is 750 mA .
5. After the Y pulse time is reached, $\mathrm{V}_{\mathrm{CC}}$ should be stepped down to 5 V .
6. The data inputs may be taken to logic levels (to permit output polarity verification) $1 \mu \mathrm{~s}$ or more after $V_{\mathrm{CC}}$ reaches its steady-state value of 5 V .
7. At a $Y$ pulse duty cycle of $35 \%$ or less, repeat steps 1 through 6 for each function to be programmed.

NOTE 4: VCC should be removed between program-pulses to reduce dissipation and chip temperatures. See Figure 1.

programming the true/false logic level of the outputs
The FPLA is supplied with internal conditions established such that when a programmed AND or $\overline{\text { AND }}$ input term is true the associated function output ( $\mathrm{F}_{\mathrm{i}}$ ) will be at a high logic level voltage, V OH .

After programming the enables, product terms, and OR matrix, the outputs can be programmed to provide a low logic level voltage (VOL) output. This is accomplished by using AND/ $\overline{\text { AND }}$ terms 50 through 55 shown in Table I and fusing the desired outputs using the step-by-step procedure.

Programming can be verified by applying $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and the input conditions which correspond to each term programmed to result in an active low-level output, measuring $\mathrm{V}_{\mathrm{OL}} \leqslant 0.5 \mathrm{~V}$ at the programmed outputs.

## programming the AND/ $\overline{\text { AND }}$ product terms

Each of the 50 product terms are capable of being programmed to decode a 12 -wide term consisting of any combination of active (true) high, active (true) low, or don't care (H or L) input conditions at each of the 12 lines. This capability is implemented by providing AND/ $\overline{\text { AND }}$ decode input gates each having a pair of associated fusible links which can be programmed to inactivate the unused decode level. Both decode levels can be removed resulting in a "don't care" input. The equivalent logic diagram showing the fusible links is shown in Figure 2.


FIGURE 2 - EQUIVALENT LOGIC DIAGRAM OF FPLA PRODUCT TERMS

## TYPES SN74S330, SN74S331 <br> EXPANDABLE 12-INPUT, 50-TERM <br> FIELD-PROGRAMMABLE LOGIC ARRAYS

A particular pattern is assumed to have been programmed into the AND/ $\overline{\text { AND }}$ fuse matrix with fused links opened at the locations marked with an " $X$ ". The resultant product terms are enumerated for the outputs of each product-term AND gate.

Product terms programmed into the AND/ $\overline{\text { AND }}$ matrix will be used to select the term for programming the OR (summing) matrix. Redundant product terms will select two sum terms in the OR matrix, and overlapping product terms'may select two or more sum terms. Reliable programming can be accomplished if redundant product terms are avoided and overlapping product terms are made unique within the FPLA for programming.

Redundant product terms are defined as being absolutely equal; i.e., $A B C D E F G \equiv A B C D E F G$. Use of apparently redundant terms is possible if the term does not use all inputs as the remaining inputs can be utilized to create FPLA unique terms for programming purposes by expansion:

Example:

## $A \bar{B} C D \bar{E} F G H \neq A \bar{B} C D E \bar{E} F \bar{H}$

After programming the entire OR matrix, the product terms can be readdressed and expanded inputs can be programmed "don't care".

Overlapping terms are defined as two or more product terms in which the lesser product term can be addressed as a result of the application of a larger product term.

Examples:


The small terms can be made FPLA unique for programming by simply expanding to non-redundant inputs.


After programming the entire OR matrix, the product terms can be shortened by readdressing the expanded terms and programming the added inputs to a "don't care". The AND/ $\widehat{A N D}$ matrix is programmed one fuse at a time by addressing the term in accordance with Table III and fusing the input while applying the logic level desired to be active. See Figure 3.

TABLE III - ADDRESSES FOR PROGRAMMING PRODUCT TERMS

| ADDRESS APPLIED TO OUTPUTS |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{F}_{5}$ | $\mathrm{F}_{4}$ | F3 | $\mathrm{F}_{2}$ | $F_{1}$ | $F_{0}$ |  |
| L | L | L | L | L | L | 0 |
| L | L | L | L | L | H | 1 |
| L | L | L | L | H | L | 2 |
| L | L | L | L. | H | H | 3 |
|  |  |  |  |  |  |  |
| H | H | L | L | L | $\llcorner$ | 48 |
| H | H | L | L | L | H | 49 |

step-by-step programming procedure for AND matrix
Programming efficiency may be enhanced by programming the OR matrix upon completion of the 12 -wide AND/AND term associated with it; or, the entire AND/AND term matrix can be programmed for all 50 product terms before programming the summing matrix.

1. Apply steady-state supply ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ ) and disable the outputs by applying 10.5 volts to the 11 data inputs not being programmed. See Figure 3.
2. Only one fuse link is programmed at a time. Address the term to be programmed by applying $\mathrm{V}_{\text {IH }}$ and $\mathrm{V}_{\text {IL }}$ to the outputs in accordance with Table II.
3. Apply the logic level to be true at the input to be programmed.
4. Step $V_{C C}$ to 10.5 V nominal. Maximum supply current required during programming is 750 mA .
5. After the $Y$ pulse time is reached, $\mathrm{V}_{\mathrm{CC}}$ should be stepped down to 5 V . See notes 6 and 7 .
6. The data inputs may be taken to logic levels (to permit product term verification) $1 \mu \mathrm{~s}$ or more after $\mathrm{V}_{\mathrm{CC}}$ reaches its steady-state value of 5 V .
7. At a $Y$ pulse duty cycle of $35 \%$ or less, repeat steps 1 through 6 for each input to be programmed.

NOTES: 5. $V_{C C}$ should be removed between program pulses to reduce dissipation and chip temperatures. See Figure 3.
6. If the input just programmed is to be a "don't care" and is not being used to expand the product term repeat steps 3 and 4 with the opposite logic level applied to the input. Before changing the product term address, program all inputs (A through L/OE for this product term including all "don't cares".
7. If input $L / \overline{O E}$ is to be used as a dedicated package enable it must be programmed as a "don't care" by fusing both links at each of the 50 product term locations.


## step-by-step programming procedure for OR matrix

Programming the OR matrix consists of fusing (one at a time) those outputs ( $F_{0}$ through $F_{5}$ ) which are desired to be false in the addressed product term. The procedure is:

1. Apply steady-state supply voltage $\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}\right)$ and apply the unique product term. See Figure 4.
2. Verify that the fuse link needs to be programmed. If not, proceed to the next fuse link.
3. Only one fuse link is programmed at a time. Enable the output to be programmed by applying $\mathrm{V}_{\mathrm{O}}(\mathrm{pr})$ to the first output to be false in the product term.
4. Step $V_{C C}$ to 10.5 V nominal. Maximum supply current required during programming is 750 mA .
5. After the $Y$ pulse time is reached, $V_{C C}$ should be stepped down to 5 V .
6. Verification can occur $1 \mu \mathrm{~s}$ or more after $\mathrm{V}_{\mathrm{CC}}$ reaches its steady-state value of 5 V .
7. At a $Y$ pulse duty cycle of $35 \%$ or less repeat steps 1 through 6 for each output to be programmed false for the active product term. Repeat for all product terms. Then program active-low outputs.

NOTES: 8. VCC should be removed between program pulses to reduce dissipation and chip temperatures. See Figure 1.
9. If product terms were expanded to make them unique for programming purposes the product terms can be addressed and the added inputs can be removed by programming them to a "don't care" (fuse the remaining links).


OUTPUT TO BE
PROGRAMMED


FIGURE 4 - OR TERM PROGRAMMING SEQUENCE

## TYPES , SN74S330, SN74S331

12-INPUT/6-OUTPUT EXPANDABLE FIELD-PROGRAMMABLE LOGIC ARRAYS


EXPAND
NUMBER OF INPUTS


OVERLAP INPUTS N:N AND OUTPUTS 1:1

- OVERLAP INPUTS BY N-BITS
- code output enables to enable FPLA "A" OR "B" AS APPROPRIATE.

EXPAND NUMBER OF OUTPUTS


OVERLAP INPUTS N:N

- USE OUTPUTS INDEPENDANTLY.
- CODE OUTPUTS ENABLED FOR BOTH FPLA " $A$ " AND " $B$ ".


# TYPES SN74S330, SN74S331 <br> EXPANDABLE 12-INPUT, 50-TERM <br> FIELD-PROGRAMMABLE LOGIC ARRAYS 

## APPLICATIONS

The FPLA is efficiently suited for generating the sum of product terms which are normally required to implement:

- Memory mapping/supplemental functions
- Random logic or function generators
- Sequential controllers
- Status decoders or result interpreters
- Priority encoders

In addition, the FPLA introduces an alternative approach to the implementation of some code converters, pattern generators, and look-up tables which have commonly utilized PROMs and/or ROMs.

## MEMORY CONTROL/SUPPLEMENTAL FUNCTIONS

The FPLA is ideally suited for implementing a wide variety of functions with respect to the control and/or supplementing of system memory capabilities. Some are:

- Memory mapping
- Microprogram control
- Memory patch
- PROM extension

The wide input capability of the 'S330/'S331 FPLA makes it ideal for decoding either a current memory address or a variety of status lines and generate a unique system control function.

## MEMORY MAPPING/MICROPROGRAM CONTROL (See Figure 6)

These similar control functions utilize FPLAs which decode the assigned (mapped) addresses to accomplish system memory management; and/or, the FPLAs decode the current system address/status and implement the hardwired jump, branch-to-subroutine, or starting address in the microprogram control memory.


FIGURE 6 - MEMORY MAPPING/MICROPROGRAM CONTROL

ORDERING INSTRUCTIONS (SHEET 1 OF 2)


ORDERING INSTRUCTIONS (SHEET 2 OF 2)

| PROD TERM NO. | PRODUCT TERM INPUT VOLTAGE LEVELS |  |  |  |  |  |  |  |  |  |  |  | SUMMING DATA |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | A | B | C | D | E | F | G | H | 1 | J | K | L/OE | FO | F1 | F2 | F3 | F4 | F5 |
|  | ${ }_{1}^{\text {PIN }}$ | $\underset{2}{\text { PIN }}$ | ${ }_{3}$ | ${ }_{4}^{\text {PIN }}$ | ${ }_{5}$ | ${ }_{6}^{\text {PIN }}$ | ${ }_{7}{ }^{\text {PIN }}$ | ${ }_{16}$ | ${ }_{17}$ | P18 | ${ }_{19}$ | PIN | 8 | PIN | ${ }_{11}$ | ${ }_{12}$ | ${ }_{13}$ | PIN |
| 15 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 17 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 18 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 19 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 20 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 22 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 23 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 24 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 25 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 26 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 27 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 28 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 29 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 31 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 32 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 33 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 34 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 35 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 36 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 37 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 38 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 39 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 40 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 41 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 42 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 43 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 44 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 45 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 46 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 47 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 48 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 49 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

- Choice of 8 Latches or 8 D-Type Flip-Flops In a Single Package
- 3-State Bus-Driving Outputs
- Full Parallel-Access for Loading and Reloading
- Buffered Control Inputs
- Clock/Enable Input has Hysteresis to Improve Noise Rejection
- P-N-P Inputs Reduce D-C Loading on Data Lines
- Operates with outputs Enabled or at High Z

SN74S373

| OUTPUT <br> CONTROL | ENABLE <br> G | D | OUTPUT |
| :---: | :---: | :---: | :---: |
| L | $H$ | $H$ | $H$ |
| L | $H$ | L | L |
| L | L | X | $\mathrm{Q}_{0}$ |
| H | X | X | $\mathrm{Hi}-\mathrm{Z}$ |

SN74S374

| OUTPUT <br> CONTROL | CLOCK | D | OUTPUT |
| :---: | :---: | :---: | :---: |
| L | $\uparrow$ | $H$ | $H$ |
| $L$ | $\uparrow$ | L | L |
| L | L | X | $\mathrm{Q}_{0}$ |
| H | X | X | $\mathrm{Hi}-\mathrm{Z}$ |

$\mathrm{Q}_{\mathrm{O}} \equiv$ the level of Q before the indicated stead-state input conditions were established.
$H \equiv$ high level
$L \equiv$ low level
$\mathrm{Hi}-\mathrm{Z} \equiv$ high impedance
$X \equiv$ irrelevant
$\uparrow \equiv$ transition from low to high level

SN54S373 . . J JPACKAGE SN74S373 . . J OR N PACKAGE (TOP VIEW)

logic: see function table

SN54S374 . . J PACKAGE SN74S374 . . J OR N PACKAGE (TOP VIEW)

description

These 8-bit registers feature totem-pole 3 -state outputs designed specifically for driving highly-capacitive or relatively low-impedance loads. The high-impedance third state and increased high-logic-level drive provide these registers with the capability of being connected directly to and driving the bus lines in a bus-organized system without need for interface or pull-up components. They are particularly attractive for implementing:

Buffer Registers
I/O Ports
Bidirectional Bus Drivers
Working Registers.
The SN54S373 and SN74S373 are transparent D-type latches meaning that while the enable (G) is high the Q output will follow the data (D) input. When the enable is taken low the output will be latched at the data that was setup.

[^17] clamped transistor is patented by Texas Instruments. U.S. Patent Number 3,463,975.

## description (continued)

The SN54S374 and SN74S374 are edge-triggered D-type flip-flops. On the positive transition of the clock the Q output will be set to the logic state that was setup at the $D$ input.

Schmitt-trigger buffered inputs at the enable ('S373) and clock ('S374) lines simplifies system design as a-c and d-c noise rejection is improved by typically 400 mV due to the input hysteresis. A buffered output control input can be used to place the eight outputs in either a normal logic state (high or low logic levels) or a high-impedance state (Hi-Z). In the Hi-Z state the outputs neither load nor drive the bus line significantly.

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



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

## recommended operating conditions

|  |  | SN54S373, SN54S374 |  |  | SN74S373, SN74S374 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| High-level output voltage, $\mathrm{V}_{\mathrm{OH}}$ |  |  |  | 5.5 |  |  | 5.5 | V |
| High-level output current, I OH |  |  |  | 2 |  |  | 6.5 | mA |
| Width of clock/enable pulse, ${ }_{\text {w }}$ | High | 6 |  |  | 6 |  |  | ns |
|  | Low | 7.3 |  |  | 7.3 |  |  |  |
| Data setup time, $\mathrm{t}_{\text {su }}$ | 'S373 | 0 $\downarrow$ |  |  | - $\downarrow$ |  |  | ns |
|  | 'S374 | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  |  |
| Data hold time, $\mathrm{t}_{\mathrm{h}}$ | 'S373 | $10 \downarrow$ |  |  | 10】 |  |  | ns |
|  | 'S374 | $2 \uparrow$ |  |  | $2 \uparrow$ |  |  | ns |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

$\uparrow \downarrow$ The arrow indicates the transition of the clock/enable input used for reference: $\uparrow$ for the low-to-high transition, $\downarrow$ for the high-to-low transition.

## TYPES SN54S373，SN54S374，SN74S373，SN74S374 OCTAL D－TYPE TRANSPARENT LATCHES AND EDGE－TRIGGERED FLIP－FLOPS

electrical characteristics over recommended operating free－air temperature range（unless otherwise noted）

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | High－level input voltage |  |  |  | 2 |  |  | $\checkmark$ |
| $V_{\text {IL }}$ | Low－level input voltage |  |  |  |  |  | 0.8 | V |
| $V_{\text {IK }}$ | Input clamp voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $I_{1}=-18 \mathrm{~mA}$ |  |  | －1．2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High－level output voltage | SN54S＇ | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I L}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{1 H}=2 V \\ & I_{O H}=M A X \end{aligned}$ | 2.4 | 3.4 |  | V |
|  |  | SN74S＇ |  |  | 2.4 | 3.1 |  |  |
| $\mathrm{V}_{\text {OL }}$ | Low－level output voltage |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & V_{I H}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA} \end{aligned}$ |  |  | 0.5 | V |
| ${ }^{1} \mathrm{OZH}$ | Off－state output current， high－level voltage applied |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} \\ & \mathrm{~V}_{\mathrm{O}}=2.4 \mathrm{~V} \end{aligned}$ | $V_{I H}=2 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
| IOZL | Off－state output current， low－level voltage applied |  | $\begin{aligned} & V_{C C}=\mathrm{MAX} \\ & \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V} \end{aligned}$ | $V_{I H}=2 \mathrm{~V},$ |  |  | －50 | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage |  | $V_{C C}=M A X$ ， | $V_{1}=5.5 \mathrm{~V}$ |  |  | 1 | mA |
| $1 / \mathrm{H}$ | High－level input current |  | $V_{C C}=M A X$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
| IIL | Low－level input current |  | $V_{C C}=M A X$, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  | －250 | $\mu \mathrm{A}$ |
| Ios | Short－circuit output current $\S$ |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$ |  | －40 |  | －100 | mA |
| ${ }^{1} \mathrm{CC}$ | Supply current |  | $V_{C C}=M A X$ | ＇S373 |  | 105 | 160 | mA |
|  |  |  | ＇S374 |  | 90 | 140 |  |

${ }^{\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}, \top_{A}=25^{\circ} \mathrm{C}$ ．
$\$$ Not more than one output should be shorted at a time and duration of the short－circuit test should not exceed one second．
switching characteristics， $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | FROM （INPUT） | то （OUTPUT） | TEST CONDITIONS | ＇S373 |  |  | ＇S374 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| $f_{\text {max }}$ |  |  | $C_{L}=15 \mathrm{pF}, \mathrm{R}_{\mathrm{L}}=280 \mathrm{~s} 2,$ <br> See Note |  |  |  | 75 | 100 |  | MHz |
| tPLH | Data | Any Q |  |  | 5 | 9 |  |  |  | ns |
| tPHL |  |  |  |  | 9 | 13 |  |  |  | s |
| tPLH | Clock or enable | Any Q |  |  | 10 | 18 |  | 8 | 15 | ns |
| tPHL |  |  |  |  | 12 | 18 |  | 11 | 17 |  |
| ${ }^{\text {Z }} \mathrm{H}$ | Output Control | Any Q |  |  | 8 | 15 |  | 8 | 15 | ns |
| ${ }^{\text {Z }} \mathrm{L}$ |  |  |  |  | 11 | 18 |  | 11 | 18 |  |
| ${ }_{\text {t }}^{\mathrm{Hz}}$ | Output <br> Control | Any Q | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=5 \mathrm{pF}, \quad \mathrm{R}_{\mathrm{L}}=280 \Omega, \\ & \text { See Note } \end{aligned}$ |  | 6 | 9 |  | 5 | 9 | ns |
| ${ }_{t}$ LZ |  |  |  |  | 8 | 12 |  | 7 | 12 |  |

NOTE：$f_{\text {max }}$ is tested with all outputs loaded．See load circuits and waveforms on page 3－10 of The TTL Data Book for Design Engineers， second edition，LCC4112．
$f_{\text {max }} \equiv$ maximum clock frequency
${ }^{\text {tpLH }}$ ㄹ propagation delay time，low－to－high level
${ }^{\text {tpHL }} \equiv$ propagation delay time，high－to－low level
${ }^{t_{Z H}} \equiv$ output enable time to high level
${ }^{{ }^{\prime}} \mathbf{Z L} \equiv$ output enable time to low level
${ }^{\mathbf{t}} \mathrm{HZ} \equiv$ output disable time from high level
${ }_{\mathrm{t}}^{\mathrm{L} Z} \mathrm{E} \equiv$ output disable time from low level



- P-N-P Inputs and 3-State Outputs Maximize I/O and Data Bus Capabilities
- Data Latch Transparency Permits Asynchronous or Latched Receiver Modes
- Mode and Select Inputs Permit Storing

With Outputs Enabled or Disabled

- Strobe-Controlled Flag Flip-Flop Indicates Status or Interrupt
- Asynchronous Clear Sets All Eight Data Lines Low and Initializes Status Flag
- High-Level Output Voltage, Typically 4 V , Drives Most MOS Functions Directly
- Direct Replacement for Intel 3212 or 8212


## description

This high-performance eight-bit parallel expandable buffer register incorporates package and mode selection inputs and an edge-triggered status flip-flop designed specifically for implementing bus-organized input/output ports. The three-state data outputs can be connected to a common data bus and controlled from the appropriate select inputs to receive or transmit data. An integral status flip-flop provides package busy or request interrupt commands. The outputs, with a 4-volt typical high-level voltage, are compatible for driving low-threshold MOS directly.

## DATA LATCHES

The eight data latches are fully transparent when the internal gate enable, G, input is high and the outputs are enabled $(O E=H$ ). Latch transparency is selected by the mode control ( $M$ ), select ( $\bar{S} 1$ and $S 2$ ), and the strobe (STB) inputs and during transparency each data output ( $\mathrm{DO}_{\mathrm{i}}$ ) follows its respective data input ( $\mathrm{DI}_{\mathrm{i}}$ ). This mode of operation can be terminated by clearing, de-selecting, or holding the data latches. See data latches function table.

## MODE SELECTION

An input mode or an output mode is selectable from this single input line. In the input mode, $\mathrm{MD}=\mathrm{L}$, the eight data latch inputs are enabled when the strobe is high regardless of device selection. If selected during an input mode, the outputs will follow the data inputs. When the strobe input is taken low, the latches will store the most-recently setup data.

In the output mode, $M=H$, the output buffers are enabled regardless of any other control input. During the output mode the content of the register is under control of the select ( $\overline{\mathrm{S} 1}$ and S 2 ) inputs. See data latches function table.

## STATUS FLIP-FLOP

The status flip-flop provides a low-level output signal when:
a. the package is selected
b. a strobe input is received.

This status signal can be used to indicate that the register is busy or to initiate an interrupt type command.
functional block diagram

schematics of inputs and outputs


TEXAS INSTRUMENTS
POST OFFICE BOX 5012 • DALLAS. TEXAS 75222

## TYPES SN54S412, SN74S412 (TIM8212) <br> MULTI-MODE BUFFERED LATCHES

DATA LATCHES FUNCTION TABLE

| FUNCTION | CLEAR | M | $\overline{\text { S }} 1$ | S2 | STB | DATA IN | DATA OUT |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Clear | L | H | H | X | X | X | L |
|  | L | L | L | H | L | X | L |
| De-select | X | L | X | L | X | X | Z |
|  | X | L | H | X | X | X | Z |
| Hold | H | H | H | L | X | X | QO |
|  | H | L | L | H | L | X | OO |
| Data Bus | H | H | L | H | X | L | L |
|  | H | H | L | H | X | H | H |
| Data Bus | H | L | L | H | H | L | L |
|  | H | L | L | H | H | H | H |

STATUS FLIP-FLOP FUNCTION TABLE

| CLEAR | $\overline{\mathbf{s}} 1$ | S2 | sTB | $\overline{\text { INT }}$ |
| :---: | :---: | :---: | :---: | :---: |
| L | H | X | X | H |
| L | X | L | X | H |
| H | X | X | $\downarrow$ | L |
| H | L | H | X | L |

$H \equiv$ high level (steady state)
$L \equiv$ low level (steady state)
$X \equiv$ irrelevant (any input, including transitions)
$Z \equiv$ high impedance (off)
$\downarrow \equiv$ transition from low to high level
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, V CC (see Note 1)
Input voltage.

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

|  |  | SN54S412 |  |  | SN74S412 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| Pulse width, $\mathrm{t}_{\mathrm{w}}$ | STB or $\overline{\text { S }} 1 \cdot$ S2 | 25 |  |  | 25 |  |  |  |
| (see Figures 1, 2, and 4) | Clear low | 25 |  |  | 25 |  |  |  |
| Setup time, $\mathrm{t}_{\text {su }}$ (see Figure 3) |  | 15 $\downarrow$ |  |  | 15 $\downarrow$ |  |  | ns |
| Hold time, $\mathrm{th}_{\mathrm{h}}$ (see Figures 1 and 3) |  | 20】 |  |  | 20 $\downarrow$ |  |  | ns |
| Operating free-air temperature, $\mathrm{T}_{\mathbf{A}}$ |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

$\downarrow$ The arrow indicates that the falling edge of the clock pulse is used for reference.

# TYPES SN54S412, SN74S412 (TIM8212) MULTI-MODE BUFFERED LATCHES 

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

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | SN54S412 |  |  | SN74S412 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| VIH | High-level input voltage |  |  |  |  |  | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.85 |  |  | 0.85 | V |
| $\mathrm{V}_{\text {IK }}$ | Input clamp voltage |  | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$; | $I_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| VOH | High-level output voltage |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{IOH}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ | 3.65 | 4 |  | 3.65 | 4 |  | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Low-level output voltage |  | $\begin{aligned} & V_{C C}=\mathrm{MIN}, \\ & V_{I H}=2 \mathrm{~V}, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | ${ }^{1} \mathrm{OL}=15 \mathrm{~mA}$ | 0.45 |  |  | 0.45 |  |  | V |
|  |  |  | $\mathrm{I}^{\text {OL }}=20 \mathrm{~mA}$ |  |  | 0.5 |  |  | 0.5 |  |
| IOZH | Off-state output current, high-level voltage applied | $\begin{aligned} & \text { DO } 1 \text { thru } \\ & \text { DO } 8 \end{aligned}$ |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  | 50 |  |  |  |  | 50 | $\mu \mathrm{A}$ |
| IOZL | Off-state output current, low-level voltage applied | $\begin{aligned} & \text { DO } 1 \text { thru } \\ & \text { DO } 8 \end{aligned}$ | $V_{C C}=$ MAX, | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -50 |  |  | -50 | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage |  | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 |  |  | 1 | mA |
| $1 / \mathrm{H}$ | High-level input current |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$, | $\mathrm{V}_{1}=5.25 \mathrm{~V}$ |  |  | 20 |  |  | 10 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | $\overline{\mathrm{S}} 1$ | $V_{C C}=$ MAX, | $V_{1}=0.4 \mathrm{~V}$ |  |  | -1 |  |  | -1 | mA |
|  |  | M |  |  |  |  | -0.75 |  |  | -0.75 |  |
|  |  | All others |  |  |  |  | -0.25 |  |  | -0.25 |  |
| IOS | Short-circuit output current $\S$ |  | $V_{C C}=M A X$ |  | -20 |  | -65 | -20 |  | -65 | mA |
| ICC | Supply current |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$, see Note 2 |  | 82 |  |  |  | 82 | 130 | mA |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
$\dagger_{\text {All typical values are at }} \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$.
§Not more than one output should be shorted at a time.
NOTE 2: ${ }^{\prime} \mathrm{CC}$ is measured with all outputs open, clear input at 4.5 V , and all other inputs grounded.
switching characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | FROM | TO | FIGURE | TEST CONDITIONS | MIN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | STB, $\overline{\mathbf{S}} 1$, or S2 | $\begin{aligned} & \text { Any } \\ & \text { DO } \end{aligned}$ | 1 | $C_{L}=30 \mathrm{pF}$ |  | 18 | 27 | ns |
| tPHL |  |  |  |  |  | 15 | 25 |  |
| tPHL | $\overline{C L R}$ | Any DO | 2 |  |  | 18 | 27 | ns |
| tPLH | DI ${ }_{i}$ | $\mathrm{DO}_{\mathbf{i}}$ | 3 |  |  | 12 | 20 | ns |
| ${ }^{\text {tPHL }}$ |  |  |  |  |  | 10 | 20 |  |
| tPLH | $\overline{\mathrm{S}} 1$ or S2 | $\overline{\text { INT }}$ | 4 | $C_{L}=30 \mathrm{pF}$ |  | 12 | 20 | ns |
| tPHL | STB | INT | 4 |  |  | 16 | 25 |  |
| ${ }^{\text {t }} \mathrm{ZH}$ | $\overline{\mathrm{S}} 1, \mathrm{~S} 2$, or M | Any DO | 5 | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |  | 21 | 35 | ns |
| ${ }^{\text {t }} \mathrm{L}$ L |  |  |  |  |  | 25 | 40 |  |
| thz | $\overline{\mathrm{S}} 1, \mathrm{~S} 2$, or M | Any DO | 5 | $C_{L}=5 \mathrm{pF}$ |  | 9 | 20 | ns |
| tLZ |  |  |  |  |  | 12 | 20 |  |

$t_{\text {PLH }} \equiv$ propagation delay time, low-to-high-level output
tpHL $^{\text {PL }} \equiv$ propagation delay time, high-to-low-level output
${ }^{\mathrm{I}} \mathrm{ZH} \equiv$ output enable time to high level
${ }^{\mathrm{t}} \mathrm{ZL} \equiv$ output enable time to low level
$\mathrm{t}_{\mathrm{HZ}} \equiv$ output disable time from high level
$t_{L Z} \equiv$ output disable time from low level

PARAMETER MEASUREMENT INFORMATION


- Designed to Be Interchangeable with Intel 8228 and 8238

PIN DESIGNATIONS

| DESIGNATION | PIN NOS. | FUNCTION |
| :---: | :---: | :---: |
| D0 thru D7 | $\begin{array}{ccc} 15, & 17, & 12, \\ 6, & 19, & 21, \end{array}$ | BIDIRECTIONAL DATA PORT (TO TMS 8080A) |
| DB0 thru DB7 | $\begin{gathered} 13,16,11,9, \\ 5,18,20,7 \\ \hline \end{gathered}$ | BIDIRECTIONAL DATA PORT (TO SYSTEM BUS) |
| I/OR | 25 | READ OUTPUT TO I/O (ACTIVE LOW) |
| IO/W | 27 | WRITE OUTPUT TO I/O (ACTIVE/ LOW) |
| $\overline{\text { MEMR }}$ | 24 | READ OUTPUT TO MEMORY (ACTIVE LOW) |
| MEMW | 26 | WRITE OUTPUT TO MEMORY (ACTIVE LOW) |
| DBIN | 4 | INPUT TO INDICATE TMS 8080A IS IN INPUT MODE (ACTIVE HIGH) |
| $\overline{\text { INTA }}$ | 23 | INTERRUPT ACKNOWLEDGE OUTPUT (ACTIVE LOW) |
| HLDA | 2 | HOLD ACKNOWLEDGE <br> INPUT (ACTIVE HIGH) <br> FROM TMS 8080A |
| $\overline{W R}$ | 3 | INPUT TO INDICATE TMS 8080A IS IN WRITE MODE (ACTIVE LOW) |
| $\overline{B U S E N}$ | 22 | SYSTEM DATA PORT <br> ENABLE INPUT (ACTIVE <br> LOW) |
| $\overline{\text { STSTB }}$ | 1 | SYNCHRONIZING STATUS <br> STROBE INPUT FROM <br> SN74LS424 (TIM8224) |
| VCC | 28 | SUPPLY VOLTAGE (5 V) |
| GND | 14 | GROUND |

NPACKAGE
(TOP VIEW)


## functional block diagram



## description

These monolithic Schottky-clamped TTL system controllers are designed specifically to provide bus-driving and peripheral-control capabilities for interfacing memory and I/O devices with the 8080 A in small to medium-large microcomputer systems.

A bidirectional eight-bit parallel bus driver is provided that isolates the 8080 A bus from the memory and $1 / \mathrm{O}$ data bus allowing the system designed to utilize cost-effective memory and peripheral devices while obtaining the maximum efficiency from the microprocessor. The TTL system drivers also provide increased fan-out with a lower impedance that enhances noise margins on the system bus.

Implementation of the status latches and control decoding array of the SN74S428/SN74S438 provides for using either a single-level interrupt vector RST7 for small systems, or multiple-byte call instructions for systems needing unlimited interrupt levels.

# TYPES SN74S428(TIM8228), SN74S438(TIM8238) <br> CONTROLLER AND BUS DRIVER FOR 8080A SYSTEMS 

## description (continued)

With respect to the system clocks, the SN74S438 is configured to generate an advanced response for I/O or memory write output signals to further simplify peripheral control implementation of complex systems. See Figure 3.

## 8-bit parrallel bus transceiver

The 8 -bit parallel bus transceiver buffers the 8080A data bus from the memory and I/O system bus by providing one port (DO through D7) to interface with the 8080A and another port (DBO through DB7) to interface with the system devices. The 8080A side of the transceiver is designed specifically to interface with the microprocessor data bus ensuring not only that the processor output drive capabilities are adequate, but also that the inputs are driven with enhanced noise margins. The system bus side features high fan-out buffers designed to drive a number of system devices simultaneously and directly. The system port is rated to sink ten milliamperes of current and to source one milliampere of current at standard low-threshold voltage levels.

Status lines from the 8080A instruction-status decoder and the system bus enable input (BUSEN) provide complete transceiver directional and enable control to ensure integrity of both the processor data and the system bus data.

## status latches

During the beginning of each machine cycle, the six status latches receive status information from the 8080A data bus indicating the type of operation that will be performed. When the STSTB input goes low, the latches store the status data and generate the signals needed to enable and sequence the memory and $1 / 0$ control outputs. The status words and types of machine cycles are enumerated in Table A.

TABLE A - STATUS WORDS


## decoding array

The decoding array receives enabling commands from the status latches and sequencing commands from the 8080A and generates memory and I/O read/write commands and an interrupt acknowledgement.

# TYPES SN74S428(TIM8228), SN74S438(TIM8238) CONTROLLER AND BUS DRIVER FOR 8080A SYSTEMS 

## description (continued)

The read commands ( $\overline{\mathrm{MEMR}}, \overline{\mathrm{I} / \mathrm{OR})}$ and the interrupt acknowledgement ( $\overline{\mathrm{INTA})}$ are derived from the status bit(s) and the data bus input mode (DBIN) signal. The write commands ( $\overline{\mathrm{MEMW}}, \overline{\mathrm{I} / \mathrm{OW}}$ ) are derived from the status bit(s) and the write mode ( $\overline{\mathrm{WR}) \text { signal. (See Table A.) All control commands are active low to simplify interfacing with }}$ memory and I/O controllers.

The interrupt acknowledgement (INTA) command output is actually a dual function pin. As an output, its function is to provide the $\overline{\text { NTA }}$ command to the memory and I/O peripherals as decoded from the status inputs and latches. When CALL is used as an interrupt instruction, the SN74S428/SN74S428 generates the proper sequence of control signals. Additionally, the terminal includes high-threshold decoding logic that permits it to be biased through a onekilohm series resistor to the 12 -volt supply to implement an interrupt structure that automatically inserts an RST7 instruction on the bus when the DBIN input is active and an interrupt is acknowledged. This capability provides a single-level interrupt vector with minimal hardware.

The asynchronous bus enable ( $\overline{B U S E N}$ ) input to the decoding array is a control signal that protects the system bus. The system bus can be accessed and driven from the SN74S428/SN74S428 controller only when the BUSEN input is at a low voltage level.

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

```
Supply voltage, VCC (see Note 1)7 V
```

Input voltage ..... 7 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}$

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

|  |  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ |  | 4.75 | 5 | 5.25 | V |
| High-level output current, I OH | D0 thru D7 |  |  | -10 | $\mu \mathrm{A}$ |
|  | All others |  |  | -1 | mA |
| Low-level output current, IOL | D0 thru D7 |  |  | 2 | mA |
|  | All others |  |  | 10 |  |
| Status strobe pulse width, $\mathrm{t}_{\mathrm{w}}$ (STSTB) (see Figure 3) |  | 22 |  |  | ns |
| Setup time, $\mathrm{t}_{\text {su }}$ (see Figure 3) | Status inputs D0 thru D7 | 8 |  |  | ns |
|  | System bus inputs to HLDA | 10 |  |  |  |
| Hold time, th (see Figure 3) | Status inputs D0 thru D7 | 5 |  |  | ns |
|  | System bus inputs to HLDA | 20 |  |  | ns |
| Operating free-air temperature, $\mathrm{T}_{\mathbf{A}}$ |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

| PARAMETER |  |  | TEST CONDITIONS |  | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | High-level input voltage |  |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.8 | V |
| $V_{\text {IK }}$ | Input clamp voltage |  | $V_{C C}=M I N$, | $\mathrm{I}_{1}=-5 \mathrm{~mA}$ |  |  | -1 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | D0 thru D7 | $\begin{array}{ll} \hline \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, & \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \\ \hline \end{array}$ |  | 3.6 | 4 |  | V |
|  |  | All other outputs |  |  | 2.4 |  |  |  |
| $\mathrm{V}_{\text {OL }}$ | Low-level output voltage |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\text {IL }}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=\mathrm{MAX} \end{aligned}$ |  |  | 0.45 | V |
| ${ }^{1} \mathrm{OZH}$ | Off-state output current, high-level voltage applied |  | $V_{C C}=$ MAX, | $\mathrm{V}_{\mathrm{O}}=5.25 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| ${ }^{\text {I O }}$ OL | Off-state output current, low-level voltage applied |  | $V_{C C}=$ MAX, | $\mathrm{V}_{\mathrm{O}}=0.45 \mathrm{~V}$ |  |  | -100 | $\mu \mathrm{A}$ |
| IIH | High-level input current | $\overline{\text { INTA }}$ | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$, | See Figure 1 |  |  | 5 | mA |
|  |  | DO thru D7 | $V_{C C}=\mathrm{MAX}, \quad \mathrm{V}_{1}=5.25 \mathrm{~V}$ |  |  |  | 20 | $\mu \mathrm{A}$ |
|  |  | All other inputs |  |  |  |  | 100 |  |
| IIL | Low-level input current | D2 or D6 | $V_{C C}=$ MAX | $V_{1}=0.45 \mathrm{~V}$ |  |  | -750 | $\mu \mathrm{A}$ |
|  |  | STSTB |  |  |  |  | -500 |  |
|  |  | All other inputs |  |  |  |  | -250 |  |
| 'os | Short-circuit output current§ |  | $V_{C C}=M A X$ |  | -15 |  | -90 | mA |
| ICC | Supply current |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$ |  |  | 140 | 190 | mA |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
\#All typical values are at $\mathrm{V}_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=25^{\prime \prime} \mathrm{C}$.
§Not more than one output should be shorted at a time.
switching characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$, see figure 3

| PARAMETER ${ }^{\text {I }}$ | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS |  | MIN | TYP MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPD | D0 thru D7 | DB0 thru DB7 | $C_{L}=100 \mathrm{pF}$, | See Figure 2 | 5 | 40 | ns |
| tPD | DB0 thru DB7 | D0 thru D7 | $C_{L}=25 \mathrm{pF}$, | See Figure 2 |  | 30 | ns |
| tPHL | $\overline{\text { STSTB }}$ | $\overline{\text { INTA, }} \overline{\text { IOR }}, \overline{M E M R}$, ПOW, MEMW | $C_{L}=100 \mathrm{pF}$, | See Figure 2 | 20 | 60 | ns |
| tPD | $\overline{\text { WR }}$ | I/OW, MEMW |  |  | 5 | 45 | ns |
| tplH | DBIN | $\overline{\text { INTA, }} \overline{\text { IOR }}$, $\overline{M E M R}$ |  |  |  | 30 | ns |
| tPLH | HLDA | $\overline{\text { INTA }}$, $\overline{1 / O R}, \overline{M E M R}$ |  |  |  | 25 | ns |
| tPZX | DBIN | D0 thru D7 | $C_{L}=25 \mathrm{pF}$, | See Figure 2 |  | 45 | ns |
| tpXZ | DBIN | D0 thru D7 |  |  |  | 45 | ns |
| tPZX | $\overline{\text { STSTB, }}$ BUSEN | DB0 thru DB7 | $C_{L}=100 \mathrm{pF}$, | See Figure 2 |  | 30 | ns |
| tPXZ | BUSEN | DB0 thru DB7 |  |  |  | 30 | ns |

$\|_{\text {tPD }} \equiv$ propagation delay time
$t_{P H L} \equiv$ propagation delay time, high-to-low-level output
tpLH $\equiv$ propagation delay time, low-to-high-level output
tpZX $\equiv$ output enable time from high-impedance state
$\operatorname{tp} \times Z \equiv$ output disable time to high-impedance state

## TYPES SN74S428(TIM8228), SN74S438(TIM8238) CONTROLLER AND BUS DRIVER FOR 8080 A SYSTEMS

PARAMETER MEASUREMENT INFORMATION


NOTE A: Advanced response of $\overline{1 / O W}$ or $\overline{M E M W}$ for the SN74S438 is indicated by the dashed line.
FIGURE 3-VOLTAGE WAVEFORMS

## TYPICAL APPLICATION DATA



FIGURE 4-SYSTEM INTERFACING WITH CENTRAL PROCESSING UNIT

- 4-Bit Slice is Cascadable to N-Bits
- Designed Specifically for Microcontroller/ Next-Address Generator Functions
- Increment/Decrement by One (Immediate or Direct Symbolic Addressing Modes)
- Offset, Vector, or Branch (Indexed or Relative Addressing Modes)
- Store Up to Four Returns or Links (Program Return Address from Subroutine)
- Program Start or Initialize (Return to Zero or Clear Mode)
- On-Chip Edge-Triggered Output Register (Provides Steady-State Micro-Address/ Instruction)
- High-Density 20-Pin Dual-in-Line Package with 300-Mil Row Pin Spacing



## description

The 'S482 is a high-performance Schottky TTL 4-bit-slice control element for use in any computer/control application requiring the coupling of high-performance bipolar speeds with the flexibility of microprogram control and bit-slice expandability. When used as a next-address generator, two 'S482 elements can address up to 256 words of microprogram; three elements can addresss up to 4096 words of microprogram; or a number of 'S482 elements can generate $\mathbf{N}$ words in multiples of four lines.

Comprised of an output register, push-pop stack, and a full adder, the 'S482 provides the capability to implement multiway testing needed to generate or to determine and select the source of the next function of microprogram address.
functional block diagram


TYPES SN54S482, SN74S482
4-BIT-SLICE EXPANDABLE CONTROL ELEMENTS

## output register and source functions

The 4-bit edge-triggered register provides a steady-state output throughout each system clock cycle. An asynchronous clear extends the multiway testing to directly implement system initialization at ROM address zero.

Two source-select lines (S5, S6) provide the output register with access to either the current instruction (no change), an operand or address stored in the push-pop stack, the output of a four-function full adder, or a direct data-in address port. The sources and functions are summarized in Tables I and II.

TABLE I. REGISTERSOURCE FUNCTIONS

| SELECT |  | REGISTER INPUT SOURCE |
| :---: | :---: | :---: |
| S5 | S6 |  |
| L | L | DATA-IN PORT (Di) |
| L | H | FULL ADDER OUTPUTS ( $\Sigma \mathrm{i}$ ) |
| H | L | PUSH-POP STACK OUTPUTS (Qi) |
| H | H | REGISTER OUTPUTS (HOLD) |

$H \equiv$ high level, $L \equiv$ low level

TABLE II. PUSH-POP STACK CONTROL AND REGISTER-SOURCE FUNCTIONS


MSB LSB
$i \equiv 3, \quad 2, \quad 1, \quad 0$
$A i \equiv$ Data inputs
QiA $\equiv$ Push-pop stack word A output (internal) QiAO $\equiv$ the level of Qi before the indicated inputs conditions were established.

Fi $\equiv$ Device outputs
Fio $\equiv$ the level of Fi before the indicated input conditions were established.
$\Sigma \mathbf{i} \equiv$ Adder outputs (internal)
*QiB, QiC, QiD do not change
${ }^{\dagger}{ }^{\circ} \mathrm{QiDO} \rightarrow \mathrm{QiD}, \mathrm{QiDO} \rightarrow \mathrm{QiC}, \mathrm{QiCO} \rightarrow \mathrm{QiB}, \mathrm{QiBO} \rightarrow \mathrm{QiA}$
$\ddagger Q_{i A O} \rightarrow \mathrm{QiB}, \mathrm{QiBO} \rightarrow \mathrm{QiC}, \mathrm{QiCO} \rightarrow \mathrm{QiD}$

# TYPES SN54S482, SN74S482 <br> 4-BIT-SLICE EXPANDABLE CONTROL ELEMENTS 

## push-pop stack control

The 4-word push-pop stack can be used for nesting up to four levels of program or return (link) addresses. In the load mode, the first (top) word is filled with new data from the output of the full adder, and no push occurs meaning that previous data at that location is lost. However, all other word locations in the push-pop stack remain unchanged. In the push mode, the new word is again entered in the first (top) location; however, previous data residing in the top three words are pushed down one word location and retained at their new locations. The bottom word is written over and lost.

In the pop mode, words in the push-pop stack move up one location on each clock transition. A unique function is provided by the bottom (fourth) register as its content is retained during the pop mode, and after 3 clock transitions, all words in the stack are filled with the operand/address that occupied the bottom register.

The operand/address will remain available indefinitely if stack functions are limited to the pop or hold modes.
The push-pop stack functions are shown in Tables II and III.
TABLE III. PUSH-POP STACK FUNCTIONS

$\mu$ link operations show previous data location after clock transition.

## full adder

The four-function full adder is controllable from select inputs S1 and S2 to perform:
A or B incrementation, or decrementation of B
Unconditional jumps or relative offsets
No change
Return to zero or one
Incrementation can be implemented by forcing a carry (high) into the ALU. In this mode either of the following options are possible:

1. Increment (A plus zero plus carry)
2. Increment $B$ (zero plus $B$ plus carry), or decrement $B$ (all highs at $A$ then $A$ plus $B$ with carry input low and disregard, don't use, carry out)
3. Increment the jump or offset (A plus B plus carry)

## TYPES SN54S482, SN74S482 <br> 4-BIT-SLICE EXPANDABLE CONTROL ELEMENTS

## full adder (continued)

4. Start at zero or one and increment on each clock (select zero plus zero plus carry, then select zero plus B plus carry), or set register to N and decrement B (see 2 above).
5. No change (carry input is always active and removal of carry combined with either the ALU or register hold mode will retain the current address).

Unconditional jumps can be implemented by applying and selecting the jump directly from the data inputs to the output register. Offset can be accomplished by summing the output register with the offset magnitude (A plus B) with carry low.

The ALU functions are shown in Table IV.

TABLE IV. ADDRESS CONTROL FUNCTIONS

| INPUTS |  | INTERNAL |
| :---: | :---: | :---: |
| S1 | S2 |  |
| $H$ | $H$ | O PLUS O PLUS C-in |
| $H$ | L | O PLUS Bi PLUS C-in |
| L | $H$ | Ai PLUS O PLUS C-in |
| L | L | Ai PLUS Bi PLUS C-in |

## compound generator functions

As the function-select lines of the register sources, push-pop stack, and adder are independent, compound functions can be selected to occur on the next clock transition.

Subroutine branches and returns can be simplified by saving the return or link addresses in the push-pop stack. This branch-and-save function can be accomplished on the same clock time as follows:

| DATA-IN | ADDER | PUSH-POP STACK | REGISTER SOURCE |
| :--- | :--- | :--- | :--- |
| Branch address | Zero plus B plus one | Push | Data-in |
|  | $(S 1=H, S 2=\mathrm{L})$ | $(S 3=S 4=H)$ | $(S 5=S 6=L)$ |

Up to four branches can be made with the return stored in the 4-word push-pop stack.
absolute maximum ratings over operating free-air temperature (unless otherwise noted)
Supply voltage, $\mathrm{V}_{\mathrm{CC}}$ (see Note 1 )
Input voltage ..

NOTE 1. All voltage values are with respect to network ground terminal.

# TYPES SN54S482, SN74S482 4-BIT-SLICE EXPANDABLE CONTROL ELEMENTS 

recommended operating conditions

|  |  | SN54S482 |  |  | SN74S482 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voltage, VCC |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| High-level output current, IOH | Carry output |  |  | -1 |  |  | -1 | mA |
|  | Any F output |  |  | -2 |  |  | -2 |  |
| Low-level output current, IOL | Carry output |  |  | 10 |  |  | 10 | mA |
|  | Any Foutput |  |  | 16 |  |  | 16 |  |
| Setup time, $\mathrm{t}_{\text {su }}$ | Data-in, S5, S6 | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | ns |
|  | Data-in via adder | $20 \uparrow$ |  |  | $15 \uparrow$ |  |  |  |
|  | S1, S2 | $40 \uparrow$ |  |  | $30 \uparrow$ |  |  |  |
|  | S3, 54 | $20 \uparrow$ |  |  | $15 \uparrow$ |  |  |  |
|  | Clear-inactive state | $0 \uparrow$ |  |  | 0 |  |  |  |
| Pulse width, $\mathrm{t}_{\mathrm{w}}$ | Clock (high or low) | 50 |  |  | 30 |  |  | ns |
|  | Clear (Iow) | 15 |  |  | 15 |  |  |  |
| Clock input rise time, $\mathrm{tr}_{\mathrm{r}}$ |  |  |  | 50 |  |  | 50 | ns |
| Hold time, th | Data-in, S5, S6 | $30 \uparrow$ |  |  | $25 \uparrow$ |  |  | ns |
|  | Data-in via adder | $15 \uparrow$ |  |  | $10 \uparrow$ |  |  |  |
|  | S1, 52 | $15 \uparrow$ |  |  | $10 \uparrow$ |  |  |  |
|  | S3, 54 | $25 \uparrow$ |  |  | $20 \uparrow$ |  |  |  |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ |  | -55 |  | 125 | 0 | 25 | 70 | ${ }^{\circ} \mathrm{C}$ |

$\uparrow_{\text {The arrow indicates that the rising edge of the clock pulse is used for reference, }}$
electrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | SN54S482 |  |  | SN74S482 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | High-level input voltage |  |  |  |  |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.8 |  |  | 0.8 | V |
| $V_{\text {IK }}$ | Input clamp voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}$, | $1_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| V OH | High-level output voltage |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\text {IL }}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 V \\ & I_{O H}=M A X \end{aligned}$ | 2.5 | 3.4 |  | 2.7 | 3.4 |  | V |
| VOL | Low-level output voltage |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 V \\ & I_{O L}=M A X \end{aligned}$ |  |  | 0.5 |  |  | 0.5 | V |
| 11 | Input current at maximum input voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$, | $\mathrm{V}_{\mathrm{L}}=5.5 \mathrm{~V}$ |  |  | 1 |  |  | 1 | mA |
| ${ }^{1} \mathrm{H}$ | High-level input current | S1, S2, Cin | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
|  |  | S3, S4, S5, S6, clock |  |  |  |  | 100 |  |  | 100 |  |
|  |  | Clear |  |  |  |  | 250 |  |  | 250 |  |
|  |  | Any A |  |  |  |  | 150 |  |  | 150 |  |
| IIL | Low-level input current | S1, S2 | $V_{C C}=M A X$, | $V_{1}=0.5 \mathrm{~V}$ |  |  | -1 |  |  | -1 | mA |
|  |  | C-in |  |  |  |  | -0.8 |  |  | -0.8 |  |
|  |  | S3, S4 |  |  |  |  | -1.2 |  |  | -1.2 |  |
|  |  | Any A, S5, S6, CK |  |  |  |  | -2 |  |  | -2 |  |
|  |  | Clear |  |  |  |  | -4 |  |  | -4 |  |
|  |  | Clock |  |  |  |  | -2.8 |  |  | -2.8 |  |
| IOS | Short-circuit output current § |  | $V_{C C}=M A X$ |  | -40 |  | -110 | -40 |  | -110 | mA |
| ICC | Supply current |  | $V_{C C}=\mathrm{MAX}$ |  |  | 90 | 130 |  | 90 | 140 | mA |

$\dagger_{\text {For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions. }}^{\text {con }}$,
${ }^{\ddagger}$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
§Not more than one output should be shorted at a time.

## 4-BIT-SLICE EXPANDABLE CONTROL ELEMENTS

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

| PARAMETER | FROM | TO | TEST CONDITIONS |  | N54S482 |  |  | 74S482 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PARAMETER | FROM | TO | TEST CONDITIONS | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX | UNIT |
| tPLH | CLOCK | DATA OUT | $\begin{aligned} & C_{L}=15 \mathrm{pF} \\ & R_{L}=280 \Omega \end{aligned}$ |  | 12 | 30 |  | 12 | 25 | ns |
| tPHL |  |  |  |  | 15 | 30 |  | 15 | 25 |  |
| tPHL | CLEAR | DATA OUT |  |  | 12 | 25 |  | 12 | 20 | ns |
| tplu | CARRY IN | CARRY OUT |  |  | 12 | 22 |  | 12 | 18 | ns |
| tPHL |  |  |  |  | 10 | 22 |  | 10 | 18 |  |
| tPLH | DATA IN | CARRY OUT |  |  | 17 | 30 |  | 17 | 25 | ns |
| tPHL |  |  |  |  | 12 | 30 |  | 12 | 25 |  |

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

TEXAS INSTRUMENTS INCORPORATED


DECEMBER 1976

## Texas Instruments INCORPORATED

## TTL INTEGRATED CIRCUITS MECHANICAL DATA

## J ceramic dual-in-line package

These hermetically sealed dual-in-line packages consist of a ceramic base, ceramic cap, and a $14-16$ - 20 -, or 24 -lead frame. Hermetic sealing is accomplished with glass. The packages are intended for insertion in mounting-hole rows on $0.300(7,62)$ or $0.600(15,24)$ centers. Once the leads are compressed and inserted, sufficient tension is provided to secure the package in the board during soldering. Tin-plated ("bright-dipped") leads ( -00 ) require no additional cleaning or processing when used in soldered assembly.


## TTL INTEGRATED CIRCUITS MECHANICAL DATA

## J ceramic dual-in-line packages (continued)




## TTL INTEGRATED CIRCUITS MECHANICAL DATA

## N plastic dual-in-line packages

These dual-in-line packages consist of a circuit mounted on a 14 -, 16-, 20 -, or 28 -lead frame and encapsulated within an electrically nonconductive plastic compound. The compound will withstand soldering temperature with no deformation and circuit performance characteristics remain stable when operated in high-humidity conditions. The packages are intended for insertion in mounting hole rows on $0.300(7,62)$ or $0.600(15,24)$ 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.


N plastic dual-in-line packages (continued)


NOTES: a. All dimensions are shown in inches (and parenthetically in millimeters for reference only). Inch dimensions govern.
b. Each pin centerline is located within $0.010(0,26)$ of its true longitudinal position.
c. This dimension does not apply for solder-dipped leads.
d. When solder-dipped leads are specified, dipped area of the lead extends from the lead tip to at least $0.020(0,50)$ above the seating plane.

TTL INTEGRATED CIRCUITS MECHANICAL DATA

N plastic dual-in-line packages (continued)


NOTES: a. All dimensions are shown'in inches (and parenthetically in millimeters for reference only). Inch dimensions govern.
b. Each pin centerline is located within $0.010(0,26)$ of its true longitudinal position.
c. This dimension does not apply for solder dipped leads.
d. When solder-dipped leads are specified, dipped area of the lead extends from the lead tip to at least $0.020(0,50)$ above the seating plane.

# TTL INTEGRATED CIRCUITS MECHANICAL DATA 

## W ceramic flat package

These hermetically sealed flat packages consist of an electrically nonconductive ceramic base and cap, and a 14-, 16-, or 24 -lead frame. Hermetic sealing is accomplished with glass. Tin-plated ('bright-dipped") leads ( -00 ) require no additional cleaning or processing when used in soldered assembly.


[^18]

## SEPTEMBER 1977

Texas Instruments

## INDEX TO 54S/74S, 54LS/74LS, AND $I^{2}$ L FUNCTIONS

Function ..... PageAccumulators, Arithmetic Logic Units,
Look-Ahead Generators ..... 3
Adders ..... 3
AND Gates. ..... 12
AND-OR-Invert Gates .....  9
Arithmetic Logic Gates ..... 3
Arithmetic Operators ..... 3
Asynchronous Counter ..... 6
BCD-to-Decimal Decoders/Drivers ..... 11
BCD-to-Seven Segment Decoders/Drivers ..... 11
Bit-Slice Processor Elements ..... 1
Buffer and Interface Gates ..... 10
Buffers, Clock Drivers ..... 11
Bus Drivers. ..... 6
Bus Transceiver Gates ..... 10
Clock Drivers, Buffers ..... 11
Clock Generator Circuits. .....  8
Comparators ..... 3
Controllers and Support Functions, Microprocessor ..... 4
Counters, Asynchronous .....  6
Counters, Synchronous. .....  6
Current-Sensing Gates ..... 5
Data Selectors, Multiplexers ..... 5
Decoders, Demultiplexers ..... 5
Display Drivers/Decoders ..... 11
Field Programmable Logic Arrays. .....  1
First-In, First-Out Memory (FIFO) ..... 1
Flip-Flops, Dual J-K. ..... 9
Flip Flops/Registers ..... 4
Gates, AND ..... 12
Gates, AND-OR-INVERT .....  9
Gates, Buffer, Interface and Transceiver. ..... 10
Gates, NAND ..... 12
Gates, NOR ..... 12
Gates, OR ..... 11
J-K Flip Flops, Dual. .....  9
Latches .....  8

# SCHOTTKY TTL AND I²L FUNCTIONS FUNCTIONAL INDEX/SELECTION GUIDE 

## $\mathbf{I}^{2}$ L 16-BIT MICROPROCESSORS

| DESCRIPTION | COMPUTER INSTRUCTIONS | CLOCK FREQUENCY | DEVICE TYPE AND PACKAGE |  |  |  | SEC. <br> PAGE <br> NO. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |  |  |
| MEMORY-TO-MEMORY ARCHITECTURE SUPPORTED WITH SEPARATE MEMORY and Cru interrupt buses | $\begin{gathered} 69 \\ \text { (TI 990/4) } \end{gathered}$ | 2 MHz | SBP 9900M SBP 9900N $\ddagger$ | J | SBP 9900E | J | 3-1 |

BIPOLAR BIT-SLICE PROCESSOR ELEMENTS

| DESCRIPTION | $\begin{gathered} \hline \text { CASCADABLE } \\ \text { TO } \\ \text { N-BITS } \\ \hline \end{gathered}$ | TYPICAL $\mu$-OPERATION TIME | TECHNOLOGY | DEVICE TYPE <br> AND PACKAGE |  |  |  | SEC. <br> PAGE <br> NO. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  |
| EXPANDABLE <br> 4BIT SLICE | Yes | 50 ns | STTL |  |  | SN74S481 | J, N | 1-1 |
|  | Yes | 100 ns | LSTTL | SN54LS481 | J | SN74LS481 | J, N | 1-1 |
|  | Yes | 300 ns | ${ }^{12} \mathrm{~L}$ | SBP0400AM | J | SBP0400AC | J, N | 2-1 |
|  | Yes | 300 ns | $1^{2} \mathrm{~L}$ | SBP0401AM | J | SBP0401AC | J, N | 2-1 |

EXPANDABLE FIELD-PROGRAMMABLE LOGIC ARRAYS

| DESCRIPTION | ORGANIZATION | TYPICAL DELAY TIME | OUTPUTS TYPE/ NO. | DEVICE TYPE AND PACKAGE |  |  | SEC. <br> PAGE <br> NO. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}$ to 7 |  |  |
| AUTOMATIC OR DEDICATED ENABLE | $12 \times 50 \times 6$ | 35 ns | $\begin{gathered} \hline \text { 3-State/6 } \\ 0-\mathrm{C} / 6 \end{gathered}$ |  | $\begin{aligned} & \text { SN74S330 } \\ & \text { SN74S331 } \end{aligned}$ | $\begin{aligned} & J, N \\ & J, N \end{aligned}$ | 5-13 |

FIRST-IN FIRST-OUT MEMORY (FIFO)

| DESCRIPTION |  | TYPICAL CLOCK FREQUENCY | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  | SEC. <br> PAGE <br> NO. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}$ to |  |  |
| ASYNCHRONOUS $16 \times 5$ | 3-State | 20 MHz | 400 mW |  | SN74S225 | J, N | 4-39 |

PROGRAMMABLE READ-ONLY MEMORIES (PROM'S)

| DESCRIPTION, PKG. PINS, AND ROW SPACING |  | ORGANI- <br> ZATION <br> $512 \times 8$ <br> $512 \times 8$ | TYPE <br> OF <br> OUTPUT$\|$ | TYPICAL <br> ADDRESS <br> TIME <br> 55 ns <br> 55 ns | TYPICAL <br> ENABLE <br> TIME <br> 20 ns <br> 20 ns <br> 20 e | TYP POWER <br> DISSIPATION <br> PER BIT <br> 0.14 mW <br> 0.14 mW | DEVICE TYPE AND PACKAGE |  |  |  | $\begin{array}{\|l\|} \hline \text { SEC. } \\ \text { PAGE } \\ \text { No. } \\ \hline \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  |  |  |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  |
| 4096-BIT ARRAYS | 20-Pin 300-Mil |  |  |  |  |  | SN54S472 <br> SN54S473 |  | SN74S472 <br> SN74S473 | $J, N$ | 4.1 |
|  | $\begin{aligned} & 24-\mathrm{Pin} \\ & 600-\mathrm{Mil} \end{aligned}$ |  | $\begin{aligned} & 512 \times 8 \\ & 512 \times 8 \end{aligned}$ | $\begin{gathered} \text { 3-State } \\ \text { O-C } \end{gathered}$ | 55 ns <br> 55 ns | $\begin{aligned} & 20 \mathrm{~ns} \\ & 20 \mathrm{~ns} \\ & \hline \end{aligned}$ | $\begin{aligned} & 0.14 \mathrm{~mW} \\ & 0.14 \mathrm{~mW} \end{aligned}$ | SN54S474 <br> SN54S475 | $\begin{aligned} & \hline J, W \\ & J, W \end{aligned}$ | SN74S474 <br> SN74S475 |  | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ |
|  | $\begin{aligned} & \text { 18-Pin } \\ & 300-\mathrm{MiI} \end{aligned}$ | $\begin{aligned} & \hline 1024 \times 4 \\ & 1024 \times 4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { 3-State } \\ & \text { O-C } \end{aligned}$ | $\begin{aligned} & 35 \mathrm{~ns} \\ & 35 \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & 20 \mathrm{~ns} \\ & 20 \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & 0.14 \mathrm{~mW} \\ & 0.14 \mathrm{~mW} \end{aligned}$ | $\begin{aligned} & \hline \text { SN54S476 } \\ & \text { SN54S477 } \end{aligned}$ | $\begin{aligned} & \mathrm{J} \\ & \mathrm{~J} \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { SN74S476 } \\ \text { SN74S477 } \end{array}$ | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \hline \end{aligned}$ |  |
| 2048-BIT <br> ARRAYS | $\begin{aligned} & \text { 20-Pin } \\ & 300-\mathrm{Mil} \end{aligned}$ | $\begin{array}{r} 256 \times 8 \\ 256 \times 8 \\ \hline \end{array}$ | $\begin{gathered} \hline \text { O-C } \\ \text { 3-State } \end{gathered}$ | $\begin{aligned} & 50 \mathrm{~ns} \\ & 50 \mathrm{~ns} \\ & \hline \end{aligned}$ | $\begin{array}{r} 20 \mathrm{~ns} \\ 20 \mathrm{~ns} \\ \hline \end{array}$ | $\begin{aligned} & 0.24 \mathrm{~mW} \\ & 0.27 \mathrm{~mW} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { SN54S470 } \\ & \text { SN54S471 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{J} \\ & \mathrm{~J} \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { SN74S470 } \\ \text { SN74S471 } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline J, N \\ J, N \\ \hline \end{array}$ | 4-1 |
| 1024-BIT | 16-Pin | $256 \times 4$ | 3-State | 40 ns | 15 ns | 0.49 mW | SN54S287 | J, w | SN74S287 | J, N | $4-1$ |
| ARRAYS | 300-Mil | $256 \times 4$ | O-C | 40 ns | 15 ns | 0.49 mW | SN54S387 | J, W | SN74S387 | J, N |  |
| 256-BIT | 16-Pin | $32 \times 8$ | O-C | 25 ns | 12 ns | 1.56 mW | SN54S188 | J, W | SN74S188 | J, N |  |
| ARRAYS | 300-Mil | $32 \times 8$ | 3-State | 25 ns | 12 ns | 1.56 mW | SN54S288 | J, W | SN74S288 | J, N |  |

[^19]SCHOTTKY TTL AND I²L FUNCTIONS
FUNCTIONAL INDEX/SELECTION GUIDE

READ-ONLY MEMORIES (ROM'S)

| DESCRIPTION | ORGANIZATION | TYPE OF OUTPUT | TYPICAL <br> ADDRESS <br> TIME | TYPICAL <br> ENABLE <br> TIME | TYP POWER DISSIPATION PER BIT | DEVICE TYPE AND PACKAGE |  |  |  | SEC. <br> PAGE <br> NO. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to 12 | C | $0^{\circ} \mathrm{C}$ to 7 |  |  |
| 16384-BIT ARRAYS | $2048 \times 8$ | $\begin{aligned} & \hline \text { O-C or } \\ & 10 \mathrm{~K} \Omega \\ & \text { Puillup } \end{aligned}$ | $\begin{gathered} 150(350) \mathrm{ns} \\ \text { to } \\ 20 \mu \mathrm{~s} \end{gathered}$ | $\begin{gathered} 60(150) \mathrm{ns} \\ \text { to } \\ 8 \mu \mathrm{~s} \\ \hline \end{gathered}$ | 0.03 mW to 0.0002 mW | $\begin{aligned} & \text { SBP 9818M } \\ & \text { (SBP 8316M) } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{J} \\ & \mathrm{~J} \end{aligned}$ | $\begin{aligned} & \text { SBP 9818C } \\ & \text { (SBP 8316C) } \end{aligned}$ | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ | 416 |
| 2048-BIT ARRAYS | $\begin{aligned} & 512 \times 4 \\ & 256 \times 8 \\ & 512 \times 4 \\ & 256 \times 8 \end{aligned}$ | O-C O-C 3-State 3-State | 45 ns 45 ns 45 ns 45 ns | $\begin{aligned} & 15 \mathrm{~ns} \\ & 15 \mathrm{~ns} \\ & 15 \mathrm{~ns} \\ & 15 \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & 0.26 \mathrm{~mW} \\ & 0.26 \mathrm{~mW} \\ & 0.26 \mathrm{~mW} \\ & 0.26 \mathrm{~mW} \end{aligned}$ | $\begin{aligned} & \hline \text { SN54S270 } \\ & \text { SN54S271 } \\ & \text { SN54S370 } \\ & \text { SN54S371 } \end{aligned}$ | $\begin{aligned} & \mathrm{J} \\ & \mathrm{~J} \\ & \mathrm{~J} \\ & \mathrm{~J} \end{aligned}$ | SN74S270 <br> SN74S271 <br> SN74S370 <br> SN74S371 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ | 4-9 |
| 1024-BIT ARRAYS | $256 \times 4$ | O-C | 40 ns | 20 ns | 0.46 mW | SN54187 | J, W | SN74187 | J, N | 4.9 |
| 256-BIT ARRAYS | $32 \times 8$ | O-C | 26 ns | 22 ns | 1.1 mW | SN5488A | J, W | SN7488A | J, N | 4.9 |

RANDOM-ACCESS READ-WRITE MEMORIES (RAM'S)

| DESCRIPTION | ORGANIZATION | TYPE OF OUTPUT | TYPICAL <br> ADDRESS TIME | $\begin{array}{\|c\|} \hline \text { TYPICAL } \\ \text { ENABLE } \\ \text { TIME } \\ \hline \end{array}$ | TYP POWER DISSIPATION PER BIT | DEVICE TYPE AND PACKAGE |  |  |  | $\begin{array}{\|c} \text { SEC. } \\ \text { PAGE } \\ \text { NO. } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  |
| 1024-BIT ARRAYS <br> WITH POWER-DOWN | $\begin{aligned} & 1024 \times 1 \\ & 1024 \times 1 \end{aligned}$ | 3-State O-C | $\begin{aligned} & 75 \mathrm{~ns} \\ & 75 \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & 75 \mathrm{~ns} \\ & 75 \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & 0.2 / 0.07 \mathrm{~mW} \\ & 0.2 / 0.07 \mathrm{~mW} \end{aligned}$ |  |  | SN74LS215 <br> SN74LS315 | JD, N | 4-27 |
| 1024-BIT ARRAYS | $\begin{aligned} & \hline 1024 \times 1 \\ & 1024 \times 1 \\ & 1024 \times 1 \\ & 1024 \times 1 \\ & \hline \end{aligned}$ | $\begin{gathered} \hline \text { 3-State } \\ \text { 3-State } \\ \text { O-C } \\ \text { O-C } \end{gathered}$ | 75 ns <br> 40 ns <br> 75 ns <br> 40 ns | $\begin{aligned} & 35 \mathrm{~ns} \\ & 15 \mathrm{~ns} \\ & 35 \mathrm{~ns} \\ & 15 \mathrm{~ns} \end{aligned}$ | $\begin{array}{r} 0.2 \mathrm{~mW} \\ 0.51 \mathrm{~mW} \\ 0.2 \mathrm{~mW} \\ 0.51 \mathrm{~mW} \end{array}$ |  |  | $\begin{array}{\|l\|} \hline \text { SN74LS214 } \\ \text { SN74S214 } \\ \text { SN74LS314 } \\ \text { SN74S314 } \end{array}$ | $\left.\begin{array}{\|c\|} \mathrm{JD}, \mathrm{~N} \\ \mathrm{JD}, \mathrm{~N} \\ \mathrm{JD}, \mathrm{~N} \\ \mathrm{JD}, \mathrm{~N} \end{array} \right\rvert\,$ | 4-27 |
|  | $\begin{aligned} & \hline 256 \times 4 \\ & 256 \times 4 \\ & 256 \times 4 \\ & 256 \times 4 \\ & \hline \end{aligned}$ | 3-State <br> 3-State <br> 3-State <br> 3-State | 75 ns 40 ns 75 ns 40 ns | $\begin{aligned} & 20 \mathrm{~ns} \\ & 15 \mathrm{~ns} \\ & 20 \mathrm{~ns} \\ & 15 \mathrm{~ns} \end{aligned}$ | $\begin{array}{r} \hline 0.3 \mathrm{~mW} \\ 0.59 \mathrm{~mW} \\ 0.3 \mathrm{~mW} \\ 0.59 \mathrm{~mW} \\ \hline \end{array}$ |  |  | $\begin{array}{\|l\|} \text { SN74LS207 } \\ \text { SN74S207 } \\ \text { SN74LS208 } \\ \text { SN74S208 } \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \hline \end{aligned}$ | 4-33 |
| 256-BIT ARRAYS | $\begin{aligned} & 256 \times 1 \\ & 256 \times 1 \end{aligned}$ | 3-State O-C | $\begin{aligned} & 42 \mathrm{~ns} \\ & 42 \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & 17 \mathrm{~ns} \\ & 13 \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & 1.9 \mathrm{~mW} \\ & 1.9 \mathrm{~mW} \end{aligned}$ |  |  | $\begin{aligned} & \text { SN74S201 } \\ & \text { SN74S301 } \end{aligned}$ | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ | 4-24 |
| 64-BIT ARRAYS | $\begin{aligned} & 16 \times 4 \\ & 16 \times 4 \\ & \hline \end{aligned}$ | 3-State O-C | $\begin{aligned} & 25 \mathrm{~ns} \\ & 25 \mathrm{~ns} \\ & \hline \end{aligned}$ | $\begin{aligned} & 12 \mathrm{~ns} \\ & 12 \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & 5.9 \mathrm{~mW} \\ & 5.9 \mathrm{~mW} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { SN54S189 } \\ & \text { SN54S289 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \end{aligned}$ | $\begin{aligned} & \hline \text { SN74S189 } \\ & \text { SN74S289 } \\ & \hline \end{aligned}$ | $\begin{aligned} & J, N \\ & J, N \end{aligned}$ | $4-20$ |

REGISTER FILES ${ }^{\boldsymbol{~}}$

| DESCRIPTION | TYPICAL <br> ADDRESS <br> TIME | TYP READ <br> ENABLE <br> TIME | DATA <br> INPUT <br> RATE | TYP TOTAL <br> POWER | DEVICE TYPE <br> AND PACKAGE |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FOUR WORDS OF FOUR BITS | 27 ns | 15 ns | 20 MHz | 125 mW | SN54LS170 | $\mathrm{J}, \mathrm{W}$ | SN74LS 170 | $\mathrm{~J}, \mathrm{~N}$ |
| FOUR WORDS OF FOUR BITS <br> (3-STATE OUTPUTS) | 24 ns | 19 ns | 20 MHz | 135 mW | SN54LS670 | $\mathrm{J}, \mathrm{W}$ | SN 74 LS 670 | $\mathrm{~J}, \mathrm{~N}$ |

[^20]
## SCHOTTKY TTL FUNCTIONS FUNCTIONAL INDEX/SELECTION GUIDE

ACCUMULATORS, ARITHMETIC LOGIC UNITS, LOOK-AHEAD CARRY GENERATORS ${ }^{\dagger}$

| DESCRIPTION | TYPICAL CARRY TIME | TYPICAL ADD TIME | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| 4BIT PARALLEL <br> BINARY ACCUMULATORS | 10 ns | 20 ns | 720 mW | SN54S281 | J, W | SN74S281 | J, N |
|  | 11 ns | 20 ns | 525 mW | SN54S381 | J | SN74S381 | J, N |
|  | 7 ns | 11 ns | 600 mW | SN54S181 | J, w | SN74S181 | J, N |
| FUNCTION GENERATORS | 16 ns | 24 ns | 102 mW | SN54LS181 | J,w | SN74LS181 | J, N |
| LOOK-AHEAD CARRY GENERATORS | 7 ns |  | 260 mW | SN54S182 | J, W | SN74S182 | J, N |

## ADDERS ${ }^{\dagger}$

| DESCRIPTION | TYPICAL CARRY TIME | $\begin{aligned} & \text { TYPICAL } \\ & \text { ADD } \\ & \text { TIME } \\ & \hline \end{aligned}$ | TYP POWER DISSIPATION PER BIT | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
|  | 20 ns | 15 ns | 24 mW | SN54LS83A | J, W | SN74LS83A | $J, N$ |
| 4BIT FULL ADDERS | 10 ns | 15 ns | 24 mW | SN54LS283 | J, W | SN74LS283 | J, N |
|  | 11 ns | 7 ns | 124 mW | SN54S283 | $J$ | SN74S283 | J, N |
| DUAL CARRY-SAVE FULL ADDERS | 15 ns | 15 ns | 23 mW | SN54LS183* | J, W | SN74LS183* | J, N |

MULTIPLIERS ${ }^{\dagger}$

| DESCRIPTION | DEVICE TYPE AND PACKAGE |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
|  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| 2-BIT-BY-4-BIT PARALLEL BINARY MULTIPLIERS | SN54LS261 | $\mathrm{J}, \mathrm{W}$ | $\mathrm{SN744LS261}$ | $\mathrm{~J}, \mathrm{~N}$ |
| 4-BIT-BY-4-BIT PARALLEL BINARY MULTIPLIERS | SN54S274 | J | $\mathrm{SN744S274}$ | $\mathrm{~J}, \mathrm{~N}$ |
| 7-BIT-SLICE WALLACE TREES | SN54LS275 | J | SN74LS275 | $\mathrm{J}, \mathrm{N}$ |
|  |  | SN54S275 | J | SN74S275 |

COMPARATORS ${ }^{\dagger}$

| DESCRIPTION | TYPICAL COMPARE TIME | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| 4-BIT MAGNITUDE COMPARATORS | $\begin{aligned} & 11.5 \mathrm{~ns} \\ & 23.5 \mathrm{~ns} \end{aligned}$ | $\begin{array}{r} 365 \mathrm{~mW} \\ 52 \mathrm{~mW} \end{array}$ | SN54S85 <br> SN54LS85 | $\begin{aligned} & \mathrm{J}, \mathrm{w} \\ & \mathrm{~J}, \mathrm{w} \end{aligned}$ | $\begin{aligned} & \hline \text { SN74S85 } \\ & \text { SN74LS85 } \\ & \hline \end{aligned}$ | $\begin{aligned} & J, N \\ & J, N \end{aligned}$ |

OTHER ARITHMETIC OPERATORS ${ }^{\dagger}$

| DESCRIPTION | TYPICAL <br> DELAY <br> TIME | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| QUADRUPLE 2-INPUT EXCLUSIVE-OR | 7 ns | 250 mW | SN54S86 | J, W | SN74S86 | J, N |
| GATES WITH TOTEM-POLE OUTPUTS | 10 ns | 30 mW | SN54LS86 | J, W | SN74LS86 | J, N |
|  | 10 ns | 30 mW | SN54LS386 | J, W | SN74LS386 | J, N |
| QUADRUPLE 2-INPUT EXCLUSIVE-OR GATES WITH OPEN-COLLECTOR OUTPUTS | 18 ns | 30 mW | SN54LS136 | J, W | SN74LS136 | J, N |
| QUADRUPLE 2-INPUT EXCLUSIVE-NOR GATES | 18 ns | 40 mW | SN54LS266 | J, W | SN74LS266 | J, N |
| QUADRUPLE EXCLUSIVE OR/NOR GATES | 8 ns | 325 mW | SN54S135 | J, W | SN74S135 | J, N |

[^21]| DESCRIPTION | TYPICAL DELAY TIME | TYP TOTAL POWER DISSIPATION | DEVICE TYPE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C}$ to $125{ }^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| 9-BIT ODD/EVEN PARITY | 31 ns | 80 mW | SN54LS280 | J, W | SN74LS280 | J, N |
| GENERATORS/CHECKERS | 13 ns | 335 mW | SN54S280 | J, w | SN74S280 | J, N |

MICROPROCESSOR CONTROLLERS AND SUPPORT FUNCTIONS

| DESCRIPTION | SYSTEM <br> APPLICATION | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  | $\begin{gathered} \hline \text { SEC. } \\ \text { PAGE } \\ \text { NO. } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C}$ to 12 | $5^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  |
| SYSTEM CONTROLLERS | $\begin{aligned} & 8080 A \\ & 8080 A \end{aligned}$ | $\begin{aligned} & 700 \mathrm{~mW} \\ & 700 \mathrm{~mW} \\ & \hline \end{aligned}$ | - | , | $\begin{aligned} & \hline \text { SN74S428 (TIM8228) } \\ & \text { SN74S438 (TIM8238) } \end{aligned}$ | $\begin{aligned} & N \\ & N \end{aligned}$ | 5-35 |
|  | Universal | 450 mW | SN54S482 | $J$ | SN74S482 | J, N | 5-41 |
| REGISTERS | TMS 9900 | 110 mW | SN54LS259 | J, W | SN74LS259 (TIM9906) | J, N | $\dagger$ |
|  | MOS | $\begin{aligned} & 210 \mathrm{~mW} \\ & 210 \mathrm{~mW} \end{aligned}$ | $\begin{aligned} & \text { SN54LS363* } \\ & \text { SN54LS364* } \end{aligned}$ | $\begin{aligned} & \mathrm{J} \\ & \mathrm{~J} \end{aligned}$ | SN74LS363* <br> SN74LS364* | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ | $\dagger$ |
| MULTI-MODE LATCHES | 8080A | 410 mW | SN54S412 | J, W | SN74S412 (TIM8212) | J, N | 5-30 |
| TRANSCEIVERS AND BUS DRIVERS | Universal | 625 mW 207 mW | SN54S226 SN54LS245 | $\begin{gathered} \mathrm{J}, \mathrm{~W} \\ \mathrm{~J} \end{gathered}$ | SN74S226 SN74LS245 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ | $\begin{gathered} 5-1 \\ + \\ \hline \end{gathered}$ |
| TRANSCEIVERS AND BUS DRIVERS (SSI) | Universal | $\begin{array}{r} 98 \mathrm{~mW} \\ 450 \mathrm{~mW} \\ 100 \mathrm{~mW} \\ 538 \mathrm{~mW} \\ 128 \mathrm{~mW} \\ 128 \mathrm{~mW} \\ 100 \mathrm{~mW} \\ \hline \end{array}$ | SN54LS240 <br> SN54S240 <br> SN54LS241 <br> SN54S241 <br> SN54L.S242 <br> SN54LS243 <br> SN54LS244 | $\begin{gathered} \mathrm{J} \\ \mathrm{~J} \\ \mathrm{~J} \\ \mathrm{~J} \\ \mathrm{~J}, \mathrm{~W} \\ \mathrm{~J}, \mathrm{~W} \\ \mathrm{~J} \\ \hline \end{gathered}$ | SN74LS240 <br> SN74S240 <br> SN74LS241 <br> SN74S241 <br> SN74LS242 <br> SN74LS243 <br> SN74LS244 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ | $\begin{gathered} \hline t \\ 5-5 \\ t \\ 5-5 \\ t \\ \dagger \\ t \\ \hline \end{gathered}$ |
| CLOCK ELEMENTS | TMS 9900 | 669 mW |  |  | SN74LS362 (TIM9904) | J, N | $\dagger$ |
|  | 8080A | 719 mW |  |  | SN74LS424 (TIM8224) | J, N | $\dagger$ |
| LOGIC ELEMENTS | $\begin{aligned} & \text { TMS } 9900 \\ & \text { TMS } 9900 \\ & \text { TMS } 9900 \end{aligned}$ | $\begin{array}{r} 190 \mathrm{~mW} \\ 35 \mathrm{~mW} \\ 63 \mathrm{~mW} \\ \hline \end{array}$ | $\begin{aligned} & \hline \text { SN54LS148 } \\ & \text { SN54LS251 } \\ & \text { SN54LS348 } \end{aligned}$ | $\begin{aligned} & \mathrm{J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \end{aligned}$ | SN74LS148 (TIM990.7) <br> SN74LS251 (TIM9905) <br> SN゙74LS348 (TIM9908) | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ | $\begin{aligned} & t \\ & t \\ & t \end{aligned}$ |

QUAD, HEX, AND OCTAL FLIP-FLOP/REGISTERS ${ }^{\dagger}$

| DESCRIPTION | $\begin{gathered} \text { F-F } \\ \text { PER } \\ \text { PKG } \end{gathered}$ | FREO | POWERPERFLIP-FLOP | DATA TIMES |  | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | SETUP <br> ns | HOLD ns |  |  |  |  |
|  |  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| D TYPE 3-STATE WITH ENABLE | 8 | 50 MHz | 26 mW | $20 \uparrow$ | $0 \uparrow$ | SN54LS364* | J | SN74LS364* | J, N |
|  |  | 50 MHz | 17 mW | $20 \uparrow$ | $0 \uparrow$ | SN54LS374 | J | SN74LS374 | J, N |
|  |  | 100 MHz | 56 mW | $5 \uparrow$ | $2 \uparrow$ | SN54S374 | J | SN74S374 | J, N |
| D TYPE WITH ENABLE | 8 | 40 MHz | 10.6 mW | $20 \uparrow$ | $5 \uparrow$ | SN54LS377 | $J$ | SN74LS377 | J, N |
|  | 6 | 40 MHz | 10.6 mW | $20 \uparrow$ | $5 \uparrow$ | SN54LS378 | J, W | SN74LS378 | J, N |
|  | 4 | 40 MHz | 10.6 mW | $20 \uparrow$ | $5 \uparrow$ | SN54LS379 | J | SN74LS379 | J, N |
| D TYPE WITH CLEAR | 8 | 40 MHz | 10.6 mW | $20 \uparrow$ | $5 \uparrow$ | SN54LS273 | J | SN74LS273 | J, N |
|  | 6 | 40 MHz | 10.6 mW | $20 \uparrow$ | $5 \uparrow$ | SN54LS174 | J, W | SN74LS174 | $J, N$ |
|  |  | 110 MHz | 75 mW | $5 \uparrow$ | $3 \uparrow$ | SN54S174 | J, W | SN74S174 | J, N |
|  | 4 | 40 MHz | 10.6 mW | $20 \uparrow$ | $5 \uparrow$ | SN54LS175 | J, W | SN74LS175 | $J, N$ |
|  |  | 110 MHz | 75 mW | $5 \uparrow$ | $3 \uparrow$ | SN54S175 | J, W | SN74S175 | J, N |

[^22]
# SCHOTTKY TTL FUNCTIONS FUNCTIONAL INDEX/SELECTION GUIDE 

DATA SELECTORS/MULTIPLEXERS ${ }^{\dagger}$

| DESCRIPTION | TYPE <br> OF OUTPUT | TYPICAL DELAY TIMES |  |  | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | DATA TO INV OUTPUT | DATA TO NON-INV OUTPUT | FROM ENABLE |  |  |  |  |  |
|  |  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| 8-LINE-TO-1-LINE | 3-State <br> 3-State <br> 2-State <br> 2-State <br> 2-State | 4.5 ns <br> 17 ns <br> 4.5 ns <br> 11 ns <br> 11 ns | $\begin{array}{r} 8 \mathrm{~ns} \\ 21 \mathrm{~ns} \\ 8 \mathrm{~ns} \\ 18 \mathrm{~ns} \end{array}$ | 14 ns <br> 21 ns <br> 9 ns <br> 27 ns <br> 18 ns | 275 mW <br> 35 mW <br> 225 mW <br> 30 mW <br> 28 mW | SN54S251 <br> SN54LS251 <br> SN54S151 <br> SN54LS151 <br> SN54LS152 | $\begin{gathered} \mathrm{J}, \mathrm{~W} \\ \mathrm{~J}, \mathrm{~W} \\ \mathrm{~J}, \mathrm{~W} \\ \mathrm{~J}, \mathrm{~W} \\ \mathrm{~W} \end{gathered}$ | SN74S251 <br> SN74LS251 <br> SN74S151 <br> SN74LS151 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ |
| DUAL <br> 4-LINE-TO-1-LINE | 3-State <br> 2-State <br> 3-State <br> 2-State <br> 2-State | $\begin{aligned} & 15 \mathrm{~ns} \\ & 12 \mathrm{~ns} \end{aligned}$ | $\begin{array}{r} 12 \mathrm{~ns} \\ \\ 6 \mathrm{~ns} \\ 14 \mathrm{~ns} \\ \hline \end{array}$ | 16 ns <br> 22 ns <br> 21 ns <br> 9.5 ns <br> 17 ns | 35 mW <br> 31 mW <br> 43 mW <br> 225 mW <br> 31 mW | SN54LS253 <br> SN54LS352 <br> SN54LS353 <br> SN54S153 <br> SN54LS153 | $\begin{aligned} & \hline J, W \\ & J, W \\ & J, W \\ & J, W \\ & J, W \\ & \hline \end{aligned}$ | SN74LS253 SN74LS352 SN74LS353 SN74S153 SN74LS153 | $\begin{aligned} & \hline J, N \\ & J, N \\ & J, N \\ & J, N \\ & J, N \\ & \hline \end{aligned}$ |
| QUADRUPLE <br> 2-LINE-TO-1-LINE <br> WITH STORAGE | 2-State <br> 2-State <br> 2-State | 20 ns § | $\begin{aligned} & 20 \mathrm{~ns} \S \\ & 20 \mathrm{~ns} \S \\ & 20 \mathrm{~ns} \S \end{aligned}$ |  | 65 mW <br> 32 mW <br> 37 mW | SN54LS298 <br> SN54LS398 <br> SN54LS399 | $\begin{gathered} J, W \\ J \\ J, W \end{gathered}$ | SN74LS298 <br> SN74LS398 <br> SN74LS399 | $\begin{aligned} & J, N \\ & J, N \\ & J, N \end{aligned}$ |
| QUADRUPLE 2-LINE-TO-1-LINE | 3-State <br> 3-State <br> 2-State <br> 2-State <br> 3-State <br> 3-State <br> 2-State <br> 2-State | 4 ns <br> 4 ns <br> 12 ns <br> 7 ns | 5 ns <br> 5 ns <br> 12 ns <br> 9 ns | $\begin{array}{r} \hline 14 \mathrm{~ns} \\ 14 \mathrm{~ns} \\ 7 \mathrm{~ns} \\ 8 \mathrm{~ns} \\ 20 \mathrm{~ns} \\ 20 \mathrm{~ns} \\ 12 \mathrm{~ns} \\ 14 \mathrm{~ns} \\ \hline \end{array}$ | $\begin{array}{r} \hline 280 \mathrm{~mW} \\ 320 \mathrm{~mW} \\ 195 \mathrm{~mW} \\ 250 \mathrm{~mW} \\ 60 \mathrm{~mW} \\ 60 \mathrm{~mW} \\ 24 \mathrm{~mW} \\ 49 \mathrm{~mW} \\ \hline \end{array}$ | SN54S258 SN54S257 SN54S158 SN54S157 SN54LS258A* SN54LS257A* SN54LS158 SN54LS157 | J,W J,W J,W J, W J, W J, W J, W J, W | SN74S258 <br> SN74S257 <br> SN74S158 <br> SN74S157 <br> SN74LS258A* <br> SN74LS257A* <br> SN74LS158 <br> SN74LS157 | $\begin{aligned} & \hline J, N \\ & J, N \\ & J, N \\ & J, N \\ & J, N \\ & J, N \\ & J, N \\ & J, N \\ & \hline \end{aligned}$ |

## DECODERS/DEMULTIPLEXERS ${ }^{\dagger}$

| DESCRIPTION | TYPE OF OUTPUT | TYPICAL <br> SELECT TIME | TYPICAL <br> ENABLE <br> TIME | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| 4-LINE-TO-10-LINE, BCD-TO-DECIMAL | Totem-Pole | 17 ns | . | 35 mW | SN54LS42 | J, W | SN74LS42 | $J, N$ |
| 3-LINE-TO-8-LINE | Totem-Pole Totem-Pole | $\begin{array}{r} 8 \mathrm{~ns} \\ 22 \mathrm{~ns} \end{array}$ | $\begin{array}{r} 7 \mathrm{~ns} \\ 21 \mathrm{~ns} \end{array}$ | $\begin{array}{r} 245 \mathrm{~mW} \\ 31 \mathrm{~mW} \end{array}$ | SN54S138 SN54LS138 | $\begin{aligned} & \mathrm{J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \end{aligned}$ | SN74S138 <br> SN74LS138 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ |
| DUAL 2-LINE-TO-4-LINE | Totem-Pole <br> Totem-Pole <br> Totem-Pole <br> Open-Collector | $\begin{gathered} \hline 7.5 \mathrm{~ns} \\ 22 \mathrm{~ns} \\ 18 \mathrm{~ns} \\ 33 \mathrm{~ns} \end{gathered}$ | $\begin{array}{r} 6 \mathrm{~ns} \\ 19 \mathrm{~ns} \\ 15 \mathrm{~ns} \\ 26 \mathrm{~ns} \end{array}$ | $\begin{array}{r} 300 \mathrm{~mW} \\ 34 \mathrm{~mW} \\ 30 \mathrm{~mW} \\ 31 \mathrm{~mW} \end{array}$ | SN54S139 <br> SN54LS139 <br> SN54LS155 <br> SN54LS156 | $\begin{aligned} & \mathrm{J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \end{aligned}$ | SN74S139 <br> SN74LS139 <br> SN74LS155 <br> SN74LS156 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ |

## CURRENT-SENSING-GATES ${ }^{\dagger}$

| DESCRIPTION | TYPICAL PROPAGATION DELAY TIME | TYP POWER DISSIPATION PER GATE | DEVICE TYPE AND PACKAGES |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| HEX | 21 ns | 3.3 mW | SN54LS63 | J, W | SN74LS63 | J, N |

[^23]
## SCHOTTKY TTL FUNCTIONS <br> FUNCTIONAL INDEX/ SELECTION GUIDE

bus transceivers and drivers

| DESCRIPTION | TYPICAL PROPAGATION DELAY TIMES | MAXIMUM SOURCE CURRENT | MAXIMUM SINK CURRENT | DEVICE TYPE AND PACKAGE |  |  |  | SEC. <br> PAGE <br> NO. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  |
| CONTROLLER AND BUS DRIVER FOR 8080A SYSTEMS |  | $\begin{aligned} & -1 \mathrm{~mA} \\ & -1 \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & 10 \mathrm{~mA} \\ & 10 \mathrm{~mA} \end{aligned}$ |  |  | SN74S428 SN74S438 | $\begin{aligned} & \mathrm{N} \\ & \mathrm{~N} \end{aligned}$ | 5-35 |
| OCTAL BUS TRANSCEIVERS | 8 ns | -12 mA | 12 mA | SN54LS245 | J | SN74LS245 | J, N | $\dagger$ |
| 4-BIT BUS TRANCEIVERS WITH STORAGE | 10 ns | -6.5 mA | 20 mA | SN54S226 | J, W | SN74S226 | J, N | 5-1 |

ASYNCHRONOUS COUNTERS (RIPPLE CLOCK) - NEGATIVE-EDGE TRIGGERED ${ }^{\dagger}$

| DESCRIPTION | COUNT FREQ | PARALLEL LOAD | CLEAR | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| DECADE | 100 MHz | Yes | Low | 375 mW | SN54S196 | J, W | SN74S196 | J, N |
|  | 32 MHz | Set-to-9 | High | 40 mW | SN54LS90 | J, W | SN74LS90 | J, N |
|  | 32 MHz | Set-to-9 | High | 40 mW | SN54LS290 | J, W | SN74LS290 | J, N |
|  | 30 MHz | Yes | Low | 60 mW | SN54LS196 | J, W | SN74LS196 | J, N |
| 4-BIT BINARY | 100 MHz | Yes | Low | 375 mW | SN54S197 | J, W | SN74S197 | J, N |
|  | 32 MHz | None | High | 39 mW | SN54LS93 | J, W | SN74LS93 | J, N |
|  | 32 MHz | None | High | 39 mW | SN54LS293 | J, W | SN74LS293 | J, N |
|  | 30 MHz | Yes | Low | 60 mW | SN54LS197 | J, W | SN74LS197 | J, N |
| DIVIDE-BY-12 | 32 MHz | None | High | 39 mW | SN54LS92 | J, W | SN74LS92 | J, N |
| DUAL DECADE | 35 MHz | None | High | 75 mW | SN54LS390 | J, W | SN74LS390 | J, N |
|  | 35 MHz | Set-to-9 | High | 75 mW | SN54LS490 | J, W | SN74LS490 | J, N |
| DUAL 4-BIT BINARY | 35 MHz | None | High | 75 mW | SN54LS393 | J, W | SN74LS393 | J, N |

## SYNCHRONOUS COUNTERS - POSITIVE-EDGE TRIGGERED ${ }^{\dagger}$

| DESCRIPTION | COUNT FREQ | PARALLEL LOAD | CLEAR | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| DECADE | 40 MHz | Sync | Sync-L | 475 mW | SN54S162 | J, W | SN74S162 | J, N |
|  | 25 MHz | Sync | Sync-L | 93 mW | SN54LS162A | J, W | SN74LS162A | J, N |
|  | 25 MHz | Sync | Async-L | 93 mW | SN54LS160A | J, W | SN74LS160A | J, N |
| DECADE <br> UP/DOWN | 40 MHz | Sync | None | 500 mW | SN54S168 | J, W | SN74S168 | J, N |
|  | 25 MHz | Sync | None | 100 mW | SN54LS168A | J, W | SN74LS168A | J, N |
|  | 25 MHz | Async | Async-H | 85 mW | SN54LS192 | J, w | SN74LS192 | J, N |
|  | 20 MHz | Async | None | 100 mW | SN54LS190 | J, w | SN74LS190 | J, N |
| 4-BIT BINARY | 40 MHz | Sync | Sync-L | 475 mW | SN54S163 | J, W | SN74S163 | J, N |
|  | 25 MHz | Sync | Sync-L | 93 mW | SN54LS163A | J, w | SN74LS163A | J, N |
|  | 25 MHz | Sync | Async-L | 93 mW | SN54LS161A | J, w | SN74LS161A | J, N |
| 4-BIT BINARY UP/DOWN | 40 MHz | Sync | None | 500 mW | SN54S169 | J, W | SN74S169 | J, N |
|  | 25 MHz | Sync | None | 100 mW | SN54LS169A | J, W | SN74LS169A | J, N |
|  | 25 MHz | Async | Async-H | 85 mW | SN54LS193 | J, w | SN74LS193 | J, N |
|  | 20 MHz | Async | None | 90 mW | SN54LS191 | J, w | SN74LS191 | J, N |

[^24]
# SCHOTTKY TTL FUNCTIONS FUNCTIONAL INDEX/SELECTION GUIDE 

SHIFT REGISTERS ${ }^{\dagger}$

| DESCRIPTION | NO. <br> OF <br> BITS | SHIFT <br> FREQ | SERIAL <br> DATA <br> INPUT | ASYNC CLEAR | MODES |  |  |  | TYP TOTAL POWER• DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $\begin{aligned} & +\mathbf{+} \\ & \text { ¢ } \\ & \text { ed } \end{aligned}$ | $\begin{array}{\|r} +\underset{~+~}{c} \end{array}$ | $\begin{aligned} & 9 \\ & \hline 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & \underline{9} \\ & \underline{0} \\ & \underline{1} \end{aligned}$ |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| PARALLEL-IN, PARALLEL-OUT (BIDIRECTIONAL) |  | 50 MHz | D | Low | $\times$ | X | X | X | 750 mW | SN54S299 | J, W | SN74S299 | J, N |
|  | 8 | 35 MHz | D | Low | $x$ | $x$ | X | X | 175 mW | SN54LS299* | J | SN74LS299* | J, N |
|  |  | 35 MHz | D | Sync L | x | $x$ | X | x | 175 mW | SN54LS323* | J | SN74LS323* | J, N |
|  | 4 | 70 MHz | D | Low | X | $x$ | $\times$ | $x$ | 450 mW | SN54S194 | J, W | SN74S194 | $J, N$ |
|  |  | 25 MHz | D | Low | $x$ | $x$ | X | x | 75 mW | SN54LS194A | J, W | SN74LS194A | J, N |
| PARALLEL-IN, PARALLEL-OUT | 5 | 10 MHz | D | Low | X |  | X |  | 60 mW | SN54LS96 | J, W | SN74LS96 | $J, N$ |
|  | 4 | 70 MHz | J-K | Low | X |  | X |  | 375 mW | SN54S195 | J, W | SN74S195 | J, N |
|  |  | 30 MHz | D | Low | X |  | x |  | 75 mW | SN54LS395A | J, W | SN74LS395A | J, N |
|  |  | 30 MHz | J-K | Low | X |  | x |  | 70 mW | SN54LS195A | J, W | SN74LS195A | J, N |
|  |  | 30 MHz | D | None | X |  | x |  | 65 mW | SN54LS95B | J, W | SN74LS95B | $J, N$ |
|  |  | 25 MHz | D | None | X |  | X |  | 70 mW | SN54LS295B | J, W | SN74LS295B | J, N |
| SERIAL-IN, PARALLEL-OUT | 8 | 25 MHz | Gated D | Low | X |  |  |  | 80 mW | SN54LS164 | J, W | SN74LS164 | J, N |
| PARALLEL-IN, | 8 | 35 MHz | D | None | X |  | X | X | 105 mW | SN54LS165 | J, W | SN74LS165 | J, N |
| SERIAL-OUT |  | 35 MHz | D | Low | X |  | X | X | 110 mW | SN54LS166 | J, W | SN74LS166 | J, N |
| SERIAL-IN, SERIAL-OUT | 8 | 25 MHz | Gated D | None | X |  |  |  | 60 mW | SN54L.S91 | J, W | SN74LS91 | J, N |

$\ddagger$ S-R $\equiv$ shift right, S-L $\equiv$ shift left

OTHER REGISTERS ${ }^{\dagger}$

| DESCRIPTION | FREQ | ASYNC CLEAR | TYP TOTAL POWER DISSIPATION | DEVICE TYPE <br> AND PACKAGE |  |  |  | SEC. <br> PAGE <br> NO. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  |
| QUADRUPLE MULTIPLEXERS | 30 MHz . | None | 36.5 mW | SN54LS398 | J | SN74LS398 | J, N | $\dagger$ |
|  | 30 MHz | None | 36.5 mW | SN54LS399 | J, w | SN74LS399 | J, N | $\dagger$ |
|  | 25 MHz | None | 65 mW | SN54LS298 | J, w | SN74LS298 | J, N | $\pm$ |
| 8-BIT UNIVERSAL SHIFT/STORAGE | 35 MHz | Low | 175 mW | SN54LS299* | J | SN74LS299* | J, N | $\dagger$ |
| REGISTERS | 50 MHz | Low | 750 mW | SN54S299 | J, w | SN74S299 | J, N | 5-9 |
| QUADRUPLE BUS-BUFFER REGISTERS | 50 MHz | High | 85 mW | SN54LS173* | J, W | SN74LS173* | J, N | + |

PRIORITY ENCODERS/REGISTERS ${ }^{\dagger}$

| DESCRIPTION | TYPICAL DELAY TIME | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| FULL BCD PRIORITY ENCODERS | 15 ns | 60 mW | SN54LS147 | J, W | SN74LS147 | J, N |
| CASCADABLE OCTAL PRIORITY ENCODERS | 15 ns | 60 mW | SN54LS148 | J, W | SN74LS148 | J, N |
| CASCADABLE OCTAL PRIORITY ENCODERS WITH 3-STATE OUTPUTS | 16 ns | 63 mW | SN54LS348 | J, W | SN74LS348 | J, N |

[^25]
## LATCHES ${ }^{\dagger}$

| DESCRIPTION | NO. OF BITS | CLEAR | OUTPUTS | TYPICAL DELAY TIME | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  | SEC.PAGE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to 12 | $5^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ}$ |  |  |
| MULTI-MODE BUFFERED | 8 | Low | Q | 11 ns | 410 mW | SN54S412 | J | SN74S412 | J, N | $\dagger$ |
| ADDRESSABLE | 8 | Low | Q | 17 ns | 110 mW | SN54LS259 | J, W | SN74LS259 | J, N | $\dagger$ |
| TRANSPARENT | 8 | None <br> None <br> None | $\begin{aligned} & \mathrm{Q} \\ & \mathrm{Q} \\ & \mathrm{Q} \\ & \hline \end{aligned}$ | $\begin{array}{r} 17 \mathrm{~ns} \\ 19 \mathrm{~ns} \\ 7 \mathrm{~ns} \\ \hline \end{array}$ | $\begin{aligned} & 210 \mathrm{~mW} \\ & 120 \mathrm{~mW} \\ & 525 \mathrm{~mW} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { SN54LS363* } \\ & \text { SN54LS373 } \\ & \text { SN54S373 } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{J} \\ & \mathrm{~J} \\ & \mathrm{~J} \end{aligned}$ | SN74LS363* SN74LS373 SN74S373 | $\begin{aligned} & J, N \\ & J, N \\ & J, N \end{aligned}$ | $\begin{gathered} t \\ t \\ 5-26 \\ \hline \end{gathered}$ |
| DUAL 2-BIT WITH INDEPENDENT ENABLE | 4 | None <br> None <br> None | $\begin{gathered} \mathrm{Q}, \overline{\mathrm{Q}} \\ \mathrm{Q} \\ \mathrm{Q}, \overline{\mathrm{Q}} \end{gathered}$ | $\begin{aligned} & 11 \mathrm{~ns} \\ & 10 \mathrm{~ns} \\ & 12 \mathrm{~ns} \end{aligned}$ | 32 mW <br> 35 mW <br> 32 mW | $\begin{aligned} & \text { SN54LS75 } \\ & \text { SN54LS77 } \\ & \text { SN54LS375 } \end{aligned}$ | $\begin{gathered} \mathrm{J}, \mathrm{~W} \\ \mathrm{~W} \\ \mathrm{~J}, \mathrm{~W} \end{gathered}$ | SN74LS75 <br> SN74LS375 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ | $\begin{aligned} & \dagger \\ & \dagger \\ & \dagger \end{aligned}$ |
| QUAD $\overline{\mathrm{s}}$ - $\overline{\mathrm{R}}$ (SSI) | 4 | None | Q | 13 ns | 19 mW | SN54LS279 | J,W | SN74LS279 | J, N | $\dagger$ |

## $\overline{\mathbf{S}}$ - $\overline{\mathrm{R}}$ LATCHES ${ }^{\dagger}$

| DESCRIPTION | TYPICAL PROPAGATİON DELAY TIME | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| QUADRUPLE $\bar{S}-\bar{R}$ LATCHES | 13 ns | 19 mW | SN54LS279 | J, W | SN74LS279 | J, N |

MONOSTABLE MULTIVIBRATORS WITH SCHMITT-TRIGGER INPUTS ${ }^{\dagger}$

| DESCRIPTION | NO. OF INPUTS |  | OUTPUT <br> PULSE <br> RANGE | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | POSITIVE | NEGATIVE |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| DUAL | $\begin{aligned} & \hline 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline 20 \mathrm{~ns}-70 \mathrm{~s} \\ & 20 \mathrm{~ns}-49 \mathrm{~s} \\ & \hline \end{aligned}$ | 23 mW <br> 23 mW | SN54LS221 | J, W | SN74LS221 | J, N |

RETRIGGERABLE MONOSTABLE MULTIVIBRATORS ${ }^{\dagger}$

| DESCRIPTION | NO. OF INPUTS |  | DIRECT CLEAR | OUTPUT PULSE RANGE | TYP TOTAL POWER | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | POSITIVE | NEGATIVE |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| SINGLE | 2 | 2 | Yes | $45 \mathrm{~ns}-\infty$ | 30 mW | SN54LS122 | J, W | SN74LS122 | J, N |
| DUAL | 1 | 1 | Yes | $45 \mathrm{~ns}-\infty$ | 60 mW | SN54LS123 | J, W | SN74LS123 | J, N |

CLOCK GENERATOR CIRCUITS ${ }^{\dagger}$

| DESCRIPTION | TYP TOTAL POWER DISSIPATION | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| CLOCK GENERATOR/DRIVERS (FOR TMS 9900) <br>  (FOR TMS 8080A) | $\begin{aligned} & 669 \mathrm{~mW} \\ & 719 \mathrm{~mW} \end{aligned}$ |  |  | SN74LS362 <br> SN74LS424 | $\begin{aligned} & J, N \\ & J, N \end{aligned}$ |
| DUAL VOLTAGE-CONTROLLED OSCILLATOR WITH ENABLE | $\begin{array}{r} 90 \mathrm{~mW} \\ 525 \mathrm{~mW} \\ 90 \mathrm{~mW} \end{array}$ | SN54LS124 <br> SN54S124 <br> SN54LS326 | $\begin{aligned} & \mathrm{J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \end{aligned}$ | SN74LS124 <br> SN74S124 <br> SN74LS326 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ |
| DUAL VOLTAGE-CONTROLLED OSCILLATOR | 150 mW 150 mW | SN54LS325 <br> SN54LS327 | $\begin{aligned} & \mathrm{J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \end{aligned}$ | SN74LS325 <br> SN74LS327 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ |
| VOLTAGE-CONTROLLED OSCILLATOR WITH ENABLE | 90 mW | SN54LS324 | J, W | SN74LS324 | J, N |

[^26]
# SCHOTTKY TTL FUNCTIONS FUNCTIONAL INDEX/SELECTION GUIDE 

AND-OR-INVERT GATES WITH TOTEM-POLE OUTPUTS ${ }^{\dagger}$

| DESCRIPTION | TYPICAL PROPAGATION DELAY TIME | TYP POWER DISSIPATION PER GATE | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| 2-WIDE 4-INPUT | 12.5 ns | 2.75 mW | SN54LS55 | J, W | SN74LS55 | J, N |
| 4-WIDE 4-2-3-2-INPUT | 3.5 ns | 29 mW | SN54S64 | J, W | SN74S64 | J, N |
| 4-WIDE 2-3-3-2-INPUT | 12.5 ns | 4.5 mW | SN54LS54 | J, W | SN74LS54 | J, N |
| DUAL 2-WIDE 2-INPUT | 3.5 ns | 28 mW | SN54S51 | J, W | SN74S51 | J, N |
|  | 12.5 ns | 2.75 mW | SN54LS51 | J, W | SN74LS51 | J, N |

AND-OR-INVERT GATES WITH OPEN-COLLECTOR OUTPUTS ${ }^{\dagger}$

| DESCRIPTION | TYPICAL PROPAGATION DELAY TIME | TYP POWER DISSIPATION PER GATE | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| 4WIDE 4-2-3-2-INPUT | 5.5 ns | 36 mW | SN54S65 | J, W | SN74S65 | $J, N$ |

DUAL J-K EDGE-TRIGGERED FLIP-FLOPS $\dagger$


| DWG. REF. | TYPICAL CHARACTERISTICS |  | DATA TIMES |  | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & f_{\max } \\ & (\mathrm{MHz}) \end{aligned}$ | $\begin{gathered} \text { Pwr/F-F } \\ (\mathrm{mW}) \end{gathered}$ | SETUP <br> (ns) | $\begin{gathered} \text { HOLD } \\ \text { (ns) } \end{gathered}$ |  |  |  |  |
|  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| A | 125 | 75 | $3 \downarrow$ | O $\downarrow$ | SN54S112 | J, W | SN74S112 | J, N |
|  | 45 | 10 | $20 \downarrow$ | - $\downarrow$ | SN54LS76A | J, W | SN74LS76A | J, N |
|  | 45 | 10 | $20 \downarrow$ | O $\downarrow$ | SN54LS112A | J, W | SN74LS112A | J, N |
| B | 125 | 75 | $3 \downarrow$ | O $\downarrow$ | SN54S114 | J, W | SN74S114 | J, N |
|  | 45 | 10 | 20ね | O $\downarrow$ | SN54LS78A | J, W | SN74LS78A | J, N |
|  | 45 | 10 | 20 $\downarrow$ | O $\downarrow$ | SN54LS114A | J, W | SN74LS114A | J, N |
| C | 125 | 75 | $3 \downarrow$ | O $\downarrow$ | SN54S113 | J, W | SN74S113 | J, N |
|  | 45 | 10 | 20 $\downarrow$ | O $\downarrow$ | SN54LS113A | J, W | SN74LS113A | J, N |
| D | 45 | 10 | 20】 | O $\downarrow$ | SN54LS73A | J, W | SN74LS73A | J, N |
|  | 45 | 10 | 20 $\downarrow$ | 0 $\downarrow$ | SN54LS107A | J | SN74LS107A | J, N |
| E | 33 | 10 | $20 \uparrow$ | $5 \uparrow$ | SN54LS109A | J, W | SN74LS109A | J, N |

[^27]BUFFER AND INTERFACE GATES WITH OPEN-COLLECTOR OUTPUTS $\dagger$

| DESCRIPTION | HIGH-LEVEL OUTPUT VOLTAGE | LOW-LEVEL OUTPUT CURRENT | TYPICAL DELAY TIME | TYP POWER PER GATE | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| QUADRUPLE <br> 2-INPUT <br> POSITIVE-NAND <br> BUFFERS | 15 V | 8 mA | 16 ns | 2 mW |  |  | SN74LS26 | J, N |
|  | 15 V | 4 mA | 16 ns | 2 mW | SN54LS26 | J, W |  |  |
|  | 5.5 V | 60 mA | 6.5 ns | 41 mW | SN54S38 | J, W | SN74S38 | J, N |
|  | 5.5 V | 24 mA | 19 ns | 4.3 mW |  |  | SN74LS38 | J, N |
|  | 5.5 V | 12 mA | 19 ns | 4.3 mW | SN54LS38 | J, W |  |  |
| QUADRUPLE | 5.5 V | 24 mA | 19 ns | 5.45 mW |  |  | SN74LS33 | J, N |
| NOR BUFFERS | 5.5 V | .12 mA | 19 ns | 5.45 mW | SN54LS33 | J, W |  |  |

GATES, BUFFERS, DRIVERS, AND BUS TRANSCEIVERS WITH 3-STATE OUTPUTS ${ }^{\dagger}$

| DESCRIPTION | TYPICAL PROPAGATION DELAY TIME | MAXIMUM SOURCE CURRENT | MAXIMUM SINK CURRENT | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| 12-INPUT NAND GATE | $\begin{aligned} & 4.5 \mathrm{~ns} \\ & 4.5 \mathrm{~ns} \end{aligned}$ | $\begin{array}{r} -6.5 \mathrm{~mA} \\ -2 \mathrm{~mA} \\ \hline \end{array}$ | $\begin{aligned} & 20 \mathrm{~mA} \\ & 20 \mathrm{~mA} \\ & \hline \end{aligned}$ | SN54S134 | J, W | SN74S134 | J, N |
| QUADRUPLE BUS BUFFERS/DRIVERS WITH INDEPENDENT OUTPUT CONTROLS | $\begin{array}{r} 8 \mathrm{~ns} \\ 8 \mathrm{~ns} \\ 8.5 \mathrm{~ns} \\ 8.5 \mathrm{~ns} \end{array}$ | $\begin{array}{r} -2.6 \mathrm{~mA} \\ -1 \mathrm{~mA} \\ -2.6 \mathrm{~mA} \\ -1 \mathrm{~mA} \end{array}$ | 24 mA <br> 12 mA <br> 24 mA <br> 12 mA | SN54LS125A <br> SN54LS126A | $\begin{aligned} & \mathrm{J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \end{aligned}$ | SN74LS125A <br> SN74LS126A | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ |
| HEX BUS BUFFERS/DRIVERS | 9.5 ns 9.5 ns 9.5 ns 9.5 ns 9.5 ns 9.5 ns 9.5 ns 9.5 ns | $\begin{array}{r} -2.6 \mathrm{~mA} \\ -1 \mathrm{~mA} \\ -2.6 \mathrm{~mA} \\ -1 \mathrm{~mA} \\ -2.6 \mathrm{~mA} \\ -1 \mathrm{~mA} \\ -2.6 \mathrm{~mA} \\ -1 \mathrm{~mA} \end{array}$ | $\begin{aligned} & 24 \mathrm{~mA} \\ & 12 \mathrm{~mA} \\ & 24 \mathrm{~mA} \\ & 12 \mathrm{~mA} \\ & 24 \mathrm{~mA} \\ & 12 \mathrm{~mA} \\ & 24 \mathrm{~mA} \\ & 12 \mathrm{~mA} \end{aligned}$ | SN54LS365A <br> SN54LS366A <br> SN54LS367A <br> SN54LS368A | $\begin{aligned} & \mathrm{J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \end{aligned}$ | SN74LS365A SN74LS366A SN74LS367A SN74LS368A | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ |
| OCTAL BUS BUFFERS/DRIVERS | 5 ns <br> 5 ns <br> 5 ns <br> 5 ns <br> 10 ns <br> 10 ns <br> 10 ns <br> 10 ns <br> 10 ns <br> 10 ns | $\begin{aligned} & -15 \mathrm{~mA} \\ & -12 \mathrm{~mA} \\ & -15 \mathrm{~mA} \\ & -12 \mathrm{~mA} \\ & -15 \mathrm{~mA} \\ & -12 \mathrm{~mA} \\ & -15 \mathrm{~mA} \\ & -12 \mathrm{~mA} \\ & -15 \mathrm{~mA} \\ & -12 \mathrm{~mA} \end{aligned}$ | 64 mA 48 mA 64 mA 48 mA 24 mA <br> 12 mA <br> 24 mA <br> 12 mA <br> 24 mA <br> 12 mA | SN54S240 <br> SN54S241 <br> SN54LS240 <br> SN54LS241 <br> SN54LS244 | J <br> J <br> J <br> J <br> J | SN74S240 <br> SN74S241 <br> SN74LS240 <br> SN74LS241 <br> SN74LS244 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ |
| CONTROLLER AND BUS DRIVER FOR 8080A SYSTEMS |  | $-1 \mathrm{~mA}$ <br> $-1 \mathrm{~mA}$ | $\begin{aligned} & 10 \mathrm{~mA} \\ & 10 \mathrm{~mA} \end{aligned}$ |  |  | $\begin{aligned} & \text { SN74S428 } \\ & \text { SN74S438 } \end{aligned}$ | $\begin{aligned} & \mathrm{N} \\ & \mathrm{~N} \end{aligned}$ |
| QUADRUPLE TRANSCEIVERS | 11 ns <br> 11 ns <br> 12 ns <br> 12 ns | $\begin{aligned} & -15 \mathrm{~mA} \\ & -12 \mathrm{~mA} \\ & -15 \mathrm{~mA} \\ & -12 \mathrm{~mA} \\ & \hline \end{aligned}$ | 24 mA <br> 12 mA <br> 24 mA <br> 12 mA | SN54LS242 <br> SN54LS243 | $\begin{aligned} & \mathrm{J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \\ & \hline \end{aligned}$ | SN74LS242 <br> SN74LS243 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ |
| QUADRUPLE TRANSCEIVERS WITH STORAGE | $\begin{aligned} & 10 \mathrm{~ns} \\ & 10 \mathrm{~ns} \end{aligned}$ | $\begin{array}{r} -10.3 \mathrm{~mA} \\ -6.5 \mathrm{~mA} \end{array}$ | $\begin{aligned} & 20 \mathrm{~mA} \\ & 20 \mathrm{~mA} \end{aligned}$ | SN54S226 | J, W | SN74S226 | J, N |
| OCTAL TRANSCEIVERS | $\begin{aligned} & 12 \mathrm{~ns} \\ & 12 \mathrm{~ns} \end{aligned}$ | $\begin{aligned} & -15 \mathrm{~mA} \\ & -12 \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & 24 \mathrm{~mA} \\ & 12 \mathrm{~mA} \end{aligned}$ | SN54LS245 | $J$ | SN74LS245 | J, N |

[^28]
# SCHOTTKY TTL FUNCTIONS FUNCTIONAL INDEX/ SELECTION GUIDE 

BUFFERS;CLOCK DRIVERS WITH TOTEM-POLE OUTPUTS ${ }^{\dagger}$

| DESCRIPTION | LOW-LEVEL OUTPUT CURRENT | HIGH-LEVEL OUTPUT CURRENT | TYPICAL DELAY TIME | TYP POWER PER GATE | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| QUADRUPLE <br> 2-INPUT <br> POSITIVE-NOR <br> BUFFERS | $\begin{aligned} & 24 \mathrm{~mA} \\ & 12 \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & -1.2 \mathrm{~mA} \\ & -1.2 \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & 12 \mathrm{~ns} \\ & 12 \mathrm{~ns} \end{aligned}$ | 5.5 mW <br> 5.5 mW | SN54LS28 | J, W | SN74LS28 | J, N |
| QUADRUPLE <br> 2-INPUT <br> POSITIVE-NAND <br> BUFFERS | $\begin{aligned} & 60 \mathrm{~mA} \\ & 24 \mathrm{~mA} \\ & 12 \mathrm{~mA} \end{aligned}$ | $\begin{array}{r} -3 \mathrm{~mA} \\ -1.2 \mathrm{~mA} \\ -1.2 \mathrm{~mA} \end{array}$ | $\begin{array}{r} 4 \mathrm{~ns} \\ 12 \mathrm{~ns} \\ 12 \mathrm{~ns} \end{array}$ | 41 mW <br> 4.3 mW <br> 4.3 mW | SN54S37 <br> SN54LS37 | $\begin{aligned} & J, W \\ & J, W \end{aligned}$ | SN74S37 <br> SN74LS37 | $\begin{aligned} & J, N \\ & J, N \end{aligned}$ |
| DUAL 4-INPUT POSITIVE-NAND BUFFERS | $\begin{aligned} & 60 \mathrm{~mA} \\ & 24 \mathrm{~mA} \\ & 12 \mathrm{~mA} \end{aligned}$ | $\begin{array}{r} -3 \mathrm{~mA} \\ -1.2 \mathrm{~mA} \\ -1.2 \mathrm{~mA} \\ \hline \end{array}$ | $\begin{array}{r} 4 \mathrm{~ns} \\ 12 \mathrm{~ns} \\ 12 \mathrm{~ns} \\ \hline \end{array}$ | $\begin{gathered} 44 \mathrm{~mW} \\ 4.3 \mathrm{~mW} \\ 4.3 \mathrm{~mW} \\ \hline \end{gathered}$ | SN54S40 <br> SN54LS40 | $\begin{aligned} & \mathrm{J}, \mathrm{~W} \\ & \mathrm{~J}, \mathrm{~W} \end{aligned}$ | SN74S40 <br> SN74LS40 | $\begin{aligned} & \mathrm{J}, \mathrm{~N} \\ & \mathrm{~J}, \mathrm{~N} \end{aligned}$ |

50-OHM/75-OHM LINE DRIVERS ${ }^{\dagger}$

| DESCRIPTION | LOW-LEVEL OUTPUT CURRENT | HIGH-LEVEL OUTPUT CURRENT | TYPICAL DELAY TIME | TYP POWER PER GATE | DEVICE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| DUAL 4-INPUT POSITIVE-NAND LINE DRIVERS | 60 mA | -40 mA | 4 ns | 44 mW | SN54S140 | J, W | SN74S140 | J, N |

OPEN-COLLECTOR DISPLAY DECODERS/DRIVERS ${ }^{\boldsymbol{\dagger}}$

| DESCRIPTION | OUTPUT SINK CURRENT | OFF-STATE OUTPUT VOLTAGE | TYP TOTAL POWER DISSIPATION | BLANKING | DEVÍCE TYPE AND PACKAGE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| BCD-TO-DECIMAL | 80 mA | 15 V | 35 mW | Invalid Codes |  |  | SN74LS145 | J, N |
| DECODERS/DRIVERS | 12 mA | 15 V | 35 mW | I Invalid Codes | SN54LS145 | J, W |  |  |
|  | 24 mA | 15 V | 35 mW | Ripple |  |  | SN74LS47 | J, N |
|  | 24 mA | 15 V | 35 mW | Ripple |  |  | SN74LS247 | J, N |
|  | 12 mA | 15 V | 35 mW | Ripple | SN54LS47 | J, W |  |  |
|  | 12 mA | 15 V | 35 mW | Ripple | SN54LS247 | J, W |  |  |
| TO- | 6 mA | 5.5 V | 125 mW | Ripple |  |  | SN74LS48 | J, N |
| SEVEN-SEGMENT | 6 mA | 5.5 V | 125 mW | Ripple |  |  | SN74LS248 | J, N |
|  | 2 mA | 5.5 V | 125 mW | Ripple | SN54LS48 | J, W |  |  |
| Decoders/Drivers | 2 mA | 5.5 V | 125 mW | Ripple | SN54LS248 | J, W |  |  |
|  | 8 mA | 5.5 V | 40 mW | Direct |  |  | SN74LS249 | J, N |
|  | 8 mA | 5.5 V | 40 mW | Direct |  |  | SN74LS49 | J, N |
|  | 4 mA | 5.5 V | 40 mW | Direct | SN54LS49 | J, W |  |  |
|  | 4 mA | 5.5 V | 40 mW | Direct | SN54LS249 | J, W |  |  |

[^29]SCHOTTKY TTL GATE SUMMARY $\dagger$

| DESCRIPTION | AND | NAND | NOR | OR |
| :---: | :---: | :---: | :---: | :---: |
| QUAD 2-INPUT | SN54S/74S08 SN54LS/74LS08 SN54S/74S09* SN54LS/74LS09* | $\begin{aligned} & \hline \text { SN54S/74S00 } \\ & \text { SN54LS/74LS00 } \\ & \text { SN54S/74S03* } \\ & \text { SN54LS/74LS03* } \\ & \text { SN54S/74S132 } \quad \text { T } \\ & \text { SN54LS/74LS132 } \quad \text { T } \end{aligned}$ | SN54S/74S02 SN54LS/74LS02 | SN54S/74S32 SN54LS/74LS32 |
| HEX INVERTERS |  | SN54S/74S04 SN54LS/74LS04. <br> SN54S/74S05* <br> SN54LS/74LS04* <br> SN54LS/74LS14. $\quad$ T |  |  |
| TRIPLE 3-INPUT | SN54S/74S11 <br> SN54LS/74LS11 <br> SN54S/74S15* <br> SN54LS/74LS15* | $\begin{aligned} & \hline \text { SN54S/74S10 } \\ & \text { SN54LS/74LS10 } \\ & \text { SN54LS/74LS12* } \end{aligned}$ | SN54LS/74LS27 |  |
| DUAL 4-INPUT | SN54LS/74LS21 | SN54S/74S20 <br> SN54LS/74LS20 <br> SN54S/74S22* <br> SN54LS/74LS22* <br> SN54LS/74LS13 ワT |  |  |
| DUAL 5-INPUT |  |  | SN54S/74S260 |  |
| 8-INPUT |  | $\begin{aligned} & \text { SN54S/74S30 } \\ & \text { SN54LS/74LS30 } \end{aligned}$ |  |  |
| 13-INPUT |  | SN54S/74S133 |  |  |

tSee the TTL Data Book for Design Engineers, Second Edition, LCC4112.
$\sigma_{\text {Schmitt-trigger inputs }}$
*Open-Collector


[^0]:    $\dagger^{\text {Integrated S Shottky-Barrier diode- }}$ 1277 clamped transistor is patented by Texas Instruments. U. S. Patent Number 3,463,975.

[^1]:    * Current out of a terminal is given as a negative value.

[^2]:    NOTE: When PC PRIORITY is low WR $\rightarrow$ AOP

[^3]:    ${ }^{\dagger}$ Absolute maximum ratings.
    NOTES: 1. Voltage values are with respect to network ground terminal. The supply-voltage rating does not apply during programming.
    2. The 'S188, 'S288, 'S470, 'S471, 'S472, 'S473, 'S474, and 'S475 are supplied with all bit locations containing a low logic level, and programming a bit changes the output of the bit to high logic level. The ' S 287 and ' S 387 are supplied with all bit outputs at a high logic level, and programming a bit changes it to a low logic level.
    3. Programming is guaranteed if the pulse applied is $98 \mu$ in duration.

[^4]:    $\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}_{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.
    An SN54S287 in the W package operating at free-air temperatures above $108^{\circ} \mathrm{C}$ requires a heat sink that provides a thermal resistance from case-to-free-air, $R_{\theta C A}$, of not more than $42^{\circ} \mathrm{C} / \mathrm{W}$.
    NOTE 4: The typical values of I Cc shown are with all outputs low.

[^5]:    $\dagger^{\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}_{A}=25^{\circ} \mathrm{C}$.

    - A SN54S387 in the W package operating at free-air temperatures above $108^{\circ} \mathrm{C}$ requires a heat sink that provides a thermal resistance from case-to-free-air, $R_{\theta C A}$, of not more than $42^{\circ} \mathrm{C} / \mathrm{W}$.
    NOTE 4: The typical values of ICC shown are with all outputs low

[^6]:    ${ }^{\dagger}$ Integrated Schottky-Barrier diodeclamped transistor is patented by Texas 977 Instruments. U. S. Patent Number

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

[^8]:    $H \equiv$ high level, $L \equiv$ low level, $X \equiv$ irrelevant

[^9]:    ${ }^{\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}_{A}=25^{\circ} \mathrm{C}$.
    §Duration of the short circuit should not exceed one second.

[^10]:    $H \equiv$ high level, $L \equiv$ low level, $X \equiv$ irrelevant

[^11]:    NOTES: 1. Voltage values are with respect to network ground terminal.

[^12]:    IIntegrated Schottky-Barrier diodeclamped transistor is patented by Texas Instruments. U. S. Patent Number $3,463,975$.

[^13]:    ${ }^{\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}$.
    §Duration of the short circuit should not exceed one second.
    NOTE 3: ICC is measured with all inputs grounded and the output open.

[^14]:    are isolated from the input/output terminals.

[^15]:    ${ }^{\text {Data }}$ includes the two serial inputs and the eight input/output data lines.

[^16]:    $\dagger_{\text {Integrated Schottky-Barrier diode- }}$ clamped transistor is patented by Texas Instruments. U. S. Patent Number 3,463,975.

[^17]:    This document provides tentative information TEXAS INSTRUMENTS on a new product. Texas Instruments reserves the right to change specifications for this post office box 5012 . dallas. texas 75222 INCORPORATED

[^18]:    NOTES: a. All dimensions are shown in inches (and parenthetically in millimeters for reference only). Inch dimensions govern.
    b. Index point is provided on cap for terminal identification only.
    c. Leads are with in $0.005(0,13)$ radius of true position (T.P.) at maximum material condition.
    d. This dimension determines a zone within which all body and lead irregularities lie.
    e. Not applicable for solder-dipped leads.
    f. When solder-dipped leads are specified, dipped area extends from lead tip to within $0.050(1,27)$ of package body.
    g. End configuration of 24 -pin package is at the option of TI .

[^19]:    $\ddagger$ MIL-STD-883 level B processing.

[^20]:    ${ }^{\dagger}$ See the TTL Data Book for Design Engineers, Second Edition, LCC4112.

[^21]:    ${ }^{\dagger}$ See the TTL Data Book for Design Engineers, Second Edition, LCC4112.
    *New Product in development as of August 1977.

[^22]:    ${ }^{\dagger}$ See the TTL Data Book for Design Engineers, Second Edition, LCC4112.
    *New product in development as of August 1977.

[^23]:    ${ }^{\dagger}$ See the TTL Data Book for Design Engineers, Second Edition, LCC4112.
    § From clock.
    *New Product in development as of August 1977.

[^24]:    ${ }^{\dagger}$ See the TTL Data Book for Design Engineers, Second Edition, LCC4112.

[^25]:    ${ }^{\dagger}$ See the TTL Data Book for Design Engineers, Second Edition, LCC4112.
    *New product in development as of August 1977.

[^26]:    ${ }^{\dagger}$ See the TTL Data Book for Design Engineers, Second Edition, LCC4112.

[^27]:    $\uparrow \downarrow$ The arrow indicates the edge of the clock pulse used for reference: $\uparrow$ for the rising edge, $\downarrow$ for the falling edge.
    ${ }^{\dagger}$ See the TTL Data Book for Design Engineers, Second Edition, LCC4112.

[^28]:    ${ }^{\dagger}$ See the TTL Data Book for Design Engineers, Second Edition, LCC4112.

[^29]:    ${ }^{\dagger}$ See the TTL Data Book for Design Engineers, Second Edition, LCC4112.

