

AD A0 61 812

AFAL-TR-78-77



DC

021

# DEVELOPMENT AID FOR AN EMULATING MICROPROCESSOR

DC FILE COPY

R. FOSDICK TRACOR, INC. AUSTIN, TEXAS 78721

**JUNE 1978** 

TECHNICAL REPORT AFAL-TR-78-77 Final Report 14 February 1977 – 28 February 1978

6) 19

Approved for public release; distribution unlimited.

AIR FORCE AVIONICS LABORATORY AIR FORCE WRIGHT AERONAUTICAL LABORATORIES AIR FORCE SYSTEMS COMMAND WRIGHT-PATTERSON AIR FORCE BASE, OHIO 45433

#### NOTICE

When Government drawings, specifications, or other data are used for any purpose other than in connection with a definitely related Government procurement operation, the United States Government thereby incurs no responsibility nor any obligation whatsoever, and the fact that the government may have formulated, furnished, or in any way supplied the said drawings, specifications, or other data, is not to be regarded by implication or otherwise as in any manner licensing the holder or any other person or corporation, or conveying any rights or permission to manufacture, use, or sell any patented invention that may in any way be related thereto.

This technical report has been reviewed and is approved for publication. This report has been reviewed by the Information Office (OI) and is releasable to the National Technical Information Service (NTIS). At NTIS, it will be available to the general public, including foreign nations.

GARY D. GAUGLER, Project Engineer Prototyping & Standardization Group Microelectronics Branch Electronic Technology Division

tayley Elvanin

STANLEY E. WAGNER, Chief Microelectronics Branch Electronic Technology Division

FOR THE COMMANDER:

WILLIAM EDWARDS, Chief Electronic Technology Division

"If your address has changed, if you wish to be removed from our mailing list, or if the addressee is no longer employed by your organization please notify AFAL/DHE-3, W-P AFB, OH 45433 to help us maintain a current mailing list".

Copies of this report should not be returned unless return is required by security considerations, contractual obligations, or notice on a specific document.

AIR FORCE/56780/8 November 1978 - 125

| 10                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | READ INSTRUCTIONS                                                                                                                                                                                                                  |
|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                          | REPORT DOCUMENTATION PAGE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | BEFORE COMPLETING FORM<br>3. RECIPIENT'S CATALOG NUMBER                                                                                                                                                                            |
| 1DT                                                      | FALLTR-78-77                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                    |
|                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 5. TYPE OF REPORT & PERIOD COVERED                                                                                                                                                                                                 |
|                                                          | EVELOPMENT AID FOR AN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Final Report.                                                                                                                                                                                                                      |
| EN                                                       | MULATING MICROPROCESSOR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 14 FEB 1077 - 28 FEB 1978                                                                                                                                                                                                          |
| 4                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | S-PERFORMING ORG: REPORT NUMBER                                                                                                                                                                                                    |
| 7.                                                       | AUTHOR(.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 8. CONTRACT OR GRANT NUMBER(s)                                                                                                                                                                                                     |
|                                                          | (15)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                    |
| 101 R.                                                   | . Fosdick                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | F33615-77-C-1115 Mar                                                                                                                                                                                                               |
| -                                                        | PERFORMING ORGANIZATION NAME AND ADDRESS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 10. PROGRAM ELEMENT, PROJECT, TASK                                                                                                                                                                                                 |
|                                                          | racor, Inc.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ARGA OVORK UNIT NUMBERS                                                                                                                                                                                                            |
|                                                          | ustin, TX 78721 $\checkmark$ (16)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 6096/40-05                                                                                                                                                                                                                         |
|                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | and a second second                                                                                                                                                                                                                |
|                                                          | CONTROLLING OFFICE NAME AND ADDRESS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | JUNE 1978                                                                                                                                                                                                                          |
| Wr                                                       | ir Force Avionics Laboratory (DHE)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 13. NUMBER OF PAGES                                                                                                                                                                                                                |
|                                                          | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                    |
| 14.                                                      | MONITORING AGENCY NAME & ADDRESS(II different from Controlling Office)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 15. SECURITY CLASS. (of this report)                                                                                                                                                                                               |
| 1                                                        | (14)330.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Unclassified                                                                                                                                                                                                                       |
|                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 15a. DECLASSIFICATION/DOWNGRADING<br>SCHEDULE N/A                                                                                                                                                                                  |
| 17.                                                      | DISTRIBUTION STATEMENT (of the abstract entered in Block 20, if different fro                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | m Report)                                                                                                                                                                                                                          |
|                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                    |
| 18.                                                      | DISTRIBUTION STATEMENT (of the abstract entered in Block 20, if different fro                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | m Report)                                                                                                                                                                                                                          |
| 19.<br>Ge<br>20.<br>TI<br>U<br>t<br>O<br>f<br>f<br>m     | DISTRIBUTION STATEMENT (of the abstract entered in Block 20, if different fro<br>SUPPLEMENTARY NOTES<br>KEY WORDS (Continue on reverse side if necessary and identify by block number)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | implement a complete emulator<br>that the GPU was going<br>ted to start the definition<br>eveloping an LSI Simulator<br>overs work performed to<br>tics of a high performance<br>the study were: op-code                           |
| 19.<br>Gu<br>20.<br>TI<br>U<br>tr<br>0<br>fr<br>du<br>du | DISTRIBUTION STATEMENT (of the abstract entered in Block 20, if different fro<br>SUPPLEMENTARY NOTES<br>KEY WORDS (Continue on reverse side if necessary and identify by block number)<br>eneral Processor Unit (GPU)<br>ABSTRACT (Continue on reverse side If necessary and identify by block number)<br>his is the final report of a program initiated to<br>tilizing the GPU circuit. When it was discovered<br>to require some mask changes the effort was redirect<br>f the LSI Micro Controller Circuit and to start de<br>or systems interface verification. This report co<br>stablish the initial requirements and characterist<br>icroprogram controller IC. Some key elements of t<br>ecomposition techniques of target machines, defini                                                     | implement a complete emulato<br>that the GPU was going<br>ted to start the definition<br>eveloping an LSI Simulator<br>vers work performed to<br>tics of a high performance<br>the study were: op-code<br>tion of the controller   |
| 19.<br>Gu<br>20.<br>TI<br>U<br>tr<br>0<br>fr<br>du<br>du | DISTRIBUTION STATEMENT (of the abstract entered in Block 20, if different fro<br>SUPPLEMENTARY NOTES<br>KEY WORDS (Continue on reverse side if necessary and identify by block number)<br>eneral Processor Unit (GPU)<br>ABSTRACT (Continue on reverse side if necessary and identify by block number)<br>his is the final report of a program initiated to<br>tilizing the GPU circuit. When it was discovered<br>o require some mask changes the effort was redirect<br>f the LSI Micro Controller Circuit and to start de<br>or systems interface verification. This report co<br>stablish the initial requirements and characterist<br>icroprogram controller IC. Some key elements of t<br>ecomposition techniques of target machines, defini<br>FORM 1473 EDITION OF 1 NOV 65 IS OBSOLETE UNCLASS | implement a complete emulato<br>that the GPU was going<br>ted to start the definition<br>eveloping an LSI Simulator<br>vers work performed to<br>tics of a high performance<br>the study were: op-code<br>tion of the controller   |
| 19.<br>Gu<br>20.<br>TI<br>U<br>tr<br>0<br>fr<br>du<br>du | DISTRIBUTION STATEMENT (of the abstract entered in Block 20, if different fro<br>SUPPLEMENTARY NOTES<br>KEY WORDS (Continue on reverse side if necessary and identify by block number)<br>eneral Processor Unit (GPU)<br>ABSTRACT (Continue on reverse side if necessary and identify by block number)<br>his is the final report of a program initiated to<br>tilizing the GPU circuit. When it was discovered<br>o require some mask changes the effort was redirect<br>f the LSI Micro Controller Circuit and to start de<br>or systems interface verification. This report co<br>stablish the initial requirements and characterist<br>icroprogram controller IC. Some key elements of t<br>ecomposition techniques of target machines, defini<br>FORM 1473 EDITION OF 1 NOV 65 IS OBSOLETE UNCLASS | implement a complete emulator<br>that the GPU was going<br>ted to start the definition<br>eveloping an LSI Simulator<br>overs work performed to<br>tics of a high performance<br>the study were: op-code<br>tion of the controller |

### SECURITY CLASSIFICATION OF THIS PAGE(When Date Entered)

P

A

function, and architecture of target machines with regards to requirements for the controller IC. The information developed under this contract will be of direct use in a follow-on contract to design and develop the controller IC.

| CCESSION for<br>NTIS<br>NDC | White | Section Section |   |      |
|-----------------------------|-------|-----------------|---|------|
| INAMNOUTHCE                 |       |                 |   |      |
| LS FICATION                 | •     |                 |   |      |
| RY                          |       |                 |   |      |
| DISTRIBUTION                | · 45. | et it v         | 1 | £\$  |
|                             |       |                 |   | CIAL |

#### SECURITY CLASSIFICATION OF THIS PAGE(When Data Entered)

11

### PREFACE

This report covers work in preparation to a follow-on contract for the design and development of a micro program controller IC in support of the General Processor Unit (GPU).

The work performed includes the detailed examination of the architectures of target machines, op-code decomposition, constraints placed upon the controller function, and the characteristics and requirements of an advanced micro program controller. The purpose of the preliminary investigation was to characterize the target machines and to correlate the architectural and op-code requirements placed upon a controller IC.

This report was prepared by Tracor Inc., Applied Technology Systems Division, Austin, Texas, under Air Force contract F33615-77-C-1115. The contract is titled "Development Aid for an Emulating Microprocessor". Amendment P00002 modified the contract to initiate the analysis to define a micro-controller circuit compatible with the GPU circuit family. The report describes work performed during the period of February 1977 through December 1977. The effort was sponsored by the Air Force Avionics Laboratory, Wright-Patterson AFB, OH. Captain Thomas Margraff (AFAL/DHE) was contract monitor.

The report was submitted January 1978.

"Publication of this report does not constitute Air Force approval of the report's findings or conclusions. It is published only for the exchange and stimulation of ideas."

Reviewed and Approved:

Approved: Dobest Fonde

ROBERT FOSDICK Program Director, Computer Devices Teletypewriters and Digital Systems

11 27 021

# TABLE OF CONTENTS

| SECTIO | DN |    |     |                                                              | PAGE |
|--------|----|----|-----|--------------------------------------------------------------|------|
| I      |    |    |     | CONTROLLER REQUIREMENTS STUDY                                | 1    |
|        | ۱. |    |     | INTRODUCTION                                                 | 1    |
|        | 2. |    |     | PROCESSOR CHARACTERISTICS SURVEY                             | 1    |
|        |    | a. |     | PDP-11 Characteristics                                       | 1    |
|        |    |    | (1) | PDP-11 Instruction Description                               | 2    |
|        |    | ь. |     | UYK-20, AYK-14 Characteristics                               | 2    |
|        |    |    | (1) | UYK-20 Instruction Description                               | 2    |
|        |    |    | (2) | UYK-20 Register Format Field                                 | 2    |
|        |    | c. |     | AYK-15 (DAIS Processor) Characteristics                      | 6    |
|        |    |    | (1) | AYK-15 Instruction Description                               | 6    |
|        | 3. |    |     | INDENTIFICATION OF CONTROL REQUIREMENTS                      | 8    |
|        |    | a. |     | PDP-11 Instruction Decomposition                             | 8    |
|        |    | b. |     | Controller Features Desirable for the PDP-11 Instruction Set | 12   |
|        |    |    | (1) | Field Masked Branching                                       | 12   |
|        |    |    | (2) | Field Branching                                              | 12   |
|        |    | c. |     | UYK-20 Emulation Approach                                    | 14   |
|        | 4. |    |     | SYNOPSIS OF CONTROL FUNCTIONS                                | 16   |
|        |    | a. |     | Machine Instruction Interpretation                           | 16   |
|        |    | ь. |     | Micro-Command Sequencing                                     | 16   |
|        |    | c. |     | Memory Request                                               | 17   |
|        |    | d. |     | Direct Memory Access (DMA)                                   | 17   |

٧

# TABLE OF CONTENTS (CONTINUED)

| SECTION |                                      | PAGE |
|---------|--------------------------------------|------|
| е.      | Register Designation                 | 17   |
| f.      | Interrupts                           | 17   |
| g.      | User Interface                       | 17   |
| h.      | Conditional Status Inputs/Storage    | 17   |
| i.      | Input/Output                         | 17   |
| 5.      | RECOMMENDATIONS                      | 17   |
| П       | GENERAL PROCESSOR UNIT (GPU) SUPPORT | 19   |

### SECTION I

### CONTROLLER REQUIREMENTS STUDY

## 1. INTRODUCTION

The family of circuits the controller is to be a part of are fabricated with the CMOS/SOS process. These circuits have certain inherent features desirable to the military for the implementation of computers which include:

- 1) Low power
- 2) High performance
- 3) Good radiation tolerance
- 4) High tolerance to voltage variation
- 5) High noise immunity
- 6) Single voltage requirement
- 7) Good packing densities

As with any new circuit technology development there is not a large base of existing circuits available to supplement the new designs and it is undesirable to mix technologies as the advantages peculiar to each technology would be lost. Therefore, it is desirable to make each device in the circuit family as complete as possible, thus minimizing the need for additional special purpose circuits. The object of this study is to survey the control functions in military avionics processors and define the requirements for the controller. It is desirable that the device be capable of implementing various control type functions in different areas of a computer with the goal of minimizing the requirements for additional unique circuit developments.

## 2. PROCESSOR CHARACTERISTICS SURVEY

a. PDP-11 Characteristics. The PDP-11 family of processors start with a basic instruction set and a range of hardware performances most suited for this application. The PDP-11 is a 16-bit architecture with all instructions also being 16-bits. Following are a list of features in the PDP-11 family that relate directly to the control functions:

- 1) 16-bit word
- 2) Direct addressing of 32K 16-bit words
- 3) Word or byte processing
- 4) Stack processing
- 5) Direct Memory Access (DMA)
- 6) 8 internal, general purpose registers
- 7) Vectored, priority interrupts
- 8) Single and double operand instructions
- 9) Multiply/divide and floating point options
- 10) Status register (1)

(1) PDP-11 Instruction Description. The PDP-11 instruction employs the use of many instruction formats with multiple field definitions to provide the memory addressing flexibility that other machines provide by using a 32-bit instruction. The basic instruction formats are shown in Figure 1. The operand derivations provided for both the source and destination fields represent a good set that contribute much to acceptance of this family. The operand derivation list is shown in Figure 2.

b. UYK-20, AYK-14 Characteristics. The AYK-14 is the Navy's airborne computer also referred to as the ISADC (Interim Standard Airborne Digital Computer). The AYK-14 emulates the UYK-20 instruction set and includes several additional instructions unique to the AYK-14. The UYK-20 has been the Navy's standard shipboard computer for the past several years and represents the nearest to a standard computer architecture for the Navy.

The UYK-20 and AYK-14 computers are 16-bit general purpose machines incorporating an extensive instruction set that has evolved from previous Navy computers. Following are a list of the functional features relating to the control requirements:

- 1) 8-bit, 16-bit, 32-bit operands
- 2) 16 general purpose registers
- 3) 2 program status registers
- 4) 16-bit and 32-bit instructions
- 5) Direct addressing by page
- 6) Relative addressing by page
- 7) Cascade indirect addressing
- 8) 3-level interrupt processing
- 9) MATHPAC option
- 10) Input-output controller
- 11) Indexing via general registers
- 12) 16-bit memory word
- 13) Real-time and monitor clocks
- 14) Direct Memory Access (DMA)

(1) UYK-20 Instruction Description. The UYK-20 has a 6-bit op-code field, a 2-bit format field, and two 4-bit register fields. The first register field, Ra, is the accumulator register. Ra is usually the source of transfers to memory or is the destination of transfers from memory. The second register, Rm, is typically a memory pointer. Rm may have uses other than a memory pointer. In single register instructions, Rm is sometimes used to expand one op-code into 16 instructions. UYK-20 Instruction Formats are shown in Figure 3.

(2) UYK-20 Register Format Field. Except for op-codes 40 through 47 (jump instructions), 60 through 63 (register immediate instructions), and 70 through 77 (I/O instructions), the two-bit register format field is used according to simple, well defined rules. These rules are:

| Op Code      | Destination |
|--------------|-------------|
| 10,0,0 11111 | Mode Reg.   |

Single Operand

| Source      | Destination |
|-------------|-------------|
| Mode   Reg. | Mode Reg.   |
|             |             |

Double Operand

| Op Code<br>0 1 1 1<br>0 0 0 0 0 1 1 | Reg. | Source/<br>Destination<br>Mode Reg. |
|-------------------------------------|------|-------------------------------------|
|-------------------------------------|------|-------------------------------------|

| Register - | Source | of | Destination |
|------------|--------|----|-------------|
|------------|--------|----|-------------|

| Base Code | Offset |   |
|-----------|--------|---|
| 0,0,00,1  | 11111  | 1 |

Branch

|                   | Op Code       |
|-------------------|---------------|
| 0 0 0 0 0 0 0 0 0 | 1 1 1 1 1 1 1 |

Miscellaneous

Figure 1. PDP-11 Instruction Formats

# Description

| 2 Register Pointer - autoincrement       |   |
|------------------------------------------|---|
| 4 Register Pointer - autodecrement       |   |
| 6 Register Pointer plus next 16-bit word |   |
| 1 Register Pointer                       |   |
| 3 Register Pointer - indirect -          |   |
| autoincrement deferred                   |   |
| 5 Register Pointer - autodecrement       |   |
| deferred - indirect                      |   |
| 7 Register Pointer plus next 16-bit word | - |
| indirect                                 |   |

Figure 2. Operand Derivations

4

Mode

1

| Op-code | f | Ra | Rm |
|---------|---|----|----|
|---------|---|----|----|

Register - Literal

| Op-code | 00 | Ra | Rm   |
|---------|----|----|------|
| p ooue  |    | nα | 1.11 |

Register - Register

|         | 1   |   |  |
|---------|-----|---|--|
| Op-code | 0 1 | d |  |
| <br>    |     |   |  |

Register - Immediate Type 1

| Op-code                                                                                                              | 01 | Ra | Rm |   |
|----------------------------------------------------------------------------------------------------------------------|----|----|----|---|
| <br>and the second |    |    |    | - |

Register - Immediate Type 2

| Op-code | 10 | Ra | Rm |
|---------|----|----|----|
|         | y  |    |    |

Register - Constant

Register - Index

Figure 3. UYK-20, AYK-14 Instruction Formats

## Format Implied Operation

0

1

- Register to Register Operations (RR) such as (Ra) +  $(Rm) \rightarrow Ra$ , where (Ra) means the content of register Ra.
- Register indirect operations (RI) such as (Ra) + (Y\*)→Ra where Y\* is the content of the memory location with address (Rm).
- 2 Register indexed operation (RK) such as (Ra) + Y→Ra Y = (Rm) + y if Rm ≠ Ro or Y = y if Rm = Ro and where y is the content of memory location following the instruction.
- 3 Register indexed, deferred operations (RX) such as (Ra) + (Y)→ Ra where (Y) is the content of the memory location derived as in format 2, above.

c. AYK-15 (DAIS Processor) Characteristics. The AYK-15 is the avionics computer developed by the Air Force in support of the Digital Avionics Information System (DIAS) program. This computer also employs a 16-bit architecture and has a fairly large instruction set with several urique instructions in support of other DAIS hardware descriptions. Following is a list of AYK-15 features related to control functions.

- 1) 16 general purpose registers
- 2) Direct addressing to 65K
- 3) Single level indirect addressing
- 4) 16-bit immediate operand
- 5) Indexing via general registers
- 6) Floating point
- 7) Bit operation
- 8) 16-bit and 32-bit operands
- 9) 16 level vectored interrupt system
- 10) 2 internal timers
- 11) 1K block write protect
- 12) 16-bit memory word

(1) AYK-15 Instruction Description. The AYK-15 only employs two instruction formats (16-bit and 32-bit). The field boundaries of the 16-bit format are identical to that of the upper half of the 32-bit format. Figure 4 shows the two formats. GRI and GR2 typically specify any of 16 general registers. The GRI field, however, may contain a shift count, condition code, or bit number in some instructions. Rx is one of 15 general registers that can be used for indexing. The 16-bit address field is either a memory address or a 16-bit immediate operated for the instructions specifying immediate addressing.

| Op-code | GR1 | GR2 |
|---------|-----|-----|
|         |     |     |

16-Bit Format

| Op-code    | GR1        | GR2 |
|------------|------------|-----|
| 16-Bit Add | ress Field |     |

32-Bit Format

Figure 4. AYK-15 Instruction Formats

The 8-bit op-codes in the AYK-15 are denoted in hex and the first digit specifies the type of instruction:

| 1)       | Bit operation | 5 |
|----------|---------------|---|
| 2)       | Shift         | 6 |
| 2)<br>3) | Jump          | 7 |
| 4)       | Load          | 8 |
| 5)       | Store         | 9 |
| 6)       | Add           | Α |
| 7)       | Subtract      | В |
| 8)<br>9) | Multiply      | C |
| 9)       | Divide        | D |
| 10)      | Logical       | E |
| 11)      | Compare       | F |

The second hex digit generally specifies the modifier on the instruction type and the addressing option from the following set:

| 1)             | Single precision direct                                                                                         | 0 |
|----------------|-----------------------------------------------------------------------------------------------------------------|---|
| 2)             | Single precision regular                                                                                        |   |
|                | to-regular                                                                                                      | 1 |
| 3)             | Single precision indirect                                                                                       | 2 |
| 4)             | Single precision immediate                                                                                      | 3 |
| 5)             | Double precision direct                                                                                         | 4 |
| 6)             | Single precision indirect<br>Single precision immediate<br>Double precision direct<br>Double precision regular- |   |
|                | to-regular                                                                                                      | 5 |
| 7)             | Double precision indirect                                                                                       | 6 |
| 7)<br>8)<br>9) | Floating point direct                                                                                           | 7 |
| 9)             | Floating point regular-                                                                                         |   |
|                | to-regular                                                                                                      | 8 |
| 10)            | Floating point indirect                                                                                         | 9 |
|                |                                                                                                                 |   |

# 3. INDENTIFICATION OF CONTROL REQUIREMENTS

a. PDP-11 Instruction Decomposition. Figure 5 illustrates a controller decode of the PDP-11 instruction set. This is a general purpose scheme that is not optimized for speeding up register-to-register operations. Trade-offs between micro-memory size and execution speed could reduce the execution time of register-to-register operations at the expense of adding more micro instructions.

In this scheme once the new instruction has been fetched from memory and the program counter updated, an "instruction type" decode is performed on the upper eight bits of the instruction. There are four possible results: double operand, single operand, branch, and miscellaneous. The "instruction type" decode sorts an instruction into a category on the following basis:



Figure 5. PDP-11 Instruction Decode Flow Chart

.

double operandX NNN XXX Xsingle operandX 000 XXX XbranchX 000 0XX Xmiscellaneous0 000 000 0

where X = don't care and NNN = not 000

Single the double operand set of instructions embodies most of the instruction decoding maneuvers, that set will serve to demonstrate the process.

The double operand instruction flow is shown in Figure 6. The first operation loads the source register, determined by instruction bits 9, 8, and 7, into temporary register Temp 6. The second operation loads Temp 6 into Temp 5 then branches on the source mode (instruction bits 12, 11, and 10) and whether or not the source register is the program counter (PC) (bits 9, 8, 7 = 111). There are 16 possible end points to the branch, four of which indicate that an illegal instruction has been detected. The remaining 12 branch end-points initiate the operations necessary to place the source operand in Temp 4 and the modified source register value in Temp 5. Temp 6 contains the source operand address which is only needed for byte operations.

As an example, Mode 7 with a source register other than the PC requires that the source register be added to the index word following the instruction. The result is the address of the address of the operand. The micro-code starting at the branch end-point indicating Mode 7 and not the PC first fetches the index value by placing the PC (which was incremented by two during instruction fetch) onto the address bus and initiating a memory fetch cycle. Prior to being restored in the GPU register file, the PC value is incremented by two. When available from memory, the index value is added to the content of Temp 6 and stored in Temp 6. Temp 6 then contains the source register plus the index value.

The addresss of the source operand is found by performing a memory fetch using the content of Temp 6 as an address and loading the data from that address into Temp 6. Finally, the source operand is determined by performing a memory fetch using Temp 6 as the address and loading the content of that address into Temp 4.

The next set of micro-instructions decodes the destination information. The destination operand is placed in Temp 1, the next value of the destination register is placed in Temp 2, and the destination address is placed in Temp 3.

Since many anomalies occur in the double operand instruction set, it is best to separate the byte and word instructions (instruction bit 16 true or false). The operation decode is first split into 16 paths by branching on instruction bits 16-13. The word instructions such as Move, Complement, Add and Subtract are then executed. The byte operations mask the source byte, aligned the



PDP-11 Double Operand Instruction Decode Flow Chart Figure 6.

source byte with the destination byte, and perform the indicated operation. The peripheral instructions such as Multiply, Divide, Floating-Point, Add, etc., require further decoding.

After execution of some instruction, the results must be moved from the temporary registers to the general register file and/or memory. First, a four way branch is executed for the source and destination modes. The resulting branch indicates that the source and destination modes are zero (SD = 0,0), the source mode is zero and the destination mode is non-zero  $(SD = 0N_{,})$ . If a source mode is zero no action is taken. If a source mode is non-zero, Temp 5 is loaded into the source register. If the destination mode is zero, Temp 1 is loaded into the destination register. If the destination mode is not zero, Temp 1 is stored into the memory location determined by Temp 3, and Temp 2 is loaded into the destination register.

b. Controller Features Desirable for the PDP-11 Instruction Set.

 Field Masked Branching. The PDP-11 instruction decode scheme previously presented contains several examples in which the ability to determine that a set of instruction bits is either all zero, neither all zero nor all ones, or all ones is quite useful. The instruction group decoding is one example. Sequential field testing would require five micro-cycles and eight micro-memory locations. The field masked branching technique requires only one micro-cycle and consumes at most nine micro-locations. The field masking section under consideration for the controller is shown in Figure 7. The final proposed instruction register will probably be 10 or 12 bits wide in each controller to allow convenient field grouping. Each field mask register (FMR) is loaded during initialization with a set of ones and zeros. A one in a particular bit position causes the FMR to examine the corresponding bit in the instruction register. A zero in a particular FMR bit position causes the corresponding instruction register bit to be ignored. The FMR has two output lines; one line indicates that all of the enabled instruction bits are one and the other line indicates that all of the enabled instruction bits are zero. The eight ouput lines from the four FMR's are masked by a general register in the controller and merged with eight bits from the ROM to form a branch address. The number of possible branch destinations can, thus, be any number from 2 to 256.

(2) Field Branching. The PDP-11 also requires taking N bits, such as 3 or 4 bits from the instruction register and branching to  $2^{N}$  possible locations. An example of this type of branch is the double operand op-code branch in which bits 16 through 13 are used to split the decode path into 15 different operations. The exact form of this branch has not been determined, but a likely protocol is to select either the upper or lower eight bits of the instruction register in a controller, mask the instruction register with a general register in the controller and merge the result with eight bits from the ROM to form the branch address.



Figure 7. Field Masking Section

c. UYK-20 Emulation Approach. The UYK-20 in many ways represents an excellent machine for implementation by a system based on the GPU parts family. The UYK-20 is a micro-programmed computer with a reasonably straightforward set of instruction formats. The complex register modification fields found in the PDP-11 instruction set is almost entirely missing in the UYK-20 instruction set.

The main drawback to the UYK-20 is the large number of registers required to control the various types of input/output operations, the two timing systems, and instruction execution. The estimated register requirements are as follows:

- 1) 16 General Registers
- 2) 15 Execution Registers
- 3) 6 Real Time and Monitor Registers
- 4) 8 Input/Output Control Registers
- 5) 64 Memory Page Registers
- 6) 2 Status Registers

An UYK-20 emulation would require most of the same controller features that a PDP-11 emulation would require. The UYK-20, however, will require more "flexibility" in register selection. The PDP-11 and the GPU reference two registers in concatenation by assuming that the register numbers only differ in the least significant bit (register even/register odd). The UYK-20 allows concatenation to start with any register and extend to sequential registers. At least one instruction (Load Multiple) allows all of the registers to be loaded from sequential memory locations.

Proposed architecture for emulating the UYK-20 would be the assignment of the I/O registers, timing registers, and program counter to one pair of GPU's with a mostly autonomous controller (the control subsystem) and the assignemnet of the register stack and temporary execution registers in two pair of GPU's with a second controller (the execution subsystem). This arrangement (see fig. 8) not only keeps logically connected registers together but allows overlapped fetch and execute operations and facilitates 32-bit arithmetic by controlled contatenation of the two 16-bit files. The microcontrol circuit should be capable of handling both function types.

The general registers in the execution set of GPU's are split between the GPU's with the even numbered registers in the right pair of GPU's and the odd numbered registers in the left pair. In 32-bit arithmetic operations, either pair of GPU's can assume the role of the upper 16-bit register.

Near the end of the execution of an instruction, the execution subsystem would send a fetch command to the control subsystem. The control subsystem issues a memory fetch and receives the next instruction from memory. The control subsystem makes a preliminary instruction decode. If the format is RK or RX, the control subsystem fetches the next memory location and updates the program counter.



When the execution subsystem has completed execution of the previous instruction, it requests the next instruction from the control subsystem and receives the partially decoded instruction. If the instruction format is RR, execution begins at once. If the format is not RR, the execution subsystem transfers the content of Rm to the control subsystem and begins setting up the execution sequence.

If the instruction format is RI (format 1) the control subsystem fetches the content of memory location (Rm). If the format is RK (format 2), the control subsytem adds (Rm) to the second half of the instruction. If the format is RX, the control subsystem adds (Rm) to the second half of the instruction and fetches the content of the resulting memory address. Once the operand has been determined, the control subsystem transfers the operand to the execution subsystem. In the case of multiple word operands, the control subsystem fetches sequential memory locations as required.

Once the required number of operands has been acquired by the execution subsystem, execution runs to completion and a new instruction cycle begins.

# 4. SYNOPSIS OF CONTROL FUNTIONS

All of the machines reviewed utilized a 16-bit architecture with capablity for handling larger and smaller operands. The use of the controller circuit is applicable to many sections of a computer and the various requirements of the different machines point out the need for flexibility in the part.

a. Machine Instruction Interpretation. It is desirable for the controller to be able to select the pertinent bits from the instruction and map the information directly to the micro address. Difficulty occurs when patterns are established for certain fields in an instruction format and exceptions are inserted. All of the machines exhibit this characteristic. It is also desirable to be able to make the proper mapping decision in one micro-cycle and not require a sequential decision making flow requiring several micro-cycles. This type of problem is more obvious in the PDP-11 which incorporates multiple field definitions because of the 16-bit instruction limitation.

b. Micro-Command Sequencing. Many of the other sections discussed result in the output effecting the micro-command sequence (DMA, Interrupt, Input/ Output, etc.). Other considerations are the desire to reduce the size of micro memory by having similar instructions sequenced with a micro program counter but most routines do not proceed through many steps before a branch decision is required. Most decisions are based on changing data value, which makes it desirable to input the normal status information (+, -, O/F, all zero) in the controller and efficiently map the information to the micro address. In the case of highly parallel architectures that incorporate parallel or overlap operations it is a requirement to be able to control the interface between controllers. c. Memory Request. Memory systems in the newer generation processors have several independent sections to service and to resolve conflicts. Requests can exist from the CPU, I/O processor, DMA, and possible other areas depending on design. The memory may also incorporate interleaved banks to increase effective speed. In these cases control is required to administer priority without eliminating a section from having any access and to determine when requests are in conflict. Machines desiring interface to a variety of memory systems can also be easily accomodated with a micro controlled interace.

d. Direct Memory Access (DMA). A DMA channel requires control handshaking, maintaining the word count, addressing memory for data, possible serialization/parallelization, format checks, and memory interface. All of these should be readily handled by the controller and GPU's depending on word size.

e. Register Designation. Selection of the various registers in the GPU has to be available to the micro-programmer as well as being designated in he instruction. The ability to test an instruction register field for all eros is required by all machines to determine indexing requirments. The ability to increment the original register select value and compare to another value is required for load and store multiple instructions.

f. Interrupts. Multiple vectored interrupts, maskable under program control, with assigned priority will probably be handled by a custom designed circuit, but the output will be an input to the control sequence. Multiple leveled interrupt systems such as the UYK-20 could use the controller to merge to various levels.

g. User Interface. Data registers and machine status in an LSI machine are not available for monitoring except under micro-program control. The controller should have the ability to micro-cycle and output information to the operator as would be the case in previous consoles.

h. Conditional Status Inputs/Storage. ALU status information (+, -, O/F, all zero) is required to be compared or mapped in support of conditional brand instructions. These values also make up part of a status register in each achine that must be stored and loaded when servicing interrupts. Since this information is required by the controller anyway, it is desirable that status be stored in the controller.

i. Input/Output. The I/O processor in the UYK-20 is similiar in operation to a CPU and would therefore have similiar requirments for the controller. In addition, the controller could be used to handle channel protocol and control GPU's when data manipulation is required.

### 5. RECOMMENDATION

The identification of control functions relates to the control design as a list of features to be considered in its design. Following is a list of

recommendations based on control requirements of the machines surveyed:

- Register for storage of portion of instruction pertinent to controller
- 2) Program counter for in-line routines
- Temporary storage registers for subroutine linkage
- 4) Iteration counter for sequential execution of the same micro instruction
- 5) Discrete inputs for micro-control branching
- 6) Mapping and input comparisons for multiply and divide data dependent decisions
- Register for storage of ALU status and ability to output
- Mask registers to obtain field classifications of the instruction
- Mask registers for mapping instruction field to micro address
- Ability to control interface between controllers operating simultaneously

### SECTION II

## 1. GENERAL PROCESSOR UNIT (GPU) SUPPORT

Extensive testing and evaluation of the GPU circuit has been accomplished under separate Air Force contracts. Tracor has supported this activity and submitted solutions to the items identified. Two of these recommendations effected control definitions.

Make the circuit output identified by the "Destination Control" available to output for all destination selections if desired. To accomplish this a tri-state control was requested in place of the "All zero detect input." This resulted in a slight redesign of the all-zero detect circuit making it a one pin pull down implementation. Also, a no load state was added.

A redistribution of the terms time shared on the most significant connect pins was recommended to allow isolation of the individual GPU circuits in a system and to provide a complete arithmetic status at one time.

An update of the control definitions is provided in Tables I through V. Table VI reflects the change in pin assignment and Figure 9 shows the change to the block diagram resulting from Item 1.

| Table I. Source Select Control | Table | Ι. | Source | Select | Control |
|--------------------------------|-------|----|--------|--------|---------|
|--------------------------------|-------|----|--------|--------|---------|

| Reference | 1np<br><u>51</u> |   | Port 1<br>Source | Port 2<br>Source | Condition,<br>Descriptio |                     |
|-----------|------------------|---|------------------|------------------|--------------------------|---------------------|
| SSO       | 0                | 0 | (R)              | (T)              | AD1                      |                     |
|           |                  |   | (R)              | (P2B)            | AD1                      |                     |
| SS1       | 0                | 1 | DI, R            | (T)              |                          | Enable R<br>if LOAD |
|           |                  |   | DI, R            | (P2B)            |                          | required            |
| SS2       | 1                | 0 | (R)              | DI               | AD1                      |                     |
|           |                  |   | (R)              | (T)              | AD1                      |                     |
| SS3       | 1                | 1 | (R + 1)          | DI               | ADI                      |                     |
|           |                  |   | (R + 1)          | (T)              | AD1                      |                     |

| Reference | <u>D2</u> | Inputs<br>D1 | <u>D0</u> | Port 1<br><u>ALC In</u> | Port 2<br><u>ALC In</u> | Condition/<br>Description |
|-----------|-----------|--------------|-----------|-------------------------|-------------------------|---------------------------|
| DSO       | 0         | 0            | 0         | Zero                    | False                   |                           |
| DS1       | 0         | 0            | 1         | True                    | False                   |                           |
| DS2       | 0         | 1            | 0         | P1B/2                   | False                   | AD1                       |
| DS2       | 0         | 1            | 0         | False                   | False                   | AD1                       |
| DS 3      | 0         | 1            | 1         | False                   | Zero                    |                           |
| DS4       | 1         | 0            | 0         | Zero                    | True                    |                           |
| DS 5      | 1         | 0            | 1         | True                    | True                    |                           |
| DS6       | 1         | 1            | 0         | P1B/2                   | True                    | AD1                       |
| DS6       | 1         | 1            | 0         | False                   | True                    | ADI                       |
| DS7       | 1         | 1            | 1         | True                    | Zero                    |                           |

Table II. Data Type Selector Control

# Table III. ALC Control

| Reference |   | A0 | Function | Comments                                      |
|-----------|---|----|----------|-----------------------------------------------|
| ADO       | 0 | 0  | ADD      | First port 2 source,<br>external carry-in     |
| AD1       | 0 | 1  | ADD      | Second port 2, source external carry-in       |
| AD2       | 1 | 0  | AND      | First port 2 source,<br>logical "l" carry-in* |
| AD3       | 1 | 1  | OR       | First port source,<br>logical "O" carry-in*   |

\*Group level propogate of external carry-in

# Table IV. Destination Select Control

| Reference | M2 | nputs<br>M1 | MO | Description                                                             |
|-----------|----|-------------|----|-------------------------------------------------------------------------|
| A00       | 0  | 0           | 0  | Direct store input to register file*                                    |
| A01       | 0  | 0           | 1  | ALC result left shift one into port 1*                                  |
| A02       | 0  | 1           | 0  | ALC result right shift one into port 1*                                 |
| A03       | 0  | 1           | 1  | ALC result right shift two into port 1*                                 |
| A04       | 1  | 0           | 0  | No load*                                                                |
| A05       | 1  | 0           | 1  | ALC result no shift into port 1*                                        |
| A06       | 1  | 1           | 0  | P2B to circuit output, ALC result<br>No shift into port 1 if load clock |
| A07       | 1  | 1           | 1  | P1B to circuit output, ALC result<br>No shift into port 1 if load clock |

\*ALC result to circuit output

Table V. Boundary and Connect Control

| ction<br>uts<br><u>MXH(1)</u>             | Hi Z          | Hi Z                                                     | Overflow                                                        | Overflow                                                        | (ALC Out) <sub>6</sub>                                        | TS                     | (P2B) <sub>7</sub>     | (P2B) <sub>7</sub>                     |
|-------------------------------------------|---------------|----------------------------------------------------------|-----------------------------------------------------------------|-----------------------------------------------------------------|---------------------------------------------------------------|------------------------|------------------------|----------------------------------------|
| MS Connection<br>Outputs<br><u>MXH(O)</u> | Hi Z          | (ALC Out)7                                               | (ALC Out)7                                                      | (ALC Out)7                                                      | (ALC Out)7                                                    | (ALC Out) <sub>7</sub> | (ALC Out) <sub>7</sub> | (ALC Out)7                             |
| Description                               | No connection | Connection for normal intra-<br>circuit shift operations | Logical "1" shift in (MSB if<br>right shift, LSB if left shift) | Logical "0" shift in (MSB if<br>right shift, LSB if left shift) | MSB extend for right shift only -<br>complimented if overflow | Remainder Correction   | Divide Code            | (ALC Out) <sub>7</sub> TS; Divide Code |
| Inputs<br>C2 C1 C0                        | 0             | -                                                        | 0                                                               | -                                                               | 0                                                             | -                      | 0                      | -                                      |
| Input                                     | 0             | 0                                                        | -                                                               | -                                                               | 0                                                             | 0                      | -                      | -                                      |
| 62                                        | 0             | 0                                                        | 0                                                               | 0                                                               | -                                                             | -                      | -                      | -                                      |
| Reference                                 | RFO           | RFI                                                      | RF2                                                             | RF3                                                             | RF4                                                           | RF5                    | RF6                    | RF7                                    |

TS - Temporary Storage

# Table VI. Pinouts of the GPU

| <u>Pin No.</u> | Function             | <u>Pin No.</u> | Function       |
|----------------|----------------------|----------------|----------------|
| 1              | V <sub>SS</sub> (-V) | 25             | VDD (+V)       |
| 2              | Data out (B4)        | 26             | R2             |
| 3              | Data out (B5)        | 27             | R3             |
| 4              | Data out (B6)        | 28             | Т2             |
| 5              | Data out (B7)        | 29             | Т3             |
| 6              | Data out (B8)        | 30             | R1             |
| 7              | Carry-out            | 31             | TI             |
| 8              | Tri-State Enable     | 32             | то             |
| 9              | AZD out              | 33             | RO             |
| 10             | MX H (0)             | 34             | MI             |
| 11             | MX H (1)             | 35             | MO             |
| 12             | CO                   | 36             | M2             |
| 13             | C1                   | 37             | MXL (0)        |
| 14             | C2                   | 38             | MXL (1)        |
| 15             | Data in (B8)         | 39             | LC             |
| 16             | Data in (B7)         | 40             | D2             |
| 17             | Data in (B6)         | 41             | AO             |
| 18             | Data in (B5)         | 42             | A1             |
| 19             | Data in (B4)         | 43             | Carry-in (CRI) |
| 20             | Data in (B3)         | 44             | D1             |
| 21             | Data in (B2)         | 45             | DO             |
| 22             | Data in (B1)         | 46             | Data out (B1)  |
| 23             | \$1                  | 47             | Data out (B2)  |
| 24             | S0                   | 48             | Data out (B3)  |



Figure 9. GPU organization

26 ≎U.S.Government Printing Office: 1978 - 657-002/207