

# Macrodata Corporation <br> 21135 Erwin Street <br> Woodland Hills, California 91365 

STUDY OF LIMITATIONS AND ATTRIBUTES

OF MICROPROCESSOR TESTING TECHNIQUES

March 17, 1977

Final Report - NASA Contract NAS8-31954

Prepared By:

Richard McCaskill
Wayne E. Sohl

Prepared For:

George C. Marshall Space Flight Center Marshall Space Flight Center, Alabama 35812

PAGE
I. GENERAL TEST PHILOSOPHY ..... 1
II. BASIC BLOCK DIAGRAM ..... 19
III. MODULAR APPROACH ..... 26
IV. DESCRIPTIONS OF MODULAR TEST APPROACH ..... 27
V. PROCESSOR TEST DESCRIPTIONS ..... 30
A. 8080 ..... 30
B. 8008 ..... 80
C. 2901 ..... 87
D. 6800 ..... 102
E. 1802 ..... 121
VI. DC TEST REQUIREMENTS ..... 139
VII. SURVEY SUMMARY ..... 140
A. LIST OF COMPANIES ..... 140
B. SURVEY QUESTIONNAIRE ..... 141
C. QUESTIONNAIRE RESPONSES ..... 145
VIII. DETECTED PROBLEMS ..... 185
IX. TEST EQUIPMENT ..... 189
x. QUALIFICATION TEST VERSUS SCREENING TESTS ..... 197
ATTACHMENT I ..... 199

## FIGURES

Page

1. Basic MPU Block Diagram ..... 3
2. 2901 Architecture ..... 6
3. 2901 Test Flow Diagram ..... 8
4. 8080 Architecture ..... 10
5. Comparison Test ..... 13
6. Stored Pattern Test ..... 14
7. 8080 Block Diagram ..... 20
8. 8008 Block Diagram ..... 21
9. 2901 Block Diagram ..... 24
10. 6800 Block Diagram ..... 24
11. 1802 Block Diagram ..... 25
12. Program Counter Test ..... 70
13. Register Array Test ..... 74
14. Stack Pointer Test ..... 76
15. Accumulator Test ..... 78
16. Arithmetic Logic Unit Test ..... 79
17. GALPAT Read Example ..... 94
18. 1802--0R Data Pattern ..... 128
19. 1802--Exclusive OR Data Pattern ..... 129
20. 1803--AND Data Pattern ..... 130
21. Basic Tester Block Diagram ..... 193TABLES
22. Recommended 8080 Instruction Sequence ..... 33
23. Register Array Test ..... 72
24. 8080 Instruction Mnemonics ..... 73
25. Stack Pointer Test Instruction ..... 77
26. ALU Source ..... 89
27. ALU Function Control ..... 90
28. ALU Destination Control ..... 91
29. ALU Source Operands ..... 99
30. ALU Function Sequence ..... 100
31. Stack Pointer Load Routine ..... 106
32. Index Register Load Routine ..... 109
33. Accumulator Load Routine ..... 114

The problems of testing microprocessors has been elevated past the conventional methods of testing integrated circuits. Just the fact that the microprocessor is not a simple collection of gates in a random format or a well ordered structure, like that of a large scale memory, does not lend itself to conventional means of testing. What is meant by the conventional means of testing is the commonly used DC test checking for inputs and output voltages and currents. This DC testing cannot prove that the microprocessor is operational, because there are from four to six or more levels of logic between the input and output pins. Also the conventional way to test random logic by applying a string of input patterns in a burst will only check for steady-state faults stuck at logic 1 or stuck at logic 0 , and will not check for any instruction or data sensitivity.

There presently are many ways that both manufacturers and users are performing testing of microprocessors. These include methods such as selftesting, comparison testing, stored pattern testing, and algorithmic-aided pattern testing.

## First Step in Testing

The first item to be considered when testing a microprocessor is to understand the operation and architecture structure of the microprocessor. The operation of the microprocessor is controlled by the execution of an
instruction set unique to each microprocessor. There is a great variety of microprocessors on the market today, ranging from 2- and 4-bit slices to 4-, 8-, and 16-bit complete microprocessor units. But of all the product types, 4-bit slices, like the 2901, and 8-bit microprocessors, like the 8080, have gained the widest acceptance and therefore are good examples to use in describing testing techniques.

In general, a microprocessor has two internal buses: an 8-bit bidirectional data bus, and a l6-bit unidirectional address bus (Figure 1). The data bus carries both the instruction code and data. Instructions are decoded and executed in connection with the appropriate controls in which data going to both the arithmetic logic unit and accumulator can be manipulated by special arithmetic or logical operations. The address bus links the main memory where both instruction codes and data are stored. Stack pointers, program counters, and register files also supply information to the address. Finally, there is an instruction decoder which interprets each instruction and controls all operations of the microprocessor.

Since a microprocessor is a complex sequential logic structure and not simply a few gates or an LSI memory, a true and meaningful test requires the understanding of the hardware architecture and software functionality rather than only the simple logic of the elemental structures.

The hardware architecture is the internal organization with consists of an ordered set of modules, such as the register stack, accumulator, arithmetic logic unit, etc. Software functionality is a set of ordered


FIGURE 1: Basic MPU Block Diagram
microinstructions which can be used to monitor the operation of these modules.

Upon developing complete knowledge of the microprocessor unit through both areas, one can develop an ordered set of test sequences in the microprocessor's instruction set for testing each module one by one until a complete test has been developed.

In general, a microprocessor has two buses: $a n$ address bus and a data bus. The address bus performs two functions, addressing the external memory and/or addressing the internal scratch pad memory. The data bus also performs two functions, supplying input data to the processor and outputting processed data. The data bus links the internal functions of the scratch pad memory, registers, arithmetic logic unit, etc., together.

Modular Breakup

The next step in microprocessor testing is to partition the device into modules, with some modules possibly overlapping. The selection of each module should be accessible from the input/output bus..by the execution of microinstructions. In other words, data should be able to be applied to the device input and propagated to the output directly or indirectly by the use of the microprocessor instruction set. The test then shall be generated for each module of the MPU so that a worst case test pattern will be run on that module. For instance, if the module in question is a RAM, a galloping 1 's and 0 's test pattern is used as this type of pattern is
considered to be worst case.

From the standpoint of software functionality, a set of MPU instructions should be executed when testing the first module. Proceeding toward the second module another set of new microprocessor instructions will be executed. (Some of these instructions may have been executed previously.) This process will then continue until all of the instructions within the instruction set are used while testing each module. Then a final test should execute all instructions to verify that all modules are working toge ther.

Two-fold diagnostic information is provided by this technique. First, from a hardware point of view if a failure occurs, the faulty module is pinpointed. Inherent in this type of modular procedure is the fact that convenient breakpoints exist in a module-by-module basis. Second, in conjunction with each module, a set of microinstructions are executed; if any fault occurs, the specific instruction(s) can be isolated and identified.

## Architecture and Test Flow

The architecture of the 2901 lends itself to the modular approach because of its own hardware and microinstruction architecture. Figure 2 illustrates the block diagram of the 2901. In examining this diagram, one will notice that the device can be divided into the following modules: RAM, Q register, arithmetic logic unit (ALU), ALU source decode multiplexer, RAM


FIGURE 2: 2901 Architecture
and $Q$ register right/left shift logic.

Once the information has been acquired on the module breakdown, a test flow can be generated. Since the 2901 has an ALU section, the first areas to be tested should be those areas which supply data to the ALU. The most logical of these is in the RAM module and then in the $Q$ register module. Once these modules have been tested, they can be used as reliable data sources for the ALU module test.

A typical test flow for the 2901 would start with the RAM memory, followed by the $Q$ register, ALU source decode multiplexer, ALU, and finally, the RAM and $Q$ register right/left shift logic (Figure 3). During this test flow, all microinstructions for the 2901 will be used.

## Test Technique

Formulating a test plan will differ between the manufacturer and user. The reason for this being that the manufacturer has access to the logic diagrams of the device, which the user in most cases cannot obtain, and their quantities are in larger amounts than the user's. Therefore, more elaborate tests can be developed which optimizes test performance and test time. The user has an advantage over the manufacturer because his test, in its simplest form, can be tailored to his specific needs, but the manufacturers' test has to guarantee all operations of the microprocessor. Not receiving schematics, logic diagrams, or other circuit information the user must therefore rely on either vendor supplied test programs or perform

| TEST FLOW CHART | FUNCTIONAL TEST DESCRIPTION | TEST PATTERN |
| :---: | :---: | :---: |
| RAM Test | A galloping " 1 " and " 0 " pattern is applied to the RAM in three combinations. <br> 1. The RAM addressed by the " $A$ " address and tested through the "Y" output port directly. <br> 2. The RAM addressed by the "A" address and tested through the ALU. ALU is held at a fixed instruction. <br> 3. The RAM addressed by the " $B$ " address and tested through the ALU. ALU is held at a fixed instruction. | Approx. $3000$ |
|  | A number 15 is loaded into the register and then read. Next, a number " 0 " is loaded and read. This is followed by a $14,1,13,2$, etc. until a " 0 " then a 15 is loaded. | $\begin{gathered} \text { App rox. } \\ 100 \end{gathered}$ |
| ALU Source Decode | The ALU Source Decodes are tested to see if all decodes are possible. The test is performed by loading values into the RAM and " $Q$ " register and selecting all decodes while testing for any interaction between bits or selections. | Approx. 50 |
| ALU | A series of numbers are loaded into the RAM and "A" register. These numbers are then used as inputs to the ALU. At the same time, all outputs and flags from the ALU are monitored, while incrementing operations the ALU can perform. | $\begin{aligned} & \text { Approx. } \\ & 1000 \end{aligned}$ |
| RAM and "Q" Register Right/Left Shift Mux. | All numbers from 0 to 15 are shifted through the RAM and "Q" register. While the RAM section is being tested, all locations are tested. After each shift, all possible number combinations are outputted to the output latch without clocking the latch, to see if there is any latch sensitivity. | Approx. $8200$ |

FIGURE 3: 2901 Test Flow Diagram
extensive characterization to generate worst case test patterns. This characterization is needed to guarantee full operation of the microprocessor for a variety of applications in which the device is used.

## The Optimum Test

At first glance of the 8080 MPU block diagram (Figure 4), the complexity of the device is not readily indicated. This is because there are only eight data input lines. However, in addition to accepting data from the input bus, the MPU can accept data from internal registers and accumulators. If the MPU could only perform one instruction, a test could be developed without much difficulty, but the MPU is capable of executing many instructions in sequence. Because of this, the number of combinations of instructions and data patterns that the MPU can perform would be extremely long.

A commonly used formula for calculating the total test time to exhaustively test an MPU is $C=2^{M N}$. Where $C$ is the number of combinations of instructions and data patterns, $M$ is the number of data bits in each word, and $N$ is the number of instructions the MPU is capable of executing.

For example, an 8-bit MPU that only has ten instructions would require $2^{80}$ test cycles for an exhaustive test of all possible combinations. Assuming a test cycle of 1 us, the MPU would take approximately 38 years to check all combinations of instructions and data patterns.


FIGURE 4: 8080 Architecture

The 8080 MPU can perform approximately 76 different instructions. Using the above formula, there would be a total of $2^{608}$ possible combinations that could be performed. Obviously, this is an astonishing number to exhaustively test the 8080 .

## Test Techniques

Once realizing that the optimum test cannot be created, one looks for other means to test the MPU. The first approach considered is called selftest. The self-test is the simplest and cheapest means of determining if an MPU is working. Self-test, or in-circuit test, is the technique in which the device is placed in the circuit where it will be used and tested for correct operation. This is utilized by some users who feel the cost of incoming inspection cannot be justified. Therefore, they will typically test the device using several different system operations. The advantage of this testing is that the actual operation of the device is tested in its circuit, eliminating the requirement for a separate costly test system. The disadvantages of this technique is that any of the in-circuit condition changes, like voltage fluctations, temperature, timing, and instruction changes, may not be detected until the unit is in the field. The rework cost of finding and removing a faulty device must be considered before this method of testing is selected. Typical costs for finding and replacing a gate is as follows:
$\$ 3.00$ to $\$ 5.00$ : Board Level
$\$ 30.00$ to $\$ 50.00$ : System Level
$\$ 300.00$ or Move: In Field

Since an MPU is more complex than a gate, the above cost would be multiplied by the complexity factor of the MPU.

The second method of testing is called comparison testing. Comparison testing is the method in which a known good device is compared to the device under test. The hardware required for this type of test is very simple, requiring only a pseudo number generator connected to all inputs and all outputs from the known good device and comparing the device under test (Figure 5). If exact comparison does not occur, the device under test is considered bad. The advantages of this method is that the test system is inexpensive to develop and with a little more hardware added, voltage and timing conditions can be created. Also, if the device is operated for a few minutes, most paths through the device will be checked. Like any test method, it has its disadvantages also. The biggest disadvantage is that this method requires a known good device, which is a problem in itself. Some MPU's have illegal instructions, therefore, no guarantees can be made for the data coming out of the device. Also, critical timing into the device may not be able to be maintained if pseudo numbers are applied to the input of the MPU. Last of all, if the device fails, no failure information can be obtained to determine the cause.

The next method of testing is the stored pattern method which utilizes a known good pattern stored in some form of data memory. This pattern is then applied to the device under test in a burst mode and the device outputs compared to the stored response (Figure 6). There are two means of generating patterns using this method. The first method is to input a test pattern into a known good device and record all input stimuli and output data.


FIGURE 5: Comparison Test


FIGURE 6: Stored Pattern Test

The input patterns would be created from some known application.

The second method of generating the stored pattern would be to develop a software or hardware simulator for the device to be tested. A known instruction sequence would then be stored and used to compare with the device under test. The advantage of this technique is that the user's instruction sequence can be completely tested and that sensitive data paths can be checked with ease. Since the tester that is required to perform this type of test usually incorporates variable voltage and timing circuits, these parameters can also be checked. The main disadvantage of using a known good device for generating the test pattern is a "known good device." What test is available to determine what is a known good device? The disadvantage of the stimulator approach is that a software or hardware similator is required. Since the schematic and logic diagrams for each MPU are not readily available from the vendor, it is difficult for a user to develop the simulator. Even if these could be obtained, it would take a knowledgeable programmer three to six months, at least, to develop the software. Other disadvantages to this method are:

LARGE, EXPENSIVE MEMORY. High-speed random access memories or shift registers become quite expensive when any great amount of memory is needed. In testing the program counter for the 8080, for example, 262,000 distinct patterns are required. A memory test on the register array of an 8080 takes approximately 50,000 patterns. The cost of memory can quickly become a major part of the total cost of the test system.

LONG TRANSFER TIME. The overhead time required to transfer a long pattern from disc, core, or other mass memory to high-speed RAM can make a large dent in the throughput rate of the test system. If transferring a 1,024 -bit pattern from disc to RAM takes 50 milliseconds, a typical figure, transferring the test pattern from the program counter takes 13.1 seconds of overhead time, in addition, to the test execution time ( $262 \times 50 \times 10^{-3}$ Seconds).

INFLEXIBLE PROGRAM. The stored program cannot easily be modified while tests are in progress. This rigidity makes it difficult to perform special or unusual tests on a single unit. A substantial amount of off-line software support is needed if such tests are to be accomplished.

The algorithmic test method utilizes a high-speed programmable pattern generator in conjunction with a local buffer memory. The contents of the buffer memory is a test pattern consisting of microprocessor instruction sequences and either full or partial data input and output response patterns. The buffer memory pattern is then applied to the microprocessor under program control of the pattern generator. A distinct advantage of this test method offered by the use of a programmable pattern generator is the ability to choose how the test pattern is applied to the device under test. This will in turn determine whether the stored data pattern and output response of the microprocessor is full or partial.

The first option is to apply the test pattern in a burst mode as in the previously defined stored response approach. In this case, the device data pattern and output response stored in the buffer memory is complete, with the pattern generator acting as a counter to advance the test pattern vectors.

In the second mode, special algorithms are written for the pattern generator which simulate the microprocessor instruction execution. These special algorithms input microprocessor instruction codes and data patterns at the proper point in the instruction cycle, and compare the device output accordingly. However, the device data pattern and output response may be partially stored in the buffer memory and partially generated in real time by the pattern generator algorithms. The effect is to enhance the MPU test program by allowing a significant increase in the number of test patterns used, enable additional tests to be performed that would be difficult, if possible at all by any of the previous methods, and reduce the total amount of stored test vectors. A disadvantage here is that in addition to the buffer test pattern required, a separate program for the pattern generator may be necessary which increases the complexity of the total effort.

This technique, which eliminates the delay time in transferring patterns to mass memory, is extremely efficient and flexible in generating patterns for logic modules such as binary counters, random access and read only memories, shift registers, as well as microprocessors.

When used in conjunction with the module approach, algorithm pattern generation permits faults to be diagnosed so that the particular module or instruction which caused a failure can be isolated. The disadvantages of this method is that a sophisticated tester is required. The programmer needs to be knowledgeable of both operation of the MPU and the test system itself to develop the program.

The recommended approach to be described is a combination of stored pattern and algorithmic techniques. This approach was selected because of its ease of program development (stored pattern) and its thorough testing ability (algorithmic).

## II. BASIC BLOCK DIAGRAM

As shown in Figure 4, the basic microprocessor unit includes a data and address bus, accumulator, arithmetic logic unit, register files, stack pointer, program counter, and timing controls. In the following figures, Figures 7 through 11, the $8080,8008,2901,6800$, and 1802 , block diagrams are illustrated.

8080

Using the 8080 (Figure 7) as a reference, all other MPU's are structured very similar. Other than their instruction set, they differ as described below.

8008

The 8008 (Figure 8) is very similar in architecture to the 8080. The basic difference is that the 8008 has seven 14-bit stack registers for storage of return addresses as a result of subroutine calls. The 8080 has one l6-bit pointer for controlling an external memory stack allowing more than seven levels of subroutine testing.

2901

The 2901 (Figure 9) differs the most from the 8080. The 2901 is only the process portion of a basic MPU, a 4-bit processor, which lacks any


FIGURE 7: 8080 Block Diagram


FIGURE 8: 8008 Block Diagram


FIGURE 9: 2901 Block Diagram
ordered instruction set. Therefore, the 2901 does not have an instruction decoder. The 2901 does have a register array ( 16 words X 4-bits), an accumulator (4-bits), and an arithmetic logic unit (ALU). The. 2901 does not have a program counter to control from which memory location the next instruction will be fetched. This is controlled by external circuitry. Last of all, the 2901 cannot execute a jump or subroutine call by itself; thus, it also lacks a stack pointer.

6800

The 6800 (Figure 10) is structured similar to the 8080 but does not contain a register array. External RAM is used for all scratch pad operations. Also, the 6800 includes two accumulators as opposed to one provided by the 8080 .

1802

The 1802 (Figure 11) architecture is similar to the 8080 except that the program counter and stack pointer are included as part of the register array. Also, instead of having a 16 -bit address bus it has an 8-bit bus, which multiplexes the address in 8-bit bytes.

EXPANDED BLOCK DIAGRAM


FIGURE 10: 6800 Block Diagram


Figure 11: 1802 Block Diagram

As previously shown, all microprocessor units have a similar architecture from which a basic test philosophy can be adopted. This philosophy is to develop an approach to test each module separately accomplishing the following goals:
A. Verify the functionality of each module within the device using the input/output pins of the device and its instruction set.
B. Test for destructive interaction between functional modules.
C. Verify all timing, status information, and interrupt operations of the device.

## IV. DESCRIPTIONS OF THE MODULAR TEST APPROACH

Since each MPU is structured around a similar architecture, a common test approach can be adopted and applied to each device. Once this approach has been established, further requirements are to implement the approach according to the specific architecture and instruction set of each device. The following is a basic description of a generalized test approach for each module previously described.
A. Program Counter

1. Verify reset state.
2. Verify that the counter can be incremented through its maximum range.
3. Check any possible register transfer to the program counter.
B. Register Arrays
4. Verify that each register can be loaded indiyidually, if possible, and its contents stored to the data bus.
5. Verify register-to-register and register-to-output transfers with all possible number combinations.
6. If the registers can be incremented and/or decremented, verify that they can accomplish this through their complete range.
C. Stack Pointer
7. Verify that the stack pointer (registers) can be loaded.
8. Check to see if stack pointer transfers are valid.
9. Verify increment and decrement operations.
D. Arithmetic Logic Unit
10. Verify ADD operations, with and without carry.
11. Verify a SUBTRACT operation, with and without a borrow.
12. Verify all shift left or shift right operations.
13. Verify rotation of a numerical value, if applicable.
14. Check all logical operations, for example, AND, OR, EOR, etc., when applicable.
E. Accumulator
15. Test to see if it can be loaded and read.
16. Check for any transfer operation that can be performed.
17. Verify that the accumulator can be incremented and decremented.
F. Timing and Control
18. Verify that all control timing occurs at correct reference points, for example, data bus enable, sync signals, write enables, etc.
19. Exercise all control operations on the device to verify operation, for example, WAIT, HOLD, INTERRUPT, etc.
20. Verify any status flags that are produced during an arithmetic operation, such as carries, negative or positive numbers, overflows, etc.
G. Instruction Decodes
21. Verify full operation by execution of the complete instruction set.
22. Verify execution of branch and jump operations.
23. Test for interaction between all modules, and verification of all data paths between modules.

## v. PROCESSOR TEST DESCRIPTIONS

A. 8080

The 8080 is an 8 -bit microprocessor using an $N$-channel silicon gate MOS process. The 8080 can be divided into the following modules based on its functional block diagram (see Figure 7).

## Functional Module Breakup

1. Timing and Control
2. Instruction Decoder
3. Program Counter
4. Register Array
5. Stack Pointer
6. Accumulator
7. Arithmetic Logic Unit (ALU)

Due to the complexity of some tests on the modules, a flow chart of the recommended test will be used to ease the burden of understanding the test.

## Timing and Control Test

The first test on the 8080 is to verify the operation of all timing and control signals. This test was selected first because the basic operation of the MPU requires that timing and control be present.

TEST 1, RESET: Verify that the Hold Acknowledge (HLDA) appears following the rising edge of clock $\emptyset 1$ and that the Data and Address buses go into a tristate condition following the rising edge of clock 02 . Verify that the Interrupt Enable (INTE) is reset. Last, following the removal of the reset, the Program Counter is equal to 0 , which will appear on the address bus. When performing a reset note that the reset signal should be present for at least four clock periods.

TEST 2, TIMING: Execute a NOP instruction following a reset, verify that the SYNC signal occurs within the first clock cycle, that the DBIN signal occurs in the second clock cycle, and finally, that the Program Counter increments and that it is present on the address bus during the fourth clock cycle. Follow this NOP instruction with a Store Accumulator (STA) direct instruction and verify that the Write (WR) goes low during the third clock cycle of that instruction.

TEST 3, HOLD: Present a Hold signal to the 8080 and verify that during T2 time cycle Hold Acknowledge (HLDA) appears and the Address and Data buses go to tristate. Upon removing the Hold signal, verify that HLDA is removed, and the buses are enabled. During the time that the Hold signal is present, the 8080 should be in a Hold operation for the time
that the Hold signal is present.

TEST 4, INT: Execute an Enable Interrupts (INTE) instruction, followed by a few NOP instructions, and present an Interrupt Request (INT) to the 8080 during an NOP instruction cycle. Verify that the Interrupt Enable is present during 11 time of the next instruction. This INTE signal should not go high until Tl time. Upon presenting a reset signal to the 8080 , verify that the INTE signal is removed.

## Instruction Decoder Test

The next test on the 8080 should check the Instruction Decoder. This test is used to verify that the complete device is operational and that it will execute all instructions in the instruction set. This recommended test is designed to test all instructions but not all data patterns. Table 1 is a listing of the recommended instruction sequence.

## Program Counter Test

This test includes a reset, which clears the Program Counter, and $2^{16}$ NOP instructions or any other instruction(s) to verify that the counter will increment through all possible addresses. A flow chart of this test is illustrated in Figure 12. This test will verify that the Program Counter resets and increments. The only operation

```
NOP
    EI * LOCATIONS O-15 ARE FOR THE*
DI * HALT=HOLD-INTERUPT ROIITINF*
EI
LXY SP
(VERIFIES HIGH IMPEDANCE DURING HOLD & HALT)
    SPL=Q? SP=0102
    SPH=01
RST (AT a\38)
PCH(QO) YO (SP-1)
PCL(Q7) T0 (SF-2) SP-2=|10a
EI
HALT
RST (AT ROAA)
    PCH(OO) TO (SPm1)
    PCL(3A) TO (SP-2) SP-2=ИGFE
LXJ B
    C=02
    H=01
LXI D MAIN INSTRUCTION SERUENCE *
    E=A8 * STARTS AT LOCATYON 15 *
    0}=9.
LXI H
    L=2a
    H=10
LXI SP
```

TABLE 1: Recommended Instruction Sequence

```
NOP
    SPL=FE SP=OAFE
    SPH=OD
LDA (B3B2)TOA
    B2
    B
    (QOFF) TO A A=4D
STA A TO (B3E2)
    Q2
    H3
    40 TO FFFF
PQP PSW
    (SP) TO F F=06
    (SP+1) TD A A = 80 S SP+2=010O
PUSH PSN
    A TO (SP-1)
    F.TO(SP-2) SP-?=ロดFE
PUSH B
    B TO (SP-1)
    C.10(SP=2) SP-?=00FC
PUSH D
    D In (SP-1)
    ET0(SP-2) SP-2=@ดFA
PUSH H
    H TO (SP-1)
    L.TO (SP-2) SP-2=GUFB
```

```
NOP
PQP B
        (SP) TO C C=0.4
        (SP+1) TO B B=@2. SP+2=a@FA
PQP O
    (SP) TO E E=10
    (SP+1) TO D D=0日 SP+2=auFC
PUP H
        (SP) TOL L=4Q
        (SP+1) TOH H=2O SP+2=OOFE
MgV M,A
    A TO (HL)
Mnv M,B
    B TO (HL)
MEV M,C
    C TO (HL)
MgV M,D
    1) TO (HL)
MOV M,E
    E TO (HL)
MOV M,H
    HTO (HL)
MOV M,L
    L TO (HL)
XCHG D=2O,H=HB,E = 4O,L=1O
MOV M,D
```

```
NOP
    D TO (HL)
mav m,E
    E TO. (HL)
MUV M,H
    H TO (HL)
MDV M,L
    L TO (HL.)
XTHL
    (SP) TO L L=FE
    (SP+1) TO H H=00
    OLOHTO (SP+1)
    OLDL TO (SP)
MOV M,H
    HTO (HL)
MOV M,L
    L. TO (HI.)
PCHL 
DAD SP HL=HL+SP HL=O!QO
PUSH H
    H T0 (SP-1)
    L.TO (SP-2)
SP-2=ADFC
MBV M,H
    H 10 (HL)
MQV M,L
```

TABLE 1 Continued

```
NOP
    LTG (HL)
```



```
MaV M,H
    H TG (HL)
MQV M,i
    L.TП (HL.)
PAD D HL=HI+DE HL=OAOGO+2O4O=2440
MOV M,H
    HTO (HL)
MOV M,L
    L ra (HL)
DADH HL=HL+HL HL=2440+204G=4880
MAV M,H
    HTG (HL)
MOV M,L
    L TO (HL)
STAX B
    A TO (BC)
STAX D
    A Y(P (DE)
604X 8
    0% TV A FROM (BC)
MOV M,A
    A TG (HL)
LDAX D
```

```
NOP
    FF TO A FROM (DE)
MPV M,A
    A TO (HL)
INXB BC+1=0205
1NYD DE+1=20.A1
INYH HL+I=4881
INX SPSP+1=FD
PUSH H
    (H) TO (SP-1)
    (L) TO (SP-2) SP-2=FA
MOV M,B
    B TG (HL)
MgV M,C
    C TU (HL)
MQV M,D
    D TV (HL.)
MRV M,E
    E TO (HI_)
MOV M,H
    HTA (HL)
MRV M,L
    L. TO (HI.)
DCX B BC-1=02V4
DCX D DE-1=2N4N
DCXH HL-1=4880
```

```
NOP
DCX SP SP-1=FA
PUSH H
    HTO (SP-1)
    L TO (SP-2) SP-2=F8
MQV M.B
    B TA (HL)
MOV M,C
    C Ta (HL)
MOV M,D
    OTO (HL)
MeV m,E
    E TO (HL.)
MQV M,H
    HTO (HL.)
MBV MOL
    L.TG (HL)
CMA COMPLFMENT A (=OA)
SIC SET CARRY = I
PUSH PSW
    A Ta (SP-1)
    FTG (SP-2) SP-2=F6
CMC CGMP. CARRY (=a)
IN
    8? DEV=OF
    90 TO A FROM OFOF
```

```
NOP
PUSH PSW
    AT日 (SP=1)
    FTQ (SP-2) SP-2=F4
DAA A TO BCD A=D3,SET FA,FA
PUSH PSW
    A TN (SP-1)
    FTO (SP-2) SP-2=F2
DAA A TO BCD A=69 CLEAR FA
PUSH PSN
    ATO (SP-1)
    FTM(SP-1) SP-2=FD
SHLD
    #?
    B3
    L TU (B3B2)
    Hra (B3B2+1)
```


## LHLD

E2.
$B 3$
0 OTGL FROM BJR2

FF TA H FROM B3R2+1

MVV M,H

H TO (HL)
MOV M,L

LTM(HL)

NOP
INR M

```
    FF FRMM (HL) +1=0日
```

    OQ TG (HL)
    OCR M
GQ FRQM (HL) $-1=F F$
FF TG (HL)
NUP
QuT
B2 DEV =AA
69 TB DEV AAAA FRGM A
MOV A,M
Q1 TD A FRBM (HL)
MQU R,M
GA TQ $B$ FROM (HI.)
MPV C.M
Q4 TO C FRQM (HL)
MRV D,M
UB TO D FROM (HL)
MOV E,M
10. TGE FROM (HL)
MQV H,M
20 TU H FRGM (HL)
MOV L.M
40) TA L FRQM (HL)
MeV M, A

NOP

A TA (HL)
MOV M,B
B 10 (HL)
MQV M,C
C TH(HL)
MOV M, D
$010(H L)$
MUV M,E
E TV (HL)
MQV M,H
H TD (HL)
MOV M.L
LTH (HI.)
MVI A
B2 92 Tด А
MVI B
R2 MATOB
MVI C
B2 08 TOC
MVI D
R2 10 TOD
MVI E
82 $2 a$ T 0
MVI H
日2 4 のTBH

NOP
MVI L
B2 80 TGL MOV M,A

A TG (HL)
$\operatorname{MAV} M, B$
B Ti (HL)
MOV M, C
C ra (HL)
MUV M.D

$$
0 \text { TA (HL) }
$$

MQV M,E
E TO (HL)
MOV M.H

$$
\text { H } T \text { (HL) }
$$

MUV M.L
LTO (HI)
MVI M
82
FF TG (HL)
INR $A \quad A+1=03$
MEV M.A
A TA (HL)
1NR R $B+1=a 5$

MBV $\mathrm{A}, \mathrm{B}$
B TA(HL)
NOP
1 NR C $C+1=9$
MOV M,C
C Th (HL)
1 NR $D \quad D+1=11$
MaV M,D
0 TO (HI)
1 NR $E \quad E+1=21$
MUV M,E
ETO(HL)
INR H $H+I=41$
MUV M.H
H TO (HL)
INR L $L+1=81$
MOV M,L
L. Ta (HI.)
DCP $A \quad A-1=12$
MOV M, A
$\Delta$ TA (HL)
DCF $A \quad B=1=04$
$M B V M, B$
B 19 ( HI )
OCR C $C-1=0.8$
MUV M, C
C TA (HL)
OCR $n \quad n-1=10$

NOP
MOV M,D
D TO (HL)
DCR E $E=1=20$
MQV M, E
$E T(H L)$
DCR H $H-1=10$
MOV M, H
H TO (HL)
DCR L L~1=80
MOV M,L
LTO. $\mathrm{HI}_{\sim}$ )
MRV $A, B \quad A=04$
MQV B,C B=AB
MOV C,D $C=10$
MOV D,E $D=29$
MOV EHH E $\quad$ GA
MQV H.L $\quad H=B O$
MQV L.,A $L=0.4$
MOV M, A

A TA (HL)
MVV M,B
$B T O(H L)$
MOV M.C
CTV(HL)
$\operatorname{MQV} M, D$

```
NOP
    D TO (HL.)
MOV M,E
    E TO (HL)
NOV M,H
    H IO (HI.)
MOV M,L
    L T0 (HL)
MOV A,C A=10
MOV B,D B=20
MOV C,E C=40
MOV D,H D=80
MOV E,L E=R|
MOV M.A
    A TO (HL)
MOV M,B
    B TD (HL)
MOV M,C
    C TO (HL.)
mOV M,n
    D TO (HL)
MOV M,E
    E YO (HL)
MOV H,A H=IV
MOV L,B L=2D
MOV M;H
```

NOP

$$
H T O(H L)
$$

MOV M,L

$$
L T D(H L)
$$

MCV $A, D \quad A=80$
$\operatorname{MOV} B, E \quad B=a \Delta$
MOV C,H $\quad \mathrm{C}=10$
MOV DR $\quad 0=20$
MOV M, A
A $10(\mathrm{~mL})$
MOV M.B
日 $T \cap(H L)$
MOV M,C
C TO (HL)
MOV M, D
D $10(\mathrm{HL})$
MOV $E, A \quad E=80$
MOV $H, B \quad H=0.4$
MOV.L,C $L=10$
MOV M, E
E TO (HL)
MOV M.H
H TO (HI)
MOV M. 1
L TO (HL)
MOV E,M

## NOP

(HL) TO $E \quad E=A C$

$$
\begin{aligned}
& \text { MOV H.M } \\
& (H L) \text { TO H } H=08
\end{aligned}
$$

mav L, M

$$
(H L) \text { TOL } \quad L=02
$$

$$
\text { MOV } A, E \quad A=40
$$

MOV E.B

$$
E=\| A
$$

$$
\operatorname{MOV} B, H \quad B=M B
$$

$$
\text { MOV H,C } \quad H=10
$$

$$
\operatorname{movc} \quad c=n 2
$$

$$
\begin{array}{ll}
\operatorname{MOV} C, L \\
\operatorname{MOV} L, D \quad L=20
\end{array}
$$

MoV M.A

$$
\text { A } 10(H L)
$$

$$
\operatorname{mov} M, B
$$

$$
\theta 10(H L)
$$

$$
\operatorname{mov} M, C
$$

$$
c \text { ro }(H L)
$$

$$
\text { rov } M, D
$$

$$
0 \text { in }(H I) \text {. }
$$

$$
\operatorname{MOV} M, E
$$

$$
E T \cap(H L)
$$

$$
\text { MOV } M, H
$$

$$
\mathrm{H}^{2} \mathrm{O}(\mathrm{HL})
$$

$$
M O V \cdot M \cdot L
$$

NOP
LTO (HL)
MOV $A, H \quad A=10$
MOV $H, O \quad H=A B$
$\begin{array}{ll}\text { MOV } D, B & D=O B \\ \text { MOV } B, L & B=20\end{array}$
MOV L, E L=AA

MOV M.A
$A$ TD (HL)
mov $M, B$
B TO (HL)
mav M.C
c. TO (HL)
mov $\mathrm{H}, \mathrm{D}$
D $\mathrm{OO}_{\mathrm{C}}(\mathrm{HL})$
Mov M.E
E TO (HL)
mov M, H
HTO (HL.)
mov M.L
L. TO (HL)

MOV A,L $\operatorname{MOV} L, H \quad L=A B$ MOV $H, E \quad H=Q 2$

```
NOP
MOV E,D E=0.8
MOV D,C D=10
MOV C,B C=20
MOV B,A B=M4.
MOV M,A
    A TO (HL.)
mov M,B
    B TO (HL)
MOV M,C
    C Tn (HL)
MOV M,D
    D TO (HL)
MOV M,E
    E TO (HL)
MOV M,H
    H TO (HL)
MOV M.L
    I. TO (HL.)
POP PSW SP=gAFQ (SEE LINE 186)
    (SP) TOF F=@2
    (SP'+1) TO A A = 80 SP+2=|ดF2
PUSH PSW
    A 10 (SP-1)
    FTO (SP-2) SP-2=GQFG
ADD B A = A+B=8O+A4=84 F=R6 A=8A
```

NOP
PUSH PSW
A $70(S P-1)$
F TO（SP－2）SP－2＝ロQEE
$A D O$ C．$A=A+C \quad A=A A \quad F=82$
PUSH PSW
A TO（SP－1）
FTO（SP－2）SP－2＝のあEC
$\triangle D D \quad A=A+D \quad A=B 4 \quad F=86$
PIJSH PSW
A 10 （SP－1）
$F \operatorname{FO}(S P-2) \quad S P=2=\operatorname{ODA}$
$A D O$ E．$A=A+E \quad A=B C \quad F=82$
PUSH PSW
A $10(S P-1)$

$A D D H \quad A=A+H \quad A \equiv B E \quad F=B 6$
PUSH PSW
A 10 （SP－1）
FTO $(S P-2) \quad S P-2=$ ИVEG 6
$A \cup D \quad A=A+L \quad A=F E \quad F=R 2$
PUSH PSW
A TO $(S P-1)$
$F$ TO $(S P-2) \quad S P-2=$ QREA
$\triangle D D M \quad A+(H L)$
（HL）$I N=0.1 \quad A=F F \quad F=86$

TABLE 1 Continued
NOP
PUSH PSW
ATO (SP-1)
F TO $(S P-2) \quad S P-2=9 \triangle E 2$
$\triangle D O \quad A=A+A \quad A=F E \quad F=93$
PUSH PSW
ATO $(S P-1)$
FTO (SP-2) $\quad S P-2=$ OQFの
$\triangle D C B \quad A=A+B+1 \quad A=A 3 \quad F=17$
PUSH PSW
$A T O(S P-1)$
$F T 0(S H-2) \quad S P-2=Q Q D E$
ACC. C. $A=A+C+1 \quad A=24 \quad F=16$
PUSH PSW
A $70(S P-1)$
F $T 0(S P-2) \quad S P-2=\operatorname{aanc}$
$A \cup C$ D $A=A+D \quad A=34 \quad F=A 2$
PUSH PSW
A TO (SP-1)
FTO (SP-2) $\quad S P-2=0.00 A$
$\triangle D C \quad A=A+E \quad A=3 C \quad F=06$
PUSH PSW
A $10(S P-1)$
$F T 0(S H=2) \quad S P-2=0008$
$\triangle D C H \quad A=A+H \quad A=3 E \quad F=12$
PUSH PSW

NOP

|  | TO | (SP-1) |  |  | $A=3 E$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | T0 | $(\mathrm{SP}-2)$ | SP-2 $=0006$ |  | $B=\varnothing \square$ |
| ADC | M | $A=A+(H L)$ | $A=0,0$ | $F=57$ | $c=2 a$ |
|  | L) | $\mathrm{IN}=\mathrm{C} 2$ |  |  | $D=10$ |
| pus | H P | SW |  |  | $E=0 B$ |
| A | 10 | (SP-1) |  |  | $\mathrm{H}=0.2$ |
| $F$ | 10 | (SP-2) | $5 P-2=0$ | 12 | $L=40$ |

$\triangle D C \quad L \quad A=A+L+1 \quad A=41 \quad F=0.6$
PUSH PSW
ATO (SP-1)
F TO (SP-2) $\quad S P-2=9002$
$A D C \quad A \quad A=A+A \quad A=82 \quad F=86$
PIJSH PSW
$A$ TO (SP-1)
$F \operatorname{TO}(S P-2) \quad S P-2=\operatorname{AnO}$
SUR $B \quad A=A-B \quad A=7 E \quad F=a 6$
PUSH PSW
ATO (SP-1)
F $T$ O $(S P-2) \quad S P-2=\pi O C E$
SuR $C \quad A=A-C \quad A=5 E \quad F=1$ ?
PllSH PSW
A $10(S P-1)$
F 10 (SP-2) $\quad S P-2=\operatorname{AnCC}$
$\operatorname{SUR} D \quad A=A-D \quad A=\triangle E \quad F=16$
PUSH PSW

NOP

```
    A TO (SP-1)
    FTO (SP-2) SP-2=DOCA
SUR E A=A-E A=46 F=12
PUSH PSW
    A TO (SP-1)
    FTO (SP-2) SP-2=00C8
SUR H A=A-H A=44 F=16
PUSH PSW
    A TO (SP-1)
    FTO (SP-2) SP-2=00C6
SUB L A=A-L A=04 F=12
PUSH PSW
    A TO (SP-1)
    F T0 (SP-2) SP-2=anca
SUB A A=A-A A=ga F=56.
PUSH PSW
    A TO (SP-1)
    FTO (SP-2) SP-2=n0C2
SUR M A=A=(HL)
    (HL) IN=FF A=\1 F=@3
PUSH PSW
    A T0 (SP-1)
    FT0 (SP-2) SP-2=anca
SBB A A=A-B-1 A=FC F=87
PUSH PSW
```

NOP
ATO (SP=1)
F TO (SP-?) SP-2.aAGBE
SBR C $A=A-C-1 \quad A=D B$ ..... $F=96$
PUSH PSW
A TO (SP-1)
F TO (SP-2) $S P-2=a(A B C$
SHR 0 $\Delta=A-D$ $A=C B$ ..... $F=92$
PUSH PSW
A 10 (SP-1)
FTO (SP-2) SP-2=DURA
SBE E $A=A-E$ ..... $A=C 3$ ..... $F=96$
FUSH PSW
A $10(S P-1)$
F TO (SP-2) $S P-2=00 B 8$
SER H $\quad \mathrm{A}=\mathrm{A}=\mathrm{H}$ ..... $A=C$. ..... $F=92$
PIJSH PSW
A TO (Sp-1)
F ro (SP-2) ..... $S P-2=0016$
$S B R \quad L \quad A=A-L$ $A=81$ ..... $F=96$
FUSH PSW
A TO (SP-1)
F TO (SP-2) SP-2=のa日 4
SER $M \quad A=A=(H L)$
(HL) $\quad \mathrm{J}=82$ $A=F F$ ..... $F=87$
PUSH ..... PSW

## TABLE $]$ Continued

NOP

```
    A ro (SP-1)
    F TO (SP-2) SP-2=ब0日2
```

$\operatorname{SBR} \quad A \quad A=A-A-1 \quad A=F F \quad F=87$
PUSH PSW
ATO (SP-1)
FTO (SP-2) $5 P-2=\operatorname{agn}$
ADI $A=A+(B 2)$
$B 2=01 \quad A=00 \quad F=57$
PUSH PSW
ATO (SP-1)
$F$ TO (SP-2) $S P-2=2 Q A E$
$\triangle C I A=A+(B 2)+1$
$B 2=F F \quad A=0 A \quad F=57$
PUSH PSW
$410(S P-1)$
$F T O(S P-2) \quad S P-2=O Q A C$
SUI $A=A=(B 2)$
$82=01 \quad A=F F \quad F=87$
PUSH PSW
a $10(S P-1)$
$F T 0(S P-2) \quad S P-2=0 D A A$
SHI $A=A=(B 2)=1$
$B 2=A B \quad A=B E \quad F=96$
PUSH PSW
A $10(S P-1)$

NOP

| F $T$ | T0 | (SP | -2) |  | SP-2=0048 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ORA | ( | A | IOR | 8 | $A=B E$ | $F=86$ | $A=B E$ |
| PUSH |  | PSW |  |  |  |  | $B=0.4$ |
| A $T$ | TO | (SP | -1) |  |  |  | $C=20$ |
| $F T$ | TO | (SP | -2) |  | SP-2=0046 |  | $D=10$ |
| XHA | B | A | $\times \dot{O R}$ | B | $A=B A$ | $F=82$ | $E=08$ |
| PUSH |  | PSW |  |  |  |  | $H=0$ ? |
| A $T$ | T0 | (SP | -1) |  |  |  | $L=\Delta a$ |
| $F T$ | TO | (SP | -2) |  | $S P-2=0 口 A 4$ |  |  |
| ORA | C | A | 10R | C | $A=B A$ | $F=8$. |  |
| PUSH PSW |  |  |  |  |  |  |  |
| A T0 |  | (SP-1) |  |  |  |  |  |
| F $T$ | TO | (SP | -2) |  | $S P-2=00 A 2$ |  |  |
| XFA | C | A | XOF | C | $A=9 \mathrm{~A}$ | $F=86$ |  |
| PUSH PSN |  |  |  |  |  |  |  |
| A TO |  | (SP | -1) |  |  |  |  |
|  | 10 | (SP | -2) |  | $S P-2=\operatorname{TOAD}$ |  |  |
| MHA |  | A | IOR | 0 | $A=9$ A | $F=86$ |  |
| PUSH |  | PSW |  |  |  |  |  |
| A 10 |  | (SP | -1) |  |  |  |  |
| F 1 | 10 | (SP | -2) |  | SP-2=009E |  |  |
| YRA | 0 | A | XOR | 0 | $A=B A$ | $F=82$ |  |
| PUSH |  | PSW |  |  |  |  |  |
| A $T$ | T0 | $(S P-1)$ |  |  |  |  |  |
| $F T$ | 10 | PSP | -2) |  | Sp-2 $=$ an9C |  |  |

## TABLE 1 Continued

## NOP

DRA E A IORE $A=8 A$ ..... $F=R 2$
PUSH ..... PSW
A $T O(S P-1)$
FTO (SP-2) ..... $S P-2=\square ด O A$
XRA E A XORE $A=82$ ..... $F=86$
PUSH PSW
$A \operatorname{TO}(S P-1)$
$F T O(5 P-2)$ $S P-2=\pi 898$
GRA H A IOR H A $=82$ ..... $F=86$
PUSH ..... PS!
ATO (SP-1)
$F \operatorname{Tn}(S P-2)$ ..... $S P-2=9096$
XRA H A XOR ..... H
$A=80$. ..... $F=R 2$
PUSH PSW
A TO (SP-1)
$F \operatorname{TO}(S P-2)$ $S P-?=9094^{\circ}$
ORA L $A$ IOR L $A=C O$ ..... $F=86$
PUSH PSW
A 10 (SP-1)
FTO (SP-2) $S P-2=0002$
XRA L A XOR I. $A=8 \cap$ ..... $F=R 2$
PUSH PSW
A TO (SP-1)
F 10 (SP-2) $5 P-2=969 n$
ORA A A IOR A $A=R a$ ..... $F=82$

## TABLE 1 Continued

NOP
PUSH PSW
A $10(S P-1)$
$F T 0(S P-?) \quad S P-2=\operatorname{ang} E$
XRA A $A \times O R \quad A \quad A=O \square$ $F=46$
PUSH PSW
ATO(SP-1)
$F 10(S P-2)$ $S P-2=908 C$
ORA M A IOR (HL)
(HL) IN $=B E$ $A=B E$ $F=86$
PUSH PSW
A $T \cap(S P-1)$
$F T O(S P-2) \quad S P-2=a \underline{0} \Delta$
XRA M A XOR (HL)
(HL)IN=78 $A=C 6$ $F=96$
PUSH PSW
ATO (SP-1)
F TO (SP-2) $S P-2=0998$
ANA M $A=A$ AND (HL)
( $H L$ ) $I N=F C$ $A=C 4$ ..... $F=92$
PUSH PSW
A $T O(S P=1)$
F $\quad 10(S P-2)$ $S P-2=10.496$
$A N A \quad A=A$ AND $A$

$$
A=C A
$$

$$
F=8 ?
$$

PUSH PSW
A TO (SP-1)

```
NOP
    FTO (SP-2) SP-2=9084
ANA B A=A AND G
    A=84
    FE@2
PUSH PSN
    A TO (SP-1)
    F 10(SP-2) SP-?=0082
ORI A=A IOR (B2)
    82=7C
        A=7C
        F=03?
PUSH PSW
    A TO (SP-1)
    Fro(SP-2) SP-2=0.0.0
ANA.C A=A AND C
    A=20
    F=12
FUSH PSW
    A TO (SP-1)
    FTO (SP-2) SP-2=a@TE
ANI A=A ANO(B2)
    82=65
    A=20
                                    F=0?
PUSH PSW
    A TO (SP-1)
    FTO (SP-2) SP-2=007C
XRI A=A XOR (B2)
    82=5c
                            A=7C
                            F=Q?
PUSH PSW
    A 10 (SP-I)
    FT0 (SP-2) SP-2=an7A
ANA D A=A ANO O
                                    A=1a
                                    F=1 ?
```

| NOP |  |  |  |
| :---: | :---: | :---: | :---: |
| PUSH PSW |  |  |  |
| A 10 (SP-1) |  |  |  |
| F TO (SP-2) | $S P-2=a 078$ |  | $A=10$ |
| CNP C A-C | $F=97$ | . | $B=0.4$ |
| PUSH PSW |  |  | $C=2.9$ |
| A $10(S P-1)$ |  |  | $D=10$ |
| F TO (SP-? ) | SP-2 $=9076$ |  | $E=08$ |
| RAR | $A=88$ | $F=96$ | $H=02$ |
| PUSH PSW |  |  | $L=40$ |
| A 10 (SP-1) |  |  |  |
| $\dot{F}$ TO (SP-2) | SP-2=0074 |  |  |
| ANA E A=A AND | E | $A=0.8$ | $F=12$ |
| PUSH PSW |  |  |  |
| A $T 0(S P-1)$ |  |  |  |
| $F \mathrm{TO}(\mathrm{SP}-2)$ | SP-2 $=9072$ |  |  |
| RAR |  | $A=04$ | $F=12$ |
| PUSH PSW |  |  |  |
| A $10(S p-1)$ |  |  |  |
| F TO (SP-2) | $s p-2=0070$ |  |  |
| FRC |  | $A=P$ ? | $F=1 ?$ |
| PUSH PSW |  |  |  |
| A TO (SP-1) |  |  |  |
| F TO (SP-2) | SP-? = 9n6E |  |  |
| ANA H $A=A$ AND | H | $A=02$ | $F=02$ |
| PUSH PSW |  |  |  |

NOP

```
    A TO (SP-1)
    FT0 (SP-2) SP-2=aU6C
```

RLC
$A=0.4$
$F=0$ ?
PUSH PSW
A $10(S P-1)$
F $10(S P-2) \quad S P-2=946 A$
CMP A $A-A \quad F=56$
PUSH PSW
ATO (SP-1)
F TO $(S P-2) \quad S P-2=0068$
CMP B $A=B \quad F=56$
PUSH PSN
ATO (SP-1)
$F T O(S P-2) \quad S P-2=0466$
CMP $D \quad A=D \quad F=93$
PUSH HSW
A TO (SP-1)

CMP E A-E $\quad F=87$
PUSH PSW
A $\operatorname{TO}(S P-1)$
FTO(SP-2) SP-2=0@62
CMP H A-H $\quad F=1 ?$

## PUSH PSW

$$
A \cdot T 0(S P-1)
$$

NOP

```
    FT0 (SP-2) SP-2=0日6a
CMP M A=(HL)
    F=1?
    (HL)IN=OO
PUSH PSW
    A TO (SP-1)
    F TO (SP-2) SP-2=005E
[MP L A-L F=93
PUSH PSW
    A TO (SP-1)
    FT0 (SP-2) SP-2=0.05C
```

RAL
PUSH PSW
A TO (SP-1)
F $10(S P-2) \quad S P-2=905 A$
QRA L $A=A$ IOR $L \quad A=49 \quad F=02$
PUSH PS'N
A $T 0(S P=1)$
F TO (SP-? ) $\quad S P=2=0 ด 58$
ANA L $A=A$ AND L $\quad A=A D \quad F=1 ?$
PUSH PSW
ATO (SP-1)
FTO (SP-2) $S P-2=7056$
CPI $A=(82) \quad F=$ の7
$\mathrm{H} 2=\mathrm{FF}$
PUSH PSW

NOP

```
    A TO (SP-1)
    FTO (SP-2) SP-2=0054
RLC
PUSH PSW
    A TO (SP-1)
    FTO (SP-2) SP-2=9952
RLC A=01 F=07
PUSH PSW
    A 10 (SP-1)
    FTO (SP-2) SP-2=0050
RRC
                                    A=8a
                                    F=07
PUSH PSW
    A TO (SP-1)
    FTO (SP-2) SP-2=\04E
RAL
                                    A=01
                                    F=07
PUSH PSW
    A TO (SP-1)
    F TO (SP-2) SP-2=90.4C
JMP (B3B2) TO PC
    B2
    E3
JC (B3B2) TO PC (CARRY=1)
    B?
    B3
JNC ND JUMP,CARRY=1
```

NOP

82
$B 3$
52
82
83

JNZ (B3B2) TO PC

82

B3
$J M$ NO JUMP,SIGN=Q
B2
83
JP (B3B2) TO PC
B2

83

JPE (H3B2) TO PC PARITY:1

82

83

JPO NO JUMP

82
$B 3$
132
$B 3$
$P C+1$
PCH TO (SP-1)
PCL TO (SP-2) SP-2=ロAAA

## TABLE 1 Continued

```
NOP
RET
    (SP) TO PCL
    (SP+1) TO PCH SP+2=uK4C
CC CALL,CARRY=1 (BJEO)TO PC
    B2
    B3 PC+1
    PCH TO (SP-1)
    PCL TO (SP-2) SP-2=0.OAA
DC RET,CARRY=1
    (s\mu) TO PCL
    (SP+1) TO PCH SP+2=a@4C
CNC NO CALL,CARRY=1
    B2
    83
RNC NO RET,CARRY=I
CZ NO CALL,ZERO=@
    B2
    83
RZ NO RET,ZERO=O
CNZ CALL,ZERO=O (B3B2) TO PC
    B2
    H3 PC+1
    PCH TO (SP-1)
    PCL. TO (SP-R) SP-2=a(AA
RNZ RET, ZERO=\
```

NOP
(SP) TO PCL
(SP+1) TO PCH SP +2=O日4C
CM NO CALL,SIGN=0
82
$B 3$
RM NO RET, SIGN=V
CP CALL,SIGN= $\quad$ (R3R2)TO PC
B2
B3 PC+1
PCHTO (SP-1)
PCL TO (SP-2) SP-2=ดのAA
RP
(SP) TO PCL
$(S P+1)$ TO PCH $S P+2=0$ COAC
CPE CALL,PARITY=1 (B3B?)TO PC
B2
B3 $P C+1$
PCKTO (SP-1)
PCL TO (SP-2) SP-2=aO $\triangle A$
RPE RET,PAPITY=1.
(SP) TO PCL
$(S P+1)$ TO PCH $S P+2=00 \triangle C$
CPO NO CALL,PARITY=1
$B 2$
83

```
NOP
RPO NO RET,PARITY=1
POP PSW
    (SP) TO F
    (SP+1)r0 A SP+2=9ด\triangleE
PUSH PSW
(SIGN, ZERO=1)
    A TO (SP-1)
    F TO (SP-2) SP-2=004C
JMP (B3B2) TO PC
    82
    B3
JC NO JUMP,CARRY=?
    B?
    83
JNC (B3B2) TO PC
    B?
    B3
JZ (B3B2) TO PC
    B2
    H3
JNZ NO JUMP,ZERO=1
    B2
    B3
JM (B3B2) TO PC SIGN=I
4?
B3
```

```
NOP
JP NO JUMP
    42
    B3
JPE NO JUMP, PARITY=a
    B?
    B3
JPD (B3B2) TO PC
    B?
    83
CALL (B3B2) TO PC
    82.
    83
        PC+1
    PCH TO (SP-1)
    PCL TO (SP-2) SP-2=004A
NET
    (SP) TO PCL
    (SP+1) YO PCH SP+2=00.4C
CC NO CALL,CARRY=O
    B2
    E3 1
RC NO RET
CNC (B3B2) TO PC , CARRY=@
    B2
    B3
        PC+1
    PCH TO.(SP-1)
```

```
NOP
    PCL ro (SP-2) SP-2=|ด\triangleA
RNC RET, CARRY={
    (SP) TO PCL
    (SP+1) TO PCH SP+2=0\.4C
CZ CALL,ZERO=1
    B2 (B3B2)TO PC
    B3}PC+
    PCH TO (SP-1)
    PCL TO (SP-2) SP-?=\OAA
R2 RET
    (SP) TO PCL
    (SP+1) TO PCH SP+2=004C
CNZ NO CALL,ZERD=S
    B2
    B3
RNZ NO RETURN .
CM CALL,SIGN=1 (B3B2) TO PC
    B2
    83 PC+1
    PCH TO (SP-1)
    PCL TO (SP-2) SP-2=0UAA
RM RETURN
    (SH) TO PCL
    (SP+1) TO PCH SP+2=0@4C
CP NO CALL,SIGN=1
```

```
NOP
    B2
    B3
RP NO RET
CPF NO CALL,PARITY=a
        B2
        B3
RPE NO RET
CPO CALL, PARITY=0 (B3B2) TO PC
    B2
    B3 PC+1
    PCH. YO (SP-1)
    PCL TO (SP-2) SP-2=0|AA
RFO RETIIRN
    (SP) TO PCL
    (SP+1) TO PCH SP+2=A\AC
RST AT GOQO PC+1
    PCH TO (SP-1)
    PCL TO (SP-2) SP-2=00.4A
RET
    (SP) TO PCL
    (SP+1) TO PCH SP +2=ROAC
RST AT OUN8 PC+1
    PCH TO (SP-1)
    PCL TO (SP-2) SP-2=0@AA
RET
```

```
NOP
    (SP) TO PCL
    (SP+1) TO PCH SP*2=0日4C
RST AT Qu1a PC+1
    PCH TO (SP-1)
    PCL TO (SP-2) SP-2=0日AA
RET
    (SP) TO PCL
    (SP+1) T0 PCH SP+2=a04C
RST AT QU18 PC+1
    PCH TO (SP-1)
    PCL TO (SP-2) SP-2=an4A
RET
    (SP) TO PCL
        (SP+1) TO PCH SP+2=004C
RST AT बaza PC+1
    PCH TO (SP-1)
    PCL TO (SP-2) SP-2=9@4A
RET
    (SP) TO PCL
    (SP+1) TO PCH SP+2=0a|C
RST AT AN2B PC+1
    PCH TO (SP-1)
    PCL TO (SP-2) SP-2=an\triangleA
RET
    (SP) TO PCL
```

```
NDP
    (SP+1) TO PCH SP+2=OGAC
RST AT RGBQ PC+1
    PCH TO (SP-1).
    PCL TO (SP-2) SP-?=404A
RET
    (Sp) TO PCL
    (SP+1) TO PCH SP+2=0@4C
RST AT 0038 PC+1
    PCH TO (SP-1)
    PCL TO (SP-2) SP-2=ANAA
EET
    (SP) TO PCL
    (SP+1) TO PCH SP+2=a|4C
NOP
```



FIGURE 12: Program Counter Test
not checked is the Register Transfer to the Program Counter: This operation is verified during the Register Array Test.

## Register Array Test

The test on the Register Array is accomplished by two tests. One verifies that each register is independent of any other register, and two, that any register can be moved from one register to another with any data combination. The test to determine uniqueness of each register is to first load each register ( $B, C, D, E, H$, and $L$ ) with unique data and read to verify the load operation. The test is performed using the instruction shown in Table 2. An explanation of the instruction mnemonics appears in Table 3.

The next test on the Register Array will verify that the registers can move from one register to another and move any data combination. This test will also check register-to-Program Counter transfers. This recommended test loads the $H$ and $L$ registers directly with a pattern of 0 's, transfers the $H$ register contents to all other registers, and outputs from the $H$ and $L$ registers through the Program Counter. The pattern is incremented until all 256 numerical combinations have been checked. A flow chart of this test is illustrated in Figure 13. The instructions that should be used for this test are LXIH, PCHL, and $\mathrm{MOV}_{r 1, r 2}{ }^{\circ}$

Stack Pointer Test

The Stack Pointer test is just like the Program Counter test, both


TABLE 2: Register Array Test

| Maemenis | Description | 07 | 08 | Tantruztion todell |  |  |  |  |  | Clech 121 Cyctos | Masmonic | Descriptian | Inntuction Codell |  |  |  |  |  |  |  | CJoch 121 <br> Crctas |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| movin.2 | Move regater to iogriler | 0 | 1 | 0 | 0 | 0 | \$ | 5 | 5 | 5 | R2. | Return on erro | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | \$/11 |
| movm. 1 | Move crobler to memory | 0 | 1. | 1 | 1 | 0 | 5 | S | \$ | 1 | RN2 | Return on no trio | 1 | 1 | 0 | 0 | 0 | 0 | c | 0 | $5 / 11$ |
| move.m | Move memorv to cegrster | 0 | 1 | 0 | D | 0 | 1 | 1 | 0 | 1 | RD | Return on poshisiv | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | $5 / 11$ |
| HIt | Halt | 0 | 1 | 1. | 1. | 0 | 1 | 1 | 0 | 1 | RM | Return on minui | 1 | 1 | 1 | $t$ | 1 | 0 | 0 | 0 | 5/11 |
| MVI' | Move immedeste requster | 0 | 0 | 0 | 0 | 0 | 1 |  | 0 | 1 | APE | Relurn on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 3/11 |
| MVI ${ }^{\text {a }}$ | Move immediste memory | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 10 | RPO | Return on patity odd | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | $5 / 11$ |
| INA, | Increment | 0 | 0 | 0 | 0 | 0 | ' | 0 | 0 | 5 | 851 | Arusil | , | 1 | 1 | 1 | 1 | , | , | , | 11 |
| OCR | Decrement reguter | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 5 | IN | ingut | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 10 |
| INA M | Increment memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 10 | OUT | Output | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 10 |
| OCR M | Decremenimemory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 10 | IXIB | toid immedate regitet | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 10 |
| A00, | Add reguster to 4 | 1 | 0 | 0 | 0 | 0 | 5 | S | S | 4 |  | Pan \& \& C |  |  |  |  |  |  |  |  |  |
| ADC: | Add regrser to A with catiy | 1 | 0 | 0 | 0 | 1 | S | S | 5 | 4 | LXIO | Load immediate register | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 10 |
| \$UB, | Subtract regrster lrom A | 1 | 0 | 0 | 1 | 0 | S | 5 | 5 | 4 |  | Pan O\&E |  |  |  |  |  |  |  |  |  |
| SBE | Subtiact register fiom A with borrow | 1 | 0 | 0 | 1 | 1 | 5 | 5 | S | 4 | Lxin | Load inmedate regiter Pail $\mathrm{H}_{8} \mathrm{~L}^{+}$ | 0 | . 0 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |
| ANA: | And regnter with A | 1 | 0 | 1 | 0 | 0 | 5 | 5 | 5 | 4 | LXISP | Load immediate stact pointer | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |
| xRA | Enclusivi Or requster with A | 1 | 0 | 1 | 0 | 1 | 5 | 5 | 5 | 4 | PUSHE | Puth ceguter Pars of C on | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 11 |
| ofar | Or register with A | 1 | 0 | 1 | 1 | 0 | S | S | S | 4 |  | stack |  |  |  |  |  |  |  |  |  |
| CMP: | Compare register with A | 1 | 0 | 1 | 1 | 1 | S | 5 | 5 | 4 | PUSH D | Push register Parr 08 E on | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 11 |
| ADDM | Add memory to A | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 7 |  | stask |  |  |  |  |  |  |  |  |  |
| AOC M | Add memory to A with carry | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | PUSH ${ }^{\text {a }}$ | Push register Pan H\& t on | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 11 |
| SUB M | Subtact memoty trom A | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 |  | stact |  |  |  |  |  |  |  |  |  |
| S0B m | Subtiact memory from $A$ with borrow | $\dagger$ | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 7 | PUSH PSW | Push $A$ and Flags on stack | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 11 |
| ANAM | And memory with A | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 7 | POP 8 | Pod register pair 8 \& C ofl | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 10 |
| XRAM | Erclusive Or memory with A | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |  | stack |  |  |  |  |  |  |  |  |  |
| ORA M | Or memory with A | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 7 | POP 0 | Pooregister pair D\& E olt | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 10 |
| CMP M | Compzit memory with A | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 7 |  | stack |  |  |  |  |  |  |  |  |  |
| ADt | Add immediate to $A$ | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 7 | POP H | Pod register paif H \& L off | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |
| ACI | Ado immediate to $A$ with earry | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 7 | POP PSW | stack ${ }_{\text {POD }}$ and flags | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |
| SU1 | Subtract immediate from A | 1 | 1 | 0 | 1 | 0 | ; | 1 | 0 | 7 |  | oft stuck |  |  |  |  |  |  |  |  |  |
| 581 | Subtract immediate from $A$ | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 7 | STA | Stort A dirsi | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 13 |
|  | with borrow |  |  |  |  |  |  |  |  |  | 10A | Load A direct | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 13 |
| ANI | And immediate with $\mathbf{A}$ | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 7 | XCHG | Exthange O\&E.M\&L | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 4 |
| XRI | Exelusive Or imme diate with | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |  | Registers |  |  |  |  |  |  |  |  |  |
|  | A |  |  |  |  |  |  |  |  |  | XTHL | Exchange tod ol stack. H \& L | 1 | 1 | 1 | 0 | 0 | 0 | 1 | , | 18 |
| ORI | Or immediate with a | 1 | 1 | 1 | 1 | 0 | 1 | , | 0 | 7 | SPHL | H 4 Lo stach pointer | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 5 |
| CPI | Compare immediate with $A$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | PCHL | H8 $L$ to program counter | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 5 |
| ALC | Rotate A left | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 4 | OAD B | Add B \& Cto CSL | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
| ARC | Rotate $A$ right | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 4 | DAD O | Addosetokel | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 10 |
| RAL | Rotate A lell through cariy | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 4 | OAD M | AddH\&Lto H8L | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 10 |
| RAR | Rotate A right through | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 4 | OADSP | Adersack pounter 10 K 8 C | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 10 |
|  | carry |  |  |  |  |  |  |  |  |  | STAX 8 | Store A indireet | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | $)$ |
| JMP | Jump uncenditional | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 10 | STAX D | Stare A indirect | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 |
| dt | Jumb on calty | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 10 | LDAX $B$ | Load A indirect | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 |
| JNC | Juma en no carty | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 10 | LDAX 0 | Losd $A$ indicect | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |
| $J 2$ | dump on zero | 1 | 1 | 0 | 0 |  | 0 | 1 | 0 | 10 | INX 8 | Incremeni 8 C C (egsters | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 5 |
| JN2 | Jump on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 10 | INXO | Increment 0 \& E registers | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 5 |
| JP | tump on posilive | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 10 | INX H | Increment M \& L registers | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 5 |
| JM | Jump os minus | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 10 | INX SP | inciement stach pointer | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 5 |
| JPE | rump on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 10 | 0 CX 8 | Decrement $B$ \& $C$ | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 5 |
| JPO | Jump on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 10 | DCX 0 | Decrement 08 E | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 5 |
| call | Call unconditional | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 11 | OCXH | Decrement ${ }^{\text {d }}$ L | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 5 |
| CC | Call on casty | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 1111 | OCX 59 | Decrement stack pointer | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 5 |
| CNC | Cail on nocaly | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | $11 / 11$ | CMA | Complement A | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 4 |
| C2 | Call on zero | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 11111 | STC | Set carty | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 |
| CN2 | Call on nozero | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1111 | CMC | Complement casty | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 4 |
| CP | Call on positive | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1111 | DAA | Decimal adusi A | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 4 |
| CM | Call on munus | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 11/11 | Shio | Stare H \& L direct | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 16 |
| CPE | Call on party oven | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | $11 / 11$ | Lhlo | Lo4d H8 L direci | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 16 |
| CPO | Call on parity odd | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 11/1 | E) | Enable Interiugh | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 4 |
| RET | Return | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 10 | Di | Disable interiudt | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 4 |
| AC | Return on catiy | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 5/11 | NOP | No.operition | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| RNC | Return on no carty | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 5/11 |  |  |  |  |  |  |  |  |  |  |  |

NOTES: 1. DOD or SSS - 000 B-001C-010D-011E-100 H-101L-110 Memory - 111 A.
2. Two possible cycle times. $15 / 111$ indicate insteuction cycles dependent on condition flags.

TABLE 3: 8080 Instruction Mnemonics


are 16 -bit registers with the additional feature of incrementing and decrementing. Therefore, the test on the Stack Pointer should check for incrementing and decrementing, and the ability to load and transfer to another register. Figure 14 is a flow chart of a recommended test and Table 4 lists the instructions used during the test.

## Accumulator Test

The accumulator in the 8080 is 8 -bits wide. A recommended test on the accumulator is to verify, load, readback, rotate, and transfer operation through its entire range. The recommended instructions (see Table 1) to be used during this test are $M O V_{A, M}, M_{M} V_{M, A}, C M A, R C L, ~ R R C$, RAL, and RAR. A flow chart of the recommended test is shown in Figure 15.

## Arithmetic Logic Unit Test

The Arithmetic Logic Unit (ALU) is 8-bits wide and used to perform all arithmetic and logical data operations in the 8080 . The ALU has been left. until last because error analysis is simplified once all other modules have been verified. A recommended test for the ALU is to test all ALU data paths and related instructions through its range. All instructions are used during this test which operation on the ALU, such as $A D D, A D C, S U B, S B B$, etc. A flow chart of this recommended test is shown in Figure 16.


FIGURE 14: Stack Pointer Test

| MNEMONICS | CYCLES | CLOCKS | CODE (DATA WORD) $76543210$ | OPERATION |
| :---: | :---: | :---: | :---: | :---: |
| LXIH | 3 | 10 | 00100001 |  |
| $<\mathrm{B}_{2}>$ |  |  |  | $<\mathrm{B}_{2}>\longrightarrow(L)$ |
| $<\mathrm{B}_{3}>$ |  |  |  | $<\mathrm{B}_{3}>\longrightarrow$ (H) |
| SPHL | 1 | 5 | 11111001 | $(\mathrm{H})(\mathrm{L}) \longrightarrow(S P)$ |
| INXSP | 1 | 5 | 00110011 | $(S P)+1(S P)$ |
| DADSP | 3 | 10 | 0011.1001 | $(\mathrm{H})(\mathrm{L})+(\mathrm{SP}) \longrightarrow(\mathrm{H})(\mathrm{L})$ |
| PCHL | 1 | 5 | 11101001 | $(H)(L) \longrightarrow(P C)$ |
| DCXSP | 1 | 5 | 00111017 | $(S P)-1 \longrightarrow(S P)$ |
| PUSHPSW | 3 | 11 | 11110101 | $(A) \longrightarrow[S P-1],(F) \longrightarrow[S P-2]$ |

TABLE 4: Stack Pointer Test Instructions


FIGURE 15: Accumulator Test


FIGURE 16: Arithmetic Logic Unit Test
B. 8008

The test program for the 8008 is divided into the major sections listed below.

1. Accumulator
2. Register Array
3. Arithmetic Logic Unit (ALU)
4. Address Stack
5. Input/Output Instruction
6. Halt and Interrupt

Accumulator

The accumulator of the 8008 is part of the scratch pad register array with an address of $\emptyset \emptyset \emptyset_{7}$. This register is a working register for the arithmetic and logical instructions. Intially, a verification test would be implemented in a series of MOV instructions to load and store data to verify the basic functionality. Data patterns should consist of all 1's, all 0 's, CHECKERBOARD, inverted CHECKERBOARD, $1_{7}, 2_{7}, 4_{7}$, $10_{7}, 20_{8}, 40_{8}$, and $100_{8}$.

## Register Array

The scratch pad register array test is designed to verify that each register can increment and decrement throughout its entire range, that each
register can be transferred to all other registers of the array, and that the $H$ and $Z$ registers can properly provide a correct address for the $M_{R, M}$ and $M_{M, R}$ instructions.

Initially the device is reset and all registers of the array loaded to a different value with the $M O V_{R, M}$ instruction, except register $R$ which is set to 0 . Register $R 1$ is now incremented from 0 to 255 to 0 , to verify the wrap-around characteristic. After each increment, the contents of the register is examined using the $M O V_{M, R}$ instruction.

At the completion of this process, the contents of all remaining registers are stored and verified. Register R1 is now decremented from 0 to 255 to 0 , verifying the underflow characteristic. After each decrement, the register contents are stored and verified using the $M O V_{M, R}$ instruction. At the completion-of this process, the contents of all other registers are read and verified.

The increment/decrement test is now performed on all remaining registers of the array.

## Transfer Operations

In order to accomplish transfer operations and preserve the unique identification of all other registers, the previously verified instructions of MOV $V_{R, M}$, VMIr, $M O V_{M, R}$, INRr, and $D E C r$ will be used. Initially
all registers are cleared. Register Rl will be tested first. Register R1 is incremented and transferred to R2. R1 is again incremented and transferred to $R 3$. This process is repeated until all registers have received data from R1. The accumulator is the last register to receive data. All register contents are now stored and verified starting the the accumulator. After repeating this process 42 times, the sequence is repeated, only this time register R2 is used as the origin of all data to be transferred. All remaining registers, except the accumulator, are verified in the same manner.

Since the accumulator cannot increment, the test for verification of transfer is accomplished in a slightly different manner. Again, all registers are set to 0 . Register $B$ is then incremented and transferred to the accumulator, which is in turn transferred to register $C$. Register $B$ is again incremented and transferred to the accumulator, which is now transferred to register $D$. This process is repeated until all registers have received data from the accumulator. All register contents are now stored and verified. This process is repeated 51 times. During this test procedure the transfer of the accumulator contents to register $B$ is not possible, since register $B$ is being used to generate the test pattern internal to the device. Therefore, it is necessary to repeat this test using register $C$ to generate the internal test pattern, transferring its contents to the accumulator and then transferring the accumulator to register $B$, incrementing register $B$, and then storing all registers. The purpose of incrementing register $B$ is to preserve the unique addressing of that register for transfer verification.

The previously verified instructions are now utilized to test the add, subtract, logical, and shift instructions. Results of the add and subtract instructions effect all condition flip-flops, while the rotate and shift instructions effect only the carry bit. The logical instructions do not effect the condition flip-flops.

The condition flip-flops cannot be gated to the data or address bus for purposes of verification. Therefore, it will be necessary to use the conditional jump instructions, JC, JZ, JM, JPE, JNC, JNZ, JP, and JPO.

After each arithmetic operation it is necessary to execute all six conditional jump instructions to test for proper operation of the condition flip-flops.

The data chosen should generate the criteria to set and reset all condition flip-flops resulting in patterns that will verify that the ALU can recognize a 0 , negative number, even parity, and a carry, or borrow.

The data patterns required for proper verification of the ALU should be designed such that execution of the arithmetic or logical instruction being tested generates the following results:

Arithmetic Instruction

1. Positive Number
2. Negative Number
3. Even Parity
4. Non-Even Parity
5. Carry (Borrow)
6. No Carry (Borrow)
7. Zero Value
8. Non-zero Value

Logical Instructions

1. Posi:tive Number
2. Negative Number
3. Zero Value
4. Non-zero Value
5. Even Parity
6. Non-Even Parity

Rotate Instructions

1. Carry
2. No Carry
3. Shift a 1 Through Carry
4. Shift a 0 Through Carry
5. Shift a 1 Through a Field of 0's
6. Shift a 0 Through a Field of $0^{\prime} s$

## Address Stack

Testing of the address stack is designed to verify that all levels of the stack are operative in response to the CALL and RETURN instructions. The device test program simulates repeated subroutine CALL's and RETURN's nesting up to the seven allowable levels. The program should be structured so that the carry feature from the lower order 8bits of the address to the higher order 6-bits is verified. In addition, all conditional CALL and conditional RETURN instructions are verified. The jump instruction should also be included in this test as an easy means of manipulating the contents of the Program Counter in generating the return addresses to be stored in the address stack.

## Input/Output Instructions

Verification of the input/output instructions consist of executing a series of eight input instructions each followed by an output instruction. During this sequence, the code for the selected input and output port is different so that all combinations are tested. The actual data used to write into the accumulator is not of critical importance.

Halt and Interrupt

The Halt instruction and Interrupt feature of the 8008 can be tested together. The Interrupt is verfied first. The critical parameter of the Interrupt is that the interrupt signal to the 8008 cannot be allowed

The test program should verify that the 8008 will properly respond to an external interrupt which occurs within the allowable timeframe as indicated below. In addition, the Interrupt signal to the 8008 should be applied during all time states of instruction execution.

After this test, the Halt instruction is executed and the ability of the 8008 to respond to an external interrupt is verified over the same time span by executing a series of Halt instructions followed by Interrupts.

C. 2901

The 2901 4-bit bipolar microprocessor slice is not like other microprocessors being only the process portion of the typical microprocessor. Like the typical microprocessor, the 2901 has a data bus, but is not bidirectional. It also provides a register file (16 Word X 4-bits), an Accumulator (4-bits), and an Arithmetic Logic Unit (ALU).

The 2901 does not include an instruction decoder, rather all instructions directly control an operation from an code input. In a typical MPU the instruction code applied on the data bus into the decoder for the complete cycle. The 2901 complete cycle lasts only one clock cycle and if. the instruction lines change during the cycle a new operation will occur. Also, the 2901 is not capable of addressing external memory directly, because it does not include an address or program counter. A typical MPU can execute jumps, subroutines, and return from subroutines due to the existance of a stack pointer which the 2901 does not contain.

The architecture of the 2901 can easily be broken up into testable modules that can be controlled and tested by the device pins and its microinstructions (see Figure 2).

The 2901 can be broken up into the following modules:

1. RAM (16 addressable registers) controlled by the "A" address field.
2. RAM (16 addressable registers) controlled by the " $B$ " address field.
3. "Q" Register or Accumulator
4. ALU Source Selector
5. Eight Function ALU
6. Output Data Selector
7. RAM Shift
8. "Q" Shift

Examination of the microinstruction control shows that the 2901 has a 9-bit microinstruction. This microinstruction is divided into three groups: ALU source control, ALU function control, and destination control. The ALU source control controls from what data path the data will be applied into the ALU (Table 5). The ALU function controls what function the ALU will perform. For example, R field + $S$ field, $R$ field or $S$ field, etc., (Table 6). The destination control routes the output of the ALU (or RAM) to different destinations within the 2901. These destinations include the RAM register stack, the "Q" register accumulator, both the RAM and "Q" register or the RAM directly out of the device (Table 7). The microinstruction controls thus route and/or manipulate data through the device.

## RAM Addressable Register Test

The RAM Address Register should be divided up into four unique portions structured to test (1) the RAM using the "A" address stored through the output by passing the ALU, (2) the RAM using the "A" address outputted through the ALU, (3) the RAM using the "B" address

| MICRO CODE |  |  |  | ALU SOURCE <br> OPERANDS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| I 2 | I 1 | I 0 | Octal <br> Code | R | S |
| L | L | L | 0 | A | Q |
| L | L | H | 1 | A | B |
| L | H | L | 2 | 0 | Q |
| L | H | H | 3 | 0 | B |
| H | L | L | 4 | 0 | A |
| H | L | H | 5 | D | A |
| H | H | L | 6 | D | Q |
| H | H | H | 7 | D | 0 |

TABLE 5: ALU Source
-89-

| MICRO CODE |  |  |  | ALU <br> Function | Symbol |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{5}$ | $\mathrm{I}_{4}$ | $\mathrm{I}_{3}$ | Octal Code |  |  |
| L | L | L | 0 | R Plus S | $R+S$ |
| L | L | H | 1 | S Minus R | $S-R$ |
| L | H | L | 2 | R Minus S | R-S |
| L | H | H | 3 | R OR S | $R \vee S$ |
| H | L | L | 4 | R AND S | $R \wedge S$ |
| H | L | H | 5 | $\overline{\mathrm{R}}$ AND S | $\bar{R} \wedge S$ |
| H | H | L | 6 | R EX-OR S | $R \forall S$ |
| H | H | H | 6 | R EX-NOR S | $\overline{\mathrm{RAS}}$ |

TABLE 6: ALU Function Control

| MICRO CODE |  |  |  | RAM FUNCTION |  | Q-REGISTER FUNCTION |  | $Y$ OUTPUT | RAM SHIFTER |  | $\begin{gathered} \text { Q } \\ \text { SHIFTER } \end{gathered}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{8}$ | $\mathrm{I}_{7}$ | $\mathrm{I}_{6}$ | OCTAL CODE | SHIFT | LOAD | SHIFT | LOAD |  | , RAM 0 | $\mathrm{RAM}_{3}$ | $Q_{0}$ | $\mathrm{Q}_{3}$ |
| L | L | L | 0 | X | None | None | $F \longrightarrow Q$ | F. | $X$ | X | X | $X$ |
| L | L | H | 1 | $x$ | None | $x$ | None | F | $x$ | $x$ | $x$ | $x$ |
| L | H | L | 2 | None | $F \longrightarrow B$ | $x$ | None | A | $x$ | $x$ | $x$ | $x$ |
| L | H | H | 3 | None | $F \longrightarrow B$ | $x$ | None | F | $x$ | $x$ | $x$ | X |
| H | L | L | 4 | Down | $\mathrm{F} / 2 \longrightarrow \mathrm{~B}$ | Down | $Q / 2 \longrightarrow \mathrm{Q}$ | F | $F_{0}$ | $\mathrm{IN}_{3}$ | $\mathrm{Q}_{0}$ | $\mathrm{IN}_{3}$ |
| H | L | H | 5 | Down | $\mathrm{F} / 2 \longrightarrow \mathrm{~B}$ | $X$ | None | F | $F_{0}$ | $\mathrm{IN}_{3}$ | $\mathrm{Q}_{0}$ | $X$ |
| H | H | L | 6 | Up | $2 \mathrm{~F} \longrightarrow \mathrm{~B}$ |  | $2 \mathrm{Q} \longrightarrow \mathrm{Q}$ | F | $\mathrm{IN}_{0}$ | $\mathrm{F}_{3}$ | IN 0 | $\mathrm{Q}_{3}$ |
| H | H | H | 7 | Up | $2 \mathrm{~F} \longrightarrow \mathrm{~B}$ | $X$ | None | F | $\mathrm{IN}_{0}$ | $\mathrm{F}_{3}$ | $x$ | $\mathrm{Q}_{3}$ |

X=Don't care. Electrically, the shift pin is a TTL input internally connected to a three-state output which is in the high-impedance state.
$B=$ Register Address by B inputs.
Up is toward MSB.
Down is toward LSB.
TABLE 7: ALU Destination Control
outputted through the ALU, and (4) the right/left shift operation of the RAM.

To test the RAM using the "A" address outputted bypassing the ALU, the following is recommended. The object of the test is to run a GALPAT pattern on the RAM using all combinations from 0 to 15 for the test pattern and the compliment of this as the background pattern. Since the RAM can only be written into a location addressed by the "B" address, care has to be taken to address only the test location when writing into the RAM. When a location is being tested or read, the " $B$ " address should be different then the " $A$ " address. The easiest solution to this would be to compliment the " $B$ " address relative to the " $A$ " address when reading a test cell. The setup to run this test would be to set the ALU source operand to octal code $7(D, \emptyset)$ when writing into the RAN and octal code $4(\emptyset, A)$ when reading out a location. The ALU function is used during this test to route the data on the data input pin to the RAM. This should be programmed for a recommended function, octal code 3 ( $R$ OR S), as this will be used in a later test. The destination control should be programmed for octal code 2 which selects the RAM "A" data port to the output, bypassing the ALU. The clock pins should be held in a high state. Throughout this test the only pins that will be sampled will be the "Y" ouput pins. Once this test setup has been executed a GALPAT pattern should be performed using all test patterns of 0 to 15 and background patterns of 15 to 0 . What the GALPAT does is to write a background pattern then write a test pattern. The test pattern is then read, a background
pattern location read, then the test location again, then another background location, test location, etc., until all background locations have been read. Then the test pattern is moved and the process repeated until all locations have been used as a test pattern. The test pattern is then incremented and the background pattern decremented. This process is then continued until all pattern combinations have been tested (see Figure 17 for illustration).

Performing this test will verify that all data combinations can be written into and read out of with every data combination.

The second test on the RAM is to check the RAM addressed'by the "A" address field but checking the data output path through the ALU. The same test should be run as previously described with only one change in the microinstruction. This change would be to modify the destination control to an octal code 3. This modifies the output path from the RAM "A" address output to the ALU output. This would then check if the RAM "A" address path through the ALU is functional with all data sequences.

The next test on the RAM would be similar to the second test, but the "B" address and output path is checked. The changes to the second test would be to have addressing to the RAM entirely controlled by the "B" address field. During this test it is recommended that the "A" address field be the compliment of the "B" address. This would cause the worst interaction between the RAM addressing. The remaining difference would be to modify the ALU source operand to select octal code


FIGURE 19: GALPAT Read Example

3 when performing a read of the RAM. This will select a source of $\emptyset, B$, thus enabling the " $B$ " output of the RAM to pass through the RAM.

The final test to be run on the RAM is verification of the right/ left shift operation. The recommended test will only describe a shift operation from the left as to test the right shift all that would be required is to input data from the right input and test the left output. The object of this test is to verify that all data combinations from 0 to 15 can be shifted through the RAM. Also, since latches are noted to be sensitive to noise, and the 4-bit output of the RAM uses a latch, the test will also recommend how to check for this. The recommended test sequence is as follows:

The test should start out by loading a 0 into location 0 , and a 15 into location 15 of the RAM. The purpose of this is that one location will be used to shift data input and the other location will be used as a background test pattern. The microinstruction for the ALU source operation when writing the initial patterns should be an octal 7 which selects the data bus. All other times during the test an octal code 4 should be selected which selects "A" output latch for input to the ALU. (Note: An octal code of 3 should be selected when checking the "B" output latch.) The ALU function should be selected for an octal code 3 ( R OR S) so that the output latch can be tested throughout the test. The advantage of using the R OR S function is that the ouput of the ALU will be the same as the output latch. The microinstruction for the destination control should be selected to octal code. 4 which will execute
a left shift. (Octal codes 5, 6, and 7 should also be tested using this same test. When selecting codes 6 and 7 , the input and output shift pins should be complimented when codes 4 and 5 are selected.) The "A" and "B" address fields should be exactly the same throughout this test. This allows an easy modification to the ALU source operand to check the "B" output latch as described earlier. Last of all, the final setup should be to produce a clock pulse each time there is a requirement to write to the RAM, but not during a test cycle when the background location is being addressed.

The test on the right/left shift will verify that (1) the shift operation will occur, (2) this shift operation can shift all combinations of l's and 0's, (3) the output latches will hold data, and (4) the shift operation can be accomplished using any RAM address. Following the initial loading of the test and background patterns one bit of the shift pattern (101000111100101) is shifted into the RAM and the shift and $Y$ outputs checked. Then the background address is addressed but no clock is produced and the outputs again checked. This will verify that the output latch will hold data. The next bit is now shifted in and verified and the background location addressed and data verified. This process continues until all bits have been shifted into the RAM. Then the testword and background address are incremented and decremented, respectively, and the above test repeated. This will continue until all RAM locations have been used for the test location and background location. Upon completion of the first pass, the background pattern is decremented until the initial pattern has
gone from 15 to 0 . This will check for a sensitivity in the RAM output latches. This test is then repeated for both right and left shift operations on the RAM.

The next test performed is on the "Q" register. There should be two tests on the "Q" register. First, a test that will load the register with all combinations from 0 to 15 and follow each load with the compliment of the previous load. Second; a test to check the right/left shift operation on the register.

The first test should start by loading a " 0 " into the register and testing. Next a "15" should be loaded and tested, then. 1, 14, 2, 13, ..., until a 0 and 15 are again reloaded. This test verifies that any number can be loaded into register and that all data tranactions are checked.

The second test checks the right/left shift of the "Q" register (ALU Destination Control, octal codes 4 and 6). To check these operations an initial value should be loaded into the register and checked. Destination control octal code 4 is selected and a pattern (1010000111100101) is shifted into the register. After each bit shift the register data is checked. Then an octal code is selected on the destination control and the other shift operation checked as previously described.

The next test will test the ALU source operands. This test verifies
that all ALU sources can be selected and that all data combinations can pass through the selector. The test should start by first loading RAM locations $0,5,10$, and 15 with data equal to the address. The "Q" register is intially loaded with a 0 . Using the ALU function "R OR S" (octal code 3), and a destination control which loads neither the RAM nor the "Q" register: (octal code 1), the sequence of ALU source operands shown in Table 8 should be tested. During this test the "A" and "B" address will equal the data being selected by the source operand.

The ALU functions and flags should be tested next, since all other sections of the devices have now been verified as operational. First, all locations in the RAM are loaded with a data pattern equal to its address. Then data values of $0,5,10$, and 15 and RAM values of 0 , 5,10 , and 15 and CN values of 0 and 1 in all combinations are used to test each of the eight possible ALU functions. In all cases, $R$ is the data bus and $S$ is the "A" output from the RAM (ALU source operand, octal code 5). First, the $R \& S$ function (octal code 0 ) is tested. The basic sequence is as shown in Table 9.

This sequence is then repeated for each of the other ALU functions.

| Function |  | Octal Code |
| :--- | :---: | :---: |
| S - R |  | 1 |
| $R-S$ | $?$ |  |
| R OR S |  | 3 |


| R | S |
| :---: | :---: |
| $A=1010$ | $Q=0000$ |
| $A=0101$ | Q = 0000 |
| $A=1010$ | $Q=0000$ |
| (Load Q with 1010) |  |
| $A=0000$ | $Q=1010$ |
| (Load Q with 0101) |  |
| $A=0000$ | $Q=0101$ |
| (Load Q with 1010) |  |
| $A=0000$ | $Q=1010$ |
| $A=1010$ | $B=0000$ |
| $A=0101$ | $B=0000$ |
| $A=1010$ | $B=0000$ |
| $A=0000$ | $B=1010$ |
| $A=0000$ | $B=0101$ |
| $A=0000$ | $B=1010$ |
| (Load Q with 1111) |  |
| $\emptyset$ | $Q=1111$ |
| $\emptyset$ | $B=0000$ |
| $\emptyset$ | $B=1111$ |
| 0 | $A=0000$ |
| 0 | $A=1111$ |
| $D=1010$ | $A=0000$ |
| $D=0101$ | $A=0000$ |
| $D=0101$ | $A=0000$ |
| $D=0000$ | $A=1010$ |
| $D=0000$ | $A=0101$ |
| $D=0000$ | $A=1010$ |
| (Load Q with 0000) |  |
| $D=1111$ | $Q=0000$ |
| $D=0000$ | $Q=0000$ |
| (Load Q with 1111) |  |
| $D=0000$ | $Q=1111$ |

TABLE 8: ALU Source Operands

| $C N$ | $R=A$ | $S=D$ |
| :--- | :--- | :--- |
| 0 | 0000 | 0000 |
| 1 | 0000 | 0000 |
| 0 | 1111 | 0000 |
| 1 | 1111 | 0000 |
| 0 | 0101 | 0000 |
| 1 | 0101 | 0000 |
| 0 | 1010 | 0000 |
| 1 | 1010 | 0000 |
| 0 | 0000 | 1111 |
| 1 | 0000 | 1111 |
| 0 | 1111 | 1111 |
| 1 | 0101 | 1111 |
| 0 | 0101 | 1111 |
| 1 | 1010 | 1111 |
| 0 | 0000 | 1111 |
| 1 | 0000 | 0101 |
| 0 | 1111 | 1010 |
| 1 | 0111 | 0101 |
| 0 | 0101 | 0101 |
| 1 | 1010 | 0101 |
| 0 | 0000 | 0101 |
| 1 | 0000 | 0101 |
| 0 | 1111 | 0101 |
| 1 | 1111 | 1010 |
| 0 | 0101 | 1010 |
| 1 | 0101 | 1010 |
| 0 | 1010 | 1010 |
| 1 | 1010 | 1010 |
| 0 |  | 1010 |
| 1 | 1010 |  |
| 0 |  | 1010 |
| 1 |  |  |

TABLE 9: ALU Function Sequence

| Function | Octal Code |
| :--- | :---: |
| R AND S | 4 |
| R AND S | 5 |
| R XOR S | 6 |
| R SNOR S | 7 |

The last test on the device is to check to see if the output enable/ disable will cause the output to go to tristate. This is accomplished by inputting a $0,5,10$, and 15 into the Data bus and outputting it through the ALU (R OR S function) to the $Y$ output. After each data pattern is on the Data bus the " $Y$ " output is checked wtih the output enable. Then the outputs are disabled and the outputs checked for tristate.

The 6800 microprocessor unit is divided into the basic modules as listed below:

1. Program Counter
2. Stack Pointer
3. Index Registers
4. Accumulators $A$ and $B$
5. Arithmetic Logic Unit
6. Timing and Control Logic
7. Interrupt Capability

For thorough testing of the 6800 , the functional test sequence should thoroughly exercise each module independent of all other modules with the specific instructions applicable to that module. In addition, sufficient data patterns are used to verify proper operation of each module. An interactive type test is also performed to ensure that execution of an instruction on module will not cause destruction of data in a different module or an otherwise malfunction of the device.

In determination of the instruction sequence, the possible discovery of instruction and/or data pattern sensitivities was not considered.

## Program Counter

The Program Counter (PC) test consists of resetting the PC to 0
and then incrementing the PC through its entire range. Results of this test may be verified after each increment or after the PC has reached full value. Benefits of this test are proof that the device is basically operational, there are no stuck-at-one stuck-at-zero defects in the PC and the address bus drivers are capable of driving a logic 0 or logic 1 in any combination of bits present on the address bus.

Operation of the device during this test is as follows:

1. Reset the device.
2. Verify the reset address vectors of $\mathrm{FFFE}_{16}$ and $\mathrm{FFFF}_{16}$.
3. Input an instruction that will cause the PC to increment by 1.
4. Continue operation of this instruction until the PC equals $\operatorname{FFFF}{ }_{16}$.
5. Execute the instruction one more time to verify the overflow characteristic of the program counter.

Stack Pointer

Operational Modes:

1. Load
2. Store
3. Increment
4. Decrement
5. Transfer +1 to Index Register
6. Receiver -1 from Index Register
7. Output Data on Address Bus for:
a. Push, Pull Data
b. Store Device Status in Stack
c. Pull Device Status from Stack

Stack pointer contents are available on the data bus and also the address bus during instruction execution. Accordingly the test approach is defined to verify both conditions of output. The method of defining the test approach follows that of all modules, i.e., start with instruction sequences designed to verify basic module operation, increasing the complexity of instructions for total testing of the particular module. The transfer of SP contents to the index register and transfer of index register contents to the stack pointer require verification of the index register's functionality, and will therefore be defined in the index register section of this description.

Load/Store, Data Bus

To initiate testing of the stack pointer, a load instruction is executed followed by a store instruction to output the SP contents on the data bus.

Stack Pointer Instructions

LDS . Immediate, Direct, Index, Extended

Implied
Implied Implied Implied

Several data patterns should be chosen such that all bits of the stack pointer have been loaded to both a logic 1 and 0 . In addition, all different operational codes of the load stack pointer/store stack pointer instruction are executed at this time. This instruction sequence is defined as illustrated in Table 10.

Benefits of this test are that the stack pointer is identified as an addressable register, is capable of being loaded to several values, each bit of the stack pointer is capable of being a logic 1 or logic 0 and that each bit of the data bus is capable of driving a logic 1 or logic 0.

## Increment/Decrement

Execution of this test requires initial loading of the $S P$ to $0^{0000}{ }_{16}$, the incrementing the $S P$ from $0000{ }_{16}$ to FFFF $_{16}$ using the increment stack pointer instruction.

For detailed error analysis, the contents of the SP should be outputted to the data bus after each increment. This method may prove

| INSTRUCTION | ADDRESS MODE | DATA PATTERN |
| :--- | :--- | :---: |
| Load Stack Pointer | Immediate | $00 \emptyset 16$ |
| Store Stack Pointer | Direct | - |
| Load Stack Pointer | Direct | FFFF 16 |
| Store Stack Pointer | Index | - |
| Load Stack Pointer | Index | AAAA 16 |
| Store Stack Pointer | Extended | - |
| Load Stack Pointer | Extended | 5555 |
| Store Stack Pointer | Extended | - |

TABLE 10: Stack Pointer Load Routine
not feasible due to test system capability and in that case the increment stack pointer instruction would be repeated 16,384 times, and the $S P$ contents then read. The increment stack pointer instruction is then executed one more time and the SP contents outputted to verify the overflow characteristic.

The Decrement Test is similar to the previous test with the exception of initially loading the stack pointer to . $\mathrm{FFFF}_{16}$, using the decrement stack pointer instruction and executing the decrement instruction on additional time after the $S P$ is equal to 0 to verify the underflow characteristic.

In either of the above tests, the choice of which stack pointer store instruction to use is arbitrary and left to the discretion of the test engineer.

Address Bus Output (Push/Pull)

The Push and Pull instructions of the 6800 will cause the contents of the stack pointer to appear on the address bus and also increment or decrement the contents of this register.

Verification of this mode is performed by resetting the 6800 (getting a starting address of $0000_{16}$ to the PC) and execution of repeated PUL instructions. During instruction execution, the address is read
during all four to verify that the following information is present:
Cycle 1: Program Counter
Cycle 2: $\quad$ Program Counter +1
Cycle 3: Stack Pointer
Cycle 4: $\quad$ Stack Pointer +1

The PUL instruction is repeatedly executed until both PC and SP are equal to $\mathrm{FFFF}_{16}$.

The PSH instruction is now executed in a similar manner, again verifying the address bus during all four clock cycles as follows:

Cycle 1:
Program Counter
Cycle 2:
Program Counter +1
Cycle 3:
Cyçe 4:
Stack Pointer
Stack Pointer +1

This sequence is repeated until the $S P$ is equal to 0 .

Index Register (X)

Operational modes:

1. Local
2. Store
3. Increment
4. Decrement

Load Immediate, Direct, Index, Extended
Store Direct, Index, Extended

Increment
Decrement

| INSTRUCTION | ADDRESS MODE | DATA PATTERN |
| :--- | :--- | :--- |
| Load Index Register | Immediate | $009 \emptyset_{16}$ |
| Store Index Register | Direct | - |
| Load Index Register | Direct | FFFF 16 |
| Store Index Register | Index | - |
| Load Index Register | Index | AAAA 16 |
| Store Index Register | Extended | - |
| Load Index Register | Extended | 555516 |
| Store Index Register | Extended | - |

TABLE 11: Index Register Load Routine

## 5. Transfer to Stack Pointer TXS

6. Receive from Stack Pointer TSX

The Index Register is identical in size (16-bits X l) and similar in operation to the Stack Pointer. Therefore, the test plan defined for this module closely parallels that of the Stack Pointer.

Load/Store

The Index Register is loaded with several data patterns, storing the register contents after each load to verify proper load operation. All different $O P$ codes of the load and store instruction should be used to verify proper operation. The instruction sequence is defined as illustrated in Table 11.

## Increment

Execution of this test requires initial loading of the Index Register to $0000_{16}$, repeating execution of the increment Index Register (INX) instruction to increment the $X$ register from ${ }^{0000}{ }_{16}$ to $\mathrm{FFFF}_{16}$.

As in the Stack Pointer test, the contents of the $X$ register should be stored in the data bus after every increment. If not feasible, the increment instruction should be repeated continuously and the $X$ register contents outputted when equal to FFFF 16 . The increment instruction should then be executed one more time and the contents of the Index Register stored to verify the overflow characteristic.

## Decrement

The Decrement test is similar to the previous test with the exception of initially loading the Index Register to $\mathrm{FFFF}_{16}$, using the decrement Index Register instruction. When the $X$ register is equal to $000{ }^{16}$, the decrement instruction should be executed one more time and the register contents stored to verify the underflow characteristic.

Stack Pointer and Index Register Transfers

Transfers of the Stack Pointer and Index Register are limited to transferring the Stack Pointer contents +1 to the Index Register or the Index Register contents -1 to the Stack Pointer. The two instructions which define those operations are TSX and TXS respectively.

The test sequence to verify this sequence takes advantage of the functionality of these registers proven by previous tests.

Both registers are initially loaded to 0 . An instruction sequence which increments the SP executes a TSX instruction and stores the Index Register contents is repeatedly executed until the Index Register is equal to $\mathrm{FFFF}_{16}$.

This procedure is now repeated in a reverse fashion by executing a decrement Index Register, TXS, instruction followed by a read of the Stack Pointer. This instruction sequence is repeated until the Stack

Pointer is equal to 0.

Accumulators $A$ and $B$

Accumulators $A$ and $B$ are two general purpose 8 -bit registers used to store operands and results for ALU operations. The instruction set for each accumulator is similar with one or two exceptions. At this point, the definition of the different modules of the 6800 are open to different philosophies as to where one module ends and another module begins. For example, controversy may arise as to whether a logical OR instruction is an accumulator instruction or an ALU instruction.

This situation illustrates the problem of two different modules being involved in the execution of an instruction. The operation of the logical OR instruction of the contents of the Accumulator A (ACCA) with a byte of memory involves the input of a byte of memory, input of ACCA and the byte of memory to the ALU, execution of the logical OR between the two and transferring this results back to ACCA. Here two different modules are involved in the instruction execution and the question is to which module group the instruction belongs. For the purposes of clarity, this type of instruction will be attributed to the ALU module. In a more general sense, where more than one module is involved in the execution of an instruction, the instruction will be classified as belonging to the module which performs the basic operation intended by the instruction.

As in the Stack Pointer and Index Register test, the initial phase of the accumulator test consists of executing a load and store accumulator routine, using all applicable operation codes in conjunction with numerous data patterns. The specific instruction sequence is defined as illustrated in Table 12. Note that the contents of the accumulator not involved in a series of instructions is stored on data bus to verify no interaction of the two accumulators.

## Increment/Decrement

Accumulator $A$ is loaded to all 0 's and the increment Accumulator $A$ instruction is executed followed by a store Accumulator A instruction. This process is continued until ACCA is equal to $\mathrm{FF}_{16}$. The decrement Accumulator A instruction is now executed followed by a store ACCA instruction. This instruction sequence is repeated until ACCA is equal to 0 .

The above process is repeated on Accumulator $B$ substituting the appropriate Accumulator $B$ instructions.

Transfer ACCA to ACCB, ACCB to ACCA

This test is designed to verify the internal transfer of accumulator to accumulator by using previously verified instructions.

| INSTRUCTION | DATA PATTERN | INSTRUCTION | DATA PATTERN |
| :---: | :---: | :---: | :---: |
| Load A | $\mathrm{FF}_{16}$ | Load A | 4016 |
| Store A | --16 | Store A | --16 |
| Load B | $\mathrm{FF}_{16}$ | Load B | 4016 |
| Store B |  | Store B |  |
| Load A | ${ }_{-}^{55} 16$ | Load A | $8_{16}$ |
| Store A | -- | Store A | --1 |
| Store B | --16 | Store B | --16 |
| Load A | $\mathrm{AA}_{16}$ | Load A | $\mathrm{FE}_{16}$ |
| Store A | -- | Store A | -- |
| Load B Store B | ${ }^{\text {A }}$ - 16 | Load B | $\mathrm{FE}_{--16}$ |
| Load A | 9016 | Load A | $\mathrm{FD}_{16}$ |
| Store A | -- 16 | Store A | _-16 |
| Load B | $00_{16}$ | Load B | $\mathrm{FD}_{16}$ |
| Store B |  | Store B | -- |
| Load A | ${ }_{-1} 16$ | Load A | $\mathrm{FB}_{16}$ |
| Store A. | -1 | Store A | FB |
| Store B | -. 16 | Store B | ${ }_{-}{ }^{-16}$ |
| Load A | 0216 | Load A | F7 16 |
| Store A | -- ${ }^{16}$ | Store A | -- |
| Load B | ${ }^{12} 16$ | Load B | $\mathrm{F}^{16}$ |
| Store B | -- | Store B | -- |
| Load A | ${ }_{-1}{ }^{-16}$ | Load A | $\mathrm{EF}_{16}$ |
| Store A |  | Store A | -- |
| Load B | ${ }_{-1}{ }^{-16}$ | Load B | EF 16 |
| Load A | 0816 | Load A | $\mathrm{DF}_{16}$ |
| Store A | -- 16 | Store A | -- 16 |
| Load B | ${ }^{18} 16$ | Load B | $\mathrm{DF}_{16}$ |
| Store B | -- | Store B | -- 16 |
| Load A | ${ }^{10} 16$ | Load A | $\mathrm{BF}_{16}$ |
| Store A | -- 16 | Store A | -- |
| Load B | $10_{16}$ | Load B | $\mathrm{BF}_{16}$ |
| Store B | $\overline{-1}$ | Store B | -- ${ }_{\text {F }}$ |
| Store A | --16 | Store A | -- 16 |
| Load B Store B | 2916 | Load B Store B | ${ }_{-2} 16$ |

TABLE 12: Accumulator Load Routine

Both accumulators are initially loaded to all $0^{\prime} \mathrm{s}$. An increment ACCA is executed followed by a transfer ACCA to ACCB, clear ACCA and then store both accumulators. Now, an increment. $A C C B$ is executed, followed by a transfer ACCB to ACCA, clear ACCB and store both accumulators. This sequence is repeated until ACCA is equal to $X^{\prime} F F$.

Shift/Rotate Capability

The Accumulator registers of the 6800 are equipped with five modes of shift and/or rotate instructions. To properly verify the operation of these instructions, each is executed with several data patterns designed to represent worst case. Also, included in the execution of the shift and rotate instructions is verification of the Condition Code register, in particular the Carry Bit (C).

The test routine for the shift and rotate instructions initializes the MPU to a 0 state and then executes all five instructions on each accumulator. The recommended data patterns for each instruction is:

FF $_{16}$
$A_{16}$
5516
9116
0916

Each instruction is executed a total of eight times in order to
shift or rotate the data pattern through the entire accumulator. The contents of the accumulator being tested should be stored after each execution of the shift or rotate instruction. Also the contents of the Condition Code register should be stored after each eight executions of the instruction being used.

Arithmetic Logic Unit (ALU)

The function of the ALU is to perform addition, subtraction, and logical operations (OR, AND, Exclusive OR, 1's complement and 2's complement). Arithmetic comparisons can also be performed to set or reset bits of the Condition Codes register (CCR) which are testable for use in condition branch instructions.

Proper verification of the ALU includes execution and verification of all associated instructions in conjunction with worst case data patterns to verify that the ALU can add, subtract, recognize a carry, half carry, positive number, negative number and 2's complement overflow. As the CCR is an intergral portion of the ALU, its contents should be verified after execution of each instruction.

As in previous situations, the actual order of the instruction and data sequence should be structured such that, when possible, only instructions that have been previously verified are used for verification of unused instructions. The actual data patterns must be chosen such that the desired results will be generated.

## Timing and Control Logic

Timing and control logic verification includes testing proper generation of the Valid Memory Address (VMA), Bus A available (BA), and Read/Write control signals (R/W). The control signals BA, VMA, and R/W are generated according to the decode of each instruction with 30 different possible combinations. Therefore, each instruction must be verified as producing the proper response of these signals.

## Interrupt Capability

The 6800 microprocessor unit has been designed to offer two priority levels of hardware interrupt capability, the $\overline{\mathrm{IRQ}}$ (maskable) and $\overline{\mathrm{NMI}}$ (non-maskable) interrupts, $\overline{\text { NMI }}$ having priority of $\overline{\mathrm{IRQ}}$.

Upon detection of an interrupt, the 6800 will enter the interrupt state at the end of the instruction being executed or after the completion of next instruction, depending upon what clock cycle of the present instruction execution the interrupt has occurred.

The "I" bit of the Condition Codes register has been designated as the mask bit for the $\overline{\text { IRQ }}$ interrupt. If an $\overline{\mathrm{IRQ}}$ occurs and the "I" bit is set, the interrupt is ignored. If not, the interrupt state is entered.

The objectives of this test can now be stated as verification of
the following conditions.

1. Proper 6800 response to an $\overline{I R Q}$ interrupt by testing the data bus for storage of internal register contents, address bus for Stack Pointer address generation during the above storage and the address bus for generation of the $\overline{I R Q}$ address interrupt vector.
2. The "I" bit is set as a results of an IRQ interrupt.
3. That the 6800 will not respond to an IRQ interrupt when the "I" bit of the CCR is set.
4. Proper response to an $\overline{N M I}$ interrupt when the "I" bit is set and reset.
5. Priority of the $\overline{N M I}$ interrupt over $\overline{\mathrm{IRQ}}$ by causing both signals to indicate interrupts simultaneously.

A third mode of interrupt is under software control by means of the SWI (Software Interrupt Instruction). Execution of this instruction is not hardware related and will therefore be executed whenever it occurs in the user program. This instruction is verified by testing the data and address bus for proper storage of internal 6800 register contents and the generation of the SWI address interrupt vector.

Execution of the WAI (Wait for Interrupt Instruction) stores all internal register in the stack and then places the 6800 in an inactive wait state. The device will remain in this state until either an $\overline{\mathrm{IRQ}}$ or $\overline{\text { NMI }}$ interrupt occurs. This instruction is verified by first observing the data and address bus during internal register content storage
and second that an $\overline{I R Q}$ and $\overline{N M I}$ interrupt will be allowed to respond as previously described for these signals.

The $\overline{I R Q}$ and $\overline{\text { NMI }}$ signals are asynchronous and as such should be tested for interrupt generating capability by causing the interrupts to occur within several timeframes. First each interrupt should occur such that the recognition routine starts after completion of the present instruction being executed at the time of interrupt and second, after completion of the next instruction at the time of interrupt.

Instruction Decode Test

The Instruction Decode test verifies proper execution of all jump, branch, and subroutine instructions.

The major aspect of the jump instruction is to test for proper address generation in response to the two addressing modes of this instruction.

Testing of the branch instructions requires execution of each instruction and testing that (1) the branch address is generated, if the branch condition is true, and (2) that the branch does not occur, if the associated condition is false.

Subroutine instructions tests are required to verify that (1) the Stack Pointer address occurs on the address bus simultaneously with the
return address on the data bus, (2) the correct subroutine address is generated, and (3) that the return from subroutine generates the Stack Pointer address on the address bus for the purpose of pulling the return address from stack.

The 1802 microprocessor unit is a static 8-bit device employing CMOS technology. The device provides the following internal architecture (see Figure 11).

1. 16-bit by 16-bit Register Array
2. 8-bit Arithmetic Logic Unit (ALU)
3. 8-bit Accumulator (D)
4. Two 4-bit Instruction Registers (I and N)
5. A 4-bit Register $P$ used to specify which of the 16-bit Registers in (1) is the present program counter.
6. A 4-bit Auxiliary Register (X)
7. An 8-bit Temporary Register (T)
8. A 1-bit Register (Q)

Examination of the instruction set of the 1802 reveals that the major data path to and from the internal register array is through the D register. Therefore, this module of the 1802 is of extreme importance and the test program will exercise this module fully as an initial starting point. Next, the uniqueness and functionality of the 16-bit by 16-bit register array will be proven. Arithmetic and Logical instructions will be tested next followed by the Branch and Skip instructions.

A unique feature of the 1802 is a built-in DMA feature which uses an internal register as a counter for the number of bytes transferred to or from memory. This feature is evaluated for both the DMA in and

DMA out modes of operation. The Interrupt feature is verified for proper operation and also tested for its masking capability.

## D Register

The importance of the $D$ register is its function of being the path by which to load or store contents of the scratch pad register array via the data bus and as a working register of the arithmetic logic unit. The initial phase of the test on this register is to ensure the ability to load worst case data patterns in the $D$ register and also store the same.

Execution of this test consists of a series of load instructions to walk a 1 through a field of 0's and a 0 through a field of l's, each load instruction being followed by a store to verify the load operation.

## Register Array

The purpose of the register array is to provide a program counter, 16-bit vectored interrupt address storage, DMA address counter, and general purpose scratch pad registers. The initial test on this module consists of a series of instructions to verify that each register can be loaded to worst case data patterns and that each register can be accessed for the retrival of this information. All input and storage of data patterns to the register array will take place through the D
register. An important point is that at all times one of the 16 registers is being utilized as a program counter, as determined by the value in the 4-bit $P$ register. Upon initial start-up and reset of the 1802 , the $P$ register is reset to 0 , making $R(0)$ the current program counter. Therefore registers $R(1)$ through $R(15)$ are tested first and then the SET $P$ instruction must be executed to change the register being used as the program counter. Register $R(0)$ is then tested in the same manner as the others. Due to the use of $R(0)$ as a program counter during this exercise, $R(0)$ should be stored through the $D$ register at the completion of this test to check that it has been incrementing during the execution of the test. Then a test sequence which loads and stores worst case data patterns can be executed. The actual test sequence of loading and storing data patterns in the register array should use different data such that the uniqueness of each register is proven.

The next portion of the Register Array test will verify operation of the increment and decrement instructions, INC and DEC.

The procedure is to verify that each of the 16 registers of the register array can increment and decrement throughout the entire range of 0 to $2^{15}-1$. Also to be verified is the over and underflow characteristics of each register. Registers $R(1)$ through $R(15)$ are to be tested first with $R(0)$ acting as the program counter. Then $R(0)$ is tested with $\mathrm{R}(1)$ as the program counter. The test procedure is as
follows:

1. Reset device.
2. Load registers $R(2)$ through $R(15)$, each with a distinct data pattern.
3. Load register $R(1)$ with 0 and using the increment $N$ instruction, cause this register to increment from 0 to $2^{15}-1$. Then execute the increment instruction an additional time to cause $R(1)$ to overflow to 0. Each increment instruction should be followed by PUT low register $N$ and PUT high register $N$ instructions to verify the increment.
4. At the completion of step 3, all other registers should be stored on the data bus to verify that no destructive interaction has occurred.
5. The decrement register $N$ instruction is now executed to cause register $R(1)$ to decrement from 0 to $2^{15}-1$, and then to 0 . Again, each decrement instruction is followed by a PUT low register $N$ and PUT high register $N$ instruction to verify each decrement.
6. Registers $R(2)$ through $R(15)$ are now read onto the data bus to verify no destructive interaction.
7. This process is repeated until registers $R(1)$ through $R(15)$ have been tested.
8. A SET $P$ instruction is executed to change the current program counter from $R(0)$ to $R(1)$.
9. Register $R(0)$ is stored on the data bus and its present contents verified.
10. $R(0)$ is loaded to. 0 and the same procedure is followed for verification as described above.
$x$ Register

The purpose of the $X$ register is to hold a four bit code used to designate one of the 16 registers of the register array for use in certain load and store instructions. Upon initial reset of the MPU, this register is reset to 0 and then may be loaded to another value by the SET $X$ instruction. Proper verification of the operation of this register is to reset the MPU, and execute a load via $X$ or store via $X$ instruction. The value which will appear on the address bus will be the contents of register $R(0)$ which is also the current contents of the program counter as a reset will clear the $P$ register to 0.

At this point the SET $X$ instruction is executed to designate $R(1)$ and the load via $X$ or store via $X$ instruction executed. This process is repeated until all registers have been designated by the $X$. register. It is important to note that all registers should be loaded to different values in order to prove that the $R(X)$ register is actually present on the address bus.

## PRegister

The $P$ register is used to hold a four bit code used to designate
which of the 16 registers of the register array is the current program counter. The verification of the register operation is performed in a similar manner to that of the $X$ register.

The device is reset, which should clear the $P$ register and register $R(0)$ to 0 .

The initial portion of this program after reset should load the register array such that each register contains a different value. By doing this, each register can be uniquely identified as it is gated to the address bus. After verification of $R(0)$ as the program counter the SET P instruction should be executed to change the current program counter from $R(0)$ to $R(1)$ and the address bus monitored. All remaining values of the $P$ register are verified in the same manner.

## Q Register

The Q register is a l-bit register which can be set or reset under program control. The Q register bit is also cleared after an initial clear is performed. Also, the status of this bit can be tested by several of the branch instructions. However, this portion of the $Q$ register test will not utilize the branch instruction as a part of the test.

The 1802 is initially cleared and the Q bit tested for the logic 0 state. The SET $Q$ instruction is executed and then reset, the state of
the Q bit being tested after each operation. This procedure can be repeated several times to ensure proper operation.

## Arithmetic Logic Unit

The test of the arithmetic logic unit is divided into two sections, the logical operations and the arithmetic operations. Also all addressing modes included in this portion of the instruction test are verified together with the operation of the DF flag.

## Logical Instruction Test

The purpose of this test is to verify that all logical instructions are operational and that worst case data patterns have no effect on functionality of the device.

For the instructions of OR, Exclusive OR, and AND, worst case data patterns are defined as those patterns that cause each bit in the result to be either set or reset according to the instruction being tested. Examples are illustrated in Figures 18, 19, and 20.

Initially the $O R$ instruction is executed with the data patterns specified. The $D$ register is loaded, the $O R$ instruction executed and the $D$ register stored on the data bus to verify the results. This test is executed twice. The first time the $O R$ instruction is used and the second time the OR IMMEDIATE instruction is used.

| Pattern 1 | Byte 1 | 10101010 |
| :---: | :---: | :---: |
|  | Byte 2 | 01010101 |
|  | Result | 11111111 |
| Pattern 2 | Byte 1 | 01010101 |
|  | Byte 2 | 10101010 |
|  | Result | 11111111 |
| Pattern 3 | Byte 1 | 11111111 |
|  | Byte 2 | 00000000 |
|  | Result | 11111111 |
| Pattern 4 | Byte 1 | 00000000 |
|  | Byte 2 | 11111111 |
|  | Result | 11111111 |
| Pattern 5 | Byte 1 | 00000000 |
|  | Byte 2 | 00000000 |
|  | Result | 00000000 |



FIGURE 19: 1802--Exclusive OR Data Pattern


The Exclusive OR, EXCLUSIVE or IMMEDIATE, AND and AND IMMEDIATE instructions are executed in the same manner.

The four shift instructions are verified using the same philosophy for worst case data patterns as for the OR and AND instructions. One of the functions of the DF bit will be used and therefore requires verification.

The procedure for verification consists of loading the $D$ register with a test pattern, executing the particular shift instruction eight times, storing the contents of the $D$ register after each instruction execution.

Verification of the proper operation of the DF bit can only be made by designing a test program such that the DF bit is left to an expected known state. This state is then used as a starting point for the next data pattern. For example, if the completion of a shift instruction has put the DF bit to a logic 1, the next shift instruction to be executed would be one that shifted the DF bit to either the least or most significant bit of the D register.

For the shift instructions, the following data patterns can be used as initial values:

Shift Right:

$$
5_{16}, A A_{16}, F F_{16}, 8 \emptyset_{16}, \emptyset_{16}
$$

Shift Right with Carry: $\quad 55_{16}, A A_{16}, F_{16}, 8 \varnothing_{16},{ }_{16} 1_{16}, \emptyset \emptyset_{16}$

Shift Left:
Shift Left with Carry:

$$
\begin{aligned}
& 55_{16}, A A_{16}, F F_{16}, 8 \emptyset_{16}, \emptyset 1_{16} \\
& 55_{16}, A A_{16}, F F_{16}, 8 \emptyset_{16}, \emptyset 1_{16}, \emptyset \emptyset_{16}
\end{aligned}
$$

Arithmetic Operations

The object of this portion of the test program on the ALU is to verify that the ALU can add, subtract, with and without a carry or borrow, respectively, detect an overflow or underflow condition via the DF bit, and that the register and immediate addressing modes are functional.

Suggested data patterns for the arithmetic instructions are as follows:

Add, Add Immediate:

$$
\begin{aligned}
& \mathrm{FF}_{16} \text { to } \mathrm{FF}_{16}, 55_{16} \text { to } 55{ }_{16}, A A_{16} \text { to } \\
& A A_{16}, \emptyset \emptyset_{16} \text { to } \emptyset \emptyset_{16}, \mathrm{~F} \text { to } \emptyset \mathrm{F}_{16}
\end{aligned}
$$

Add with Carry, $\mathrm{OD}_{16}$ to $\mathrm{CC}_{16}, \mathrm{FF}_{16}$ to $\mathrm{FF}_{16}, \mathrm{FD}_{16}$ to
Add with Carry Immediate ${ }^{89} 16$

Subtract,
Subtract Immediate

Subtract with Borrow, $F_{16}$ from $\emptyset 1_{16}, \emptyset F_{16}$ from $\emptyset F_{16}, 8 \emptyset_{16}$
Subtract with Borrow Immediate from $99{ }_{16}, 6 \emptyset_{16}$ from $7 \emptyset_{16}$

| Subtract Memory, | $\mathrm{FF}_{16}$ from $\mathrm{FF}_{16},{ }^{55}{ }_{16}$ from $A A_{16}, \mathrm{AA}_{16}$ from |
| :---: | :---: |
| Subtract Memory Immediate | ${ }^{55} 16$ |
| Subtract Memory with Borrow | , $\quad F_{16}$ from $\emptyset 1_{16}, \emptyset F_{16}$ from $\emptyset F_{16}$, |
| Subtract Memory with Borrow | Immediate $809_{16}$ from $99{ }_{16}, 69_{16}$ from $7 \emptyset_{16}$ |

Two methods exist for verifying proper operation of the DF bit during execution of these instructions. The first is to follow each add or subtract instruction by an add with carry or subtract with borrow. This second add or subtract instruction will verify the proper DF bit operation if the results are what is expected as a result of the instruction execution.

The second is to execute a shift right with carry or shift left with carry to put the value of DF into the MSB or LSB of the D register respectively. The contents of the $D$ register are now read and the MSB or LSB verified to reflect the expected state of the DF bit. This is the preferred method for several reasons. First, if a failure occurs using the first method, the cause of the failure could be that the ALU did not detect the original overflow or could not execute the add or subtract with carry. As the shift instructions have previously been verified, this mode of verification pinpoints the cause of failure.

## Branch and Skip Instructions (Long \& Short)

The branch and skip instructions are verified by causing the condition tested by the particular instruction to occur and then executing
the associated branch or skip instruction. The address bus is tested for generation of the expected branch address. Alternately, the opposite condition is verified by executing the necessary branch or skip instruction when the branch condition does not exist and verifying that the branch or skip does not execute. The conditions tested for in the branch and skip are the following:

$$
\text { Short Branch if: } \begin{aligned}
& D=\emptyset \\
& D \neq \emptyset \\
& D F=1 \\
& D F=\emptyset \\
& Q=1 \\
& Q=\emptyset \\
& E F 1=1 \\
& E F 1=\emptyset \\
& E F 2=1 \\
& E F 2=\emptyset \\
& E F 3=1 \\
& E F 3=\emptyset \\
& E F 4=1 \\
& E F 4=\emptyset \\
& \text { Always }, \text { Never }
\end{aligned}
$$

The short branch and long branch are similar with the exception that the long branch provides an absolute branch address, while the short branch provides an address which is 0 to +255 locations from the address containing the short branch instruction. The conditions tested
for the long branch instruction is limited to the states of the $D$ register, DF bit, and Q bit. Specifically these are:

Long Branch if: | $D=\emptyset$ |
| :--- |
| $D \neq \emptyset$ |
| $D F=1$ |
| $D F \neq 1$ |
| $Q=1$ |
| $Q \neq 1$ |
| Always, Never |

The skip instructions are similar to the branch instructions except no branch address is required. The conditions tested are as follows:

$$
\begin{array}{ll}
\text { Short Skip: } & \text { Never } \\
\text { Long Skip: } & \text { Always } \\
\text { Long Skip if: } & D=\emptyset \\
& D \neq \emptyset \\
& D F=1 \\
& D F=\emptyset \\
& Q=1 \\
& Q=\emptyset \\
& I E=1
\end{array}
$$

## Interrupt

The response of the 1802 to an asychronous Interrupt is tested by causing the Interrupt input to become active and verifying that the following states occur:

1. The instruction in process at the time of interrupt is completed.
2. The next machine cycle is a normal fetch except the address gated to the address bus is from register $R(1)$.
3. The $X$ register has been set to $210^{\circ}$
4. The state codes indicate Interrupt recognition.
5. The IE enable bit has been reset by causing the Interrupt input to indicate additional Interrupts and verifying that they are ignored.
6. The values of registers $X$ and $P$ have been saved in the $T$ register. (This can be accomplished by execution of a MARK isntruction).
7. The Interrupt mode of operation is asynchronous by repeating the test in every clock cycle of instruction execution.

DMA-In-0ut

The DMA-In-Out features are tested in a manner similar to that of the Interrupt with all expected activities verified.
$\overline{\text { DMA In }}$

1. $\overline{D M A-I N}$ is caused to become active.
2. At the completion of the present instruction, verify the state codes indicate $\overline{\mathrm{DMA}-\mathrm{In}}$, register $\mathrm{R}(0)$ is gated to the address bus and $\overline{M W R}$ is active.
3. Item 2 is repeated for as long as $\overline{\mathrm{DMA}-\mathrm{In}}$ remains active, with register $R(0)$ being incremented after each transfer.
4. Normal program execution is resumed when $\overline{\overline{D M A}-\mathrm{In}}$ becomes in-active.
$\overline{\text { DMA-Out }}$
5. $\overline{\mathrm{DMA}-0 \mathrm{O}}$ is caused to become active.
6. At the completion of the present instruction execution, the state codes indicate $\overline{\mathrm{DMA}-0 \mathrm{Ot}}, \overline{\mathrm{MRD}}$ is active, and register $\mathrm{R}(0)$ is gated to the address bus.
7. Item 2 is repeated for as long as $\overline{\text { DMA-Out }}$ is active.
8. Normal program execution is resumed when $\overline{\mathrm{DMA}-0 \mathrm{Ot}}$ becomes in-active.

At this point, the priority of the previous tests should be verified such that a DMA and Interrupt request occur simultaneously. The order of priority is DMA-In first, $\overline{\text { DMA-Out }}$ second, and Interrupt last.

Input/Output Transfers

The test to verify the input and output instruction capability of the 1802 is performed separately for proper operation. Each instruction should be executed with all possible combinations of I/O device selections, testing for proper access of the least three significant bits on output pins $N O, N 1$, and $N 2$, and the contents of register $R(X)$ being

## VI. DC TEST REQUIREMENTS

Although the major portion of this report has been devoted to testing of the functional characteristics of microprocessor units, the importance of $D C$ testing should not be de-emphasized. As with other semiconductor devices, microprocessor units malfunction as a results of DC characteristics being out of specification. Therefore, it is recommended that any complete test on a microprocessor unit include verification of the manufacturers specified DC characteristics.

The commonly specified DC parameters are input and output voltage levels, input and output currents and leakages, tristate leakage currents, power supply voltages and power supply currents. Proper verification and/or measurement of each parameter should be performed, simulating the necessary condition for accurate test execution. Refer to Attachment I for DC specifications of each device.
VII. SURVEY SUMMARY
A. List of Companies Interviewed

Advanced Micro Devices, Sunnyvale, California
American Micro Systems, Incorporated, Cupertino, California
Boeing Aerospace, Seattle, Washington
Burroughs Corporation, Pasadena, California
Chrysler Corporation, Hunstville, Alabama
Fairchild Systems \& Technology, San Jose, California
General Electric Company, Pittsfield, Massachusetts
Hewlett Packard, Palo Alto, California
Hughes Aircraft Corporation, Culver City, California
Intel Corporation, Santa Clara, California
Motorola, Austin, Texas
Motorola, Phoenix, Arizona
National Semiconductor, Santa Clara, California
RCA, Sommerville, New Jersey
Rockwell International, Anaheim, California
Tektronics, Beaverton, Oregon
Texas Instruments, Houston, Texas
B. REVIEW OF PRESENT MICROPROCESSOR TEST TECHNIQUES QUESTIONNAIRE

## I. TEST EQUIPMENT

A. Tester (Which Device on Which Tester)
B. Clock Speed of Tester
C. Burn-in Equipment

1. Type Used
2. Static
3. Dynamic
4. What Type
II. DC TEST (PRODUCTION)
A. Parameters Tested
5. What DC Parameters Are Tested
6. Are Voltage Measurements Done DC Static or Functional
7. IF DC, How Long Is Sample
8. IF AC, Is VOH and VOL Measured One Pass or Two Pass
B. Execution Time (Delete Overhead)
C. Overhead Time
D. Percentage of Total Test Program
E. Differences Between Wafer and Final Package DC Tests
F. Type of Failures Observed
III. FUNCTIONAL TESTS (PRODUCTION)
A. Test Pattern
9. Method of Generation
10. Instruction Sequence (What Do. They Test For)
a. Modular
b. Other
11. Gold Device
a. As A Comparison Test
b. As A Learn Method
c. Self Diagnostic (Board Test)
12. Pattern Length
13. Pattern Sensitivity
14. Frequency of Testing Device Output(s)
a. Each Cycle
b. End of Operation
c. Other
B. Functional Test Conditions
15. Device Timing
16. AC Parameters
a. Rise/Fall Times
b. Minimum Pulses
c. Access Times
17. Execution Time (Delete Overhead)
18. Overhead Time
19. Error Analysis
a. Why Device Failed
b. What Instruction
c. What Data Pattern
d. What $\operatorname{Pin}(s)$
C. Percentage of Total Test Program :
D. Types of Failures Discovered
E. Differences Between Wafer and Final Package Functional Test Programs
IV. CHARACTERI ZATION EFFORTS
A. Parameters Characterized
20. Functional and $A C$
21. DC
B. Temperature Conditions
C. Burn-in Conditions
D. Form of Characterization Data Log
22. Histogram
23. Shmoo Plot
24. Other
E. Number of Devices Characterized
F. Department Responsible for Characterization
V. PRODUCTION TESTING
A. Temperature Conditions
25. Hold, Cold, Ambient

2: If Not Done, Why
B. Burn-in Conditions

1. What Temperature
2. $A C$ or Static
3. What Loads
4. If Not Done, Why
C. Data Logging
5. Bin Classification
6. Hardcopy
a. What Is Obtained
D. Location Performed
E. Percentage of Devices Screened
F. Department Responsible for Production Testing
G. 38510 Specification--Yes/No (If Yes, Who Wrote It)
H. Types of Failures
VI. WHAT TYPE OF PROBLEMS ARE YOU FINDING
VII. RECOMMENDATIONS FOR USER TESTING OF MICROPROCESSORS
C. QUESTIONNAIRE RESPONSES
7. TEST EQUIPMENT
A. Tester

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Fairchild Sentry II | 2 | 1 |  | 1 |  |
| 2. Fairchild Sentry 600 | 2 | 2 |  |  |  |
| 3. Macrodata MD-154 |  |  |  |  | 1 |
| 4. Tektronics S-3260 | 3 | 1 |  | 1 |  |
| 5. Teradyne J277 | 1 |  |  |  |  |
| 6. Teradyne J283 |  |  |  | 1 | 1 |
| 7. Teradyne J293 |  |  |  | 1 |  |
| 8. In-House System |  |  | 1. |  | 1 |

B. Burn-In Equipment

| RESPONSE | DEVICE |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Blue M | 1 |  | 1 | 1 |  |
| 2. In-house Design | 5 | 1 |  | 3 |  |
| 3. Commercially Available | 1 | 1 |  |  |  |
| 4. Not Being Performed |  |  |  |  | 1 |

II. DC TESTS (PRODUCTION)
A. Parameters Tested

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. All. Data Sheet Parameters <br> 2. All Data Sheet Parameters Plus Several Unspecified Parameters | 5 | 2 1 | 1 | 3 | 1 |

B. Voltage Measurements, Static or Dynamic

| RESPONSE | DEVICE |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 2. Static | 4 | 2 |  |  |  |
| 3. Clocked Very Slow |  |  |  |  |  |
| (Considered Static) |  |  |  |  |  |
| 4. Static Where Possible |  |  |  |  |  |
| Dynamic Otherwise |  |  |  |  |  |

C. Length of Sample Time, If Voltage Measurements are Static

| RESPONSE | DEVICE |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. 5 ms | 1 |  |  |  |  |
| 2. 10 ms |  |  |  |  |  |
| 3. Dependent On Parameter | 1 | 1 | 1 | 3 | 1 |
| 4. Don't Know |  |  |  |  |  |

D. VOL and VOH Measurements

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. AC Measurement--Made In One Pass Using Differential Voltage Comparators. | 4 | 2 | 2 |  | 1 |
| 2. AC Measurement--Made In Two Passes. |  | 1 |  | 4 |  |
| 3. AC Measurement--Made In Separate Passes. | 2 |  |  |  |  |
| 4. DC Measurement--Made In Static Mode. |  |  |  | 1 |  |


| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. $1 / 4$ Seconds Total Test Time, Breakdown Not Available | 1 |  |  |  |  |
| 2. 2 Seconds Total Test Time, Breakdown Not Available | 1 |  | 1 |  |  |
| 3. 3 Seconds Total Test Time, Breakdown Not Available |  | 1 |  |  |  |
| 4. 3.5 Seconds Total Test Time, Breakdown Not Available |  |  |  | 1 |  |
| 5. 5 Seconds Total Test Time, Breakdown Not Available |  | 1 |  | 1 |  |
| 6. Up to 9 Seconds Total Test Time, Breakdown Not Available |  |  |  |  | 1 |
| 7. 10 Seconds Total Test Time, Breakdown Not Available |  | 1 |  |  |  |
| 8. 20 Seconds Total Test Time, Breakdown Not Available | 1 |  |  | 1 |  |
| 9. 60 Seconds Total Test Time, Breakdown Not Available | 2 |  |  |  |  |
| 10. All tests performed are engineering type tests, not production or incoming inspection oriented. | 1 |  |  | 1 | . |
| 11. Full test program not written to date, time undeterminable. | 1 |  |  |  |  |

## F. Overhead Time, DC Test Program

| RESPONSE | DEVICE |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1.10 Seconds For Hardcopy <br> Printout. |  |  |  | 1 |  |
| 2. $1 \%$ |  |  |  |  |  |
| 3. Undeterminable |  |  |  |  |  |

G. Percentage of Total Test Program

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. $0 \%$ |  |  | 1 |  |  |
| 2. $4 \%$ |  |  |  | 1 |  |
| 3. $10 \%$ | 1 |  |  |  |  |
| 4. $20 \%$ | 2 |  | 1 |  |  |
| 5. $20-30 \%$ |  | 1 |  |  |  |
| 6. $70-80 \%$ | 1 |  |  | 1 |  |
| 7. Undeterminable | 2 | 2 |  | 2 | 1 |

H. Differences Between Wafer and Final Package DC Tests

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | . 2901 | 1802 |
| 1. Wafer level tests include a 25 V Stress Test which is not done at final package. | 1 |  |  |  |  |
| 2. Wafer level DC tests are closely monitored for indications of yield relating to process parameters. Final Package is strictly Go/NoGo. |  | 1 |  |  |  |
| 3. Wafer level tests are performed with wider guardbands. |  |  | 1 | 1 |  |
| 4. None. | 1 |  |  | 1 | 1 |
| 5. Undeterminable. | 1 | 2 |  |  |  |
| 6. Not Applicable. | 3 |  |  | 2 |  |

I. Types of Failures

| RESPONSE | DEVICE |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Normal Process Related | 2 | 2 |  | 3 |  |
| Failures. |  |  |  |  |  |
| 2. Leakage Current, Temperature |  |  |  |  |  |
| Failures. |  |  |  |  |  |
| 3. Undeterminable | 2 | 1 |  |  | 1 |
| 4. No Comment | 1 | 1 | 1 | 1 |  |

III. FÜNCTIONAL TEST PROGRAM, PRODUCTION
A. Test Pattern

1. Method of Generation

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Functional Computer Simulation. <br> 2. Manual, Line by Line. <br> 3. Manual, Line by Line, Generation in Tester Assembly Language. <br> 4. Half Simulation (Learn Mode). <br> 5. Gold Device (DUT operates in parallel to known good device.). | $4$ | 2 | 1 | 2 <br> 1 | 1 |

2. Basis For the Order of uP Instruction Test Sequence

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Exercise every node. Verify operation of every instruction within specified timing requirement. Exercise adjacent nodes in Modular Approach Satisfy large user requirements. | 1 |  | 1 |  |  |
| 2. Use a Modular Approach to verify device operation. Also utilizes test engineer's experience to generate an interactive type test. | 1 |  |  |  |  |
| 3. Modular Approach using worst case instruction and data pattern sequence. | 3 |  |  |  |  |
| 4. Modular Approach designed to represent worst case operation. |  | 2 |  | 3 |  |
| 5. Test pattern developed by device designer to represent worst case operation. | 1 | 1 |  | 1 |  |
| 6. Identify all data paths, all instruction operations. |  |  |  |  | 1 |

3. Pattern Length

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. 1 K |  |  |  | 1 |  |
| 2. 2 K | 1 | 3 |  |  |  |
| 3. 2 K Clock Cycles | 1 |  |  |  |  |
| 4. 5 K |  |  |  | 1 |  |
| 5. 8 K |  |  |  | 1 |  |
| 6. 12 K | 1 |  |  |  |  |
| 7. 16 K | 1 |  |  |  |  |
| 8. 7500 |  |  |  |  | 1 |
| 9. Program Incomplete To Date | 1 |  |  | 1 |  |
| 10. No Comment | 1 |  |  | 1 |  |

4. Pattern Sensitivity

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. RAM section sensitive to a CHECKERBOARD Pattern. Results are based upon a sample space of five devices. |  |  |  | 1 |  |
| 2. ALU |  |  |  | 1 |  |
| 3. None | 6 | 3 | 1 | 2 | 1 |

5. Frequency of Testing Device Outputs

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Each Cycle, Each Pin | 5 | 3 |  | 2 | 1 |
| 2. When Determinable Data Is Expected to Be Present. | 1 |  |  |  |  |
| 3. Not Every Pin, Every Clock Cycle. The Status of a Pin is Tested Based Upon the Test Engineers Judgement. | 1 |  | 1 |  |  |
| 4. Several Instructions are Executed, Pins of Interest Are Tested. |  |  |  | 1 |  |

B. FUNCTIONAL TEST CONDITIONS

1. Device Timing, Frequency

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. 1 MHz |  | 1 |  |  |  |
| 2. 2 MHz | 1 |  |  |  |  |
| 3. 3 MHz |  |  |  | 1 |  |
| 4. 4 MHz | 1 |  |  | 1 |  |
| 5. 100 MHz |  |  |  | 1 |  |
| 6. 500 MHz |  |  |  | 1 |  |
| 7. Minimum and Maxiumum Cycle Time. | 1 |  |  |  |  |
| 8. Maximum Cycle Time, Minimum Cycle Time, Each Extreme Tested With Guardband. | 1 | 2 | 2 |  |  |
| 9. Maximum | 2 |  |  |  |  |

2. $A C$ Test Parameters

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Rise and Fall Times, Minimum Pulse Width, Access Times. | 2 | 1 |  | 1 |  |
| 2. Minimum Pulse Width's, Access Times. | 4 | 2 | 1 | 3 | 1 |

3. Functional Test Execution Times and Overhead

4. Error Analysis Information Available

\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{RESPONSE} \& \multicolumn{5}{|c|}{DEVICE} \\
\hline \& 8080 \& 6800 \& 8008 \& 2901 \& 1802 \\
\hline \begin{tabular}{l}
1. Results indicate what test, what uP instruction, what data pattern, what pin(s), although this information is not used in Go/NoGo testing. \\
2. Only Pass/Fail status. \\
3. Resulits indicate what test failed, what up instruction, what data pattern, and the pin(s) involved. \\
4. Results indicate the up instruction involved in the failure but not expected data output or what pin(s) involved. The failing test is indicated. \\
5. Results indicate what test failed and the data pattern involved. The instructions involved can be determined with a manual. \\
6. Off-line analysis, the failing pin is not displayed. \\
7. Only RAM section test results indicate what data pattern, input code and failing pin(s) status. \\
8. The capability for indicating failing test, uP instruction, data pattern, and pin(s) involved exists although it is not used in the Go/NoGo situation. \\
9. Parametric test portion indicates the test failed, functional portion indicates up instruction which failed.
\end{tabular} \& 5

1 \& 2
1 \& 1 \& 1 \& 1 <br>
\hline
\end{tabular}

5. Types of Failures Discovered

\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{RESPONSE} \& \multicolumn{5}{|c|}{DEVICE} \\
\hline \& 8080 \& 6800 \& 8008 \& 2901 \& 1802 \\
\hline \begin{tabular}{l}
1. Normal, no pattern sensitivity found. \\
2. Timing, logic error, temperature related failures. \\
3. Parts are slow, do not meet timing specifications. \\
4. Majority of failures are totally inoperative. \\
5. Package devices are mainly functional failures. \\
6. Normal type failures of \(D C\) and functional. \\
7. Normal process related failures. \\
8. Mostly functional failures. \\
9. In DC mode, leakage current is the predominant failure mode. Most failures are parts that fail within first 15 instructions. \\
10. Have only tested small amount information inaccurate. \\
11. Have not completed in-coming inspection program to date. \\
12. Information not available.
\end{tabular} \& 1
1
1
1
1
1
1 \& 1 \& 1 \& 1

1
1 \& 1 <br>
\hline
\end{tabular}

## 6. Differences Between Wafer and Final Package Functional Tests

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. No Multiple Probes on Wafer. | 1 |  |  |  |  |
| 2. Less Functional Tests at Wafer, to Identify Working Parts, do Speed Classification at Final Package. | 2 |  |  |  |  |
| 3. Final Package Tests Include More Extensive Timing and Voltage Corners To Classify Parts. |  | 2 |  |  |  |
| 4. Test Pattern Is the Same. Timing and Voltage Corners Are More Extensive to Classify Parts. |  |  |  | 1 |  |
| 5. Do No Perform Wafer Probe Except Under Special Circumstances. Test Would Be Different But Details Not Available. |  |  |  | 1 |  |
| 6. None. | 1 |  | 1 |  | 1 |
| 7. Not Applicable. | 2 | 1 |  | 1 |  |

## IV. Characterization Efforts

A. Parameters Characterized

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. All AC \& DC Parameters. | 1 |  | 1 | 3 | 1 |
| 2. All AC \& DC Parameters Except Rise \& Fall Times. | 4 | 2 |  | 1 |  |
| 3. All $A C \& D C$ Parameters <br> Plus Additional Parameters <br> Related to Process Control. | 1 |  |  |  |  |
| 4. All AC \& DC Parameters, Except Rise \& Fall Times, Data Patterns and Instruction Sequences. |  | 1 |  |  |  |


| RESPONSE 808 | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ temperature, $6-7^{\circ} \mathrm{C}$ increments, life test evaluation performed in.lieu of burn-in. | 1 |  | 1 | , |  |
| 2. At present ambient, expect to go to $80^{\circ} \mathrm{C}$ case temperature, life testing. | 1 |  |  |  |  |
| 3. Military: $-55^{\circ} \mathrm{C},-40^{\circ} \mathrm{C}, 0^{\circ} \mathrm{C}$, $25^{\circ} \mathrm{C}, 100^{\circ} \mathrm{C}, 125^{\circ} \mathrm{C}$. Commercial $0-70^{\circ} \mathrm{C}$. Burn-in at $150^{\circ} \mathrm{C}$ 40 hours minimum, $\emptyset 1, \emptyset 2$ clocked, loaded outputs. | 1 |  |  |  |  |
| 4. $-55^{\circ} \mathrm{C},-30^{\circ} \mathrm{C}$, Ambient, $85^{\circ} \mathrm{C}$, $125^{\circ} \mathrm{C}$, life testing at $125^{\circ} \mathrm{C}$, 1000-2000 hours. | 1 |  |  |  |  |
| 5. $0^{\circ} \mathrm{C} \& 70^{\circ} \mathrm{C}$, will go to $85^{\circ} \mathrm{C}$, possibly higher, no burn-in. | 1 |  |  |  |  |
| 6. $70^{\circ} \mathrm{C}$, no burn-in. | 1 |  |  |  | 1 |
| 7. Ambient, no burn-in. |  | 1 |  |  |  |
| 8. $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$, guard banded life test. |  | 1 |  |  |  |
| 9. $-55^{\circ} \mathrm{C}$ to $+25^{\circ} \mathrm{C}$, burn in at $125^{\circ} \mathrm{C}, 48$ hours, outputs loaded, $\emptyset 1, \emptyset 2$, clocked. |  | 1 |  |  |  |
| 10. $-55,30^{\circ} \mathrm{C}$, Ambient, $85^{\circ} \mathrm{C}$, $+125^{\circ} \mathrm{C}$, life test at $125^{\circ} \mathrm{C}$, dynamic, 1000-2000 hours. |  |  |  | 1. |  |
| $\begin{aligned} & \text { 11. }-55,0^{\circ} \mathrm{C}, 25^{\circ} \mathrm{C}, 70^{\circ} \mathrm{C},+125^{\circ} \mathrm{C} \\ & \text { life test at } 125^{\circ} \mathrm{C} \text {, dynamic, } \\ & 5000 \text { hours. } \end{aligned}$ |  |  |  | 1 |  |
| 12. $0^{\circ} \mathrm{C}, 70^{\circ} \mathrm{C}, 125^{\circ} \mathrm{C}$, burn-in is static, power supplied, no pattern applied, outputs loaded. |  |  |  | 1 |  |
| 13. Temperature is $-65^{\circ} \mathrm{C}$ to $+200^{\circ} \mathrm{C}$. Perform burn-in only if contract specifies. Have capability to perform all burn-in and environmental tests. |  |  |  | 1 |  |

C. Form of Characterization Data Log

D. Number of Devices Characterized

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. 6 |  |  |  | 1 |  |
| 2. 10 | 1 | 1 |  |  |  |
| 3. $12-24$ | 1 |  |  |  |  |
| 4. 20 |  |  |  | 1 |  |
| 5. 40 |  |  |  | 1 |  |
| 6. 50 | 1 |  |  |  |  |
| 7. 100 | 1 |  |  |  |  |
| 8. 500 | 1 |  | 1 |  |  |
| 9. 1400 |  | 1 |  |  |  |
| 10. Information Not Available | 1 | 1 |  | 1 | 1 |

E. Department Responsible for Characterization


## F. Method of Processing Characterization Data

| RESPONSE | DEVICE |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Automatically | 5 | 3 | 1 | 4 | 1 |
| 2. Manually | 1 |  |  |  |  |

## V. PRODUCTION TESTING

A. Temperature Conditions

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Ambient | 1 | 2 |  | 2 | 1 |
| 2. $-55^{\circ} \mathrm{C},+125^{\circ} \mathrm{C}$ Ambient | 1 |  |  | 1 |  |
| 3. $0-70^{\circ} \mathrm{C}, 125^{\circ} \mathrm{C}$, Ambient | 1 |  |  |  |  |
| 4. $70^{\circ} \mathrm{C}$ |  | 1 |  |  |  |
| 5. Commercial parts $70^{\circ} \mathrm{C}$, Military, Cold, Ambient, Hot | 1 |  | 1 |  |  |
| 6. Initial at $70^{\circ} \mathrm{C}$, plan to reduce to Ambient. | 2 |  |  |  |  |
| 7. Wafer at Ambient, final package per MD STD 883, 5004, 5005, Class C. |  |  |  | 1 | . |

B. Burn-in Conditions

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. $125^{\circ} \mathrm{C}$, dynami C , outputs loaded, performed as part of QA sampling, not normal portion of production test. |  | 2 |  |  |  |
| 2. $125^{\circ} \mathrm{C}$, dynamic, outputs loaded. | 1 |  |  | 1 |  |
| 3. At customers request only, $125^{\circ} \mathrm{C}$, static, outputs loaded. | 3 |  |  |  |  |
| 4. At customers request $125^{\circ} \mathrm{C}$ to $160^{\circ} \mathrm{C}$, dynamic, outputs loaded. |  |  |  | 1 |  |
| 5. Performed as part of $Q A$ sampling, static mode, no pattern applied, outputs loaded, $125^{\circ} \mathrm{C}$. |  |  |  | 1 |  |
| 6. Only performed if contract specifies. Have capability to do full military temperature range and dynamic type burn-in. |  |  |  | 1 |  |
| 7. Military only, $150^{\circ} \mathrm{C}, 40$ Hours minimum, $\emptyset 1, \emptyset 2$, clocked, outputs loaded. | 1 |  | 1 |  |  |
| 8. No burn-in. | 1 |  |  |  | 1 |
| 9. None at present. |  | 1 |  |  |  |

C. Datalog Format and Hardcopy

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. 6 Bins, hardcopy of Bin distribution obtained. | 1 |  |  |  |  |
| 2. Go/NoGo Testing, hardcopy of Bin count. | 1 |  |  | 3 |  |
| 3. Bin classification, hardcopy of Bin count. | 4 | 3 | 1 | ' | 1 |
| 4. Bin classification: <br> Pass, Fail, DC, Fail <br> Functional, no hardcopy obtained. |  | - |  | 1 |  |

## D. Percentage of Devices Screened

| RESPONSE | DEVICE |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
|  | 6 | 3 | 1 | 4 | 1 |

E. Department Responsible for Production Testing

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Production Operations | 1 |  | 1 |  |  |
| 2. Production Control | 1 |  |  |  |  |
| 3. Production Testing | 1 |  |  |  | 1 |
| 4. Incoming Inspection | 2 | 1 |  | 1 |  |
| 5. Product Engineering | 1 | 1 |  |  |  |
| 6. Manufacturing Engineering | - | 1 |  |  |  |
| 7. Bipolar Microprocessor Department |  | - |  | 1 |  |
| 8. Quality Assurance |  |  |  | 1 |  |
| 9. Operations Department |  |  |  | 1 |  |

## F. Use of 38510 Specification

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Are testing to what the 8080, 38510 is anticipated to contain. | 1 |  |  |  |  |
| 2. Are testing to in-house version of 38510 , specification for 8080, written by Quality Assurance Department. | 1 |  |  |  |  |
| 3. None--an in-house specification is used which parallels a class $C$ military specification. | 1 |  |  |  |  |
| 4. Are using 38510 slash sheet. |  | 1 |  |  |  |
| 5. Use in-house version of 38510. |  |  | . | 1 |  |
| 6. Will generate in-house version. |  |  |  |  | 1 |
| 7. None | 3 | 2 |  | 1 |  |

## G. Types of Functional Failures

| RESPONSE | DEVICE |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 8080 | 6800 | 8008 | 2901 | 1802 |
| 1. Totally inoperative parts, functionally. | 1 |  |  |  |  |
| 2. Normal process and packaged related failures. | 1 |  |  | 1 |  |
| 3. Package devices are predominantly functional failures. | 1 | 1 |  |  |  |
| 4. $D C$ tests are predominantly leakage failures; functional failures are parts that wholly inoperative. |  |  |  |  | 1 |
| 5. No data available. | 2 | 2 |  | 2 |  |
| 7. No comment. | 1 |  | 1 | 1 |  |

## VI. Iypes of Problems Encountered in Testing Microprocessors

The problems being encountered in the testing of microprocessors do not reflect upon an individual microprocessor but rather the concept of testing a central processing unit intergrated on one LSI chip. The following is a summary of all comments received.

The range of problems encountered in testing microprocessors is best presented by establishing a categorical list derived from both manufacturer's and user's. These problems are:

1. None
2. Time Involved
3. Money Expenditures
4. Knowledge of Device
5. User Understanding of Device Operation and Application
6. Appreciation of Total Efforts
7. Test Equipment
8. Accurate Technical, Information on Device

## Item 1

Four (4) interviewers stated that no one area of testing presented unusual problems or problems considered to approach the limits of present test technology.

## Item 2

The time factor encompasses all aspects of testing microprocessors. This includes test time, preparation of the total test program (production and characterization) and analysis of test results.

## Item 3

The amount of monies involved in testing includes capital expenditures for equipment and program development.

Item 4 \& 8

Before the device can properly be tested complete knowledge of the microprocessor is essential. Users are of the opinion that this effort is hindered by a lack of adequate technical information concerning device operation including accurate timing and instruction operations.

Item $5 \& 6$

User's who test microprocessors for outside companies and in-house departments are finding that those people responsible for management of these tasks do not appreciate the total effort of testing. The device application is often not fully stated, nor, is the complexity of the test hardware and software requirements understood.

## Item 7

Only one interviewer indicated that presently available test equipment posed a problem in testing. This conment concerned the speed of test equipment with respect to test time. However, the time involved in preparing test programs as viewed from an ease of program development standpoint and the actual test time due to test system overhead requirements can also be considered a valid criticism under this heading.

## Item 8

All user's except one stated that existing technical information about specific device operation is not sufficient. Additional information is needed which will accurately define total device operation in terms of timing and instruction execution.

## VII. Recommendations for User Testing

Recommendations for user testing were found to touch upon just about every aspect of testing, ranging from determining the extent of testing required to tips on test program structure.

Collating all the comments gathered results in the following summary.

First, determine the nature of the MPU testing problem from consideration of such factors as application, reliability requirements, and money available.

The results of this study should then indicate the capabilities of the test system to be used including hardware/software trade-offs, ease of use, DC and AC test capabilities and provision of test result analysis. Test equipment possibilities also include the end product system or a uP development system, in addition to the option of designing a system in-house. Another alternative is to not buy test equipment but use a testing laboratory instead.

Overall test philosophy should be defined as early in the process as possible with the key objective of being as thorough as possible within the confines of times, money, and manpower available.

The actual test program should retain the objective of thoroughness
by functional verification of each module of the device followed by an interactive type test to insure that there is no module-to-module destruction of data. If possible, the test scheme should be designed such that modifications are easily installed at some later time.

Be prepared for the time and money expenditures that will be necessary for the design and implementation of a thorough testing plan. Additional considerations to be included are resources for providing facilities for the test equipment and personnel to operate and maintain these items.

The following instruction sequence sensitivities, module weaknesses, or failures were either described during the study conducted and/or detected by Macrodata Corporation during its characterization of the device prior to this contract. All problems described that were verified by Macrodata have been reported to the manufacturer(s). In all cases, parts manufactured after reporting the problem areas did not exhibit these characteristics.

Verified By
Device Problem
Macrodata

8080 1. It was detected on some devices that the $\emptyset 1$ Yes clock cross couples noise that exceeded the threshold level on the HLDA input 1 ns .
2. When running a test similar to the one Yes described for the program counter, certain devices would fail to respond to a reset pulse every time.
3. When performing a test similar to the test Yes described for the register array, some devices showed a sensitivity to $H \longrightarrow B$ and $H \longrightarrow D$ transfers when the 5 MSB's, in the data sequence were all l's.
4. Not all manufactured parts operate exactly Yes alike. One 8080 will not execute a program

Device
Problem
instruction identical to that of another manufacturers part. The main differences lies in the execution of arithmetic instructions in that status flag operation is not always identical from one manufacturer to another. This difference between parts produced by different manufacturers still is present.

8008 1. It has been detected that if an instruction Yes sequence which causes the stack registers to perform push and pop operation is repeated multiple times, the device fails to operate. This was not detected on any other area within the device.
2. Some of the fail devices operated correctly No for a short period of time, but after a period of time the devices would fail to operate. This period of time was around 5 to 10 seconds. Once the device failed, it would not ever become operational again, even if power was removed and reapplied. The device became a total failure.

## Problem

2901 1. The "A" output.latch for the RAM would change state on some devices that were operated at a slightly elevated temperature and voltage (still within specification). The problem was detected by shifting a binary pattern of 1110 into the RAM and holding this pattern and then addressing another location with a pattern of 1111 , but not clocking this pattern into the latch. The parts that exhibited this sensitivity showed that the output latch value changed from a 1110 pattern to a 1111 pattern.
2. Some parts that have been tested showed a sensitivity to a CHECKERBOARD pattern on the RAM.
3. Not all parts will operate at their rated Yes speed. Newer versions of these devices do not exhibit this problem.
4. It has been reported that the ALU section has shown some kind of sensitivity to either data, instruction, or a combination of the two. This sequence was not defined, so this failure could not be verified.
Device ProblemMacrodata
6800 \& No problems were reported on these parts
1802 other than normal manufacturing process
problems, which were detected by the ..... 1
manufacturers. User's reported no
extensive testing on either of thesedevices, therefore, no errors werereported by them.

## IX. TEST EQUIPMENT

DC Requi rement

1. Voltage/Current Force Function

Voltage Force Range $=0$ to $\pm 15$ Volts
It is recommended that there should be two ranges within this total range.

Accuracy > . $7 \%$ of Full Scale
Current Force Range $=500 \mathrm{pa}$ to 50 ma
This range should be divided into at least three ranges.

Accuracy > . $7 \%$ of Full Scale
2. Voltage/Current Measurement

Voltage Measurement $=+15$ Volts to -5 Volts
Recommended at least two ranges.

Accuracy > . $3 \%$ Full Scale
Current Measurement $=500$ pa to 300 ma
Recommended ranges: 2 uA Full Scale, $20 \mathrm{uA}, 200 \mathrm{uA}, 2 \mathrm{ma}, 20 \mathrm{ma}$, 300 ma.

Accuracy - 0.5\% Full Scale

## Power Supplies

Three Device Bias Supplies Plus Ground

Voltage Range $= \pm 15$ Volts
Current Range $=300 \mathrm{ma}$, Minimum
Accuracy $=0.2 \%$ of Set Voltage for Testing

AC Voltage Requirements

Logical input voltage swing: +15 Volts to -1.5 Volts, Maximum

This voltage should be variable in 10 mV increments throughout the range.
+15 V --------------------
$-1.5 \mathrm{~V}$ $\qquad$

Logical output voltage detection: +15 Volts to -1.5 Volts, Maximum This voltage should be variable in 10 mV increments throughout the range.

It is recommended that the output sampling circuit be able to detect both a VOL and VOH voltage simultaneously. This will allow for a functional test measurement in one pass.

## Timing Requirements

It should be noted that all timing edges produced for input or output timing are required to be synchronized to one master clock generator.

Input

Clock Frequency $=10 \mathrm{MHz}$ to DC .

Minimum Clock Pulse Width $=20 \mathrm{~ns}$.
Clocks required $=2$ Minimum - Device Clocks
1 Minimum - Data Bus Clock
1 Minimum - Data Bus I/O Control
2 Minimum - Control Signals for Setup and Hold Time Measurements

Timing edge should be capable of being variable in 1 ns increments.

Minimum of one output comparator strobe with both edges variable in 1 ns increments. Strobe positioning should vary over the complete clock input cycle.

With only one comparator strobe it will be required to make more than one functional test on the devices. This is required to verify all output timing of the particular devices.

## Tester Configuration

To generate the basic patterns to test the microprocessor that have been previously described the following tester would be required. Figure 21 illustrates the block diagram of a basic tester.

Mass storage, such as disc, or extended RAM or shift register memory is used to store total test patterns.

A high-speed storage media consisting of high-speed RAM or shift register memory (minimum of 1 K deep $\times 48$ wide) is used to hold portions of total test pattern. Overlay of this memory is required from the mass storage medium.

The Pattern Control and Sequence control logic allows repetition of the same teṣt pattern or series of patterns to reduce total test pattern size and enable performance of tests that would otherwise not be possible due


Figure 21: Basic Tester Black Diagram
to size of test pattern. The capability to allow real time error interrupt is also provided.

The Interface logic provides the necessary formatting of signals to DUT including voltage and timing levels and signal format in addition to the capability of holding a test pattern on the device while the highspeed storage media is overlayed by the mass memory.

The Error Detect circuit compares the output of the device under test with the previously stored output response pattern, alerting the pattern control and sequencer module of error conditions.

This basic system can be developed by a company whose testing requirements necessitate the use of such a system. Because of the design variations for the different microprocessors, a project of this type can become costly and time consuming. Since at least three test equipment manufacturers produce equipment that can perform the described test, it is recommended that a company consider purchasing this type of system from a commercially available supplier. Companies that produce this type of equipment are:

| Fairchild Systems | Macrodata Corporation | Tektronic Systems |
| :--- | :--- | :--- |
| San Jose, CA | Woodland Hills, CA | Beaverton, OR |

## Software Requirements

section can be itemized as follows: .

1. Disc Operating System
2. Test System Executive Program
3. Microprocessor Test Pattern Development Program

Discussion

In order to efficiently store the large quantities of test data necessary to execute the tests previously described, a magnetic disc based computer system was chosen. The use of the disc requires a sophisticated computer program to control storing and retrieval of information to and from the disc. Programs of this type are available from the manufacturer of the computer chosen for use and can be incorporated in the total system software by the manufacturer of the test system. The user also has the option of designing his own program. The test system Executive Program is a custom computer program designed and developed specifically by the manufacturer of the test equipment. The elements of such a program are many. First, a test system language must be developed to allow the user to easily develop test programs for a wide variety of devices. Additional necessary programs are Editor, List, and Assembly programs.

An Editor program is one which allows the user to modify existing programs in source language. List programs output the entire source or object code contents of a test program to a peripheral medium (line printer or video terminal) to allow examination of the contents of a program. The

Assembly Program converts the source statements of a test program to a binary object code which is understandable by the computer. An Executive Program must be able to initiate to the different modules of the test system for storage and retrieval of information in addition to controlling their activities.

The Microprocessor Test Pattern Development Program is designed to simplify the development of the test patterns previously described. The most desirable and accurate form of this program would be one which would completely simulate the microprocessor from an input string consisting of mnemonics and data patterns. The total output of such a program is a clock cycle by clock cycle definition of all input and output pins of the microprocessor in response to the defined input instructions. This program also includes test system control data such as when to input microprocessor instructions and data patterns and also when to test the output pins. If the test system cannot accomodate testing of all device outputs simultaneously, several versions of the test pattern are necessary to completely verify each device pin.

The test required for qualification of the device should include:

1. All functional and $D C$ tests as previously described.
2. Each functional module test should be verified over the complete voltage operating range of the device. The best means to do this is to generate shmoo plots which plot voltage (VDD, VBB, etc.) versus timing parameters and also voltage versus voltage.
3. All AC timings specified in the manufacturers data sheet should be verified. Again, the best method is shmooing voltage versus each individual timing parameter and other voltages. Voltage should be varied over the complete specification range.
4. Qualification should consist of testing the device over the manufacturers full temperature range. Recommended temperatures are $+125,+70,+25$, $\emptyset$, and $-55^{\circ} \mathrm{C}$. All manufacturers do not perform this test except for normal AQL sampling.
5. An extensive burn-in program should be performed since manufacturers only perform this upon specific request from a customer. A recommended burn-in program should be at least 160 hours at $125^{\circ} \mathrm{C}$ with elevated voltages. Also, random dynamic signals should be applied continuously during the burn-in cycle. This is only a recommendation since further
performed on the subject of microprocessor burn-in procedures.
6. All DC specifications on the device should also be varied over the complete voltage range of the device. Again, using the shmoo plot method is recommended.

A $100 \%$ screening test should be based on the results from the qualification test. This test should include:

1. Testing each functional module as previously described at upper and lower power supply limits and all combinations.
2. Testing all manufactures $D C$ parameters.
3. If the device is to be used over the complete military temperature range, the test should be performed at $+125,+25$, and $-70^{\circ} \mathrm{C}$.
4. A burn-in conditioning should be conducted as previously recommended.
5. Only critical timing should be verified in order to reduce test time. These should include minimum clock pulse width, clock frequency, and access time.

ATTACHMENT 1

## 8080A FUNCTIONAL PIN DEFINITION

The following describes the function of all of the 8080A 1/O pins. Several of the descriptions refer to internal timing periods.
$A_{15} . A_{0}$ (output threo-state)
ADDRESS BUS; the address bus provides the address to memory (up to 64 K 8 -bit words) or denotes the $1 / O$ device number for up to 256 input and 256 output devices. $A_{0}$ is the least significant address bit.
$D_{7} \cdot D_{0}$ (input/output three-state)
DATA BUS: the data bus provides bi-directional communication between the CPU, memory, and 1/O devices for instructions and data transfers. Also, during the first clock cycle of each machine cycle, the 8080 A outputs a status word on the data bus that describes the current machine cycle: $\mathrm{D}_{0}$ is the least significant bit.

## SYNC (output)

SYNCHRONIZING SIGNAL; the SYNC pin provides a signal to indicate the beginning of each machine cycle.

DBIN (output)
DATA BUS IN; the DBIN signal indicates to external circuits that the data bus is in the input mode. This signal should be used to enable the gating of data onto the 8080A data bus from memory or I/O.

## READY (input)

READY; the READY signal indicates to the 8080A that valid memory or input data is available on the 8080A data bus. This signal is used to synchronize the CPU with slower memory or 1/O devices. If after sending an address out the 8080A does not receive a READY input, the 8080A will enter a WAIT state for as long as the READY line is low. READY can also be used to single step the CPU.

## WAIT (output)

WAIT; the WAIT signal acknowledges that the CPU is in a WAIT state.
$\overline{W R}$ (output)
WRITE; the $\overline{W R}$ signal is used for memory WRITE or I/O output control. The data on the data bus is stable while the WR signal is active low $(\overline{W R}=0)$.
HOLD (input)
HOLD; the HOLD signal requests the CPU to enter the HOLD state. The HOLD state allows an external device to gain control of the 8080A address and data bus as soon as the 8080A has com. pleted its use of these buses for the current machine cycle. It is recognized under the following conditions:

- the CPU is in the HALT state.
- the CPU is in the T2 or TW state and the READY signal is active. As a result of entering the HOLD state the CPU ADDRESS BUS ( $A_{15} \cdot A_{0}$ ) and DATA BUS ( $D_{7} \cdot D_{0}$ ) will be in their high impedance state. The CPU acknowledges its state with the HOLD AC. KNOWLEDGE (HLDA) pin.

HLDA (output)
HOLD ACKNOWLEDGE: the HLDA signal appears in response to the HOLD signat and indicates that the data and address bus


## Pin Configuration

will go to the high impedance state. The HLDA signal begins at:

- T3 for READ memory or input.
- The Clock Period following T3 for WRITE memory or OUT. PUT operation.
In either case, the HLDA signal appears after the rising edge of $\phi_{1}$ and high impedance occurs after the rising edge of $\phi_{2}$.


## INTE (output)

INTERRUPT ENABLE; indicates the content of the internal interrupt enable flip/flop. This flip/flop may be set or reset by the Enable and Disable Interrupt instructions and inhibits interrupts from being accepted by the CPU when it is reset. It is automatically feset (disabling further interrupts) at time $T 1$ of the in. struction fetch cycle (M1) when an interrupt is accepted and is also reset by the RESET signal.

## INT (input)

INTERRUPT REQUEST; the CPU recognizes an interrupt request on this line at the end of the current instruction or while halted. If the CPU is in the HOLD state or if the Interrupt Enable flip/flop is reset it will not honor the request.

RESET (input)(1)
RESET; while the RESET signal is activated, the content of the program counter is cleared. After RESET, the program will start at location 0 in memory. The INTE and HLDA flip/flops are also reset. Note that the flags, accumulator, stack pointer, and registers are not cleared.

| $V_{S S}$ | Ground Reference. |
| :--- | :--- |
| $V_{D D}$ | $+12 \pm 5 \%$ Volts. |
| $V_{\mathrm{CC}}$ | $+5 \pm 5 \%$ Volts. |
| $V_{\mathrm{BE}}$ | $-5 \pm 5 \%$ Volts (substrate bias). |
| $\rho_{1} . \Phi_{2}$ | 2 externally supplied clock phases. (non TTL compatible) |

## 8080A FUNCTIONAL PIN DEFINITION

The following describes the function of all of the 8080A l/O pins. Several of the descriptions refer to internal timing periods.
$A_{15} A_{0}$ (output three-state)
AODRESS BUS; the address bus provides the address to memory (up to 64 K 8 -bit words) or denotes the I/O device number for up to 256 input and 256 output devices. $A_{0}$ is the least significant address bit.
$D_{7} \cdot D_{0}$ (input/output three-state)
DATA BUS; the data bus provides bi-directional communication between the CPU, memory, and I/O devices for instructions and data transfers. Also, during the first clock cycle of each machine cycle, the 8080A outputs a status word on the data bus that describes the current machine cycle. $\mathrm{D}_{0}$ is the least significant bit.
SYNC (output)
SYNCHRONIZING SIGNAL; the SYNC pin provides a signal to indicate the beginning of each machine cycle.

DBIN (output)
DATA BUS IN; the DBIN signal indicates to external circuits that the data bus is in the input mode. This signal should be used to enable the gating of data onto the 8080A data bus from memory or I/O.

## READY (input)

READY; the READY signal indicates to the 8080A that valid memory or input data is available on the 8080A data bus. This signal is used to synchronize the CPU with slower memory or $1 / 0$ devices. If after sending an address out the 8080A does not receive a READY input, the 8080A will enter a WAIT state for as long as the READY line is low. READY can also be used to single step the CPU.

## WAIT (output)

WAIT; the WAIT signal acknowledges that the CPU is in a WAIT state.

## $\overline{W R}$ (output)

WRITE: the $\overline{W R}$ signal is used for memory WRITE or I/O output control. The data on the data bus is stable while the $\overline{W R}$ signal is active low ( $\overline{W R}=0)$.

HOLD (input)
HOLD; the HOLD signal requests the CPU to enter the HOLD state. The HOLD state allows an external device to gain control of the 8080A address and data bus as soon as the 8080A has com. pleted its use of these buses for the current machine cycle. it is recognized under the following conditions:

- the CPU is in the HALT state.
- the CPU is in the T2 or TW state and the READY signal is active. As a result of entering the HOLD state the CPU ADDRESS BUS ( $A_{15} \cdot A_{0}$ ) and DATA BUS $\left\{D_{7}, D_{0}\right.$ ) will be in their high impedance state. The CPU acknowledges its state with the HOLD AC. KNOWLEDGE (HLDA) pin.

HLDA (output)
HOLD ACKNOWLEDGE: the HLDA signal appears in response to the HOLD signal and indicates that the data and address bus


Pin Configuration
will go to the high impedance state. The HLDA signal begins at: - T3 for READ memory or input.

- The Clock Period following T3 for WRITE memory or OUT. PUT operation.
In either case, the HLDA signal appears after the rising edge of $\phi_{1}$ and high impedance occurs after the rising edge of $\phi_{2}$.


## INTE (output)

INTERRUPT ENABLE; indicates the content of the internal interrupt enable flip/flop. This flip/flop may be set or reset by the Enable and Disable Interrupt instructions and inhibits interrupts from being accepted by the CPU when it is reset. It is auto. matically reset (disabling further interrupts) at time $T 1$ of the in. struction fetch cycle ( $M 1$ ) when an interrupt is accepted and is also reset by the RESET signal.

INT (input)
INTERRUPT REQUEST; the CPU recognizes an interrupt request on this line at the end of the current instruction or while halted. If the CPU is in the HOLD state or if the Interrupt Enable flip/flop is reset it will not honor the request.

RESET (input)(1)
RESET; while the RESET signal is activated, the content of the program counter is cleared. After RESET, the program will start at location 0 in memory. The INTE and HLDA flip/flops are also reset. Note that the flags, accumulator, stack pointer, and registers are not cleared.

| $V_{\text {SS }}$ | Ground Reference. |
| :--- | :--- |
| $V_{\text {OD }}$ | $+12 \pm 5 \%$ Volts. |
| $V_{\text {CC }}$ | $+5 \pm 5 \%$ Volts. |
| $V_{8 B}$ | $-5 \pm 5 \%$ Volts (substrate bias). |
| $O_{1} . \phi_{2}$ | 2 externally supplied clock phases. (non TTL compatible) |

## 8080 A

## absolute maximum ratings*

| Temperature Under Bias | $0^{\circ} \mathrm{C} 10+70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| All Input or Output Voltages |  |
| With Respect to $V_{\text {Bb }}$ | -0.3V $10+20 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{CC}} . \mathrm{V}_{\text {DO }}$ and $\mathrm{V}_{\text {SS }}$ With Respect to $\mathrm{V}_{\text {BB }}$ | -0.3V $10+20 \mathrm{~V}$ |
| Power Dissipation | . 5 |

"COMMENT: Stresses ahove those listed under "Absolute Maxi. mum Ratings" may cause permanent damage to the device. This is a strcss rating onlv and functional operation of the device at these or any other conditions above those indicared in the operational sections of this specification is not implicd. Ex. posure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS
$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, V_{D D}=+12 \mathrm{~V} \pm 5 \%, V_{C C}=+5 \mathrm{~V} \pm 5 \%, V_{B B}=-5 \mathrm{~V} \pm 5 \%, V_{S S}=0 \mathrm{~V}$. Unless Otherwise Noted.

| Symbol | Parameter |  |  | Min. | TYp. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{12 C}$ | Clock Input Low Voltage |  |  | $\mathrm{v}_{\mathrm{ss}}-1$ |  | $\mathrm{V}_{\text {SS }}+0.8$ | V |  |
| $\mathrm{V}_{\text {IHC }}$ | Clock Input High Voltage |  |  | 9.0 |  | $\mathrm{V}_{\mathrm{DD}}+1$ | $\checkmark$ |  |
| $V_{12}$ | Input Low Voltage |  |  | $\mathrm{v}_{\text {Ss }}-1$ |  | $\mathrm{v}_{\mathrm{ss}}+0.8$ | $v$ |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage |  |  | 3.3 |  | $\mathrm{V}_{\mathrm{cc}}+1$ | $v$ |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  |  |  |  | 0.45 | $v$ | $1 \mathrm{OL}=1.9 \mathrm{~m} \dot{A}$ on all outputs, |
| V OH | Output High Voltage |  |  | 3.7 |  |  | $\checkmark$ | $b_{H}=-150 \mu \mathrm{~A}$. |
| lod (av) | Avg. Power Supply Current (VDO) |  |  |  | 40 | 70 | mA |  |
| IcC(av) | Avg. Power Supply Current ( $\mathrm{VCC}^{\text {) }}$ |  |  |  | 60 | 80 | mA | $\mathrm{T}_{\mathrm{CY}}=.48 \mu \mathrm{sec}$ |
| $\mathrm{I}_{\text {B ( }}$ (av) | Avg. Power Supply Current ( $\mathrm{V}_{8 B}$ ) |  |  |  | . 01 | 1 | mA |  |
| $1 / 2$ | Input Leakage |  |  |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\mathrm{CL}}$ | Clock Leakage |  |  |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $V_{S S} \leqslant V_{C L O C K} \leqslant V_{D D}$ |
| ${ }_{\text {dL }}{ }^{[2]}$ | Data Bus Leakage in Input Mode |  |  |  |  | $\begin{aligned} & -100 \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \mu A \\ & m A \end{aligned}$ | $\begin{aligned} & V_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |
| $\mathrm{IfL}_{\text {f }}$ | Address and Data Bus Leakage During HOLD |  |  |  |  | $\begin{array}{r} +10 \\ -100 \end{array}$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{A D D R / D A T A}=V_{C C} \\ & V_{A D D R / D A T A}=V_{S S}+0.45 V \end{aligned}$ |
| CAPACITANCE$T_{A}=25^{\circ} \mathrm{C} \quad V_{C C}=V_{D D}=V_{S S}=0 V, V_{B B}=-5 \mathrm{~V}$ |  |  |  |  |  |  | TYPICAL SUPPLY CURRENT VS. temperature, normalized. (3) |  |
| Symbol | Parameter | Typ. | Max. | Unit | Test Condition |  |  |  |
| $\mathrm{C}_{\text {¢ }}$ | Clock Capacitance | 17 | 25 | pf | $\mathrm{f}_{\mathrm{c}}=1 \mathrm{MH}$ |  |  | - |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 6 | 10 | pf | Unmeasured Pins |  |  |  |
| Cout | Output Capacitance | 10 | 20 | pi R | Returned | to $\mathrm{V}_{\mathrm{SS}}$ |  |  |
| NOTES: <br> 8. The RESET signal musi be active for a minimum of 3 clock cycles. |  |  |  |  |  |  |  |  |

DATA BUS CHARACTERISTIC DURING DEIN


## 8080 A

A.C.-CHARACTERISTICS
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=45 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$. Unless Otherwise Noted

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{1} \mathrm{Cr}^{(3)}$ | Clock Period | 0.48 | 2.0 | $\mu \mathrm{sec}$ | $\left\{\begin{array}{l} -c_{L}=100 \mathrm{pf} \\ -c_{L}=50 \mathrm{pf} \end{array}\right.$ |
| $t_{1}, t_{1}$ | Clock Rise and Fall Time | 0 | 50 | nsec |  |
| 181 | $\phi_{1}$ Pulse Width | 60 |  | nsec |  |
| ${ }_{802}$ | $\phi_{2}$ Pulse Width | 220 |  | n sec |  |
| 101 | Delay $\phi_{1}$ to $\phi_{2}$ | 0 |  | n sec |  |
| ${ }^{1} 02$ | Delay $\phi_{2}$ to $\phi_{1}$ | 70 |  | nsec |  |
| ${ }^{10} 3$ | Delay $\phi_{1}$ to $\phi_{2}$ Leading Edges | 80 |  | nsec |  |
| ${ }^{104}$ [2] | Address Output Delay From $\phi_{2}$ |  | 200 | n sec |  |
| $100^{121}$ | Data Output Delay From $\phi_{2}$ |  | 220 | nsec |  |
| $\mathrm{rac}^{121}$ | Signal Output Delay From $\phi_{1}$, or $\phi_{2}$ (SYNC, WR,WAIT, HLDA) |  | 120 | nsec |  |
| tof 121 | DBIN Delay From $\phi_{2}$ | 25 | 140 | nsec |  |
| $t_{01}{ }^{[1]}$ | Delay for Input Bus to Enter Input Mode |  | tof | nsec |  |
| ${ }^{\text {tos }}$ | Data Setup Time During $\phi_{1}$ and DBIN | 30 |  | nsec |  |

TIMING WAVEFORMS ${ }^{[14]}$
(Note: Timing measurements are made at the following reference voltages: CLOCK " 1 " $=8.0 \mathrm{~V}$ $" 0 "=1.0 \mathrm{~V}$; INPUTS " 1 " = $3.3 \mathrm{~V}, \quad{ }^{\prime \prime} 0^{\prime \prime}=0.8 \mathrm{~V}$; OUTPUTS " 1 " $=2.0 \mathrm{~V}, " 0 "=0.8 \mathrm{~V}$. )

A.C. CHARACTERISTICS (Continued)
$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, V_{D D}=+12 \mathrm{~V} \pm 5 \%, V_{C C}=+5 \mathrm{~V} \pm 5 \%, V_{B B}=-5 \mathrm{~V} \pm 5 \%, V_{S S}=0 \mathrm{~V}$, Unless Otherwise Noted

| Symbol | Paramater | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| tos2 | Data Setup Time to $\phi_{2}$ During OBIN | 150 |  | nsec | $C_{L}=50 \mathrm{pf}$ |
| $\mathrm{IDH}^{11}$ | Data Hold Time From $\phi_{2}$ During DBIN | (1) |  | $n \mathrm{sec}$ |  |
| $\mathrm{I}_{1 E}(2)$ | INTE Output Delay From $\phi_{2}$ |  | 200 | nsec |  |
| $t_{\text {RS }}$ | READY Setup Time During $\phi_{2}$ | 120 |  | nsec |  |
| IHS | HOLD Setup Time to $\phi_{2}$ | 140 |  | nsec |  |
| $1{ }_{15}$ | INT Setup Time During $\phi_{2}$ (During $\varphi_{1}$ in Hals Mode) | 120 |  | n sec |  |
| ${ }_{1} \mathrm{H}$ | Hold Time From $\phi_{2}$ (READY, INT, HOLD) | 0 |  | n sec |  |
| $i_{\text {FD }}$ | Delay to Float During Hold (Address and Oata Bus) |  | . 120 | nsec |  |
| ${ }_{t_{A W}}(2]$ | Address Stable Prior to WR | . 151 |  | nsec |  |
| $\mathrm{low}^{[2]}$ | Output Data Stable Prior to $\overline{W R}$ | (6) |  | nsec |  |
| $7_{\text {wo }}{ }^{[2]}$ | Output Data Stable From $\overline{W R}$ | [7] |  | nsec |  |
| $t_{W A}{ }^{[2]}$ | Address Stable From WR | [7] |  | n sec | $\begin{aligned} & C_{L}=100 \mathrm{pf:} \text { Address, Data } \\ & C_{L}=50 \mathrm{pf}: \overline{\mathrm{WR}}, \mathrm{HLDA}, \mathrm{DBIN} \end{aligned}$ |
| $\mathrm{tHF}^{\text {[2] }}$ | HLDA to Float Delay | [8) |  | nsec |  |
| ${ }_{\text {IWF }}$ [2] | WR to Float Delay | [9] |  | $n$ sec |  |
| $t_{A H}{ }^{[2]}$ | Address Hold Time After DBIN During HLDA | -20 |  | nsec |  |



1. Data input should be enabled with O8IN status. No bus conflici can then occur and data hold time is assured. ${ }^{1} \mathrm{DH}$ - 50 ns or tDF. whichever is less.
2. Load Cirtuit.


TYPICAL $\triangle$ OUTPUT DELAY VS. $\triangle$ CAPACITANCE

3. The folsowing are relevent when intertacing the 8080A to devices having $V_{I H}=3.3 \mathrm{~V}$ :
a) Maximum output rise time from .8 V to $3.3 \mathrm{~V}=100 \mathrm{~ns} \oplus C_{L}=$ SPEC.
b) Output deloy when masured to $3.0 \mathrm{~V}=\mathrm{SPEC} \cdot 60 \mathrm{~ms}$ © $\mathrm{C}_{\mathrm{L}}$ - SPEC.

taw - 2 tcy -to3 -t,02-140nsec
IDW-1cr-tD3-1,o2-170niec.
H not HLOA, IWO = IWA - toj - tro2 - 10ns. It hLDA. IWD - twa = IWF.
${ }^{2} \mathrm{HF}=\mathrm{tO3} \cdot \mathrm{t}_{102}-50 \mathrm{~ns}$.
twF $=103+1,02-10 \mathrm{ni}$
Osta in must be stable for this pernod during D8IN • T3. Both iDS1 and tDS2 must be whisfiad.
fleady wignal inust be siabile for this period during $T_{2}$ or $T_{W} W$. Must be axternally ivnctionired.)
 and $\mathrm{T}_{\text {WH }}$ whon in told mode. (External ernctionsisation is not iequired.)
4. Intariugt signal muti to statio during this period of the last clock cycle of any instiuction in order to be eacognized on the following ingtiuction. (E ethrnal aynchionization is not required.l


## instruction set

The accumulator group instructions include arithmetic and logical operators with direct, indirect, and immediate addressing modes.
Move, load, and store instruction groups provide the ability 10 move either 8 or 16 bits of data between memory, the six working registers and the accumulator using direct, indirect, and immediate addressing modes.
The ability to branch to different portions of the program is provided with jump, jump conditional, and computed jumps. Also the ability to call to and return from subroutines is provided both conditionally and unconditionally. The RESTART (or single byte call instruction) is useful for interrupt vector operation.
Double precision operators such as stack manipulation and double add instructions extend both the arithmetic and interrupt handling capability of the 8080A. The ability to
increment and decrement memory, the six general registers and the accumulator is provided as well as extended increment and decrement instructions to operate on the register pairs and stack pointer. Further capability is provided by the ability to rotate the accumulator left or right through or around the carry bit.
Input and output may be accomplished using memory ad. dresses as I/O ports or the directly addressed 1/O provided for in the 8080A instruction set.

The following special instruction group completes the 8080A instruction set: the NOP instruction. HALT to stop processor execution and the DAA instructions provide decimal arithmetic capability. STC allows the carry flag to be di. rectly set, and the CMC instruction allows it to be complemented. CMA complements the contents of the accumulator and XCHG exchanges the contents of two 16 -bit register pairs directly.

## Data and Instruction Formats

Data in the 8080A is stored in the form of 8 -bit binary integers. All data transfers to the system data bus will be in the same format.

$$
\frac{D_{7} \quad D_{6}}{D_{5}} \begin{array}{lllllll} 
& D_{4} & D_{3} & D_{2} & D_{1} & D_{0} \\
\text { DATA WORD }
\end{array}
$$

The program instructions may be one, two, or three bytes in length. Multiple byte instructions must be stored in successive words in program memory. The instruction formats then depend on the particular operation executed.
One Byte Instructions
$\mathrm{D}_{7} \quad \mathrm{D}_{6} \mathrm{D}_{5} \quad \mathrm{D}_{4} \mathrm{D}_{3} \quad \mathrm{D}_{2} \mathrm{O}_{1} \quad \mathrm{D}_{0}$ OP CODE

TYPICAL INSTRUCTIONS
Register to register, memory reference, arithmetic or logical, rotate, return, push, pop, enable or disable Interrupt instructions
Two Brie Instructions

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ | OPE CODE

Immediate mode or I/O instructions
Three Byte instructions

|  | OP CODE | Jump, call or direct load and store |
| :---: | :---: | :---: |
| $D_{7} D_{6} \quad D_{5} \quad D_{4} D_{3} D_{2} D_{1} D_{0}$ | LOW ADDRESS OR OPERAND I | instructions |
| $\mathrm{D}_{7} \mathrm{O}_{6} \mathrm{D}_{5} \mathrm{D}_{4} \mathrm{D}_{3} \mathrm{D}_{2} \mathrm{D}_{1} \mathrm{D}_{0}$ | HIGH ADDRESS OR OPERAND 2 |  |

For the 8080A a logic " 1 " is defined as a high level and a logic " 0 " is defined as a low level.

## INSTRUCTION SET

Summary of Processor Instructions

| Mnemonte | Description | 07 | 06 | Imiruction Codelll |  |  |  |  |  | Clock 121 <br> Cycies | Mintmonie | Ouscription | Innturion Codill |  |  |  |  |  |  |  | Clect ${ }^{17]}$ Cyins |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| movin.p | Move cegister to cegrter | 0 | 1 | 0 | 0 | 0 | 5 | 5 | 5 | 5 | A2 | Return on reso | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | $8 / 11$ |
| moVm.t | Move register to memory | 0 | 1. | 1 | 1 | 0 | S | S | 5 | 1 | ANZ | Return on no sero | 1 | 1 | 0 | 0 | 0 | 0 | $c$ | 0 | $5 / 11$ |
| mevem | Move memory to regrster | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | AP | Refurn on poilive | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | \$/11 |
| HLT | Hath | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | HM | Retuen an minus | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | $9 / 11$ |
| mvi, | Move immediate register | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | RDE | Return on panty even | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | $5 / 11$ |
| Hivi M | Move immediste memory | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 10 | RPO | Return on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 5/11 |
| INR, | Increment iegrster | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 5 | RSI | Restart | 1 | 1 | A | A | A | 1 | 1 | 1 | 11 |
| DCR ${ }^{\text {r }}$ | Decrement cegrster | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 5 | IN | Inout | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 10 |
| INA M | increment memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 10 | OUT | Output | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 10 |
| OCAM | Decrement memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 10 | [XI B | toad ammediate register | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 10 |
| AOD ; | Add reguter to A | 1 | 0 | 0 | 0 | 0 | S | 5 | S | 4 |  | Pats 8 C |  |  |  |  |  |  |  |  |  |
| AOC, | Add reguter to A with carry | 1 | 0 | 0 | 0 | 1 | 5 | 5 | 5 | 4 | cxio | Load immediate register | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 10 |
| SUB : | Subtract regster liom $A$ | 1 | 0 | 0 | 1 | 0 | 5 | 5 | 5 | 4 |  | Pair \& E $^{\text {e }}$ |  |  |  |  |  |  |  |  |  |
| 58B, | Subtiactreguser from A with borrow | 1 | 0 | 0 | 1 | 1 | S | 5 | 5 | 4 | LXIH | Load ammediate register Par H 86 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |
| ANA | And register with A | 1 | 0 | 1 | 0 | 0 | S | 5 | 5 | 4 | [XISP | Coad immediate siack pointer | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |
| XRA: | Enetusive Of register with A | 1 | 0 | 1 | 0 | 1 | S | 5 | 5 | 4 | PUSH 8 |  | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 11 |
| ORA, | Or sequster with A | 1 | 0 | 1 | 1 | 0 | 5 | 5 | S | 4 |  | stack |  |  |  |  |  |  |  |  |  |
| CMP ; | Compare register with A | 1 | 0 | 1 | 1 | 1 | S | 5 | 5 | 4 | Push 0 | Push requster Par O\& E on | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 11 |
| ADOM | Add memosy to A | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 |  | stack |  |  |  |  |  |  |  |  |  |
| ADC M | Add memory to $A$ with cariy | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | PUSH H | Push register Par H \& L on | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 11 |
| SUB M | Subsact memory trom A | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |  | stach |  |  |  |  |  |  |  |  |  |
| SBBM | Subtract memory foom $A$ with borsow | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | PUSH PSW | Push $A$ and Flags on stack | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 11 |
| ANA M | And memory with A | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | POP B | Popregister par B \& C cff | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 10 |
| XAAM | Exelusive Or memory with A | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |  | slack |  |  |  |  |  |  |  |  |  |
| ORAM | Ormamory with A | 1 | 0 | , | 1 | 0 | 1 | 1 | 0 | 7 | POP 0 | Pop regrster pair O\& E ofl | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 10 |
| CMP M | Compire memory with A | 1 | 0 | 1 | 1 | 1 | 1 |  | 0 | 1 |  | slach |  |  |  |  |  |  |  |  |  |
| ADI | Ado immediate to A | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 7 | POP H | Pod register dair H 8 L off | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |
| ACI | Add immediate to $A$ with | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |  | stach |  |  |  |  |  |  |  |  |  |
|  | carry |  |  |  |  |  |  |  |  |  | POP PSW | Pop $A$ and Flags | $!$ | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |
| SU1 | Subtract immediate from A | 1 | 1 | 0 | 1 | 0 | 1 | , | 0 | 7 |  | off stack |  |  |  |  |  |  |  |  |  |
| S01 | Subtaset immediat from A | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 7 | STA | Store a direct | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 13 |
|  | with borrow |  |  |  |  |  |  |  |  |  | IDA | Load A direet | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 13 |
| ANI | . And immediate with A | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 7 | XCHG | Exchange D\&E, H\& L | 1 | $t$ | 1 | 0 | 1 | 0 | 1 | 1 | 4 |
| XRI | Eaclusive Or ammedase with a | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 7 | XTHL | Registers <br> Eschange toe of sack $\mathrm{H} \& \mathrm{~L}$ | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 18 |
| ORI | Or immetate with A | 1 | 1 | 1 | 1 | 0 | 1 | , | 0 | 7 | SPHI | H 8 to sack pointer | 1 | , | 1 | 1 | 1 | 0. | 0 | 1 | 5 |
| CPI | Compare immediate with $A$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 7 | PCHL | H\& $\downarrow$ to program counter | 1 | 1 | 1 | 0 | 1 | 0 | 0 | , | 5 |
| RLC | Aotare A left | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | OAD ${ }^{\text {d }}$ | Add B C Cio H | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
| 日RAC | Rotuti A right | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 4 | DAD D | ASOD\&EtOH8L | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 10 |
| RAL | Rotuti A left through cary | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 4 | OAD H |  | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 10 |
| RAR | Aotute A right through | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 4 | OAOSP | Add stack pointer to H \& L | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 10 |
|  | cily |  |  |  |  |  |  |  |  |  | Stax ${ }^{\text {S }}$ | Stort A indirest | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 7 |
| JMP | Jump unconditional | 1 | 1 | 0 | 0 | 0 | 0 | , | 1 | 10 | Stax 0 | Store A indirect | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 |
| JC | Jump on cativ | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 10 | LOAX 0 | Losd $A$ indirect | 0 | 0 | 0 | 0 | 1 | 0 | 1. | 0 | 1 |
| JNC | Jump on no caily | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 10 | LOAX 0 | losd $A$ indirect | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |
| 12 | Jump on zers | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 10 | InX ${ }^{\text {a }}$ | increment \& C ingusers $^{\text {a }}$ | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 5 |
| JN2 | Jump on no lero | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 10 | INXO | Intrement 0 \& E registers | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 5 |
| J9 | Sump da posilive | 1 | 1 | , | 1 | 0 | 0 | 1 | 0 | 10 | INX |  | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 5 |
| JM | Jump on minus | 1 | 1 | ' | 1 | 1 | 0 | 1 | 0 | 10 | INXSP | Increment stack pointer | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 5 |
| JPE | Jump on pariev even | 1 | 1 | , | 0 | 1 | 0 | 1 | 0 | 10 | DCX 8 | Decrement is C | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 5 |
| \$90 | Jump on partiy odo | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 10 | DCX D | Decrement 0 \& E | 0 | 0 | 0 | 1 | 1 | 0 | 1 ' | 1 | 5 |
| CALL | Call uncondimenal | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 11 | OCXH | Decrement \& $^{\text {l }}$ | 0 | 0 | 1 | 0. | 1 | 0 | 1 | 1 | 5 |
| CC | Call on carty | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 11/1) | OCX SP | Decrement stach pointer | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 5 |
| CNC | Call on no calty | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 1111 | CMA | Complement A | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 4 |
| C2 | Call on turo | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 11/11 | STC | Setcarty | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 4 |
| CH2 | Call an no zero | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | $11 / 11$ | CMC | Complement cary | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 4 |
| CP | Call on postive | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 11/11 | DAA | Decimal edjutia | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 4 |
| CM | Call on minus | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | $11 / 11$ | ShIO | Store H\& 1 duett | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 16 |
| CPE | Call on postity ion | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 11/11 | LHLO | Lond Hit direct | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 16 |
| CPO | Coll on patily odd | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | $11 / 1$ | (1) | Enabiolntituols | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 4 |
| AET | Raturn | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 10 | 01 | Disuble interrupt | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 |
| RC | Return on carty | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | \$/11 | NOP | No ogarition | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 4 |
| WNC | Rotuen an notaty | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | \$/11 |  |  |  |  |  |  |  |  |  |  |  |

NOTES: 1. DOD or SSS - 000 B - 001 C-010 D-011E-100H-101L-110 Memory - 111A.
2. Two possible cycle times. $(5 / 11)$ indicate instruction cycles dependent on condition flags.

## 8008/8008-1

EIGHT-BIT MICROPROCESSOR

- Instruction Cycle Time 12.5 , s with 8008-1 or $20 \mu \mathrm{~s}$ with 8008
- Directly addresses $16 \mathrm{~K} \times 8$ bits of memory (RAM, ROM, or S.R.)
- Interrupt Capability
- 48 Instructions, Data Oriented
- Address stack contains eight 14-bit registers (including program counter) which permit nesting of subroutines up to seven levels

The 8008 is a single chip MOS 8 -bit parallel central processor unit for the MCS-8 microcomputer system.
This CPU contains six 8 -bit data registers, an 8 -bit accumulator, two 8 -bit temporary registers, four flag bits (carry, zero, sign, parityl. and an 8 -bit parallel binary arithmetic unit which implements addition, subtraction, and logical operations. A memory stack containing a 14 -bit program counter and seven 14 -bit words is used internally to store program and subroutine addresses. The 14 -bit address permits the direct addressing of 16 K words of memory (any mix of RAM, ROM or S.R.).
The instruction set of the 8008 consists of 48 instructions including data manipulation, binary arithmetic, and jump to subroutine.
The normal program flow of the 8008 may be interrupted through the use of the INTERRUPT control line. This allows the servicing of slow I/O peripheral devices while also executing the main program.

The READY command line synchronizes the 8008 to the memory cycle allowing any type or speed of semiconductor memory to be used.



8008 PHOTOMICROGRAPH

## 8008, 8008-1

## 8008 FUNCTIONAL PIN DESCRIPTION



## $D_{0}-D_{7}$

BI-DIRECTIONAL DATA BUS. All address and data communice:ion between the processor and the program merrory, data memory, and $1 / 0$ devices occurs on these 8 lines. Cycle control information is also available.

INT
INTERRUPT inout. A logic " 1 " level at this input causes the processor to enter the INTERRUPT mode.

## READY

READY input. This command line is used to synchronize the 8008 to the memory cycle allowing any speed memiory to be used.

## SYNC

SYNC output. Synchronization signal generated by the processor. It indicates the beginning of a machine cycle.
$\phi_{1}, \phi_{2}$
Two phase clock inputs.
$S_{0}, S_{1}, S_{2}$
MACHINE STATE OUTPUTS. The processor controls the use of the data bus and determines whether it will be sending or receiving data. State signals $S_{0}, S_{1}$, and $S_{2}$, along with SYNC inform the peripheral circuitry of the state of the processor.
$V_{c c}+5 V \pm 5 \%$
VDD -9V $\pm 5 \%$

## 8008, 8008-1

## BASIC INSTRUCTION SET

## Data and Instruction Formats

Data in the 8008 is stored in the form of 8 bit binary integers. All data transfers to the system data bus will be in the same format.

$$
D_{1} D_{6} D_{5} D_{4} D_{3} D_{2} D_{1} D_{0}
$$

data word

The program instructions may be one, two, or three bytes in length. Multiple byte instructions must be stored in successive words in program memory. The instruction formats then depend on the particular operation executed.

One Byre insiructions
$0_{2} \mathrm{O}_{6} \mathrm{O}_{3} \mathrm{O}_{4} \mathrm{O}_{3} \mathrm{O}_{2} \mathrm{O}_{1} \mathrm{O}_{0}$

$\mathrm{D}_{1} \mathrm{D}_{6} \mathrm{D}_{5} \mathrm{D}_{4} \mathrm{O}_{3} \mathrm{O}_{7} \mathrm{D}_{1} \mathrm{O}_{\mathrm{C}}$

There Brie Insiluctions
$O_{7} D_{6} D_{5} D_{4} D_{3} D_{7} D_{1} O_{0}$
$D_{0}, O_{6} D_{5} O_{4} O_{3} D_{7} D_{1} D_{0}$

OPCOOL

OP CODE
operand
op cooe
LOW ADDRESS
higm addetss.
irpical instauctions
Reg.ster to engitry. memory ietricence.
tro erithmetic a logical, rolste on
leturn inutuctions
inurnedalt mode enstictions
-
JUMP or CALL ensicuctions
*For the therd byte of this instrucion. $\mathrm{O}_{6}$ and $\mathrm{O}_{7}$, ere "don't are" oisk.
For the MCS $8^{\text {TMA }}$ a logic " 1 " is defined as a high level and a logic " 0 " is defined as a low level.
Index Register Instructions
The load instructions do not affect the flag flip.flops. The increment and decrement instructions affect all flipflops except the carry.

| MNEMONIC | MINIMUM STATES REOUIRED | INSTRUCTION CODE |  |  |  |  |  |  | DESCRIPTION OF OPERATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{O}_{7} \mathrm{O}_{6}$ |  | $\mathrm{D}_{4}$ |  |  | $\mathrm{O}_{1}$ | $\mathrm{D}_{0}$ |  |
| (11movil.'2 | (5) | 11 | D |  | 0 | 5 | 5 | S | Load index register '1 with the content of index register '2. |
| 121 mov r.m | (8) | 11 | 0 | 0 | 0 | 1 | 1 | 1 | Load index register, with the content 'ot memorv register $M$. |
| mov M, | (7) | 11 |  | 1 | 1 | 5 | S | S | Load memory register $M$ with the content of index register P . |
| 131 mvi, | (8) | $\begin{array}{ll}0 & 0 \\ 8 & 8\end{array}$ |  |  |  | 1 | 1 | O | Load index register , with data B , . 8. |
| MVIM | (9) | $\begin{array}{ll}0 & 0 \\ B & 8\end{array}$ |  |  | 1 <br> $B$ | 1 8 | 1 6 | 0 | Load memory register $M$ with data 8 . . . $B$. |
| INR | (5) | 00 |  | D | 0 | 0 | 0 | 0 | Incremem the content of index register if / Al. |
| OCR | (5) | 00 |  |  | 0 | 0 | 0 | 1 | Decrement the content of index register r fi Al. |

Accumulator Group Instructions
The restilt of the $A L U$ instructions affect all of the flag flip.flops. The rotate instructions affect only the carry flip. llop.

| AOO: | 151 |  | 0 | 0 | 0 | 0 | 5 | S | S | Add the content of inden register i. memory register M. or data B ... B to the accumulator. An overilow (carry) sets the carty thop Hop. <br> Add the content of inden egister $r$, memory register M , or dasa B . . . B tiom the accumulator with carly. An overflow (cariy) sels the carry flip-tlop. <br> Subiract the content of index register 4 , memory register $M$, or dist 8 . . 8 ifom the accurnulator. An underflow (boriow) sels the carty flip-tlop. <br>  data 8 . . 8 trom the accumulator with boriow. An underflow tborinwl selithe coriv lip.llop. |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADOM | (8) | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |  |  |
| ADI | (8) | 0 | O |  | 0 |  |  |  |  |  |  |
| ADC, | (5) | 1 | 0 | 0 | 0 | 1 | 5 | 5 | 5 |  |  |
| ADC M | (8) | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |  |  |
| ACl | (8) | 0 $B$ | 0 8 |  | 0 8 | 1 6 | 1 |  |  |  |  |
| Su8. | (5) | 1 | 0 | 0 | 1 | 0 | 5 | 5 | 5 |  |  |
| SU8 M | (8) | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 |  |  |
| SUI | 181 | 0 8 | 0 0 |  | 1 | 0 8 |  |  |  |  |  |
| S88. | (5) |  | 10 | 0 | 1 | 1 | 5 | 5 | S |  |  |
| SBEM | (8) | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 |  |  |
| 561 | 181 | 0 | 0 |  | 1 |  |  |  |  |  |  |

## 8008, 8008-1

## BASIC INSTRUCTION SET:

| MNEMONIC | MINIMUM STATES REOUIRED | D, $\mathrm{O}_{6}$ | INSINUCTION CODE |  |  |  |  |  | DESCRIPTION OF OPERATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{a}_{5} \mathrm{D}_{4} \mathrm{D}_{3}$ |  |  |  |  |  |  |
| ANA. | (5) | 10 | 1 |  | 0 | 5 | 5 | S | Cominite the logit A AND al the comient of indes reqistes $r$. mermoty ragister M, or dald B . . 8 with the accumulator. |
| ANAM | (8) | 10 | 1 | o | 0 | 1 | 1 | 1 |  |
| ANI | (8) | $\begin{array}{ll} 0 & 0 \\ B & 8 \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & \mathrm{~A} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \hline 0 \\ & 0 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 8 \end{aligned}$ |  |  |  |
| XRA. | (5) | 10 | 1 | 0 | 1 | 5 | 5 | S | Combute the EXCLUSIVE OR of the content of inden tegister |
| XRAM | (8) | 10 | 1 | 0 | 1 | 1 | 1 | 1 | . mermory register M, or data B . . . B with the iccumulator. |
| XR1 | (8) | $\begin{array}{r} 0 \\ \hline \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & \mathbf{B} \end{aligned}$ | $\begin{aligned} & 0 \\ & 8 \end{aligned}$ | $\begin{array}{r} 1 \\ 8 \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & 8 \\ & \hline \end{aligned}$ | $\begin{array}{r} 0 \\ \mathbf{B} \\ \hline \end{array}$ |  |  |
| ORA. | 15) | 10 | 1 | 1 | 0 | 5 | 5 | 5 | Commote inf INCLUSIVE OR of the content of index reguter |
| ORAM | (8) | 10 | 1 | 1 | 0 | 1 | 1 | 1 | r. memoty register m. or data 8 . . B with the accumulator. |
| ORI | (8) | 0 0 6 | 1 | 1 1 | $\begin{aligned} & \hline 0 \\ & 8 \\ & \hline \end{aligned}$ | 1 | 1 8 | 1 B |  |
| CMP | (5) | 10 | 1 | 1 | 1 | 5 | 5 | S | Compare the content of index register 1 , memory register $M$. |
| CMP A | (8) | 10 | 1 | 1 | 1 | 1 | 1 | 1 | or data $8 . .8$ with the accumulator. The content of the |
| CPI | (8) | $\begin{array}{ll} 0 & 0 \\ B & 8 \end{array}$ | 1 | 1 | $\begin{aligned} & 1 \\ & B \end{aligned}$ | 1 | 0 | O | accurmutator is unchanged. |
| RLC | (5) | 00 | 0 | 0 | 0 | 0 | 1 | 0 | Rotate the content of the accumulator left. |
| ARC | (5) | 0 | 0 | 0 | 1 | 0 | 1 | 0 | Rotate the content of the accumulator cight. |
| MAL | (5) | 0 | 0 | 1 | 0 | 0 | 1 | 0 | Rotate the content of the accumulator telt through the carry. |
| RAR | (5) | 00 | 0 | 1 | 1 | 0 | 1 | 0 | Rotate the content of the accumulator right through the carry. |

Program Counter and Stack Control Instructions

| (4) JMP | (11) | $\begin{aligned} & 01 \\ & B_{2} 8_{2} \\ & \times \times \end{aligned}$ | $x$ $x$ $x$ <br> $B_{2}$ $B_{2}$ $B_{2}$ <br> $B_{3}$ $B_{3}$ $B_{3}$ | 1 0 0 <br> $B_{2}$ $B_{2}$ $B_{2}$ <br> $B_{3}$ $B_{3}$ $8_{3}$ | Unconditionary iump to memory address $\mathrm{B}_{3} \ldots \mathrm{~B}_{3} \mathrm{~B}_{2} \ldots \mathrm{~B}_{2}$. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| (5) JNC. JNZ. JP, JPO | (9 or 11) | $\begin{aligned} & 0 \quad 1 \\ & B_{2} B_{2} \\ & x \times x \end{aligned}$ | $\begin{array}{lll} 0 & C_{4} & C_{3} \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array}$ | $\begin{array}{lll} 0 & 0 & 0 \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array}$ | Jump to memorv address $\mathrm{B}_{3} \ldots \mathrm{~B}_{3} \mathrm{~B}_{2} \ldots \mathrm{~B}_{2}$ if the condition tlip-flod is talse. Otherwise. execute the next in $-:$ uction in sequence. |
| $\begin{aligned} & \text { JC. JZ } \\ & \text { JM, JPE } \end{aligned}$ | (9 or 111 | $\begin{array}{ll} 0 & 1 \\ B_{2} & 8_{2} \\ x & \end{array}$ | $\begin{aligned} & 1 C_{4} C_{3} \\ & B_{2} B_{2} B_{2} \\ & B_{3} B_{3} B_{3} \end{aligned}$ | $\left.\begin{array}{lll} 0 & 0 & 0 \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array}\right]$ | Jump to memory address $\mathrm{B}_{3} \ldots \mathrm{~B}_{3} \mathrm{~B}_{2} \ldots \mathrm{~B}_{2}$ ir the condition tip-trop is true. Oinerwise, execute the next instructicn in sequence. |
| CALL | (11) | $\begin{array}{ll} 0 & 1 \\ B_{2} & B_{2} \\ \times & x \end{array}$ | $\begin{array}{lll} x & x & x \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array}$ | $\begin{array}{ccc} 1 & 1 & 0 \\ B_{2} & B_{2} & B_{2} \\ 8_{3} & B_{3} & B_{3} \end{array}$ | Unconditionally call the subroutine at memory adoress $\mathrm{B}_{3}$... $\mathrm{B}_{3}{ }^{\mathrm{B}} 2 \ldots \mathrm{~B}$. Save the current address tup one level in the stack). |
| $\begin{aligned} & \text { CNC. CNZ. } \\ & \text { CP. CPO } \end{aligned}$ | (9 or 111 | $\begin{aligned} & 01 \\ & B_{2} B_{2} \\ & \times \times \end{aligned}$ | $\begin{array}{lll} \hline 0 & C_{4} & C_{3} \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \\ \hline \end{array}$ | $\left.\begin{array}{lll} 0 & 1 & 0 \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array} \right\rvert\,$ | Call the subroutine at memorv address $\mathrm{B}_{3} \ldots \mathrm{~B}_{3} \mathrm{~B}_{2} \ldots \mathrm{~B}_{2}$ it the condition llip-flop is false, and save the current address fup one tevel in the stack.) Otherwise. execute the next instruction in sequence. |
| $\begin{aligned} & C C, C Z . \\ & C M, ~ C P E \end{aligned}$ | (9 or 111 | $\begin{aligned} & \hline 0 \quad 1 \\ & B_{2} B_{2} \\ & \times \times \end{aligned}$ | $\begin{array}{lll} 1 & C_{4} & C_{3} \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \\ \hline \end{array}$ | $\begin{array}{lll} \hline 0 & 1 & 0 \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array}$ | Call the subroutine at memory address $\mathrm{B}_{3} \ldots \mathrm{~B}_{3} \mathrm{~B}_{2} \ldots \mathrm{~B}_{2}$ it the condition Hip-llop is true, and save the current address lud one tevel in the stack). Otherwise, execute the next instruction in sequence. |
| RET | 151 | 00 | $\times \times \times$ | 111 | Unconditionally return (down one level in the stack). |
| RNC, RNZ. RP, RPO | $(3$ or 51 | 00 | $0 \mathrm{C}_{4} \mathrm{C}_{3}$ | 011 | Return (down one level in the stack) it the condition flip-flop is Talse. Otherwise, execute the next instluction in sequence. |
| RC. AZ RM, RPE | $(3$ or 5 ) | 00 | $1 \mathrm{C}_{4} \mathrm{C}_{3}$ | 011 | Return tdown one level in the stack) il the condition (lip-flod is true. Otherwise. execute the next instruction in sequence. |
| RST | 15) | 00 | $A$ A A | 101 | Call the subroutine at memory address AAA 000 lup one level in the stack). |

Input/Output Instructions


NOTES
(1) SSS - Source Inden Hegisten $\quad$ These registers, i. are designsied Alaccumulator - 0001.

ODD = Destination Inden Fegister B10011. C10101. DIO111. Ellool. H(101). L1110).
Menow iegisters are andiesind tiv the contents of irqusters $H \& L$.
Additional bytes ol instiuction ate designated by BOLBABEB.
$x$ - "Donil Care".
 parity 111 parity is everl).

## 8008, 8008-1

ABSOLUTE MAXIMUM RATINGS*

| Ambient Temperature |  |
| :--- | ---: |
| Under Blas | $.00^{\circ} \mathrm{C}$ to $070^{\circ} \mathrm{C}$ |
| Storage Temperature | $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Input Voltages and Supply |  |
| Vollage With Respect |  |
| 10 $\mathrm{V}_{\mathrm{CC}}$ | +0.5 to -20 V |
| Power Dissipation | $1.0 \mathrm{~W} @ 25^{\circ} \mathrm{C}$ |

- COMMENT

Stresses above those listed under "Absolute Max. imum Ratings" may cause permanent damage to the device. This is a stress rating only and lunc tional operation of the device at these or any other condition above those indicated in the operational sectrons of this specitication is not implied.
D.C. AND OPERATING CHARACTERISTICS
$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, V_{c C}=+5 \mathrm{~V} \pm 5 \%, V_{00}=-9 \mathrm{~V} \pm 5 \%$ unless otherwise sperified. Logic $" 1 "$ is defined as the more positive level ( $\mathrm{V}_{1 \mathrm{H}}$. $\mathrm{V}_{\mathrm{Om}}$ ). Logic " 0 " is defined as the more negative level ( $\mathrm{V}_{\mathrm{il}} . \mathrm{V}_{\mathrm{OL}}$ ).

| SYMBOL | PARAMETER | Limits |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | TYP. | MAX. |  |  |
| ${ }_{00}$ | AVERAGE SUPPLY CURRENToutputs loaded. |  | 30 | 60 | $m A$ | $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ |
| ${ }^{\prime}$ | input leakage current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{iN}}=0 \mathrm{~V}$ |
| $\mathrm{V}_{1}$ | INPUT LOW VOLTAGE (INCLUDING CLOCKS) | $V_{D D}$ |  | $v_{c c}-4.2$ | $v$ |  |
| $V_{\text {IH }}$ | INPUT HIGH VOLTAGE (INCLUDING CLOCKS) | $v_{c c}-1.5$ |  | $V_{c c}+0.3$ | $\checkmark$ |  |
| $V_{0}$ | OUTPUT LOW VOLTAGE |  |  | 0.4 | $\checkmark$ | $\begin{aligned} & \mathrm{C}_{\mathrm{OL}}=0.44 \mathrm{~mA} \\ & C_{L}=200 \mathrm{pF} \end{aligned}$ |
| $V_{\text {OH }}$ | OUTPUT HIGH VOLTAGE | $v_{c c}-1.5$ |  |  | $v$ | $\mathrm{I}_{\mathrm{OH}}=0.2 \mathrm{~mA}$ |

- Measurements are made while the 8008 is executing a typical sequence of instructions. The test load is selected such that at $V_{O L}=0.4 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=0.44 \mathrm{~mA}$ on each output.
A.C. CHARACTERISTICS
$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 5 \%, V_{D O}=-9 \mathrm{~V} \pm 5 \%$. All measurements are referenced to 1.5 V levels.

| SYMBOL | PARAMETER | $\frac{8008}{\text { LIMITS }}$ |  | $\begin{aligned} & 8008 \cdot 1 \\ & \text { LIMITS } \end{aligned}$ |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  | MIN. | MAX. | MIN. | MAX. |  |  |
| ${ }^{1} \mathrm{Cr}$ | CLOCK PERIOD | 2 | 3 | 1.25 | 3 | $\mu \mathrm{s}$ | $\mathrm{t}_{\mathrm{R} \cdot} \mathrm{t}_{\mathrm{F}}=50 \mathrm{~ns}$ |
| $\mathrm{i}_{\mathrm{R}, \mathrm{I}_{\mathrm{F}} \mathrm{F}}$ | CLOCK RISE AND FALL TIMES |  | 50 |  | 50 | ns |  |
| ${ }_{1} \square_{1}$ | PULSE WIDTH OF $\phi_{1}$ | . 70 |  | . 35 |  | $\mu s$ |  |
| ${ }_{1}{ }_{0}$ | PULSE WIDTH OF $O_{2}$ | . 55 |  | . 35 |  | $\mu s$ |  |
| ${ }^{1} 01$ | CLOCK DELAY FROM FALLING EDGE OF $\phi_{1}$ TO FALLING EDGE OF $\phi_{2}$ | . 90 | 1.1 |  | 1.1 | $\mu s$ |  |
| ${ }^{1} \mathrm{D} 2$ | CLOCK DELAY FROM $\phi_{2}$ TO $\phi_{1}$ | . 40 |  | . 35 |  | $\mu s$ |  |
| ${ }^{1} \mathrm{O}_{3}$ | CLOCK OELAY FROM $\phi_{1}$ TO $\phi_{2}$ | . 20 |  | . 20 |  | $\mu s$ |  |
| ${ }^{\text {t }}$ D | DATA OUT DELAY |  | 1.0 |  | 1.0 | $\mu s$ | $C_{L}=100 \rho \mathrm{~F}$ |
| ${ }^{1} \mathrm{OH}$ | HOLD TIME FOR DATA BUS OUT | . 10 |  | . 10 |  | $\mu \mathrm{s}$ |  |
| $\mathrm{I}_{\mathrm{IH}}$ | HOLD TIME FOR DATA IN | 131 |  | 111 |  | $\mu \mathrm{s}$ |  |
| ${ }^{1}$ SO | SYNC OUT DELAY |  | . 70 |  | . 70 | $\mu \mathrm{s}$ | $C_{L}=100 \rho \mathrm{~F}$ |
| ${ }^{\text {'s }}$, | STATE OUT DELAY (ALL STATES EXCEPT TI AND T111 ${ }^{121}$ |  | 1.1 |  | 1.1 | $\mu s$ | $C_{L}=100 \mathrm{pF}$ |
| ${ }^{1} 52$ | STATE OUT DELAY ISTATES TI AND TIII |  | 1.0 |  | 1.0 | $\mu s$ | $C_{L}=100 \mathrm{pF}$ |
| ${ }^{\text {traw }}$ | PULSE WIDTH OF READY DURING $\varphi_{22}$ TO ENTER T3 STATE | . 35 |  | . 35 |  | $\mu s$ |  |
| ${ }^{\text {r }}$ D | READY DELAY TO ENTER WAIT STATE | . 20 |  | . 20 |  | $\mu s$ |  |



## TIMING DIAGRAM



Notes: 1. READY line must be at " " 0 " prior to $\Phi_{22}$ of $T_{2}$ to guarantee entry into the WAIT state. 2. INTERRUPT line must not change levels within 200 ns (max.) of falling ooge of $\phi_{1}$.

TYPICAL D.C. CHARACTERISTICS


TYPICAL A.C. CHARACTERISTICS



CAPACITANCE $t=1 \mathrm{MHz} ; T_{A}=25^{\circ} \mathrm{C}$; Unmeasured Pins Grounded

| SYMBOL | TEST | LIMIT ( P F) |  |
| :---: | :---: | :---: | :---: |
|  |  | IYP. | MAX. |
| $\mathrm{C}_{\text {in }}$ | INPUT CAPACITANCE | 5 | 10 |
| $\mathrm{C}_{\text {ot }}$ | DATA BUS I/O CAPACITANCE | 6 | 10 |
| $\mathrm{C}_{\text {our }}$ | OUTUT CAPACITANCE | 6 | 10 |


| distinctive characteristics <br> - Two-address architecture Independent simultaneous access to two working registers saves machine eycles. <br> - Eight-function ALU Performs addition, two subtraction operations, and five logic functions on two source operands. <br> - Flexible data source selection - <br> ALU data is selected from five source ports for a total of 203 source operand pairs for every ALU function. <br> - Left/right shift independent of ALU Add and shift operations take only one cycle. <br> - Four status flags Carry, overflow, zero, and negative. <br> - Expandable Connect any number of Am2901's together for longer word lengths. <br> - Microprogrammable Three groups of three bits each for source operand, ALU function, and destination control. | GENERAL DESCRIPTION <br> The four-bit bipolar microprocessor slice is designed as a high-speed cascadable element intended for use in CPU's. peripheral controllers, programmable microprocessors and numerous other applications. The microinstruction flexibility of the Am2901 will allow efficient emulation of almost any digital computing machine. <br> The device, as shown in the block diagram below, consists of a 16 -word by 4 -bit two-port RAM, a high-speed ALU, and the associated shifting, decoding and multiplexing circuitry. The nine-bit microinstruction word is organized into three groups of three bits each and selects the ALU source operands, the ALU function, and the ALU destination register. The microprocessor is cascadable with full look-ahead or with ripple carry, has three-state outputs, and provides various status flag outputs from the ALU. Advanced low-power Schottky processing is used to fabricate this 40 -lead LSI chip. |
| :---: | :---: |
| TABLE OF CONTENTS | MICROPROCESSOR SLICE BLOCK DIAGRAM |

## ARCHITECTURE

A detailed block diagram of the bipolar microprogrammable microprocessor structure is shown in Figure 1 . The circuit is a four-bit slice cascadable to any number of bits. Therefore, all data paths within the circuit are four bits wide. The two key elements in the Figure 1 block diagram are the 16 word by 4 -bit 2-port RAM and the high-speed ALU.

Data in any of the 16 words of the Random Access Memory (RAM) can be read from the A-port of the RAM as controlled by the 4 -bit $A$ address field input. Likewise, data in any of the 16 words of the RAM as defined by the $B$ address field input can be simultaneously read from the B-port of the RAM. The same code can be applied to the $A$ select field and $B$ select field in which case the identical file data will appear at both the RAM A-port and B-port outpues simultaneously.

When enabled by the RAM write enable (RAM EN), new data is always written into the file (word) defined by the B address field of the RAM. The RAM data input field is driven by a 3 -input multiplexer. This configuration is used to shift the ALU output data ( $F$ ) if desired. This three-input multiplexer scheme allows the data to be shifted up one bit position, shifted down one bit position, or not shifted in either direction.

The RAM A-port data outputs and RAM B-port data outputs drive separate 4-bit latches. These latches hold the RAM data while the clock input is LOW. This eliminates any possible race conditions that could occur while new data is being written into the RAM.

The high-speed Arithmetic Logic Unit (ALU) can perform three binary arithmetic and five logic operations on the two 4 -bit input words $R$ and $S$. The $R$ input field is driven from a 2 -input multiplexer, while the $S$ input field is driven from a 3 -input multiplexer. 8oth multiplexers also have an inhibit capability; that is, no data is passed. This is equivalent to a "zero" source operand.

Referring to Figure 1, the ALU R-input multiplexer has the RAM A-port and the direct data inputs ( $D$ ) connected as inputs. Likewise, the ALU S-input multiplexer has the RAM A-port, the RAM B-port and the $\mathbf{Q}$ register connected as inputs.

This multiplexer scheme gives the capability of selecting various pairs of the A, B, D, Q and " 0 " inputs as source operands to the ALU. These five inputs, when taken two at a time, result in ten possible combinations of source operand pairs. These combinations include $A B, A D, A Q, A O, B D, B D, B 0, D O, D O$ and $O 0$. It is apparent that $A D, A Q$ and $A O$ are somewhat redundant with $B D, B Q$ and $B O$ in that if the $A$ address and $B$ address are the same, the identical function results. Thus, there are only seven completely non-redundant source operand pairs for the ALU. The Am2901 microprocessor implements eight of these pairs. The microinstruction inputs used to select the ALU source operands are the $I_{0} I_{1}$, and $I_{2}$ inputs. The definition of $1_{0}, I_{1}$. and $1_{2}$ for the eight source operand combinations are as shown in Figure 2. Also shown is the octal code for each selection.

The two source operands not fully described as yet are the D input and $O$ input. The $\mathbf{D}$ input is the four-bit wide direct data field input. This port is used to insert all data into the working registers inside the device. Likewise, this input can be used in the ALU 10 modify any of the intetnal data files. The $Q$ register is a separate 4 -bit lite intended primarily for multiplication and division routines but it can also be used as an accumulator or holding register for some applications.

The ALU itself is a high-speed arithmetic/logic operator capable of performing thee binary arithenetic and five logic functions. The $1_{3} .1_{4}$, and $1_{5}$ microinstuction inputs are used to select the

ALU function. The definition of these inputs is shown in Figure 3. The octal code is also shown for reference. The normal technique for cascading the ALU of several devices is in a look-ahead carry mode. Carry generate, $\bar{G}$, and carry propagate, $\bar{P}$, are outputs of the device for use with a carry-look-ahead-generator such as the Am2902 ('182). A carrv-out, $C_{n+4}$, is also generated and is available as an output for use as the carry flag in a status register. Both carry-in $\left(C_{n}\right)$ and carry-out $\left(C_{n+4}\right)$ are active HIGH.

The ALU has three other status-oriented outputs. These are $F_{3}$. $F=0$, and overflow (OVR). The $F_{3}$ output is the most significant (sign) bit of the ALU and can be used to determine positive or negative results without enabling the three-state data outputs. $F_{3}$ is non-inverted with respect to the sign bit output $\gamma_{3}$. The $F=0$ output is used for zero detect. It is an open-collector output and can be wire OR'ed between microprocessor slices. $F=0$ is HIGH when all F outputs are LOW. The overflow outpu: (OVR) is used to flag arithmetic operations that exceed the available two's complement number range. The overflow output (OVR) is HIGH when overflow exists. That is, when $C_{n+3}$ and $C_{n+4}$ are not the same polarity.

The ALU data output is routed to several destinations. It can be a data output of the device and it can also be stored in the RAM or the O register. Eight possible combinations of ALU destination functions are available as defined by the $1_{6}, 17$, and 18 microinstruction inputs. These combinations are shown in Figure 4.

The four-bit data output field $|Y|$ features three-state outputs and can be directly bus organized. An output control ( $\overline{\mathrm{OE}})$ is used to enable the three-state outputs. When OE is HIGH, the Y outputs are in the high-impedance state.

A two-input multiplexer is also used at the data output such that either the A-port of the RAM or the ALU outputs $(F)$ are selected at the device $Y$ outputs. This selection is controlled by the $\mathbf{I}_{6}, \mathrm{I}_{7}$, and $I_{8}$ microinstruction inputs. Refer to Figure 4 for the selected output for each microinstruction code combination.

As was discussed previously, the RAM inputs are driven from a three-input multiplexer. This allows the ALU outputs to be entered non-shifted, shifted up one position (X2) or shifted down one position ( $\div 2$ ). The shifter has two ports; one is labeled RAM 0 and the other is labeled RAM RA $_{3}$. Both of these ports consist of a buffer-driver with a three-state output and an input to the multiplexer. Thus, in the shift up mode, the RAM 3 buffer is enabled and the RAM $M_{0}$ multiplexer input is enabled. Likewise, in the shift down mode, the RAM ${ }_{0}$ buffer and RAM 3 input are emabled. In the no-shift mode, both buffers are in the high-impedance state and the multiplexer inputs are not selected. This shifter is controlled from the $I_{6}, I_{7}$ and $I_{8}$ microinstruction inputs as defined in Figure 4.

Similarly, the $\mathbf{O}$ register is driven from a 3 -input multiplexer. In the no-shift mode, the multiplexer enters the ALU data into the O register. In either the shift-up or shift-down mode, the multiplexer selects the $\mathbf{O}$ register data appropriately shifted up or down. The $Q$ shifter also has two ports; one is labeled $Q_{0}$ and the other is $\mathrm{Q}_{3}$. The operation of these two ports is similar to the RAM shifter and is also controlled from $\mathrm{I}_{6}, \mathrm{I}_{7}$, and $\mathrm{I}_{8}$ as shown in Figure 4.

The clock input to the Am2901 controls the RAM, the O register, and the $A$ and $B$ data latches. When enabled, data is clocked into the $\mathbf{Q}$ register on the LOW. to-HIGH transition of the clock. When the clock input is HIGH, the $A$ and $B$ latches are open and will pass whotever data is present at the RAM outputs. When the clock input is LOW, the latches are closed and will retain the last data entered. If the RAM-EN is enabled, new dota will be written into the RAM file (word) detined by the $\mathbf{B}$ address tield when the clock input is LOW.


| MICRO COOE |  |  |  | ALU SOURCE OPERANDS |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| '2 | $1 /$ | ${ }^{1} 0$ | Oclal Cose | R | 5 |
| 1 | $\llcorner$ | $L$ | 0 | A | 0 |
| L | L | H | 1 | A | - |
| 1 | H | 1 | 2 | 0 | 0 |
| 1 | H | H | 3 | 0 | B |
| H | 1 | 1 | 4 | 0 | A |
| H | 1 | H | 5 | 0 | A |
| H | H | L | 6 | 0 | 0 |
| H | H | H | , | D | 0 |

Figure 2. ALU Source Operand Control.

| micrio code |  |  |  | $\underset{\text { Function }}{\text { ALU }}$ | Symbol |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{B}}$ | 14 | 13 | $\begin{aligned} & \text { Octol } \\ & \text { Code } \end{aligned}$ |  |  |
| $\downarrow$ | L | 1 | 0 | R Pluz S | R +S |
| $L$ | 1 | H | 1 | S Minut $R$ | S-R |
| 1 | H | $\stackrel{1}{6}$ | 2 | R Minus S | A-S |
| L | H | H | 3 | nors | RVS |
| H | $t$ | L | 4 | TANDS | R^5 |
| H | 1 | H | 5 | $\overline{\text { TiANOS }}$ | ¢^5 |
| H | H | 4 | 6 | Hex.ors | Rrs |
| H | H | H | , | a ex.nos | ¢YS |

Figure 3. ALU Function Control.

| MICRO CODE |  |  |  | RAM FUNCTION |  | Q.REG. <br> FUNCTION |  | $\begin{gathered} \mathbf{Y} \\ \text { OUTPUT } \end{gathered}$ | RAM SHIFTER |  | $0$ <br> SHIFTER |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 18 | ${ }^{17}$ | '6 | Octal Code | Shitt | Load | Shitt | Loed |  | RAM0 | $\mathrm{RAM}_{3}$ | 00 | $0_{3}$ |
| 1 | L | L | 0 | X | NONE | NONE | $F \rightarrow \mathbf{O}$ | F | $\times$ | X | X | X |
| $L$ | L | H | 1 | $x$ | NONE | x | NONE | F | $x$ | $x$ | $x$ | x |
| 1 | H | $L$ | 2 | NONE | $F \rightarrow B$ | $x$ | NONE | A | x | $x$ | $\times$ | x |
| 1 | H | H | 3 | NONE | $F \rightarrow 8$ | $x$ | NONE | F | $\times$ | $\times$ | $x$ | $x$ |
| H | $L$ | $L$ | 4 | DOWN | $F / 2 \rightarrow B$ | DOWN | $0 / 2 \rightarrow 0$ | F | $F_{0}$ | $1 \mathrm{~N}_{3}$ | $0_{0}$ | $\mathrm{IN}_{3}$ |
| H | L | H | 5 | DOWN | $F / 2 \rightarrow B$ | $x$ | NONE | F | $F_{0}$ | $\mathrm{IN}_{3}$ | $0_{0}$ | $\times$ |
| H | H | $L$ | 6 | UP | $2 \mathrm{~F} \rightarrow \mathrm{~B}$ | UP | $20 \rightarrow 0$ | $F$ | $\mathrm{IN}_{0}$ | $F_{3}$ | $\mathrm{NO}_{0}$ | $0_{3}$ |
| H | H | H | 7 | UP | $2 \mathrm{~F} \rightarrow \mathrm{~B}$ | X | NONE | F | $\mathrm{IN}_{0}$ | F3 | X | $0_{3}$ |

$X=$ Don't care. Electrically, the shift pin is a TTL input internally connected to a threestate output which is in the highimpedance state.
$B=$ Register Addressed by B inputs.
Up is toward MSB. Down is toward LSB.
Figure 4. ALU Destination Control.

|  | 10 OCTAL | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{ll} A & 4 \\ L & 3 \end{array}$ | ALU Function | A, 0 | A. B | O. 0 | O. B | O.A | D. $A$ | D, $\mathbf{Q}$ | D. 0 |
| 0 | $C_{n}=L$ <br> R Pius $S$ $C_{n}=H$ | $\begin{aligned} & A+O \\ & A+Q+1 \end{aligned}$ | $\begin{gathered} A+B \\ A+B+1 \end{gathered}$ | $\begin{gathered} 0 \\ 0+1 \end{gathered}$ | $\begin{gathered} 8 \\ 8+1 \end{gathered}$ | A $A+1$ | $\begin{aligned} & D+A \\ & D+A+1 \end{aligned}$ | D+ 0 <br> $0+0+1$ | $\begin{gathered} 0 \\ 0+1 \end{gathered}$ |
| 1 | $c_{n}=L$ <br> S Minus R $C_{n}=H$ | $\begin{aligned} & O-A-1 \\ & O-A \end{aligned}$ | $\begin{aligned} & B-A-1 \\ & B-A \end{aligned}$ | $\begin{gathered} 0-1 \\ 0 \end{gathered}$ | $\begin{gathered} 8-1 \\ 8 \end{gathered}$ | $\begin{gathered} A-1 \\ A \end{gathered}$ | $\begin{aligned} & A-D-1 \\ & A-D \end{aligned}$ | $\begin{aligned} & 0-D-1 \\ & 0-0 \end{aligned}$ | $\begin{gathered} -D-1 \\ -D \end{gathered}$ |
| 2 | $C_{n}=L$ R Minus S $C_{n}=H$ | $\begin{aligned} & A-O-1 \\ & A-O \end{aligned}$ | $\begin{gathered} A-8-1 \\ A-8 \end{gathered}$ | $\begin{gathered} -0-1 \\ -0 \end{gathered}$ | $\begin{gathered} -8-1 \\ -8 \end{gathered}$ | $\begin{gathered} -A-1 \\ -A \end{gathered}$ | $\begin{aligned} & D-A-1 \\ & D-A \end{aligned}$ | $\begin{aligned} & 0-0-1 \\ & 0-0 \end{aligned}$ | $\begin{gathered} 0-1 \\ 0 \end{gathered}$ |
| 3 | RORS | $A \vee O$ | AVB | 0 | $B$ | A | OVA. | $0 \vee 0$ | 0 |
| 4 | R AND S | A AO | $A \wedge B$ | 0 | 0 | 0 | DAA | $0 \wedge 0$ | 0 |
| 5 | - AND S | $\bar{A} \wedge 0$ | $\bar{A} \wedge B$ | 0 | 8 | A | $\overline{\mathrm{D}}$ A A | ŌへO | 0 |
| 6 | R EX-ORS | A 70 | AVB | 0 | 8 | A | DVA | DYO | 0 |
| 7 | R EX-NORS | $\overline{A 70}$ | $\overline{\text { Arb }}$ | 0 | E | $\pi$ | - $\bar{O}$ | 0\%0 | $\overline{0}$ |

Figure 5. Source Operand and ALU Function Matrix.

SOURCE OPERȦNDS AND ALU FUNCTIONS

There are eight source onerand poirs available to the ALU as selected by the $I_{0} . I_{1}$, and $I_{2}$ instruction inputs. The ALU can perform eight functions; five logic and three arithmetic. The $I_{3}$. $I_{4}$, and $I_{5}$ instruction inputs control this function selection. The carry input. $\mathrm{C}_{\mathrm{n}}$, also affects the ALU results when in the arithmetic mode. The $C_{n}$ input has no effect in the logic mode. When $I_{0}$ through $I_{5}$ and $C_{n}$ are viewed together, the matrix of

Figure 5 results. This matrix fully defines the ALU/source operand function for each state.
The ALU functions can also te examined on a "task" basis, i.e., add, subtract. AND. OR, etc. In the arithmetic mode, the carry will affect the function performed while in the logic mode, the carry will have no bearing on the ALU output. Figure 6 defines the various logic operations that the Am2901 can perform and Figure 7 shows the arithmetic functions of the device. Both carry-in LOW ( $\mathrm{C}_{n}=0$ ) and carry-in HIGH $\left(C_{n}=1\right)$ are defined in these operations.

| $\begin{gathered} \text { Octal } \\ i_{543} . I_{210} \end{gathered}$ | Group | Function |
| :---: | :---: | :---: |
| $\begin{aligned} & 40 \\ & 41 \\ & 45 \\ & 46 \end{aligned}$ | AND | A^O <br> A^B <br> D^A <br> D^O |
| $\begin{aligned} & 30 \\ & 31 \\ & 35 \\ & 36 \end{aligned}$ | OR | AVQ <br> AVB <br> DVA <br> DVQ |
| $\begin{aligned} & 60 \\ & 61 \\ & 65 \\ & 66 \end{aligned}$ | EX-OR | A $\forall \square$ <br> $A \forall B$ <br> DVA <br> DVO |
| $\begin{aligned} & 70 \\ & 71 \\ & 75 \\ & 76 \end{aligned}$ | EX-NOR | $\begin{aligned} & \overline{\overline{A \forall O}} \overline{\overline{A \forall B}} \\ & \overline{D \forall A} \\ & \overline{D \forall Q} \end{aligned}$ |
| $\begin{aligned} & 72 \\ & 73 \\ & 74 \\ & 77 \end{aligned}$ | INVERT | $\begin{aligned} & \overline{\mathrm{Q}} \\ & \bar{B} \\ & \bar{A} \\ & \bar{D} \end{aligned}$ |
| $\begin{aligned} & 62 \\ & 63 \\ & 64 \\ & 67 \end{aligned}$ | PASS | $\begin{aligned} & \text { Q } \\ & \text { B } \\ & \text { A } \\ & \text { D } \end{aligned}$ |
| $\begin{aligned} & 32 \\ & 33 \\ & 34 \\ & 37 \end{aligned}$ | PASS | $\begin{aligned} & \mathrm{O} \\ & \mathrm{~B} \\ & \mathrm{~A} \\ & \mathrm{D} \end{aligned}$ |
| $\begin{aligned} & 42 \\ & 43 \\ & 44 \\ & 47 \end{aligned}$ | "ZERO" | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ |
| $\begin{array}{r} 50 \\ 51 \\ 55 \\ 56 \\ \hline \end{array}$ | MASK | $\bar{A} \wedge 0$ <br> $\overline{\mathrm{A}} \wedge \mathrm{B}$ <br> D̄へA <br> ס̄ヘO |

Figure 6. ALU Logic Mode Functions. ( $\mathrm{C}_{\mathrm{n}}$ Irrelevant)

| $\begin{gathered} \text { Octal } \\ I_{543}, I_{210} \end{gathered}$ | $C_{n}=0$ (Low) |  | $\mathrm{C}_{\mathrm{n}}=1$ (High) |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Group | Function | Group | Function |
| 00 |  | A+a |  | A + Q +1 |
| 01 | ADD | $A+B$ | ADD plus | $A+B+1$ |
| 05 |  | D+A | one | D + A+1 |
| 06 | . | D+O |  | D + Q +1 |
| 02 |  | 0 |  | Q+1 |
| 03 | PASS | B | Increment | B+1 |
| 04 |  | A |  | A+1 |
| 07 |  | D |  | D+1 |
| 12 |  | 0-1 |  | a |
| 13 | Decrement | B-1 | PASS | B |
| 14 |  | A-1 |  | A |
| 27 |  | D-1 |  | D |
| 22 |  | -0-1 |  | -0 |
| 23 | 1's Comp. | -B-1 | 2's Comp. | -8 |
| 24 |  | -A-1 | (Negate) | -A |
| 17 |  | -D-1 |  | -0 |
| 10 |  | O-A-1 |  | O-A |
| 11 | Subtract | B-A-1 | Subtract | B-A |
| 15 | (1's Comp) | A-D-1 | (2's Comp) | A-D |
| 16 |  | O-D-1 |  | O-D |
| 20 |  | A-0-1 |  | A-O |
| 21 |  | A-B-1 |  | $A-B$ |
| 25 |  | D-A-1 |  | D-A |
| 26 |  | O-0-1 |  | O-O |

Figure 7. ALU Arithmetic Mode Functions.

## LOGIC FUNCTIONS FOR G, P, $C_{n+4}$, AND OVR

The four signals $G, P, C_{n+4}$, and $O V R$ are designed to indicate carry and overflow conditions when the $A m 2901$ is in the add or subtract mode. The table below indicates the logic equations for these four signals for each of the eight ALU functions. The $R$ and $S$ inputs are the two inputs selected according to Figure 2.

## Definitions $(+=O R)$

| $P_{0}=R_{0}+S_{0}$ | $G_{0}=R_{0} S_{0}$ |
| :--- | :--- |
| $P_{1}=R_{1}+S_{1}$ | $G_{1}=R_{1} S_{1}$ |
| $P_{2}=R_{2}+S_{2}$ | $G_{2}=R_{2} S_{2}$ |
| $P_{3}=R_{3}+S_{3}$ | $G_{3}=R_{3} S_{3}$ |
| $C_{4}=G_{3}+P_{3} G_{2}+P_{3} P_{2} G_{1}+P_{3} P_{2} P_{1} G_{0}+P_{3} P_{2} P_{1} P_{0} C_{n}$ |  |
| $C_{3}=G_{2}+P_{2} G_{1}+P_{2} P_{1} G_{0}+P_{2} P_{1} P_{0} C_{n}$ |  |



Note: $\left[\bar{P}_{2}+\bar{G}_{2} \bar{P}_{1}+\bar{G}_{2} \bar{G}_{1} \bar{P}_{0}+\bar{G}_{2} \bar{G}_{1} \bar{G}_{0} C_{n}\right] \forall\left[\bar{P}_{3}+\bar{G}_{3} \bar{P}_{2}+\bar{G}_{3} \bar{G}_{2} \bar{P}_{1}+\bar{G}_{3} \bar{G}_{2} \bar{G}_{1} \bar{P}_{0}+\bar{G}_{3} \bar{G}_{2} \bar{G}_{1} \bar{G}_{0} C_{n}\right]$
Figure 8.

## PACKAGE OUTLINE



Figure 9.


Figure 10.

## PIN DEFINITIONS

A0-3 The four address inputs to the register stack used to select one register whose contents are displayed through the A.port.
$\mathrm{B}_{0-3}$ The four address inputs to the register stack used to select one register whose contents are displayed through the B-port and into which new data can be written when the clock goes LOW.
$\mathbf{I}_{0-8}$ The nine instruction control lines to the Am2901, used to determine what data sources will be applied to the ALU ( $\mathrm{O}_{12}$ ), what function the ALU will perform ( $l_{345}$ ), and what data is to be deposited in the 0 -register or the register stack ( $1_{678}$ ).
$\mathbf{O}_{3} \quad$ A shift line at the MSB of the O register $\left(\mathrm{O}_{3}\right)$ and the $\mathrm{RAM}_{3}$ register stack ( $\mathrm{RAM}_{3}$ ). Electrically these lines are three-state outputs connected to TTL inputs internal to the Am2901. When the destination code on $\mathrm{I}_{678}$ indicates an up shift (octal 6 or 7 ) the three-state outputs are enabled and the MSB of the 0 register is available on the $O_{3}$ pin and the MSB of the ALU output is available on the RAM3 pin. Otherwise, the three-state outputs are OFF (high-impedance) and the pins are electrically LS-TTL inputs. When the destination code calls for a down shift, the pins are used as the data inputs to the MSB of the 0 register (octal 4) and RAM (octal 4 or 5).
$\mathrm{O}_{0} \quad$ Shift tines like $\mathrm{O}_{3}$ and RAM3, but at the LSB of the $R A M_{0}$ O-register and RAM. These pins are tied to the $O_{3}$ and RAM $_{3}$ pins of the adjacent device to transfer data between devices for up and down shifts of the O register and ALU data.
$\mathbf{D}_{\mathbf{0 - 3}} \quad$ Direct data inputs. A four-bit data field which may be selected as one of the ALU data sources for entering data into the $A m 2901 . D_{0}$ is the LSB.

Yo-3 The four data outputs of the Am2901. These are three-state output lines. When enabled, they display either the four outputs of the ALU or the data on the A-port of the register stack, as determined by the destination code $\mathrm{I}_{678}$.
$\overline{\mathrm{OE}} \quad$ Output Enable. When $\overline{\mathrm{OE}}$ is HIGH, the $Y$ outputs are OFF; when $\overline{O E}$ is LOW, the $Y$ outputs are active (HIGH or LOW).
$\overline{\mathbf{P}}, \overline{\mathbf{G}} \quad$ The carry generate and propagate outputs of the Am2901's ALU. These signals are used with the Am2902 for carry-lookahead. See Figure 8 for the logic equations.

OVR Overflow. This pin is logically the Exclusive-OR of the carry-in and carry-out of the MSB of the ALU. At the most significant end of the word, this pin indicates that the result of an arithmetic two's complement operation has overflowed into the sign-bit. See Figure 8 for logic equation.
$\mathbf{F}=\mathbf{0}$ This is an open collector output which goes HIGH (OFF) if the data on the four ALU outputs $\mathrm{F}_{0-3}$ are all LOW. In positive logic, it indicates the result of an ALU operation is zero.
$C_{n} \quad$ The carry-in to the Am2901's ALU.
$\mathbf{C}_{\mathrm{n}+4}$ The carry-out of the Am2901's ALU. See Figure 8 for equations.
CP The clock to the Am2901. The Q register and register stack outputs change on the clock LOW-ro-HIGH transition. The clock LOW time is internally the write enable to the $16 \times 4$ RAM which comprises the "master" latches of the register stack. White the clock is LOW, the "slave" latches on the RAM outputs are closed, storing the data previously on the RAM outputs. This allows synchronous master-slave opera. tion of the register stack.

MAXIMUM RATINGS (Above which the useful life may be impaired)

| Storage Temperature | $-65^{\circ} \mathrm{C} 10+150^{\circ} \mathrm{C}$ |
| :--- | ---: |
| Temperature (Ambient) Under Bias | $-55^{\circ} \mathrm{C} 10+125^{\circ} \mathrm{C}$ |
| Supply Voltage to Ground Potential | -0.5 V to +6.3 V |
| DC Voltage Applied to Outputs for HIGH Output State | $-0.5 \mathrm{~V} 10+\mathrm{VCC}$ max |
| DC Input Voltage | $-0.5 \mathrm{~V} 10+5.5 \mathrm{~V}$ |
| DC Output Current, Into Outputs | 30 mA |
| DC Input Current | $-30 \mathrm{~mA} 10+5.0 \mathrm{~mA}$ |



ELECTRICAL CHARACTERISTICS OVER OPERATING RANGE (Untess Otherwise Noted)
(Group A, Subgroups 1, 2 and 3)


Notes: 1. For conditiont shown as MIN. or MAX., usa the appropriato valuo anachion undar Elactrical Charactapisticitar the applicable davice tyo. 2. Tynical limilis ato at $\mathrm{V}_{\mathrm{CC}}-5.0 \mathrm{~V}$. $25^{\circ} \mathrm{C}$ amblant and maximum loading

Thosere mathe thet the theee state outpuit OFF.

## gUARANTEED OPERATING CONDITIONS

## TABLEI

## OVEII TEMPERATURE AND VOLTAGE

Tables 1. II. and III below define the timing requirements of the Am2001 in a system. The Am2901 is guaranteed to function correctly over the operating sange when used within the delay and set-up time constraints of these tables for the appropriate device type. The tables are divided into three ivpes of parameters; clock characteristics, combinational delays from inputs to outputs, and set-up and hold time requirements. The latter table defines the time prior to the end of the cycle (i.e., clock LOW-to-HIGH transition) that each input must be stable to guarantee that the correct data is written into one of the internal registers.
The performance of the Am2901 within the limits of these tables is guaranteed by the testing defined as "Group A, Subgroup 9" Electrical Testing. For a copy of the tests and limits used for subgroup 9, contact Advanced Micro Devices' Product Marketing.

## CYCLE TIME AND CLOCK CHARACTERISTICS

| time | Am29010C.PC | Am2901DM.FM |
| :---: | :---: | :---: |
| Read-Modily-Write Cycle (time from selection of A. B registers to end of cycle) | 105 ns | 120ns |
| Maximum Clock Frequency to Shift O Register (50\% duty cycle) | 9.5 MHz | 8.3 MHz |
| Minimum Clock LOW Time | 30 ns | 30 ns |
| Minimum Clock HIGH Time | 30ns | 30 ns |
| Minimum Clock Period | 105 ns | 120 ns |

TABLE II
MAXIMUM COMBINATIONAL PROPAGATION DELAYS (all in ns, $C_{L} \leqslant 15 \mathrm{pF}$ )

|  | Am29010C. PC $10^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C} ; 5 \mathrm{~V} \pm 5 \%$ ) |  |  |  |  |  |  |  | Am2901DM, FM ( $-55^{\circ} \mathrm{C}$ to $\left.+125^{\circ} \mathrm{C} ; 5 \mathrm{~V} \pm 10 \%\right)$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  | $\begin{aligned} & \text { Shif } \\ & \text { Outp } \end{aligned}$ | $\begin{aligned} & \text { ift } \\ & \text { puts } \end{aligned}$ |  |  |  |  | $\mathrm{F}=0$ |  | $\begin{aligned} & \text { Shift } \\ & \text { Outputs } \end{aligned}$ |  |
|  | $r$ | F3 |  | P | $\begin{aligned} & R_{L} \\ & 470 \end{aligned}$ | OVR | $\begin{array}{\|l\|} \mathrm{RAM}_{0} \\ \mathrm{RAM}_{3} \\ \hline \end{array}$ | $\begin{aligned} & a_{0} \\ & \alpha_{3} \end{aligned}$ | $r$ | F3 | $\mathrm{C}_{\mathrm{n}+4}$ | G, $P$ | $\begin{aligned} & R_{L}= \\ & 470 \end{aligned}$ | OVR | $\begin{aligned} & \mathrm{RAM}_{0} \\ & \mathrm{RAM}_{3} \end{aligned}$ | $\begin{aligned} & \mathbf{a}_{0} \\ & \mathrm{a}_{3} \end{aligned}$ |
| A, B | 110 | 85 | 80 | 80 | 110 | 75 | 110 | - | 120 | 95 | 90 | 90 | 120 | 85 | 120 | - |
| D (arithmetic mode) | 100 | 70 | 70 | 70 | 100 | 60 | 95 | - | 110 | 80 | 75 | 75 | 110 | 65 | 105 | - |
| D ( $1=\times 37$ ) (Note 5) | 60 | 50 | - | - | 60 | - | 60 | - | 65 | 55 | - | - | 65 | - | 65 | - |
| $\mathrm{C}_{\mathrm{n}}$ | 55 | 35 | 30 | - | 50 | 40 | 55 | - | 60 | 40 | 30 | - | 55 | 45 | 60 | - |
| 1012 | 85 | 65 | 65 | 65 | 80 | 65 | 80 | - | 90 | 70 | 70 | 70 | 85 | 70 | 85 | - |
| 1345 | 70 | 55 | 60 | 60 | 70 | 60 | 65 | - | 75 | 60 | 65 | 65 | 75 | 65 | 70 | - |
| 1678 | 55 | - | - | - | - | - | 45 | 45 | 60 | - | - | - | - | - | 50 | 50 |
| $\overline{\mathrm{OE}}$ Enable/Disable | 40/25 | - | - | - | - | - | - | - | 40/25 | - | - | - | - | - | - | - |
| $\begin{aligned} & \text { A bypassing } \\ & \text { ALU }(1=2 x \mathrm{x}) \end{aligned}$ | 60 | - | - | - | - | - | - | - | 65 | - | - | - | - | - | - |  |
| Clock ${ }^{\text {P }}$ (Note 6) | 115 | 85 | 100 | 100 | 110 | 95 | 105 | 60 | 125 | 95 | 110 | 110 | 120 | 105 | 115 | 65 |

SET-UP AND HOLD TIMES (all in ns) (Note 1)
TABLE III

| From Input | Notes | Am2901DC, PC $10^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, 5 \mathrm{~V} \pm 5 \%$ ) |  | Am2901DM, FM( $-55^{\circ} \mathrm{C}$ to $\left.+125^{\circ} \mathrm{C}, 5 \mathrm{~V} \pm 10 \%\right)$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Set-Up Time | Hold Time | Set.Up Time | Hold Time |
| A. 8 Source | $\begin{aligned} & 2.4 \\ & 3,5 \end{aligned}$ | $\begin{gathered} 105 \\ \mathrm{ipwL}^{2}+30 \end{gathered}$ | 0 | $\begin{array}{r} 120 \\ \mathrm{tpw}^{20}+30 \\ \hline \end{array}$ | 0 |
| B Dest. | 2.4 | $\mathrm{tpw}^{\text {L }}$ + 15 | 0 | ${ }^{\text {tpw }} \mathrm{L}+15$ | 0 |
| D (arithmetic mode) |  | 100 | 0 | 110 | 0 |
| $D(1=\times 37)($ Note 5 ) |  | 60 | 0 | 65 | 0 |
| $\mathrm{C}_{\mathrm{n}}$ |  | 55 | 0 | 60 | 0 |
| ${ }^{1} 12$ |  | 85 | 0 | 90 | 0 |
| ${ }^{1} 315$ |  | 70 | 0 | 75 | 0 |
| ${ }^{6} 678$ | 4 | $\mathrm{t}_{\mathrm{pw}} \mathrm{L}+15$ | 0 | ${ }^{1} \mathrm{pwL}+15$ | 0 |
| RAM $0.3 . O_{0,3}$ | ' | 30 | 0 | 30 | 0 |

Notas: 1. See Figuro 11 and 12.
2. If the B eddrass is used at source operand, allow for the "A, B sourco" ser-up time; if lit used only for the deatination addrata, use the "B dest" sor.up time
Where iwo numbori ero thown, both muat be met
4. "Iowi" is thp clock LOW itme
6. DVO is the tastost way io load the RAM from the O inputs. Thli function is obtalnod with i-337.
6. Using O registor as iutce operand in arithmesic mode. Clock is not normally in critical apeod pash whon O la not asourca.

SET-UP AND HOLD TIMES (minimum cycles from each input)

Set- up and hold times are defined relative to the clock LOW-to HIGH edge. Inputs must be steady at all times from the set-up
time prior to the clock until the hold time after the clock. The set-up fimes allow sufficient time to perform the correct operation on the correct data so that the correct ALU data can be written into one of the registers.


Figure 11. Minimum Cycle Times from Inputs. Numbers Shown are Minimum Data Stable Times for Am2901 DC, in ns. See Table III for Detailed Information.


Notes: 1. This delay is the max. tpd of the register containing A, B. D, and I. For the Am2918, uso 13nz
2. IOnt for look ahand cariy. For rimpla cariy ovar 16 bis usa $2 \times\left(C_{n}{ }^{-+} C_{n}+4\right)$. or $60 n s$
. Thle is the dalay astocintod with the multiplexof betwoan the shift outpuis and shifi inpuit on the Am2901s. Sae Floure 19.
4. Not applicatife for logle oneratione.
6. Ciock fising edge may occur here if add and ahifi do not occur on ame cycle.

Figure 12. Switching Wavoforms for 16 Bit System Assuming $\cap, B, D$ and $I$ are all Driven from Registers with the samo Propagation Delay, Clocked by the Am2901 Clock.


Figure 13. Am2901 Input/Output Current Interface Conditions.


Figure 14. Am2901 Burn-In Circuit.

## MICROPROCESSING UNIT (MPU)

The MC6800 is a monolithic 8 -bit microprocessor forming the central control function for Motorola's M6800 family. Compatible with TTL, the MC6800, as with all MG800 system parts, requires. only one +5.0-volt power supply, and no external TTL devices for bus interface.

The MC6800 is capable of addressing 65 K bytes of memory with its 16 -bit address lines. The 8 -bit data bus is bidirectional as well as 3 -state, making direct memory addressing and multiprocessing applications realizable.

- Eight-Bit Parallel Processing
- Bi-Directional Data Bus
- Sixteen-Bit Address Bus - 65K Bytes of Addressing
- 72 Instructions - Variable Length
- Seven Addressing Modes - Direct, Relative, Immediate, Indexed, Extended, Implied and Accumulator
- Variable Length Stack
- Vectored Restart
- Maskable Interrupt Vector
- Separate Non-Maskable Interrupt - Internal Registers Saved In Stack
- Six Internal Registers - Two Accumulators, Index Register, Program Counter, Stack Pointer and Condition Code Register
- Direct Memory Addressing (DMA) and Multiple Processor Capability
- Clock Rates as High as 1 MHz
- Simple Bus Interface Without TTL
- Halt and Single Instruction Execution Capability


## MICROPROCESSOR



CERAMIC PACKAGE CASE 715

NOT SHOWN: P SUFFIX
PLASTIC PACKAGE
CASE 711


ELECTRICAL CHAHACTERISTICS $\left(V_{C C}=5.0 \mathrm{~V}: 5 \%, V_{S S}=0 . T_{\wedge}=0.070^{\circ} \mathrm{C}\right.$ unless othorwiso noted.)

| Charactoristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage Logic <br>  $\$ 1 . \$ 2$ | $\begin{aligned} & v_{I H} \\ & v_{I H C} \end{aligned}$ | $\begin{aligned} & v_{\mathrm{SS}}+2.0 \\ & v_{\mathrm{CC}}-0.3 \end{aligned}$ | - | $\begin{gathered} v_{C C} \\ v_{C C}+0.1 \end{gathered}$ | Vodc |
|  | $\begin{aligned} & v_{\text {IL }} . \\ & v_{\text {ILC }} \end{aligned}$ | $\begin{aligned} & v_{S S}-0.3 \\ & v_{S S}-0.1 \end{aligned}$ | - | $\begin{aligned} & \mathrm{v}_{\mathrm{SS}}+0.8 \\ & \mathrm{v}_{\mathrm{SS}}+0.3 \end{aligned}$ | Vdic |
| Clock Overshoot/Undershoot - Input High Level <br> - Input Low Level | $\mathrm{v}_{\text {OS }}$ | $\begin{aligned} & v_{C C}-0.5 \\ & v_{S S}-0.5 \end{aligned}$ | - | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}}+0.5 \\ & \mathrm{v}_{\mathrm{SS}}+0.5 \end{aligned}$ | Vdc |
| $\begin{array}{\|ll} \hline \text { Input Leakage Current } & \\ \left(V_{\text {in }}=0 \text { to } 5.25 \mathrm{~V}, V_{C C}=\max \right) & \text { Logic } \\ \left(V_{\text {in }}=0 \text { to } 5.25 \mathrm{~V}, V_{C C}=0.0 \mathrm{~V}\right) & \phi 1 . \phi 2 \end{array}$ | $\mathrm{I}_{\text {in }}$ | - | 1.0 | $\begin{gathered} 2.5 \\ 100 \end{gathered}$ | $\mu \mathrm{Adc}$ |
| Three-State (Off State) !nput Current D0-D7 <br> $\left(V_{\text {in }} 0.4\right.$ to $2.4 \mathrm{~V}, \mathrm{~V}_{C C}=$ max $)$ A0.A $15, R / \mathrm{W}$ | ITSI | - | 2.0 | $\begin{gathered} 10 \\ 100 \end{gathered}$ | $\mu \mathrm{Adc}$ |
| Output High Voltage  <br> ( Load $\left.=-205 \mu \mathrm{Adc}, V_{C C}=\mathrm{min}\right)$ OO-D7 <br> ( $\left.{ }_{\text {Load }}=-145 \mu \mathrm{Adc}, V_{C C}=\mathrm{min}\right)$ AO $\cdot \mathrm{A} 15, R / \mathrm{W}, \mathrm{VMA}$ <br> ( Load $\left.=-100 \mu \mathrm{Adc}, V_{C C}=\mathrm{min}\right)$ BA | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & V_{S S}+2.4 \\ & V_{S S}+2.4 \\ & v_{S S}+2.4 \end{aligned}$ | - | - | Vdc |
| $\begin{aligned} & \text { Output Low Voltage } \\ & \text { (ILoad }=1.6 \mathrm{mAdc}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{min} \text { ) } \end{aligned}$ | VOL | - | - | $\mathrm{V}_{\text {SS }}+0.4$ | Voc |
| Power Dissipation | $P_{\text {D }}$ | - | 0.600 | 1.2 | W |
| Capacitance $\#$ $\phi 1, \phi 2$ <br> $\left(V_{\text {in }}=0 . T_{A}=25^{\circ} \mathrm{C}, f=1.0 \mathrm{MHz}\right)$ TSC <br>  DBE <br>  DO.D7. <br>  Logic Inputs | $\mathrm{c}_{\text {in }}$ | $80$ | $\begin{gathered} 120 \\ - \\ 7.0 \\ 10 \\ 6.5 \end{gathered}$ | $\begin{gathered} \hline 160 \\ 15 \\ 10 \\ 12.5 \\ 8.5 \\ \hline \end{gathered}$ | $\rho F$ |
|  | $\mathrm{C}_{\text {out }}$ | - | - | 12 | pF |
| Frequency of Operation | 1 | 0.1 | - | 1.0 | MHz |
| Clock Timing (Figure 1) Cycle Time | $\mathrm{t}_{\text {cyc }}$ | 1.0 | - | 10 | $\mu \mathrm{s}$ |
| Clock Pulse Width $\begin{array}{ll}\left(\text { Measured at } V_{C C}-0.3 \mathrm{~V}\right) & \phi 1 \\ & \phi 2\end{array}$ | $\mathrm{PW}_{\varphi} \mathrm{H}$ | $\begin{aligned} & 430 \\ & 450 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & 4500 \\ & 4500 \end{aligned}$ | ns |
| Total 01 and $\varphi 2$ Up Time | $\mathrm{t}_{\text {ut }}$ | 940 | - | - | ns |
| Rise and Fall Times \$1, 82 (Measured between $\mathrm{V}_{\mathrm{SS}}+0.3 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{CC}}-0.3 \mathrm{~V}$ ) | $t_{\phi r}, t_{\phi f}$ | 5.0 | - | 50 | ns |
| Delay Time or Clock Separation (Measured at $\mathrm{V}_{\mathrm{OV}}=\mathrm{V}_{\mathrm{SS}}+0.5 \mathrm{~V}$ ) | ${ }^{\text {d }}$ - | 0 | - | 9100 | ns |
| Overshoot Ouration | ${ }^{\text {tos }}$ | 0 | - | 40 | ns |

*Except $\overline{\mathrm{TRO}}$ and $\overline{\mathrm{NM}}$, which require $3 \mathrm{k} \Omega \Omega$ pullup load resistors for wire-OR capability at optimum operation.
"Capacitances are periodically sampled rather than $100 \%$ tested.
FIGURE 1 - CLOCK timing WAVEFORM


MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltago | $\mathrm{V}_{\mathrm{Cc}}$ | -0.3 to +7.0 | Valc |
| Input Voltage | $V_{\text {in }}$ | -0.3 to +7.0 | Voc |
| Operating Temperature Range | $\mathrm{T}_{\text {A }}$ | $010+70$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature hange | $\mathrm{T}_{\text {sig }}$ | $-5510+150$ | ${ }^{\circ} \mathrm{C}$ |
| Thermal Resistance | $0_{\text {JA }}$ | 70 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |

This device contains circuitry to protect the inputs against darnage due to high static volt. ages or electric fields: however, it is advised that notmal precautions the taken to avoid applica. tion of any voltage higher than maximum rated voltages to this high impedance circuit.

READ/WRITE TIMING Figures 2 and $3,1=1.0 \mathrm{MHz}$, Load Circuit of Figure 6 .

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Address Delay | ${ }^{1}$ AD | - | 220 | 300 | ns |
| Peripheral Read Access Time $t_{a c c}=t_{u t}-\left(t_{A D}+t_{D S R}\right)$ | ${ }^{\text {tacc }}$ | - | - | 540 | ns |
| Data Setup Time (Read) | tosR | 100 | $\square$ | - | ns |
| Input Data Hold Time | $\mathrm{t}_{\mathrm{H}}$ | 10 | - | - | ns |
| Output Data Hold Time | ${ }_{\text {t }}^{\mathrm{H}}$ | 10 | 25 | - | ns |
| Address Hold Time (Address, R/W, VMA) | ${ }^{1} \mathrm{AH}$ | 50 | 75 | - | ns |
| Enable High Time for DBE Input | ${ }^{t}$ EH | 450 | - | - | ns |
| Data Delay Time (Write) | ${ }^{\text {t }}$ DDW | - | 165 | 225 | ns |
| Processor Controls* <br> Processor Control Setup Time <br> Processor Control Rise and Fall Time <br> Bus Available Delay <br> Three State Enable <br> Three State Delay <br> Data Bus Enable Down Time During $\phi 1$ Up Time (Figure 3) <br> Data Bus Enable Delay (Figure 3) <br> Data Bus Enable Rise and Fall Times (Figure 3) | $\begin{gathered} \text { tPCS } \\ \text { tPCr. tPCf } \\ \text { tBA } \\ \text { tTSE } \\ \text { tTSD } \\ \text { tDBE } \\ \text { tDBED } \\ \text { tDBEr, } \mathrm{IDBEf} \end{gathered}$ | $\begin{gathered} 200 \\ - \\ - \\ - \\ - \\ 150 \\ 300 \end{gathered}$ | - - - - - - - - | $\begin{gathered} - \\ 100 \\ 300 \\ 40 \\ 700 \\ - \\ - \\ 25 \end{gathered}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ ns |

*Additional information is given in Figures 12 through 16 of the Family Characteristics - see pages 17 through 20.

FIGURE 2 - READ DATA FROM MEMOHY OR PERIPHERALS



FIGURE 4 - TYPICAL DATA BUS OUTPUT DELAY versus CAPACITIVE LOADING


FIGURE 5 - TYPICAL READ/WRITE, VMA, AND ADDRESS OUTPUT DELAY versus CAPACITIVE LOADING

figure 6 -- bus timing test load

$C=130 \mathrm{pF}$ for DO-D7
$=90 \mathrm{pF}$ for AO-A 15, R/W, and VMA
$=30 \mathrm{pF}$ for BA
$R=11.7 \mathrm{k} \Omega$ for D0.07
$=16.5 \mathrm{k} \Omega$ ior A0.A15, R/W, and VMA
$=24 \mathrm{k} \Omega$ for $B A$

TYPICAL POWER SUPPLY CURRENT


FIGURE 8 - VARIATIONS WITH TEMPERATURE


EXPANDED BLOCK DIAGRAM


Proper operation of the MPU requires that certain control and timing signals be provided to accomplish specilic functions and that other signal lines be monitored to determine the state of the processor.

Clocks Phase Ono and Phase Two ( $\$ 1, \phi 2$ ) -- Two pins are used for a two phase non-overlapping clock that runs at the $V_{C C}$ voltage level.

Address Bus (A0-A15) - Sixteen pins are used for the address bus. The outputs are three-state bus drivers capable of driving one standard TTL load and 130 pF . When the output is turned off, it is essentially an open circuit. This permits the MPU to be used in DMA applications.

Data Bus (D0-D7) - Eight pins are used for the data bus. It is bidirectional, transferring data to and from the memory and peripheral devices. It also has three-state output buffers capable of driving one standard TTL load and 130 pF .

Halt - When this input is in the low state, all activity in the machine will be halted. This input is level sensitive. In the halt mode, the machine will stop at the end of an instruction, Bus Available will be at a one level, Valid Memory Address will be at a zero, and all other three-state lines will be in the three-state mode.

Transition of the Halt line must not occur during the last 250 ns of phase one. To insure single instruction operation, the Halt line must go high for one Clock cycle.

Three-State Control (TSC) - This input causes all of the address lines and the Read/Write line to go into the off or high impedance state. This state will occur 700 ns after TSC $=2.0 \mathrm{~V}$. The Valid Memory Address and Bus Available signals will be forced low. The data bus is not affected by TSC and has its own enable (Data Bus Enable). In DMA applications, the Three-State Control line should be brought high on the leading edge of the Phase One Clock. The $\phi 1$ clock must be held in the high state and the $\phi 2$ in the low state for this function to operate properly. The address bus will then be available for other devices to directly address memory. Since the MPU is a dynamic device, it can be held in this state for only $4.5 \mu \mathrm{~s}$ or destruction of data will occur in the MPU.

Read/Write (R/W) - This TTL compatible output signals the peripherals and memory devices whether the MPU is in a Read (high) or Write (low) state. The normal standby state of this signal is Read (high). Three-State Control going high will turn•Read/Write to the off (high impedance) state. Also, when the processor is halted, it will be in the off state. This output is capable of driving one standard TTL load and 90 pF .

Valid Memory Address (VMA) -- This output indicates to peripheral devices that there is a valid address on the address bus. In normal operation, this signal should be utilized for enabling peripheral interfaces such as the PIA and ACIA. This signal is not three-state. One standard TTL load and 90 pF may be directly driven by this active high signal.

Data Bus Enable (DBE) - This input is the threestate control signal for the MPU data bus and will enable the bus drivers when in the high state. This input is ${ }^{\circ}$ TTL compatible; however in normal operation, it would be driven by the phase two clock. During an MPU read cycle, the data bus drivers will be disabled internally. When it is desired that another device control the data bus such as in Direct Memory Access (DMA) applications, DBE should be held low.

Bus Available (BA) - The' Bus Available signal will normally be in the low state; when activated, it will go to the high state indicating that the microprocessor has stopped and that the address bus is available. This will occur if the Halt line is in the low state or the processor is in the WAIT state as a result of the execution of a WAIT instruction. At such time, all three-state output drivers will go to their off state and other outputs to their normally inactive level. The processor is removed from the WAIT state by the occurrence of a maskable (mask bit $\mathrm{I}=0$ ) or nonmaskable interrupt. This output is capable of driving one standard TTL load and 30 pF .
$\overline{\text { Interrupt Request }}(\overline{1 R Q})$ - This level sensitive input requests that an interrupt sequence be generated within the machine. The processor will wait until it completes the current instruction that is being executed before it recognizes the request. At that time, if the interrupt mask bit in the Condition Code Register is not set, the machine will begin an interrupt sequence. The Index Register, Program Counter, Accumulators, and Condition Code Register are stored away on the stack. Next the MPU will respond to the interrupt request by setting the interrupt mask bit high so that no further interrupts may occur. At the end of the cycle, a 16 -bit address will be loaded that points to a vectoring address which is located in memory locations FFF8 and FFF9. An address loaded at these locations causes. the MPU to branch to an interrupt routine in memory.

The Halt line must be in the high state for interrupts to be serviced. Interrupts will be latched internally while Halt is low.

The $\overline{\mathrm{RQ}}$ has a high impedance pullup device internal to the chip; however a $3 \mathrm{k} \Omega$ external resistor to $\mathrm{V}_{\mathrm{CC}}$ • should be used for wire-OR and optimum control of interrupts.
$\overline{\text { Reset }}$ - This input is used to reset and start the MPU from a power down condition, resulting from a power failure or an initial start-up of the processor. If a high level is detected on the input, this will signal the MPU to begin the restart sequence. This will start execution of a routine to initialize the processor from its reset condition. All the higher order address lines will be forced high. For the restart, the last two (FFFE, FFFF) locations in memory will be used to load the program that is addressed by the program counter. Diring the restart routine, the interrupt mask bit is set and must be reset before the MPU can be interrupted by $\overline{T R O}$.

Figure 9 shows the initialization of the microprocessor after restart. $\widehat{R e s e t}$ must be held low for at least eight clock periods after $V_{\text {CC'reaches }} 4.75$ volts. If Reset goes high prior to the leading edge of $\phi 2$, on the next $\phi 1$ the first restart memory vector adelress (FFFE) will appear on the address lines. This location should contain the higher order eight bits to be stored into the program counter. Following, the next address FFFF should contain the lower order eight bits to be stored into the program counter.
$\overline{\text { Non-Maskable Interrupt }}(\overline{N M I})$ - A low-going edge on this input requests that a non-mask-interrupt sequence be generated within the processor. As with the Interrupt Request signal, the processor will complete the current instruction that is being executed before it recognizes the $\overline{N M I}$ signal. The interrupt mask bit in the Condition Code Register has no effect on $\overline{\mathrm{NMI}}$.

The Index Register. Program Counter, Accumulators, and Condition Code Register are stored away on the stack. At the end of the cycle, a 16 -bit address will be loaded that points to a vectoring address which is located in memory locations FFFC and FFFD. An address loaded at these locations causes the MPU to branch to a nonmaskable interiupt routine in memory.
$\overline{\text { NMI }}$ has a high impedance pullup resistor internal to the chip; however a $3 \mathrm{k} \Omega$ external resistor to VCC should be used for wire-OR and optimum control of interrupts.

Inputs $\overline{\mathrm{RQ}}$ and $\overline{\mathrm{NMI}}$ are hardware interrupt lines that are sampled during $\phi 2$ and will start the interrupt routine on the $\phi 1$ following the completion of an instruction.

Figure 10 is a flow chart describing the major decision paths and interrupt vectors of the microprocessor. Table 1 gives the memory map for interrupt vectors.

FIGURE 9 - INITIALIZATION OF MPU AFTER RESTART


TABLE 1 - MEMORY MAP FOR INTERRUPT VECTORS

| Vector | Description |
| :---: | :---: |
| FFFE FFFF | Restart |
| FFFC FFFD | Non-maskable Interrupt |
| FFFFB FFFB | Softwaro Intotrupt |



## MPU REGISTERS

The MPU has three 16 -bit registers and three 8 -bit registers available for use by the programmer (Figure 11).

Program Counter - The program counter is a two byte (16-bits) register that points to the current program address.

Stack Pointer - The stack pointer is a two byte register that contains the address of the next available location in an external push-down/pop-up stack. This stack is not mally a random access Read/Write memory that may
have any location (address) that is convenient. In those applications that require storage of information in the stack when power is lost, the stack must be non-volatile.

Index Register - The index register is a two byte register that is used to store data or a sixteen bit memory address for the Indexed mode of memory addressing.

Accumulators - The MPU contains two 8 bit accumulators that are used to hold operands and results from an arithmetic logic unit (ALU).


FIGURE 12 - SAVING THE STATUS OF THE MICROPROCESSOR IN THE STACK


Condition Code Register - The condition code register indicates the results of an Arithmetic Logic Unit operation: Negative (N), Zero (Z), Overflow (V), Carry Irom bit 7 (C), and half carry from bit 3 (H). These bits of the Condition Code Register are used as testable conditions for the conditional branch instructions. Bit 4 is the interrupt mask bit (1). The unused bits of the Condition Code Register (b6 and b7) are ones.

Figure 12 shows the order of saving the microprocessor status within the stack.

## MPU INSTRUCTION SET

The MC6800 has a set of 72 different instructions. Included are binary and decimal arithmetic, logical, shift, rotate, load, store, conditional or unconditional branch, interrupt and stack manipulation instructions (Tables 2 thru 6).

## MPU ADDRESSING MODES

The MC6800 eight-bit microprocessing unit has seven address modes that can be used by a programmer, with the addressing mode a function of both the type of instruction and the coding within the instruction. A summary of the addressing modes for a particular instruction can be found in Table 7 along with the associated instruction execution time that is given in machine cycles. With a clock frequency of 1 MHz , these times would be microseconds.

Accumulator (ACCX) Addressing - In accumulator only addressing, either accumulator $A$ or accumulator $B$ is specified. These are one-byte instructions.

Immediate Addressing - In immediate addressing, the operand is contained in the second byte of the instruction except LDS and LDX which have the operand in the second and third bytes of the instruction. The MPU addresses
this location when it fetches the immediate instruction for execution. These are two or three byte instructions.

Direct Addressing - In direct addressing, the address of the operand is contamed in the second byte of the instruction. Direct addressing allows the user to directly address the lowest 256 bytes in the machine i.e., locations zero through 255. Enhanced execution times are achieved by storing data in these locations. In most conligurations, it should be a random access memory. These are two byte instructions.

Extended Addressing - In extended addressing, the address contained in the second byte of the instruction is used as the higher eight-bits of the address of the operand. The third byte of the instruction is used as the lower eight-bits of the address for the operand. This is an absolute address in memory. These are three-byte instructions.

Indexed Addressing - In indexed addressing, the address contained in the second byte of the instruction is added to the index register's lowest eight bits in the MPU. The carry is then added to the higher order eight bits of the index register. This result is then used to address memory. The modified address is held in a temporary address register so there is no change to the index register. These are two-byte instructions.

Implied Addressing - In the implied addressing mode the instruction gives the address (i.e., stack pointer, index register, etc.). These are one-byte instructions.

Relative Addressing - In relative addressing, the address contained in the second byte of the instruction is added to the program counter's lowest eight bits plus two. The carry or borrow is then added to the high eight bits. This allows the user to address data within a range of -125 to +129 bytes of the present instruction. These are twobyte instructions.

TABLE 2 - MICROPROCESSOR INSTRUCTION SET - ALPHABETIC SEQUENCE

| ABA | Add Accumulators | CLR | Clear | PUL | Pull Data |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ADC | Add with Carry | CLV | Clear Overflow | ROL | Rotate Left |
| ADD | Add | CMP | Compare | ROR | Rotate Right |
| AND | Logical And | COM | Complement | RTI | Return from Interrupt |
| ASL | Arithmetic Shift Left | CPX | Compare Index Register | RTS | Return from Subroutine |
| ASR | Arithmetic Shift Right | DAA | Decimal Adjust | SBA | Subiract Accumulators |
| 8CC | Branch if Carry Clear | DEC | Decrement | SBC | Subtract with Carry |
| BCS | Branch if Carry Set | DES | Decrement Stack Pointer | SEC | Set Carry |
| BEO | Branch if Equal to Zero | DEX | Decrement Index Register | SEI | Set Interrupt Mask |
| BGE | Branch if Greater or Equal Zero | EOR | Exclusive OR | SEV | Set Overtiow |
| BHI | Branch if Greater than Zero Branch if Higher | INC | Increment | STA | Store Accumulator |
| BIT | Bit Test | INS | Increment Stack Pointer | STS | Store Stack Register |
| BLE | Branch if Less or Equal | INX | Increment Index Register | SUB | Subtract |
| BLS | Branch if Lower or Same | JMP | Jump | SWI | Software Interrupt |
| BMI | Branch if Less than Zero Branch if Minus | JSR | Jump to Subroutine | TAB | Transfer Accumulators |
| 8NE | Branch it Not Equal to Zero | LDA | Load Accumulator | TAP | Transter Accumulators to Condition Code Reg. |
| BPL | Branch if Plus | LDS | Load Slack Pointer | TBA | Transter Accumulators |
| BRA | Branch Always | LDX | Load Index Register | TPA | Transter Condition Code Reg. to Accumulator |
| BSA | Branch to Subroutino | LSR | Logical Shitt Right | TST | Test |
| BvC | Branch it Overlow Clear |  |  | TSX | Transfer Stack Pointer to Index Register |
| BVS | Branch it Overdow Set | NOP | No Operation | TXS | Transter. Index Register to Stack Pointor |
| $\begin{aligned} & \text { CBA } \\ & \text { CLC } \end{aligned}$ | Compare Accumulators Cloar Carry | ORA | Inclusive OR Accumulator | WAI | Wait for Interrupt |
| CLI | Clear Interrupt Mask | PSH | Push Data |  |  |

TABLE 3-ACCUMULATOR AND MEMORY INSTRUCTIONS

LEGNO:

| OP | Oprestigen Code Ifrastrecinall. | * | Boutrat Inclusive OH. |
| :---: | :---: | :---: | :---: |
| - | Number al MiPit Cralos. | $\bigcirc$ | Boute an faclusive OH. |
| - | Number of Prograll Bries. | 4 | Complriarit of it. |
| + | Actinertic Pins. | - | Tisustri linu. |
|  | Artherectis Mume. | 0 | Bil <eto. |
|  | Bacdesil Alll. | 00 | Brie. /etu, |
| Misp |  |  |  |

## CONDITION COOE SYABEIS:

```
Hall carry hombur 3.
Hmlerount mask
Nryative (magi But)
Irob(bytr)
Ovrstow. 2;icmplomitrot
Cany tuanbil/
Hevil Alway,
Set Alway:
Iatl and url it tine, tlealed athatwo
Nul Alloniro
```

| POINTER OPERATIONS | MNEMONIC | IMME D |  |  | Dinect |  |  | MWDEX |  |  | EXTND |  |  | IMPLIED |  |  | boolean/arithmetic opernation | CONO. CODE REG. |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | 5 | 4 | 3 |  |  |  | 2 | 1 | 0 |  |  |  |  |
|  |  | OP | $\sim$ | : |  |  |  | OP | $\sim$ | : |  |  |  | OP | $\sim$ | : |  | OP | $\sim$ | : | OP | $\sim$ | $=$ | H | 1 | $N$ | z | $v$ | c |
| Combure Index Reg | CPX | 8 C | 3 | 3 | 9C | 4 | 2 | AC | 6 | 2 | EC | 5 | 3 |  |  |  |  | - | - |  |  |  |  |
| Decrement Intex Reg | DEX |  |  |  |  |  |  |  |  |  |  |  |  | 03 | 4 | 1 | $x-1 \rightarrow x$ | - | - |  |  | - | - |
| Decrimineni Stack Pntl | DES |  |  |  |  |  |  |  |  |  |  |  |  | 34 | 4 | 1 | SP - 1 - SP | - | - |  |  | - | - |
| Increment Index Reg | INX |  |  |  |  |  |  |  |  |  |  |  | . | 08 | 4 | 1 | X $+1-\mathrm{X}$ | $\bullet$ | - |  |  | - |  |
| Increment Stack Pout | INS |  |  |  |  |  |  |  |  |  |  |  |  | 31 | 4 | 1 | $5 P+1 \cdots 5 P$ | - | - |  |  | - |  |
| Load Index Reg | L0x | CE | 3 | 3 | OE | 4 | 2 | EE | 6 | 2 | FE | 5 | 3 |  |  |  | $M \rightarrow X_{H}(M+1) \rightarrow X_{L}$ | - | $\bullet$ |  |  | R |  |
| Load Slack Pntr | LOS | 8 E | 3 | 3 | 9 E | 4 | 2 | AE | 6 | 2 | BE | 5 | 3 |  |  |  | $\mathrm{M} \rightarrow \mathrm{SP} \mathrm{P}_{\mathrm{H}}(\mathrm{M}+1) \rightarrow$ SP $\mathrm{S}_{\text {L }}$ | - | - |  |  | R |  |
| Store hidex Reg | STX |  |  |  | DF | 5 | 2 | EF | . 7 | 2 | FF | 6 | 3 |  |  |  | $\mathrm{X}_{\mathrm{H}} \rightarrow \mathrm{M}, \mathrm{X}_{\mathrm{L}} \cdots(\mathrm{M}+1)$ | - |  |  |  | R |  |
| Store Stack Pntr | STS |  |  |  | 9 F | 5 | 2 | AF | 7 | 2 | BF | 6 | 3 |  |  |  | $S P_{H} \cdots M_{\text {S }}$ SP $P_{L} \cdots(M+1)$ | - |  |  |  | P | - |
| Indx Reg - Stack Putr | TXS |  |  |  |  |  |  |  |  |  |  |  |  | 35 | 4 | 1 | $\mathrm{X}-\mathrm{I} \rightarrow \mathrm{SP}$ | - | - | - |  | - | - |
| Stack Pnti $\cdots$ Indx Reg | ISX |  |  |  |  |  |  |  |  |  |  |  |  | 30 | 4 | 1 | SP + $1 \rightarrow X$ | - | - | - |  | - |  |

TABLE 5 - JUMP AND BRANCH INSTRUCTIONS

| OPERATIONS | MNEMONIC |  |  |  |  |  |  |  |  |  |  |  |  | BRANCH TEST |  | COND. CODE REG. |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | RELATIVE |  |  | INDEX |  |  | EXTND |  |  | IMPLIED |  |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | DP | $\sim$ | $=$ | OP | $\sim$ | $=$ | OP | $\sim$ | $=$ | OP | $\sim$ | = |  |  | H | 1 | N | 2 | $V$ | C |
| Branch Always | BRA | 20 | 4 | $?$ |  |  |  |  |  |  |  |  |  |  | None | - | - | - | - | - | - |
| Branch If Carry Clear | BCC | 24 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $C=0$ | - | - | - | - | - | - |
| Branch If Carry Set | BCS | 25 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $C=1$ | - | - | - | - | - | - |
| Branch If = Zero | BEO | 27 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $2=1$ | - | - | - | - | - | - |
| Branch II $\geqslant$ Zero | BGE | 2C | $4^{-}$ | 2 |  |  |  |  |  |  |  |  |  |  | $N(4) V=0$ | - | - | - | - | - | - |
| Branch if $>$ Zero | BGT | 2 E | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $Z+(N \oplus V)=0$ | - | - | - | - | - | - |
| Branch If Higher | BHI | 22 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $C+Z=0$ | - | - | - | - | - | - |
| Branch If $\leqslant$ Zero | BLE | 28 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $Z+(N \subset V)=1$ | - | - | - | - | - | - |
| Branch If Lower Or Same | BLS | 23 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $C+2=1$ | - | - | - | $\bullet$ | - | - |
| Branch if < Zero | BLT | 20 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $\mathrm{N}(4) \mathrm{V}=1$ | - | - | - | - | - | - |
| Branch If Minus | BMI | 28 | 4 | 2 |  |  |  |  |  |  |  | . |  |  | $N=1$ | - | - | - | $\bullet$ | - | - |
| Branch If Not Equal Zero | BNE | 26 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | Z $=0$ | - | - | - | - | - | - |
| Branch If Overflow Clear | BVC | 28 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $V=0$ | - | - | - | - | - | - |
| Branch II Overfiow Set | BVS | 29 | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $V=1$ | - | - | - | - | - | - |
| Branch II Plus | BPL | 2 A | 4 | 2 |  |  |  |  |  |  |  |  |  |  | $\mathrm{N}=0$ | - | - | - | - | - | - |
| Branch To Subroutine | BSR | 8 D | 8 | 2 |  |  |  |  |  |  |  |  |  |  |  | - | - | - | - | - | - |
| Jump | $J M P$ |  |  |  | 6 E | 4 | 2 | 7E | 3 | 3 |  |  |  |  | See Special Operations | - | - | - | - | - | - |
| Juinp To Subroutine | JSR |  |  |  | AD | 8 | 2 | BD | 9 | 3 |  |  |  | ) |  | - | - | - | - | - | - |
| No Operalion | NOP |  |  |  |  |  |  |  |  |  | 01 | 2 | 1 |  | Advances Prog. Contr. Only | - | - | - | - | - | - |
| Return From Interrupt | RTI |  |  |  |  |  |  |  |  |  | 38 | 10 | 1 |  |  |  |  |  |  |  |  |
| Return From Subroutine | RTS |  |  |  |  |  |  |  |  |  | 39 | 5 | 1 |  |  | $\bullet$ | $\bullet$ | - 1 | $\bullet$ | $\bullet$ | - |
| Soliwate Interiupl | SWI |  |  |  |  |  |  |  |  |  | 3 F | 12 | 1 | $\}$ | See Special Operations | $\bullet$ |  | - | - | - | - |
| Wati for Interrupi* | WAI |  |  |  |  |  |  |  |  |  | $3 E$ |  | 1 |  |  | - | (i1) | - | - | - | - |

WAI puts Addess Bus, $A N$, and Data Bus in the the ee state mode whate ViAA is held low.

SPECIAL OPERATIONS
JSR, JUMP TO SUBHOUTINE:


BSR. BRANCH TO SUBROUTINE:


JMP, JUMP:


RTS, RETURN FROM SUBROUTINE:


RTI, RETURN FROM INTERRUPT:


TABLE 6 - CONDITION CODE REGISTER MANIPULATION INSTRUCTIONS

| OPERATIDNS | MNEMONIC |  |  |  | BDOLEAN OPERAIION | COND. CODE REG. |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MAPLIED |  |  |  | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | OP | $\sim$ | $:=$ |  | H | 1 | N | 2 | $v$ | C |
| Clear Carry | CLC | 0 C | 2 | 1 | $0 \rightarrow \mathrm{C}$ | - | - | - |  | - | A |
| Clear Interrupt Mask | CLI | OE | 2 | 1 | $0-1$ | $\bullet$ | R | - |  | - | $\bullet$ |
| Clear Overilow | CIV | OA | 2 | 1 | $0 \rightarrow \mathrm{~V}$ | - | - | - |  | R | - |
| Set Carry | SEC | 00 | 2 | 1 | 1-c | - | - | - |  | - | S |
| Sel Intertupt Mask | SEI | or | 2 | 1 | 1.1 | - | S | - | - | - | - |
| Set Overflow | SFV | OB | 2 | 1 | $1 \cdot \mathrm{~V}$ | - |  | - |  | S | - |
| Acmilt A CCR | TAP | 06 | 2 | 1 | $A \cdots C C R$ |  |  | (1) |  |  |  |
| CCH - Acmlt A | IPA | 01 | 2 | 1 | CCn ${ }^{\text {A }}$ |  | $\bullet$ | - |  |  | - |

CONOITION COOE REGISTER NOTES: (thit set it test is the and cleded utherwise)

| ( BH l V) | Irsi Resalt $10000000{ }^{3}$ |
| :---: | :---: |
| (B)C C) | 1est Arsul! - 0000000ut? |
| ( B 1 C ) |  (Nut ctrated if inreviunsly wal) |
| ( 101 V ) |  |
| ( 3,11 |  |
| (lit V) |  |


| 1 | (BII N$)$ | Test: Sigu bit ul must sugriliant (tas) byte 17 |
| :---: | :---: | :---: |
| 8 | (Bi) V) |  |
| 9 | (BI) N) |  |
| 10 | (All) |  |
| 11 | (B11) |  litermpt is requirid fop ant the wat siste. |
| 12 | (All) | Set according to the conteris of Aucimulator $A$. |



NOTE: Interrupt time is 12 cycles from the end of
the instruction being executed, except foltowing a WAl instruction. Then it is 4 eycles.


## SUMMARY OF CYCLE BY CYCLE OPERATION

Table 8 provides a detailed description of the information present on the Address Bus, Data Bus, Valid Memory Address line (VMA), and the Read/Write line (R/W) during each cycle for each instruction.

This information is uscful in comparing actual with ex. pected results during debug of both soflware and hard-
ware as the control program is executed. The information is categorized in groups according to Addressing Mode and Number of Cyeles per instruction. (In general, instructions with the same Addressing Mode and Number of Cycles execute in the same manner; exceptions are indicated in the table.)

TABLE 8 - OPERATION SUMMARY

| Address Mode and Instructions | Cycles | Cycle <br> 4 | VMA Line | Address Bus' | R/W <br> Line | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IMMEDIATE |  |  |  |  |  |  |
| ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | $1$ | $\begin{aligned} & \text { Op Code Address } \\ & \text { Op Code Address }+1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Op Code <br> Operand Data |
| $\begin{aligned} & \text { CPX } \\ & \text { LDS } \\ & \text { LDX } \end{aligned}$ | 3 | 1 2 3 | 1 1 1 | Op Code Address <br> Op Code Address +1 <br> Op Code Address +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |

DIRECT

| ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Op Code <br> Address of Operand Operand Data |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { CPX } \\ & \text { LDS } \\ & \text { IDD } \end{aligned}$ | 4 | $\begin{aligned} & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Address of Operand <br> Operand Address + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Address of Operand <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| STA | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Destination Address <br> Destination Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Destination Address <br> Irrelevant Data (Note 1) <br> Data from Accumulator |
| $\begin{aligned} & \text { STS } \\ & \text { STX } \end{aligned}$ | 5 | 1 2 3 4 5 | 1 1 0 | Op Code Address <br> Op Code Address + 1 <br> Address of Operand <br> Address of Operand <br> Address of Operand +1 | 1 1 1 0 0 | Op Code <br> Address of Operand <br> Irrelevant Data (Note 1) <br> Register Data (High Order Byte) <br> Register Data (Low Order Byte) |


| JMP | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Index Register <br> Index Register Plus Orfset (w/o Carry) | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Offset <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Index Register <br> Index Register Plus Offset (w/o Carry) <br> Index Register Plus Oflset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Offset <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Operand Data |
| $\begin{aligned} & \text { CPX } \\ & \text { LDS } \\ & \text { LDX } \end{aligned}$ | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Index Register <br> Index Register Plus Ollsut (w/o Carry) <br> Index Register Plus OIfset <br> Index Registar Plus Ofiset +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Offset <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Operand Data (High Order Byte) <br> Operand Data (Luw Order Byte) |

TADLE 8 - OPERATION SUMMARY (Continued)

| Address Modo and Instructions | Cyclos | $\begin{gathered} \text { Cycto } \\ \prime \prime \end{gathered}$ | VMA Lino | Adiross Bus | n/W <br> Lino | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |


| STA | 6. | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Codo Addross +1 <br> Index Registor <br> Index Register Plus Offset (w/o Carry) <br> Index Register Plus Offset <br> Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Codo <br> Offset <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Noto 1) <br> Irrelevant Data (Note 1) <br> Operand Data |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ASL LSR <br> ASR NEG <br> CLR ROL <br> COM ROR <br> DEC TST <br> INC | 7 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ |  | Op Codo Address <br> Op Code Address +1 <br> Index Register <br> Index Register Plus Offset (w/o Carry) <br> Index Register Plus Offset <br> Index, Register Plus Offset <br> Index Register Plus Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Offset <br> Irrelevant Data (Note 11 <br> Irrelevant Data (Note 1) <br> Curreni Operand Data <br> Irrelevant Data (Note 1) <br> New Operand Data (Note 3) |
| $\begin{aligned} & \text { STS } \\ & \text { STX } \end{aligned}$ | 7 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Index Register <br> Index Register Plus Offset (w/o Carry) <br> Index Register Plus Offset <br> Index Register Plus Offset <br> Index Register Pius Offset +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code <br> Offset <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| JSR | 8 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Index Register <br> Stack Pointer <br> Stack Pointer - 1 <br> Stack Pointer - 2 <br> Index Register <br> Index Register Plus Offset (w/o Carry) | 1 1 1 0 0 1 1 1 | Op Code <br> Offset <br> Irrelevant Data (Note 1) <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) |


| JMP | 3 | 1 2 3 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Op Code Address +2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Jump Address (High Order Byte) <br> Jump Address (Low Order Byte) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADC EOR <br> ADD LDA <br> AND ORA <br> BIT SBC <br> CMP SUB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Op Code Address +2 <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Operand Data |
| $\begin{aligned} & \text { CPX } \\ & \text { LDS } \\ & \text { LDX } \end{aligned}$ | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Op Code Address +2 <br> Address of Operand <br> Address of Operand +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Operand Data (High Order Byte). <br> Operand Data (Low Order Byte) |
| STA A STA B | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Op Code Address +2 <br> Operand Destination Address <br> Operand Destination Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Destination Address (High Order Byte) Destination Address (Low Order Byte) Irrelevant Data (Note 11 <br> Data Irom Accumulator |
| ASL LSR ASR NEG CLIR ROL COM ROR DEC TST INC | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ |  | Op Code Address <br> Op Code Address +1 <br> Op Code Aduross +2 <br> Address of Operand <br> Aduress of Operand <br> Address of Operand | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Current Operand Data <br> Irrelevani Data (Noto 1 ) <br> New Operand Data (Note 3) |

## TABLE 8 - OPETIATION SUMMARY (Continued)

| Adiress Mode and Instructions | Cycles | Cyclo $\#$ | VMA Line | Addross Bus | $\begin{aligned} & \text { R/W } \\ & \text { Lino } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |

EXTENDED (Continurd)

| $\begin{aligned} & \text { STS } \\ & \text { STX } \end{aligned}$ | 6 | $\begin{aligned} & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address + 2 <br> Address of Operand <br> Address of Operand <br> Address of Operand +1 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | Op Code <br> Address of Operand (High Order Byte) <br> Address of Operand (Low Order Byte) <br> Irrelevant Data (Note 1 ) <br> Operand Data (High Order Byte) <br> Operand Data (Low Order Byte) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JSR | 9 | 1 2 3 4 5 6 7 8 9 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Op Code Address +2 <br> Subroutine Starting Address <br> Stack Pointer <br> Stack Pointer - 1 <br> Stack Pointer - 2 <br> Op Code Address +2 <br> Op Code Address +2 | 1 1 1 1 0 0 1 1 1 | Op Code <br> Address of Subroutine (High Order Byte) <br> Address of Subroutine (Low Order Byte) <br> Op Code of Next Instruction <br> Return Address (Low Order Byte) <br> Return Address (High Order Byte) <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) <br> Address of Subroutine (Low Order Byte) |


| ABA <br> ASL <br> ASR <br> CBA <br> CLC <br> CLI <br> CLR <br> CLV <br> COM | DAA SEC <br> DEC SEI <br> INC SEV <br> LSR TAB <br> NEG TAP <br> NOP TBA <br> ROL TPA <br> ROR TST <br> SBA | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Op Code <br> Op Code of Next Instruction |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{\|l} \hline \text { DES } \\ \text { DEX } \\ \text { INS } \\ \text { INX } \end{array}$ |  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Previous Register Contents <br> New Register Contents | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Op Code of Next Instruction <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1) |
| PSH |  | 4 | $\begin{array}{r} 1 \\ 2 \\ 3 \\ 4 \end{array}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 . \\ & 0 \\ & 1 \end{aligned}$ | Op Code <br> Op Code of Next Instruction <br> Accumulator Data <br> Accumulator Data |
| PUL |  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Stack Pointer <br> Stack Pointer +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Op Code of Next Instruction <br> Irrelevant Data (Note 1) <br> Operand Data from Stack |
| TSX |  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer <br> New Index Register | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Op Code of Next Instruction <br> Irrelevant Data (Note 1) <br> Irrelevant Data (Note 1 ) |
| TXS |  | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Index Register <br> New Stack Pointer | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code <br> Op Code of Next Instruction <br> Irrelevant Data <br> Irrelevant Data |
| RTS |  | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \\ & i \end{aligned}$ | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer <br> Stack Pointer +1 <br> Stack Pointer +2 | 1 1 1 1 1 | Op Code <br> Irrelevant Data (Note 2) <br> Irrelevant Data (Note 1) <br> Address of Next Instruction (High Order Bytel <br> Address of Next Instruction (Low Order Byte) |

table b - OPERATION SUMmARY (Continuod)

| Address Modo and lastructions | Cycles | Cycte <br> " | VMA Lino | Addross Bus | $\begin{aligned} & 1 R / W \\ & \operatorname{Line} \end{aligned}$ |  | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

## NItERENT (Continuod)

| WAI | 9 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 8 \\ & 9 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Op Code Address <br> Op Code Address +1 <br> Stack Pointer <br> Stack Pointer-1 <br> Stack Pointer - 2 <br> Stack Pointer - 3 <br> Stack Pointer - 4 <br> Stack Pointer - 5 <br> Stack Pointer - 6 (Note 4) | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RTI | 10 |  |  | Op Code Address <br> Op Code Address + 1 <br> Stack Póinter <br> Stack Pointer +1 <br> Stack Pointer +2 <br> Stack Pointer +3 <br> Stack Pointer +4 <br> Stack Pointer +5 <br> Stack Pointer + 6 <br> Stack Pointer +7 |  |
| SWI | 12 |  | 1 <br> 1 <br> 1 <br> 1 <br> 1 <br> 1 <br> 1 <br> 1 <br> 1 <br> 0 <br> 1 <br> 1 | Op Code Address <br> Op Code Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 <br> Stack Pointer - 2 <br> Stack Pointer - 3 <br> Stack Pointer - 4 <br> Stack Pointer - 5 <br> Stack Pointer - 6 <br> Stack Pointer - 7 <br> Vector Address FFFA (Hex) <br> Vector Address FFFB (Hex) | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ |

Op Codo
Op Code of Nexi Instruction
Return Addess (Low Order Byte)
Return Audress (High Order Byte)
Index Register (Low Order Byio)
Index Register (High Order Byte)
Contents of Accumulator A
Contents of Accumulator B
Contents of Cond. Code Register
Op Code
Irrelevant Data (Note 2)
Irrelevant Data (Note 1 )
Contents of Cond. Code Register from Stack

Contents of Accumulator B from Stack
Contents of Accumulator A from Stack
Index Register from Stack (High Order Byte)
Index Register from Stack (Low Order Byte)
Next Instruction Address from Stack (High Order Byte)
Next Instruction Address from Stack (Low Order Byte)

## Op Code

Irrelevant Data (Note 1)
Return Address (Low Order Byte) Return Address (High Order Byte) Index Register (Low Order Byte) Index Register (High Order Byte)
Contents of Accumulator A
Contents of Accumulator B
Contents of Cond. Code Register Irrelevant Data (Note 1 )
Address of Subroutine (High Order Bytel

Address of Subroutine (Low Order Byte)

## RELATIVE

| BCC | BHI | BNE | 4 | 1 | 1 | Op Code Address | 1 | Op Code |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BCS | BLE | BPL |  | 2 | 1 | Op Code Address +1 | 1 | Branch Offset |
| BEQ | BLS | 8RA |  | 3 | 0 | Op Code Address + 2 | 1 | Irrelevant Data (Note 11 |
| BGE | BLT | BVC |  | 3 | 0 | Op Code Address + 2 | 1 | Irrelevant Data (Note 1) |
| BGT | BMI | BVS |  | 4 | 0 | Branch Address | 1 | Irrelevant Data (Note 1) |
| BSR |  |  | 8 | 1 | 1 | Op Code Address | 1 | Op Code |
|  |  |  |  | 2 | 1 | Op Code Address + 1 | 1 | Branch Offset |
|  |  |  |  | 3 | 0 | Return Address of Main Program | 1 | Irrelevant Data (Note 1) |
|  |  |  |  | 4 | 1 | Stack Pointer | 0 | Return Address (Low Order Byte) |
|  |  |  |  | 5 | 1 | Stack Pointer - 1 | 0 | Return Address (High Order Bytol |
|  |  |  |  | 6 | 0 | Stuck Pointer - 2 | 1 | Irrelevant Data (Noto 1) |
|  |  |  |  | 7 | 0 | Return Address of Main Program | 1 | Irrelevant Data (Note 11 |
|  |  |  |  | 8 | 0 | Subroutine Address | 1 | Irrelivant Data (Noto 1) |

Note 1. If device which is afflressed during this cycte uses VMA, then the Data Bus will go to lle high innpedance three-state condition. Deplending on bus capacitance, data trom the previous cycle inay be retained on the Data dus.
Note 2. Ditit is ignored by the MPU.
Note 3. For TSI. VMA 0 and Opitrand data dues noi change.
Note 4. White the MIJJ is wating lor the interrupt, Bus Available will go high indicating the following states of the control lines: VMA is low: Adtress Bus, $I$ /W, infd Duts Bus ure all in the high impedancu state.


Solid State Division

## Microprocessor Products

CDP1802D
CDP1802CD

Preliminary Data ${ }^{\text {a }}$

## COSMAC Microprocessor

## Features.

- Static silicon-gate CMOS circuitry-

CD4000 serics compatible

- Instruction fetch-execute time of $2.5 / 3.75 \mu \mathrm{~s}$
at $V_{D D}=10 \mathrm{~V}$
- Compatible with CDP 1801 software
- Full military.temperature range ( $-5510+125^{\circ} \mathrm{C}$ )
- High noise immunity, wide operating-voltage range
- Single voltage supply
- No minimum clock frequency.
- Lo minimur

40. Lead Dual.

- TTL compatible
- Single.phase clock; optional on-chip crystal-controlled oscillator
- Simple control of reset, start, and pause
- 8 -bit parallel organization with bidirectional data bus

The RCA.CDP 1802 is an LSI COS/MOS 8 -bit register-oriented central-processing unit (CPU) designed for use as a general-purpose computing or control element in a wide range of stored-program systems or products. It has the same basic COSMAC architecture as the CDP1801 microprocessor (see Fig. 5), but has an expanded instruction set, including a more powerful set of branch and ALU instructions, and enhanced hardware and performance features. The CDP1802 incorporates both the register and control chips of the CDP 1801 on a single chip in a 40 -lead hermetic dual-in-line ceramic package.
The CDP1802D is functionally identical to the CDP1802CD. The CDP1802D has a recommended operating voltage range of 3.12 volts; the CDP1802CD, a recommended operating voltage range of 4.6 volts.

- Any combination of standard RAM and ROM
- Memory addressing up to 65,536 bytes
- Flexible programmed I/O mode
- Program interrupt mode
- On-chip DMA
- Four I/O flag inputs directly tested by branch instructions
- Programmable output port
- 91 easy-to-use instructions
- $16 \times 16$ matrix of registers for use as multiple progran counters, data pointers, or data registers


[^0]

ARCHITECTURE
The COSMAC block diagram is shown in Fig. 5. The principal feature of this system is a register array ( $R$ ) consisting of sixteen 16 bit scratchpad registers. Individual registers in the array (R) are designated (selected) by a 4 -bit binary code from one of the 4 -bit registers labeled $N, P$, and $X$. The contents of any register can be directed to any one of the following three paths:

1. the external memory Imultiplexed, higher-order byte first, on to 8 memory address lines);
2. the $D$ register (either of the two bytes can be gated to D):
3. the increment/decrement circuit where it is increased or decreased by one and stored back in the selected 16 -bit register.
The three paths, depending on the nature of the instruction, may operate independently or in various combinations in the same machine cycle.
With two exceptions, COSMAC instructions consist of two 8 -clock-pulse machine cycles. The first cycle is the fetch cycle, and the second-and third, if necessary-are execute cycles. During the fetch cycle the four bits in the $P$ designator select one of the 16 registers $R(P)$ as the current program counter. The selected register $R(P)$ contains the address of the memory location from which the instruction is to be fetched. When the instruction is read out from the memory, the higher-order 4 bits of the instruction byte are loaded into the I register and the lower-order 4 bits into the N. register. The content of the program counter is automatically incremented by one so that $R(P)$ is now "pointing" to the next byte in the memory.
The $X$-designator selects one of the $\mathbf{1 6}$ registers $R(X)$ to "point" to the memory for an operand (or data) in certain ALU or 1/O operations.
The N designator can perform the following five functions depending on the type of instruction fetched:
4. designate one of the 16 registers in $R$ to be acted upon during register operations;


Fig. 4-Typical toral power dissipation vs. clock input freguency.
5. indicate to the $I / O$ devices a command code or device-selection code for peripherals;
6. indicate the specific operation to be executed during the ALU instructions, types of tests to be performed during the Branch instructions, or the specific operation required in a class of miscellaneous instructions (70-73 and 78 . 7B);
7. indicate the value to be loaded into $P$ to designate a new register to be used as the program counter $R(P)$;
8. indicate the value to be loaded into $X$ to designate a new register to be used as data pointer $R(X)$.
The registers in R can be assigned by a programmer in three different ways: as program counters, as data pointers, or as scratchpad locations (data registers) to hold two bytes of data.

## Program Counters

Any register can be the main program counter: the address of the selected register is held in the $P$ designator. Oither registers in R can be used as subroutine program counters. By a single instruction the contents of the $P$ register can be changed to effect a "call" to a subroutine. When interrupts are being serviced, register $R(1)$ is used as the program counter for the interrupt servicing routine. At all other times the register designated as program counter is at the discretion of the user.

## Data Pointers

The registers in $R$ may be used as data pointers $t o$ indicate a location in memory. The register designated by $X$ (i.e., $R(X)$ ) points to memory for the following instruc. tions (see Table II:

1. ALU operations FO.F5, F7, 74, 75, 77: 2. output instructions 61 through 67:
2. input instluctions 69 through 6 F;
3. certain miscellaneous instructions-7073. 78.

The register designated by $N$ li.e:, $R(N)$ ) points to memory for the "load $D$ from memory" instructions $O N$ and $4 N$ and the "Store D" instruction 6N. The register designated by $\mathbf{P}$ (i.e., the program counter) is


Fig. 5-CDP 1802 block diagram.
used as the data pointer for ALU instructions FB-FD, FF, 7C, 70, 7F. During these instruction executions the operation is referred to as "data immediate".

Another important use of R as a data pointer supports the built-in Direct-Memory-Access (DMA) function. When a DMA.In or DMA. Out request is received, one machine cycle is "stolen". This operation occurs at the end of the execute machine cycle in the current instruction. Register $R(0)$ is always used as the data pointer during the DMA operation. The data is read from (DMA.Out) or written into (DMA-In) the memory location pointed to by the $\mathrm{R}(0)$ register. At the end of the transfer, $R(0)$ is incremented by one so that the processor is ready to act upon the next DMA byte transfer request. This feature in the COSMAC architecture saves a substantial amount of logic when fast exchanges of blocks of data are required, such as with magnetic discs or during CRT-display-refresh cycles.
A program load facility, using the DN:A-In channel, is provided to enable users to load programs into the memory. This facility provides a simple, one-step means for initially entering programs into the microprocessor ystem and eliminates the requirement for specialized "bootstrap" ROM's.

## Data Registers

When registers in $R$ are used to store bytes of data. four instructions are provided which allow $D$ to receive from or write into either the higher-order-or lower-order-byte portions
of the register designated by N. By this mechanism (together with loading by data immediate) program pointer and data pointer designations are initialized. Also, this technique allows scratchpad registers in $R$ to be used to hold general data. By employing. increment or decrement instructions, such registers may be used as loop counters.
The $\mathbf{O}$ Flip Flop
An internal flip flop, $Q$, can be set or reset by instruction and can be sensed by conditional branch instructions. The output of O is also available as a microprocessor output.

## Interrupt Servicing

Register $\mathrm{R}(1)$ is always used as the program counter whenever interrupt servicing is initiated. When an interrupt request comes in and the interrupt is allowed by the program (again, nothing takes place until the completion of the current instruction) the contents of the $X$ and $P$ registers are stored in the temporary register $T$, and $X$ and $P$ are set to new values; hex digit 2 in $X$ and hex digit I in $P$. Interrupt enable is automatically deactivated to inhibit further interruptions. The interrupt routine is now in control: the contents of $T$ are saved by means of a single instruction (78) in the memory location pointed to by $R(X)$. At the conclusion of the interrupt, the routine restores the preinterrupted values of $X$ and $P$ with a single in. struction (70 or 71). The interruptenable llip.flop can be activated to permit further interrupts or can be disabled to prevent them.

Preliminary CDP 1802D, CDP 1802CD $\qquad$
COSMAC Register Summary

| D | 8 Bus | Data Register (Accumulator) | N | 4 bits | Holds Lnw. Order Instr. Digit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DF | 1611 | Data Flag (ALU Carry) | 1 | 4 Bits | Holds High Order instr. Digit |
| R | 16 Bils | 1 of 16 Scratchpad Registers | T . | 8 Bits | Holds old X, P after Interrupt |
| P | 4 Bits | Designates which register is |  |  | $(X$ is high byte) |
|  |  | Program Counter | IE | 18 Bit | Interrupt Enable |
| X | 4 Bits | Designates which register is Data Pointer | 0 | 1 Bit | Output Flip Flop |

instruction set

The COSMAC instruction summary is given in Table I. Hexadecimal notation is used to refer to the 4 -bit binary codes.
In all registers bits are numbered from the least significant bit (LSB) to the most significant bit (MSB) starting with 0 .
$R(W)$ : Register designated by $W$, where $W=N$ or $X$. or $P$

R(W).0: Lower-order byte of R(W)
$R(W) .1:$ Higher-order byte of R(W).
NO = Least significant Bit of $N$ Register Operation Notation
$M(R(N))+D ; R(N)+1$
This notation means: The memory byte pointed to by $R(N)$ is loaded into $D$. and $R(N)$ is incremented by 1 .


```
-NOTE: THISINSTRUCTION IS ASSOCIATED WITHMORE THAN ONE
    MNF MONIC EACH MNEMONIC IS INDIVIDUALTY LISTEO.
    THE AHITIMME IIC OPI HAITONS AND IHE SHIFT INSTRUCTIONS
    ARE lHE ONLY INSTHUCTIONS IHAT CAN ALTER IME OE
    AfIER AN AODINSIRUCIION
        DF - I DINOIES A CARRY HAS OCCURAEO
        OF - ODINOILS A CAHAY HAS NOT OCCURHED
    AFTCRA SUBIRACI INSIHUCIION
        DF - DI NIDISSNO UOHROW DIS A Thu% POSITIVE NUMEEA
        OF - OGINOIESA HOHRUW DIS IWO'S COMPI FMENI
        THE SVNIAAX--INOI DII'OINOIESTHE SURIIGACTION OF IME BORROW
```

. 6 .


|  | Instructio | SUMM | $Y$ (CONT'D) |
| :---: | :---: | :---: | :---: |
| INSTRUCTION | MNEMONIC | $\begin{gathered} \mathrm{OP} \\ \mathrm{CODE} \end{gathered}$ | OPERATION |
| BRANCH INSTRUCIIONS-LONG BRANCH |  |  |  |
| LONG BRANCH | L8R | C0 | $M(R(P)) \cdot f(P) .1$ |
|  |  |  | $M(R(P)+1) \cdot R(P) .0$ |
| NO LONG BRANCH (SEE LSKP) | NLBR | C8* | $\mathrm{R}(\mathrm{P})+2$ |
| LONG BRANCH IF D=0 | LBZ | C2 | $\text { IF } \begin{aligned} &=0, \\ & M(R(P)) \cdot R(P) .1 \\ & M(R(P)+1) \cdot R(P) .0 \end{aligned}$ |
|  |  |  | ELSER(P) +2 |
| LONG BRANCH IF D NOT 0 | LBNZ | CA |  |
| LONG BRANCH IF DF=1 | LBDF | C3 |  |
| LONG BRANCH IF DF $=0$ | LBNF | C8 | $\begin{gathered} \text { IF } D F=0 . \quad M(R(P))+R(P) .1 \\ M(R(P)+1) * R(P) .0 \\ E L S E R(P)+2 \end{gathered}$ |
| LONG BRANCH IF $\mathrm{Q}=1$ | LBO | C1 | $\begin{aligned} & \text { IF } \mathrm{O}=1 . M(R(P) \mid+R(P) .1 \\ & M(R(P)+1)+R(P) .0 \\ & E L S E R(P)+2 \end{aligned}$ |
| LONG BRANCH IF $\mathrm{O}=0$ | LBNO | C9 | $\begin{gathered} \text { IF } \mathrm{O}=0, \mathrm{M}(\mathrm{R}(\mathrm{P}))+\mathrm{R}(\mathrm{P}) .1 \\ \mathrm{M}(\mathrm{R}(P)+1) \rightarrow R(P) .0 \\ \mathrm{ELSE} R(P)+2 \end{gathered}$ |
| SKIP INSTRUCTIONS |  |  |  |
| SHORT SKIP | SKP | 38 | $\mathbf{R}(\mathrm{P})+1$ |
| (SEE NBR) |  |  |  |
| LONG SKIP (SEE NLBR) | LSKP | C8* | $\mathrm{R}(\mathrm{P})+2$ |
| LONG SKIP IF D=0 | LSZ | CE | IF $\mathrm{D}=0 . \mathrm{R}(\mathrm{P})+2$ |
|  |  |  | ELSE CONTINUE |
| LONG SKIP IF D NOT O | LSNZ | C6 | IF D NOT $0, R(P)+2$ <br> ELSE CONTINUE |
| LONG SKIP IF DF: 1 | LSDF | CF | if $D F=1, R(P)+2$ |
|  |  |  | ELSE CONTINUE |
| LONG SKIP IF DF=0 | LSNF | C7 | $\begin{aligned} & \text { IF } D F=0, R(P)+2 \\ & \text { ELSE CONTINUE } \end{aligned}$ |
| LONG SKIP IF $0=1$ | LSO | CD | IF $O=1 . R(P)+2$ |
|  |  |  | ELSE CONTINUE |
| LONG SKIP IF $\mathrm{Q}=0$ | LSNO | C5 . | $\begin{aligned} & \text { IF } \mathrm{O}=0, \mathrm{R}(\mathrm{P})+2 \\ & \text { ELSE CONTINUE } \end{aligned}$ |
| LONG SKIP IF IE=1 | LSIE | CC | IF $I E=1, R(P)+2$ <br> else continue |
| CONTROL INSTRUCTIONS |  |  |  |
| IDLE | IDL | $00^{3}$ | WAIT FOR DMA OR INTERRUPT: M(R(0)) + BUS |
| NO OPERATION | NOP | C4 | CONTINUE |
| SET P | SEP | DN | $N+\mathrm{P}$ |
| SET $X$ | SEX | EN | $N+X$ |
| SET 0 | SEO | 7B | $1+0$ |
| RESET 0 | REO | 7 A | $0 \rightarrow 0$ |
| SAVE | SAV | $78$ | $T+M(R(X))$ |
| PUSH X, P TO STACK | MARK | 79 | $\begin{aligned} & (X, P)+T ;(X, P)+M(R(2)) \\ & \text { THEN } P+X ; R(2)-1 \end{aligned}$ |
| RETURN | RET | 70 | $\operatorname{Min}_{i \rightarrow 1 E}(\mathrm{R}(X)+(X, P) ; R(X)+1$ |
| DISABLE | DIS | 71 | $\begin{aligned} & M(R(X))+(X, P) ; R(X)+1 \\ & O \rightarrow 1 E \end{aligned}$ |

\#An idle instruction initiates a repeating S1 cycle. The processor will continue to idie untit an I/O request (INTERRUPT, DMA.IN, or DMA.OUT) is activated. When the request is acknowledged, the IDLE cycle is terminated and the I/O request is serviced. and then normal operation is resumed.
onote: this instruction is associaten with more than one
MNEMONIC. EACH MNE MUNIC IS INDIVIOUALLY LISTED.

| INSTRUCTION | MNEMONIC | $\begin{aligned} & \mathrm{OP} \\ & \mathrm{CODE} \end{aligned}$ | OPERATION |
| :---: | :---: | :---: | :---: |
| INPUT-OUTPUT BYTE TRANSFER |  |  |  |
| OUTPUT 1 | OUT 1 | 61 | M $(R(X) \mid$ BUS; $R(X)+1 ;$ L LINES $=1$ |
| OUTPUT 2 | OUT 2 | 62 | M(R(X)) $\mathrm{BUS}: R(X)+1 ; \mathrm{N}$ LINES $=2$ |
| OUTPUT 3 | OUT 3 | 63 | $M(R(X)]$ BUS; $R(X)+1 ; N$ LINES $=3$ |
| OUTPUT 4 | OUT 4 | 64 | M(R(X))+BUS: $R(X)+1 ; N$ LINES $=4$ |
| OUTPUT 5 | OUT 5 | 65 | M(R(X) + BUS; $R(X)+1 ; N$ LINES $=5$ |
| OUTPUT 6 | OUT 6 | 66 | $\mathrm{M}(\mathrm{R}(\mathrm{X}) 1$-BUS; $\mathrm{R}(\mathrm{X})+1 ; \mathrm{N}$ LINES $=6$ |
| OUTPUT 7 | OUT 7 | 67 | $M(R(X))$-BUS; $R(X)+1 ; N$ LINES $=7$ |
| JNPUT 1 | INP 1 | 69 | BUS + M $(\mathrm{R}(\mathrm{X})$ ); BUS $+\mathrm{D} ; \mathrm{N}$ LINES $=1$ |
| INPUT 2 | INP 2 | 6 A |  |
| INPUT 3 | INP 3 | 68 | BUS + M (R $(X) 1 ;$ BUS + D N LINES $=3$ |
| INPUT 4 | INP 4 | 6 C | BUS $\rightarrow$ M (R (X)); BUS + D; N LINES $=4$ |
| INPUT 5 | INP 5 | 60 | BUS + M (R $(X) 1$; BUS 0 O N LINES $=5$ |
| INPUT 6 | INP 6 | $6 E$ | BUS + M (R(X)); BUS + D; LINES $=6$ |
| INPUT 7 | INP 7 | 6 F | BUS $+M(R(X) 1: B U S+D ; N$ LINES $=7$ |

- Long-Branch, Long-Skip and No Op instructions are the only instructions that require three eycles to complete ( 1 fetch +2 execute).
Long-Branch instructions are three bytes long. The first byte specifies the condition to be tested; and the second and third byte, the branching address.
The long-branch instructions can:
a) Branch unconditionally
b) Test for $\mathrm{D}=0$ or $\mathrm{D} \neq 0$
c) Test for $\mathrm{DF}=0$ or $\mathrm{DF}=1$
d) Test for $Q=0$ or $Q=1$
e) effect an unconditional no branch

If the tested condition is met, then branching takes place; the branching address bytes are loaded in the high-and-low-order bytes of the current program counter, respectively. This operation effects a branch to any memory location.
If the tested condition is not met, the branching address bytes are skipped over, and the next instruction in sequence is fetched and executed. This operation is taken for the case of unconditional no branch.
2. The short-branch instructions are two bytes long. The first byte specifies the condition to be tested, and the second specifies the branching address.
The short-branch instructions can:
a) Branch unconditionally
b) Test for $\mathrm{D}=0$ or $\mathrm{D} \neq 0$
c) Test for $D F=0$ or $D F=1$
d) Test for $\mathrm{Q}=0$ or $\mathrm{Q}=1$
e) Test the status (1 or 0) of the four EF flags

1) Effect an unconditional no branch

If the tested condition is met, then branching takes place; the branching address byte is loaded into the low-order byte position of the current program counter. This effects a branch with the current 256 -byte page of the memory, i.e., the page which holds the branching address. If the tested condition is not met, the branching address byte is skipped over, and the next instruction in sequence is fetched and executed. This same action is taken in the case of unconditional no branch.
3. The skip instructions are one byte long. There is one Unconditional Short-Skip (SKP) and eight Long-Skip instructions.
The Unconditional Short-Skip instruction takes 2 cycles to complete ( 1 fetch +1 execute). Its action is to skip over the byte following it. Then the next instruction in sequence is fetched and executed. This SKP instruction is identical to the unconditional no-branch instruction (NBR) except that the skipped-over byte is not considered part of the program. The Long-Skip instructions take three cycles to complete ( 1 tetch +2 execute).
They can:
a) Skip unconditionally
b) Test for $\mathrm{D}=0$ or $\mathrm{D} \neq 0$
c) Test for $\mathrm{DF}=0$ or $\mathrm{DF}=1$
d) Test for $\mathrm{O}=0$ or $\mathrm{O}=1$
e) Test for IE=1

If the tested condition is met, then Long Skip takes place; the current program counter is incremented iwice. Thus iwo bytes are skipped over and the next instruction in sequence is fetched and executed. It the tested condition is not met. then no action is taken.
Execution is continued by fetching the next instruction in sequence.

BUS 0 to BUS 7
(Data Bus)
NO to N2 (1/O Command)
$\overline{E F 1} 10 \overline{E F 4}$ (4 Flags)

INTERAUPT, DMA.IN, DMA.OUT (3 1/O Reauests)

SCO. SC1,
(2 State Code Lines)

TPA. TPB
(2 Timing Pulses)

MAO to MA7
(8 Memory Address Lines)

8-hit directional DATA BUS tines. These lines are used for uansterring dara between the memory, the microprocessor. and $1 / O$ devices.
Issued by an $1 / O$ instruction to signal the $1 / O$ control logic of a data transfer between memory and $1 / O$ interface. These lines can be used to issuc command codes or device selection codes to the $1 / O$ devices (independently or combined with the memory byte on the data bus when an I/O instruction is being executed). The $N$ bits are low at all times except when an $1 / 0$ instruction is being executed. During this time their state is the same as the cortesponding bits in the N regisier:
The direction of data flow is defined in the $1 / O$ instruction by bit N3 and is indicated by the level of the MRD signal.
$\overline{M R D}=V_{C C}$ : Data from I/O to $C P U$ and Memory
$\overline{M R D}=V_{S S}$ : Data from Memory to I/O
These levels enable the $1 / 0$ controllers to transfer status information to the processor. The levels can be tested by the conditional branch instructions. They can be used in conjunction with the INTERRUPT request line to establish interrupt priorities. These flags can also be used by 1/O devices to "call the attention" of the processor, in which case the program must routinely test the status of these flag(s). The flag(s) are sampled at the beginning of every S1 cycle.
These signals are sampled by the CDP 1802 during the interval between the leading edge of TPB and the leading edge of TPA.
Interrupt Action: $X$ and $P$ are stored in $T$ after executing current instruction; designator $X$ is set to 2; designator $P$ is set to 1 ; interrupt enable is reset to 0 (inhibit); and instruction execution is resumed.
DMA Action: Finish executing current instruction; $R(0)$ points to memory area for data transfer; data is loaded into or read out of memory; and increment $R(0)$.
Note: In the event of concurrent DMA and INTERRUPT requests, DMA.IN has priority followed by DMA.OUT and then INTERRUPT.
These lines indicate that the CPU is: 1) fetching an instruction, or 2l executing an instruction, or 3) processing a DMA request, or 4) acknowledging an interrupt request. The levels of state code are tabulated below. All states are valid at TPA. $\mathrm{H}=\mathrm{V}_{\mathrm{CC}}, \mathrm{L}=\mathrm{V}_{\mathrm{SS}}$.

| State Type | State Code Lines |  |
| :--- | :---: | :---: |
|  | L | SC0 |
| S1 (Execute) | L | H |
| S2 (DMA) | H | L |
| S3 (Interrupt) | H | H |

Positive pulses that occur once in each machine cycle (TPB follows TPA). They are used by I/O controtlers to interpret codes and to time interaction with the data bus. The trailing edge of TPA is used by the memory system to latch. the higher-order byte of the 16 bit memory address. TPA is suppressed in IDLE when the CPU is in the load mode.

The higher order byte of a $\mathbf{1 6}$ bit COSMAC memory address appears on the memory address lines MAO-7 first. Those bits required by the memory system are strobed into external address taiches by timing pulse TPA. The low-order byte of the 16 bit address appears on the address lines after the termination of TPA. Latching of all 8 higher-order address bits would permit a memory system ol G4K bytes.

- 10 .
$\overline{M W R}$ (Write Pulse)

0

CLOCK

WAIT, CLEAR
(2 Control Lines)

A negative pulse anueating in a memory-write cycle, atter the address lines have stabilized.
A low levet on MAD indicates a memory read eycle. It can be used to contiol threestate outputs from the addressed memory which may have a common data input and output bus. If a memory does not have a theee-state high-impedance output, $\bar{M} \bar{D}$ is useful for driving memoryfbus separator gates. It is also used to indicate the direction of data trans. fer during an I/O instruction:
$\overline{M R D}=\mathrm{V}_{\mathrm{CC}}$ : Data from I/O to CPU and Memory
$\overrightarrow{M R D}=V_{\mathbf{S S}}$ : Data from Memory to I/O
Single bit output from the CPU which can be set or reset under program control. During SEQ or REQ instruction execution. $O$ is set or reset between the trailing edge of TPA and the leading edge of TPB.
Input for externally generated single-phase clock. A typical clock frequency is 6.4 MHz at $\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=10 \mathrm{volts}$. The clock is counted down internally to 8 clock pulses per machine cycle.
Connection to be used with clock input terminal, for an external crystal, if the on-chip oscillator is utilized. The crystal is connected between terminals 1 and 39 (CLOCK and $\overline{X T A L}$ ) in parallel with a resistance ( 10 megohms typ.). Frequency trimming capacitors may be required at terminals 1 and 39.
Provide four control modes as listed in the following truth table:

| $\overline{\text { CLEAR }}$ | WATT | MODE |
| :---: | :---: | :--- |
| L | L | Load |
| L | $H$ | Reset |
| $H$ | L | Pause |
| $H$ | $H$ | Run |

The function of the modes are defined as follows: Load
Holds the CPU in the IDLE execution state and allows an 1/O device to load the memory without the need for a "bootstrap" loader. It modifies the IDLE condition so that DMA-IN operation does not force execution of the next instruction.
Reset
Registers I, N, $Q$ are reset, IE is set and $0^{\prime}$ ( $V_{S S}$ ) are placed on the data bus. TPA and TPB are suppressed while reset is held and the CPU is placed in S1. The first machine cycle after termination of reset is an initialization cycle. During this cycle the CPU remains in S1 and registers X, P. and R(0) are reset. Interrupt and DMA servicing are suppressed during the initialization cycle.
The next eycle is an S0. S1. or an S2 but never an S3. With the use of a 71 instruction followed by 00 at memory locations 0000 and 0001, this feature may be used to reset IE, so as to preclude interrupts until ready for them. Powerup reset can be realized by connecting an external RC to CLEAR.
Pause
Stops the internal CPU timing generator on the first negative high-to-low transition of the input clock. The oscillator continues to operate, but subsequent clock transitions are ignored.
Pun
May be initiated from the Pause or Reset mode functions. If initiated from Pause, the CPU resumes operation on the first negative high-to low transition of the input clack. When initiated from the Reset operation, the first machine cycle following Reset is always the initialization cycle. The initialization cycle is then followed by a DMA (S2) cycle or fetch ( SO ) from location 0000 in memory.

## - 11 .



The CDP1802 and CDP1802C CPU state transitions when in the RUN mode are shown in Fig. 6. Each machine cycle requires the same period of time-8 clock pulses. The execution of an instruction requires either two or three machine cycles, 50 followed by a single $S 1$ cycle or two $S 1$ cycles. $S 2$ is the response to a DMA request and S3 is the interrupt response.

Fig. 6-CDP 1802 microprocessor state transitions (Run Mode).
OPERATING AND HANDLING CONSIDERATIONS FOR CDP1802D AND CDP1802CD

1. Handling

All inputs and outputs of this device have a network for electrostatic protection during handing. Recommended handling practices for COS/MOS devices are described in ICAN 6000 "Handling and Operating Considerations for MOS Integrated Circuits", available on request from RCA Solid State Division, Box 3200 . Somerville, N.J. 08876.
2. Operating

## Operating Voltage

During operation near the maximum supply voltage limit, care should be taken to avoid or suppress power supply turnon and turn-off transients, power supply ripple, or ground noise: any of these conditions must not cause $V_{D D} \cdot V_{S S}$ to
exceed the absolute maximum rating. $V_{C C}$ must be less than equal to $\mathrm{V}_{\mathrm{DO}}$. Power supplies should be sequenced to insure compliance.

## Input Signals

To prevent damage to the input protec. tion circuit, input signats should never be greater than VDD nor less than VSS. Input currenis must not exceed 10 mA even when the power supply is off.

## Unused Inputs

A connection must be provided at every input terminal. All unused input terminals must be connected to either VOD or $V_{S S}$, whichever is appropriate.

## Output Short Circuits

Shorting of outputs to VDD or VSS may damage COS/MOS devices by exceeding the maximum device dissipation.

DIMENSIONAL OUTLINE

CDP1802D, CDP1802CD
40-Lead Dual-In-Line Ceramic


Whon incorporating RCA Solta Siste Devicet in squipment. It is iecommienderl thet the destynat refer to "Ouperoting Conviderntions tor HCA Soltd tequet from HC Sillil Sitis Divialun. Bon 3200 . somervilis. N. J. Ous $/ 0$.
RCAISolid State Division|Somerville. NJ 08876

| DIM. | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN. | MAX. | MIN. | MAX. |
| A | 50.30 | 51.30 | 1.980 | 2.020 |
| C | 2.42 | 3.93 | 0095 | 0355 |
| 0 | 0.43 | 0.56 | 0.017 | 0023 |
| $F$ | 1.27 REF. |  | 0.050 REF. |  |
| G | 254 BSC |  | 0.100 BSC |  |
| H | 076 | 178 | 0030 | 0070 |
| $J$ | 020 | 030 | 0008 | 0012 |
| K | 318 | 4.45 | 0125 | 0175 |
| $L$ | 1474 | 1574 | 0580 | 0620 |
| M | - | 70 | - | 30 |
| $p$ | 064. | 127 | 0025 | 0050 |
| N | 40 |  | 40 |  |

## NOTES

1. Leadi within 013 mm 100051 iadius of true porition at manimum matetial condition.
2. Dimension "L" to center of leads when lormed psiallel
3. Whea ithis device is suppled walder dipped, the mianimum lasd thictiness (natiow portion) will not eiceed 0013 in. $1033 \mathrm{~mm})$

[^0]:    - The Pielimuner Data ere uniended tor gurdance pur. Intormation furnished by RCA is believed
    
     itandero line of comirnaricially eveitable products. for ewrient intormation on the tiotios of this preqgem Mreme coniact you HCA Salen Otife. esponsibitity is aisumed by RCA tor it ese nor tiry $u$ arsumed by HCA tor $n$ I or oiker tor any inifingements of ostenis Trademash(s) fiegistered ${ }^{(0)}$ or oither ights ol thiro paties which may Marcaisi fiegistradals)
    resuli lrom its ure. No ticenie is granted or implication or otherwise umiter any patent or petent rights of HCA.

