The Engineering Staff of
TEXAS INSTRUMENTS INCORPORATED
Semiconductor Group


## Bipolar

## Microcomputer

Components Data Book for Design Engineers

JANUARY 1977

## TI worldwide sales offices



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

First Edition

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

## 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 $1^{2} \mathrm{~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 SN54S/74S481, with a clock cycle time of 100 ns , is the industry's highest complexity Schottky TTL processor element, and the only bipolar micro/miacroprogrammable element featuring automatically sequenced iterative multiply and divide and cyclical-redundancy algorithms.

The SBP0400A and the SBP0401A, integrated injection logic ( ${ }^{2} \mathrm{~L}$ ) bit slices with complete $\mathrm{TTL} / \mathrm{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 SBP9900 microprocessor, a ruggedized monolithic 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, the SN54S/74S330/'S331.

A number of advanced high-complexity $\mathrm{I} / \mathrm{O}$ and interface circuits have been added to the series. Most of these $\mathrm{I} / \mathrm{O}$ and interface functions as well as a number of the other processor support functions are offered in space saving $\mathbf{2 0}$-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 TI 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.
†Integrated Schottky-Barrier diodeclamped transistor is patented by Toxes Instruments. U. S. Patent Number 3,463,975.

TEXAS INSTRRUMENTS
POST OFFICE EOX 5012 . DALLAS. TEXAS 75222 stage, and Toxas Instruments recorves the right to change these specifications in any manner, without notice.

NUMERICAL INDEX

| type numbers |  | SECTION | Page | TYPE NUMBERS |  | SECtion | Page |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SBP0400A |  | 2 | 1 | SN54S299 | SN74S299 | 5 | 9 |
| SBP0401A |  | 2 | 1 | SN54LS300A | SN74LS300A | 4 | 19 |
| SBP9900 |  | 3 | 1 | SN54S300A | SN74S300A | 4 | 19 |
| SN5488A | SN7488A | 4 | 7 | SN54S301 | SN74S301 | $\dagger$ |  |
| SN54186 | SN74186 | $\dagger$ |  | SN54LS302 | SN74LS302 | 4 | 19 |
| SN54187 | SN74187 | 4 | 7 | SN54LS314 | SN74LS314 | 4 | 25 |
| SN54S188 | SN74S188 | 4 | 1 |  | SN74S314A | 4 | 25 |
| SN54S189 | SN74S189 | 4 | 15 | SN54S314 | SN74S314 | 4 | 25 |
| SN54LS200A | SN74LS200A | 4 | 19 | SN54LS315 | SN74LS315 | 4 | 25 |
| SN54S200A | SN74S200A | 4 | 19 | SN54S330 | SN74S330 | 5 | 13 |
| SN54S201 | SN74S201 | $\dagger$ |  | SN54S331 | SN74S331 | 5 | 13 |
| SN54LS202 | SN74LS202 | 4 | 19 | SN54S370 | SN74S370 | 4 | 7 |
| SN54LS207 | SN74LS207 | 4 | 31 | SN54S371 | SN74S371 | 4 | 7 |
| SN54S207 | SN74S207 | 4 | 31 | SN54S373 | SN74S373 | 5 | 26 |
| SN54LS208 | SN74LS208 | 4 | 31 | SN54S374 | SN74S374 | 5 | 26 |
| SN54S208 | SN74S208 | 4 | 31 | SN54S387 | SN74S387 | 4 | 1 |
| SN54LS214 | SN74LS214 | 4 | 25 | SN54S400 | SN74S400 | 4 | 37 |
|  | SN74S214A | 4 | 25 | SN54S401 | SN74S401 | 4 | 37 |
| SN54S214 | SN74S214 | 4 | 25 | SN54S412 | SN74S412 | 5 | 30 |
| SN54LS215 | SN74LS215 | 4 | 25 |  | SN74S428 | 5 | 35 |
| SN54S225 | SN74S225 | 4 | 39 |  | SN74S438 | 5 | 35 |
| SN54S226 | SN74S226 | 5 | 1 | SN54S470 | SN74S470 | 4 | 1 |
| SN54S240 | SN74S240 | 5 | 5 | SN54S471 | SN74S471 | 4 | 1 |
| SN54S241 | SN74S241 | 5 | 5 | SN54S472 | SN74S472 | 4 | 1 |
| SN54S270 | SN74S270 | 4 | 7 | SN54S473 | SN74S473 | 4 | 1 |
| SN54S271 | SN74S271 | 4 | 7 | SN54S474 | SN74S474 | 4 | 1 |
| SN54S287 | SN74S287 | 4 | 1 | SN54S475 | SN74S475 | 4 | 1 |
| SN54S288 | SN74S288 | 4 | 1 | SN54S481 | SN74S481 | 1 | , |
| SN54S289 | SN74S289 | 4 | 15 | SN54S482 | SN74S482 | 5 | 41 |

$\dagger$ Not recommended for new designs. For data sheets, see The Semiconductor Memory Data Book for Design Engineers. For new designs, refer to section 4 of this manual for Tl's advanced Schottky PROM and RAM families.

## GLOSSARY <br> TTL TERMS AND DEFINITIONS

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

## GLOSSARY

TIL TERMS AND DEFINITIONS

## 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, $\mathrm{I}_{\mathrm{IH}}$
The current into* an input when a high-level voltage is applied to that input.
High-level output current, $I \mathrm{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.

[^0]
## GLOSSARY TTL TERMS AND DEFINITIONS

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}_{\mathrm{c}}(\mathrm{rd})$ (see note)
The time interval between the start and end of a read cycle.

## Read-write cycle time, $\mathbf{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, $\mathbf{t}_{\mathbf{c}}$ (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, th
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, $\mathbf{t P Z H}$ (or low level, $\mathbf{t P Z L}$ )
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

## ITL 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 threestate 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, tPLH
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, $\mathbf{t}_{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, $\mathbf{t s u}_{\mathbf{s u}}$
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.

## Transition Time

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

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}_{\mathbf{I 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{VOH}_{\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, VIK
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, VOL

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}+}$.

Off-state output voltage, VO(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, VO(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}}-$.

## EXPLANATION OF FUNCTION TABLES

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

| H | $=$ | high level (steady state) |
| :---: | :---: | :---: |
| L | $=$ | low level (steady state) |
| $\uparrow$ | = | transition from low to high level |
| $\downarrow$ | = | transition from high to low level |
| $\rightarrow$ | = | value/level or resulting value/level is routed to indicated destination |
| $n$ | = | 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 $\mathbf{Q}$ before the indicated steady-state input conditions were established |
| $\bar{O}_{0}$ | = | complement of $\mathrm{Q}_{0}$ or level of $\overline{\mathbf{Q}}$ before the indicated steady-state input conditions were established |
| $\mathrm{Q}_{\mathrm{n}}$ | = | level of $\mathbf{Q}$ before the most recent active transition indicated by $\downarrow$ or $\uparrow$ |
| $\sqrt{\square}$ | = | one high-level pulse |
| $\square$ | $=$ | one low-level pulse |
| TOGGLE | $=$ | each output changes to the complement of its previous level on each active transition indicated by $\downarrow$ or $\uparrow$. |

The Engineering Staff of
TEXAS INSTRUMENTS INCORPORATED
Semiconductor Group


NOVEMBER 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 © 1976
Texas Instruments Incorporated

## 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 - AI 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 (A:B or B: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
5. MECHANICAL DATA ..... 50
6. PIN ASSIGNMENTS ..... 50

## 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 I - Arithmetic Operations: A Plus B Plus ALUCIN $\rightarrow\left\{\begin{array}{c}\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
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 Summary ..... 29
Table 19 Recommended Operating Conditions ..... 48
Table 20 Electrical Characteristics ..... 49
Table 21 Switching Characteristics ..... 49

## 1. INTRODUCTION

### 1.1 ARCHITECTURAL FEATURES

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

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

Primary among the ' $\mathbf{S 4 8 1}$ 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 of the 'S481, coupled with its macroprogrammable multiply and divide algorithms, make the 'S481 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 microcycle. Some other operational features are:

- Simultaneous one-clock compound operations with status can reduce microcycles and improve throughput
- Pre-programmed multiply, divide, and CRG algorithms
- $\quad$ Performs $\mathbf{1 6}$-bit by $\mathbf{1 6}$-bit double-precision divide in less than 3 microseconds
- 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

The 'S481 is supplied in a high-density 48 -pin package with the qud pin rows formed on 600 - and 800 -mil centers. Within each of the four rows pin spacing is 100 -mils, center-to-center. See mechanical data for detailed dimensions.

## design goal

TABLE 1
FUNCTIONAL DESCRIPTIONS

| PIN NUMBER | PIN NAME | PIN FUNCTION | INPUT, OUTPUT, OR INPUT/OUTPUT |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & 46,47 \\ & 1,2 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{BI} / \mathrm{OO}, \mathrm{BI} / \mathrm{O1} \\ & \mathrm{BI} / \mathrm{O2}, \mathrm{BI} / \mathrm{O} \end{aligned}$ | 4-bit parallel data input port to the $\mathbf{B}$ latch, or 4 -bit parallel data output for the - -bus when not being used as an input. | Inputs/Outputs |
| $\begin{aligned} & 6,5 \\ & 4,3 \end{aligned}$ | $\begin{aligned} & A 10, A 11 \\ & A 12, A 13 \end{aligned}$ | 4-bit parallel data input port to the A latch and WR. | Inputs |
| $\begin{aligned} & \hline 7,8 \\ & 9,10 \\ & 17,14 \\ & 13,11 \\ & 15,16 \end{aligned}$ | $\begin{aligned} & \text { OPO, OP1 } \\ & \text { OP2, OP3 } \\ & \text { OP4, OP5 } \\ & \text { OP6, OP7 } \\ & \text { OP8, OP9 } \end{aligned}$ | 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 | $V_{\text {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 $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 | COUT | Outputs low-active ripple carry data. | Output |
| 23 | EQ | Outputs true (active-high) equality of $2^{\prime \prime}$ bus equals zero for each 4-bit slice. The open-collector output permits wire-AND to achieve N $\times 4$-bit equality output. | Open-Collector-Output |
| 24 | LDWR | When low, data applied at the Al port coincident with the $\uparrow$ clock transition is loaded into the WR. | Input |
| $\begin{aligned} & 26 \\ & 25 \end{aligned}$ | WRRT, WRLFT | Working register and $\dot{\text { L-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/0 |
| $\begin{aligned} & 28 \\ & 27 \end{aligned}$ | XWRRT, <br> 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/0 |
| $\begin{aligned} & 29 \\ & 30 \end{aligned}$ | $\begin{aligned} & \hline \text { D0 } \\ & \text { D1 } \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 { DOPO } \\ & \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 CCT on the next $\uparrow$ clock transition. When high, inhibits MC to hold mode. As CCO 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{C C O}$ 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{aligned} & 38,39 \\ & 40,41 \end{aligned}$ | $\begin{aligned} & \text { AOPO, AOP1 } \\ & \text { AOP2, AOP3 } \end{aligned}$ | 4-bit parallel address-out port. | Outputs |
| 42 | AO | Selects one of two AOP sources (PC or MC). | Input |
| 43 | 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 | CCl | In least-significant position, a low input directs enabled PC or enabled MC to increment by one on next I 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 BI/O to output 之'bus data. When high, the BI/O output drivers are placed in a high-impedance state permitting BI/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 |
| :---: | :---: |
| 23.6 V | MOST-SIGNIFICANT POSITION (MSP) |
| 1.8 t 03 V |  |
| $<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/O 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{C C O}$ (OUT) | $\overline{C C O}$ (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 ' $S 481$ 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.

### 2.5 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 'S481 by minimizing the active components needed to achieve both the simple but highly flexible data routing tasks and full ALU capabilities.


B OPERAND SOURCES
B INPUT/OUTPUT
B INPUT/OUTPUT SELECTIONS


FIGURE 4 - ALU OPERAND SOURCES

### 2.6 ARITHMETIC/LOGIC UNIT (ALU)

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 ' S 481 at minimum logic/gate levels, this architecture permits fully symmetrical operations to be performed on the $\mathbf{A}$ or $\mathbf{B}$ sources within the selections offered by these 'S481 arithmetic/logical operation forms.

TABLE 5
'SA81 ALU AND LOGIC FUNCTIONS

| DATA INPUT |  | TWO'S COMPLEMENT INTEGER ARITHMETIC OP'S |  | LOGICAL OP'S (FORM VIII) CIN = HORL |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 | A | A |
| A | ONES | A | A MINUS 1 | ONES | zeros | A |
| A | ZEROS | MINUS A | MINUS A MINUS 1 | A | A | A |
| A | ONES | MINUS A MINUS 1 | MINUS A MINUS 2 | ONES | zeros | A |
| zeros | B | B PLUS 1 | B | B | B | E |
| ONES | B | B | B MINUS 1 | ONES | zeros | B |
| ZEROS | $\bar{B}$ | MINUS B | MINUS 8 MINUS 1 | B | B | B |
| ONES | $\bar{B}$ | MINUS B MINUS 1 | MINUS B MINUS 2 | ONES | zeros | $\overline{\text { B }}$ |
| A | B | A PLUS B PLUS 1 | A PLUS B | $A+B$ | $\overline{\mathbf{A}} \cdot \overline{\mathbf{B}}$ | $\overline{A \oplus B}$ |
| A | E | 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 | $\bar{A}+B$ | A $\cdot \overline{\text { B }}$ | $A \oplus B$ |
| $\overline{\text { A }}$ | $\overline{8}$ | MINUS A MINUS B MINUS 1 | MINUS A MINUS B MINUS 2 | $\bar{A}+\mathbf{B}$ | A. B | $\overline{A+8}$ |

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

| FORM NO. | FUNCTION |
| :---: | :---: |
| 1 | $A(A L U) B \cdot$ WR |
|  | $A(A L U) B \cdot X W R$ |
|  | $A(A L U) B \cdot P C$ |
| 11 | $A(A L U)$ B DOUBLE-PRECISION SHIFTED LOGICAL LEFT OR RIGHT |
| 111 | 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 \cdot \mathrm{BUS} \neq \mathrm{ZERO}(E Q=L)$ |
| III (ARITH WITH SHIFT) | LSL, RSL | £-BUS $\neq$ ZERO ( ${ }^{\text {( }}$ ( $=$ L) |
|  | LSA or RSA | ADDER C-OUT |
| IV, V, or VI (SHIFTS) | ALL | AI $\neq$ ZERO $(E Q=L)$ |
| VII (COMPARE) | A: B | A IS LG THAN B |
|  | B: A | B IS LG THAN A |
| VIII (LOGICAL) | ALL | $\Sigma$-BUS $\neq$ ZERO ( $\quad$ ( $)=L$ ) |
| IX (NO OP) | ZERO L-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 \cdot$ BUS $=0$ | $\overline{\mathrm{C}-\mathrm{IN}}$ | c-BUS $\neq 0$ | E-BUS $>0$ | E-BUS $=0$ | $\overline{\mathrm{C} \cdot \mathrm{IN}}$ |
| ARITHMETIC OPERATIONS: |  |  |  |  |  |  |  |  |
| SUBTRACTION WITH LSA OR RSA | X | $Y$ | $\mathrm{E} \cdot \mathrm{BUS}=1$ 's | $\overline{\mathrm{COUT}}$ | ADDER C-OUT | MINUEND + C-IN IS AG THAN SUBTRAHEND | E-BUS $=1$ 's | C-OUT |
| ALL OTHER ARITHMETIC | x | Y | $\Sigma$-BUS $=0$ | $\overline{\mathrm{C}-\mathrm{OUT}}$ | £-BUS $\neq 0$ | $\Sigma$-BUS $>0$ | $\Sigma-$ BUS $=0$ | 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{C C O}$ ) 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 |
| III (ARITH WITH SHIFT) | LSL, RSL | ALU OVERFLOW |
|  | RSA | $\mathrm{OV}=\mathrm{L}$ |
|  | LSA | NEXT CLOCK WILL CAUSE SHIFT OVERFLOW |
| IV, V, or VI (SHIFTS) | LSA | NEXT CLOCK WILL CAUSE SHIFT OVERFLOW |
|  | ALL OTHERS | $O V=L$ |
| VII (COMPARE) | A : B | UNDEFINED |
|  | B : A | UNDEFINED |
| VIII (LOGICAL) | ALL | $\mathrm{OV} \equiv \mathrm{L}$ |
| IX (NO OP) | ZERO L-BUS | $\mathrm{OV} \equiv \mathrm{L}$ |
| $\times$ THRU XIV | HARDWIRED ALGORITHMS | SEE OPERATION FORM DESCRIPTIONS |

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


TO: DO MUX, PC, MC, WR MUX, XWR MUX, 3-STATE 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 $1 / 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.
2.10 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 M U X$ ), or B-input multiplexer ( $B M U X$ ). 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.


FIGURE 10 - WORKING REGISTER (WR) AND WR MULTIPLEXER
An asynchronous control line, $\overline{\text { LDWR, }}$, 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.

### 2.13 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 M U X$ ), B-input multiplexer ( $B$ MUX), 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 $\Sigma$ '-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. 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 MODE | MOST－SIGNIFICANT POSITION |  |  |  | INTERMEDIATE POSITION |  |  |  | LEAST－SIGNIFICANT POSITION |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | WRLFT | WRLFT＇ | WRRT＇ | WRRT | WRLFT | WRLFT＇ | WRRT＇ | WRRT | WRLFT | WRLFT＇ | WRRT＇ | WRRT |
| LSL（SP） | 2 | $x$ | WRRT | $z$ | WR3 | $x$ | WRRT | $z$ | WR3 | $x$ | WRRT | 2 |
| LSL（DP） | XWR3 | $x$ | WRRT | Z | WR3 | $x$ | WRRT | Z | WR3 | $x$ | WRRT | Z |
| LSA（SP） | WR3 | $\times$ | WRRT | 2 | WR3 | $x$ | WRRT | 2 | WR3 | X | L | z |
| LSA（DP） | XWR3 | $x$ | WRRT | 2 | WR3 | $x$ | WRRT | Z | WR3 | $x$ | WRRT | $z$ |
| LCIR（SP） | WR3 | X | WRRT | Z | WR3 | $x$ | WRRT | Z | WR3 | X | WRRT | 2 |
| LCIR（DP） | XWR3 | $x$ | WRRT | z | WR3 | $x$ | WRRT | 2 | WR3 | $x$ | WRRT | 2 |
| RSL（SP） | 2 | WRLFT | $x$ | WRO | Z | WRLFT | X | WRO | Z | WRLFT | X | 2 |
| RSL（DP） | 2 | L | $x$ | WRO | 2 | WRLFT | $x$ | WRO | 2 | WRLFT | x | WRO |
| RSA（SP） | 2 | WR3 | X | WRO | Z | WRLFT | $x$ | WRO | Z | WRLFT | X | WRO |
| RSA（DP） | 2 | WR3 | $x$ | WRO | z | WRLFT | $x$ | WRO | 2 | WRLFT | X | WRO |
| RCIR（SP） | 2 | WRLFT | X | WRO | $z$ | WRLFT | X | WRO | 2 | 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） | z | $x$ | WRRT | z | 23 | X | WRRT | 2 | こ3 | $x$ | WRRT | 2 |
| LSL（DP） | XWR3 | $x$ | WRRT | $z$ | $\stackrel{3}{ }$ | X | WRRT | 2 | $\pm 3$ | $x$ | WRRT | 2 |
| LSA（SP） | $こ 3$ | X | WRRT | z | $\stackrel{\checkmark}{ }$ | X | WRRT | 2 | $\because 3$ | X | L | 2 |
| LSA（DP） | XWR3 | $x$ | WRRT | 2 | こ．3 | $x$ | WRRT | 2 | $\stackrel{3}{3}$ | $x$ | WRRT | 2 |
| LCIR（SP） | 23 | $x$ | WRRT | Z | こ3 | X | WRRT | 2 | －3 | X | WRRT | 2 |
| LCIR（DP） | XWR3 | $\times$ | WRRT | Z | 23 | X | WRRT | 2 | $\geq 3$ | $x$ | WRRT | 2 |
| RSL（SP） | 2 | WRLFT | $\times$ | こ0 | Z | WRLFT | X | －0 | Z | WRLFT | X | $\Sigma 0$ |
| RSL（DP） | 2 | C．OUT | X | こ0 | 2 | WRLFT | $x$ | こ0 | z | WRLFT | $x$ | － 0 |
| RSA（SP） | 2 | ＊ | X | $\because 0$ | 2 | WRLFT | X | こ0 | Z | WRLFT | X | と0 |
| RSA（DP） | $z$ | ＊ | $x$ | －0 | 2 | WRLFT | $x$ | こ0 | z | WRLFT | $x$ | s0 |
| RCIR（SP） | Z | WRLFT | X | co | Z | WRLFT | X | $\Sigma 0$ | Z | WRLFT | X | $\Sigma 0$ |
| RCIR（DP） | 2 | XWRLFT | $x$ | vo | 2 | WRLFT | $x$ | ごO | z | WRLFT | x | 20 |

＊VARIABLE $=(\Sigma 3 \cdot A L U$ OVERFLOW $)+(C-O U T \cdot A L U O V E R F L O W)$

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＇ | XWRRT＇ | XWRRT | XWRLFT | XWRLFT＇ | XWRRT ${ }^{\text {P }}$ | XWRRT |
| LSL（SP） | 2 | $x$ | XWRRT | 2 | XWR3 | $x$ | XWRRT | 2 | XWR3 | $x$ | XWRRT | 2 |
| LSL（DP） | 2 | x | XWRRT | 2 | XWR3 | $x$ | XWRRT | 2 | XWR3 | x | XWRRT | 2 |
| LSA（SP） | xWR3 | X | XWRRT | 2 | XWR3 | x | XWRRT | z | XWR3 | $x$ | L | 2 |
| LSA（DP） | WR3 | $x$ | XWRRT | 2 | XWR3 | $x$ | XWRRT | $z$ | XWR3 | $x$ | L | 2 |
| LCIR（SP） | XWR3 | x | XWRRT | 2 | XWR3 | X | XWRRT | 2 | XWR3 | x | XWRRT | 2 |
| LCIR（DP） | WR3 | $\times$ | XWRRT | 2 | XWR3 | x | XWRRT | $z$ | XWR3 | $\times$ | XWRRT | 2 |
| RSL（SP） | 2 | XWRLFT | $\times$ | XWRO | 2 | XWRLFT | $\times$ | XWRO | z | XWRLFT | $x$ | 2 |
| RSL（DP） | 2 | WRLFT | $x$ | XWRO | 2 | XWRLFT | $x$ | XWRO | $z$ | XWRLFT | $x$ | XWRO |
| RSA（SP） | 2 | XWR3 | x | XWRO | 2 | XWHLFT | x | XWRO | z | XWRLFT | X | XWRO |
| RSA（DP） | z | WRLFT | $x$ | XWRO | 2 | XWRLFT | $x$ | XWRO | z | XWRLFT | $x$ | XWRO |
| RCIR（SP） | 2 | XWRLFT | x | XWRO | $z$ | XWRLFT | x | XWRO | z | XWRLFT | x | XWRO |
| RCIR（DP） | 2 | WRLFT | x | XWRO | 2 | 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) | Z | $x$ | XWRRT | $z$ |
| LSL (DP) | $z$ | $x$ | XWRRT | z |
| LSA (SP) | XWR3 | X | XWRRT | Z |
| LSA (DP) | 23 | $\times$ | XWRRT | z |
| LCIR (SP) | XWR3 | X | XWRRT | Z |
| LCIR (DP) | 23 | $\times$ | XWRRT | $z$ |
| RSL (SP) | Z | XWRLFT | $\times$ | XWR0 |
| 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

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 LENGTH | DOUBLE LENGTH | SINGLE <br> LENGTH | DOUBLE 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^{\circ}$ bus.

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


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 |  |
| :---: | :--- | :---: |
| OP FORM | DESTINATION |  |
| I | PC | MC |
| III | Yes | Yes |
| VIII | No | Yes |
|  | Yes | No |



FIGURE 15 - ARITHMETIC SHIFT FUNCTIONS

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} / O V}$ output facilitates cascading the program and memory counters. In the least-significant and intermediate positions, the CCO pins of lesser significant packages are connected to the CCT 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 | E'BUS |
| L | H | EXTENDED WORKING REGISTER |
| H | L | WORKING REGISTER |
| H | H | HIGH-IMPEDANCE |

The functionally identical program and memory counters, sharing a common counter carry input (CCT) control pin and a common counter carry output (CCO) pin, feature individual control lines (INCPC, INCMC) 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 CCO/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 | 4 | 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 I G H$ LEVEL, L=LOW LEVEL, $X=I R R E L E V A N T, ~ 4=$ LOW.TO-HIGH TRANSITION

FIGURE 18 - PROGRAM AND MEMORY COUNTER FUNCTIONS

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

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


FIGURE 20 - TYPICAL 16-BIT PROCESSOR

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

TABLE 18
OPERATION FORM SUMMARY
A PLUS B PLUS ALUCIN $\rightarrow\left\{\begin{array}{c}\Sigma \prime \text { BUS ONLY } \\ \text { WR, XWR, PC, OR MC }\end{array}\right\}$

8,192
B PLUS A PLUS ALUCIN DOUBLE-PRECISION SHIFTED $\longrightarrow$ WR and XWR 384

III A PLUS B PLUS ALUCIN SHIFTED $\longrightarrow$ WR OR XWR 1,536

IV A SHIFTED $\longrightarrow \Sigma$ ' BUS
$v \quad\left\{\begin{array}{c}W R \\ X W R\end{array}\right\}$ SHIFTED $\left.\rightarrow \left\lvert\, \begin{array}{c}W R \\ X W R\end{array}\right.\right\}$
VI WR AND XWR DOUBLE-PRECISION SHIFTED $\longrightarrow$ WR AND XWR 256

VII A:B OR B:A (COMPARE) 512
VIII $\left\{\begin{array}{c}\text { NOR } \\ \text { OR } \\ E X O R\end{array}\right\} B \rightarrow$ WR, XWR, PC OR B IN/OUT $\begin{aligned} & 3,072 \\ & 3,072\end{aligned}$

IX ZERO $\longrightarrow \Sigma^{\prime}$ BUS (NO OP)
$\times \quad$ CRC CALCULATION (N CLK TIMES, CRC PARTIAL SUM IN WR)
XI N-BIT QUOTIENT (WITH R) SIGNED DIVIDE (N+3 CLK TIMES)
5
XII N-BIT QUOTIENT (WITH R) UNSIGNED DIVIDE (N+1 CLK TIMES) 3
XIII N-BIT BY N-BIT DOUBLE-PRECISION UNSIGNED MULTIPLY (N CLK TIMES) 1
XIV N-BIT BY N-BIT DOUBLE-PRECISION SIGNED MULTIPLY (N CLK TIMES)

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 { REGISTERR }\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:

$$
\text { A }\left\{\begin{array}{l}
\text { PLUS } \\
\text { MINUS }
\end{array}\right\} \quad \text { B PLUS ALUCIN } \rightarrow \Sigma^{\prime} \text { 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 B I/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.

$\triangle X X X X=$ 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:

A $\left\{\begin{array}{l}\text { PLUS } \\ \text { MINUS }\end{array}\right\}$ B PLUS ALUCIN $\rightarrow$ 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 - ADD/SUBTRACT WITH DOUBLE.PRECISION SHIFT

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) (B MINUS A MINUS 1)

$$
\begin{aligned}
& \text { SHIFTED } \rightarrow \text { WR, XWR } \\
& \text { SHIFTED } \rightarrow \text { WR, XWR }
\end{aligned}
$$

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

(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:

SEL B INPUT/OUTPUT
SEL DOB SOURCE
SEL AOB SOURCE INCREMENT PC OR MC INHIBIT PC ANDIOR MC LOAD WR

H = HIGH LEVEL, L = LOW LEVEL

1. OVFL (MSP) $=H$ Indicates that the shift operation in process will cause the selected register to overflow.
2. "MAGNITUDE: During LSA or RSA, A plus C (N1) is compared to $\overline{\mathrm{B}}$ (N2); during the remaining operations, the $\Sigma$ Bus is compared to ZERO. Resultant outputs are:
$A G=H$ (N1 ARITHMETICALLY $>N 2$ ) or ( 2 BUS
ARITHMETICALLY > ZERO)
$L G=H(N 1>N 2)$ or ( $2 B U S \neq Z E R O$ )
$E Q=H(N 1=N 2)$ or ( $2 B U S=Z E R O)$
3. COUT (MSP) - L Indicates ALU Carry Out.

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 $\mathbf{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.
$H=$ HIGH LEVEL, L = LOW LEVEL
ASYNCHRONOUS CONTROLS:
SEL B INPUT/OUTPUT
SEL DOB SOURCE
SEL AOB SOURCE
INCREMENT PC OR MC INHIBIT PC AND/OR MC LOAD WR

| SHIFT SEL |  |  |  |
| :--- | :--- | :--- | :--- | :--- |
| L2 | D1 | DO | SEL |
| L | L | L | LSL |
| L | H | L | RSL |
| L | H | H | RSA |
| H | L | L | LCIR |
| H | L | H | RCIR |
| H | H | L | NOT DEFINED |
| H | H | H | NOT DEFINED |

1. $\overline{C O U T}=\overline{C I N}$
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: AI 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^{*}$ 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.
FORM VA
FORM VB
F

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\}$

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 = HIGH LEVEL, L = LOW LEVEL


| D2 | D1 | DO | SEL |
| :--- | :--- | :--- | :--- |
| L | L | L | LSL |
| L | L | H | RSL |
| L | H | L | LSA |
| L | H | H | RSA |
| $H$ | L | L | LCIR |
| H | L | H | RCIR |
| H | H | L | NOT DEFINED |
| H | H | H | NOT DEFINED |

1. $\overline{\text { COUT }}=\overline{C I N}$
2. $\operatorname{OVFL}(M S P=H)$

Indicates that LSA operation in process will cause shift
overflow. For all other operations, OVFL $\approx=\mathrm{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 27 - FORM VI-DOUBLE-PRECISION SHIFTS: (WR, XWR)SHIFTED $\rightarrow$ WR, XWR)
3.8 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.
3.9 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 1, 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.

|  | 잉 | $\stackrel{\square}{0}$ | $\stackrel{N}{\mathbf{N}}$ | 0 0 0 | $\square$ 0 0 | $\begin{aligned} & \infty \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { n } \\ & 0 \\ & 0 \end{aligned}$ | 0 0 0 | n | 8 0 0 | 12 | 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FORM VIIA | H | H | H | L | L | A | B2 | B1 | B0 | L | H | A: B |
| FORM VIIB | H | H | H | L | $L$ | A | B2 | B1 | B0 | H | H | B : A |

INCREMENT PC OR MC INHIBIT PC AND/OR MC LOAD WR

| A-SOURCE SEL |
| :--- |
| A |
| L |
| H |
| AI |

SEL B INPUT/OUTPUT* SEL DOB SOURCE SEL AOB SOURCE

| B-SOURCE SEL |  |  |  |  |
| :--- | :--- | :--- | :--- | :---: |
| B2 | B1 | BO | SEL |  |
| L | L | L | BI |  |
| L | L | H | $H^{*}$ |  |
| L | H | L | BI $\cdot$ WR |  |
| L | H | H | WR* |  |
| H | L | L | BI •XWR |  |
| H | L | H | XWR* |  |
| H | H | L | BI •PC |  |
| H | H | H | PC* |  |

-BI/O CAN BE USED AS OUTPUT ( $\Sigma$ BUS $=\mathbf{N} 1-N 2-1$
$H=H I G H$ LEVEL, L = LOW LEVEL

$$
\text { FIGURE } \left.28 \text { - FORM VII-COMPARE: } \left\lvert\, \begin{array}{l}
A: B \\
B: A
\end{array}\right.\right\}
$$

|  | O | $\bar{\square}$ | N | 0 | $\stackrel{\square}{\circ}$ | - | - | a | \% | ! | 号 | NOR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FORM VIIA | H | L | H | L | A1 | A0 | B2 | B1 | B0 | S1 | So |  |
| FORM VIIB | H | L | H | H | A1 | AO | B2 | B1 | B0 | S1 | so | OR |
| FORM VIIIC | H | H | L | L | A1 | A0 | B2 | B1 | B0 | S1 | So | EX-OR |



> -BI/O CAN BE USED AS OUTPUT.


### 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=HIGH LEVEL, L=LOW LEVEL
As shown above, the A and B sources are selectable by the A1, B1, and B2 bits in their true or complementary form (bits AO, BO) to facilitate performing the NOR, mixed NOR/AND, and the AND functions. As implemented, 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=\text { 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 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.


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.


ASYNCHRONOUS CONTROLS:
SEL B INPUT/OUTPUT

| SEL DOB SOURCE | AG $=$ ZERO |
| :--- | :--- |
| SEL AOB SOURCE | LG $=$ ZERO |
| INCREMENT PC OR MC | $E Q=$ HIGH |
| INHIBIT PC AND/OR MC |  |
| LOAD WR |  |

FIGURE 33 - FORM IX-NO OPERATION: ZERO $\rightarrow Z^{\prime \prime}$ BUS

### 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 OP8 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) [ $A G=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


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

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IH }}$ | High-level input voltage |  |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.8 | V |
| $V_{\text {IK }}$ | Input clamp voitage |  | $V_{C C}=$ MIN, $\quad I_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | V |
| $\mathrm{VOH}_{\mathrm{OH}}$ | High-level output voltage |  | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}, \quad \mathrm{V}_{1 H}=2 \mathrm{~V}$, | 54S' | 2.5 | 3.4 |  | V |
|  |  |  | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX}$ | 748' | 2.7 | 3.4 |  |  |
| VOL | Low-level output voltage |  | $\begin{array}{ll} V_{C C}=M I N, & V_{I H}=2 \mathrm{~V}, \\ V_{I L}=0.8 \mathrm{~V}, & I_{O L}=M A X \end{array}$ |  |  |  | 0.5 | V |
| 11 | Input current at maximum input voltage |  | $V_{C C}=M A X, V_{1}=5.5 \mathrm{~V}$ |  |  |  | 1 | mA |
| ${ }^{1 / H}$ | High-level input current | POS | $V_{C C}=$ MAX, $V_{1}=V_{C C}$ |  |  |  | 1 | mA |
|  |  | $\begin{aligned} & \hline \text { OPO, OP1, } \\ & \text { OP2, OP3, CIN } \end{aligned}$ | $V_{C C}=\mathrm{MAX}, \mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  |  | 200 | $\mu \mathrm{A}$ |
|  |  | Any other |  |  |  |  | 100 |  |
| IIL | Low-level input current | $\begin{aligned} & \text { OPO, OP1, OP2 } \\ & \text { OP3, टाN } \end{aligned}$ | $V_{C C}=M A X, V_{1}=0.5 \mathrm{~V}$ |  |  |  | -3.2 | mA |
|  |  | WRRT, WRLFT, XWRRT, XWRLFT, CCI, CLOCK |  |  |  |  | -2 |  |
|  |  | Any other |  |  |  |  | -1 |  |
| 'os | Short-circuit output current§ | Any output or 1/O except EQ, OP8, OP9 | $V_{C C}=M A X$ |  | -30 |  | -100 | mA |
| ${ }^{\text {ICC }}$ | Supply current |  | $V_{C C}=$ MAX |  | 225 |  |  | mA |

$\dagger$ For conditions shown as MIN or MAX, use the appropriate value specifled 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.

TABLE 21
SWITCHING CHARACTERISTICS, $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | OPERATION ROUTING | MIN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tp | AI, BI/O | DOP | LATCH $\rightarrow$ ALU $\rightarrow$ DOP |  | 80 |  | ns |
|  |  | WRLFT, WRRT | LATCH $\rightarrow$ ALU |  | 80 |  | ns |
|  |  | Y/AG, X/LG, COUT | LATCH $\rightarrow$ ALU |  | 60 |  | ns |
|  |  | EQ, OV | LATCH $\rightarrow$ ALU |  | 60 |  | ns |
| tp | AI, BI/O | BI/O | LATCH $\rightarrow$ ALU |  | 90 |  | ns |
| tp | CIN | COUT |  |  | 20 |  | ns |
| tp | CCI | CCD |  |  | 15 |  | ns |
| $t p$ | AO | AOP |  |  | 20 |  | ns |
| tp | D0, D1 | DOP |  |  | 20 |  | ns |
| tpxz | BI/O SEL or DO, D1 | BI/O or DOP |  |  | 10 |  | ns |
| tPZX | BI/O SEL or DO, D1 | BI/O or DOP |  |  | 15 |  | ns |
| $t^{\text {p }}$ | CLOCK | AOP, DOP | NO SHIFT |  | 30 |  | ns |
|  |  | WRLFT, WRRT, XWRLFT, XWRRT | [WR, XWR, $\Sigma$-BUS] $\rightarrow$ SHIFTED |  | 30 |  | ns |
|  |  | AOP, DOP |  |  | 30 |  | ns |
|  |  | AOP, DOP | $[$ [WR, XWR, PC] $\rightarrow$ ALU $\rightarrow$ SHIFTED |  | 90 |  | ns |
|  |  | OV |  |  | 50 |  | ns |
|  |  | CCO |  |  | 25 |  | ns |
|  |  | COUT |  |  | 50 |  | ns |
|  |  | OP8, OP9 |  |  | 30 |  | ns |
| tp | CIN | DOP |  |  | 40 |  | ns |

tp $\equiv$ Propagation delay
$t_{p} \times Z \equiv$ Disable time to $\mathrm{Hi}-\mathrm{Z}$
tpZX $\equiv$ Enable time ( $\mathrm{Hi}-\mathrm{Z}$-To-Enable)

## 5. MECHANICAL DATA


6. PIN ASSIGNMENTS


The Engineering Staff of
TEXAS INSTRUMENTS INCORPORATED
Semiconductor Group


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.

## 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 (RFO $\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-Field, 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 $=\mathrm{HL}$ ..... 30
5.2.1.4 D -Field $=\mathrm{HH}$ ..... 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 1 . ..... 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 $R_{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 = 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

[^2]- 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 (|2 $\mathbf{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 voit minimum at desired injector current
- ALU/shift operation time . . . 240 nanoseconds typical at 200 mW nominal power
- Fully TTL compatible at nominal injector current
- 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} & \text { S2 } \\ & \text { S1 } \\ & \text { S0 } \\ & \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 | $\overline{\text { XWRRT }}$ | Bidirectional $\mathrm{I} / \mathrm{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 | $\begin{aligned} & \mathrm{XWR} \\ & \mathrm{MSB} / \mathrm{LSB} \end{aligned}$ | 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 { DOPO } \\ & \text { DOP1 } \\ & \text { DOP2 } \\ & \text { DOP3 } \end{aligned}$ | 4-bit, paraliel, 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} & \hline \text { DIP3 } \\ & \text { DIP2 } \\ & \text { DIP1 } \\ & \text { DIPO } \\ & \hline \end{aligned}$ | 4-bit, parallel, high active, data-in port (DIP3 $\rightarrow$ DIPO) | Input <br> Input <br> Input <br> Input |
| 18 | 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 \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 | ENINCBY2/ AMSB | 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 { AOP0 } \end{aligned}$ | 4-bit, parallel, high-active, address-out port. $($ AOP3 $\rightarrow$ AOPO) | Output Output Output Output |
| 30 | PC PRIORITY | Selects program counter to the address-out port (high active). Overrides internal direction of address-out port. | Input |
| 33 | $\overline{\mathbf{P}}$ | ALU Carry-propagate | Output |
| 34 | $\overline{\text { 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 Input Input 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 $\mathbf{2 0 - o u t p u t ~ P L A , ~ d e r i v e s ~ t h e ~ p r e s e n t ~ ( r e s i d e n t ) ~ o p e r a t i o n ~ f r o m ~ t h e ~ s t e a d y - s t a t e ~ i n p u t ~ a t ~ t h e ~ n i n e ~ o p - s e l e c t ~ i n p u t s . ~ T h e ~}$ '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 SBPO400A 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 A L U=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

|  |  |  |  |  | ACTIV | D DATA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | ALUCIN $=$ H | ALUCIN $=$ L |
|  | OP3 | OP2 | OP1 | OPO | (WITH CARRY, NO BORROW) | (WITH CARRY, NO BORROW) |
|  | L | L | L | L | $\mathrm{F}_{\mathrm{n}}=\mathrm{L}$ | $\mathrm{Fn}=\mathrm{H}$ |
|  | L | L | L | H | $F_{n}=B$ minus $A$ | $F_{n}=B$ minus $A$ minus 1 |
|  | L | L | H | L | $F_{n}=A$ minus $B$ | $F \mathrm{n}=\mathrm{A}$ minus B minus 1 |
|  | L | L | H | H | $F_{n}=A$ plus $B$ plus 1 | $F_{n}=A$ plus $B$ |
|  | L | H | L | L | $\mathrm{F}_{\mathrm{n}}=\mathrm{B}$ plus 1 | $\mathrm{F}_{\mathrm{n}}=\mathrm{B}$ |
|  | L | H | L | H | $F_{n}=\bar{B}$ plus 1 | $\mathrm{F}_{\mathrm{n}}=\overline{\mathrm{B}}$ |
|  | L | H | H | L | $F_{n}=$ A plus 1 | $F_{n}=A$ |
|  | L | H | H | H | $\mathrm{F}_{\mathrm{n}}=\overline{\mathrm{A}}$ plus 1 | $\mathrm{F}_{\mathrm{n}}=\overline{\mathrm{A}}$ |
|  | H | L | L | L | $F_{n}=A n B n$ |  |
|  | H | L | L | H | $F_{n}=A_{n} \oplus B_{n}$ |  |
|  | H | L | H | L | $F_{n}=\overline{A n \oplus B n}$ |  |
|  | H | L | H | H | $F_{n}=\bar{A}_{n B n}$ |  |
|  | H | H | L | L | $F \mathrm{n}=\mathrm{An}^{\bar{B}} \mathrm{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}$ |  |

### 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 84-BIT <br> WORDS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| RIPPLE | 240 ns | 285 ns | 405 ns | 645 ns | $1.1 \mu \mathrm{~m}$ |
| SINGLE-LEVEL LOOK-AHEAD* | NA | 300 ns | 300 ns | 405 ns | 625 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, POSO)

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, POSO), 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 |  | RELATIVE POSITION | MULTIFUNCTION 1/O |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| POS1 | POSO |  | $\begin{gathered} \hline \overline{\text { PCCOUT/ }} \\ \text { BMSB } \end{gathered}$ | ENINCBY2/ AMSB | XWR MUX MSB/LSB |
| L | H | LEAST SIGNIFICANT POSITION (LSP) | PCCOUT | ENINCBY2 | XWR LSB |
| L | L | INTERMEDIATE POSITION (IP) | PCCOUT | Hi-Z | ZERO |
| H | L | MOST SIGNIFICANT POSITION (MSP); DOUBLE-SIGNED/DOUBLE-PRECISION (DS/DP) ARITHMETIC SHIFTS | BMSB | AMSB | XWR MSB |
| H | H | MOST SIGNIFICANT POSITION (MSP); SINGLE-SIGNED/DOUBLE-PRECISION (SS/DP) ARITHMETIC SHIFTS | BMSB | AMSB | XWR MSB |

### 3.6 REGISTER FILE (RFO $\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 OP3 $\rightarrow$ OPO | D.FIELD <br> D1 $\rightarrow$ D0 | S-FIELD $\mathbf{S 2} \rightarrow \mathbf{S 0}$ |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & R F \rightarrow D O P \\ & R F \rightarrow X W R \\ & R F A L U W R \rightarrow R F \\ & \text { RF ALU } W R \rightarrow W R \end{aligned}$ | 1116 IIIc la Ib | LLLL <br> LLLH <br> LLLL $\rightarrow$ HHHH <br> LLLL $\rightarrow$ HHHH | HL <br> HL <br> LL <br> LH | $\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 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 | L.HHH <br> LHLL <br> LHLH <br> HLLH | HL <br> HL <br> HL <br> 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, $X W R$ <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 <br> HL <br> HL <br> HL | LLL $\rightarrow \mathrm{HHH}$ <br> $L L L \rightarrow \mathrm{HHH}$ <br> $L L L \rightarrow \mathrm{HHH}$ <br> LLL $\rightarrow \mathrm{HHH}$ |

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

TABLE 6
RF DESTINATION OPERANDS

| OPERATION | OP FORM | OP.FIELD $\mathrm{OP3} \rightarrow \mathrm{OPO}$ | D-FIELD <br> D1 $\rightarrow$ D0 | $\begin{aligned} & \text { S-FIELD } \\ & \text { S2 } \rightarrow \text { SO } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| $D I P \rightarrow R F$ | 1118 | HHHH | HL | LLL $\rightarrow$ HHH |
| XWR plus ALUCIN $\rightarrow$ RF | 1 lg | HHHL | HL | $L L L \rightarrow H H H$ |
| RF ALU WR $\rightarrow$ RF | 1 l | LLLL $\rightarrow$ HHHH | LL | LLL $\rightarrow$ HHH |
| RF plus DIP plus ALUCIN $\rightarrow$ RF | IId | LHHH | HL | $L L L \rightarrow H H H$ |

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

note: the same clock (1)That executes operation(1)loads operation (2)INTO the omoca or.


FIGURE B-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 PCCIN and ENINCBY2 inputs as defined by the relative-position control (see Table 3). For cascading purposes, RF7 overflow is provided via the 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 |  |  | INPUT |  | PC IS INCREMENTED ON NEXT CLOCK BY |
| :---: | :---: | :---: | :---: | :---: | :---: |
| LSP | IP | MSP | $\overline{\text { PCCIN }}$ | ENINCBY2 |  |
| YES | NO | NO | H | X | 0 |
|  |  |  | L | L | 1 |
|  |  |  | L | H | 2 |
| NO | YES | NO | H | $x$ | 0 |
|  |  |  | L | $\times$ | 1 |
| NO | NO | YES | H | $x$ | 0 |
|  |  |  | L | $\times$ | 1 |

Instruction look-ahead techniques may be employed to boost the system-level efficiency. While the internal operation register of the SBPO400A 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, POSO), the BMSB is available (see Table 3) when POS1 is high, but if POS1 is taken low, PCCOUT is available. After time $\mathrm{t}_{0}$ the PC contents of the most significant (MSP) will persist until the next L-to-H clock transition. Thus, the BMSB, then 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 PCCIN and ENINCBY2 inputs of the LSP of an expanded wordlength system are shown in Figure 7. An increment-by- 1 command ( $\overline{P C C I N}=L$, ENINCBY2 $=L$ ) advances the PC from 4088 to 4089 synchronously with the $t_{2}$ clock; an increment-by- 2 command ( $\mathrm{PCCIN}=\mathrm{L}$, ENINCBY2 $=H$ ) advances the PC from 4089 to 4091 synchronously with the $t_{3}$ clock; a PC disable-increment command (PCCIN $=H$ ) retains the PC at its present count status. When the PC is at maximum count, an increment-by- 1 command ( $\mathrm{PCCIN}=\mathrm{L}$, ENINCBY2 $=\mathrm{H}$ ) conditions the PCCOUT/PCCIN 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 (PCCIN $=\mathrm{L}$, ENINCBY2 $=\mathrm{H}$ ) conditions the PCCOUT/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 | $\begin{aligned} & \text { D-FIELD } \\ & \text { D1 } \rightarrow \text { D0 } \end{aligned}$ | S-FIELD $\mathbf{S 2} \rightarrow \mathbf{S 0}$ |
| :---: | :---: | :---: | :---: | :---: |
| *WR ALU DIP $\rightarrow$ DOP <br> ${ }^{*}$ WR ALU DIP $\rightarrow$ WR <br> WR ALU DIP $\rightarrow X$ XR <br> WR ALU RF $\rightarrow$ RF | lc <br> Id <br> If <br> la | $\begin{aligned} & \text { LLLL } \rightarrow \text { HHHH } \\ & \text { LLLL } \rightarrow \text { HHHH } \\ & \text { LLLL } \rightarrow \text { HHHH } \\ & \text { LLLL } \rightarrow \text { HHHH } \end{aligned}$ | HH <br> HH <br> HH <br> LL | LLL <br> LLH <br> HLL <br> LLL $\rightarrow$ 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 IVa IVf 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} \\ & \text { 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 <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 (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} \end{aligned}$ | HLH <br> HLH <br> HLH <br> HLH |
| (WR plus ALUCIN) RCIR $\rightarrow$ WR <br> $(W R$ plus ALUCIN) RSA $\rightarrow$ WR <br> (WR plus ALUCIN) RSL $\rightarrow$ WR <br> (WR plus ALUCIN,XWR) LCIR $\rightarrow$ (WR,XWR) | $\begin{aligned} & \hline \mathrm{Vb} \\ & \mathrm{Va} \\ & \mathrm{Ve} \\ & \mathrm{VId} \end{aligned}$ | HLLH <br> LLLL <br> HLLL <br> HHHH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \\ & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | HLH <br> HLH <br> HLH <br> HLH |
| (WR plus ALUCIN,HWR) LCIR $\rightarrow$ (WR,XWR) <br> (WR plus ALUCIN,XWR) LSA $\rightarrow$ (WR,XWR) <br> (WR plus ALUCIN,XWR) LSL $\rightarrow$ (WR,XWR) <br> (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) <br> WR plus DIP plus ALUCIN $\rightarrow$ DOP | VIb <br> Vla <br> Vie <br> lli | LHLH <br> LHLL <br> HHLL <br> LHHH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \\ & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | HLH <br> HLH <br> HLH <br> LHL |
| WR plus DIP plus ALUCIN $\rightarrow$ XWR <br> (WR plus DIP plus ALUCIN) LCIR $\rightarrow$ WR,XWR <br> $(W R$ plus DIP plus ALUCIN) RSA $\rightarrow$ WR, XWR <br> WR plus RF plus ALUCIN $\rightarrow$ XWR | Ith <br> IVb <br> IVg <br> 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} & \text { IVd } \\ & \text { IVi } \end{aligned}$ | HLLH HLHH | $\begin{aligned} & \mathrm{HL} \\ & \mathrm{HL} \end{aligned}$ | $\begin{aligned} & \mathrm{LLL} \rightarrow \mathrm{HHH} \\ & \mathrm{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) | OP.FIELD $\mathrm{OP} 3 \rightarrow \mathrm{OPO}$ | D.FIELD <br> D1 $\rightarrow$ D0 | $\begin{aligned} & \text { S-FIELD } \\ & \text { S2 } \rightarrow \text { SO } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| 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 | Ib IVa IVd IVc | $\begin{aligned} & \text { LLLL } \rightarrow \text { HHHH } \\ & \text { HLLL } \\ & \text { LLHL } \\ & \text { HLLL } \\ & \hline \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 <br> (WR 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 $($ 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 |
| $(W R$ plus ALUCIN) RCIR $\rightarrow$ WR <br> $(W R$ 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) $(W R$ plus ALUCIN, XWR) LSA $\rightarrow$ (WR, XWR) $(W R$ 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> VIe | 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} & \mathrm{IVb} \\ & \mathrm{IVg} \end{aligned}$ | HLLH HLHH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | $\overline{\mathrm{LHL}}$ LHL |
| (WR plus RF plus ALUCIN) LCIR $\rightarrow$ WR, XWR (WR plus RF plus ALUCIN) RSA $\rightarrow$ WR, XWR | $\begin{aligned} & \text { IVd } \\ & \text { IVi } \end{aligned}$ | HLLH <br> HLHH | $\begin{aligned} & \mathrm{HL} \\ & \mathrm{HL} \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}$ | $\begin{aligned} & \text { D.FIELD } \\ & \text { D1 } \rightarrow \text { D0 } \end{aligned}$ | S-FIELD $\mathbf{S 2} \rightarrow \mathbf{S 0}$ |
| :---: | :---: | :---: | :---: | :---: |
| XWR ALU DIP $\rightarrow$ DOP <br> $X W R$ ALU DIP $\rightarrow$ WR <br> XWR ALU DIP $\rightarrow$ XWR <br> XWR plus ALUCIN $\rightarrow$ DOP | In <br> le <br> Ig <br> III | LLLL $\rightarrow \mathrm{HHHH}$ <br> LLLL $\rightarrow$ HHHH <br> LLLL $\rightarrow \mathrm{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> XWR plus RF plus ALUCIN $\rightarrow$ WR | $\begin{aligned} & \hline \mathrm{IIj} \\ & \mathrm{IIk} \\ & \mathrm{IIf} \\ & \mathrm{IIe} \end{aligned}$ | 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}$ |

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

| OPERATION | OP FORM (See 5.3) | OP FIELD $\mathrm{OP3} \rightarrow \mathrm{OPO}$ | D.FIELD $\text { D1 } \rightarrow \text { D0 }$ | $\begin{array}{r} \text { S-FIELD } \\ -\mathbf{S 2} \rightarrow \text { S0 } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: |
| DIP ALU XWR $\rightarrow$ XWR | 19 | 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 (WR minus DIP minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR (WR minus RF minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | IVa <br> IVf <br> IVc | HLLL <br> LLHL <br> HLLL | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \\ & \mathrm{HL} \end{aligned}$ | $\begin{aligned} & \text { LHL } \\ & \text { LHL } \\ & \text { LLL } \rightarrow \text { HH } \end{aligned}$ |
| (WR minus RF minus 1 plus ALUCIN, XWR) RSA WR, XWR (WR plus ALUCIN) RSA $\rightarrow$ WR, XWR <br> (WR plus ALUCIN) RSA $\rightarrow$ WR, XWR | IVh <br> ive <br> IVe | LLHL <br> HLHL <br> HLHL | HL <br> HL <br> HH | $\begin{aligned} & \text { LLL } \rightarrow \text { HHH } \\ & \times X X \\ & \text { LHL } \end{aligned}$ |
| (WR plus ALUCIN, XWR) LCIR $\rightarrow$ (WR, XWR) | VId | HHHH | HH | HLH |
| (WR plus ALUCIN, XWR) LCIR $\rightarrow$ (WR, XWR) <br> (WR plus ALUCIN, XWR) LSA $\rightarrow$ (WR, XWR) <br> (WR plus ALUCIN, XWR) LSL $\rightarrow(W R, X W R)$ <br> (WR plus ALUCIN, XWR) RCIR $\rightarrow$ (WR, XWR) | $\begin{aligned} & \hline \text { VId } \\ & \text { VIc } \\ & \text { VIf } \\ & \text { VIb } \\ & \hline \end{aligned}$ | LHHH <br> LHHL <br> HHHL <br> HHLH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \\ & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | 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) | VIb <br> VIa <br> Vle | LHLH LHLL 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 <br> (WR plus DIP plus ALUCIN) RSA $\rightarrow$ WR, XWR <br> WR plus RF plus ALUCIN $\rightarrow$ XWR | IIh. <br> IVb <br> IVg <br> Ha | LLHH <br> HLLH <br> HLHH <br> LLHH | HH <br> HH <br> HH <br> HL | LHL <br> LHL <br> LHL <br> LLL $\rightarrow \mathrm{HHH}$ |
| (WR plus RF plus ALUCIN) LCIR $\rightarrow$ WR, XWR (WR plus RF plus ALUCIN) RSA $\rightarrow$ WR, XWR | $\begin{aligned} & \hline \mathrm{IVd} \\ & \mathrm{IVi} \end{aligned}$ | $\begin{aligned} & \text { HLLH } \\ & \text { HLHH } \end{aligned}$ | $\begin{aligned} & \mathrm{HL} \\ & \mathrm{HL} \end{aligned}$ | $\begin{aligned} & \text { 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{IIfe} \end{aligned}$ | HHLH LLLH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | LHL LHL |

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

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 <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 |
|  | 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> ABUS 1 <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 WRRT. 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 WRLFF |
| :---: | :---: | :---: |
|  | LEFT SHIFT ARITHMETIC LEFT SHIFT LOGICAL LEFT CIRCULATE | $\frac{\overline{A L U 3}}{\overline{A L U 3}} \overline{\overline{A L U 3}}$ |
|  | LEFT SHIFT ARITHMETIC LEFT SHIFT LOGICAL LEFT CIRCULATE | HIGH <br> HIGH <br> ALU3 |
|  | LEFT SHIFT ARITHMETIC LEFT SHIFT LOGICAL LEFT CIRCULATE | $\overline{X W R 3}$ <br> XWR3 <br> $\overline{X W R 3}$ |
|  | LEFT SHIFT ARITHMETIC LEFT SHIFT LOGICAL LEFT CIRCULATE |  |

### 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 RIGHT SHIFT LOGICAL RIGHT CIRCULATE | $\begin{aligned} & \overline{\text { ALUO }} \\ & \overline{\text { ALUO }} \\ & \overline{\text { ALUO }} \end{aligned}$ |
|  | RIGHT SHIFT ARITHMETIC <br> RIGHT SHIFT LOGICAL <br> RIGHT CIRCULATE | $\begin{aligned} & \text { HIGH } \\ & \text { HIGH } \\ & \overline{\text { ALUO }} \end{aligned}$ |
|  | RIGHT SHIFT ARITHMETIC RIGHT SHIFT LOGICAL RIGHT CIRCULATE | HIGH <br> HIGH <br> XWRO |

### 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 ( $\operatorname{Bit} 0$ ) is available at the XWR LSB output. Control for the XWR MUX 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
XWR MUX TRANSFERS

| OPERATION TYPE (DOUBLE-PRECISION) |  | XWR MUX OUTPUT |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 3 | 2 | 1 | 0 |
|  | RIGHT SHIFT ARITHMETIC SINGLE-SIGNED RIGHT SHIFT ARITHMETIC DOUBLE-SIGNED 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 | $\begin{aligned} & \text { XWR2 } \\ & \text { XWR2 } \\ & \text { XWR2 } \\ & \text { XWR2 } \\ & \text { DOB1 } \\ & \text { XWR0 } \\ & \text { XWR0 } \\ & \text { XWR0 } \\ & \text { XWR0 } \end{aligned}$ | XWR1 <br> XWR1 <br> XWR1 <br> XWR 1 <br> DOBO <br> XWRRT <br> XWRRT <br> XWRRT <br> XWRRT |
|  | RIGHT SHIFT ARITHMETIC SINGLE-SIGNED RIGHT SHIFT ARITHMETIC DOUBLE-SIGNED 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{X W R R T}$, 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 ( $X W R$ KMUX) is a special purpose multiplexer which outputs, in accordance with Table 15, appropriate double-precision left-shift data via the bidirectional shift accommodation 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) | XWR KMUX OUTPUT TO XWRLFT |
| :---: | :---: | :---: |
|  | 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} & \mathrm{HIGH} \\ & \mathrm{HIGH} \\ & \mathrm{HIGH} \\ & \hline \text { ALU3 } \end{aligned}$ |

The extended working register $L$ multiplexer ( $X W R$ LMUX) is a special purpose multiplexer which outputs, in accordance with Table 16, appropriate double-precision right shift data via the bidirectional shift accommodation XWRRT. 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 <br> 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 | $\begin{aligned} & \overline{\overline{A L U O}} \\ & \overline{\overline{A L U O}} \\ & \overline{\text { ALUO }} \\ & \overline{A L U O} \end{aligned}$ |

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 |  | $\begin{aligned} & \text { OP-FIELD } \\ & \text { OP3 } \rightarrow \text { OPO } \end{aligned}$ | D.FIELD $\mathbf{D} 1 \rightarrow \mathbf{D O}$ | $\begin{gathered} \text { S-FIELD } \\ \text { S2 } \rightarrow \text { SO } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (WR plus ALUCIN) RSL $\rightarrow$ WR | RIGHT-SHIFT-LOGICAL (RSL) | Figure 8 | $V^{*}$ | HLLL | HH | HLH |
| $($ WR plue 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 | Va | 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 WRRT. 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 POLARITYI 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)


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 $\text { OP3 } \rightarrow \text { OPO }$ | D.FIELD $\mathrm{D} 1 \rightarrow \mathrm{D} 0$ | S-FIELD $\mathbf{s 2} \boldsymbol{\rightarrow} \mathbf{s o}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (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 | $\begin{aligned} & \text { VIe } \\ & \text { VIf } \end{aligned}$ | HHLL HHHL | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | HLH HLH |
| WR plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR (WR plus ALUCIN, XWR) LSA $\rightarrow$ WR, XWR | RIGHT-SHIFT-ARITHMETIC (RSA) LEFT-SHIFT-ARITHMETIC (LSA) | Figure 16, 17 <br> Figure 18, 19 | Vis Vic | LHLL LHHL | HH HH | HLH <br> HLH |
| (WR plus ALUCIN, XWR) RCIR $\rightarrow$ WR, XWR (WA plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | RIGHT-CIRCULATE (RCIR) LEFT-CIRCULATE (LCIR) | Figure 20 <br> Figure 21 | $\begin{aligned} & \text { VIb } \\ & \text { VI3 } \end{aligned}$ | LHLH LHHH | $\begin{aligned} & \mathrm{HH} \\ & \mathrm{HH} \end{aligned}$ | $\begin{aligned} & \text { HLH } \\ & \text { HLH } \end{aligned}$ |

### 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 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 INTRAPACKAGE 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 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 XWRRT. 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 - SINQLE SIGN/DOUBLE PRECISION (RSA - 88/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 vis 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.

$$
\text { FIGURE } 18 \text { - 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) INTERPACKAGE.
FIGURE 19 - LEFT SHIFT ARITHMETIC - DOUBLE SIGN/DOUBLE PRECISION (LSA - DS/DP)

## 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 $\overline{X W R R T}$ 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) }
$$

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


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)

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 21 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 | op. FORM (See 5.3 ) | OP.FIELD OP3 3 OPO | $\begin{aligned} & \text { D.FIELD } \\ & \text { D1 } \rightarrow \mathbf{D O} \end{aligned}$ | $\begin{aligned} & \text { S-FIELD } \\ & \$ 2 \rightarrow 80 \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (WR minus DIP minus 1 plus ALUCIN, XWR) LCIR - WR, XWR | Left-CIRCULATE (LCIP) | Figure 21 | iva | HLLL | HH | LHL |
| (WR minus RF( $n$ ) minus 1 plus ALUCIN, XWR) LCIR $\rightarrow$ WR, XWR | LEFT-CIRCULATE (LCIR) | Figure 21 | ive | HLLL | HL | $L$ LL $\rightarrow$ HHH |
| (WR plus DIP plus Alucin, XWR) LCIR -. WR, XWR | Left-circulate (LCIR) | Figure 21 | ivb | HLLH | He | LHL |
| (WR plus RF(n) plus ALUCIN, XWR) LCIR - WR, XWR | Left-Circulate (LCIR) | Figure 21 | ivd | HLLH | HL | $L$ LLL $\rightarrow$ HHM |
| (WR minus DIP minus 1 Plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR | RIGHT-SHIFT-ARITHMETIC (RSA) | Figure 16 | ivf | LLHL | HH | LHL. |
| $(W R$ minus RF(n) minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR | RIGHT-SHIFT-ARITHMETIC (RSA) | Figure 16 | IVh | LLHL | HL | LLL $\rightarrow$ HHH |
| (WR plus DIP plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR | RIGHT-SHIFT.ARITHMETIC (RSA) | Figure 16 | IVg | HLHH | HH | LHL |
| (WR plus RF(n) plus ALUCIN, XWR) RSA - WR, XWR | RIGHT-SHIFT-ARITHMETIC (RSA) | Figure 16 | ivi | HLHH | HL | $L L L \rightarrow$ HKH |

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

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

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


## B.2.1 D-Field, Operation-Select Word

This 2-bit D-field ( $\mathrm{D} 1 \rightarrow \mathrm{D} 0$ ) 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.

### 62.1.1 D-Fie/d $=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 " HL ", the ALU 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.


### 5.2.1.4 D-Field $=H H$

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 $=\mathbf{H H}$


### 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 |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | LD |  | ALUCIN = H | ALUCIN $=$ L |
| OP3 | OP2 | OP1 | OPO | (WITH CARRY) | (NO CARRY) |
| L | L | L | L | $F_{n}=L$ | $F \mathrm{~F}=\mathrm{H}$ |
| L | L | L | H | $F_{n}=B$ minus $A$ | $F \mathrm{~F}=\mathrm{B}$ minus A minus 1 |
| L | L | H | L | $F_{n}=A$ minus $B$ | $F_{n}=A$ minus $B$ minus 1 |
| L | L | H | H | $F \mathrm{n}=$ A plus B plus 1 | $F_{n}=A$ plus $B$ |
| L | H | L | L | $F_{n}=B_{\text {plus }} 1$ | $F_{n}=B$ |
| L | H | L | H | Fn=Epplus 1 | $F \mathrm{~F}=\overline{\mathrm{B}}$ |
| L | H | H | L | $F_{n}=$ A plus 1 | $F n^{\prime}=A$ |
| L | H | H | H | $\mathrm{F}_{\mathrm{n}}=\bar{A}$ plus 1 | $F_{n}=\bar{A}$ |
| H | L | L | L | $F_{n}=A_{n} B_{n}$ |  |
| H | $L$ | L | H | $F_{n}=A_{n} \oplus B_{n}$ |  |
| H | L | H | L | $F_{n}=\overline{A n}\left(\overline{A n}^{(1)}\right.$ |  |
| H | L | H | H | $F_{n}=\bar{A}_{n} B_{n}$ |  |
| 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{A}_{n}+\mathrm{Bn}^{\prime}$ |  |


$W R \rightarrow R F$
RF ALU WR $\rightarrow$ WR

- DIP ALU WR $\rightarrow$ DOP
- DIP ALU WR $\rightarrow$ WR

DIP ALU XWR $\rightarrow$ WR DIP ALU WR $\rightarrow$ XWR DIP ALU XWR $\rightarrow$ XWR DIP ALU XWR $\rightarrow$ DOP

TABLE 23
16 FUNCTION ALU OPERATIONS

operations, the D-field interacts with the S-field to specify two operand sources in combination with an operation-result destination. Either the DIP or RF is available as an operand source to the " $A$ " input port of the ALU; either the DIP, WR or XWR is available as an operand source to the " $B$ " input port of the ALU. Ultimate destinations for ALU output results include either the DOP, RF, WR or XWR.

An ALU function from Table 22 may be selected as the operand combination/modification mechanism for each operation in Table 23 by simply choosing the appropriate OP-field code. For example, a D-field code of " HH " interacts with an S-field code of "LLH" to specify the operation DIP ALU WR $\rightarrow$ WR. If the WR is to be subtracted from the DIP, an OP-field code of "LLHL" ( $F_{n}=A$ minus $\left.B, A L U C I N=H\right)$ must be selected from Table 22 along with an ALUCIN $=H$ forced into the LSP. The resulting operation-select word will then specify the operation DIP minus $W R \rightarrow$ DOP.

| OP | $D$ | $S$ |
| :---: | :---: | :---: |
| LLHL | HH | LLL |

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, $X \rightarrow Y$ with the LSP's ALUCIN $=L$, and 4) two's-complement transfers, $X$ plus $1 \rightarrow Y$ with the LSP's ALUCIN $=H$.

TABLE 24
REGISTER TRANSFER OPERATIONS

| WR plus ALUCIN $\rightarrow$ RF | L | H | L | L | L | L | RF: LLL $\rightarrow \mathrm{HHH}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RF plus ALUCIN $\rightarrow$ WR | L | H | H | L | L | H | RF: LLL $\rightarrow$ HHH |
| WR plus ALUCIN $\rightarrow$ XWR | L | H | L | L | H | H | H L L |
| XWR plus ALUCIN $\rightarrow$ WR | L | H | L | L | H | H | L H H |
| CIP plus ALUCIN $\rightarrow$ WR | L | H | H | L | H | H | L H H |
| DIP plus ALUCIN $\rightarrow$ XWR | L | H | H | L | H | H | H L L |
| DIP plus ALUCIN $\rightarrow$ DOP | L | H | H | L | H | H | H H H |
| XWR plus ALUCIN $\rightarrow$ DOP | L. | H | L | L | H | H | H H H |
| -DIP plus ALUCIN $\rightarrow$ DOP | L | H | H | L | H | H | L L L |
| *WR plus ALUCIN $\rightarrow$ DOP | L | H | L | L | H | H | $L L L$ |
| DIP plus ALUCIN $\rightarrow$ WR | L | H | H | L | H | H | L L H |
|  | OP3 | OP2 | OP1 | OPO | D1 | DO | S2 8180 |
| $\overline{\text { WR }}$ plus ALUCIN $\rightarrow$ RF | L | H | L | H | L | L | RF: LLL $\rightarrow$ HHH |
| RF plus ALUCIN $\rightarrow$ WR | L | H | H | H | L | H | RF: LLL $\rightarrow$ HHH |
| $\overline{\text { WR }}$ plus ALUCIN $\rightarrow$ XWR | L | H | L | H | H | H | $H L L$ |
| XWR plus ALUCIN $\rightarrow$ WR | L | H | L | H | H | H | L H H |
| $\overline{\text { DIP plus ALUCIN }} \rightarrow$ WR | L | H | H | H | H | H | L H H |
| $\overline{\text { DIP plus ALUCIN } \rightarrow \text { XWR }}$ | L | H | H | H | H | H | HLL |
| DTP plus ALUCIN $\rightarrow$ DOP | L | H | H | H | H | H | HHH |
| $\overline{\text { XWR plus ALUCIN } \rightarrow \text { DOP }}$ | L | H | L | H | H | H | HHH |
| *DTP plus ALUCIN $\rightarrow$ DOP | L | H | H | H | H | H | L L L |
| *WR plus ALUCIN $\rightarrow$ DOP | L | H | L | H | H | H | L L L |
| * DIP plus ALUCIN $\rightarrow$ WR | L | H | H | H | H | H | L L H |
|  | OP3 | OP2 | OP1 | OPO | D1 | D0 | S2 S1 S0 |

- $\times W R \rightarrow A O P$, otherwise WR $\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 $=\mathrm{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

HIGH - RF, ALUCIN = LOW
HIGH $\rightarrow$ WR, ALUCIN = LOW
*HIGH $\rightarrow$ WR, ALUCIN = LOW
HIGH $\rightarrow$ XWR, ALUCIN = LOW
HIGH $\rightarrow$ DOP, ALUCIN = LOW
*HIGH $\rightarrow$ DOP, ALUCIN = LOW

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

$\cdot X W R \rightarrow A O P$, otherwise $W R \rightarrow$ AOP. PC PRIORITY $=$ 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

 into six operation-forms as described in Tables 27 through 32. Each operation-form may, in turn, beThe 3-bit S-field (S2 $\rightarrow \mathbf{S O}$ ) 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

TABLE 26
RF SELECTION

| RF LOCATION | S2 | S1 | SO |
| :---: | :---: | :---: | :---: |
| RFO | $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.

TABLE 27 OPERATION FORM
Operation form 1 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

TABLE 29 OPERATION FORM III
Operation form III may be utilized to transfer one or two operand sources (RF, DIP) to one of four destinations (RF, WR, XWR, DOP).

TABLE 28
OPERATION FORM II

| II | OPERATION TYPE | OP3 $\rightarrow$ OPO | D1 | D0 | 52 | 51 | 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$ HHH |  |  |
| c. | RF plus DIP plus ALUCIN $\rightarrow$ XWR | L HLH | H | L | RF: LLL $\rightarrow$ 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$ HHH |  |  |
| 9. | $X$ WR plus ALUCIN $\rightarrow$ RF | HHHL | H | L | RF: LLL $\rightarrow \mathrm{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

| I | OPERATION TYPE | OP3 | $\rightarrow \quad$ OPO | D1 | DO | S2 | S1 | so |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| a. | RF ALU WR $\rightarrow$ RF | ALU | LLLL $\rightarrow$ HHHH | L | L | RF: LLL $\rightarrow$ HHH |  |  |
| b. | RF ALU WR $\rightarrow$ WR | ALU | LLLL $\rightarrow$ HHHH | L | H | RF: LLL $\rightarrow \mathrm{HHH}$ |  |  |
| c. | *DIP ALU WR $\rightarrow$ DOP | ALU | LLLL $\rightarrow$ HHHH | H | H | L | L | L |
| d. | *DIP ALU WR $\rightarrow$ WR | ALU | LLLL $\rightarrow$ HHHH | H | H | L | L | H |
| e. | DIP ALU XWR $\rightarrow$ WR | ALU | LLLL $\rightarrow$ HHHH | H | H | L | H | H |
| f. | DIP ALU WR $\rightarrow$ XWR | ALU | LLLL $\rightarrow$ HHHH | H | H | H | L | L |
| g. | DIP ALU XWR $\rightarrow$ XWR | ALU | LLLL $\rightarrow$ HHHH | H | H | H | H | L |
| h. | DIP ALU XWR $\rightarrow$ DOP | ALU | LLLL $\rightarrow$ HHHH | H | H | H | H | H |

$\bullet \times W R \rightarrow A O P$, otherwise $W R \rightarrow A O P$. PC PRIORITY $=$ HIGH overrides

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

| DV | OPERATION TYPE | OP3 |  |  | OPO | D1 | D0 | S2 | S1 | SO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 |  | LLL | HHH |
| e. | (WR plus ALALUCIN, XWR) RSA $\rightarrow$ XWR | H | L | H | L | H | L | $X$ | X | X |
| e. | (WR plus ALALUCIN, XWR) RSA | 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 |
| 9. | (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 | RF: LLL $\rightarrow$ HHH <br> RF: LLL $\rightarrow \mathrm{HHH}$ |  |  |
| i. | $(W R$ plus RF plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR | H | $L$ | H | H | H | L |  |  |  |

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


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

## 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 OP FIELD | $\begin{aligned} & \text { D1 D0 } \\ & \text { D-FIELD } \end{aligned}$ | $\mathbf{S 2} \rightarrow \mathbf{S 0}$ <br> S-FIELD |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & D I P \rightarrow D O P \\ & D I P \rightarrow D O P \\ & D I P \rightarrow R F \\ & D I P \rightarrow \text { WR } \end{aligned}$ | IIIf <br> IIIf <br> IIla <br> IIId | HHHH <br> LLLL <br> HHHH <br> LHHL | HH <br> HH <br> HL <br> HL | LHL <br> LHL <br> LLL $\rightarrow$ HHH <br> XXX |
| DIP $\rightarrow$ WR <br> DIP $\rightarrow$ XWR <br> - DIP ALU WR $\rightarrow$ DOP <br> - DIP ALU WR $\rightarrow$ WR | IIId <br> lile Ic ld | LHHL <br> LLLH <br> LLLL $\rightarrow$ HHHH <br> LLLL $\rightarrow$ HHHH | HH <br> HH <br> HH <br> HH | LHL <br> LHL <br> LLL <br> LLH |
| $\begin{aligned} & \text { DIP ALU } W R \rightarrow X W R \\ & \text { DIP ALU } X W R \rightarrow \text { DOP } \\ & \text { DIP ALU } X W R \rightarrow W R \\ & \text { DIP ALU } X W R \rightarrow X W R \end{aligned}$ | $\begin{aligned} & \hline \text { If } \\ & \text { in } \\ & \text { ig } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { LLLL } \rightarrow \mathrm{HHHH} \\ & \text { LLLL } \rightarrow \mathrm{HHHH} \\ & \text { LLLL } \rightarrow \mathrm{HHHH} \\ & \text { LLLL } \rightarrow \mathrm{HHHH} \end{aligned}$ | 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> IIb | HLLH <br> HLHH <br> HHH <br> LHLL | HH <br> HH <br> HL <br> HL | LHL <br> LHL <br> LLL $\rightarrow \mathrm{HHH}$ <br> LLL $\rightarrow$ HHH |
| DIP plus RF plus ALUCIN $\rightarrow$ XWR DIP plus WR plus ALUCIN $\rightarrow$ DOP <br> DIP plus WR plus ALUCIN $\rightarrow$ XWR <br> DIP plus XWR plus ALUCIN $\rightarrow$ WR | Ilc III,IIh IIh IIj | LHLH <br> LHHH <br> LLHH <br> HHLL | HL <br> 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 |

[^3]TABLE 34
RF SOURCE OPERANDS

| OPERATION | OP FORM/TYPE | OP3 $\rightarrow$ OPO OP FIELD | $\begin{aligned} & \text { D1 D0 } \\ & \text { D-FIELD } \end{aligned}$ | $\text { S2 } \rightarrow \text { SO }$ <br> S-FIELD |
| :---: | :---: | :---: | :---: | :---: |
| RF -• DOP <br> RF $\rightarrow$ XWR <br> RF ALU WR $\rightarrow$ RF <br> RF ALU WR $\rightarrow$ WR | 1116 IIIc la lb | LLLL <br> LLLH <br> LLLL $\rightarrow$ HHHH <br> LLLL $\rightarrow$ HHHH | $\begin{aligned} & \mathrm{HL} \\ & \mathrm{HL} \\ & \mathrm{LL} \\ & \mathrm{LH} \end{aligned}$ | $\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 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 | lld <br> 11 b <br> IIc <br> IVd | LHHH <br> LHLL <br> LHLH <br> HLLH | HL <br> HL <br> HL <br> 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 $X$ WR plus ALUCIN $\rightarrow$ WR <br> RF plus XWR plus ALUCIN $\rightarrow$ XWR | IVi <br> Ha <br> Ile <br> IIf | HLHH <br> LLHH <br> HHLL <br> HHLH | HL <br> HL <br> HL <br> HL | LLL $\rightarrow \mathrm{HHH}$ <br> LLL $\rightarrow$ HHH <br> LLL $\rightarrow$ HHH <br> LLL $\rightarrow$ 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 <br> D.FIELD | $\mathbf{S 2} \rightarrow \mathbf{S 0}$ <br> S.FIELD |
| :---: | :---: | :---: | :---: | :---: |
| XWR ALU DIP $\rightarrow$ DOP <br> XWR ALU DIP $\rightarrow$ WR <br> XWR ALU DIP $\rightarrow$ XWR <br> XWR plus ALUCIN $\rightarrow$ DOP | Ih le Ig 111 | 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 |
| $X$ WR plus ALUCIN $\rightarrow$ RF <br> XWR plus DIP plus ALUCIN $\rightarrow$ WR <br> XWR plus DIP plus ALUCIN $\rightarrow$ XWR <br> $X W R$ plus RF plus ALUCIN $\rightarrow$ WR | $\begin{aligned} & \hline \mathrm{IIj} \\ & \mathrm{IIk} \\ & \mathrm{He} \\ & \mathrm{IIf} \end{aligned}$ | HHHL <br> HHLL <br> HHLH <br> HHLL | HL <br> HH <br> HH <br> HL | $\begin{aligned} & \text { 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.

| OPERATION | OP FORM/TYPE | $\begin{aligned} & \text { OP3 } \rightarrow \text { OPO } \\ & \text { OP-FIELD } \end{aligned}$ | $\begin{gathered} \text { D1 D0 } \\ \text { D.FIELD } \end{gathered}$ | $\mathbf{s 2} \rightarrow \mathbf{s o}$ <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 | $\begin{aligned} & \text { Ic } \\ & \text { Id } \\ & \text { If } \\ & \text { la } \\ & \hline \end{aligned}$ | LLLL $\rightarrow$ HHHH <br> LLLL $\rightarrow$ HHHH <br> LLLL $\rightarrow$ HHHH <br> LLLL $\rightarrow$ HHHH | HH <br> HH <br> HH <br> LL | LLL <br> LLH <br> HLL <br> LLL $\rightarrow$ HHH |
| WR ALU RF $\rightarrow$ WR <br> $($ WR minus BIP 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 | $\begin{aligned} & \text { LLLL } \rightarrow \text { HHHH } \\ & \text { HLLL } \\ & \text { LLHL } \\ & \text { HLLL } \end{aligned}$ | LH <br> HH <br> HH <br> HL | $\begin{aligned} & \text { LLL } \rightarrow \text { HHH } \\ & \text { LHL } \\ & \text { LHL } \\ & \text { LLL } \rightarrow \text { HHH } \end{aligned}$ |
| (WR minus RF minus 1 plus ALUCIN, XWR) RSA $\rightarrow$ WR, XWR $(W R$ plus ALUCIN) RSA $\rightarrow$ WR, XWR <br> $(W R$ plus ALUCIN) RSA $\rightarrow$ WR, XWR <br> $(W R$ 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 } \\ & \times X X \\ & \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 $(W R$ plus ALUCIN) RSA $\rightarrow$ WR $(W R$ plus ALUCIN) RSL $\rightarrow$ WR (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, XWH) (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(W R, X W R)$ (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> Vla <br> Vie <br> lli | LHLH LHLL HHLL 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 <br> (WR plus DIP plus ALUCIN) RSA $\rightarrow$ WR, XWR <br> WR plus RF plus ALUCIN $\rightarrow$ XWR | IIh IVb IVc Ha | 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} & \text { IVd } \\ & \text { IVi } \end{aligned}$ | HLLH HLHH | $\begin{aligned} & \text { HL } \\ & \text { HL } \end{aligned}$ | $\begin{array}{ll}\text { LLL } & \text { HHH } \\ \text { LLL. } & \text { HHH }\end{array}$ |

$\bullet$ XWR $\rightarrow$ AOP, otherwise WR $\rightarrow$ AOP. PC PRIORITY $=$ HIGH overrldes.

## 6. INTERFACING

The input/output (I/O) accommodations of these processor elements have been designed for TTL and/or MOI compatibility. Direct interfacing, supportable by the entire families of catalog devices, is shown in Figure 22. Typiea 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 threshoid is achieved via two 10 K ohm resistors which function as a voltage divider to increase the one $\mathrm{V}_{\mathrm{BE}}$ 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 $\mathbf{+ 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).


FIOURE 23 - SCHEMATICS OF EQUIVALENT INPUT8, OUTPUTE, INPUTB/OUTPUTS

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

### 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 VCC. A single transient protecting resistor, specified as shown in Table 38, may be utilized common to $(N)$ inputs.

## 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 (VOL) 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 | $R_{p}=\frac{V_{C C}-3.3}{.0005(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 O H-.0005(N)}$ <br> NOT REC | $R_{B}=\frac{V_{C C}-2.4}{1 \mathrm{OH}-.00025(\mathrm{~N})}$ |
| SOURCED BY TTL WITH 5 V ACTIVE PULL-UP | DRIVE |  |

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})$ and current $(\mathrm{IOH}), 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 $R_{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:

$$
\mathrm{V}_{\mathrm{RL}}=\mathrm{V}_{\text {source }}-\mathrm{V}_{\mathrm{OH} \text { min }}
$$

The total current through the load resistor ( $I_{R L}$ ) is the sum of the load current and the high-level output current ( 1 OH ):
$I_{R L}=$ Load Current (into the load inputs $+I_{O H}$ where: $I_{\mathrm{OH}}=375 \mu \mathrm{~A}$ max
Therefore, calculations for the maximum value of $R_{L}$ would be:
$R_{\mathrm{L}(\text { max })}$ in ohms $=\frac{V_{\text {source }}-V_{\mathrm{OH} \text { min }}}{\text { Amperes of Load Current }+.000375}$


$$
\text { Assume: } V_{\text {source }}=5 \mathrm{~V} \text { and } \mathrm{V}_{\mathrm{OH}(\min )}=2.4 \mathrm{~V}
$$

$$
R_{L(\max )}=\frac{v_{\text {source }}-v_{\text {OH }}}{I_{\text {load }}+0.000375}
$$

$$
: \quad R_{L(\max )}=\frac{5-2.4}{0.00025+0.000375} \Omega=\frac{2.6}{0.000625} \Omega=4160
$$

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 IOL capability of the output. Therefore, the equation is:

$$
R_{L(\min )}=\frac{v_{\text {source }}-v_{O L \text { max }}}{I_{\text {OL 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}}$ capebility $=20 \mathrm{~mA}$
$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$
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) |  |
| 20 mA <br> SINK OUTPUTS | $234 \Omega 2$ <br> $250 \Omega$ <br> $256 \Omega$ <br> $230 \Omega$ <br> $230 \Omega$ | $6190 \Omega$ 5909 ת 5777 § 6341 s $6500 \Omega$ | 25252 <br> 383 s2 <br> 460 s 2 <br> $230 s 2$ <br> $230 s 2$ | 5200 S2 <br> $4333 \Omega$ <br> 4160 S2 <br> $5777 \Omega$ <br> 6500 s | $\begin{array}{r} 280 \Omega \\ 1150 \Omega \\ 2300 \Omega 2 \\ 231 \Omega 2 \\ 231 \Omega 2 \end{array}$ | $4333 \Omega$ <br> $3250 \Omega$ <br> $2888 \Omega$ <br> $5200 \Omega$ <br> $6498 \Omega$ | $\begin{aligned} & \text { 54LS/74LS } \\ & 54 / 74 \\ & 54 S / 74 S \\ & \text { MOS } \\ & \text { C-MOS } \end{aligned}$ |
| 10 mA <br> SINK OUTPUTS | 47732 <br> 547 s2 <br> 575 S2 <br> $464 \Omega$ <br> 460 S2 | $6190 \Omega$ <br> 5909 s <br> $5777 \Omega$ <br> 6341 s <br> $6500 \Omega$ | $\begin{gathered} 560 \Omega \\ 2300 \Omega \\ 4000 \Omega 2 \\ 462 \Omega \\ 460 \Omega 2 \end{gathered}$ | $\begin{aligned} & 5200 \Omega \\ & 4333 \Omega 2 \\ & 4000 \Omega 2 \\ & 5777 \Omega \\ & 6500 \Omega \end{aligned}$ | TYPE OF LOGIC 54LS/74LS $54 / 74$ $54 S / 74 S$ MOS C.MOS |  |  |

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

## CONDITIONS:

| $V_{\text {source }}=5 \mathrm{~V}$ |  |  |
| :---: | :---: | :---: |
| $\mathrm{VOH}_{\text {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 |  |  |
| $\mathrm{IOH}^{\prime}=375 \mu \mathrm{~A}$ (Maximum leakage of SBP0400A/SBP0401A) |  |  |
| 1 OL as specified ( $20 \mathrm{~mA}, 10 \mathrm{~mA}$ ) |  |  |
| And unit loads of: | IIL $=$ | $1 \mathrm{IH}=$ |
| 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 RL(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 ( 1 OL ) of the particular output beind 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

12L 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 voltang,

|  | quired <br> power ample, pply and panded P0401A <br> gures 28 ges. Ta ector cu | suffi <br> p/pow <br> 5-vo <br> he inj <br> stems <br> nd 29 <br> 40 p <br> ents. <br> CUR | (see <br> down TL or pin sing <br> ow ides | ble 40 perati wer su of the ultiple <br> typic appr <br> E 40 <br> TING R | A dry <br> n) - li <br> ply is 12 L de 4 bit <br> inject ximate <br> SISTO | ll bat lly wh e used e, as il ces, an node sistor |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {a mpecon }}$ | 0.01 mA | 0.1 mA | 1 mA | 10 mA | 100 mA | 200 mA | Sup Volt |
| 㐫 | 1.19 | 114 K | 11 K | 1.1 K | 110 | 56 | 12 V |
| ¢ | 840 K | 84k | 8.4 K | 830 | 82 | 41 | 9 V |
| \% | 540k | 54 K | 5.4 K | 530 | 52 | 26 | 6v |
| $\frac{1}{6}$ | 40K | 44 K | 4.4 K | 430 | 42 | 21 | 5 v |
|  | $390 \%$ | ${ }^{39}$ | ${ }^{3.9 \mathrm{~K}}$ | 380 | 37 | 18 | 4.5 v |
| 8 | 240 K | 24k | 2.4 K | 230 | 22 | 11 | 3 V |
| 4 | 90K | 9 K | 960 | 82 | 7 | 3.25 | 1.5 v |
| 4 | 63k | 6K | 550 | 50 | 4 | 1.75 | 1.2 V |



FIGURE 27 - INJECTOR CURRENT CALCULATIONS


FIOURE 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 $=\mathbf{2 0 0} \mathbf{~ m A}$

|  |  | SBP0400AM |  |  | SBP 0400AC |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply current, ICC |  |  | 200 | 300 |  | 200 | 300 | mA |
| High-level output voltage, VOH |  |  |  | 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 }}$, PCCOUT/BMSB, ENINCBY 2/AMSB |  |  | 10 |  |  | 10 |  |
| Width of clock pulse, $\mathrm{t}_{\text {w }}$ | High |  | 255 |  |  | 230 |  | ns |
|  | Low |  | 50 |  |  | 45 |  |  |
| Setup time, t su <br> (See Figure 30) | OPERATION SELECT (0400A ONLY) |  | 78 |  |  | 70 |  |  |
|  | $\overline{\text { PCCIN }}$ |  | 28 |  |  | 25 |  |  |
|  | DIP $\rightarrow$ RF, WR, XWR |  | 110 |  |  | 100 |  | ns . |
|  | DIP THRU ALU |  | 200 |  |  | 180 |  | r |
|  | ALUCIN |  | 132 |  |  | 120 |  |  |
| Hold time, $\mathrm{th}^{\text {a }}$ (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 IOVER RECOMMENDED OPERATING FREE-AIR TEMPERATURE RANGE, UNLESS OTHERWISE NOTED)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | SBP0400AM |  |  | SBP0400AC |  |  | 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 |
| VIK | Input clamp voltage |  | $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} & I_{\mathrm{CC}}=200 \mathrm{~mA}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 \mathrm{~V} \\ & V_{O H}=5.5 \mathrm{~V} \end{aligned}$ |  |  | 400 |  |  | 250 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Low-level output voltage |  | $\begin{aligned} & \mathrm{I} \mathrm{CC}=200 \mathrm{~mA}, \\ & \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.4 |  |  | 0.4 | V |
|  | Input current | Clock, PCCIN | $I^{C C}=200 \mathrm{~mA}, \quad 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}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$.

| TaRAMETER | FROM | то | TEST CONDITIONS | TYP MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ReLH or tPHL | DIP | DOP | VIA A BUS, BYPASS ALU | 85 | ns |
| \%2H or tPHL | DIP | DOP | VIA A BUS, THRU ALU | 155 | ns |
| WhH or tPHL | DIP | DOP | VIA B BUS, THRU ALU | 155 | ns |
| \% 2 H or tPHL | PC PRIORITY | AOP |  | 70 | ns |
| * ${ }^{\text {ch }}$ L or TPHL | ALUCIN | ALUCOUT |  | 60 | ns |
|  | DIP | ENINCBY2/AMSB | POSO $=X, \quad$ POS1 $=H$ | 80 | ns |
| 5LH or tPHL | DIP | PCCOUT/BMSB | POS0 $=X, \quad$ POS $1=H$ | 80 | ns |
| FLH or tPHL | POSO, or POS1 | ENINCBY2/AMSB or $\overline{\text { PCCOUT/BMSB }}$ |  | 95 | ns |
| * LH or tPHL | $\overline{\text { PCCIN }}$ | PCCOUT |  | 35 | ns |
| ${ }^{3} \mathrm{PLH}$ or tPHL | ALUCIN | DOP |  | 105 | ns |
| X\%H or tPHL | CLOCK | $\overline{\text { PCCOUT/BMSB }}$ | POSO $=X, \quad$ POS1 $=H$ | 140 | ns |
| 6iPH or tPHL | CLOCK | DOP | VIA A BUS, BYPASS ALU | 155 | ns |
| TPLH or tPHL | CLOCK | DOP | VIA A BUS, THRU ALU | 240 | ns |
| 3 LH or TPHL | CLOCK | ENINCBY2/AMSB | POSO = X, POS1 $=H$ | 155 | ns |
| \% ${ }_{\text {LH }}$ Or TPHL | CLOCK | DOP | VIA B BUS, THRU ALU | 225 | ns |
| WH or TPHL | CLOCK | P.G, or ALUCOUT | VIA A OR B BUS, THRU ALU | 180 | ns |
| \$IH or tPHL | CLOCK | AOP |  | 105 | ns |
| PLH or tPHL | CLOCK | $\overline{\text { WRLFT, }} \overline{\text { WRRT }}, \overline{\text { XWRLFT }}$, or XWRRT |  | 240 | ns |
| \%LH or tPHL | CLOCK | XWR MUX MSB | $P O S 0=H, \quad$ POS $1=H$ | 130 | ns |
| PPLH or TPHL | CLOCK | XWR MUX LSB | POSO $=H, \quad$ POS $1=L$ | 130 | ns |
| PLH or tPhL | CLOCK | $A L U=0$ |  | 215 | ns |

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

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



SETUP, HOLD, AND PROPAGATION DELAY TIMES FOR TYPICALSBPO400A ADD AND SHIFT OPERATION

FIGURE 30 - PROPAGATION DELAY TIMES - SBPO400A SYNCHRONOUS OPERATIONS


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



| REF. | OUTPUTS | MAXIMUM CURRENT RATING | $R_{\text {L }}$ VALUE | $C_{L}$ VALUE |
| :---: | :---: | :---: | :---: | :---: |
| 1 | ANY AOB, DOB, $\bar{P}, \bar{G}$, ALUCOUT OR XWR MSB/LSB | 20 mA | $280 \Omega$ | 50 PF |
| 2 | $\overline{\overline{X W R L F T}} \overline{\text { XWRRT, }} \overline{\text { WRRT, }} \overline{\text { WRLFT, }}$ $\overline{\text { PCCOUT/BMSB, ENINCBY2/AMSB }}$ | 10 mA | $560 \Omega$ | 25 PF |

FIGURE 33 - SWITCHING TIMES LOAD CIRCUITS


FIGURE 34 - TYPICAL SWITCHING CHARACTERISTICS


FIGURE 35 - PLASTIC DUAL-IN-LINE PACKAGE


FIGURE 36 - CERAMIC DUAL-IN-LINE PACKAGE

ORDERING INFORMATION

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

The Engineering Staff of
TEXAS INSTRUMENTS INCORPORATED Semiconductor Group


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.

## 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. 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 89900 LDCR/STCR Data Transfers ..... 8
Figure $9 \quad 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 ..... 18
Table 5 Status Register Bit Definitions ..... 19
Table 6 Instruction Execution Times ..... 27


FIGURE 1 - SBP 9900 ARCHITECTURE
TENTATIVE DATA SHEET
This document provides tentative Information on a new product. Texas Instruments reserves the right to change speclfications for thls product in any manner without notice.

## 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. 12 L technology enables the SBP9900 to operate over a -55 to $125^{\circ} \mathrm{C}$ ambient temperature range from a single 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
- $\quad 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
- $1^{2} \mathrm{~L}$ Technology:
- $\quad-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ Ambient Temperature Range
- 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)


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, FFFC16 and 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{R E S E T}$, and $\overline{\text { 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 RESET 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, except for level-zero interrupt, which loads zero into the mask. 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 to preserve program linkage should a higher priority interrupt occur. 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 Levei | Vector Location (Memory Address In Hex) | Device Assignment | Interrupt Mesk Values To Enable Respective Interrupts (ST12 thru ST15) | $\begin{gathered} \text { Interrupt } \\ \text { Codes } \\ \text { ICO thru IC3 } \\ \hline \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| (Highest priority) 0 | 00 | Reset | 0 through 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 TNTRED 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 $\mathbf{4 0 9 6}$ peripheral input bits and up to 4096 peripheral output bits. The SBP $\mathbf{9 9 0 0}$ 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 9800 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

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

## 25 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 $\mathbf{1 6 - b i t}$ 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.


### 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, RESET, or 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 FFC 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.

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

TABLE 3
9900 PIN ASSIGNMENTS AND FUNCTIONS


| 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). |
| INTREQ | 32 | IN | INTERRUPT CONTROL <br> INTERRUPT REQUEST. When active (logic level LOW), INTREQ indicates that an external interrupt is requesting service. If 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) ICO (LSB) | 36 33 | IN | INTERRUPT CODES. ICO (MSB) through IC3 (LSB), receiving an interrupt identity code, are sampled by the SBP 9900 when INTRED 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 requesting service. | requesting service.

## 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}$, MEMEN, 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, WE, MEMEN, 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 microinstruction cycle on the low-to-high transition of the next CLOCK.

When active (logic level LOW), $\overline{L O A D}$ causes the SBP 9900 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{L O A D}$ will also terminate an idle state. If LOAD is active during the time 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)

| SGGNATURE | PIN | $1 / 0$ | DESCRIPTION |
| :--- | :--- | :--- | :--- |
| LOAD (Cont.) |  |  | used to monitor instruction boundaries). 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. |
| RESET | 6 | IN | When active (logic level LOW), RESET causes the SBP 9900 to reset itself and inhibit WE and CRUCLK. <br> When RESET is released, the SBP 9900 initiates a level-zero interrupt sequence acquiring the WP and PC <br> trap vectors from memory locations 000016 and O00216, sets all status register bits to logic level LOW, <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 (AO through A14).

$R D=R E A D$ DATA

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 MEMEN becomes active. At the end of a memory-read cycle, MEMEN 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, WE becomes active (logic level LOW) with the first high-to-low transition of the clock after MEMEN becomes active; DBIN remains inactive. At the end of a memory-write cycle, WE and MEIMEN 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 (HOLD) 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 HOLD 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 D0 through D15. When HOLD 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.


FIQURE 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 R

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 $\mathbf{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 |
| TD | Destination address modifier |
| TS | Source address modifier |
| W | Workspace register |
| WRor | 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 |
| - | 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.


TABLE 5
STATUS REGISTER BIT DEFINITIONS

| BIT | NAME | INSTRUCTION | CONDITION TO SET BIT TO 1 |
| :---: | :---: | :---: | :---: |
| STO | LOGICAL GREATER THAN | C.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) #=0 If result }=``` |
| 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 | C, CB <br> C1 <br> COC <br> CZC <br> TB <br> ABS <br> All Others | $\begin{aligned} & \text { If }(S A)=(D A) \\ & \text { If }(W)=1 O P \\ & \text { If }(S A) \text { and }(D A)=0 \\ & \text { If }(S A) \text { and }(D A)=0 \\ & \text { If } C R U I N=1 \\ & \text { If }(S A)=0 \\ & \text { If result }=0 \end{aligned}$ |
| ST3 | CARRY | $A, A B, A B S, A I, D E C$, DECT, INC, INCT, <br> NEG, S, SB <br> SLA, SRA, SRC, SRL | 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 # MSB(DA) If MSB(W) = MSB of IOP and MSB of result }\not=\mathrm{ MSB(W) If MSB(SA) = MSB(DA) and MSB of result }=\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 If $1<C<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 WR 15 is 1 |

### 3.5 INSTRUCTIONS

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

General format:


If $\mathrm{B}=1$ the operands are bytes and the operand addresses are byte addresses. If $\mathrm{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 $\mathbf{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 | STATUS | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 012 |  |  | $\text { TO } 0$ | AFFECTED |  |
| A | 1001 | 0 | Add | Yes | 0-4 | $(S A)+(D A) \rightarrow(D A)$ |
| AB | 1001 | 1 | Add bytes | Yes | 0.5 | $(S A)+(D A) \rightarrow(D A)$ |
| C | 100 | 0 | Compare | No | 0.2 | Compare (SA) to (DA) and set appropriate status bits |
| CB | 100 | 1 | Compare bytes | No | 0-2,5 | Compare (SA) to (DA) and set appropriate status bits |
| S | $0 \begin{array}{lll}0 & 1 & 1\end{array}$ | 0 | Subtract | Yes | 0.4 | $(D A)-(S A) \rightarrow(D A)$ |
| SB | $\begin{array}{lll}0 & 1 & 1\end{array}$ | 1 | Subtract bytes | Yes | 0-5 | $(D A)-(S A) \rightarrow(D A)$ |
| SOC | $\begin{array}{lll}1 & 1 & 1\end{array}$ | 0 | Set ones corresponding | Yes | 0.2 | $(\mathrm{DA}) \mathrm{OR}(S A) \rightarrow(\mathrm{DA})$ |
| SOCB | 1111 | 1 | Set ones corresponding bytes | Yes | 0-2,5 | $(D A)$ OR $(S A) \rightarrow(D A)$ |
| SZC | 0 1 10 | 0 | Set zeroes corresponding | Yes | 0-2 | $(\mathrm{DA})$ AND $(\overline{S A}) \rightarrow(\mathrm{DA})$ |
| SZCB | 010 | 1 | Set zeroes corresponding bytes | Yes | 0-2,5 | $(\mathrm{DA})$ AND $(\overline{S A}) \rightarrow(\mathrm{DA})$ |
| MOV | 110 | 0 | Move | Yes | 0.2 | $(S A) \rightarrow(D A)$ |
| MOVB | $1 \begin{array}{lll}1 & 1 & 0\end{array}$ | 1 | Move bytes | Yes | 0-2,5 | $(S A) \rightarrow$ (DA) |

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

General format:

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

The addressing mode for the source operand is determined by the ${ }^{T} \mathbf{S}$ field.

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

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

| MNEMONIC | OP CODE | MEANING | RESULT COMPARED TO 0 | STATUS BITS 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 | (D) $\oplus(S A) \rightarrow$ (D) |
| MPY | 001110 | Multiply | No |  | Multipiy 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 WR 15 will be used for the least significant half of the product. |
| DIV | 001111 | Divide | No | 4 | If unsigned (SA) is less than or equal to unsigned (D), perform no operation and set ST4. Otherwise, divide unsigned ( $D$ ) and ( $D+1$ ) by unsigned (SA). 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$ |  | $T_{S}$ |  | 5 |  |  |

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:
$\left(400_{16}+4 D\right) \rightarrow(W P)$
$(4216+4 D) \rightarrow(P C)$
$(4216+4 D) \rightarrow(P C)$
SA $\rightarrow$ (new WR11)
(old WP) $\rightarrow$ (new WR 13)
(old PC) $\rightarrow$ (new WR14)
(old ST) $\rightarrow$ (new WR15)
The 9900 does not test interrupt requests (INTREQ) upon completion of the XOP instruction.

### 3.5.4 Single Operand Instructions

General format:


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

| MNEMONIC | OP CODE | MEANING | RESULT COMPARED$\text { 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 | - | $\mathrm{SA} \rightarrow(\mathrm{PC})$ |
| 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); |
|  |  |  |  |  | $\begin{aligned} & \text { (old PC) } \rightarrow \text { (new WR 14); } \\ & \text { (old ST) }\end{aligned}$ |
|  |  |  |  |  | the interrupt input (INTREQ) is not |
|  |  |  |  |  | tested upon completion of the |
|  |  |  |  |  | BLWP instruction. |
| CLR | 0000010011 | Clear operand | No | - | $0 \rightarrow$ (SA) |
| SETO | 0000011100 | Set to ones | No | - | FFFF $16 \rightarrow$ (SA) |
| INV | 0000010101 | Invert | Yes | 0-2 | $(\overline{S A}) \rightarrow(S A)$ |
| NEG | 0000010100 | Negate | Yes | 0.4 | $-(S A) \rightarrow(S A)$ |
| ABS | 0000011101 | Absolute value* | No | 0.4 | $\\|(S A)\\| \rightarrow(S A)$ |
| SWPB | 0000011011 | 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 | 0000010110 | Increment | Yes | 0.4 | $(S A)+1 \rightarrow(S A)$ |
| INCT | 0000010111 | 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 | 0000011001 | Decrement by two | Yes | 0.4 | $(S A)-2 \rightarrow(S A)$ |
| ${ }^{+1}$ | 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 worde 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

General format:

| 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | $O P C O D E$ |  |  |  | $C$ |  | $T S$ |  | 0 |  |  |  |  |  |  |

The C field specifies the number of bits to be transferred. If $\mathrm{C}=0,16$ bits will be transferred. The CRU base register (WR 12, 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 ( $\mathrm{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}=\mathbf{1}$ through 8 , and is incremented by 2 otherwise.

| MNEMONIC | OP CODE | MEANING | ```RESIJLT COMPARED TO O``` | 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 . |

tsts is affected only if $1 \leqslant \mathrm{C} \leqslant 8$.

### 3.5.6 CRU Single-Bit Instructions



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


### 3.5.7 Jump Instructions

General format:

| OP CODE |  |  |  |  |  |  |  | DISPLACEMENT |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

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.

| MNEMONIC | OP CODE |  |  |  |  |  |  |  |  | MEANING | ST CONDITION TO LOAD PC |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 |  | 7 |  |  |
| JEQ | 0 | 0 | 0 | 1 | 0 | 0 | 1 |  | 1 | Jump equal | ST2 $=1$ |
| JGT | 0 | 0 | 0 | 1 | 0 | 1 | 0 |  | 1 | Jump greater than | ST1 $=1$ |
| JH | 0 | 0 | 0 | 1 | 1 | 0 | 1 |  | 1 | Jump high | STO $=1$ and ST2 $=0$ |
| JHE | 0 | 0 | 0 | 1 | 0 | 1 | 0 |  | 0 | Jump high or equal | STO $=1$ or ST2 $=1$ |
| JL | 0 | 0 | 0 | 1 | 1 | 0 | 1 |  | 0 | Jump low | STO $=0$ and ST2 $=0$ |
| JLE | 0 | 0 | 0 | 1 | 0 | 0 | 1 |  | 0 | Jump low or equal | STO $=0$ or ST2 $=1$ |
| JLT | 0 | 0 | 0 | 1 | 0 | 0 | 0 |  | 1 | Jump less than | $\mathrm{ST1}=0$ and ST2 $=0$ |
| JMP | 0 | 0 | 0 | 1 | 0 | 0 | 0 |  | 0 | Jump unconditional | unconditional |
| JNC | 0 | 0 | 0 | 1 | 0 | 1 | 1 |  | 1 | Jump no carry | ST3 $=0$ |
| JNE | 0 | 0 | 0 | 1 | 0 | 1 | 1 |  | 0 | Jump not equal | ST2 $=0$ |
| JNO | 0 | 0 | 0 | 1 | 1 | 0 | 0 |  | 1 | Jump no overflow | ST4 $=0$ |
| JOC | 0 | 0 | 0 | 1 | 1 | 0 | 0 |  | 0 | Jump on carry | ST3 $=1$ |
| JOP | 0 | 0 | 0 | 1 | 1 | 1 | 0 |  | 0 | Jump odd parity | ST5 $=1$ |

### 3.5.8 Shift Instructions



If $C=0$, bits 12 through 15 of $W R O$ contain the shift count. If $C=0$ and bits 12 through 15 of $W R O=0$, the shift count is 16 .

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

3.5.9 Immediate Register Instructions


| MNEMONIC | OP CODE | MEANING | RESULT | STATUS | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 012345678910 |  | $\text { то } 0$ | AFFECTED |  |
| AI | 00000010001 | Add immediate | Yes | 0-4 | $(\mathrm{W})+\mathrm{IOP} \rightarrow(\mathrm{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 | 00000010000 | Load immediate | Yes | 0-2 | $10 P \rightarrow(W)$ |
| ORI | 00000010011 | OR immediate | Yes | 0.2 | (W) OR IOP $\rightarrow$ (W) |

3.5.10 Internal Register Load Immediate Instructions



### 3.5.11 Internal Register Store Instructions

General format:

| OP CODE |  |  |  |  |  |  |  |  | $N$ | W |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

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 | $(S T) \rightarrow(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 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 |  | 15 |  |

The RTWP instruction causes the following transfers to occur:

$$
\begin{aligned}
& (W R 15) \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: |  |  |  |  |  | $O P$ CODE |  |  |  |  |  | $N$ |  |  |  |  |

External instructions cause the three most-significant address lines ( $A 0$ through $A 2$ ) to be set to the below-described levels and the CRUCLK line to be pulsed, allowing external control functions to be initiated.

| MNEMONIC | OP CODE | MEANING | STATUS BITS AFFECTED | DESCRIPTION | ADDRESS BUS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 012345678910 |  |  |  | AO | A1 | A2 |
| IDLE | 00000011010 | Idle | - | Suspend TMS 9900 instruction execution until an interrupt, $\overline{\text { LOAD, or }}$ $\overline{\text { RESET occurs }}$ | L | H | L |
| RSET | 00000010101 | Reset | 12-15 | $0 \rightarrow$ ST12 thru ST15 | $L$ | H | H |
| CKOF | 00000011110 | User defined |  | --- | H | H | L |
| CKON | 000000111001 | User defined |  | --- | H | L | H |
| LREX | 000000111111 | 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.

## SBP 9900 INSTRUCTION EXECUTION TIMES

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

1) Clock cycle time, $\mathrm{t}_{\mathrm{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_{\mathbf{c}}(C+W \cdot M)
$$

where:
$T=$ total instruction execution time;
$t_{C}=$ clock cycle time;
$\mathrm{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 | $\begin{gathered} \text { CLOCK } \\ \text { CYCLES } \\ \text { C } \\ \hline \end{gathered}$ | MEMORY ACCESS M | ADDRESS MODIFICATION ${ }^{\dagger}$ |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | SOURCE | DEST |
| A | 14 | 4 | A | A |
| $A B$ | 14 | 4 | B | B |
| ABS (MSB - 0) | 12 | 2 | A |  |
| (MSB - 1) | 14 | 3 | A |  |
| AI | 14 | 4 |  |  |
| ANDI | 14 | 4 |  |  |
| B | 8 | 2 | A |  |
| BL | 12 | 3 | A |  |
| BLWP | 26 | 6 | A | - |
| C | 14 | 3 | A | A |
| CB | 14 | 3 | B | B |
| Cl | 14 | 3 |  |  |
| CKOF | 12 | 1 |  |  |
| CKON | 12 | 1 |  |  |
| CLR | 10 | 3 | A |  |
| COC | 14 | 3 | A |  |
| CZC | 14 | 3 | A |  |
| DEC | 10 | 3 | A |  |
| DECT | 10 | 3 | A |  |
| DIV (ST4 is set) | 16 | 3 | A |  |
| DIV (ST4 is reset) | $92 \cdot 124$ | 6 | A |  |
| IDLE | 12 | 1 |  |  |
| !NC | 10 | 3 | A |  |
| INCT | 10 | 3 | A |  |
| INV | 10 | 3 | A |  |
| Jump (PC is |  |  |  |  |
| changed) | 10 | 1 |  |  |
| (PC is not chinged) | 8 | 1 |  |  |
| LDCR (C 0) | 52 | 3 | A |  |
| (1.C.8) | $20+2 \mathrm{C}$ | 3 | B |  |
| (9.C. 15) | $20+2 \mathrm{C}$ | 3 | A |  |
| LI | 12 | 3 |  |  |
| LIMI | 14 | 2 |  |  |
| I-REX | 12 | 1 | . |  |
| $\overline{\text { RESET }}$ Iunction | 26 | 5 |  |  |
| $\overline{\text { LOAD function }}$ | 22 | 5 |  | - |
| Interrupt context iwitch |  | 5 | . |  |


| INSTRUCTION | $\begin{aligned} & \text { CLOCK } \\ & \text { CYCLES } \end{aligned}$ | MEMORY ACCESS | ADDRESS MODIFICATION ${ }^{\dagger}$ |  |
| :---: | :---: | :---: | :---: | :---: |
|  | C | M | SOURCE | DEST |
| LWPI | 10 | 2 |  |  |
| MOV | 14 | 4 | A | A |
| MOVB | 14 | 4 | B | B |
| MPY | 52 | 5 | A |  |
| NEG | 12 | 3 | A |  |
| ORI | 14 | 4 |  |  |
| RSET | 12 | 1 |  |  |
| RTWP | 14 | 4 |  | - |
| S | 14 | 4 | A | A |
| SB | 14 | 4 | B | B |
| SBO | 12 | 2 |  |  |
| SBZ | 12 | 2 |  |  |
| SETO | 10 | 3 | A |  |
| Shill (C, 0) | 12+2C | 3 |  |  |
| (C. O. Bits $12 \quad 15$ of WRO-01 | 52 | 4 |  |  |
| (C-0. Bits $12 \quad 15$ of WRP $N: 0)$ | $20+2 \mathrm{~N}$ | 4 |  |  |
| SOC | 14 | 4 | A | A |
| SOCB | 14 | 4 | B | B |
| STCR (C-0) | 60 | 4 | A |  |
| (1.C.7) | 42 | 4 | B |  |
| (C. 8 ) | 44 | 4 | B |  |
| (9.C. 15 ) | 58 | 4 | A |  |
| STST | 8 | 2 |  |  |
| STWP | 8 | 2 |  |  |
| SWPB | 10 | 3 | A |  |
| SZC | 14 | 4 | A | A |
| SZCB | 14 | 4 | B | B |
| TB | 12 | 2 |  |  |
| $\times{ }^{\text {- }}$ | 4 | 1 | A |  |
| XOP | 36 | 8 | A |  |
| XOR | 14 | 4 | A |  |
|  |  |  |  |  |
| Undetined op code |  |  |  |  |
| $\begin{aligned} & \text { Undetined op codes } \\ & \text { 0000-01FF.0320. } \\ & \text { 033F, OC00.0FFF. } \\ & 0780.07 \mathrm{FF} \end{aligned}$ | 6 | 1 |  | - |

-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. tThe letters $A$ and $B$ refer to the respective tables that follow.


## ADDRESS MODIFICATION - TABLE A

| ADDRESSING MODE | $\begin{gathered} \text { CLOCK } \\ \text { CYCLES } \\ \mathrm{C} \\ \hline \end{gathered}$ | $\begin{gathered} \text { MEMORY } \\ \text { ACCESSES } \\ M \\ \hline \end{gathered}$ |
| :---: | :---: | :---: |
| 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$ ) | 8 | 2 |
| Symbolic ( $T_{S}$ or $T_{D}=10$, S or $\mathrm{D}=0$ ) | 8 | 1 |
| Indexed ( $T_{S}$ or $T_{D}=10$, S or $D \neq 0$ ) | 8 | 2 |

ADDRESS MODIFICATION - TABLE B

| ADDRESSING MODE | CLOCK <br> CYCLES <br> C | 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 \text { or } D=0)$ | 8 | 1 |
| $\begin{aligned} & \text { Indexed }\left(T_{S} \text { or } T_{D}=10,\right. \\ & S \text { or } D \neq 0) \end{aligned}$ | 8 | 2 |

As an example, the instruction MOVB is used in a system with $\mathrm{t}_{\mathrm{C}}=0.333 \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.333(14+0.4) \mu s=4.662 \mu \mathrm{~s}
$$

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

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

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

$$
\begin{aligned}
T= & t_{C}(C+W \cdot M) \\
& C=14+8=22 \\
& M=4+1=5 \\
T= & 0.333(22+2 \cdot 5) \mu \mathrm{s}=10.656 \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

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 $\mathrm{V}_{\mathrm{BE}}$ 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.

## 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 (IOL) 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 nign output voltage ( VOH ) and current $(\mathrm{IOH}), 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 SBP 9900
output voltage
vs
OUTPUT CURRENT


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

12L 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.

An alternate solution utilizes the Texas Instruments TL497 switching-regulator as illustrated in Figure 20.


GENERAL FORMULA (OHM'S LAW)
$R_{\text {DROP }}=\frac{V_{\text {SUPPLY }}-V_{C C}}{I_{C C}}$
EXAMPLE FOR VSUPPLY $=$ BV, AND ICC $=\mathbf{5 0 0} \mathrm{mA}$ :
$R_{\text {DROP }}=\frac{5-1.05}{0.5}=\frac{3.95}{0.5}=7.9$ OHMS
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 - SWITCHING-REGULATOR inJector source


FIGURE 21 - SBP 9800 CLOCK PERIOD VS. INJECTOR CURRENT


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

VS. INJECTOR CURRENT
6. ELECTRICAL AND MECHANICAL SPECIFICATIONS
6.1 SBP 9900 RECOMMENDED OPERATING CONDITIONS, UNLESS OTHERWISE NOTED ICC $=\mathbf{5 0 0} \mathbf{~ m A}$

|  |  | 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, 1 OL |  |  |  | 20 | mA |
| Clock frequency, fclock |  | 0 |  | 2 | MHz |
| Width of clock pulse, $\mathrm{t}_{\text {w }}$ | High (67\%) ( $\mathrm{V}_{1 \mathrm{H}}=2.5 \mathrm{~V}$ max) | 330 |  |  | ns |
|  | Low (33\%) | 170 |  |  |  |
| Clock rise time, $\mathrm{t}_{\mathrm{r}}$ |  |  | 10 |  | ns |
| Clock fall time, $\mathrm{t}_{\mathrm{f}}$ |  |  | 10 |  | ns |
| Setup time, $\mathrm{t}_{\text {su }}$ (see Figure 24) | $\overline{\text { HOLD }}$ |  | $160 \uparrow$ |  | ns |
|  | READY |  | $90 \uparrow$ |  |  |
|  | D0-D15 |  | $45 \uparrow$ |  |  |
|  | CRUIN |  | $25 \uparrow$ |  |  |
|  | INTREQ |  | $0 \uparrow$ |  |  |
|  | ICO-IC3 |  | $0 \uparrow$ |  |  |
| Hold time, $\mathrm{th}^{\text {(see Figure } 24)}$ | HOLD |  | $0 \uparrow$ |  | ns |
|  | READY |  | $30 \uparrow$ |  |  |
|  | DO-D15 |  | $30 \uparrow$ |  |  |
|  | CRUIN |  | $35 \uparrow$ |  |  |
|  | INTREQ |  | $60 \uparrow$ |  |  |
|  | ICO-IC3 |  | $60 \uparrow$ |  |  |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ |  | -55 |  | 125 | ${ }^{\circ} \mathrm{C}$ |

$\uparrow$ Rising edge of clock pulse is reference.
TENTATIVE DATA SHEET

[^4]6.2 SBP 9900 ELECTRICAL CHARACTERISTICS (OVER RECOMMENDED OPERATING FREE-AIR TEMPERATURE RANGE, UNLESS OTHERWISE NOTED)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{+}$ | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\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 |  | ICC $=$ MIN, $\quad I_{1}=-12 \mathrm{~mA}$ |  |  | -1.5 | V |
| ${ }^{\mathrm{IOH}}$ | High-level output current |  | $\begin{array}{ll} \mathrm{I}_{\mathrm{CC}}=500 \mathrm{~mA}, & \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & \mathrm{~V}_{\mathrm{OH}}=5.5 \mathrm{~V} \end{array}$ |  |  | 400 | $\mu \mathrm{A}$ |
| $\mathrm{VOL}_{\text {OL }}$ | Lowlevel output voltage |  | $\begin{array}{ll} I_{C C}=500 \mathrm{~mA}, & \mathrm{~V}_{1 \mathrm{H}}=2 \mathrm{~V} \\ V_{I L}=0.8 \mathrm{~V}, & I_{\mathrm{OL}}=20 \mathrm{~mA} \end{array}$ |  |  | 0.4 | V |
| $1 /$ | Input current | Clock | $1 \mathrm{CC}=500 \mathrm{~mA} \quad V_{1}=2.4 \mathrm{~V}$ | 480 |  |  | $\mu \mathrm{A}$ |
|  |  | All other inputs | $\mathrm{CCC}^{\prime}=500 \mathrm{~mA}, \quad V_{1}=2.4 \mathrm{~V}$ |  | 240 |  |  |

${ }^{\dagger}$ For conditions shown as MAX, use the appropriate value specified under recommended operating conditions.
$\ddagger$ All typical values are at ${ }^{1} \mathrm{CC}=500 \mathrm{~mA}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$.
6.3 SBP 9900 SWITCHING CHARACTERISTICS (ICC $=500 \mathrm{~mA}$ ) SEE FIGURES 24 AND 25.

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

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


FIGURE 24 - SWITCHING TIMES-VOLTAGE WAVEFORMS


FIGURE 25 - SWITCHING TIMES LOAD CIRCUITS
6. CLOCK FREQUENCY VS. TEMPERATURE

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


[^5]
## 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 ElA 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:

5 Vdc @ 20 A
12 V dc @ 2 A
-12 V dc @ 1 A
-5 V dc @ 0.1 A

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

The Engineering Staff of
TEXAS INSTRUMENTS INCORPORATED
Semiconductor Group


DECEMBER 1976

## Texas Instruments

## INDEX FOR SCHOTTKY TTL BIPOLAR MEMORIES

FIELD PROGRAMMABLE READ-ONLY MEMORY (PROM) LINE SUMMARY (SEE PAGE 1)

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

| TYPE NUMBER (PACKAOE8) |  | TYPE OF OUTPUT(8) | BIT 8IZE (ORGANIZATION) | TYPICAL PERFORMANCE |  | $\begin{aligned} & \text { SEE } \\ & \text { PAOE } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $-66^{\circ} \mathrm{C}$ to $126^{\circ} \mathrm{C}$ | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |  |  | ADDRESS ACCESS TIME | POWER DISSIPATION |  |
| SN5488A(J, W) | SN7488A(J, N) | Open-Collector | $\begin{gathered} 256 \text { Blts } \\ (32 \mathrm{~W} \times 8 \mathrm{~B}) \end{gathered}$ | 26 n8 | 320 mW | 7 |
| SN54187(J, W) | 8N74187(J, N) | Open-Collector | $\begin{gathered} 1024 \text { Bits } \\ (288 \mathrm{~W} \times 4 \mathrm{~B}) \end{gathered}$ | 40 ns | 460 mW | 7 |
| SNB4S270(J) | SN74S270(J, N) | Open-Collector | 2048 Bits | 45 n |  | 7 |
| SNS4S370(J) | SN74S370(J, N) | 3-State | ( $612 \mathrm{~W} \times 4 \mathrm{~B}$ ) | 46 ns | 626 mW | 7 |
| SN54S271(J) | SN74S271(J, N) | Open-Collector | 2048 Bits | 45 | 525 | 7 |
| SN54S371(J) | SN74S371 (J, N) | 3-State | (288 W. $\times 8$ 8) | 46 ns | 626 mW | 7 |

READ/WRITE MEMORY (RAM) LINE SUMMARY

| TYPE NUMBER (PACKAGES) |  | BIT 8IZE (ORGANIZATION) | OUTPUT CONFIGURATION | TYPICAL PERFORMANCE |  | $\begin{aligned} & \text { 8EE } \\ & \text { PAOE } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $-66^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  | ADDRESS ACCESS TIME | POWER DISSIPATION |  |
| SN64S189(J, W) | SN74S189(J, N) | $\begin{gathered} 64 \text { bits } \\ (16 \mathrm{~W} \times 48) \end{gathered}$ | Three-state | 25 ns | 375 mW | 15 |
| SN54S289(J, W) | SN748289(J, N) |  | Open-Collector |  |  |  |
| SN64S200A (J, W) | 8N74S200A(J, N) | $\begin{gathered} 286 \mathrm{blts} \\ (286 \mathrm{~W} \times 18) \end{gathered}$ | Three-State | 25 ns | 500 mW | 19 |
| SN54LS200A(J, W) | SN74LS200A (J, N) |  |  | 38 ns | 275 mW |  |
| 8NB4LS202(J, W) | SN74L8202(J, N) |  |  |  | 275/100* mW |  |
| 8NB48300A(J, W) | 8N748300A(J, N) |  | Open-Collector | 25 ns | 500 mW |  |
| SNB4LS300A(J, W) | SN74L8300A (J, N) |  |  | 35 ns | 275 mW |  |
| 8N54LS302(J, W) | 8N74L8302(J, N) |  |  |  | 276/100* mW |  |
|  | 8N748214A(J, N) | $\begin{gathered} 1024 \text { bits } \\ (1024 \mathrm{~W} \times 1 \mathrm{~B}) \end{gathered}$ | Three-8tate | 30 ns | 550 mW | 26 |
| SN648214(J) | 8N748214(J, N) |  |  | 40 ns | 550 mW |  |
| SN64L8214(J) | 8N74LS214(J, N) |  |  | 85 nt | 200 mW |  |
| SN64LS218(J) | SN74LS218(J,N) |  |  | 75 ns | 200/100*mW |  |
|  | SN748314A(J, N) |  | Open-Collector | 30 ns | 650 mW |  |
| SN64S314(J) | SN74S314(J, N) |  |  | 40 ns | 560 mW |  |
| SN54LS314(J) | SN74L8314(J, N) |  |  | 75 ns | 200 mW |  |
| SN54LS315(J) | SN74S314(J, N) |  |  | 76 ns | 200/100 ${ }^{\circ} \mathrm{mW}$ |  |
| SN54S207(J) | SN74S207(J, N) | $\begin{gathered} 1024 \text { bits } \\ (256 \mathrm{~W} \times 48) \end{gathered}$ | Three-State | 40 ns | 600 mW | 31 |
| SN54LS207(J) | SN74LS207(J, N) |  |  | 76 ns | 200 mW |  |
| SN54S208(J) | SN74S208(J,N) |  |  | 40 ns | 600 mW |  |
| SN64LS208(J) | SN74LS208(J,N) |  |  | 75 ns | 200 mW |  |
| SN54S400(J) | SN74S400(J, N) | $\begin{gathered} 4006 \text { bits } \\ (4009 \mathrm{~W} \times 18) \end{gathered}$ | Three-State | 75 ns | 500 mW | 37 |
| SN54S401 (J) | SN74S401(J, N) |  | Open-Collector |  |  |  |

FIRST-IN/FIRST-OUT (FIFO) MEMORY

| TYPE NUMBER <br> (PACKAGES) | BIT $812 E$ (ORGANIZATION) | TYPICAL PERFORMANCE |  |  |  | $\begin{aligned} & \text { 8EE } \\ & \text { PAGE } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | DATA RATES |  | FALL THROUGH | POWER DISSIPATION |  |
|  |  | INPUT | OUTPUT |  |  |  |
| SN74S226(J, N) | $\begin{gathered} 80 \text { bits } \\ (16 \mathrm{~W} \times 68) \end{gathered}$ | dec to 10 MHz | d-c to 10 MHz | 215 ns | 400 mW | 39 |

- Powered down
- 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
Address Mapping/Look-Up Tables

| TYPE NUMBER (PACKAGES) |  | BIT SIZE (ORGANIZATION) | OUTPUT CONFIGURATION | TYPICAL PERFORMANCE |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $-88^{\circ} \mathrm{C}$ to $128^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  | ADDRESS ACCESS TIME | POWER DISSIPATION |
| 8N64S188(J, W) | SN74S188(J, N) | 256 bits | open-collector | 25 | 400 |
| SNS4S288(J,W) | SN74S288(J, N) | (32W $\times 8 \mathrm{~B}$ ) | three-state | 26 n8 | 400 mW |
| 8N64S287(J, W) | SN74S287(J, N) | 1024 bits | three-state |  | 500 mW |
| 8N848387(J, W) | SN74S387(J, N) | (256W $\times 4$ B) | open-collector | n8 | 600 mw |
| SNB4S470(J) | SN74S470(J, N) | 2048 bits | open-collector | 50 | 550 mW |
| 8NE48471 (J) | SN74S471(J, N) | (256 W 8 B ${ }^{\text {) }}$ | three-state | 50 n | 650 mW |
| 8N648472(J) | SN74S472(J, N) | 4096 bits | three-state | 55 n | 600 m |
| SNE4S473(J) | SN74S473(J, N) | (512 W $\times 8 \mathrm{~B}$ ) | open-collector | 65 ns | 600 mW |
| SNS4S474(J, W) | SN74S474(J, N) | 4096 bits | three-state | 55 ns | 600 mW |
| SNS4S475(J, W) | SN74S476(J, N) | (512W W 8 B ) | open-collector | 55 ns | 600 mW |

248 BIT8
M WORDS BY 8 B
4188, "8288


1024 BIT8
NORD8 BY 4
' $8287, ~ ‘ 8387$


2048 BIT8
NORDS BY 8
'8470, 'C471


4006 BIT8
( 812 WORDS BY 8 BIT8)
'8472, '8473


1

4098 BIT8 (812 WORD8 BY 8 BIT8) '8474, '8478


## description

These monolithic TTL programmable read-only memories (PROM's) feature titanium-tungsten (Ti-W) fuse links with each link designed to program in one millisecond or less. 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 a dual-in-line package having pin-row spacings of 0.300 inch.

## description (continued)

Data can be electronically programmed, as desired, at any bit location in accordance with the programming proceduret 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, 'S475

'S188, 'S387,
'S470, 'S473, 'S475

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

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage (see Note 1) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 V
Input voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V
Off-state output voltage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5.5 V
Operating free-air temperature range: SN54S' Circuits . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $\mathbf{1 2 5}^{\circ} \mathrm{C}$
SN74S' Circuits . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage temperature range $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
recommended conditions for programming

${ }^{\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 supplled with all bit locations containing a low logic lever, and programming a bit changes the output of the bit to high logic level. The 'S287 and 'S387 are supplied with all bit outputs at a high logic level, and programming a bit changes it to a low logic leval.
3. Programming is guaranteed if the pulse applied is 0.9 ms long.

## step-by-step programming procedure

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 supply during programming is 150 mA .
5. Step $\mathrm{V}_{\mathrm{CC}}$ 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 $10 \mu \mathrm{~s}$ and 1 ms after $\mathrm{V}_{\mathrm{CC}}$ has reached its $10.5-\mathrm{V}$ level. See programming sequence of Figure 2.
7. After the $X$ pulse time ( 1 ms ) is reached, a high logic level is applied to the chip-select inputs to disable the outputs.
8. Within $10 \mu \mathrm{~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) $10 \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


## SERIES 54S/74S <br> PROGRAMMABLE READ-ONLY MEMORIES WITH 3-STATE OUTPUTS

## recommended operating conditions


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 |  |
| $V_{\text {IH }}$ | High-level input voltage |  |  |  |  | 2 |  |  | 2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  |  |  |  | 0.8 |  |  | 0.8 | V |
| VIK | Input clamp voltage | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$, | $1_{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{IOH}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ | 2.4 | 3.4 |  | 2.4 | 3.2 |  | $\checkmark$ |
| VOL | Low-level output voltage | $\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 L}=M A X \end{aligned}$ |  |  | 0.5 |  |  | 0.5 | V |
| IOZH | Off-state output current, high-level voltage applied | $\begin{aligned} & V_{C C}=\mathrm{MAX}, \\ & V_{O}=2.4 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\text {IH }}=2 \mathrm{~V}$, |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
| 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}$ | $\mathrm{V}_{\text {IH }}=2 \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 |
| 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}=$ MAX, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  | -250 |  |  | -250 | $\mu A$ |
| Ios | Short-circuit output current § | $V_{C C}=$ MAX |  | -30 |  | -100 | -30 |  | -100 | mA |
| ICC | 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 TA and VCC (unless otherwise noted)

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

[^6]
## recommended operating conditions


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

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$ |  | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $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}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| IOH | 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 |  |
| VOL | Low-level output voltage | $\begin{array}{ll} V_{C C}=M I N, & V_{I H}=2 \mathrm{~V}, \\ V_{I L}=0.8 \mathrm{~V}, & I_{\mathrm{OL}}=\mathrm{MAX} \end{array}$ |  |  |  | 0.5 | V |
| 11 | Input current at maximum input voltage | $V_{C C}=M A X$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 | mA |
| IIH | High-level input current | $V_{C C}=M A X$,$V_{C C}=M A X$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 25 | $\mu \mathrm{A}$ |
| 1 L | Low-level input current |  | $\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 VCC (unless otherwise noted)

| TYPE | TEST CONDITIONS | $t_{a}(\mathrm{ad})$ (ns) <br> Access time from address |  | $\mathrm{t}_{\mathrm{a}(\mathrm{~S})} \text { (ns) }$ <br> Access time from chip select (enable time) |  | tPLH (ns) <br> Propagation delay time, low-to-high-level output from chip select (disable time) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX |
| SNEAS188 | $\begin{aligned} & C_{L}=30 p F, \\ & R_{L 1}=300 \Omega, \\ & R_{L 2}=600 \Omega, \\ & \text { See Figure } 3 \end{aligned}$ | 25 | 50 | 12 | 30 | 12 | 30 |
| SN74S188 |  | 25 | 40 | 12 | 25 | 12 | 25 |
| SN54S387 |  | 42 | 75 | 15 | 40 | 15 | 40 |
| SN74S387 |  | 42 | 65 | 15 | 35 | 15 | 35 |
| SN54S470 |  | 50 | 80 | 20 | 40 | 15 | 35 |
| 8N74S470 |  | 50 | 70 | 20 | 35 | 15 | 30 |
| 8N64S473, SN54S475 |  | 55 | 85 | 20 | 45 | 15 | 40 |
| SN74S473, SN74S475 |  | 55 | 75 | 20 | 40 | 15 | 35 |

[^7]
## PARAMETER MEASUREMENT INFORMATION



LOAD CIRCUIT


VOLTAGE WAVEFORMS

NOTES:
A. The input pulse generator has the following characteristics: $Z_{\text {out }} \approx 50 \Omega$, PRR $\leqslant 1 \mathrm{MHz}, \mathrm{t}_{\mathrm{r}} \leqslant 2.5 \mathrm{~ns}$, and $\mathrm{t}_{\mathrm{f}} \leqslant 2.5 \mathrm{~ns}$.
B. $C_{L}$ includes probe and jig capacitance.
C. The pulse generator is connected to the input under test. The other inputs, memory content permitting, are connected so that the input will switch the output under test.

FIGURE 3 - SWITCHING TIMES OF 'S188, 'S470, 'S387, 'S473, AND 'S475


NOTES: A. When measuring access times from address inputs, the chip select input(s) is(are) low.
B. When measuring access and disable times from chip-select input(s), the address inputs are steady-state.
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 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 \mathbf{1} \mathbf{M H z}$, and $Z_{\text {out }} \approx 50 \$ 2$.

FIGURE 4 - SWITCHING TIMES OF ‘S287, ‘S288, ‘S471, 'S472, AND 'S474

- Mask-Programmed Memories That Can Replace PROMs
- Full On-Chip Decoding and Fast Chip Select(s) Simplify System Decoding
- All Schottky-Clamped ROMs Offer
-Choice of 3-State or Open-Collector Outputs
-P-N-P Inputs for Reduced Loading on System Buffers/Drivers
- Applications Include:
-Microprogramming Firmware/Firmware Loaders
- Code Converters/Character Generators
-Translators/Emulators
-Address Mapping/Look-Up Tables

| TYPE NUMBER (PACKAGES) |  | TYPE OF OUTPUT(S) | BIT SIZE | TYPICAL ACCESS TIMES |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $-66^{\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 |  | 45 |
| SN54S370(J) | SN74S370(J, N) | 3-State | ( $512 \mathrm{~W} \times 4 \mathrm{~B}$ ) |  | 45 ns |
| SN54S271(J) | SN74S271(J, N) | Open-Collector | 2048 Bits | 15 | 45 |
| SN54S371(J) | SN74S371(J, N) | 3-State | ( $256 \mathrm{~W} \times 8 \mathrm{~B}$ ) |  |  |

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

256 BITS ( 32 WORDS BY 8 BITS)
'88A

1024 BITS (256 WORDS BY 4 BITS)

- 187


2048 BITS ( 512 WORDS BY 4 BITS) 'S270, 'S370


2048 BITS (256 WORDS BY 8 BITS) 'S271, 'S371


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

Integrated Schotiky-Berrier diodoclamped tranesiotor is paterited by
Toxes Instruments. U. 8. Patent
Number 3,463,976.
functional block diagrams

SN5488A, SN7488A


SNB4S370, SN748730
Same as SNB4S270, SN74S270 except
outputs are as shown below:
Chit er 3

word addressing

## -88A

WORD ADDRESS TABLE

| WORD | INPUTS |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | E | D | C | B | A |
| O | 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 |
| B | L | H | L | L | L |
|  |  | Words | thru |  |  |
| 27 |  | 28 | Omitted |  |  |
| 28 | H | H | H | H | L |
| 29 | H | H | H | L | H |
| 30 | H | H | H | H | L |
| 31 | H | H | H | H | H |

SN54187, SN74187



SNE4S371, SN74S371
Same es SNE4S271, SN 74S271 except
outputs are as shown below

'S270, 'S370
WORD ADDRESS TABLE


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

'88A, '187


'187
'88A


## 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 SN54187 in the $W$ package operating at free-air temperatures above $111^{\circ} \mathrm{C}$ requires a heat sink that provides e 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 <br> READ-ONLY MEMORIES

recommended operating conditions


NOTE 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, $R_{\theta C A}$, of not more than $46^{\circ} \mathrm{C} / \mathrm{W}$.
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 | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$, | $I_{1}=-12 \mathrm{~mA}$ |  |  | -1.5 |  |  | -1.5 | V |
| ${ }^{1} \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} & V_{C C}=M I N, \\ & V_{I H}=2 \mathrm{~V}, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\mathrm{I}^{\text {OL }}=12 \mathrm{~mA}$ |  | 0.2 | 0.4 |  |  | 0.4 | V |
|  |  |  | $\mathrm{IOL}^{\prime}=16 \mathrm{~mA}$ |  |  |  |  |  | 0.45 |  |
| $1 /$ | Input current at maximum input voltage | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \quad \mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  |  | 1 |  |  | 1 | mA |
| $\mathrm{I}_{1} \mathrm{H}$ | High-level input current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \quad \mathrm{V}_{1}=2.4 \mathrm{~V}$ |  |  |  | 25 |  |  | 40 | $\mu \mathrm{A}$ |
| I/L | Low-level input current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \quad \mathrm{V}_{1}=0.4 \mathrm{~V}$ |  |  |  | -1 |  |  | -1 | mA |
| ICC | Supply current |  |  |  | 64 | 80 |  | 92 | 130 | mA |
| $\mathrm{C}_{0}$ | Off-state output capacitance | $\begin{aligned} & V_{C C}=5 \mathrm{~V}, \quad V_{O}=5 \mathrm{~V}, \\ & 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{C}} \mathrm{C}=5 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$.
NOTE 3: With outputs open and $\overline{C S}$ input(s) grounded, ' 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, VCC $=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS | '88A |  | '187 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP | MAX | TYP | MAX |  |
| $\mathrm{ta}_{\text {a }}^{\text {ad) }}$ ) | Access time from address |  | $\begin{aligned} & C_{L}=30 \mathrm{pF}, \\ & R_{L 1}=400 \Omega(\prime 88 A) \\ & 300 \Omega(\prime 187) \end{aligned}$ | 26 | 45 | 40 | 60 | ns |
| $\mathrm{t}_{\mathrm{a}}(\overline{\mathbf{S}}$ ) | Access time from chip select (enable time) | 22 |  | 35 | 20 | 30 | ns |
| ${ }^{\text {tPLH }}$ | Propagation delay time, low-to-high-level output from chip select (disable time) | $\begin{aligned} & 300 \Omega(' 187) \\ & R_{L 2}=600 \Omega, \end{aligned}$ <br> See Figure 1 | 22 | 35 | 20 | 30 | ns |

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

|  | SN54S270 <br> SN54S271 |  |  | $\begin{aligned} & \text { SN74S270 } \\ & \text { SN74S271 } \end{aligned}$ |  |  | SN54S370 <br> SN54S371 |  |  | $\begin{aligned} & \text { SN74S370 } \\ & \text { SN74S371 } \end{aligned}$ |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | NOM | MAX | 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.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, ${ }^{\text {OH }}$ |  |  |  |  |  |  |  |  | -2 |  |  | -6.5 | mA |
| Low-level output current, IOL |  |  | 16 |  |  | 16 |  |  | 16 |  |  | 16 | mA |
| Operating free-air temperature, $\mathrm{T}_{\text {A }}$ | -55 |  | 125 | 0 |  | 70 | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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 |  |
| $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} & V_{C C}=\mathrm{MIN}, \\ & V_{I L}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 V, \\ & I_{O H}=M A X \end{aligned}$ |  |  |  | 2.4 |  |  | V |
| ${ }^{1} \mathrm{OH}$ | High-level output current | $\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{OH}}=2.4 \mathrm{~V}$ |  |  | 50 |  |  |  | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{OH}}=5.5 \mathrm{~V}$ |  |  | 100 |  |  |  | $\mu \mathrm{A}$ |
| $\mathrm{VOL}_{\text {O }}$ | Low-level output voltage | $\begin{array}{\|l\|} \hline \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V} \\ \hline \end{array}$ | $\begin{aligned} & V_{I H}=2 V \\ & I_{O L}=M A X \end{aligned}$ |  |  | 0.5 |  |  | 0.5 | V |
| IOZH | 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} & \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}=$ MAX, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 |  |  | 1 | mA |
| $\mathrm{I}_{1} \mathrm{H}$ | High-level input current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 25 |  |  | 25 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{1 \mathrm{~L}}$ | Low-level input current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  | -0.25 |  |  | -0.25 | mA |
| Ios | Short-circuit output current \$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  |  |  |  | -30 |  | -100 | mA |
| ICC | Supply current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$, | See Note 4 |  | 105 | 155 |  | 105 | 155 | mA |
| $C_{0}$ | Off-state output capacitance | $\begin{aligned} & 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 A l l$ typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
8Not 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 CS input(s) grounded, ICC 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 TA and VCC (unless otherwise noted)

| PARAMETER | TEST CONDITIONS | SN54270 <br> SN54271 |  | $\begin{aligned} & \hline \text { SN74270 } \\ & \text { SN74271 } \end{aligned}$ |  | $\begin{aligned} & \hline \text { SN54370 } \\ & \text { SN54370 } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { SN74370 } \\ & \text { SN74370 } \\ & \hline \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX |  |
| $\mathrm{t}_{\mathrm{a}}(\mathrm{ad}) \quad$ Access time from address | $R_{\mathrm{L} 2}=600 \mathrm{~S} 2,$ <br> See Figure 1 | 45 | 95 | 45 | 70 |  |  |  |  | ns |
| $\mathrm{ta}_{\mathrm{a}}$ S ) Access time from chip select (enable time) |  | 15 | 45 | 15 | 30 |  |  |  |  | ns |
| tPLH <br> Propagation delay time, <br> low-to-high-level output <br> from chip select (disable time) |  |  | 40 | 15 | 25 |  |  |  |  | ns |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{ad})$ Access time from address | $C_{L}=30 \mathrm{pF}$ <br> See Figure 2 |  |  |  |  | 45 | 95 | 45 | 70 | ns |
| $\mathrm{t}_{\mathbf{a}(1 \text { 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$ All typical values are at $\mathrm{V}_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$.


LOAD CIRCUIT
VOLTAGE WAVEFORMS

NOTES: A. The input pulse generator has the following characteristics: $P R R \leqslant 1 \mathrm{MHz}, \mathbf{Z}_{\text {out }} \approx 50 \mathrm{~S}$, For $\mathbf{S e r i e s} 54 / 74, \mathrm{t}_{\mathrm{r}} \leqslant 7 \mathrm{~ns}, \mathrm{tf}_{\mathrm{f}} \leqslant 7 \mathrm{~ns}$, for Series $54 \mathrm{~S} / 74 \mathrm{~S}, \mathrm{t}_{\mathrm{r}} \leqslant 2.5 \mathrm{~ns}, \mathrm{t}_{\mathrm{f}} \leqslant 2.5 \mathrm{~ns}$.
B. $C_{L}$ includes probe and jig capacitance.
C. The pulse generator is connected to the input under test. The other inputs, memory content permitting, are connected so that the input will switch the output under test.

FIGURE 1-SWITCHING TIMES OF '88A, '187, 'S270, AND 'S271 (OPEN-COLLECTOR OUTPUTS)


NOTES: A. When measuring access times from address inputs, the chip-select input(s) is(are) low.
B. When measuring access and disable times from chip-select input(s) the address inputs are steady-state.
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 pulse generators having the following characteristics: $t_{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$.

FIGURE 2-SWITCHING TIMES OF 'S370 AND 'S371 (3-STATE OUTPUTS)

## 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) TI 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. $\mathrm{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

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)
2. 7 Punch a right.justified integer representing the binary input address (007-255) for the last set of outputs described on the card.
3. 9 Blank

## SERIES 54/74, 54S/74S <br> 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-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.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 informa tion 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 loutputs 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.

PRITIILD IN USA
It connot assume ony responsibitity for any circuits shown

TEXAS INSTRRUMENTS
POST OFFICE BOX 5012 - DALLAS. TEXAS 75222

- 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 I2L 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 p-n-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]
## 64-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

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

|  |  | SN54S189 |  |  | SN64S289 |  |  | SN74S189 |  |  | SN74S289 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply Voltage, VCC |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 | V |
| High-level output voltage, $\mathrm{V}_{\mathrm{OH}}$ |  |  |  |  |  |  | 5.5 |  |  |  |  |  | 5.5 | V |
| High-lovel output current, 1 OH |  |  |  | -2 |  |  |  |  |  | -6.5 |  |  |  | mA |
| Low-level output current, IOL |  |  |  | 16 |  |  | 16 |  |  | 16 |  |  | 16 | mA |
| Width of write pulse (write enable low), tw(wr) |  | 25 |  |  | 25 |  |  | 25 |  |  | 25 |  |  | ns |
| Sotup time | Address before write pulse, $t_{s u}(d a)$ | O】 |  |  | O+ |  |  | O $\downarrow$ |  |  | O $\downarrow$ |  |  | n8 |
|  | Data before end of write pulse, tsu(da) | $25 \dagger$ |  |  | $25 \dagger$ |  |  | $25 \uparrow$ |  |  | $25 \uparrow$ |  |  |  |
|  | Chip-select before end of write pulen, $\mathrm{t}_{\text {su }}(\mathrm{S})$ | $25 \uparrow$ |  |  | $25 \uparrow$ |  |  | $25 \uparrow$ |  |  | $25 \uparrow$ |  |  |  |
| Hold <br> time | Address after write pulse, th(ad) | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | ns |
|  | Date after write pulse, $\mathrm{th}^{\text {(da) }}$ | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  |  |
|  | Chip-select after write pulse, th ( $\overline{\mathbf{S}})$ | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  |  |
| Operating free-air temperature, $T_{A}$ |  | -65 |  | 125 | -55 |  | 125 | 0 |  | 70 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

thThe errow indicates the trensition of the write-enable input used for reference: $\uparrow$ for the low-to-high transition, $\downarrow$ for the high-to-low trandtion.
dectrical 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 |  |
| $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}, \quad \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.2 |  |  | -1.2 | V |
| VOH | High-level output voltage | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}, \quad \mathrm{V}_{\text {IH }}=2 \mathrm{~V}$, | SN54S' | 2.4 | 3.4 |  |  |  |  | V |
|  |  | $V_{1 L}=0.8 \mathrm{~V}, \mathrm{I}^{\mathrm{OH}}=\mathrm{MAX}$ | SN74S' | 2.4 | 3.2 |  |  |  |  |  |
| VOL | Low-level output voltage | $\begin{aligned} & V_{C C}=M I N, \quad V_{I H}=2 \mathrm{~V} \\ & V_{1 L}=0.8 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{0}=2.4 \mathrm{~V}$ |  |  |  |  |  | 40 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{0}=5.5 \mathrm{~V}$ |  |  |  |  |  | 100 |  |
| IOH | High-loval output current | $\begin{array}{ll} V_{C C}=M I N, & V_{I H}=2 \mathrm{~V}, \\ V_{I L}=0.8 \mathrm{~V}, & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{array}$ | SN54S' |  | 0.35 | 0.6 |  | 0.35 | 40 | V |
|  |  |  | SN74S' |  | 0.35 | 0.45 |  | 0.35 | 100 |  |
| IOZH | Off-state output current, high-level voltage applied | $\begin{array}{ll} V_{C C}=M A X, & V_{I H}=2 \mathrm{~V}, \\ V_{I L}=0.8 \mathrm{~V}, & V_{O H}=2.4 \mathrm{~V} \end{array}$ |  |  |  | 50 |  |  |  | $\mu \mathrm{A}$ |
| IOZL | Off-state output current, low-level voltage applied | $\begin{array}{ll} V_{C C}=M A X, & V_{1 H}=2 \mathrm{~V}, \\ V_{I L}=0.8 \mathrm{~V}, & V_{O L}=0.4 \mathrm{~V} \end{array}$ |  |  |  | -50 |  |  |  | $\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 |
| I/H | High-leval input current | $V_{C C}=M A X, \quad V_{1}=2.7 \mathrm{~V}$ |  |  |  | 25 |  |  | 25 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | $V_{C C}=M A X, 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 | VCC $=$ MAX, See Note 2 |  |  | 75 | 110 |  | 75 | 105 | mA |

[^9]
## 64-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

'S189 switching characteristics over recommended operating ranges of TA and VCC (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS$\begin{aligned} & C_{L}=30 \mathrm{pF}, \\ & R_{L}=300 \Omega \\ & \text { See Note } 3 \end{aligned}$ | SN54S189 |  | SN74S189 |  | UNIT ${ }^{\circ}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX |  |
| $t_{\text {a }}$ (ad) | Access time from address |  |  | 25 | 50 | 25 | 35 | ns |
| $\mathrm{ta}_{\mathbf{a}}(\mathrm{S})$ | Access time from chip select (enable time) |  |  | 12 | 25 | 12 | 17 | \% |
| tSR | Sense recovery time |  |  | 22 | 40 | 22 | 35 | ns |
| tpxz | Disable time from high or low leval | from $\overline{\mathbf{S}}$ |  | $\begin{aligned} & C_{L}=5 \mathrm{pF}, \\ & R_{L}=300 \Omega, \\ & \text { See Note } 3 \end{aligned}$ | 12 | 25 | 12 | 17 |  |
|  |  | from $\bar{W}$ | 12 |  | 30 | 12 | 25 | ns |

'S289 switching characteristics over recommended operating ranges of TA and VCC (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS$\begin{aligned} & C_{L}=30 \mathrm{pF}, \\ & R_{\mathrm{L} 1}=300 \Omega, \\ & R_{\mathrm{L} 2}=600 \Omega, \\ & \text { See Note } 3 \end{aligned}$ | SN54S289 |  | SN74S289 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX |  |
| $\mathrm{ta}_{\mathrm{a}}$ (ad) | Access time from eddress |  |  | 25 | 50 | 25 | 35 | ns |
| $\mathrm{ta}_{\mathbf{a}}(\mathbf{S})$ | Access time from chip select (enable time) |  |  | 12 | 25 | 12 | 17 | ns |
| tSR | Sense recovery time |  |  | 22 | 40 | 22 | 35 | n |
| tPLH | Propagation delay time; low-to-high-level output (disable time) | from 5 |  | 12 | 25 | 12 | 17 | ne |
|  |  | from W |  | 12 | 30 | 12 | 25 |  |

$\ddagger$ All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$
NOTES: 3. Loed circult and voltege 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 I2L Circuits
- Chip-Enable/Select Inputs Simplify External Decoding
- Typical Performance:

| TYPES | READ ACCESS <br> TIME | POWER <br> DISS. |
| :--- | :---: | :---: |
| SN74S200A/'S300A | 30 ns | 500 mW |
| SN54S200A/'S300A | 30 ns | 500 mW |
| SN74LS200A/'LS300A | 35 ns | 275 mW |
| SN54LS200A/'LS300A | 35 ns | 275 mW |
| SN74LS202/'LS302 | 35 ns | 275 mW |
| SN54LS202/'LS302 | 35 ns | 275 mW |
| S202/'LS302 | (65 ns |  |
| POWER DOWN | enable) | 100 mW |



E1. E2, E3, = Chip - Enable for 'LS202, 'LS302 $\overline{\text { S1 }}, \overline{\text { S2 }}, \overline{\text { S3 }},=$ Chip - Select for ' LS200A, ' LS 300, 'S200A, 'S300A.

## description

These 256-bit active-element memories are monolithic transistor-transistor logic (TTL) arrays organized as $\mathbf{2 5 6}$ words of one bit. They are fully decoded and have three chip-enable/select inputs to simplify decoding required to achieve expanded system organizations. When the 'LS202/'LS302 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 three chip-enable/select inputs and the write-enable input are low. While the write-enable input is low, the 'S200A, 'LS200A and 'LS202 outputs are in the high-impendance state and the 'S300A, 'LS300A and 'LS302 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-enable/select inputs are low. When any one of the chip-nable/select inpts are high, the 'S200A, 'LS200A, or 'LS202 outputs will be in the high-impedance state, the S300A, LS300A, or LS302 outputs will be off, and the 'LS202 or 'LS302 will be in a power-down mode.

## 256-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

FUNCTION TABLE

| FUNCTION | INPUTS |  | $\begin{gathered} \text { 'S200A } \\ \text { ‘LS200A } \\ \text { 'LS202 } \\ \text { OUTPUT ( } \overline{\mathrm{DO})} \text { ) } \end{gathered}$ | $\begin{gathered} \text { 'S300A } \\ \text { 'LS300A } \\ \text { 'LS302 } \\ \text { OUTPUT ( } \overline{\mathrm{DO}}) \\ \hline \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
|  | CHIP ENABLE (Ēi) or SELECT ( $\mathbf{S i}_{\text {i }}$ ) | WRITE ENABLE ( $\overline{\mathbf{W}})$ |  |  |
| Write | L | L | High Impedance | Off |
| Read | L | H | Complement of Date Entered | Complement of Data Entered |
| Inhibit | H | X | High Impedance | Off |

$H \equiv$ high level, $L \equiv$ low level, $X \equiv$ irrelevant
$\ddagger$ For chip enable/select: $L \equiv$ all $\bar{E} i$ or $\overline{\mathbf{S}}$ inputs low, $H \equiv$ one or more $\bar{E} I$ or $\overline{\mathbf{S}} \mathrm{I}$ inputs high
schematics of inputs and outputs

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 SN54S200A or SN54S300A in the W package operating at free-air temperatures above $104{ }^{\circ} \mathrm{C}$ requires a heat sink that providee e thermal resistance from care to free-air, $\mathrm{R}_{\theta \mathrm{CA}}$, of not more than $38 \mathrm{C} / \mathrm{W}$.
recommended operating conditions

|  |  | SN54S200A |  |  | SN54S300A |  |  | SN74S200A |  |  | SN74S300A |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply Voitage, VCC (see Note 1) |  | 4.5 | 5 | 5.5 | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | 4.75 | 5 | 5.25 | V |
| High-level output voltage, $\mathrm{V}_{\mathrm{OH}}$ |  |  |  |  |  |  | 5.5 |  |  |  |  |  | 5.5 | V |
| High-level output current, IOH |  |  |  | -5.2 |  |  |  |  |  | -10.3 |  |  |  | mA |
| Low-level output current, IOL |  |  |  | 16 |  |  | 16 |  |  | 16 |  |  | 16 | mA |
| Width of write pulse (write enable low), 4w(wr) |  | 40 |  |  | 50 |  |  | 30 |  |  | 40 |  |  | ns |
| Setup | Address before write pulse, $t_{\text {su }}(\mathrm{ad})$ | O $\downarrow$ |  |  | O $\downarrow$ |  |  | O $\downarrow$ |  |  | O $\downarrow$ |  |  | ns |
|  | Data before end of write pulse, $t_{s u}$ (da) | $40 \uparrow$ |  |  | 50¢ |  |  | $30 \uparrow$ |  |  | $40 \uparrow$ |  |  |  |
|  | Chip-select before end of write pulse, $\mathrm{t}_{\text {su }}(\mathbf{S})$ | 404 |  |  | $50 \uparrow$ |  |  | $30 \uparrow$ |  |  | $40 \uparrow$ |  |  |  |
| $\begin{aligned} & \text { Hold } \\ & \text { time } \end{aligned}$ | Address after write pulse, $\mathrm{t}_{\mathrm{h}}(\mathrm{ad})$ | $5 \uparrow$ |  |  | $5 \dagger$ |  |  | 54 |  |  | $5 \uparrow$ |  |  | ns |
|  | Data after write pulse, $\mathrm{t}_{\text {( }}$ (da) | $5 \dagger$ |  |  | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  | 54 |  |  |  |
|  | Chip-select after write pulse, $\text { th( } \bar{S})$ | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  | 51 |  |  |  |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ (See Note 2) |  | -55 |  | 125 | -55 | 125 |  | 0 | 70 |  | 0 | 70 |  | ${ }^{\circ} \mathrm{C}$ |

recommended operating conditions

|  |  |  | SN54LS200A SN54LS300A |  |  | SN74LS200A SN74LS300A |  |  | SN54LS202 SN54LS302 |  |  | SN74LS202 SN74LS302 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX | 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 | 4.5 | 5 | 5.5 | 4.75. | 5 | 5.25 | V |
| $\begin{aligned} & \text { Hightil } \\ & \mathrm{V}_{\mathrm{OH}} \end{aligned}$ | vel output voltage, | $\begin{aligned} & \text { 'LS300A, } \\ & \text { ‘LS302 } \end{aligned}$ |  |  | 5.5 |  |  | 5.5 |  |  | 5.5 |  |  | 5.5 | V |
| $\begin{aligned} & \text { High-i } \\ & \mathrm{IOH} \end{aligned}$ | ovel output current, | $\begin{aligned} & \text { 'LS200A, } \\ & \text { 'LS202 } \end{aligned}$ |  |  | -2 |  |  | -2.6 |  |  | -2 |  |  | -2.6 | mA |
| Low-level output current, IOL |  |  |  |  | 16 |  |  | 16 |  |  | 16 |  |  | 16 | mA |
| Width of write pulse (write enable low), \& (wr) |  |  | 50 |  |  | 35 |  |  |  | 15 |  |  | 15 |  | ns |
| Setup time | Address before write pulse, $t_{s u}(\mathrm{ad})$ |  | $20 \downarrow$ |  |  | 15 $\downarrow$ |  |  | O $\downarrow$ |  |  | 0 $\downarrow$ |  |  | ns |
|  | Data before end of write pulse, $t_{\text {su }}$ (da) |  | 40¢ |  |  | 30ヶ |  |  | $15 \uparrow$ |  |  | $15 \uparrow$ |  |  |  |
|  | Chip enable before end of write pulse, $\mathbf{t}_{\text {su }}(E), \mathbf{t}_{\text {su }}(\overline{\mathbf{S}})$ |  | 50^ |  |  | 40^ |  |  | $35 \uparrow$ |  |  | $35 \dagger$ |  |  |  |
| Hold time | Address after write pulse, th(ad) |  | $10 \uparrow$ |  |  | $0 \uparrow$ |  |  | $-5 \uparrow$ |  |  | -5 $\uparrow$ |  |  | ns |
|  | Date after write pulse, $\mathrm{t}_{\mathrm{h}}$ (da) |  | $10 \uparrow$ |  |  | $0 \uparrow$ |  |  | -5 $\uparrow$ |  |  | -5 $\uparrow$ |  |  |  |
|  | Chip-enable after write pulse,$\operatorname{th}_{h}(E), t_{s u}(\bar{S})$ |  | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  | -5 $\uparrow$ |  |  | -5 $\uparrow$ |  |  |  |
| Operating free-air temperature, $T_{A}$ |  |  | -55 |  | 125 | 0 |  | 70 | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

NOTES: 1. Voltage values are with respect to network ground terminel.
2. An SNS4S200A or SN54S300A in the W Packege operating at free-air temperatures above $104{ }^{\circ} \mathrm{C}$ requires a heat sink that provides a thermal resistance from care to free-air, $\mathrm{R}_{\theta} \mathrm{CA}$, of not more than $38 \mathrm{C} / \mathrm{W}$.

## 256-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

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

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$ |  |  | ${ }^{\prime}$ S200A |  |  | 'S300A |  |  | 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 | $\mathrm{V}_{\text {CC }}=$ MIN, $\quad I_{1}=-18 \mathrm{~mA}$ |  |  |  |  | -1.2 |  |  | -1.2 | V |
| VOH | High-level output voltage | $\begin{array}{ll} V_{C C}=M I N, & V_{I H}=2 \mathrm{~V}, \\ V_{I L}=0.8 \mathrm{~V}, & I_{O H}=M A X \end{array}$ |  |  | 2.4 |  |  |  |  |  | V |
| VOL | Low-level output voltage | $\begin{aligned} & V_{C C}=M 1 N, \\ & V_{I L}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 \mathrm{~V}, \\ & I_{O L}=M A X \end{aligned}$ | SN54S' |  |  | 0.5 |  |  | 0.5 | V |
|  |  |  |  | SN74S' |  |  | 0.45 |  |  | 0.45 |  |
| ${ }^{\prime} \mathrm{OH}$ | High-level output current | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{1 H}=2 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  |  |  | 50 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{0}=5.5 \mathrm{~V}$ |  |  |  |  |  | 100 |  |
| IOZH | Off-state output current, high-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}, & V_{O H}=2.4 \mathrm{~V} \end{array}$ |  |  |  |  | 50 |  |  |  | $\mu \mathrm{A}$ |
| 'OZL | Off-state output current, low-level voltage applied | $\begin{array}{ll} V_{\mathrm{CC}}=\mathrm{MAX}, & V_{\mathrm{IH}}=2 \mathrm{~V}, \\ V_{\mathrm{IL}}=0.8 \mathrm{~V}, & V_{\mathrm{OL}}=0.5 \mathrm{~V} \end{array}$ |  |  |  |  | -50 |  |  |  | $\mu \mathrm{A}$ |
| $1 /$ | Input current at maximum input voltage | $V_{C C}=\mathrm{MAX}, \quad V_{1}=5.5 \mathrm{~V}$ |  |  |  |  | 1 |  |  | 1 | mA |
| IIH | High-level input current | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \quad \mathrm{V}_{1}=$ |  |  |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \quad \mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  |  |  | -250 |  |  | -250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current \$ | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  |  | -30 |  | -100 |  |  |  | mA |
| ICC | Supply current | $V_{C C}=M A X$, | See Note 3 | $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ |  |  | 143 |  |  | 143 | mA |
|  |  |  |  | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |  | 100 | 135 |  | 100 | 135 |  |
|  |  |  |  | $T_{A}=70^{\circ} \mathrm{C}$ |  |  | 124 |  |  | 124 |  |
|  |  |  |  | $\mathrm{T}_{\mathrm{A}}=125^{\circ} \mathrm{C}$ |  |  | 117 |  |  | 117 |  |

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

| PARAMETER |  | TEST CONDITIONS ${ }^{\dagger}$ |  |  | $\begin{aligned} & \text { ‘LS200A } \\ & \text { ‘LS202 } \end{aligned}$ |  |  | $\begin{aligned} & \text { ‘LS300A } \\ & \text { ‘LS302 } \end{aligned}$ |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN ${ }^{\text {' }}$ | 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 |
| VIK | Input clamp voltage | $\mathrm{V}_{C C}=$ MIN, | $I_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.2 |  |  | -1.2 | V |
| VOH | High-level output voltage | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & V_{I H}=2 V, \\ & I_{O H}=M A X \end{aligned}$ |  | 2.4 |  |  |  |  |  | V |
| VOL | Low-level output voltage | $\mathrm{V}_{\text {CC }}=$ MIN, | $V_{\text {IH }}=2 \mathrm{~V}$, | SN54S' |  |  | 0.5 |  |  | 0.5 | V |
|  |  | $\mathrm{V}_{\text {IL }}=0.8 \mathrm{~V}$, | $\mathrm{I}_{\mathrm{OL}}=\mathrm{MAX}$ | SN74S' |  |  | 0.45 |  |  | 0.45 |  |
| ${ }^{1} \mathrm{OH}$ | High-level output current | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $V_{I H}=2 V,$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  |  |  |  | 30 | $\mu \mathrm{A}$ |
|  |  |  |  | $\mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  |  |  |  |  | 100 |  |
| IOZH | Off-state output current, high-level voltage applied | $\begin{aligned} & V_{C C}=M A X, \\ & V_{16}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \end{aligned}$ |  |  |  | 30 |  |  |  | $\mu \mathrm{A}$ |
| IOZL | Off-state output current, low-level voltage applied | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{OL}}=0.5 \mathrm{~V} \end{aligned}$ |  |  |  | -30 |  |  |  |  |
| 11 | Input current at maximum input voltage | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  |  | 1 |  |  | 1 | mA |
| IIH | High-leval input current | $V_{C C}=M A X$, | $V_{1}=2.7 \mathrm{~V}$ |  |  |  | 20 |  |  | 20 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  |  | -250 |  |  | -250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current § | $V_{C C}=$ MAX |  |  | -20 |  | -100 |  |  |  | mA |
| ICC | Supply current - Power up | $V_{C C}=M A X$, | See Note 3 |  |  | 55 | 70 |  | 55 | 70 | mA |
| ICC | Supply current - Power down | $V_{C C}=$ MAX, | $C E=2.4 \mathrm{~V}$ | $\begin{array}{\|l\|} \hline \text { 'LS202 } \\ \text { 'LS302 } \\ \hline \end{array}$ |  | 20 |  |  | 20 |  | mA |

[^10]2200A, 'LS200A switching characteristics over recommended operating ranges of TA and VCC (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | SN54S200A |  | SN74S200A |  | SNGALS200A |  | SN74LS200A |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX |  |
| (4)d) | Access time from address |  |  | $\begin{aligned} & C_{L}=30 \mathrm{pF}, \\ & R_{L}=400 \Omega, \end{aligned}$ <br> See Note 4 | 30 | 60 | 30 | 40 | 35 | 55 | 35 | 45 | ns |
| tels) | Access time from chip select (select time) |  | 15 |  | 40 | 15 | 30 | 15 | 30 | 15 | 25 | ns |
| 5sR | Sense recovery time |  |  |  | 50 |  | 40 |  | 55 |  | 45 | ns |
| tPXZ | Disable time from high or low level | From ${ }^{\text {S }}$ | $\begin{aligned} & C_{L}=5 \mathrm{pF}, \\ & R_{L}=400 \Omega, \\ & \text { See Note } 4 \end{aligned}$ | 15 | 40 | 15 | 30 | 15 | 30 | 15 | 25 | ns |
|  |  | From $\bar{W}$ |  |  | 45 |  | 35 | 20 | 40 |  | 30 |  |

'S300A and 'LS300A switching characteristics over recommended operating ranges of TA and VCC (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | SN54S300A |  | SN74S300A |  | SN74LE300A <br> TYP $\ddagger$ MAX |  | $\begin{aligned} & \text { SN74LE300A } \\ & \text { TYP } \ddagger \text { MAX } \end{aligned}$ |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pagad) | Access time from address |  | $\begin{aligned} & C_{L}=30 p F, \\ & R_{L 1}=300 \Omega, \\ & R_{L 2}=600 \Omega, \\ & \text { See Note } 4 \end{aligned}$ | 30 | 65 | 30 | 45 | 35 | 55 | 35 | 45 | ns |
| C(S) | Access time from chip enable (enable time) |  |  | 15 | 40 | 15 | 30 | 15 | 30 | 15 | 25 | ns |
| $t_{S R}$ | Sense recovery time |  |  |  | 50 |  | 40 |  | 55 |  | 45 | ns |
| tPLH | Propagation delay time, low-to-high-level output (disable time) | From $\overline{\mathbf{S}}$ |  | 15 | 35 | 15 | 30 | 15 | 30 | 15 | 25 |  |
|  |  | From $\bar{W}$ |  | 20 | 45 | 20 | 35 | 20 | 40 | 20 | 30 | ns |

'LS202 switching characteristics over recommended operating ranges of TA and VCC (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | SN54LS202 <br> TYP $\ddagger$ MAX | SN74LS202 <br> TYP $\ddagger$ MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| talad) | Access time from addreas |  | $\begin{aligned} & C_{L}=30 \mathrm{pF}, \\ & R_{L}=400 \Omega, \\ & \text { See Note } 4 \end{aligned}$ | 35 | 35 | ns |
| 4 (E) | Access time from chip enable (enable time) |  |  | 45 | 45 | ms |
| tsR | Sense recovery time |  |  | 20 | 20 | ns |
| tPx | Disable time from high or low level | From E | $\begin{aligned} & C_{L}=5 p F, \\ & R_{L 1}=400 \Omega, \\ & \text { See Note } 4 \\ & \hline \end{aligned}$ | 20 | 20 | ns |
|  |  | From $\bar{W}$ |  | 20 | 20 |  |
| tEPD | Chip power-down time |  | See Figure 1 | 65 | 65 | ns |

\#All typleal values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$.
NOTE: 4. Load circuit and voltage waveforms are shown in Appendix A, page 44.

## 256-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

## 'LS302 switching characteristics over recommended operating ranges of TA and VCC (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | SN54LS302 |  | SN74LS302 | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | TYP $\ddagger$ | MAX | TYP $\ddagger$ MAX |  |
| $\mathrm{ta}_{\mathrm{a}}(\mathrm{ad})$ | Access time from address |  |  | $\begin{aligned} & C_{L}=15 p F, \\ & R_{L 1}=400 \Omega, \\ & R_{L 2}=600 \Omega, \end{aligned}$ <br> See Note 5 | 35 |  | 35 | $1{ }^{1}$ |
| $\mathrm{ta}_{\mathrm{a}}(\overline{\mathrm{E}})$ | Access time from chip enable (enable time) |  | 45 |  |  | 45 | nB |
| ${ }^{\text {t }}$ SR | Sense recovery time |  | 20 |  |  | 20 | n |
| ${ }^{\text {tPLH }}$ | Propagation delay time, | From CE | 20 |  |  | 20 |  |
|  | low-to-high level output (disable time) | From W | 20 |  |  | 20 | $n 8$ |
| ${ }^{\text {tePD }}$ | Chip power-down time (1 CC < 38.5 mA ) |  | See Figure 1 | 65 |  | 65 | ns |

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


FIGURE 1. POWER-DOWN WAVEFORMS

- 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 $I^{2}$ L Circuits
- Chip-Enable/Select Inputs Simplify External Decoding
- Typical Performance

| TYPES | READ <br> ACCESS TIMES | POWER <br> DISS |
| :--- | :---: | :---: |
| SN74S214A/'S314A | 30 ns | 550 mW |
| SN74S214/'S314 | 40 ns | 550 mW |
| SN54S214/'S314 | 40 ns | 550 mW |
| SN74LS214/'LS314 | 75 ns | 200 mW |
| SN54LS214/'LS314 | 75 ns | 200 mW |
| SN74LS215/'LS315 | 75 ns | 200 mW |
| SN54LS215/'LS315 | 75 ns | 200 mW |
| 'LS215/'LS315 |  | 100 mW |
| POWER DOWN |  |  |

## sescription

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 'S214A, 'S214, 'LS214, and 'LS215 outputs are in the high-impedance state and the 'S314A, '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 'S214A, 'S214, 'LS214, or 'LS215 output will be in the high-impedance state, the 'S314A, S314, LS314, or LS315 output will be off, and the 'LS215 or 'LS315 will be in a power-down mode.

## 1024-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

$H \equiv$ high level, $L \equiv$ Iow level, $X \equiv$ irrelevant
schematics of inputs and outputs

absolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, VCC (see Note 1)
Input voltage.

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

| 1024-BIT HIGH-P |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Ssint 'S214 recommended operating conditions |  |  |  |  |  |  |  |  |  |  |  |
|  |  | SN54S214 |  |  | SN74S214A |  |  | SN74S214 |  |  | UNIT |
|  |  | MIN | NOM | MAX | 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 | 4.75 | 5 | 5.25 | V |
| Migh-level output current, 1 OH |  |  |  | -5.2 |  |  | -10.3 |  |  | -10.3 | mA |
| Low-evel output current, IOL |  |  |  | 16 |  |  | 16 |  |  | 16 | mA |
| Width of write pulse (write enable low), $\mathrm{t}_{\mathrm{w}}$ (wr) |  | 55 |  |  | 35 |  |  | 50 |  |  | ns |
| setup | Address before write pulse, $\mathrm{t}_{\text {sulad }}$ | $15 \downarrow$ |  |  | 5 $\downarrow$ |  |  | $15 \downarrow$ |  |  | ns |
|  | Data before end of write pulse, $t_{\text {sul }}$ (da) | $60 \uparrow$ |  |  | $40 \uparrow$ |  |  | $65 \uparrow$ |  |  |  |
|  | Chip select before end of write pulse, $\mathrm{t}_{\text {su }}(\overline{\mathbf{S}})$ | 60^ |  |  | $40 \uparrow$ |  |  | $65 \uparrow$ |  |  |  |
| Hold | Address after write pulse, $\mathrm{t}_{\mathrm{h}}(\mathrm{ad})$ | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  | ns |
|  | Data after write pulse, $t_{\text {h }}(\mathrm{da})$ | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  |  |
|  | Chip select after write pulse, $\mathrm{th}_{\mathrm{h}}(\mathbf{S})$ | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  |  |
| Operating free-air temperature, $T_{A}$ |  | -55 |  | 125 | 0 |  | 70 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

'S314A, 'S314 recommended operating conditions


It 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 trensition.
NOTE: 1. Voltage values are with respect to network ground terminal.
‘LS214, 'LS314, 'LS215, 'LS315 recommended operating conditions

|  |  | SN54LS214 SN54LS314 |  |  | SN74LS214 <br> SN74LS314 |  |  | SN54LS215 <br> SN54LS315 |  |  | SN74LS215 <br> SN74LS315 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply Voltage, $\mathrm{V}_{\text {CC }}$ (see Note 1) |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| High-le | evel output voltage, $\mathrm{V}_{\mathrm{OH}}{ }^{\text {LS314, }}$ LS315 |  |  | 5.5 |  |  | 5.5 |  |  | 5.5 |  |  | 5.5 | $V$ |
| High-l | evel output current, IOH $\begin{aligned} & \text { LS214, } \\ & \text { LS215 }\end{aligned}$ |  |  | -5.2 |  |  | -5.2 |  |  | -5.2 |  |  | -5.2 | mA |
| Low-level output current, IOL |  |  |  | 16 |  |  | 16 |  |  | 16 |  |  | 16 | mA |
| Width of write pulse (write enable low), $t_{w}$ (wr) |  | 75 |  |  | 60 |  |  | 75 |  |  | 60 |  |  | ns |
| Setup <br> time | Address before write pulse, ${ }^{\text {t }}$ su(ad) | 25 |  |  | $20 \downarrow$ |  |  | $25 \downarrow$ |  |  | 20 |  |  | ns |
|  | Data before end of write pulse, $t_{\text {su }}$ (da) | $95 \uparrow$ |  |  | $75 \uparrow$ |  |  | $95 \uparrow$ |  |  | $75 \uparrow$ |  |  |  |
|  | Chip-select/enable before end of write pulse, $\mathrm{t}_{\text {su }}(\overline{\mathrm{E}}), \mathrm{t}_{\text {su }}(\overline{\mathbf{S}})$ | 95 $\uparrow$ |  |  | $75 \uparrow$ |  |  | $95 \uparrow$ |  |  | $75 \uparrow$ |  |  |  |
| Hold <br> time | Address after write pulse, $\mathrm{th}_{\text {(ad) }}$ | 20^ |  |  | $15 \uparrow$ |  |  | 20ヶ |  |  | $15 \uparrow$ |  |  | ns |
|  | Data after write pulse, $\mathrm{th}^{\text {(da) }}$ | 204 |  |  | $15 \uparrow$ |  |  | 204 |  |  | $15 \uparrow$ |  |  |  |
|  | Chip-select/enable after write pulse <br> $t_{h}(\bar{E}), t_{h}(\bar{S})$ | $20 \uparrow$ |  |  | $15 \uparrow$ |  |  | $20 \uparrow$ |  |  | $15 \uparrow$ |  |  |  |
| Operating freerair temperature, $\mathrm{T}_{\mathbf{A}}$ |  | -55 |  | 125 | 0 |  | 70 | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

'S214A, 'S214, 'S314A, 'S314 electrical characteristics over recommended operating free-air temperature range (otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | 'S214A, 'S314A |  |  | 'S214, 'S314 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | TYP $\ddagger$ | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $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}_{\text {CC }}=\mathrm{MIN}, \mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.2 |  |  | -1.2 | V |
| VOH | High-level output voltage | $\begin{aligned} & \text { 'S214A, } \\ & \text { 'S214 } \end{aligned}$ | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{MIN}, V_{I H}=2 \mathrm{~V}, \\ & V_{I L}=0.8 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ | SN54S' | 2.4 | 3.3 |  | 2.4 | 3.3 |  | $V$ |
|  |  |  |  | SN74S' | 2.4 | 2.9 |  | 2.4 | 2.9 |  |  |
| VOL $\begin{array}{ll}\text { Low-level } \\ \text { output voltage }\end{array}$ |  |  | $\begin{aligned} & V_{C C}=M I N, V_{I H}=2 \mathrm{~V}, \\ & V_{I L}=0.8 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=\mathrm{MAX} \end{aligned}$ | SN54S' |  |  | 0.5 |  |  | 0.5 | V |
|  |  |  | SN74S' |  |  | 0.45 |  |  | 0.45 |  |
| ${ }^{1} \mathrm{OH}$ | High-level output current | $\begin{aligned} & \text { 'S314A, } \\ & \text { 'S314 } \end{aligned}$ |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \quad \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
|  |  |  | $\mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  |  |  | 100 |  |  | 100 |  |  |
| IOZH | Off-state output current, high-level voltage applied | $\begin{aligned} & \text { 'S214A, } \\ & \text { 'S214 } \end{aligned}$ | $\begin{aligned} & V_{C C}=\mathrm{MAX}, \mathrm{~V}_{1 H}=2 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \end{aligned}$ |  |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |  |
| IOZL | Off-state output current, low-level voltage applied | $\begin{aligned} & \text { 'S214A, } \\ & \text { 'S214 } \end{aligned}$ | $\begin{aligned} & V_{C C}=M A X, V_{I H}=2 \mathrm{~V} \\ & V_{I L}=0.8 \mathrm{~V}, V_{\mathrm{OL}}=0.5 \mathrm{~V} \end{aligned}$ |  |  |  | -50 |  |  | -50 | $\mu \mathrm{A}$ |  |
| 11 | Input current at maximum input voltage |  | $V_{C C}=M A X, V_{1}=5.5 \mathrm{~V}$ |  |  |  | 1 |  |  | 1 | mA |  |
| IIH | 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 |  | $V_{C C}=M A X, V_{1}=0.5 \mathrm{~V}$ |  |  |  | -250 |  |  | -250 | $\mu \mathrm{A}$ |  |
| Ios | Short-circuit output current § | 'S214A, <br> 'S214 | $V_{C C}=$ MAX |  | -30 |  | -100 | -30 |  | -100 | mA |  |
| ICC Supply current |  |  | $V_{C C}=M A X, \text { See Note } 2$ | $\mathrm{T}_{A}=-55^{\circ} \mathrm{C}$ |  |  | 170 |  |  | 170 | mA |  |
|  |  |  |  | $T_{A}=0^{\circ} \mathrm{C}$ |  |  | 155 |  |  | 155 |  |  |
|  |  |  |  | $T_{A}=\mathrm{MAX}$ |  |  | 130 |  |  | 130 |  |  |

[^11]
## 1024-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

LS214, 'LS314, 'LS215, 'LS315 electrical characteristics over recommended operating free-air temperature range (otherwise noted)

| 5- | PARAMETER |  | TEST CONDITIONS ${ }^{\boldsymbol{\dagger}}$ |  | $\begin{aligned} & \hline \text { 'LS214 } \\ & \text { 'LS314 } \end{aligned}$ |  |  | $\begin{aligned} & \prime \text { 'LS215 } \\ & \text { 'LS315 } \\ & \hline \end{aligned}$ |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \% |  |  | MIN | TYP | MAX | MIN | TYP $\ddagger$ | MAX |  |
| $\mathrm{VV}_{1}$ | High-level input voltage |  |  |  |  |  | 2 |  |  | 2 |  |  | V |
| $\nabla_{1 L}$ | Low-level input voltage |  |  |  |  |  | 0.8 |  |  | 0.8 | V |
| $V_{1 K}$ | Input clamp voitage |  | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}, \quad 11=-18 \mathrm{~mA}$ |  |  |  | -1.2 |  |  | -1.2 | V |
| VOH | High-level output voltage | $\begin{array}{\|c} \hline \text { LS214, } \\ \hline \text { LS215 } \\ \hline \end{array}$ | $\begin{aligned} & V_{C C}=M I N, V_{I H}=2 \mathrm{~V}, \\ & V_{I L}=0.8 \mathrm{~V}, \mathrm{IOH}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ |  | 2.4 | 3.3 |  | 2.4 | 3.3 |  | V |
| VOL | Low-level output voltage |  | $\begin{aligned} & V_{C C}=M I N, V_{I H}=2 \mathrm{~V}, \\ & V_{I L}=0.8 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=\mathrm{MAX} \end{aligned}$ |  |  |  | 0.5 |  |  | 0.5 | V |
| IOH | High-level output current | 'LS314, | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}, \mathrm{V}_{\text {IH }}=2 \mathrm{~V}$, | $\mathrm{V}_{\mathrm{O}}=2.4 \mathrm{~V}$ |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
|  |  | 'LS315 | $V_{1 L}=0.8 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |  |  | 100 |  |  | 100 |  |
| ! 102 H | Off-state output current, high-level voltage applied | $\begin{aligned} & \hline \text { LS214, } \\ & \text { 'LS215 } \end{aligned}$ | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{MAX}, \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & V_{\mathrm{IL}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{OH}}=2.4 \mathrm{~V} \end{aligned}$ |  |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
| ${ }^{1} \mathrm{OZL}$ | Off-state output current, low-level voltage applied | $\begin{aligned} & \hline \text { LS214, } \\ & \hline \text { 'LS215 } \end{aligned}$ | $\begin{aligned} & V_{C C}=M A X, V_{I H}=2 \mathrm{~V}, \\ & V_{I L}=0.8 \mathrm{~V}, V_{\mathrm{OL}}=0.5 \mathrm{~V} \end{aligned}$ |  |  |  | -50 |  |  | -50 | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage |  | $V_{C C}=M A X, V_{1}=5.5 \mathrm{~V}$ |  |  |  | 1 |  |  | 1 | mA |
| ${ }_{1 /}$ | High-level input current |  | $V_{C C}=M A X, V_{1}=2.7 \mathrm{~V}$ |  |  |  | 25 |  |  | 25 | $\mu \mathrm{A}$ |
| 112 | Low-level input current |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}, \mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  |  | -250 |  |  | -250 | $\mu \mathrm{A}$ |
| los | Short-circuit output current \$ | $\begin{aligned} & \hline \text { 'LS214, } \\ & \hline \text { 'LS215 } \\ & \hline \end{aligned}$ | $V_{C C}=$ MAX |  | -30 |  | -100 | -30 |  | -100 | mA |
| ICC | Supply current |  | $V_{C C}=$ MAX, See Note 2 | $\mathrm{T}_{A}=-55^{\circ} \mathrm{C}$ |  |  | 75 |  |  |  | mA |
|  |  |  | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |  | 40 | 65 |  | 40 |  |  |
|  |  |  | $\mathrm{T}_{A}=\mathrm{MAX}$ |  |  | 55 |  |  |  |  |
| lcc | Supply current - Power down | 'LS215 |  | $V_{C C}=M A X, \bar{E}=2.4 \mathrm{~V}$ |  |  |  |  |  | 20 |  | mA |

TFer conditions shown as MIN or MAX use the appropriate value specified under recommended operating conditions.
TTheee typlcal values are at $V_{C C}=5 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$.
Duration of the short circuit should not exceed one second.
WOTE: 2. ICC 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 | SN64S214 |  | SN74S214A |  | SN74S214 |  | SN54LS214 |  | SN74LS214 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX |  |
| taled) | Access time from address |  |  | $\begin{aligned} & C_{L}=30 \mathrm{pF}, \\ & R_{L}=400 \Omega, \end{aligned}$ <br> See Note 3 | 40 | 75 | 30 | 45 | 40 | 70 | 75 | 140 | 75 | 95 | ns |
| C-( $\overline{8}$ ) | Access time from chip select (select time) |  | 15 |  | 45 | 15 | 30 | 15 | 40 | 30 | 50 | 30 | 40 | ns |
| tgR | Sense recovery time |  | 20 |  | 55 | 20 | 40 | 25 | 50 | 35 | 75 | 35 | 65 | ns |
| ¢ $\times 2$ | Disable time from high or low level | from $\bar{S}$ | $\begin{aligned} & C_{L}=5 p F, \\ & R_{L}=400 \Omega, \end{aligned}$ <br> See Note 3 | 20 | 50 | 15 | 30 | 20 | 40 | 30 | 50 | 30 | 40 | ns |
|  |  | from $\bar{W}$ |  |  | 45 |  | 30 | 20 | 40 | 35 | 60 | 35 | 50 | ns |

$\ddagger$ All typleal values are at $\mathrm{V}_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
WOTE: 3. Load circuit and voltage waveforms are shown in Appendix $A$, page 44.

## 1024-BIT HIGH-PERFORMANCE RANDOM-ACCESS MEMORIES

'S314 and 'LS314 switching characteristics over recommended operating ranges of TA and VCC (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | SN54S314 |  | SN74S314A |  | SN74S314 |  | SN54LS314 |  | SN74LS314 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX | TYP $\ddagger$ | MAX |  |
| ${ }^{\text {ta }}$ (ad) | Access time from address |  |  | $\begin{aligned} & C_{L}=30 \mathrm{pF} \\ & R_{L 1}=300 \Omega \\ & R_{L 2}=600 \mathrm{~s}, \end{aligned}$ <br> See Note 3 | 40 | 75 | 30 | 45 | 40 | 70 | 75 | 140 | 75 | 95 | ns |
| $\mathrm{t}_{\mathbf{a}}(\overline{\mathbf{S}})$ | Access time from chip select (select time) |  | 15 |  | 45 | 15 | 30 | 15 | 40 | 35 | 60 | 35 | 50 | ns |
| ${ }^{\text {t }}$ SR | Sense recovery time |  | 20 |  | 55 | 20 | 40 | 25 | 50 | 35 | 60 | 35 | 50 | $n 3$ |
| ${ }^{\text {PPLH }}$ | Propagation delay time, low-to-high-level output (disable time) | $\bar{S}$ | 20 |  | 50 | 15 | 30 | 20 | 40 | 45 | 70 | 45 | 60 |  |
|  |  | $\bar{W}$ | 20 |  | 45 | 20 | 30 | 25 | 40 | 35 | 60 | 35 | 50 |  |

$\ddagger$ All typlcal values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$.
'LS215 switching characteristics over recommended operating ranges of TA and VCC
(unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | TYP $\ddagger$ MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{ta}_{\text {a }}$ ad) | Access time from address |  | $\begin{aligned} & C_{L}=15 \mathrm{pF}, \\ & R_{L}=400 \mathrm{~s} 2, \end{aligned}$ <br> See Note 5 | 75 | ns |
| $\mathrm{t}_{\mathrm{a}}(\overline{\mathrm{E}})$ | Access time from chip enable (enable time) |  |  | 55 | ns |
| ${ }^{\text {t }}$ SR | Sense recovery time |  |  | 35 | ns |
| tPXZ | Disable time from high or low level | from $\overline{\mathbf{E}}$ | $C_{L}=5 p F,$ | 30 |  |
|  |  | from $\bar{W}$ | $R_{L 1}=400$ s , <br> See Note 3 | 35 | ns |
| ${ }^{\text {t EPD }}$ | Chip power-down time |  | See Figure 1 | 65 | ns |

'LS315 switching characteristics over recommended operating ranges of TA and VCC
(unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS | TYP $\ddagger$ MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{a}}$ (ad) | Access time from address |  | $\begin{aligned} & C_{L}=15 \mathrm{pF} \\ & R_{L 1}=400 \mathrm{~s}, \\ & R_{L 2}=600 \mathrm{~s}, \end{aligned}$ <br> See Note 3 | 75 | $n 8$ |
| $\mathrm{t}_{\mathrm{a}}(\overline{\mathrm{E}})$ | Access time from chip enable (enable time) |  |  | 55 | ns |
| ${ }^{\text {t }}$ SR | Sense recovery time |  |  | 35 | ns |
| tPLH | Propagation delay time, <br> low-to-high level output (disable time) | from $\bar{E}$ |  | 30 | ns |
|  |  | from $\bar{W}$ |  | 35 | ns |
| tEPD | Chip power-down time |  | See Figure 1 | 65 | ns |

$\ddagger$ All typical values are at $V_{C C}=5 \mathrm{~V}, \boldsymbol{T}_{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 1K PROM's (SN54S287, SN74S287, SN54S387, and SN74S387)
- 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 |  |
| SN54S207/'S208 | 35 ns | 40 ns | 600 mW |
| SN54LS207/'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



SN54LS208,SN54S208 . . . J PACKAGE
SN74LS208,SN74S208 . . . J OR N PACKAGE (TOP VIEW)


Pin assignments are same for all packeges.


## write cycle

While the output-enable input, $\overline{O E}$, 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.

## reed cycle

The stored information is available at the output when the output-enable input is low. POST OFFICE BOX 5012 - DALLAS, TEXAS 73222

TImtegrated schottiyy-Berrier diodoelemped tranalator is patented by Toxas Instruments U. S. Patent Number $3,463,976$.

## 1024-BIT EDGE-TRIGGERED RANDOM-ACCESS MEMORIES

'LS207, 'S207 functional block diagram

'LS208, 'S208 functional block diagram


| FUNCTION | WRITE | ENABLE | OUTPUTS |
| :--- | :---: | :---: | :---: |
| WRITE AND READ | $\uparrow$ | L | DATA ADDRESSED |
| READ | H or L | L | DATA ADDRESSED |
| DO NOTHING | H or L | H | Hi-Z |
| WRITE ONLY | $\uparrow$ | H | Hi-Z |

$H=$ HIGH, L = LOW, $\uparrow=$ LOW.TO-HIGH TRANSITION

## 1024-BIT EDGE-TRIGGERED RANDOM-ACCESS MEMORIES

```
Wbolute maximum ratings over operating free-air temperature range (unless otherwise noted)
Supply voltage, VCC (see Note 1) . . }7\textrm{V
Input voltage . . . . . . . . . . 5.5 V
Off-state output voltage . . . . . . . . . . . . . . . }5.5\textrm{V
Operating free-air temperature range: SN54LS', SN54S . . . . . . . . . - 
SN74LS', SN74S . . . . . . . . . . . 0
Storage temperature range . . . . . . . . . . . - 
NOTE 1: All voltage values are with respect to network ground terminal.
\$5207, 'S208 recommended operating conditions
```

|  |  |  | SN54S' |  |  | SN74S' |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voltage, $\mathrm{V}_{\text {CC }}$ |  |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | $\checkmark$ |
| High-level output current, IOH |  |  |  |  | -2 |  |  | -6.5 | mA |
| Low-level output current, IOL |  |  |  |  | 16 |  |  | 16 | mA |
| Width of write pulse (high), $\mathrm{t}_{\text {w }}$ (wr) |  |  |  | $15 \uparrow$ |  |  | $15 \uparrow$ |  | ns |
| Setup time | Address before write, $\mathrm{t}_{\text {su }}(\mathrm{ad})$ |  |  | $0 \uparrow$ |  |  | $0 \uparrow$ |  | ns |
| (see Figures 3 and 4) | Data before write, $\mathrm{t}_{\text {su }}$ (da) |  | $0 \uparrow$ |  |  | $0 \uparrow$ |  |  |  |
| Hold time | Output enable after write, $\mathrm{th}_{\mathrm{h}}(\overline{\mathrm{EE}}$ ) (see Figure 3) | 'S207 | $t^{\text {th }}$ (da) ${ }^{\text {¢ }}$ |  |  | $t_{\text {l }}(\mathrm{da})^{\dagger}$ |  |  | ns |
|  | Address after write, $\mathrm{t}_{\mathrm{h}}(\mathrm{ad}$ ) (see Figures 3 and 4) |  |  | $35 \uparrow$ |  |  | $35 \uparrow$ |  |  |
|  | Data after write, $\mathrm{t}_{\mathrm{h}}(\mathrm{da)}$ (see Figures 3 and 4) |  |  | $35 \uparrow$ |  |  | $35 \uparrow$ |  |  |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ (see Note 3) |  |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ}$ |

The arrow Indicates that the rising transition of the write input is used for reference.
'3207,'\$208 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 |  |
| $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 |
| 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} & V_{I H}=2 V \\ & I_{O H}=M A X \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}_{\mathrm{IH}}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{aligned}$ |  | 0.5 |  | 0.5 | V |
| ${ }^{\text {IOZH}}$ | Off-state output current high-level voltage applied | 'S207 | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX} \\ & \mathrm{~V}_{\mathrm{O}}=2.4 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{1 \mathrm{H}}=2 \mathrm{~V}$, |  | 100 |  | 100 | $\mu \mathrm{A}$ |
|  |  | 'S208 |  |  |  | 50 |  | 50 |  |
| Iozl | Off-state output current low-level voltage applied | 'S207 | $\begin{aligned} & V_{C C}=\mathrm{MAX}, \\ & V_{O}=0.5 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\text {IH }}=2 \mathrm{~V}$, |  | -250 |  | -250 | $\mu \mathrm{A}$ |
|  |  | 'S208 |  |  |  | -50 |  | -50 |  |
| 11 | Input current at maximum input voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  | 1 |  | 1 | mA |
| 1/H | High-level input current | 'S207 | $V_{C C}=$ MAX, | $V_{1}=2.4 \mathrm{~V}$ |  | 100 |  | 100 | $\mu \mathrm{A}$ |
|  |  | 'S208 |  |  |  | 25 |  | 25 |  |
| $1 / 12$ | 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}=$ MAX |  | -30 | -100 | -30 | -100 | mA |
| ICC | Supply current | 'S207 | $V_{C C}=$ MAX | See Note 2 | 120 |  | 120 |  | mA |
|  |  | 'S208 |  |  | 120 |  | 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 ${ }^{+}$ |  | SN54LS' |  | SN74LS |  | 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}=$ MIN, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  | -1.2 |  | -1.2 | V |
| VOH | High-level output voltage |  | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & V_{I H}=2 V, \\ & I_{O H}=M A X \end{aligned}$ | 2.4 | 3.4 | 2.4 | 3.2 | V |
| VOL | Low-level output voltage |  | $\begin{aligned} & V_{C C}=M I N \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & V_{I H}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \end{aligned}$ |  | 0.5 |  | 0.5 | V |
| 'OZH | Off-state output current high-level voltage applied | 'LS207 | $\begin{aligned} & V_{C C}=M A X, \\ & V_{O}=2.4 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\text {IH }}=2 \mathrm{~V}$, |  | 100 |  | 100 | $\mu \mathrm{A}$ |
|  |  | ${ }^{\prime}$ LS208 |  |  |  | 50 |  | 50 |  |
| IOZL | Off-state output current low-level voltage applied | ${ }^{\prime}$ LS207 | $\begin{aligned} & V_{C C}=M A X \\ & V_{O}=0.5 \mathrm{~V} \end{aligned}$ | $V_{1 H}=2 \mathrm{~V}$, |  | -250 |  | -250 | $\mu \mathrm{A}$ |
|  |  | 'LS208 |  |  |  | -50 |  | -50 |  |
| 11 | Input current at maximum input voltage |  | $\mathrm{V}_{\text {CC }}=$ MAX, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  | 1 |  | 1 | mA |
| 1/H | High-leval input current | ${ }^{\prime}$ LS207 | $V_{C C}=$ MAX, | $V_{1}=2.4 \mathrm{~V}$ |  | 100 |  | 100 | $\mu \mathrm{A}$ |
|  |  | 'LS208 |  |  |  | 25 |  | 25 |  |
| IIL | Low-level input current |  | $V_{C C}=M A X$, | $V_{1}=0.5 \mathrm{~V}$ |  | -250 |  | -250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current § |  | $V_{C C}=M A X$ |  | -20 | -100 | -20 | -100 | $m A$ |
| ICC | Supply current | ${ }^{\prime}$ LS207 | $V_{C C}=M A X$, | See Note 2 | 40 |  | 40 |  | mA |
|  |  | ${ }^{\prime}$ LS208 |  |  | 40 |  | 40 |  |  |

[^12]witching characteristics at $\mathrm{VCC}=5 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER |  |  | TEST CONDITIONS | 'S207 | 'S208 | ${ }^{\prime}$ LS207 | LS208 | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | TYP | MAX | TYP | MAX |  |
| (ed) | Access time from address |  |  | $C_{L}=30 \mathrm{pF}, \quad R_{L}=300 \mathrm{~s},$ <br> See Figures 1 thru 5 | 40 |  | 75 |  | ns |
| (OE) | Access time from output enable (enable time) |  | 15 |  |  | 20 |  | ns |
| (war) | Access time from write | 'L5208, 'S208 | 25 |  |  | 50 |  | ns |
| - $9 \times 2$ | Disable time from high or low level (see Note 4) | from OE § | $C_{L}=5 p F, \quad R_{L 1}=300 \Omega,$ <br> See Figures 3 and 5 | 15 |  | 20 |  | ns |
|  |  | from W |  | 15 |  | 20 |  |  |

Thls parameter defines the delay for the $1 / O$ port to enter the input mode.

## PARAMETER MEASUREMENT INFORMATION


$C_{L}$ includes probe and jig capacitance. All dioder 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

OTE 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 outputenable 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 ls 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 \mathbf{2 . 5} \mathbf{n s}, \mathrm{tf}_{\boldsymbol{f}} \leqslant \mathbf{2 . 5} \mathbf{n s}, \mathrm{PRR} \leqslant \mathbf{1} \mathbf{M H z}$, and $Z_{\text {out }} \approx 50 \Omega$.

- Organized as 4096 Words of 1 Bit Each
- Fully Static Storage
- High-Density 18-Pin Package
- Synchronous Operation with Latched Output Data
- Symmetrical Read/Write Performance
- Single 5-Volt Supply
- Fully TTL Compatible
- Choice of Three State (S400) or Open Collector (S401) Output
- Efficient High Performance Operation:

75 ns Read Cycle
75 ns Write Cycle
500 mW Power Dissipation
(Typicals at $25^{\circ} \mathrm{C}$ )


## description

The 'S400 and 'S401 are monolithic, active-element, random-access memories with non-destructive data readout organized as 4096 words of 1 bit each. These RAMs integrate an $1^{2} \mathrm{~L}$ static storage matrix with an edge-triggered Schottky-clamped forward transistor periphery to produce efficient, high performance operation.

Primary memory control is simplified to two pins; the $R / \bar{W}$ input which selects either the read or write mode of operation and the $\overline{\mathrm{S}}$ input which serves the combined function of enabling or disabling the memory as well as triggering either the read or write cycle. Memory operation is therefore synchronous as a negative transition ( $\downarrow$ ) at $\overline{\mathbf{S}}$ initiates execution of either the read or write cycle dependent on the state of the $R / \bar{W}$ input.

The 'S400 and 'S401 utilize separate pins for DI (date input) and DO (data output) with the DO buffer having a significantly faster disable than enable time. These features facilitate memory designs using either a separate or common I/O bus structure.

The 'S400, with a 3 -state output, and the 'S401, with an open-collector output, are offered in both commercial 0 to $70^{\circ} \mathrm{C}(74 \mathrm{~S})$ and military -55 to $125^{\circ} \mathrm{C}(54 \mathrm{~S})$ temperature range versions.

## functional block diagram



Texas Instruments INCORPORATED post office box 5012 - dallas. texas 75222



The read function is selected by applying a high logic level to the $R \bar{W}$ input. If data is to be read from a newly addressed location, the $R / \bar{W}$ and $A 0-A 11$ inputs must be setup ( $t_{\text {su }}$ ) prior to negative transition ( $\downarrow$ ) at the $\bar{S}$ input and be held ( $t_{h}$ ) stable until completion of the read cycle. A negative transition at $\bar{S}$ strobes the periphery circuitry causing the addressed location to be sensed, latched and the output to become active presenting true data. Following a read cycle the output will remain active presenting true data until either the $\overline{\mathrm{S}}$ input is taken high or the $\mathrm{R} \overline{\mathrm{W}}$ input is taken low.

## write cycle

The write function is selected by applying a low logic level to the $R / \bar{W}$ input. The $D I, R / \bar{W}$ and $A 0-A 11$ inputs must be setup ( $\mathrm{t}_{\mathrm{su}}$ ) prior to a negative transition at $\overline{\mathrm{S}}$ and be held ( $\mathrm{t}_{\mathrm{h}}$ ) stable until completion of the write cycle. A negative transition at $\overline{\mathrm{S}}$ will strobe the periphery circuitry causing DI to be stored in the addressed location and loaded into the output latch. Any time the $R \bar{W}$ input is low, the device output will be at a high-impedance (off). This feature permits common I/O connection for bi-directional data bus designs.

## ORDERING INFORMATION

| PART NUMBER | AMBIENT TEMPERATURE RANGE | OUTPUT | PACKAGE (18 PIN) |
| :--- | :--- | :--- | :--- |
| SN74S400N | Commercial -0 to $70^{\circ} \mathrm{C}$ | 3-State | Plastic DIP |
| SN74S400J | Commercial -0 to $70^{\circ} \mathrm{C}$ | Ceramic DIP |  |
| SN54S400J | Military --55 to $125^{\circ} \mathrm{C}$ | Ceramic DIP |  |
| SN74S401N | Commercial -0 to $70^{\circ} \mathrm{C}$ | 3-State | Plastic DIP |
| SN74S401J | Commercial -0 to $70^{\circ} \mathrm{C}$ | Open-Collector | Ceramic DIP |
| SN54S401J | Military -55 to $125^{\circ} \mathrm{C}$ | Open-Collector | Ceramic DIP |

```
- Independent Synchronous Inputs and Outputs
- Organized as \(\mathbf{1 6 - W o r d s ~ o f ~} 5\) Bits
- DC to \(10 \mathbf{M H z}\) Data Rate
- 3-State Data Outputs
- 20-Pin, 300-mil, High Density Package
eription
This 80-bit active-element memory is a monolithic, Schottky-clamped transistor-transistor logic (STTL) array orgenized 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.
```

SN74S225 . . . J OR NPACKAGE
(TOP VIEW)


Pin assignments are sume for all packeges

## dopation

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.

TENTATIVE DATA SHEET
be deoument provides tentative information
1 - new product. Texas Instruments reserve - rint to change specifications for this anet in any manner without notice.
tintegrated Sehotuky-Berrier diodoclamped trenciotor is patented by Toxis Instrumertis U. \&. Patent Number 3,463,076.

## FUNCTION TABLES

Table 1 - Input Functions

| Input | Pin | Description |
| :--- | ---: | :--- |
| CK A | 1 | Load Clock A |
| DI 1 - DI 5 | 4.8 | Data Inputs |
| OE | 9 | Output Enable |
| CK IN | 16 | Unload Clock Input |
| CLR | 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 \cdot 15$ | Data Outputs |
| OR | 17 | Output Ready |

sohematics of inputs and outputs


## functional block diagram



## 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 Voltago, VCC. |  | 4.75 | 5 | 5.25 | V |
| High-level output current, IOH | All Outputs Except Data |  |  | -3.2 | mA |
|  | Data Outputs |  |  | -6.5 |  |
| Low-leval output current, IOL | All Outpute Except Data |  |  | 8 | mA |
|  | Data Outputs |  |  | 16 |  |
| Pulse Width | Load Clock A or B, ${ }_{\text {w }}$ (high) | 25 |  |  | ns |
|  | Unload Clock Input, ${ }_{\text {w }}$ ( (low) | 7 |  |  |  |
|  | Clear, ${ }^{\text {w }}$ (low) | 40 |  |  |  |
| Setup Time | Data to Load Clock, $t_{\text {gu }}$ (DII) Seo Note 2 | -164 |  |  | ns |
|  | Clear Release to Load Clock, ${ }_{\text {IM }}$ | 25 + |  |  |  |
| Hold TIme, Data from Load Clock, th(DII) |  | 704 |  |  | $n 8$ |
| Operating free-air temperature, $\mathrm{T}_{\mathbf{A}}$ |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

NOTE 2: Date must be setup within 15 ns after the load clock positive traneltion.
$\uparrow \equiv$ The arrow Indicates that the low-to-high tranaltion of the load clock le used for reference.
clectrical characteristics over recommended operating free-air temperature range (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{1}$ | 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}=$ MIN, | $I_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| VOH | High-level output voltage |  | $\begin{aligned} & V_{C C}=\mathrm{MIN}, \\ & V_{1 L}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 V \\ & I_{O H}=M A X \end{aligned}$ | 2.4 | 2.9 |  | 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 V \\ & I_{O L}=M A X \end{aligned}$ |  | 0.35 | 0.50 | V |
| IOZH | Off-state output current, high-level voltage applied |  | $\begin{aligned} & V_{C C}=M A X, \\ & V_{1 L}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 \mathrm{~V} \\ & V_{O}=2.4 \mathrm{~V} \end{aligned}$ |  |  | 50 | $\mu \mathrm{A}$ |
| IOZL | Off-state output current, low-level voltage applied |  | $\begin{aligned} & V_{C C}=M A X, \\ & V_{I L}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{1 H}=2 \mathrm{~V} \\ & V_{0}=0.5 \mathrm{~V} \end{aligned}$ |  |  | -50 | $\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 |
| I/H | High-leval input current | Data In | $V_{C C}=$ MAX | $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}=$ MAX, | $V_{1}=0.6 \mathrm{~V}$ |  |  | -1 | mA |
|  |  | All Inputs Except Data In |  |  |  |  | . 250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current § |  | $V_{C C}=M A X$ |  | -30 |  | -100 | mA |
| Icc | Supply Current |  | $V_{C C}=$ MAX, | See Note 3 |  | 80 | 120 | mA |

[^13]
## TYPE SN74S225

$16 \times 5$ ASYNCHRONOUS FIRST-IN/FIRST-OUT MEMORY
switching characteristics over recommended operating ranges of TA and VCC (unless otherwise noted)

| PARAMETERS§ | FROM | TO | TEST CONDITIONS | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $f_{\text {max }}$ | CK A |  | $\begin{aligned} & C_{L}=30 \mathrm{pF}, \\ & R_{L}=300 \Omega, \\ & \text { See Note } 4 \end{aligned}$ | 10 | 20 |  | MH2 |
| $f_{\text {max }}$ | CK B |  |  | 10 | 20 |  | $\mathrm{MH}_{3}$ |
| $f_{\text {max }}$ | CK IN |  |  | 10 | 20 |  | $\mathrm{MHz}_{2}$ |
| ${ }^{\text {tw }}$ | CK OUT |  |  | 7 | 14 |  | ns |
| tPLZ | $\overline{O E}$ | DOi | $\begin{gathered} C_{L}=5 p F, \\ \cdot R_{L 1}=300 \Omega, \text { See Note } 4 \end{gathered}$ |  |  | 40 | ns |
| tPHZ |  |  |  |  |  | 40 |  |
| tPLH | CK IN | DOi | $\begin{gathered} C_{L}=30 \mathrm{pF}, \\ R_{L}=300 \Omega, \\ \text { See Note } 4 \end{gathered}$ |  | 50 | 75 | m |
| tPHL |  |  |  |  | 50 | 75 |  |
| tPLH | $\begin{gathered} \text { CK A } \\ \text { or } \\ \text { CK B } \end{gathered}$ | OR |  |  | 215 | 325 | ns |
| tPLH | CK IN | OR |  |  | 40 | 60 | ns |
| tPHL |  |  |  |  | 30 | 45 |  |
| tPHL | CLR | OR |  |  | 40 | 60 | ns |
| tPHL | $\begin{aligned} & \text { CK A } \\ & \text { or } \\ & \text { CK B } \end{aligned}$ | CK OUT |  |  | 35 | 50 | ns |
| tPHL | CK IN | CK OUT |  |  | 300 | 450 | nm |
| tPHL | $\begin{aligned} & \text { CK A } \\ & \text { or } \\ & \text { CK B } \end{aligned}$ | IR |  |  | 42 | 65 | m |
| tplH | CK IN | IR |  |  | 290 | 450 | n |
| tPLH | $\overline{C L R}$ | IR |  |  | 20 | 35 | ns |
| tPHL |  |  |  |  |  |  |  |
| ${ }_{\text {tPLH }}$ | OR $\uparrow$ | DOi |  |  | 5 | 15 | nt |
| tPHL | OR $\downarrow$ |  |  |  | 5 | 15 |  |

[^14]NOTE 4: Load clrcuit and voltage waveforms are shown In Appendix A.

TYPICAL WAVEFORMS


EXPANDING THE S225 FIFO
( 48 WORDS OF 10 BITS SHOWN )


PRINTED IN U.SA
TEXAS INSTRUUMENTS
II connot ossume ony responsibility for ony circuits shown
or represeni that they are free from patent infringement. 43
POST OFFICE BOX 5012 - DALLAS. TEXAS 75222

## APPENDIX A


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

PRINTED IN USA
II connol assume ony responssbility for any circuits shown
texas instruments reserves the right to make changes at any time in ORDER TO Improve design and io supply the best product possible.

TEXASINSTRUMENTS POST OFFICE BOX 5012 - DALLAS. TEXAS 75222

The Engineering Staff of
TEXAS INSTRUMENTS INCORPORATED
Semiconductor Group


DECEMBER 1976

INDEX TO
BIPOLAR MICROCOMPUTER SUPPORT FUNCTIONS

| TYPE NUMBER (PACKAGES) |  | FUNCTION | $\begin{array}{\|c} \text { SEE } \\ \text { PAGE } \end{array}$ |
| :---: | :---: | :---: | :---: |
| $-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 | 5 |
| 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. | 13 |
| SN54S331(J) | SN74S331(J,N) | PROGRAMMABLE LOGIC ARRAYS (FPLA) | 13 |
| SN54S373(J) | SN74S373(J,N) | OCTAL D-TYPE TRANSPARENT LATCHES | 26 |
| 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 |  |
| 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 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 4 -bit transparent latches and feature 3 -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 bus-organized lines directly. They are particularly attractive for implementing:

Bidirectional bus transceivers
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. Entry 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 operation remains stable for the selected function. Further control is offered through the availability of independent output controls which can be used to enable

SN54S228.
SN74S226 $\qquad$ J PACKAGE J OR N PACKAGE


## functional block diagram



## DESIGN GOAL

This document provides tentative information TEXAS INSTREUMENTS
On a product in the developmental stage. Texas on a product in the developmental stage. Texas Instruments reserves the right to change or pOSt office box 5012 . dallas. texas 75222 discontinue this product without notice.
$\dagger^{\dagger}$ Integrated Schottky-Barrier diodeclamped transistor is patented by Texas Instruments. U. S. Patent Number $3,463,975$.

## BUS-MANAGEMENT FUNCTION TABLE

| OPERATION | S2 | S1 | LATCH FUNCTIONS |
| :--- | :---: | :---: | :--- |
| DRIVE BUS 2 | L | L | Pass Bus 1 Data to Bus 2 |
| DRIVE BUS 1 | H | L | Pass Bus 2 Data to Bus 1 |
| EXCHANGE | H | H | Store Bus 1 and Bus 2 Data |
| BUS 1 \& 2 | L | H | Readout Stored Data |

OUTPUT-CONTROL FUNCTION TABLE

| $20 C$ | $10 C$ | OUTPUT FUNCTION |
| :---: | :---: | :---: |
| L | X | Disable Bus 1 Outputs (Hi-Z) |
| H | X | Enable Bus 1 Outputs |
| X | L | Disable Bus 2 Outputs (HI-Z) |
| X | H | Enable Bus 2 Outputs |

or 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 pnp inputs feature typically 400 millivolts of hysteresis to enhance noise rejection.

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



[^15]
## SN54S226, SN74S226 4-BIT PARALLEL LATCHED BUS TRANSCEIVERS

recommended operating conditions

|  |  |  | N54S2 |  |  | N74S2 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voltage, VCC |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| High-level output voltage, VOH |  |  |  | 5.5 |  |  | 5.5 | V |
| High-level output current, IOH |  |  |  | -6.5 |  |  | -10.3 | mA |
| Date setup time, $\mathrm{t}_{\text {su }}$ | Data | $5 \downarrow$ |  |  | $3 \downarrow$ |  |  | ns |
|  | Select | $5 \downarrow$ |  |  | $3 \downarrow$ |  |  |  |
| Data hold time, $t_{\text {h }}$ | Data | $5 \downarrow$ |  |  | $3 \downarrow$ |  |  | ns |
|  | Select | $5 \downarrow$ |  |  | $3 \downarrow$ |  |  |  |
| Operating free-air temperature, $\mathrm{T}_{\mathbf{A}}$ |  | -55 | 125 |  | 0 | 70 |  | ${ }^{\circ} \mathrm{C}$ |

$\uparrow \downarrow$ The arrow indicates the transition of the 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 (unless otherwise noted)

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  |  | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{1} \mathrm{H}$ | High-level input voltage |  |  |  |  | 2 |  |  | V |
| $V_{16}$ | Low-level input voltage |  |  |  |  |  |  | 0.8 | V |
| $V_{1 K}$ | Input clamp voltage |  | $\mathrm{V}_{\text {CC }}=\mathrm{MIN}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  |  | -1.2 | V |
| VOH | High-level output voltage | SN54S226 | $V_{C C}=\mathrm{MIN}$, | $\mathrm{V}_{1 H}=2 \mathrm{~V}$, | SN54S226 | 2.4 | 3.3 |  | $v$ |
|  |  | SN74S226 | $V_{\text {IL }}=0.8 \mathrm{~V}$, | $I_{O H}=$ MAX | SN74S226 | 2.4 | 2.9 |  |  |
| 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}=20 \mathrm{~mA} \end{aligned}$ |  |  |  | 0.5 | V |
| IOZH | Off-state output current, high-level voltage applied |  | $\begin{aligned} & V_{C C}=M A X, \\ & V_{O}=2.4 \mathrm{~V} \end{aligned}$ | $V_{I H}=2 V$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| 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_{I H}=2 \mathrm{~V},$ |  |  |  | -100 | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage |  | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  |  | 1 | mA |
| $\mathrm{I}_{\mathrm{IH}}$ | High-leval input current |  | $V_{C C}=M A X$, | $V_{1}=2.7 \mathrm{~V}$ |  |  |  | 100 | $\mu \mathrm{A}$ |
| $1 / \mathrm{L}$ | Low-level input current |  | $V_{C C}=M A X$, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  |  | -300 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current § |  | $V_{C C}=M A X$ |  |  | -50 |  | -180 | mA |
| ICC | Supply current |  | $V_{C C}=M A X$ <br> See Note 2 |  |  |  | 125 |  | mA |

${ }^{\dagger}$ For conditions shown as MIN or MAX, use the approprlate value specifled under recommended operating conditions.
$\ddagger$ All typical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$.
8Not more than one output should be shorted at a time and duration of the short-circuit test should not exceed one second.
NOTE 2: 'CC is measured with all inputs (and outputs) grounded.

## SN54S226, SN74S226

4-BIT PARALLEL LATCHED BUS TRANSCEIVERS
switching characteristics, VCC $=5 \mathrm{~V}, \mathrm{TA}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | FROM (INPUT) | TO (OUTPUT) | TEST C | ITIONS | MIN TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | Data | Any 0 | $C_{L}=50 \mathrm{pF}, \quad R_{L}=280 \Omega$, |  | 14 |  | ns |
| tPHL |  |  |  |  | 14 |  |  |
| tPLH | Select | Any 0 |  |  | 12 |  | ns |
| tPHL |  |  |  |  | 12 |  |  |
| tPLH | Strobe | Any 0 |  |  | 12 |  | ns |
| tPHL |  |  |  |  | 12 |  |  |
| ${ }^{\text {I }} \mathrm{ZH}$ | Output | Any 0 |  |  | 9 |  | ns |
| tZL | Control |  |  |  | 9 |  |  |
| thz | Output <br> Control | Any 0 | $C_{L}=5 \mathrm{pF}$, | $R_{L}=280 \Omega$, | 7 |  | ns |
| ${ }_{\text {t }}$ |  |  |  |  | 7 |  |  |

$t_{\text {PLH }} \equiv$ propagation delay time, low-to-high level
${ }^{\text {tPHL }}$ P $\equiv$ propagation delay time, high-to-low level
$t_{\mathrm{ZH}} \equiv$ output enable time to high leval
tZL $\equiv$ output enable time to low level
$t_{H Z}=$ output disable time from high level
tLZ $\overline{\text { I }}$ output disable time from low level

## applications

The following examples demonstrate four fundamental bus-management functions which can be performed with the 'S226. Exchange of data on the two bus lines can be accomplished with a single high-to-low transition atS2 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:

$$
\frac{S N 74 S^{\prime}}{64 \mathrm{~mA}} \quad \frac{S N 54 S^{\prime}}{48 \mathrm{~mA}}
$$

$$
\mathrm{IOH}_{\mathrm{OH}} \text { (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 $\mathrm{p}-\mathrm{n}-\mathrm{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.

SN54S240 . . . J PACKAGE
SN74S240 . . J OR N PACKAGE (TOP VIEW)

logic: $\quad 1 Y=1 \bar{A}$ when $1 \overline{\mathrm{G}}$ is low $2 \mathbf{Y}=2 \mathbf{A}$ when $2 \mathbf{G}$ is low
When $1 \overline{\mathrm{G}}$ is high 1 Y outputs are at a high impedance When $\mathbf{2} \overline{\mathbf{G}}$ is high $\mathbf{2 Y}$ outputs are at a high impedance

> SN54S241 . . . J PACKAGE

SN74S241 . . . J OR N PACKAGE
(TOP VIEW)

logic: $\quad 1 Y=1 A$ when $1 \bar{G}$ is low $2 Y=2 A$ when $2 G$ is high When $1 \bar{G}$ is high $1 Y$ outputs are at a high impedance When 2G is low 2Y outputs are at a high impedence
'S241 BUS TRANSCEIVER

L... RECEIVE BUS 1 DRIVE BUS 2 H... RECEIVE BUS 2 DRIVE bUS 1

## TENTATIVE DATA SHEET

[^16]
## TYPES SN54S240, SN54S241, SN74S240, SN74S241 <br> 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}_{\text {CC }}$ (see Note 1) | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| High-level output current, IOH |  |  | -12 |  |  | -15 | mA |
| Low-level output current, IOL |  |  | 48 |  |  | 64 | mA |
| Operating free-air temperature, $\mathrm{T}_{\mathbf{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, $\mathrm{R}_{\theta \mathrm{CA}}$, 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 |  |  | $\bar{v}$ |
| $\mathrm{V}_{\text {IL }}$ | Low-level input voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \quad \mathrm{I}_{\mathrm{I}}=-18 \mathrm{~mA}$ |  |  |  | 0.8 |  |  | 0.8 | V |
| VIK | Input clamp voltage |  |  |  | - -1.2 |  |  | - 1.2 |  |  | V |
|  | Hysteresis ( $\mathrm{V}_{\mathbf{T}+-}-\mathrm{V}_{\mathrm{T}_{-}}$) |  | $\mathrm{V}_{\text {CC }}=$ MIN |  | 0.2 | 0.4 |  | 0.20 .4 | 0.4 |  | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage |  | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, & V_{I L}=0.8 \mathrm{~V}, \\ \mathrm{I}_{\mathrm{OH}}=-3 \mathrm{~mA} \end{array}$ |  | 2.43 .4 |  |  | 2.43 .4 |  |  | $v$ |
|  |  |  | $\begin{array}{ll} V_{C C}=M I N, & V_{I L}=0.5 \mathrm{~V}, \\ I_{O H}=\text { MAX } & \end{array}$ |  | 2 |  |  | 2 |  |  |  |
| VOL | Low-level output voltage |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, \quad 1 \mathrm{OL}=\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 \mathrm{~V}, \\ & V_{I L}=0.8 \mathrm{~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 \mathrm{~V}$ |  |  |  | 1 |  |  | 1 | mA |
| $\mathrm{IIH}^{\text {H }}$ | High-level input current, any input |  | $V_{C C}=$ MAX, |  |  |  | 50 |  |  | 50 | $\mu \mathrm{A}$ |
| IIL | Low-level input current | Any A | $V_{C C}=$ MAX , | $\mathrm{V}_{1 L}=0.5 \mathrm{~V}$ |  |  | -400 |  |  | -400 | $\mu \mathrm{A}$ |
| IOS | Short-circuit output current $¢$ | Any G | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  |  |  | -2 |  |  | -2 | mA |
| ${ }^{\prime} \mathrm{CC}$ | Supply current | T | $V_{C C}=M A X,$ <br> Outputs open | SN54S' |  | 80 |  |  | 95 | 147 | nA |
|  |  | outputs high |  | SN74S' |  | 80 | 135 |  | 95 | 160 |  |
|  |  | Total, |  | SN54S' |  | 100 | 145 |  | 120 | 170 |  |
|  |  | outputs low |  | SN74S' |  | 100 | 150 |  | 120 | 180 |  |
|  |  | Outputs at |  | SN54S' |  | 100 | 145 |  | 120 | 170 |  |
|  |  | Hi-Z |  | 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 $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$., $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$.
INot more then one output should be shorted at a time, and duration of the short-circult should not exceed one second.
switching characteristics, $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER |  | TEST CONDITIONS |  | \$240 |  |  | 5241 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| tPLH | Propagation delay time, low-to-high-level output |  |  | $C_{L}=50 \mathrm{pF} .$ <br> See Note 3 | $R_{L}=90 \Omega$, |  | 4.5 | 7 |  | 6 | 9 | ns |
| ${ }^{\text {tPHL }}$ | Propagation delay time, high-to-low-level output |  | 4.5 |  |  | 7 |  | 6 | 9 | ns |
| ${ }^{\text {t }} \mathrm{ZL}$ | Output enable time to low level |  | 10 |  |  | 15 |  | 10 | 15 | ns |
| IZH | Output enable time to high level |  | 6.5 |  |  | 10 |  | 8 | 12 | ns |
| thz | Output disable time from low level | $C_{L}=5 \mathrm{pF}$, | $\mathrm{R}_{\mathrm{L}}=90 \Omega$ |  | 10 | 15 |  | 10 | 15 | ns |
| thz | Output disable time from high level |  |  |  | 6 | 9 |  | 6 | 9 | ns |

## TYPES SN54S240, SN54S241, SN74S240, SN74S241 OCTAL BUFFERS/LINE DRIVERS/LINE RECEIVERS WITH 3-STATE OUTPUTS


'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

TEXAS INSTRUUMENTS POST OFFICE BOX 5012 - DALLAS. TEXAS 78222

- 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, SO 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 | SERIAL <br> SL SR |  | $\mathbf{N}^{\prime} \mathbf{a}_{\mathbf{A}}$ | $B / Q_{B}$ | ${ }_{c}{ }^{\circ} \mathrm{C}$ | ${ }_{\text {D }} / O_{D}$ | $E / Q_{E}$ | $F_{\text {F }} \mathbf{O}_{\text {F }}$ | $\mathbf{G / 0} \mathbf{Q}_{\mathbf{G}}$ | H/OH | $\mathbf{a}_{\mathbf{A}^{\prime}}$ | $\mathbf{O}_{\mathbf{H}^{\prime}}$ |
|  |  | S1 | SO | G71 ${ }^{+}$ | $\overline{\text { G]2 }}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Clear | L | X | L | L | L | X | X | $x$ | L | 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{a}_{\mathrm{BO}}$ | $\mathrm{Q}_{\mathrm{CO}}$ | $\mathrm{Q}_{\text {D0 }}$ | $\mathrm{Q}_{\text {EO }}$ | $\mathrm{Q}_{\text {FO }}$ | $\mathrm{O}_{\mathrm{GO}}$ | $\mathrm{a}_{\mathrm{HO}}$ | $\mathrm{Q}_{\text {AO }}$ | $\mathrm{O}_{\mathrm{HO}}$ |
|  | H | X | X | L | L | L | X | X | $\mathrm{Q}_{\text {AO }}$ | $\mathrm{O}_{\mathrm{BO}}$ | $\mathrm{Q}_{\mathrm{CO}}$ | $\mathrm{Q}_{\mathrm{DO}}$ | $\mathrm{O}_{\text {EO }}$ | $\mathrm{Q}_{\text {Fo }}$ | $\mathrm{O}_{\mathrm{GO}}$ | $\mathrm{O}_{\mathrm{HO}}$ | $\mathrm{Q}_{\text {AO }}$ | $\mathrm{O}_{\mathrm{HO}}$ |
| Shift Right | H | L | H | L | L | $\uparrow$ |  | H | H | $\mathrm{Q}_{\text {An }}$ | $\mathrm{O}_{8 n}$ | $\mathrm{O}_{\mathrm{C}}$ | $\mathrm{O}_{\mathrm{Dn}}$ | $\mathrm{O}_{\mathrm{En}}$ | $\mathrm{Q}_{\mathrm{Fn}}$ | $\mathrm{O}_{\mathrm{Gn}}$ |  | $\mathrm{O}_{\mathrm{Gn}}$ |
|  | H | $L$ | H | L | L | $\uparrow$ | X | L | L | $Q_{A n}$ | $Q_{B n}$ | $Q_{C n}$ | $\mathrm{Q}_{\mathrm{Dn}}$ | $\mathrm{Q}_{\mathrm{En}}$ | $\mathrm{O}_{\mathrm{Fn}}$ | $\mathrm{Q}_{\mathrm{Gn}}$ | L | $\mathrm{O}_{\mathrm{Gn}}$ |
| Shift Left | H | H | L | L | L | $\uparrow$ | H | X | $\mathrm{a}_{8 n}$ | $\mathrm{a}_{\text {Cn }}$ | $\mathrm{O}_{\text {Dn }}$ | $\mathrm{O}_{\mathrm{En}}$ | $\mathrm{Q}_{\mathrm{Fn}}$ | $\mathrm{O}_{\mathrm{G}}$ | $\mathrm{Q}_{\mathrm{Hn}}$ | H | $\mathrm{O}_{\mathrm{Bn}}$ | H |
|  | H | H | L |  | L | $\uparrow$ |  | X | $\mathrm{a}_{8 n}$ | $\mathrm{O}_{\mathrm{Cn}}$ | $\mathrm{O}_{\text {Dn }}$ | $\mathrm{O}_{\mathrm{En}}$ | $\mathrm{Q}_{\mathrm{Fn}}$ | $Q_{G n}$ | $\mathrm{OH}_{\mathrm{Hn}}$ | L | $a_{B n}$ | L |
| Load | H | H | H | X | X | $\dagger$ | X | X | a | b | c | d | e | $f$ | $g$ | h | a | h |

[^17]a... $h=$ level of the steady-state input at inputs $A$ through $H$, respectively. These data are loaded into the flipflops while the flip-flop outputs are isolated from the input/output terminals.

## TYPES SN54S299, SN74S299 <br> 8-BIT UNIVERSAL SHIFT/STORAGE REGISTERS

functional block diagram


## TYPES SN54S299, SN74S299 8-BIT UNIVERSAL SHIFT/STORAGE REGISTERS

schematics of inputs and outputs
EQUIVALENT OF CLOCK OR
CLEAR INPUTS
TYPICAL OF OUTPUTS
absolute maximum ratings over operating free-air temperature range (unless otherwise noted)


NOTES 1: Voltage values are with respect to network ground terminal.
recommended operating conditions

|  |  | SN54S299 |  |  | SN74S289 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voltage, VCC |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| High-lovel output current, IOH | $\mathrm{Q}_{A}$ thru $\mathrm{Q}_{H}$ |  |  | -2 |  |  | -6.5 | mA |
|  | $Q_{A^{\prime}}$ or $Q_{H^{\prime}}$ |  |  | -0.6 |  |  | -0.5 |  |
| Low-level output current, IOL | $\mathrm{Q}_{\mathbf{A}}$ thru $\mathrm{Q}_{H}$ |  |  | 20 |  |  | 20 | mA |
|  | $Q_{A^{\prime}}$ or $Q_{H^{\prime}}$ |  |  | 6 |  |  | 6 |  |
| Clock frequency, fclock |  | 0 |  | 50 | 0 |  | 50 | MHz |
| Width of clock pulse, $\mathrm{t}_{\text {w }}$ (clock) | Clock high | 10 |  |  | 10 |  |  | ns |
|  | Clock low | 10 |  |  | 10 |  |  |  |
| Width of clear pulse, $\mathrm{t}_{\text {w }}$ (clear) | Clear low | 10 |  |  | 10 |  |  | ns |
| Setup time, $\mathrm{t}_{\text {su }}$ | Select | $15 \uparrow$ |  |  | $15 \uparrow$ |  |  | ns |
|  | High-lavel data ${ }^{\circ}$ | $7 \uparrow$ |  |  | $7 \uparrow$ |  |  |  |
|  | Low-level data ${ }^{\circ}$ | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  |  |
|  | Clear inactive-state | 10ヶ |  |  | 10ヶ |  |  |  |
| Hold time, $\mathrm{th}^{\text {h }}$ | Select | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  | ns |
|  | Data ${ }^{\circ}$ | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  | ns |
| Operating free-air temperature, $T_{\text {A }}$ |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

[^18]
## TYPES SN54S299, SN74S299 <br> 8-BIT UNIVERSAL SHIFT/STORAGE REGISTERS

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

| PARAMETER |  |  | TEST CONDITIONS ${ }^{\dagger}$ |  | MIN | TYP $\ddagger$ | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $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}_{\text {CC }}=\mathrm{MIN}$, | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| $\mathrm{V}_{\mathrm{OH}}$ | High-level output voltage | $\mathrm{Q}_{A}$ thru $\mathrm{Q}_{H}$ | $\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}, \\ & I_{O H}=M A X \end{aligned}$ | 2.4 | 3.2 |  | V |
|  |  | $\mathrm{Q}_{A^{\prime}}$ or $\mathrm{O}_{H^{\prime}}$ |  |  | 2.7 | 3.4 |  |  |
| $\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{IOL}_{\mathrm{OL}}=\mathrm{MAX} \end{aligned}$ |  |  | 0.5 | V |
| IOZH | Off-state output current, high-level voltage applied | $\mathrm{Q}_{\mathbf{A}}$ thru $\mathrm{Q}_{\mathbf{H}}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \\ & \mathrm{~V}_{\mathrm{O}}=2.4 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{1 H}=2 \mathrm{~V}$, |  |  | 100 | $\mu \mathrm{A}$ |
| IOZL | Off-state output current low-level voltage applied | $Q_{A}$ thru $Q_{H}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}, \\ & \mathrm{~V}_{\mathrm{O}}=0.5 \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{1 H}=2 \mathrm{~V}$, |  |  | -250 | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 | mA |
| 1/H | High-level input current | A thru H, S0, S1 | $V_{C C}=M A X$, | $\mathrm{V}_{1}=2.7 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
|  |  | Any other |  |  |  |  | 50 |  |
| 1 IL | Low-level input current | Clock or clear | $V_{C C}=M A X$, | $\mathrm{V}_{1}=0.5 \mathrm{~V}$ |  |  | -2 | mA |
|  |  | Any other |  |  |  |  | -250 | $\mu \mathrm{A}$ |
| Ios | Short-circuit output current § | $Q_{A}$ thru $A_{H}$ | $V_{C C}=$ MAX |  | -40 |  | -100 | mA |
|  |  | $\mathrm{Q}_{A^{\prime}}$ or $\mathrm{Q}_{H^{\prime}}$ |  |  | -20 |  | -100 | mA |
| ICC | Supply current |  | $\mathrm{V}_{\mathrm{CC}}=\mathrm{MAX}$ |  |  | 140 | 225 | mA |

${ }^{\dagger}$ For condltions shown as MIN or MAX, use the appropriate value specifled 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 test should not exceed one second.
switching characteristics, VCC $=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER ${ }^{\text {I }}$ | FROM (INPUT) | TO (OUTPUT) | TEST CONDITIONS | MIN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $f_{\text {max }}$ |  |  | See Note 2 | 50 | 70 |  | MHz |
| ${ }_{\text {tPLH }}$ | Clock | $Q_{A^{\prime}}$ or $Q_{H^{\prime}}$ | $C_{L}=15 \mathrm{pF},$ <br> See Note 2 |  | 12 | 20 | ns |
| ${ }_{\text {tPHL }}$ |  |  |  |  | 13 | 20 |  |
| ${ }_{\text {tPHL }}$ | Clear | $Q_{A^{\prime}}$ or $Q_{H^{\prime}}$ |  |  | 14 | 21 | ns |
| tPLH | Clock | $Q_{A}$ thru $Q_{H}$ | $C_{L}=45 \mathrm{pF}, \quad \mathrm{R}_{\mathrm{L}}=280 \Omega$,See Note 2 |  | 15 | 21 | ris |
| tPHL |  |  |  |  | 15 | 21 |  |
| tPHL | Clear | $Q_{A}$ thru $Q_{H}$ |  |  | 16 | 24 | ns |
| tPZH | $\overline{\mathrm{G}} 1, \overline{\mathrm{G}} 2$ | $\mathrm{Q}_{\mathbf{A}}$ thru $\mathrm{Q}_{\mathbf{H}}$ |  |  | 10 | 18 |  |
| tPZL |  |  |  |  | 12 | 18 | ns |
| tPHZ | $\overline{\mathrm{G}} 1, \overline{\mathrm{G}} 2$ | $\mathrm{Q}_{\mathbf{A}}$ thru $\mathrm{Q}_{\mathbf{H}}$ | $C_{L}=5 \mathrm{pF},$ <br> See Note 2 |  | 7 | 12 | n8 |
| tPLZ |  |  | See Note 2 |  | 7 | 12 |  |

$I_{f_{\text {max }}} \equiv$ maximum clock frequency
$t_{\text {PLH }} \equiv$ propagetion delay time, low-to-high-level output
${ }^{\text {tPHL }} \equiv$ propagetion delay time, high-to-low-leval output
tPZH $\equiv$ output enable time to high level
t PZL $\equiv$ output eniable time to low leval
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:
- 35 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 k $\Omega$ Passive-Pullup ('S331) Outputs


## description

These high-performance, Schottky-clamped 12 -input, 6 -output logic arrays can be field programmed to provide $\mathbf{5 0}$ 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/OE) to serve as an output enable (OE). Either option makes the FPLA expandable with respect to product terms.

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 SN54S/74S330 is implemented with bus-driving 3-state outputs and can be connected directly to similar outputs in a bus-organized system. The $\mathrm{SN} 54 \mathrm{~S} / 74 \mathrm{~S} 331$ 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 series SN74S' outputs are also rated to source $250 \mu \mathrm{~A}$ of current at $\mathrm{V}_{\mathrm{OH}}=\mathbf{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.

[^19]TYPES SN54S330, SN54S331, SN74S330, SN74S331
EXPANDABLE 12-INPUT, 50-TERM

## FIELD-PROGRAMMABLE LOGIC ARRAYS



WHERE:

$$
F_{1}=F_{0}, F_{1}, F_{2}, F_{3}, F_{4}, \text { or } F_{5}
$$

(ABC . . . . . L) $=12$ PROGRAMMABLE INPUTS ( $H$ - TRUE OR L $=$ TRUE) FOR EACH OF 60 PRODUCT TERMS

## TYPES SN54S330, SN54S331, SN74S330, SN74S331 EXPANDABLE 12-INPUT, 50-TERM FIELD-PROGRAMMABLE LOGIC ARRAYS

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

|  |  | SN54S330, SN54S331 |  |  | SN74S330, SN74S331 |  |  | 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 current, 1 OH | 'S330 (T-S) |  |  | -2 |  |  | -6.5 | mA |
|  | 'S331 (2.5 k $\Omega$ Pullup) |  |  | -0.2 |  |  | -0.25 |  |
| Operating free-air temperature, $\mathrm{T}_{\mathbf{A}}$ |  | -55 |  | 125 | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

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

${ }^{\top}$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
${ }^{\dagger}$ All typical values are at $V_{C C}=5 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$.
§ Not more than one output of the 'S330 should be shorted at a time.
NOTE 2: ICC is measured with all outputs open and all inputs grounded.
switching characteristics, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| PARAMETER | FROM | T0 | TEST CONDITIONS | MIN TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tPLH | Any input | Any output | $C_{L}=30 \mathrm{pF}$ | 35 |  | ns |
| tPHL |  |  |  | 35 |  |  |
| t ZL | Enable | Any output |  | 15 |  | ns |
| ${ }^{\text {Z }} \mathrm{Z} \mathrm{H}$ |  |  |  | 15 |  |  |
| ${ }_{\text {t }} \mathrm{HZ}$ | Enable | Any output | $C_{L}=5 \mathrm{pF}$ | 15 |  | ns |
| ${ }_{\text {t }}$ |  |  |  | 15 |  |  |

# TYPES SN54S330, SN54S331, SN74S330, SN74S331 <br> EXPANDABLE 12-INPUT. 50-TERM <br> FIELD-PROGRAMMABLE LOGIC ARRAYS 

## 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 in TI's PROM's. The conditions recommended for programming the FPLA are virtually identical to those used for 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/OE input before the OR term. Programming the automatic enable feature active, the true/false logic level of the outputs, and the data/enable input (L/OE) can be accomplished before or after the AND and OR matrices are established.
recommended conditions for programming

|  | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: |
| Supply voltage, $V_{\text {cc }}$ (see Note 1) | 4.75 | 5 | 5.75 | V |
| Program pulse voltage, $\mathrm{V}_{(\mathrm{pr})}$ (see Note 1) | 10 | 10.5 | $11^{\dagger}$ | $V$ |
| Program pulse rise time |  | 100 |  | ns |
| High level, $\mathrm{V}_{\text {IH }}$ | 2.4 |  | 5 | V |
| Low level, $\mathrm{V}_{\text {IL }}$ | 0 |  | 0.5 |  |
| Voltage applied to output for OR programming, $\mathrm{V}_{\mathrm{O}}(\mathrm{pr})$ (see Figure D) | 0 | 0.25 | 0.3 | V |
| Duration of programming pulse Y (see Figures A, C, D, and Note 2) | 0.9 | 1 | 20 | ms |
| 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 0.9 ms long. Typlcally, programming occurs in 1 ms .

## 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 ( $F_{n}$ ) will be at a high logic level voltage, $\mathrm{VOH}_{\mathrm{OH}}$.

Programming the output to provide a low logic level voltage ( VOL ) when the programmed input term is true can be 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.

TABLE I - ADDRESSES FOR PROGRAMMING OUTPUT LEVELS AND ENABLES

| ADDRESS APPLIED TO OUTPUTS |  |  |  |  |  | PRODUCT TERM ADDRESSED | PROGRAMS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $F_{5}$ | $F_{4}$ | $F_{3}$ | $F_{2}$ | $F_{1}$ | Fo |  |  |
| H | H | L | L | H | L | 50 | Output $\mathrm{F}_{5}$ true low |
| H | H | L | L | H | H | 51 | Output $\mathrm{F}_{4}$ true low |
| H | H | L | H | L | L | 52 | Output $\mathrm{F}_{3}$ true low |
| H | H | L | H | $L$ | H | 53 | Output $F_{2}$ true low |
| H | H | L | H | H | L | 54 | Output $F_{1}$ true low |
| H | H | L | H | H | H | 55 | Output Fo true low |
| H | H | H | L | L | L | 56 | L/OE input into logical product term |
| H | H | H | $L$ | $L$ | H | 57 | Automatic output enable active |

Programming can be verified before AND-OR programming by applying $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ and measuring $\mathrm{V}_{\mathrm{OL}} \leqslant 0.5 \mathrm{~V}$ at the programmed output(s). After programming this test can be made by applying the input conditions which correspond to each term programmed to result in an active low-level output.
step-by-step programming procedure for outputs and enables

1. Apply steady-state supply voltage $\left(\mathrm{V}_{\mathrm{C}}=5 \mathrm{~V}\right)$ and disable the outputs by applying 10.5 volts to the 12 data inputs. See Figure 1.
2. 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 $V_{\text {IH }}$ and $V_{\text {IL }}$ to the outputs in accordance with Table I.
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 ( 1 ms ) is reached, $\mathrm{V}_{\mathrm{C}}$ should be stepped down to 5 V at which level verification can be accomplished.
6. The data inputs may be taken to logic levels (to permit program verification) $10 \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.

NOTES 3: $V_{C C}$ should be removed between program-pulses to reduce dissipation and chip temperatures. See Figure 1.


FIGURE 1 - OUTPUTS AND ENABLES PROGRAMMING SEQUENCE

## programming the $L(e n)$ input

The L/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 12 th data input a single fuse, at term 562 (see Table I), should be programmed in accordance with steps 1 through 4 above; then, input $L$ is programmed logically into each AND/ $\overline{A N D}$ product term.

If input L/OE is to function as a dedicated output enable, term 562 is not fused: however, both AND/AND fuse links at each of the 50 product term addresses must be fused as outlined below creating a "don't care" for input L . This causes the input to become an overriding output enable/disable for the package.

## TYPES SN54S330, SN54S331. SN74S330, SN74S331 EXPANDABLE 12-INPUT, 50-TERM FIELD-PROGRAMMABLE LOGIC ARRAYS

## programming the automatic disable to be inactive

The 'S330 and 'S331 are supplied with fuse links completing a circuit which automatically disables the six outputs (highimpedance (Z) for 'S330, high (H) for 'S331) for any product term which is purely "don't care'"; i.e., not decoded by the AND matrix. Fusing one link inactivates the automatic output enabling circuit resulting in the six outputs being enabled for any input term, even "don't care"

The automatic disable fuse is programmed inactive by addressing term $57_{2}$ (see Table I) and fusing in accordance with the step-by-step procedure above.
programming the AND/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/NAND 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

A particular pattern is assumed to have been programmed into the AND/ $\overline{A N D}$ 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/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 for programming.

Redundant product terms are defined as being absolutely equal; i.e., $A \bar{B} C D \bar{E} F G \equiv A \bar{B} C D \bar{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 unique terms for programming purposes by expansion:

Example:

## $\mathrm{A} \overline{\mathrm{B}} \mathrm{CD} \overline{\mathrm{E} F G H \equiv A \bar{B} C E \bar{D} F G \bar{H}}$

After programming the OR matrix, the product terms can be readdressed and the H input 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:
$\mathrm{A} \overline{\mathrm{B}} \mathrm{CD} \overline{\mathrm{E} F G} \longleftarrow$ — This large product term
$A \bar{B} D \bar{E} G \neq$
ACDF——also addresses these small terms

The small terms can be made unique for programming by simply expanding to non-redundant inputs.


After programming the OR matrix, the product terms can be shortened by readdressing each and programming the added inputs to a "don't care". The AND/ $\overline{\text { AND }}$ matrix is programmed one fuse at a time by addressing the term in accordance with Table II and fusing the input while applying the logic level desired to be active. See Figure 3.

TABLE II - ADDRESSES FOR PROGRAMMING PRODUCT TERMS

| ADDRESS APPLIED TO OUTPUTS |  |  |  |  |  | PRODUCT <br> TERM <br> ADDRESSED |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $F_{5}$ | $F_{4}$ | $\mathrm{F}_{3}$ | $F_{2}$ | Fo | $F_{1}$ |  |
| 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 |
|  |  |  |  |  |  | $\cdot$ |
| H | H | $L$ | L | L | L | 48 |
| H | H | L | L | L | H | 49 |

## TYPES SN54S330, SN54S331, SN74S330, SN74S331 EXPANDABLE 12-INPUT, 50-TERM FIELD-PROGRAMMABLE LOGIC ARRAYS

step-by-step programming procedure for AND matrix

1. Apply steady-state supply ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ ) and disable the outputs by applying 10.5 volts to the 12 data inputs. See Figure 3.
2. 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 II.
4. Apply the level to be true at the input to be programmed.
5. Step $V_{C C}$ to 10.5 V nominal. Maximum supply current required during programming is 750 mA .
6. After the $Y$ pulse time ( 1 ms ) is reached, $\mathrm{V}_{\mathrm{CC}}$ should be stepped down to 5 V at which level verification can be accomplished.
7. The data inputs may be taken to logic levels (to permit program verification) $10 \mu \mathrm{~s}$ or more after $\mathrm{V}_{\mathrm{CC}}$ reaches its steady-state value of 5 V .
8. At a $Y$ pulse duty cycle of $35 \%$ or less, repeat steps 1 through 7 for each input to be programmed.

NOTES: 4. $V_{C C}$ should be removed between program-puises to reduce dissipation and chip temperatures. See Figure 3.
5. If the input just programmed is to be a "don't care" and is not being used to expand the product term repeat ateps 4 and 5 with the opposite loglc leval 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'".
6. If input L/OE 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.

The OR (summing)'matrix for each product term can be programmed immediately upon completion of the 12-wide AND/ $\overline{A N D}$ term associated with it; or, the entire AND/ $\overline{A N D}$ term matrix can be programmed for all 50 product terms before programming the summing matrix.


## programming the OR (summing) matrix

Product term(s) programmed into the AND/ $\overline{\text { AND }}$ matrix can now be selected to provide a true logic level output. The true logic level output at $F_{0}$ through $F_{5}$ will be high if the output polarity fuses are intact, or $F_{0}$ through $F_{5}$ will be low if the output polarity fuses have been programmed, or a combination of highs and lows if some of the output polarity fuses have been programmed.

## step-by-step programming procedure for OR matrix

Programming the OR matrix consists of fusing (one at a time) those outputs ( $\mathrm{F}_{0}$ through $\mathrm{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 term 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 ( 1 ms ) is reached, $\mathrm{V}_{\mathrm{CC}}$ should be stepped down to 5 V at which level verification can be accomplished.
6. Program verification can occur $10 \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.
NOTES:
8. $\mathrm{V}_{\mathrm{CC}}$ should be removed between program pulsas to reduce dissisotion and chlp temperatures. Soe Figure 1 .
9. If product terms were expanded to make then 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

TYPES SN54S330, SN54S331, SN74S330, SN74S331 12-INPUT/6-OUTPUT EXPANDABLE FIELD-PROGRAMMABLE LOGIC ARRAYS


OVERLAP INPUTS AND OUTPUTS 1:1

- CODE OUTPUT ENABLES TO ENABLE FPLA " $A$ " FOR SOME INPUT PATTERNS AND FPLA "B" FOR THE REST.

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
 FIELD-PROGRAMMABLE LOGIC ARRAYS TYPES SN54S330, SN54S331, SN74S330, SN74S331

# TYPES SN54S330, SN54S331, SN74S330, SN74S331 EXPANDABLE 12-INPUT, 50-TERM 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

## MEMORY PATCH/PROM EXTENSION (See Figures 7 and 8)

These supplemental functions are cost-effective solutions for enhancing or upgrading existing memory systems or designs. Either the patch or extension can be used to correct existing deficiencies, to prioritize improved control over existing functions, or to extend the existing capabilities. Priority and source select can be programmed into the FPLA.


FIGURE 7 - MEMORY PATCH


FIGURE 8 - PROM EXTENSION

## DIGITAL SEQUENTIAL CONTROLLERS (See Figure 9)

This broad category of functions range from simple stand-alone machine controllers to the microprogram sequencing of any size computer or machine. The identifiable common denominator being that a sequential controller decodes a present state and generates the next state. Contrasted to a data processor or computer which generates information from operating on a word of data, the sequential controller generates information on a bit-by-bit basis.

Sequences generated can range from simple counting schemes to arbitrary bit-by-bit generation of any unique output states.

This application shows how the FPLA can simplify the implementation of a sequential controller. When the combinatorial logic of the FPLA is combined with the flexibility and synchronization of standard flip-flops in a feed-back loop, the full capability to generate a next state functional directive can be decoded from the present state: the outputs of the flip flops (present state) in conjunction with the status inputs.

## STATUS DECODERS/RESULT INTERPRETERS

This broad category of functions, generally described as the elements which monitor the execution results of present instructions in sequential machines, can provide the decision-making hardware needed to both determine that the present operation is complete and simultaneously generate the next starting address or state. The actual configuration varies widely, but one popular method is to configure the FPLA similar to that shown for memory mapping.


FIGURE 9 - SEQUENTIAL CONTROLLER

## PRIORITY ENCODERS

The unique properties of the FPLA's capability to be programmed for decoding a number of product terms in virtaully any combination provides the user with the flexibility of identifying and implementing virtually any prioritized scheme. This option is normally available in any use shown for the ' $\mathrm{S} 330 /$ ' S 331 .

## RANDOM LOGIC OR FUNCTION GENERATORS

The 'S330/'S331 FPLAs provide the system designer with the options of reducing package count and/or system design time. Random gate logic can potentially be replaced at a package ratio of 12.5 -to-1 up to 50 -to-1 depending on the particular system needs. Function generators can be programmed directly into the FPLA from simple truth tables. In addition to reducing design and production start-up time, this technique can reduce the direct and indirect costs associated with logic and package minimization processes.

- 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 $\mathbf{Z}$ SN748373

| OUTPUT <br> CONTROL | ENABLE <br> G | D | OUTPUT |
| :---: | :---: | :---: | :---: |
| $L$ | $H$ | $H$ | $H$ |
| $L$ | $H$ | $L$ | $L$ |
| $L$ | $L$ | $X$ | $O_{0}$ |
| $H$ | $X$ | $X$ | $H i \cdot Z$ |

SN74S374

| OUTPUT <br> CONTROL | CLOCK | D | OUTPUT |
| :---: | :---: | :---: | :---: |
| $L$ | $\uparrow$ | $H$ | $H$ |
| $L$ | $\uparrow$ | $L$ | $L$ |
| $L$ | $L$ | $X$ | $Q_{0}$ |
| $H$ | $X$ | $X$ | $H_{i} \cdot 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
Hi-Z $\equiv$ high impedance
$X$ 五irrelevant
$\uparrow$ 毛 transition from low to high level

## 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. product in any manner without notice.

# TYPES SN54S373, SN54S374, SN74S373, SN74S374 <br> OCTAL D-TYPE TRANSPARENT LATCHES AND EDGE-TRIGGERED FLIP-FLOPS 

## 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 $\mathrm{Hi}-\mathrm{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

|  |  | SNE | 73, 8N | 374 | SN7 | 73, 8N | 3374 | UN |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| Supply voitage, VCC |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | $\checkmark$ |
| High-level output voltage, $\mathrm{V}_{\mathrm{OH}}$ |  |  |  | 5.5 |  |  | 5.5 | $\checkmark$ |
| High-leval output current, 1 OH |  |  |  | 2 |  |  | 6.5 | mA |
| Width of clock/enable pulse, $\mathrm{t}_{\mathbf{w}}$ | High | 6 |  |  | 6 |  |  | ns |
|  | Low | 7.3 |  |  | 7.3 |  |  |  |
| Date setup time, $\mathrm{t}_{\text {gu }}$ | 'S373 | 0 $\downarrow$ |  |  | - $\downarrow$ |  |  | ns |
|  | 'S374 | $5 \uparrow$ |  |  | $5 \uparrow$ |  |  |  |
| Data hold time, in | 'S373 | $10 \downarrow$ |  |  | $10 \downarrow$ |  |  | ns |
|  | 'S374 | $2 \uparrow$ |  |  | $2 \uparrow$ |  |  | ns |
| Operating free-air temperature, $\mathrm{T}_{\mathbf{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 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $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$, | $I_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 | V |
| VOH | 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_{I H}=2 V, \\ & I_{O H}=M A X \end{aligned}$ | 2.4 | 3.4 |  | $v$ |
|  |  | SN74S' |  |  | 2.4 | 3.1 |  |  |
| VOL | Low-level output voltage |  | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I L}=0.8 \mathrm{~V} \end{aligned}$ | $\begin{aligned} & V_{1 H}=2 \mathrm{~V}, \\ & \mathrm{IOL}^{2}=20 \mathrm{~mA} \end{aligned}$ |  |  | 0.5 | V |
| IOZH | 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}$ | $\mathrm{V}_{1 H}=2 \mathrm{~V}$, |  |  | 50 | $\mu \mathrm{A}$ |
| 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_{I H}=2 \mathrm{~V} .$ |  |  | -50 | $\mu \mathrm{A}$ |
| 11 | Input current at maximum input voltage |  | $\mathrm{V}_{C C}=$ MAX, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 | mA |
| IIH | High-level input current |  | $V_{C C}=M A X$, | $V_{1}=2.7 \mathrm{~V}$ |  |  | 50 | $\mu \mathrm{A}$ |
| 1 LL | 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 ${ }^{\text {§ }}$ |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$ |  | -40 |  | -100 | mA |
| ${ }^{1} \mathrm{Cc}$ | Supply current |  | $V_{C C}=\mathrm{MAX}$ | 'S373 |  | 105 | 160 | mA |
|  |  |  | 'S374 |  | 90 | 140 | 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}$.
SNot 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) | TO (OUTPUT) | TEST CONDITIONS | 'S373 |  |  | 'S374 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |
| $f_{\text {max }}$ |  |  | $\begin{aligned} & C_{L}=15 \mathrm{pF}, R_{\mathrm{L}}=280 \mathrm{~s} 2, \\ & \text { See Note } \end{aligned}$ |  |  |  | 75 | 100 |  | MHz |
| tPLH | Data | Any 0 |  |  | 5 | 9 |  |  |  | ns |
| tPHL |  |  |  |  | 9 | 13 |  |  |  |  |
|  | Clock or | Any 0 |  |  | 7 | 14 |  | 8 | 15 | n8 |
| (PLH | enable |  |  |  | 12 | 18 |  | 11 | 17 |  |
| ${ }^{\text {I }} \mathrm{ZH}$ | Output | Any 0 |  |  | 8 | 15 |  | 8 | 15 | ns |
| ${ }^{\text {Z }}$ L | Control |  |  |  | 11 | 18 |  | 11 | 18 |  |
| ${ }_{\text {thz }}$ | Output <br> Control | Any 0 | $C_{L}=5 p F, \quad R_{L}=280 \mathrm{~S},$ <br> See Note |  | 6 | 9 |  | 5 | 9 | ns |
| ${ }_{\text {t }}$ |  |  |  |  | 8 | 12 |  | 7 | 12 |  |

NOTE: $f_{\text {max }}$ is tested with all outputs loaded.
${ }^{\text {max }}$ ㅋmaximum clock frequency
$t_{\text {L }}$ H propagation delay time, low-to-high level
${ }^{\mathbf{t} P H L} \equiv$ propagation delay time, high-to-low level
$\mathbf{t}_{\mathrm{ZH}} \equiv$ output enable time to high level
$t_{Z L} \equiv$ output enable time to low level
${ }^{\mathbf{t}} \mathrm{HZ}$ 포 output disable time from high level
${ }^{\text {t }}$ LZ $\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 $\left(D O_{i}\right)$ follows its respective data input ( $D I_{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, $M D=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.

[^20]
## TYPES SN54S412, SN74S412 (TIM8212) MULTI-MODE BUFFERED LATCHES

## functional block diagram


schematics of inputs and outputs


TEXAS INSTRUMENTS
POST OFFICE BOX 5012 - DALLAS. TEXAS 75222

TYPES SN54S412, SN74S412 (TIM8212)
MULTI-MODE BUFFERED LATCHES
data latches function table

| FUNCTION | CLEAR | M | S1 | 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 | O O $^{2}$ |
|  | 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{\text { S }} 1$ | S2 | STB | 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)
$\mathrm{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)


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}_{\text {CC }}$ |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| Pulse width, $\mathrm{t}_{w}$ (see Figures 1. 2, and 4) | STB or S1 - S2 | 25 |  |  | 25 |  |  | ns |
|  | Clear low | 25 |  |  | 25 |  |  |  |
| Setup time, $\mathrm{t}_{\text {su }}$ (see Figure 3) |  | 15 $\downarrow$ |  |  | 15 $\downarrow$ |  |  | ns |
| Hold time, $\mathrm{th}^{\text {(see Figures } 1 \text { 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 |  |
| $V_{\text {IH }}$ | High-level input voltage |  |  |  |  |  | 2 |  |  | 2 |  |  | V |
| $V_{\text {IL }}$ | Low-level input voltage |  |  |  |  |  | 0.85 |  |  | 0.85 | V |
| $V_{\text {IK }}$ | Input clamp voltage |  | $\mathrm{V}_{C C}=\mathrm{MIN}$; | $\mathrm{I}_{1}=-18 \mathrm{~mA}$ |  |  | -1.2 |  |  | -1.2 | V |
| VOH | High-level output valtegs |  | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I L}=0.8 \mathrm{~V}, \end{aligned}$ | $\begin{aligned} & V_{I H}=2 \mathrm{~V}, \\ & I_{O H}=-1 \mathrm{~mA} \end{aligned}$ | 3.65 | 4 |  | 3.65 | 4 |  | V |
| VOL | Low-level output voltage |  | $\begin{aligned} & V_{C C}=M I N, \\ & V_{I H}=2 \mathrm{~V}, \end{aligned}$ | $\mathrm{IOL}^{\prime}=15 \mathrm{~mA}$ |  |  | 0.45 |  |  | 0.45 | $v$ |
|  |  |  | $V_{I L}=0.8 \mathrm{~V}$ | '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}$ | $V_{C C}=$ MAX , | $\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}=M A X$, | $\mathrm{V}_{\mathrm{O}}=0.5 \mathrm{~V}$ |  |  | -50 |  |  | -50 | $\mu \mathrm{A}$ |
| 11 | Input current at meximum input voltage |  | $V_{C C}=$ MAX, | $V_{1}=5.5 \mathrm{~V}$ |  |  | 1 |  |  | 1 | mA |
| I/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 | S1 | $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 § |  | $V_{C C}=M A X$ |  | -20 |  | -65 | -20 |  | -65 | mA |
| I'c. | Supply current |  | $\mathrm{V}_{\text {CC }}=\mathrm{MAX}$, | see Note 2 | 82 |  |  |  | 82 | 130 | 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}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
\& Not more than one output should be shorted at a time.
NOTE 2: ICC 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, ${ }^{\text {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 |
| ${ }_{\text {tPLH }}$ | DIi | DO; | 3 |  |  | 12 | 20 | ns |
| tpHL |  |  |  |  |  | 10 | 20 |  |
| tPLH | S1 or S2 | INT | 4 | $C_{L}=30 \mathrm{pF}$ |  | 12 | 20 | ns |
| tPHL | STB | INT | 4 |  |  | 16 | 25 |  |
| ${ }^{\text {I }} \mathrm{ZH}$ | S], S2, or M | Any DO | 5 | $C_{L}=30 \mathrm{pF}$ |  | 21 | 35 | ns |
| t 2 L |  |  |  |  |  | 25 | 40 |  |
| $\mathrm{t}_{\mathrm{Hz}}$ | S $1, ~ 52$, or M | Any DO | 5 | $C_{L}=5 \mathrm{pF}$ |  | 9 | 20 | ns |
| ${ }_{\text {t }}$ L |  |  |  |  |  | 12 | 20 |  |

tPLH mpropagation delay time, low-to-high-level output

tZH ${ }^{\text {Z }}$ Output enable time to high level
${ }^{2}$ ZL ( output enable time to low level
$t_{H Z}$ ㄹoutput disable time from high level
tLZ $=$ output disable time from low level

## TYPES SN54S412, SN74S412 (TIM8212)

MULTI-MODE BUFFERED LATCHES

PARAMETER MEASUREMENT INFORMATION


[^21]- Designed to Be Interchangeable with Intel 8228 and 8238


## PIN DESIGNATIONS

| DESIGNATION | PIN NOS. | FUNCTION |
| :---: | :---: | :---: |
| DO thru D7 | $\begin{gathered} 15,17,12,10 \\ 6,19, \\ \hline \end{gathered}$ | BIDIRECTIONAL DATA PORT (TO TMS 8080A) |
| DB0 thru DB7 | $\begin{array}{\|c\|} \hline 13,16,11,9, \\ 5,18,20,7 \\ \hline \end{array}$ | BIDIRECTIONAL DATA PORT (TO SYSTEM BUS) |
| I/OR | 25 | READ OUTPUT TO I/O (ACTIVE LOW) |
| 10/W | 27 | WRITE OUTPUT TO I/O (ACTIVE LOW) |
| 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{N T A}$ | 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) |
| BUSEN | 22 | SYSTEM DATA PORT ENABLE INPUT (ACTIVE LOW) |
| $\overline{\text { STSTB }}$ | 1 | SYNCHRONIZING STATUS STROBE INPUT FROM SN74LS424 (TIM8224) |
| VCC | 28 | SUPPLY VOLTAGE (5 V) |
| GND | 14 | GROUND |

N PACKAGE
(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 8080A in small to medium-large microcomputer systems.

A bidirectional eight-bit parallel bus driver is provided that isolates the 8080A bus from the memory and I/O data bus allowing the system designed to utilize costeffective 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 $1 / 0$ 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 $1 / 0$ 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 I/O control outputs. The status words and types of machine cycles are enumerated in Table A.

TABLE A - STATUS WORDS

| STATUS WORD | $8080 A$ <br> STATUS OUTPUT |  |  |  |  |  |  |  | TYPE OF MACHINE CYCLE | $\begin{aligned} & \text { 'S428/'S438 } \\ & \text { COMMAND } \\ & \text { GENERATED } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Do | D1 | D2 | D3 | D4 | D5 | D6 | 07 |  |  |
| 1 | L | H | L | L | L | H | L | H | Instruction fetch | MEMR |
| 2 | L | H | L | L | $L$ | $L$ | L | H | Memory read | MEMR |
| 3 | L | L | L | L | L | $L$ | $L$ | L | Memory write | MEMW |
| 4 | L | H | H | L | L | L | L | H | Steck read | MEMR |
| 5 | L | L | H | L | L | L | $L$ | L | Stack write | MEMW |
| 6 | L | H | L | L | L | L | H | L | Input read | $\overline{\text { I/OR }}$ |
| 7 | L | L | $L$ | $L$ | H | L | L | $L$ | Output write | T/OW |
| 8 | H | H | L | L | L | H | L | $L$ | Interrupt acknowledge | INTA |
| 9 | L | H | L | H | L | L | L | H | Halt acknowledge | NONE |
| 10 | H | H | $L$ | H | $L$ | H | L | $L$ | Interrupt ecknowledge at halt | INTA |
|  | $\frac{\mathbb{L}}{\mathbf{2}}$ | $10$ |  <br> TATU | E | $\stackrel{5}{5}$ | $\bar{\Sigma}$ TION | $\underline{\underline{2}}$ | $\sum_{\underset{\sim}{\mathbf{N}}}^{\boldsymbol{N}}$ |  |  |

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{M E M R}, \overline{I / O R}$ ) and the interrupt acknowledgement ( $\overline{(N T A)}$ are derived from the status bit(s) and the data bus input mode (DBIN) signal. The write commands (MEMW, I/OW) are derived from the status bit(s) and the write mode ( $\overline{W R}$ ) 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{\mathrm{INTA}}$ 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 one kilohm 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, $\mathrm{V}_{\mathrm{CC}}$ (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, VCC |  | 4.75 | 5 | 5.25 | V |
| High-level output current, 1OH | 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}_{\text {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, $\mathrm{th}^{\text {( }}$ (see Figure 3) | Status inputs D0 thru D7 | 5 |  |  | ns |
|  | System bus inputs to HLDA | 20 |  |  |  |
| Operating free-air temperature, $\mathrm{T}_{\mathrm{A}}$ |  | 0 |  | 70 | ${ }^{\circ} \mathrm{C}$ |

## TYPES SN74S428(TIM8228), SN74S438(TIM8238) CONTROLLER AND BUS DRIVER FOR 8080A SYSTEMS

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 |
| VIK | Input clamp voltage |  | $V_{C C}=\mathrm{MIN}, \quad \mathrm{I}_{1}=-5 \mathrm{~mA}$ |  |  | -1 | V |
| VOH | High-level output voltage | D0 thru D7 | $\begin{array}{ll} 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}$ | 3.6 | 4 |  | V |
|  |  | All other outputs |  | 2.4 |  |  |  |
| $\mathrm{V}_{\text {OL }}$ | Low-fevel output voltage |  | $\begin{array}{ll} \mathrm{V}_{\mathrm{CC}}=\mathrm{MIN}, & \mathrm{~V}_{\text {IH }}=2 \mathrm{~V}, \\ \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}, & \mathrm{I}_{\mathrm{OL}}=\mathrm{MAX} \\ \hline \end{array}$ |  |  | 0.45 | V |
| IOZH | Off-state output current, high-level voltage applied |  | $V_{C C}=\mathrm{MAX}, \quad \mathrm{V}_{\mathrm{O}}=5.25 \mathrm{~V}$ |  |  | 100 | $\mu \mathrm{A}$ |
| IOZL | Off-state output current, low-level voltage applied |  | $V_{C C}=\mathrm{MAX}, \quad V_{O}=0.45 \mathrm{~V}$ |  |  | -100 | $\mu \mathrm{A}$ |
| IIH | High-level input current | $\overline{\text { INTA }}$ | $\mathrm{V}_{C C}=$ MIN, See Figure 1 |  |  | 5 | mA |
|  |  | DO thru D7 | $V_{C C}=$ MAX, $V_{1}=5.25 \mathrm{~V}$ |  |  | 20 | $\mu \mathrm{A}$ |
|  |  | All other inputs |  |  |  | 100 |  |
| I/L | Low-level input current | D2 or D6 | $V_{C C}=$ MAX, $\quad V_{1}=0.45 \mathrm{~V}$ |  |  | -750 | $\mu \mathrm{A}$ |
|  |  | STS'E |  |  |  | -500 |  |
|  |  | All other inputs |  |  |  | -250 |  |
| Ios | 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.
$\ddagger$ All typical values are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{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}, \quad$ See Figure 2 |  | 30 | ns |
| tPHL | $\overline{\text { STSTB }}$ | INTA, TOR, MEMR, IOW, MEMW | $C_{L}=100 \mathrm{pF}, \quad$ See Figure 2 | 20 | 60 | ns |
| tPD | WR | IOW, MEMW |  | 5 | 45 | ns |
| tPLH | DBIN | INTA, T/OR, MENR |  |  | 30 | ns |
| tPLH | HLDA | INTA, T/OR, MEMR |  |  | 25 | ns |
| tPZX | DBIN | D0 thru D7 | $C_{L}=25 \mathrm{pF}, \quad$ See Figure 2 |  | 45 | ns |
| tPXZ | DBIN | D0 thru D7 |  |  | 45 | ns |
| tPZX | STSTE, BUSEN | DB0 thru DB7 | $C_{L}=100 \mathrm{pF}, \quad$ See Figure 2 |  | 30 | ns |
| tpxz | BUSEN | DB0 thru DB7 |  |  | 30 | ns |

If tp $=$ propagation delay time
tPHL $\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
tpXZ $\equiv$ output disable time to high-impedance state

# TYPES SN74S428(TIM8228), SN74S438(TIM8238) CONTROLLER AND BUS DRIVER FOR 8080A SYSTEMS 

PARAMETER MEASUREMENT INFORMATION


FIGURE 1-INTA INPUT CURRENT TEST CIRCUIT


FIGURE 2-SWITCHING CHARACTERISTICS LOAD CIRCUIT


NOTE A: Advanced response of $\overline{1 / O W}$ or $\overline{M E M W}$ for the SN74S438 is Indicated by the deshed 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 ' S 482 elements can generate $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



## TENTATIVE DATA SHEET

[^22]IIntegrated Schottky-Berrier diodoelamped transistor is patented by
Texpes Instruments. U. S. Petent Number 3,4e3,975.

## TYPES SN54S482, SN74S482 <br> 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 |  | REOISTER INPUT SOURCE |
| :--- | :--- | :--- |
| 88 | 88 |  |
| L | L | DATA-IN PORT (DI) |
| L | H | FULL ADDER OUTPUTS (EI) |
| H | L | PUSH-POP STACK OUTPUTS (QI) |
| H | H | REGISTER OUTPUTS (HOLD) |



TABLE II. PUSHPOP STACK CONTROL AND REGISTER-SOURCE FUNCTIONS

|  | INPUTS |  |  |  |  |  | INTERNAL OiA | OUTPUTS Fi |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 83 | 54 | 58 | 88 | CLOCK | CLEAR |  |  |
| HOLD | X | $x$ | $x$ | X | L | H | QiAO | FiO |
| CLEAR | X | $x$ | X | X | $\times$ | L | QiAO | L |
| PUSHPOP | L | L | L | L | $\dagger$ | H | OIAO* | Di |
|  | L | L | L | H | $\uparrow$ | H | OIAO* | $\Sigma 1$ |
|  | L | L | H | L | $\dagger$ | H | QIAO* | QIAO |
|  | L | L | H | H | $\uparrow$ | H | Q1AO* | Fio |
| PUSH-POP | L | H | L | L | $\uparrow$ | H | $\Sigma^{\circ}{ }^{\circ}$ | Di |
|  | L | H | L | H | $\uparrow$ | H | $\Sigma 1^{\circ}$ | $\Sigma \mathrm{I}$ |
| STACK "LOAD" | L | H | H | L | $\uparrow$ | H | $\Sigma 1^{*}$ | QiAO |
|  | L | H | H | H | $\uparrow$ | H | $\Sigma 1^{\circ}$ | FIO |
| PUSHPOP | H | L | L | L | $\dagger$ | H | O1B0 ${ }^{+}$ | Di |
|  | H | L | L | H | $\uparrow$ | H | QiBO ${ }^{+}$ | $\Sigma \mathrm{i}$ |
|  | H | L | H | L | $\uparrow$ | H | Qibo ${ }^{+}$ | QiAO |
|  | H | L | H | H | $\dagger$ | H | Cibo ${ }^{+}$ | FiO |
| PUSH-POP | H | H | L | L | $\uparrow$ | H | $\boldsymbol{\Sigma} \mathrm{i}^{\ddagger}$ | Di |
|  | H | H | L | H | $\uparrow$ | H | $\boldsymbol{\Sigma 1} \ddagger$ | $\Sigma \mathrm{I}$ |
| STACK "PUSH" | H | H | H | L | $\uparrow$ | H | 「i $\ddagger$ | QiAO |
|  | H | H | H | H | $\uparrow$ | H | Ei $\ddagger$ | FiO |

$$
\begin{array}{llll}
\text { MSB } & & & \text { LSB } \\
\text { E } & \text { 2. } & \text { 1. } & 0
\end{array}
$$

$A i \equiv$ Data inputs
$Q_{i} A \equiv P$ ush-pop stack word $A$ output (internal) QiAO $\equiv$ the level of Ql 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 \mid \equiv$ Adder outputs (internal

- QiB, QIC, QID do not change
${ }^{\dagger}$ QIDO $\rightarrow$ QID, QIDO $\rightarrow$ QIC, QiCO $\rightarrow$ QiB, QIBO $\rightarrow$ QiA
$\ddagger$ QIAO $\rightarrow$ QiB, QIBO $\rightarrow$ QIC, QiCO $\rightarrow$ QiD


## TYPES SN54S482, SN74S482 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. PUBHPOP STACK FUNCTIONS

$\mu l i n k$ 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 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 ( $\mathbf{A}$ plus $\mathbf{B}$ ) with carry low.

The ALU functions are shown in Table IV.

TABLE IV. ADDRESS CONTROL FUNCTIONS

| INPUTS |  | INTERNAL |
| :---: | :---: | :---: |
| $\mathbf{S 1}$ | $\mathbf{S 2}$ |  |
| $H$ | $H$ | 0 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=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)



NOTE 1. All voltege 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 voltape, VCC |  | 4.5 | 5 | 5.5 | 4.75 | 5 | 5.25 | V |
| High-leval output current, IOH | Carry output |  |  | -1 |  |  | -1 | mA |
|  | Any F output |  |  | -2 |  |  | -2 |  |
| Low-lavel output current, IOL | Carry output |  |  | 10 |  |  | 10 | mA |
|  | Any F output |  |  | 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 \uparrow$ |  |  |  |
| Pulse width, ${ }_{\text {w }}$ | Clock (high or low) | 50 |  |  | 30 |  |  | ns |
| Pulse width, w | Clear (low) | 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, S2 | $15 \uparrow$ |  |  | $10 \uparrow$ |  |  |  |
|  | S3, 54 | $25 \uparrow$ |  |  | $20 \uparrow$ |  |  |  |
| Operating free-air temperature, $\mathrm{T}_{\mathbf{A}}$ |  | -55 |  | 125 | 0 | 25 | 70 | ${ }^{\circ} \mathrm{C}$ |

个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 ${ }^{\text {F }}$ | MAX | MIN | TYP\# | MAX |  |
| $\mathrm{V}_{\text {IH }}$ | Highteval input voltage |  |  |  |  |  | 2 |  |  | 2 |  |  | V |
| $V_{1 L}$ | Low-level input voltage |  |  |  |  |  | 0.8 |  |  | 0.8 | V |
| $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}_{I H}=2 \mathrm{~V}, \\ & \mathrm{I}_{\mathrm{OH}}=\mathrm{MAX} \end{aligned}$ | 2.5 | 3.4 |  | 2.7 | 3.4 |  | $\checkmark$ |
| 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{L}}=\mathrm{MAX} \end{aligned}$ |  |  | 0.5 |  |  | 0.5 | V |
| 11 | Input current at maximum input voltage |  | $V_{C C}=$ MAX, | $\mathrm{V}_{1}=5.5 \mathrm{~V}$ |  |  | 1 |  |  | 1 | mA |
| IIH | Hightevel input current | S1, S2, Cin | $V_{C C}=$ MAX | $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-leval input current | S1, S2 | $V_{C C}=$ MAX, | $v_{1}=0.5 \mathrm{~V}$ |  |  | -1 |  |  | -1 | mA |
|  |  | C-in |  |  |  |  | -0.8 |  |  | -0.8 |  |
|  |  | S3, 54 |  |  |  |  | -1.2 |  |  | -1.2 |  |
|  |  | Any A, S5, S6, CK |  |  |  |  | -2 |  |  | -2 |  |
|  |  | Clear |  |  |  |  | -4 |  |  | -4 |  |
|  |  | Clock |  |  |  |  | -2.8 |  |  | -2.8 |  |
| Ios | Short-circuit output current § |  | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  | -40 |  | -110 | -40 |  | -110 | mA |
| ICC | Supply current |  | $\mathrm{V}_{C C}=\mathrm{MAX}$ |  |  | 90 | 130 |  | 90 | 140 | mA |

[^23]
## TYPES SN54S482, SN74S482 <br> 4-BIT-SLICE EXPANDABLE CONTROL ELEMENTS

switching characteristics over recommended operating ranges of $T_{A}$ and $\mathbf{V}_{\mathbf{C}}$ (unless otherwise noted)

| PARAMETER | FROM | то | TEST CONDITIONS | SN54S482 |  |  | SN74S482 |  |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | MIN | TYP ${ }^{\text {¢ }}$ | MAX | MIN | TYP7 | max |  |
| tPLH | CLOCK | DATA OUT | $\begin{aligned} & C_{L}=15 \mathrm{pF}, \\ & \mathrm{R}_{\mathrm{L}}=280 \Omega \end{aligned}$ |  | 12 | 30 |  | 12 | 25 |  |
| tPHL |  |  |  |  | 15 | 30 |  | 15 | 25 |  |
| tPHL | CLEAR | DATA OUT |  |  | 12 | 25 |  | 12 | 20 | $n 8$ |
| tPLH | CARRY IN | CARRY OUT |  |  | 12 | 22 |  | 12 | 18 | m |
| tPHL |  |  |  |  | 10 | 22 |  | 10 | 18 | $\ldots$ |
| tPLH | DATA IN | CARRY OUT |  |  | 17 | 30 |  | 17 | 25 | ns |
| tPHL |  |  |  |  | 12 | 30 |  | 12 | 25 |  |

$\ddagger_{\text {All typical values are at }} V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$.

The Engineering Staff of
TEXAS INSTRUMENTS INCORPORATED
Semiconductor Group


DECEMBER 1976

TEXAS INSTRUMENTS<br>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)


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.

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


TTL INTEGRATED CIRCUITS MECHANICAL DATA

## $\mathbf{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 specifled, dipped area of the lead extends from the lead tip to at least 0.020 ( 0,50 ) above the seating plane.

TEXAS INSTRUMENTS

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 processina when used in soldered assembly.



[^24]
[^0]:    - Current out of a terminal is glven as a negative value.

[^1]:    $\uparrow \downarrow$ The arrow indicates the transition of the olock input used for reference: $\uparrow$ for the low-to-high transition, $\downarrow$ for the high-to-low transition.

[^2]:    This document provides tentative information
    on a now product. Toxes Instruments reserves the right to change specifications for this

[^3]:    $\bullet X W R \rightarrow$ AOP, otherwise WR $\rightarrow$ AOP. PC PRIORITY $=$ HIGH overrldes.

[^4]:    This document provides tentative information on a new product. Texas Instruments reserves the right to change specifications for this product in any manner without notice.

[^5]:    MOTE A. Esch pin centerline is located within 0.010 of its true longitudinal position.

[^6]:    $\dagger$ For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
    $\ddagger$ All typlical 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 OCA $^{\prime}$, of not more than $42 \mathrm{C} / \mathrm{W}$.
    NOTE 4: The typical values of ICC shown are with all outputs low.

[^7]:    T For conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions.
    \$All typlcal values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$.
    $\triangle$ An SNB4S387 in the $W$ package operating at free-air temperatures above $108^{\circ} \mathrm{C}$ requires a heat sink that provides a thermal resistance from ceseto-free-air, $R_{\theta C A}$, of not more than $42^{\circ} \mathrm{C} / \mathrm{W}$.
    NOTE 4: The typleal values of ICC shown are with all outputs low.

[^8]:    $M \equiv$ high level, $L \equiv$ low level, $X \equiv$ irrelevant

[^9]:    tFor conditions shown as MIN or MAX use the appropriate value epecified 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 circult should not exceed one second.
    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.

[^10]:    †For conditions shown as MIN or MAX use the appropriate value specifled under recommended operating conditions.
    $\dagger$ For conditions shown as MIN or MAX use the approp
    $\ddagger$ These typlcal values are at $V_{C C}=5 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C}$.

    + These typical values are at $V C C=5 V, T A=25 C$.
    \& Duration of the short circult should not exceed one second.
    NOTE: 3. ICC is measured with all inputs grounded and the output open.

[^11]:    $\dagger$ For conditions shown as MIN or MAX use the appropriate value specified under recommended operating conditions.
    $\ddagger$ These typlcal values are at $V_{C C}=5 V, T_{A}=26^{\circ} \mathrm{C}$.
    § Duration of the short clrcuit 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.

[^12]:    T For conditlons shown as MIN or MAX, use the appropriate value epecifled under recommended operating conditions.
    $\ddagger$ All typical values are at $V_{C C}=5 V, T_{A}=25^{\circ} \mathrm{C}$.
    8 Duration of the short-circult thould not exceed one second.
    NOTES: 1. All voltage valuce are with respect to network ground terminal.
    2. Icc is measured with the write Input high, output enable Input grounded, alf other Inputs at 4.5 V , and all outputs open.

[^13]:    †For conditions shown as MIN or MAX use the approprlate value specified under recommended operating conditions.
    \$All typical values are at $\mathrm{V}_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$.
    8 Duration of the short circuit should not exceed one second.
    NOTE 3: ICC is measured with all inputs grounded and the output open.

[^14]:    $I f_{\text {max }}$ maximum clock frequency.
    $t_{w}$ IF pulee width (output)
    $\dagger \downarrow$ 送 The arrow Indicates that the low-to-high ( $\dagger$ ) or high-to-low ( $\downarrow$ ) transition of the output ready (OR) output is used for reforence.
    tPLH $=$ propegation delay time, low to-high leval output
    tPHL $\equiv$ propagation delay time, high-to-low-level output.
    $\ddagger$ All typlical values are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

[^15]:    NOTE 1: Voltage values are with respect to network ground terminal.

[^16]:    This document provides tentative information on a new product. Texas Instruments reserves the right to change specifications for this product in any manner without notice.

[^17]:    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.

[^18]:    OData Includes the two serial inputs and the eight input/output data lines.

[^19]:    TEXAS INSTRRUMENTS
    post office box 5012 - dallas. texas 75222

[^20]:    TENTATIVE DATA SHEET
    This document provides tentative information TEXAS INSTRUMENTS
    on a now product. Toxes Instruments reserves on a now product. Toxes Instruments reserves the right to change apecifications for this product in any manner without notice.

[^21]:    Texas Instruments
    POET OFFICE BOX 5012 - DALLAE. TEXAS 75222

[^22]:    This document provides tentative information TEXAS INSTRUMENTS on a new product. Texas Inatruments reserves the right to change specffications for this poet office box 5012 . dALLAs. TEXAS 73222 product in any menner without notice.

[^23]:    ${ }^{\text {tFor conditions shown as MIN or MAX, use the appropriate value specified under recommended operating conditions. }}$
    ${ }^{\ddagger}$ All typlcal 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.

[^24]:    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 within $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.

