

# intel

# Series 3000 Family Of Computing Elements — The Total System Solution.

Since its introduction in September, 1974, the Series 3000 family of computing elements has found acceptance in a wide range of high performance applications from disk controllers to airborne CPU's.

The Series 3000 family represents more than a simple collection of bipolar components, it is a complete family of computing elements and hardware/software support that greatly simplifies the task of transforming a design from concept to production.

### The Series 3000 Component Family

A complete set of computing elements that are designed as a system requiring a minimum amount of ancillary circuitry.

| 3001              | Microprogram Control Unit.                 |
|-------------------|--------------------------------------------|
| 3002              | Central Processing Element.                |
| 3003 ·            | Look-Ahead Carry Generator.                |
| 3212              | Multi-Mode Latch Buffer.                   |
| 3214              | Interrupt Control Unit.                    |
| 3216/26           | Parallel Bi-directional Bus Driver.        |
| <b>ROMs/PROMs</b> | A complete set of bipolar ROMs and PROMs.  |
| RAMs              | A Complete family of MOS and bipolar RAMs. |
|                   |                                            |

### The Series 3000 Support

A comprehensive support system that assists the designer in writing microprograms, debugging hardware and microcode, and programming prototype and production PROMs.

| CROMIS               | Cross microprogram assembler.                                                                                                                         |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| MDS-800              | Microcomputer development system with TTY/CRT,<br>line printer, diskette, PROM programmer and high<br>speed paper tape reader facilities.             |
| ICE-30               | In-circuit emulation for the 3001 MCU.                                                                                                                |
| ROM-SIM              | ROM simulation for all of Intel's Bipolar ROMs and PROMs.                                                                                             |
| Application<br>Notes | Central processor and disk controller designs and<br>system timing considerations.                                                                    |
| Customer<br>Course   | Comprehensive 3 day course covering the component family, CPU and controller designs, microprogramming and the MDS-800, ICE-30 and ROM-SIM operation. |

The Series 3000 family is designed to provide a Total System Solution: high performance, minimum package count and total commitment to support.

# **Contents**

|         | INTRODUCTION 1-1                                                                                                                                                                                            |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | COMPONENT FAMILY 2-1                                                                                                                                                                                        |
| e<br>al | 3001 Microprogram Control Unit2-13002 Central Processing Element2-153003 Look-Ahead Carry Generator2-313212 Multi-Mode Latch Buffer2-393214 Interrupt Control Unit2-493216/3226 Parallel Bi-Directional2-61 |
|         | APPLICATIONS                                                                                                                                                                                                |
|         | Disk Controller Designed With Series 3000<br>Computing Elements                                                                                                                                             |
|         | Central Processor Designs Using The<br>Intel® Series 3000 Computing<br>Elements 3-19                                                                                                                        |
|         | ORDERING AND PACKAGING INFORMATION4-1                                                                                                                                                                       |
|         | Ordering Information                                                                                                                                                                                        |

# Series 3000 Reference Manual

# INTRODUCTION

### A family architecture

To reduce component count as far as practical, a multi-chip LSI microcomputer set must be designed as a complete, compatible family of devices. The omission of a bus or a latch or the lack of drive current can multiply the number of miscellaneous SSI and MSI packages to a dismaying extent-witness the reputedly LSI minicomputers now being offered which need over a hundred extra TTL packages on their processor boards to support one or two custom LSI devices. Successful integration should result in a minimum of extra packages, and that includes the interrupt and the input/output systems.

With this objective in mind, the Intel Schottky bipolar LSI microcomputer chip set was developed. Its two major components, the 3001 Microprogram Control Unit (MCU) and the 3002 Central Processing Element (CPE), may be combined by the digital designer with standard bipolar LSI memory to construct high-performance controller-processors (Fig. 1) with a minimum of ancillary logic.

Among the features that minimize package count and improve performance are: the multiple independent data and address busses that eliminate time multiplexing and the need for external latches; the three-state output buffers with high fanout that make bus drivers unnecessary except in the largest systems, and the separate output-enable logic that permits bidirectional busses to be formed simply by connecting inputs and outputs together.

Each CPE represents a complete two-bit slice through the data-processing section of a computer. Several CPEs may be arrayed in parallel to form a processor of any desired word length. The MCU, which together with the microprogram memory, controls the step-by-step operation of the processor, is itself a powerful microprogramed state sequencer.

Enhancing the performance and capabilities of these two components are a number of compatible computing elements. These include a fast look-ahead carry generator, a priority interrupt unit, and a multimode latch buffer. A complete summary of the first available members of this family of LSI computing elements and memories is given in the table on this page.

| 3001  | Microprogram control unit                 |
|-------|-------------------------------------------|
| 3002  | Central processing element                |
| 3003  | Look-ahead carry generator                |
| 3212  | Multimode latch buffer                    |
| 3214  | Priority interrupt unit                   |
| 3216  | Noninverting bidirectional bus driver     |
| 3226  | Inverting bidirectional bus driver        |
| 3601  | 256-by-4-bit programable read-only memory |
| 3604  | 512-by-8-bit programable read-only memory |
| 3301A | 256-by-4-bit read-only memory             |
| 3304A | 512-by-8-bit read-only memory             |



1. Bipolar microcomputer. Block diagram shows how to implement a typical 16-bit controller-processor with new family of bipolar computer elements. An array of eight central processing elements (CPEs) is governed by a microprogram control unit (MCU) through a separate read-only memory that carries the microinstructions for the various processing elements. This ROM may be a fast, off-the-shelf unit.

Intel Corporation assumes no responsibility for the use of any circuitry or microprogram other than circuitry or microprograms embodied in an Intel product. No other circuit patent licenses are implied.

### **CPEs form a processor**

Each CPE (Fig. 2) carries two bits of five independent busses. The three input busses can be used in several different ways. Typically, the K-bus is used for microprogram mask or literal (constant) value input, while the other two input busses, M and I, carry data from external memory or input/output devices. D-bus outputs are connected to the CPE accumulator; A-bus outputs are connected to the CPE memory address register. As the CPEs are wired together, all the data paths, registers, and busses expand accordingly.

Certain data operations can be performed simply by connecting the busses in a particular fashion. For example, a byte exchange operation, often used in datacommunications processors, may be carried out by wiring the D-bus outputs back to the I-bus inputs, exchanging the high-order outputs and low-order inputs. Several other discretionary shifts and rotates can be accomplished in this manner.

A sixth CPE bus, the seven-line microfunction bus, controls the internal operation of the CPE by selecting the operands and the operation to be performed. The arithmetic function section, under control of the microfunction bus decoder, performs over 40 Boolean and binary functions, including 2's complement arithmetic and logical AND, OR, NOT, and exclusive-NOR. It increments, decrements, shifts left or right, and tests for zero. Unlike earlier MSI arithmetic-logic units, which contain many functions that are rarely used, the microfunction decoder selects only useful CPE operations. Standard carry look-ahead outputs, X and Y, are generated by the CPE for use with available look-ahead devices or the Intel 3003 Look-ahead Carry Generator. Independent carry input, carry output, shift input, and shift output lines are also available.

What's more, since the K-bus inputs are always ANDed with the B-multiplexer outputs into the arithmetic function section, a number of useful functions that in conventional MSI ALUS would require several cycles are generated in a single CPE microcycle. The type of bit masking frequently done in computer control systems can be performed with the mask supplied to the K-bus directly from the microinstruction.

Placing the K-bus in either the all-one or all-zero state will, in most cases, select or deselect the accumulator in the operation, respectively. This toggling effect of the K-bus on the accumulator nearly doubles the CPE's repertoire of microfunctions. For instance, with the K-bus in the all-zero state, the data on the M-bus may be complemented and loaded into the CPE's accumulator. The same function selected with the K-bus in the all-one state will exclusive-NOR the data on the M-bus with the accumulator contents.



2. Central processing element. This element contains all the circuits representing a two-bit-wide slice through a small computer's central processor. To build a processor of word width N, all that's necessary is to connect an array of N/2 CPEs together.

#### Three innovations

The power and versatility of the CPE are increased by three rather novel techniques. The first of these is the use of the carry lines and logic during non-arithmetic operations for bit testing and zero detection. The carry circuits during these operations perform a word-wide logical OR (ORing adjacent bits) of a selected result from the arithmetic section. The value of the OR, called the carry OR, is passed along the carry lines to be ORed with the result of an identical operation taking place simultaneously in the adjacent higher-order CPE.

Obviously, the presence of at least one bit in the logical 1 state will result in a true carry output from the highest-order CPE. This output, as explained later, can be used by the MCU to determine which microprogram sequence to follow. With the ability to mask any desired bit, or set of bits, via the K-bus inputs included in the carry OR, a powerful bit-testing and zero-detection facility is realized.

The second novel CPE feature is the use of three-state outputs on the shift right output (RO) and carry output (CO) lines. During a right shift operation, the CO line is placed in the high-impedance (Z) state, and the shift data is active on the RO line. In all other CPE operations, the RO line is placed in the Z state, and the carry data is active on the CO line. This permits the CO and RO lines to be tied together and sent as a single rail input to the MCU for testing and branching. Left shift operations utilize the carry lines, rather than the shift lines, to propagate data.

The third novel CPE capability, called conditional clocking, saves microcode and microcycles by reducing the number of microinstructions required to perform a given test. One extra bit is used in the microinstruction to selectively control the gating of the clock pulse to the central processor (CP) array. Momentarily freezing the clock (Fig. 3) permits the CPE microfunction to be performed, but stops the results from being clocked into the specified registers. The carry or shift data that results from the operation is available because the arithmetic section is combinatorial, rather than sequential. The data can be used as a jump condition by the MCU and in this way permits a variety of nondestructive tests to be performed on register data.

#### Microprogram control

The classic form of microprogram control incorporates a next-address field in each microinstruction-any



3. Conditional clock. This feature permits an extra bit in microinstruction to selectively control gating of clock pulse to CP array. Carry or shift data thus made available permits tests to be performed on data with fewer microinstructions.

other approach would require some type of program counter. To simplify its logic, the MCU (Fig. 4) uses the classic approach and requires address control information from each microinstruction. This information is not, however, simply the next microprogram address. Rather, it is a highly encoded specification of the next address and one of a set of conditional tests on the MCU bus inputs and registers.

The next-address logic and address control functions of the MCU are based on a unique scheme of memory addressing. Microprogram addresses are organized as a two-dimensional array or matrix. Unlike in ordinary memory, which has linearly sequenced addresses, each microinstruction is pinpointed by its row and column address in the matrix. The 9-bit microprogram address specifies the row address in the upper 5 bits and the column address in the lower 4 bits. The matrix can therefore contain up to 32 row addresses and 16 column addresses for a total of 512 microinstruction addresses.

The next-address logic of the MCU makes extensive use of this addressing scheme. For example, from a particular row or column address, it is possible to jump either unconditionally to any other location in that row or column or conditionally to other specified locations, all in one operation. For a given location in the matrix there is a fixed subset of microprogram addresses that may be selected as the next address. These are referred to as a jump set, and each type of MCU address control jump function has a jump set associated with it.

Incorporating a jump operation in every microinstruction improves performance by allowing processing functions to be executed in parallel with program branches. Reductions in microcode are also obtained because common microprogram sequences can be shared without the time-space penalty usually incurred by conditional branching.

Independently controlled flag logic in the MCU is available for latching and controlling the value of the carry and shift inputs to the CP array. Two flags, called C and Z, are used to save the state of the flag input line. Under microprogram control, the flag logic simultaneously sets the state of the flag output line, forcing the line to logical 0, logical 1, or the value of the C or Z flag.

The jump decisions are made by the next-address logic on the basis of: the MCU's current microprogram address; the address control function on the accumulator inputs; and the data that's on the macroinstruction (X) bus or in the program latch or in the flags. Jump decisions may also be based on the instantaneous state of the flag input line without loading the value in one of the flags. This feature eliminates many extra micro-instructions that would be required if only the flag flip-flop could be tested.

Microinstruction sequences are normally selected by the operation codes (op codes) supplied by the microinstructions, such as control commands or user instructions in main memory. The MCU decodes these commands by using their bit patterns to determine which is to be the next microprogram address. Each decoding results in a 16-way program branch to the desired microinstruction sequence.



4. Microprogram control unit. The MCU's two major control functions include controlling the sequence of microprograms fetched from the microprogram memory, and keeping track of the carry inputs and outputs of the CP array by means of the flag logic control.

#### Cracking the op codes

For instance, the MCU can be microprogramed to directly decode conventional 8-bit op codes. In these op codes the upper 4 bits specify one of up to 16 instruction classes or address modes, such as register, indirect, or indexed. The remaining bits specify the particular subclass such as ADD, SKIP IF ZERO, and so on. If a set of op codes is required to be in a different format, as may occur in a full emulation, an external pre-decoder, such as ROM, can be used in series with the X-bus to reformat the data for the MCU.

In rigorous decoding situations where speed or space is critical, the full 8-bit macroinstruction bus can be used for a single 256-way branch. Pulling down the load line of the MCU forces the 8 bits of data on the X-bus (typically generated by a predecoder) directly into the microprogram address register.

The data thus directly determines the next microprogram address which should be the start of the desired microprogram sequence. The load line may also be used by external logic to force the MCU, at power-up, into the system re-initialization sequence. From time to time, a microprocessor must examine the state of its interrupt system to determine whether an interrupt is pending. If one is, the processor must suspend its normal execution sequence and enter an interrupt sequence in the microprogram. This requirement is handled by the MCU in a simple but elegant manner.

When the microprogram flows through address row 0 and column 15, the interrupt strobe enable line of the MCU is raised. The interrupt system, an Intel 3214 Interrupt Control Unit, responds by disabling the row address outputs of the MCU via the enable row address line, and by forcing the row entry address of the microprogram interrupt sequence onto the row address bus. The operation is normally performed just before the macroinstruction fetch cycle, so that a macroprogram is interrupted between, not during, macroinstructions.

The 9-bit microprogram address register and address bus of the MCU directly address 512 microinstructions. This is about twice as many as required by the typical 16-bit disk-controller or central processor.



5. Microinstruction format. Only a generalized microinstruction format can be shown since allocation of bits for the mask field and optional processor functions depends on the wishes of the designer and the tradeoffs he decides to make.

Moreover, multiple 512 microinstruction memory planes can easily be implemented simply by adding an extra address bit to the microinstruction each time the number of extra planes is doubled. Incidentally, as the number of bits in the microinstruction is increased, speed is not reduced. The additional planes also permit program jumps to take place in three address dimensions instead of two.

Because of the tremendous design flexibility offered by the Intel computing elements, it is impossible to describe every microinstruction format exactly. But generally speaking, the formats all derive from the one in Fig. 5. The minimum width is 18 bits: 7 bits for the address control functions, plus 4 bits for the flag logic control; plus 7 bits for the CPE microfunction control.

More bits can be added to the microinstruction format to provide such functions as mask field input to the CP array, external memory control, conditional clocking, and so on. Allocation of these bits is left to the designer who organizes the system. He is free to trade off memory costs, support logic, and microinstruction cycles to meet his cost/performance objectives.

### Microprograming technology

■ Microprogram: A type of program that directly controls the operation of each functional element in a microprocessor.

Microinstruction: A bit pattern that is stored in a microprogram memory word and specifies the operation of the individual LSI computing elements and related subunits, such as main memory and input/output interfaces.

■ Microinstruction sequence: The series of microinstructions that the microprogram control unit (MCU) selects from the microprogram to execute a single macroinstruction or control command. Microinstruction sequences can be shared by several macroinstructions.

 Macroinstruction: Either a conventional computer instruction (e.g. ADD MEMORY TO REGISTER, IN-CREMENT, and SKIP, etc.) or device controller command (e.g., SEEK, READ, etc.).

#### The cost/performance spectrum

The total flexibility of the Intel LSI computing elements is demonstrated by the broad cost/performance spectrum of the controllers and processors that can be constructed with them. These include:

• High-speed controllers, built with a stand-alone ROM-MCU combination that sequences at up to 10 megahertz; it can be used without any CPEs as a system state controller.

• Pipelined look-ahead carry controller-processors, where the overlapped microinstruction fetch/execute cycles and fast-carry logic reduce the 16-bit add time to less than 125 nanoseconds.

• Ripple-carry controller processors (a 16-bit design adds the contents of two registers in 300 nanoseconds).

 Multiprocessors, or networks of any of the above controllers and processors, to provide computation, interrupt supervision, and peripheral control.

These configurations represent a range of microinstruction execution rates of from 3 million to 10 million instructions per second, or up to two orders of magnitude faster, for example, than p-channel microprocessors. Moreover, the increases in processor performance are achieved with relative simplicity. A ripple-carry 16-bit processor uses one MCU, eight CPEs, plus microprogram memory. One extra computing element, the 3003 Look-ahead Carry Generator, enhances the processor with fast carry. Increasing speed further by pipelining, the overlap of microinstruction fetch and execute cycles, requires a few D-type MSI flip-flops.

At the multiprocessor level, the microprogram memory, MCU, or CPE devices can be shared. A 16-bit processor, complete with bus control and microprogram memory, requires some 20 bipolar LSI packages and half that many small-scale ICs. In this configuration, it replaces an equivalent MSI TTL system having more than 200 packages.

Furthermore, systems built with this large-scale integrated circuitry are much smaller and less costly and consume less energy than equivalent designs using lower levels of transistor-transistor-logic integration. Even allowing for ancillary logic circuits, the new bipolar computing elements cut 60% to 80% off the package count in realizing most of today's designs made with small- or medium-scale-integrated TTL.



# intel

The  $INTEL^{\textcircled{0}}$  3001 Microprogram Control Unit (MCU) controls the sequence in which microinstructions are fetched from the microprogram memory. Its functions include the following:

Maintenance of the microprogram address register.

Selection of the next microinstruction based on the contents of the micro-program address register.

Decoding and testing of data supplied via several input busses to determine the microinstruction execution sequence.

Saving and testing of carry output data from the central processor (CP) array.

Control of carry/shift input data to the CP array.

Control of microprogram interrupts.

# SCHOTTKY BIPOLAR LSI MICROCOMPUTER SET

High Performance - 85 ns Cycle

Fully Buffered Three-State and Open

**Direct Addressing of Standard Bipolar** 

512 Microinstruction Addressability

**Eleven Address Control Functions** 

Three Jump and Test Latch

**Eight Flag Control Functions** 

Four Flag Input Functions Four Flag Output Functions

16-way Jump and Test Instruction

9-Bit Microprogram Address Register

TTL and DTL Compatible

**Collector Outputs** 

Advanced Organization

4-Bit Program Latch

Two Flag Registers

PROM or ROM

and Bus

Functions

40 Pin DIP

**Bus Function** 

Time

# 3001 MICROPROGRAM CONTROL UNIT

# PACKAGE CONFIGURATION

| $\begin{array}{c c c c c c c c c c c c c c c c c c c $ |
|--------------------------------------------------------|
|                                                        |



| PIN               | SYMBOL                           | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                                                     | TYPE <sup>(1)</sup>       |
|-------------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| 1-4               | PX <sub>4</sub> -PX <sub>7</sub> | Primary Instruction Bus Inputs<br>Data on the primary instruction bus is tested by the JPX function to<br>determine the next microprogram address.                                                                                                                                                                                                    | active LOW                |
| 5, 6, 8, 10       | SX <sub>0</sub> -SX <sub>3</sub> | Secondary Instruction Bus Inputs<br>Data on the secondary instruction bus is synchronously loaded into the<br>PR-latch while the data on the PX-bus is being tested (JPX). During a<br>subsequent cycle, the contents of the PR-latch may be tested by the<br>JPR, JLL, or JRL functions to determine the next microprogram address.                  |                           |
| 7, 9, 11          | PR <sub>0</sub> -PR <sub>2</sub> | PR-Latch Outputs<br>The PR-latch outputs are asynchronously enabled by the JCE function.<br>They can be used to modify microinstructions at the outputs of the<br>microprogram memory or to provide additional control lines.                                                                                                                         | open collector            |
| 12, 13, 15,<br>16 | FC <sub>0</sub> -FC <sub>3</sub> | Flag Logic Control Inputs<br>The flag logic control inputs are used to cross-switch the flags (C and Z)<br>with the flag logic input (FI) and the flag logic output (FO).                                                                                                                                                                             |                           |
| 14                | FO                               | Flag Logic Output<br>The outputs of the flags (C and Z) are multiplexed internally to form the<br>common flag logic output. The output may also be forced to a logical 0<br>or logical 1.                                                                                                                                                             | active LOW<br>three-state |
| 17                | FI                               | Flag Logic Input<br>The flag logic input is demultiplexed internally and applied to the inputs<br>of the flags (C and Z). Note: the flag input data is saved in the F-latch<br>when the clock input (CLK) is low.                                                                                                                                     | active LOW                |
| 18                | ISE                              | Interrupt Strobe Enable Output<br>The interrupt strobe enable output goes to logical 1 when one of the JZR<br>functions are selected (see Functional Description, page 6). It can be used                                                                                                                                                             |                           |
|                   |                                  | to provide the strobe signal required by the INTEL 3214 Priority Interrupt Control Unit or other interrupt circuits.                                                                                                                                                                                                                                  |                           |
| 19                | CLK                              | Clock Input                                                                                                                                                                                                                                                                                                                                           |                           |
| 20                | GND                              | Ground                                                                                                                                                                                                                                                                                                                                                |                           |
| 21-24<br>37-39    | AC <sub>0</sub> -AC <sub>6</sub> | Next Address Control Function Inputs<br>All jump functions are selected by these control lines.                                                                                                                                                                                                                                                       |                           |
| 25                | EN                               | Enable Input<br>When in the HIGH state, the enable input enables the microprogram<br>address, PR-latch and flag outputs.                                                                                                                                                                                                                              |                           |
| 26-29             | MA <sub>0</sub> -MA <sub>3</sub> | Microprogram Column Address Outputs                                                                                                                                                                                                                                                                                                                   | three-state               |
| 30-34             | MA4-MA8                          | Microprogram Row Address Outputs                                                                                                                                                                                                                                                                                                                      | three-state               |
| 35                | ERA                              | Enable Row Address Input<br>When in the LOW state, the enable row address input independently<br>disables the microprogram row address outputs. It can be used with the<br>INTEL 3214 Priority Interrupt Control Unit or other interrupt circuits<br>to facilitate the implementation of priority interrupt systems.                                  |                           |
| 36                | LD                               | Microprogram Address Load Input<br>When in the active HIGH state, the microprogram address load input<br>inhibits all jump functions and synchronously loads the data on the<br>instruction busses into the microprogram register. However, it does not<br>inhibit the operation of the PR-latch or the generation of the interrupt<br>strobe enable. |                           |
| 40                | vcc                              | +5 Volt Supply                                                                                                                                                                                                                                                                                                                                        |                           |

NOTE:

(1) Active HIGH unless otherwise specified.

### LOGICAL DESCRIPTION

The MCU performs two major control functions. First, it controls the sequence in which microinstructions are fetched from the microprogram memory. For this purpose, the MCU contains a microprogram address register and the associated logic for selecting the next microinstruction address. The second function of the MCU is the control of the two flag flip-flops that are included for interaction with the carry input and carry output logic of the CP array. The logical organization of the MCU is shown in Figure 2.

### NEXT ADDRESS LOGIC

The next address logic of the MCU provides a set of conditional and unconditional address control functions. These address control functions are used to implement a jump or jump/test operation as part of every microinstruction. That is to say, each microinstruction typically contains a jump operation field that specifies the address control function, and hence, the next microprogram address.

In order to minimize the pin count of the MCU, and reduce the complexity of the next address logic, the microprogram address space is organized as a two dimensional array or matrix. Each microprogram address corresponds to a unit of the matrix at a particular row and column location. Thus, the 9bit microprogram address is treated as specifying not one, but two addresses the row address in the upper five bits and the column address in the lower four bits. The address matrix can therefore contain, at most, 32 row addresses and 16 column addresses for a total of 512 microinstructions.

The next address logic of the MCU makes extensive use of this two component addressing scheme. For example, from a particular row or column address, it is possible to jump unconditionally in one operation anywhere in that row or column. It is not possible, however, to jump anywhere in the address matrix. In fact, for a given location in the matrix, there is a fixed subset of microprogram addresses that may be selected as the next address. These possible jump target addresses are referred to as a jump set. Each type of MCU address control (jump) function has a jump set associated with it. Appendix C illustrates the jump set for each function.

### FLAG LOGIC

The flag logic of the MCU provides a set of functions for saving the current value of the carry output of the CP array and for controlling the value of the carry input to the CP array. These two distinct flag control functions are called flag input functions and flag output functions.

The flag logic is comprised of two flip-flops, designated the C-flag and the Z-flag, along with a simple latch, called the F-latch, that indicates the current state of the carry output line of the CP array. The flag logic is used in conjunction with the carry and shift logic of the CP array to implement a variety of shift/rotate and arithmetic functions.



Figure 2. 3001 Block Diagram

# FUNCTIONAL DESCRIPTION

### ADDRESS CONTROL FUNCTIONS

The address control functions of the MCU are selected by the seven input lines designated  $AC_0-AC_6$ . On the rising edge of the clock, the 9-bit micro-program address generated by the next address logic is loaded into the micro-program address register. The next microprogram address is delivered to the microprogram memory via the nine output lines designated  $MA_0-MA_8$ . The microprogram address outputs are organized into row and column addresses as:

MA<sub>8</sub> MA<sub>7</sub> MA<sub>6</sub> MA<sub>5</sub> MA<sub>4</sub> row address MA<sub>3</sub> MA<sub>2</sub> MA<sub>1</sub> MA<sub>0</sub>

column address

Each address control function is specified by a unique encoding of the data on the function input lines. From three to five bits of the data specify the particular function while the remaining bits are used to select part of either the row or column address desired. Function code formats are given in Appendix A, "Address Control Function Summary."

The following is a detailed description of each of the eleven address control functions. The symbols shown below are used throughout the description to specify row and column addresses.

| Symbol           | Meaning                                                                |
|------------------|------------------------------------------------------------------------|
| row <sub>n</sub> | 5-bit next row address<br>where n is the decimal row<br>address.       |
| col <sub>n</sub> | 4-bit next column address<br>where n is the decimal<br>column address. |

### UNCONDITIONAL ADDRESS CON-TROL (JUMP) FUNCTIONS

The jump functions use the current microprogram address (i.e., the contents of the microprogram address register prior to the rising edge of the clock) and several bits from the address control inputs to generate the next microprogram address.

| Mnemonic Eunctio | n Description |
|------------------|---------------|

JCC Jump in current column. AC<sub>0</sub>-AC<sub>4</sub> are used to select 1 of 32 row addresses in the current column, specified by  $MA_0$ - $MA_3$ , as the next address

JZR

JCR

JCE

Jump to zero row.  $AC_0-AC_3$  are used to select 1 of 16 column addresses in row<sub>0</sub>, as the next address.

Jump in current row.  $AC_0-AC_3$  are used to select 1 of 16 addresses in the current row, speci fied by  $MA_4-MA_8$ , as the next address.

Jump in current column/ row group and enable PR-latch outputs. AC<sub>0</sub>-AC<sub>2</sub> are used to select 1 of 8 row addresses in the current row group, specified by MA<sub>7</sub>-MA<sub>8</sub>, as the next row address. The current column is specified by MA<sub>0</sub>-MA<sub>3</sub>. The PR-latch outputs are asynchronously enabled.

### FLAG CONDITIONAL ADDRESS CONTROL (JUMP/TEST) FUNCTIONS

The jump/test flag functions use the current microprogram address, the contents of the selected flag or latch, and several bits from the address control function to generate the next microprogram address.

| Mnemonic | Function Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| JFL      | Jump/test F-Latch.<br>AC <sub>0</sub> -AC <sub>3</sub> are used to<br>select 1 of 16 row ad-<br>dresses in the current<br>row group, specified by<br>MA <sub>8</sub> , as the next row<br>address. If the current<br>column group, specifier<br>by MA <sub>3</sub> , is col <sub>0</sub> -col <sub>7</sub> ,<br>the F-latch is used to<br>select col <sub>2</sub> or col <sub>3</sub> as th<br>next column address.<br>MA <sub>3</sub> specifies column<br>group col <sub>8</sub> -col <sub>15</sub> , the<br>F-latch is used to select<br>col <sub>10</sub> or col <sub>11</sub> as the<br>next column address. |
| JCF      | Jump/test C-flag.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Jump/test C-flag.  $AC_0-AC_2$  are used to select 1 of 8 row addresses in the current row group, specified by  $MA_7$  and  $MA_8$ , as the next row address. If the current column group specified by  $MA_3$  is colo-col7, the C-flag is used to select col2 or col3 as the next column address. If  $MA_3$  specifies column group col8-col15, the C-flag is used to select col10 or col11 as the next column address.

Jump/test Z-flag. Identical to the JCF function described above, except that the Z-flag, rather than the C-flag, is used to select the next column address.

### PX-BUS AND PR-LATCH CONDI-TIONAL ADDRESS CONTROL (JUMP/TEST) FUNCTIONS

JZF

The PX-bus jump/test function uses the data on the primary instruction bus  $(PX_4-PX_7)$ , the current mircoprogram address, and several selection bits from the address control function to generate the next microprogram address. The PR-latch jump/test functions use the data held in the PR-latch, the current microprogram address, and several selection bits from the address control function to generate the next microprogram address.

|                          | Mnemonic | Function Description                                                                                                                                                                                                                                                                                                                            |  |
|--------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| y<br>t<br>ed<br>he<br>If | JPR      | Jump/test PR-latch.<br>AC <sub>0</sub> -AC <sub>2</sub> are used to<br>select 1 of 8 row ad-<br>dresses in the current<br>row group, specified by<br>MA <sub>7</sub> and MA <sub>8</sub> , as the<br>next row address. The<br>four PR-latch bits are<br>used to select 1 of 16<br>possible column ad-<br>dresses as the next<br>column address. |  |
|                          | Mnemonic | Function Description                                                                                                                                                                                                                                                                                                                            |  |
| t                        | JLL      | Jump/test leftmost PR-<br>latch bits. $AC_0-AC_2$ are<br>used to select 1 of 8 row<br>addresses in the current<br>row group, specified by<br>$MA_7$ and $MA_8$ , as the<br>next row address. $PR_2$<br>and $PR_3$ are used to                                                                                                                   |  |

### FUNCTIONAL DESCRIPTION (con't)

select 1 of 4 possible column addresses in col<sub>4</sub> through col<sub>7</sub> as the next column address.

JRL Jump/test rightmost PRlatch bits. AC<sub>0</sub> and AC<sub>1</sub> are used to select 1 of 4 high-order row addresses in the current row group, specified by MA<sub>7</sub> and MA<sub>8</sub>, as the next row address. PR<sub>0</sub> and PR<sub>1</sub> are used to select 1 of 4 possible column addresses in col<sub>12</sub> through col<sub>15</sub> as the next column address.

.IPX

Jump/test PX-bus and load PR-latch.  $AC_0$  and  $AC_1$  are used to select 1 of 4 row addresses in the current row group, specified by  $MA_6$ - $MA_8$ , as the next row address.  $PX_4$ - $PX_7$  are used to select 1 of 16 possible column addresses as the next column address.  $SX_0$ - $SX_3$  data is locked in the PR-latch at the rising edge of the clock.

### FLAG CONTROL FUNCTIONS

The flag control functions of the MCU are selected by the four input lines designated  $FC_0$ - $FC_3$ . Function code formats are given in Appendix B, "Flag Control Function Summary."

The following is a detailed description of each of the eight flag control functions.

### FLAG INPUT CONTROL FUNCTIONS

The flag input control functions select which flag or flags will be set to the current value of the flag input (FI) line. Data on FI is stored in the F-latch when the clock is low. The content of the Flatch is loaded into the C and/or Z flag on the rising edge of the clock.

| Mnemonic | Function Description                                                                              |
|----------|---------------------------------------------------------------------------------------------------|
| SCZ      | Set C-flag and Z-flag to<br>FI. The C-flag and the Z-<br>flag are both set to the<br>value of FI. |
| STZ      | Set Z-flag to FI. The Z-<br>flag is set to the value of<br>FI. The C-flag is<br>unaffected.       |
| STC      | Set C-flag to FI. The C-<br>flag is set to the value of<br>FI. The Z flag is<br>unaffected.       |
| HCZ      | Hold C-flag and Z-flag.<br>The values in the C-flag                                               |

### FLAG OUTPUT CONTROL FUNCTIONS

The flag output control functions select the value to which the flag output (FO) line will be forced.

and Z-flag are unaffected.

| Mnemonic | Function Description                                          |
|----------|---------------------------------------------------------------|
| FF0      | Force FO to 0. FO is forced to the value of logical 0.        |
| FFC      | Force FO to C. FO is<br>forced to the value of<br>the C-flag. |
| FFZ      | Force FO to Z. FO is forced to the value of the Z-flag.       |
| FF1      | Force FO to 1. FO is forced to the value of                   |

### LOAD AND INTERRUPT STROBE FUNCTIONS

The load function of the MCU is controlled by the input line designated LD. If the LD line is active HIGH at the rising edge of the clock, the data on the primary and secondary instruction busses, PX4-PX7 and SX0-SX3, is loaded into the microprogram address register. PX4-PX7 are loaded into MA0-MA3 and SX0-SX3 are loaded into MA4-MA7. The high-order bit of the microprogram address register MA8 is set to a logical 0. The bits from the primary instruction bus select 1 of 16 possible column addresses. Likewise, the bits from the secondary instruction bus select 1 of the first 16 row addresses.

The interrupt strobe enable of the MCU is available on the output line designated ISE. The line is placed in the active high state whenever a JZR to col<sub>15</sub> is selected as the address control function. Customarily, the start of a macroinstruction fetch sequence is situated at  $row_0$  and col<sub>15</sub> so that the INTEL 3214 Priority Interrupt Control Unit may be enabled at the beginning of the fetch/execute cycle. The priority interrupt control unit may respond to the interrupt by pulling the enable row address (ERA) input line down to override the selected next row address from the MCU. Then by gating an alternative next row address on to the row address lines of the microprogram memory, the microprogram may be forced to enter an interrupt handling routine. The alternative row address placed on the microprogram memory address lines does not alter the contents of the microprogram address register. Therefore, subsequent jump functions will utilize the row address in the register, and not the alternative row address, to determine the next microprogram address.

Note, the load function always overrides the address control function on  $AC_0$ - $AC_6$ . It does not, however, override the latch enable or load sub-functions of the JCE or JPX instruction, respectively. In addition, it does not inhibit the interrupt strobe enable or any of the flag control functions.

logical 1.

# D.C. AND OPERATING CHARACTERISTICS

### **ABSOLUTE MAXIMUM RATINGS\***

| Temperature Under Bias         |  |
|--------------------------------|--|
| Storage Temperature            |  |
| All Output and Supply Voltages |  |
| All Input Voltages             |  |
| Output Currents                |  |

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

# $T_A = 0^{\circ}C$ to $70^{\circ}C$ $V_{CC} = 5.0V \pm 5\%$

| SYMBOL               | PARAMETER                                                                                                                                     | MIN | TYP <sup>(1)</sup>        | MAX                     | UNIT           | CONDITIONS                                       |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|---------------------------|-------------------------|----------------|--------------------------------------------------|
| Vc                   | Input Clamp Voltage (All<br>Input Pins)                                                                                                       |     | -0.8                      | -1.0                    | v              | I <sub>C</sub> = -5 mA                           |
| IF                   | Input Load Current:<br>CLK Input<br>EN Input<br>All Other Inputs                                                                              |     | -0.075<br>-0.05<br>-0.025 | -0.75<br>-0.50<br>-0.25 | mA<br>mA<br>mA | V <sub>F</sub> = 0.45V                           |
| IR                   | Input Leakage Current:<br>CLK<br>EN Input<br>All Other Inputs                                                                                 |     |                           | 120<br>80<br>40         | μΑ<br>μΑ<br>μΑ | V <sub>R</sub> = 5.25V                           |
| VIL                  | Input Low Voltage                                                                                                                             |     |                           | 0.8                     | v              | V <sub>CC</sub> = 5.0V                           |
| VIH                  | Input High Voltage                                                                                                                            | 2.0 |                           |                         | v              |                                                  |
| lcc                  | Power Supply Current (2)                                                                                                                      |     | 170                       | 240                     | mA             |                                                  |
| V <sub>OL</sub>      | Output Low Voltage<br>(All Output Pins)                                                                                                       |     | 0.35                      | 0.45                    | v              | I <sub>OL</sub> = 10 mA                          |
| V <sub>OH</sub>      | Output High Voltage<br>(MA <sub>0</sub> -MA <sub>8</sub> , ISE, FO)                                                                           | 2.4 | 3.0                       |                         | v              | I <sub>OH</sub> = -1 mA                          |
| los                  | Output Short Circuit Current<br>(MA <sub>0</sub> -MA <sub>8</sub> , ISE, FO)                                                                  | -15 | -28                       | -60                     | mA             | V <sub>CC</sub> = 5.0V                           |
| I <sub>O (off)</sub> | Off-State Output Current:<br>MA <sub>0</sub> -MA <sub>8</sub> , FO<br>MA <sub>0</sub> -MA <sub>8</sub> , FO, PR <sub>0</sub> -PR <sub>2</sub> |     |                           | -100<br>100             | μΑ<br>μΑ       | V <sub>O</sub> = 0.45V<br>V <sub>O</sub> = 5.25V |

NOTES:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

(2) EN input grounded, all other inputs and outputs open.

# A.C. CHARACTERISTICS AND WAVEFORMS $T_A = 0^{\circ}C$ to 70°C, $V_{CC} = 5.0V \pm 5\%$

| SYMBOL          | PARAMETER                                                                                                                             | MIN | TYP <sup>(1)</sup> | MAX | UNIT | _ |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------|-----|------|---|
| tCY             | Cycle Time <sup>(2)</sup>                                                                                                             | 85  | 60                 |     | ns   |   |
| twp             | Clock Pulse Width                                                                                                                     | 30  | 20                 |     | ns   |   |
|                 | Control and Data Input Set-Up Times:                                                                                                  |     |                    |     |      |   |
| ts⊨             | LD, AC <sub>0</sub> -AC <sub>6</sub>                                                                                                  | 10  | 0                  |     | ns   |   |
| tsĸ             | FC <sub>0</sub> , FC <sub>1</sub>                                                                                                     | 0   |                    |     | ns   |   |
| tsx             | SX <sub>0</sub> -SX <sub>3</sub> , PX <sub>4</sub> -PX <sub>7</sub>                                                                   | 35  | 25                 |     | ns   |   |
| tsi             | FI                                                                                                                                    | 15  | 5                  |     | ns   |   |
|                 | Control and Data Input Hold Times:                                                                                                    |     |                    |     |      |   |
| tur             | LD. ACo-ACe                                                                                                                           | 5   | 0                  |     | ns   |   |
| tur             | FC <sub>0</sub> , FC <sub>1</sub>                                                                                                     | 0   | -                  |     | ns   |   |
| tux             | SX0-SX3, PX4-PX7                                                                                                                      | 20  | 5                  |     | ns   |   |
| tHI             | FI                                                                                                                                    | 20  | 8                  |     | ns   |   |
| t <sub>CO</sub> | Propagation Delay from Clock Input (CLK) to Outputs (MA <sub>0</sub> -MA <sub>8</sub> , FO)                                           | 10  | 30                 | 45  | ns   |   |
| <sup>t</sup> ко | Propagation Delay from Control Inputs $FC_2$ and $FC_3$ to Flag Out (FO)                                                              |     | 16                 | 30  | ns   |   |
| t <sub>FO</sub> | Propagation Delay from Control Inputs $AC_0$ - $AC_6$ to Latch Outputs (PR_0-PR_2)                                                    |     | 26                 | 40  | ns   |   |
| tEO             | Propagation Delay from Enable Inputs EN and ERA to Outputs (MA <sub>0</sub> -MA <sub>8</sub> , FO, PR <sub>0</sub> -PR <sub>2</sub> ) |     | 21                 | 32  | ns   |   |
| t <sub>FI</sub> | Propagation Delay from Control Inputs AC <sub>0</sub> -AC <sub>6</sub> to Interrupt Strobe Enable Output (ISE)                        |     | 24                 | 40  | ns   |   |

#### NOTE:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

(2)  $t_{CY} = t_{WP} + t_{SF} + t_{CO}$ 

### **TEST CONDITIONS:**

Input pulse amplitude of 2.5 volts. Input rise and fall times of 5 ns between 1 volt and 2 volts. Output load of 10 mA and 50 pF. Speed measurements are taken at the 1.5 volt level.



# CAPACITANCE<sup>(2)</sup> $T_A = 25^{\circ}C$

| SYMBOL           |                                                   | PARAMETER | MIN | ТҮР              | MAX      | UNIT     |
|------------------|---------------------------------------------------|-----------|-----|------------------|----------|----------|
| C <sub>IN</sub>  | Input Capacitance:<br>CLK, EN<br>All Other Inputs |           |     | 11 <u>.</u><br>5 | 16<br>10 | pF<br>pF |
| С <sub>ОUT</sub> | Output Capacitance                                |           |     | 6                | 12       | pF       |

NOTE:

(2) This parameter is periodically sampled and is not 100% tested. Condition of measurement is f = 1 MHz,  $V_{BIAS} = 2.5V$ ,  $V_{CC} = 5V$  and  $T_A = 25^{\circ}C$ .

# D.C. AND OPERATING CHARACTERISTICS

### **ABSOLUTE MAXIMUM RATINGS\***

| Temperature Under Bias         |                |
|--------------------------------|----------------|
| Storage Temperature            |                |
| All Output and Supply Voltages |                |
| All Input Voltages             | –1.0V to +5.5V |
| Output Currents                | 100 mA         |

MILITARY TEM

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

| SYMBOL               | PARAMETER                                                                                                                                     | AMETER MIN TYP <sup>(1)</sup> |                   | MAX                  | UNIT           | CONDITIONS                                      |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------|----------------------|----------------|-------------------------------------------------|
| v <sub>c</sub>       | Input Clamp Voltage (All<br>Input Pins)                                                                                                       |                               | -0.8              | -1.2                 | v              | I <sub>C</sub> = -5 mA                          |
| ١ <sub>F</sub>       | Input Load Current:<br>CLK Input<br>EN Input<br>All Other Inputs                                                                              |                               | -75<br>-50<br>-25 | -750<br>-500<br>-250 | μΑ<br>μΑ<br>μΑ | V <sub>F</sub> = 0.45V                          |
| I <sub>R</sub>       | Input Leakage Current:<br>CLK<br>EN Input<br>All Other Inputs                                                                                 |                               |                   | 120<br>80<br>40      | μΑ<br>μΑ<br>μΑ | V <sub>R</sub> = 5.5V                           |
| VIL                  | Input Low Voltage                                                                                                                             |                               |                   | 0.8                  | v              | V <sub>CC</sub> = 5.0V                          |
| VIH                  | Input High Voltage                                                                                                                            | 2.0                           |                   |                      | v              |                                                 |
| lcc                  | Power Supply Current <sup>(2)</sup>                                                                                                           |                               | 170               | 250                  | mA             |                                                 |
| V <sub>OL</sub>      | Output Low Voltage<br>(All Output Pins)                                                                                                       |                               | 0.35              | 0.45                 | v              | I <sub>OL</sub> = 10 mA                         |
| V <sub>OH</sub>      | Output High Voltage<br>(MA <sub>0</sub> -MA <sub>8</sub> , ISE, FO)                                                                           | 2.4                           | 3.0               |                      | v              | I <sub>OH</sub> = -1 mA                         |
| I <sub>OS</sub>      | Output Short Circuit Current<br>(MA <sub>0</sub> -MA <sub>8</sub> , ISE, FO)                                                                  | -15                           | -28               | -60                  | mA             | V <sub>CC</sub> = 5.0V                          |
| I <sub>O (off)</sub> | Off-State Output Current:<br>MA <sub>0</sub> –MA <sub>8</sub> , FO<br>MA <sub>0</sub> –MA <sub>8</sub> , FO, PR <sub>0</sub> –PR <sub>2</sub> |                               |                   | -100<br>100          | μΑ<br>μΑ       | V <sub>O</sub> = 0.45V<br>V <sub>O</sub> = 5.5V |

### $T_A = -55^{\circ}C$ to +125°C, $V_{CC} = 5.0V \pm 10\%$

NOTES:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage. (2) EN input grounded, all other inputs and outputs open.

| A.C. CH         | ARACTERISTICS AND WAVEFORMS $T_A = -55^{\circ}C$ to +1                                        | 25°C, V <sub>CC</sub> | = 5.0V ±10         | A.C. CHARACTERISTICS AND WAVEFORMS $T_A = -55^{\circ}C$ to $+125^{\circ}C$ , $V_{CC} = 5.0V \pm 10\%$ |      |  |  |  |  |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------|-----------------------|--------------------|-------------------------------------------------------------------------------------------------------|------|--|--|--|--|--|--|--|--|
| SYMBOL          | PARAMETER                                                                                     | MIN                   | ТҮР <sup>(1)</sup> | MAX                                                                                                   | UNIT |  |  |  |  |  |  |  |  |
| tCY             | Cycle Time <sup>(2)</sup>                                                                     | 95                    | 60                 |                                                                                                       | ns   |  |  |  |  |  |  |  |  |
| t <sub>WP</sub> | Clock Pulse Width                                                                             | 40                    | 20                 |                                                                                                       | ns   |  |  |  |  |  |  |  |  |
|                 | Control and Data Input Set-Up Times:                                                          |                       |                    |                                                                                                       |      |  |  |  |  |  |  |  |  |
| tsF             | $LD, AC_0 - AC_6$                                                                             | 10                    | 0                  |                                                                                                       | ns   |  |  |  |  |  |  |  |  |
| tsĸ             | FC <sub>0</sub> , FC <sub>1</sub>                                                             | 0                     |                    |                                                                                                       | ns   |  |  |  |  |  |  |  |  |
| tsx             | $SX_0-SX_3$ , $PX_4-PX_7$                                                                     | 35                    | 25                 |                                                                                                       | ns   |  |  |  |  |  |  |  |  |
| tsi             | FI                                                                                            | 15                    | 5                  |                                                                                                       | ns   |  |  |  |  |  |  |  |  |
|                 | Control and Data Input Hold Times:                                                            |                       |                    |                                                                                                       |      |  |  |  |  |  |  |  |  |
| tHF             | LD, AC0-AC6                                                                                   | 5                     | 0                  |                                                                                                       | ns   |  |  |  |  |  |  |  |  |
| <sup>t</sup> нк | FC <sub>0</sub> , FC <sub>1</sub>                                                             | 0                     |                    |                                                                                                       | ns   |  |  |  |  |  |  |  |  |
| tHX             | $SX_0-SX_3$ , $PX_4-PX_7$                                                                     | 25                    | 5                  |                                                                                                       | ns   |  |  |  |  |  |  |  |  |
| tHI             | FI                                                                                            | 22                    | 8                  |                                                                                                       | ns   |  |  |  |  |  |  |  |  |
| t <sub>CO</sub> | Propagation Delay from Clock Input (CLK) to Outputs (MA <sub>0</sub> -MA <sub>8</sub> , FO)   | 10                    | 30                 | 45                                                                                                    | ns   |  |  |  |  |  |  |  |  |
| <sup>t</sup> ко | Propagation Delay from Control Inputs $FC_2$ and $FC_3$ to Flag Out (FO)                      |                       | 16                 | 50                                                                                                    | ns   |  |  |  |  |  |  |  |  |
| <sup>t</sup> FO | Propagation Delay from Control Inputs $AC_0$ - $AC_6$ to Latch Outputs (PR_0-PR_2)            |                       | 26                 | 50                                                                                                    | ns   |  |  |  |  |  |  |  |  |
| <sup>t</sup> EO | Propagation Delay from Enable Inputs EN and ERA to Outputs $(MA_0-MA_8, FO, PR_0-PR_2)$       |                       | 21                 | 35                                                                                                    | ns   |  |  |  |  |  |  |  |  |
| tFI             | Propagation Delay from Control Inputs $AC_0$ - $AC_6$ to Interrupt Strobe Enable Output (ISE) |                       | 24                 | 40                                                                                                    | ns   |  |  |  |  |  |  |  |  |

#### NOTE:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

(2)  $t_{CY} = t_{WP} + t_{SF} + t_{CO}$ 

### **TEST CONDITIONS:**

### Input pulse amplitude of 2.5 volts. Input rise and fall times of 5 ns between 1 volt and 2 volts. Output load of 10 mA and 50 pF. Speed measurements are taken at the 1.5 volt level.



TEST LOAD CIRCUIT:

3001

MII

# $CAPACITANCE^{(2)} T_A = 25^{\circ}C$

| SYMBOL          | PARAMETER                                         | MIN | ТҮР     | MAX      | UNIT     |
|-----------------|---------------------------------------------------|-----|---------|----------|----------|
| C <sub>IN</sub> | Input Capacitance:<br>CLK, EN<br>All Other Inputs |     | 11<br>5 | 16<br>10 | pF<br>pF |
| COUT            | Output Capacitance                                |     | 6       | 12       | pF       |

NOTE:

(2) This parameter is periodically sampled and is not 100% tested. Condition of measurement is f = 1 MHz, V<sub>BIAS</sub> = 2.5V, V<sub>CC</sub> = 5V and T<sub>A</sub> = 25°C.

## 3001 WAVEFORMS



# TYPICAL AC AND DC CHARACTERISTICS

CLOCK PULSE WIDTH VS. VCC AND TEMPERATURE





CLOCK TO mA OUTPUTS VS. LOAD CAPACITANCE



OUTPUT CURRENT VS. OUTPUT LOW VOLTAGE



OUTPUT CURRENT VS. OUTPUT HIGH VOLTAGE



CLOCK TO MA OUTPUTS VS. LOAD CAPACITANCE



.

# 3001

# APPENDIX A ADDRESS CONTROL FUNCTION SUMMARY

|     | DESCRIPTION             | FUNCTION        |   |    |    |                |                |                | NEXT ROW        |    |                |                |                | NEXT COL       |                |    |                |
|-----|-------------------------|-----------------|---|----|----|----------------|----------------|----------------|-----------------|----|----------------|----------------|----------------|----------------|----------------|----|----------------|
|     | DESCRIPTION             | AC <sub>6</sub> | 5 | 4  | 3  | 2              | 1              | 0              | MA <sub>8</sub> | 7  | 6              | 5              | 4              | MA3            | 2              | 1  | 0              |
| JCC | Jump in current column  | 0               | 0 | d4 | d3 | d <sub>2</sub> | d1             | d <sub>0</sub> | d4              | d3 | d <sub>2</sub> | dı             | do             | m <sub>3</sub> | m <sub>2</sub> | m1 | m <sub>0</sub> |
| JZR | Jump to zero row        | 0               | 1 | 0  | d3 | d <sub>2</sub> | d <sub>1</sub> | d <sub>0</sub> | 0               | 0  | 0              | 0              | 0              | d3             | d <sub>2</sub> | d1 | d <sub>0</sub> |
| JCR | Jump in current row     | 0               | 1 | 1  | d3 | d <sub>2</sub> | d1             | d <sub>0</sub> | mg              | m7 | m <sub>6</sub> | m5             | m4             | d3             | d <sub>2</sub> | d1 | d <sub>0</sub> |
| JCE | Jump in column/enable   | 1               | 1 | 1  | 0  | d <sub>2</sub> | d <sub>1</sub> | d <sub>0</sub> | m <sub>8</sub>  | m7 | d <sub>2</sub> | dı             | d <sub>0</sub> | m3             | m <sub>2</sub> | m1 | m <sub>0</sub> |
| JFL | Jump/test F-latch       | 1               | 0 | 0  | d3 | d <sub>2</sub> | d1             | d <sub>0</sub> | m <sub>8</sub>  | d3 | d <sub>2</sub> | dı             | d <sub>0</sub> | m3             | 0              | 1  | f              |
| JCF | Jump/test C-flag        | 1               | 0 | 1  | 0  | d <sub>2</sub> | d1             | d <sub>0</sub> | m <sub>8</sub>  | m7 | d <sub>2</sub> | d1             | d <sub>0</sub> | m <sub>3</sub> | 0              | 1  | с              |
| JZF | Jump/test Z-flag        | 1               | 0 | 1  | 1  | d <sub>2</sub> | d1             | d <sub>0</sub> | m <sub>8</sub>  | m7 | d <sub>2</sub> | d1             | d <sub>0</sub> | m <sub>3</sub> | 0              | 1  | z              |
| JPR | Jump/test PR-latches    | 1               | 1 | 0  | 0  | d <sub>2</sub> | d1             | d <sub>0</sub> | m8              | m7 | d <sub>2</sub> | dı             | d <sub>0</sub> | P3             | p <sub>2</sub> | P1 | p <sub>0</sub> |
| JLL | Jump/test left PR bits  | 1               | 1 | 0  | 1  | d <sub>2</sub> | d <sub>1</sub> | d <sub>0</sub> | m <sub>8</sub>  | m7 | d <sub>2</sub> | d1             | d <sub>0</sub> | 0              | 1              | p3 | p2             |
| JRL | Jump/test right PR bits | 1               | 1 | 1  | 1  | 1              | d <sub>1</sub> | d <sub>0</sub> | m <sub>8</sub>  | m7 | 1              | d1             | d <sub>0</sub> | 1              | 1              | P1 | P <sub>0</sub> |
| JPX | Jump/test PX-bus        | 1               | 1 | 1  | 1  | 0              | d <sub>1</sub> | d <sub>0</sub> | m <sub>8</sub>  | m7 | m <sub>6</sub> | d <sub>1</sub> | d <sub>0</sub> | ×7             | ×6             | ×5 | ×4             |

| SYMBOL         | MEANING                                              |
|----------------|------------------------------------------------------|
| d <sub>n</sub> | Data on address control line n                       |
| m <sub>n</sub> | Data in microprogram address register bit n          |
| p <sub>n</sub> | Data in PR-latch bit n                               |
| ×n             | Data on PX-bus line n (active LOW)                   |
| f, c, z        | Contents of F-latch, C-flag, or Z-flag, respectively |

# APPENDIX B FLAG CONTROL FUNCTION SUMMARY

| ТҮРЕ             | MNEN            | IONIC  | ;      |                    | DESC               | RIPTION         |        |      |    | FC1 | 0 |                                       |
|------------------|-----------------|--------|--------|--------------------|--------------------|-----------------|--------|------|----|-----|---|---------------------------------------|
|                  | SC              | z      |        |                    | Set C-             | flag and Z      | Z-flag | to f |    | 0   | 0 | · ·                                   |
| Flag STZ         |                 |        |        |                    | Set Z-             | flag to f       |        |      |    | 0   | 1 |                                       |
| Input            | ST              | C      |        |                    | Set C-             | flag to f       |        |      |    | 1   | 0 |                                       |
|                  | нс              | Z      |        |                    | Hold (             | C-flag and      | Z-fla  | g    |    | 1   | 1 | · · · · · · · · · · · · · · · · · · · |
| ТҮРЕ             | MNEN            | IONIC  | ;      |                    | DESC               | RIPTION         |        |      |    | FC3 | 2 |                                       |
|                  | FF              | 0      |        |                    | Force              | FO to 0         |        |      |    | 0   | 0 |                                       |
| Flag FFC         |                 |        |        | Force FO to C-flag |                    |                 |        |      | 0  | 1   |   |                                       |
| Output           | FF:             | z      |        |                    | Force FO to Z-flag |                 |        |      |    | 1   | 0 |                                       |
|                  | FF              | FF1    |        |                    |                    | Force FO to 1   |        |      |    |     | 1 |                                       |
| LOAD<br>FUNCTION |                 | NEX    | T RO   | w                  |                    | N               | IEXT   | COL  |    |     |   |                                       |
| LD               | MA <sub>8</sub> | 7      | 6      | 5                  | 4                  | MA <sub>3</sub> | 2      | 1    | 0  |     |   |                                       |
| 0                | see Ap          | pendi  | хA     |                    |                    | see Ap          | pendix | хA   |    |     |   |                                       |
| 1                | 0               | ×3     | ×2     | ×1                 | ×0                 | ×7              | ×6     | ×5   | ×4 |     |   |                                       |
| SYMBOL           | MEAN            | IING   |        |                    |                    |                 |        |      |    |     |   |                                       |
| f                | Conter          | nts of | the F- | latch              |                    |                 |        |      |    |     |   |                                       |
| ×n               | Data o          | n PX-  | or SX  | -bus li            | ine n (            | active LO       | W)     |      |    |     |   |                                       |

#### APPENDIX C JUMP SET DIAGRAMS

The following ten diagrams illustrate the jump set for each of the eleven jump and jump/test functions of the MCU. Location 341, indicated by the black square, represents one current row (row<sub>21</sub>) and current column (col<sub>5</sub>) address. The grey boxes indicate the microprogram locations that may be selected by the particular function as the next address.



col 15

col<sub>12</sub>



JPR

ro

current row group Mg 7 10

row31

cólo

Jump/Test PR-Latch

col<sub>15</sub>

current row group M<sub>87</sub> 10



col7

col4

# **TYPICAL CONFIGURATIONS**



Non-Pipelined Configuration with 512 Microinstruction Addressability



Pipelined Configuration with 2048 Microinstruction Addressability

# intط

# **SCHOTTKY BIPOLAR LSI** MICROCOMPUTER SET

# 3002 **CENTRAL** PROCESSING ELEMENT

The INTEL<sup>®</sup> 3002 Central Processing Element contains all of the circuits that represent a 2-bit wide slice through the data processing section of a digital computer. To construct a complete central processor for a given word width N, it is simply necessary to connect an array of N/2 CPE's together. When wired together in such an array, a set of CPE's provide the following capabilities:

2's complement arithmetic Logical AND, OR, NOT and exclusive-OR Incrementing and decrementing Shifting left or right Bit testing and zero detection Carry look-ahead generation Multiple data and address busses High Performance - 100 ns Cycle Time

# PACKAGE CONFIGURATION

| TTL and DTL Compatible                               |                     |        |                     |
|------------------------------------------------------|---------------------|--------|---------------------|
| N-Bit Word Expandable Multi-Bus<br>Organization      |                     |        | v                   |
| 3 Input Data Busses                                  | 10 - 0 I •          |        | 28 VCC              |
| 2 Three-State Fully Buffered Output                  | 11-02               |        | 27 F2               |
| Data Busses                                          | К <sub>0</sub> — 3  |        | 26 - F1             |
| 11 General Purpose Registers                         | K1 -∞ 4             |        | 25 - F <sub>0</sub> |
| _                                                    | x 5                 |        | 24 - F3             |
| Full Function Accumulator                            | Y                   |        | 23 - ED             |
| Independent Memory Address Register                  | CO• 7               | INTEL® | 22 - Mo             |
| Cascade Outputs for Full Carry                       | RO 8                | 3002   | 21 ⊶ M1             |
| Look-Ahead                                           | LI 9                |        | 20 ⊶ D1             |
|                                                      | CI 10               |        | 19 - D <sub>0</sub> |
| Versatile Functional Capability                      | EA 11               |        | 18-CLK              |
| 8 Function Groups                                    | A1-012              |        | 17 - F4             |
| Over 40 Useful Functions<br>Zero Detect and Bit Test | A <sub>0</sub> → 13 |        | 16 F <sub>5</sub>   |
|                                                      | GND - 14            |        | 15 - F6             |
| Single Clock                                         |                     |        |                     |

28 Pin DIP



# **PIN DESCRIPTION**

| PIN              | SYMBOL                                                                                                                                     | NAME AND FUNCTION                                                                                                                                                                                               | TYPE <sup>(1)</sup>       |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| 1, 2             | I <sub>0</sub> -I <sub>1</sub> External Bus Inputs<br>The external bus inputs provide a separate input port for external input<br>devices. |                                                                                                                                                                                                                 | Active LOW                |
| 3, 4             | К <sub>0</sub> -К <sub>1</sub>                                                                                                             | Mask Bus Inputs<br>The mask bus inputs provide a separate input port for the microprogram<br>memory, to allow mask or constant entry.                                                                           | Active LOW                |
| 5, 6             | Х, Ү                                                                                                                                       | Standard Carry Look-Ahead Cascade Outputs<br>The cascade outputs allow high speed arithmetic operations to be<br>performed when they are used in conjunction with the INTEL 3003<br>Look-Ahead Carry Generator. |                           |
| 7                | со                                                                                                                                         | Ripple Carry Output<br>The ripple carry output is only disabled during shift right operations.                                                                                                                  | Active LOW<br>Three-state |
| 8                | RO                                                                                                                                         | Shift Right Output<br>The shift right output is only enabled during shift right operations.                                                                                                                     | Active LOW<br>Three-state |
| 9                | LI                                                                                                                                         | Shift Right Input                                                                                                                                                                                               | Active LOW                |
| 10               | CI                                                                                                                                         | Carry Input                                                                                                                                                                                                     | Active LOW                |
| 11               | EA                                                                                                                                         | Memory Address Enable Input<br>When in the LOW state, the memory address enable input enables the<br>memory address outputs (A <sub>0</sub> -A <sub>1</sub> ).                                                  | Active LOW                |
| 12-13            | A <sub>0</sub> -A <sub>1</sub>                                                                                                             | Memory Address Bus Outputs<br>The memory address bus outputs are the buffered outputs of the<br>memory address register (MAR).                                                                                  | Active LOW<br>Three-state |
| 14               | GND                                                                                                                                        | Ground                                                                                                                                                                                                          |                           |
| 15-17,<br>24-27, | F <sub>0</sub> -F <sub>6</sub>                                                                                                             | Micro-Function Bus Inputs<br>The micro-function bus inputs control ALU function and register<br>selection.                                                                                                      |                           |
| 18               | CLK                                                                                                                                        | Clock Input                                                                                                                                                                                                     |                           |
| 19-20            | D <sub>0</sub> -D <sub>1</sub>                                                                                                             | Memory Data Bus Outputs<br>The memory data bus outputs are the buffered outputs of the full<br>function accumulator register (AC).                                                                              | Active LOW<br>Three-state |
| 21-22            | M <sub>0</sub> -M <sub>1</sub>                                                                                                             | Memory Data Bus Inputs<br>The memory data bus inputs provide a separate input port for<br>memory data.                                                                                                          | Active LOW                |
| 23               | ED                                                                                                                                         | Memory Data Enable Input<br>When in the LOW state, the memory data enable input enables the<br>memory data outputs (D <sub>0</sub> -D <sub>1</sub> )                                                            | Active LOW                |
| 28               | V <sub>CC</sub>                                                                                                                            | +5 Volt Supply                                                                                                                                                                                                  |                           |

NOTE:

1. Active HIGH, unless otherwise specified.

# LOGICAL DESCRIPTION

The CPE provides the arithmetic, logic and register functions of a 2-bit wide slice through a microprogrammed central processor. Data from external sources such as main memory, is brought into the CPE on one of the three separate input busses. Data being sent out of the CPE to external devices is carried on either of the two output busses. Within the CPE, data is stored in one of eleven scratchpad registers or in the accumulator. Data from the input busses, the registers, or the accumulator is available to the arithmetic/logic section (ALS) under the control of two internal multiplexers. Additional inputs and outputs are included for carry propagation, shifting, and micro-function selection. The complete logical organization of the CPE is shown below.

# MICRO-FUNCTION BUS AND DECODER

The seven micro-function bus input lines of the CPE, designated  $F_0-F_6,$  are decoded internally to select the ALS function, generate the scratchpad address, and control the A and B multiplexers.

### M-BUS AND I-BUS INPUTS

The M-bus inputs are arranged to bring data from an external main memory into the CPE. Data on the M-bus is multiplexed internally for input to the ALS.

The I-bus inputs are arranged to bring data from an external I/O system into the CPE. Data on the I-bus is also multiplexed internally, although independently of the M-bus, for input to the ALS Separation of the two busses permits a relatively lightly loaded memory bus even though a large number of I/O devices are connected to the I-bus. Alternatively, the I-bus may be wired to perform a multiple bit shift (e.g., a byte exchange) by connecting it to one of the output busses. In this case, I/O device data is gated externally onto the M-bus.

### SCRATCHPAD

The scratchpad contains eleven registers designated  $R_0$  through  $R_9$  and T. The output of the scratchpad is multiplexed internally for input to ALS. The ALS output is returned for input into the scratchpad.

### ACCUMULATOR AND D-BUS

An independent register called the accumulator (AC) is available for storing the result of an ALS operation. The output of the accumulator is multiplexed internally for input back to the

ALS and is also available viá a threestate output buffer on the D-bus outputs. Conventional usage of the D-bus is for data being sent to the external main memory or to external 1/O devices.

### A AND B MULTIPLEXERS

The A and B multiplexers select the two inputs to the ALS specified on the micro-function bus. Inputs to the Amultiplexer include the M-bus, the scratchpad, and the accumulator. The B-multiplexer selects either the I-bus, the accumulator, or the K-bus. The selected B-multiplexer input is always logically ANDed with the data on the K-bus (see below) to provide a flexible masking and bit testing capability.

### ALS AND K-BUS

The ALS is capable of a variety of arithmetic and logic operations, including 2's complement addition, incrementing, and decrementing, plus logical AND, inclusive-OR, exclusive-NOR, and logical complement. The result of an ALS operation may be stored in the accumulator or one of the scratchpad registers. Separate left input and right output lines, designated LI and RO, are available for use in right shift operations. Carry input and carry output lines, designated CI are provided for normal ripple carry propagation. CO and RO data are brought out via two alternately enabled tri-state buffers. In addition, standard look ahead carry outputs, designated X and Y, are available for full carry look ahead across any word length.

The ability of the K-bus to mask inputs to the ALS greatly increases the versatility of the CPE. During non-arithmetic operations in which carry propagation has no meaning, the carry circuits are used to perform a word-wise inclusive-OR of the bits, masked by the K-bus, from the register or bus selected by the function decoder. Thus, the CPE provides a flexible bit testing capability. The K-bus is also used during arithmetic operations to mask portions of the field being operated upon. An additional function of the K-bus is that of supplying constants to the CPE from the microprogram.

### MEMORY ADDRESS REGISTER AND A-BUS

A separate ALS output is also available to the memory address register (MAR) and to the A-bus via a threestate output buffer. Conventional usage of the MAR and A-bus is for sending addresses to an external main memory. The MAR and A-bus may also be used to select an external device when executing I/O operations.



Figure 2. 3002 Block Diagram

# FUNCTIONAL DESCRIPTION

During each micro-cycle, a microfunction is applied to F-bus inputs of the CPE. The micro-function is decoded, the operands are selected by the multiplexers, and the specified operation is performed by ALS. If a negative going clock edge is applied, the result of the ALS operation is either deposited in the accumulator or written into the selected scratchpad register. In addition, certain operations permit related address data to be deposited in the MAR. A new micro-function should only be applied following the rising edge of the clock.

By externally gating the clock input to CPE, referred to as conditional clocking, the clock pulse may be selectively omitted during a micro-cycle. Since the carry, shift, and look-ahead circuits are not clocked, their outputs may be used to perform a variety of non-destructive tests on data in the accumulator or in the scratchpad. No register contents are modified by the operation due to the absence of the clock pulse.

The micro-function to be performed is determined from the function group (F-Group) and register group (R-Group) selected by the data on the F-bus. The F-Group is specified by the upper three bits of data, F<sub>4</sub>-F<sub>6</sub>. The R-Group is specified by the lower four bits of data, F0-F3. R-Group I contains R0 through Ro, T, and AC and is denoted by the symbol Rn. R-Group II and R-Group III contain only T and AC. F-Group and R-Group formats are summarized in Appendix A.

The following is a detailed explanation of each of the CPE micro-functions. A general functional description of each operation is given followed by two additional descriptions which explain the result of the micro-function with both K-bus inputs at logical 0 or both at logical 1. In most cases, the effect of placing the K-bus in the all-one or the all-zero state is to either select or deselect the accumulator in the operation, respectively. A micro-function mnemonic is included with each description for reference purposes and to assist in the design of micro-assembly languages. The micro-functions are summarized in Appendix A. The effective micro-functions for the all-zero and the all-one K-bus states are summarized in Appendix B.

F-GROUP O **R-GROUP I** 

Logically AND the contents of AC with the data on the K-bus. Add the result to the contents of Rn and the value of the carry input (CI). Deposit the sum in AC and Rn.

K-BUS = 00

Conditionally increment Rn and load the result in AC. Used to load AC from R<sub>n</sub> or to increment R<sub>n</sub> and load a copy of the result in AC.

ALR K-BUS= 11 Add AC and CI to Rn and load the result in AC. Used to add AC to a register. If R<sub>n</sub> is AC, then AC is shifted left one bit position.

F-GROUP O **R-GROUP II** Logically AND the contents of AC with the data on the K-bus. Add the result to CI and the data on the M-bus. Deposit the sum in AC or T, as specified. ACM K-BUS = 00 Add CI to the data on the M-bus. Load the result in AC or T, as specified. Used to load memory data in the specified register, or to load incremented memory data in the specified register. AMA K-BUS = 11 Add the data on the M-bus to AC and CI, and load the result in AC or T, as specified. Used to add memory data or incremented memory data to AC

and store the sum in the specified register.

ILR

F-GROUP O **R-GROUP III** (General description omitted, see Appendix A.)

SRA K-BUS = 00 Shift the contents of AC or T, as specified, right one bit position. Place the previous low order bit value on RO and fill the high order bit from the data on LI. Used to shift or rotate AC or T right one bit.

(K-bus = 11 description omitted, see Appendix B.)

#### F-GROUP 1 **R-GROUP I**

Logically OR the contents of Rn with the data on the K-bus. Deposit the result in MAR. Add the data on the K-bus to contents of Rn and CI. Deposit the result in Rn.

LMI K-BUS = 00 Load MAR from Rn. Conditionally increment Rn. Used to maintain a macro-instruction program counter. DSM

K-BUS = 11

Set MAR to all one's. Conditionally decrement Rn by one. Used to force MAR to its highest address and to decrement Rn.

F-GROUP 1 **R-GROUP II** 

Logically OR the data on the M-bus with the data on the K-bus. Deposit the result in MAR. Add the data on the K-bus to the data on the M-bus and CI. Deposit the sum in AC or T, as specified.

K-BUS = 00 LMM Load MAR from the M-bus. Add CI to the data on the M-bus. Deposit the result in AC or T. Used to load the address register with memory data for macro-instructions using indirect

addressing. K-BUS = 11 I DM Set MAR to all ones. Subtract one from the data on the M-bus. Add CI to the difference and deposit the result in AC or T, as specified. Used to load decremented memory data in AC or T.

F-GROUP 1 **R-GROUP III** 

Logically OR the data on the K-bus with the complement of the contents of AC or T, as specified. Add the result to the logical AND of the contents of specified register with the data on the K-bus. Add the sum to CI. Deposit the result in the specified register.

K-BUS = 00

K-BUS = 11

Add CI to the complement of the contents of AC or T, as specified. Deposit the result in the specified register. Used to form the 1's or 2's complement of AC or T.

### DCA

CIA

Subtract one from the contents of AC or T, as specified. Add CI to the difference and deposit the sum in the specified register. Used to decrement AC or T.

### FUNCTIONAL DESCRIPTION (con't)

### F-GROUP 2 R-GROUP I

Logically AND the data on the K-bus with the contents of AC. Subtract one from the result and add the difference to Cl. Deposit the sum in  $R_n$ .

CSR K-BUS = 00 Subtract one from CI and deposit the

difference in  $R_n$ . Used to conditionally clear or set  $R_n$  to all 0's or 1's, respectively.

SDR K-BUS = 11 Subtract one from AC and add the difference to CI. Deposit the sum in B. Used to store AC in B. or to store

 $R_n$ . Used to store AC in  $R_n$  or to store the decremented value of AC in  $R_n$ .

F-GROUP 2 R-GROUP II Logically AND the data on the K-bus with the contents of AC. Subtract one from the result and add the difference to CI. Deposit the sum in AC or T, as specified.

CSA K-BUS = 00

Subtract one from CI and deposit the difference in AC or T, as specified. Used to conditionally clear or set AC or T.

SDA K-BUS = 11 Subtract one from AC and add the difference to CI. Deposit the sum in AC or T, as specified. Used to store AC in T, or decrement AC, or store the decremented value of AC in T.

F-GROUP 2 R-GROUP III

Logically AND the data of the K-bus with the data on the I-bus. Subtract one from the result and add the difference to CI. Deposit the sum in AC or T, as specified.

(K-bus = 00 description omitted, see CSA above.)

LDI

K-BUS = 11

Subtract one from the data on the I-bus and add the difference to CI. Deposit the sum in AC or T, as specified. Used to load input bus data or decremented input bus data in the specified register.

### F-GROUP 3

ADR

Logically AND the contents of AC with the data on the K-bus. Add the contents of  $R_n$  and CI to the result. Deposit the sum in  $R_n$ .

**R-GROUP I** 

INR K-BUS = 00 Add CI to the contents of  $R_n$  and deposit the sum in  $R_n$ . Used to increment  $R_n$ .

K-BUS = 11

Add the contents of AC to  $R_n$ . Add the result to CI and deposit the sum in  $R_n$ . Used to add the accumulator to a register or to add the incremented value of the accumulator to a register.

| F-GROUP 3            | R-GROUP II             |
|----------------------|------------------------|
| (All descriptions on | nitted, identical to   |
| F-Group O/R-Group    | p II described above.) |

### F-GROUP 3 R-GROUP III Logically AND the data on the K-bus with the data on the I-bus. Add CI and the contents of AC or T, as specified, to the result. Deposit the sum in the specified register.

INA K-BUS = 00 Conditionally increment the contents of AC or T, as specified. Used to increment AC or T.

AIA K-BUS = 11 Add the data on the I-bus to the contents of AC or T, as specified. Add CI to the result and deposit the sum in the specified register. Used to add input data or incremented input data to the specified register.

 $\label{eq:F-GROUP4} R-GROUP I \\ \mbox{Logically AND the data on the K-bus} \\ \mbox{with the contents of AC. Logically} \\ \mbox{AND the result with the contents of} \\ \mbox{R}_n. \mbox{Deposit the final result in R}_n. \\ \mbox{Logically OR the value of CI with the} \\ \mbox{word-wise OR of the bits of the final} \\ \mbox{result. Place the value of the carry OR} \\ \mbox{on the carry output (CO) line.} \\ \end{tabular}$ 

 $\label{eq:clr} \begin{array}{ll} \mbox{CLR} & \mbox{K-BUS} = 00 \\ \mbox{Clear } R_n \mbox{ to all 0's. Force CO to Cl.} \\ \mbox{Used to clear a register and force CO} \\ \mbox{to Cl.} \end{array}$ 

### F-GROUP 4 R-GROUP II

Logically AND the data on the K-bus with the contents of AC. Logically AND the result with the data on the M-bus. Deposit the final result in AC or T, as specified. Logically OR the value of CI with the word-wise OR of the bits of the final result. Place the value of the carry OR on CO.

CLA K-BUS = 00 Clear AC or T, as specified, to all 0's. Force CO to CI. Used to clear the specified register and force CO to CI.

ANM K-BUS = 11 Logically AND the data on the M-bus with the contents of AC. Deposit the result in AC or T, as specified. Force CO to one if the result is non-zero. Used to AND M-bus data to the accumulator and test for a zero result.

**R-GROUP III** 

### F-GROUP 4

Logically AND the data on I-bus with the data on the K-bus. Logically AND the result with the contents of AC or T, as specified. Deposit the final result in the specified register. Logically OR CI with the word-wise OR of the bits of the final result. Place the value of the carry OR on CO.

(K-bus = 00 description omitted, see CLA above.)

ANI K-BUS = 11 Logically AND the data on the I-bus with the contents of AC or T, as specified. Deposit the result in the specified register. Force CO to one if the result is non-zero. Used to AND the I-bus to the accumulator and test for a zero result.

### F-GROUP 5 R-GROUP I

TZR

Logically AND the data on the K-bus with the contents of  $R_n$ . Deposit the result in  $R_n$ . Logically OR CI with the word-wise OR of the result. Place the value of the carry OR on CO.

(K-bus = 00 description omitted, see CLR above.)

K-BUS = 11

Force CO to one if  $R_n$  is non-zero. Used to test a register for zero. Also used to AND K-bus data with a register (see general description) for masking and, optionally, testing for a zero result.

### FUNCTIONAL DESCRIPTION (con't)

**R-GROUP II** 

### F-GROUP 5

Logically AND the data on the K-bus with the data on the M-bus. Deposit the result in AC or T, as specified. Logically OR CI with the word-wise OR of the result. Place the value of the carry OR on CO.

(K-bus = 00 description omitted, see CLA above.)

LTM K-BUS = 11

Load AC or T, as specified, with data from the M-bus. Force CO to one if the result is non-zero. Used to load the specified register from memory and test for a zero result. Also used to AND K-bus data with M-bus data (see general description) for masking and, optionally, testing for a zero result.

### F-GROUP 5

R-GROUP III

Logically AND the data on K-bus with contents of AC or T, as specified. Deposit the result in the specified register. Logically OR CI with the word-wise OR of the result. Place the value of the carry OR on CO.

(K-bus = 00 description omitted, see CLA above.)

TZA

K-BUS = 11

Force CO to one if AC or T, as specified, is non-zero. Used to test the specified register for zero. Also used to AND K-bus data to the specified register (see general description) for masking and, optionally, testing for a zero result.

**F-GROUP 6** R-GROUP I Logically OR CI with the word-wise OR of the logical AND of AC and the data on the K-bus. Place the result of the carry OR on CO. Logically OR the contents of  $R_n$  with the logical AND of AC and the data on the K-bus. Deposit the result in  $R_n$ .

### NOP K-BUS = 00 Force CO to CI. Used as a null operation or to force CO to CI.

ORR K-BUS = 11

Force CO to one if AC is non-zero. Logically OR the contents of the accumulator to the contents of  $R_n$ . Deposit the result in  $R_n$ . Used to OR the accumulator to a register and, optionally, test the previous accumulator value for zero. F-GROUP 6

Logically OR CI with the word-wise OR of the logical AND of AC and the data on the K-bus. Place the value of the carry OR on CO. Logically OR the data on the M-bus, with the logical AND of AC and the data on the K-bus. Deposit the final result in AC or T, as specified.

LMF K-BUS = 00 Load AC or T, as specified, from the M-bus. Force CO to CI. Used to load the specified register with memory data and force CO to CI.

ORM K-BUS = 11 Force CO to one if AC is non-zero. Logically OR the data on the M-bus with the contents of AC. Deposit the result in AC or T, as specified. Used to OR memory data with the accumulator and, optionally, test the previous value of the accumulator for zero.

F-GROUP 6 R-GROUP III Logically OR CI with the word-wise OR of the logical AND of the data on the I-bus and the data on the K-bus. Place the value of the carry OR on CO. Logically AND the data on the K-bus with the data on the I-bus. Logically OR the result with the contents of AC or T, as specified. Deposit the final result in the specified register.

(K-bus = 00 description omitted, see NOP above.)

ORI

K-BUS = 11

Force CO to one if the data on the I-bus is non-zero. Logically OR the data on the I-bus to the contents of AC or T, as specified. Deposit the result in the specified register. Used to OR I-bus data with the specified register and, optionally, test the I-bus data for zero.

F-GROUP 7 R-GROUP I

Logically OR CI with the word-wise OR of the logical AND of the contents of  $R_n$  and AC and the data on the K-bus. Place the value of the carry OR on CO. Logically AND the data on the K-bus with the contents of AC. Exclusive-NOR the result with the contents of  $R_n$ . Deposit the final result in  $R_n$ . CMR K-BUS = 00

Complement the contents of  $R_n$ . Force CO to CI.

XNR

K-BUS = 11

Force CO to one if the logical AND of AC and  $R_n$  is non-zero. Exclusive-NOR the contents of AC with the contents of  $R_n$ . Deposit the result in  $R_n$ . Used to exclusive-NOR the accumulator with a register.

### F-GROUP 7

**R-GROUP II** 

Logically OR CI with the word-wise OR of the logical AND of the contents of AC and the data on the K-bus and M-bus. Place the value of the carry OR on CO. Logically AND the data on the K-bus with the contents of AC. Exclusive-NOR the result with the data on the M-bus. Deposit the final result in AC or T, as specified.

$$\label{eq:LCM} \begin{split} \text{LCM} & \text{K}-\text{BUS}=00\\ \text{Load the complement of the data on}\\ \text{the M-bus into AC or T, as specified.}\\ \text{Force CO to CI.} \end{split}$$

XNM

K-BUS = 11

Force CO to one if the logical AND of AC and the M-bus data is non-zero. Exclusive-NOR the contents of AC with the data on the M-bus. Deposit the result in AC or T, as specified. Used to exclusive-NOR memory data with the accumulator.

F-GROUP 7

XNI

R-GROUP III

Logically OR CI with the word-wise OR of the logical AND of the contents of the specified register and the data on the l-bus and K-bus. Place the value of the carry OR on CO. Logically AND the data on the K-bus with the data on the l-bus. Exclusive-NOR the result with the contents of AC or T, as specified. Deposit the final result in the specified register.

CMA K-BUS = 00 Complement AC or T, as specified. Force CO to CI.

K-BUS = 11

Force CO to one if the logical AND of the contents of AC or T, as specified, and the I-bus data is non-zero. Exclusive-NOR the contents of the specified register with the data on the I-bus. Deposit the result in AC or T, as specified. Used to exclusive-NOR input data with the accumulator.

R-GROUP II ie word-wise

# D.C. AND OPERATING CHARACTERISTICS

### **ABSOLUTE MAXIMUM RATINGS\***

| Temperature Under Bias         |  |
|--------------------------------|--|
| Storage Temperature            |  |
| All Output and Supply Voltages |  |
| All Input Voltages             |  |
| Output Currents                |  |

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum ratings for extended periods may effect device reliability.

# $T_A = 0^{\circ}C$ to +70°C, $V_{CC} = 5.0V \pm 5\%$

|                      |                                                                                                                                                                                          |     | LIMITS                 |                       |                |                                                  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------------|-----------------------|----------------|--------------------------------------------------|
| SYMBOL               | PARAMETER                                                                                                                                                                                | MIN | TYP <sup>(1)</sup>     | MAX                   | UNIT           | CONDITIONS                                       |
| V <sub>C</sub>       | Input Clamp Voltage (All<br>Input Pins)                                                                                                                                                  |     | -0.8                   | -1.0                  | V              | I <sub>C</sub> = -5 mA                           |
| IF                   | Input Load Current:<br>F <sub>0</sub> -F <sub>6</sub> , CLK, K <sub>0</sub> , K <sub>1</sub> , EA, ED<br>I <sub>0</sub> , I <sub>1</sub> , M <sub>0</sub> , M <sub>1</sub> , LI<br>CI    |     | -0.05<br>-0.85<br>-2.3 | -0.25<br>-1.5<br>-4.0 | mA<br>mA<br>mA | V <sub>F</sub> = 0.45V                           |
| IR                   | Input Leakage Current:<br>F <sub>0</sub> -F <sub>6</sub> , CLK, K <sub>0</sub> , K <sub>1</sub> , EA, ED<br>I <sub>0</sub> , I <sub>1</sub> , M <sub>0</sub> , M <sub>1</sub> , LI<br>CI |     |                        | 40<br>60<br>180       | μΑ<br>μΑ<br>μΑ | V <sub>R</sub> = 5.25V                           |
| VIL                  | Input Low Voltage                                                                                                                                                                        |     |                        | 0.8                   | v              | $V_{CC} = 5.0V$                                  |
| VIH                  | Input High Voltage                                                                                                                                                                       | 2.0 |                        |                       | v              |                                                  |
| lcc                  | Power Supply Current <sup>(2)</sup>                                                                                                                                                      |     | 145                    | 190                   | mA             |                                                  |
| V <sub>OL</sub>      | Output Low Voltage (All<br>Output Pins)                                                                                                                                                  |     | 0.3                    | 0.45                  | v              | I <sub>OL</sub> = 10 mA                          |
| V <sub>OH</sub>      | Output High Voltage (All<br>Output Pins)                                                                                                                                                 | 2.4 | 3.0                    |                       | v              | I <sub>OH</sub> = −1 mA                          |
| I <sub>OS</sub>      | Short Circuit Output Current<br>(All Output Pins)                                                                                                                                        | -15 | -25                    | -60                   | mA             | V <sub>CC</sub> = 5.0V                           |
| I <sub>O (off)</sub> | Off State Output Current $A_0$ , $A_1$ , $D_0$ , $D_1$ , CO and RO                                                                                                                       |     |                        | -100<br>100           | μΑ<br>μΑ       | V <sub>O</sub> = 0.45V<br>V <sub>O</sub> = 5.25V |

NOTES:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage

(2) CLK input grounded, other inputs open.

### A.C. CHARACTERISTICS AND WAVEFORMS

 $T_A = 0^{\circ}C$  to  $70^{\circ}C$ ,  $V_{CC} = 5V \pm 5\%$ 

| SYMBOL          | PARAMETER                                                                                           | MIN | TYP <sup>(1)</sup> | MAX | UNIT |
|-----------------|-----------------------------------------------------------------------------------------------------|-----|--------------------|-----|------|
| tCY             | Clock Cycle Time <sup>(2)</sup>                                                                     | 100 | 70                 |     | ns   |
| twp             | Clock Pulse Width                                                                                   | 33  | 20                 |     | ns   |
| t <sub>FS</sub> | Function Input Set-Up Time ( $F_0$ through $F_6$ )                                                  | 60  | 40                 |     | ns   |
|                 | Data Set-Up Time:                                                                                   |     |                    |     |      |
| t <sub>DS</sub> | 1 <sub>0</sub> , 1 <sub>1</sub> , M <sub>0</sub> , M <sub>1</sub> , K <sub>0</sub> , K <sub>1</sub> | 50  | 30                 |     | ns   |
| t <sub>SS</sub> | LI, CI                                                                                              | 27  | 13                 |     | ns   |
|                 | Data and Function Hold Time:                                                                        |     |                    |     |      |
| teh             | F <sub>0</sub> through F <sub>6</sub>                                                               | 5   | -2                 |     | ns   |
| tDH             | Io, I1, Mo, M1, Ko, K1                                                                              | 5   | -4                 |     | ns   |
| tsH             | LI, CI                                                                                              | 15  | 2                  |     | ns   |
|                 | Propagation Delay to X, Y, RO from:                                                                 |     |                    |     |      |
| <sup>t</sup> xf | Any Function Input                                                                                  |     | 37                 | 52  | ns   |
| t <sub>XD</sub> | Any Data Input                                                                                      |     | 29                 | 42  | ns   |
| tхт             | Trailing Edge of CLK                                                                                |     | 40                 | 60  | ns   |
| txL             | Leading Edge of CLK                                                                                 | 20  |                    |     | ns   |
|                 | Propagation Delay to CO from:                                                                       |     |                    |     |      |
| t <sub>CL</sub> | Leading Edge of CLK                                                                                 | 20  |                    |     | ns   |
| tct             | Trailing Edge of CLK                                                                                |     | 48                 | 70  | ns   |
| tCF             | Any Function Input                                                                                  |     | 43                 | 65  | ns   |
| t <sub>CD</sub> | Any Data Input                                                                                      |     | 30                 | 55  | ns   |
| tcc             | CI (Ripple Carry)                                                                                   | •   | 14                 | 25  | ns   |
|                 | Propagation Delay to $A_0$ , $A_1$ , $D_0$ , $D_1$ from:                                            |     |                    |     |      |
| t <sub>DL</sub> | Leading Edge of CLK                                                                                 | 5   | 32                 | 50  | ns   |
| t <sub>DE</sub> | Enable Input ED, EA                                                                                 |     | 12                 | 25  | ns   |

### NOTE:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

(2)  $t_{CY} = t_{DS} + t_{DL}$ .

### **TEST CONDITIONS:**

TEST LOAD CIRCUIT:

Input pulse amplitude: 2.5 V Input rise and fall times of 5 ns between 1 and 2 volts. Output loading is 10 mA and 30 pF. Speed measurements are made at 1.5 volt levels.



# CAPACITANCE<sup>(2)</sup> $T_A = 25^{\circ}C$

| SYMBOL | PARAMETER          | MIN | ТҮР | MAX | UNIT |
|--------|--------------------|-----|-----|-----|------|
| CIN    | Input Capacitance  |     | 5   | 10  | рF   |
| COUT   | Output Capacitance |     | 6   | 12  | pF   |

NOTE:

(2) This parameter is periodically sampled and is not 100% tested. Condition of measurement is f = 1 MHz,  $V_{BIAS}$  = 2.5V,  $V_{CC}$  = 5.0V and  $T_A$  = 25°C.

### D.C. AND OPERATING CHARACTERISTICS

### ABSOLUTE MAXIMUM RATINGS\*

| Temperature Under Bias         | 55°C to +125°C |
|--------------------------------|----------------|
| Storage Temperature            | $\ldots$       |
| All Output and Supply Voltages |                |
| All Input Voltages             | –1.0V to +5.5V |
| Output Currents                | 100 mA         |

MILITARY TEMP.

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum ratings for extended periods may effect device reliability.

### $T_A = -55^{\circ}C$ to +125°C, $V_{CC} = 5.0V \pm 10\%$ .

|                      |                                                                                                                                                                                          |     | LIMITS                 |                       |                |                                                 |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------------|-----------------------|----------------|-------------------------------------------------|
| SYMBOL               | PARAMETER                                                                                                                                                                                | MIN | ТҮР <sup>(1)</sup>     | MAX                   | UNIT           | CONDITIONS                                      |
| Vc                   | Input Clamp Voltage (All<br>Input Pins)                                                                                                                                                  |     | -0.8                   | -1.2                  | v              | I <sub>C</sub> = -5 mA                          |
| ١ <sub>F</sub>       | Input Load Current:<br>F <sub>0</sub> -F <sub>6</sub> , CLK, K <sub>0</sub> , K <sub>1</sub> , EA, ED<br>I <sub>0</sub> , I <sub>1</sub> , M <sub>0</sub> , M <sub>1</sub> , LI<br>CI    |     | -0.05<br>-0.85<br>-2.3 | -0.25<br>-1.5<br>-4.0 | mA<br>mA<br>mA | V <sub>F</sub> = 0.45V                          |
| I <sub>R</sub>       | Input Leakage Current:<br>F <sub>0</sub> -F <sub>6</sub> , CLK, K <sub>0</sub> , K <sub>1</sub> , EA, ED<br>I <sub>0</sub> , I <sub>1</sub> , M <sub>0</sub> , M <sub>1</sub> , LI<br>CI |     |                        | 40<br>100<br>250      | μΑ<br>μΑ<br>μΑ | V <sub>R</sub> = 5.5V                           |
| VIL                  | Input Low Voltage                                                                                                                                                                        |     |                        | 0.8                   | v              | V <sub>CC</sub> = 5.0V                          |
| VIH                  | Input High Voltage                                                                                                                                                                       | 2.0 |                        |                       | v              |                                                 |
| Icc                  | Power Supply Current                                                                                                                                                                     |     | 145                    | 210                   | mA             |                                                 |
| V <sub>OL</sub>      | Output Low Voltage (All<br>Output Pins)                                                                                                                                                  |     | 0.3                    | 0.45                  | v              | I <sub>OL</sub> = 10 mA                         |
| V <sub>OH</sub>      | Output High Voltage (All<br>Output Pins)                                                                                                                                                 | 2.4 | 3.0                    |                       | v              | I <sub>OH</sub> = -1 mA                         |
| I <sub>OS</sub>      | Short Circuit Output Current<br>(All Output Pins)                                                                                                                                        | -15 | -25                    | -60                   | mA             | V <sub>CC</sub> = 5.0V                          |
| I <sub>O</sub> (off) | Off State Output Current $A_0$ , $A_1$ , $D_0$ , $D_1$ , CO and RO                                                                                                                       |     |                        | 100<br>100            | μΑ<br>μΑ       | V <sub>O</sub> = 0.45V<br>V <sub>O</sub> = 5.5V |

NOTES:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage

(2) CLK input grounded, other inputs open.

### A.C. CHARACTERISTICS AND WAVEFORMS

| SYMBOL          | PARAMETER                                                                                           | MIN | TYP <sup>(1)</sup> | MAX | UNIT |
|-----------------|-----------------------------------------------------------------------------------------------------|-----|--------------------|-----|------|
| tCY             | Clock Cycle Time <sup>[2]</sup>                                                                     | 120 | 70                 |     | ns   |
| twp             | Clock Pulse Width                                                                                   | 42  | 20                 |     | ns   |
| t <sub>FS</sub> | Function Input Set-Up Time ( $F_0$ through $F_6$ )                                                  | 70  | 40                 |     | ns   |
|                 | Data Set-Up Time:                                                                                   |     |                    |     |      |
| t <sub>DS</sub> | I <sub>0</sub> , I <sub>1</sub> , M <sub>0</sub> , M <sub>1</sub> , K <sub>0</sub> , K <sub>1</sub> | 60  | 30                 |     | ns   |
| tss             | LI, CI                                                                                              | 30  | 13                 |     | ns   |
|                 | Data and Function Hold Time:                                                                        |     |                    |     |      |
| tFH             | F <sub>0</sub> through F <sub>6</sub>                                                               | 5   | -2                 |     | ns   |
| t <sub>DH</sub> | I <sub>0</sub> , I <sub>1</sub> , M <sub>0</sub> , M <sub>1</sub> , K <sub>0</sub> , K <sub>1</sub> | 5   | -4                 |     | ns   |
| tsh             | LI, CI                                                                                              | 15  | 2                  |     | ns   |
|                 | Propagation Delay to X, Y, RO from:                                                                 |     |                    |     |      |
| <sup>t</sup> xf | Any Function Input                                                                                  |     | 37                 | 65  | ns   |
| txD             | Any Data Input                                                                                      |     | 29                 | 55  | ns   |
| tхт             | Trailing Edge of CLK                                                                                |     | 40                 | 75  | ns   |
| txL             | Leading Edge of CLK                                                                                 | 22  |                    |     | ns   |
|                 | Propagation Delay to CO from:                                                                       |     |                    |     |      |
| tCL             | Leading Edge of CLK                                                                                 | 22  |                    |     | ns   |
| tст             | Trailing Edge of CLK                                                                                |     | 48                 | 85  | ns   |
| t <sub>CF</sub> | Any Function Input                                                                                  |     | 43                 | 75  | ns   |
| t <sub>CD</sub> | Any Data Input                                                                                      |     | 30                 | 65  | ns   |
| tcc             | CI (Ripple Carry)                                                                                   |     | 14                 | 30  | ns   |
|                 | Propagation Delay to $A_0$ , $A_1$ , $D_0$ , $D_1$ from:                                            |     |                    |     |      |
| tDL             | Leading Edge of CLK                                                                                 | 5   | 32                 | 60  | ns   |
| tDE             | Enable Input ED, EA                                                                                 |     | 12                 | 35  | ns   |

MILITARY TEI

### $T_A = -55^{\circ}C$ to $+125^{\circ}C$ , $V_{CC} = 5.0V \pm 10\%$ .

### NOTE:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

(2)  $t_{CY} = t_{DS} + t_{DL}$ 

### **TEST CONDITIONS:**

### TEST LOAD CIRCUIT:

Input pulse amplitude: 2.5 V Input rise and fall times of 5 ns between 1 and 2 volts. Output loading is 10 mA and 30 pF. Speed measurements are made at 1.5 volt levels.



### CAPACITANCE<sup>(2)</sup> $T_{\Delta} = 25^{\circ}C$

| SYMBOL           | PARAMETER          | MIN | ТҮР | MAX | UNIT |
|------------------|--------------------|-----|-----|-----|------|
| CIN              | Input Capacitance  |     | 5   | 10  | pF   |
| С <sub>ОИТ</sub> | Output Capacitance |     | 6   | 12  | pF   |

NOTE:

(2) This parameter is periodically sampled and is not 100% tested. Condition of measurement is f = 1 MHz, V<sub>BIAS</sub> = 2.5V, V<sub>CC</sub> = 5.0V and T<sub>A</sub> = 25°C.

# 3002 WAVEFORMS



# TYPICAL AC AND DC CHARACTERISTICS



OUTPUT CURRENT VS. OUTPUT VOLTAGE



#### CARRY IN SET UP TIME VS. VCC AND TEMPERATURE







OUTPUT CURRENT VS. OUTPUT LOW VOLTAGE



CLOCK PULSE WIDE VS. VCC AND TEMPERATURE



PROPAGATION DELAY FROM FUNCTION INPUTS TO CASCADE OUTPUTS VS. VCC AND TEMPERATURE



PROPAGATION DELAY – CLOCK TO "A" AND "D" DATA OUTPUT VS. LOAD CAPACITANCE



# TYPICAL CONFIGURATIONS



Ripple-Carry Configuration (N 3002 CPE's)



Carry Look-Ahead Configuration With Ripple Through the Left Slice (32 Bit Array)
| F-GROUP | R-GROUP | MICRO-FUNCTION                                                                                                                               |                                                                                                                                           |
|---------|---------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
|         | l       | $R_n$ + (AC ∧ K) + CI → $R_n$ , AG                                                                                                           | 2                                                                                                                                         |
| 0       | н       | $M + (AC \land K) + CI \to AT$                                                                                                               |                                                                                                                                           |
|         | Ш       | $\begin{array}{l} AT_{L} \land (\overline{I_{L} \land K_{L}}) \rightarrow RO \\ [AT_{L} \land (I_{L} \land K_{L})] \lor [AT_{H} \end{array}$ | LI ∨ [(I <sub>H</sub> ∧ K <sub>H</sub> ) ∧ AT <sub>H</sub> ] → AT <sub>H</sub><br>∨ (I <sub>H</sub> ∧ K <sub>H</sub> )] → AT <sub>L</sub> |
|         | l       | K ∨ R <sub>n</sub> → MAR                                                                                                                     | $R_n + K + CI \rightarrow R_n$                                                                                                            |
| 1       | П       | K ∨ M → MAR                                                                                                                                  | M + K + CI → AT                                                                                                                           |
|         | 111     | $(\overline{AT} \lor K) + (AT \land K) + CI \rightarrow$                                                                                     | AT                                                                                                                                        |
|         | I       | $(AC \land K) - 1 + CI \rightarrow R_n$                                                                                                      |                                                                                                                                           |
| 2       | н       | $(AC \land K) - 1 + CI \rightarrow AT$                                                                                                       | (see Note 1)                                                                                                                              |
|         | 111     | $(I \land K) - 1 + CI \rightarrow AT$                                                                                                        |                                                                                                                                           |
|         | I       | $R_n + (AC \land K) + CI \rightarrow R_n$                                                                                                    |                                                                                                                                           |
| 3       | н       | $M + (AC \land K) + CI \to AT$                                                                                                               |                                                                                                                                           |
|         | 111     | AT + (I $\land$ K) + CI $\rightarrow$ AT                                                                                                     |                                                                                                                                           |
|         | ł       | CI $\vee$ (R <sub>n</sub> $\wedge$ AC $\wedge$ K) $\rightarrow$ CO                                                                           | $R_n \land (AC \land K) \rightarrow R_n$                                                                                                  |
| 4       | н       | $CI \ \lor (M \land AC \land K) \to CO$                                                                                                      | $M \land (AC \land K) \rightarrow AT$                                                                                                     |
|         | 111     | $CI \lor (AT \land I \land K) \to CO$                                                                                                        | AT ∧ (I ∧ K) → AT                                                                                                                         |
| ****    | I       | $CI \lor (R_n \land K) \rightarrow CO$                                                                                                       | $K \land R_n \rightarrow R_n$                                                                                                             |
| 5       | н       | $CI \lor (M \land K) \rightarrow CO$                                                                                                         | $K \wedge M \rightarrow AT$                                                                                                               |
|         | 111     | $CI \lor (AT \land K) \rightarrow CO$                                                                                                        | $K \land AT \to AT$                                                                                                                       |
|         | I       | CI ∨ (AC ∧ K) → CO                                                                                                                           | $R_n \lor (AC \land K) \rightarrow R_n$                                                                                                   |
| 6       | П       | $CI \lor (AC \land K) \rightarrow CO$                                                                                                        | $M \lor (AC \land K) \rightarrow AT$                                                                                                      |
|         | 111     | $CI \lor (I \land K) \rightarrow CO$                                                                                                         | AT ∨ (I ∧ K) → AT                                                                                                                         |
| · .     |         | $CI \lor (R_n \land AC \land K) \rightarrow CO$                                                                                              | $R_n \oplus (AC \wedge K) \rightarrow R_n$                                                                                                |
| 7       | П       | $CI \lor (M \land AC \land K) \to CO$                                                                                                        | $M \ \overline{\oplus} (AC \land K) \to AT$                                                                                               |
|         | 111     | CI ⊻ (AT ∧ I ∧ K) → CO                                                                                                                       | AT ⊕ (I ∧ K) → AT                                                                                                                         |

# APPENDIX A MICRO-FUNCTION SUMMARY

NOTES:

1. 2's complement arithmetic adds 111 . . . 11 to perform subtraction of 000 . . . 01.

2.  $R_{n}$  includes T and AC as source and destination registers in R-group 1 micro-functions.

3. Standard arithmetic carry output values are generated in F-group 0, 1, 2 and 3 instructions.

| SYMBOL         | MEANING                                                       | 1 |
|----------------|---------------------------------------------------------------|---|
| I, K, M        | Data on the I, K, and M busses, respectively                  |   |
| CI, LI         | Data on the carry input and left input, respectively          |   |
| CO, RO         | Data on the carry output and right output, respectively       |   |
| R <sub>n</sub> | Contents of register n including T and AC (R-Group I)         |   |
| AC             | Contents of the accumulator                                   |   |
| AT             | Contents of AC or T, as specified                             |   |
| MAR            | Contents of the memory address register                       |   |
| L, H           | As subscripts, designate low and high order bit, respectively |   |
| +              | 2's complement addition                                       |   |
| -              | 2's complement subtraction                                    |   |
| $\wedge$       | Logical AND                                                   |   |
| V              | Logical OR                                                    |   |
| Ð              | Exclusive-NOR                                                 |   |
| $\rightarrow$  | Deposit into                                                  |   |

# APPENDIX B ALL-ZERO AND ALL-ONE K-BUS MICRO-FUNCTIONS

| K-BUS = 00                           | MICRO-FUNCTION                                         | MNEMONIC | K-BUS = 11 MICRO-FU                     | MNEMONIC                                 |     |
|--------------------------------------|--------------------------------------------------------|----------|-----------------------------------------|------------------------------------------|-----|
| R <sub>n</sub> + CI → R <sub>r</sub> | , AC                                                   | ILR      | $AC + R_n + CI \rightarrow R_n, AC$     |                                          | ALR |
| M + CI → AT                          |                                                        | ACM      | $M + AC + CI \to AT$                    |                                          | AMA |
| AT <sub>L</sub> → RO                 | AT <sub>H</sub> → AT <sub>L</sub> LI → AT <sub>H</sub> | SRA      | (See Appendix A)                        |                                          | -   |
| R <sub>n</sub> → MAR                 | R <sub>n</sub> + CI → R <sub>n</sub>                   | LMI      | 11 → MAR                                | R <sub>n</sub> – 1 + Cl → R <sub>n</sub> | DSM |
| M→MAR                                | $M + CI \rightarrow AT$                                | LMM      | 11 → MAR                                | M – 1 + CI → AT                          | LDM |
| AT + CI → A                          | r                                                      | CIA      | AT – 1 + CI → AT                        |                                          | DCA |
| $CI - 1 \rightarrow R_n$             | See Note 1                                             | CSR      | $AC - 1 + CI \rightarrow R_n$ Se        | e Note 1                                 | SDR |
| $CI-1\toAT$                          | See Notes 1,4                                          | CSA      | $AC - 1 + CI \rightarrow AT$ Se         | e Notes 1,4                              | SDA |
| (See CSA abo                         | ve)                                                    | _        | I – 1 + CI → AT                         |                                          | LDI |
| R <sub>n</sub> + Cl → R <sub>n</sub> |                                                        | INR      | $AC + R_n + CI \rightarrow R_n$         |                                          | ADR |
| (See ACM abo                         | ove)                                                   | _        | (See AMA above)                         |                                          | -   |
| AT + CI → AT                         | г                                                      | INA      | I + AT + CI → AT                        |                                          | AIA |
| CI → CO                              | $0 \rightarrow R_n$                                    | CLR      | $CI \lor (R_n \land AC) \rightarrow CO$ | $R_n \land AC \rightarrow R_n$           | ANR |
| CI → CO                              | 0 → AT                                                 | CLA      | $CI.\lor\ (M\wedgeAC)\toCO$             | $M\wedgeAC{\rightarrow}AT$               | ANM |
| (See CLA abo                         | ove)                                                   | -        | $CI  \lor  (AT  \land  I) \to CO$       | $AT \land I \rightarrow AT$              | ANI |
| (See CLR abo                         | ove)                                                   | _        | CI ∨ R <sub>n</sub> → CO                | $R_n \rightarrow R_n$                    | TZR |
| (See CLA abo                         | ove)                                                   | -        | $CI \lor M \rightarrow CO$              | M → AT                                   | LTM |
| (See CLA abo                         | ove)                                                   | -        | $CI \lor AT \rightarrow CO$             | AT → AT                                  | TZA |
| CI → CO                              | R <sub>n</sub> → R <sub>n</sub>                        | NOP      | CI ∨ AC → CO                            | $R_n \lor AC \rightarrow R_n$            | ORR |
| CI → CO                              | M → AT                                                 | LMF      | $CI \lor AC \rightarrow CO$             | $M\veeAC{\rightarrow}AT$                 | ORM |
| (See NOP abo                         | ove)                                                   | -        | CI ∨ I → CO                             | I ∨ AT → AT                              | ORI |
| CI → CO                              | $\overline{R_n} \rightarrow R_n$                       | CMR      | $CI \vee (R_n \land AC) \rightarrow CO$ | $R_n \oplus AC \to R_n$                  | XNR |
| CI → CO                              | M → AT                                                 | LCM      | CI ∨ (M AC) → CO                        | M ⊕ AC → AT                              | XNM |
| CI → CO                              | $\overline{AT} \to AT$                                 | СМА      | $CI \lor (AT  I) \rightarrow CO$        | I ⊕ AT → AT                              | XNI |

4. The more general operations, CSR and SDR, should be used in place of the CSA and SDA operations, respectively.

# 3002

# APPENDIX C FUNCTION AND REGISTER GROUP FORMATS

| FUNCTION<br>GROUP | F <sub>6</sub> | 5 | 4 |
|-------------------|----------------|---|---|
| 0                 | 0              | 0 | 0 |
| 1                 | 0              | 0 | 1 |
| 2                 | 0              | 1 | 0 |
| 3                 | 0              | 1 | 1 |
| 4                 | 1              | 0 | 0 |
| 5                 | 1              | 0 | 1 |
| 6                 | 1              | 1 | 0 |
| 7                 | 1              | 1 | 1 |

| REGISTER<br>GROUP | REGISTER       | F <sub>3</sub> | 2 | 1 | 0 |
|-------------------|----------------|----------------|---|---|---|
|                   | R <sub>0</sub> | 0              | 0 | 0 | 0 |
|                   | $R_1$          | 0              | 0 | 0 | 1 |
|                   | $R_2$          | 0              | 0 | 1 | 0 |
|                   | $R_3$          | 0              | 0 | 1 | 1 |
|                   | R <sub>4</sub> | 0              | 1 | 0 | 0 |
|                   | R <sub>5</sub> | 0              | 1 | 0 | 1 |
|                   | R <sub>6</sub> | -0             | 1 | 1 | 0 |
|                   | R <sub>7</sub> | 0              | 1 | 1 | 1 |
|                   | R <sub>8</sub> | 1              | 0 | 0 | 0 |
|                   | R <sub>9</sub> | 1              | 0 | 0 | 1 |
|                   | Т              | 1              | 1 | 0 | 0 |
|                   | AC             | 1              | 1 | 0 | 1 |
|                   | Т              | 1              | 0 | 1 | 0 |
| 11                | AC             | 1              | 0 | 1 | 1 |
|                   | Т              | 1              | 1 | 1 | 0 |
| 111               | AC             | 1              | 1 | 1 | 1 |



# SCHOTTKY BIPOLAR LSI MICROCOMPUTER SET

# 3003 LOOK-AHEAD CARRY GENERATOR

The INTEL<sup>®</sup> 3003 Look-Ahead Carry Generator (LCG) is a high speed circuit capable of anticipating a carry across a full 16-bit 3002 Central Processing Array. When used with a larger 3002 CP Array multiple 3003 carry generators provide high speed carry look-ahead capability for any word length.

The LCG accepts eight pairs of active high cascade inputs (X,Y) and an active low carry input and generates active low carries for up to eight groups of binary adders.

# High Performance – 10 ns typical propagation delay

Compatible with INTEL 3001 MCU and 3002 CPE

DTL and TTL compatible

Full look-ahead across 8 adders

Low voltage diode input clamp

Expandable

28-pin DIP

# PACKAGE CONFIGURATION





# LOGIC DIAGRAM

٦

| PIN DESC                   | RIPTION                                |                                         |                |
|----------------------------|----------------------------------------|-----------------------------------------|----------------|
| PIN                        | SYMBOL                                 | NAME AND<br>FUNCTION                    | TYPE           |
| 1,7,8,11<br>18,21,23<br>27 | Y <sub>0</sub> -Y <sub>7</sub>         | Standard carry<br>look-ahead<br>inputs  | Active<br>HIGH |
| 2,5,6,10<br>19,20,24<br>26 | Х <sub>0</sub> -Х <sub>7</sub>         | Standard carry<br>look-ahead<br>inputs  | Active<br>HIGH |
| 17                         | Cn                                     | Carry input                             | Active<br>LOW  |
| 4,9,12<br>13,15,16         | C <sub>n+1</sub> -<br>C <sub>n+8</sub> | Carry outputs                           | Active<br>LOW  |
| 3                          | ECn+8                                  | C <sub>n+8</sub> carry<br>output enable | Active<br>HIGH |
| 28                         | V <sub>CC</sub>                        | +5 volt supply                          |                |
| 14                         | GND                                    | Ground                                  |                |

EC<sub>n</sub>+

# 3003 LOGIC EQUATIONS

The 3003 Look-Ahead Generator is implemented in a compatible form for direct connection to the 3001 MCU and 3002 CPE. Logic equations for the 3003 are:

$$\frac{\overline{c_{n}+1} = Y_{0}X_{0} + Y_{0}\overline{c}_{n}}{\overline{c_{n}+2} = Y_{1}X_{1} + Y_{1}Y_{0}X_{0} + Y_{1}Y_{0}\overline{c}_{n}}$$

$$\frac{\overline{c_{n}+2} = Y_{1}X_{1} + Y_{1}Y_{0}X_{0} + Y_{1}Y_{0}\overline{c}_{n}}{\overline{c_{n}+3} = Y_{2}X_{2} + Y_{2}Y_{1}X_{1} + Y_{2}Y_{1}Y_{0}X_{0} + Y_{2}Y_{1}Y_{0}\overline{c}_{n}}$$

$$\frac{\overline{c_{n}+4} = Y_{3}X_{3} + Y_{3}Y_{2}X_{2} + Y_{3}Y_{2}Y_{1}X_{1} + Y_{3}Y_{2}Y_{1}Y_{0}X_{0} + Y_{3}Y_{2}Y_{1}Y_{0}\overline{c}_{n}}{\overline{c_{n}+5} = Y_{4}X_{4} + Y_{4}Y_{3}X_{3} + Y_{4}Y_{3}Y_{2}X_{2} + Y_{4}Y_{3}Y_{2}Y_{1}X_{1} + Y_{4}Y_{3}Y_{2}Y_{1}Y_{0}X_{0} + Y_{4}Y_{3}Y_{2}Y_{1}Y_{0}\overline{c}_{n}}$$

$$\frac{\overline{c_{n}+6} = Y_{5}X_{5} + Y_{5}Y_{4}X_{4} + Y_{5}Y_{4}Y_{3}X_{3} + Y_{5}Y_{4}Y_{3}Y_{2}X_{2} + Y_{5}Y_{4}Y_{3}Y_{2}Y_{1}X_{1} + Y_{5}Y_{4}Y_{3}Y_{2}Y_{1}Y_{0}X_{0} + Y_{5}Y_{4}Y_{3}Y_{2}Y_{1}Y_{0}\overline{c}_{n}}{\overline{c_{n}+7}} = Y_{6}X_{6} + Y_{6}Y_{5}X_{5} + Y_{6}Y_{5}Y_{4}X_{3} + Y_{6}Y_{5}Y_{4}Y_{3}X_{3} + Y_{6}Y_{5}Y_{4}Y_{3}Y_{2}X_{2} + Y_{6}Y_{5}Y_{4}Y_{3}Y_{2}Y_{1}X_{1} + Y_{6}Y_{5}Y_{4}Y_{3}Y_{2}Y_{1}Y_{0}X_{0} + Y_{6}Y_{5}Y_{4}Y_{3}Y_{2}Y_{1}Y_{0}\overline{c}_{n}}$$

$$\frac{\overline{c_{n}+8}} = \text{High Impedance State when EC_{n}+8 Low}$$

$$\frac{\overline{c_{n}+8}} = Y_{7}X_{7} + Y_{7}Y_{6}X_{6} + Y_{7}Y_{6}Y_{5}X_{5} + Y_{7}Y_{6}Y_{5}Y_{4}X_{3}Y_{2}Y_{1}Y_{0}\overline{c}_{n} \text{when EC}_{n}+8 high$$

# D.C. AND OPERATING CHARACTERISTICS

**ABSOLUTE MAXIMUM RATINGS\*** 

| Temperature Under Bias   |       | •   | • | • |  |   |   |   |   |   |   |   |  |   |  | • | · |  | • | · |   | . 0  | °C t | o 70°            | С |
|--------------------------|-------|-----|---|---|--|---|---|---|---|---|---|---|--|---|--|---|---|--|---|---|---|------|------|------------------|---|
| Storage Temperature .    |       | •   | • |   |  | • |   |   | • | • |   |   |  |   |  |   |   |  |   |   | - | 65°C | to + | 160 <sup>°</sup> | С |
| All Output and Supply Vo | oltag | ges |   |   |  |   | • |   |   |   | • | • |  |   |  |   |   |  |   |   |   | -0.  | 5V   | to +7            | v |
| All Input Voltages       |       |     |   |   |  |   |   | • |   | • | • |   |  | • |  |   |   |  |   |   |   | -1.0 | / to | +5.5             | v |
| Output Current           |       |     |   |   |  | • |   |   |   |   |   |   |  |   |  |   |   |  |   |   |   |      | 1    | 00 m             | A |

\*COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

 $T_A = 0^{\circ}C \text{ to } +70^{\circ}C \quad V_{CC} = 5.0V \pm 5\%$ 

| SYMBOL              | PARAMETER                                                                                  | MIN. | түр. <sup>(1)</sup>     | MAX.                    | UNIT           | CONDITIONS                                                          |
|---------------------|--------------------------------------------------------------------------------------------|------|-------------------------|-------------------------|----------------|---------------------------------------------------------------------|
| v <sub>c</sub>      | Input Clamp Voltage (All<br>Input Pins)                                                    |      | -0.8                    | -1.0                    | V              | I <sub>C</sub> = -5 mA                                              |
| ۱ <sub>F</sub>      | Input Load Current:<br>$X_6, X_7 Cn, EC_n + 8$<br>$Y_7, X_0 \cdot X_5,$<br>$Y_0 \cdot Y_6$ |      | -0.07<br>-0.200<br>-0.6 | -0.25<br>-0.500<br>-1.5 | mA<br>mA<br>mA | V <sub>F</sub> = 0.45∨                                              |
| I <sub>R</sub>      | Input Leakage Current:<br>C <sub>n</sub> and EC <sub>n</sub> + 8<br>All Other Inputs       |      |                         | 40<br>100               | μΑ<br>μΑ       | V <sub>R</sub> = 5.25V                                              |
| V <sub>IL</sub>     | Input Low Voltage                                                                          |      |                         | 0.8                     | v              | V <sub>CC</sub> = 5.0V                                              |
| VIH                 | Input High Voltage                                                                         | 2.0  |                         |                         | V              | V <sub>CC</sub> = 5.0V                                              |
| lcc                 | Power Supply Current                                                                       |      | 80                      | 130                     | mA             | All Y and EC <sub>n</sub> + 8 high,<br>All X and C <sub>n</sub> low |
| V <sub>OL</sub>     | Output Low Voltage (All<br>Output Pins)                                                    |      | 0.35                    | 0.45                    | v              | I <sub>OL</sub> = 4 mA                                              |
| v <sub>он</sub>     | Output High Voltage (All<br>Output Pins)                                                   | 2.4  | 3                       |                         | v              | I <sub>OH</sub> = -1 mA                                             |
| IOS                 | Short Circuit Output Current<br>(All Output Pins)                                          | -15  | -40                     | -65                     | mA             | V <sub>CC</sub> = 5V                                                |
| I <sub>O(off)</sub> | Off-State Output Current<br>(C <sub>n</sub> + 8)                                           |      | -+                      | 100<br>100              | μΑ<br>μΑ       | V <sub>O</sub> = 0.45V<br>V <sub>O</sub> = 5.25V                    |

NOTE:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

# A.C. CHARACTERISTICS

 $T_A = 0^\circ C$  to  $70^\circ C$ ,  $V_{CC} = +5V \pm 5\%$ 

| SYMBOL          | PARAMETER                       | MIN. | түр.(1) | MAX. | UNIT |
|-----------------|---------------------------------|------|---------|------|------|
| <sup>t</sup> XC | X, Y to Outputs                 | 3    | 10      | 20   | ns   |
| tCC             | Carry In to Outputs             |      | 13      | 30   | ns   |
| <sup>t</sup> EN | Enable Time, C <sub>n</sub> + 8 |      | 20      | 40   | ns   |

NOTE:

(1) Typical values are for  $T_A \approx 25^{\circ}C$  and nominal supply voltage.

# D.C. AND OPERATING CHARACTERISTICS

| ABSOLUTE MAXIMUM RATINGS*      |      |            |
|--------------------------------|------|------------|
| Temperature Under Bias         |      | to +125°C  |
| Storage Temperature            | 65°C | to +160°C  |
| All Output and Supply Voltages |      | 5V to +7V  |
| All Input Voltages             |      | / to +5.5V |
| Output Current                 |      | 100 mA     |

\*COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

# $T_A = -55^{\circ}C$ to $+125^{\circ}C$ , $V_{CC} = 5.0V \pm 10\%$ .

| SYMBOL          | PARAMETER                                                   | MIN. | түр. <sup>(1)</sup>                   | MAX.                           | UNIT           | CONDITIONS                                                          |
|-----------------|-------------------------------------------------------------|------|---------------------------------------|--------------------------------|----------------|---------------------------------------------------------------------|
| v <sub>c</sub>  | Input Clamp Voltage (All<br>Input Pins)                     |      | -0.8                                  | -1.2                           | v              | l <sub>C</sub> = -5 mA                                              |
| IF              | Input Load Current:<br>X6,X7,Cn,ECn+8<br>Y7,X0-X5,<br>Y6-Y6 |      | -0.07<br><b>-0.200</b><br><b>-0.6</b> | -0.25<br><b>-0.500</b><br>-1.5 | mA<br>mA<br>mA | V <sub>F</sub> = 0.45V                                              |
| 'R              | C <sub>n</sub> and EC <sub>n</sub> + 8<br>All Other Inputs  |      |                                       | 40<br>100                      | μΑ<br>μΑ       | V <sub>CC</sub> = 5.25V, V <sub>R</sub> = 5.5V                      |
| VIL             | Input Low Voltage                                           |      |                                       | 0.8                            | v              | V <sub>CC</sub> = 5.0V                                              |
| V <sub>IH</sub> | Input High Voltage                                          | 2.1  |                                       |                                | V              | V <sub>CC</sub> = 5.0V                                              |
| lcc             | Power Supply Current                                        |      | 80                                    | 130                            | mA             | All Y and EC <sub>n</sub> + 8 high,<br>All X and C <sub>n</sub> low |
| V <sub>OL</sub> | Output Low Voltage (All<br>Output Pins)                     |      | 0.35                                  | 0.45                           | v              | IOL = 4 mA                                                          |
| VOH             | Output High Voltage (All<br>Output Pins)                    | 2.4  | 3                                     |                                | v              | I <sub>OH</sub> = -1 mA                                             |
| los             | Short Circuit Output Current<br>(All Output Pins) -         | - 15 | -40                                   | -65                            | mA             | V <sub>CC</sub> = 5V                                                |
| lO(off)         | Off-State Output Current<br>(C <sub>n</sub> + 8)            |      | -                                     | -100<br>+100                   | μΑ<br>μΑ       | V <sub>O</sub> = 0.45V<br>V <sub>O</sub> = 5.5V                     |

NOTE:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

.

# A.C. CHARACTERISTICS

| TA | = -55 | °C to | +125° | °C, | Vcc | = | +5.0V | ±10% |
|----|-------|-------|-------|-----|-----|---|-------|------|
|----|-------|-------|-------|-----|-----|---|-------|------|

| ture X X to Outputs                             | 2 |    |    |    |
|-------------------------------------------------|---|----|----|----|
| XC X, 1 to Outputs                              | 3 | 10 | 25 | ns |
| t <sub>CC</sub> Carry In to Outputs             |   | 13 | 40 | ns |
| <sup>t</sup> EN Enable Time, C <sub>n</sub> + 8 |   | 20 | 50 | ns |

NOTE:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

# WAVEFORMS



# $CAPACITANCE^{(2)} T_A = 25^{\circ}C$

| SYMBOL           |                    | PARAMETER          | MIN | түр | MAX | UNIT |
|------------------|--------------------|--------------------|-----|-----|-----|------|
| CIN              | Input Capacitance  | All inputs         |     | 12  | 20  | pF   |
| C <sub>OUT</sub> | Output Capacitance | C <sub>n</sub> + 8 |     | 7   | 12  | pF   |

NOTE:

(2) This parameter is periodically sampled and is not 100% tested. Condition of measurement is f = 1 MHz,  $V_{BIAS} = 5.0V$ ,  $V_{CC} = 5.0V$  and  $T_A = 25^{\circ}$ C.

# **TEST CONDITIONS:**

Input pulse amplitude of 2.5V. Input rise and fall times of 5 ns between 1 and 2 volts. Output loading is 5 mA and 30 pF. Speed measurements are made at 1.5 volt levels.

# TEST LOAD CIRCUIT: Vcc

# TYPICAL A.C. AND D.C. CHARACTERISTICS





# OUTPUT CURRENT VS. OUTPUT, HIGH VOLTAGE



# X, Y TO OUTPUT DELAY VS. LOAD CAPACITANCE



# X, Y TO OUTPUTS VS. $V_{\mbox{CC}}$ AND TEMPERATURE



# X, Y TO OUTPUTS VS. VCC AND TEMPERATURE



OUTPUT CURRENT VS. OUTPUT LOW VOLTAGE

# **TYPICAL CONFIGURATIONS**

The 3003 LCG can be directly tied to the 3001 MCU and a 3002 CP array of any word length. The following figures represent typical configurations of 16- and 32-bit CP arrays. Figures 1 and 2 illustrate use of the 3003 in a system where the carry output (CO) to the 3001 MCU is rippled through the high order CPE slice. Figure 3 illustrates use of the 3003 in a system where tri-state output  $C_{n+8}$  is connected directly to the flag input on the 3001 MCU.  $C_{n+8}$  is disabled during shift right by decoding that instruction externally, thus multiplexing  $C_{n+8}$  with the shift right (RO) output of the low order CPE slice.



Figure 1. Carry Look-Ahead Configuration with Ripple through the Left Slice (16-Bit Array)



Figure 2. Carry Look-Ahead Configuration with No Carry Ripple through the Left Slice (32-Bit Array)



The INTEL<sup>®</sup> 3212 Multi-Mode Latch Buffer is a versatile 8-bit latch with three-state output buffers and built-in device select logic. It also contains an independent service request flip-flop for the generation of central processor interrupts. Because of its multi-mode capabilities, one or more 3212's can be used to implement many types of interface and support systems for Series 3000 computing elements including:

- Simple data latches
- Gated data buffers
- Multiplexers
- **Bi-directional bus drivers**
- Interrupting input/output ports

# SCHOTTKY BIPOLAR LSI MICROCOMPUTER SET

High Performance - 50 ns Write Cycle

Low Input Load Current - 250 µA

Three-State Fully Buffered Outputs

Independent Service Request Flip-

Asynchronous Data Latch Clear

**High Output Drive Capability** 

Time

Flop

24 Pin DIP

Maximum

# 3212 MULTI-MODE LATCH BUFFER

# PACKAGE CONFIGURATION





Figure 1. Block Diagram of a Typical System

# **PIN DESCRIPTION**

| PIN               | SYMBOL                           | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                      | TYPE <sup>(1)</sup> |
|-------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| 1                 | DS <sub>1</sub>                  | Device Select Input 1                                                                                                                                                                                                                                                                                                  | active LOW          |
| 2                 | MD                               | Mode Input                                                                                                                                                                                                                                                                                                             |                     |
|                   |                                  | When MD is high (output mode) the output buffers are enabled and the<br>write signal to the data latches is obtained from the device select logic.<br>When MD is low (input mode) the output buffer state is determined by<br>the device select logic and the write signal is obtained from the strobe<br>(STB) input. |                     |
| 3, 5, 7, 9,       | DI <sub>1</sub> -DI <sub>8</sub> | Data Inputs                                                                                                                                                                                                                                                                                                            |                     |
| 16, 18, 20,<br>22 |                                  | The data inputs are connected to the D-inputs of the data latches.                                                                                                                                                                                                                                                     |                     |
| 4, 6, 8, 10,      | D01-D08                          | Data Outputs                                                                                                                                                                                                                                                                                                           | three-state         |
| 15, 17, 19,<br>21 |                                  | The data outputs are the buffered outputs of the eight data latches.                                                                                                                                                                                                                                                   |                     |
| 11                | STB                              | Strobe Input                                                                                                                                                                                                                                                                                                           |                     |
|                   |                                  | When MD is in the LOW state, the STB input provides the clock input to the data latch.                                                                                                                                                                                                                                 |                     |
| 12                | GND                              | Ground                                                                                                                                                                                                                                                                                                                 |                     |
| 13                | DS <sub>2</sub>                  | Device Select Input 2                                                                                                                                                                                                                                                                                                  |                     |
|                   |                                  | When $DS_1$ is low and $DS_2$ is high, the device is selected.                                                                                                                                                                                                                                                         |                     |
| 14                | CLR                              | Clear                                                                                                                                                                                                                                                                                                                  | active LOW          |
| 23                | INT                              | Interrupt Output                                                                                                                                                                                                                                                                                                       | active LOW          |
|                   |                                  | The interrupt output will be active LOW (interrupting state) when either the service request flip-flop is low or the device is selected.                                                                                                                                                                               |                     |

NOTE:

(1) Active HIGH, unless otherwise specified.

.

# FUNCTIONAL DESCRIPTION

The 3212 contains eight D-type data latches, eight three-state output buffers, a separate D-type service request flip-flop, and a flexible device select/ mode control section.

# DATA LATCHES

The Q-output of each data latch will follow the data on its corresponding date input line  $(DI_1 - DI_8)$  while its clock input is high. Data will be latched when the internal write line WR is brought low. The output of each data latch is connected to a three-state, non-inverting output buffer. The internal enable line EN is bussed to each buffer. When the EN is high, the buffers are enabled and the data in each latch is available on its corresponding data output line  $(DO_0 - DO_8)$ .

# DEVICE SELECT LOGIC

Two input lines  $DS_1$  and  $DS_2$  are provided for device selection. When  $DS_1$  is low and  $DS_2$  is high, the 3212 is selected.

# MODE CONTROL SECTION

The 3212 may be operated in two modes. When the mode input line MD is low, the device is in the input mode. In this mode, the output buffers are enabled whenever the 3212 is selected; the internal WR line follows the STB input line.

When MD is high, the device is in the output mode and, as a result, the output buffers are enabled. In this mode, the write signal for the data latch is obtained from the device select logic.

# SERVICE REQUEST FLIP-FLOP AND STROBE

The service request flip-flop SR is used to generate and control central processor interrupt signals. For system reset, the SR flip-flop is placed in the noninterrupting state (i.e., SR is set) by bringing the CLR line low. This simultaneously clears (resets) the 8-bit data latch. The Q output of the SR flip-flop is logically ORed with the output of device select logic and then inverted to provide the interrupt output INT. The 3212 is considered to be in the interrupting state when the INT output is low. This allows direct connection to the active LOW priority request inputs of the INTEL®3214 Interrupt Control Unit. When operated in the input mode (i.e., MD low) the strobe input STB is used to synchronously write data into the data latch and place the SR flip-flop in the interrupting (reset) state. The interrupt is removed by the central processor when the interrupting 3212 is selected.





# D.C. AND OPERATING CHARACTERISTICS

# **ABSOLUTE MAXIMUM RATINGS\***

| Temperature Under Bias         | $\ldots$       |
|--------------------------------|----------------|
| Storage Temperature            | 65°C to +160°C |
| All Output and Supply Voltages | 0.5V to +7V    |
| All Input Voltages             |                |
| Output Currents                |                |

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

| Symbol          | Parameter                                                                                 | Min. | Тур. | Max. | Unit | Conditions                  |
|-----------------|-------------------------------------------------------------------------------------------|------|------|------|------|-----------------------------|
| ۱ <sub>F</sub>  | Input Load Current<br>STB, DS <sub>2</sub> , CLR, DI <sub>1</sub> -DI <sub>8</sub> Inputs |      |      | 25   | mA   | V <sub>F</sub> = .45V       |
| ۱ <sub>F</sub>  | Input Load Current<br>MD Input                                                            |      |      | 75   | mA   | V <sub>F</sub> = .45V       |
| ۱ <sub>F</sub>  | Input Load Current<br>DS <sub>1</sub> Input                                               |      |      | -1.0 | mA   | V <sub>F</sub> = .45V       |
| I <sub>R</sub>  | Input Leakage Current<br>STB, DS, CLR, DI <sub>1</sub> —DI <sub>8</sub> Inputs            |      |      | 10   | μA   | V <sub>R</sub> = 5.25V      |
| I <sub>R</sub>  | Input Leakage Current<br>MD Input                                                         |      |      | 30   | μA   | V <sub>R</sub> = 5.25V      |
| I <sub>R</sub>  | Input Leakage Current<br>DS <sub>1</sub> Input                                            |      |      | 40   | μA   | V <sub>R</sub> = 5.25V      |
| v <sub>c</sub>  | Input Forward Voltage Clamp                                                               |      |      | -1   | ν    | I <sub>C</sub> = -5 mA      |
| VIL             | Input "Low" Voltage                                                                       |      |      | .85  | v    |                             |
| VIH             | Input "High" Voltage                                                                      | 2.0  |      |      | v    |                             |
| V <sub>OL</sub> | Output "Low" Voltage                                                                      |      |      | .45  | v    | I <sub>OL</sub> = 15 mA     |
| V <sub>OH</sub> | Output "High" Voltage                                                                     | 3.65 | 4.0  |      | v    | I <sub>OH</sub> = -1 mA     |
| I <sub>SC</sub> | Short Circuit Output Current                                                              | -15  |      | -75  | mA   | V <sub>CC</sub> = 5.0V      |
| 101             | Output Leakage Current<br>High Impedance State                                            |      |      | 20   | μA   | V <sub>O</sub> = .45V/5.25V |
| Icc             | Power Supply Current                                                                      |      | 90   | 130  | mA   |                             |

# $T_A = 0^{\circ}C \text{ to } +75^{\circ}C \qquad V_{CC} = +5V \pm 5\%$

| A.C. CHARACTERISTICS | $T_A = 0^{\circ}C$ to 75°C, $V_{CC} = +5.0V \pm 5\%$                                                           |  |
|----------------------|----------------------------------------------------------------------------------------------------------------|--|
|                      | - The second |  |

| Symbol          | Parameter                    | Min. | Тур. | Max. | Unit |                        |
|-----------------|------------------------------|------|------|------|------|------------------------|
| t <sub>PW</sub> | Pulse Width                  | 25   |      |      | ns   |                        |
| t <sub>PD</sub> | Data To Output Delay         |      |      | 30   | ns   |                        |
| <sup>t</sup> we | Write Enable To Output Delay |      |      | 40   | ns   |                        |
| tset            | Data Setup Time              | 15   |      |      | ns   |                        |
| t <sub>H</sub>  | Data Hold Time               | 20   |      |      | ns   |                        |
| t <sub>R</sub>  | Reset To Output Delay        |      |      | 40   | ns   |                        |
| t <sub>S</sub>  | Set To Output Delay          |      |      | 30   | ns   |                        |
| t <sub>E</sub>  | Output Enable Time           |      |      | 45   | ns   | C <sub>L</sub> = 30 pf |
| tc              | Clear To Output Display      |      |      | 45   | ns   |                        |

# TEST CONDITIONS:

# TEST LOAD CIRCUIT:

Input pulse amplitude of 2.5 volts. Input rise and fall times of 5 ns between 1 volt and 2 volts. Output load of 15 mA and 30 pF. Speed measurements are taken at the 1.5 volt level.



# CAPACITANCE(1)

| Symbol          | Tast                                                                              | LIMITS |      |      |       |  |
|-----------------|-----------------------------------------------------------------------------------|--------|------|------|-------|--|
| Symbol          | 1 851                                                                             | Min.   | Тур. | Max. | Units |  |
| C <sub>IN</sub> | DS <sub>1</sub> , MD Input Capacitance                                            |        | 9    | 12   | pf    |  |
| C <sub>IN</sub> | DS <sub>2</sub> , CLR, STB, DI <sub>1</sub> —DI <sub>8</sub><br>Input Capacitance |        | 5    | 9    | pf    |  |
| Cout            | DO <sub>1</sub> -DO <sub>8</sub> Output Capacitance                               |        | 8    | 12   | pf    |  |

NOTE:

(1) This parameter is periodically sampled and is not 100% tested. Condition of measurement is f = 1 MHz,  $V_{BIAS} = 2.5V$ ,  $V_{CC} = 5V$  and  $T_A = 25^{\circ}C$ .

# D.C. AND OPERATING CHARACTERISTICS

# ABSOLUTE MAXIMUM RATINGS\*

| Temperature Under Bias         | $-55^{\circ}C$ to $+125^{\circ}C$ |
|--------------------------------|-----------------------------------|
| Storage Temperature            | $-65^{\circ}C$ to $+160^{\circ}C$ |
| All Output and Supply Voltages | 0.5V to +7V                       |
| All Input Voltages             | 1.0V to +5.5V                     |
| Output Currents                | 100 mA                            |

MILITARY TEM

\*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

| Symbol          | Parameter                                                                                 | Min. | Тур. | Max. | Unit | Conditions              |
|-----------------|-------------------------------------------------------------------------------------------|------|------|------|------|-------------------------|
| ۱ <sub>F</sub>  | Input Load Current<br>STB, DS <sub>2</sub> , CLR, DI <sub>1</sub> —DI <sub>8</sub> Inputs |      |      | 25   | mA   | V <sub>F</sub> = .45V   |
| ۱ <sub>F</sub>  | Input Load Current<br>MD Input                                                            |      |      | 75   | mA   | V <sub>F</sub> = .45V   |
| ۱ <sub>F</sub>  | Input Load Current<br>DS <sub>1</sub> Input                                               |      |      | -1.0 | mA   | V <sub>F</sub> = .45V   |
| I <sub>R</sub>  | Input Leakage Current<br>STB, DS, CLR, DI <sub>1</sub> —DI <sub>8</sub> Inputs            |      |      | 10   | μA   | V <sub>R</sub> = 5.5V   |
| ۱ <sub>R</sub>  | Input Leakage Current<br>MD Input                                                         |      |      | 30   | μA   | V <sub>R</sub> = 5.5V   |
| I <sub>R</sub>  | Input Leakage Current<br>DS <sub>1</sub> Input                                            |      |      | 40   | μA   | V <sub>R</sub> = 5.5V   |
| vc              | Input Forward Voltage Clamp                                                               |      |      | 1.2  | v    | I <sub>C</sub> = -5 mA  |
| V <sub>IL</sub> | Input "Low" Voltage                                                                       |      |      | .80  | v    |                         |
| V <sub>IH</sub> | Input ''High'' Voltage                                                                    | 2.0  |      |      | v    |                         |
| V <sub>OL</sub> | Output "Low" Voltage                                                                      |      |      | .45  | v    | I <sub>OL</sub> = 10 mA |
| V <sub>OH</sub> | Output "High" Voltage                                                                     | 3.5  | 4.0  |      | v    | I <sub>OH</sub> = .5 mA |
| I <sub>SC</sub> | Short Circuit Output Current                                                              | -15  |      | -75  | mA   | V <sub>CC</sub> = 5.0V  |
| 10              | Output Leakage Current<br>High Impedance State                                            |      |      | 20   | μA   | $V_0 = .45V/5.5V$       |
| Icc             | Power Supply Current                                                                      |      | 90   | 145  | mA   |                         |

# $T_A = -55^{\circ}C \text{ to } +125^{\circ}C; V_{CC} = 5.0V \pm 10\%$

# A.C. CHARACTERISTICS $T_A = -55^{\circ}C$ to $+125^{\circ}C$ , $V_{CC} = 5.0V \pm 10\%$

|                  |                                               |                        |             |      | N    | 3212                   |
|------------------|-----------------------------------------------|------------------------|-------------|------|------|------------------------|
| A.C. CHA         | <b>RACTERISTICS</b> $T_A = -55^{\circ}C$ to + | 125°C, V <sub>CC</sub> | = 5.0V ± 10 | 1%   |      | TARY TEMP.             |
| Symbol           | Parameter                                     | Min.                   | Тур.        | Max. | Unit | •                      |
| t <sub>PW</sub>  | Pulse Width                                   | 40                     |             |      | ns   |                        |
| t <sub>PD</sub>  | Data To Output Delay                          |                        |             | 30   | ns   |                        |
| twe              | Write Enable To Output Delay                  |                        |             | 50   | ns   |                        |
| t <sub>SET</sub> | Data Setup Time                               | 20                     |             |      | ns   |                        |
| t <sub>H</sub>   | Data Hold Time                                | 30                     |             |      | ns   |                        |
| t <sub>R</sub>   | Reset To Output Delay                         |                        |             | 55   | ns   |                        |
| t <sub>S</sub>   | Set To Output Delay                           |                        |             | 35   | ns   |                        |
| t <sub>E</sub>   | Output Enable Time                            |                        |             | 50   | ns   | C <sub>L</sub> = 30 pf |
| t <sub>C</sub>   | Clear To Output Display                       |                        |             | 55   | ns   |                        |

# **TEST CONDITIONS:**

Input pulse amplitude of 2.5 volts. Input rise and fall times of 5 ns between 1 volt and 2 volts. Output load of 15 mA and 30 pF. Speed measurements are taken at the 1.5 volt level.

# **TEST LOAD CIRCUIT:**



# CAPACITANCE(1)

| Symphol          | Test                                                                              | LIMITS |      |      |       |
|------------------|-----------------------------------------------------------------------------------|--------|------|------|-------|
| Symbol           |                                                                                   | Min.   | Тур. | Max. | Units |
| CIN              | DS <sub>1</sub> , MD Input Capacitance                                            |        | 9    | 12   | pf    |
| C <sub>IN</sub>  | DS <sub>2</sub> , CLR, STB, DI <sub>1</sub> —DI <sub>8</sub><br>Input Capacitance |        | 5    | 9    | pf    |
| С <sub>ОUT</sub> | DO <sub>1</sub> –DO <sub>8</sub> Output Capacitance                               |        | 8    | 12   | pf    |

NOTE:

(1) This parameter is periodically sampled and is not 100% tested. Condition of measurement is f = 1 MHz, V<sub>BIAS</sub> = 2.5V, V<sub>CC</sub> = 5V and T<sub>A</sub> = 25°C.

# WAVEFORMS



# TYPICAL A.C. AND D.C. CHARACTERISTICS



OUTPUT CURRENT VS. OUTPUT "HIGH" VOLTAGE



# OUTPUT CURRENT VS. OUTPUT "LOW" VOLTAGE



OUTPUT "LOW" VOLTAGE (V)

DATA TO OUTPUT DELAY VS. LOAD CAPACITANCE



WRITE ENABLE TO OUTPUT DELAY VS. TEMPERATURE



DATA TO OUTPUT DELAY VS. TEMPERATURE



# **TYPICAL CONFIGURATIONS**

# GATED BUFFER (TRI-STATE)



# INTERRUPTING INPUT PORT



# **OUTPUT PORT (WITH HAND-SHAKING)**



### BI-DIRECTIONAL BUS DRIVER



# intel

The Intel®3214 Interrupt Control Unit (ICU) implements multi-level interrupt capability for systems designed with Series 3000 computing elements.

The ICU accepts an asynchronous interrupt strobe from the 3001 Microprogram Control Unit or a bit in microprogram memory and generates a synchronous interrupt acknowledge and an interrupt vector which may be directed to the MCU or CP Array to uniquely identify the interrupt source.

The ICU is fully expandable in 8-level increments and provides the following system capabilities:

Eight unique priority levels per ICU

Automatic Priority Determination

Programmable Status

N-level expansion capability

Automatic interrupt vector generation

# SCHOTTKY BIPOLAR LSI MICROCOMPUTER SET

High Performance - 80 ns Cycle Time

Compatible with Intel 3001 MCU and

8-Bit Priority Interrupt Request Latch

3-Bit Priority Encoder with Open

**4-Bit Priority Status Latch** 

DTL and TTL Compatible

8-Level Priority Comparator

**Collector Outputs** 

Fully Expandable

24-Pin DIP

3002 CPE

# 3214 INTERRUPT CONTROL UNIT

# PACKAGE CONFIGURATION





# **PIN DESCRIPTION**

| PIN   | SYMBOL                         | NAME AND FUNCTION                                                                                                                                                                                                                                                                                                                                      | TYPE <sup>(1)</sup>      |
|-------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| 1–3   | B <sub>0</sub> -B <sub>2</sub> | Current Status Inputs                                                                                                                                                                                                                                                                                                                                  | Active LOW               |
|       |                                | The Current Status inputs carry the binary value modulo 8 of the current priority level to the current status latch.                                                                                                                                                                                                                                   |                          |
| 4     | SGS                            | Status Group Select Input                                                                                                                                                                                                                                                                                                                              | Active LOW               |
|       |                                | The Status Group Select input informs the ICU that the current priority level does belong to the group level assigned to the ICU.                                                                                                                                                                                                                      |                          |
| 5     | IA                             | Interrupt Acknowledge                                                                                                                                                                                                                                                                                                                                  | Active LOW               |
|       |                                | The Interrupt Acknowledge Output will only be active from the ICU<br>(multi-ICU system) which has received a priority request at a level<br>superior to the current status. It signals the controlled device (usually<br>the processor) and the other ICUs OR-tied on the Interrupt Acknowledge<br>line that an interrupt request has been recognized. | Open-Collector<br>Output |
|       |                                | The IA signal also sets the Interrupt Disable flip-flop (it overrides the clear function of the ECS input).                                                                                                                                                                                                                                            |                          |
| 6     | CLK                            | Clock Input                                                                                                                                                                                                                                                                                                                                            |                          |
|       |                                | The Clock input is used to synchronize the interrupt acknowledge with the operation of the device which it controls.                                                                                                                                                                                                                                   |                          |
| 7     | ISE                            | Interrupt Strobe Enable Input                                                                                                                                                                                                                                                                                                                          |                          |
|       |                                | The Interrupt Strobe Enable input informs the ICU that it is authorized to enter the interrupt mode.                                                                                                                                                                                                                                                   |                          |
| 8–10  | A <sub>0</sub> -A <sub>2</sub> | Request Level Outputs                                                                                                                                                                                                                                                                                                                                  | Active LOW               |
|       |                                | When valid, the Request Level outputs carry the binary value (modulo 8) of the highest priority request present at the priority request inputs or stored in the priority request latch. The request level outputs can become active only with the ICU which has received the highest priority request with a level superior to the current status.     | Open-Collector           |
| 11    | ELR                            | Enable Level Read Input                                                                                                                                                                                                                                                                                                                                | Active LOW               |
|       |                                | When active, the Enable Level Read input enables the Request Level output buffers $(A_0-A_2)$ .                                                                                                                                                                                                                                                        |                          |
| 12    | GND                            | Ground                                                                                                                                                                                                                                                                                                                                                 |                          |
| 13    | ETLG                           | Enable This Level Group Input                                                                                                                                                                                                                                                                                                                          |                          |
|       |                                | The Enable This Level Group input allows a higher priority ICU in multi-<br>ICU systems to inhibit interrupts within the next lower priority ICU<br>(and all the following ICUs).                                                                                                                                                                      |                          |
| 14    | ENLG                           | Enable Next Level Group Output                                                                                                                                                                                                                                                                                                                         |                          |
|       |                                | The Enable Next Level Group output allows the ICU to inhibit inter-<br>rupts within the lower priority ICU in a multi-ICU system.                                                                                                                                                                                                                      |                          |
| 15—22 | R <sub>0</sub> -R <sub>7</sub> | Priority Interrupt Request Inputs                                                                                                                                                                                                                                                                                                                      | Active LOW               |
|       |                                | The Priority Interrupt Request inputs are the inputs of the priority Interrupt Request Latch. The lowest priority level interrupt request signal is attached to $R_0$ and the highest is attached to $R_7$ .                                                                                                                                           |                          |
| 23    | ECS                            | Enable Current Status Input                                                                                                                                                                                                                                                                                                                            | Active LOW               |
|       |                                | The Enable Current Status input controls the current status latch<br>and the clear function of the Interrupt Inhibit flip-flop.                                                                                                                                                                                                                        |                          |
| 24    | V <sub>CC</sub>                | +5 Volt Supply                                                                                                                                                                                                                                                                                                                                         |                          |

NOTE:

(1) Active HIGH, unless otherwise noted.

# FUNCTIONAL AND LOGICAL DESCRIPTION

The ICU adds interrupt capability to suitably microprogrammed processors or controllers. One or more of these units allows external signals called interrupt requests to cause the processor/controller to suspend execution of the active process, save its status, and initiate execution of a new task as requested by the interrupt signal.

It is customary to strobe the ICU at the end of each instruction execution. At that time, if an interrupt request is acknowledged by the ICU, the MCU is forced to follow the interrupt microprogram sequence.

Figure 1 shows the block diagram of the ICU. Interrupt requests pass through the interrupt request latch and priority encoder to the magnitude comparator. The output of the priority encoder is the binary equivalent of the highest active priority request. At the comparator, this value is compared with the Current Status (currently active priority level) contained in the current status latch. A request, if acknowledged at interrupt strobe time, will cause the interrupt flip-flop to enter the "interrupt active" state for one microinstruction cycle. This action causes the interrupt acknowledge (IA) signal to go low and sets the interrupt disable flip-flop.

The IA signal constitutes the interrupt command to the processor. It can directly force entry into the interrupt service routine as demonstrated in the appendix. As part of this routine, the microprogram normally reads the requesting level via the request level output bus. This information which is saved in the request latch can be enabled onto one of the processor input data buses using the enable level read input. Once the interrupt handler has determined the requesting level, it normally writes this level back into the current status register of the ICU. This action resets the interrupt disable flipflop and acts to block any further request at this level or lower levels.

Entry into a macro level interrupt service routine may be vectored using the request level information to generate a subroutine address which corresponds to the level. Exit from such a macroprogram should normally restore the prior status in the current status latch.

The Enable This Level Group (ETLG) input and the Enable Next Level Group (ENLG) output can be used in a daisy chain fashion, as each ICU is capable of inhibiting interrupts from all of the following ICUs in a multiple ICU configuration. The interrupt acknowledge flip-flop is set to the active LOW state on the rising edge of the clock when the following conditions are met:

An active request level  $(R_0-R_7)$  is greater than the current status  $B_0-B_2$ 

The interrupt mode (ISE) is active

ETLG is enabled

The interrupt disable flip-flop is reset

When active, the IA signal asynchronously sets the disable flip-flop and holds the requests in the request latch until new current status information ( $B_0-B_2$ , SGS) is enabled (ECS) into the current status latch. The disable flip-flop is reset at the completion of this load operation.

During this process, ENLG will be enabled only if the following conditions are met:

ETLG is enabled

The current status (SGS) does not belong to this level group

There is no active request at this level

The request level outputs  $A_0-A_2$  and the IA output are open-collector to permit bussing of these lines in multi-ICU configuration.



# D.C. AND OPERATING CHARACTERISTICS

# **ABSOLUTE MAXIMUM RATINGS\***

| Temperature Under Bia | as |      |     |    |  |  |  |  |  |  |   |   |  |  |  |  |  |  |                 |
|-----------------------|----|------|-----|----|--|--|--|--|--|--|---|---|--|--|--|--|--|--|-----------------|
| Ceramic               |    |      |     |    |  |  |  |  |  |  |   |   |  |  |  |  |  |  | 65°C to +75°C   |
| Plastic               |    |      |     |    |  |  |  |  |  |  |   |   |  |  |  |  |  |  | 0°C to +75°C    |
| Storage Temperature   |    |      |     |    |  |  |  |  |  |  | • |   |  |  |  |  |  |  | –65°C to +160°C |
| All Output and Supply | v  | olta | age | s. |  |  |  |  |  |  |   |   |  |  |  |  |  |  | 0.5V to +7V     |
| All Input Voltages .  |    |      |     |    |  |  |  |  |  |  |   |   |  |  |  |  |  |  | 1.0V to +5.5V   |
| Output Currents       |    |      |     |    |  |  |  |  |  |  |   | • |  |  |  |  |  |  | 100 mA          |

\*COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

| SYMBOL          | PARAMETER                           |                                                 | MIN | LIMITS<br>TYP <sup>(1)</sup> | MAX           | UNIT     | CONDITIONS               |
|-----------------|-------------------------------------|-------------------------------------------------|-----|------------------------------|---------------|----------|--------------------------|
| v <sub>c</sub>  | Input Clamp Voltage (all            | nputs)                                          |     |                              | -1.0          | v        | I <sub>C</sub> = -5 mA   |
| ۱ <sub>F</sub>  | Input Forward Current:              | ETLG input<br>all other inputs                  |     | 15<br>08                     | -0.5<br>-0.25 | mA<br>mA | V <sub>F</sub> = 0.45V   |
| I <sub>R</sub>  | Input Reverse Current:              | ETLG input<br>all other inputs                  |     |                              | 80<br>40      | μΑ<br>μΑ | V <sub>R</sub> = 5.25V   |
| VIL             | Input LOW Voltage:                  | all inputs                                      |     |                              | 0.8           | v        | V <sub>CC</sub> = 5.0V   |
| v <sub>IH</sub> | Input HIGH Voltage:                 | all inputs                                      | 2.0 |                              |               | V        | V <sub>CC</sub> = 5.0V   |
| 'cc             | Power Supply Current <sup>(2)</sup> |                                                 |     | 90                           | 130           | mA       |                          |
| V <sub>OL</sub> | Output LOW Voltage:                 | all outputs                                     |     | .3                           | .45           | v        | I <sub>OL</sub> = 15 mA  |
| v <sub>OH</sub> | Output HIGH Voltage:                | ENLG output                                     | 2.4 | 3.0                          |               | v        | I <sub>OH</sub> = -1 mA  |
| IOS             | Short Circuit Output Curr           | ent: ENLG output                                | -20 | -35                          | -55           | mA       | V <sub>CC</sub> = 5.0V   |
| ICEX            | Output Leakage Current:             | IA and<br>A <sub>0</sub> A <sub>2</sub> outputs |     |                              | 100           | μΑ       | V <sub>CEX</sub> = 5.25V |

# $T_A = 0^{\circ}C$ to +75°C, $V_{CC} = 5.0V \pm 5\%$

NOTES:

<sup>(1)</sup>Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage. <sup>(2)</sup>B<sub>0</sub>-B<sub>2</sub>, SGS, CLK, R<sub>0</sub>-R<sub>4</sub> grounded, all other inputs and all outputs open.

# A.C. CHARACTERISTICS

 $T_A = 0^{\circ}C \text{ to } +75^{\circ}C, V_{CC} = +5V \pm 5\%$ 

| SYMBOL                         | PARAMETER                                                                              | MIN | LIMITS<br>TYP <sup>(1)</sup> | MAX | UNIT            |
|--------------------------------|----------------------------------------------------------------------------------------|-----|------------------------------|-----|-----------------|
| tCY                            | CLK Cycle Time                                                                         | 80  |                              |     | ns              |
| <sup>t</sup> PW                | CLK, ECS, IA Pulse Width                                                               | 25  | 15                           |     | ns              |
|                                | Interrupt Flip-Flop Next State Determination:                                          |     |                              |     |                 |
| <sup>t</sup> ISS               | ISE Set-Up Time to CLK                                                                 | 16  | 12                           |     | ns              |
| <sup>t</sup> ISH               | ISE Hold Time After CLK                                                                | 20  | 10                           |     | ns              |
| tetcs <sup>2</sup>             | ETLG Set-Up Time to CLK                                                                | 25  | 12                           |     | ns              |
| tetch <sup>2</sup>             | ETLG Hold Time After CLK                                                               | 20  | 10                           |     | ns              |
| teccs <sup>3</sup>             | ECS Set-Up Time to CLK (to clear interrupt inhibit prior to CLK)                       | 80  | 25                           |     | ns              |
| <sup>t</sup> ECCH <sup>3</sup> | ECS Hold Time After CLK (to hold interrupt inhibit)                                    | 0   |                              |     | ns              |
| tecrs <sup>3</sup>             | ECS Set-Up Time to CLK (to enable new requests through the request latch)              | 110 | 70                           |     | ns              |
| tecrh <sup>3</sup>             | ECS Hold Time After CLK (to hold requests in request latch)                            | 0   |                              |     |                 |
| tecss <sup>2</sup>             | ECS Set-Up Time to CLK (to enable new status through the status latch)                 | 75  | 70                           |     | ns              |
| tecsh <sup>2</sup>             | ECS Hold Time After CLK (to hold status in status latch)                               | 0   |                              |     | ns              |
| tDCS <sup>2</sup>              | SGS and $B_0-B_2$ Set-Up Time to CLK (current status latch enabled)                    | 70  | 50                           |     | ns              |
| <sup>t</sup> DCH <sup>2</sup>  | SGS and $B_0-B_2$ Hold Time After CLK (current status latch enabled)                   | 0   |                              |     | ns              |
| t <sub>RCS</sub> 3             | Rg-R7 Set-Up Time to CLK (request latch enabled)                                       | 90  | 55                           |     | ns              |
| <sup>t</sup> RCH <sup>3</sup>  | Rg-R7 Hold Time After CLK (request latch enabled)                                      | 0   |                              |     | ns              |
| <sup>t</sup> ICS               | IA Set-Up Time to CLK (to set interrupt inhibit F.F. before CLK)                       | 55  | 35                           |     | ns              |
| <sup>t</sup> CI                | CLK to IA Propagation Delay                                                            |     | 15                           | 25  | ns              |
|                                | Contents of Request Latch and Request Level Output Status Determination:               |     |                              |     |                 |
| <sup>t</sup> RIS <sup>4</sup>  | R <sub>Ø</sub> -R <sub>7</sub> Set-Up Time to IA                                       | 10  | 0                            |     | ns              |
| <sup>t</sup> RIH <sup>4</sup>  | R <sub>Ø</sub> -R <sub>7</sub> Hold Time After IA                                      | 35  | 20                           |     | ns              |
| <sup>t</sup> RA                | $R_0$ - $R_7$ to $A_0$ - $A_2$ Propagation Delay (request latch enabled)               |     | 80                           | 100 | ns              |
| <sup>t</sup> ELA               | ELR to $A_0 - A_2$ Propagation Delay                                                   |     | 40                           | 55  | ns              |
| <sup>t</sup> ECA               | ECS to $A_{0}$ - $A_{2}$ Propagation Delay (to enable new requests through request lat | ch) | 100                          | 120 | ns <sup>,</sup> |
| <sup>t</sup> ETA               | ETLG to Ag-A <sub>2</sub> Propagation Delay                                            |     | 35                           | 70  | ns              |

# 3214

# A.C. CHARACTERISTICS (CON'T)

| SYMBOL                         | PARAMETER                                                                      | MIN | LIMITS<br>TYP <sup>(1)</sup> | MAX | UNIT |
|--------------------------------|--------------------------------------------------------------------------------|-----|------------------------------|-----|------|
|                                | Contents of Current Priority Status Latch Determination:                       |     |                              |     |      |
| tDECS <sup>4</sup>             | SGS and $B_{0}$ - $B_{2}$ Set-Up Time to ECS                                   | 15  | 10                           |     | ns   |
| <sup>t</sup> DECH <sup>4</sup> | SGS and $B_0-B_2$ Hold Time After ECS                                          | 15  | 10                           |     | ns   |
|                                | Enable Next Level Group Determination:                                         |     |                              |     |      |
| tREN                           | Rg-R7 to ENLG Propagation Delay                                                |     | 45                           | 70  | ns   |
| <sup>t</sup> ETEN              | ETLG to ENLG Propagation Delay                                                 |     | 20                           | 25  | ns   |
| <sup>t</sup> ECRN              | ECS to ENLG Propagation Delay (enabling new request through the request latch) |     | 85                           | 90  | ns   |
| <sup>t</sup> ECSN              | ECS to ENLG Propagation Delay (enabling new SGS through status latch)          |     | 35                           | 55  | ns   |

NOTES:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

(2) Required for proper operation if ISE is enabled during next clock pulse.

(3) These times are not required for proper operation but for desired change in interrupt flip-flop.

(4) Required for new request or status to be properly loaded.

(5) tCY = tICS + tCI

# TEST CONDITIONS: TEST LOAD CIRCUIT Input pulse amplitude: 2.5 volts. Input rise and fall times: 5 ns between 1 and 2 volts. Output loading of 15 mA and 30 pf. Speed measurements taken at the 1.5V levels.

# EST LOAD CIRCUIT

# CAPACITANCE<sup>(5)</sup>

# $T_A = 25^{\circ}C$

| SYMBOL                               | PARAMETER                                                              | MIN | LIMITS<br>TYP <sup>(1)</sup> | МАХ | UNIT |
|--------------------------------------|------------------------------------------------------------------------|-----|------------------------------|-----|------|
| C <sub>IN</sub>                      | Input Capacitance                                                      |     | 5                            | 10  | pf   |
| с <sub>оит</sub>                     | Output Capacitance                                                     |     | 7                            | 12  | pf   |
| TEST CONE<br>V <sub>BIAS</sub> = 2.5 | DITIONS:<br>5V, V <sub>CC</sub> = 5V, T <sub>A</sub> = 25°C, f = 1 MHz |     |                              |     |      |

NOTE:

<sup>(5)</sup>This parameter is periodically sampled and not 100% tested.

# D.C. AND OPERATING CHARACTERISTICS

# **ABSOLUTE MAXIMUM RATINGS\***

| Temperature Under Bias         |      |                    |                    |
|--------------------------------|------|--------------------|--------------------|
| CerDip                         | <br> |                    | <br>               |
| Storage Temperature            | <br> |                    | <br>65°C to +160°C |
| All Output and Supply Voltages | <br> |                    | <br>–0.5V to +7V   |
| All Input Voltages             | <br> |                    | <br>–1.0V to +5.5V |
| Output Currents                | <br> | ·<br>· · · · · · · | <br>               |

MILITARY TEMP.

\*COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability.

# $T_A$ = -55°C to +125°C; $V_{CC}$ = 5.0V ± 10%

| SYMBOL          | PARAMETER                           |                                     | MIN | LIMITS<br>TYP <sup>(1)</sup> | МАХ           | UNIT     | CONDITIONS              |
|-----------------|-------------------------------------|-------------------------------------|-----|------------------------------|---------------|----------|-------------------------|
| v <sub>c</sub>  | Input Clamp Voltage (all i          | nputs)                              |     |                              | -1.2          | v        | I <sub>C</sub> = -5 mA  |
| ۱ <sub>F</sub>  | Input Forward Current:              | ETLG input<br>all other inputs      |     | 15<br>08                     | -0.5<br>-0.25 | mA<br>mA | V <sub>F</sub> = 0.45V  |
| I <sub>R</sub>  | Input Reverse Current:              | ETLG input<br>all other inputs      |     |                              | 80<br>40      | μΑ<br>μΑ | V <sub>R</sub> = 5.5V   |
| VIL             | Input LOW Voltage:                  | all inputs                          |     |                              | 0.8           | v        | V <sub>CC</sub> = 5.0V  |
| v <sub>IH</sub> | Input HIGH Voltage:                 | all inputs                          | 2.0 |                              |               | v        | V <sub>CC</sub> = 5.0V  |
| lcc             | Power Supply Current <sup>(2)</sup> |                                     |     | 90                           | 130           | mA       |                         |
| V <sub>OL</sub> | Output LOW Voltage:                 | all outputs                         |     | .3                           | .45           | v        | I <sub>OL</sub> = 10 mA |
| v <sub>он</sub> | Output HIGH Voltage:                | ENLG output                         | 2.4 | 3.0                          |               | v        | I <sub>OH</sub> = -1 mA |
| IOS             | Short Circuit Output Curr           | ent: ENLG output                    | ~15 | -35                          | -55           | mA       | V <sub>CC</sub> = 5.0V  |
| ICEX            | Output Leakage Current:             | IA and<br>Ag-A <sub>3</sub> outputs |     |                              | 100           | μΑ       | V <sub>CEX</sub> = 5.5V |

NOTES:

(1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

(2)  $B_0-B_2$ , SGS, CLK,  $R_0-R_4$  grounded, all other inputs and all outputs open.

# A.C. CHARACTERISTICS

 $T_A = -55^{\circ}C$  to  $+125^{\circ}C$ ;  $V_{CC} = 5.0V \pm 10\%$ 

| SYMBOL                         | PARAMETER                                                                             | MIN  | LIMITS<br>TYP <sup>(1)</sup> | MAX | UNIT |
|--------------------------------|---------------------------------------------------------------------------------------|------|------------------------------|-----|------|
| <sup>t</sup> CY                | CLK Cycle Time <sup>(5)</sup>                                                         | 85   |                              |     | ns   |
| <sup>t</sup> PW                | CLK, ECS, IA Pulse Width                                                              | 25   | 15                           |     | ns   |
|                                | Interrupt Flip-Flop Next State Determination:                                         |      |                              |     |      |
| tiss                           | ISE Set-Up Time to CLK                                                                | 16   | 12                           |     | ns   |
| <sup>t</sup> ISH               | ISE Hold Time After CLK                                                               | 20   | 10                           |     | ns   |
| tetcs <sup>2</sup>             | ETLG Set-Up Time to CLK                                                               | 25   | 12                           |     | ns   |
| <sup>t</sup> etch <sup>2</sup> | ETLG Hold Time After CLK                                                              | 20   | 10                           |     | ns   |
| teccs <sup>3</sup>             | ECS Set-Up Time to CLK (to clear interrupt inhibit prior to CLK)                      | 85   | 25                           |     | ns   |
| tecch3                         | ECS Hold Time After CLK (to hold interrupt inhibit)                                   | 0    |                              |     | ns   |
| tecrs <sup>3</sup>             | ECS Set-Up Time to CLK (to enable new requests through the request latch)             | 110  | 70                           |     | ns   |
| tecrh <sup>3</sup>             | ECS Hold Time After CLK (to hold requests in request latch)                           | 0    |                              |     |      |
| tecss <sup>2</sup>             | ECS Set-Up Time to CLK (to enable new status through the status latch)                | 85   | 70                           |     | ns   |
| tecsh <sup>2</sup>             | ECS Hold Time After CLK (to hold status in status latch)                              | 0    |                              |     | ns   |
| tDCS <sup>2</sup>              | SGS and $B_0-B_2$ Set-Up Time to CLK (current status latch enabled)                   | 90   | 50                           |     | ns   |
| <sup>t</sup> DCH <sup>2</sup>  | SGS and $B_0-B_2$ Hold Time After CLK (current status latch enabled)                  | 0    |                              |     | ns   |
| <sup>t</sup> RCS <sup>3</sup>  | Rg-R7 Set-Up Time to CLK (request latch enabled)                                      | 100  | 55                           |     | ns   |
| <sup>t</sup> rch <sup>3</sup>  | $R_{m{0}}$ - $R_7$ Hold Time After CLK (request latch enabled)                        | 0    |                              |     | ns   |
| tics                           | IA Set-Up Time to CLK (to set interrupt inhibit F.F. before CLK)                      | 55   | 35                           |     | ns   |
| <sup>t</sup> CI                | CLK to IA Propagation Delay                                                           |      | 15                           | 30  | ns   |
|                                | Contents of Request Latch and Request Level Output Status Determination:              |      |                              |     |      |
| <sup>t</sup> RIS <sup>4</sup>  | Rg-R7 Set-Up Time to IA                                                               | 10   | 0                            |     | ns   |
| <sup>t</sup> RIH <sup>4</sup>  | R <sub>Ø</sub> -R <sub>7</sub> Hold Time After IA                                     | 35   | 20                           |     | ns   |
| <sup>t</sup> RA                | $R_{0}$ - $R_{7}$ to $A_{0}$ - $A_{2}$ Propagation Delay (request latch enabled)      |      | 80                           | 100 | ns   |
| <sup>t</sup> ELA               | ELR to Ag-A2 Propagation Delay                                                        |      | 40                           | 55  | ns   |
| <sup>t</sup> ECA               | ECS to $A_{m Q}$ - $A_2$ Propagation Delay (to enable new requests through request la | tch) | 100                          | 130 | ns   |
| <sup>t</sup> ETA               | ETLG to Ag-A <sub>2</sub> Propagation Delay                                           |      | 35                           | 70  | ns   |

MILITARY TEN

# A.C. CHARACTERISTICS (CON'T)

|                                |                                                                                | M   | IL IT                        |             | 3214 |
|--------------------------------|--------------------------------------------------------------------------------|-----|------------------------------|-------------|------|
| A.C. CHA                       | RACTERISTICS (CON'T)                                                           |     |                              | <b>I</b> RY | TEMP |
| SYMBOL                         | PARAMETER                                                                      | MIN | LIMITS<br>TYP <sup>(1)</sup> | MAX         | UNIT |
|                                | Contents of Current Priority Status Latch Determination:                       |     |                              |             |      |
| tDECS <sup>4</sup>             | SGS and $B_{0}$ - $B_{2}$ Set-Up Time to ECS                                   | 20  | 10                           |             | ns   |
| <sup>t</sup> DECH <sup>4</sup> | SGS and $B_0-B_2$ Hold Time After ECS                                          | 20  | 10                           |             | ns   |
|                                | Enable Next Level Group Determination:                                         |     |                              |             |      |
| <sup>t</sup> REN               | R <sub>Ø</sub> -R <sub>7</sub> to ENLG Propagation Delay                       |     | 45                           | 70          | ns   |
| <sup>t</sup> ETEN              | ETLG to ENLG Propagation Delay                                                 |     | 20                           | 30          | ns   |
| <sup>t</sup> ECRN              | ECS to ENLG Propagation Delay (enabling new request through the request latch) |     | 85                           | 110         | ns   |
| <sup>t</sup> ECSN              | ECS to ENLG Propagation Delay (enabling new SGS through status latch)          |     | 35                           | 55          | ns   |

NOTES:

<sup>(1)</sup> Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

(2) Required for proper operation if ISE is enabled during next clock pulse.

(3) These times are not required for proper operation but for desired change in interrupt flip-flop.

(4) Required for new request or status to be properly loaded.

(5)  $t_{CY} = t_{ICS} + t_{CI}$ 

# TEST CONDITIONS: v<sub>cc</sub> **TEST LOAD CIRCUIT** Input pulse amplitude: 2,5 volts. Input rise and fall times: 5 ns between 1 and 2 volts. **≤ 300**Ω Output loading of 15 mA and 30 pf. OUT O Speed measurements taken at the 1.5V levels. **≤ 600**Ω = 30 pf

# CAPACITANCE<sup>(5)</sup>

# $T_{\Delta} = 25^{\circ}C$

| SYMBOL                              | PARAMETER                                                              | MIN | LIMITS<br>TYP <sup>(1)</sup> | МАХ | UNIT |
|-------------------------------------|------------------------------------------------------------------------|-----|------------------------------|-----|------|
| CIN                                 | Input Capacitance                                                      |     | 5                            | 10  | pf   |
| с <sub>оит</sub>                    | Output Capacitance                                                     |     | 7                            | 12  | pf   |
| TEST CONI<br>V <sub>BLAS</sub> = 2. | DITIONS:<br>5V, V <sub>CC</sub> = 5V, T <sub>A</sub> = 25°C, f = 1 MHz |     |                              |     |      |

NOTE:

<sup>(5)</sup>This parameter is periodically sampled and not 100% tested.

# WAVEFORMS



# TYPICAL CONFIGURATIONS

The ICU has been designed for use with the INTEL Series 3000 Bipolar Microcomputer Set. It operates from the single common system clock and can accept an interrupt strobe (ISE) generated by the 3001 Micropgoram Control Unit or by a bit in microprogram memory as shown in Figures 2 and 3.

The ICU responds to interrupt requests of sufficient priority by entering the interrupt active mode. Its output (IA) can be tied to the row enable input (ERA) of the 3001 MCU. This gates an alternate row address onto the microprogram memory address bus which forces the system to execute an interrupt handling routine. Alternatively, the ICU output can be used to directly modify the MCU jump instruction (AC inputs) so that the next microprogram address corresponds to the start of the interrupt routine rather than the start of the macroinstruction fetch sequence. Of course, in the case of this particular implementation, the interrupt strobe must be generated one clock period earlier and the ISE output of the MCU should not be used.

As shown in Figure 4, when several ICUs are used together to provide a

multiple of 8 priority levels, most control lines will be bussed. The Intel 3205 Decoder may be used to decode the high order bits of the request level, the information being derived from the daisy-chain group level signals.

As mentioned in the functional description, the request level information  $(A_0-A_2)$  may be sent to the 3001 MCU or the 3002 CP array as a constant through the Mask (K) bus or as data through the memory (M) or data (I) busses. Similarly, the status information can be generated by the CP array and carried to the ICU by the data (D) output bus of the CP array.

# TYPICAL CONFIGURATIONS (CON'T)



Figure 2. Interfacing 3214 with 3001.

Interrupt strobe generated by MCU. Interrupt routine start address at column 15 row 31. Macro-instruction fetch start address at column 15 row Ø.



Figure 3. Interfacing 3214 with 3001.

Interrupt strobe generated by the microprogram memory. Interrupt routine start address at column 14 row Ø. Macro-instruction fetch start address at column 15 row Ø.



Figure 4. Using Several 3214 Interrupt Chips to Provide more than Eight Priority Levels. (The 3214 at the upper right is used to encode the high order bits of the requesting level)

# intel

The INTEL<sup>®</sup> 3216 is a high-speed 4-bit Parallel, Bidirectional Bus Driver. Its three-state outputs enable it to isolate and drive external bus structures associated with Series 3000 systems

The INTEL 3226 is a high-speed 4-bit Parallel, Inverting Bidirectional Bus Driver. Its three-state outputs enable it to isolate and drive external bus structures associated with Series 3000 systems.

The 3216/3226 driver and receiver gates have three state outputs with PNP inputs. When the drivers or receivers are tri-stated the inputs are disabled, presenting a low current load, typically less than 40  $\mu$ amps, to the system bus structure.

# SCHOTTKY BIPOLAR LSI MICROCOMPUTER SET

High Performance – 25 ns typical propagation delay Low Input Load Current – 0.25 mA maximum High Output Drive Capability for Driving System Data Busses Three-State Outputs TTL Compatible 16-pin DIP

# 3216/3226 PARALLEL BIDIRECTIONAL BUS DRIVER

# PACKAGE CONFIGURATION







# LOGIC DIAGRAM 3216



# LOGIC DIAGRAM 3226



# D.C. AND OPERATING CHARACTERISTICS

# **ABSOLUTE MAXIMUM RATINGS\***

| Temperature Under Bia | as |      |     |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |      |      |      |     |
|-----------------------|----|------|-----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|------|------|------|-----|
| Ceramic               |    |      |     |   |   |   |   |   | • |   |   | • |   |   |   |   |   |   |   |   | -65° | C to | o +7 | 5°C |
| Plastic               | ·  |      |     | • | · | • | • |   | • | • | • | • |   |   | • | • | • | · | • |   | 0°   | C to | o +7 | 5°C |
| Storage Temperature   |    |      |     |   | • |   |   |   | • | • |   |   | • | • |   |   | • |   |   | - | 65°C | ; to | +16  | 0°C |
| All Output and Supply | Vo | ltag | es. |   |   |   | • | • |   |   |   |   | • |   |   |   |   |   |   |   | -0   | .5V  | to - | +7V |
| All Input Voltages .  |    |      |     |   | • |   | · | • | • | • |   |   | • | • |   |   |   |   |   |   | -1.0 | V t  | o +5 | .5V |
| Output Currents       |    |      |     |   | • |   |   | • | • |   |   |   |   |   |   |   |   |   |   |   |      |      | 125  | mA  |

\*COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

|                |                              |      | Limit |       |      |                                  |
|----------------|------------------------------|------|-------|-------|------|----------------------------------|
| Symbol         | Parameter                    | Min. | Тур.  | Max.  | Unit | Condition                        |
| ١ <sub>F</sub> | Input Load Current           |      |       |       |      |                                  |
|                | DCE, CS Inputs               |      | -0.15 | -0.5  | mA   | V <sub>F</sub> = 0.45V           |
|                | All Other Inputs             |      | -0.08 | -0.25 | mA   |                                  |
| l <sub>B</sub> | Input Leakage Current        |      |       |       |      |                                  |
|                | DCE, CS Inputs               |      |       | 80    | μA   | V <sub>R</sub> = 5.25∨           |
|                | DI Inputs                    |      |       | 40    | μA   |                                  |
| v <sub>c</sub> | Input Clamp Voltage          |      |       | -1    | v    | I <sub>C</sub> = -5mA            |
| VIL            | Input Low Voltage            |      |       | 0.95  | v    | V <sub>CC</sub> = 5.0V           |
| VIH            | Input High Voltage           | 2.0  |       |       | v    | V <sub>CC</sub> = 5.0V           |
| Vol 1          | Output Low Voltage           |      | 0.3   | 0.45  | v    | DO Outputs IOI =15mA             |
| 021            | DO, DB Outputs               |      |       |       |      | DB Outputs I <sub>OL</sub> =25mA |
| Vola           | Output Low Voltage           |      | 05    | 0.6   | v    | DB Outputs Iou = 50mA            |
| VOL2           | DB Outputs Only              |      | 0.0   | 0.0   | •    |                                  |
| N/             | Output High Voltage          | 2 65 | 4.0   |       | V    | 1 - 1 - 1 - 1                    |
| VOH1           | DO Outputs Only              | 3.05 | 4.0   |       | v    | OHIIIA                           |
|                |                              |      |       |       |      |                                  |
| VOH2           | Output High Voltage          | 2.4  | 3.0   |       | V    | l <sub>OH</sub> ≖-10mA           |
|                | DB Outputs Only              |      |       |       |      |                                  |
| Isc            | Output Short Circuit Current |      |       |       |      |                                  |
|                | DO Outputs                   | -15  | -35   | -65   | mA   | V <sub>CC</sub> = 5.0V           |
|                | DB Outputs                   | -30  | -75   | -120  | mA   |                                  |
|                | Output Leakage Current       |      |       |       |      |                                  |
|                | High Impedance State         |      |       |       |      |                                  |
|                | DO Outputs                   |      |       | 20    | μΑ   | V <sub>O</sub> =0.45V/5.25V      |
|                | DB Outputs                   |      |       | 100   | μΑ   |                                  |
| lcc            | Power Supply Current 3216    |      | 95    | 130   | mA   |                                  |
|                | 3226                         |      | 85    | 120   | mA   | •                                |

# $T_{A}$ = 0°C to +75°C, $V_{CC}$ = +5.0V $\pm 5\%$

NOTE: Typical values are for  $T_A = 25^{\circ}C$ 

# **A.C. CHARACTERISTICS** $T_A = 0^{\circ}C$ to +75°C, $V_{CC} = +5.0V \pm 5\%$

| Symbol           | Parameter                      |      | Min. | Limit<br>Typ. | Max. | Unit  | Condition                                                                                   |
|------------------|--------------------------------|------|------|---------------|------|-------|---------------------------------------------------------------------------------------------|
| T <sub>PD1</sub> | Input to Output Delay          | 3216 |      | 15            | 25   | ns    | C <sub>L</sub> =30pF, R <sub>1</sub> =300Ω,                                                 |
|                  | DO Outputs                     | 3226 |      | 14            | 25   |       | R <sub>2</sub> ≈600\2                                                                       |
| T <sub>PD2</sub> | Input to Output Delay          | 3216 |      | 19            | 30   | ns    | C <sub>L</sub> ≈300pF, R₁=90Ω,                                                              |
|                  | DB Outputs                     | 3226 |      | 16            | 25   |       | R <sub>2</sub> =180Ω                                                                        |
| Τ <sub>Ε</sub>   | Output Enable Time             | 3216 |      | 42            | 65   | ns(2) | DO Outputs: C <sub>L</sub> =30pF,                                                           |
|                  | DCE, CS                        | 3226 |      | 36            | 54   |       | R <sub>1</sub> =300Ω/10ΚΩ,<br>R <sub>2</sub> =600Ω/1ΚΩ                                      |
|                  |                                |      |      |               |      |       | DB Outputs: C <sub>L</sub> =300pF,<br>R <sub>1</sub> =90Ω/10KΩ,<br>R <sub>2</sub> =180Ω/1KΩ |
| Τ <sub>ΰ</sub>   | Output Disable Time<br>DCE, CS |      |      | 16            | 35   | ns(2) | DO Outputs: C <sub>L</sub> =5pF,<br>R <sub>1</sub> =300Ω/10KΩ,<br>R <sub>2</sub> =600Ω/1KΩ  |
|                  |                                |      |      |               |      |       | DB Outputs: C <sub>L</sub> =5pF,<br>R <sub>1</sub> =90Ω/10KΩ,<br>R <sub>2</sub> =180Ω/1KΩ   |

NOTE: (1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

(2) The test load circuit is set for worst case source and sink loading on the outputs. The two resistor values for R1 and R2 correspond to worst case sink and source loading, respectively.

# CAPACITANCE<sup>(2)</sup> $T_A = 25^{\circ}C$

| Symbol | Parameter          | Min. | Typ. | Max. | Unit |
|--------|--------------------|------|------|------|------|
| CIN    | Input Capacitance  |      | 4    | 6    | pF   |
| COUT   | Output Capacitance |      |      |      |      |
|        | DO Outputs         |      | 6    | 10   | pF   |
|        | DB Outputs         |      | 13   | 18   | рF   |

### Note:

(2) This parameter is periodically sampled and is not 100% tested. Condition of measurement is f = 1MHz, V<sub>BIAS</sub> = 2.5V, V<sub>CC</sub> = 5.0V and T<sub>A</sub> = 25°C.

# WAVEFORMS



# TEST CONDITIONS:

Input pulse amplitude of 2.5V. Input rise and fall times of 5 ns between 1 and 2 volts. Output loading is 5 mA and 10 pF. Speed measurements are made at 1.5 volt levels.

# TEST LOAD CIRCUIT:



vcc

.....

# D.C. AND OPERATING CHARACTERISTICS

# **ABSOLUTE MAXIMUM RATINGS\***

| Femperature Under Bias         |                 |
|--------------------------------|-----------------|
| Ceramic                        | -65°C to +75°C  |
| Storage Temperature            | -65°C to +160°C |
| All Output and Supply Voltages | 0.5V to +7V     |
| All Input Voltages             | 1.0V to +5.5V   |
| Output Currents                | 125 mA          |

MILITARY TI

\*COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

# $T_A = -55^{\circ}C$ to $+125^{\circ}C$ , $V_{CC} = +5.0V \pm 10\%$

|                  |                                                                            |            | Limit          |               |          |                                                                      |
|------------------|----------------------------------------------------------------------------|------------|----------------|---------------|----------|----------------------------------------------------------------------|
| Symbol           | Parameter                                                                  | Min.       | Тур.           | Max.          | Unit     | Condition                                                            |
| IF               | Input Load Current<br>DCE, <del>CS</del> Inputs<br>AII Other Inputs        |            | -0.15<br>-0.08 | -0.5<br>-0.25 | mA<br>mA | V <sub>F</sub> = 0.45V                                               |
| I <sub>R</sub>   | Input Leakage Current<br>DCE, CS Inputs<br>DI Inputs                       |            |                | 80<br>40      | μΑ<br>μΑ | V <sub>R</sub> = 5.5V                                                |
| V <sub>C</sub>   | Input Clamp Voltage                                                        |            |                | -1.2          | V        | I <sub>C</sub> = -5mA                                                |
| VIL              | Input Low Voltage M3216<br>M3226                                           |            |                | 0.95<br>0.90  | v<br>v   | V <sub>CC</sub> = 5.0V                                               |
| VIH              | Input High Voltage                                                         | 2.0        |                |               | v        | V <sub>CC</sub> = 5.0V                                               |
| V <sub>OL1</sub> | Output Low Voltage<br>DO, DB Outputs                                       |            | 0.3            | 0.45          | v        | DO Outputs I <sub>OL</sub> =15mA<br>DB Outputs I <sub>OL</sub> =25mA |
| V <sub>OL2</sub> | Output Low Voltage<br>DB Outputs Only                                      |            | 0.5            | 0.6           | v        | DB Outputs I <sub>OL</sub> = 45mA                                    |
| V <sub>OH1</sub> | Output High Voltage<br>DO Outputs Only                                     | 3.4        | 3.8            |               | v        | I <sub>OH</sub> =-0.5mA<br>I <sub>OH</sub> =-2.0mA                   |
| V <sub>OH2</sub> | Output High Voltage<br>DB Outputs Only                                     | 2.4        | 3.0            |               | v        | I <sub>OH</sub> =-5mA                                                |
| I <sub>SC</sub>  | Output Short Circuit Current<br>DO Outputs<br>DB Outputs                   | -15<br>-30 | -35<br>-75     | -65<br>-120   | mA<br>mA | V <sub>CC</sub> = 5.0V                                               |
| <sup>I</sup> o   | Output Leakage Current<br>High Impedance State<br>DO Outputs<br>DB Outputs |            |                | 20<br>100     | μΑ<br>μΑ | V <sub>O</sub> =0.45V/5.5V                                           |
| lcc              | Power Supply Current M3216<br>M3226                                        |            | 95<br>85       | 130<br>120    | mA<br>mA |                                                                      |

NOTE: Typical values are for  $T_A = 25^{\circ}C$ 

| Limit |                                     |       |      |      |      |                                                        |                                                                                |  |
|-------|-------------------------------------|-------|------|------|------|--------------------------------------------------------|--------------------------------------------------------------------------------|--|
| ymbol | Parameter                           |       | Min. | Тур. | Max. | Unit                                                   | Condition                                                                      |  |
| PD1   | Input to Output Delay<br>DO Outputs |       |      | 15   | 25   | ns                                                     | C <sub>L</sub> =30pF, R <sub>1</sub> =300Ω,<br>R <sub>2</sub> =600Ω            |  |
| PD2   | Input to Output Delay               | M3216 |      | 19   | 33   | ns                                                     | C <sub>L</sub> =300pF, R <sub>1</sub> =90Ω,                                    |  |
|       | DB Outputs                          | M3226 |      | 16   | 25   |                                                        | R <sub>2</sub> =180Ω                                                           |  |
| Ē     | Output Enable Time                  | M3216 |      | 42   | 75   | ns(2)                                                  | DO Outputs: CL=30pF,                                                           |  |
|       | ·                                   | M3226 | 36   | 62   |      | R <sub>1</sub> =300Ω/10ΚΩ,<br>R <sub>2</sub> =600Ω/1ΚΩ |                                                                                |  |
|       |                                     |       |      |      |      |                                                        | DB Outputs: CL=300pF,<br>R <sub>1</sub> =90Ω/10KΩ,<br>R <sub>2</sub> =180Ω/1KΩ |  |
| ٥.    | Output Disable Time                 | M3216 |      | 16   | 40   | ns(2)                                                  | DO Outputs: C <sub>L</sub> =5pF,                                               |  |
| U     |                                     | M3226 | 226  | 16   | 38   |                                                        | R <sub>1</sub> =300Ω/10ΚΩ,<br>R <sub>2</sub> =600Ω/1ΚΩ                         |  |
|       |                                     |       |      |      |      |                                                        | DB Outputs: CL=5pF,<br>R <sub>1</sub> =90Ω/10KΩ,<br>R <sub>2</sub> =180Ω/1KΩ   |  |

.....

NOTE: (1) Typical values are for  $T_A = 25^{\circ}C$  and nominal supply voltage.

(2) The test load circuit is set for worst case source and sink loading on the outputs. The two resistor values for R1 and R2 correspond to worst case sink and source loading, respectively.

# CAPACITANCE<sup>(2)</sup> $T_A = 25^{\circ}C$

| Symbol | Parameter          | Min. | Тур. | Max. | Unit |
|--------|--------------------|------|------|------|------|
| CIN    | Input Capacitance  |      | 4    | 6    | pF   |
| COUT   | Output Capacitance |      |      |      |      |
|        | DO Outputs         |      | 6    | 10   | pF   |
|        | DB Outputs         |      | 13   | 18   | рF   |

# Note:

(2) This parameter is periodically sampled and is not 100% tested. Condition of measurement is f = 1MHz, VBIAS = 2.5V,  $V_{CC}$  = 5.0V and  $T_A$  = 25°C.

# WAVEFORMS



## **TEST CONDITIONS:**

Input pulse amplitude of 2.5V. Input rise and fall times of 5 ns between 1 and 2 volts. Output loading is 5 mA and 10 pF. Speed measurements are made at 1.5 volt levels.

MILITARY 3216/3226






# Series 3000 System Timing Considerations

by Gary Fielland

While the timing for each component in Intel's 3000 Series Schottky Bipolar Microcomputer Set is clearly specified, the composite system timing must be derived. This system timing is highly dependent on the particular configuration implemented, and hence, must be carefully considered for each implementation.

Though Intel cannot generate the system timing for every possible configuration, an effort has been made to study a few simple variations. By examining these examples and taking note of considerations given, it should be easier for the system designer to realize those times which are critical, and to generate the appropriate timing for his particular system.

The designer must consider many different factors in determining this "proper" system timing. Several simplifications are made to facilitate this discussion. Intel commercial grade parts are specified over a wide temperature range  $(0^{\circ}C - 70^{\circ}C)$  and so variations in timing due to temperature will not be considered, except for a short note at the end.

Whenever a signal must traverse a conductor between two points, there is a finite delay introduced into the signal path that is not accounted for by any data sheet. This is the delay due to such factors as the length of the conductor, its transmission properties, and the characteristics of the driver and receiver. When a TTL totempole output drives a TTL input a short distance away this delay is usually negligible compared to other delays in the signal path. However, if there are many loads (increasing the capacitance), or the driver is of the open-collector type (limiting the drive), or if the receiver is physically far removed, the designer should consider and allow for any possible deleterious effects of this delay. For this discussion, except in one special case, the delay introduced by interconnection is not considered.

Aside from these simplifications, it should be realized that this note is not an extensive study of the timing of any particular system, but rather a compendium of typical considerations which a designer might examine.

Consider the basic "data sheet" 16-bit processor configuration as shown in Figure 1. It utilizes pipeline registers, full carry look-ahead, and a priority interrupt mechanism. To implement any such system the designer must be very careful to provide the proper timing for all components under all possible operating conditions. Such a system is highly complex and the analysis is best approached in a piecemeal fashion.



Figure 1. Basic 16-Bit Processor Configuration

## **System Timing**

### ARITHMETIC DELAY PATHS

First an analysis will be made of the arithmetic paths and delays. Imagine cycles in which arithmetic is being done within the CPE array. The carrys must have time to propagate through the arithmetic portion and reach the MCU so that a conditional jump may be made based on that carry out bit. For the moment ignore other critical paths, and examine Figure 2 which illustrates these arithmetic cycles.

The cycle begins with the rising edge of the system clock as it clocks the pipeline registers. After the delay  $(t_{PLR})$  introduced by the pipeline, the function is available at the CPE array. There is a delay  $(t_{XF})$ while all the CPE's decode the function and generate their X and Y outputs for the operation. Once the X and Y outputs are stable, the Carry Look-Ahead circuit takes some time (txc) to simultaneously generate all the carry outputs, including the one which goes to the MCU flag input. Time must be provided to allow for the carry-input setup time of the CPE's (tss) and the MCU (tsi). Finally, adding in enough time for the clock pulse, which acts as a write pulse for the CPE register array, the cycle time is determined. Note the time for the MCU flag output to stabilize  $(t_{KO})$  was ignored as it is not a limiting specification for this configuration.

Keeping the same train of thought, consider individually the effects of variants from the configuration of Figure 1. If full carry look-ahead is not used and the carry is allowed to ripple through only the last slice, an additional delay path is introduced. After the 3003 has generated the carry outputs there is the CPE carry-in setup time  $(t_{SS})$  which must be met as before. However, the carry-out of the last slice will not be available to the MCU flag input until it has rippled through  $(t_{CC})$  that slice. Finally, the MCU flag input setup time  $(t_{SI})$  must be satisfied.

$$t_{CYCLE} = t_{PLR} + t_{XF} + t_{XC} + t_{CC} + t_{SI} + t_{WP}$$

If the 3003 Look-Ahead Carry circuit is not used, there will be considerable delay added to the basic cycle due to ripple carry time. Once the CPE function-inputs are stable, the function must be decoded and the carry-out of the least significant slice generated ( $t_{\rm CF}$ ). The carry must ripple through six slices (6\*  $t_{\rm CC}$ ) and meet the carry setup time ( $t_{\rm SS}$ ) of the most significant slice. However, it must also ripple through this last slice ( $t_{\rm CC}$ ) and meet the MCU flag input setup time which is a more severe restriction.

$$t_{CYCLE} = t_{PLR} + t_{XF} + t_{XC} + t_{SS} + t_{WF}$$

$$t_{CYCLE} = t_{PLR} + t_{CF} + (7 * t_{CC}) + t_{SI} + t_{WP}$$



Figure 2. Non-Interrupt 16-Bit Processor Cycle Timing

If pipeline registers are not used, there will be additional delay. It takes some time  $(t_{CO})$  after the rising edge of the clock for the next address to propagate through the MCU address register and buffers. Then, when this address is stable the ROMs must be accessed and there will be a delay  $(t_{ROM}, access$ time) before their output and hence the CPE function-input is stable. Thus, the cycle time for a nonpipelined system with carry look-ahead is:

 $t_{CYCLE} = t_{CO} + t_{ROM} + t_{XF} + t_{XC} + t_{SS} + t_{WP}$ 

In the previous discussion it was assumed that the operands in the arithmetic operations were internal registers and the K-bus as implemented. If one of the operands is the M-bus or the I-bus, additional consideration should be given. This situation will typically arise at the completion of a Memory-Read or Input cycle. Typically, these cycles are implemented such that the processor clock stops in its high state to wait for the data to be available, while the processor is in the midst of executing an LMM or similar instruction. Thus, it is often the case that the pipeline registers have long since been accessed and the function decoded.

Then, when the data becomes available a clock pulse is issued and normal operation continues. It is the time from the point the data becomes available until the clock pulse is issued (Data Input Setup Time) that is of concern here. Consider first a special case. Namely, the data is input via an LTM instruction and no test will be made on the carry-output. This implies that for this specific instruction, carry propagation is unimportant and it is acceptable to have an erroneous carry-output. For such a case, it is sufficient to only allow for the CPE data setup time  $(t_{DS})$ .

 $t_{SETUP} = t_{DS}$ 

For the more general case where arithmetic is done on input and the carry-output may be tested, the above analysis is incomplete. While the above condition must be met, it is no longer the determining factor. Time must be allowed for carry propagation. See Figure 3, which illustrates this case.

From the point in time when the data becomes stable at the CPE inputs, there is a delay  $(t_{XD})$  while the CPE generates the X and Y outputs. If Ripple Carry is employed, the delay  $(t_{CD})$  is in waiting for the carry-output of the least significant slice. After either of these delays the rest of the setup time is allocated analogously to that depicted in Figure 2 and discussed previously in relation to arithmetic cycle times.

$$\begin{split} t_{SETUP} & (Basic) = t_{XD} + t_{XC} + t_{SS} \\ t_{SETUP} & (Last Slice Ripple) = t_{XD} + t_{XC} + t_{CC} + t_{SI} \\ t_{SETUP} & (Ripple Carry) = t_{CD} + (7* t_{CC}) + t_{SI} \\ t_{SETUP} & (No Pipeline) - Same as Basic \end{split}$$



Figure 3. 16-Bit Processor Data Input Set-Up Times

### CONTROL DELAY PATHS

After carefully examining the arithmetic paths and delays it is appropriate to push all of this information onto your "mental stack" and begin again with a consideration of the control paths and delays. After this study the stack can be popped and information merged to yield overall system requirements.

Consider the MCU as it cycles in normal operation (see Figure 4). At the rising edge of the clock the new microprogram address is loaded into its holding register and through the output buffers. Thus, the new address reaches the ROM after a delay ( $t_{\rm CO}$ ). Then there is a wait ( $t_{\rm ROM}$ ) while the ROMs are accessed before the outputs are valid. At this time the MCU address control inputs (which are never pipelined) are valid and this must be early enough in the cycle to satisfy the MCU address control input setup time ( $t_{\rm SF}$ ). Adding the time for the clock pulse ( $t_{\rm WP}$ ) yields the cycle time requirement. Note this paragraph has ignored the generation of the ISE output.

 $t_{CYCLE} = t_{CO} + t_{ROM} + t_{SF} + t_{WP}$ 

In the basic configuration shown in Figure 1 the ISE output is used to strobe the 3214 Interrupt Control Unit each time a JZR 15 (usually a jump to macro-instruction fetch) is recognized at the MCU address

control inputs. Some consideration must be given to the additional requirements on timing imposed by the use of this ISE output. After the ROM has been accessed and the MCU address control inputs are valid, it takes the MCU some time ( $t_{FI}$ ) to decode the JZR 15 operation and raise the ISE output. This output is used as the 3214 ISE input and must be valid early enough to meet that input setup time ( $t_{ISS}$ ). As this setup time is relative to the rising edge of the clock, the clock pulse width need not be added in.

$$t_{CYCLE} = t_{CO} + t_{ROM} + t_{FI} + t_{ISS}$$

Recalling the basic configuration depicted in Figure 1 and the situation described in the last paragraph, imagine that an interrupt request had been active long enough to meet the request setup time ( $t_{RCS}$ ) of the ICU. Then since the ISE input went high and satisfied the input setup time, the Interrupt Acknowledge flip-flop within the 3214 will change state and lower the MCUs ERA input after a delay ( $t_{CI}$ ). After the row address outputs are disabled ( $t_{EO}$ ), the pull-up resistors will begin to pull these lines high and after the voltage on these lines rises to 2.0V ( $t_{RISE}$ ) the ROM address will be valid. The remainder of this cycle is the same as previously described and usually will not be required to again generate an ISE pulse.

$$t_{CYCLE} = t_{CI} + t_{EO} + t_{RISE} + t_{ROM} + t_{SF} + t_{WP}$$



Figure 4. MCU & Interrupt Cycle Timing

Examining the times shown on Figure 4 for this case of an interrupt cycle using pull-up resistors, it is clear that unless something is done this will be the limiting cycle time requirement. There are several techniques which may be used to ease this requirement.

Since interrupt cycles are relatively infrequent in comparison with other cycles, one solution might be to extend just that cycle. In other words, the system cycle time would be determined by all considerations previously mentioned, but ignoring the abnormal interrupt cycle requirement. Then the clock circuit would be designed such that it could extend a cycle in response to a signal from the 3214 Interrupt Control Unit (see Figure 5).



Figure 5. Interrupt Cycle Extension

The interrupt cycle would still be exactly as depicted in Figure 4, but the length of the interrupt cycle would be longer than a normal cycle, and in fact long enough to accommodate the interrupt cycle requirement.

It can be seen that a significant portion of the interrupt cycle is lost waiting for the pull-up resistors to charge the capacitance on the address lines. Thus, another method of easing the interrupt cycle requirement would be to reduce the address line rise time (t<sub>RISE</sub>). Reducing the resistance of the pull-ups would help but this technique is limited by the available MCU address output fanout. Alternatively, the MCU row address outputs (MA8-4) could be connected to the ROM address lines through a multiplexer such as the 74S158 (see Figure 6). With such a connection the interrupt cycle time is reduced since the MCU enable time  $(t_{EO})$  plus the address line rise time  $(t_{RISE})$  may be replaced with simply the multiplexer select time (t<sub>MUX</sub>) as shown in Figure 4. However, it should be noted that such a connection adds delay to the MCU address outputs, thus effectively lengthening this existing delay  $(t_{CO})$  by the multiplexer propagate time (t<sub>MUX-PROP</sub>) and hence lengthening any cycle which was dependent on the MCU delay  $(t_{CO})$ .

 $t_{CYCLE}$  (Interrupt with MUX) =

 $t_{CI} + t_{MUX} + t_{ROM} + t_{SF} + t_{WP}$ 



Figure 6. Multiplexer to Reduce Address Rise Time

A third alternative to solve the long interrupt cycle requirement is to implement the interrupts in quite a different way. Rather than changing the MCU address outputs, the MCU address control input least significant bit  $(AC\phi)$  may be altered (see Figure 7). Using this technique an extra ROM bit (Interrupt Strobe) is required to strobe the 3214 ICU since the MCUs ISE output occurs one cycle too late. Implementing the same mechanism (interrupt strobe on JZR 15) could be done by using the interrupt strobe bit to strobe the ICU (see Figure 7) the cycle before the JZR 15 code appears. An added benefit of this method is that the interrupt structure may be strobed at points other than the beginning of an instruction fetch cycle, facilitating PAUSE or WAIT instructions.

Examining the timing diagrams in Figure 7, it can be seen that this implementation of interrupts does not limit the system cycle time. Rather, this interrupt mechanism's timing is less restrictive than timing for a normal cycle. The only requirements are that the interrupt strobe bit from the ROM reaches the 3214 ICU ISE-input within its setup time ( $t_{ISS}$ ). In the next cycle it is only necessary that the IA-output has gone low ( $t_{CI}$ ) early enough to meet the MCU address control input setup time ( $t_{SF}$ ). Thus, for the price of one bit of ROM interrupts can be implemented with no penalty in time.

At this point both major delay paths (arithmetic and control) have been examined for the implementation in question. After the designer has assured himself



there are no other delays which he may have overlooked, such as introducing external circuitry into the paths, he may merge the various requirements generated into a uniform set of system requirements. Any change introduced after these requirements have been generated must be closely examined that it does not subtly alter any system requirements. Delays that are negligible in one configuration may be dominant in a slightly different structure.

### WHAT HASN'T BEEN MENTIONED?

1. In the introduction it was explained that temperature would not be considered in the examples since Intel specifies products over the 0° C to 70° C temperature range. This deserves further comment. A quick glance at an Intel Data Sheet will verify that Intel parts are specified and guaranteed over the 0° C to 70° C ambient temperature range and concurrently with a five percent tolerance power supply. This is a reasonable range and allows the designer to guarantee circuit operation. Unfortunately, the standard Schottky MSI line (74SXX) is only specified at  $25^{\circ}$ C ambient and V<sub>CC</sub> = 5V. The variance of parameters over the allowable temperature and supply voltage is unspecified and left to the designer's experience. Due to this uncertainty the designer should "appropriately" modify any times attributable to non-Intel parts to allow for variations over temperature and supply voltage.

2. In the examples given it was always assumed that setup times would be honored. Though most of a computing system is synchronous, it typically has to interface with asynchronous events. It is at this interface that difficulty may be encountered. Consider a popular circuit (Figure 8) used to "synchronize" asynchronous signals.

In this circuit the output delay is guaranteed only if the input setup time is met. But since the input is asynchronous, this setup time may not always be satisfied, as at the second event depicted in Figure 8. What happens? Though the results are highly dependent on the flip-flop circuit design, some general observations may be made. Typically, the effect is to stretch out the flip-flop delay time as the event approaches arbitrarily close to the clock edge. Theoretically, the delay will go to infinity if the event falls precisely on the clock edge. Some flip-flops also exhibit a characteristic in which the output may change state and some time later return to the original state. This phenomena is known as "hang-up" and has been observed to last for twenty nanoseconds on a 74S74. It cannot be absolutely prevented when asynchronous signals are introduced into a synchronous system, but the probability of the "hung" flip-flop causing an error can be reduced without limit. The technique is simply to cascade these interfaces.

If two such flip-flops are cascaded there is some probability  $P_1$  ( $P_1 < 1$ ) that the asynchronous event will fall close enough to the clock edge to hang the first flip-flop. Given that it hangs, there is some probability  $P_2$  that it will hang for very nearly an entire clock period and into the hang-up zone of the second flip-flop. Then, there is a probability  $P_3$  that the second flip-flop will hang long enough to cause an error. Thus, the probability of error is  $P_E = P_1 * P_2 * P_3$ . Hence, by cascading flip-flops the probability of error can be reduced without limit.

Recall the 3214 Interrupt Control Unit and its request setup time  $(t_{RCS})$  and its IA output delay  $(t_{CI})$ . This delay is in several critical system paths as shown by the examples. Of course, the IA output delay specified also presumes the IA flip-flop setup time was met. When deliberately violating the IA flip-flop setup time, a hang-up of 50 nsec has been observed. What is a designer to do?

Slowing down the system such that it could tolerate any expected hang-up would be the easiest solution. This may not always be as bad as it sounds. Recalling the situation depicted in Figure 7, note that some flip-flop hang-up is tolerable. [ $t_{IA-HANG} = t_{CYCLE} - (t_{SF} + t_{WP})$ ]. An alternative would be to "synchronize" the asynchronous interrupt requests using the technique previously described. An octal D flip-flop such as the 74S374 would be suitable.

3. In the examples given it has been assumed that the system, including all the CPEs, the MCU, and the ICU, operates from a single clock. If a circuit, such as in Figure 9, that provides a separate clock for different components is used, the possible clock skew must also be considered when determining system timing.



Figure 8. Synchronizing Circuit Exhibiting Hang-Up



Figure 9. CPE Clock Inhibit Circuit

4. Though not explicitly mentioned, it has been assumed that all input hold times would be observed. Usually these times are satisfied with no conscious effort required of the system designer. However, parameters such as the MCU SX and PX input hold time must be carefully considered. These inputs are used for macro instruction decoding and typically are used at the end of an instruction fetch cycle. When using these inputs the designer must provide the necessary data hold time before allowing the data to change.

### SUMMARY

Generating the correct timing for a complex system in which parameters may vary with temperature, power supply voltage, lead length and the like is no trivial task. Fortunately, large scale integration such as Intel's 3000 family is making the task much easier. With the 3000 family of compatible parts the designer need only worry about the interfaces and may be assured the internal timing is correct. Such a system is best analyzed by separately considering the various delay paths and later combining the sundry results. And of course, with Murphy on vacation the designer can be confident of a flawless design on the first pass.

# Disk Controller Designed With Series 3000 Computing Elements

by Glenn Louie



Figure 1. Bipolar Microprogrammed Disk Controller

With the introduction of the first microprocessor, digital designers began a massive switch to programmable LSI technology, away from hardwired random logic. Designers found that with these new LSI components and the availability of low cost ROMs they could easily implement structured designs which were both cost effective and flexible. However, not all digital designs were amenable to the microcomputer approach. One of the basic limitations was the speed at which a particular critical program sequence could be executed by a microprocessor. The early P-channel MOS microprocessors, such as Intel's 4004 and 8008, were able to solve a broad class of logic problems where speed was not essential. With the introduction of the more powerful n-channel MOS microprocessors, such as the Intel<sup>®</sup>8080, the range of applications was significantly broadened, but there still existed a class of applications that even these newer devices were not fast enough to handle.

Recently, two new Schottky bipolar LSI computing elements, members of the Intel Bipolar Microcomputer Set, were introduced which expand the range of microcomputer applications to include high speed peripheral controllers and communication equipment. The new elements are the 3001 Microprogram Control Unit (MCU) and the 3002 Central Processing Element (CPE). These two components facilitate the design of specialized, high speed microprocessors that together with a minimum of external logic perform the intricate program sequences required by high speed peripheral controllers.

A multi-chip bipolar microprocessor differs from the single chip MOS microprocessor in that the bipolar microprocessor is programmed at the microinstruction level rather than at the macroinstruction level. This means that instead of specifying the action via a macroprogram using a fixed instruction set, a designer can specify the detailed action occurring inside the microprocessor hardware via a microprogram using his own customized microinstructions.

In general, microinstructions are wider than macroinstructions (e.g. 24 to 32 bits) and have a number of independent fields that specify simultaneous operations. In a single microcycle, an arithmetic operation can be executed while a constant is stored into external logic and a conditional jump is being performed.

A bipolar LSI microprocessor design is similar to a general MSI/SSI microprocessor design where the intricacies of the application are imbedded in the program patterns in ROM. However, the large amount of logic necessary to access the microcode has been replaced by the LSI MCU chip. Also, the MSI logic required to provide the arithmetic and register capabilities has been replaced by the functionally denser LSI CPE slices. Because of these new LSI chips, microprogramming with all its advantages can now be applied to designs which previously were unable to justify microprogramming overhead.

The effectiveness of these new LSI components in a high speed peripheral controller design has been demonstrated by the Applications Research group at Intel with the design of a 2310/5440 moving head disk controller (BMDC). The BMDC has a total of 67 IC chips and is packaged on a printed circuit board measuring 8" x 15", as shown in Figure 1. Disk controllers of equivalent complexity realized with conventional components typically require between 150 and 250 I.C.'s. The BMDC performs all the operations required to interface up to four "daisy chained" moving head disk drives, with a combined storage capacity of 400 megabits, to a typical minicomputer. It is fast enough to keep up with the drive's 2.5 MHz bit serial data stream while performing the requisite data channel functions of incrementing an address register, decrementing a word count register, and terminating upon completion of a block transfer.

The BMDC interacts with the minicomputer's disk operating system (DOS) via I/O commands, interrupts and direct memory access (DMA) cycles. The I/O commands recognized by the BMDC's microprogram are:

| Conditions In |
|---------------|
| Seek Cylinder |
| Write Data    |
| Read Data     |
| Verify Data   |
| Format Data   |

The BMDC sends an interrupt to the minicomputer when either a command is successfully executed, a command is aborted, or a drive has finished seeking. The DOS then interrogates the BMDC with a Conditions In command. The following flags specify the conditions which the BMDC can detect:

> Done flag Malfunction flag Not Ready flag Change In Seek Status flag Program Error flag Address Error flag Data Error flag Data Overrun flag

Data transfers between the minicomputer and the disk BMDC occur during DMA cycles. DMA cycles are also used for passing command information from the minicomputer to the BMDC.

The bipolar LSI microcomputer in the BMDC performs the necessary command decoding, address checking, sector counting, overlap seeking, direct memory accessing, write protection, password protection, overrun detection, drive and read selection, and formatting. External hardware assists the microprocessor in updating the sector counter. performing parallel-to-serial and serial-to-parallel conversion, and generating the CRC data checking information. The BMDC uses a special purpose microprocessor, configured with the components listed in Table A. The LSI microprocessor uses an MCU, an 8:1 multiplexer, eight 3601 PROMs, a command latch, a data buffer, and an array of eight CPE slices (Fig. 2). The characteristics of this design, only one of many possible with the 3000 family, are as follows:

- 400 nsec system clock
- 16-bit wide CP array
- Ripple carry CPE configuration
- Non-pipelined architecture
- One level subroutining
- 230 32-bit microinstructions
- Word to 4-bit nibble serialization

The MCU controls the sequence in which microinstructions are executed. It has a set of unconditional and conditional jump instructions which is based on a 2-dimensional array for the microprogram address spece called the MCU Jump Map. <sup>(1)</sup>

| PART # | DESCRIPTION                 | QUANTITY |
|--------|-----------------------------|----------|
| 3001   | MCU                         | 1        |
| 3002   | CPE                         | 8        |
| 3212   | 8 bit I/O Port              | 6        |
| 3205   | 1 of 8 Decoder              | 2        |
| 3601   | 1K PROM                     | 8        |
| 3404   | 6 bit Latch                 | 1        |
| 4173   | 4 bit Gated D F/F           | 1        |
| 4174   | 6 bit D F/F                 | 1        |
| 4175   | 4 bit D F/F                 | 1        |
| 4151   | 8:1 Multiplexer             | 1        |
| 233    | Dual 4:1 Multiplexer        | 2        |
| 300    | 4 bit Shift Register        | 1        |
| 316    | 4 bit Binary Counter        | 1        |
| 503    | CRC Generator               | 1        |
| 474    | Dual D F/F                  | 5        |
| 473    | Dual J-K F/F                | 2        |
| 451    | And-Or-Invert Gate          | 1        |
| 404    | Hex Inverter                | 6        |
| 400    | Quad 2 Input Nand Gate      | 9        |
| 4H08   | Quad 2 Input And Gate       | 1        |
| 403    | Quad 2 Input Nand O.C. Gate | 2        |
| 438    | Quad O.C. Drivers           | 4        |
| 4H103  | Dual J-K F/F                |          |
|        | Total                       | 67 I.C.  |

### Table A. I.C. Component List for Disk Controller



Figure 2. Disk Controller – The various elements of a specialized microprogrammed processor is shown with the external logic which together is the entire disk controller.

In addition, the MCU is connected in such a manner as to perform command decoding, external input testing, and one level subroutining.

Command decoding is achieved by connecting the command latch to the Primary Instruction (PX) bus inputs and using the JPX instruction (Fig. 3). The testing of external input signals is performed by routing the least significant bit (LSB) of the seven bit jump code through an eight-to-one multiplexer (Fig. 2). The multiplexer is controlled by a 3-bit Input Select Code which selects either the LSB of the jump code or one of 7 external input signals to be routed to the MCU. This technique has the effect of conditionally modifying an unconditional jump code so that the next address will either be an odd or even location (Fig. 3). A one instruction wait for external signal loop can be simply implemented in this fashion.

One level subroutining is achieved by feeding the four least significant bits of the address microprogram outputs back into the secondary instruction (SX) inputs. Enough program status information can then be saved in the internal PR latch when a subroutine is called with a JPX instruction so that upon exiting, a subroutine with a JPR instruction, control can be returned to the procedure which called it (Fig. 4). This technique saves a significant amount of microcode in the BMDC because some long sequences do not have to be repeated.

The microprogram control store is an array of eight 3601 PROMs organized to give 256 words x 32 bits (230 words were required for the BMDC). The 32-bit wide word is divided into the following subcontrol fields:

| 1. Jump Code field     | 7 bits  |
|------------------------|---------|
| 2. Flag Control field  | 2 bits  |
| 3. CPE Function field  | 7 bits  |
| 4. Input Select field  | 3 bits  |
| 5. Output Select field | 3 bits  |
| 6. Mask or Data field  | 8 bits  |
| 7. Mask Control field  | 2 bits  |
| TOTAL                  | 32 bits |

The command latch and data buffer retain command information from the computer so that the memory bus will not be held up if the BMDC should be busy performing an updating task. The data buffer also retains the next data word during a Write Data to disk operation.

## **Disk Controller Design**

The CP array is connected in a ripple carry configuration as shown in Figure 5. The eight CPE slices provide the BMDC with a 16-bit arithmetic, logic and register section. Word to nibble serialization is made possible by connecting the Shift Right Outputs (RO) of the first, third, fifth, and seventh CPE to the Nibble Out bus. By using only four shift right operations a word in a register can be converted into four 4-bit nibbles. The final serialization of these nibbles is done in the external



Figure 3. MCU Jump Map for instruction decoding and conditional branching on external inputs

logic. Similarly, the Shift Right Inputs (LI) of the second, fourth, sixth, and eighth CPE are connected to the Nibble In bus so that with only four shift right operations, a word can be assembled from four nibbles.



Figure 4. MCU Jump Map for one level subroutine call and return. A subroutine is called from four different places in the program each with a unique column number. Upon returning from the subroutine, control will be transferred back to the portion of program which called it. A subroutine may be called from a maximum of 16 different places.



Figure 5. CPE Array – A 16-bit arithmetic, logic and register section is built up with 8 CPE slices connected in a ripple carry configuration. The K, I, and M bus is used for loading information into the CPE slices. The LI inputs and RO outputs are connected to make up the Nibble In and Nibble Out buses.

An eight bit mask bus is connected to the mask inputs of the least significant half of the array. The mask inputs of the most significant half of the CP array are all tied to the eighth mask bit. A constant with a value between +127 and -128 can therefore be loaded into the array from the microprogram. The mask bus comes from the data field of the microprogram via a 0-1 data multiplexer. When the CP array requires either an all one or all zero mask, the data field is freed to provide data to external logic.

The 3002 CPE is an extremely flexible component which makes it particularly attractive for controller designs. The Memory Address Register makes an ideal DMA address register.<sup>(1)</sup> The accumulator (AC) register, which also has its own output bus can be used as a data word buffer during a write DMA cycle. Concurrently, another word can be assembled in the T register using the shift right operation. The three separate input buses provide a multiplexing capability for routing different data into the CPE. In the BMDC, the I-bus is used for loading disk drive conditions, the K-bus for loading mask or constant information, and the M-bus for reading an external data buffer. The arithmetic logic section performs zero detection and bit testing with the result delivered to the

MCU chip via the carry out line. Finally, the eleven scratchpad registers allow the controller to retain data and status for the processor.

The CP array in the microprocessor performs the following for the BMDC with its registers and arithmetic functions.

- 1. Sector counting
- 2. Word to nibble serialization
- 3. Drive seek status monitoring
- 4. Header checking
- 5. DMA address incrementing
- 6. Word counting
- 7. Multi-sector length counting
- 8. Automatic resynchronization of sector counter
- 9. Accessing of additional information from memory
- 10. Time delays

The organization of the microprocessor was chosen to maximize the use of the MCU and CPE in performing the various tasks required for disk control. However, there are some specialized tasks which are more economically performed by external logic. The microprocessor controls this external logic by output ports which are selected by the output select field in the microinstruction. The



Figure 6. External Logic – Microprocessor monitors and controls external logic via input-output port to perform specialized disk controller functions.

data to these ports is delivered from the shared data field.

The external logic section of the BMDC (Fig. 6) has a double buffered 4-bit shift register which is used for initial packing and the final serialization of data. It is controlled by a modulo-4 counter circuit. During a write operation, serial data from the shift register is encoded by the clock controlled double frequency encoder and sent to the drive. As data is being transferred to a cyclic redundancy code (CRC) is generated and then appended to the end of the data stream to be recorded on the disk. The external logic also contains addressing latches and flag flip-flops to capture sector and index pulses. It also contains main memory bus control circuitry for performing bus protocol, bus acquisition, and data overrun detection.

The microprogram for the BMDC microprocessor directly implements the six I/O commands. The program controls the sequential action of the various elements of the microprocessor and of the external logic needed to decode and execute the commands. In Figure 7, the flow chart of the Read command shows the actions required to read a file off the disc. The BMDC first selects the drive specified by the command and checks its ready status. It then uses a memory pointer passed to it by the command to access four more words from the main memory using DMA cycles. The first word is the Header, which contains the track address and sector address information. The second word is the Starting Address specifying the first location in memory where the data is to be stored. The third word is the Block Length of the file to be retrieved. All of the address information and the Block Length are stored in several CPE registers for further processing. The fourth word is the Password which is compared against a microprogram word to insure that the command from the computer is a valid one and not a program error. The password can prevent an erroneous command, due to a user programming error, from destroying important files on the disc.

After the password check, the BMDC resynchronizes the sector counter if necessary and waits for the desired sector by monitoring the sector pulse flag. When the desired sector arrives, the BMDC synchronizes itself to a start nibble and reads the header which it compares to the desired header to insure that the head is positioned properly. It then reads and stores 128 words of data at sequential locations in memory. A cyclic redundancy code is compiled during the read oper-







Figure 8. BMDC Flowchart — The BMDC runs in the idle loop when it is not busy doing command processing. ation and compared against the CRC word read in after the data. At the end of each sector the block length is decremented to see if it is the last sector. If it is not, the sector address is incremented and another sector is read.

In addition to the command routines, the microprogram has an idle loop routine (Fig. 8) which the BMDC executes when it is not busy with a command. While in the loop, the BMDC updates the sector count, monitors the drives seeks status lines and decodes any disc commands from the disc operating system in the minicomputer.

The design process for the BMDC began with an evaluation of what disc controller operations could effectively be handled by the microprocessor. This also determined what had to be performed by external logic. A microprocessor configuration was then established and certain critical sequences were programmed to verify that the configuration was fast enough. A flow chart was produced and the microprogram coded directly from it. All attempts were made to use the MCU and CPE slices effectively and keep the microprogram within 256 words. The assignment of MCU addresses which initially appeared difficult, was, with a little experience, quite straight forward and less restrictive than a state counter design. After the coding, the microprogram was assembled and loaded into the microprocessor's control memory.

The BMDC design demonstrates how a specialized high speed microprocessor can be designed using standard bipolar LSI devices and microprogrammed to perform disc control functions with the addition of a small amount of external logic. The flexibility of Series 3000 allows a designer to optimize the configuration for his application. For extremely high speed applications, the designer can add fast carry logic and microinstruction pipelining to his microprocessor to achieve a 150 nsec 16-bit microprocessor.

At Intel, our design experience with the BMDC design exercise has shown that the use of the MCU and CPE results in a clean, well structured design. The complexity of the design resides primarily in the microprogram leaving the external logic relatively simple. During debugging, most of the problems encountered were restricted to the microprogram which was easily modified and debugged using bipolar RAM for the control memory.

### References

J. Rattner, J. Cornet, M. E. Hoff, Jr., "Bipolar LSI Computing Elements Usher In New Era of Digital Design," ELECTRONICS, September 5, 1974, pp 89–96.

Disk Controller Design

# APPENDIX — DISK CONTROLLER SCHEMATIC



3-16



# **APPENDIX — DISK CONTROLLER SCHEMATIC**



3-21

# Contents

# **Central Processor Designs** Using The Intel<sup>®</sup> Series 3000 **Computing Elements**

| g Elements  | UNITS                                | 3-23      |
|-------------|--------------------------------------|-----------|
|             | Basic Design Steps                   | 3-23      |
| by          | Hardware Organization                | 3-23      |
|             | Writing of Microprograms             | 3-26      |
|             | DEFINITION OF CONTROL FIELDS         | 3-26      |
| James Sugg, | ASSIGNMENT TO CONTROL MEMORY         | 3-27      |
| Ron Yara    | PROGRAMMING TECHNIQUES               | 3-28      |
|             | A DESIGN EXAMPLE                     | 3-29      |
|             | Initial Specifications               | 3-30      |
|             | Macro-Instruction Decoding           | 3-33      |
|             | Microprogram Implementation          | 3-34      |
|             | MEMORY REFERENCE AND                 |           |
|             | IMMEDIATE GROUP                      | 3-34      |
|             | JUMP GROUP                           | 3-43      |
|             | REGISTER MOVE AND SUBROUTINE         | 2 40      |
|             |                                      | 3-40      |
|             |                                      | 0-49      |
|             |                                      | 3.52      |
|             | Microprogram Memory Assignment       | 3-53      |
|             | CONCLUSION                           | 3.58      |
|             |                                      | 0-00      |
|             | INSTRUCTION SET                      | 3-62      |
|             | Memory Reference Group               | 3-62      |
|             | Immediate Group                      | 3-62      |
|             | Jump Group                           | 3-63      |
|             | Subroutine Call Group                | 3-63      |
|             | Subroutine Return Group              | 3-64      |
|             | Register Manipulation Group          | 3-64      |
|             | Byte Load and Store Group            | 3-64      |
|             | Special Memory Reference Instruction | 3-64      |
|             | Base and Status Register Move Group  | 3-64      |
|             | Input/Output Group                   | 3-64      |
|             | Stack Push and Pop Group             | 3-64      |
|             | APPENDIX B – MICROPROGRAM LISTINGS   | 3-65      |
|             | APPENDIX C – CENTRAL PROCESSOR       | 9.70      |
|             |                                      | - · · · · |

AN INTRODUCTION TO MICROPROGRAMMING. 3-21

THE SERIES 3000 FAMILY .....

CONSTRUCTING CENTRAL PROCESSING

### INTRODUCTION

Until recently, the area of high performance, general purpose and special purpose central processors was unaffected by the microprocessor revolution. Although they covered a broad range of applications, the P-channel and N-channel microprocessors' performance limitation prevented their use in applications where high speed was necessary.

The introduction of the Series 3000 Computing Elements has expanded the spectrum of microprocessor applications to include both high performance central processors and controllers. Utilizing Intel's Schottky bipolar technology, the Series 3000 components realized a level of performance that was not possible with MOS microprocessors. For example, a 16-bit processor with a microinstruction cycle time of 150 nanoseconds can be built with the 3000 components. In addition, the components of the family can be arranged into a number of different configurations and microprogrammed by the system designer to perform in a variety of processing environments from front end processing to arithmetic intensive computation.<sup>1</sup>

This application note describes a systematic procedure for designing central processors with the Series 3000. Using a CPU design example, simple guidelines are given for tasks such as macro-instruction opcode assignment, macro-instruction decoding and execution and microprogram memory assignment.

### THE SERIES 3000 FAMILY

The Intel<sup>®</sup> Series 3000 Bipolar Microcomputer Set is a family of Schottky bipolar LSI computing elements which simplify the construction of microprogrammed central processors and device controllers. These processors and controllers are truly microprogrammed in the sense that their control functions are determined by the contents of a control memory. This control memory may be realized with standard read-only (ROM) memory, read/ write (RAM) memory or programmable read-only memory (PROM) elements.

The two most important computing elements in the family are the 3001 Microprogram Control

Unit (MCU) and the 3002 Central Processing Element (CPE). The MCU determines the sequence of micro-instruction execution and controls carry/ shift data to and from the CPE array. The CPE provides a complete two-bit wide slice through the data processing section of a central processing unit. CPEs may be arrayed in parallel to form a processor of any desired word length. For example, to produce a 16-bit wide data path, eight CPEs would be used.

All of the above components use standard TTL logic levels, as some designers may wish to utilize SSI and MSI TTL logic to control external circuitry, or to add functions not included in the basic set to increase the speed of certain operations.

Other members of the family currently include the following computing elements:

- 3003 Look-Ahead Carry Generator
- 3212 Multi-Mode Latch Buffer
- 3214 Interrupt Control Unit
- 3216 Bidirectional Bus Driver
- 3226 Inverting Bidirectional Bus Driver

The control and main memory portion of the central processor may be implemented with any of the standard bipolar or MOS memory components shown on page 2.

### AN INTRODUCTION TO MICROPROGAMMING

The central processing unit of a general purpose computer usually consists of two portions: an arithmetic portion and a control portion. The control portion determines the sequence of instructions to be executed and presides over their fetching and execution while the arithmetic portion performs arithmetic and logical operations.

The basic operation of the control portion consists of selecting the next instruction from memory, then executing a series of states based upon the instruction fetched. This sequence may be implemented via a combination of flip-flop and random logic, or by the use of tables in control memory.

<sup>&</sup>lt;sup>1</sup>J. Rattner, J. Cornet, and M. E. Hoff, Jr., "Bipolar LSI Computing Elements Usher In New Era of Digital Design," ELECTRONICS, September 5, 1974, pp 89-96.

| PART<br>NUMBER | NUMBER<br>OF PINS | TECHNOLOGY       | DATA<br>ORGANIZATION | ACCESS<br>TIME |
|----------------|-------------------|------------------|----------------------|----------------|
|                |                   | CONTROL MEMOR    | Y                    |                |
| 3601           | 16                | Bipolar PROM     | 256×4                | 70 nS*         |
| 3602           | 16                | Bipolar PROM     | 512×4                | 70 nS          |
| 3604           | 24                | Bipolar PROM     | 512×8                | 70 nS          |
| 3624           | 24                | Bipolar PROM     | 512×8                | 70 nS          |
| 3301A          | 16                | Bipolar ROM      | 256×4                | 45 nS          |
| 3302           | 16                | Bipolar ROM      | 512×4                | 70 nS          |
| 3304A          | 24                | Bipolar ROM      | 512×8                | 70 nS          |
| 3324A          | 24                | Bipolar ROM      | 512×8                | 70 nS          |
| 3106A          | 16                | Bipolar RAM      | 256×1                | 60 nS          |
| 3107A          | 16                | Bipolar RAM      | 256×1                | 60 nS          |
|                |                   | MAIN MEMORY      |                      |                |
| 1702A          | 24                | Static MOS EPROM | 256×8                | 1000 nS        |
| 2704           | 24                | Static MOS EPROM | 512×8                | 500 nS         |
| 2708           | 24                | Static MOS EPROM | 1024×8               | 500 nS         |
| 1302           | 24                | Static MOS ROM   | 256×8                | 1000 nS        |
| 2308           | 24                | Static MOS ROM   | 1024×8               | 500 nS         |
| 2316           | 24                | Static MOS ROM   | 2048×8               | 850 nS         |
| 2101           | 22                | Static MOS RAM   | 256×4                | 1000 nS*       |
| 2102           | 16                | Static MOS RAM   | 1024×1               | 1000 nS*       |
| 2111           | 18                | Static MOS RAM   | 256×4                | 1000 nS*       |
| 2112           | 16                | Static MOS RAM   | 256×4                | 1000 nS*       |
| 2104           | 16                | Dynamic MOS RAM  | 4096×1               |                |
| 2107B          | 22                | Dynamic MOS RAM  | 4096×1               | 200 nS         |
| 5101           | 22                | Static CMOS RAM  | 256×4                | 650 nS         |

Standard Bipolar and MOS Memory Components

\*Higher speed versions of these devices are available. Consult the Intel Data Catalog.

When the latter technique is used, the central processor is said to be microprogrammed.

The functions of the control portion of a microprogrammed central processing unit are very similar to that of a central processing unit itself. To avoid confusion, the terms "micro" and "macro" are used to distinguish those operations in the control unit from those of the realized central processor. For example, the central processor, under the direction of micro-instructions read from its control memory, fetches macro-instructions from main memory. Each macro-instruction is then executed as a series of micro-instructions. Main memory contains macroprograms, while control memory contains microprograms which define the realized central processor.

Figure 1 shows a block diagram of a microprogrammed central processing unit (defined by the dotted boundary). The control unit issues addresses to the control memory and fetches micro-instructions. This control unit uses the contents of control memory (micro-instructions) to drive the data processing unit, external circuits, and to select the



Figure 1. Block Diagram – Microprogrammed Computer

next micro-instruction. The data processing unit performs the actual computations, logical operations, etc.

In the Intel<sup>®</sup> Bipolar Microcomputer set, the 3001 MCU performs the control unit function, while the 3002 CPE is the basic building block for the data processing section.

Thus, within a microprogrammed machine, there are at least two levels of control and two levels of programming to be considered. The designer of a central processor is usually concerned with the definition of the macro-instruction set and its realization as a microprogram. The Intel<sup>®</sup> Series 3000 Bipolar Microcomputer Set establishes a micro-instruction set which is used as a base for the microprograms which generate macro-instruction sets.

The reason for using this microprogrammed approach is that very complex macro-instruction sets can be realized as sequences of relatively primitive micro-instructions. The logic of the final macro-machine remains relatively simple, with most of the design complexity residing in the micro-instruction sequences contained in control memory.

The final user of the computer seldom needs to be aware that the CPU was realized with microprograms rather than hardwired logic. A functional description of the macro-instruction set is usually sufficient for his purposes. However, the user will benefit from the microprogrammed approach if he finds it necessary to alter or enhance the basic macro-instruction set in some fashion. The tabular or programming approach offered by the microprogrammed architecture makes such changes far easier than would be possible in a processor realized via hardwired logic.

# CONSTRUCTING CENTRAL PROCESSING UNITS

### **Basic Design Steps**

To realize a central processor with the Series 3000 computing elements, several steps are necessary:

- 1. Definition of hardware organization.
- 2. Definition of the central processor macroinstruction set.
- 3. Implementation of microprograms which realize the desired macro-instruction set.

### Hardware Organization

A typical CPU constructed utilizing the Series 3000 computing elements will consist of an array of CPE chips, one MCU, and a control memory. The array of CPE chips realizes the arithmetic, logical functions and registers of the CPU, while the combination of the MCU and control memory realizes the control portion. The microprogram contained in control memory initializes the machine when power is first turned on and supervises the fetching and execution of macro-level instructions. In addition, routines to handle such special functions as interrupts will also be contained within the control memory.

The 3002 CPE array contains six buses for communication with external circuitry. Four of these buses are used primarily to communicate with memory and I/O devices while the remaining two, the function control bus (F-Bus) and the control memory data bus (K-Bus), enable the control portion of the processor to drive the CPE array. The function control bus is driven by control memory outputs which direct the CPE array to execute the desired operation. The K-Bus allows the control memory to supply various constants and/or masks to the CPE array.

Because 8 bits of operation code information can be passed directly to the MCU, the set is best adapted to macro-instruction sets in which all of the operation code information is defined by 8 bits (256 unique macro-instructions). However, larger macro-instruction sets can be realized by saving any remaining bits of the operation code in the CPE array or in an external register. The saved bits can then be tested later by routing them to the MCU, through its 8-bit input port.

A "pipelined" mode of operation may be implemented by placing a register of edge triggered D flip-flops between control memory outputs and the circuitry controlled by those outputs. This register causes the execution of a micro-instruction to overlap the fetching of the next micro-instruction. The control lines which issue micro-instruction sequence information to the MCU are not routed through the pipeline register when the pipelined mode is used; they are routed directly from the microprogram memory outputs to the AC0–AC6 inputs of the MCU.

Microprograms written to realize a given macroinstruction set will differ for pipelined and nonpipelined machines. The major differences are associated with conditional jumps in the microprogram which test the results of arithmetic or logical operations executed by the CPE array. In a pipelined machine, these results are delayed by one microinstruction, so that conditional jumps must be delayed by at least one micro-instruction before execution. More detailed information concerning these differences is contained in the microprogramming section of this application note.

Figure 2 shows block diagrams illustrating the organization of standard and pipelined central processing units. The block diagrams show the basic modules of standard and pipelined CPUs: the MCU, CPE array, microprogram memory and the pipeline register. The six buses associated with the CPE array are shown:

- The address bus (A-Bus) to main memory
- The data bus (D-Bus) to memory
- The data bus (M-Bus) from memory with its path for operation code data to the MCU
- The external device input bus (I-Bus), not shown
- The micro-function bus (F-Bus) from the pipeline register
- The constant bus (K-Bus) from the pipeline register

In addition, the carry logic bus to and from the MCU and the micro-instruction sequence logic bus from control memory to the MCU are shown. Additional control fields to such external logic as memory and I/O control are shown as an output bus from control memory.

The number of bits required for each word of control memory, i.e., each micro-instruction, is determined by the number of logical functions the micro-instruction controls. A minimum of 18 bits is usually required for basic hardware control: 7 bits of micro-instruction sequence control to the MCU, (AC0-AC6), 4 bits of carry control to the MCU, (FC0-FC3), and 7 bits of micro-function selection to the CPE array, (F0-F6). That is, the basic hardware requires at least three control word fields of 7 bits, 4 bits, and 7 bits width respectively. Almost every processor will require additional fields to control other logical functions such as main memory control, I/O control, and constant generation. Figure 3 illustrates a typical microinstruction word format with several typical user defined control fields added.



Figure 2. Bipolar Microcomputer Non-Pipelined Organization



Figure 2. Bipolar Microcomputer Pipelined Organization

The constant bus to the CPE array seldom needs to be as wide as the data buses. For example, consider a 16-bit machine where an array of eight CPEs is used. While the constant bus is nominally 16 bits wide, if a limited set of masking operations are used, the number of bits can be reduced significantly. Figure 4 shows how 4 bits can be used to generate the masks for such a machine where the only masks needed are for separating high and low order data bytes, for testing the sign and magnitude of the data word, and for testing the least significant bit of the word. As an example of the use of additional logic to enhance the set, consider the use of a control field (1-bit width) to inhibit the CPE clock. This operation allows non-destructive testing of CPE registers via the MCU carry logic. The carry logic in the MCU responds just as if the micro-instruction were executed, but the fact that the CPE clock was inhibited leaves the CPE registers unaltered. An example of conditional clocking is given in a later section called "Programming Techniques."



Figure 3. General Micro-Instruction Format







Figure 5. Conditional Clocking

### Writing of Microprograms

Once the hardware design is established and the macro-instruction set chosen, the designer should proceed to implement the microprograms for the system. To assist in the writing of these microprograms, Intel has developed CROMIS, a complete microprogramming system for Series 3000 computing elements.

CROMIS consists of two major software subsystems, XMAS and XMAP. XMAS is a symbolic microassembler which is extensible in both microinstruction length and memory address space. XMAP is a complementary subsystem which maps the micro-instruction bit patterns produced by XMAS into compatible ROM/PROM programming files for use with standard memory components.

Programs written in the microassembly language have two main parts, a declaration part in which various aspects of the micro-instruction word are defined and a specification part in which microinstruction contents are symbolically declared. Provision is made for comment statements throughout the program so that the programmer may explain the functions being performed.

The main body of the program, the specification part, defines the sequences of states to be executed, and the operations which take place for each state. The main effort in writing a microprogram will be expended in developing this section.

Each statement of the specification part of the program defines the action (and location) of one micro-instruction, i.e., one word of control memory. The statement will declare, either directly or by default, the contents of each control field for the specified micro-instruction. Furthermore, the statement will include assignment information designating the address in control memory where the statement is located.

A specification statement consists of one or more labels followed by a series of control field specifications. A colon after an entry indicates that it is a label. The contents of the control fields are indicated symbolically, using either standard MCU or CPE symbols or user-defined symbols, or by an equation of the type

### FNM = 101B

where FNM is a name associated with the field. The entry 101B implies the binary value 101. Each symbol is associated with only one field, so that the various symbols can be uniquely interpreted by the assembler. A number of symbols are predefined for the assembler, and are not to be used except as provided by the assembler. These reserved symbols include the standard symbols for the MCU and CPE functions, and a number of directives to the assembler.

### DEFINITION OF CONTROL FIELDS

Each control field added by the hardware designer must be declared to the microprogram assembler. In addition, each bit pattern to be assembled into a word in the control field may be symbolically designated. A FIELD definition statement in the declaration part of the microprogram is used to declare the field by name and define any states.

As an example, let a 2-bit field be defined for memory control. If the programmer wishes to name this field MEMC, and define symbols for the states with 01 corresponding to READ, 10 corresponding to WRITE, and 11 signalling RMW (readmodify-write) and default to 00 if READ, WRITE or RMW is not specified, the statement:

> MEMC FIELD MICROPS (READ=01B, WRITE=10B, RMW=11B) LENGTH=2 DEFAULT=00B;

would perform the definition. The words FIELD, MICROPS, LENGTH, and DEFAULT are directives to the microprogram assembler.

Additional directives include IMPLY, STRING, KBUS, and ADDRESS. The use of these words, and other features of CROMIS are covered in the Series 3000 Cross Microprogramming System Specification.

A typical statement of the specification section might take the form:

78H: LAB: ILR(R3) FF0 STZ JFL(NC TC);

The number 7BH (hexadecimal) followed by a colon tells the assembler that the micro-instruction is assigned to row 7 column 11 of control memory (when control memory is treated as an array of 32 rows and 16 columns). The symbolic label LAB

(the colon indicates a label) is also associated with this location. ILR(R3) indicates that the contents of register 3 are to be conditionally incremented and copied to the AC register, while FF0 forces the carry input to a logic zero, so that the increment operation does not take place. STZ indicates that the Z flip-flop is to be set by the results, so that, as no carry can result, the Z flip-flop will be set to a logic zero. These symbols are standard symbols, with ILR associated with the CPE and FF0 and STZ associated with the MCU carry logic. The JFL tests the carry output line for a conditional jump to either the statement labeled NC or to the statement labeled TC. JFL is also a standard symbol. Note that, if the machine is pipelined, the conditional jump tests the results of the previous instruction, not of the present one. The semicolon indicates the end of the statement.

In the statement above, no information was provided for the K-Bus. It is assumed the assembler will provide the appropriate default value associated with the ILR operation, i.e., the K-Bus at all zeros.

The reader is referred to the Intel<sup>®</sup> Series 3000 Cross Microprogramming System Specification for detailed information concerning CROMIS.

### ASSIGNMENT TO CONTROL MEMORY

The nature of the MCU next state address control requires the programmer to assign control memory locations to each micro-instruction. While this may at first seem unfamiliar, it can usually be easily accomplished if the following sequence is followed:

- 1. The microprogram should be written without regard to address assignment. Then conditional jumps are assigned using the basic conditional jumps provided by the MCU (JFL, JCF, JZF, JPR, JLL, JRL, JPX), noting the number of possible destinations for the conditional jumps chosen. When a sequence of instructions is to be executed unconditionally and does not indicate what jump codes will be used to advance to the next state (unless the JCE enable feature is required), use the non-committal code JMP rather than selecting a JCC, JZR or JCR.
- 2. Prepare a state sequence flowchart for the program (see example, Figure 7). According to the programmer's preference, this may be done before, during or after the actual writing of the code. Label the conditional jump points on the flowchart.

3. Using the flowchart as a guide, perform the assignment. In general, conditional jumps should be assigned first, with clusters of conditional jumps assigned before isolated jumps. Leave long chains of unconditional sequences for last. The process of assignment can be assisted by using a diagram of the control memory showing the 32 rows and 16 columns. As each state is assigned, the control memory diagram is marked to show occupancy of that word and the flowchart marked to show the assignment of the state. With the assignment complete, the addresses are copied from the memory diagram.

One other procedure in microprogram memory assignment has been found to be useful. When the control memory diagram is marked as each state is assigned, it is helpful to include state linkage information in the diagram, i.e., memory location(s) that reference the current location and memory location(s) referenced by the current location. With the additional information, micro-instruction sequences can be easily traced on the control memory diagram.

The state linkage information can be quite useful when most of the microcode has been assigned and only a few locations are left to assign the remaining states. If reassignment of memory locations becomes necessary in order to assign the remaining microcode, or modify the existing microcode, the state linkage information will greatly simplify the task.

When reassignment becomes necessary, sequences of unconditional micro-instructions should be considered first since they are the easiest to move. Therefore, these types of states are useful to annotate.

In some cases, a particular sequence may be impossible to assign as written. For example, consider the following section of microprogram:

/\* ENTER WITH INSTRUCTION DISPLACEMENT "D" IN AC, SAVE AT R9 \*/ 175: SDR(9) FFI JPX(M0, M1, M2, M3, M4, M5, M6, M7, M8, M9, MA, MB, MC, MD, ME, MFI; /\* ALSO TESTS HIGH 4 BITS OF MACRO-INSTRUCTION \*/ /\* M0\_MACRO\_INSTRUCTION RGDUP 1 FETCH R3 \*/

| 10 - | - Acric | 1113111001 |     |           |
|------|---------|------------|-----|-----------|
| 128: | MO:     | ILR(R2)    | FF0 | JMP(M1P); |

| 129: | M1:   | ILR(R3) | FFO; |  |
|------|-------|---------|------|--|
|      | M 1P: | ADR(R9) | FFO; |  |



Figure 6. Operation MIP Can Be Reached From Both M0 and M1 by Locating MIP in Row 0 or Duplicating it in Both Column 0 and Column 1

In the above example, MIP follows both M0 and M1. Since the row in which M0 and M1 reside is completely filled, MIP must be located in row zero (because the JZR jump operation allows a location in row zero to be reached from anywhere in memory). If row zero were already fully occupied, the assignment could not be made. However, in this case the state represented by MIP might be duplicated so that it can be reached from state M0 and M1. No extra execution time is added by this modification, although one more memory location is used.

When assigning to memory, row zero locations should be used judiciously, but not sparingly, because only they can be reached from anywhere else in the program using a single JZR jump function.

Finally, in a 512-word microprogram memory there are 64 possible destination pairs for the JCF, JZF and JFL conditional jump functions, since all three use columns 2 and 3 or columns 10 and 11 as their jump target. It is therefore important to insure that enough destination pairs are available for the conditional jumps used in a microprogram.

### PROGRAMMING TECHNIQUES

Because of the flexibility of both the micro-operations and the architecture of the Series 3000 computing elements, a number of programming "tricks" can be used to implement a desired operation. As the programmer becomes more familiar with the set, he will find new ways to perform different functions. The list of operations given here are intended as examples. In general, the labels indicating assignments to memory are not shown. In all of the examples, KB is the name associated with the K-Bus field of the micro-instruction. Statements bounded by /\*...\*/ are comments and do not affect the assembly. 1. Forcing a fixed address to access a predetermined location in memory or to select a specific I/O device. (Also may be used to load literals.)

```
CLR(N) :
LMI(N) KB=DESAD ;
```

The first operation clears the register selected by N, while the second loads the logical OR of the contents of N and the contents of the K-Bus to the memory address register (MAR) of the CPE array and into register N. DESAD is a symbol for the desired address value previously defined by the programmer. The pair of micro-ops above may also be used to set any register to any desired constant, although the contents of the MAR are destroyed.

2. Any register may be set to all 1's by the operation

CSR(N) FF0

3. A value read from memory or I/O into the AC may be split into bytes and stored in another register as follows:

```
SDR(N) FF1 KFF00; /* STORE RIGHT BYTE IN REG N */
SDR(AC) FF1 K00FF; /* SET LEFT BYTE OF AC TO ZERO */
```

where KFF00 is a symbol which causes the K-Bus to be set to 1111 1111 0000 0000 in binary, and K00FF is a symbol for setting the K-Bus to 0000 0000 1111 1111 in binary. The high order byte is placed in the upper byte of register N while the low order byte remains in the low position of the AC. The low byte of register N and high byte of the AC are cleared.

4. Sign Testing and Absolute Magnitude – To test sign bits most effectively, an inhibit operation at the CPE clock is very desirable. In the following examples the symbol INH implies a signal from the control memory to inhibit the CPE clock. This prevents modification of the AC register.

The operations

AN

ΔP-

TZR(AC) K8000 INH JFL(AP,AN); CIA(AC) ;

generate the absolute magnitude of AC in AC for the non-pipelined case (note K8000 implies 1000 0000 0000 0000 on the K-Bus) while

```
        TZR(AC)
        K8000
        INH
        :

        NOP
        JFL(AP,AN);
        .

        AN:
        CIA(AC)
        .
        .

        AP:
        .
        .
        .
```

performs the same operation for the pipelined case.

3-28

When two numbers in AC and T must be converted to positive numbers and the signs saved, as well as the sign of the product, the following routine may be used for a pipelined machine.

| /* | ENTER | WITH VAL   | UES IN T | , AC * | /             |                                  |  |
|----|-------|------------|----------|--------|---------------|----------------------------------|--|
| /• | FIRST | CLEAR SIG  | N AREA   | REG    | STER 9 FOR TH | IS EXAMPLE */                    |  |
|    | CLRIR | 9),        |          |        |               |                                  |  |
| /• | NEXT  | TEST SIGNS | OF AC,   | THEN 1 | •/            |                                  |  |
|    |       | TZR(AC)    | K8000    | INH;   | /* TEST AC S  | GN BIT */                        |  |
|    |       | TZR(T)     | K8000    | INH    | JFL(AP,AN);   | /* TEST T SIGN BIT */            |  |
|    | AP:   | LMI(R9)    | K8000    | FF1    | JFL(TP,TN);   | /* SET HIGH AND LOW ORDER BIT */ |  |
|    | AN:   | CIA(AC)    |          |        | JFL(TP,TN);   | /* COMPLEMENT AC */              |  |
|    | TP:   | LMI(R9)    | K4000    | FF1    | JMP(NXOP);    | /* SET BIT 15 */                 |  |
|    | TN:   | CIA(T);    |          |        |               | / COMPLEMENT T /                 |  |
| N: | KOP   |            |          |        |               |                                  |  |
|    |       |            |          |        |               |                                  |  |

Upon reaching label NXOP, both AC and T will contain positive numbers (high order bit = 0) and register 9 will contain a 1 in the high order bit if and only if AC was originally positive, a 1 in the second bit from the top if and only if T was originally positive, and a zero in the low order bit if and only if the signs were the same. A one will appear in the second lowest order bit if and only if both numbers were originally positive. Execution of the sequence takes 5 micro-instruction cycles.

5. Pipelined Multiply – Assume that AC and T represent the partial product and multiplier respectively, while register 9 contains the multiplicand and register 8 will be used as a loop counter. Register 7 is used for temporary storage. It is assumed that both numbers are positive.

```
/* SET UP LOOP COUNTER */
  MCL: CSR(R8) K0000; /* SET R8 TO FFFF HFX *
         TZR(RB) KFFF0; / SET RB TO FFF0 HEX 1
/* CLEAR PARTIAL PRODUCT (AC) */
CLR(ACI;
/* FETCH AND TEST MULTIPLIER LOW ORDER BIT */
         SRA(T)
/* MAIN LOOP -- EXECUTE MULTIPLIER BIT TEST, ADD IF NECESSARY */
  MLP: LMI(R8) FF1 ST2 JFL(MBZ,MB1), /* INCREMENT LOOP COUNTER SAVE IN Z */
/* ADD SEQUENCE */
  MB1: SDR(R7) FF1: /* SAVE AC IN REG7 */
         ILR(R9) FF0, /* PLACE MULTIPLICAND, R9, IN AC
         ALR(R7) FF0 /* ADD MULTIPLICAND TO PARTIAL PRODUCT */
/* NOW ROTATE. THEN TEST LOOP COUNT ~ SAVED IN Z */
/* NOTE - PIPELINE ALLOWS USE OF Z FOR SHIFT BIT PROPAGATION */
  NOTE THE SDR(R7), ILR(R9), AND ALR(R7) MICRO-INSTRUCTIONS CAN BE
REPLACED WITH AN AMA MICRO-INSTRUCTION ELIMINATING Z INSTRUCTIONS
FROM THE INNER LOOP IF DATA IS LATCHED ON THE MBUS '/
  MBZ: SRA(AC) FF0 STZ;
                                           /* SHIFT PARTIAL PRODUCT, SAVE LSB */
                     FFZ_JZF(MLP,MEX); /* Z TEST IF OF LOOP COUNTI */
         SRA(T)
  MEX
```

Note that the pipeline causes the JZF (or a JCF) to test the contents of the flip-flop as set two or more instructions earlier.

A state sequence flow diagram for the multiply sequence might be drawn as shown in Figure 7.

Note that in Figure 7, each symbolically labeled state is noted, and each conditional jump is indicated and the conditions corresponding to each jump are noted. A flowchart like that of Figure 7 contains sufficient information to perform the assignment to memory. An assignment might be as shown in Figure 8.



Figure 7. State Sequence Flow Diagram – Multiply Loop

|        | COL<br>0  | COL<br>1  | COL<br>2 | COL<br>3 | COL<br>4  | COL<br>5  |
|--------|-----------|-----------|----------|----------|-----------|-----------|
| ROW 9  | MCL       | MCL<br>+1 | MLP      | MEX      | MCL<br>+2 | MCL<br>+3 |
| ROW 10 | MB1<br>+1 | MB1<br>+2 | MBZ      | MB1      |           |           |

Figure 8. An Assignment of the Multiply Loop to Control Memory

Because MLP and MEX are the two destinations. of a JZF jump function, they must be in the same row, in columns two and three respectively or in columns 10 and 11 respectively. Since MLP executes a JFL to MBZ, MB1, then MBZ and MB1 must be in the same pair of columns as MLP and MEX. For the example, rows 9 and 10 were chosen, and columns 2 and 3, and the four states MLP, MEX, MBZ, MB1 are assigned first. Next the states following MBL (indicated by MB1+1 and MB1+2) and MBZ are assigned. As all of these jumps are unconditional, the operations JCC, JCR, and JZR are used. As the JZR is usually reserved for entry to commonly used routines, only the JCC and JCR jumps are used here.

To demonstrate the techniques introduced above, a central processing unit design cycle will be carried through from initial specification to final microprogram memory assignment.

### A DESIGN EXAMPLE

The following design example illustrates some of the basic techniques which may be used in developing a central processor with the Intel<sup>®</sup> Series 3000 Bipolar Microcomputer Set. The basic design sequence consists of stating the machine objectives, then designing the hardware configuration and microprograms. For this example, it is assumed that the designer has the freedom to specify operation code assignments, and to modify the instruction set to take greatest advantage of the chip set's capabilities.

### **Initial Specifications**

Let the following list of design objectives represent the initial specifications for a central processor instruction set.

- 1. The machine should use a 16-bit data path, with instructions containing an opcode portion and a data or displacement portion.
- 2. Machine registers should include a program counter, P, a stack pointer, S, an accumulator, A, an index register, X, and two base registers. B and E. B is a base register for data and E is a base register for program. In addition, a carry flip-flop may be a bit in the status word, W.
- 3. References to memory for data should be relative to the B register, using the displacement portion of the instruction (designated D). Memory reference modes include direct (Address=B+D), indirect (address equals the contents of B+D), and indirect indexed (address equals the value given by the sum of X and the contents of the word at address B+D). Indirect and indirect-indexed modes should include both absolute and B relative (i.e., the address is relative to the contents of the B register) forms so that indirections may be computed both at time of assembly and during program execution.
- 4. Memory reference instructions include: load address to A, load data to A, AND data to A, OR data to A, XOR data to A, add data to A, subtract data from A, push address to stack, push data to stack, store A at computed address, pop stack to computed address, load address to X, load data to X, add data to X, subtract data from X, store X at computed address (operations involving X may not need to implement indirect-indexed modes).
- 5. Immediate instructions using the displacement portion of the instruction as the data, include, load A, load X, add to A, add to X. A two word "load immediate" instruction may also be implemented.
- 6. Jump instructions include a short relative jump (Address=P+D-K, where K is a constant), an indirect jump to an address relative to the E base register, and an indirect call operation.
- 7. The call (to a subroutine) operation saves the P, E, B, and W registers (global call), or the P register (local call) on the stack and loads the

P register with the starting address of the routine. Similarly, a return instruction restores the appropriate registers. Some jumps may also be conditional, checking the status of the C flip-flop, or the sign or magnitude of the A register.

- 8. Additional operations may involve manipulations of data in the A and X registers and the ability to move data between the X and the W, B, E or S registers.
- 9. Byte load and store operations should include automatic packing and unpacking of bytes in a 16-bit memory location.
- 10. Input/output instructions should use either the displacement or the X register to specify the I/O device address.

In addition to the definition of the macro-instruction set, the designer should also prepare descriptions of the initialization operations (i.e., at "power on") and interrupt handling to be used. For this machine, let it be considered necessary for the machine to start at power up with W, A, and X cleared and for S to be set to the contents of word 0, B to be set to the contents of word 1 of memory, E set to the contents of word 2, and P set to the contents of the memory location pointed to by E.

Let I/O device 0 represent a source of interrupt level information (level requesting in) and a destination for current level out, consistent with the use of the 3214 Interrupt Control chip. In addition, let the low order bits of W contain current interrupt level information.

When servicing an interrupt, the processor will execute a jump to subroutine which will reload P and E while saving all registers except S on the stack. The service routine will interrogate the interrupt hardware to determine the level of the request and will restore former status upon exit from the interrupt program. For this purpose, a return and restore status instruction will be provided.

In parallel with the specification of the design objectives, a first pass at the CPU's architecture can be made. The block diagram in Figure 9 shows a general CPU architecture as defined in the initial specification above.

The design example machine uses a pipelined architecture and includes a control structure which implements eight basic memory bus and clock operations. A 3-bit field is used to control this structure. The states for this field are designated



Figure 9. Block Diagram of CPU Architecture

NBO (No Bus Operation), INH (Inhibit CPE Clock), CNB (CPE uses bus), RMW (read modify write signal to memory – starts a read cycle and prevents release of bus until the CPU executes a write cycle), RRM (Request read cycle from memory), RWM (Request write to memory), RIN (Request input from an I/O device), and ROT (Request an output to an I/O device).

The stack has been designed to run "backwards" through memory, with a pop incrementing the

stack pointer and a push decrementing it. This direction is preferred, as it leaves the stack pointer pointing at the topmost entry in the stack. In addition, pops usually appear more often than pushes (pushes share code), and the increment operation requires fewer micro-instructions.

The designer must select the actual instructions to be used. Let the instructions and their associated mnemonics shown in Table I be selected in the first design pass.

### Table I. Proposed Instruction Set

|         | MEMORY REFERENCE GROUP |
|---------|------------------------|
| MNEMONI | C FUNCTION             |
| LAA     | Load address to A      |
| LDA     | Load data to A         |
| ADA     | Add data to A          |
| SDA     | Subtract data from A   |
| NDA     | AND data to A          |
| ODA     | OR data to A           |
| XDA     | Exclusive OR data to A |
| PAS     | Push address to stack  |
| PDS     | Push data to stack     |
| SAM     | Store A into memory    |
| PSM     | Pop stack into memory  |
| LAX     | Load address to X      |
| LDX     | Load data to X         |
| ADX     | Add data to X          |
| SDX     | Subtract data from X   |
| SXM     | Store X in memory      |

### IMMEDIATE GROUP

| MNEMONIC | FUNCTION                    |
|----------|-----------------------------|
| LAI      | Load to A immediate         |
| AAI      | Add to A immediate          |
| NAI      | AND to A immediate          |
| OAI      | OR to A immediate           |
| XAI      | Exclusive OR to A immediate |
| PSI      | Push to stack immediate     |
| LXI      | Load to X immediate         |
| AXI      | Add to X immediate          |
|          |                             |

If D is equal to zero, the contents of the memory location following the instruction is used as the immediate value.

| JUMP GROUP       |                   |                    |  |  |  |
|------------------|-------------------|--------------------|--|--|--|
| MNEN<br>RELATIVE | IONIC<br>INDIRECT | FUNCTION           |  |  |  |
| JRU              | JIU               | Jump unconditional |  |  |  |
| JRGE             | JIGE              | Jump if A≥0        |  |  |  |
| JRLT             | JILT              | Jump if A<0        |  |  |  |
| JRXG             | JIXG              | Jump if X>A        |  |  |  |
| JREZ             | JIEZ              | Jump if A=0        |  |  |  |
| JRNZ             | JINZ              | Jump if A≠0        |  |  |  |

| JUMP GROUP (continued)                               |      |             |  |
|------------------------------------------------------|------|-------------|--|
| MNEMONIC<br>RELATIVE INDIRECT                        |      | FUNCTION    |  |
| JRCZ                                                 | JICZ | Jump if C=0 |  |
| JRXL                                                 | JIXL | Jump if X≪A |  |
| JRLE                                                 | JILE | Jump if A≪0 |  |
| JRGT                                                 | JIGT | Jump if A>0 |  |
| JRCN                                                 | JICN | Jump if C≠0 |  |
| JRXE                                                 | JIXE | Jump if X=A |  |
| Jump relative: P=P+D-128<br>Jump indirect: P=(E+D)+E |      |             |  |

### STACK PUSH AND POP GROUP

| MNEMONIC | FUNCTION                      |  |
|----------|-------------------------------|--|
| РНАХ     | Push A and X onto stack       |  |
| PPAX     | Pop A and X from top of stack |  |

### SPECIAL MEMORY REFERENCE INSTRUCTION

| MNEMONIC | FUNCTION |
|----------|----------|
|          |          |

| ISZ Inc | rement location | B+D | and skip | it | zero |
|---------|-----------------|-----|----------|----|------|
|---------|-----------------|-----|----------|----|------|

### SUBROUTINE CALL GROUP

| MNEMONIC | FUNCTION                                                                                           |  |  |
|----------|----------------------------------------------------------------------------------------------------|--|--|
| CLS      | Call local subroutine, push P onto stack<br>P=E+(E+D)                                              |  |  |
| CVS      | Call value subroutine, push W, B, E, P<br>onto stack<br>E=E+(E+D)<br>P=E'+(E')<br>where E'=E+(E+D) |  |  |
| CAS      | Call absolute subroutine, push W, B, E, P<br>onto stack<br>P=(D)                                   |  |  |

### SUBROUTINE RETURN GROUP

| MNEMONIC | FUNCTION                                                                |  |  |
|----------|-------------------------------------------------------------------------|--|--|
| RLS      | Return from local subroutine, pop P from stack                          |  |  |
| RVS      | Return from value subroutine, pop P, E,<br>B, W from stack              |  |  |
| RSA      | Return from subroutine, restore all, pop<br>A, X, P, E, B, W from stack |  |  |

### Table I. Proposed Instruction Set (continued)

### DVTE LOAD AND ATODE ODOUD

| BTTE LUAD AND STORE GROUP |                              | INPUT/OUTPUT GROUP                        |                                                         |  |  |
|---------------------------|------------------------------|-------------------------------------------|---------------------------------------------------------|--|--|
| MNEMONIC                  | FUNCTION                     | MNEMONIC                                  | FUNCTION                                                |  |  |
| LBA                       | Load byte absolute           | IND                                       | Input one word to the A register                        |  |  |
| LBR                       | Load byte relative           | OTD                                       | Output one word from the A register                     |  |  |
| SBA Store byte absolute   |                              | D serves as the address for the I/O port. |                                                         |  |  |
| SBR                       | Store byte relative          | INX                                       | Input one word to the A register                        |  |  |
| Absolute mode:            | Byte address = $(B+D)+X/2$   | отх                                       | Output one word from the A register                     |  |  |
| Relative mode:            | Byte address = $(B+D)+B+X/2$ | The X register pr                         | The X register provides the address for the $I/O$ port. |  |  |

The least significant bit of the X register is treated as the byte pointer in main memory as follows:

X Reg. LSB = 0 the left or high order byte is selected = 1 the right or low order byte is selected

For load operations, the selected byte is loaded into the right byte position of the A register and the left byte is cleared. For store operations, the right byte of the A register is stored at the selected byte location leaving the unselected byte of the word unaltered.

| REGISTER MANIPULATION GROUP |                                    |  |  |
|-----------------------------|------------------------------------|--|--|
| MNEMONIC FUNCTION           |                                    |  |  |
| RAR                         | Rotate A right, include CFF        |  |  |
| RAX                         | Rotate A and X right, include CFF  |  |  |
| SAX                         | Shift A and X right, preserve sign |  |  |
| SAL                         | Shift A left, fill with zeros      |  |  |

The shift count is given by D if D is non-zero or by the least significant seven bits of the X register if D is zero.

| MNEMONIC | FUNCTION            |  |  |
|----------|---------------------|--|--|
| MSX      | Move S to X, adjust |  |  |
| МВХ      | Move B to X, adjust |  |  |
| MEX      | Move E to X, adjust |  |  |
| MWX      | Move W to X, adjust |  |  |
| MXS      | Move X to S, adjust |  |  |
| МХВ      | Move X to B, adjust |  |  |
| MXE      | Move X to E, adjust |  |  |
| MXW      | Move X to W, adjust |  |  |

The destination register is adjusted by D-128 (i.e., D-128 is added to the destination register).

| MNEMONIC          | FUNCTION                             |  |  |
|-------------------|--------------------------------------|--|--|
| IND               | Input one word to the A register     |  |  |
| OTD               | Output one word from the A register  |  |  |
| D serves as the a | ddress for the I/O port.             |  |  |
| INX               | Input one word to the A register     |  |  |
| отх               | Output one word from the A register  |  |  |
| The X register pr | ovides the address for the I/O port. |  |  |

NOUT/OUTDUT ODOUD

Given the basic design objectives, the next step is to write the sequences of micro-instructions to implement the macro-instruction described above. Each macro-instruction must be assigned a unique operation code. The operation code (opcode) will be used by the 3001 MCU to generate the appropriate address for the micro-instruction which executes that macro-instruction.

### **Macro-Instruction Decoding**

To take full advantage of the 3001 MCU's eight input lines (SX0-3, PX4-7) for instruction decoding, all macro-instruction operations should be completely specified in an 8-bit opcode field and use the remaining 8 bits for displacement values. In Figure 10 the 8-bit opcode of a macro-instruction being read in on the memory data bus is gated directly to the 3001 MCU. While the displacement is being stored in the CPE array, a JPX operation is



the 3001

executed by the 3001. The JPX operation executes a 16 way branch based on the 4 bits of the PX lines and also stores the 4 bits on the SX lines in the PR latches for later decoding. For best microcode efficiency then, the opcode field should be arranged in such a manner that the first 4 bits tested (by the JPX operation) select the initial processing (usually an address calculation) of the macro-instruction. A possible instruction format is shown in Figure 11.



Figure 11. Possible Macro-Instruction Format

In the case of the CPU design example, the initial processing involves address calculations and/or operand fetching. Table II contains the initial processing modes for the design example.

### Table II. Memory Modes

In the description below, the letters A, X, B, S, P, W, and E represent the contents of the respective registers. D represents the 8-bit displacement treated as a positive number ranging from 0 to 255. D' represents D-128. () are used to designate contents of memory. For example, (B+D) means the contents of the memory location whose address is equal to the sum of the contents of B and the displacement D. It is assumed that, when the instruction is fetched, P is incremented prior to instruction execution.

### MEMORY REFERENCE MODES

- 1. Direct: Address = B+D
- 2. Indirect: Address = (B+D)
- 3. Indirect relative: Address = (B+D)+B
- 4. Indirect indexed: Address = (B+D)+X
- 5. Indirect indexed relative: Address = (B+D)+B+X

### IMMEDIATE MODES

If D≠0, Data = D-128
 If D=0, Data = (P), P=P+1

### JUMP MODES

- 7. Jump relative: P=P+D-128
- 8. Jump indirect: P=(E+D)+E
- 9. Call relative: P=(E+D)+E
- 10. Call indirect: P=E'+(E') where E'=E+(E+D)

### **REGISTER MODE**

### 11. Fetch source register

Using the instruction format shown in Figure 11, the high order 4 bits (bits 12 to 15) will be used to select one of the modes listed in Table II. Thus, by executing a JPX operation, a 16 way branch on the PX0-PX3 bus can be performed to determine the address mode specified. At the same time the SX bus bits (the Operation Code field) will be stored in the PR latches for later use. A possible assignment of the first 4 bits (bits 12 through 15) might be as shown in Table III. In addition to the initial address mode processing input/output, register to register, and other special function operations can be specified in the first 4 bits, as shown in Table III.

### **Microprogram Implementation**

Having assigned the first 4 bits of the macroinstruction operation code, the next 4 may be tentatively assigned. These 4 bits will have different meanings for different instruction classes. To improve microcode efficiency it is desirable to share as much code as possible between different microprogram segments. For example, the ADA and AAI instructions might share the add operation once the data has been fetched.

# MEMORY REFERENCE AND IMMEDIATE GROUP

The assignment shown in Table IV might be used for the memory reference and immediate group instructions. The clustering has been chosen in a way that should allow JPR and JLL and JRL micro-operations to be used effectively and to allow code sharing between the two groups.

An initial flowchart for the memory reference and immediate group instructions is shown in Figure 12. In the flowchart, the boxes indicate the operations performed. The appropriate jump operations (JPX, JLL and JRL) are indicated along with the bit patterns that select each box.

It is possible that when the actual code for the sequence is written, some improvements in efficiency may still be made. In addition, some of the boxes shown as dummies may be eliminated by suitable placement of the JLL and JRL instructions.

Knowledge of the MCU assignment restrictions may also influence some choices here. For example, the MCU provides twice as many possible JLL jump destinations as JRL jump destinations, while the sequence shown uses twice as many JRLs as JLLs. As a result, an easier assignment might be obtained if the JLLs and JRLs were exchanged, which is equivalent to a reassignment of the macrooperation codes.

Also, recognizing that the MCU's JCC type jump facilitates jumping from one JLL destination to another, it is desirable to assign the macro-operation codes so that operations which share final segments are aligned in columns. For example, the SDA instruction would typically be achieved by complementing the data, then adding it to A, which may share the code for ADA. As a result, a

| ADDRESS MODE<br>BITS | MODE                               | INITIAL PROCESS | SUBSEQUENT PROCESSING |
|----------------------|------------------------------------|-----------------|-----------------------|
| 0000                 | No operation                       |                 |                       |
| 0001                 | Jump relative                      | P+D'            | Condition testing     |
| 0010                 | Jumps (index, etc.)                | (E+D)+E         |                       |
| 0011                 | Immediate                          | D' or (P)       | LAI, AAI, etc.        |
| 0100                 | Direct memory reference            | B+D             |                       |
| 0101                 | Indirect memory reference          | (B+D)           |                       |
| 0110                 | Indirect index                     | (B+D)+X         | LAA, LDA, etc.        |
| 0111                 | Indirect index relative            | (B+D)+X+B       |                       |
| 1000                 | I/O input                          | D → MAR         |                       |
| 1001                 | I/O input                          | X → MAR         |                       |
| 1010                 | I/O output                         | D → MAR         |                       |
| 1011                 | I/O output                         | X → MAR         |                       |
| 1100                 | Move group                         |                 |                       |
| 1101                 | Special function group             |                 | Shift A               |
| 1110                 | Indirect relative memory reference | (B+D)+B         |                       |
| 1111                 | No operation                       |                 |                       |

Table III. Mode Bit Assignments

### Table IV. Memory Reference and Immediate Op Code Assignment

| OP FIELD<br>BITS | MEMORY<br>REFERENCE<br>FUNCTION | IMMEDIATE<br>FUNCTION |
|------------------|---------------------------------|-----------------------|
| 0000             | ADA                             | AAI                   |
| 0001             | ADX                             | AXI                   |
| 0010             | NDA                             | NAI                   |
| 0011             | ODA                             | OAI                   |
| 0100             | LDA                             | LAI                   |
| 0101             | LDX                             | LXI                   |
| 0110             | PDS                             | PSI                   |
| 0111             | XDA                             | XAI                   |
| 1000             | LAA                             |                       |
| 1001             | LAX                             |                       |
| 1010             | PAS                             |                       |
| 1011             | SDA                             |                       |
| 1100             | SAM                             |                       |
| 1101             | SXM                             |                       |
| 1110             | PSM                             |                       |
| 1111             | SDX                             |                       |
|                  |                                 |                       |

better assignment of opcodes might be achieved by placing ADA and SDA in the same column. For example, see the assignment shown in Table V. Table V also assumes exchange of the JLL and JRL instructions.

### Table V. Modified Memory Reference Op Code Assignments

| 0000 = NDA | 0100 = ODA | 1000 = XDA | 1100 = ADA |
|------------|------------|------------|------------|
| 0001 = LDA | 0101 = LDX | 1001 = PDS | 1101 = ADX |
| 0010 = LAA | 0110 = LAX | 1010 = PAS | 1110 = SDA |
| 0011 ≈ SAM | 0111 = SXM | 1011 = PSM | 1111 = SDX |

Except for those considerations mentioned above, the code is most easily written without regard to memory assignment. Also, it is assumed that reassignments of macro-operations codes are made when efficiency can be improved.

Let the CPE register assignments be made as shown in Table VI.

The code which follows represents the specification portion of the microprogram in which the various fields are identified, and symbols defined.



Figure 12. First Pass of Memory Reference Group Flowchart

| /* | BIPOLAR MICROCOMPUTER MACRO-MACHINE<br>REGISTER MACHINE12/13/74<br>UPDATED 3/18/75 |                       |    |
|----|------------------------------------------------------------------------------------|-----------------------|----|
|    | MACHINE HAS 7 REGISTERS AS FOLLOWS:                                                |                       |    |
|    | А                                                                                  | ACCUMULATOR           | RO |
|    | х                                                                                  | INDEX REGISTER        | R1 |
|    | Р                                                                                  | PROGRAM COUNTER       | R3 |
|    | S                                                                                  | STACK POINTER         | R4 |
|    | В                                                                                  | DATA BASE REG         | R5 |
|    | E                                                                                  | PROG. BASE REG.       | R6 |
|    | W                                                                                  | STATUS WORD           | R7 |
| ,  | C=CARRY,LI                                                                         | NK FLIP-FLOP=HOB OF \ | N  |
|    | DEFINITION                                                                         | OF KBUS FIELD */      |    |

|    |                                               | MICROPS(                                                                             | K0000=0<br>K8000=8                                                                           | K007F=1<br>KFF00=12          | K000FF=3<br>KFF80=14           | K7FFF=7<br>KFFFF=15):      |
|----|-----------------------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|------------------------------|--------------------------------|----------------------------|
|    | КВ                                            | KBUS;                                                                                |                                                                                              |                              |                                |                            |
| /* | DEFINITION                                    | OF BUS CO                                                                            | ONTROL FIEL                                                                                  | D */                         |                                |                            |
|    | MCF                                           | FIELD<br>MICROPS(                                                                    | LENGTH=3<br>NBO=000B<br>RIN=100B                                                             | DEF,<br>INH=001B<br>ROT=101B | AULT=0<br>RMW=010E<br>RRM=110E | 3 CNB=011B<br>3 RWM=111B); |
| /* | INH<br>RMW<br>CNB<br>RIN<br>ROT<br>RRM<br>RWM | NBO<br>INHIBIT C<br>READ-MOI<br>CPU NEED<br>REQUEST<br>REQUEST<br>REQUEST<br>REQUEST | NO BUS OPE<br>PE ARRAY<br>DIFY-WRITE<br>IS BUS<br>INPUT<br>OUTPUT<br>READ MEM.<br>WRITE MEM. | RATION                       |                                |                            |
|    | SET UP FOR                                    | SYMBOLIC                                                                             | REPRESENT                                                                                    | ATION OF RE                  | GISTER DESIG                   | NATIONS */                 |
|    | A<br>X<br>P<br>S<br>B                         | STRING<br>STRING<br>STRING<br>STRING<br>STRING                                       | 'R0';<br>'R1';<br>'R3';<br>'R4';<br>'R5';                                                    |                              |                                |                            |

DEFAULT=0

Е STRING 'R6';

КΒ

ľ

w STRING 'R7';

/\* SET UP A SPECIAL NO.OP STRING \*/

FIELD

LENGTH=4

NO.OP STRING 'NOP(R3)';

/\* NEXT WE SPECIFY A DEFAULT TO FF1 IN THE FO FIELD FOR THE SDR MICROP IN THE CPE FIELD. SDR IS NORMALLY USED AS A STORE OPERATION. WHEN A DECREMENT OPERATION IS ALSO DESIRED, FF0 WILL HAVE TO BE EXPLICITLY SPECIFIED \*/

SDR IMPLY FO=11B;

| Table VI. R | egister Assignments            |
|-------------|--------------------------------|
| R0          | = A                            |
| R1          | = X                            |
| R3          | = P                            |
| R4          | = S                            |
| R5          | = B                            |
| R6          | = E                            |
| R7          | = W (C is high order bit of W) |

The next portion of the code represents the machine initialization (in which registers are set to initial values during power up), and the memory reference and immediate group of instructions. The elementary flowchart followed is that of Figure 13, reflecting the reassignment shown in Table V.

A number of programming "tricks" can be found in the microcode. For example, the C flag of the MCU (not to be confused with the C flip-flop of the macro machine) is set each time the machine executes a fetch instruction by the SDR microoperation. SDR adds 111...1 to the AC (as masked by the K-Bus) so that whenever the carry input of the CPE array is a 1, the masked AC register will be stored unchanged into the designated register, and the carry output of the CPE array will be 1. Similarly, a ILR micro-operation (KBUS = 0) with a carry-in of zero never generates a carry, so that it can be used to clear the C flag if so desired.


Figure 13. Second Pass of Memory Reference Group Flowchart

The C flag is used to implement a type of microcode subroutine where code is shared by two "calling" routines, one which leaves the C flag unchanged and the other which clears it. Upon exit from the shared code sequence, the C flag is tested giving a unique exit for each of the two calling routines (see Figure 14).

The inhibit operation, indicated by the "INH" micro-operation, inhibits the clock to the CPE array. For these operations the carry function and conditional jump results are the same as if the operation were executed. However, none of the CPE registers are altered when the clock is inhibited.



# Figure 14. Microcode Subroutine Using the C-Flag to Determine Exit

The result is a number of "compare" or test micro-operations.

In general, row zero locations should be used sparingly because they are the only locations that can be reached from anywhere in microprogram memory using a single JZR micro-operation. During the first pass of the microprogram implementation, notes can be added to indicate where code might be saved if row zero locations are used.

A common case of such microcode saving follows the execution of a JPR or JPX micro-operation. If the datum being tested by the JPR or JPX represents a macro-instruction operation code in which less than 16 modes are used, there is always the possibility that an invalid code might be encountered. Rather than have the machine behave unpredictably, it is better to have the machine execute some designated sequence for invalid macrooperation codes. As a result, all 16 locations reached by the JPX or JPR micro-operation must be considered occupied. Therefore, when it is desirable to have a single state follow each of several states reached by a single JPX or JPR microoperation, two possible methods can be used which do not require additional jump micro-operations:

- 1. Locate the single state in the row zero
- 2. Locate the single state in a column reached by a JCF or JZF micro-instruction and insure the corresponding (C or Z) flag is in the desired state.

As an example of this situation, consider the following sequence of micro-instructions (only labels and jumps shown):

In the sequence above, D0 through D15 occupy an entire row. The micro-instruction labeled D1A unconditionally follows both of those labeled D0 and D1. Since the row containing D0 through D15 is fully occupied, D1A cannot be assigned to that row. The only other unconditional jump which can reach a common location from more than one column is the JZR. However, such conditional jumps as JCF and JZF, where the condition is pre-set, can jump to a given location from up to eight sites in a given row, as illustrated in Figure 15.



Figure 15. Special Use of the Conditional Jump Functions

/\* INITIALIZATION SEQUENCE ZERO A, X, AND W \*/

INIT: CLR(A); CLR(X); GLR(W);

/\* ZERO T AS TEMPORARY POINTER, WRITE W TO INTERRUPT STRUCTURE \*/

CLR(T); LMI(T); ILR(W) ROT;

/\* SET S = (0), T = 1 FOR NEXT OPERATION \*/

LMI(T) FF1 RRM; ACM(AC) ; SDR(S);

/\* SET B = (1), T = 2 FOR NEXT OPERATION \*/

LMI(T) FF1 RRM; ACM(AC); SDR(B) STC; /

/\* THIS SETS THE C FLAG TO INSURE A CORRECT JUMP TO XRTN \*/ /\* GET (2), JUMP TO XRTN TO SET E = (2), P = (E) \*/

LMI(T) RRM; ACM(AC)

JCF (\*,XRTN);

/\* FETCH SEQUENCE & START OF MACRO-INSTRUCTION PROCESSING P IS ISSUED TO MAR AND INCREMENTED, MACRO-INSTRUCTION IS FETCHED AND TESTED BY JPX MICRO-OPERATOR. NOTE FETCH IS IN LOCATION 15 TO STROBE INTERRUPT ON ENTRY. \*/

FETCH: LMI(P) FF1 RRM;

/\* LOAD DISPLACEMENT AND TEST FOR ZERO USING Z FLAG \*/

LTM(AC) STZ K00FF;

/\* SAVE DISPLACEMENT, TEST 4 BITS OF MACRO-OP. TEST IS DELAYED TO ALLOW PIPELINE PROPAGATION. ALSO C FLAG IS SET FOR LATER USE IN PSEUDO-SUBROUTINES. \*/

| SDR(R9) STC | JPX (NA0, JREL, JIG, IMMD, DMRF, IMRF, IXMA, IXMB, IND, |
|-------------|---------------------------------------------------------|
|             | INX,OTD,OTX,MVGP,SPFG,IRBM,NA15);                       |

/\* UNASSIGNED OP-CODE GROUPS- -NOPS FOR THIS VERSION \*/

| NA0:  | NO.OP | JZR(FETCH); |
|-------|-------|-------------|
| NA15: | NO.OP | JZR(FETCH); |

/\* IMMEDIATE GROUP OF MACRO-INSTRUCTIONS- -TEST FOR LONG OR SHORT FORM- -D IS IN AC AND R9- -ADJUST AC BY -128 \*/

IMMD: LMI(AC) KFF80 JZF(IMML,IMMS);

/\* LONG FORM: FETCH NEXT WORD TO AC \*/

| IMML: | LMI(P) FF1 RRM; |                          |
|-------|-----------------|--------------------------|
|       | ACM(AC)         | JRL(ILGA,ILPX,NAI1,NAI2) |

/\* SHORT FORM: NO PROCESSING NEEDED \*/

IMMS: NO.OP JRL(ILGA,ILPX,NAI1,NAI2);

/\* PREPROCESSING FOR ARITHMETIC AND LOGIC ROUTINES? NONE NEEDED \*/

| ILGA: | NO.OP | JLL(NDA,ODA,XDA,ADA); |
|-------|-------|-----------------------|
| ILPX: | NO.OP | JLL(LDA,LDX,PDS,ADX)  |

/\* NOTE: NAI1 AND NAI2 ARE NON-VALID INSTRUCTIONS!! THEY ARE MADE INTO NO-OPS IN THIS VERSION OF THE MACRO-MACHINE \*/

| NAI1: | NO.OP | JZR(FETCH); |
|-------|-------|-------------|
| NAI2: | NO.OP | JZR(FETCH); |

/\* BASIC ARITHMETIC AND LOGIC PROCESSING - - UPDATE C FF OF MACRO-MACHINE FOR ADA - - TOGGLE IT ON CARRY FROM ADA \*/

| ADR(A);      |                                           |
|--------------|-------------------------------------------|
| NO.OP        | JFL(NCY,SCY);                             |
| NO.OP        | JZR(FETCH);                               |
| LMI(W) K8000 | JZR(FETCH);                               |
|              | ADR(A);<br>NO.OP<br>NO.OP<br>LMI(W) K8000 |

/\* LOGICALS \*/

| NDA: | ANR(A)   | JZR(FETCH); |
|------|----------|-------------|
| ODA: | ORR(A)   | JZR(FETCH); |
| XDA: | CMR(AC); |             |
|      | XNR(A)   | JZR(FETCH); |

| /* | LDA AND                           | LDX OPERATIONS */                                                   |                                                              |
|----|-----------------------------------|---------------------------------------------------------------------|--------------------------------------------------------------|
|    | LDA:<br>LDX:                      | SDR(A)<br>SDR(X)                                                    | JZR(FETCH);<br>JZR(FETCH);                                   |
| /* | STACK PU<br>REVERSE               | SHADVANCE STACK POINTE<br>DIRECTION STACKA DECREM                   | R TO NEXT LOCATION (FOR THE<br>MENT OF S), THEN WRITE */     |
|    | PDS:<br>PDS1:                     | DSM(S);<br>LMI(S) RWM                                               | JZR(FETCH);                                                  |
| /* | ADX – SH                          | ARES CODE FOR ADA – ALSO T                                          | OGGLES C FF OF MACRO MACHINE */                              |
|    | ADX:                              | ADR(X)                                                              | JMP(ADA1);                                                   |
| /* | MEMORY<br>DIRECT-                 | REFERENCE INSTRUCTION GRC<br>-GET B+D INTO ACALSO R9 *              | pups<br>7                                                    |
|    | DMRF:                             | ILR(B);<br>ALR(R9)                                                  | JRL(MRV1,MRV2,MRAD,STPG);                                    |
| /* | INDIRECT                          | -ABSOLUTEGET (B+D) INTO A                                           | ACC FLAG USED FOR PSEUDO-SUBROUTINE */                       |
|    | IMRF:<br>IMRF1:                   | ILR(B);<br>ALR(R9);                                                 |                                                              |
|    | MLOAD:                            | LMI(R9) RRM<br>ACM(AC)                                              | JCF(MADD,MLOAD);<br>JRL(MRV1,MRV2,MRAD,STPG);                |
| /* | NOTE: MA<br>B, X, ETC.            | ADD WILL BE USED FOR OTHER<br>HAS BEEN LOADED TO R8 */              | INDIRECT OPERATIONS WHERE                                    |
|    | MADD:                             | ACM(AC);<br>ALR(R8)                                                 | JRL(MRV1,MRV2,MRAD,STPG);                                    |
| /* | INDIRECT                          | INDEXED ABSOLUTE – CLEAR                                            | C FLAG, MOVE X TO R8 */                                      |
|    | IXMA:                             | ILR(X) STC;<br>SDR(R8);                                             |                                                              |
| /* | NOTING T<br>JUMP TO I<br>IS ADDED | HAT ASSIGNMENT RULES WOUL<br>MRF UNLESS IXMA+1 WERE IN F<br>HERE */ | .D NOT ALLOW THE DESIRED<br>ROW ZERO– –AN EXTRA STATE        |
|    | IXMA2:                            | ILR(B)                                                              | JMP(IMRF1);                                                  |
| /* | INDIRECT                          | INDEXED RELATIVE - CLEAR O                                          | CFLAG, PUT B+X IN R8 */                                      |
|    | IXMB:                             | ILR(X) STC;<br>SDR(R8);<br>ILR(B);<br>ADR(R8)                       | JMP(IMRF);                                                   |
| /* | INDIRECT                          | RELATIVE (TO B) - CLEAR C F                                         | LAG, PUT B IN R8 */                                          |
|    | IRBM:                             | ILR(B);                                                             |                                                              |
| /* | AGAIN AS<br>LOCATED               | SIGNMENT RULES PREVENT JUI<br>IN ROW ZEROPLACEMENT TI               | MPING TO IXMA+1 UNLESS IT IS<br>HERE COULD FREE TWO WORDS */ |
|    |                                   | SDR(R8)                                                             | JMP(IXMA2);                                                  |
| /* | THE FOLL<br>VALUE AN              | OWING PROCEDURES IMPLEME<br>ND ADDRESS LOADING.                     | NT THE BASIC PREPROCESSING FOR                               |
|    | VALUE-G                           | ROUP 1: GET (AC) IN AC */                                           |                                                              |
|    | MRV1:                             | LMI(AC) RRM;<br>ACM(AC)                                             | JLL (NDA,ODA,XDA,ADA);                                       |

| /* | VALUE GF             | ROUP 2 */                              |                                          |
|----|----------------------|----------------------------------------|------------------------------------------|
|    | MRV2:                | LMI(AC) RRM;<br>ACM(AC)                | JLL(LDA,LDX,PDS,ADX);                    |
| /* | MRAD GR              | OUP INCLUDES ADDRESS LOAD              | S AND SUBTRACT FROM A $\ */$             |
|    | MRAD:                | NO.OP                                  | JLL(LAA,LAX,PAS,ISDA);                   |
|    | LAA:<br>LAX:<br>PAS: | SDR(A)<br>SDR(X)<br>DSM(S)             | JZR(FETCH);<br>JZR(FETCH);<br>JMP(PDS1); |
| /* | FOR SUBT             | RACT, ADD 1'S COMPLEMENT P             | LUS 1 */                                 |
|    | ISDA:                | LMI(AC) RRM;<br>LCM(AC);<br>ADR(A) FF1 | JMP(ADA1);                               |

/\* STPG GROUP INCLUDES STORES AND SUBTRACT FROM X \*/

| STPG: | LMI(AC)    | JLL(SAM,SXM,PSM,SDX); |
|-------|------------|-----------------------|
| SAM:  | ILR(A) RWM | JZR(FETCH);           |
| SXM:  | ILR(X) RWM | JZR(FETCH);           |

/\* POP STACK TO MEMORY - SAVE ADDRESS, POP STACK \*/

| PSM: | SDR(T);         |  |
|------|-----------------|--|
|      | LMI(S) FF1 RRM; |  |
|      | ACM(AC);        |  |
|      | LMI(T) RWM      |  |

/\* SUBTRACT FROM X \*/

| SDX: | LMI(AC) RRM; |            |
|------|--------------|------------|
|      | LCM(AC);     |            |
|      | ADR(X) FF1   | JMP(ADA1); |

Thus the initialization procedure requires 16 words of microcode, the fetch sequence 3, and the memory reference and immediate groups use a total of 57 words. In addition, two dummy locations (NAI1 and NAI2) are needed for unassigned macrooperation codes. Sample execution times for some of the instructions may be estimated by counting the number of micro-instructions in the sequences and the number of read and write memory cycles. Allowing 150 nsec for each micro-instruction, and 400 nsec for each memory cycle, some representative execution times would be as shown in Table VII.

| INSTRUCTION                  | MICROCYCLES | READ CYCLES | WRITE CYCLES | EXECUTION TIME |
|------------------------------|-------------|-------------|--------------|----------------|
| ADA, direct                  | 10          | 2           |              | 2.3 μS         |
| ADI, short                   | 9           | 1           |              | 1.75 μS        |
| LDA                          | 8           | 2           |              | 2.0 μS         |
| LAI, short                   | 7           | 1           |              | 1.45 μS        |
| LDA, indirect index relative | 15          | 3           |              | 3.45 μS        |

JZR(FETCH);

#### Table VII. Representative Execution Times

#### JUMP GROUP

The next section shows the realization of the jump group instructions. Two basic classes, a jump relative to the program counter and an indirect jump through a table stored at the beginning of the program are represented. Conditional jumps include A>0,  $A\ge0$ , A=0,  $A\ne0$ ,  $A\le0$ , A<0,  $X\neA$ , X>0,  $X\leA$ , C=0 and  $C\ne0$ .

In addition, two classes of subroutine calls are provided; a local call which pushes P onto the stack, and jumps relative to E, and a global subroutine call which stores the W, B, E, and P registers on stack and computes new values for E, the program base register, and P. Also, included in this section of microcode is the operation that pushes both A and X onto the stack.

Table VIII shows the opcode assignments for the various jump operations implemented. Except for

the conditional jumps, X>A, X $\leq$ A, X=A and X $\neq$ A which share a common subroutine and exit via a JLL jump, the opcode values were assigned arbitrarily.

A flowchart representing the jump coding is shown in Figure 16. During the microcoding of the sequence, two methods were evaluated. One used the JRL, JLL sequence of testing 2 bits of macrooperation code at a time, while the one actually selected uses a JPR macro-operation. The JPR test selected uses no more code than the JRL, JLL sequence method, and executes more rapidly. At one point (for the X=A, X≠A, X>A, X≤A tests), code is shared as if it were part of a subroutine, then a JLL instruction is used to resolve the exit. This method is another example of a pseudosubroutine that saves microprogram memory. Use of this technique does put a constraint on the assignment of macro-operation codes.

|            | SUM OTION                        | RELA | TIVE | INDI | RECT |
|------------|----------------------------------|------|------|------|------|
| MNEMONIC   | FUNCTION                         | М    | 0    | м    | 0    |
| JRU, JIU   | Jump unconditional               | 0001 | 0000 | 0010 | 0000 |
| JRGE, JIGE | Jump if A≥0                      | 0001 | 0001 | 0010 | 0001 |
| JRLT, JILT | Jump if A<0                      | 0001 | 0010 | 0010 | 0010 |
| JRXG,JIXG  | Jump if X>A                      | 0001 | 0011 | 0010 | 0011 |
| JREZ, JIEZ | Jump if A=0                      | 0001 | 0100 | 0010 | 0100 |
| JRNZ, JINZ | Jump if A≠0                      | 0001 | 0101 | 0010 | 0101 |
| JRCZ, JICZ | Jump if C=0                      | 0001 | 0110 | 0010 | 0110 |
| JRXL, JIXL | Jump if X≼A                      | 0001 | 0111 | 0010 | 0111 |
| JRLE, JILE | Jump if A≪0                      | 0001 | 1000 | 0010 | 1000 |
| JRGT, JIGT | Jump if A>0                      | 0001 | 1001 | 0010 | 1001 |
| JRCN, JICN | Jump if C <del>≠</del> 0         | 0001 | 1010 | 0010 | 1010 |
| JRXE,JIXE  | Jump if X=A                      | 0001 | 1011 | 0010 | 1011 |
| CVS        | Call subroutine, push W, B, E, P | N    | .A.  | 0010 | 1100 |
| PHAX       | Push A, X onto stack             | 0001 | 1101 | 0010 | 1101 |
| CLS        | Call subroutine, push P          | N    | .A.  | 0010 | 1110 |
| JRXN, JIXN | Jump if X≠A                      | 0001 | 1111 | 0010 | 1111 |

#### Table VIII. Jump Instruction Group

| Subroutine c | alls |
|--------------|------|
|--------------|------|

| Local: | Push P to stack            |
|--------|----------------------------|
|        | P=E+(E+D)                  |
| Value: | Push W, B, E, P to stack   |
|        | E=E+(E+D)                  |
|        | P=E'+(E') where E'=E+(E+D) |

Unconditional and conditional jumps

| Relative: | P=P+D'   | where D'=D-128 |
|-----------|----------|----------------|
| Indirect: | P=E+(E+[ | D)             |



Figure 16. Jump Group Flowchart

/\* JUMP GROUPS- -USE JPR MICRO-OPERATION TO RESOLVE CONDITION SELECTION DESTINATION ADDRESS IS COMPUTED FIRST- -PLACED IN AC AND R9 JUMP RELATIVE TO P- -ADDRESS=P+D-128 \*/

JREL: ILR(P); JRDR: LMI(AC) KFF80; ALR(R9)

JPR (JUNC, JAGE, JALT, JXGA, JAEQ, JANE, JCEZ, JXLA, JALE, JAGT, JCNZ, JXEA, CPSS, PXA, CLOP, JXNA);

/\* JUMP INDIRECT - GET E+(E+D) IN AC AND R9 \*/

JIG: ILR(E); ADR(R9); LMI(R9) RRM; AMA(AC); SDR(R9)

JPR(JUNC,JAGE,JALT,JXGA,JAEQ,JANE,JCEZ,JXLA, JALE,JAGT,JCNZ,JXEA,CPSS,PXA,CLOP,JXNA);

/\* UNCONDITIONAL JUMP \*/

JUNC: SDR(P)

JZR(FETCH);

/\* TESTS FOR A.GE.0, ETC. \*/

| TZR(A) K8000 INH | JMP(TTRU);                                               |
|------------------|----------------------------------------------------------|
| TZR(A) K8000 INH | JMP(TFAL);                                               |
| TZR(A)           | JMP(TTRU);                                               |
| TZR(A)           | JMP(TFAL);                                               |
|                  | TZR(A) K8000 INH<br>TZR(A) K8000 INH<br>TZR(A)<br>TZR(A) |

| JAGT: | TZR(A) K8000 INH;<br>TZR(A) | JFL(APRE,ANPE); |
|-------|-----------------------------|-----------------|
| APRE: | NO.OP                       | JFL(JNT2,JTR2); |
| ANPE: | NO.OP                       | JZR(FETCH);     |
| JALE: | TZR(A) K8000 INH;<br>TZR(A) | JFL(APE2,AN2);  |
| APE2: | NO.OP                       | JFL(JTR1,JNT1); |
| AN2:  | SDR(P)                      | JZR(FETCH);     |

/\* TESTS OF C FLIP-FLOP (HIGH ORDER BIT OF W) \*/

| JCEZ: | TZR(W) K8000 INH | JMP(TTRU); |
|-------|------------------|------------|
| JCNZ: | TZR(W) K8000 INH | JMP(TFAL); |

/\* TEST EXECUTION FOR ABOVE TESTS - ROW ZERO USED \*/

| TTRU: | NO.OP  | JFL(JTR1,JNT1);  |
|-------|--------|------------------|
| JTR1: | SDR(P) | JZR(FETCH);      |
| JNT1: | NO.OP  | JZR(FETCH);      |
| TFAL: | NO.OP  | JFL(JNT2,JTR2,); |
| JNT2: | NO.OP  | JZR(FETCH);      |
| JTR2: | SDR(P) | JZR(FETCH);      |

/\* TESTS FOR X.GT.A, X.LE.A, X.EQ.A, X.NE.A--SHARED PSEUDO-SUBROUTINE USES JLL FOR AN EXIT TEST- - ROUTINE ENTRY IN ROW 0 C FLAG IS SET FOR X.GT.A. FL TEST FOR X.EQ.A \*/

| JXGA: | ILR(X) | JMP(XATS); |
|-------|--------|------------|
| JXLA: | ILR(X) | JMP(XATS); |
| JXEA: | ILR(X) | JMP(XATS); |
| JXNA: | ILR(X) | JMP(XATS); |

/\* SAVE X AT T, FETCH AND COMPLEMENT A \*/

XATS: SDR(T); ILR(A) STC; /\* CLEAR C FLAG \*/ CMA(AC);

/\* ADD HOB'S OF A' AND X - CARRY MEANS X NEG., A.GE.0 \*/

ADR(T) K8000;

/\* EXECUTE PREVIOUS TEST, SET UP TO TEST HOB OF RESULT- -IF 1, THE SIGNS OF A AND X WERE THE SAME \*/

> TZR(T) K8000 INH JFL(TFEQ,TXNG);

/\* TXNG IMPLIES X NEG AND A.GE.0- -I.E. X.NE.A AND X.LT.A- -DO A DUMMY OPERATION TO FORCE THE PROPER F FLAG \*/

TXNG: ILR(A)

JLL(JXGX,JXLX,JXEX,JXNX);

/\* PERFORM A TEST ADDITION AND EXECUTE SIGN-EQUAL TEST C WILL BE SET IF SIGNS WERE THE SAME AND X.GT.A \*/

TFEQ: ADR(T) STC K7FFF JFL(SNEQ,SWEQ);

/\* SNEQ IMPLIES SIGNS NOT EQUAL- -I.E. X.GE.O, A NEG- -X.GT.A \*/

/\* DUMMY OP TO SET C FLAG \*/ SNEQ: SDR(AC) STC; NO:OP JLL(JXGX,JXLX,JXEX,JXNX);

| /* | ' FOR SIGNS EQUAL, IF X=A RESULT WOULD BE 11111. INCREMENT<br>WILL GENERATE A CARRY IF SO */ |                                                                                                       |                                                                          |  |
|----|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|--|
|    | SWEQ:                                                                                        | ILR(AC) FF1                                                                                           | JLL(JXGX,JXLX,JXEX,JXNX);                                                |  |
| /* | EXECUTIO                                                                                     | ON OF JUMP TESTS */                                                                                   |                                                                          |  |
|    | JXGX:<br>JXLX:<br>JXEX:<br>JXNX:                                                             | ILR(R9)<br>ILR(R9)<br>ILR(R9)<br>ILR(R9)                                                              | JCF(JNT2,JTR2);<br>JCF(JTR1,JNT1);<br>JFL(JNT2,JTR2);<br>JFL(JTR1,JNT1); |  |
| /* | SUBROUT<br>CALL LOC<br>CALL LOC<br>CL FLAG I                                                 | INE CALLS<br>CAL AND PUSH W, B, E, P =CPSS<br>CAL AND PUSH P ONLY=CLOP<br>IS USED FOR EXIT TEST AFTER | PUSHING P */                                                             |  |
|    | CPSS:                                                                                        | DSM(S);<br>ILR(W);                                                                                    |                                                                          |  |
|    |                                                                                              | LMI(S) RWM;                                                                                           |                                                                          |  |
|    | CPG2:                                                                                        | DSM(S);<br>ILR(B);<br>LMI(S) RWM;                                                                     |                                                                          |  |
|    |                                                                                              | DSM(S);<br>ILR(E);<br>LMI(S) RWM;                                                                     |                                                                          |  |
|    | CLOP2:                                                                                       | DSM(S);<br>ILR(P);<br>LMI(S) RWM;                                                                     |                                                                          |  |
| /* | E+(E+D) IN                                                                                   | NTO AC */                                                                                             |                                                                          |  |
|    |                                                                                              | ILR(R9)                                                                                               | JCF(LRTN,XRTN);                                                          |  |
|    | XRTN:                                                                                        | SDR(E);<br>LMI(E) RRM;<br>AMA(AC);                                                                    |                                                                          |  |
|    | LRTN:                                                                                        | SDR(P)                                                                                                | JZR(FETCH);                                                              |  |
|    | CLOP:                                                                                        | DSM(S);<br>ILR(P) STC                                                                                 | JMP(CLOP2);                                                              |  |
| /* | PUSH INST                                                                                    | RUCTION */                                                                                            |                                                                          |  |
|    | PXA:                                                                                         | DSM(S);<br>ILR(X);<br>LMI(S) RWM;                                                                     |                                                                          |  |
|    |                                                                                              | DSM(S);<br>ILR(A);<br>LMI(S) RWM                                                                      | JZR(FETCH);                                                              |  |
|    |                                                                                              |                                                                                                       |                                                                          |  |

# REGISTER MOVE AND SUBROUTINE RETURN GROUP

In this section of code, the Register Move and Subroutine Return group instructions are implemented. Both groups share the same JPX entry point, 1100B. Table X shows the opcode values assigned to the macro-instructions. To simplify the decoding for register selection (S, B, E or W) in the Register Move group, the two low order bits of the PR latch are used to modify the micro-instruction as it is strobed into the pipeline register. By tying the two PR latch outputs of the 3001 to the two low order bits of the CPE control field, a JCE jump function (which enables the PR

latch outputs) can be used to provide a wire OR of PR0, PR1 and F0, F1 (see Figure 17).



#### Figure 17. Wire-OR of PO<sub>0-1</sub> and F<sub>0-1</sub>

Thus, in the micro-instruction

SDR(R7) JCE (MXRX)

the register group field F0-F3 is modified as shown in Table IX.

The microprogram sequence is shown in Figure 18.

#### Table IX. Register Group Field F0-F3 Modification

| MNEMONIC | FUNCTION             | м    | 0    |
|----------|----------------------|------|------|
| RLS      | Pop P                | 1100 | 1111 |
| RVS      | Pop P, E, B, W       | 1100 | 1101 |
| RSA      | Pop A, X, P, E, B, W | 1100 | 1100 |
| PPAX     | Рор А, Х             | 1100 | 1110 |
| MSX      | Move S to X, adjust  | 1100 | 0100 |
| MBX      | Move B to X, adjust  | 1100 | 0101 |
| MEX      | Move E to X, adjust  | 1100 | 0110 |
| MWX      | Move W to X, adjust  | 1100 | 0111 |
| MXS      | Move X to S, adjust  | 1100 | 0000 |
| МХВ      | Move X to B, adjust  | 1100 | 0001 |
| MXE      | Move X to E, adjust  | 1100 | 0010 |
| MXW      | Move X to W, adjust  | 1100 | 0011 |
| NO.OP    | Nothing implemented  | 1100 | 10XX |

Table X. Register Move and Subroutine

Return Group

| MICROPROGRAM<br>MEMORY OUTPUT<br>(F0-F3) | PR LATCH<br>OUTPUT | RESULT STORED IN<br>PIPELINE REGISTER | SELECTED REGISTER |
|------------------------------------------|--------------------|---------------------------------------|-------------------|
| 0111                                     | 00                 | 0100                                  | S                 |
| 0111                                     | 01                 | 0101                                  | В                 |
| 0111                                     | 10                 | 0110                                  | E                 |
| 0111                                     | 11                 | 0111                                  | w                 |
|                                          |                    |                                       |                   |



Figure 18. Register Move and Subroutine Return Group Flowchart

| /* | MOVE GR<br>THAT REC<br>FIRST MO                  | OUP OF INSTRUCTIONSUSES<br>GISTER ASSIGNMENT BECOMES<br>DIFY D TO GET D-128 */                               | JCE TO SELECT R           | EGISTER– –NOTE          |
|----|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------|---------------------------|-------------------------|
|    | MVGP:                                            | LMI(R9) KFF80                                                                                                | JLL(MVXR,MVRX             | (,MOD,PGRP);            |
| /* | MOVE X T                                         | O REG. – GET X, MODIFY BY D                                                                                  | ′=D-128 */                |                         |
|    | MVXR:<br>MXRX:                                   | ILR(X);<br>ALR(R9);<br>SDR(R7)<br>NO.OP                                                                      | JCE(MXRX);<br>JZR(FETCH); | /* REGISTER OVERRIDE */ |
| /* | MOVE RE                                          | G TO X – FETCH REG USING JCI                                                                                 | EOVERRIDE */              |                         |
|    | MVRX:<br>MRXX:                                   | ILR(R7)<br>ALR(R9)                                                                                           | JCE(MRXX);<br>JMP(LDX);   |                         |
| /* | MOD NOT                                          | IMPLEMENTED IN THIS VERSIC                                                                                   | DN */                     |                         |
|    | MOD:                                             | NO.OP                                                                                                        | JZR(FETCH);               |                         |
| /* | ADJUST S<br>PPALPC<br>PPRAPC<br>PPAXPC<br>POPPPC | TACK AND RETURN GROUP<br>DPS A, X, P, E, B, AND W<br>OPS P, E, B, AND W<br>DPS ONLY A AND X<br>DPS ONLY P */ |                           |                         |
|    | PGRP:                                            | ILR(R9);<br>ADR(S)                                                                                           | JRL(PPAL,PPRA,F           | PPAX,POPP);             |
|    | PPAL:                                            | LMI(S) FF1 RRM;<br>ACM(AC);<br>SDR(A);                                                                       |                           |                         |
|    | PAXC:                                            | LMI(S) FF1 RRM;<br>ACM(AC)<br>SDR(X);                                                                        | JCF(PAXE,PAXC)            | :                       |
|    | PPRA:                                            | LMI(S) FF1 RRM;<br>ACM(AC);<br>SDR(P);                                                                       |                           |                         |
|    |                                                  | LMI(S) FF1 RRM;<br>ACM(AC);<br>SDR(E);                                                                       |                           |                         |
|    |                                                  | LMI(S) FF1 RRM;<br>ACM(AC);<br>SDR(B);                                                                       |                           |                         |
|    |                                                  | LMI(S) FF1 RRM;<br>ACM(AC);<br>SDR(W);                                                                       |                           |                         |
| /* | RESTORE                                          | INTERRUPT STRUCTURE */                                                                                       |                           |                         |
|    |                                                  | CLR(T);<br>LMI(T) ROT                                                                                        | JZR(FETCH);               |                         |
|    | PAXE:                                            | SDR(X)                                                                                                       | JZR(FETCH);               |                         |
|    | PPAX:                                            | ILR(AC) STC                                                                                                  | JMP(PPAL);                |                         |
|    | POPP:                                            | LMI(S) FF1 RRM;<br>ACM(AC)                                                                                   | JMP(JUNC);                |                         |

#### SPECIAL FUNCTION GROUP

The JPX entry point 1101B is used as an entry point for the special function groups which include byte load and store, register manipulation, and the absolute subroutine call and increment and skip if zero instructions. Table XI lists the opcode values assigned to the instructions. A flowchart of the sequences is shown in Figure 19.

In order to execute a byte load or store operation efficiently, a byte swap capability (which exchanges the high and low order byte positions) is necessary. By wiring the data outputs of the high order byte to the I inputs of the low order byte, and the low order outputs to the high order I inputs, a byte swap operation can be performed (see Figure 20).

Note that with the configuration shown in Figure 20, a byte swap can be performed on either a memory word or the AC register of the CPE array by reading data in on the I-Bus inputs while performing a memory read or enabling the D-Bus, respectively.

#### Table XI. Special Function Groups

| MNEMONIC | FUNCTION                                     | м    | 0    |
|----------|----------------------------------------------|------|------|
| LBA      | Load byte absolute                           | 1101 | 0000 |
| LBR      | Load byte relative                           | 1101 | 0100 |
| SBA      | Store byte absolute                          | 1101 | 1000 |
| SBR      | Store byte relative                          | 1101 | 1100 |
| RAR      | Rotate A right, include<br>CFF               | 1101 | 0001 |
| RAX      | Rotate A and X right, include CFF            | 1101 | 0101 |
| SAX      | Shift A and X right, preserve sign           | 1101 | 1001 |
| SAL      | Shift A left, fill with zeros                | 1101 | 1101 |
| ISZ      | Increment and skif ip zero                   | 1101 | XX10 |
| CAS      | Call absolute, push<br>P, E, W, B<br>P ← (D) | 1101 | XX11 |



Figure 19. Special Function Groups Flowchart



#### Figure 20. I-Bus Wired for Byte Swap

| /* | SPECIAL F<br>BYTE OPE<br>CALL TO<br>SHIFT AN<br>INCREME<br>FETCH B | FUNCTION GROUP<br>RATORSADDR=(B+D)+B+X/2<br>(D) AND PUSH ALL<br>D ROTATE GROUP<br>NT AND SKIP<br>JUST IN CASE */ | OR (B+D)+X/2                                                   |
|----|--------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
|    | SPFG:                                                              | ILR(B)                                                                                                           | JRL(BYTE,RSGP,SCJG,ISJG);                                      |
| /* | BYTE GRO                                                           | DUPCOMPUTE ADDR, STORE I                                                                                         | B IN CASE NEEDED */                                            |
|    | BYTE:                                                              | SDR(R8);<br>ADR(R9);<br>ILR(X);<br>SRA(AC) STC;<br>LMI(R9) RRM;<br>ACM(AC)                                       | JLL(LBYA,LBYR,SBYA,SBYR);                                      |
|    | LBYR:<br>LBYA:<br>LBYT:<br>RBYT:<br>DBIA:                          | ALR(R8);<br>LMI(AC) RRM<br>LDI(AC) FF1 K00FF<br>LTM(AC) K00FF;<br>SDR(A)                                         | JCF(LBYT,RBYT);<br>JMP(DBIA);<br>JZR(FETCH);                   |
|    | SBYR:<br>SBYA:<br>STRB:<br>SRB1:                                   | ALR(R8);<br>LMI(AC);<br>ILR(A);<br>TZR(AC) KOOFF RRM<br>LTM(T) KFF00;<br>ALR(T) RWM                              | /* LOAD MAR FOR LATER USE */<br>JCF(STLB,STRB);<br>JZR(FETCH); |
|    | STLB:                                                              | LTM(T) KOOFF;<br>LDI(AC) FF1 CNB                                                                                 | JMP(SRB1);                                                     |
|    |                                                                    |                                                                                                                  |                                                                |

/\* ROTATE GROUP ROTATE A WITH C- -ROTATE A AND X WITH C- -SHIFT A, X RIGHT, FILL WITH SIGN- -SHIFT A LEFT, FILL WITH ZEROES AT ENTRY, Z FLAG IS ZERO IF D=0. DUE TO PIPELINED OPERATION, IT IS THIS CONDITION THAT IS TESTED BY THE FIRST JZF  $\ */$ 

| RSGP:<br>SZDS: | TZR(W) STZ K8000 INH<br>ILR(X): | JZF(SZDS,SNZD);            |
|----------------|---------------------------------|----------------------------|
|                | SDR(R9) FF0 K007F               | JLL(RACI, RAXI,SAXI,SLZI); |
| SNZD:          | DSM(R9)                         | JLL(RACI,RAXI,SAXI,SLZI);  |
| RACI:          | ILR(A)                          | JMP(RUNR);                 |
| RAXI:          | ILR(X);                         |                            |
|                | SDR(T)                          | JMP(RACI);                 |
| SAXI:          | TZR(A) STZ K8000 INH            | JMP(RAXI);                 |
| SLZI:          | ILR(A)                          | JMP(RUNR);                 |
|                |                                 |                            |

/\* MAIN ROTATION LOOP \*/

| RUNR: DSM(R9) STC JLL(RACR,RAXR,SAXR,SL                  | _ZR); |
|----------------------------------------------------------|-------|
| RACR: SRA(AC) FFZ STZ JFL(RSEX,RUNR);                    |       |
| RAXR: SRA(AC) FF2 S12;<br>SRA(T) FF2 STZ JCF(RSEX,RUNR); |       |
| SAXR: SRA(AC) FFZ STC;<br>SRA(T) FFC JCF(RSEX,RUNR);     |       |
| SLZR: ADR(AC) STZ JFL(RSEX,RUNR);                        |       |
| RSEX: SDR(A) JLL(RACF,RAXF,SAXF,SL                       | ZF);  |
| RACF: TZR(W) K7FFF JZF(SNCF,SSCF);                       |       |
| SNCF: NO.OP JZR(FETCH);                                  |       |
| SSCF: LMI(W) K8000 JZR(FETCH);                           |       |
| RAXF: ILR(T);                                            |       |
| RXF1: SDR(X) JMP(RACF);                                  |       |
| SAXF: ILR(T) JMP(RXF1);                                  |       |
| SLZF: TZR(W) K7FFF JZF(SNCF,SSCF);                       |       |

/\* SPECIAL CALL AND JUMP GROUP- –CURRENTLY CONTAINS ONLY THE CALL TO (D) AND PUSH W,B,E,P- –ALL 4 OPCODES DO THE SAME THING  $\,^*/$ 

| SCJG: | LMI(R9) RRM; |            |
|-------|--------------|------------|
|       | ACM(AC);     |            |
|       | SDR(R9)      | JMP(CPSS); |

/\* INCREMENT AND SKIP GROUP- –AGAIN 4 OPCODES ARE USED FOR ONE INSTRUCTION- –LOCATION AT B+D IS INCREMENTED  $\ */$ 

| ISJG: | ALR(R9);         |                 |
|-------|------------------|-----------------|
|       | LMI(R9) RMW;     |                 |
|       | ACM(AC) FF1 RWM; |                 |
|       | NO.OP            | JFL(NOSK,SKIP); |
| NOSK: | NO.OP            | JZR(FETCH);     |
| SKIP: | LMI(P) FF1       | JZR(FETCH);     |

#### **INPUT/OUTPUT GROUP**

In this section of code, the input/output instructions are implemented. In conjunction with the memory address register, the bus control field generates a Request Input or Request Output to select an I/O port and specify the operation to be performed. Table XII lists the opcode values assigned to the macro-instructions. The flowchart in Figure 21 shows the microcode sequence used.

| MNEMONIC | FUNCTION                   | м    | 0    |
|----------|----------------------------|------|------|
| IND      | Input one word<br>A ← (D)  | 1000 | XXXX |
| OTD      | Output one word<br>(D) ← A | 1001 | XXXX |
| INX      | Input one word<br>A ← (X)  | 1010 | XXXX |
| отх      | Output one word<br>(X) ← A | 1011 | XXXX |
|          |                            |      |      |

#### Table XII. Input/Output Group

A basic means for microcoding interrupts when using the 3214 Interrupt Control Circuit involves forcing an alternate microprogram address which then leads to an interrupt handling routine. The interrupt handling routine interrogates the interrupt structure to determine the interrupting level. This level is rewritten to the interrupt structure to block further interrupts at the interrupting priority level or lower levels while enabling interrupts at higher levels.



INTERRUPTS

Figure 21. Input/Output Flowchart

/\* INTERRUPT--UTILIZED CALL ROUTINES FOR REGISTER SAVING I/O DEVICE #0 REPRESENTS EXTERNAL INTERRUPT STRUCTURE START BY PUSHING OLD VALUE OF STATUS \*/

INTER: DSM(S); ILR(W); LMI(S) RWM;

/\* READ INTERRUPTING LEVEL FROM EXTERNAL STRUCTURE \*/

CLR(T); LMI(T) RIN; LTM(AC) KOOFF ROT; /\* NOTE LEVEL REWRITTEN \*/

/\* STORE PRIORITY IN W - SET C FLAG FOR PROPER LOADING OF REGISTERS \*/

SDR(W) STC;

/\* INTERRUPT ROUTINE STARTING ADDRESS IS COMPUTED IN R9  $\ */$ 

LMI(W) RRM; ACM(AC); SDR(R9)

JMP(CPG2);

#### Microprogram Memory Assignment

Having written the actual code with minimal regard to memory assignment, the actual assignment to ROM must be performed. To assist in this function, a complete state (i.e., microcode instruction) flowchart should be prepared. Each machine state is represented by a dot in the state diagrams shown below. Conditional jumps should be labeled as to type and condition corresponding to each destination. This information will be necessary when performing an assignment. No other information is needed on the flowchart, but it is quite useful to show any symbolic label that may be associated with a state.



IMMEDIATE GROUP





#### JUMP GROUP (CONTINUED)



MOVE GROUP



#### SPECIAL FUNCTION GROUP



I/O GROUP



INTERRUPT SERVICE ROUTINE



Once all of the state diagrams have been prepared, a number of steps may be followed to simplify the assignment procedure. First, the basic hardware characteristics dictate that INIT, FETCH, and INTER be located in microprogram memory locations 0, 15, and 255 (decimal), respectively. Then, note that each conditional jump has a limited range. As a result, when several conditional jumps follow one another in sequence, all may have to be located within a restricted range in microprogram memory. For JCF, JZF, JLL and JRL microinstructions, the calling instruction must be in the same block of eight rows as the destinations.

To do the best assignment, the most restricted set of micro-instructions should be assigned first. The most restricted groups of micro-instructions are usually associated with clusters of conditional jumps which must be located within a given range of memory. It is therefore very useful to catalog all such clusters of conditional jumps. Table XIII lists the clusters associated with this machine. In each case the conditional jump is identified by the jump micro-operation and the first of its destinations. Thus in Table XIII the symbol JRL(MRV1) really refers to the code JRL(MRV1, MRV2, MRAD, STPG). For this machine, there are only five clusters.

#### Table XIII. Conditional Jump Clusters

| 1. | JPX (NAO)<br>JRL (ILGA), JRL (BYTE)<br>JLL (NDA), JLL (LDA), JLL (MVXR), JLL (RACI)<br>JZF (IMML), JZF (SZDS) |
|----|---------------------------------------------------------------------------------------------------------------|
| 2. | JRL (MRV1)<br>JLL (SAM), JLL (LAA)<br>JCF (MADD)                                                              |
| 3. | JLL (JXEX)<br>JFL (JTR1), JCF (JNT2)                                                                          |
| 4. | JRL (PPAL)<br>JCF (PAXC)                                                                                      |
| 5. | JLL (RACR), JLL (RACF)<br>JCF (RSEX)<br>JZF (SNCF)                                                            |

An examination of the flowcharts indicates that a simpler code might result if clusters one and five were combined because of the coupling between JLL(RACI) of cluster one and the JCF(RSEX) of cluster five. The combination of these two clusters represents the greatest degree of restriction, as within the same block of rows there would be one JPX, six JLL, two JRL, one JCF and three JZF micro-operations. In addition, the JLL(MVXR)

executes a JCE jump which uses an additional location within the JLL destination columns. However, the basic jump micro-operation characteristics do allow all of these conditional jumps to be placed within one block of eight rows.

To retain row zero, the conditional jumps of clusters one and five are placed in the last eight rows of the microprogram memory. In addition to the destinations, space must be reserved for the "calling" micro-instructions for each of the conditional jumps listed in the clusters.

Chart 1 shows an assignment of the conditional jumps of clusters one and five, together with some of the immediately related states. For the assignment procedure, a form like that of Chart 1 is used to show which microprogram memory locations are occupied and which are available. The format also aids visualization of valid jump micro-operations. As each state is assigned to its location in micro memory, the corresponding position on the state diagram is marked to show assignment. In this way, unassigned states are easily located on the state diagrams.

The information placed in the memory maps includes the state label or, for strings of states with no assigned label, the label of the nearest previously labeled state plus information to indicate how far from that labeled state the present state is. For example, INIT+2 is the second state after INIT.

The state assignment can proceed, with conditional jumps and short unconditional sequences being assigned before long unconditional sequences. Chart 2 shows the state assignment at a point when all states except those between INIT and FETCH, those between PPRA and FETCH, and those associated with IND, INX, OTD and OTX have been assigned.

For those states which have only one calling state (i.e., a state which has only one state jumping to it with a non-conditional jump) and only one target state (i.e., it makes a non-conditional jump to another state), two hexadecimal numbers are also written on the memory map. The number in the lower left-hand corner is the address of the calling state (first hex digit is the row, second hex digit is the column), and the number in the lower righthand corner is the address of the target state. This information will tell the designer at a glance which states can be easily moved in the process of memory assignment, and to which locations they can be moved. For instance, a state with its calling state and target state in the same row (or column) can be moved anywhere in that row (or column), and a

state with its target state in the row zero can be moved anywhere in the same row or column as its calling state.

As an example of how this information can be used, note that in Chart 2 state RAXI+1 has been assigned to location 090H. However, when the INIT sequence is assigned, it becomes convenient to locate INIT+1 somewhere in column 0. Since there are no available spaces in column 0, the designer notes that state RAXI+1 has both its calling and target states in row 9, and so RAXI+1 can be moved anywhere in row 9. In Chart 3, RAXI+1 has been reassigned to location 098H, and INIT+1 has been assigned to location 090H. This moving process will typically be frequently necessary in the assignment procedure, and thus it is quite useful to have this information right on the working memory map.

The final state assignments consist mostly of the long unconditional sequences. Row zero locations

may then be used freely. In those cases where extra states were used to avoid the use of row zero locations, the assignment may be reconsidered. For this machine, the operations IND, INX, OTD and OTX were rewritten to utilize row zero locations. Figure 22 shows the revised flow diagram for these four operations.

The final assignment is as shown in Chart 3. Two locations remain.



**Revised Flow Diagram** 

/\* INPUT AND OUTPUT- -CURRENT VERSION DOES NOT DECODE INTO SUBGROUPS- -ALSO ROW ZERO IS USED TO SAVE CODE \*/

| IND:  | LMI(R9) RIN; |
|-------|--------------|
| IND1: | ACM(AC);     |
|       | SDR(A)       |
| INX:  | LMI(X) RIN   |
| OTD:  | LMI(R9);     |
| OTD1: | ILR(A) ROT   |
| OTX:  | LMI(X)       |

JZR(FETCH); JMP(IND1); JZR(FETCH);

JMP(OTD1);

#### CONCLUSION

In the central processor design example described above, the final definition of the central processor macro-instruction set evolved as the microprograms were being implemented. In many instances, it was necessary to modify the macro-instruction opcode assignment in order to take full advantage of the capabilities of the Series 3000 architecture. Macroinstruction operations were also redefined to add more flexibility as microprogramming techniques improved.

The microprograms were implemented without regard to memory assignment except in cases where code sharing between micro-instruction opcode assignments were critical. Actual assignment of the micro-instructions to memory involved a very small portion of the design cycle. The 3001 MCU's ability to decode macro-instruction opcodes and large repertoire of conditional and unconditional jump operations resulted in both efficient microprograms and complete memory utilization. Only two memory locations remained unused after the microcoding was complete.

The central processor developed in this application note is used as a design example only, and therefore does not represent a complete central processor or an instruction set designed for a specific application. However, because of the microprogrammability of the Series 3000 family, the same basic organization can be tailored to a wide range of operating environments from I/O processing to data processing and dedicated arithmetic computation.

| Chart  | 1 |
|--------|---|
| Onai t |   |

|    |                 |              | JFL,<br>COLUMI<br>f,c,z=0 | JCF, JZF<br>N RESTRICT<br>f,c,z=1 |      | JLL COLUN | IN RESTRI | ст   |     |              | JFL,<br>COLUMI<br>f,c,z=0 | JCF, JZF<br>N RESTRICT<br>f,c,z=1 |      | JRL COLUMN RESTRICT |      |       |
|----|-----------------|--------------|---------------------------|-----------------------------------|------|-----------|-----------|------|-----|--------------|---------------------------|-----------------------------------|------|---------------------|------|-------|
|    | 0               | 1            | 2                         | 3                                 | 4    | 5         | 6         | 7    | 8   | 9            | A                         | В                                 | С    | D                   | E    | F     |
| 00 | INIT            |              |                           |                                   |      |           |           |      |     |              |                           |                                   |      |                     |      | FETCH |
| 01 |                 |              |                           |                                   |      |           |           |      |     |              |                           |                                   |      |                     |      |       |
| 02 |                 |              |                           |                                   |      |           |           |      |     |              |                           |                                   |      |                     |      |       |
| 03 |                 |              |                           |                                   |      |           |           |      |     |              |                           |                                   |      |                     |      |       |
| 04 |                 |              |                           |                                   |      |           |           |      |     |              |                           |                                   |      |                     |      |       |
| 05 |                 |              |                           |                                   |      |           |           |      |     |              |                           |                                   |      |                     |      |       |
| 06 |                 |              |                           |                                   |      |           |           |      |     |              |                           |                                   |      |                     |      |       |
| 07 |                 |              | ļ                         |                                   |      |           |           |      |     |              |                           |                                   |      |                     |      |       |
| 08 | NAO             | JREL         | JIG                       | IMMD                              | DMRF | IMRF      | IXMA      | IXMB | IND | INX          | OTD                       | отх                               | MVGP | SPFG                | IRBM | NA 15 |
| 09 | RAXI+1<br>95 94 |              | RSEX                      | RUNR                              | RACI | RAXI      | SAXI      | SLZI |     | SZDS+1<br>9A | SZDS                      | SNZD                              |      |                     |      |       |
| 0A | RAXR+1<br>A4    | SAXR+1<br>A6 | SNCF                      | SSCF                              | RACR | RAXR      | SAXR      | SLZR |     |              |                           |                                   |      |                     |      |       |
| 0B | RXFI            | IMML+1<br>B2 | IMML                      | IMMS                              | RACF | RAXF      | SAXF      | SLZF |     |              |                           |                                   |      |                     |      |       |
| 0C |                 |              |                           |                                   | MVXR | MVRX      | MOD       | PGRP |     |              |                           |                                   | BYTE | RSGP                | SCJG | ISJG  |
| 0D |                 |              |                           |                                   | NDA  | ODA       | XDA       | ADA  |     |              | PAXC                      | PAXE                              | PPAL | PPRA                | PPAX | POPP  |
| 0E |                 |              |                           |                                   | LDA  | LDX       | PDS       | ADX  |     |              |                           |                                   | ILGA | ILPX                | NAI1 | NAI2  |
| 0F |                 |              |                           |                                   |      | MRXX      |           |      |     |              |                           |                                   |      |                     |      | INTER |

#### Chart 2

|    |                 |                | JFL, JCF, JZF<br>COLUMN RESTRICT<br>f.c.z=0 f.c.z=1 |                 | IL           | LL COLUM        | N RESTRIC       | т               | JFL, JCF, JZ<br>COLUMN REST<br>f,c,z=0 f,c, |                  |                 | CF, JZF<br>RESTRICT<br>f,c,z=1 | T JRL COLUMN RESTRICT |                  |                 | T                |
|----|-----------------|----------------|-----------------------------------------------------|-----------------|--------------|-----------------|-----------------|-----------------|---------------------------------------------|------------------|-----------------|--------------------------------|-----------------------|------------------|-----------------|------------------|
|    | 0               | 1              | 2                                                   | 3               | 4            | 5               | 6               | 7               | 8                                           | 9                | A               | В                              | с                     | D                | E               | F                |
| 00 | INIT            | JAGT+1         | JTR1                                                | JNT1            | TFAL         | TTRU            |                 | JALE+1          |                                             | MADD+1           | IMRF1+1         | XATS                           |                       | CLOP2            |                 | FETCH            |
| 01 | SNEQ+1<br>12    |                | SNEQ                                                | SWEQ            | LBYA         | LBYR            | SBYA            | SBYR            | SBYA+1<br>16 79                             | SBYA+2<br>18     | STLB            | STRB                           | STLB+1<br>1A 1D       | SRBI             |                 | FETCH+1<br>OF 9F |
| 02 | DBIA            |                | LBYT                                                | RBYT            | JXGX         | JXLX            | JXEX            | JXNX            |                                             |                  |                 |                                |                       | PPRA+1<br>DD 2F  | BYTE+5<br>AE    |                  |
| 03 | JUNC            | JAGE           | JALT                                                | JXGA            | JAEQ         | JANE            | JCEZ            | JXLA            | JALE                                        | JAGT             | JCNZ            | JXEA                           | CPSS                  | ΡΧΑ              | CLOP            | JXNA             |
| 04 | PXA+2<br>4D 70  |                | APE2                                                | AN2             |              | IXMB+3<br>47 85 | IXMA+1<br>86 56 | IXMB+2<br>57 45 |                                             |                  |                 | XATS+1<br>OB 5B                | SCJG+2<br>4E 3C       | PXA+1<br>3D 40   | SCJG+1<br>CE 4C |                  |
| 05 | JIG+3<br>E0 60  | XATS+4<br>5A   | TFEQ                                                | TXNG            | DMRF+1<br>84 | IMRF1           | IXMA2           | IXMB+1<br>87 47 | INTER+3<br>5F 59                            | INTER+4<br>58 69 | XATS+3<br>5B 51 | XATS+2<br>4B 5A                | CPSS+1<br>3C 5D       | CPSS+2<br>5C AD  | IRBM+1<br>8E 56 | INTER+2<br>BF 58 |
| 06 | JIG+4<br>50     | JRDR+1<br>71   | JNT2                                                | JTR1            | LAA          | LAX             | PAS             | ISDA            | ISDA+1<br>67 F8                             | INTER+5<br>59 6C | MADD            | MLOAD                          | INTER+6<br>69 6D      | INTER+7<br>6C 6F | CLOP+1<br>3E 0D | INTER+8<br>6D AF |
| 07 | PXA+3<br>40 F0  | JRDR<br>81 61  | APRE                                                | ANPE            | SAM          | SXM             | PSM             | SDX             | PSM+1<br>76 A8                              | SDX+1<br>77 F9   | CPG2+2<br>AA 7B | CPG2+3<br>7A EB                | MRV1                  | MRV2             | MRAD            | STPG             |
| 08 | NA0             | JRLE           | JIG                                                 | IMMD            | DMRF         | IMRF            | IXMA            | іхмв            | IND                                         | INX              | OTD             | отх                            | MVGP                  | SPFG             | IRBM            | NA 15            |
| 09 | RAXI+1<br>95 94 |                | RSEX                                                | RUNR            | RACI         | RAXI            | SAXI            | SLZJ            |                                             | SZDS+1<br>9A     | SXDS            | SNZD                           | MRV1+1<br>7C          | MRV2+1<br>7D     |                 | FETCH+2<br>1F    |
| 0A | RAXR+1<br>A4    | SAXR+1<br>A6   | SNCF                                                | SSCF            | RACR         | RAXR            | SAXR            | SLZR            | PSM+2<br>78 B8                              | ISJG+3<br>D9     | CPG2+1<br>AD 7A | BYTE+3<br>AC AE                | BYTE+2<br>BC AB       | CPG2             | BYTE+4<br>AB 2E | INTER+9<br>6F AD |
| 08 | RXFI            | IMML+1<br>B2   | IMML                                                | IMMS            | RACF         | RAXF            | SAXF            | SLZF            | PSM+3<br>A8 0F                              | XRTN+2<br>B9 BA  | LRTN            | XRTN                           | BYTE+1<br>CC AC       | CLOP2+1<br>0D    | XRTN+1<br>BB B9 | INTER+1<br>FF 5F |
| 0C | MVXR+1<br>C4 C1 | MVXR+2<br>C0   | NCY                                                 | SCY             | MVXR         | MVRX            | MOD             | PGRP            | PGRP+1<br>C7                                | ISJG+1<br>CF D9  | NOSK            | SKIP                           | BYTE                  | RSGP             | SCJG            | ISJG             |
| 0D | POPP+1<br>DF 30 | XDA+1<br>D6 0F | CPG2+7<br>F2 0D                                     | PPAL+1<br>DC D8 | NDA          | ODA             | XDA             | ADA             | PPAL+2<br>D3 E8                             | ISJG+2<br>D9 A9  | PAXE            | PAXC                           | PPAL                  | PPRA             | PPAX            | POPP             |
| 0E | JIG+2<br>E2 50  | MXRX           | JIG+1<br>82 E0                                      |                 | LDA          | LDX             | PDS             | ADX             | PPAL+3<br>D8 E9                             | PPAL+4<br>E8     |                 | CPG2+4<br>7B FB                | ILGA                  | ILPX             | NAI1            | NAI2             |
| 0F | PXA+4<br>70 F1  | PXA+5<br>F0 OF | CPG2+6<br>FB D2                                     |                 |              | MRXX            | PDS1            | ADA1            | ISDA+2<br>68 F7                             | SDX+2<br>79 F7   |                 | CPG2+5<br>EB F2                |                       |                  |                 | INTER            |

#### Chart 3

|    |                 | JFL, J<br>COLUMN | CF, JZF<br>RESTRICT | T JLL COLUMN RESTRICT |                 |                 | т               |                 |                  | JFL, JO<br>COLUMN | F, JZF<br>RESTRICT | JRL COLUMN RESTRICT |                  |                  | т               |                  |
|----|-----------------|------------------|---------------------|-----------------------|-----------------|-----------------|-----------------|-----------------|------------------|-------------------|--------------------|---------------------|------------------|------------------|-----------------|------------------|
|    |                 | 1                | 1,c,z=0             | T,C,Z=1               |                 | E               | 6               | 7               |                  |                   | t,c,z=U            | t,c,z=1             |                  |                  | -               | -                |
| 00 | INIT            | JAGT+1           | JTR1                | JNT1                  | TFAL            | TTRU            | OTD1            | JALE+1          | IND1             | MADD+1            | IMRF1+1            | XATS                | INIT+12<br>FC    | CLOP2            | PPRA+4<br>1E    | FETCH            |
| 01 | SNEQ+1<br>12    | INIT+4<br>21 41  | SNEQ                | SWEQ                  | LBYA            | LBYR            | SBYA            | SBYR            | SBYA+1<br>16 79  | SBYA+2<br>18      | STLB               | STRB                | STLB+1<br>1A 1D  | SRBI             | PPRA+5<br>OE 9E | FETCH+1<br>OF 9F |
| 02 | DBIA            | INIT+3<br>91 11  | LBYT                | RBYT                  | JXGX            | JXLX            | JXEX            | ХИХ             | INDI+1<br>08 0F  | PPRA+13<br>2B OF  | PPRA+11<br>EA 2B   | PPRA+12<br>2A 29    |                  | PPRA+1<br>DD 2F  | BYTE+5<br>AE    | PPRA+2<br>2D 4F  |
| 03 | JUNC            | JAGE             | JALT                | JXGA                  | JAEQ            | JANE            | JCEZ            | JXLA            | JALE             | JAGT              | JCNZ               | JXEA                | CPSS             | РХА              | CLOP            | JXNA             |
| 04 | PXA+2<br>4D 70  | INIT+5<br>11 44  | APE2                | AN2                   | INIT+6<br>41 F4 | IXMB+3<br>47 85 | IXMA+1<br>86 56 | IXMB+2<br>57 45 | INIT+11<br>49 0C | INIT+10<br>4A 48  | INIT+9<br>FA 49    | XATS+1<br>OB 5B     | SCJG+2<br>4E 3C  | PXA+1<br>3D 40   | SCJG+1<br>CE 4C | PPRA+3<br>2F 0E  |
| 05 | JIG+3<br>E0 60  | XATS+4<br>5A     | TFEQ                | TXNG                  | DMRF+1<br>84    | IMRF1           | IXMA2           | IXMB+1<br>87 47 | INTER+3<br>5F 59 | INTER+4<br>58 69  | XATS+3<br>5B 51    | XATS+2<br>4B 5A     | CPSS+1<br>3C 5D  | CPSS+2<br>5C AD  | IRBM+1<br>8E 56 | INTER+2<br>BF 58 |
| 06 | JIG+4<br>50     | JRDR+1<br>71     | JNT2                | JTR1                  | LAA             | LAX             | PAS             | ISDA            | ISDA+1<br>67 F8  | INTER+5<br>59 6C  | MADD               | MLOAD               | INTER+6<br>69 6D | INTER+7<br>6C 6F | CLOP+1<br>3E 0D | INTER+8<br>6D AF |
| 07 | PXA+3<br>40 F0  | JRDR<br>81 61    | APRE                | ANPE                  | SAM             | SXM             | PSM             | SDX             | PSM+1<br>76 A8   | SDX+1<br>77 F9    | CPG2+2<br>AA 7B    | CPG2+3<br>7A EB     | MRV1             | MRV2             | MRAD            | STPG             |
| 08 | NA0             | JRLE             | JIG                 | IMMD                  | DMRF            | IMRF            | IXMA            | ІХМВ            | IND              | INX               | OTD                | отх                 | MVGP             | SPFG             | IRBM            | NA 15            |
| 09 | INIT+1<br>00 91 | INIT+2<br>90 21  | RSEX                | RUNR                  | RACI            | RAXI            | SAXI            | SLZJ            | RAXI+1<br>95 94  | SZDS+1<br>9A      | SXDS               | SNZD                | MRV1+1<br>7C     | MRV2+1<br>7D     | PPRA+6<br>1E FE | FETCH+2<br>1F    |
| 0A | RAXR+1<br>A4    | SAXR+1<br>A6     | SNCF                | SSCF                  | RACR            | RAXR            | SAXR            | SLZR            | PSM+2<br>78 B8   | ISJG+3<br>D9      | CPG2+1<br>AD 7A    | BYTE+3<br>AC AE     | BYTE+2<br>BC AB  | CPG2             | BYTE+4<br>AB 2E | INTER+9<br>6F AD |
| 0B | RXFI            | IMML+1<br>B2     | IMML                | IMMS                  | RACF            | RAXF            | SAXF            | SLZF            | PSM+3<br>A8 0F   | XRTN+2<br>B9 BA   | LRTN               | XRTN                | BYTE+1<br>CC AC  | CLOP2+1<br>0D    | XRTN+1<br>BB B9 | INTER+1<br>FF 5F |
| 0C | MVXR+1<br>C4 C1 | MVXR+2<br>C0     | NCY                 | SCY                   | MVXR            | MVRX            | MOD             | PGRP            | PGRP+1<br>C7     | ISJG+1<br>CF D9   | NOSK               | SKIP                | вүте             | RSGP             | SCJG            | ISJG             |
| 0D | POPP+1<br>DF 30 | XDA+1<br>D6 0F   | CPG2+7<br>F2 0D     | PPAL+1<br>DC D8       | NDA             | ODA             | XDA             | ADA             | PPAL+2<br>D3 E8  | ISJG+2<br>D9 A9   | PAXE               | PAXC                | PPAL             | PPRA             | РРАХ            | POPP             |
| 0E | JIG+2<br>E2 50  | MXRX             | JIG+1<br>82 E0      | PPRA+9<br>F3 EA       | LDA             | LDX             | PDS             | ADX             | PPAL+3<br>D8 E9  | PPAL+4<br>E8      | PPRA+10<br>E3 2A   | CPG2+4<br>7B FB     | ILGA             | ILPX             | NAI1            | NAI2             |
| 0F | PXA+4<br>70 F1  | PXA+5<br>F0 OF   | CPG2+6<br>FB D2     | PPRA+8<br>FE E3       | INIT+7<br>44 FA | MRXX            | PDS1            | ADA1            | ISDA+2<br>68 F7  | SDX+2<br>79 F7    | INIT+8<br>F4 4A    | CPG2+5<br>EB F2     | INIT+13<br>0C    |                  | PPRA+7<br>9E F3 | INTER            |

## APPENDIX A

#### THE DESIGN EXAMPLE INSTRUCTION SET

The basic machine uses a 16-bit word. All instructions are single word instructions except the long immediate forms. Macroprograms are fully relocatable without reassembly. The data segment is also independently relocatable. There are five basic instruction catagories: memory reference, immediate data, jumps (including calls and returns), register moves and manipulations, and input-output functions.

The machine has seven registers as follows:

|     | REGISTER                        | ASSIGNED<br>CPE<br>REGISTER |
|-----|---------------------------------|-----------------------------|
| (A) | Accumulator                     | RO                          |
| (X) | Index Register                  | R1                          |
| (B) | Data-Base Register              | R5                          |
| (E) | Program Execution Base Register | R6                          |
| (P) | Program Counter                 | R3                          |
| (S) | Stack Pointer                   | R4                          |
| (W) | Status Word Register*           | R7                          |

The operations supported under these five modes are as follows:

| MNEMONIC | FUNCTION               | ο    |
|----------|------------------------|------|
| NDA      | AND data to A          | 0000 |
| LDA      | Load data to A         | 0001 |
| LAA      | Load address to A      | 0010 |
| SAM      | Store A in memory      | 0011 |
| ODA      | OR data to A           | 0100 |
| LDX      | Load data to X         | 0101 |
| LAX      | Load address to X      | 0110 |
| SXM      | Store X in memory      | 0111 |
| XDA      | Exclusive OR data to A | 1000 |
| PDS      | Push data to stack     | 1001 |
| PAS      | Push address to stack  | 1010 |
| PSM      | Pop stack to memory    | 1011 |
| ADA      | Add data to A          | 1100 |
| ADX      | Add data to X          | 1101 |
| SDA      | Subtract data from A   | 1110 |
| SDX      | Subtract data from X   | 1111 |

\*A carry flip-flop designated C is the high order bit of the status word register W.

#### **Memory Reference Group**

| ADDRESS MODE              | ADDRESS<br>COMPUTATION | M-FIELD<br>CODES |
|---------------------------|------------------------|------------------|
| Direct                    | B+D                    | 0100             |
| Indirect                  | (B+D)                  | 0101             |
| Indirect Relative         | (B+D)+B                | 1110             |
| Indirect Indexed          | (B+D)+X                | 0110             |
| Indirect Indexed Relative | (B+D)+X+B              | 0111             |

#### SUMMARY OF MEMORY REFERENCE MODES

Note: Values enclosed in ( ) designate indirect addresses.

#### **Immediate Group**

| MNEMONIC | FUNCTION                    | M-<br>FIELD | O-<br>FIELD |
|----------|-----------------------------|-------------|-------------|
| LAI      | Load to A immediate         | 0011        | 0001        |
| ΑΑΙ      | Add to A immediate          | 0011        | 1100        |
| NAI      | AND to A immediate          | 0011        | 0000        |
| OAI      | OR to A immediate           | 0011        | 0100        |
| XAI      | Exclusive OR to A immediate | 0011        | 1000        |
| PSI      | Push to stack immediate     | 0011        | 1001        |
| LXI      | Load to X immediate         | 0011        | 0101        |
| AXI      | Add to X immediate          | 0011        | 1101        |

If D is equal to zero, the contents of the memory location following the instruction is used as the immediate value.

### Jump Group

|            | FUNCTION           | RELA | TIVE | INDIRECT |      |  |
|------------|--------------------|------|------|----------|------|--|
| MINEMONIC  | FUNCTION           | м    | 0    | М        | 0    |  |
| JRU,JIU    | Jump unconditional | 0001 | 0000 | 0010     | 0000 |  |
| JRGE,JIGE  | Jump if A.GE.O     | 0001 | 0001 | 0010     | 0001 |  |
| JRLT,JILT  | Jump if A.LT.O     | 0001 | 0010 | 0010     | 0010 |  |
| JRXG,JIXG  | Jump if X.GT.A     | 0001 | 0011 | 0010     | 0011 |  |
| JREZ,JIEZ  | Jump if A.EQ.O     | 0001 | 0100 | 0010     | 0100 |  |
| JRNZ,JINZ  | Jump if A.NE.O     | 0001 | 0101 | 0010     | 0101 |  |
| JRCZ,JICZ  | Jump if C.EQ.O     | 0001 | 0110 | 0010     | 0110 |  |
| JRXL,JIXL  | Jump if X.LE.A     | 0001 | 0111 | 0010     | 0111 |  |
| JRLE,JILE  | Jump if A.LE.O     | 0001 | 1000 | 0010     | 1000 |  |
| JRGT,JIGT  | Jump if A.GT.O     | 0001 | 1001 | 0010     | 1001 |  |
| JRCN, JICN | Jump if C.NE.O     | 0001 | 1010 | 0010     | 1010 |  |
| JRXE,JIXE  | Jump if X.EQ.A     | 0001 | 1011 | 0010     | 1011 |  |
| JRXN,JIXN  | Jump if X.NE.A     | 0001 | 1111 | 0010     | 1111 |  |

Unconditional and conditional jumps:

Relative: P = P+D' where D'=D-128 Indirect: P = E+(E+D)

#### Subroutine Call Group

|          | CUNATION                                                     | ABSC    | DLUTE |      |      |
|----------|--------------------------------------------------------------|---------|-------|------|------|
| MNEMONIC | FUNCTION                                                     | м       | 0     |      |      |
| CAS      | Call absolute, push<br>P, E, W, B<br>P ← (D)                 | 1101    | XX11  |      |      |
|          |                                                              | м       | о     | м    | ο    |
| CLS      | Call local subroutine,<br>push P                             | N.A.    |       | 0010 | 1110 |
| CVS      | Call global subroutine,<br>push W. B, E, P                   | N.A.    |       | 0010 | 1100 |
| Local:   | Push P to stack<br>P = E+(E+D)                               |         |       |      |      |
| Value:   | Push W, B, E, P to stack<br>E = E+(E+D)<br>P = E'+(E') where | E'=E+(E | :+D)  |      |      |

#### Subroutine Return Group

**Register Manipulation Group** 

CFF

zeros

MNEMONIC

RAR

RAX

SAX

SAL

| MNEMONIC | FUNCTION             | М    | 0    |
|----------|----------------------|------|------|
| RLS      | Pop P                | 1100 | 1111 |
| RVS      | Pop P, E, B, W       | 1100 | 1101 |
| RSA      | Pop A, X, P, E, B, W | 1100 | 1100 |

FUNCTION

Rotate A right, include

Rotate A and X right,

Shift A and X right,

Shift A left, fill with

include CFF

preserve sign

М

1101

1101

1101

1101

0

0001

0101

1001

1101

The shift count is given by D if D is non-zero or by the least significant seven bits of the X register if D is zero.

#### Base and Status Register Move Group

| MNEMONIC | FUNCTION            | м    | ο    |
|----------|---------------------|------|------|
| MSX      | Move S to X, adjust | 1100 | 0100 |
| MBX      | Move B to X, adjust | 1100 | 0101 |
| MEX      | Move E to X, adjust | 1100 | 0110 |
| MWX      | Move W to X, adjust | 1100 | 0111 |
| MXS      | Move X to S, adjust | 1100 | 0000 |
| MXB      | Move X to B, adjust | 1100 | 0001 |
| MXE      | Move X to E, adjust | 1100 | 0010 |
| MXW      | Move X to W, adjust | 1100 | 0011 |
| NO.OP    | Nothing implemented | 1100 | 10XX |

The destination register is adjusted by D-128.

#### Byte Load and Store Group

| MNEMONIC | I       | UNCTION       | м         | 0     |
|----------|---------|---------------|-----------|-------|
| LBA      | Load b  | oyte absolute | 1101      | 0000  |
| LBR      | Load b  | oyte relative | 1101      | 0100  |
| SBA      | Store I | oyte absolute | 1101      | 1000  |
| SBR      | Store I | oyte relative | 1101      | 1100  |
| Absolute | mode:   | Byte address  | = (B+D)+X | (/2   |
| Relative | mode:   | Byte address  | = (B+D)+E | 8+X/2 |

#### Input/Output Group

| MNEMONIC | FUNCTION                   | м    | 0    |
|----------|----------------------------|------|------|
| IND      | Input one word<br>A ← (D)  | 1000 | XXXX |
| OTD      | Output one word<br>(D) ← A | 1001 | XXXX |
| INX      | Input one word<br>A ← (X)  | 1010 | XXXX |
| ΟΤΧ      | Output one word<br>(X) ← A | 1011 | XXXX |

#### Special Memory Reference Instruction

| MNEMONIC | FUNCTION              | м    | 0    |  |
|----------|-----------------------|------|------|--|
| ISZ      | Increment and skip if | 1101 | XX10 |  |

#### Stack Push and Pop Group

| MNEMONIC | FUNCTION             | м    | 0    | М    | 0    |
|----------|----------------------|------|------|------|------|
| PHAX     | Push A, X onto stack | 0001 | 1101 | 0010 | 1101 |
| PPAX     | Pop A, X             | 1100 | 1110 |      |      |

#### APPENDIX B

MICROPROGRAM LISTING © Intel Corporation, 1975 RECORD NUMBER /\* BIPOLAR MICROCOMPUTER MACRO-MACHINE 1 2 **REGISTER MACHINE--12/13/74** 3 UPDATED 3/18/75 Δ 5 MACHINE HAS 7 REGISTERS AS FOLLOWS: 6 A ACCUMULATOR R0 7 Х INDEX REGISTER R1 8 Ρ PROGRAM COUNTER R3 9 s STACK POINTER R4 10 DATA BASE REG R5 в 11 Ε PROG. BASE REG. R6 12 W STATUS WORD R7 13 14 C=CARRY, LINK FLIP-FLOP=HOB OF W 15 DEFINITION OF KBUS FIELD \*/ 16 17 18 KB FIELD LENG1H=4 DEFAULT=0 K007F=1 19 MICROPS(K0000=0 KOOFF=3 K7FFF=7 20 K8000=8 KFF00=12 KFF80=14 KFFFF=15); 21 22 КΒ KBUS: 23 24 25 /\* DEFINITION OF BUS CONTROL FIELD \*/ 20 27 MCF DEFAULT=0 FIELD LENGTH=3 28 MICROPS(NMG=000B INH=001B RMW=010B CNB=011B 29 RIN=100B ROT=101B RRM=110B RWM=111B); 30 NO BUS OPERATION 31 /\* NBO INHIBIT CPE ARRAY 32 INH 33 RMW READ-MODIFY-WRITE 34 CNB CPU NEEDS BUS 35 RIN **REQUEST INPUT** 36 ROT **REQUEST OUTPUT** REQUEST READ MEM. 37 RRM 38 RWM **REQUEST WRITE MEM.** 39 40 SET UP FOR SYMBOLIC REPRESENTATION OF REGISTER DESIGNATIONS #/ 41 42 STRING 'R0'; А 'R1'; 43 Х STRING 44 ₽ STRING 'R3'; 45 s STRING 'R4'; 46 в STRING 'R5'; 47 Е STRING 'R6'; 48 STRING 'R7'; W 49 /\* SET UP A SPECIAL NO.OP STRING \*/ 50 51 52 NO.OP STRING 'NOP(R2)'; 53 /\* NEXT WE SPECIFY A DEFAULT TO FF1 IN THE FO FIELD FOR THE SDR 54 55 MICROP IN THE CPE FIELD. SDR IS NORMALLY USED AS A STORE OPERATION. WHEN A DECREMENT OPERATION IS ALSO DESIRED, FFO 56 57 WILL HAVE TO BE EXPLICITLY SPECIFIED #/ 58 SDR FO=11B; 59 IMPLY 60

RECORD

125

0 B2H:

TMML:

LMI(P) FF1 RRM;

61 62 63 64 /\* INITIALIZATION SEQUENCE 65 ZERO A, X, AND W \*/ 66 67 000H: INIT: CLR(A); 090H: 68 CLR(X); 091H: CLR(W); 69 70 71 /\* ZERO I AS TEMPORARY POINTER, WRITE W TO INTERRUPT STRUCTURE \*/ 72 73 CLR(T); 021H: LMI(T); 74 011H: 75 041H: ILR(W) ROT; 76 /\* SET S = (0), T = 1 FOR NEXT OPERATION \*/77 78 79 044H: LMI(T) FF1 RRM; 80 0F4H: ACM(AC) ; OFAH: SDR(S); 81 82 /\* SET B = (1), T = 2 FOR NEXT OPERATION \*/ 83 84 LMI(T) FF1 RRM; 85 04AH: 86 049H: ACM(AC); 048H: SDR(B) STC; /\* THIS SETS THE C FLAG TO INSURE 87 88 A CORRECT JUMP TO XRTN #/ 89 90 /\* GET (2). JUMP TO XRTN TO SET E = (2). P = (E) \*/91 92 00CH: LMI(T) RRM; 93 OFCH: JCF (\*,XRTN); ACM(AC) 94 95 /\* FETCH SEQUENCE & START OF MACRO-INSTRUCTION PROCESSING P IS ISSUED TO MAR AND INCREMENTED, MACRO-INSTRUCTION 96 97 IS FETCHED AND TESTED BY JPX MICRO-OPERATION. NOTE 98 FETCH IS IN LOCATION 15 TO STROBE INTERRUPT ON ENTRY. \*/ 99 FETCH: LMI(P) FF1 RRM; 100 00FH: 101 /\* LOAD DISPLACEMENT AND TEST FOR ZERO USING Z FLAG \*/ 102 103 104 01FH: LTM(AC) STZ KOOFF: 105 /\* SAVE DISPLACEMENT, TEST 4 BITS OF MACRO-OP. TEST IS 106 DELAYED TO ALLOW PIPELINE PROPAGATION. ALSO C FLAG IS 107 108 SET FOR LATER USE IN PSEUDO-SUBROUTINES. \*/ 109 110 09FH: SDR(R9) STC JPX(NA0, JREL, JIG, IMMD, DMRF, IMRF, IXMA, IXMB, IND, 111 INX, OTD, OTX, MVGP, SPFG, IRBM, NA15); 112 113 /\* UNASSIGNED OP-CODE GROUPS--NOPS FOR THIS VERSION \*/ 114 115 080H: NAO: NO.OP JZR(FETCH): 116 U8FH: NA15: NO.UP JZR(FETCH); 117 /\* IMMEDIATE GROUP OF MACRO-INSTRUCTIONS--TEST FOR LONG OF SHORT 118 119 FURM--D IS IN AC AND R9--ADJUS1 AC BY -128 \*/ 120 0636: IMMD: 121 LHI(AC) KFF80 JZF(IMML, IMMS); 122 /\* LONG FORM: FETCH NEXT WORD TO AC \*/ 123 124

RECORD

126 0B1H: ACM(AC) JRL(ILGA, ILPX, NAI1, NAI2): 127 128 /\* SHURI FORM: NO PROCESSING NEEDED \*/ 129 130 0838: IMMS: NO.UP JRL(ILGA, ILPX, NAI1, NAI2); 131 /\* PREPROCESSING FOR ARITHMETIC AND LOGIC ROUTINES? NONE NEEDED \*/ 132 133 NO.UP 134 OECH: ILGA: JLL(NDA.ODA.XDA.ADA): 135 OEDH: ILPX: NO.OP JLL(LDA,LDX,PDS,ADX); 136 137 /\* NOTE: NAI1 AND NAI2 ARE NUN-VALID INSTRUCTIONS!! THEY ARE MADE INTO NU-UPS IN THIS VERSION OF THE MACRO-MACHINE \*/ 138 139 140 OFEH: NAT1: NO.OP JZR(FETCH): 141 OEFH: NAI2: NO.OP JZR(FETCH): 142 143 /\* BASIC ARITHMETIC AND LOGIC PROCESSING--UPDATE C FF OF MACRO-144 MACHINE FOR ADA--TOGGLE IT ON CARRY FROM ADA \*/ 145 146 UD/H: ADA: ADR(A); 147 OF7H: ADA1: NO.OP JFL(NCY,SCY); 148 0C2H: NCY: NO.UP JZR(FETCH): 149 0C3H: SCY: LMI(W) K8000 JZR(FETCH); 150 151 /\* LUGICALS \*/ 152 153 0D4H: NDA: ANR(A) JZR(FETCH); 154 0D5H: ODA: ORR(A) JZR(FETCH); 155 0D6H: XDA: CMR(AC): 156 0D1H: XNR(A) JZR(FETCH); 157 /\* LDA AND LDX OPERATIONS \*/ 158 159 160 0E4H: LDA: SDR(A) JZR(FETCH); 161 0E5H: LDX: SDR(X) JZR(FETCH); 162 /\* STACK PUSH--ADVANCE STACK POINTER TO NEXT LOCATION (FOR THE 163 REVERSE DIRECTION STACK -- A DECREMENT OF S), THEN WRITE \*/ 164 165 166 0E6H: PDS: DSM(S); 0F6H: PDS1: LMI(S) RWM JZR(FETCH): 167 168 /\* ADX - SHARES CODE FOR ADA - ALSU TOGGLES C FF OF MACRO MACHINE \*/ 169 170 171 01711: ADX: ADR(X) IMP(ADA1): 172 173 /\* MEMORY REFERENCE INSTRUCTION GROUPS 174 DIRECT--GET B+D INTO AC--ALSO R9 \*/ 175 176 084H: DMRF: ILP(B); 177 054H: ALR(R9) JRL(MRV1.MRV2.MRAD.STPG): 178 179 /\* INDIRECT-ABSOLUTE--GET (B+D) INTO AC--C FLAG USED FOR PSEUDO-SUBROUTINE \*/ 180 181 0.85H: IMRF: ILR(B); 182 0558: IMRF1: ALR(R9); LMI(R9) RRM 183 00AH: JCF(MADD, MLOAD); 184 06BH: MLOAD: ACM(AC) JRL(MRV1,MRV2,MRAD,STPG); 185 180 /\* NOIE: MADD WILL BE USED FOR OTHER INDIRECT OPERATIONS WHERE 187 B, X, ETC. HAS BEEN LOADED TO R8 \*/ 188 189 Ú6AH: MADD: ACH(AC); 140 009H: ALR(R8) JRL(MRV1,MRV2,MRAD,STPG); 191 192 /\* INDIRECT INDEXED ABSOLUTE - CLEAR C FLAG, MOVE X TO R8 \*/ 193 194 086H: 1LR(X) STC; IXMA: 195 046H: SDR(R8); 196

```
RECORD
NUMBER
       /* NOTING THAT ASSIGNMENT RULES WOULD NOT ALLOW THE DESIRED
  197
  198
          JUMP TO IMRE UNLESS IXMA+1 WERE IN ROW ZERO--AN EXTRA STATE
          IS ADDED HERE #/
  199
  200
        056H:
                 IXMA2: ILR(B)
                                                   JMP(IMRF1);
  201
  202
       /* INDIRECT INDEXED RELATIVE - CLEAR C FLAG, PUT B+X IN R8 */
  203
  204
  205
        087H:
                 IXMB:
                          ILR(X) STC;
                          SDR(R8);
        057H:
  206
  207
        047H:
                          ILR(B);
        045H:
                          ADR(R8)
                                                   JMP(IMRF);
  208
  209
       /* INDIRECT RELATIVE (TO B) - CLEAR C FLAG, PUT B IN R8 */
  210
  211
        08EH:
  212
                 IRAM:
                         ILR(B):
  213
       /* AGAIN ASSIGNMENT RULES PREVENT JUMPING TO IXMA+1 UNLESS IT IS
  214
  215
           LOCATED IN ROW ZERO--PLACEMENT THERE COULD FREE TWO WORDS */
  216
        05EH:
                          SDR(RR)
  217
                                                   JMP(IXMA2);
  218
  219
       /* THE FOLLOWING PROCEDURES IMPLEMENT THE BASIC PREPROCESSING FOR
  220
           VALUE AND ADDRESS LOADING.
  221
           VALUE-GROUP 1: GET (AC) IN AC */
  222
  223
        07CH:
                         LMI(AC) RRM;
  224
                 MRV1:
  225
        09CH:
                          ACM(AC)
                                                   JLL(NDA, UDA, XDA, ADA);
  226
       /* VALUE GROUP 2 */
  227
  228
  229
        07DH:
                 MRV2:
                         LMI(AC) RRM;
  230
        0904:
                          ACM(AC)
                                                   JLL(LDA,LDX,PDS,ADX);
  231
  232
       /* MRAD GROUP INCLUDES ADDRESS LOADS AND SUBTRACT FROM A */
  233
  234
        07EH:
                 MRAD:
                          NO.OP
                                                   JLL(LAA, LAX, PAS, ISDA);
  235
  236
        064H:
                 LAA:
                          SDR(A)
                                                   JZR(FETCH);
        065H:
  237
                 LAX:
                          SDR(X)
                                                   JZR(FETCH);
  238
        066H:
                 PAS:
                          DSM(S)
                                                   JMP(PDS1);
  239
  240
       /* FOR SUBTRACT, ADD 1'S COMPLEMENT PLUS 1 */
  241 -
  242
        067H:
                 ISDA:
                          LMI(AC) RRM;
        068H:
  243
                         LCM(AC);
  244
        0F8H:
                          ADR(A) FF1
                                                   JMP(ADA1);
  245
  246
       /* STPG GROUP INCLUDES STORES AND SUBTRACT FROM X */
  247
        0764:
                 STPG:
                          LMI(AC)
  248
                                                   JLL(SAM, SXM, PSM, SDX);
  249
  250
        074H:
                 SAM:
                         ILR(A) RWM
                                                   JZR(FETCH);
  251
        U75H:
                 SXM:
                          ILR(X) RWM
                                                   JZR(FETCH);
  252
  253
       /* POP STACK TO MEMORY - SAVE ADDRESS, POP STACK */
  254
        076H:
  255
                 PSM:
                          SDR(T);
  256
        078H:
                          LMI(S) FF1 RRM;
  257
        UA8H:
                          ACM(AC);
  258
        0B8H:
                          LMI(T) RWM
                                                   JZR(FETCH);
  259
  260
       /* SUBTRACT FROM X */
  261
  262
        077H:
                 SOX:
                          LMI(AC) RRM;
  263
        079H:
                          LCM(AC);
        0F9H:
  264
                          ADR(X) FF1
                                                   JMP(ADA1);
  265
  266
       /* JUMP GROUPS--USE JPR MICRO-OPERATION TO RESOLVE CONDITION SELECTION
          DESTINATION ADDRESS IS COMPUTED FIRST--PLACED IN AC AND R9
  267
```

RECORD NUMBER 268 JUMP RELATIVE TO P--ADDRESS=P+D-128 \*/ 269 270 081H: IRFL: ILR(P): 271 071H: JRDR: LMI(AC) KFF80; 272 061H: ALR(R9) JPR(JUNC, JAGE, JALT, JXGA, JAEQ, JANE, JCEZ, JXLA, 273 JALE, JAGT, JCNZ, JXEA, CPSS, PXA, CLOP, JXNA); 274 275 /\* JUMP INDIRECT - GET E+(E+D) IN AC AND R9 \*/ 276 277 082H: JIG: ILR(E); 278 0F2H: ADR(R9): 279 OFOH: LMI(R9) RRM; 280 050H: AMA(AC); 281 060H: SDP(R9) JPR(JUNC, JAGE, JALT, JXGA, JAEQ, JANE, JCEZ, JXLA, 282 JALE, JAGT, JCNZ, JXEA, CPSS, PXA, CLOP, JXNA); 283 /\* UNCONDITIONAL JUMP \*/ 284 285 286 U30H: JUNC: SDR(P) JZR(FETCH): 287 288 /\* TESTS FUR A.GE.U, ETC. \*/ 289 TZR(A) K8000 INH 290 031H: JAGE: JMP(TTRU); 291 032H: JALT: TZR(A) K8000 INH IMP(TFAL): 292 034H: JAEO: TZR(A) JMP(TTRU); 293 035H: JANE: TZR(A) JMP(TFAL); 244 295 0398: JAGT: TZR(A) K8000 ENH: 296 001H: TZR(A) JFL(APRE, ANPE); 297 298 0724: APRE: NO.UP JFL(JNT2,JTR2); 299 073H: ANPE: NO.OP JZR(FETCH); 300 301 038H: JALE: TZR(A) K8000 INH; 302 007H: TZR(A) JFL(APE2,AN2); 303 304 0428: APF2: NO OP JFL(JTR1, JNT1); 305 043H: AN2: SUP(P) JZR(FETCH); 306 /\* TESTS OF C FLIP-FLOP (HIGH ORDER BIT OF W) \*/ 307 308 309 0368: JCEZ: TZR(w) K8000 INH JMP(TTRU); 310 03AH: JCNZ: T2R(w) K8000 INH JMP(TFAL); 311 312 /\* TEST EXECUTION FUR ABOVE TESTS - ROW ZERO USED \*/ 313 005H: TTRU: 314 NO. 0P JFL(JTR1, JNT1); 315 0024: 316 JIR1: SOR(P) JZR(FETCH); 317 003H: JNT1: NO.OP JZR(FETCH); 318 004H: 319 TFAL: NO.UP JFL(JNT2, JTR2); 320 06281 321 JNT2: NO.UP JZR(FETCH); 322 063H: JTR2: SDR(P) JZR(FETCH); 323 324 /\* TESTS FOR X.GT.A, X.LE.A, X.EQ.A, X.NE.A--SHARED PSEUDO-SUBROUTINE USES JLL FOR AN EXIT TEST-- KOUTINE ENTRY IN ROW O 325 C FLAG IS SET FOR X.GT.A, FL TEST FOR X.EQ.A \*/ 326 327 033H: 328 JXGA: ILR(X) JMP(XATS); 037H: 329 JXLA: ILR(X) JMP(XATS); 03BH: ILR(X) 330 JXEA: JMP(XATS); 03FH: 331 JXNA: ILR(X) JMP(XATS); 332 333 /\* SAVE X AT I, FETCH AND COMPLEMENT A \*/ 334 335 00BH: XATS: SDR(T): 336 04BH: 1LR(A) STC; /\* CLEAR C FLAG \*/ 337 0568: CMA(AC);

338

RECORD NUMBER /\* ADD HOB'S OF A' AND X - CARRY MEANS X NEG., A.GE.O \*/ 339 340 341 USAH: ADR(T) K8000: 342 343 /\* EXECUTE PREVIOUS TEST, SET UP TO TEST HOB OF RESULT--IF 1, 344 THE SIGNS OF A AND X WERE THE SAME \*/ 345 TZR(T) K8000 1NH 340 0518: JFL(TFE0,TXNG); 341 348 /\* TXNG IMPLIES X NEG AND A.GE.O--I.E. X.NE.A AND X.LT.A--DO A 349 DUMMY OPERATION TO FORCE THE PROPER F FLAG \*/ 350 351 0534: TXNG: 1LR(A) JLL(JXGX, JXLX, JXEX, JXNX); 352 353 /\* PERFORM A TEST ADDITION AND EXECUTE SIGN-EQUAL TEST 354 C WILL BE SET IF SIGNS WERE THE SAME AND X.GT.A \*/ 355 356 052H: IFEO: ADR(T) STC K7FFF JFL(SNEO.SWEO): 357 358 /\* SNEQ IMPLIES SIGNS NOT EQUAL--I.E. X.GE.O, A NEG--X.GT.A \*/ 359 360 012H: SNEO: SDR(AC) STC; /\* DUMMY OP TO SET C FLAG \*/ 361 010H: NO.OP JLL(JXGX, JXLX, JXEX, JXNX); 362 363 /\* FOR SIGNS EQUAL, IF X=A RESULT WOULD BE 1111...1. INCREMENT 364 WILL GENERATE A CARRY IF SO #/ 365 366 013H: SWEO: ILR(AC) FF1 JLL(JXGX, JXLX, JXEX, JXNX); 367 /\* EXECUTION OF JUMP TESTS \*/ 368 369 JCF(JNT2, JTR2); 370 024H: JXGX: ILR(R9) 371 025H: JXLX: ILR(R9) JCF(JTR1, JNT1); 372 0268: JXEX: ILR(R9) JFL(JNT2, JTR2); 373 027H: JXNX: ILR(R9) JFL(JTR1, JNT1); 374 375 /\* SUBROUTINE CALLS 376 CALL LOCAL AND PUSH W, B, E, P = CPSS 377 CALL LOCAL AND PUSH P ONLY=CLOP C FLAG IS USED FOR EXIT TEST AFTER PUSHING P \*/ 378 379 03CH: DSM(S): 380 CPSS: 381 05CH: ILR(W); 382 05DH: LMI(S) RWM; 383 CPG2: 384 OADH: DSM(S): 385 OAAH: ILR(B); 386 07AH: LMI(S) RWM; 387 388 0788: DSM(S); 389 OEBH: ILR(E); 390 OFBH: LMI(S) RWM; 391 392 0F2H: DSM(S); 393 0D2H: ILR(P); 394 00DH: CLOP2: LMI(S) RWM; 395 396 /\* E+(E+D) INTO AC \*/ 397 398 OBDH: ILR(R9) JCF(LRTN, XRTN); 399 400 0888: XRTN: SDR(E); OBEH: 401 LMI(E) RRM; 0B9H: 402 AMA(AC); 403 UBAH: 404 L R T N : SDR(P) JZR(FETCH): 405 03EH: CLOP: DSM(S); 406 407 06EH: 1LR(P) STC JMP(CLOP2); 408 /\* PUSH INSTRUCTION \*/ 409

RECORD

NUMBER 410 411 03DH:

PXA: DSM(S): 412 04DH: ILR(X); 413 040H: LMI(S) RWM; 414 070H: 415 DSM(S); OFOH: 416 ILR(A); 417 OF1H: LMI(S) RWM JZR(FETCH); 418 419 /\* MUVE GROUP OF INSTRUCTIONS--USES JCE TO SELECT REGISTER--NOTE 420 THAT REGISTER ASSIGNMENT BECOMES IMPORTANT 421 FIRST MUDIFY D TO GET D-128 \*/ 422 423 08CH: MVGP: LMI(R9) KFF80 JLL(MVXR, MVRX, MOD, PGRP); 424 /\* MOVE X TO REG. - GET X, MODIFY BY D'=D-128 \*/ 425 426 427 00441 MVXR: ILR(X); 428 **OCOH:** ALR(R9); OC1H: SDR(R7) 429 /\* REGISTER OVERRIDE \*/ JCE(MXRX); 430 0E1H: MXRX: NO.OP JZR(FETCH); 431 /\* MOVE REG TO X - FETCH REG USING JCE OVERRIDE \*/ 432 433 434 0C5H: MVRX: ILR(R7) JCE(MRXX); ALR(R9) JMP(LDX); 435 0F5H: MRXX: 436 437 /\* MOD NOT IMPLEMENTED IN THIS VERSION \*/ 438 439 0C6H: MUD: NO.OP JZR(FETCH); 440 441 /\* ADJUST STACK AND RETURN GROUP PPAL--POPS A, X, P, E, B, AND W PPRA--POPS P, E, B, AND W 442 443 PPAX--POPS UNLY A AND X 444 445 POPP--POPS ONLY P \*/ 446 447 0C7H: PGRP: 1LP(R9); 448 0C8H: ADR(S) JRL(PPAL, PPRA, PPAX, POPP); 449 450 ODCH: PPAL: LMI(S) FF1 RRM; 451 0D3H: ACM(AC); UD8H: SDR(A); 452 453 454 LMI(S) FF1 RRM; 0E8H: ACM(AC) 0E9H: JCF(PAXE, PAXC); 455 456 ODBH: PAXC: SDR(X); 457 458 00DH: PPRA: LMI(S) FF1 RRM; 459 020H: ACM(AC): 460 02FH: SDR(P); 461 462 U4FH: LMI(S) FF1 HRM; 00EH: ACM(AC); 463 404 01EH: SDR(E); 465 406 09EH: LMI(S) FF1 RRM; 467 OFEH: ACM(AC); 468 0F3H: SDR(B); 469 470 UE3H: LMI(S) FF1 RRM; 471 OEAH: ACM(AC); 472 02AH: SDR(W); 473 474 /\* RESTORE INTERRUPT STRUCTURE \*/ 475 476 0288: CLR(T): 477 029H: LMI(T) ROT JZR(FETCH); 478 479 ODAH: PAXE: SDR(X) JZR(FETCH); 480

## RECORD

481 ODEH: PPAX: ILR(AC) STC JMP(PPAL); 482 483 ODFH: POPP: LMI(S) FF1 RRM; JMP(JUNC); 00041 484 ACM(AC) 485 /\* SPECIAL FUNCTION GROUP 486 487 BYTE OPERATORS--ADDR=(B+D)+B+X/2 OR (B+D)+X/2 CALL TO (D) AND PUSH ALL 488 489 SHIFT AND ROTATE GROUP 490 INCREMENT AND SKIP 491 FETCH B JUST IN CASE \*/ 492 493 0804: SPFG: ILR(B) JRL(BYTE,RSGP,SCJG,ISJG); 494 495 /\* BYTE GROUP--COMPUTE ADDR, STORE B IN CASE NEEDED \*/ 496 497 OCCH: BYTE: SDR(R8); 498 OBCH: ADR(R9); 499 UACH: ILR(X); 500 OABH: SRA(AC) STC; 501 OAEH: LMI(R9) RRM; 02EH: 502 AMA(AC) JLL(LBYA, LBYR, SBYA, SBYR); 503 504 0154: LBYR: ALR(R8); 505 014H: LBYA: JCF(LBYT, RBYT); LMI(AC) RRM 506 022H: LDI(AC) FF1 K00FF LBYT: JMP(DBIA); 507 023H: RBYT: LTM(AC) KOOFF; 508 020H: DBIA: SDR(A) JZR(FETCH): 509 510 017H: SBYR: ALR(R8); 511 016H: SBYA: LMI(AC); /\* LOAD MAR FOR LATER USE \*/ 512 018H: ILR(A); 019H: TZR(AC) KOOFF RRM 513 JCF(STLB,STRB); 514 0164: STRB: LTM(T) KFF00; 515 01DH: SRB1: ALR(T) RWM JZR(FETCH); 516 517 014H: STLB: LIM(I) KOOFF; 518 01CH: LDI(AC) FF1 CNB JMP(SRB1); 519 520 /\* ROTATE GROUP RUTATE A WITH C--ROTATE A AND X WITH C--SHIFT A, X RIGHT, FILL 521 522 WITH SIGN--SHIFT A LEFT, FILL WITH ZEROES 523 524 AT ENTRY, Z FLAG IS ZERO IF D=0. DUE TO PIPELINED OPERATION, IT IS 525 THIS CONDITION THAT IS TESTED BY THE FIRST JZF \*/ 526 527 OCDH: RSGP: TZR(W) STZ K8000 INH JZF(SZDS, SNZD); 528 0944: SZDS: ILR(X); 529 099H: SDR(R9) FF0 K007F JLL(RACI, RAXI, SAXI, SLZI); 530 09BH: SNZD: DSM(R9) JLL(RACI, RAXI, SAXI, SLZI); 531 532 094H: RACI: ILR(A) JMP(RUNR): 095H: 533 RAXI: ILR(X); 534 098H: SDR(T) JMP(RACI); 535 0964: SAXI: TZR(A) STZ K8000 INH JMP(RAXI); 097H: SLZI: 536 ILR(A) JMP(RUNR); 537 /\* MAIN ROTATION LOOP \*/ 538 539 540 093H: RUNR: DSM(R9) STC JLL(RACR, RAXR, SAXR, SLZR); 541 542 0A4H: RACR: JFL(RSEX.RUNR); SRA(AC) FFZ STZ 0A5H: 543 RAXR: SRA(AC) FFZ SIZ; 544 OAOH: SRA(T) FFZ STZ JCF(RSEX,RUNR); 545 0A6H: SAXR: SRA(AC) FFZ STC; 546 0A1H: SRA(T) FFC JCF(RSEX,RUNR); 547 0A7H: SLZR: ADR(AC) STZ JFL(RSEX,RUNR); 548 549 092H: JLL(RACF, RAXF, SAXF, SLZF); RSEX: SUR(A) 550 551 0B4H: RACF: TZR(W) K7FFF JZF(SNCF,SSCF);

RECORD

JZR(FETCH): 552 OA2H: SNCF: NO.UP SSCF: LMI(W) K8000 JZR(FETCH); 553 UA3H: 0858: RAXF: ILR(T): 554 555 **OBOH:** RXF1: SDR(X) JMP(RACF); SAXF: TLR(T) JMP(RXF1); 0868: 556 TZR(w) K7FFF JZF(SNCF,SSCF); 557 vB7H: SLZF: 558 /\* SPECIAL CALL AND JUMP GROUP--CURRENTLY CONTAINS ONLY THE 559 CALL TO (D) AND PUSH W, B, E, P--ALL 4 UPCODES DO THE SAME THING \*/ 560 561 OCEH: SCJG: LMI(R9) RRM; 562 04EH: ACM(AC); 503 564 04CH: SDR(R9) IMP(CPSS): 565 /\* INCREMENT AND SKIP GROUP--AGAIN 4 UPCUDES ARE USED FOR ONE 566 567 INSTRUCTION--LOCATION AT 8+D IS INCREMENTED \*/ 568 569 OCFH: ISJG: ALR(R9); LMI(R9) RMW: 009H: 570 571 0D9H: ACM(AC) FF1; JFL(NOSK, SKIP): 0A9H: NO.OP RWM 572 JZR(FETCH); 573 OCAH: NOSK: NU.OP 574 OCBH: SKIP: LMI(P) FF1 JZR(FETCH); 575 576 /\* INPUT AND OUTPUT--CURRENT VERSION DOES NOT DECODE INTO SUBGROUPS--ALSO ROW ZERU IS USED TO SAVE CODE \*/ 577 578 LM1(R9) RIN; 579 0888: IND: 008H: IND1: ACM(AC); 580 0288: SDR(A) JZR(FFTCH): 581 089H: INX: LMI(X) RIN JMP(IND1); 582 08AH: OTD: 583 LMI(R9): 584 006H: OTD1: ILR(A) ROT JZR(FETCH); OTX: LMI(X) JMP(OTD1); 585 08881 586 /\* INTERRUPT--UTILIZES CALL ROUTINES FOR REGISTER SAVING 587 1/O DEVICE #0 REPRESENTS EXTERNAL INTERRUPT STRUCTURE 588 START BY PUSHING OLD VALUE OF STATUS \*/ 589 590 591 OFFH: INTER: DSM(S); 592 OBFH: ILR(W); 593 05FH: LMI(S) RWM; 594 595 /\* READ INTERRUPTING LEVEL FROM EXTERNAL STRUCTURE \*/ 596 597 0588: CLR(T): 598 059H: LMI(T) RIN; LTM(AC) KOOFF ROT; /\* NOTE LEVEL REWRITTEN \*/ 069H: 599 600 /\* STORE PRIORITY IN W - SET C FLAG FOR PROPER LOADING OF REGISTERS \*/ 601 602 06CH: SDR(W) STC; 603 604 /\* INTERRUPT ROUTINE STARTING ADDRESS IS COMPUTED IN R9 \*/ 605 606 LMI(W) RRM: 607 06DH: 608 06FH: ACM(AC); 609 OAFH: SDR(R9) JMP(CPG2); 610 611 EOF 612 NO PROGRAM ERRORS

END OF PROGRAM
MICROPRUGRAM MEMORY IMAGE

|             | 0н               | 1H             | 2H               | 3н                   | 4H                   | 58           | 6н               | 7H                 | 8H               | 98               | AH                    | вн                   | СН               | DH               | EH               | FH               | _ |
|-------------|------------------|----------------|------------------|----------------------|----------------------|--------------|------------------|--------------------|------------------|------------------|-----------------------|----------------------|------------------|------------------|------------------|------------------|---|
|             | JCC<br>0090н     | JFL<br>0072H   | * JZR<br>* 000FH | * JZR<br>* U00FH     | * JFL<br>* 0062H     | JFL<br>0002H | JZR<br>000FH     | JFL =<br>. 0042H = | JCC<br>0028H     | JRL<br>007CH     | * JCF<br>* 006AH      | JCC<br>004BH         | JCC<br>OOFCH     | JCC<br>00BDH     | JCC<br>001EH     | JCC<br>001FH     | : |
|             | 67<br>U          | 296            | * 316<br>* 4     | * 317<br>* 4         | * 319<br>* 3         | 314<br>3     | . 584<br>. 2     | 302<br>1           | 580<br>2         | 190<br>1         | * 183<br>* 1          | 335<br>4             | 92<br>1          | 394<br>2         | 463              | 100<br>38        | • |
| •           | JLL .<br>0024H . | JCC<br>0041H   | * JCP<br>* U010H | ≠ JLL<br>≠ υ024H     | * JCF<br>* 0022H     | JCR<br>0014H | JCR<br>0018H     | JCR =              | JCR<br>0019h     | JCF<br>001AH     | * JCR<br>* 001CH      | JCR<br>001DH         | JCR<br>001DH     | JZR<br>000Fh     | JCC .<br>009EH   | JCC .            |   |
|             | 361              | 74<br>1        | * 360<br>* 1     | * 366<br>* 1         | * 505<br>* 2         | 504<br>1     | 511<br>2         | 510<br>1           | 512<br>1         | 513<br>1         | * 517<br>* 1          | 514<br>1             | 518<br>1         | 515<br>2         | 464              | 104              | • |
| •           | J2R .<br>000FH . | JCC<br>0011H   | * JCR<br>* 0020h | * JCR<br>* 0020H     | JCF<br>0062H         | JCF<br>0002H | JFL<br>0062H     | JFL =<br>0002H =   | JZR<br>000FH     | JZK<br>000FH     | * JCR<br>* 002BH      | JCR<br>0029H         |                  | JCR<br>002FH     | JLL .<br>0014H   | JCC<br>004FH     | : |
|             | 508 .<br>2       | 73             | * 506<br>* 1     | * 507<br>* 1         | * 370<br>* 3         | 371<br>3     | 372<br>3         | 373<br>3           | 581<br>1         | 477<br>1         | * 472<br>* 1          | 476<br>1             |                  | 459              | 502<br>1         | 460<br>1         | : |
| -<br>•<br>• | JZK .<br>JUUFH . | JZR<br>0005H   | * JZR<br>* 0004H | * JZR<br>* 000вн     | ¥ JZ⊮<br>≭ 0005H     | JZR<br>0004H | JZR<br>0005H     | JZR =              | JZR<br>0007H     | JZR<br>0001H     | * JZR<br>* 0004H      | - JCC<br>000вн       | JCC<br>005CH     | . JCC<br>. 004DH | JCC<br>006EH     | JZR<br>000BH     | • |
|             | 286              | 290 -<br>2 -   | * 291<br>* 2     | * 328<br>* 22        | * 292<br>* 2         | 293<br>2     | 309<br>2         | 329<br>2           | 301<br>2         | 295<br>2         | * 310<br>* 2          | 330<br>2             | ⊧ 380<br>⊧ 3     | 411              | 406<br>2         | 331<br>2         |   |
| 0044        | JCC .<br>0070н . | )<br>ОО44Н     | ♦ JFL<br>● 0002H | + JZR +<br>+ UOVFH + | ♥ JCC<br>♥ 00F4H     | JCC<br>0085H | JCC<br>0056H     | . JCR =            | JZR<br>000CH     | JCR<br>0048H     | * JCR<br>* 0049H      | UCC<br>005ВН         | JCC<br>003CH     | JCR<br>0040H     | JCR<br>004CH     | JZR .<br>000EH . | • |
| ••••        | 413              | 75<br>1        | * 304<br>* 1     | * 305<br>* 1         | * 79<br>* 1          | 208<br>1     | 195<br>1         | 207                | = 87<br>= 1      | 86<br>1          | * 85<br>* 1           | * 336 *<br>* 1 *     | 564<br>1         | 412              | . 563<br>. 1     | 462<br>1         |   |
|             | JCC .<br>0060н . | JFL<br>0052H   | * JFL<br>* 0012H | ♥ JLL<br>♥ 0024H     | ♥ JRL<br>♥ 007CH     | JZR<br>000AH | JCR<br>0055H     | . JCC =            | = JCR<br>= 0059н | . JCC<br>. 0069Н | * JCR<br>* 0051H      | * JCR *<br>* 005AH * | JCR<br>005DH     | JCC<br>00ADH     | . JCR<br>. 0056H | JCR<br>0058H     | • |
|             | 280              | 346            | * 356<br>* 1     | * 351<br>* 1 *       | 177                  | 182<br>2     | 201<br>2         | 206                | 597<br>1         | 598<br>1         | * 341<br>* 1<br>*     | * 337<br>* 1 *       | 381<br>1         | 382              | 217              | 593<br>1         | : |
| 0064        | . JPR<br>0030н   | . JPR<br>0030н | ■ JZR<br>■ 000FH | - JZR<br>- UJOFH -   | ■ JZR .<br>■ 000FH . | JZR<br>000Fh | . JCC<br>. 00F6н | JCR =              | JCC<br>00F8H     | JCR<br>006CH     | * JZR<br>* 0009H      | ♥ JRL ♥<br>♥ 007CH ♥ | JCR<br>006DH     | JCR<br>006FH     | JZR<br>000DH     | JCC<br>00AFH     | • |
| ••••        | 281              | 272            | 321              | 322                  | 236                  | 237          | 238<br>1         | 242                | 243              | 599<br>1         | * 189<br>* 1 *        | 184<br>1 1 1         | 603<br>1         | 607<br>1         | 407              | 608<br>1         |   |
| 007         | JCC .<br>OOFOH . | JCC 0061H      | * JFL<br>* 0062H | ■ JZR =              | * JZR<br>* 000FH     | JZR<br>000FH | JCR<br>0078H     | JCR =              | JCC<br>00A8H     | JCC<br>00F9H     | * JCR<br>* 007BH<br>* | * JCC<br>* 00EBH     | ■ JCC<br>■ 009CH | . JCC<br>. 009DH | . JLL<br>. 0064H | . JLL<br>. 0074H | : |
| •           | 415              | 271<br>1       | * 298<br>* 1     | 299                  | 250<br>1             | 251<br>1     | 255<br>1         | . 262<br>. 1       | 256<br>1         | 263              | * 306<br>* 1          | * 308 *              | 224              | . 229<br>. 3     | . 234<br>. 3     | . 248<br>. 3     | • |

MICROPROGRAM MEMORY IMAGE

|           | 0Н           | 1H               | 2H                   | 3н                | 4H                      | 5H                | 6н                   | 7H                   | вн                | 9н           | AH                                         | вн               | СН                | DH               | EH                 | FH                   |
|-----------|--------------|------------------|----------------------|-------------------|-------------------------|-------------------|----------------------|----------------------|-------------------|--------------|--------------------------------------------|------------------|-------------------|------------------|--------------------|----------------------|
|           | JZR<br>000Fh | JCC 4<br>0071H   | JCC<br>Ove2h         | JZF<br>UOB2H      | JCC<br>0054H            | JCC<br>0055н      | JCC<br>0046н         | JCC =<br>0057H =     | JCC<br>0008н      | JZR<br>0008H | • JZR<br>• 0006H                           | JZR<br>0006H     | JLL<br>00C4H      | JRL<br>. OOCCH   | . JCC<br>. 005EH   | . JZR .<br>. 000FH . |
| 008H      | 115          | 270              | 277                  | 121               | 176                     | 181               | 194                  | 205 =<br>1 =         | = 579<br>= 1      | 582<br>1     | * 583 *<br>* 1 *                           | 1 505 1<br>1 1   | ⊧<br>• 423<br>⊧ 1 | . 493<br>. 1     | . 212<br>. 1       | . 116 .              |
| -         | JCR          | JCC              | JLL                  |                   | JCR                     | JCR               | JCR                  | JCR                  | =                 | JLL          | * JCR                                      | JLL              | JLL               | JLL              | JCC                | . JPX .              |
| 009H      | 68<br>68     | 69 ×             | 549                  | 540               | 532                     | 533               | 535                  | 536 -                | = 0094H<br>= 534  | 529          | * 0099H<br>* 528 *                         | 530              | 225               | . 230            | . 466              | . 0080H .            |
| :         | 1<br>        |                  | 4 4<br>              | 6 - 6 - 1<br>     | * 3.<br>*<br>* JFL .    | 3 .<br>JCB        | JCR                  | JFL                  |                   | JFL          | * 1 *<br>**                                | 1 1<br>          | F 1 .<br>F        |                  |                    | . 1.<br>. JCB.       |
| 00AH      | 0092H        | 0092H            | 000FH                | 000FH             | 0092H                   | HOADU             | 00A1H                | 0092H =              | = 0088H           | 00CAH        | * 007AH                                    | 00AEH            | OOABH             | . 00AAH          | . 002EH            | OUADH .              |
| :         | 544<br>1<br> | . 546 ·          | • 552 ·              | 2                 | • 542<br>• 1            | 1                 | . 545                | 1 =                  | = 1               |              | * 385 *<br>* 1 *                           | * 500 *<br>* 1 * | + 499<br>+ 1<br>+ | . 2              | • 1<br>• • • •     | . 009.<br>. 1.       |
| 00BH      | JCP<br>0084H | JRL ·            | • JCR •<br>• 00B1H • | JRL<br>00ECH      | * JZF<br>* 00A2H .<br>* | JCR<br>00B0H      | . JCR .<br>. 00ВОН . | JZF =<br>00A2H =     | = JZR<br>= 000FH  | JCR<br>00BAH | * JZR<br>* 000FH<br>*                      | JCR<br>00BEH     | JCC<br>00ACH      | . JCF<br>. OOBAH | . JCF<br>. 0089H   | JCC .<br>005FH .     |
|           | 555<br>2     | 126              | 125                  | 130               | • 551<br>• 2            | 554<br>1          | 556<br>1             | 557 =                | = 258<br>= 1      | 402<br>1     | * 404<br>* 3                               | 400<br>2         | 498               | . 398<br>. 1     | 401                | 592.<br>1.           |
| •         | JCR<br>00C1H | . JCE<br>. 00E1H | JZR<br>GOOFH         | JZR<br>000FH      | # JCR<br># 00C0H        | JCE<br>00F5H      | JZR<br>OUOFH         | JCR =<br>00C8H =     | = JRL<br>= 00DCH  | JCC<br>00D9H | * JZR<br>* 000FH                           | JZR<br>UOOFH     | JCC<br>00BCH      | JZF<br>009AH     | JCC<br>004EH       | . JCR .<br>00С9н .   |
|           | 428<br>1     | 429              | * 148<br>* 1         | * 149<br>* 1      | + 427<br>+ 1            | 434               | 439                  | 447                  | -<br>= 448<br>= 1 | 570<br>1     | * 573<br>* 1                               | 574<br>1         | 497               | 527<br>1         | 562<br>1           | 569<br>1             |
| •         | О030H        | . JZR<br>. 000FH | * JZR<br>* 000DH     | JCR<br>00D8H      | * JZR<br>* 000FH        | JZR<br>000FH      | JCR<br>OUD1H         | ЈСС<br>00F7H         | = JCC<br>= 00E8H  | ЈСС<br>00А9Н | * JZR<br>* 000FH                           | JCR<br>00DDH     | JCR<br>00D3H      | JCC<br>002DH     | JCR<br>00DCH       | JCR .<br>Oudoh .     |
| 00DH<br>• | 484<br>1     | . 156            | * 393<br>* 1         | • 451<br>• 1      | *<br>* 153<br>* 2       | . 154<br>. 2      | 155<br>2             | 146                  | = 452<br>= 1      | 571<br>1     | * 479<br>* 1                               | 456              | 450               | 458              | 481                | 483                  |
| -         | JCC<br>0050н | . JZR<br>. 000FH | * JCR<br>* 00E0H     | * JCR<br>* 00EAH  | * ·<br>* JZR<br>* 000FH | JZR<br>000FH      | JCC .<br>00F6H       | JCC<br>00F7H         | = JCR<br>= 00E9H  | JCF<br>00DAH | * JCC <sup>2</sup><br>* 002AH <sup>2</sup> | JCC 4<br>00FBH 4 | JLL<br>00D4H      | . JLL<br>. 00E4H | JZR<br>. 000FH     | JZR .<br>000FH .     |
| OVEH      | 279<br>1     | . 430<br>. 1     | *<br>* 278<br>* 1    | *<br>* 470<br>* 1 | *<br>* 160<br>* 2       | . 161<br>. 3      | 166                  | 171                  | =<br>= 454<br>= 1 | 455          | * 471 *<br>* 471 *                         | 389<br>1         | 134<br>2          | 135              | . 140              | 141                  |
| -         | JCR<br>00F1H | - JZR<br>. UDOFH | * JCC<br>* 00D2H     | * JCC<br>* 00E3H  | *<br>* JCR<br>* 00FAH   | JCC               | JZR .                | JFL :                | JCR<br>00F7H      | JCR<br>00F7H | *<br>* JCC *<br>* 004AH *                  | JCR 4            | JCF .             | • • • •          | JCR .              | JCC .                |
| 00FH      | 416          | 417              | *<br>* 392           | *<br>* 468        | * 80                    | 435               | 167                  | 147                  | = 244             | 264          | * 91                                       | 390              | 93                | •                | 467                | 591                  |
| ====      | 1            | . 1              | + 1 :<br>*======     | + 1<br>#======    | * 1<br>*========        | . 1<br>========== | . 2.<br>========     | . 4 :<br>::::::::::: | = 1               | . 1          | + 1 4<br>*=======                          | • 1 •            | 1                 |                  | . 1 .<br>========= | . 0.                 |

# **CPU Design**

# APPENDIX C CENTRAL PROCESSOR SCHEMATICS



ORDERING AND ORDERING INFORMATION PACKAGING INFORMATION

### **ORDERING INFORMATION**

Standard Package Type

| Component            | No. Of Pins | Ceramic (C) | CerDIP (D) | Plastic (P) |
|----------------------|-------------|-------------|------------|-------------|
| 3001<br>MC3001       | 40          | Yes         | Yes<br>Yes |             |
| 3002<br>MC3002       | 28          | Yes         | Yes<br>Yes |             |
| 3003<br>MC3003       | 28          | Yes         | Yes<br>Yes |             |
| 3212<br>MD3212       | 24          |             | Yes<br>Yes | Yes         |
| 3214<br>MD3214       | 24          | Yes         | Yes<br>Yes | Yes         |
| 3216/26<br>MD3216/26 | 16          |             | Yes<br>Yes | Yes         |

## **PACKAGE OUTLINES**



24-LEAD CerDIP DUAL IN-LINE PACKAGE (D)





#### 40-LEAD CERAMIC DUAL IN-LINE PACKAGE (C)



#### 40-LEAD CerDIP DUAL IN-LINE PACKAGE (D)



# intel

INTEL CORPORATION, 3065 Bowers Avenue, Santa Clara, California 95051 (408) 246-7501

Printed in U.S.A. MCS 048-0276/10K