Microdata



# Microprogramming Handbook

# Microprogramming Handbook



APRIL 1972 2nd Edition



Microdata

second Edition

## MICROPROGRAMMING **HANDBOOK**

## Second Edition

**Microdata** 



Microdata Corporation 644 East Young Street Santa Ana, California

Copyright 1971 by Microdata Corporation 644 E. Young St. Santa Ana, California

Reissued 14 April 1972

PRINTED IN U.S.A.

## PART I

## MICROPROGRAMMED COMPUTER PRIMER

## **PART II**

## APPLICATION OF THE MICROPROGRAMMED COMPUTERS

PART III

MICRO 800 USERS MANUAL

**PART IV** 

MICRO 1600 REFERENCE MANUAL

PART V

SYSTEM DESIGN PROCEDURES USING MICROPROGRAMMING

PART VI
PRODUCT CATALOG

## **FOREWORD**

This is the second edition of a handbook written and published by Microdata Corporation, which introduces the computer user to microprogramming and its advantages in computing and control applications. The book provides detailed instructions to the system designer for the most economical and efficient use of microprogramming technology.

Microprogrammable architecture permits development and production of a single system of compatible hardware which can be program-tailored to a wide range of requirements.

Microdata recognized and put to use the microprogramming concept at an early date. The company's MICRO 800 series of computers was introduced early in 1969, and the MICRO 1600 family more recently. The MICRO 1600 family builds on MICRO 800 technology, offering significant performance improvements at a lower cost.

This publication is offered as an aid to users and potential users of computers who intend to avail themselves of microprogramming. Comments and additions by readers who wish to help expand the growing body of knowledge in this field are encouraged and solicited by Microdata.

## **TABLE OF CONTENTS**

|         | Introduction                                                                               |
|---------|--------------------------------------------------------------------------------------------|
| PART I  | MICROPROGRAMMED COMPUTER PRIMER                                                            |
|         | Introduction                                                                               |
|         | Organization of the Microprogrammed Computer 4                                             |
|         | The Fixed Instruction Computer                                                             |
| ·.      | Memory                                                                                     |
|         | The Microprogrammed Computer 6                                                             |
|         | Memory                                                                                     |
|         | Cost and Performance Advantages of the Microprogrammed Computer                            |
|         | Comparison of a Microprogrammable Computer to a General Purpose Fixed Instruction Computer |
|         | Instruction Repertoire                                                                     |
|         | Instruction Speeds                                                                         |
|         | Glossary                                                                                   |
| PART II | APPLICATION OF THE MICROPROGRAMMED                                                         |
| . ,     | COMPUTER                                                                                   |
|         | Introduction                                                                               |
|         | Classes of Application                                                                     |
|         | General Purpose Computers                                                                  |
|         |                                                                                            |

|          | Application Examples                                                                                                | 59             |
|----------|---------------------------------------------------------------------------------------------------------------------|----------------|
|          | Automatic Test System Floating Point Processor (Special Purpose) Fast Fourier Transform Processor (Special Purpose) | 59<br>60<br>60 |
|          | Multilane Parking Facility Computer                                                                                 | 61             |
|          | Numerical Control of Vertical Machining Center                                                                      | 63             |
|          | Vibration Analyzer (Special Purpose)                                                                                | 64             |
|          | Interface for Campus Central Processor, Satellite Computers                                                         | 64             |
| PART III | MICRO 800 USERS MANUAL                                                                                              | 67             |
|          | Chapter 1. System Design Features                                                                                   | 69             |
|          | General Characteristics                                                                                             | 70             |
|          | System Organization                                                                                                 | 70             |
| tre.     | Registers and File                                                                                                  | 71             |
|          | Core Memory                                                                                                         | 73             |
|          | Control Memory                                                                                                      | 73             |
| -        | Arithmetic Functions                                                                                                | 74             |
|          | Status and Condition Flags                                                                                          | 78<br>79       |
| •        | Command Timing                                                                                                      | ./9            |
|          | Chapter 2. Microcommand Repertoire                                                                                  | 80             |
|          | Command Formats                                                                                                     | 80             |
|          | Terms and Symbols Used in the Command                                                                               |                |
|          | Descriptions                                                                                                        | 82             |
|          | Microcommands—Formats, Descriptions and                                                                             | -00            |
|          | Examples                                                                                                            | 82             |
|          | Load T <sup>-</sup>                                                                                                 | 83             |
|          | Load M                                                                                                              | 83             |
| •        | Load N                                                                                                              | 84             |
| •        | Load U                                                                                                              | 84             |
|          | Load Zero Control                                                                                                   | 85             |
| , .      | Load Seven Control                                                                                                  | 86             |
|          | Jump                                                                                                                | 87             |
|          | Load File                                                                                                           | 89             |
|          | Add to File                                                                                                         | 90             |
| -        | Test If Zero                                                                                                        | 91             |
|          | Test If Not Zero                                                                                                    | 92             |
|          | Compare                                                                                                             | 94             |
|          | Control                                                                                                             | 94             |
|          | Add                                                                                                                 | 101            |
|          | Subtract                                                                                                            | 104            |
|          | Read Memory, Write Memory                                                                                           | 106            |
|          | Copy                                                                                                                | 110            |
|          | OR                                                                                                                  | 112            |
|          | Exclusive OR                                                                                                        | 114            |
|          | AND                                                                                                                 | 116            |
|          | Shift                                                                                                               | 118            |
|          | Execute                                                                                                             |                |

|   | CPU Microcommand Repertoire 128                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C | Chapter 3. Input/Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|   | General Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|   | Internal Status Interrupt       133         Bus Lines       133         Input Lines       133         Output Lines       135         Serial Interface       137         Direct Memory Access       137         Typical Byte I/O Interface       137                                                                                                                                                                                                                                                                                                                                                                                                        |
|   | Examples of I/O Microprogramming 140                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ( | Chapter 4. Central Processor Options 143                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|   | Real-Time Clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| C | Chapter 5. Operator Controls                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|   | Consoles       144         Displays       145         Switches       145         Operating Procedures — System Console       146                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|   | Chapter 6. Programming Systems for MICRO 800 Firmware Development                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|   | AP800 Cross Assembler       153         MAP800 Cross Assembler       153         Symbolic Language       153         Machine Commands       155         Operand Field Expressions       155         Microcommands       156         Alphabetic List of Commands       157         Assembler Instructions       157         Assembly Listing and Diode Map       158         Format for AP800       158         Error Flags       159         Diode Map for AP800       159         Sample Listing       159         Operation Program Card Deck From AP800       163         Simulator Operating System (SOS) and       163         Introduction       163 |
|   | Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|   | Alterable Read-Only Memory Operating System (AROS)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|   | Introduction <t< td=""></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|   | v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Progr<br>Sumr | ators                                                                              | 176<br>177 |
|---------------|------------------------------------------------------------------------------------|------------|
| Chapter 7.    | Techniques and Examples                                                            | 188        |
| Techniq       | ues for Efficient Microprogramming                                                 | 188        |
| 1.            | Generation of delays for memory accesses, U Register Applications and input/output | 189        |
| 2.            | Double Functions on a Single Command                                               |            |
| 3.            | Uses, Setting and Testing Link                                                     |            |
| 4.            | Uses of the U Register                                                             | 190        |
| 5.<br>C       | Setting and Using Condition flags                                                  | 191        |
| 6.            | Use of Loops vs Straight Line Programming.                                         | 192        |
| 7.            | Small General Purpose Subroutines                                                  | 193        |
| 8.<br>9.      | Use of shift Right 4 Command Use of File Register for Flags, Counters, and         | 193        |
| 9.            |                                                                                    | 100        |
| 10.           | Reference Data                                                                     | 193        |
|               | minimize Commands                                                                  | 193        |
| 11.           | Saving of Diodes by Selection of Files and                                         |            |
| **            | Instructions                                                                       | 193        |
| 12.           | Saving Jump Instructions when Branching                                            | 194        |
| 13.           | Reducing two Branches to one by Multi-                                             |            |
|               | Function Commands                                                                  | 195        |
| 14.           |                                                                                    | 196        |
| 15.           | Use of Inhibit File Write                                                          | 196        |
| 16.           | Moving Data from a File to a Register                                              | 196        |
| Micropro      | ogramming Examples                                                                 | 196        |
| 1.            | Multiply Two Positive Numbers                                                      | 198        |
| 2.            | Subroutine Jumps                                                                   | 201        |
| 3.            | Time Delay Routine                                                                 | 203        |
| 4.            | Data Input from 4 External Registers                                               | 206        |
| 5.            | Load 8 successive File Registers from 8                                            |            |
|               | successive core locations                                                          | 208        |
| 6.            | 16 Bit Add (Core to File)                                                          | 210        |
| 7.            | Input a 32 Bit Word from an External Device                                        |            |
|               | to Core Memory                                                                     | 211        |
| 8.            | 16 Bit Right Shift with End Around Carry                                           |            |
|               | with the Shift Count in File Register S                                            | 214        |
| 9.            | A ORed with B to A                                                                 | 215        |
| 10.           | A ORed with B to A Update 10 BCD Digit Display from Core                           | 215        |
| 11.           | Clear a Block of Core Memory                                                       | 218        |
| 12a.          | Read 8 consecutive Core locations into 8                                           |            |
|               | consecutive File Registers                                                         | 220        |
| 12b.          | Write 8 consecutive Files into 8 consecutive                                       |            |
|               | Core locations                                                                     | 221        |
| . 13a.        | Output from 8 Files to 8 Shift Registers                                           | 223        |
| 13b.          | File to Register; with Hardware Rotation                                           |            |
| •             | of Bit Pattern                                                                     | 226        |

|         | 14.<br>15.<br>16.<br>17.                  | Input from 8 Shift Registers to 8 Files in MICRO 800                                                                                      | . 231<br>. 235                  |
|---------|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
|         | 18.<br>19.<br>20.                         | General Purpose Multiple File Shift Routine Hexadecimal to ASCII Conversion Routine. General Purpose Code Conversion by Table Translation | . 247                           |
|         | 21.<br>22.                                | Binary Multiply (16 Bits)                                                                                                                 | . 255<br>. 259                  |
|         | 23.                                       | Generate ASCII Parity                                                                                                                     | . 261                           |
|         | Chapter 8.                                | MICRO 810 Firmware Manual                                                                                                                 | 262                             |
|         | File Reg<br>Informa<br>Operand            | 810 Functions                                                                                                                             | 262<br>264<br>266<br>267<br>271 |
|         | Conc<br>Seria<br>Byte                     | rupts                                                                                                                                     | 274                             |
|         |                                           | 810 Assembly Listings                                                                                                                     | 300                             |
|         |                                           | struction                                                                                                                                 | 300                             |
| PART IV | MICRO 16                                  | 00 REFERENCE MANUAL                                                                                                                       | 309                             |
|         | Chapter 1.                                | MICRO 1600 Design Features                                                                                                                | 310                             |
|         | General                                   | Characteristics                                                                                                                           | 311                             |
|         | Chapter 2.                                | System Description                                                                                                                        | 312                             |
|         | Data Flo<br>Register<br>Control<br>Memory | 0 Flags and Internal Status                                                                                                               | 317<br>318                      |
|         | Chapter 3.                                | Microcommand Repertoire                                                                                                                   | 321                             |
|         | Comma                                     | nd Formats                                                                                                                                | 321                             |

|        | Chapter 4. Control Panel Operation                                                                                                                                                                                                                                                                                                           | 352                                                                                     |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
|        | System Console                                                                                                                                                                                                                                                                                                                               | 352<br>353<br>353<br>355                                                                |
|        | Chapter 5. Micro Assembler Program                                                                                                                                                                                                                                                                                                           | 357                                                                                     |
|        | Source Language Statement Format Operand Field Expressions Machine Commands Class One Class Two Class Three Class Four Class Five Assembler Instructions Assembly Listing Error Flags Program Tape Format Sample Listing Microcommands (Class Order)                                                                                         | 357<br>358<br>359<br>360<br>361<br>361<br>361<br>362<br>362<br>363<br>364<br>365<br>368 |
|        | Chapter 6. Input/Output                                                                                                                                                                                                                                                                                                                      | 371                                                                                     |
|        | General Description                                                                                                                                                                                                                                                                                                                          | 361<br>371<br>377                                                                       |
|        | Chapter 7. Physical Characteristics and System Power                                                                                                                                                                                                                                                                                         | 384                                                                                     |
|        | Mechanical Configurations                                                                                                                                                                                                                                                                                                                    | 384<br>384                                                                              |
|        | Appendix A. Microcommand Reference Table                                                                                                                                                                                                                                                                                                     | 392                                                                                     |
| PART V | SYSTEM DESIGN PROCEDURES USING MICROPROGRAMMING                                                                                                                                                                                                                                                                                              | 395                                                                                     |
|        | Introduction                                                                                                                                                                                                                                                                                                                                 | 397                                                                                     |
|        | Outline of System Definition Procedures                                                                                                                                                                                                                                                                                                      | 397                                                                                     |
|        | System Functional Definition     System Configuration Definition     Detailed System Performance Specifications     Interface Performance Specifications     Program Specifications     Tradeoffs     Hardware Specs     Software or Firmware Program Specifications     Detailed Program Functions Analysis     Definitions and Programming | 399<br>400<br>400<br>401<br>401<br>402<br>404<br>404<br>405                             |
|        | microprogramming Aids                                                                                                                                                                                                                                                                                                                        | , 400                                                                                   |

| PART VI | PRODUCT CATALOG                                        | 407         |
|---------|--------------------------------------------------------|-------------|
|         | MICRO 400 Computer                                     | 408         |
|         | MICRO 800 Computer                                     | 412         |
|         | MICRO 810 Computer                                     | 413         |
|         | MICRO 820 Computer                                     | 414         |
|         | MICRO 800 Series Computer System Elements and Options  |             |
|         | MICRO 1600/21 Computer                                 |             |
|         | MICRO 1600 Computer Series System Elements and Options | 423         |
|         | Firmware Training System                               | <b>42</b> 8 |
|         | Microprogramming System                                | 121         |

## INTRODUCTION

Microprogramming techniques are the secret of the demonstrable advantages of Microdata's advanced microprogrammable computers over fixed-instruction minicomputers.

The major difference between Microdata's products and conventional minicomputers is the incorporation of microprogrammed control memories as a major adjunct to the usual basic elements of any computer—control unit, main memory, arithmetic/logic unit and input/output.

Microprogrammed control memories provide ease of programming using a wide choice of languages.

Microprogramming also means higher speed and more efficient use of the main memory of the computer.

In many cases, the usable storage of the main memory is increased because the programs used in conventional minicomputers to perform certain operational instructions are stored in the control memory, thus freeing storage capacity in the main memory for the purpose it was intended—problem-solving.

Inherently, microprogramming gives the user the flexibility to tailor the computer to his specific needs, no matter how complex or simple, and he can change the system at will, swiftly and economically. In addition to telling the computer what to do, microprogramming makes it possible to tell the computer how to do it.

The result is high performance at minimum cost, high memory efficiency and the availability of a wide variety of languages from which to choose. In short, Microdata has reached a pinnacle in the only meaningful measurement of computer performance—the ability to solve specific problems accurately and efficiently in terms of time and therefore cost to the user.

Microprogrammed computers also have ripped away many barriers to broader application of minicomputers. The way is clear for use of Microdata's products in business and scientific applications because of the ease and flexibility of programming techniques.

A number of factors have contributed to these advances by Microdata Corporation, including modern facilities geared to volume production, exploitation of the most advanced techniques and concepts available, and the field-proven reliability of more than 1000 microdata computers.

All of these elements are available to and benefit the user of Microdata's products.



## PART I MICROPROGRAMMED COMPUTER PRIMER

## INTRODUCTION

December 1945, ENIAC, the first electronic high-speed stored program general purpose computer was completed. Six years later Professor M.V. Wilkes of Cambridge University coined the word microprogramming to describe computer instructions that carry out numerous information transfers in a single execution cycle. Cost-performance improvements as a result of 25 years of advancement in computer technologies have been almost overwhelming. In 1965 it became practical and possible to build computers with control units driven by microprograms. The concept was not exploited on a widespread basis until recently. In large and medium scale computers microprogramming provides the capability to emulate other computers, and to maintain upward/downward compatibility over a wide range of models within a computer series.

The small or so called minicomputer incorporating microprogramming now exploits the advances in semiconductor and memory technologies with microprogramming far beyond the larger model computers. Full advantage of new low cost memories are realized only by users of small microprogrammed computers. The spectrum of applications between the special purpose computer, where the entire program is implemented in a microprogram, to the general purpose computer implemented by microprogram can be selected by the user to achieve a meaningful price/performance ratio for the application.

## ORGANIZATION OF THE MICROPROGRAMMED COMPUTER

The organization of the microprogrammed computer can best be described after we first review the organization of its predecessor, the fixed instruction stored program general purpose computer.

## The Fixed Instruction Computer

In simple terms the fixed instruction stored program computer is built around a storage and retrieval scheme, typically a magnetic core memory. The structure and information paths of a computer are represented in the simplified block diagram (Figure 1).

As defined in most textbooks, the five elements comprising a digital computer are: memory, arithmetic unit, input, output and control unit.

Memory: Modern computer memories are implemented using high speed semiconductors or magnetic core memory systems. These memories are high-speed random access devices of which information, usually in a binary form, is written or read from any addressed section of the memory.

Arithmetic Unit: In many instances is referred to as the arithmetic and logic unit (ALU). As the name implies it performs the arithmetic operations on data transferred within the computer, the memory, the input and the output.

**Input/Output:** Communication with a wide variety of devices in the language of the operator are made possible by transfer channels referred to as the input and output sections of a computer. Devices connected to the input/output of a computer referred to as computer peripherals include elementary switches and indicator lamps, typewriters, magnetic or paper tape units, line printers, analog converters, cathode ray tube displays (TV type devices), card readers and punches, communication lines, etc.



Figure 1. Simplified Block Diagram
Fixed Instruction Stored Program General Purpose Computer

In addition to man communication type devices the input/output of a computer may be connected to intermediate storage devices for mass memory requirements. Such mass memory devices include but are not limited to magnetic disc storage systems, magnetic drums, and a larger scale computer memory.

Control Unit: The control unit may be referred to as the "brain" portion of any computer because it coordinates all units of the computer in timed logical sequence. The control unit of a small fixed instruction computer receives sequences of instructions from memory. These sequences, called programs, reside in the memory and are referred to as "software." The control unit is closely synchronized to the memory cycle speed and execution time of each fixed instruction is usually a multiple of the memory speed.

## The Microprogrammed Computer

Four of the elements of the microprogrammed computer are nearly identical to the fixed instruction computer. The significant difference is in the control unit ("Brain"). The basic control sequences of a microprogrammed computer originate in a separate "control memory," usually a read-only memory (ROM) which operates at speeds many times faster than the main memory section of the computer. Thus the simplified block diagram (Figure 2) of the microprogrammed computer has one more element than the fixed instruction computer.



Figure 2. Simplified Block Diagram Microprogrammed Computer

Memory: The random access main memory of the microprogrammed computer differs little from the fixed instruction computer. It is implemented with magnetic core or semiconductor systems in similar sizes and speeds to the fixed instruction computer. The basic difference is the timing and control of the memory system. The control unit of the microprogrammed computer is clocked to a significantly higher speed separate memory system. Hence, the main memory speed is essentially independent of the processor speed and is operated in a manner similar to an input/output device.

Arithmetic Unit: The arithmetic and logic unit in a microprogrammed computer operates on fixed data lengths, typically 8 bits. The speed of the unit is 10 to 50 times faster than fixed instruction computer arithmetic units operating on smaller portions of arithmetic problems at each step. Microcommands are much more intimately related to the computer architecture and to bit patterns. This allows high versatility in problem solution and minimizes the restrictions usually encountered at the software level.

Input/Output: Microprogrammed computers provide extremely fast elementary I/O capabilities. Data paths are fixed length, typically 8 bits, and the I/O control functions are simple elements sequenced by high speed control memory firmware. This permits special I/O systems to be designed for the users' requirements. The microprogrammed computer offers all of the I/O capabilities found in fixed instruction computers coupled with the unique advantage of providing only the capabilities needed, and the versatility to be changed when required.

Control Unit: The control unit of the microprogrammed computer is simple and straightforward. It operates and controls all elements of the computer system including two levels of memory. Because it is more basic than the control units in fixed instruction computers it provides capability to solve problems in an added dimension. The control unit is programmable, not fixed. Programs operating upon the control unit are called microprograms, and are referred to as firmware. These programs are as easy to write and implement as is software in the fixed instruction computer.

If we refer to the control unit of any computer as the "Brain," then the microprogrammed computer control unit could be referred to as a brain ingredient, which we can readily adjust to suit our needs.

Control Memory: The control memory is the element that most dramatically distinguishes the microprogrammed computer. The control memory contains the stored sequence of control functions that dictate end user architecture of the microprogrammed computer. These stored sequences are called "microprograms" or "firmware" corresponding to fixed instruction computer sequences called "programs" or "software."

The control memory has been called many other names including, readonly store (ROS), read-only memory (ROM) and control store. Terminology relating to the control memory of microprogrammed computers is most complex because of many misnomers coined by computer and semiconductor manufacturers. Present terminology that relates to the mechanization of control memory are:

**ROM:** Read-Only Memory: Any memory system in which the bit patterns of each word are fixed, and unalterable.

In application, few ROM's can be modified after manufacture. Those ROM's that can, may be called modifiable. To make any change requires a hardware modification such as adding or deleting diodes in a diode matrix ROM or rerouting of wires in a core ROM.

**BROM:** Bipolar Read Only Memory: Large scale integration (LSI) bipolar devices are used for volume manufacture. Original setup masking is expensive. Cost for manufactured elements is low.

PROM: Programmable Read Only Memory: A semiconductor diode array is programmed by fusing or burning out diode junctions. Cost for setup is minimal. Manufacturing cost is moderate to high. The PROM is usually used for final shake down of a system prior to investing in the BROM setup.

AROM: Alterable Read Only Memory: A true misnomer. The AROM is actually a read-write memory that is used for initial checkout of firmware. The firmware is typically loaded into the AROM via a paper tape input device. Once loaded the AROM operates the control unit as does any ROM control memory. The advantage of the AROM is programming within a few minutes rather than a manufacturing process. Cost is high; however, the devices are used indefinitely for checkout and analysis of numerous firmware implementations.

## COST AND PERFORMANCE ADVANTAGES OF THE MICROPRO-GRAMMED COMPUTER

Fixed instruction minicomputers are basically application sensitive. Even with numerous models to choose from only a few offer good price performance for any specific application. Even more important to note is the fact that if a specific fixed instruction computer offers the best price performance for a given application at one level of complexity it may offer less relative value as the complexity changes.

Typically, to increase the performance of the fixed instruction computer the main memory (usually core memory) is increased in size.

In the final analysis, the performance of any computer is measured by its ability to solve a specific problem within a given period of time.

For most project managers the selection of a minicomputer is a traumatic experience. They are exposed to numerous technical concepts, specifications and a variety of salesmen and skilled technicians from companies with one goal—to sell him their solution to his technical problem. If a thorough up-to-date evaluation were performed with all minicomputer manufacturers the evaluation could cost him more than the project implementation. The prime criteria for selection of the appropriate minicomputer is time and cost of implementation over the entire project life. In this light, the microprogrammed minicomputer offers an answer to this enigma. The user selects the cost/performance lines between three elements; hardware, firmware, and software for his specific application.

One of the primary purposes of this "Microprogramming Handbook", is to educate and illustrate for the user the capabilities of specific product lines and to assist in these cost/performance trade-off selections.

The following comparison chart illustrates five capability levels comparing one of the more popular fixed instruction minicomputers, referred to as brand X, and a microprogrammable minicomputer, the MICRO 1600. Each level represents computer problem solving capability with corresponding notation on price, memory use and relative speed (micro vs. fixed). Within

any capability level numerous trade-offs between control memory size and core memory size can be established for the MICRO 1600.

For example, level number 4 shown in the comparison chart represents a computer capability for a time-sharing system employing high-level interpretive language and executive programs. Implementation of floating point arithmetic and executive subroutines in firmware thus expands the ROM from 768 words to 8,192 words. As a result, the MICRO 1600 cost is reduced approximately 15 percent and execution time is improved by a factor of approximately 20.

This comparison clearly illustrates that as the size of the control memory increases advantages result in price and relative speed. In addition, programming costs and implementation time can be significantly reduced once the users' needs are established in firmware. Now, with the availability of supporting systems from Microdata, firmware development is in the same dimension in price and turn-around time normally associated with fixed instruction computers. The result: computer users can benefit from microprogramming along with the computer manufacturer.

|       | Microprogrammed Computer<br>(MICRO 1600) |                           |                      |                   |                 | nstruction<br>er (Brand X) |
|-------|------------------------------------------|---------------------------|----------------------|-------------------|-----------------|----------------------------|
| Level | Core<br>Memory<br>Size                   | Control<br>Memory<br>Size | System<br>Price      | Relative<br>Speed | System<br>Price | Core<br>Memory<br>Size     |
| 1.    | 8K X 8<br>4K X 8                         | 512 X 16<br>1024 X 16     | \$5,910<br>\$5,420   | 1:2<br>2:1        | \$6,250         | 4K X 16                    |
| 2.    | 16K X 8<br>12K X 8                       | 512 X 16<br>2048 X 16     | \$8,610<br>\$7,690   | 1:2<br>5:1        | \$8,950         | 8K X 16                    |
| . 3.  | 32K X 8<br>24K X 8                       | 512 X 16<br>1024 X 16     | \$14,010<br>\$11,470 | 1:2<br>10:1       | \$14,350        | 16K X 16                   |
| 4.    | 48K X 8<br>24K X 8                       | 768 X 16<br>8192 X 16     | \$19,770<br>\$16,750 | 2:3<br>15:1       | \$19,750        | 24K X 16                   |
| 5.    | 65K X 8<br>32K X 8                       | 1024 X 16<br>12K X 16     | \$25,170<br>\$22,250 | 1:1<br>20:1       | \$27,000        | 32K X 16                   |

## COMPARISON OF A MICROPROGRAMMABLE COMPUTER TO A GENERAL PURPOSE FIXED INSTRUCTION COMPUTER

In the general purpose fixed instruction computer, the instructions are stored in core memory along with data. Both instructions and data can be altered by the program. In a microprogrammable computer, the instructions are stored in a read only memory along with permanent (or constant) data. Only variable data, pointer, and flags are stored in core memory.

## Instruction Repertoire

In the general purpose fixed instruction computer there is usually a limited instruction repertoire with variations of instruction, and memory reference instructions having limited addressing modes.

In the microprogrammable computer there is usually a smaller number of instructions which are more compact and specialized than the fixed instructional computer. Memory addressing and I/O functions usually are built up by assembling a group of micro instructions. The micro instructions are closely related to the internal architecture and I/O structure of the basic computer.

## **Instruction Speeds**

Microprogrammable computers are faster than fixed instruction computers for the following reasons:

- 1. Instruction execution times are from 5 to 30 times faster in a micro-programmed computer.
- File registers can be used for data storage, and pointers, where core is required in a fixed instruction computer, thus program execution time can be sped up by avoiding memory access cycles.
- 3. Subroutines are closely tailored to specific requirements and data word lenghts, thus improving computer efficiency and speed.
- 4. Input/output routines can be simplified for the application to increase I/O speed.
- 5. Special time-consuming algorithms (math, logic, etc.), which are not available in the general purpose processor can be easily incorporated into a microprogrammed processor.

Additional comparisons between a general purpose processor and a micro-programmable processor are included in Table 1.

Table 1. Comparison of Microprogrammed Computer to General Purpose Software Programmed Computer

| Function                        | General Purpose                                                                                     | Microprogrammed<br>MICRO 1600                                                                   |
|---------------------------------|-----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|
| Arithmetic and logic operations | <ul> <li>memory reference/<br/>register reference</li> </ul>                                        | • register reference                                                                            |
|                                 | <ul> <li>conditions automatically set</li> </ul>                                                    | <ul> <li>conditions set when<br/>enabled</li> </ul>                                             |
|                                 | <ul> <li>usually 12 or 16 bits</li> </ul>                                                           | • 8 bits                                                                                        |
| ,                               | • specific registers are used                                                                       | <ul> <li>general purpose file<br/>registers</li> </ul>                                          |
|                                 | <ul> <li>execution time 2-10 microseconds</li> </ul>                                                | • 200 nanoseconds                                                                               |
| Shift Operations                | <ul> <li>multiple bits at a time</li> </ul>                                                         | • single bit at a time                                                                          |
|                                 | <ul><li>left/right</li></ul>                                                                        | • left/right                                                                                    |
|                                 | <ul> <li>limited types of shift</li> </ul>                                                          | <ul> <li>unlimited types of shift</li> </ul>                                                    |
|                                 | <ul> <li>usually 16 bits</li> </ul>                                                                 | • 8 bits                                                                                        |
|                                 | <ul> <li>specific registers only</li> </ul>                                                         | <ul> <li>any file registers</li> </ul>                                                          |
| Conditional Skips               | <ul><li>forward/reverse</li></ul>                                                                   | • forward                                                                                       |
|                                 | <ul> <li>to multiply locations</li> </ul>                                                           | <ul> <li>to one location</li> </ul>                                                             |
|                                 | <ul> <li>fixed registers used<br/>and tested</li> </ul>                                             | <ul> <li>any file register can be<br/>tested</li> </ul>                                         |
|                                 | <ul> <li>program conditions tested</li> </ul>                                                       | <ul> <li>basic conditions tested</li> </ul>                                                     |
| Jumps/Return Jumps              | <ul> <li>programmable locations</li> </ul>                                                          | • programmable locations                                                                        |
|                                 | <ul> <li>return jump, automatic<br/>address set up</li> </ul>                                       | <ul> <li>set up return jump<br/>address with microcode</li> </ul>                               |
| Memory Accesses                 | <ul> <li>referred to as part of<br/>Memory Reference<br/>Instruction</li> </ul>                     | <ul> <li>set up memory address<br/>registers, initiate transfer<br/>in microcode</li> </ul>     |
|                                 | <ul> <li>address in instruction</li> </ul>                                                          | • address in any file registe                                                                   |
| Memory Addressing               | <ul> <li>16K to 65K Bytes core<br/>memory</li> </ul>                                                | • 65K Bytes core memory                                                                         |
|                                 | • control-fixed                                                                                     | <ul> <li>control variable, ROM;</li> <li>256 x 16 expandable to</li> <li>16,386 x 16</li> </ul> |
| 1/0                             | <ul> <li>instruction designates<br/>destination and source</li> </ul>                               | <ul> <li>data transfer and timing<br/>controlled by microcode</li> </ul>                        |
| Interrupts                      | <ul> <li>automatic hardware function</li> </ul>                                                     | <ul> <li>microcode test, and handling</li> </ul>                                                |
| Concurrent I/O                  | <ul> <li>optional, referred to as<br/>direct multiplex channel<br/>or 3 cycle data break</li> </ul> | • implemented directly in microcode                                                             |
| DMA                             | <ul> <li>external memory access</li> </ul>                                                          | • external memory access                                                                        |
| Indexing                        | <ul> <li>specific register(s) assigned</li> </ul>                                                   | • index in any file register                                                                    |
| Program                         | • software                                                                                          | • firmware                                                                                      |
| Execution Time                  | <ul> <li>microseconds</li> </ul>                                                                    | <ul> <li>nanoseconds</li> </ul>                                                                 |



## **GLOSSARY**

## Α

- ACCESS, IMMEDIATE Ability to obtain data from or place data in a storage device, or register directly without serial delay, usually in a relatively short time.
- ACCESS, PARALLEL Obtaining data from or placing data into storage where time required is dependent on simultaneous transfer of all elements of a word from a given location.
- ACCESS, RANDOM (1) Obtaining data from or placing data into storage where time required is independent of location of information most recently obtained or stored; (2) device in which random access, as defined in definition 1, can be achieved without time penalty.
- ACCESS, SERIAL Obtaining data from or placing data into storage where time required is dependent on necessity for waiting while nondesired storage locations are processed.
- ACCUMULATOR (1) Register and associated equipment in arithmetic unit of computer in which arithmetical and logical operations are performed; (2) unit in a digital computer where numbers are accumulated. Often the accumulator stores one operand and on receipt of any second operand, it forms and stores result.
- ACCURACY Degree of exactness of an approximation or measurement. Accuracy normally denotes absolute quality of computed results; precision refers to the amount of detail used in representing those results.
- ADDER Device which forms, as output, the sum of two or more numbers presented as inputs. Often no data retention feature is included; the output signal remains only as long as the input signals are present.
- ADDRESS (1) Identification, represented by a name, label, or number, for registers or location in storage. Addresses are also a part of an instruction word along with commands, tags, and other symbols; (2) part of an instruction which specifies an operand.
- ADDRESS, ABSOLUTE Address which indicates exact storage location where the referenced operand is to be found or stored in the actual machine code address numbering system.
- ADDRESS, BASE (1) Number which appears as an address in a computer instruction, but which serves as base, index, initial or starting point for subsequent addresses to be modified; (2) number used in symbolic coding in conjunction with relative address.
- ADDRESS, DIRECT Address which indicates the location where referenced operand is to be found or stored with no reference to index register or B-Box.
- ADDRESS, EFFECTIVE (1) Modified address; (2) address actually considered to be used in particular execution of computer instruction.
- ADDRESS, IMMEDIATE Instruction address in which address part of instruction is operand.
- ADDRESS, INDEXED Address that is to be modified or has been modified by index register or similar device.
- ADDRESS, INDIRECT Address in computer instruction which indicates location of address of referenced operand.
- ADDRESS PART Part of instruction word that defines address of register or location.

- ADDRESS, RELATIVE Address to which base address must be added to find machine address.
- ADDRESS, SYMBOLIC Label, alphabetic or alphameric, used to specify storage location in context of a particular program. Programs are often first written using a symbolic address in some convenient code, which are translated into absolute addresses by assembly program.
- ADDRESS, VARIABLE See address, indexed.
- ADP Automatic Data Processing.
- ALGEBRA, BOOLEAN Process of reasoning or deductive system of theorems using symbolic logic, and dealing with classes, propositions, or on-off circuit elements. It employs symbols to represent operators such as AND, OR, NOT, EXCEPT, IF . . . THEN, etc., to permit mathematical calculation. (Named for George Boole, English mathematician [1815-1864]).
- ALGOL ALGOrithmic Language. See language, algorithmic.
- ALGORITHMIC Constructive calculating process usually assumed to lead to solution of problem in finite number of steps.
- ALLOCATION, STORAGE Process of reserving blocks of storage to specified blocks of information.
- ALPHAMERIC Contraction of alphanumeric and alphabetic-numeric. Characters which include letters of the alphabet, numerals, and other sucy symbols as punctuation or mathematical symbols.
- ALU Arithmetic and Logical Unit.
- ANALOG Representation of numerical quantities by means of physical variables: translation, rotation, voltage, or resistance. Contrasted with digital.
- ANALYSIS, NUMERICAL Study of methods of obtaining useful quantitative solutions to mathematical problems, regardless of whether an analytic solution exists, and study of errors and bounds on errors in obtaining such solutions.
- ANALYSIS, SYSTEMS Examination of an activity, procedure, method, technique, or business to determine what must be accomplished and how necessary operations may best be accomplished.
- ANALYST Person skilled in definition and development of techniques for solving problems; especially those techniques for solutions on computer.
- ANALYZER Computer routine to analyze program written for the same or a different computer. Computer (usually analog) designed and used primarily for solving many types of different equations.
- APPLICATION System or problem to which a computer is applied. Reference is often made to an application as being either computational type, wherein arithmetic computations predominate, or data processing type, wherein data handling operations predominate.
- ARGUMENT (1) Independent variable: in looking up quantity in a table, number or any numbers which identify location of desired value; or in mathematical function, variable which when certain value is substituted for it, value of function is determined; (2) operand in an operation on one or more variables.
- ARITHMETIC, FLOATING POINT Calculation which automatically accounts for location of radix point. Usually accomplished by handling number as signed mantissa times radix raised to an integral exponent.
- ARITHMETIC SECTION See unit, arithmetic.
- AROM Electrically Alterable Read Only Memory.

- ASSEMBLE (1) To integrate subroutines that are supplied, selected, or generated into main routine, by means of preset parameters, by adapting, or changing relative and symbolic addresses to absolute form, or by placing them in storage; (2) to operate, or perform functions of an assembler.
- ASSEMBLER Computer program which operates on symbolic input data to produce machine instructions by carrying out such functions as: translation of symbolic operation codes into computer operating instructions; assigning locations in storage for successive instructions; or computation of absolute addresses from symbolic addresses. An assembler generally translates input symbolic codes into machine instructions item for item, and produces as output the same number of instructions or constants which were defined in the input symbolic codes.
- ASYNCHRONOUS Lack of time coincidence in set of repeated events where the term is applied to computer to indicate that execution of one operation is dependent on a signal that previous operation is completed.
- ATLAS Abbreviated Test Language for Avionics Systems.
- AUTOMATION (1) Implementation of processes by automatic means; (2) theory, art, or technique of making a process more automatic; (3) investigation, design, development, application of methods of rendering processes automatic, self-moving, or self-controlling.

В

- BASIC Beginner's All-purpose Symbolic Instruction Codes. A simple, easy to learn, machine independent, conversational computer language.
- BAUD (1) Unit of signalling speed equal to number of code elements per second; (2) unit of signalling speed equal to twice the number of Morse code dots continuously sent per second.
- BINARY Characteristic, property, or condition in which there are but two possible alternatives: binary number system using 2 as its base and using only digits zero and one.
- BIT (1) Abbreviation of binary digit; (2) single character in binary number; (3) single pulse in group of pulses; (4) unit of information capacity of a storage device. Capacity in bits is the logarithm to the base two of the number of possible states of the device.
- BIT, PARITY Check bit that indicates whether total number of binary "1" digits in a character or word (excluding parity bit) is odd or even. If a "1" parity bit indicates an odd number of "1" digits, then a "0" bit indicates an even number. If total number of "1" bits, including parity bit, is always even, system is called an even parity system. In an odd parity system, total number of "1" bits, including parity bit, is always odd.
- BLOCK (1) Group of computer words considered as a unit by virtue of their being stored in successive storage locations; (2) set of locations or tape positions in which a block of words is stored or recorded; (3) circuit assemblage which functions as a unit: circuit building block of standard design, and logic block in sequential circuit.
- BOOTSTRAP Technique for loading first instructions of a routine into storage; then using these instructions to bring in the rest of the routine; usually involves either entering of a few instructions manually or use of a special console key.
- BRANCH Selection of one, two, or more possible paths in flow of control based on some criterion. Instructions which mechanize this concept are sometimes called branch instructions, but the terms transfer of control and jump are more widely used.
- BRANCHPOINT Point in a routine where one of two or more choices is selected under control of routine.

- BREAKPOINT Point in computer program at which conditional interruption, to permit visual check, printing out, or other analysis. Breakpoints are usually used in debugging operations.
- BROM Bipolar Read Only Memory.
- BUFFER (1) Internal portion of data processing system serving as intermediary storage between two storage or data handling systems with different access times or formats; usually to connect an input or output device with main or internal high-speed storage; (2) logical OR circuit; (3) an isolating component designed to eliminate reaction of a driven circuit on circuits driving it: buffer amplifier; (4) diode.
- BUS (1) Circuit over which data or power is transmitted, often one which acts as a common connection among a number of locations; (2) communications path between two switching points.
- BYTE (1) Generic term to indicate measurable portion of consecutive binary digits: an 8-bit or 6-bit byte; (2) group of binary digits usually operated upon as a unit.

C

- CAPACITY, CHANNEL (1) Maximum number of binary digits or elementary digits to other bases which can be handled in a particular channel per unit time; (2) maximum possible information transmission rate through channel at specified error rate. Channel capacity may be measured in bits per second or bauds.
- CAPACITY, STORAGE Number of elementary pieces of data that can be contained in storage device. Frequently defined in terms of characters in a particular code or words of fixed size.
- CARD, PUNCH Heavy stiff paper of constant size and shape, suitable for punching in a pattern that has meaning and that can be handled mechanically. Punched holes are sensed electrically by wire brushes, mechanically by metal fingers, or photoelectrically by photocells.
- CARRY (1) Signal, or expression, produced as result of arithmetic operation on one digit place of two or more numbers expressed in positional notation and transferred to next higher place for processing there; (2) signal or expression as defined above which arises in adding, when the sum of two digits in the same digit place equals or exceeds base of the number system in use. If a carryinto-a-digit place will result in a carry-out of the same digit place, and if the normal adding circuit is bypassed when generating this new carry, it is called a high speed carry, or "standing on nines" carry. If the normal adding circuit is used in such a case, the carry is called a cascaded carry. If a carry resulting from the addition of carries is not allowed to propagate (when forming the partial product in one step of a multiplication process) process is called a partial carry. If it is allowed to propagate, the process is called a complete carry. If a carry generated in the most significant digit place is sent directly to least significant place (when adding two negative numbers using nine complements) that carry is called an end-around carry; (3) signal or expression in direct subtraction, as defined in (1) above which arises when the difference between the digits is less than zero. Such a carry is frequently called a borrow; (4) action of forwarding a carry; (5) command directing a carry to be forwarded.
- CELL (1) Storage for one unit of information, usually one character or one word; (2) location specified by whole or part of address and possessed of the faculty of store. Specific terms such as column, field, location, and block are preferable when appropriate.
- CHAD Small piece of paper tape or punch card removed when punching a hole to represent information.
- CHADLESS Type of punching of paper tape in which each chad is left fastened by about a quarter of the circumference of the hole, at the leading edge. This

mode of punching is useful where it is undesirable to destroy information written or printed on punched tape or it is undesirable to produce chads. Chadless punched paper tape must be sensed by mechanical fingers, for the presence of chad in the tape would interfere with reliable electrical or photoelectric reading of the paper tape.

- CHAIN (1) Any series of items linked together; (2) routine consisting of segments which are run through computer in tandem, only one being within computer at any one time and each using output from previous program as its input.
- CHANNEL (1) Path along which information, particularly a series of digits or characters, may flow; (2) one or more parallel tracks treated as a unit; (3) in a circulating storage, a channel is one recirculating path containing fixed number of words stored serially by word; (4) path for electrical communication; (5) band of frequencies used for communication.
- CHARACTER (1) One symbol of a set of elementary symbols such as those corresponding to typewriter keys. Symbols usually include decimal digits 0 through 9, letters A through Z, punctuation marks, operation symbols, and any other single symbols which computer may read, store, or write; (2) electrical, magnetic, or mechanical profile used to represent character in a computer, and its various storage and peripheral devices. Character may be represented by a group of other elementary marks, such as bits or pulses.
- CHARACTER, BINARY CODED One element of a notation system representing alphameric character such as deciminal digits, alphabetic letters, and punctuation marks by predetermined configuration of consecutive binary digits.
- CHARACTER, ILLEGAL Character or combination of bits which is not accepted as a valid representation by the machine design or by a specific routine. Illegal characters are commonly detected and used as an indication of machine malfunction.
- CHARACTER, REDUNDANT Character specifically added to a group of characters to ensure conformity with certain rules which can be used to detect computer malfunction.
- CHART, FLOW Graphic representation of the major steps of work in process. Illustrative symbols may represent documents, machines, or actions taken during process. The area of concentration is on where or who does what rather than how it is to be done.
- CHART, LOGICAL FLOW Detailed solution of work order in terms of the logic, or built-in operations and characteristics, of a specific machine. Concise symbolic notation is used to represent information and describe input, output, arithmetic, and logical operations involved. Chart indicates types of operations by use of a standard set of block symbols. Coding process normally follows the logical flow chart.
- CHECK Process of partial or complete testing of the correctness of machine operations, the existence of certain prescribed conditions within the computer, or the correctness of the results produced by a program. A check of any of these conditions may be made automatically by the equipment or may be programmed.
- CHECK, PARITY Summation check in which binary digits, in character or word, are added, modulo 2, and the sum checked against a single, previously computed parity digit: a check which tests whether number of ones in a word is odd or even.
- CHECK-SUM Check in which groups of digits are summed, usually without regard for overflow, and that sum checked against a previously computed sum to verify that no digits have been changed since the last summation.
- CHECK, VALIDITY Check based on known limits or on given information or computer results: a calendar month will not be numbered greater than 12; a week does not have more than 168 hours.

- CIRCUIT (1) System of conductors and related electrical elements through which electrical current flows; (2) communications link between two or more points.
- CLEAR To erase the contents of storage device by replacing the contents with blanks, or zeros.
- CLOCK, REAL TIME Clock which indicates passage of actual time, in contrast to a fictitious time set up by the computer program, such as elapsed time in the flight of a missile, wherein a 60-second trajectory is computed in 200 actual milliseconds, or a 0.1 second interval is integrated in 100 actual microseconds.
- COBOL Common Business Oriented Language.
- CODE (1) System of symbols for meaningful communication; (2) system of symbols for representing data or instructions in a computer or tabulating machine; (3) to translate program for the solution of a problem on a given computer into a sequence of machine language or pseudo instructions and addresses acceptable to that computer; (4) machine language program.
- CODE, BINARY (1) Coding system in which encoding of any data is done through use of bits, 0 or 1; (2) a code for the ten decimal digits, 0 through 9, in which each is represented by its binary, radix 2, equivalent: straight binary.
- CODE, COMPUTER (1) System of combinations of binary digits used by a given computer; (2) repertoire of instructions.
- CODE, ERROR CORRECTING Error-detecting code in which forbidden pulse combination produced by gain or loss of a bit indicates which bit is wrong.
- CODE, ERROR DETECTING Code in which errors produce forbidden combinations. A single error-detecting code produces a forbidden combination if a digit gains or loses a single bit. A double error-detecting code produces a forbidden combination if digit gains or loses either one or two bits.
- CODE, INSTRUCTION List of symbols, names, and definitions of instructions which are intelligible to a given computer or computing system.
- CODE, MICRO (1) System of coding making use of suboperations not ordinarily accessible in programming: coding that makes use of parts of multiplication or division operations; (2) list of small program steps. Combinations of these steps, performed automatically in a prescribed sequence from a macrooperation (multiply, divide, and square root).
- CODE, STRAIGHT LINE Repetition of sequence of instructions, with or without address modification, by explicitly writing instructions for each repetition. Generally straight line coding will require less execution time and more space than equivalent loop coding. If number of repetitions is large, this type of coding is tedious unless a generator is used. Feasibility of straight line coding is limited by required space and difficulty of coding a variable number of repetitions.
- CODE, SYMBOLIC Code which expresses programs in source language: by referring to storage locations and machine operations by symbolic names and addresses which are independent of their hardware determined names and addresses.
- CODING Ordered list in computer code or pseudo code, of successive computer instructions representing successive computer operations for solving a specific problem.
- COLLATE To merge two or more ordered sets of data or cards to produce one or more ordered sets that still reflect the original ordering relations. The collation process is the merging of two sequences of cards, each ordered on some mutual key, into a single sequence ordered on the same key.

- COLUMN (1) Character or digit position in a positional information format, particularly one in which characters appear in rows, and rows are placed one above another: the rightmost column in a five decimal place table, or in a list of data; (2) character or digit position in a physical device, such as punch card or a register, corresponding to a position in a written table or list: the rightmost place in a register; or the third column in an eighty column punch card.
- COMMAND (1) Electronic pulse, signal, or set of signals to start, stop, or continue some operation. It is incorrect to use command as a synonym for instruction;
   (2) portion of an instruction word which specifies operation to be performed.
- COMMENT Expression which explains or identifies a particular step in a routine, but which has no effect on the operation of the computer in performing instructions for the routine.
- COMPARE To examine representation of a quantity to discover its relationship to zero, or to examine two quantities usually for the purposes of discovering identity or relative magnitude.
- COMPATIBILITY, EQUIPMENT Characteristic of computers by which one computer may accept and process data prepared by another computer without conversion or code modification.
- COMPILE To produce a machine language routine from a routine written in source language by selecting appropriate subroutines from a subroutine library, as directed by the instructions or other symbols of the original routine, supplying the linkage which combines the subroutines into a workable routine and translating the subroutines and linkage into machine language. The compiled routine is then ready to be loaded into storage and run: the compiler does not usually run the routine it produces.
- COMPILER Computer program more powerful than an assembler. In addition to its translating function which is generally the same process as that used in an assembler, it is able to replace items of input with series of instructions (subroutines). Thus, where an assembler translates item for item, and produces as output the same number of instructions or constants which were put into it, a compiler will do more. Program which results from compiling is a translated and expanded version of the original.
- COMPLEMENT (1) Quantity expressed to the base N, which is derived from a given quantity by a particular rule; frequently used to represent the negative of the given quantity; (2) a complement on N, obtained by subtracting each digit of the given quantity from N-1, adding unity to the least significant digit, and performing all resultant carrys: the twos complement of binary 11010 is 00110; the tens complement of decimal 456 is 544; (3) a complement of N-1, obtained by subtracting each digit of the given quantity from N-1: the ones complement of binary 11010 is 00101; the nines complement of decimal 456 is 543.
- COMPUTER Device capable of accepting information, applying prescribed processes to that information, and supplying the results of these processes. It usually consists of input and output devices, storage, arithmetic, and logical units, and a control unit.
- COMPUTER, ANALOG Computer which represents variables by physical analogies. Any computer which solves problems by translating physical conditions such as flow, temperature, pressure, angular position, or voltage into related mechanical or electrical quantities and uses mechanical or electrical equivalent circuits as an analog for the physical phenomenon being investigated. Computer which generally uses an analog for each variable and produces analogs as output. Thus an analog computer measures continuously whereas a digital computer counts discretely.
- COMPUTER, DIGITAL Computer which processes information represented by combinations of discrete or discontinuous data as compared with an analog computer for continuous data. A device for performing sequences of arithmetic and logical operations, not only on data but its own program. A stored

- program digital computer capable of performing sequences of internally stored instructions, as opposed to such calculators as card-programmed calculators, on which the sequence is impressed manually.
- COMPUTER, FIXED PROGRAM Computer in which the sequence of instructions are permanently stored or wired, and performs automatically. Not subject to change either by the computer or the programmer except by rewiring or changing the storage input.
- COMPUTER, GENERAL PURPOSE Computer designed to solve a large variety of problems: a stored program computer which may be adapted to any of a very large class of applications.
- COMPUTER, SOLID STATE Computer built primarily from solid state electronic circuit elements.
- COMPUTER, SPECIAL PURPOSE Computer designed to solve a specific class or narrow range of problems.
- COMPUTER, STORED PROGRAM Computer capable of performing sequences of internally stored instructions, usually capable of modifying those instructions as directed by the instructions.
- COMPUTER, WIRED PROGRAM Computer in which instructions that specify the operations are specified by the placement and interconnection of wires. Wires are usually held by a removable control panel, allowing flexibility of operation, but the term is also applied to permanently wired machines which are then called fixed program computers.
- CONDITIONAL TRANSFER OF CONTROL Computer instruction which when reached in a program will cause the computer either to continue with the next instruction in the original sequence or to transfer control to another stated instruction, depending on a condition regarding some property of numbers which has then been determined.
- CONFIGURATION Group of machines which are interconnected and are programmed to operate as a system.
- CONJUNCTION Logical operation which makes use of the AND operator or logical product.
- CONSOLE Portion of the computer which may be used to control the machine manually, correct errors, determine the status of machine circuits, registers and counters, determine contents of storage, and manually revise storage contents.
- CONSTANT(S) Quantities or messages present in the machine and available as data for the program and which usually are not subject to change.
- CONTENT(S) Data contained in any storage medium. Quite prevalently, the symbol () is used to indicate the contents of: (M) indicates the contents of the storage location whose address is M; or (T<sub>2</sub>) may indicate the contents of the tape on input-output unit two.
- CONTROL (1) Part of a digital computer or processor which determines the execution and interpretation of instructions in proper sequence, including decoding of each instruction and application of the proper signals to the arithmetic unit and other registers in accordance with the decoded information; (2) one or more of the components in any mechanism responsible for interpreting and carrying out manually-initiated directions. Sometimes it is called manual control; (3) in some business applications, a mathematical check; (4) in programming, instructions which determine conditional jumps are often referred to as control instructions; time sequence of execution of instructions is called the flow of control.
- CONTROL, MANUAL Direction of a computer by means of manually operated switches.

- CONTROL, MASTER Application-oriented routine usually applied to the highest level of a subroutine hierarchy.
- CONTROL, NUMERICAL Descriptive of systems in which digital computers are used for the control of operations, particularly of automatic machines wherein the operation control is applied at discrete points in the operation or process.
- CONTROL, PROGRAM Descriptive of system in which a computer is used to direct an operation or process and automatically hold or make changes in the operation or process on the basis of a prescribed sequence of events.
- CONVERSION (1) Process of changing information from one form of representation to another, such as from the language of one type of machine to that of another or from tape to print; (2) process of changing from one data processing method to another, or from one type of equipment to another: conversion from punch card equipment to magnetic tape equipment.
- CONVERSION, BINARY TO DECIMAL Process of converting a number written to base of two to the equivalent number written to base of ten.
- CONVERSION, DECIMAL TO BINARY Process of converting a number written to base of ten, or decimal, into the equivalent number written to base of two, or binary.
- CONVERT (1) To change numerical information from one number base to another; (2) to transfer information from one recorded medium to another.
- CONVERTER Device which converts representation of information, or which permits changing the method for data processing from one form to another: a unit which accepts information from punch cards and records the information on magnetic tape, possibly including editing facilities.
- COPY To reproduce information in a new location, replacing whatever was previously stored there, usually leaving information unchanged at the original location.
- COPY, HARD A printed copy of machine output: printed reports, listings, documents, summaries.
- COUNTER Device, register, or location in storage for storing numbers or number representations which permits these numbers to be increased or decreased by the value of another number, or to be changed or reset to zero or to an arbitrary value.
- COUNTER, PROGRAM Register which holds the identification of the instruction word to be executed next in time sequence, following present operation. Register often a counter which is incremented to the address of the next sequential storage location, unless transfer or other special instruction is specified by the program.
- CPU Central Processing Unit.
- CROSS ASSEMBLER A symbolic language translator that operates on one type of computer to produce machine code for another type of computer.
- CROSSTALK (1) Unwanted signals in a channel which originate from one or more other channels in the same communication system; (2) signals electrically coupled from another circuit, usually undesirably, but sometimes useful.
- CYBERNETICS Technology involved in the comparative study of the control and intracommunication of information-handling machines and nervous systems of animals and man to understand and improve communication.
- CYCLE (1) Same as loop (1); (2) a nonarithmetic shift in which digits dropped off at one end of a word are returned at the other end in circular fashion: cycle left and cycle right; (3) to repeat a set of operations indefinitely or until a

stated condition is met. The set of operations may be subject to variation on each repetition, as by address changes obtained by programmed computation or by use of devices such as an index register; (4) occurrence, phenomena, or interval of space or time that recurs regularly and in the same sequence: the interval required for completion of one operation in a repetitive sequence of operations.

CYCLE, STORAGE — (1) Periodic sequence of events occurring when information is transferred to or from the storage device of a computer; (2) storing, sensing, and regeneration form parts of storage sequence.

D

- DATA General term denoting any or all facts, numbers, letters, and symbols, or facts that refer to or describe an object, idea, condition, situation, or other factors. Connotes basic elements of information which can be processed or produced by a computer. Sometimes data is considered to be expressible only in numerical form, but information is not so limited.
- DATA, RAW Data which has not been processed. Such data may or may not be in machine-sensible form.
- DATA-REDUCTION Process of transforming masses of raw data, usually gathered by automatic recording equipment, into useful, condensed, or simplified intelligence.
- DATA-REDUCTION, ON-LINE Processing of information as rapidly as the information is received by the computing system or as rapidly as it is generated by the source.
- DECADE Group or assembly of ten units: a counter which counts to ten in one column or a resistor box which inserts resistance quantities in multiples of powers of 10.
- DECIMAL, BINARY CODED Decimal notation in which the individual decimal digits are represented by a pattern of ones and zeros: in the 8-4-2-1 coded decimal notation, the number twelve is represented as 0001 0020 for 1 and 2, respectively, whereas in pure or straight binary notation it is represented as 1100.
- DECISION Computer operation to determine if a certain relationship exists between words in storage or registers, and taking alternative courses of action, affected by conditional jumps or equivalent techniques. The process consists of making comparisons by use of arithmetic to determine the relationship of two terms (numeric, alphabetic or a combination of both): equal, greater than, or less than.
- DECISION, LOGICAL Choice or ability to choose between alternatives. Basically this amounts to an ability to answer yes or no with respect to certain fundamental questions involving equality and relative magnitude: in an inventory application, it is necessary to determine whether or not there has been an issue or a given stock item.
- DECODE (1) To apply a code to reverse some previous encoding; (2) to determine meaning of individual characters or groups of characters in a message; (3) to determine the meaning of an instruction from the set of pulses which describes the instruction, command, or operation to be performed.
- DECODER (1) Device which determines the meaning of a set of signals and initiates a computer operation based thereon; (2) matrix of switching elements which selects one or more output channels according to the combination of input signals present.
- DECREMENT (1) Quantity by which a variable is decreased; (2) specific part of an instruction word in some binary computers a set of digits.

- DEFINITION (1) Resolution and sharpness of an image, or the extent to which an image is brought into sharp relief; (2) degree with which a communication system reproduces sound images or messages.
- DELAY (1) Time after the close of a reporting period before information pertaining to that period becomes available. Delay may also cover the time to process data and to report; (2) retardation of the flow of information in a channel for a finite period of time.
- DELIMITER A character which limits a string of characters, and therefore cannot be a member of the string.
- DENSITY, CHARACTER Number of characters stored per unit of length: on some magnetic tape drives, 800 or 1600 bits can be stored serially, linearly, and axially per inch.
- DENSITY, PACKING Number of units of useful information contained within a given linear dimension, usually expressed in units per inch: the number of binary digit magnetic pulses or number of characters stored on tape or drum per linear inch on a single track by a single head.
- DESIGN, LOGICAL (1) Planning of a data processing system before detailed entineering design; (2) synthesizing of a network of logical elements to perform a specified function; (3) result of (1) and (2), frequently called the logic of a computer or of a data processing system.
- DEVICE, INPUT Mechanical unit designed to bring data to be processed into a computer: a card reader, a tape reader, or a keyboard.
- DEVICE, OUTPUT The part of a machine which translates the electrical impulses representing data processed by the machine into permanent results such as printed forms, punched cards, and magnetic writing on tape.
- DIAGRAM (1) Schematic representation of a sequence of subroutines designed to solve a problem; (2) coarser and less symbolic representation than a flow chart, frequently including descriptions in words; (3) schematic or logical drawing showing the electrical circuit or logical arrangements within a component.
- DIAGRAM, BLOCK (1) Graphic representation of the hardware in a computer system. A block diagram indicates the paths along which information and control flows between the various parts of a computer system, not to be confused with the term flow chart; (2) coarser and less symbolic representation than a flow chart.
- DICTIONARY List of code names used in a routine or system; their intended meaning in that routine or system.
- DIGIT Sign or symbol used to convey a specific quantity of information either by itself or with other numbers of its set; 2, 3, 4, and 5 are digits; the base or radix must be specified and each digit's value assigned.
- DIGITAL Pertaining to utilization of discrete integral numbers in a given base to represent all the quantities that occur in a problem or calculation. It is possible to express in digital form all information stored, transferred, or processed by a dual state condition: on-off, open-closed, and true-false.
- DIRECTORY File containing the layout for each field of the described record.

  A directory describes the layout of a record within a file.
- DISK, MAGNETIC Storage device on which information is recorded on the magnetizable surface of a rotating disk. A magnetic disk storage system is an array of such devices, with associated reading and writing heads which are mounted on movable arms.
- DUMP, STORAGE Listing of contents of a storage device, or parts of it.

DUPLEX — Twin, pair, or two-in-one situation: channel providing simultaneous transmission in both directions or a second set of equipment to be used in event of failure of the primary or either device.

Е

- EDP Electronic Data Processing.
- ENCODE (1) To apply a code, frequently one consisting of binary numbers, to represent individual characters or groups of characters in a message; (2) to substitute letters, numbers, or characters for other numbers, letters, or characters, usually to intentionally hide the meaning of the message except to certain individuals who know the enciphering scheme.
- ENCODER Device capable of translating from one method of expression to another method of expression; translating a message into a series of binary digits.
- END OF FILE Termination or point of completion of a quantity of data.
- ENTRY (1) Statement in a programming system. In general, each entry is usually written on one line of a coding form and punched on one card; some systems permit a single entry to overflow several cards; (2) item of a list.
- EQUIPMENT, OFF-LINE Peripheral equipment or devices not in direct communication with the central processing unit of a computer.
- EQUIPMENT, ON-LINE System and peripheral equipment or devices in which the operation of such equipment is under control of the central processing unit, in which information reflecting current activity is introduced into the data processing system as soon as it occurs, directly in-line with the main flow of transaction processing.
- EQUIPMENT, PERIPHERAL Auxiliary machines which may be placed under central computer control: card readers, card punches, magnetic tape feeds, and high-speed printers. Peripheral equipment may be used on-line or off-line depending upon computer design and job requirements.
- ERROR (1) General term referring to any deviation of a computed or a measured quantity from the theoretically correct or true value; (2) part of the error due to a particular identifiable cause: a truncation error, or a rounding error. In a restricted sense, that deviation due to unavoidable random disturbances, or to the use of finite approximations to what is defined by an infinite series; (3) amount by which the computed or measured quantity differs from the theoretically correct or true value.
- ERROR, ABSOLUTE Magnitude of the error disregarding the algebraic sign or (if a vectorial error) disregarding its direction.
- ERROR, INHERITED Error in initial values, especially the error inherited from previous steps in the step-by-step integration. This error could also be the error introduced by the inability to make exact measurements of physical quantities.
- ERROR, ROUNDING Error resulting from rounding off a quantity by deleting the less significant digits and applying some rule of correction to the part retained: 0.2751 can be rounded to 0.275 with a rounding error of .0001.
- ERROR, TRUNCATION Error resulting from the use of only a finite number of terms of an infinite series, or from approximation of operations in the infinitesimal calculus by operations in calculus of finite differences. Frequently convenient to define truncation error, by exclusion, as any error generated in computation not due to rounding, initial conditions, or mistakes. A truncation error would thus be that deviation of a computed quantity from the theoretically correct value that would be present even in the hypothetical situation in which no mistakes were made, all given data were exact, no inherited error, and infinitely many digits retained in all calculations.

- EXECUTE To interpret a machine instruction and perform the indicated operation(s) on the operand(s).
- EXIT A way of momentarily interrupting or leaving a repeated cycle of operations in a program.
- EXPRESSION Any symbol or group of symbols representing a variable, or group of variables, possibly combined by symbols representing operators to a set of definitions and rules.

F

- FETCH To obtain data from storage.
- FIELD Assigned area in a record to be marked with information.
- FIELD, CONTROL A constant location where information for control purposes is placed; e.g., in a set of punch cards, if columns 79 and 80 contain various codes which control whether or not certain operations will be performed on any particular card, then columns 79 and 80 constitute a control field.
- FILE Organized information directed toward some purpose; may or may not be sequenced according to a key contained in each record.
- FLAG (1) Bit of information attached to a character or word indicating boundary of a field; (2) indicator used to tell some later part of a program that some condition occurred earlier; (3) indicator used to identify the members of several intermixed sets.
- FORTRAN FORmula TRANslator. Programming language designed for problems which can be expressed in algebraic notation allowing for exponentiation up to three subscripts. The FORTRAN compiler is a routine for a given machine which accepts a program written in FORTRAN source language and produces a machine language routine object program. FORTRAN II added considerably to the power of the original language by giving it the ability to define and use almost unlimited hierarchies of subroutines, all sharing a common storage region if desired. Later improvements have added the use of Boolean expressions, and some capabilities for inserting symbolic machine language sequences within a source program.

G

- GAP (1) Space or time interval used as an automatic sentinel to indicate the end of a word, record, or file of data on a tape: a word gap at the end of a word, a record or item gap at the end of a group of words, a file gap at the end of a group of records or items; (2) absence of information for a specified length of time or space on a recording medium, contrasted with marks and sentinels which are the presence of specific information to achieve a similar purpose. Marks are used primarily internally in variable word length machines. Sentinels achieve similar purposes either internally or externally, but sentinels are programmed, not inherent in the hardware; (3) space between the reading or recording head and the recording medium, such as tape, drum, or disk.
- GAP, RECORD Interval of space or time associated with a record to indicate or signal the end of the record.
- GATE, AND Signal circuit with two or more input wires in which the output wire gives a signal only if all input wires receive coincident signals.
- GATE, OR Electrical gate or mechanical device which implements the logical OR operator. An output signal occurs whenever there are one or more inputs on a multi-channel input. An OR gate performs the function of the logical "inclusive OR Operator."

- GENERATE To produce or prepare a specific term in accordance with a specific and defined rule or program.
- GENERATOR, PROGRAM Program which permits a computer to write other programs automatically. Two types: 1. the character controlled generator, which operates like a compiler in that it takes entries from a library tape, but unlike a simple compiler in that it examines control characters associated with each entry, and alters instructions found in the library according to the directions contained in control characters. 2. Pure generator is a program that writes another program. When associated with an assembler, a pure generator is usually a program section called into storage by the assembler from a library tape, which then writes one or more entries in another program. Most assemblers are also compilers and generators. The entire system is usually referred to as an assembly system.
- GENERATOR, RANDOM NUMBER Machine routine or hardware designed to produce a random number or series of random numbers to specified limitations.
- GENERATOR, REPORT Technique for producing complete data processing reports giving only description of the desired content and format of output reports, and certain information concerning the input file.

н

- HANDLING, DATA Same as processing, data (2).
- HARDWARE The physical equipment or devices forming a computer and peripheral equipment.
- HEAD Device which reads, records, or erases information in a storage medium, usually a small electromagnet used to read, write or erase information on a magnetic drum or tape or the set of perforating or reading fingers and block assembly for punching or reading holes in paper tape or cards.
- HOLLERITH System of encoding alphanumeric information onto cards, synonymous with punch cards.
- HOUSEKEEPING Administrative or overhead operations necessary to maintain control of a situation: involves setting up of constants and variables to be used in the program.
- HYSTERESIS (1) Lagging in the response of a unit of a system behind an increase or a decrease in the strength of a signal; (2) phenomenom demonstrated by materials which make their behavior a function of the history of their environment.

ı

- IMAGE Exact duplicate array of information or data stored in (or in transit to) a different medium.
- IMAGE, CARD Representation in storage of the holes punched in a card, so that the holes are represented by one binary digit and the unpunched spaces are represented by the other binary digit.
- INDEX Symbol or a number identifying a particular quantity in an array of similar quantities: X5 is the fifth item in an array of X's,
- INDICATORS Devices registering conditions such as high or equal conditions resulting from a computation. Sequence of operations within a procedure may be varied according to the position of an indicator.
- INPUT (1) Information or data transferred or to be transferred from an external storage medium into internal storage of the computer; (2) describing the routines which direct input as defined in (1) or the devices from which such information is available to the computer; (3) device or collective set of devices necessary for input as defined in (1).

- INPUT-OUTPUT General term for the equipment used to communicate with a computer and the data involved in the communication.
- INQUIRY Technique whereby the interrogation of computer storage may be initiated at a keyboard.
- INSTRUCTION (1) Set of characters which defines an operation together with one or more addresses, or no address, and which, as a unit, causes the computer to perform the operation on the indicated quantities. "Instruction" is preferable to the terms "command" and "order"; "command" is reserved for a specific portion of the instruction word: the part which specifies the operation which is to be performed. Order is reserved for the ordering of the characters, implying sequence, or the order of the interpolation, or the order of the differential equation; (2) the operation or command to be executed by a computer, together with associated addresses, tags and indices.
- INSTRUCTION, MACRO (1) Instruction consisting of a sequence of micro instructions inserted into the object routine for performing a specific operation; (2) more powerful instructions which combine several operations in one instruction.
- INSTRUCTION, MICRO Small, single, short, add, shift or delete type of command.
- INSTRUCTION, SYMBOLIC Instruction in assembly language directly translatable into a machine code.
- INTELLIGENCE, ARTIFICIAL Study of computer techniques to supplement human capabilities. As man has invented and used tools to increase his physical powers, he now is beginning to use artificial intelligence to increase his mental powers. In a more restricted sense, the study of techniques for more effective use of digital computers by improved programming techniques.
- INTERFACE Common boundary between automatic data processing systems or parts of a single system.
- INTERLACE To assign successive storage locations: on a magnetic drum, usually to reduce access time.
- INTERPRETER (1) Punch card machine which will take a punch card with no printing on it, read the information in the punched holes, and print a translation in characters in specified rows and columns; (2) executive routine which as computation progresses translates a stored program expressed in machine-like pseudo code into machine code and performs indicated operations, by subroutines, as translated. An interpreter is essentially a closed subroutine which operates successively on an indefinitely long sequence of program parameters, the pseudo instructions, and operands. It may usually be entered as a closed subroutine and left by a pseudo-code exit instruction.
- INTERRUPT To temporarily disrupt the normal operation of a routine by a special signal from the computer. Normal operation can normally be resumed from that point later.
- ITEM (1) Set of one or more fields containing related information; (2) unit of correlated information relating to a single person or object; (3) contents of a single message.
- ITERATIVE Procedure or process which repeatedly executes a series of operations until some condition is satisfied. Can be implemented by a loop in routine.

- KEY (1) A group of characters which identifies or is part of a record or item; any entry in a record or item can be used as a key for collating or sorting; (2) marked lever manually operated for copying a character: a typewriter, paper tape perforator, card punch, manual keyboard, digitizer or manual word generator; (3) lever or switch on a computer console for manually altering computer action.
- KEYPUNCH (1) A special device to record information in cards or tape by punching holes in the cards or tape to represent letters, digits, and special characters;
   (2) to operate a device for punching holes in cards or tape.

1

- LABEL Symbols used to identify or describe an item, record, message, or file. It may be the same as the address in storage.
- LANGUAGE System for representing and communicating information or data between people, or between people and machines. A system consists of a carefully defined set of characters and rules for combining them into larger units, such as words or expressions, and rules for word arrangement or usage to achieve specific meanings.
- LANGUAGE, ALGORITHMIC Arithmetic language by which numerical procedures may be precisely presented to a computer in a standard form. Language is intended as a means of directly presenting any numerical procedure to any suitable computer for which a compiler exists, and also to communicate numerical procedures among individuals. The language itself results from international cooperation to obtain a standardized algorithmic language.
- LANGUAGE, COMMON MACHINE Machine-sensible information representation common to a related group of data processing machines.
- LANGUAGE, COMMON BUSINESS ORIENTED Specific language by which business data processing procedures may be precisely described in a standard form, intended not only to present any business program to any suitable computer for which a compiler exists, but as a means of communicating such procedures among individuals.
- LANGUAGE, INTERNATIONAL ALGEBRAIC Forerunner of ALGOL.
- LANGUAGE, MACHINE (1) Language designed for interpretation and use by a machine without translation; (2) system for expressing information which is intelligible to a specific machine (a computer or class of computers). Such a language may include instructions which define and direct machine operations, and information to be recorded by or acted upon by these machine operations; (3) set of instructions expressed in the number system basic to a computer, together with symbolic operation codes with absolute addresses, relative addresses, or symbolic addresses.
- LANGUAGE, OBJECT Language which is output of an automatic coding routine.

  Usually object language and machine language are the same, but a series of steps in an automatic coding system may involve object language of one step serving as a source language for the next step.
- LANGUAGE, PROBLEM ORIENTED (1) Language designed for convenience of program specification in a general problem area rather than for easy conversion to machine instruction code. (Components of such language may bear little resemblance to machine instructions.); (2) machine-independent language where one need only state the problem, not the how of solution.
- LANGUAGE, PROGRAM Language used by programmers to write computer routines.
- LANGUAGE, SOURCE Original form in which a program is prepared before machine processing.

- LENGTH, RECORD Number of characters necessary to contain all the information in a record.
- LENGTH, WORD Number of characters in a machine word. In a given computer, the number may be constant or variable.
- LIBRARY Collection of information available to a computer, usually on magnetic tapes.
- LIBRARY, ROUTINE Collection of standard, proven routines and subroutines by which problems may be solved.
- LIBRARY, SUBROUTINE Standard and proven subroutines kept on file for use at any time.
- LINE, ACOUSTIC DELAY Delay line using a medium providing acoustic delay as mercury or quartz delay lines.
- LIST, ASSEMBLY Printed list, the byproduct of an assembly procedure. It lists in logical instruction sequence details of a routine showing the coded and symbolic notation next to the actual notations established by the assembly procedure. Highly useful in the debugging of a routine.
- LIST, PUSH DOWN List of items where the last item entered is the first item of the list, and the relative position of the other items is "pushed back" by one item.
- LIST, PUSH UP List of items where each item is entered at the end of the list, and the other items maintain their same relative position in the list.
- LOAD (1) To put data into a register or storage; (2) to put a magnetic tape onto a tape drive, or to put cards into a card reader.
- LOAD-AND-GO Automatic coding procedure which compiles the program, creating machine language, and proceeds to execute the created program. Such procedures are usually part of a monitor.
- LOCATION Storage position in the main internal storage which stores one computer word and which is usually identified by an address.
- LOGIC (1) Science dealing with criteria or formal principles of reasoning and thought; (2) systematic scheme which defines the interactions of signals in the design of an automatic data processing system; (3) principles and application of truth tables and interconnection between logical elements required for arithmetic computation in an automatic data processing system.
- LOGIC, SYMBOLIC (1) Study of formal logic and mathematics by special written language which avoids the ambiguity and inadequacy of ordinary language; (2) mathematical concepts, techniques, and languages as used in (1), whatever their particular application or context.
- LOOK UP TABLES See table.
- LOOP (1) Self-contained series of instructions in which the last instruction can modify and repeat itself until a terminal condition is reached. Productive instructions in the loop generally manipulate the operands, while bookkeeping instructions modify the productive instructions, count the number of repetitions. A loop may contain any number of conditions for termination. The equivalent can be achieved by the technique of straight line coding, whereby the repetition of productive and bookkeeping operations is accomplished by explicitly writing the instructions for each repetition; (2) communications circuit between two private subscribers or between subscriber and local switching center.
- LOW-ORDER Pertaining to the weight or significance assigned to the digits of a number: in the number 123456, the lower order digit is six. The three loworder bits of a binary word are another example.
- LPM Lines Per Minute.

- MAINTENANCE, FILE Periodic file modification to incorporate changes occurring during a given period.
- MAINTENANCE, PREVENTIVE Maintenance of a computer system to keep equipment in operating condition and prevent failures during productive runs.
- MAINTENANCE, REMEDIAL Maintenance performed by contractor following equipment failure: performed as required, on an unscheduled basis.
- MALFUNCTION Failure in the operation of the hardware of a computer.
- MASKING (1) Process of extracting a nonword group or a field of characters from a word or string of words; (2) process of setting internal program controls to prevent transfers that otherwise would occur upon setting of internal machine latches.
- MATRIX (1) Array of quantities in a prescribed form. In mathematics, usually capable of being subject to mathematical operation by an operator or another matrix; (2) array of coupled circuit elements: diodes, wires, magnetic cores, and relays, capable of performing a specific function such as conversion from one numerical system to another. The elements are usually arranged in rows and columns. A matrix is a particular type of encoder or decoder.
- MESSAGE (1) Group of words, variable in length, transported as a unit; (2) transported item of information.
- MICROCOMMAND A word obtained from the control store that exercises elementary control over the various system elements within a basic machine cycle.
- MICROPROGRAM (1) Program of analytic instructions which the programmer constructs from the basic subcommands of a digital computer; (2) sequence of pseudo commands translated by hardware into machine subcommands; (3) means of building various analytic instructions as needed from the subcommand structure of a computer; (4) plan for obtaining maximum utilization of the abilities of a digital computer by efficient use of the subcommands of the machine.
- MISTAKE Human failing: faulty arithmetic, use of incorrect formula, or incorrect instructions: sometimes called gross errors to distinguish from rounding and truncation errors. Computers malfunction and humans make mistakes. Computers do not make mistakes and humans do not malfunction, in this sense.
- MIT Master Instruction Tape. See tape, master instruction.
- MNEMONIC Pertaining to the assisting of human memory: a mnemonic term, usually an abbreviation, that is easy to remember (mpy for multiply and acc for accumulator).
- MODIFY (1) To alter a portion of an instruction to make its interpretation and execution other than normal. Modification may or may not permanently change the instruction or affect only the current execution. Most frequent modification is that of the effective address through use of index registers; (2) to alter a subroutine according to a defined parameter.
- MODULE (1) Interchangeable plug-in item containing components; (2) an incremental block of storage or other building block for expanding the computer capacity.
- MONITOR To supervise and verify the correct operation of a program during its execution, usually by a diagnostic routine used from time to time to answer questions about the program.
- MONITOR ROUTINE See routine, executive.

- MULTIPLEX The process of transferring data from several storage devices operating at relatively low transfer rates to one storage device operating at a high transfer rate so that the high-speed device is not obliged to wait for the low-speed devices.
- MULTIPROGRAMMING Technique for handling numerous routines or programs simultaneously by an interweaving process.

N

- NANOSECOND One-thousandth of a millionth of a second; 10-9 seconds.
- NOISE Meaningless extra bits or words which must be ignored or removed from the data when the data are used.
- NORMALIZE (1) To adjust the exponent and fraction of a floating point quantity so that the fraction lies in the prescribed normal standard range; (2) to reduce a set of symbols or numbers to a normal or standard form.
- NOTATION (1) Act, process, or method of representing facts or quantities by a system or set of marks, signs, figures, or characters; (2) system of such symbols or abbreviations used to express technical facts or quantities; as mathematical notations; (3) annotation; note.
- NOTATION, SYMBOLIC Method of representing a storage location by one or more figures.
- NUMBER (1) The, or a total, aggregate, or amount of units; (2) a figure or word, or a group of figures or words, representing graphically an arithmetical sum; a numeral, as the number 45; (3) numeral by which a thing is designated in a series, as a pulse number; (4) single member of a series designated by consecutive numerals, as a part number; (5) character, or a group of characters, uniquely identifying or describing an article, process, condition, document, or class; (6) to count, enumerate; (7) to distinguish by a number.
- NUMBER, BINARY A number, usually consisting of more than one figure, representing a sum, in which the individual quantity represented by each figure is based on a radix of two. The figures used are 0 and 1.
- NUMBER, DECIMAL A number, usually of more than one figure, representing a sum, in which the quantity represented by each figure is based on the radix of ten. The figures are 0, 1, 2, 3, 4, 5, 6, 7, 8, and 9.
- NUMBER, HEXADECIMAL Number, usually of more than one figure, representing a sum in which the quantity represented by each figure is based on a radix of sixteen.
- NUMBER, SYMBOLIC Numeral, used in writing routines, for referring to a specific storage location; such numerals are converted to actual storage addresses in the final assembling of the program.

0

- OCTAL Pertaining to eight; usually a number system of base or radix eight: in octal notation, octal 214 is 2 times 64, plus 1 times 8, plus 4 times 1, and equals decimal 140. Octal 214 in binary-coded-octal is represented as 010, 001, 100; octal 214, as a straight binary number is written 10001100. Note that binary coded octal and straight binary differ only in the use of commas; in the example shown, the initial zero in the straight binary is dropped.
- OFF-LINE Descriptive of a system and peripheral equipment or devices in which the operation of peripheral equipment is not under the control of the central processing unit.
- ON-LINE Descriptive of a system and of peripheral equipment or devices in which the operation of such equipment is under control of the central processing

- unit, and in which information reflecting current activity is introduced into the data processing system as soon as it occurs. Thus, directly in-line with the main flow of transaction processing.
- OPEN-ENDED Quality by which addition of new terms, subject headings, or classifications does not disturb the preexisting system.
- OPERAND Quantity entering or arising in an instruction. An operand may be an argument, a result, a parameter, or an indication of the location of the next instruction, as opposed to the operation code or symbol itself. It may be the address portion of an instruction.
- OPERATION, HOUSEKEEPING General term for the operation performed for a machine run before actual processing begins. Examples of housekeeping operations are establishing controlling marks, setting up auxiliary storage units, reading in first record for processing, initializing, setup verification operations, and file identification.
- OPERATION, PARALLEL The performance of several actions, usually of a similar nature, simultaneously through provision of individual similar or identical devices for each such action. Particularly flow or processing of information. Parallel operation is performed to save time over serial operation. Parallel operation usually requires more equipment.
- OPERATION, REAL TIME Use of computer as an element of a processing system in which times of occurrence of data transmission are controlled by other portions of the system, or by physical events outside the system, and cannot be modified for convenience in computer programming. Such an operation either proceeds at the same speed as the events being simulated or at a sufficient speed to analyze or control simultaneous external events.
- OPERATION, SEQUENTIAL Performance of actions one after the other in time. The actions referred to are of a large scale as opposed to the smaller scale operations referred to by the term serial operation. For an example of sequential operation consider Ax(BxC). The two multiplications indicated follow each other sequentially. However, the processing of the individual digits in each multiplication may be either parallel or serial.
- OPERATION, SERIAL Flow of information through a computer in time sequence using only one digit, word, line or channel at a time.
- OPERATOR (1) A mathematical symbol which represents a mathematical process to be performed on an associated operand; (2) the portion of an instruction which tells the machine what to do; (3) a machine operator.
- OPERATOR, AND (1) Logical operator which has the property that if P is a statement and Q is a statement, then P AND Q is true if both statements are true, false if either is false or both are false. Truth is normally expressed by the value 1, falsity by 0. The AND operator is often represented by a centered dot (P·Q), by no sign (PQ), by an inverted "u" or logical product symbol (P  $\cap$  Q), or by the letter "X" or multiplication symbol (PxQ). Note that the letters AND are capitalized to differentiate between the logical operator AND the conjunction; (2) the logical operation which makes use of the AND operator or logical product.
- OPERATOR, EXCLUSIVE OR A logical operator which has the property that if P and Q are two statements, then the statement P\*Q, where the \* is the Exclusive OR operator, is true if either P or Q, but not both are true, and false if P and Q are both false or both true, according to the following table, wherein the figure 1 signifies a binary digit or truth.

| P | Q | P*Q |   |        |
|---|---|-----|---|--------|
| 0 | 0 | 0   | , | (even) |
| 0 | 1 | 1   |   | (odd)  |
| 1 | 0 | 1   |   | (odd)  |
| 1 | 1 | 0   |   | (even) |
|   |   |     |   |        |

The Exclusive OR is the same as the Inclusive OR, except that the case with both inputs true yields no output: P\*Q is true if P or Q are true, but not both. Primarily used in compare operations,

- OPERATOR, INCLUSIVE OR Logical operator which has the property that P or Q is true, if P or Q or both is true; when the term OR is used alone, as in ORgate, the inclusive OR is usually implied.
- OPERATOR, OR Logical operator which has the property such that if P or Q are two statements, then the statement P or Q is true or false varies according to the following possible combinations:

| Р     | Q     | PorQ  |
|-------|-------|-------|
| False | True  | True  |
| True  | False | True  |
| True  | True  | True  |
| False | False | False |

- ORDER (1) Defined successive arrangement of elements or events. Losing favor as a synonym for instructions, due to ambiguity; (2) to sequence or arrange in a series; (3) weight or significance assigned to a digit position in a number.
- ORIGIN The absolute storage address in relative coding to which addresses in a region are referenced.
- OUTPUT (1) Information transferred from internal storage of a computer to secondary or external storage, or to any device outside of the computer; (2) routines which direct (1); (3) device or collective set of devices necessary for (1); (4) to transfer from internal storage on to external media.
- OVERFLOW (1) The condition which arises when the result of an arithmetic operation exceeds the capacity of the storage space allotted in a digital computer; (2) digit arising from this condition if a mechanical or programmed indicator is included (otherwise digit may be lost.
- OVERLAY Technique for bringing routines into high-speed storage from some other form of storage during processing, so that several routines will occupy the same storage locations at different times. Overlay is used when the total storage requirements for instructions exceed the available main storage.
- OVERPUNCH To add holes in a card column that already contain one or more holes.

Ρ

- PANEL, CONTROL (1) Interconnection device, usually removable, which employs removable wires to control the operation of computing equipment. Used on punch card machines to carry out functions controlled by the user. On computers it is used primarily to control input and output functions; (2) device or component of some data processing machines that permits the expression of instructions in a semifixed computer program by the insertion of pins, plugs, or wires into sockets, or hubs in the device, in a pattern to represent instructions, thus making electrical interconnections which may be sensed by the data processing machine.
- PARALLEL (1) To handle simultaneously in separate facilities; (2) to operate on two or more parts of a word or item simultaneously.
- PARAMETER (1) Quantity in a subroutine whose value specifies or partly specifies the process to be performed. It may be given different values when the subroutine is used in different main routines or in different parts of one main routine, but which usually remains unchanged throughout any one such use; (2) quantity used in a generator to specify machine configuration, designate subroutines to be included, or otherwise to describe the desired routine to be generated; (3) constant or a variable in mathematics, which remains constant

- during some calculation; (4) definable characteristic of an item, device, or system.
- PASS Complete cycle of reading, processing and writing: a machine run.
- PATCH (1) Section of coding inserted into a routine to correct a mistake or alter the routine, often not inserted into the actual sequence of the routine being corrected, but placed somewhere else, with an exit to the patch and a return to the routine provided; (2) to insert corrected coding.
- PERIOD, PERFORMANCE Period of 30 consecutive calendar days during which a newly installed computer is being tested for acceptance by the U.S. Government. Such a period does not include equipment time used for data purification, file conversion, and similar preparatory operations or those hours of operation rescheduled as a result of equipment failure.
- PING-PONG Programming technique of using two magnetic tape units for multiple reel files and switching automatically between the two units until the complete file is processed.
- PLOTTER Visual display or board in which a dependent variable is graphed by an automatically controlled marker as a function of one or more variables.
- POINTER, BINARY Radix pointer in a binary number system: the dot that marks the position between the integral and fractional, or units and halves in a binary number.
- POINT, LOAD Preset point at which magnetic tape is initially positioned under the read-write head to start reading or writing.
- POINT, RADIX Dot delineating the integer digits from the fractional digits of a number; specifically, the dot that delineates the digital position, involving the zero exponent of the radix from the digital position involving the minus-one exponent of the radix. The radix point is often identified by the name of the system (binary point, octal point, or decimal point). In the writing of any number in any system, if no dot is included, the radix point is assumed to follow the rightmost digit.
- PRE-EDIT To edit the input data previous to the computation.
- PRECISION (1) Degree of exactness with which a quantity is stated; (2) degree of discrimination or amount of detail: a 3 decimal digit quantity discriminates among 1000 possible quantities. A result may have more precision than it has accuracy: the true value of pi to 6 significant digits is 3.14159; the value 3.14162 is precise to 6 figures, given to 6 figures, but is accurate only to about 5
- PRIMITIVE Primitive usually pertains to the lowest level of a machine instruction or lowest unit of language translation.
- PROBLEM, BENCHMARK Routine used to determine the speed performance of a computer. One method is to use one-tenth of the time required to perform nine complete additions and one complete multiplication. A complete addition or a complete multiplication time includes the time required to procure two operands from storage, perform the operation and store the result, and the time required to select and execute the required number of instructions.
- PROCESS General term covering such terms as assemble, compile, generate, interpret, and compute.
- PROCESS, ITERATIVE A process for calculating a desired result by means of a repeating cycle of operations, which comes closer and closer to the desired result; e.g., the arithmetical square root of N may be approximated by an iterative process using additions, subtractions, and divisions only.
- PROCESSING, AUTOMATIC DATA Processing performed by a system of electronic or electrical machines so interconnected and interacting as to reduce to

- a minimum the need for human assistance or intervention. Synonymous with (ADP) and related to (system, automatic data processing).
- PROCESSING, BATCH Technique by which terms to be processed must be coded and collected into groups before processing.
- PROCESSING, DATA (1) Preparation of source media which contain data or basic elements of information, and the handling of such data according to precise rules or procedures to accomplish such operations as classifying, sorting, calculating, summarizing, and recording; (2) production of records and reports.
- \_PROCESSING, ELECTRONIC DATA Data processing performed largely by electronic equipment.
- PROCESSING, INFORMATION A less restrictive term than data processing, encompassing the complete scientific and business operations performed by a computer.
- PROCESSING, PARALLEL The operation of a computer so that programs for more than one run are stored simultaneously in its storage, and executed concurrently.
- PROCESSING, REAL TIME Processing of information or data in a sufficiently rapid manner so that the results of the processing are available in time to influence the process being monitored or controlled.
- PROCESSOR (1) Generic term which includes assembly, compiling, and generation; (2) shorter term for automatic data processor or arithmetic unit.
- PROGRAM (1) Complete plan for the solution of a problem, more specifically the complete sequence of machine instructions and routines necessary to solve a problem; (2) to plan the procedures for solving a problem. This involves the analysis of the problem, preparation of a flow diagram, preparing details, testing, and developing subroutines, allocation of storage locations, specification of input and output formats, and incorporation of a computer run into a complete data processing system.
- PROGRAM, CONTROL Sequence of instructions which prescribes the steps to be taken by a computer system or any other device.
- PROGRAM, GENERAL Program expressed in computer code designed to solve a class of problems, or specializing on a specific problem when appropriate parametric values are supplied.
- PROGRAM, OBJECT Program which is the output of an automatic coding system. Often the object program is a machine language program ready for execution, but it may well be in an intermediate language. Contrasted with (program, source).
- PROGRAM, SOURCE Computer program written in a language designed for ease of expression of a class of problems or procedures, by humans: symbolic or algebraic. A generator, assembler, translator, or compiler routine is used to perform the mechanics of translating the source program into an object program in machine language. See program, object, above.
- PROGRAMMING, INTERPRETIVE Writing of programs in pseudo machine language, which is precisely converted by the computer into actual machine language instructions before being performed by the computer.
- PROGRAMMING, MICRO Technique of using a special set of instructions for an automatic computer that consists only of basic elemental operations which the programmer may combine into higher level instructions, which he may then program using the higher level instructions only: if a computer has only basic instructions for adding, subtracting, and multiplying, the instruction for dividing would be defined by microprogramming.

- PROGRAMMING, SYMBOLIC Use of arbitrary symbols to represent addresses in order to facilitate programming.
- PROM Programmable Read Only Memory. Integrated circuit array that is manufactured with a pattern of all logical zeros or ones and has a specific pattern written into it by a special hardware programmer.
- PSEUDO-OPERATION An operation which is not part of the computer's operation repertoire as realized by hardware; hence an extension of the set of machine operations.
- PSEUDO-RANDOM Property of satisfying one or more of the standard criteria for statistical randomness but being produced by a definite calculation process.
- PUNCH, CARD Machine which punches cards in designated locations to store data which can be conveyed to other machines or devices by reading or sensing the holes.

R

RADIX — Quantity of characters for use in each of the digital positions of a numbering system. In the more common numbering systems the characters are some or all of the Arabic numerals:

| System Name | Character             | Radix |
|-------------|-----------------------|-------|
| Binary      | (0,1)                 | 2     |
| Octal       | (0,1,2,3,4,5,6,7)     | 8     |
| Decimal     | (0,1,2,3,4,5,6,7,8,9) | 10    |

Unless otherwise indicated, the radix of any number is assumed to be 10. For positive identification of a radix 10 number, the radix is written in parentheses as a subscript to the expressed number:  $126_{(10)}$ . The radix of any nondecimal number is expressed in similar fashion:  $11_{(2)}$  and  $5_{(8)}$ . Synonymous with base.

- RANDOM ACCESS See access, random.
- RATE, BIT Rate at which binary digits, or pulses representing them, pass a given point on a communications line or channel.
- RATE, CLOCK Time rate at which pulses are emitted from the clock. The clock rate determines the rate at which logical or arithmetic gating is performed with a synchronous computer.
- RATE, ERROR Total amount of information in error, due to the transmission media, divided by the total amount of information received.
- RATE, SAMPLING Rate at which measurements of physical quantities are made: if it is desired to calculate the velocity of a missile and its position is measured each millisecond, then the sampling rate is 1,000 measurements per second.
- RATIO, SIGNAL-TO-NOISE Ratio of the amount of signals conveying information to the amount of signals not conveying information.
- READ (1) To sense information contained in some source; (2) the sensing of information contained in some source.
- READ-IN To sense information contained in some source and transmit this information to an internal storage.
- READ, NONDESTRUCTIVE Reading of the information in a register without changing that information.
- ${\sf READ-OUT-To\ sense\ information\ contained\ in\ some\ internal\ storage\ and\ transmit\ this\ information\ to\ a\ storage\ external\ to\ the\ computer.}$

- READ, CARD (1) Mechanism that senses information punched into cards; (2) input device consisting of a mechanical punch card reader and related electronic circuitry which transcribes data from punch cards to working storage or magnetic tape.
- READER, CHARACTER Specialized device which can convert data represented in one of the type fonts or scripts read by human beings directly into machine language. Such a reader may operate optically, or if the characters are printed in magnetic ink, the device may operate magnetically or optically.
- READER, HIGH-SPEED Reading device capable of being connected to a computer to operate online without seriously holding up the computer. A card reader reading more than 250 cards per minute would be called a high-speed reader. A reader which reads punched paper tape at a rate greater than 50 characters per second could also be called a high-speed reader.
- READER, MAGNETIC TAPE Device capable of sensing information recorded on a magnetic tape in the form of a series of magnetized spots.
- READER, PAPER TAPE Device capable of sensing information punched on a paper tape in the form of a series of holes.
- RECORD, UNIT (1) Separate record that is similar in form and content to other records; (2) sometimes a piece of nontape auxiliary equipment (card reader, printer or console typewriter).
- REGISTER Hardware device used to store bits or characters. A register is usually constructed of elements such as transistors or tubes and usually contains approximately one word of information. Common programming usage demands that a register have the ability to operate upon information and not merely store information, hardware usage does not make the distinction.
- REGISTER, INDEX A register which contains a quantity which may be used to modify addresses, B-register.
- REGISTER, SHIFT Register in which the characters may be shifted one or more positions to the right or left. In a right shift, the rightmost characters are lost. In a left shift, the leftmost characters are lost.
- RELIABILITY (1) A measure of the ability to function without failure; (2) the amount of credence placed in a result.
- RERUN To repeat all or part of a program on a computer.
- RESTART To go back to a specific planned point in a routine, usually in the case of machine malfunction, for the purpose of rerunning the portion of the routine in which the error occurred. The length of time between restart points in a given routine should be a function of the mean free-error time of the machine itself.
- RESTORE To return an index register, a variable address, or other computer word to its initial or preselected value.
- RETRIEVAL, INFORMATION Recovering of desired information or data from a collection of graphic records.
- RETURN Mechanism providing for a return in the usual sense, in particular a set of instructions at the end of a subroutine which permit control to return to the proper point in the main routine.
- ROUND Deletion of the least significant digit(s) with or without modifications to reduce bias.
- ROUTINE Set of coded instructions arranged in proper sequence to direct the computer to perform a desired operation or sequence of operations, or a subdivision of a program consisting of two or more instructions that are functionally related (a program). See subroutine and program.

- ROUTINE, DIAGNOSTIC Routine used to locate a malfunction in a computer, or to aid in locating mistakes in a computer program. Thus, any routine specifically designed to aid in debugging or trouble shooting.
- ROUTINE, EXECUTIVE Routine which controls loading and relocation of routines and in some cases makes use of instructions which are unknown to the general programmer. Effectively, an executive routine is part of the machine itself.
- ROUTINE, FLOATING POINT Set of subroutines which cause a computer to execute floating point arithmetic. These routines may be used to simulate floating point operations on a computer with no built-in floating point hardware.
- ROUTINE, HOUSEKEEPING Initial instructions in a program which are executed only one time: clear storage.
- ROUTINE, INTERPRETIVE Routine that decodes and executes instructions written as pseudocodes, contrasted with a compiler which decodes the pseudocodes into a machine language routine to be executed at a later time. The essential characteristic of an interpretive routine is that a particular pseudo code operation must be decoded each time it is executed.
- RUN Performance of one program on a computer, thus the performance of one routine, or several routines linked so that they form an automatic operating unit, during which manual manipulations by the computer operator are minimal.

s

- SCALE A range of values frequently dictated by the computer word-length or routine at hand.
- SCAN To examine every reference or every entry in a file routinely as a part of a retrieval scheme; occasionally, to collate.
- SCREEN (1) Surface in an electrostatic cathode ray storage tube where electrostatic charges are stored, and by means of which information is displayed or stored temporarily; (2) to make preliminary selection from a set of entities, selection criteria being based on a given set of rules or conditions.
- SEARCH To examine a series of items for any that have a desired property or properties.
- SEARCH, BINARY Search in which the series of items is divided into two parts, one of which is rejected, and the process repeated on the unrejected part until the item with the desired property is found. This process usually depends upon the presence of a known sequence in the series.
- SEGMENT (1) To divide a routine in parts, each consisting of an integral number of subroutines, and each part capable of being completely stored in the internal storage and containing the necessary instructions to jump to other segments; (2) that portion of a routine too long to fit into internal storage which is short enough to be stored entirely in the internal storage. Such a segment contains the coding necessary to call in other segments automatically. Routines which exceed internal storage capacity may be automatically divided into segments by a compiler.
- SELECT (1) To take the alternative A if the report on a condition is of one state, and alternative B if the report on the condition is of another state; (2) to choose a needed subroutine from a file of subroutines.
- SELECTOR Device which interrogates a condition and initiates one of several alternate operations.
- SENSE (1) To examine, particularly relative to a criterion; (2) to determine the present arrangement of some element of hardware, especially a manually-set switch; (3) to read punched holes or other marks.

- SENSING, MARK Technique for detecting special pencil marks entered in special places on a punch card and automatically translating the marks into punched hole.
- SEQUENCE (1) To put a set of symbols into an arbitrarily defined order: to select A if A is greater than or equal to B, or select B if A is less than B; (2) arbitrarily defined order of a set of symbols: an orderly progression of items of information or of operations in accordance with some rule.
- SEQUENCE, CALLING Instructions used for linking a closed subroutine with a main routine: standard linkage and a list of the parameters.
- SEQUENCE, CONTROL Normal order of selection of instructions for execution. In some computers one of the addresses in each instruction specifies the control sequence. In most computers, the sequence is consecutive except where a transfer occurs.
- SEQUENCE, RANDOM NUMBER Unpredictable array of numbers produced by change, and satisfying one or more of the tests for randomness.
- SERIAL (1) Handling of one after the other in a single facility, such as transfer or store in a digit-by-digit time sequence, or to process a sequence of instructions one at a time (sequentially); (2) time sequence transmission of, storage of, or logical operations on the parts of a word, with the same facilities for successive parts. Related to operation, serial and contrasted with parallel (2).
- SERIAL-PARALLEL (1) Combination of serial and parallel (serial by character, parallel by bits comprising the characters; (2) descriptive of a device which converts a serial input into a parallel output.
- SET (1) To place a storage device in a prescribed state; (2) to place a binary cell in the one state; (3) a collection of elements having some feature in common or which bear a certain relation to one another: all even numbers, geometrical figures, terms in a series, a group of irrational numbers, all positive even integers less than 100 may be a set or a subset.
- SET, CHARACTER Agreed set of representations (characters) from which selections are made to denote and distinguish data. Each character differs from all others, and the total number of characters in a given set is fixed: a set may include the numerals 0 to 9, the letters A to Z, punctuation marks and a blank or space. Clarified by alphabet.
- SHIFT To move the characters of a unit of information columnwise right or left. For a number, this is equivalent to multiplying or dividing by a power of the base of notation. See below.
- SHIFT, ARITHMETIC To multiply or divide a quantity by a power of the number base: if binary 1101, which represents decimal 13, is arithmetically shifted twice to the left, the result is 110100, which represents 52, which is also obtained by multiplying 13 by 2 twice; on the other hand, if the decimal 13 were to be shifted to the left twice, the result would be the same as multiplying by 10 twice, or 1300.
- SHIFT, CYCLIC Shift in which the digits dropped-off at one end of a word are returned at the other in a circular fashion: if register holds eight digits, 23456789, the result of a cyclic shift two columns to the left would be to change the contents of the register to 45678923.
- SIMULATION (1) The representation of physical systems and phenomena by computers, models or other equipment: an imitative type of data processing in which an automatic computer is used as a model of some entity; a chemical process. Information enters the computer to represent the factors entering the real process, the computer produces information that represents the results of the process, and the processing done by the computer represents the process itself; (2) in computer programming, the technique of setting up a routine for one computer to make it operate as nearly as possible like some other computer.

- SIMULATOR (1) Computer or model representing a system or phenomenon which mirrors or maps the effects of various changes in the original, enabling the original to be studied, analyzed, and understood by means of the behavior of the model; (2) a program or routine corresponding to a mathematical model or representing a physical model; (3) a routine executed by one computer but which imitates the operations of another computer.
- SOFTWARE The totality of programs and routines used to extend the capabilities of computers, such as compilers, assemblers, narrators, routines, and subroutines. Contrasted with hardware.
- SORT To arrange items of information according to rules dependent upon a key or field contained in the items or records: to digital-sort is to sort first the keys on the least significant digit, and to resort on each higher order digit until the items are sorted on the most significant digit.
- SORT, MERGE To produce a single sequence of items, ordered according to some rule, from two or more previously unordered sequences, without changing the items in size, structure, or total number. More than one pass may be required for a complete sort, but items are selected during each pass on the basis of the entire key.
- STORAGE (1) The term preferred to memory; (2) pertaining to a device in which data can be stored and from which it can be obtained at a later time. The means of storing data may be chemical, electrical or mechanical; (3) a device consisting of electronic, electrostatic, electrical, hardware or other elements into which data may be entered, and from which data may be obtained as desired; (4) the erasable storage in any given computer. See memory.
- STORAGE, BUFFER (1) Synchronizing element between two different forms of storage, usually between internal and external; (2) input device in which information is assembled from external or secondary storage and stored ready for transfer to internal storage; (3) output device into which information is copied from internal storage and held for transfer to secondary or external storage. Computation continues while transfers between buffer storage and secondary or internal storage or vice versa take place; (4) device which stores information temporarily during data transfers, See buffer.
- STORAGE, DISK Storage of data on the surface of magnetic disks. See disk, magnetic and storage, magnetic disk.
- STORAGE, MAGNETIC CORE Storage device in which binary data are represented by the direction of magnetization in each unit of an array of magnetic material, usually in the shape of o-rings, but also in other forms such as wraps on bobbins. Synonymous with core storage.
- STORAGE, MAGNETIC DISK Storage system consisting of magnetically coated disks, on the surface of which information is stored in the form of magnetic spots arranged to represent binary data. These data are arranged in circular tracks around the disks and are accessible to reading and writing heads on an arm which can be moved mechanically to the desired disk and then to the desired track on that disk. Data from a given track are read or written sequentially as the disk rotates. See storage, disk.
- STORAGE, PARALLEL Storage of data in which all bits, characters, or words are essentially equally available in space, without time being one of the factors. When words are in parallel, the storage is said to be parallel by words; when characters within words, or binary digits within words or characters, are dealt with simultaneously, not one after the other, the storage is parallel by characters, or parallel by bit.
- STORAGE, PROGRAM Portion of the internal storage reserved for the storage of programs, routines, and subroutines. In many systems protection devices are used to prevent inadvertent alteration of the contents of the program storage. Contrasted with storage, temporary.

- STORAGE, TEMPORARY Portion of the internal storage reserved for the data upon which operations are being performed. Synonymous with working space and storage; contrasted with storage, program.
- STORE (1) To transfer an element of information to a device from which the unaltered information can be obtained at a later time; (2) to retain data in a device from which it can be obtained at a later time.
- SUBPROGRAM Part of a larger program which can be converted into machine language independently. See microprogram.
- SUBROUTINE (1) Set of instructions necessary to direct the computer to carry out a well defined mathematical or logical operation; (2) subunit of a routine. A subroutine is often written in relative or symbolic coding even when the routine to which it belongs is not; (3) portion of a routine that causes a computer to carry out a well-defined mathematical or logical operation; (4) routine arranged so that control may be transferred to it from a master routine and so that, at the conclusion of the subroutine, control reverts to the master routine (usually called closed subroutine); (5) single routine may simultaneously be both a subroutine with respect to another routine and a master routine with respect to a third. Control is usually transferred to a single subroutine from more than one place in the master routine; the reason for using the subroutine is to avoid having to repeat the same sequence of instructions in different places in the master routine. See routine.
- SUBROUTINE, CLOSED Subroutine not stored in the main path of the routine. Such a subroutine is entered by a jump operation; provision is made to return control to the main routine at the end of the operation. The instructions related to the entry and reentry function constitute a linkage.
- SUBROUTINE, STATIC A subroutine which involves no parameters other than the addresses of the operands.
- SUBSET (1) A set contained within a set; (2) a subscriber apparatus in a communications network.
- SUBTRAHEND The number or quantity which is subtracted from another number, called the minuend, giving a result usually called the difference, or sometimes called the remainder.
- SUM, LOGICAL A result, similar to an arithmetic sum, obtained in the process of ordinary addition, except that the rules are such that a result of one is obtained when either one or both input variables is a one, and an output of zero is obtained when the input variables are both zero. The logical sum is the name given the result produced by the inclusive or operator.
- SYMBOL, LOGICAL Sign used as an operator to denote the particular operation to be performed on the associated variables.
- SYNTAX The rules governing sentence structure in a language, or statement structure in a language such as that of a compiler.
- SYSTEM Assembly of procedures, processes, methods, routines, or techniques united by regulated interaction to form an organized whole.
- SYSTEM, INFORMATION Network of all communication methods within an organization. Information may be derived from many sources other than a data processing unit: telephone, personal contact, or by studying an operation.
- SYSTEM, INFORMATION RETRIEVAL System for locating and selecting, on demand, certain documents or other graphic records relevant to a given information requirement from a file. Examples of information retrieval systems are classification, indexing, and machine searching systems.
- SYSTEM, NUMBER (1) Systematic method for representing numerical quantities in which any quantity is represented as the sequence of coefficients of the

successive powers of a particular base with an appropriate point. Each succeeding coefficient from right to left is associated with and usually multiplies the next higher power of the base. The first coefficient to the left of the point is associated with the zero power of the base. For example, in decimal notation 371.426 represents  $(3\times10^2)+(7\times10^1)+(1\times10^0)+(4\times10^{-1})+(2\times10^{-2})+(6\times10^{-3})$ ; (2) following are names of the number systems with bases 2 through 20: 2, binary; 3, ternary; 4, quaternary; 5, quinary; 6, senary; 7, septenary; 3, octal, or octonary; 9, novenary; 10, decimal; 11, undecimal; 12, duodecimal; 13, terdenary; 14, quaterdenary; 15, quindenary; 16, sexadecimal, or hexadecimal; 17, septendecimal; 18, octodenary; 19, novemdenary; 20, vicenary. 32, duosexadecimal, or duotricinary; and 60, sexagenary. The Binary, Octal, Decimal, and Sexadecimal systems are widely used in computers.

SYSTEM, OPERATING — Integrated collection of service routines for supervising the sequencing of programs by a computer. Operating systems may perform debugging, input-output, accounting, compilation, and storage assignment tasks.

Т

- TABLE Collection of data in a form suitable for ready reference, frequently as stored in sequenced machine locations or written in the form of an array of rows and columns for easy entry and in which an intersection of labeled rows and columns serves to locate a specific piece of data or information.
- TABLE, FUNCTION (1) Two or more sets of information so arranged that an entry in one set selects one or more entries in the remaining sets; (2) a dictionary; (3) a device constructed of hardware, or a subroutine, which can either decode multiple inputs into a single output or encode a single input into multiple outputs; (4) a tabulation of the values of a function for a set of values of the variable.
- TABLE LOOK UP (TLU) Obtaining a function value corresponding to an argument, stated or implied, from a table of function values stored in the computer. Also, the operation of obtaining a value from a table.
- TABLE, TRUTH Representation of a switching function, or truth function, in which every possible configuration of argument values 0, 1, or true-false is listed, and beside each is given the associated function value 0-1 or true-false. The number of configurations is  $2^N$ , where N is the number of arguments, unless the function is incompletely specified: don't care conditions. An example of a truth table for the AND-function and the OR-function (inclusive) is:

| VARIABLE |   | AND  | OR  |
|----------|---|------|-----|
| Α        | В | AB - | A+B |
| 0        | 0 | 0    | 0   |
| 0        | 1 | 0    | . 1 |
| 1        | 0 | 0    | 1   |
| 1        | 1 | 1    | 1   |

- TAG Unit of information whose composition differs from that of other members of the set so that it can be used as a marker or label. A tag bit is an instruction word that is also called a sentinel.
- TAPE, MAGNETIC Tape or ribbon of any material impregnated or coated with magnetic or other material on which information may be placed in the form of magnetically polarized spots.
- TAPE, PAPER Strip of paper capable of storing or recording information. Storage may be in the form of punched holes, partially punched holes, carbonization or chemical change of impregnated material, or imprinting. Some paper tapes, such as punched paper tapes, are capable of being read by the input device of a computer or a transmitting device by sensing the pattern of holes which represent coded information.

- TAPE, PUNCH Tape, usually paper, upon which data may be stored in the form of punched holes. Hole locations are arranged in columns across the width of the tape. There are usually 5 to 8 positions (channels) per column, with data represented by a binary coded decimal system. All holes in a column are sensed simultaneously in a manner similar to that for punch cards.
- TIME, ACCESS (1) Time it takes a computer to locate data or an instruction word in its storage section and transfer it to its arithmetic unit where the required computations are performed; (2) time required to transfer information which has been operated on from the arithmetic unit to the location in storage where the information is to be stored.
- TIME, EXECUTION The portion of an instruction cycle during which the actual work is performed or operation executed: the time required to decode and perform an instruction. See below.
- TIME, INSTRUCTION Portion of an instruction cycle during which the control unit is analyzing the instruction and setting up to perform the indicated operation. Same as time, execution.
- TIME, LATENCY (1) Time lag between completion of instruction staticizing and the initiation of the movement of data from its storage location; (2) rotational delay time from a disc file or a drum file.
- TIME-SHARING Use of a device for two or more purposes during the same overall time, accomplished by interspersing component actions in time.
- TIME, SWITCHING (1) Time interval between the reference-time, or time at which the leading edge of switching or driving pulse occurs, and the last instant at which the instantaneous voltage response of a magnetic cell reaches a stated fraction of its peak value; (2) time interval between the reference time and the first instant at which the instantaneous integrated voltage response reaches a stated fraction of its peak value.
- TIME, TURN-AROUND Time required to reverse the direction of transmission in a communication channel.
- TRACE Interpretive diagnostic technique which provides an analysis of each executed instruction and writes it on an output device as each instruction is executed.
- TRACK Path along which information is recorded on a storage device: the track on a drum or tape.
- TRANSFER (1) Conveyance of control from one mode to another by means of instructions or signals; (2) conveyance of data from one place to another; (3) instruction for transfer; (4) to copy, exchange, read, record, store, transmit, transport, or write data; (5) instruction which provides the ability to break the normal sequential flow of control.
- TRANSFER OPERATION See operation, transfer.
- TRAP (1) Special form of a conditional breakpoint activated by the hardware itself, by conditions imposed by the operating system, or by a combination of the two. Traps are an outgrowth of switch-controlled halts or jumps. Internal triggers or traps often exist in a computer. Since these are usually set only by unexpected or unpredictable occurrences and since the execution time and number of instructions for testing them can be burdensome, these triggers usually cause an automatic transfer of control, or jump to a known location, to record in other standard locations the location from which the transfer occurred and the cause of the transfer. Some trapping features can also be enabled or inhibited under program control: an overflow trap; (2) routine to determine indirectly the setting of internal triggers in the computer.
- TROUBLE-SHOOT To seek the cause of a malfunction or erroneous program behavior to remove the malfunction.

TRUNCATE — To drop digits of a number of terms of a series, lessening precision: the number 3.14159265 is truncated to five figures in 3.1415, whereas one may round off to 3.1416.

u

- UNDERFLOW (1) Condition which arises when a machine computation yields a result which is smaller than the smallest possible quantity which the machine is capable of storing; (2) a condition in which the exponent plus the excess becomes negative in a floating point arithmetic operation.
- UNIT Portion or subassembly of a computer which constitutes the means of accomplishing some inclusive operation or function.
- UNIT, ARITHMETIC Portion of the hardware of a computer in which arithmetic and logical operations are performed. The arithmetic unit generally consists of an accumulator, special registers for the storage of operands and results, supplemented by shifting and sequencing circuitry for implementing multiplication, division, and other desired operations.
- UNIT, ASSEMBLY (1) Device which performs the function of associating and joining several parts or piecing together a program; (2) a portion of a program capable of being assembled into a larger whole program.
- UNIT, CONTROL Computer segment which directs the sequence of operations, interprets the coded instructions, and initiates the proper commands to the computer circuits preparatory to execution.
- UNIT, PAPER TAPE Mechanism which handles punched paper tape and usually consists of a paper tape transport, sensing and recording or perforating heads and associated electrical and electronic equipments.
- UNIT, READ PUNCH Input-output unit of a computing system which punches computed results into cards, reads input information into the system, and segregates output cards. The read-punch unit generally consists of a card feed, a read station, a punch station, another read station, and output card stackers.
- UNIT, TAPE Device consisting of a tape transport, controls, a set of reels and a length of tape capable of recording and reading information on and from the tape, at the request of the computer under the influence of a program.
- UPDATE (1) To put into a master file the changes required by current information or transactions; (2) to modify an instruction so that the address numbers are increased by a stated amount each time the instruction is performed.

v

- VALIDITY Correctness: especially degree of closeness by which iterated results approach the correct result.
- VALIDITY CHECK See check, validity.
- VARIABLE (1) Quantity which can assume any of the numbers of some set of numbers; (2) condition, transaction, or event which changes or may be changed as a result of processing additional data through the system.
- VECTOR Quantity having magnitude and direction, in contrast with a scalar which has quantity only.
- VERIFIER Device on which a record can be compared or tested for identity character-by-character with a retranscription or copy as it is being prepared.
- VERIFY To check a transcribing operation by a compare operation. It usually applies to transcriptions which can be read mechanically or electrically.
- VOCABULARY List of operating codes or instructions available to the programmer for writing the program for a given problem for a specific computer.

VOCABULARY, SOPHISTICATED — Advanced and elaborate set of instructions. Some computers can perform only the more common mathematical calculations such as addition, multiplication, and subtraction. A sophisticated vocabulary computer can go beyond this and perform such operations as linearize, extract square root, and select highest number.

w

- WORD Ordered set of characters which occupies one storage location and is treated by the computer circuits as a unit and transferred as such. Ordinarily a word is treated by the control unit as an instruction, and by the arithmetic unit as a quantity. Word lengths may be fixed or variable.
- WORD, CONTROL Word, usually the first or last of a record, or first or last word of a block, which carries indicative information for the following words, records, or blocks.
- WORD, DATA Word which may be primarily regarded as part of the information manipulated by a program. A data word may be used to modify a program instruction or be arithmetically combined with other data words.
- WORD, INFORMATION Ordered set of characters bearing at least one meaning and handled by a computer as a unit, including separating and spacing, which may be contrasted with instruction words. See word, machine.
- WORD-LENGTH, VARIABLE Having the property that a machine word may have a variable number of characters, applicable either to a single entry whose information content may be changed from time to time, or to a group of functionally similar entries whose corresponding components are of different lengths.
- WORD, MACHINE A unit of information of a standard number of characters which a machine regularly handles in each transfer: a machine may regularly handle numbers or instruction in units of 36 binary digits; this is then the machine word. See word, information.
- WRITE (1) To transfer information, usually from main storage, to an output device; (2) to record data in a register, location, or other storage device.

Z

- ZERO Numeral normally denoting lack of magnitude. In many computers there are distinct representations for plus and minus zero.
- ZONE (1) Portion of internal storage allocated for a particular function or purpose;
   (2) three top positions of 12, 11 and 0 on certain punch cards. In these positions, a second punch can be inserted so that with punches in the remaining positions 1 to 9 alphabetic characters may be represented.
- ZONE, NEUTRAL Area in space or an interval of time in which a state of being other than the implementing state exists: a range of values in which no control action occurs or a brief period between words when certain switching action takes place. Similar to dead band.



# **PART II**

# APPLICATION OF THE MICROPROGRAMMED COMPUTERS

#### INTRODUCTION

There are four classes of applications which are established for Microprogrammed computers. Each class contains several sub classes which are implemented by control unit programming (firmware) variation.

Any class, augmentation of, or variation of, represents a computer architecture different from one another each offering specific advantages to the intended end application.

#### **General Purpose Computers**

- General Purpose Computers With Standard Instruction Set.
- General Purpose Computers With Added Special Instructions.
- General Purpose Computers With Background for Special Data Processing or Input/Output Functions.
- General Purpose Computer With Addition of Special Microprogram Which is Entered and Exits From the Software Program, and Remains Active for a Relatively Long Period of Time.

#### **Special Purpose Computers**

- Special Instruction Set.
- Direct Application Microprogram.
- Direct Sequence of Subroutines.
- Interlaced Microprogram Instructions and/or Subroutines With Partial Processing.
- Subroutine Branching According to System States.

#### **Emulator Computer**

- Duplication or Approaching Equal Functional Capability With a Preexisting Fixed Instruction Stored Program General Purpose Computer.
- Duplication or Approaching Equal Functional Capability With a Preexisting Special Purpose Computer.

## Language Processor

- Direct Execution of High Level Language Statements.
- Partial Execution of High Level Language Statements.

With such a large selection of organizations to choose from, use of a microprogrammable computer provides a very useful method for arriving at the most cost-effective processing or control system, including development, hardware, programming and operating costs.

#### **CLASSES OF APPLICATION**

#### **General Purpose Computers**

General Purpose Computer with Standard Instruction Set.

In this class of computers the microprogram is designed to fetch instructions from core memory and to execute them by microprogram subroutines. Once started the microprogram continues to loop back on itself, looking for and executing instructions until it sees a halt instruction, or gets into an input mode, and waits for a character. The instruc-

tions share the core memory with data and flags. The coding of the instructions in core bears no particular relationship in format to the microcommands.

The general flow of firmware functions for the General Purpose Computer is shown in Figure 4.

All operations, including arithmetic, logical, control, shift, branching, jumps, input/output, and register transfer are programmed into microprogram subroutines.

An example of General Purpose firmware is described in detail in Part IV "MICRO 810 Firmware Manual".

#### General Purpose Computer with added special instructions.

Firmware for a general purpose computer will contain several unused operation codes which can be used for additional instructions. The simplest



Figure 4. Firmware Function Flow

way to add instructions is to make use of a spare operation code which can easily be converted to a jump instruction to enter a new firmware routine. The new instruction can be either a memory reference or non memory reference instruction. Multiple instructions can be added by using sub-operation codes. Typical instructions which may be added are as follows:

Floating Point Arithmetic.

BCD Arithmetic.

Data Block Manipulation Routines.

Error Code Generation and Checking.

Push Down Stacks and Related Functions.

Special Input/Output Routines for Greater Speed, Increased Func-

tional Complexity, or Simplified Interfaces.

Curve Fitting Routines and Interpolation.

Square, Square Root, and Other Related Functions.

Table Search.

Character Test and Manipulation.

Communications Handshaking.

Filtering and Spectrum Analysis Operations.

Pattern Manipulation and Recognition Functions.

The capacity to add instructions of these types tremendously increases throughput capability and processing power of any General Purpose computer.

The procedure for adding instructions is to define the instruction algorithm, flow chart, and microcode, then to do a timing analysis of the routine to see if it is equal to or less than the maximum permissible interrupt time. If not, the routine must be subdivided to do only a portion of the operation each time it is entered, or to allow testing of interrupts at scheduled times during the routine.

#### • General Purpose Computer with Background Microprogram.

Microprograms can be added to the general purpose computer which run continuously, or on command, and perform some function independent of the software, or indirectly related to the software. These programs are periodically entered as interrupt routines although they don't divert the software program like a normal interrupt does. One example of this is the concurrent input/output routine of the MICRO 810. This firmware transfers a block of data between interface devices and core memory. The concurrent input/output operation is set up and initiated by software, but proceeds independent of the software until the complete block of data has been transferred. Another example is the communications multiplexing function of the MICRO 820 Series computers. This firmware handles up to 32 low speed asynchronous communications lines with character assembly and disassembly performed by firmware. A character queue, and status flags are maintained by the multiplexing firmware to provide a link to the software program. The multiplexer firmware is controlled by the software by means of programmable rates and configurations, enable and disable functions, buffer assignments, and setting or resetting of control flags. Once set up, however, the multiplexer firmware proceeds independently of any specific instructions from the software program. Sampling rates are timed by hardware rate generators.

Other typical background microprograms which fit into this category are as follows:

Analog Data Channel Scanning and Input, or Analog Time Series Sampling.

Matrix Manipulations.

Mapping Functions.

Coordinate Conversions.

Output of Memory Map to Large-Scale Lamp Display.

Statistical Functions, Such as Determining Average, Standard Deviation, and Trends of Large Blocks of Data.

Continuous Data String Manipulations and Code Conversions.

#### • General Purpose Computer with Special Microprogram.

Occasionally there is a requirement for high processing rate (requiring dedicated uninterrupted microprogramming) combined with software flexibility. This combination may be achieved by placing a general purpose instruction set, and a special microprogram instruction set in the same computer. The general purpose or software instruction set is used for relatively slow functions, such as system initialization, monitoring console parameters, updating displays, determination of system states, implementing of relatively slow but complex system control functions, and message preparation.

The microprogram routine is used for high-speed and/or complex data input/output, computation, and control functions. The general procedure for this type computer system is to perform all software functions necessary to set up the microprogram for some segment of its entire job, and then turn complete program control over to the special microprogram until the segment is complete. At this time the special microprogram returns control to the software program. A typical application for this approach is machine tool control. The machine control function involves position sampling, polynomial curve fitting, system control computations, control outputs, timing, status monitoring, and other functions depending on the machine function complexity. Use of microprogramming provides for large increases in processing rate which are necessary to maintain precise control, with complex curves, at specified machine rates.

The software sets up the curves and process rates for a machine processing segment. These curves and rates are interpolated by the microprogram.

Other examples besides machine tool control are as follows:

Sampling a large block of high speed data which occurs in a burst.

Spectrum analysis or filtering with frequency parameters set up by software program.

Contour plotter controller.

#### **Special Purpose Computers**

### Special Instruction Set

For many applications a standard software instruction set, such as the MICRO 820 may be more sophisticated than needed. Such features as multiple addressing modes, variable word length, concurrent I/O, etc.,

may not be needed. In this case it is possible and desirable to create a special instruction set which will increase throughput rates, make better use of core memory, and provide an instruction set tailored to a specific need. The general organization for this firmware is the same as for the MICRO 820 firmware. However, functions may be deleted or modified, such as testing for interrupts, operand addressing, etc.

Typical applications for a special purpose software instruction set are as follows:

Compiler or Interpreter.
Special Communications Processor.
Automatic Tester.
Sequence Controller.
Business Processor.
Batch Terminal.
Inventory System.
Data collection/reduction system.

#### Direct Application Microprogram.

In this case, the application program is completely written at the firmware level. This type of program is suitable for dedicated applications, where the processing is relatively simple, but very high processing rates are required, a permanent program is desired, or simplified interface hardware is used, which requires microprogramming for the interface control and data transfer sequences.

Direct application microprograms may occur in one of many different general structures. Three of these which will be described are as follows:

Direct Sequence of Instructions and/or Subroutines.

Interlaced Subroutines with Processing Status Flags and Partial Processing During Each Entry to a Routine.

Branching to Subroutines Dependent on System States.

Each of these will be discussed briefly in the following paragraphs.

In many applications a combination of any two or all three of these methods may be used.

## Direct Sequence of Instructions and/or Subroutines.

This approach is the simplest, and potentially the fastest, if it fits the application. The flow diagram for this approach is shown in Figure 5.

The sequence of instruction execution is always the same. The loop may be free running for very simple applications, or it may be initialized by a real time clock where time precision is required.

A typical example of this organization is a dedicated communication line processor where the computer samples and updates a large number of full duplex, serial, asynchronous data lines. The firmware does sampling, character assembly and disassembly, and loads a buffer when a character is assembled. The data is then transferred to another device. A program such as this must be able to handle maximum line load conditions without loss of data. Some of the functions, such as loading the buffer could be spread out over a full character time to smooth out the work load, but then the



Figure 5. Subroutines or Instructions

program would become more complex, and would become category 2. Statistical averaging shows that the possibility of all lines being active, and in both bit and character sync, is extremely remote. A system like this could handle a line rate times line quantity product which has a theoretical peak instantaneous load of at least 130% of the processing time available and not lose nearly as much data due to processing time limitations as due to random line errors, because the probability of an instantaneous load approaching even 100% is very remote.

Other examples of the direct sequence approach are as follows:

Low Speed Sequence Controller.

Dedicated Synchronous Data Line Concentrator.

Dedicated Device Controller.

High-Speed Status Monitor.

On-Line Performance Monitor.

Auxiliary High-Speed Processor.

# Interlaced Microprogram Subroutines with Processing Status Flags and Partial Processing during each entry to a Routine.

Many direct application microprograms involve a number of slow-speed peripheral devices which could be serviced by the microprogram on a parttime basis, or handle data formatted to cause load peaking. Each time a device, or data value is looked at by the microprogram some different phase of the process may occur, or many times no processing is required at all. The phase may depend on the previous phase, or on the time interval, or a status flag. The microprogram for this class of organization has an execution, or main loop routine which goes from one routine to the next, in sequence and tests status flags to see if the subroutine is to be entered and what processing is required. The general flow is in Figure 6 and the expansion of one functional step is in Figure 7.

In Figure 6 each circle represents a subroutine status, retrieval, test, entry, update and storage function. The boxes represent the routines which are entered from the main loop.



Figure 6. General Flow for Interlaced Subroutines

As can be seen from Figure 7, processing time must be expended to fetch, test, and store flags, pointer, and data, and this reduces the overall processing capacity. However, this approach allows time spreading of the work load which in most cases makes up for the loss in average processing capacity by a large increase in peak load capacity. The two improvements to interlacing are increased peak load capacity and increased overall throughput capacity.

For example, to process a string of serial characters, load peaking comes when a character has been assembled, and when a block has been assembled. In each case there is a time gap until the next character is assembled. Therefore, the work load can be spread out over a number of bit sample times. It can be partitioned according to line number to simplify subroutine organization. When a message block has been assembled, there is even more time until the next block is assembled, so that the time for character checking, buffer moving, etc., can sometimes be spread out over an entire message block. Another requirement might be a code conversion on an assembled character. This could be broken down into subroutines with only a portion being executed at each time interval.



Figure 7. Expansion of One Functional Element of Interlaced Routine Flow Chart

A typical situation which must be handled by interlacing to achieve high throughput is as follows:

In Figure 8 is a block diagram of a microprogrammed peripheral controller.



Figure 8. Peripheral Controller Block Diagram

The three devices must run concurrently to achieve maximum throughput. Each of the devices has operations which can be broken up into sub-operations as shown in Figure 9.



Figure 9. Simplified Processing Profiles

Device B could start as soon as device A has completed some of the suboperations. Therefore the sub-operations are interlaced. If the devices are asynchronous, and the correspondence between sub-operations is not on a one-to-one basis, the subroutine status tests may at times indicate no processing for one cycle of the microprogram.

Typical applications for interlaced subroutines are as follows:

Batch Processing Terminals.
On-Line Inventory and Audit Systems.
Process Controllers.
General Purpose Communications Terminals.
Monitoring Systems.

#### Subroutine Branching According to System States.

In some programs branching into subroutines may be a function of the state of a peripheral device or time, or the settings on a control panel. In many of these cases it is not necessary to fetch the status, data or flags of each subroutine in sequence to see if it is to be processed.

For example in a particular machine control application, the processing functions depend on machine temperature, RPM, etc.

For many of these parameters, a truth table may be prepared, which indicates the next program state as a function of the previous and present system states. Then the executive routine tests the states, and determines which subroutines to execute next. Typical examples where this method of microprogramming applies are as follows:

Power Plant Control.
Petroleum System Control.
Chemical Processing Plant.
Interactive Systems.
Numerical Machine Tool Control.
Medical and Laboratory Instrumentation Control.

#### **Emulator Computer**

In the truest sense all applications of the microprogrammed computer can be considered emulation. However, as defined here, the emulator computer is the microprogrammed computer with its firmware allowing functional duplication of another computer. Direct emulation of a preexisting general purpose or special purpose computer is practical only if an advantage results. Usually a cost advantage is realized if the preexisting computer is several yers old. In many cases a speed advantage will result.

Many parameters need be considered to determine feasibility and efficiency of a microprogrammed computer emulating any specific general purpose or special purpose computer. Essentially these parameters are:

Complexity and Number of Logical Elements. Word Size and Number of Hardware Registers. Maximum Main Memory (Core) Size and Word Length. Execution Time Required Per Operation. Input/Output Requirements.

Detailed knowledge of both the preexisting computer and the microprogrammed computer is needed to properly evaluate the feasibility and fit of emulation.

#### Language Processors

The instruction set configuration of a special purpose computer which is to be programmed at the assembler language level is usually a "hostile" environment to the implementation of compiler level languages. The microprogrammed processor permits the configuration of a minicomputer architecture which is efficient in a compiler language environment. In essence, the utilization of an assembler may be minimized and the compiler statements are in effect interpreted more directly.

For purpose of illustration the implementation of a BASIC compiler in the MICRO 820 computer will be discussed. The MICRO 820 has a general purpose instruction repertoire with conventional assembler and utility software. A single-user BASIC has been developed for the MICRO 820 computer. This BASIC compiler is written in the MICRO 820 assembler language. The early version of the BASIC was installed in the MICRO 820, occupying approximately 7,500 bytes of core memory. A subsequent version of the MICRO 820 architecture is being augmented with special firmware routines such as floating point and other firmware routines. By doubling the micro memory from 768 words to 1,536 words of microcommands, the storage requirement of the compiler in core memory is reduced approximately 66 percent, or from 7,500 bytes to 2,500 bytes. As a result, greater working storage is available for the user and the compile time for the processor is sharply decreased.

This improvement in processor efficiency becomes more significant as the system is extended to perform time share BASIC. An important capability in the implementation of time share BASIC is an operating system which permits the computer to look like a single machine to multiple users. Microdata's time-sharing operating system (MICROshare) initially resides in approximately 4,096 bytes of core memory. Through microprogramming the performance of MICROshare can be sharply increased by con-

verting various features of MICROshare from software (1  $\mu$ sec per 8-bit instruction) into firmware (200 ns per 16-bit instruction). When a time-sharing system is under control of a high-performance operating system, it provides for the efficient transfer and execution of programs and files in mass storage (disc memory). System response time is sharply increased; core usage is significantly minimized.

The MICRO 1600 is designed to accommodate all the functions of the MICRO 800 product line. This includes direct function processors, special purpose computers which may or may not require architectural augmentation and compiler language processors. The MICRO 1600 provides a new dimension in the minicomputer field as a compiler language processor. Large arrays of micromemories can be conveniently implemented. The control memory in the MICRO 1600 can be addressed up to 16K X 16. It permits the effective implementation of higher level languages such as BASIC, COBOL, FORTRAN, SNOBOL, ATLAS or equivalent.

#### APPLICATION EXAMPLES

#### **Automatic Test System**

MICRO 811 computers are used to control all functions contained in automatic facilities for routine testing and detailed trouble-shooting of printed circuit boards (Figure 10).

The MICRO 811, intended primarily for testing boards used in the MICRO 800 computer, generates stimulus functions and measures corresponding responses of any circuit boards which are digital in nature. Memory boards which are primarily analog are handled on a special tester.

Components of the automatic test system are the MICRO 811 computer with 8K memory, instruction repertoire and input/output line driver and receiver. The card test unit includes stimulus, response and control boards, power supply, 480-pin patch board receiver, 10 test characters and interface cable.

Software includes a Microdata board test control program, board test tape generator, board test tape, control board and data board. Other options are available for special-purpose uses.



Figure 10. Automatic Test System

# Floating Point Processor (Special Purpose)

An ideal use of the MICRO 800 computer is as a floating point processor, since the machine is an extremely high performance processor with the facility for creating specialized instruction sets at the micro step level.

The machine can be mechanized by microprogramming, thus achieving floating point operations at high processing and throughput rates.

As a floating point processor, the MICRO 800 operates on variable word length floating point data. These word lengths may be specified — and changed at any time — to be 8-128-bit fraction plus 8 bits for sign and exponent. Floating point operations use four operating accumulator registers, each 136 bits long, which can be maintained either in core memory or in a special high-speed scratchpad memory.

Data is transferred between accumulator registers and file registers at a high rate of speed by using the microprogram. Maintaining the accumulators in core memory results in low hardware cost, but processing speed is somewhat slower than if the slightly more costly high-speed scratchpad memory is used.

The floating point processor can be integrated into a system in a variety of configurations, each of which has a slightly different equipment requirement, a different mode of operation, requires a different microprogram and yields a different throughput rate.

These configurations are: a peripheral processor to an existing computer; a separate, complete, self-contained floating point computer; a dual processor, sharing memory with a standard processor or computer, or a combined floating point processor and general purpose integer processor such as the MICRO 810.

# Fast Fourier Transform Processor (Special Purpose)

MICRO 800 computers are being used to perform spectral analyses of electrical signals using the computational technique known as fast Fourier transform.

Using specially designed fast Fourier transform read-only memories, the MICRO 800 and other components of the system sample and digitize input signals at uniformly spaced time intervals, performs the spectral analysis and processes the results to construct outputs of a specified form.

The output is displayed on one of three devices — an oscilloscope, slow X-Y plotter or fast X-Y plotter. The displays are driven by two 8-bit digital-to-analog converters in a number of modes, including small-interval stairstep, recurrent and single-cycle.

Several functions are displayed, including input signal frame, power spectrum, log power spectrum, amplitude spectrum and phase spectrum.

The system features a special resolution of one part in 200 over the signal input bandwidth and an amplitude error of less than 10%.

The MICRO 800 computers used in the system are configured with a 4096-word core memory, real time clock, power fail protect, I/O expander with 32 inputs and 32 outputs, and ADC-DAC unit with power supply.

# **Multilane Parking Facility Computer**

Multilane parking facilities associated with large modern buildings are relatively complex and are now being automated with various technologies.

The microprogrammed computer provides a significant reduction in the amount of interface hardware, and provides for the permanence of fixed hardwired control systems. Microprogramming provides this capability in all functions:

Fee Calculation.
Customer I.D. Card Validation.
Audit Calculations and Printouts.
Automobile Counts by Lane.
Lane and Area Count Totalizations.
Violation Detections.
Fee Display Update.
Real Time Clock.
Input Customer I.D. Data.

To keep the interfaces simple, all data including treadle pulses, I.D. card information, local data entry and loop detector pulses enter the computer in bit serial form. Display data is on a common bus, with select lines to control distribution.

All data assembly, accumulation, evaluation, storage, retrieval, and control functions are done within the processor, eliminating the requirement for special external hardware to do counting, data assembly, detection logic, and arithmetic functions.

In Figure 1 is a general block diagram showing the types of data going in and out of the processor.

The ticket machines, treadles, loops, and fee displays are in remote locations from the computer and the printer, keyboard, etc., are nearby. The data from the ticket machines consists of contact closures detecting the presence of a ticket, or indicating output, and taking of a ticket. The ticket machine reader inputs serial data which is organized similar to a serial teletype message. This information consists of entry and exit time, or customer I.D.

In the lanes are loop detectors and treadles. Loop detectors input contact closures when they are crossed. The treadle detectors input a series of closures to indicate direction of travel.

For generation of time of day clock, external time of day pulses are used instead of the internal computer clock to maintain time synchronism with the local power company.

Fee display is output in digit serial BCD form accompanied by display select codes, to minimize the number of wires to the display units.

For this example, which represents a medium size parking facility, the local keyboard, printer, and punch is a teletype.

All of the items shown are mounted in the basic computer cabinet.

A system of this type will handle 10-20 lanes with typical numbers of devices such as 25 treadles, 50 loops, and 10 ticket machines.

In a program like this the core memory is used to store data tables, flags, input and output maps, partially processed data, messages, clock, fee totals, lane totals, and area totals. No program is stored in core because the entire program is in firmware.

# **Data Communications Application, Special Purpose Concentrator**

The MICRO 800 computer with a dedicated microprogram used as a concentrator connects a large number of local data terminals to a small group of dedicated trunk line modems on a time share basis. All data messages handled have fixed formats.

The data concentrator is designed to function as a complete data and control interface, performing the following functions:

Data Source Scanning and Queueing. Modem Poll Monitor and Response.



Figure 11. Concentrator Block Diagram

Data Routing Control.
Control Character Examining and Processing.
Header Identification and Stripping.
Hand Shaking With Trunk Modems.
Data Transfer.
Supervisory Data Processing.
Canned Status Message Generation.
Addition of Header Information.
Parity and Block Character Check.
Character Bit Stripping and Adding.

All of these operations are performed with a maximum throughput delay of 3 characters.

The interfaces to the data terminals and trunk modems is in bit serial form, thus simplifying the interface hardware.

The concentrator operates on the 2400 baud synchronous data with the trunk modems and simultaneously provides data clocks to the terminals.

A block diagram of the concentrator is shown in Figure 11. There are two interface types, the trunk modem interface and the data terminal interface. The scratchpad memory is used to store pointers, transfer instructions, flags, request queues, and as a data buffer. All programming is in the read only memory.

Within the MICRO 800, the arithmetic/logic unit is used for character recognition, character shifting, conditional branching, parity and block character checking, bit stripping, I-D to address conversion, queueing preparation and evaluation, code conversion, and other miscellaneous character processing functions.

The MICRO 800 file registers are used for storage of data immediately after it is read in from one of the modules or before reading it out; for storage of status, and control words, for storage of indices, for storage of outputs from the arithmetic unit, and as operational registers for the arithmetic, logic and control functions performed by the MICRO 800.

The firmware instructions are organized in sequences similar to core memory programs with the capability to execute nested subroutines, conditional branching, and various arithmetic control and logic functions necessary to efficiently perform identical functions on multiple data paths with asynchronous timing between paths.

The real time clock option is used to generate an internal timing interrupt at approximately 2500 cps. which controls all bit and character processing cycles within the concentrator. The 2500 cps. rate ensures that no data bit changes at 2400 cps. will be missed by the system.

# **Numerical Control of Vertical Machining Center**

A MICRO 800 computer is being used as the complete numerical control system for a vertical machining center utilizing some innovative machine tool programming techniques.

Consisting of a vertical mill, an automatic tool changer and a digital control system with its associated panels, the mill is completely hydraulic with options for high accuracy laser positioning feedback.

The MICRO 800 positions the table, saddle and spindle (X, Y and Z axis) and controls the direction and speed of rotation of the spindle. The microprogramming feature of the MICRO 800 is used to perform the feedback control of the position and velocity of the axis.

Both linear and circular contouring are provided with a positioning accuracy of 200 micro-inches and velocity of the tool with respect to the workpiece of 0.01 to 200 inches per minute.

The MICRO 800 also controls an automatic tool changer containing 20 tools. All motions are initiated and confirmed by the computer to achieve the necessary sequences.

Machining operations are specified through choice of a manual or tape preparation panel.

The manual panel permits moving the mill in a very simple manner and also provides for entry of tool dimensions used for offset and length compensation.

The tape preparation panel permits programming the machine operations in a sort of "graphical APT" manner. Canned sequences such as drill, bore, tap, mill, etc., are specified along with all pertinent data without regard to tool dimensions. Workpiece dimensions are specified in absolute, relative or trigonometric form. Contours also are specified.

When the computer has validated the requested operation, it assumes control of the machining and can initiate, abort, terminate, test, accept or reject through the tape panel. If accepted by the operator, the operation is preserved on magnetic tape for later use.

After completion of the first workpiece, additional copies are made by merely replaying the cassette magnetic tape with the MICRO 800 control system in the automatic mode. The cassette can be removed from the controller for future use.

# Vibration Analyzer (Special Purpose)

The MICRO 800 computer is being used as the heart of a vibration analysis system operating with six channels of frequency shifters and filters, a high-speed multiplexer and analog-to-digital converter, a specially designed control panel and 13 other digital-to-analog converters.

Input to the system is from vibration sensors or other noise sources for which power spectral density plots are desired. Frequency range for analysis is 4 Hz to 6 KHz. Output data, both linear and decibel, is plotted on up to 12 X-Y plotters, and analysis of all six channels is done concurrently.

Using customized firmware, the MICRO 800 computer operates the panel, controls frequency shifting through a voltage controlled oscillator, performs data averaging and maintains system timing.

In addition, the computer calculates both linear and logarithmic (decibels) power spectra, controls the X-Y recorders and can measure the period of an external signal and convert it to frequency (4 Hz to 8 KHz) with an accuracy of 0.1% of indicated frequency over the entire range.

# Interface for Campus Central Processor, Satellite Computers

MICRO 800 computers are in use at a major university as the key ingredients of remote terminals interfacing satellite computers at various campus locations to a large-scale central computer (Figure 12).

These "smart terminals" — versatile displays ranging from elegant to not so elegant — provide straightforward interfacing to other computers which handle specific kinds of communications.

Use of the MICRO 800 in this application has eliminated the need for a large amount of specialized hardware at remote sites, and provides an abundance of flexible programming capability through the use of microprogrammed firmware.

With its 220 nanosecond microcommand time and the ability to put input/output and interface functions into firmware provides a far greater throughput rate than is possible with core memory.

A safety factor is provided, too. Storage is fixed in the read-only control memory, insuring that no one, no matter how inexperienced can modify or destroy programs. Storage can be modified according to need by simply exchanging boards.

The MICRO 800 also gives the university a "do-it-yourself" computer capability. Computer center engineers can economically tailor the performance characteristics of the computer in firmware to suit the specific needs of each terminal location.

Eventually, the university plans to interface all existing campus computers to its large-scale central processor.

The MICRO 800 represents a general solution to the university's vast number of applications because of its flexibility. Among these applications are interactive display systems and automated systems, which, without the MICRO 800, would have required two completely different sets of hardware.



Figure 12. Campus Interface System



# PART III MICRO 800 USERS MANUAL



#### **CHAPTER 1**

# SYSTEM DESIGN FEATURES

MICRO 800 is a byte-oriented microprogrammed computer designed for dedicated applications. The functional, mechanical and electrical design of the computer provides a set of functional elements which can be tailored to specific application requirements. The MICRO 800 is a basic set of hardware which, with modification, can be expanded to a series of machines.

The design concepts embodied in the MICRO 800 provide a unique combination of features unavailable in other computer systems. These include:

# Microprogramming

The MICRO 800 incorporates a set of commands which exert powerful micro-control over the machine's data manipulation paths and control. Command sequences which form microprograms are stored in a read-only storage. The MICRO 800 can be programmed to emulate instructions of general or special purpose computers or to perform specific applications.

#### Speed

The machine features a 1.1 microsecond core memory cycle time and a 220 nanosecond command execution time. This speed permits rapid emulation of macro instructions and can be used to minimize interface hardware by applying the speed of the machine to interface functions.

## Modularity

The modular electrical and mechanical design has all the flexibility needed to apply the MICRO 800 to a wide range of applications. The modular design of the core memory read-only storage, processor options, and input/output elements permits expansion of the system as required. The compact 8%-inch-high enclosure has a number of spare circuit board slots and ample power for system and peripheral interfaces even when the processor is fully expanded.

#### Low Cost

The MICRO 800 uses TTL monolithic integrated circuits, including a large number of the medium scale integration type for savings in parts and assembly time. The use of a read-only memory for control further reduces the number of circuits that might otherwise be required to provide similar functional capability. Packaging and powering of the MICRO 800 is designed for significant cost savings.

#### Software

Programs for the MICRO 800 include an assembler written in FORTRAN for use on large-scale computers, utility programs for generating the read-only memory maps, processor and memory diagnostics, and a simulator program for checking our microprograms. See Chapter 6, "Programming Systems."

#### **GENERAL CHARACTERISTICS**

The advanced features and operating characteristics include:

- Memory addressing to 32K.
- 1024, 4096 or 8192 byte memory modules.
- 32,768 bytes of memory in basic 8%-inch-high cabinet.
- 1.1 microsecond memory speed (full cycle).
- 8 or 9 bit memory bytes for efficient character handling.
- Direct memory access (DMA) option.
- 16 general-purpose eight-bit file registers.
- Up to 1024 words of read only storage in 256 word modules with optional expansion capability to 2048 words.
- 220 nanosecond microcommand execution time.
- 15 basic commands.
- Three versions of control consoles.
- TTL integrated circuitry.
- Operating temperature range 0°C to 50°C.
- Dimensions: 8% inches high, 19 inches wide, 23 inches deep.
- Power: 115/230 vac, 50-60 cycle.
- Four versions of read only memory.

#### SYSTEM ORGANIZATION

The MICRO 800 is a bus organized machine built around a file of 16 programmable registers and employing microprogrammed control. The basic elements of the machine are shown in the block diagram of Figure 13.

The machine executes 15 basic commands with many variations. All commands are 16 bits in length and are in one of three formats. MICRO 800 programs, which are known as microprograms, are placed in a read-only memory and thereafter become a part of the machine's hardware. The program can be changed by replacing the printed circuit boards containing the read-only memory. The commands read out of the read-only memory control all aspects of the operation of the basic machine and are executed in a single machine clock cycle.

The eight-bit arithmetic/logic unit performs all manipulation of data, including: addition, subtraction, logical AND, logical OR, logical exclusive OR, and one-bit left and right shifts. The output of the logic network is the A-bus which is the input to the files and other machine registers. All byte data movement is performed over this bus. The output of the file is one of the inputs to the arithmetic/logic unit; the other is the B bus. Inputs to this bus are determined by the command, its options, and the I/O mode. Bus inputs are the true output of the T register, the complement output of the T register, the input bus and the eight-bit literal contained in some commands.

The memory data and address busses communicate between the core memory modules, the processor and the DMA. Either the processor or the DMA may operate with the memory, with the DMA having top priority.



Figure 13. MICRO 800 Block Diagram

The registers, file, arithmetic/logic unit and bussing are organized onto two identical "data" printed circuit boards—a four-bit slice of the machine on each board. All command decoding, control, clock generation and memory timing are located on a single "control" board. Each 256 words of diode read-only storage requires a single board and the core memory a pair of boards. The fusable diode, and bipolar ROM's contain up to 2048 instructions on one board.

#### REGISTERS AND FILE

There are eight registers and 16 file registers, each of which has a specific use in the processor, while the file is used for general storage and flags.

#### T Register

The eight-bit T register serves as the operand register for most of the operate class commands, and as a buffer register for output and memory operations. Both the true and complement output of the T register can be gated to the B-bus as an operand. When both the contents of T and its complement are selected as operands, the effective operand is all 1-bits; if neither is selected the operand is all 0-bits. The T register can be loaded

from core memory on a read instruction, directly from read-only memory using a load T instruction or from a file register by designating T as the destination register of an operate class command. All programmed outputs including both control and data bytes go out via the T register.

# M Register

The eight-bit M register contains the seven high order bits of the processor memory address. This register is gated onto the memory address bus at all times except when a DMA operation is in process. The M register can be loaded directly from ROM using a load M command, or can be loaded by designating M as the destination register of an operate class command. The M register is cleared on a load N command.

# N Register

The eight-bit N register contains the eight low order bits of the processor memory address. This register is gated onto the memory address bus at all times except when a DMA memory operation is in process. The N register can be loaded directly from ROM using a load N command, or by being designated as the destination register of an operate class command.

#### L Register

The 10-bit L register is the machine's program counter and contains the read-only storage address of the next command to be executed, unless altered by a jump command. The eight low order bits of the L register are a counter which is incremented by one at each clock time when the processor is running unless there is a command execution delay imposed. L is loaded by a load L command, or as a destination register of an operate class command.

# **U** Register

The eight-bit U register is used to modify the output of the read-only storage. For commands with 0's in the four high order bits of 1's in bit 15 and the three low order bits, the contents of the U register is inclusive-ORed with the eight high order bits of the read-only memory output as it is gated into the R register. This allows for dynamic modification and changing of operation codes and file register designators. U is loaded by a load U command or as a destination register of an operate class command.

# R Register

The 16-bit register holds the present command being executed. Its output is decoded and controls the operation of the processor at each clock time.

# LINK Register

The one-bit LINK register holds the adder's high order carry from add, subtract, and compare commands and the shifted off end bit from the shift command.

#### I/O Control Register

This three-bit register generates the control signals for the I/O bus. Seven separate control signals can be developed by decoding of the register outputs. It is loaded and cleared by a control command, placing the timing of

I/O control signals under command control. There are three output modes and four input modes. The high order bit of the register is the input flag. When this bit is a 1-bit the input bus is substituted for the T register when it is selected and the input bus is the source of data when executing an external I/O control command.

# File Registers

The file consists of 16 eight-bit operational registers. All commands except the load register with OP code (1) specify a file register to be operated on or to provide an operand or both. All file registers are functionally identical except for file register 0 which contains eight flags, and cannot be used for general storage. The flags of file register 0 are given in Table 2.

Table 2. File Register 0 Flags

| BIT                        | FLAG                                                                                                                                                                                                                              |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>1<br>2<br>3<br>4<br>5 | <ul> <li>Overflow Result Condition</li> <li>Negative Result Condition</li> <li>Zero Result Condition</li> <li>Concurrent I/O Request Line</li> <li>Internal Interrupt</li> <li>I/O Reply Line</li> <li>Serial Teletype</li> </ul> |
| 7                          | <ul> <li>External Interrupt Line</li> </ul>                                                                                                                                                                                       |

#### **CORE MEMORY**

The magnetic core memory is organized into pluggable modules of 4096 or 8192 bytes. The memory is addressed at the byte level and each byte contains 8 or 9 bits. The ninth bit is devoted to the memory parity bit option. Memory may be expanded up to four modules (32,768 bytes) within the basic 8%-inch cabinet.

The memory is operated in read/write and full/half cycle operations. The full-cycle memory timing is five 220 ns clock cycles (1.1 microseconds); the half-cycle timing in the system is three clock cycles (660 ns). For a read operation, the accessed data is placed in the T register two clock cycles after the start of the memory operation. Full cycle regeneration of the data in the memory does not require the use of the T register and T may be modified by the microprogram before completion of the restore part of the cycle.

The four memory modules plug into the memory address and data busses which run vertically on the back-plane. A spare board slot wired for access options which can include a DMA I/O channel and a special DMA peripheral controller.

#### CONTROL MEMORY

The read-only memory provides the storage for commands and constants of the microprogram. Its output is gated into the R register where it controls the operation of the machine at the next clock time.

The read-only memory is organized into modules of 256 words contained on a single printed circuit board. Each of the four possible read-only memory boards receives an address from the L register via the read only memory address bus, and the selected board gates its addressed contents onto the read-only memory data bus where it is entered into the R register.

The memory is constructed of diodes with a diode being placed at the proper coordinates for 1-bits in the commands. The commands are designed to use 0-bits as the normal case to reduce the number of diodes on the board; on the average, about one-third of the total bits contain 1's.

The read-only memory is always accessed for the next command while the current command is being executed. This lookahead achieves faster command execution time. When the sequence of command execution is altered by a jump or skip, an additional cycle must be taken to perform an access before the next command is executed. When the machine is halted, the L register contains the address of the first command to be executed when operation is started.

#### ARITHMETIC FUNCTIONS

The MICRO 800 uses a 2's complement binary number system. The registers and memory cells are 8 bits in length. For convenience of programming, entering data, printing out, and preparing punched paper tape, the 8 bits are organized into two hexadecimal digits. The hexadecimal digits, with their decimal and binary equivalents, are as follows:

| Decimal                                              | Hexadecimal                                              | Binary                                                                               |
|------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------|
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10 | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>A<br>B | 0000<br>0001<br>0010<br>0011<br>0100<br>0101<br>0110<br>0111<br>1000<br>1001<br>1010 |
| 12                                                   | C B                                                      | 1100                                                                                 |
| 1                                                    |                                                          |                                                                                      |
| 13                                                   | Ď                                                        | 1101                                                                                 |
| 14                                                   | E                                                        | 1110                                                                                 |
| 15                                                   | F                                                        | 1111                                                                                 |

Throughout this document hexadecimal numbers are identified with single quotes:

'33' 'AA'

For additional functions, the two numbers are added directly with the carry out of the most significant bit going to LINK, and overflow setting the overflow bit, if designated in the command.

For subtraction, one number is converted to a 2's complement and added to the other.

For single byte operations, with a 2's complement number system, the range of numbers is as follows:

| Binary                                       | Hexadecimal          | Decimal            |          |
|----------------------------------------------|----------------------|--------------------|----------|
| 01111111<br>00000001<br>00000000             | '7F'<br>'01'<br>'00' | +127<br>+ 1<br>0   | POSITIVE |
| 11111111<br>11111110<br>10000000<br>Sign bit | 'FF'<br>"FE"<br>'80' | - 1<br>- 2<br>-128 | NEGATIVE |

Examples of Arithmetic Functions:

Addition: 
$$A + B = C$$

| Example<br>#1 | Decimal                                                | Hexadecimal                                               | Binary                                                          |
|---------------|--------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------|
| #1            | 3<br><u>+5</u><br>8                                    | '03' '05' '008' Link = 0  Verflow = 0  Link               | 00000011<br>00000101<br>000001000<br>Link                       |
| Example<br>#2 | Decimal                                                | Hexadecimal                                               | Binary                                                          |
| π2            | 65<br>+82<br>147<br>A<br>Beyond norma<br>range of +127 | '41'<br>+'52'<br>'093' Link = 0<br>↑ Overflow = 1<br>Link | 01000001<br>01010010<br>010010011<br>A Sign becomes<br>negative |

On example #2 the overflow occurred because the range of positive numbers was exceeded. LINK was 0 because the carryout of the add was 0 even though overflow occurred.

| Example<br>#3 | Decimal                                                                              | Hexadecimal 2's Complement                              | Binary<br>(2's Complement)                                                     |
|---------------|--------------------------------------------------------------------------------------|---------------------------------------------------------|--------------------------------------------------------------------------------|
|               | - 93 +(-105) -198  Overflow occurs because -198 exceeds the maximum negative number. | 'A3'<br>+'97'<br>'13A'<br>↑<br>Link = 1<br>Overflow = 1 | 10100011 +10010111 100111010 Link Effective 8 bit result is a positive number. |

| Example<br>#4 | Decimal                                                             | Hexadecimal<br>2's Complement                           | Binary<br>(2's Complement)                     |
|---------------|---------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------|
|               | 45<br>+(-62)<br>-17<br>↑<br>No overflow,<br>within number<br>range. | '2D'<br>+'C2'<br>'OEF' Link = 0<br>↑ Overflow =<br>Link | 00101101<br>11000010<br>011101111<br>0 Link    |
| Example #5    | Decimal                                                             | Hexadecimal<br>2's Complement                           | Binary<br>(2's Complement)                     |
|               | 77 +(-27) +50  No overflow within number range.                     | '4D'<br>+'E5'<br>+'132'<br>Link = 1                     | 01001101<br>+11100101<br>100110010<br>Link = 1 |
|               | Link = 1<br>No overflow                                             |                                                         |                                                |

In general, arithmetic overflow occurs whenever the number range (+127 to -128) of the MICRO 800 is exceeded on an arithmetic operation. As can be seen in the examples, the link bit may be set even though an overflow did not occur. This is the result of using a 2's complement number system.

To mechanize overflow detection in the MICRO 800 use is made of the fact that when there is an overflow, the carry into the most significant bit does not equal the carry out of the most significant bit. This can be shown as follows:

# Overflow Examples:



| Decimal                                                      | Hexadecimal                                 | Binary                                                                                                                |
|--------------------------------------------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| 126 + 1 127 No overflow because positive range not exceeded. | '7E'<br><u>'01'</u><br>'07F'                | 01111110<br>00000001<br>001111111<br>0 carry in<br>0 carry out<br>Carry into bit 7 = carry out                        |
| exceeded,                                                    |                                             | of bit 7.<br>Therefore no overflow.                                                                                   |
| Decimal                                                      | Hexadecimal                                 | Binary                                                                                                                |
| -93<br>+(-105)<br>-198<br>Overflow                           | 'A3'<br>+'97'<br>'13A'<br>↓<br>Link         | 10100011 +10010111 100111010  Carry into bit 7 = 0 Carry out of bit 7 = 1 Therefore overflow occurred.                |
| Decimal                                                      | Hexadecimal                                 | Binary                                                                                                                |
| 77<br><u>-27</u><br>+50<br>No overflow                       | '4D'<br><u>+'E5'</u><br>+'132'<br>↓<br>Link | 01001101<br>11100101<br>100110010<br>AA<br>  Carry into bit 7 = 1<br>Carry out of bit 7 = 1<br>Therefore no overflow. |
| Decimal                                                      | Hexadecimal                                 | Binary                                                                                                                |
| 93<br><u>+105</u><br>198<br>Overflow                         | '5D'<br><u>+ 69</u><br>0C6                  | 01010010<br>01101001<br>011000110<br>01                                                                               |
|                                                              |                                             | Carry in does not = carry out. Therefore overflow occurred.                                                           |
|                                                              |                                             |                                                                                                                       |

For 2's complement, the number is first converted to 1's complement, then 1 is added.

Example - 2's complement of '35'

#### STATUS AND CONDITION FLAGS

#### **Internal Status**

Eight internal status bits are provided to designate a particular internal interrupt condition. When any of the internal status bits are a 1-bit, the internal interrupt flag (bit 4) in file register 0 is also a 1-bit. This flag is tested by the microprogram to detect the presence of the internal interrupt condition. The internal status bits are entered via the A-bus into the selected file register by a control command, at which time the status bits are cleared. The eight internal status bits have the assignments given in Table 3.

Table 3. Internal Status Bits

| ВІТ | INTERNAL STATUS               |
|-----|-------------------------------|
| 0   | Console Interrupt             |
| 1   | DMA Termination               |
| 2   | Real-Time Clock Interrupt     |
| 3   | (Spare)                       |
| 4   | Memory Parity Error Interrupt |
| 5   | (Spare)                       |
| 6   | Console Halt Switch           |
| 7   | Power Fail/Restart Interrupt  |
|     | •                             |

All the internal status bits except the console interrupt and halt are associated with processor options and may be reassigned for special applications.

# Condition Flags

The overflow, negative and zero conditions resulting from an operation involving the arithmetic/logic unit may be stored in file register 0 (see Table 3). The condition flags are updated for command 7 and for commands 8, 9, B-F if bit 4 is a 1-bit. These condition flags can be tested by the microprogram for implementing various conditional operations. Definition of the condition flags is as follows:

**Overflow** — The Overflow condition flag stores the arithmetic overflow condition during an add, subtract or copy command. The overflow condition flag stores the shifted off end bit during a shift command. Arithmetic overflow occurs, when the result exceeds the range of the computer's 8-bit registers.

**Negative** — The Negative condition flag stores the high order bit of the result on the A-bus, since the 2's complement number system uses the most significant bit as the sign bit.

Zero — The zero condition flag stores the zero test condition of the result on the A-bus. When the link control (bit 7) of the operate commands is a 1-bit, the zero condition flag may not be set to indicate a zero result unless it is already set; it may be reset to indicate a non-zero result. This provides

a linked zero test over multiple bytes of a variable byte operation. For a detailed description of linked zero test, refer to the description of the Add command.

#### COMMAND TIMING

Each command is executed in a single clock cycle time, although execution may be delayed because of core memory or read-only memory operations. The system clock rate is 4.55 mHz, and the clock cycle 220 nanoseconds.

# Memory Busy Delays

If the memory is busy (because of processor or DMA operation) at the time a read or write memory command or a command which will modify the M or N registers is to be executed, execution is delayed until the memory operation is completed. These commands are executed on the last clock of the memory half or full cycle. If a DMA request is pending at the time a read or write memory command is to be executed, execution is delayed to give the DMA memory priority.

## **Memory Data Delays**

Operate class commands which select the contents of either the T register or its complement during the first two cycles of a processor memory read operation are executed during the third cycle of the read operation. This allows time for the accessed byte to be placed in the T register.

The memory delays are explained in more detail in the description of the memory command.

# **Read-Only Memory Delays**

An extra cycle is required for command execution because of the lookahead nature of the read-only memory for the following conditions:

- Jump command.
- Test If zero command when a skip occurs.
- Test If not zero command when a skip occurs.
- Compare command when a skip occurs.
- Operate class commands which have the L register designated.

#### **CHAPTER 2**

# MICROCOMMAND REPERTOIRE

This section contains descriptions of all MICRO 800 commands. With each description is a diagram showing the format of the command and its operation code, given in hexadecimal. Above each diagram is the command's mnemonic code and the name of the command. Under each diagram is a description of the command, followed by a list of the registers and indicators that can be affected by the command. The timing of each command is one clock cycle (220 ns) unless the L register is designated as the destination of the result, in which case the command execution time is two cycles.

#### **COMMAND FORMATS**

There are three basic command formats. Each command is 16 bits in length and is contained in a single read-only memory location.

The formats are literal commands, operate commands and execute commands.

#### Literal Commands

The literal class commands have the following format:



In this format the operation code occupies the four high order bits. Bits 11-8 contain either a file register designator (f) or a register or control group designator (r). Bits 7-0 contain an eight-bit literal which is transferred as an operand to the B-bus.

## **Operate Commands**

The operate class commands have the following format:



In this format the operation code occupies the four high order bits. Bits 11-8 contain a file register designator (f) which specifies one of the 16 file registers to be used in command execution. Bits 7-4 contain control option bits (c) which are unique to the specific command. When bit 3 is one, the result of an operate class command is inhibited from being placed in the designated file register. Symbolically, this is specified to the program assembler by appending an \* to the command mnemonic. The register designator (r) in bits 2-0 specifies a processor register destination to receive the result of the operation.

Since there is only one file register selected at a time, the only file register that can receive the result of a particular operate command is the same file register selected for the operand. The register's identifier is added as a second character of the command mnemonic. The register codes (Table 4) are:

Table 4. Register Designators for Operate Commands

| Designator | Mnemonic | Register                                                  |
|------------|----------|-----------------------------------------------------------|
| 0          |          | none                                                      |
| 1          | T        | T Register                                                |
| 2          | M        | M Register                                                |
| 3          | N        | N Register                                                |
| 4          | L        | L Register-addresses: 000-0FF and 200-2FF                 |
| 5          | K .      | L Register-addresses: 100-1FF and 300-3FF                 |
| 6          | U        | U Register                                                |
| 7          | S        | U Register ORed into command (except for Control command) |

#### Execute Command

The execute command causes the contents of the U register to be ORed with the eight high order bits of the command to form an effective command. This operation is also performed when r=7 for the operate class commands. The execute command has zero-bits in the four high order bits. The remainder of the command has the format required for the effective command to be executed.

#### Formats for Execute Commands



If U contains Operate command OP code.



If U contains Literal command OP code.

#### Literal Commands

The literal commands, listed by OP code are as follows:

| OP Code | Command       |
|---------|---------------|
| 1       | Load Register |
| 2       | Load File     |
| 3       | Add to File   |
| 4       | Test Zero     |
| 5       | Test Not Zero |
| 6       | Compare       |

The literal commands are used to load constants into various MICRO 800 registers, to test for bit configurations and data values in file registers, and to load or add constants to file registers. Eight of the 16 bits are used as command, and the other 8 are available as data.

# **Operate Commands**

The operate commands, listed by OP code are as follows:

| OP Code | Command      |
|---------|--------------|
| 7       | Control      |
| 8       | Add          |
| 9       | Subtract     |
| Ą       | Memory       |
| В       | Copy         |
| С       | OR ·         |
| D       | EXCLUSIVE OR |
| E       | AND          |
| F       | SHIFT        |

The operate commands are used to control the flow of data in or out and through the MICRO 800 computer, and to perform the arithmetic and logic functions in the computer.

With this powerful command set it is possible to implement all of the data handling and control functions of a larger computer.

# TERMS AND SYMBOLS USED IN THE COMMAND DESCRIPTIONS

(f<sub>1</sub>) Contents of file 1.

 $(f_1) \rightarrow T$  Contents of file 1 to T register.

.... Indeterminate value or function.
'AA' Hexadecimal number in flow chart.

X'AA' Hexadecimal constant in assembly language statement.

# Affected Register States

For each command certain registers are modified. These are described in examples as affected registers.

∧ LOGICAL AND

∨ LOGICAL OR

→ LOGICAL EXCLUSIVE OR

Effective Address of L register as used in examples. (Because of the lookahead feature of the MICRO 800, the actual L address is one higher than indicated in the examples.)

# MICROCOMMANDS-FORMATS, DESCRIPTIONS, AND EXAMPLES

The formats of the examples for each command have been selected to facilitate explanation of that particular command. Because of the differences in characteristics and utilization of the various commands, and associated data patterns, the example formats are different for each command category.



The contents of the eight-bit literal field are placed in the T register. The condition flags and LINK register are not affected.

This command is used to provide constant data values, bit patterns for comparison tests, masks, and input/output control codes, which are most conveniently used in the T Register.

The T register is also modified by designation as destination register in operate commands.

Example: Load T with hexadecimal value 'AA'

| L     | Machine | Assembly | Flow Chart          |
|-------|---------|----------|---------------------|
|       | Code    | Language | Notation            |
| '024' | '11AA'  | LT X'AA' | 'AA' <del>→</del> T |

Affected Register States:

| Register | Before | After |
|----------|--------|-------|
| . L      | '024'  | '025' |
| T ·      |        | 'AA'  |

· Command Execution Time - 220 nanoseconds.

LM LOAD M

| 12                |   |   |   | - | - | _it | era | ı |   |   |
|-------------------|---|---|---|---|---|-----|-----|---|---|---|
| 15 14 13 12 11 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1 | ᢆ |

The contents of the eight-bit literal field are placed in the M register. The condition flags and LINK register are not affected.

This command is used to set the M register for accessing dedicated core locations. The M register is also modified by designation as destination register in operate commands.

Example: Load M with page address hexadecimal value '55'

| L     | Machine | Assembly | Flow Chart          |
|-------|---------|----------|---------------------|
|       | Code    | Language | Notation            |
| '134' | '1255'  | LM X'55' | '55' <del>→</del> M |

## Affected Register States:

| Register | Before       | After         |
|----------|--------------|---------------|
| L        | <b>'134'</b> | '135 <b>'</b> |
| M        | • • • •      | <b>'</b> 55'  |

Command Execution Time - 220 nanoseconds.

# LN LOAD N



The contents of the eight-bit literal field are placed in the N register and the M register is cleared. The condition flags and LINK register are not affected.

This command is used to set the N register for accessing dedicated core locations. If the location is in page 0 of core ('0000'—'00FF') only this command is required to set both the M and N registers, since M is automatically cleared. If M is not to be page 0, then N must first be set, followed by M.

Example: Load N with address hexadecimal value "F" and set M = '00'

| ·.L          | Machine | Assembly | Flow Chart           |
|--------------|---------|----------|----------------------|
|              | Code    | Language | Notation             |
| <b>'235'</b> | '13FF'  | LN X'FF' | 'FF' → N<br>'00' → M |

# Affected Register States:

| Register | Before       | After         |
|----------|--------------|---------------|
| L<br>M   | '235'<br>——— | '236'<br>'FF' |
| N        | · .          | '00 <b>'</b>  |

Command Execution Time: 220 nanoseconds.

# LU LOAD U

| 16                |   |   |   |   | L | .ite | era | ı |   |   |
|-------------------|---|---|---|---|---|------|-----|---|---|---|
| 15 14 13 12 11 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3   | 2 | 1 | 0 |

This command is used to place specific command codes into the U register, which is used in conjunction with general function EXECUTE class commands. The U register can also be modified by being designated as the destination register in an operate command. The differences in utilization of these two approaches for modifying the U register are described in a later paragraph which discusses U register applications.

Whenever the U register is modified it is necessary to place at least one command between the modifying command and a command which uses the U register as an input. Otherwise an undefined value of U may be used.

Example: Load U with hexadecimal value '84'

| L             | Machine | Assembly | Flow Char          |
|---------------|---------|----------|--------------------|
|               | Code    | Language | Notation           |
| '155 <b>'</b> | '1684'  | LU X'84' | '84' <del></del> Ú |

# Affected Register States:

| Register | Before        | After |
|----------|---------------|-------|
| L        | '155 <b>'</b> | '156' |
| U        |               | '84'  |

#### LZ LOAD ZERO CONTROL

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

When this command is executed, a pulse called CGOX of approximately 200 nanoseconds width is generated. CGOX is available on the I/O and option board connectors of the MICRO 800. During CGOX, the literal value is on the A-bus, which is available to the option board. An 8 bit control latch can be set on the option board by this command and used for any purpose, such as enabling counters, interrupts, or control lines.

On I/O boards, a literal value must be first placed in T, and then strobed out with CGOX. CGOX can be used without the literal to initiate special I/O sequences.

Example: Set bits 1 and 2 of special control latch on option board using Load Zero Control.

| Bit pattern   |                 | 00000110 - '06'      |                        |  |  |
|---------------|-----------------|----------------------|------------------------|--|--|
| L'            | Machine<br>Code | Assembly<br>Language | Flow Chart<br>Notation |  |  |
| '055 <b>'</b> | '1006'          | LZ X'06'             | '06' <del>→</del> Z    |  |  |

# Affected Register States:

| Register | Before       | After |
|----------|--------------|-------|
| L        | <b>'055'</b> | '056  |
| Special  |              | '06'  |

# LS LOAD SEVEN CONTROL



The eight bits of the literal perform control functions as described below.

- 1700 No operation.
- 1701 Enable serial teletype. The serial teletype input is gated into bit 6 of file register 0. The serial TTY value is available all the time.
- 1704 Disable external interrupts: Recognition of external interrupts is inhibited.
- 1708 Enable external interrupts: Recognition of external interrupts is enabled.

Note: Commands 1704 and 1708 are meaningful only when the option board has been installed in the MICRO 800, and a modification has been made to the computer backplane. These commands set and reset an interrupt input enable latch on the option board. Without the option board the external interrupt line is always enabled.

- 1710 Disable real time clock: The real-time clock and interrupt are disabled.
- 1720 Enable real time clock: The real-time clock and interrupt are enabled.

**Note:** These commands are meaningful only when the option board containing the real time clock is installed. When the clock is enabled it is preset to its wired value. Each time the real time clock cycles, it sets internal status bit 2, which remains set until sampled by the microprogram.

- 1740 Spare.
- 1780 Halt: The processor is halted.

When the processor halts, all clocks stop, except for clock 6, and the L register remains at the next value after the halt command. Depressing the run switch will start the program at the next instruction after the halt command.

Command Execution Time - 220 nanoseconds.

Non-conflicting commands can be executed simultaneously. For example, enable external interrupts can be combined with enable real time clock. The bits of the literal parts of the commands are ORed to produce the hexadecimal code.

| Example:               | Machine<br>Code | Literal<br>Bits |
|------------------------|-----------------|-----------------|
| Enable Interrupts      | 1708            | 0000   1000     |
| Enable Real Time Clock | 1720            | 0010 0000       |
| Composite Command      | 1728            | 0010   1000     |

JP JUMP

| 14/15/1C/1D           | Literal         |
|-----------------------|-----------------|
| 15 14 13 12 11 10 9 8 | 7 6 5 4 3 2 1 0 |

The contents of the eight-bit literal are placed in the eight low order bits of the L register; the content of bit 8 is placed in L<sub>8</sub> and the content of bit 11 is placed in L<sub>9</sub>. The location of the next command to be executed is at the address specified by the new contents of the L register. The execution time of the command is two cycles. The jump operation codes for the four 256-word pages in read-only memory are as follows:

14 — Jump to locations 000-0FF (page 0)

15 - Jump to locations 100-1FF (page 1)

1C — Jump to locations 200-2FF (page 2)

1D - Jump to locations 300-3FF (page 3)

In order to fully explain this command, a detailed description of the L register follows:

# L REGISTER ORGANIZATION

| 9 8 | 7 | 0      |
|-----|---|--------|
|     |   | 8 bits |

Bits 0 to 7 act somewhat like a counter in that they are incremented like a counter after each command execution except conditional skips, jumps, or operate commands containing L or K as a destination. If the L count is at XFF, and the next command causes L to be incremented, the L count will go to X00, with no indication of a carry. If a command causes L to skip, L will go from XFF to X01.

To change pages, it is necessary to change bit 8 or 9. Bit 9 can be changed only with a jump (literal to L) command. With the jump command, any part of L can be reached.

Bit 8 can be changed with either a jump command or by designating the L register as the destination register in an operate command.

As shown in Table 4, a destination designator of 4 or 5 affects the L register. The designator 4 causes bit 8 to reset, and 5 causes bit 8 to set. In the assembly language mnemonics, a 4 is labeled L, and a 5 is labeled K.

The various methods of changing L are shown in the following read-only map outline.



Since L is always addressing the next command to be executed, any condition, such as a skip, jump, or L destination results in a clock cycle skip because the "next" command must be discarded for a new "next" command.

# Examples:

|    | L            | Code             | Language  | Notation                                                                                 |
|----|--------------|------------------|-----------|------------------------------------------------------------------------------------------|
| 1) | Jump to page | ge 0 location '3 | 3′        |                                                                                          |
|    | '021'        | '1433'           | JP X'033' | '033'→L<br>Sometimes just shown<br>as a line from one block<br>to another in flow chart. |

2) Jump to page 2 location '46'
 '150' '1C46' JP X'246' '246'→L
 3) Jump to page 3 location '31'
 '230' '1D31' JP X'331' '331'→L

# L Register States:

| Example | Before        | After |
|---------|---------------|-------|
| 1       | '021 <b>'</b> | '033' |
| 2       | '150 <b>'</b> | '246' |
| 3       | <b>'230'</b>  | '331' |

Command Execution Time - 440 nanoseconds.



The contents of the eight-bit literal field are placed in the file register designated by f. File register 0 cannot be loaded by this command. The condition flags and LINK register are not affected.

This command is used for initializing or clearing file registers. It is also used for setting relative and absolute jump addresses into files. It can also be used as part of a table look-up routine. Another application is for setting indirect return addresses into files.

A brief description of a table look-up technique follows:

The table look-up function can be implemented using a combination of load file, jump, and operate class (L destination) commands.

A table of values is stored in the ROM which are accessed by jumping to a selected command using an operate class command with an L destination. The selected command is a load file command. After the load file command there must be a jump command to get back to the program routine.



If, because of a large table, it is necessary to conserve memory locations in the ROM, a number of load file commands could be grouped with each jump command. This will temporarily tie up as many files as load file commands.

Example of load file command:

Load file 3 with '55'

|       | Machine       | Assembly    | Flow (       |      |
|-------|---------------|-------------|--------------|------|
| L.    | Code          | Language    | Nota         | tion |
| '025' | <b>'2355'</b> | LF 3, X'55' | <b>'</b> 55' | f3   |

Affected Register States:

| Register | Before       | After        |
|----------|--------------|--------------|
| L        | <b>'025'</b> | '026'        |
| file 3   |              | <b>'</b> 55' |



The contents of the eight-bit literal field are added to the contents of the file register designated by f and the sum replaces the original contents of the file register. Subtraction is performed by placing the 2's complement of the number in the literal field. The condition flags and LINK register are not affected. File 0 may not be selected by this command.

This command is used whenever it is desired to add a number other than 1 (in which case the operate class add is used) to a file register. Specific cases are where a file is used for a pointer or to update the U register and changes of 2 or greater are required. Another use is to clear out higher order bits from a register. This command can also be used to set a flag bit in a file without resetting the other flag bits.

# Examples:

- 1) All '2A' to file 3 which contains '31'
- 2) Subtract '03' from file 5 which contains '54'
- 3) Set flag bit 6 in file 9 which has flag bit 1 set

| Example<br>Number | L .           | Machine<br>Code                         | Assembly<br>Language            | Flow Chart<br>Notation                             |
|-------------------|---------------|-----------------------------------------|---------------------------------|----------------------------------------------------|
| 1)                | '015 <b>'</b> | ′332A′<br>′35FD′ ①                      | AF 3,X'2A'                      | $(f_3)+'2A' \rightarrow f_3$                       |
| 2)                | '105 <b>'</b> |                                         | AF 5,X'FD'                      | (f <sub>5</sub> )-'03' <del>-</del> f <sub>5</sub> |
| 3)                | <b>'250'</b>  | ′3940′ ②                                | AF 9,X'40'                      | (f <sub>9</sub> )+'40'→f <sub>A</sub>              |
|                   |               | 2's compleme December 2's Hexadecimal ( | nt of '03'<br>equivalent of bit | : 6 = 1                                            |

# Affected Register States:

| Example<br>Number | Register | Before | After |
|-------------------|----------|--------|-------|
| 1)                | L        | '015'  | '016' |
|                   | file 3   | '31'   | '5B'  |
| 2)                | L        | '105'  | '106' |
|                   | file 5   | '54'   | '51'  |
| 3)                | L        | '250'  | '251' |
|                   | file 9   | '02'   | '42'  |

Execution Time - 220 nanoseconds.



If, for all the 1-bits of the literal field, the corresponding bits of the file register designated by f are 0-bits, the next command is skipped. The condition flags, LINK register and the file register are not affected. If the skip is taken, the timing of the command is two clock cycles.

This is a conditional branch type of command designed to test for the following conditions or functions existing in the referenced file register: negative or positive number, odd or even number, interrupt or internal status bits, sense switch bits, condition flags set or not set, teletype input bit set or not set. Since all of the selected bits must be 0, this is a logical AND type function. If a test bit is 0, the corresponding bit in the file does not affect the skip.

#### Bit Pattern Examples:

| Test Zero Literal                  | 00111000             | No Skip |
|------------------------------------|----------------------|---------|
| File Register<br>Test Zero Literal | 11100111<br>00011000 | Skip    |
| File Register<br>Test Zero Literal | 10110000<br>01001010 | Skip    |
| File Register<br>Test Zero Literal | 00010000<br>00010000 | No Skip |

Since all bits tested must be 0, this command is good for testing for the occurrence of any of a number of possibilities, such as testing for the presence of any of 3 interrupt flags.

The conditional skip can be used for branching, or for simply skipping one instruction for certain conditions. For branching, the skip is followed by a jump command.



A three-way branch can be implemented with two test and skip commands and two jump commands.



Example: Skip if bits 3, 4, and 7 are not set in file 0.



# Affected Register States:

| * *    | Register | Before        | After         |         |
|--------|----------|---------------|---------------|---------|
| Case 1 | L<br>F0  | '00E'<br>'43' | '010'<br>'43' | Skip    |
| Case 2 | L<br>F0  | '00E'<br>'80' | '00F'<br>'80' | No Skip |

Command Execution Time – 220 nanoseconds – No Skip. – 440 nanoseconds with Skip.

This timing applies to test not zero, and compare, as well.

# TN TEST IF NOT ZERO



If, for any bit of the literal field which is a 1-bit, the corresponding bit of the file register designated by f is also a 1-bit, the next command is skipped. The condition flags, LINK register and file register are not affected. If the skip is taken the timing of the command is two clock cycles.

This command differs from the test zero command in two ways. First it skips on 1's instead of 0's, and it skips on any 1 as opposed to all 0's on the test zero instruction.

If both tests (zero and not zero) were reduced to one bit comparisons, the only variation would be that one command produces the opposite result of the other. The choice would then be if a jump was wanted if the tested bit was 1, or 0.

If multiple bits are tested, the test not zero is the MAX TERM, and test zero is the MIN TERM logic equivalent.

# Bit Pattern Examples for test not zero:

| File Register<br>Test Not Zero Literal | 01101100<br>00110001 | Skip    |
|----------------------------------------|----------------------|---------|
| File Register<br>Test Not Zero Literal | 01000001<br>00011010 | No Skip |
| File Register<br>Test Not Zero Literal | 01100110<br>01101000 | Skip    |
| File Register<br>Test Not Zero Literal | 11100111<br>00010000 | No Skip |

Example: Skip if bit 0 in file 1 = 1

| L     | Machine<br>Code | Mnemonic   | Flow Chart<br>Notation |
|-------|-----------------|------------|------------------------|
| '01C' | <b>'</b> 5101'  | TN 1,X'01' | bit 0 N N No Skip      |
|       |                 | •          | Skip                   |

# Affected Register States:

|        | Register            | Before        | After         |         |
|--------|---------------------|---------------|---------------|---------|
| Case 1 | L<br>F <sub>1</sub> | '01C'<br>'01' | '01E'<br>'01' | Skip    |
| Case 2 | L<br>F <sub>1</sub> | '01C'<br>'80' | '01D'<br>'80' | No Skip |

Command Execution Time – 220 nanoseconds – No Skip. 440 nanoseconds – Skip.



If the sum of the contents of the file register designated by f and the contents of the eight-bit literal is greater than  $2^8$ -1, the next command is skipped. The condition flags, and file register are not affected. If the skip is taken the timing of the command is two clock cycles. The LINK stores the carry out of the adder. File 0 may not be selected by this command.

This command is used for looping control, and for data value testing. It is also used to test OP codes in instructions for selection of a particular class of OP codes, such as memory reference, having OP code (MICRO 810) greater than 5, for example. To test if the content of a file register exceeds a selected number, the 1's complement is placed in the literal part of the compare command.

Example: Skip if  $(f_1) > '5F'$ 

| L     | Machine<br>Code | Mnemonic   |
|-------|-----------------|------------|
| '014' | '61A0'          | CP 1,X'A0' |



# Affected Register States:

|        | Register            | Before        | After         | ,       |
|--------|---------------------|---------------|---------------|---------|
| Case 1 | L<br>F <sub>1</sub> | '014'<br>'52' | '016'<br>'52' | No Skip |
| Case 2 | L<br>F <sub>1</sub> | '014'<br>'66' | '015'<br>'66' | Skip    |

 $\begin{array}{c} \text{Command Execution Time} - 220 \text{ nanoseconds} - \text{No Skip.} \\ \text{440 nanoseconds} - \text{Skip.} \end{array}$ 

# K CONTROL



This command is used to control special data flow operations, and input/output functions. The prime functions are as follows:

- Enter sense switches from panel to selected file register.
- Shift selected file right 4 bit places.
- Enter internal status to selected file register.
- Set and clear the 3 input/output control flip flops (IOXX).

A secondary function for some of the prime functions is that data can simultaneously be moved from a file, or the input bus ANDed with the selected file, to a register. File 0 may be selected by the shift right 4 function only. These functions will be explained in detail in the following paragraphs. This command unconditionally updates the arithmetic condition flags in file 0.

The prime functions of this command are determined by the value of the c field as follows:

c Operation

Explanation

- 0 No Operation
- 1 Enter Sense Switches:

The status of the four console sense switches are placed in the four high order bits of the file register designated by f. The four low order bits are set to 1-bits. The status can also be placed in the designated destination register.

2 - Shift File Right 4:

The four high order bits of the file register designated by f are placed in four low order bits of the file register. The four high bits are set to 1-bits. The result can also be transferred to the designated destination register.

- 3 Unused
- 4 Enter Internal Status:

The eight internal status bits are placed in the file register designated by f, and the designated destination register. The internal interrupt flag in file 0 is reset by this command, along with the console interrupt, real time clock, memory parity, and power fail/restart. Console step is reset upon release of the console switch and spare bits are controlled according to their individual implementation in hardware.

- 5 Unused
- 6 Unused

### 7 — Enter Console Switches:

The contents of the eight low order console command switches are ANDed with eight low order bits of the next command. File register 0 and destination register 0 must be selected to prevent any modification of the file or register during the execution of the Control command. The command physically preceding this operation must not cause a read-only memory delay.

### 8 - Clear I/O Mode:

The I/O Control register is cleared. Data from the designated file or the input bus ANDed with the designated file can be transferred to the designated file register and register (r).

### 9-F - Set I/O Mode:

The I/O Control register is loaded with the three low order bits of c placing it in one of seven I/O bus or serial teletype modes. These modes are described in Section 4. Data from the designated file or the input bus ANDed with the designated file can be transferred to a designated file register and register (r).

# Affected: F, I/O Control, Condition Flags, r

For all values of c, except 0, 3, 5, 6, or 7, source data is placed in the designated file, if bit 3=0 and in the designated destination register. Destination r=7 is undefined for this command. In other words, the U register is not used.

# Examples:

### C = 1 Enter sense switches into file 1

| Machine<br>L Code M |                | Mnemonic | Flow Chart<br>Notation  |  |
|---------------------|----------------|----------|-------------------------|--|
| '005'               | '7110 <b>'</b> | K 1,1    | $(SSW) \rightarrow f_1$ |  |

### Affected Register Status:

| •      | Register                               | Before       | After         |
|--------|----------------------------------------|--------------|---------------|
|        | L<br>file 1                            | '005'        | '006'<br>'9F' |
| Case 1 | Sense SW (Binary)<br>File 0 (Bits 2-0) | 1001         | 1001<br>010   |
| 0 0    | L<br>file 1                            | '005'<br>——— | '006'<br>'2F' |
| Case 2 | Sense SW (Binary)<br>File 0 (Bits 2-0) | 0010         | 0010<br>000   |

### C = 2 Shift file 1 right 4

|              | Machine        | Flow Chart |                           |  |
|--------------|----------------|------------|---------------------------|--|
| , L          | Code           | Mnemonic   | Notation                  |  |
| <b>'012'</b> | '7120 <b>'</b> | K 1,2      | $F_1 SR4 \rightarrow F_1$ |  |

### Affected Register States:

| Register        | Before        | After        |
|-----------------|---------------|--------------|
| L               | '012 <b>'</b> | <b>'013'</b> |
| file 1          | 'E0'          | 'FE'         |
| file 0 (Bits 2- | 0)            | 010          |

### C = 4 Enter internal status to file 1

|      | Machine | Flow Chart |                       |  |
|------|---------|------------|-----------------------|--|
| L    | Code    | Mnemonic   | Notation              |  |
| 1E3′ | '7140'  | K 1,4      | Status—f <sub>1</sub> |  |

# Affected Register Status:

| Register          | Before      | After       |
|-------------------|-------------|-------------|
| L                 | '1E3'       | '1E4'       |
| file 1            |             | <b>'45'</b> |
| Status            | <b>'45'</b> | '40'        |
| file 0 (Bits 2-0) |             | 000         |

Note: Sense switch 4 can be tested by testing negative condition flag after entering SSW to file 0.

### C = 7 Enter console switches

This requires two commands, the first being the enter console switches, followed by a load file, if the switch settings are to go into a file; a load register if switch settings are to go into a register, or an operate command if switches are to modify the command. A load file operation will be used for the example. The load file literal must be FF to duplicate the switch settings into the file.

Example: Enter console switches into f5.

|       | Machine        |             | Flow Chart    |
|-------|----------------|-------------|---------------|
| L     | Code           | Mnemonic    | Notation      |
| '112' | '7070 <b>'</b> | K 0,7       | f5 ∧ CSW → f5 |
| '113' | '25FF'         | LF 5, X'FF' |               |

# Affected Register Status:

| Register         | Before | After |
|------------------|--------|-------|
| L                | '112'  | '114' |
| file 5           |        | 'A5'  |
| Console SW       | 'A5'   | 'A5'  |
| file 0 (Bit 2-0) |        | 010   |

This command cannot be executed via the front panel because it requires a dynamic situation, and two separate functions entered on the front panel.

# C = 8-F Input/Output control

When c equals 8-F, the operations are associated with external input/output, and the three low order bits of c are placed in the I/O Control register. On the same operation, data can be moved from the designated file register or the input bus ANDed with the designated file register as determined by the current contents of the I/O Control register, to the designated file or destination register. The data source is specified as follows:

| 1/0 | Control Register | Mode | Source                                        |
|-----|------------------|------|-----------------------------------------------|
|     | 0-3              | [    | Designated file register.                     |
|     | 4-7              | İ    | nput bus ANDed with designated file register. |

The values 4-7 correspond to the IO3X control flip flop. This flip flop must be set in order to transfer data from the input bit to the computer internal registers. Other than this restriction, the three I/O control register bits can be used in any manner desired at the microprogramming level of the MICRO 800 and as long as standard I/O interface modules are not used.

For purposes of standardization of common interface modules, and implementation of standard I/O software instructions, a convention for I/O codes has been adopted as shown inTable 5.

| c Field<br>(Hex)                     | I/O<br>Mode                          | IOXX<br>3 2 1.                                                       | Control Activity                                                                                                                                      |                                   |
|--------------------------------------|--------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| 8<br>9<br>A<br>B<br>C<br>D<br>E<br>F | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | 0;0;0<br>0;0;1<br>0;1;0<br>0;1;1<br>1;0;0<br>1;0;1<br>1;1;0<br>1;1;1 | None Control Output (COXX/) Data Output (DOXX/) Space Serial Teletype Concurrent Acknowledge (CACK/) I/O Acknowledge (IACK/) Data Input (DIXX/) Spare | Output<br>Codes<br>Input<br>Codes |

Table 5. MICRO 810/820 Standard I/O Control Codes

Note that the I/O mode is directly represented as the 3 least significant bits of the c field.

### Standard Output Functions:

The two output codes COXX, DOXX represent a two-byte output sequence, where the first byte is for control, and the second byte is for data. A device select control byte is first put in the T register (which is also the output bus) and then COXX is set and reset. Then a data value is placed in T and DOXX is set and reset.

## Standard Input Functions:

COXX and DIXX control codes are used for data input routines. A device select control byte is first placed in T, and COXX is set and reset. Then DIXX is set, data is input while DIXX is set and then DIXX is reset.

While DIXX is set, data can be entered two different ways:

- Operate commands involving T get the input bus instead of T as long as I03X is set. These commands are ADD, OR, COPY, EXCLUSIVE OR, AND. Any of these can be used to input data while DIXX is set as long as T complement is not selected.
- 2) The control command with the c field = 8-F causes the input bus to be ANDed with the selected file register as long as I03X is set. This method allows inputting on the same command that resets DIXX (providing the selected file has first been set to 'FF').

## I/O Examples:

1) Generate following output wave form:





# 2) Input data according to following wave form:



For a very simple interface having only 3 data registers to set, a single byte sequence will suffice for outputting data.

 Output a byte to interface Latch No. 2, where only 3 interface latches exist in the system, using the simple interface technique mentioned above



On an input cycle it is necessary to wait at least one clock cycle after generating DIXX to input data. The I/O controls are set in time at the completion of the control command. An input on the next clock would attempt to transfer data before the interface unit has the correct response data ready for input.

c field = B which is I/O mode 3 is used to set the serial teletype mode to SPACE, which ties up the I/O channel.

c field = D which is I/O mode 5 is used to acknowledge interrupts.

## A ADD



The selected operand is added to the contents of the file register designated by f. The sum is placed in the file register (f), if \* is a 0-bit, and in the register designated by r. The state of the carry out of the high order bit of the adder is placed in LINK. File 0 may not be selected by this command. The c field controls selection of the operand, incrementing the result and modification of the condition flags as follows:

Link Control: The content of LINK is added to the sum.  $x \times x$ The zero condition flag can be reset but cannot be set. providing a linked zero test over multiple bytes. A linked zero over multiple bytes functions as follows: Assume a 2-byte add is to be performed. Two file registers contain a 16-bit number to be added to another 16-bit number in core memory. The add is performed one byte at a time, with the LINK used for carry into the second add. On the first byte addition the condition flags are modified. If the result of the first byte addition is not zero, then of course the entire addition results in a non-zero condition, so that the zero condition flag should not be set on the second byte add even if its result is zero. On the other hand, if the first add produces a zero condition, the second may not, therefore the zero condition flag should be resettable on the second byte add.

> The add function can be used to move data from a file to another register by not selecting any input in the c field.

- x 1 x x Add One: One is added to the sum.
- x x 1 x Select T: The contents of the T register or the input bus are selected as the operand. If the T register is not selected, the operand is zero.
- $\mathbf{x} \ \mathbf{x} \ \mathbf{x} \ \mathbf{1}$  Modifying Condition Flags: The condition flags are updated according to the result.

Eight different examples have been selected to illustrate various c states, data values, and destination registers. Since the L register advances 1 unless it is the destination, its state will not be shown in the affected register state chart. File 1 will be used in all examples.

The various functions selected for each example are shown in Tables 6, 7, 8 and 9.

#### Table 6.

The general form of the examples is -

Add the contents of file 1 to one or more of the following:

Link, 1, T

Destination register choices are

T, F<sub>1</sub>, or N

Link is always updated.

Condition flags are updated on selected examples.

Table 7.

Add command uses file 1 for all examples. Table of functions selected for each example.

|                                                                                          |             | c Field |             |   |                                         |                                | Destination |                          |  |
|------------------------------------------------------------------------------------------|-------------|---------|-------------|---|-----------------------------------------|--------------------------------|-------------|--------------------------|--|
| Example                                                                                  | Add<br>Link |         | Select<br>T |   | Hexa-<br>decimal<br>Code for<br>c Field | Selected<br>Register<br>Symbol |             | Hexa-<br>decimal<br>Code |  |
| 1. Add (file 1) to (T), put result in T and f <sub>1</sub> , and update condition flags. | 0           | 0       | 1           | 1 | 3                                       | T, f <sub>1</sub>              | 0001        | 1                        |  |
| 2. Add (file 1) to<br>(T), put result in<br>T, update condi-<br>tion flags.              | 0           | 0       | 1           | 1 | 3                                       | Т                              | 1001        | 9                        |  |
| 3. Add (file 1) to<br>T, put result in N,<br>update condition<br>flags.                  | 0           | 0       | 1           | 1 | 3                                       | N                              | 1011        | В                        |  |
| 4. Add (file 1) to<br>T, +1, put result<br>in f <sub>1</sub> and N.                      | 0           | 1       | 1           | 0 | 6                                       | N, f <sub>1</sub>              | 0011        | 3                        |  |
| 5. Add (file 1) to (LINK), put result in f <sub>1</sub> .                                | 1           | 0       | 0           | 0 | 8                                       | f <sub>1</sub>                 | 0000        | 0                        |  |
| 6. Add one to f <sub>1</sub> and put result in f <sub>1</sub> , update C.                | 0           | 1       | 0           | 1 | 5                                       | f <sub>1</sub>                 | 0000        | 0                        |  |
| 7. Add (f <sub>1</sub> ) to T<br>and (LINK).<br>Put result in f <sub>1</sub> .           | 1           | 0       | 1           | 0 | А                                       | T, f <sub>1</sub>              | 0000        | 0                        |  |
| 8. Add (file 1) to<br>(T) plus 1. Put<br>result in T, f <sub>1</sub> .                   | 0           | . 1     | 1           | 0 | 6                                       | T, f <sub>1</sub>              | 0001        | 1                        |  |

The coding for the 8 Addition examples is shown below.

Table 8.

| Example                              | Machine<br>Code<br>(Hex)                                     | Assembly<br>Language<br>Mnemonics                                             | Flow Chart<br>Notation                                                                                                                                                                                                                                                                    |
|--------------------------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8 | 8131<br>8139<br>813B<br>8163<br>8180<br>8150<br>81A0<br>8161 | AT 1,T,C<br>AT* 1,T,C<br>AN* 1,T,C<br>AN 1,I,T<br>A 1,L<br>A 1,I,C<br>A 1,I,T | $(f_1) + (T) \longrightarrow T, f_1, C$<br>$(f_1) + (T) \longrightarrow T, C$<br>$(f_1) + (T) \longrightarrow N, C$<br>$(f_1) + (T) + 1 \longrightarrow N, f_1$<br>$(f_1) + (L) \longrightarrow f_1$<br>$(f_1) + T + (L) \longrightarrow f_1$<br>$(f_1) + (T) + 1 \longrightarrow T, f_1$ |

NOTE: If both Link and 1 are selected as inputs, they are ORed instead of added, thus the effective input is 1 regardless of the value of L.

Command Execution Time - 220 nanoseconds.

Table 9. Affected Register State Chart

|         |                 |              |              |        |          |      | Condit |        |
|---------|-----------------|--------------|--------------|--------|----------|------|--------|--------|
| Example | F1 , -          | File         | Т            | Link   | N        | Zero | Neg    | Ovflow |
| 1       | Before<br>After | '65'<br>00   | '9B'<br>00   | 1      |          | 1    | 0      | 0      |
| 2       | Before<br>After | '65'<br>'65' | '15'<br>'7A' | <br>0  |          | 0    | 0      | 0      |
| 3       | Before<br>After | '65'<br>'65' | '65'<br>'65' | 0      | <br>'СА' | 0    | <br>1  | 1 .    |
| 4       | Before<br>After | '65'<br>'66' | '00'         | 0      | <br>'66' |      |        |        |
| 5       | Before<br>After | '00'<br>'01' |              | 1<br>0 |          |      |        |        |
| 6       | Before<br>After | 'FF'<br>'00' |              | 1      |          | 1    | 0      | 0      |
| 7       | Before<br>After | '00'<br>'01' | '00'         | 1      |          |      |        | ,      |
| 8       | Before<br>After | '01'<br>'03' | '01'<br>'03' | 0      |          |      |        | _      |

S SUBTRACT



The complement of the selected operand <u>plus one</u> is added to the contents of the file register designated by f. The difference is placed in the file register (f) if \* is a 0-bit, and in the register designated by r. The result is a 2's complement subtraction. The state of the carry out of the high order bit of the adder is placed in LINK. File 0 may not be selected by this command. The c field controls selection of the operand, incrementing the result, and modification of the condition flags as follows:

Link control: The content of LINK is added to the sum. Selection of the LINK inhibits the automatic addition of one. The zero condition flag cannot be set, providing a linked zero test over multiple bytes. Refer to the add description for details on linked zero test.

x 1 x xInhibit add one: If link control is not selected, one is automatically added to the result to produce a 2's complement subtraction. This control bit inhibits this addition, providing a 1's complement subtraction.

Select T: This complement of the contents of the T register  $x \times 1 x$ are selected as the operand to the adder. If not selected, the operand consists of a 1-bit in each bit position.

 $x \times x \times 1$ Modify Condition Flags: The condition flags are updated according to the result.

Affected: F, LINK, Condition Flags, r

If the input bus is enabled (103X), this command will yield an unpredictable result because the complement of the input bus is not available.

# Examples:

Subtract zero from file 1.

'9100'

Affected register states:

| Register | Before      | After |
|----------|-------------|-------|
| Link     |             | 1     |
| file 1   | <b>'00'</b> | '00'  |

P.

1

Even though 0 is subtracted from 0, since 2's complement adding is used there is a carry of 1 all through the adder to the Link.

2. Subtract T, 1 from file 1 Destination T Update condition flags

| Machine<br>Code | Mnemonic    | Flow Chart<br>Notation        |
|-----------------|-------------|-------------------------------|
| '9179 <b>'</b>  | ST* 1,D,T,C | (f <sub>1</sub> ) - T-1 → T,C |

## Affected register states:

| Register       | Before | After                                            |
|----------------|--------|--------------------------------------------------|
| f <sub>1</sub> | '31'   | '31'                                             |
| 1              | '31'   | 'FF' <del>&lt;-</del> 2's comple-<br>ment for -1 |
| L              |        | 0                                                |
| С              | *****  | 0 1 0<br>Zero Neg Overflow                       |

Command execution time - 220 nanoseconds.

### R READ MEMORY W WRITE MEMORY



The primary function of this command is to initiate a core memory cycle in which one byte is transferred between the T register and core memory. The address in core is determined by the contents of the M and N registers. File 0 may not be selected by this command.

The lower two bits of the c field determine whether the memory operation is read or write and whether the operation is a full or half cycle.

The c-bits control the type of memory operation as follows:

| c-bits<br>7 6 5 4 | Memory Access Operation                                                                                                              |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| x x 1 x           | Half Cycle: If this bit is a 1-bit, a half cycle memory operation is performed; otherwise a <u>full cycle</u> operation is selected. |
| x x x 1           | Write: If this bit is a 1-bit, a write memory operation is performed; otherwise a <u>read operation</u> is selected.                 |

A full cycle takes 5 clock times.

A half cycle takes 3 clock times.

A full cycle <u>read</u> leaves the data in core unchanged.

A full cycle <u>write</u> causes the old data to be cleared so the new value is unaffected by the old.

A half cycle read leaves all ones in the core location.

A half cycle write ANDS the data to be written with the data already in core.

If a half cycle write into a particular memory cell was preceded by a half cycle read, the data value gets stored without modification since it is ANDed with all 1's, left from the previous half cycle read.

A secondary function of this command is to simultaneously move data between registers while initiating the memory cycle.

The contents of the file register designated by f is unaltered, incremented, or decremented as controlled by the c field. The result is placed in the file register (f) if \* is a 0-bit, and in the register designated by r. At the same time, a read (R) or write (W) memory operation is initiated as controlled by bit 4. If the operation is a memory read, the T register is cleared and the accessed data is set into the T register after two clock cycle times. Data to be written into memory must be placed in the T register during or before the write memory command, if the operation is a half cycle write, and by the first clock cycle time after the write memory command on a full cycle write. The condition flags and LINK are not affected. Execution of the memory command is delayed if the memory is in a busy condition from a previous R or W command or DMA operation.

The bits of the c field control the transfer of data from the file register as follows:

|   | oits<br>6 |   | 4 | Operation                                                                                                                                                                                                                                                                                                                |
|---|-----------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | 0         | X | × | Transfer: The contents of the file register are transferred unaltered.                                                                                                                                                                                                                                                   |
| 0 | 1         | x | x | Decrement: The contents of the file register minus one are routed as specified. If the M register is selected as the destination and the content of LINK is a 1-bit, the contents of the file register are transferred without being decremented. This provides a decrement with link control when M is the destination. |

- 1 0 x x Add Link: The content of LINK is added to the contents of the file register, and the sum is transferred as specified.
- 1 1 x x Increment: The contents of the file register plus one are transferred as specified.

This data transfer feature permits setting up one of the registers directly involved with the memory access (M, N, or T) at the same time the memory cycle is initiated. There are some timing restrictions pertaining to modification of M, N, or T registers during a memory cycle. Some of the functions have logic interlocks to prevent errors, and some do not. These restrictions must be carefully considered with respect to data errors, and unexpected program time delays. The restrictions are as follows:

1) Attempting to change M, or N while a memory cycle is in progress stops the computer clock until the memory cycle is over. No data errors result. Either M or N can be changed by the command initiating the memory cycle without causing delay.

- Accessing T during a read cycle causes the clock to stop until the new data value from core is correctly in T. This causes delay but no data error.
- Changing T during a write cycle will not cause delay but it may cause a data error.

The memory access restrictions are specifically defined in the following chart:

|                                     | Full Cycle<br>Read                      | Full Cycle<br>Write                              | Half Cycle<br>Read                      | Half Cycle<br>Write                    |
|-------------------------------------|-----------------------------------------|--------------------------------------------------|-----------------------------------------|----------------------------------------|
| Delay from changing M and N         | Up to 4<br>clocks                       | Up to 4<br>clocks                                | Up to 2<br>clocks                       | Up to 2<br>clocks                      |
| Delay due to T access               | Up to 2 clocks                          | 0                                                | Up to 2<br>clocks                       | 0<br>clocks                            |
| Data in T available<br>(on Read)    | 3rd clock<br>after<br>memory<br>command |                                                  | 2nd clock<br>after<br>memory<br>command |                                        |
| T must be loaded by<br>(on Write)   |                                         | 1st clock<br>after<br>memory<br>cycle<br>command |                                         | Memory<br>Cycle<br>Command             |
| T must stay loaded until (on Write) |                                         | 4 clocks<br>after<br>memory<br>command           |                                         | 2 clocks<br>after<br>memory<br>command |



| Examples:                                                                                         | Machine<br>Code           |                                          |                                                              |                            |                                                                                                                                                                          |
|---------------------------------------------------------------------------------------------------|---------------------------|------------------------------------------|--------------------------------------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Example                                                                                           | f d<br>i e<br>ols<br>pect | Mnemonics                                | c Field Binary<br>Functions and Codes for<br>Memory Commands | c<br>Field<br>Hex.<br>Code | General Description                                                                                                                                                      |
| 1) Full cycle write (file 1) + 1 → N, f <sub>1</sub>                                              | A 1 D 3                   | WN 1, I                                  | Increment Full cycle<br>write<br>1 1 0 1                     | D                          | Full cycle write memory is initiated and N register is updated as well as f <sub>1</sub> .                                                                               |
| 2) Half cycle read<br>(file 2) → M, f <sub>2</sub>                                                | A 2 2 2                   | RM 2,H                                   | Transfer Half cycle<br>read<br>0 0 1 0                       | 2                          | Half cycle read memory is initiated while M register is updated directly from f <sub>2</sub> .                                                                           |
| 3) Half cycle write<br>(file 2) + (Link) → M, f <sub>2</sub>                                      | A 2 B 2                   | WM 2, L, H                               | Add Link Half cycle<br>write<br>1 0 1 1                      | В                          | Half cycle write memory is initiated while file 2 and M are updated by adding (LINK).                                                                                    |
| 4) Full cycle write (file 3) — T, f <sub>3</sub>                                                  | A 3 1 1                   | WT 3                                     | Transfer Full cycle<br>write<br>0 0 0 1                      | 1 .                        | Full cycle write memory is initiated,<br>T is updated from f <sub>3</sub> on the same<br>command.                                                                        |
| 5) Half cycle read (f <sub>1</sub> ) - 1 → N followed (f <sub>3</sub> ) + (T) → T, f <sub>3</sub> | A 1 6 B<br>8 3 2 1        | Inhibit file write  RN* 1, D, H  AT 3, T | Decrement Half cycle read  0 1 1 0                           | 6<br>-                     | Half cycle read memory is initiated, followed by T register access on the next instruction. This will cause a program delay until the third clock.                       |
| 6) Half cycle write followed by loading T (f3) T, f <sub>3</sub>                                  | A 0 3 0<br>8 3 0 1        | W 0, H<br>AT 3                           | Transfer Half cycle write 0 0 1 1                            | 3                          | Half cycle write memory is initiated, followed by loading T on next instruction. No time delay occurs, but data written into memory may be incorrect.                    |
| 7) Full cycle read, decrement (file 1) and transfer to M (f₁) − 1 → M, f₁                         | A 1 4 2                   | RM 1, D                                  | Decrement Full cycle<br>read<br>0 1 0 0                      | 4                          | A full cycle read is initiated. (f <sub>1</sub> ) is decremented and transferred to M. If (LINK) = 1 the contents of the file are transferred without being decremented. |



The selected operand is placed in the file register designated by f, if \* is a 0-bit, and in the register designated by r. The LINK is not affected. The c field controls selection of the operand, incrementing the operand, and modification of condition flags as follows:

c-bits 7 6 5 4

Operation

1 x x x Link Control: The content of LINK is added to the sum.

The zero condition flag can be reset but cannot be set, providing a linked zero test over multiple bytes.

x 1 x x Add One: One is added to the sum.

x x 1 x Select T: The contents of the T register or Input bus are selected as the operand. If the T register is not selected, the operand is zero.

x x x 1 Modify condition flags: The condition flags are updated according to the result.

Affected: F, Condition Flags, r

This command is used to transfer T to a selected file register, with the option of incrementing or adding LINK while transferring. It is also used for inputting data, because when the input control flip flop (I03X) is set during an input mode, operate commands selecting T get the input bus instead.

The command can be used to test the condition of T by selecting f0 as the file register (which is unaffected) and setting the modify condition flag in the c field.

The command can also be used to clear one file and another selected register by not selecting any input in the c field.

Command Execution Time — 220 nanoseconds.

File register 1 is used for all examples except setting condition flag example. Examples of Copy Command:

|                                                 | Machine<br>Code |             |        |             | Code |          |             |                        | Code         |                    |                |              |                 |                                                                                                                    |  |  | c field for Copy Commands  Destination for Copy Commands |  |  |  |  |  |
|-------------------------------------------------|-----------------|-------------|--------|-------------|------|----------|-------------|------------------------|--------------|--------------------|----------------|--------------|-----------------|--------------------------------------------------------------------------------------------------------------------|--|--|----------------------------------------------------------|--|--|--|--|--|
| Examples                                        | o<br>p          | i<br>I<br>e | С      | e<br>s<br>t | Link | Add<br>1 | Select<br>T | Mod.<br>Cond.<br>Flags | Hex.<br>Code |                    | Binary<br>Code | Hex.<br>Code | Mnemonics       | General Discussion                                                                                                 |  |  |                                                          |  |  |  |  |  |
| (T) — f <sub>1</sub>                            | В               | 1           | 2      | o           | 0    | 0        | 1           | 0                      | 2            | f <sub>1</sub>     | 0000           | 0            | C 1,T           | (T) is transferred,<br>unaltered to file 1.                                                                        |  |  |                                                          |  |  |  |  |  |
| (T) + 1 → f <sub>1</sub> , N                    | В               | 1           | 6      | 3           | 0    | 1        | 1           | 0                      | 6            | f <sub>1</sub> , N | 0011           | 3            | CN 1,I,T        | (T) is incremented and<br>transferred to file 1,<br>and to the N register.                                         |  |  |                                                          |  |  |  |  |  |
| (T) + (LINK)                                    | В               | 1           | Α      | 0           | 1    | 0        | 1           | 0                      | Α            | f <sub>1</sub>     | 0000           | 0            | C 1,T,L         | (T) is added to (LINK) and transferred to f <sub>1</sub> .                                                         |  |  |                                                          |  |  |  |  |  |
| 0—►f <sub>1</sub> , N                           | В               | 1           | 0      | 3           | 0    | 0        | 0 .         | 0                      | , 0          | f <sub>1</sub> , N | 0011           | 3            | CN 1            | File 1 and N registers<br>are cleared because no<br>input is selected.                                             |  |  |                                                          |  |  |  |  |  |
| (T) → f <sub>0</sub> , C<br>Set Condition Flags | В               | 1           | 3      | 0           | 0    | 0        | 1           | 1                      | 3            | f <sub>0</sub>     | 0000           | 0            | C 0,T,C         | Condition flags are set according to the state of (T). File 0 can't be loaded by this instruction so is unchanged. |  |  |                                                          |  |  |  |  |  |
| Set DIXX                                        | 7               |             | _      | 0           |      |          |             |                        |              |                    |                |              | K 0,X'E'        | The input flip flop is set by the DIXX                                                                             |  |  |                                                          |  |  |  |  |  |
| Delay                                           | ·               | -           | 0      | _           |      |          |             |                        |              |                    | 2004           |              | LZ X'00'        | command, so the copy<br>T command transfers                                                                        |  |  |                                                          |  |  |  |  |  |
| (T) → f <sub>1</sub> , T<br>Reset DIXX          | B<br>7          | 0           | 2<br>8 | 0           | 0    | 0        | 1           | 0                      | 2            | f <sub>1</sub> ,T  | 0001           | 1            | CT 1,T<br>K 0,8 | the Input bus to file 1<br>and to T.                                                                               |  |  |                                                          |  |  |  |  |  |



The selected operand is logically inclusive-ORed on a bit-for-bit basis with the contents of the file register designated by f and the result is placed in the file register, if \* is a 0-bit, and in the register designated by r..The LINK is not affected. The c field controls selection of the operand and modification of the condition flags as shown below:

| C- | DITS | 3 |   |  |           |
|----|------|---|---|--|-----------|
| 7  | 6    | 5 | 4 |  | Operation |
|    |      |   |   |  |           |

- 1 x x x Link control: The zero condition flag can be reset but cannot be set, providing a linked zero test over multiple bytes. See the description of the add command for a detailed description of linked zero test.
- x 1 x x Select complement T: The complement of the contents of the T register is selected as the operand. If the T register is also selected, the effective operand contains a 1-bit in each bit position.
- x x 1 x Select T: The contents of the T register or Input bus are selected as the operand. If neither the T register nor the complement of the T register is selected, the operand is zero.
- x x x 1 Modify Condition Flags: The condition flags are updated according to the result.

Affected: F, Condition Flags, r

If both complement T and  $\overline{T}$  are selected, the operand is all 1's. If the input bit is enabled (103X), complement T must not be selected.

This command is used for the general function of logical ORing as needed in a microprogram. It also has the following specific applications: Setting flag bits without disturbing other bits (with the OR function it doesn't matter if the flag is already set since there is no carry); moving data from a file to another register by not selecting any operand; setting all 1's in a file register and/or one other selected register by selecting both T and  $\overline{\mathsf{T}}$  complement as operands; combining two numbers into one byte, such as for assembling hexadecimal digits into multiple digit numbers after the digits have been input to the computer as a string.

Bit pattern example of OR function:

|        | Binary   | Hexadecimal  |
|--------|----------|--------------|
| file 1 | 01101000 | '68 <b>'</b> |
| T      | 00110100 | <u>'34'</u>  |
| Result | 01111100 | '7C'         |

Command Execution Time - 220 nanoseconds.

Examples of OR command:

|                                                    | Machine<br>Code<br>f d |             |   |             | Code |                      |             |                        | c field for OR commands |                       |                |              |            | Destination for OR command results                                                                                                                      |  |  |  |  |
|----------------------------------------------------|------------------------|-------------|---|-------------|------|----------------------|-------------|------------------------|-------------------------|-----------------------|----------------|--------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Flow Chart<br>Notation                             | o<br>p                 | i<br>I<br>e | С | e<br>s<br>t | Link | Select<br>Comp.<br>T | Select<br>T | Mod.<br>Cond.<br>Flags |                         | Selected<br>Registers | Binary<br>Code | Hex.<br>Code | Mnemonics  | General Discussion                                                                                                                                      |  |  |  |  |
| (f <sub>1</sub> ) ∨ (T) —► T                       | С                      | 1           | 2 | 9           | 0    | 0                    | 1           | 0                      | 2                       | T,                    | 1001           | 9            | OT* 1, T   | OR (file 1) with (T), inhibit file write put result in T.                                                                                               |  |  |  |  |
| (f <sub>1</sub> ) ∨ 0 → N, f <sub>1</sub>          | С                      | 1           | 0 | 3           | 0    | 0                    | 0           | 0                      | 0                       | N, f <sub>1</sub>     | 0011           | 3            | ON 1       | Move (file 1) to N by ORing with 0 and putting result in N.                                                                                             |  |  |  |  |
| (f <sub>1</sub> ) ∨ (T) → f <sub>1</sub>           | С                      | 1           | 2 | 0           | 0    | 0                    | 1           | 0                      | 2                       | f <sub>1</sub>        | 0000           | 0            | O 1,T      | OR (file 1) with (T) and put result in file 1.                                                                                                          |  |  |  |  |
| $(f_1) \lor (T), (\overline{T}) \longrightarrow N$ | С                      | 1           | 6 | В           | 0    | 1                    | 1           |                        | 6                       | N                     | 1011           | В            | ON* 1,T,F  | Set N = FF (all ones)<br>by ORing ( $f_1$ ) with<br>T, T and putting<br>result in N.                                                                    |  |  |  |  |
| (f <sub>1</sub> ) ∨ (T) (T) → f <sub>1</sub>       | С                      | 1           | 6 | 0           | 0    | 1                    | 1           | 0                      | 6                       | f <sub>1</sub>        | 0000           | 0            | O 1,T,F    | Set $f_1 = FF$ by ORing $f_1$ with $T$ , $\overline{T}$ and putting result in $f_1$ .                                                                   |  |  |  |  |
| (f <sub>1</sub> ) ∨ (T) → Link, C                  | С                      | 1           | В | 8           | 1    | 0                    | 1           | 1                      | В                       | none                  | 1000           | 8            | O* 1,T,L,C | Perform conditional test on (f <sub>1</sub> ) V (T) without changing f <sub>1</sub> or T, Select L to perform linked zero test with a previous command. |  |  |  |  |



The selected operand is logically exclusive-ORed on a bit for bit basis with the contents of the file register designated by f and the result is placed in the file register, if \* is a 0-bit, and in the register designated by r. The LINK is not affected. The c field controls selection of the operand and modification of the condition flags as shown below:

| c-b | its | :    |          |                                                                                                                                                                                                                 |
|-----|-----|------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   |     |      | 4        | Operation                                                                                                                                                                                                       |
| 1   | x   | x    | x        | Link Control: The zero condition flags can be reset but cannot be set, providing a linked zero test over multiple bytes. See the description of the Add command for a detailed description of linked zero test. |
| x   | 1   | ×    | x        | Select Complement T: The complement of the contents of<br>the T register is selected as the operand. If the T register is<br>also selected, the effective operand contains a 1-bit in each<br>bit position.     |
| х   | ×   | 1    | <b>x</b> | Select T: The contents of the T register or input bus are selected as the operand. If neither the T register nor the complement of the T register is selected, the operand is zero.                             |
| x   | x   | x    | 1        | Modify Condition Flags: The condition flags are updated according to the result.                                                                                                                                |
| Αf  | fec | etec | d:       | F, Condition Flags, r                                                                                                                                                                                           |

, triceted.

If both T and  $\overline{T}$  are selected, this command produces the one's complement of the value in the file register. If the input bus is enabled (I03X), complement T must not be selected.

This command is used for the following functions: general purpose exclusive OR; data comparison; ones complementing; and flipping selected bits such as controls and status flags.

Bit pattern example of exclusive OR.

|             | Binary               | Hexadecimal     |
|-------------|----------------------|-----------------|
| file 1<br>T | 01101100<br>00011010 | '6C'<br>'1A'    |
| Result      | 01110110             | <del>'76'</del> |

Command execution time - 220 nanoseconds.

File register 1 is used for all examples. Examples of Exclusive OR command:

|                                                    |        | laci<br>Cod | nine<br>de | d           |      | c field for          | OR com      | mands                  |   |                       | on for Exc<br>nmand res |              |      |              |                                                                                                                     |
|----------------------------------------------------|--------|-------------|------------|-------------|------|----------------------|-------------|------------------------|---|-----------------------|-------------------------|--------------|------|--------------|---------------------------------------------------------------------------------------------------------------------|
| Example<br>Flow Chart<br>Notation                  | o<br>p | i<br>I<br>e | С          | e<br>s<br>t | Link | Select<br>Comp.<br>T | Select<br>T | Mod.<br>Cond.<br>Flags |   | Selected<br>Registers | Binary<br>Code          | Hex.<br>Code | Mner | nonics       | General Discussion                                                                                                  |
| (f <sub>1</sub> ) <del>∀</del> (T) <del></del> T   | D      | 1           | 2          | 9           | 0    | 0                    | 1           | 0                      | 2 | Т                     | 1001                    | 9            | XT*  | 1, T         | Exclusive OR (file<br>1) with (T) inhibit<br>file write, put<br>result in T.                                        |
| (f <sub>1</sub> ) ¥ 0 → N, f <sub>1</sub>          | D      | 1           | 0          | 3           | Ó    |                      | 0           | 0                      | 0 | N, f <sub>1</sub>     | 0011                    | 3            | ΧŅ   | 1            | Move (file 1) to N<br>by exclusive ORing<br>with 0 (same result<br>as OR), put result<br>in N.                      |
| (f <sub>1</sub> ) → (T) → f <sub>1</sub>           | D      | 1           | 2          | 0           | 0    | 0                    | 1           | 0                      | 2 | f <sub>1</sub>        | 0000                    | 0            | X    | 1, T         | Exclusive OR (file<br>1) with (T) and put<br>result in file 1.                                                      |
| $(f_1) \neq (T), (\overline{T}) \longrightarrow T$ | D      | 1           | 6          | В           | 0    | 1                    | 1           | 0                      | 6 | N                     | 1001                    | 9            | XT*  | 1,T,F        | Produce ones complement of (f <sub>1</sub> ) and place result in T.                                                 |
| f <sub>1</sub> ∀ (T), (T) → f <sub>1</sub>         | D      | 1           | 6          | 0           | 0    | 1                    | 1           | 0                      | 6 | f <sub>1</sub>        | 0000                    | 0            | X    | 1,T,F        | Produce ones complement of (f <sub>1</sub> ) and put it back into f <sub>1</sub> .                                  |
| (f <sub>1</sub> ) <del>∀</del> (T) → Link, C       | D      | 1           | В          | 8           | 1    | 0                    | 1           | 1                      | В | none                  | 1000                    | 8            | X*   | 1, T,<br>L,C | Perform conditional test and linked zero test on (f <sub>1</sub> ) ★ (T) without changing (f <sub>1</sub> ) or (T). |



The selected operand is logically ANDed on a bit-for-bit basis with the contents of the file register designated by f and the result is placed in the file register, if \* is a 0-bit, and in the register designated by r. The LINK is not affected. The c field controls selection of the operand and modification of the condition flags as shown below:

c-bits 7 6 5 4

## Operation

- 1 x x x

  Link control: The zero condition flag can be reset but cannot be set, providing a linked zero test over multiple bytes. See the description of the add command for a detailed description of a linked zero test.
- x 1 x x Select complement T: The complement of the contents of the T register is selected as the operand. If the T register is also selected, the effective operand contains a 1-bit in each bit position.
- x x 1 x Select T: The contents of the T register or Input bus are selected as the operand. If neither the T register nor the complement of the T register is selected, the operand is zero.
- x x x 1 Modify condition flags: The condition flags are modified by execution of the command. Updated according to the result.

Affected: F, Condition Flags, r

If both T and  $\overline{T}$  are selected and And command moves the data, unchanged from the selected file register to the designated destination register. If the input bus is enabled (I03X), complement T must not be selected.

The and command is used for the following functions: General purpose anding of files and T; resetting selected flag or status bits, without disturbing other flags; and masking out parts of a byte.

# Examples of And Command:

| Example                                              |        | Machine<br>Code<br>f d |   | c field for And commands |      |                      |             |                        | ination fo<br>mmand re |                       |                |              |               |                                                                                                                                                            |
|------------------------------------------------------|--------|------------------------|---|--------------------------|------|----------------------|-------------|------------------------|------------------------|-----------------------|----------------|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Flow Chart<br>Notation                               | o<br>p | i<br>I<br>e            | С | e<br>s<br>t              | Link | Select<br>Comp.<br>T | Select<br>T | Mod.<br>Cond.<br>Flags | Hex.<br>Code           | Selected<br>Registers | Binary<br>Code | Hex.<br>Code | Mnemonics     | General Discussion                                                                                                                                         |
| (f <sub>1</sub> ) ∧ (T) · → f <sub>1</sub>           | E      | 1                      | 2 | 0                        | 0    | 0                    | 1           | 0                      | 2                      | f <sub>1</sub>        | 0000           | 0            | N 1,T         | (f <sub>1</sub> ) is anded with (T).<br>The result is put into<br>f <sub>1</sub> .                                                                         |
| $(f_1) \wedge 0 \longrightarrow N, f_1$              | Е      | 1                      | 0 | 3                        | 0    | 0                    | 0           | 0                      | 0                      | N, f <sub>1</sub>     | 0011           | 3            | NN 1          | (f <sub>1</sub> ) is anded with 0.<br>The result (which is 0)<br>is put into N, and f <sub>1</sub> .                                                       |
| (f <sub>1</sub> )∧(T) → T                            | Е      | 1                      | 2 | 9                        | 0    | 0                    | 1           | 0                      | 2                      | Т                     | 1001           | 9            | NT* 1,T       | $(f_1)$ is anded with $(T)$ .<br>The result is put in $T$ and inhibited from $f_1$ .                                                                       |
| $(f_1) \wedge (T), (\overline{T}) \longrightarrow N$ | Е      | 1                      | 6 | В                        | 0    | 1                    | 1           | 0                      | 6                      | N                     | 1011           | В            | NN* 1,T,F     | (f <sub>1</sub> ) is anded with (T),<br>(T) which is same as<br>anding with FF (all<br>ones). Result is put in<br>N and inhibited from<br>f <sub>1</sub> . |
| $(f_1) \wedge (\overline{T}) \longrightarrow f_1$    | Е      | 1                      | 4 | 0                        | 0    | 1                    | 0           | 0                      | 4                      | f <sub>1</sub>        | 0000           | 0            | N 1,F         | $(f_1)$ is anded with $(\overline{T})$ .<br>The result is put into $f_1$ .                                                                                 |
| (f <sub>1</sub> ) ∧ (T) → Link, C                    | E      | 1                      | В | 8                        | 1    | 0                    | 1           | 1                      | В                      | none                  | 1000           | 8            | N 1,T,<br>L,C | (f <sub>1</sub> ) is anded with (T). The result is not put in any register. Only the condition flags are set. Use of link results in multi byte zero test. |

Bit pattern examples of the and function.

|            | Binary       | Hexadecimal  |  |  |  |  |
|------------|--------------|--------------|--|--|--|--|
| file 1     | 01101011     | '6B'         |  |  |  |  |
| T          | 10101101     | <u>'AD'</u>  |  |  |  |  |
| Result     | 00101001     | <b>'</b> 29' |  |  |  |  |
| file 1     | 01000010     | '42          |  |  |  |  |
| T          | 10111111     | 'BF'         |  |  |  |  |
| Result     | 00000010     | '02'         |  |  |  |  |
|            | Reset a flag |              |  |  |  |  |
| file 1     | 10100101     | 'A5'         |  |  |  |  |
| T          | 11010011     | 'D3'         |  |  |  |  |
| (Select T) | (00101100)   | ('2C')       |  |  |  |  |
| Result     | 00100100     | '24'         |  |  |  |  |
| file 1     | 10100101     | 'A5'         |  |  |  |  |
| T, T       | 11111111     | <u>'FF'</u>  |  |  |  |  |
| Result     | 10100101     | 'A5'         |  |  |  |  |

Command Execution Time - 220 nanoseconds.

### H SHIFT



The contents of the file register designated by f is shifted left or right one bit position and placed in the file register, if \* is a 0-bit, and in the register designated by r. The high order or low order bit which is shifted off is placed in LINK and in the overflow flag if the modify condition flag is selected. The c field controls the direction of shift, entry of an end bit, and modification of the condition flags as follows:

| c-t | oit |   |   |           |
|-----|-----|---|---|-----------|
| 7   | 6   | 5 | 4 | Operation |

- 1 x x x

  Link control: The content of the LINK is inserted into the vacated low order or high order bit position. The zero condition flag can be reset but cannot be set, providing a linked zero test over multiple bytes. See the description of the add command for a detailed description of the linked zero test.
- x 1 x x Insert 1: A 1-bit is unconditionally inserted into the vacated low order or high order bit position; otherwise a 0-bit is inserted unless the contents of LINK is selected.

## Operation

- x x 1 x Shift right: if bit 5 is a 1-bit, the operation is a right shift; otherwise a left shift is performed.
- x x x 1 Modify condition flags: The zero and negative flags are updated according to the result. The content of the bit shifted out is placed in the overflow flag.

Affected: F, LINK, Condition Flags, r

This command provides great flexibility for various shifting functions mechanized by microprogramming. These are as follows:

- Left or right shifting;
- End around carry or no end around carry;
- Arithmetic or logical shifts;
- Multiple byte shift register implementations in either file registers or core memory;
- Pattern rotations by successive shifting of 8 files one bit at a time and assembling into a 9th file;
- Set or reset link bit by shifting with no destination register.

Bit pattern examples of shift command. All examples are for shift  $(f_1)$  and put result back in  $f_1$ .

| Instruction                                | Sequence<br>Number | file 1<br>Binary     | Link   | file 1<br>Hexa-<br>decimal | Condition<br>Flags |
|--------------------------------------------|--------------------|----------------------|--------|----------------------------|--------------------|
| Shift Right                                | before<br>after    | 01101001<br>00110100 | 0<br>1 | '69'<br>'34'               |                    |
| Shift Left                                 | before<br>after    | 01101001<br>11010010 | 1<br>0 | · '69'<br>'D2'             |                    |
| Shift<br>Right<br>Enter<br>Link            | before<br>after    | 00111000<br>10011100 | 1<br>0 | '38'<br>'9C'               |                    |
| Shift<br>Left<br>Enter 1                   | before<br>after    | 10001010<br>00010101 | 0<br>1 | '8A'<br>'15'               |                    |
| Shift Left<br>Modify<br>Condition<br>Flag  | before<br>after    | 11001011<br>10010110 | 0      | 'CB'<br>'96'               | 011                |
| Shift Right<br>Modify<br>Condition<br>Flag | before<br>after    | 00000001<br>00000000 | 0<br>1 | '01'<br>'00'               | 101                |

Instruction codes for bit pattern examples of shift command. These examples are the same except for additional Destination Registers.

| ,                                                                  |                                                                    | Machine<br>Code<br>f |             |   |             |                | · · · · · · · · · · · · · · · · · · · | c field        |                        |              |                       | ination formand r |              |     |        |                                                                                                                        |
|--------------------------------------------------------------------|--------------------------------------------------------------------|----------------------|-------------|---|-------------|----------------|---------------------------------------|----------------|------------------------|--------------|-----------------------|-------------------|--------------|-----|--------|------------------------------------------------------------------------------------------------------------------------|
| Example                                                            | Flow Chart<br>Notation                                             | o<br>p               | i<br>I<br>e | С | e<br>s<br>t | Insert<br>Link | Insert<br>1                           | Shift<br>Right | Mod.<br>Cond.<br>Flags | Hex.<br>Code | Selected<br>Registers | Binary<br>Code    | Hex.<br>Code | Mne | monics | General Discussion                                                                                                     |
| Shift right result to f <sub>1</sub> , T.                          | (f <sub>1</sub> )@ <sub>R</sub> → f <sub>1</sub> ,T                | F                    | 1           | 2 | 1           | 0              | 0                                     | 1              | 0                      | 2            | f <sub>1</sub> ,T     | 0001              | 1            | HT  | 1,R    | (file 1) is shifted right<br>one bit, link, or 1 are<br>not inserted. The result<br>is put in T and f <sub>1</sub> .   |
| Shift left result to f1.                                           | (f <sub>1</sub> )@∟—►F <sub>1</sub>                                | F                    | 1           | 0 | 0           | 0              | 0                                     | 0              | 0                      | 0            | f <sub>1</sub>        | 0000              | 0            | Η.  | 1      | (file 1) is shifted left<br>one bit, link or 1 are<br>not inserted. The result<br>is put in f <sub>1</sub> .           |
| Shift right insert link result to f <sub>1</sub> , N.              | (f <sub>1</sub> )@ <sub>R</sub> +LK <del>►</del> f <sub>1</sub> ,N | F                    | 1           | Α | 3           | 1              | 0                                     | 1              | Ó                      | Α            | f <sub>1</sub> ,N     | 0011              | 3            | HN  | 1,R,L  | (file 1) is shifted right one bit, (Link) is inserted in vacated left hand bit. Result is put in f <sub>1</sub> and N. |
| Shift left insert 1 result to f <sub>1</sub> , M.                  | (f <sub>1</sub> )@L+1 <del>-&gt;</del> f <sub>1</sub> ,M           | F                    | 1           | 4 | 2           | 0              | 1                                     | 0              | 0                      | 4            | f <sub>1</sub> , M    | 0010              | 2            | НМ  | 1, I   | (file 1) is shifted left. 1 is inserted into the vacated right hand bit. Result is put in f <sub>1</sub> and M.        |
| Shift left<br>modify cond.<br>flag. Result<br>to f <sub>1</sub> .  | (f <sub>1</sub> )@ <sub>L</sub> → f <sub>1</sub> , C               | F                    | 1           | 1 | 0           | 0              | 0                                     | 0              | 1                      | 1,           | f <sub>1</sub>        | 0000              | 0            | Н   | 1,C    | (file 1) is shifted left.<br>The result is put into<br>file 1. Condition flags<br>are modified.                        |
| Shift right<br>Modify cond.<br>flag. Result<br>to f <sub>1</sub> . | (f <sub>1</sub> )@ <sub>R</sub> → F <sub>1</sub> ,C                | F                    | 1           | 3 | 0           | 0              | 0                                     | 1              | 1                      | 3            | f <sub>1</sub>        | 0000              | 0            | Н   | 1,R,C  | (file 1) is shifted right.<br>The result is put into<br>file 1. Condition flags<br>are modified.                       |



The eight-bit contents of the U register are ORed with the eight high order bits of the execute command to form an effective command. This provides a means of partially modifying the contents of a read only storage location. The ORing is performed before the output of the read only storage is gated into the R register. The meaning of bits present in positions 0-11 is dependent upon the desired effective operation code after the modification. Due to the lookahead feature of the read-only memory, the new contents of the U register are not available until after one machine cycle following the transfer of data to it.

The execute command provides a means for program modification of a command. This capability is used for many different functions, three of which are as follows:

Indexing of file registers in a program loop.

 Having a general purpose instruction which may take on different specific functions, such as load a register, add to the register, AND with the register, etc., depending on program variables.

• Selection of alternate file registers depending on program variables.

Sometimes a combination of two of the above is used.

The U register can be set with the load U command, or by being designated as the destination register of an operate class command, such as Add, Copy, etc.

For file register indexing, a separate file register is designated as an index register. It is loaded with an initial value, then incremented, with the result being put in U each time through the loop, until the loop is exited.

Examples of execute commands:

U register '84'

Execute Command '0021' ET 0, 2

Effective Command '8421' 
$$\begin{cases} (f_4) + (T) & f_4, T \\ AT & 4, T \end{cases}$$

Incrementing the U register value leaves the command the same, but changes the file register number to 5. If this continued to file F, the next increment would change the command to a subtract.

| U Register | 'F1'                         |    |
|------------|------------------------------|----|
| Execute    | This command is stored in RC | MC |
| Command    | ′0020′ E 0,2                 |    |
| Effective  | 'F120' Shift Right file 1    |    |
| Command    | H 1, R                       |    |

The meaning of the c field of the lower two hexadecimal digits in the execute command changes with the OP code value in the U register. Therefore the c field is left as a digit in the MNEMONIC for the execute command.

Commands can also be modified by the U register by using the operate commands with a 7 in the destination register. This method is advantageous if there are two variable functions to be done in one loop, with one U register setting. For example, a program may be indexing through a set of files where it is necessary to add to a file, and shift the same file in the same program loop. This could be mechanized as follows:

$$(f_F) + 1 \longrightarrow U$$
,  $f_F$ 
---- NOP

 $(f_0) + (T) \longrightarrow f_0$ , Destination = 7 (OR U with command)

 $(F_0) @_R \longrightarrow F_0$ , Destination = 7

The coding for this is:

|                 | Machine<br>Code | Mne | monic              |
|-----------------|-----------------|-----|--------------------|
|                 | '8F46'          | AU  | F, I               |
| another command |                 | . — |                    |
|                 | <b>'</b> 8027'  | AS  | 0, T Add to file 0 |
|                 | 'F027'          | HS  | 0, R Shift file 0  |

Assume U = '04' after the first command.

The effective commands following are:

| <b>'</b> 8427' | Add to file 4      |
|----------------|--------------------|
| 'F427'         | Shift file 4 right |

This method of command modification has the limitation of no destination register since the destination register code position is tied up selecting U as a modifier to the command. The execute command does not have this restriction.

#### **COMMAND REFERENCE TABLE**





| Mnemonic |     |                                                       |                  |
|----------|-----|-------------------------------------------------------|------------------|
| Command  |     | Operation Code Comments                               | Operand<br>Field |
| Control  | к   | 7· f c * r<br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0   |                  |
|          |     | 0 No Op                                               |                  |
|          |     | 1 Enter Sense SW                                      | -                |
|          |     | 2 Shift Right 4                                       |                  |
|          |     | 4 Enter Internal Status                               |                  |
|          |     | 7 Enter Console SW                                    |                  |
|          |     | 8 Clear I/O                                           |                  |
|          |     | 9 Set COXX (in MICRO 810/820)                         |                  |
|          |     | A Set DOXX (in MICRO 810/820)                         |                  |
|          |     | B Space Serial TTY                                    |                  |
|          |     | C Set CACK (in MICRO 810/820)                         |                  |
|          |     | D Set IACK (in MICRO 810/820)                         |                  |
|          |     | E Set DIXX (in MICRO 810/820)                         |                  |
|          |     | F Spare                                               |                  |
|          |     |                                                       |                  |
| Add      | Ar* | 8 f c * r                                             |                  |
| ,        |     | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0<br>1 x x x Link | L                |
|          |     | x 1 x x Add 1                                         |                  |
|          |     | x x 1 x Select T                                      | Т                |
|          |     | x x x 1 Modify Condition Flags                        | c c              |
|          |     |                                                       |                  |
| Subtract | Sr* | 9 f c * r<br>15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0    |                  |
|          |     | 1 x x x Link                                          | L                |
|          |     | x 1 x x Decrement                                     | D                |
|          |     | x x 1 x Select T                                      | т                |
|          |     | x x x 1 Modify Condition Flags                        | С                |
|          |     |                                                       |                  |

| Mnemonic        |            |                                        |                  |
|-----------------|------------|----------------------------------------|------------------|
| Command         | 7          | OperationCode Comments                 | Operand<br>Field |
| Memory          | Wr*<br>Rr* | A f c * r                              | -                |
|                 |            | 1 x x x Link                           | L                |
|                 |            | x 1 x x Decrement                      | D                |
|                 | -          | 1 1 x x Increment                      | 1                |
|                 |            | x x 1 x Half Cycle Operation           | н                |
|                 |            | x x x 1 Write Operation (supplied by C | P Code)          |
| Сору            | Cr*        | B f c * r                              |                  |
| -               |            | 1 x x x Link                           | L ·              |
|                 |            | x 1 x x Add 1                          | ı                |
|                 |            | x x 1 x Select T                       | т                |
|                 |            | x x x 1 Modify Condition Flags         | С                |
| OR              | Qr*        | C f c * r                              |                  |
|                 |            | 1 x x x Link                           | L                |
|                 |            | x 1 x x T                              | F                |
|                 |            | x x 1 x T                              | T                |
|                 |            | x x x 1 Modify Condition Flags         | C                |
| Exclusive<br>OR | Xr*        | D f c • r                              |                  |
|                 |            | 1 x x x Link                           | , <b>L</b>       |
|                 |            | х 1 х х Т                              | F                |
|                 |            | x x 1 x T                              | т                |
|                 |            | x x x 1 Modify Condition Flags         | · · · C          |

| Mnemonic |     |               |            |                 |                  |
|----------|-----|---------------|------------|-----------------|------------------|
| Command  |     | Operation Cod | le         | Comments        | Operand<br>Field |
| AND      | Nr* | E f c         | * r        |                 |                  |
|          |     | 1 x >         | x Link     |                 | L                |
|          |     | x 1 >         | x T        |                 | F                |
|          |     | x x '         | х Т        |                 | т                |
|          |     | x x >         | 1 Modify   | Condition Flags | С                |
| Shift    | Hr* | F f c         | * r        |                 |                  |
|          | ٠   | 1 x x         | x Link     |                 | L                |
|          |     | x 1 x         | x Insert 1 | l               | 1                |
|          |     | x x 1         | x Shift R  | <u>;</u>        | R                |

С

**Modify Condition Flags** 

# **CPU MICRO COMMAND REPERTOIRE**

|                              | Code                                                                                                                         | Mnemonic                                                            | Name                                                                                                                 | Operation                                                                                                                                                                                                                                                                                                        |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Literal<br>Class<br>Commands | 0XXX<br>10XX<br>11XX<br>11XX<br>11XX<br>12XX<br>15XX<br>15XX<br>1CXX<br>1CXX<br>16XX<br>17XX<br>2fXX<br>3fXX<br>4fXX<br>5fXX | E<br>LZ<br>LT<br>LM<br>LN<br>JP<br>JP<br>JP<br>LS<br>LF<br>AF<br>TN | Execute Load Zero Load M Load N Jump Jump Jump Load U Load Seven Load File (f) Add to File Test if zero Test if zero | OX is ORed with U Register No Operation XX replaced contents of T XX replaces contents of M XX replaces N & M is cleared to page 0 to page 1 to page 2 to page 3 XX replaces contents of U Internal Controls f = File number f = File number Skip on no bits match Skip on Any bits match                        |
|                              | 6fXX                                                                                                                         | СР                                                                  | Compare                                                                                                              | Skip on f + XX 28-1                                                                                                                                                                                                                                                                                              |
| Operate<br>Class<br>Commands | Code<br>7fC*r                                                                                                                | Mnemonic<br>K                                                       | Name<br>Control                                                                                                      | c Field (Binary)  0000 No Operation 0001 Enter Sense Switches 0010 Shift Right Four Bits 0100 Enter Internal Status 0111 Enter Console Switches 1000 Clear I/O Mode 1001 Control Output 1010 Data Output 1011 Space Serial TTY 1100 Concurrent Acknowledge 1110 Interrupt Acknowledge 1111 Data Input 1111 Spare |
|                              | 8fC*r                                                                                                                        | А                                                                   | Add                                                                                                                  | 0001 Modify Flags<br>0010 File + T<br>0100 Sum + 1<br>1000 Sum + Link Bit                                                                                                                                                                                                                                        |
|                              | 9fC*r                                                                                                                        | S                                                                   | Subtract                                                                                                             | 0001 Modify Flags<br>0010 File + T complement<br>0100 Inhibit Increment<br>1000 Difference + Link                                                                                                                                                                                                                |
|                              | AfC*r                                                                                                                        | R/S                                                                 | Read/Write<br>Memory                                                                                                 | 00XX Transfer<br>01XX Decrement<br>10XX Add Link<br>11XX Increment<br>XX1X Half Cycle<br>XXX1 Write (Not Read)                                                                                                                                                                                                   |
|                              | BfC*r                                                                                                                        | С                                                                   | Сору                                                                                                                 | XXX1 Modify Flags<br>XX1X Select T<br>X1XX Select + 1<br>1XXX Select Link                                                                                                                                                                                                                                        |
| If * = 0,<br>result of       | CfC*r                                                                                                                        | 0                                                                   | OR                                                                                                                   | XXX1 Modify Flags<br>XX1X Select T<br>X1XX Select T complement<br>1XXX Linked Zero Test                                                                                                                                                                                                                          |
| operation                    | DfC*r                                                                                                                        | X                                                                   | Exclusive OR                                                                                                         | Same as OR                                                                                                                                                                                                                                                                                                       |
| is placed<br>in file         | EfC*r                                                                                                                        | N                                                                   | AND                                                                                                                  | Same as OR                                                                                                                                                                                                                                                                                                       |
| (f).                         | FfC*r                                                                                                                        | H                                                                   | Shift                                                                                                                | XXX1 Modify Flags<br>XX1X Shift Right<br>X1XX Insert ONE<br>1XXX Insert Link                                                                                                                                                                                                                                     |

## **CHAPTER 3**

## INPUT/OUTPUT

### GENERAL DESCRIPTION

The CPU provides an extremely fast, elementary input/output capability. The data paths and control functions are simple elements that are sequenced from the control memory with flexible disciplines. The fact that the I/O element is very fast, 220 ns/step, microprograms (firmware) in the control memory can implement facilities with a high degree of versatility in timing, data paths and I/O capabilities such as priority interrupts, fully buffered data channels, macroprogrammable transfers, and special purpose communication multiplexer channels. This basic I/O element called the "Byte I/O Bus" is described in the following paragraphs. In addition, the direct memory occurs (DMA) and serial data interface are described.

#### BYTE I/O BUS

The byte I/O facility allows for data transfers over a party-line I/O bus under microprogram control. This I/O facility consists of a byte input bus, a byte output bus, and a three-bit I/O control register.

The I/O control register is loaded by bits 6-4 of the control command. The contents of the I/O control register define an I/O bus mode. The I/O control register outputs may be decoded to form individual control signals defining the type of transfer being performed on the byte I/O bus and the state of the serial interface output. Of the eight possible states of the I/O control register, one represents no activity on the bus, three are output modes, and four are input modes. One of the output modes removes the MARKing current from the serial interface output a SPACE to be output.

The byte I/O control modes are given in Table 10.

Table 10. Byte I/O Control Modes

| Control C   | Control Command |     |     |   |   |   |   |    | _   |      |   |       |      |                              |
|-------------|-----------------|-----|-----|---|---|---|---|----|-----|------|---|-------|------|------------------------------|
| 7           | 1               | f   |     | С |   | * | r |    |     |      |   |       |      |                              |
| 15 14 13 12 | 11 10           | 9 8 | 7   | 6 | 5 | 4 | 3 | 2  |     | ਰ_   |   | Hex   | Mode | Control Activity             |
|             |                 |     | 0   | 0 | 0 | 0 |   |    |     |      |   | 0     |      | No Operation                 |
|             |                 |     | 0   | 0 | 0 | 1 |   |    |     |      |   | 1     |      | Enter Sense Switches         |
|             |                 |     | 0   | 0 | 1 | 0 |   |    |     |      |   | 2     |      | Shift "f" Right Four Places  |
|             |                 |     | 0   | 1 | 0 | 0 |   |    |     |      |   | 4     |      | Enter Internal Status        |
|             |                 |     | 0   | 1 | 1 | 1 |   |    |     |      |   | 7     |      | Enter Console Switches (0-7) |
|             |                 |     | - ī | ō | ō | 0 |   |    | _   |      | _ | _ 8 _ | 0    | Clear I/O Mode               |
| OUTPUT      | • '             |     | 1   | 0 | Ó | 1 |   |    |     |      |   | 9     | 1    | SPARE (*)                    |
| FUNCTION    | ONS             |     | 1   | Ō | 1 | 0 |   |    | _   |      |   | Α     | 2    | SPARE (*)                    |
| `           |                 |     | 1   | Õ | 1 | 1 |   | 1/ |     | ITRO |   | В     | 3    | Space Serial Interface       |
|             |                 |     | _1  | 1 | ō | 0 |   |    | 011 |      | _ | С     | 4    | SPARE (*)                    |
| INPUT       | •               |     | 1   | 1 | Ō | 1 |   |    |     |      |   | D     | 5    | SPARE (*)                    |
| FUNCTI      | 2MO             |     | 1   | 1 | 1 | Ó |   |    |     |      |   | Ε     | 6    | SPARE (*)                    |
|             | J. 13           |     | 1   | 1 | 1 | 1 |   |    |     |      |   | F     | 7    | SPARE                        |

<sup>\*</sup>These functions are used in the MICRO 810 and 820 I/O systems.

When the c field equals hexadecimal 8-F, the operations are associated with external input/output, and the three low order bits of c are placed in the I/O control register.

This three-bit register generates the control signals for the I/O bus by a decoding of the register outputs. It is loaded and cleared by a control command and therefore the timing of I/O control signals is under command control. There are three output modes and four input modes. The high order bit of the register is the input flag. When this bit is a 1-bit the input bus is substituted for the T register inputs, thus providing a source of data when executing an external I/O control command. On the same operation, data can be moved from the designated file register or the input bus, as determined by the current contents of the I/O control register, to the designated file or destination register. The data source is specified as follows:

| Designated File Register<br>(Output Data or Control)<br>Input Bus<br>(Input Data or Control) |
|----------------------------------------------------------------------------------------------|
|                                                                                              |
|                                                                                              |

| Mode       | Control Activity | Comments                                                                                                                                                                                                                                                                           |
|------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | Clear I/O Mode:  | The I/O control register is cleared. Data from<br>the designated file or Input bus can be trans-<br>ferred to the designated file register and<br>register (R).                                                                                                                    |
| <b>1-7</b> | Set I/O Mode:    | The I/O Control register is loaded with the three low order bits of c placing it in one of seven I/O bus or serial interface modes. These modes are described above. Data from the designated file or Input bus can be transferred to a designated file register and register (r). |

Mode

NOTE: Once an I/O control register mode has been SET, an I/O clear mode must be executed to change the I/O control register mode of operation.

### Internal Status - Interrupt

Eight internal status bits are provided to designate a particular internal interrupt condition. When any of the internal status bits are a 1-bit, the internal interrupt flag (bit 4) in the file register 0 is also a 1-bit. This flag bit is tested by the microprogram to detect the presence of the internal interrupt condition. The internal status bits are entered via the A bus into the selected file register by a control command. The eight internal status bits have the assignments given as follows:

#### Internal Status Bits

|                                      | Internal Status                                                                              |                                                                                                                                                     |  |  |  |  |  |  |  |
|--------------------------------------|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Bit                                  | Without Processor Option Bd                                                                  | With Processor Option bd                                                                                                                            |  |  |  |  |  |  |  |
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | Console Interrupt SPARE (DMA)* SPARE SPARE SPARE SPARE SPARE SPARE Console Halt Switch SPARE | Console Interrupt SPARE (DMA)* Real Time Clock Interrupt SPARE Memory Parity Error Interrupt SPARE Console Halt Switch Power Fail/Restart Interrupt |  |  |  |  |  |  |  |

<sup>\*</sup>Not available as SPARE if DMA is installed.

All the internal status bits except the console interrupt and halt are associated with processor options and may be reassigned for special applications.

#### **Bus Lines**

The byte I/O bus consists of

- input data lines
- input control lines
- output data lines
- output control lines

The electrical implementation of the input and output bus lines is shown in Figure 14.

### Input Lines

The data lines are an input to the B bus gating. The control lines are input to bits of file register 0. The input lines are ground TRUE signals which are properly terminated at the processor. If the bus is carried out of the basic enclosure it also must be terminated at the remote end. Each peripheral device gates information onto the bus by means of open collector type 944 DTL drive circuits. Up to 15 drivers may be connected to each line.

The logic level on the twisted pairs are:

One - 0 Volts Zero - +3 Volts

# \*Typical Byte I/O Control Modes (MICRO 810/820)

| Mode | Control Activity       | Term  |
|------|------------------------|-------|
| 0    | None                   | None  |
| 1    | Control Output         | coxx/ |
| 2    | Data Output            | DOXX/ |
| 3    | Space Serial Interface | SP1X/ |
| 4    | Interrupt Acknowledge  | IACK/ |
| - 5  | Concurrent Acknowledge | CACK/ |
| 6    | Data Input             | DIXX/ |
| 7    | Spare                  | SP3X/ |



**TRANSMITTERS** 

RECOMMENDED CONFIGURATION N≤ TEN GATES M≤ FIFTEEN GATES

Figure 14. Bus Lines

### **Output Lines**

The output data lines originate with the FALSE output of the T register. The output control lines originate with the I/O control register. If all peripheral devices on the bus are local to the enclosure, and the bus does not leave the enclosure, then the bus is standard logic levels and no DTL drivers and terminations are used. It may be necessary to repower the signals. If the bus leaves the enclosure, an I/O control board is required to provide type 944 DTL output drivers and decoding the control register. The cable length can be up to 30 feet in length and must be terminated at the remote end. Up to 15 receivers can be accommodated. The levels on the twisted pairs are:

One - 0 Volts Zero - +3 Volts

| Control | LLin | ies In |
|---------|------|--------|
| COLLIG  |      |        |

### Typical Use in the System

| External | Interrupt | (FIN | 1/): | А   | peripr | nera |
|----------|-----------|------|------|-----|--------|------|
|          |           |      |      | ron | TILECT | an   |

A peripheral device makes this line low to request an interrupt of the macroprogram. The microprogram must respond with an I/O acknowledge (mode 5)\* signal. This line is bit 7 of the file register 0 where a 1-bit indicates an external interrupt request.

I/O Reply (ERPY/):

A peripheral device makes this line low in response to an I/O operation when closed-loop operation is required. This line is bit 5 of the file register 0.

I/O Request (ECIO/):

A peripheral device makes this line low in order to request a concurrent data transfer. The microprogram must respond with an I/O acknowledge (mode 5)\* signal. This line is bit 3 of the file register 0.

# File Register 0 Flags

| Bit                                  | Flag                                                                                                                                                                                                                                                                                                       |
|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | <ul> <li>Overflow Result Condition</li> <li>Negative Result Condition</li> <li>Zero Result Condition</li> <li>Concurrent I/O Request Line** or (SPARE)</li> <li>Internal Interrupt</li> <li>I/O Reply Line** or (SPARE)</li> <li>Serial Interface</li> <li>External Interrupt Line** or (SPARE)</li> </ul> |

<sup>\*\*</sup>If a standard CPU interface is not used, these Flags may be used as SPARE bits.



Figure 15, I/O Interface Block Diagram

Since the function code is only 3 bits instead of 4 it is effectively multiplied by 2 when put into the device and function code word.

Description of functional block diagram (Figure 15).

The control decoder receives the IOXX lines from the control line receivers and first decodes them into COXX, DOXX, and DIXX. These three are ORed to produce KIXX which is used to set and reset function and connect latches.

The device address decoder becomes active whenever the boards address appears on the 0D00-0D04 lines. DAXX is active only when COXX is active. Otherwise DAXX would become active every time the device address appeared on the output data lines.

The function latches set or reset every time there is a KIXX pulse. The output functions FN0X, etc., are not enabled unless CONN is active. The functions are used to enable the output latch.

The connection latch is set when the board detects its device address and COXX is active. It is reset on the trailing edge of the next DIXX or DOXX pulse.

The connection latch enables the functions and the input selection gate.

The input selection gates place the input data onto the input bus during DIXX whenever the CONN latch has been set indicating that this board has been addressed.

The output latches are updated to the values on the ODOX lines during DOXX whenever the corresponding function code FNNX is active.

#### Serial Interface

The processor contains a serial interface capable of communicating with a full duplex teletype. The input from the teletype appears as bit 6 of file register 0 where a 1-bit indicates that the teletype is transmitting a SPACE. The output to the teletype normally transmits a 20 milliampere MARKing current which can be keyed off to send a SPACE signal by placing the I/O control register in mode 3. Character assembly and disassembly, including all timing and synchronization, are performed by microprogramming.

The serial interface is standard. A teletype or CRT wired for 4-wire full duplex 20 milliampere operation may be directly connected to the cable provided with the machine. Other types of serial I/O devices also may use this condition.

# **Direct Memory Access**

The direct memory access (DMA) interface allows for direct connection to the memory address, data and control busses. Within the machine enclosure there is a circuit board slot which is reserved for the DMA. This board may contain a channel to which a number of peripheral devices are connected, or a device controller which has direct memory access capability. Generally the DMA system will be customized for special applications.

The maximum data transfer rate is 909,000 bytes per second. The DMA I/O takes precedence over the processor for memory operations. The DMA must supply its own address control.

### Typical Byte I/O Interface

To illustrate byte I/O programming, a typical interface has been selected which has minimum functions for transferring bytes in and out of the computer. A more complex device, such as a tape controller, or card reader, using the byte I/O function would contain logic similar to this for transferring control, status, and data between the controller and the MICRO 800.

The byte I/O interface described contains the following basic functions.

- Line receivers and drivers
- Device address decoder
- Function latch and decoder
- Connection latch
- Input multiplexer
- Input selection gates
- Output latches
- Control decoder

For the following examples assume that the device code is 00001. This results in the following device and function codes:

| Function Code |   | Device and Function Code |     |  |
|---------------|---|--------------------------|-----|--|
| Binary Hex    |   | Binary                   | Hex |  |
| 000           | 0 | 000 0 0001               | 01  |  |
| 001           | 1 | 001 0 0001               | 21  |  |
| 010           | 2 | 010 0 0001               | 41  |  |
| 011           | 3 | 011 0 0001               | 61  |  |

For summary purposes the logic terms used in the I/O interface example (which are standard for MICRO 800 interfaces) are defined in Table 11.

Table 11. Definition of Terms in I/O Interface Block Diagram

| coxx      | FUNCTION AND DEVICE CODE OUTPUT CONTROL PULSE                                       |
|-----------|-------------------------------------------------------------------------------------|
| DOXX ·    | DATA OUTPUT CONTROL PULSE                                                           |
| DIXX      | DATA INPUT CONTROL PULSE                                                            |
| кіхх      | INTERFACE CLOCK PULSE FORMED BY ORing COXX, DOXX, and DIXX                          |
| DAXX      | DETECTED DEVICE ADDRESS ENABLED BY COXX                                             |
| 0D00-0D07 | OUTPUT DATA LINES RECEIVES FROM MICRO<br>800 T COMPLEMENT REGISTER                  |
| FN0X-FN7X | LATCHED AND DECODED FUNCTIONS ENABLED BY CONN.                                      |
| FD05-FD06 | LATCHED BUT UNDECODED FUNCTION BITS                                                 |
| CONN      | CONNECT LATCH INDICATING THAT THE I/O BOARD HAS RECEIVED ITS DEVICE CODE WITH COXX. |
| MRES      | MASTER RESET FROM MICRO 800                                                         |
| 101X-103X | 3 BITS FROM CONTROL OUTPUT REGISTER                                                 |
| DIG MUX   | DIGITAL MULTIPLEXER                                                                 |

See Figure 16 for I/O signal source.



Figure 16. CPU Input/Output Signals

### **EXAMPLES OF I/O MICROPROGRAMMING**

Example 1. For the first Input/Output example the timing of events and the microprogram routine are described for outputting a byte from the MICRO 800 to latch 0 in the interface board with device code 01.

Timing Diagram: Output a byte to latch register 0.



Microprogram: For outputting a data byte from the MICRO 800 to device 1, byte 0.

Example 1.

|                                                | I            |              | t ·                    |  |
|------------------------------------------------|--------------|--------------|------------------------|--|
| FLOW CHART                                     | MACHINE CODE |              | ASSEMBLY LANGUAGE CODE |  |
| . 🗡                                            | L            | COMMAND      | ,                      |  |
| DEVICE & FUNCTION CODE → T ('01' → T)          | 040          | 1101         | LT X'01'               |  |
| SET COXX                                       | 041          | 7090         | К 0,9                  |  |
| 3 CLOCK DELAY*<br>NO OP +<br>JMP TO NEXT COMM. | 042<br>043   | 1000<br>1444 | LS X'00'<br>JP X'044'  |  |
| RESET COXX                                     | 044          | 7080         | K 0,8                  |  |
| GET OUTPUT DATA<br>FROM CORE MEMORY            | 045          | A1C3         | RN 1, 1                |  |
| SET DOXX                                       | 046          | 70A0         | K 0, 10                |  |
| 3 CLOCK DELAY*                                 | 047<br>048   | 1000<br>1449 | LS X'00'<br>JP X'49'   |  |
| RESET DOXX                                     | 049          | 7080         | K 0,8                  |  |
| REMOVE DATA FROM T                             | 04A<br>ANY   | INSTRUCTION  | WITH T AS              |  |
| DESTINATION                                    |              |              |                        |  |

<sup>\*</sup>This is the standard delay in the MICRO 810 to generate an 880 ns COXX and DOXX. It could be shorter if the interface is in the computer. Housekeeping can be done on delay clocks.

Example 2. For the second input/output example, the timing of events and the microprogram are described for inputting a byte from input byte 2 of device 01 to file register 1 and T.



Microprogram for example 2 inputting a data byte from device 01, byte 2 to  $\ensuremath{f_1}$  and T.

| FLOW CHART                                    | MACHINE CODE |              | ASSEMBLY LANGUAGE CODE |  |
|-----------------------------------------------|--------------|--------------|------------------------|--|
| 1                                             | L            | COMMAND      |                        |  |
| DEVICE & FUNCTION CODE TO T                   | 060          | 1141         | LT X'41'               |  |
| SET COXX                                      | 061          | 7090         | к 0,9                  |  |
| 3 CLOCK DELAY<br>NO OP +<br>JMP TO NEXT COMM. | 062<br>063   | 1000<br>1464 | LZ X'00'<br>JP X'64'   |  |
| RESET COXX                                    | 064          | 7080         | к 0,8                  |  |
| SET DIXX                                      | 065          | 70E0         | К 0,14                 |  |
| 2 CLOCK DELAY                                 | 066          | 1467         | . JP X'67'             |  |
| INPUT DATA USING COPY T COMMAND               | 067          | B121         | СТ 1, Т                |  |
| RESET DIXX                                    | 068          | 7080         | К 0,8                  |  |
| NEXT<br>INSTRUCTION                           | 069          | ANY INST     | RUCTION CAN BE NEXT    |  |
| 1                                             |              |              |                        |  |

## Example 3. Special Input Function

To achieve minimum input time and still achieve one clock delay after setting DIXX use the following:

| K  | 0, 14    | Set DIXX                                                        |
|----|----------|-----------------------------------------------------------------|
| LF | K, X'FF' | Set file 1 = all ones and generate<br>1 clock delay             |
| Κ  | 1, 11    | Reset DIXX and simultaneously 'and' the input bus with (file 1) |
|    |          |                                                                 |

Example 4. High speed multiple byte output to a special interface. Output bytes from files 1, 2, 3, and 4 to a 32 bit register on a special interface unit is an I/O connector. Use DOXX followed by a load zero command (CGOX). DOXX is used to distinguish from input command, followed by 4 file to T commands:



For this a very simple interface can be designed to transfer 32 bits of data from the MICRO 800 to an interface in only 1.54 microseconds.

### **CHAPTER 4**

### CENTRAL PROCESSOR OPTIONS

In addition to the option hardware, proper firmware must be provided to implement system action and response. This firmware may be designed specially for a given application. Standard firmware for each option described below is available.

#### Real-Time Clock

The real-time clock option provides an internal interrupt at a crystal-controlled timing rate. This may be used at the macroprogramming level for a real-time clock. The timing is derived from the processor internal clock which is divided down by some integer number less than  $2^{13}$ , as determined by optional strapping on the option board.

When the timing signal occurs, it provides an internal interrupt by setting condition flag bit 4 and bit 2 of the internal status byte. The timing signal internal interrupt may be disabled and enabled by commands 1710 and 1720 respectively. The microprogram must detect the internal interrupt and take appropriate action. Special real-time clock interrupt handling firmware is available.

### Power-Fail/Automatic Restart

The power-fail and automatic restart option provides the following:

- 1. An internal interrupt by setting condition flag bit 5 and bit 7 of the internal status byte upon detection of loss of primary power.
- 2. A machine reset when the computer is halted after loss of primary power.
- 3. A machine reset for 200 milliseconds after power is applied.
- 4. Automatic switch to run mode after the power-on reset period.
- Power-restart interrupt immediately after automatic switch to run mode.

A power-fail interrupt detected while the machine is in the run mode can be used to cause the machine registers to be stored and to bring the processor to a halt. The automatic machine reset that follows the halt and the one following power-on prevents any spurious operations in the core memory. At power-on, the machine reset clears the L register causing the machine to start at read-only memory location 0. The power-fail interrupt which occurs at this time can be detected and treated as a restart interrupt to cause a restoring of the machine registers. Standard power-fail/automatic restart interrupt firmware is available.

### **CHAPTER 5**

# **OPERATOR CONTROLS**

#### CONSOLES

Two control console options are available: system console and basic console. These consoles differ in their number of displays and controls. This range of consoles permits the user to tailor the cost to meet the control and display capability required for a particular application. The system console is shown in Figure 17.

### System Console

The system console provides complete control and display facilities. It is primarily used for maintenance, system and firmware checkout. This console provides for display of the MICRO 800 registers in addition to the functions of the basic console. The features include:

- Run and halt indicators
- Display of A-bus
- Display of M, N, and L registers
- Display of output of read-only memory
- Four sense switches
- Six control switches, including run, step, interrupt, clock reset, and save
- Manual command execution
- Power on-off

### **Basic Console**

The basic console provides minimal control capability and is designed for dedicated system application where operator control is not required. The features include:

Run and halt indicators



Figure 17. System Console

- Four sense switches
- Six control switches, including run, step, interrupt, clock, reset and save
- Power on-off

### **DISPLAYS**

### Run Lamp

The run lamp is illuminated when the processor is running.

### Halt Lamp

The halt lamp is illuminated when the power is on and the process is not running.

#### **SWITCHES**

### Display Selector

These seven interlocked switches select the register or bus to be displayed on the system console. The displays which can be selected are: L register, M register, N register, eight high order bits of the read-only memory output, eight low order bits of the read-only memory and the A bus. When the machine is halted the output of the read-only memory is the same as the contents of the R register, and is the next command to be executed.

#### Command

These 16 alternate action switches are substituted for the read-only storage on the system console when the SELECT switch is in the PANEL position. Depressing the CLOCK switch causes the command set on the switches to be executed. The command may also be executed repeatedly by depressing the RUN switch. These switches are used to gate registers to the A bus display and for entering data into the file and registers.

#### Select

This alternate action switch selects the console panel command switches (PANEL) or the read only memory (ROM) as the command to be executed next. This switch is not available on the basic console.

#### Sense

The four alternate action sense switches are available on both consoles. The state of these switches may be transferred to a file register or machine register by the control command. These switches may be used to provide manual control of micro level and macro level programs.

#### Run

This momentary contact switch places the processor in the run mode causing it to execute microcommands.

### Step

This momentary contact switch places the processor in the run mode and as long as the switch is depressed causes an internal interrupt. The halt internal interrupt is bit 7 of the internal status. This switch is normally microprogrammed to cause a processor halt. Since the processor is forced to run when the switch is depressed, the machine can be microprogrammed to cause a single macro instruction to be executed.

### Interrupt

This momentary contact switch places the processor in the run mode and causes an internal interrupt. The console interrupt is bit 0 of the internal status. This switch is normally microprogrammed to cause a console interrupt.

#### Clock

This momentary contact switch causes the processor to execute a single microcommand. If the processor is running at the time the switch is depressed, the processor will come to a forced halt following the current microcommand execution.

#### Reset

This momentary contact switch halts the processor and clears the L register, I/O control register and other control flip flops. The reset is made available to I/O devices. Since the current microcommand execution will not be completed, the computer should not be stopped by this switch.

#### Save

This alternate action switch is the same as the RESET switch but can be set on providing a continuous reset. If this switch is on at the time the power is turned on or off the contents of the memory will not be lost or altered.

### **OPERATING PROCEDURES - SYSTEM CONSOLE**

### **Execution of Commands from the front panel of the System Console**

Most microcommands can be executed from the front panel by using the command switches to simulate read only memory. These commands can be used to check-out most of the MICRO 800 logic, and also to gain familiarity with the microcommand set. The following list of commands is a minimum that should be tried out when first becoming acquainted with the MICRO 800.

For the examples all command switch settings and displays are shown in hexadecimal.

- 1. Loading and stepping the L register
  - a. Load L
    - 1) Set CLOCK, RESET
    - 2) Set 'SELECT' to panel
    - 3) Select L display
    - 4) Set the following commands into the command switches, and press the CLOCK switch once for each

| Setting Switches | Display |
|------------------|---------|
| 14AA             | 0AA     |
| 1455             | 055     |
| 15FF             | 1FF     |
| 1C11             | 211     |
| 1DEE             | 3EE     |

### b. Step L

- 1) Set SELECT to ROM
- 2) Set RESET
- 3) Select L display
- Each time the CLOCK switch is pressed, the L count should increment, skip, or jump. If no ROM board is plugged in, the L count will step.

### 2. Test M and N

- 1) Set SELECT to PANEL
- 2) Display to M or N
- 3) Set the following command into the command switches and press the clock switch once for each.

| 1255 | Load M | M = 55        |
|------|--------|---------------|
| 13AA | Load N | N = AA, M = 0 |

Try other values and repeat.

- 3. Test ROM and L register (with 810 firmware).
  - 1) Set SELECT to ROM
  - 2) Set RESET
  - 3) Select L, or R2 or R1

| 4) <u>L</u> | <u>R2</u> | <u>R1</u>   |                  |
|-------------|-----------|-------------|------------------|
| 000         | BF        | 02 <b>)</b> |                  |
| 001         | 2B        | 00          | Repeatedly press |
| 002         | 2A        | 00          | the CLOCK        |
| 003         | 40        | 10 J        |                  |

After this, the L value depends on computer register states, because of conditional skips and jumps.

- 4. Test the T register
  - 1) Set SELECT to PANEL
  - 2) Set DISPLAY to D (A bus)
  - 3) Set the following sequences into the command switches and press the CLOCK switch.

| 11AA | CLOCK | Load T                         |
|------|-------|--------------------------------|
| B020 |       | Display $T = AA$ with copy $T$ |
| 1155 | CLOCK | Load T                         |
| B020 |       | Display $T = 55$ with Copy $T$ |

Try other values and repeat.

- 5. Test the File Registers
  - a. Load and Read each File.
    - 1) Set SELECT to PANEL
    - 2) Set DISPLAY to D (A bus)

Set the following sequences into the command switches and press the CLOCK switch.

21AA CLOCK Load file 1 with 'AA'
C100 OR 0 with file 1 (Display file 1)

OBSERVE 'AA'

Repeat with file numbers 2-F and different data patterns.

- b. Load all files first, and then read back.
  - 1) SELECT to PANEL
  - 2) DISPLAY to D (A bus)
  - 3) Set command switches to 2111, press CLOCK, change command switches to 2222, press CLOCK. Repeat up to 2FFF.
  - 4) Display file 1 with 8100 or C100, and repeat for 8200, 8300, etc., to 8F00.
- c. Test Add to File
  - 1) SELECT to PANEL
  - 2) DISPLAY to D
  - 3) Set command switches to 2100 (clear file 1), press CLOCK.
  - 4) Set command switches to 3101 (Add 1 to file 1). Display will be at 01 before CLOCK is pressed. Each time CLOCK is pressed, display will increment.
  - 5) Repeat for different file values and increment sizes (3102, etc.).
- 6. Test various Arithmetic, Logic and Shift Commands...
  - 1) SELECT to PANEL
  - 2) DISPLAY to D
  - a. ADD

| 1101 | CLOCK | 01——►T                                             |
|------|-------|----------------------------------------------------|
| 2101 | CLOCK | 01 <del>≻</del> f <sub>1</sub>                     |
| 8120 |       | $(f_1)+(T) \longrightarrow f_1$ Initial display=02 |

Each time CLOCK is pressed display will increment.

1101 CLOCK 01
$$\longrightarrow$$
T  
2101 CLOCK 01 $\longrightarrow$ f<sub>1</sub>  
8121 (f<sub>1</sub>)+(T) $\longrightarrow$ f<sub>1</sub>, T Initial display=02

Each time CLOCK is pressed display value will double.

2100 CLOCK 8140 (file 1)+1→ file 1 Display = 01

Repeat with different initial values in f1 and T.

Change destination register to M and N and display these directly while repeating above tests.

### b. SUBTRACT

1101 CLOCK 01—
$$\rightarrow$$
T  
21FF CLOCK FF— $\rightarrow$  f<sub>1</sub>  
9120 (f<sub>1</sub>)-(T)— $\rightarrow$  f<sub>1</sub> Display = FE

Each time CLOCK is pressed display value will decrement.

Repeat for other values in f1 and T.

# c. Logic Functions

|      | 11AA | CLOCK | AA <del></del> T                 |
|------|------|-------|----------------------------------|
|      | 21CC | CLOCK | cc <del>−−</del> f <sub>1</sub>  |
| OR   | C120 | C140  | Display result of logic function |
| EXOR | D120 | D140  |                                  |
| AND  | E120 | E140  |                                  |

### Table of Values:

| c field = 2         | OR                   | EX OR                | AND                  |
|---------------------|----------------------|----------------------|----------------------|
| T<br>f <sub>1</sub> | 10101010<br>11001100 | 10101010<br>11001100 | 10101010<br>11001100 |
| Display             | 11101110             | 01100110             | 10001000             |
| c field = 4         |                      |                      |                      |
| Ŧ                   | 01010101             | 01010101             | 01010101             |
| f <sub>1</sub>      | 11001100             | 11001100             | 11001100             |
|                     | 11011101             | 10011001             | 01000100             |

# d. Shift

| 1) | 2101 | CLOCK | 01—→ file 1                |
|----|------|-------|----------------------------|
|    | F100 |       | Display bit shifted left 1 |

Each time CLOCK is pressed the bit will shift left one place.

| 2) | 2100 | CLOCK | 00                         |
|----|------|-------|----------------------------|
|    | F100 | CLOCK | Clears link                |
|    | 2101 | CLOCK | 01——►f <sub>1</sub>        |
|    | F185 |       | Display bit shifted left 1 |

Repeated pressing of CLOCK will cause a left shift with end around carry.

| F120 | Causes Right Shift      |         |
|------|-------------------------|---------|
| F140 | Causes Left Shift inser | t ones. |

### 7. Load and Read Memory

This requires setting M and N, loading T, and executing a write memory command to load. To read, set M and N, execute a read memory command, and a B020 to display T. Set SELECT on PANEL and display on D.

Load core location 0210 with AA.

Read core location 0010

#### 8. Enter Sense Switches

Set command switches to 7010, sense switch settings will appear on display as follows:

# 9. Shift file right 4

Set SELECT to PANEL

### 10. Test U Register

The lower 4 bits of the U register can easily be loaded and tested by observing its effect on a file display command. First load all files in sequence with the file number for a value. Then load U with a Cf value, followed by an execute command, with 0000 set on the command switches. This will cause the value of file f to be displayed.

- 1) Set SELECT to PANEL
- 2) DISPLAY to D
- 3) Load files
  - 2101 CLOCK 2202 CLOCK 02-----f<sub>2</sub> (repeat for all files up to F)
- 4) Load U

16C1 CLOCK C1----> U

- 5) Set 0000 on command switches Display 01 from file 1
- 6) Load U

16C2 CLOCK C2----- U

7) Set 0000 on command switches Display 02 from file 2

Repeat 6 and 7 for all files to F.

### 11. Set and Display Condition Flags and Link

The flags can be displayed by the command C000 (file  $0 \lor 0 \longrightarrow \text{file } 0$ ), and the link can be displayed by B080. Copy link—→no destination, which displays the link as LSB on the A bus.

- 1) Set SELECT to PANEL
- 2) DISPLAY to D
  - 3) Depress CLOCK for first two instructions only:

| Load File     | 2101 |               | 2100 | zero condition |
|---------------|------|---------------|------|----------------|
| Add to file   | 8110 |               | 8100 |                |
| Display link  | B080 | Link = 0      | B080 | Link = 0       |
| Display flags | C000 | All flags = 0 | C000 | Flag = 1       |
|               | 2180 | Negative      | 217F | Overflow       |
|               | 8110 | cond.         | 8150 |                |
|               | B080 | Link = 0      | B080 | Link = 0       |
|               | C000 | Flag = 1      | C000 | Flag = 1       |
|               | 21FF | Zero cond.    |      | •              |
|               | 8150 |               |      |                |
| -             | B080 | Link = 1      |      |                |
|               | C000 | Flag = 1      |      |                |

# Condition Flag Display (File zero)



# **Explanation of Codes**

| 8110 | Add 0 to file 1   | Update Condition flags   |
|------|-------------------|--------------------------|
| 8150 | Add 1 to file 1   | Update Condition flags   |
| B080 | Copy Link to no c | lestination except A bus |
| C000 | OR file 0 with no | operand                  |

### 12. External Internal Status

This instruction will demonstrate sensing of the console STEP, and console interrupt inputs.

- 1) Set SELECT to PANEL
- 2) DISPLAY to D

Command switches

7040



Press console STEP and interrupt switches, and observe changes in bits  $\bf 0$  and  $\bf 6$ .

### **CHAPTER 6**

# PROGRAMMING SYSTEMS FOR MICRO 800 FIRMWARE DEVELOPMENT

The programming systems for the MICRO 800 computer permits the user to develop special application firmware at a cost and turnaround time that is now comparable to software development in competitively priced fixed instruction computers. This chapter describes the assemblers, operating systems, simulator and use of the Alterable Read Only Memory system which are used as standard aids in microprogramming. In addition, procedures for checkout and debugging of microprograms are provided.

### **AP800 CROSS ASSEMBLER**

AP800 is a symbolic assembly program for the MICRO 800 computer. The assembler provides for symbolic addressing and mnemonics for machine and assembler instructions. This program is written in FORTRAN IV and may be adapted to many computer systems. The MICRO 800 source program is entered by punch cards and the output of the assembler includes an assembly listing, read only storage diode map, and an object program card deck.

#### MAP800 CROSS ASSEMBLER

MAP800 is a two pass symbolic assembly program which allows for assembly of MICRO 800 microprograms on the MICRO 810 or MICRO 820 computer. It is designed to operate using an ASR 33 Teletype with paper tape reader and punch. Output consists of an assembly listing and an object program paper tape for use by the MICRO 800 simulator program, SIM800.

The assembly language includes the following features:

Address Arithmetic — Decimal and hexadecimal numbers, symbolic addresses, and arithmetic expressions.

**Listing Control** — The format of the listing may be controlled with comment cards included.

**Diagnostics** — Diagnostics for source program errors included in the output listing.

Option Flags — Single letter flags to signify options to microcommands.

### SYMBOLIC LANGUAGE

The source language is a sequence of symbolic commands, called statements. Each statement is written on a single line and may consist of from one to four entries: a name field, an operation field, an operand field, and a comments field.

#### Name Field

The name field entry is always a symbol. The first character of a symbol is alphabetic or a period; subsequent characters may be

alphabetic, numeric, or a period. A name entry is usually optional. When an asterisk, \*, appears as the first character the remainder of the line is considered as comment. The type of command determines the legal content of the name field.

### **Operation Field**

The operation field entry is a mnemonic operation code specifying the machine command or assembler instruction. The field begins with the first non blank character following the name field in paper tape or with column 8 in cards. All machine command mnemonics are two characters except those of the operate class where no destination register is designated. The operate class commands have a basic single letter mnemonics. If the result of the operation is to be sent to a machine register then the register identifier character, r, is appended as the second character of the mnemonic. Register identifier characters are shown below. An asterisk, \*, is appended to the mnemonic if the result of the operation is not to be placed in the designated file register. Some of the mnemonics accepted by the assembler are commonly used forms of other commands.

| Register<br>Designator               | r                               | Register                                                                                                                                                                                                   |
|--------------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | T<br>M<br>N<br>L<br>K<br>U<br>S | None. T Register. M Register. M Register. N Register. L Register Addresses: 000-0FF and 200-2FF. L Register Addresses: 100-1FF and 300-3FF. U Register. U Register ORed in command (Except for K command). |

# Operand Field

The operand field entries provide the file register designators, literals, and option bits for the machine commands. The operand field may start anywhere following the operation field. When punched in cards, column 14 is the normal starting column. It is terminated by the first blank. One or more operands, separated by commas may be written, depending on the needs of the command. All entries in the operand field, except the single character option bit identifiers for the operate class commands, are expressions. An expression is a symbol, decimal number, or hexadecimal number, or a combination of these terms made by + and — operators.

The following single character option identifiers, designators and literals may appear in the operand field.

- L Link Control.
- I Add one or insert one on Shift.
- D Decrement one.
- T T register operand.
- F Complement of T register operand.
- H Half cycle memory operation (otherwise full cycle).
- R Right shift (otherwise left shift).
- C Set condition flags.

- f File register designator (0-15)
- c Option code (0-15)
- n Literal (8, 9, or 10 bit)

#### Comments Field

Comments describing the information about the program may be inserted between the end of the operand field and column 72. All characters, including spaces, may be used in writing a comment. If the listing is printed on a teletype, only the first 53 characters of the source line are printed.

#### MACHINE COMMANDS

Machine commands are expressed by a one or two character mnemonic code in the operation field. The required operands depend on the command type. The four syntax types are described below. Examples of the method of writing machine commands in the assembly language are shown in the sample listing in section 5.

### Load Register Commands (Command 1)

All commands of this syntax type have two character mnemonics beginning with L, except for the jump command. The second character is the register identifier character. The operand field of all commands of this type except jump must contain a single operand which is an expression, whose value is less than 1024 and greater or equal to -256. It is evaluated modulo 256. The jump commands must contain an operand expression which has a positive value less than 1024.

#### Literal-File Commands

The commands of this syntax group (commands 2-6), have two character mnemonics and require two operands. The first operand is an expression which designates a file register (f) and must be in the range 0-15. The second operand (n) is an expression which must be less than 1024 and greater than or equal to -256. It is evaluated modulo 256.

#### **Execute and Control Commands**

The commands of this syntax group have operation code mnemonics identical to those of the next group, and require two operands. The first operand is an expression which designates a file register (f) and must be in the range 0-15. The second operand (c) is an expression which designates the option bits (7-4) and must be in the range 0-15.

### Operate Class Commands other than Execute and Control

The commands of this syntax group have basic operation code mnemonics which are a single character. If the result of the operation is to be routed to a machine register the designator of that register is appended as a second character of the mnemonic. If the result is not to be placed in the designated file register, an \* is appended to the mnemonic.

#### OPERAND FIELD EXPRESSIONS

Expressions in the operand field are made up of one or more terms which are connected by + and — arithmetic operators. No parenthetical expressions are allowed. Each term of the expression represents a value. Values

#### MICROCOMMANDS

| Command            | Mnemonics         | Operand Field |
|--------------------|-------------------|---------------|
| Load T             | LT                | n             |
| Load M             | LM                | n             |
| Load N             | LN                | n             |
| Load U             | LU                | n             |
| Load Zero Control  | LZ (L)            | n .           |
| Load Seven Control | LS                | n             |
| Jump               | JP                | n             |
| Load File          | LF                | f,n           |
| Add to File        | AF                | f,n           |
| Test If Zero       | TZ ·              | · f,n         |
| Test If Not Zero   | TN                | f,n           |
| Compare            | CP                | f,n           |
| Execute            | Er*               | f,c           |
| Control            | Kr*               | f,c           |
| Add                | Ar*               | . f,L,I,T,C   |
| Increment          | lr*               | f,L,C         |
| Subtract           | Sr*               | f,L,D,T,C     |
| Decrement          | Dr*               | f,L,C         |
| Copy               | Cr*               | f,L,I,T,C     |
| Read               | Rr*               | f,L,I,D,H     |
| Write -            | Wr*               | f,L,I,D,H     |
| Logical OR         | Or*               | f,L,F,T,C     |
| Move               | Mr*               | f,L,C         |
| Exclusive-OR       | Xr*               | f,L,F,T,C     |
|                    |                   | f,L,F,T,C     |
| Shift              | Hr.*              | f,L,I,R,C     |
| Logical AND        | Xr*<br>Nr*<br>Hr* |               |

may be assigned by the assembler program (symbols), or there may be inherent in the term itself (constants). The range of values depends on the operand and the instruction.

# **Symbols**

A symbol is composed of one to three characters in MAP800, or one to six characters in AP800. The first character must be alphabetic or period; subsequent characters may be numeric, alphabetic, or period. Imbedded blanks are not allowed and the assembler stops scanning the symbol with the first character which is not alphanumeric or a period. All symbols, except the special symbol \*, used in an operand field, must be defined by a single appearance in the name field of statement within the program.

### Special Symbol

The special symbol \* represents the momentary values of the assembler's location counter. It may be used as any other symbol in an expression but must never appear in the name field.

### ALPHABETIC LIST OF COMMANDS

| Command            | Mnemonic | Operation Code | Page |
|--------------------|----------|----------------|------|
| AND                | N        | Ef             | 116  |
| Add                | Α        | 8f             | 101  |
| Add To File        | AF       | 3f             | 90   |
| Compare            | CP       | 6f             | 94   |
| Control            | K        | <b>7</b> f     | 94   |
| Сору               | С        | Bf             | 110  |
| Exclusive-OR       | Χ        | Df             | 114  |
| Execute            | Ε        | 0              | 121  |
| Jump               | JP       | 14,15,1C,1D    | 87   |
| Load File          | LF       | 2f , , ,       | 89   |
| Load T             | LT       | 11,19          | 83   |
| Load M             | LM       | 12             | 83   |
| Load N             | LN       | 13             | 84   |
| Load U             | LU -     | 16             | 84   |
| Load Seven Control | LS       | 17             | 86   |
| Load Zero Control  | LZ (L)   | 10             | 85   |
| OR                 | 0        | Cf             | 112  |
| Read               | R        | Af             | 106  |
| Shift              | Н        | Ff             | 118  |
| Subtract           | S        | 9f             | 104  |
| Test if Zero       | TZ       | 4f             | 91   |
| Test if Not Zero   | TN       | 5f             | 92   |
| Write              | W        | Af             | 106  |

### **Constants**

The values of the constant terms are not assigned by the assembler program but are inherent in the terms. There are two types of constant terms: decimal and hexadecimal.

#### a. Decimal Constant

A decimal constant is an unsigned decimal number. The value must be less than 65,536.

#### b. Hexadecimal Constant

A hexadecimal constant is an unsigned hexadecimal number of up to four characters written as a sequence of hexadecimal digits. The digits are enclosed in single quotation marks and preceded by the letter X. Each hexadecimal digit represents a four-bit binary number. The characters A through F are used to identify the hexadecimal integers 10 through 15.

#### ASSEMBLER INSTRUCTIONS

Seven assembler instructions are included for control of the assembly process and the output listing.

#### **ORG** — Set Location Counter

The ORG assembler instruction alters the setting of the location counter. The name field entry, if any, will be assigned the value of the program

counter after it is altered. The operand field of ORG must contain an expression whose value will be placed in the location counter. All symbols in the expression must have been previously defined when the instruction is first encountered. The next command which places object code in the program is forced to begin a new object card.

### **EQU** — Equate Symbol

The EQU assembler instruction is used to define a symbol by assigning to it the value of the operand field. Any symbols appearing in the expression must have been previously defined when the instruction is first encountered. A name field entry must be present.

#### DC — Define Constant

The DC assembler instruction is used to create any microcommand for which a symbolic representation does not exist. Each statement specified only one constant. The constant is written as an expression and is assembled as a 16-bit word in storage.

### END - End Assembly

The END assembler instruction terminates the assembly of a program and must be the last statement in a source program.

The next three descriptions are available only in the AP800 version.

### IDENT — Program Identification

The IDENT assembler instruction is used to identify the start of a program and to supply the program name which is located in the operand field. The IDENT must be the first statement in a source program.

### SPACE — Space Listing

The SPACE assembler instruction causes one or more blank lines to be inserted into the listing. The name field is disregarded by the assembler. The operand field contains an expression specifying the number of blank lines. If the spacing is beyond the end of the current page, the listing begins at the top of the next page.

### **EJECT — Start New Listing Page**

The EJECT instruction causes the next line of the listing to appear at the top of the next page. The name and operand fields are disregarded by the assembler.

#### ASSEMBLY LISTING AND DIODE MAP

The output listing from the assembler contains the memory address, and contents of words in the object program. The source statement is printed side-by-side with the object code.

#### **FORMAT FOR AP800**

| Printer Columns<br>8 - 11<br>15 - 17<br>21 - 24 | Contents         |  |  |
|-------------------------------------------------|------------------|--|--|
| 8 - 11                                          | Error flags      |  |  |
| 15 - 17                                         | Storage address  |  |  |
| 21 - 24                                         | Storage contents |  |  |
| 31 - 110                                        | Source statement |  |  |

#### **ERROR FLAGS**

#### A - Address Error

This error occurs when an address expression in the operand field is incorrectly written or the value is out of range for one of the operands. An error flag will occur for each operand in error or out of range.

### F - Flag Error

This error occurs when an operate class command has an option flag in the operand field which is not allowed for the command or is unrecognizable.

### M - Multidefined Symbol Error

This error occurs when the symbol in the name field has been previously defined by appearing in the name field of another instruction.

#### N - Name Field Error

This error occurs when the symbol in the name field starts with a character other than alphabetic or period, or contains a non alphanumeric or non period character.

### O — Operation Mnemonic Error

This error occurs when the assembler does not recognize the contents of the operation field starting in column 8. A zero value is assembled to allow patching.

## U - Undefined Symbol Error

This error occurs when the symbol encountered in an expression of the operand field is not defined by an appearance in the name field.

#### **DIODE MAP FOR AP800**

The read only memory diode map is printed if a control card following the END card contains a 1, 2 or 3 in column 1. The digit specifies the number of diode maps to be printed. The diode map for each 256 word read only memory board is placed on three pages of the assembly listing. The format of the map is the same as the physical layout of the ROM board. An X on the map indicates a 1-bit and that a diode is to be placed at the position of the X, while an 0 indicates a 0-bit and no diode.

Each of the 64 lines of the diode map for a board contains the diodes for four words. The address of the first word is printed at the left of the map. The four words are interleaved so that the same bit position in each of the four words are grouped together and printed as a cluster at four diode positions. The 16 bit positions are printed across the page and the sum of the number of diodes on the line is placed at the right of the map.

#### SAMPLE LISTING

In order to illustrate assembly language programming, three examples are included in this manual (Figures 18, 19 and 20). The first is a set of unrelated commands assembled by AP800 showing how to write various commands. The second is a listing of a portion of the MICRO 810 firmware assembled by MAP800. The third example is a sample coding sheet with a portion of a program on it.



Figure 18. Sample Listing



Figure 19. MICRO 810 System Listings

# MICRO 800 SERIES SYMBOLIC CODING FORM

| PROGRAM NAME                          | SHM                                 |                              | AUTHOR                                          | PROJECT NUMBER                                                       | DATE                | PAGE<br>OF          | CARD<br>NUMBER                           | ,   |
|---------------------------------------|-------------------------------------|------------------------------|-------------------------------------------------|----------------------------------------------------------------------|---------------------|---------------------|------------------------------------------|-----|
| IAME                                  | OPERATION                           | OPERAND FIELD                | COMMENTS                                        |                                                                      |                     |                     |                                          |     |
| 234567                                | 8 9 10 11 12 13<br>3 <b>6</b> 1 1 1 | 15 16 17 18 19 20 21 22 23 : | 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | 9 40 41 42 43 44 45 46 47 48 49 50 51 52 53 <b>54 56 56</b> 57 58 59 | 60 61 62 63 64 65 6 | 6 67 68 69 70 71 72 | 73 74 75 76 77 78 79 80                  | 1 2 |
|                                       | 1111                                |                              |                                                 |                                                                      | 111111              |                     | 111111                                   | ];  |
| I REA                                 | NEXI                                | INSTRUCTION                  | <b>N</b>                                        | <u> </u>                                                             | <u> </u>            |                     |                                          |     |
| MIG                                   | :M (                                | DM                           | CLEAR OV/W                                      | <u> </u>                                                             |                     |                     |                                          |     |
|                                       |                                     | PU, X1001                    | LILLI CLEAR PILL                                |                                                                      | 11111               | 11111               | 111111                                   | L   |
| أعتبتنا                               | LiFi                                | P.L., X100, /                |                                                 |                                                                      |                     |                     |                                          |     |
|                                       |                                     | =0.1X1101                    | INTERNAL I                                      | MTERRUPIT                                                            |                     | шш                  |                                          | 1   |
|                                       | <u> GPLLLLE</u>                     | LNITIZ                       | YES                                             |                                                                      |                     | سسب                 |                                          | ╁   |
| لسسا                                  | K                                   | التسلسلين المراك             | IIIII ENTER SENS                                | A SIWATICHAS                                                         |                     | шш                  |                                          | 1   |
| لببيد                                 |                                     | I, X 80/                     | SWIITCH 4 0                                     | M                                                                    | <u> </u>            |                     |                                          | 1   |
|                                       | TP.                                 | LOAD                         | TES LOAD B                                      | DOT STRAP                                                            |                     |                     |                                          |     |
| NJLL                                  | <u> </u>                            | OV, X' oe (                  | LILLI SLEAR ON IN                               |                                                                      | 11111               |                     |                                          | 1   |
| NIS                                   | וון מאַ                             | Puri                         | <del></del>                                     |                                                                      |                     | 11111               |                                          |     |
|                                       | 1111                                | بنسسسن                       |                                                 |                                                                      | 11111               |                     |                                          | 1   |
| لىسىا                                 |                                     |                              |                                                 |                                                                      |                     | шш                  |                                          | ļ   |
| انسب                                  |                                     |                              | <del></del>                                     |                                                                      |                     |                     |                                          | 1   |
|                                       |                                     |                              | <del></del>                                     |                                                                      |                     | سببت                |                                          | 1   |
|                                       | لللللا                              |                              | <del></del>                                     |                                                                      |                     | حيثيب               |                                          | ł   |
|                                       |                                     |                              | <del></del>                                     |                                                                      |                     |                     |                                          | ſ   |
|                                       | للتللد                              |                              | <del></del>                                     |                                                                      |                     | للللل               |                                          | Ļ   |
|                                       | لنبيب                               | <del></del>                  | <del></del>                                     | <del></del>                                                          |                     | шш                  | نسسن                                     | 1   |
|                                       |                                     | <del></del>                  | <del></del>                                     |                                                                      |                     |                     | -1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1 | ļ   |
|                                       |                                     | <del></del>                  |                                                 |                                                                      |                     |                     | 111111                                   | t   |
|                                       | 4444                                |                              | <del></del>                                     |                                                                      |                     |                     |                                          | 100 |
| I I I I I I I I I I I I I I I I I I I | ليبين                               |                              |                                                 |                                                                      |                     |                     |                                          | Ľ   |

C. MICAO OUC

#### **OPERATION PROGRAM CARD DECK FROM AP800**

The assembly program generates a deck of cards which contain the binary object code, if a control card following the END card contains a 0 in column 2. All information punched on the cards is in Hollerith code, with a single hexadecimal digit (four binary bits) punch in each column. This format allows easy visual reading of the cards after they are interpreted and permits rapid patching or generation of patches to the deck. Each card contains 16 program words. If all 16 words are zero, the card is not punched.

The cards have two fields as follows:

Columns 1-4 - Load address.

Columns 5-68 - Object code, four columns per word

The format of the binary paper tape created by MAP800 is described under Simulator Operating System. -

# SIMULATOR OPERATING SYSTEM (SOS) AND SIMULATOR PROGRAM (SIM800)

#### INTRODUCTION

The Simulator Operating System (SOS) is an on-line executive system for controlling the operations of the MICRO 800 simulator (SIM800) and incorporates teletype control of debug, console, and executive functions. The teletype is used rather than any console operations except for the console interrupt, which is used to cause control to return to SOS while the simulator is operating. SIM800 and SOS are always loaded into the MICRO 810 or 820 as a single program because all simulator operations are controlled by SOS.

The following is a list of the features available to the user:

Display and change the content of a simulated read only memory location.

Display and change the content of a simulated core memory location.

Two breakpoints for microprogram debugging.

Display and change the content of a simulated MICRO 800 element.

Display the content of all simulated MICRO 800 elements.

Simulate execution of a microprogram.

Load a formatted program tape into simulated read only memory.

Load a formatted tape into simulated core memory.

Punch the content of simulated read only memory into paper tape.

Punch the content of simulated core memory into paper tape.

#### INSTRUCTIONS FOR USE

This section provides instructions for using the SOS program.

### Loading the SOS and SIM800 by the bootstrap and basic loaders

The SOS is loaded into memory via the basic paper tape loader. This basic loader is in the bootstrap format (1 data byte per frame of tape) and is spliced onto the front of the SOS tape. The splice is made so that the last frame of the loader is followed immediately with the leader of the SOS tape. The microprogrammed bootstrap loader loads the basic loader and transfers control to it. Then the basic loader loads the SOS and, after a successful load, transfers control to the SOS. Following is a procedure for loading a formatted paper tape through the teletype via the bootstrap and basic loaders.

- 1. Place the TTY in the off-line mode, place the reader control lever to the "free" position and enable the teletype reader. Type control and Q.
- Place the TTY in the on-line mode and insert the SOS tape in the reader with the first rub-out character at the read station. Set the reader control lever in the stop (center) position.
- 3. Set the front panel sense switches as follows:

Sense switch 1: off for serial TTY interface, on for parallel TTY interface.

Sense switch 2: must be off.

Sense switch 3: must be off.

Sense switch 4: must be on. This selects the bootstrap loader whenever the run switch is selected and was preceded by a reset.

- 4. Press the reset and the run switches and the system will wait for the teletype reader to be started.
- 5. Press the TTY reader lever to the start position. When the basic loader is loaded and operating properly, the teletype page printer mechanism will chatter whenever a record separator passes the read station. This is caused by the issuance of reader off and reader on codes between records.

If a checksum error is found, the message 'CE' is typed and the system will halt. Another attempt to properly load the record may be accomplished by backing up the tape to the previous record separator, placing the reader control lever in the stop (center) position, and pressing the run switch on the front console. When the SOS is properly loaded, control will transfer to it, the teletype bell will ring, and an equal sign will be typed.

### Loading the SOS and SIM800 by the R Operator of TOS

Unroll about 30 inches of the program tape to bypass the basic loader and locate the leader (any frame with channel 8 present) of the formatted tape. Insert the tape into the reader with any part of the leader at the read station and set the reader control lever to center position. Typing an R will start the loading. A checksum is calculated for each record loaded and if it doesn't equal the checksum read with the record, the letters 'CE'

will be typed and control will return to the standard teletype operating system program (TOS). By backing up the tape to the previous separator and typing an R, another attempt may be made to load the tape.

### **SOS Operators**

All operations which are performed by SOS are initiated by typing a single alphabetic character which designates one of 13 operators. These operators are described in detail in Section 3 and are summarized in Appendix A.

The SOS program is ready to accept an operator designator character at any time after ringing the bell and typing an equal sign. If a character other than a legal operator designator is typed, SOS will reject the character, ring the bell, and type an equal sign again.

**NOTE:** For the purposes of this manual, all references to the teletype carriage return are as shown; (CR).

# Hexadecimal Input/Output

All data and addresses are displayed and entered in hexadecimal. The 16 hexadecimal digits are: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E and F. The hexadecimal values may not be signed. When entering a two-digit memory cell value or a four-digit memory address, no spaces or other than hexadecimal characters may be in the digit string. SOS assumes that the hexadecimal digit string is terminated when it receives the first non-hexadecimal character; therefore, it will not act on an input until the digit string is terminated. If more than the required number of digits are entered, SOS will take the last two or four as required. Leading zero digits need not be typed. If the first non-hexadecimal character is not a space, comma, or carriage return (CR), the data or address value is ignored and the operation is terminated. However, before termination, all valid hexadecimal data or address values that were accepted are retained. When more than one address or data value is typed they may be separated by either a comma or a space. For clarity in this document only commas are shown. When an operator requires an address, it will ignore leading spaces, i.e.:

W ssss, eeee (CR)

### Console Interrupt

The console interrupt is used to interrupt the simulation of a microprogram or to abort the I, O, R, or W operator and return control to SOS. The user should be careful if the simulator is interrupted because complete simulation of the current command may not be complete but the K,L register will be pointing to the next sequential location.

If the console interrupt is activated when control is residing in SOS (waiting for an operator), an exit is made to the resident TOS. When using the serial teletype interface, the exit is not taken until one character is typed on the keyboard to force completion of the IBS instruction.

#### Halt and Error Returns

If a microcommand halt (1780) is detected, control will return to SOS and an H followed by the content of the K,L register plus one will be typed.

During the simulation of microprograms, various undefined microcommands and system timing violations are checked for and if detected will cause an error return to SOS. The letter E and a three digit error number will be typed, followed by the content of the K,L register plus one, and control will return to SOS. A list of the error codes and their meaning are contained in Appendix B.

#### **OPERATORS**

#### Card Read: C

The C operator causes SOS to load a program card deck into simulated ROS. The format of the cards must be as described in the AP800 Assembly Program manual. Loading is terminated and control is returned to SOS, when a card is read containing a blank in column 5. If a blank card is read. any character other than a hexadecimal character is read, or a card reader malfunction occurs; the message ERR will be typed and control will return to SOS. Loading may continue, by correcting the error condition, backing up one card, starting the reader, and typing a C. Since no information goes through the reader when a blank card is read or when a pick failure occurs, it is not necessary to back up one card.

### Display: Dn

The D operation causes the contents of the simulated system element n to be typed out followed by a dash. At this time the contents of the element may be changed by typing in one or two hexadecimal digits. When a comma or space is typed after the data or after the dash, the contents of the next element in sequence will be displayed. The various simulated system elements (n) and their meaning are listed below in sequence. If a (CR) is typed, or if a space or comma is typed after the contents of the panel switches (P) has been displayed, this operator is terminated. All examination must be completed on one line of type.

List of values for "n", in order of their appearance:

0 Files 0 through F 9

Т T Register Μ M Register Ν N Register

Κ (L Register Bits 9, 8)

L L Register (Bit 7-0)

U **U** Register

Ζ Link flip-flop (1 bit)

Q R Register (Bits 15-8) R Register (Bits 7-0) R

S Internal Status Register

ı Input bus

I/O Control Register (3 bits) 0 Ρ

Panel command switches (7-0)

### Display: D (CR)

This mode of the D operator causes all of the simulator system elements to be typed out on two lines. A single space is provided between each element and there is a double space after every fourth element. Sixteen files are contained on line one with thirteen additional elements being displayed on line two in the following manner.

D (CR)

00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D

### End of Tape: E

The E operation punches an end of tape record consisting of a zero record size and an execution address of zero. This ensures that tapes punched by SOS will not contain a load and go address. Following the punching of this record, six inches of trailer will be punched automatically.

## Go To: G ssss, tttt, uuuu (CR)

The G operation causes SOS to set trap operations for read only memory locations tttt and uuuu, and to start simulation at read only memory location ssss. If a (CR) is typed after G, simulation starts at the location contained in the K,L register. If a (CR) is typed after ssss, no traps are set, and if a (CR) is typed after tttt only one trap is set. All traps set are automatically cleared when either one is reached or control is transferred to SOS, signalled by the ringing of the teletype bell and the printing of an equal sign. Upon return from a trap, a T, followed by the contents of the K,L registers, is typed out. At this time the command located at the trap location has not been executed. A trap at location zero is not permitted as this value is used by SOS to indicate that a trap has not been set.

# Input: I

The I operator causes SOS to load a MICRO 800 program tape into simulated read only memory in the same manner as the R operator loads a formatted tape into core memory. The tape may be created by the O operator of SOS or by the MAP800 assembler.

#### Leader/Trailer: L

The L operator will cause the paper tape punching device to punch six inches of tape containing channel eight punches only.

### Memory: M ssss,

The M operator causes the contents of the simulated memory location specified by ssss to be typed out followed by a dash. At this time the contents of the memory location may be changed by typing in two hexadecimal digits. When a space or comma is typed after the data or after the dash, the contents of the next sequential location is typed by SOS. A (CR) terminates this operator. The actual amount of simulated core memory will vary depending on the size of the actual memory and the amount of simulated read only memory desired. Standard configuration is 768 words of read only memory and 256 bytes of core memory.

### Output: O ssss, eeee (CR)

The O operator causes the contents of the simulated read only memory area starting with ssss and ending with eeee to be written on the standard output device in the same format as with the W operator. Each record will contain 6410 commands from read only memory except the last record which will contain a number of commands equal to the total number module 6410. Typing a (CR) following the second address will start the operation.

#### Print ROM: P ssss.

The P operator causes the simulated read only memory address specified by ssss to be typed out on a new line followed by the contents of that location. A dash is typed after the value to indicate that it may be changed by typing in one to four hexadecimal digits. When a space or comma is typed after the new data or after the dash, the next sequential read only storage address and its contents are typed by SOS on a new line. A (CR) terminates this operator.

#### Read: R

The R operator causes SOS to load a formatted tape into simulated core memory. This operation can be configured for any standard input device, but normally the device will be the teletype paper tape reader. The tape must be inserted in the reader with the leader (any frame with channel 8 present) placed at the read station before the R is typed. When the loader encounters an end of tape record the loading process is terminated and controls are transferred to SOS. If an end of tape record is not read, loading will continue until the computer is halted or until the console interrupt is activated. A checksum is calculated for each record loaded and if it doesn't equal the checksum read with the record, the letters 'CE' will be typed and control will return to SOS. By backing up the tape to the previous separator and typing an R, another attempt may be made to load the tape.

### Time: T

The T operator causes SOS to print the letters I, M, and E, followed by a four digit hexadecimal number and a dash. This number represents the total number of machine cycles accumulated through simulation since the last reset or preset. The counter may be reset or preset by typing in one to four hexadecimal digits before typing a carriage return to terminate the operation.

# Write: W ssss, eeee (CR)

The W operation causes the contents of the simulated memory area starting with ssss and ending with eeee to be written on the standard output device, normally the teletype punch. Each record of the output will contain 128<sub>10</sub> data bytes except the last record which will contain a number of bytes equal to the total byte count module 128<sub>10</sub>. Typing a (CR) following the second address will start the operation.

# Zero Flags: Z

The Z operation causes SOS to reset flags used by the simulator for error detection and to simulate the functions performed by the reset switch on

the front panel. File zero will be cleared, all internal status bits will be cleared, and the K,L register, I/O control register, and the value of the input bus will be set to zero. This operator should be used before setting up parameters and starting a simulation sequence.

### PROGRAM TAPE FORMAT

The binary paper tape format (Figure 21), can be generated by the two pass assembler, and by the output and write subroutines of SOS. This format allows for variable length records of up to 64<sub>10</sub> sixteen-bit microcommands, or 128<sub>10</sub> eight-bit bytes, a record load address, and a record checksum. Each record contains a count of the number of data bytes and the 15 bit address at which data is to be loaded. The record is loaded sequentially starting with this address. When there is a discontinuity in the loading addresses, a new record is started so that a load address may be specified. The last byte of each record is a checksum which is the summation of the byte count, load address, and data bytes formed on an eight-bit basis with overflow added into the least significant bit of the sum.

A byte count of zero signifies an end of tape record and if present will be the last record read. The paper tape reader will be stopped and control is returned to SOS.



Figure 21. Binary Paper Tape Format

### APPENDIXES

#### APPENDIX A

#### SUMMARY OF SOS OPERATORS

Underlined items are typed out by SOS:

| <b>C</b> . | Read a program card deck into simulated ROM. |
|------------|----------------------------------------------|
|            |                                              |

D1 xx-, xx-nn (CR) Display content of File 1, leave File 1 unaltered and display content of File 2, change the content to nn and terminate

the operation.

D (CR) Display the content of all simulated elements. Line one contains the 16 files and line two contains 13 additional elements.

Ε Write an end of tape record into for-

matted paper tape.

G (CR) Simulation starts at the location contained in the K.L register.

G ssss (CR) Simulation starts at location ssss.

G ssss. tttt (CR) Simulation starts at location ssss, a trap

is set for location tttt.

Simulation starts at location ssss, traps are G ssss, tttt, uuuu (CR) set for locations tttt and uuuu.

Simulation starts at the location contain-G, tttt (CR)

ed in the K,L register, a trap is set for

location tttt.

Simulation starts at the location contain-G, tttt, uuuu (CR) ed in the K,L register, traps are set for

locations tttt and uuuu.

Input a formatted program tape to simulated read only memory. After loading,

control returns to SOS.

Punch six inches of paper tape leader

(channel 8 only).

Display the contents of simulated mem-M ssss, xx-nn, xx- (CR) ory location ssss and change the contents

to nn. Display the contents of location ssss+1, leave the location unaltered and terminate the operation. This operation must be completed on one line of type.

only memory from locations ssss through

O ssss, tttt (CR) Output the contents of simulated read

tttt into formatted paper tape.

| ontent of simulated read only                                   |
|-----------------------------------------------------------------|
| cation ssss, leave the location                                 |
| nd display the content of local<br>Change the content of ssss+1 |
| ı                                                               |

R Read a formatted paper tape into simulated core memory. After loading, control returns to SOS.

TIME xxxx- O (CR)

Display the number of machine cycles accumulated during simulation. Reset the time to zero and terminate the operation.

W ssss, tttt (CR)

Write the contents of simulated core locations ssss through tttt into formatted paper tape.

Z

Zero simulator error flags and reset the simulated MICRO 800 system.

to nnnn and terminate the operation.

# **APPENDIX B**

# **SIM800: ERROR MESSAGES**

| # 1 | Meaning                                                                                                                                                                 |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 001 | U-Register timing — can't use U during first cycle following its setting.                                                                                               |
| 002 | Console command switches — Command preceding 707X control command causes an ROM delay. $\dot{}$                                                                         |
| 003 | Memory write full cycle — attempt to set $T$ during second, third or fourth cycle following the memory command.                                                         |
| 004 | Memory read $-$ T is set without being selected, during the first or second cycle following the memory command.                                                         |
| 005 | Attempt to load literal with an undefined register destination of 8, 9, A, B, E, or F. Destination 9 is undefined because the memory spare bit option is not simulated. |
| 006 | Attempt to load or add literal into file register zero.                                                                                                                 |
| 007 | Attempt to use undefined C-bit combinations 3, 5, or 6 in a control command.                                                                                            |
| 800 | Console command switches — file register zero not selected in 707X control command.                                                                                     |
| 009 | Address in M and N exceeds available simulated memory.                                                                                                                  |
| 010 | Memory write half cycle $-$ attempt to set $T$ during first or second cycle following the memory command.                                                               |
| 011 | Execute command found after U-register OR-ed into instruction.                                                                                                          |
| 012 | Undefined B-bus operand — usually resulting from selection of complement T when the input bus ( $103X$ ) is enabled.                                                    |

# ALTERABLE READ-ONLY MEMORY OPERATING SYSTEM (AROS)

### INTRODUCTION

The Alterable Read-Only Memory Operating System (AROS) is a program which permits on-line control, loading and dumping of firmware code using the teletypewriter and/or card reader. The program is used in conjunction with Microdata's Alterable Read-Only Memory System (AROM). The Microprogramming System described in Part VI "Product Catalog" is a valuable tool for checkout of firmware systems. It is particularly useful in realtime firmware or I/O oriented applications that require precise timing to be analyzed which cannot be done with the simulator system.

The features of the AROS program include the following:

Loading of the AROM system (memory) with firmware code in the form of formatted punched cards or punched paper tapes.

Display and/or change of operator designated AROM locations using the teletypewriter.

Listing and/or dumping of AROM on teletypewriter and punched paper tape.

### **INSTRUCTIONS FOR USE**

This section provides instructions for using the AROS program.

# Loading AROS by the bootstrap and basic loaders

The AROS is loaded into memory via the basic paper tape loader. This basic loader is in the bootstrap format (1 data byte per frame of tape) and is spliced onto the front of the AROS tape. The splice is made so that the last frame of the loader is followed immediately with the leader of the AROS tape. The microprogrammed bootstrap loader loads the basic loader and transfers control to it. Then the basic loader loads the AROS and, after a successful load, transfers control to the AROS. Following is a procedure for loading a formatted paper tape through the teletype via the bootstrap and basic loaders.

- 1. Place the TTY in the off-line mode, place the reader control lever to the "free" position and enable the teletype reader. Type control and Q.
- 2. Place the TTY in the on-line mode and insert the AROS tape in the reader with the first sub-out character at the read station. Set the reader control lever in the stop (center) position.
- 3. Set the front panel sense switches as follows:

Sense switch 1: off for serial TTY interface, on for parallel TTY interface.

Sense switch 2: must be off.

Sense switch 3: must be off.

Sense switch 4: must be on. This selects the bootstrap loader whenever the run switch is selected and was preceded by a reset.

- 4. Press the reset and the run switches and the system will wait for the teletype reader to be started.
- 5. Press the TTY reader lever to the start position. When the basic loader is loaded and operating properly, the teletype page printer mechanism will chatter whenever a record separator passes the read station. This is caused by the issuance of reader off and reader on codes between records.

If a checksum error is found, the message "CE" is typed and the system will halt. Another attempt to properly load the record may be accomplished by backing up the tape to the previous record separator, placing the reader control lever in the stop (center) position, and pressing the run switch on the front console. When the AROS is properly loaded, control will transfer to it, the teletype bell will ring, and an at sign (@) will be typed.

# Loading AROS by the R Operator of TOS

Unroll about 30 inches of the program tape to bypass the basic loader and locate the leader (any frame with channel 8 present) of the formatted tape. Insert the tape into the reader with any part of the leader at the read station and set the reader control lever to center position. Typing an R will start the loading. A checksum is calculated for each record loaded and if it doesn't equal the checksum read with the record, the letters "CE" will be typed and control will return to TOS. By backing up the tape to the previous separator and typing an R, another attempt may be made to load the tape.

### **AROS Operators**

All operations which are performed by AROS are initiated by typing a single alphabetic character which designates one of 10 operators.

The AROS program is ready to accept an operator designator character at any time after ringing the bell and typing at sign (@). If a character other than a legal operator designator is typed, AROS will reject the character, ring the bell, and type an at sign (@) again.

NOTE: For the purposes of this manual, all references to the teletype carriage return are shown as; (CR).

# Hexadecimal Input/Output

All data and addresses are displayed and entered in hexadecimal. The 16 hexadecimal digits are: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E and F. The hexadecimal values may not be signed. When entering a four digit data value or a four digit memory address, no spaces or other than hexadecimal characters may be in the digit string. AROS assumes that the hexadecimal digit string is terminated when it receives the first non-hexadecimal character. Therefore, it will not act on an input until the digit string is terminated. If more than the required number of digits are entered, AROS will take the last four as required.

Leading zero digits need not be typed. If the first non-hexadecimal character is not a space, comma, or carriage return (CR), the data or address value is ignored and the operation is terminated. However, before termination, all valid hexadecimal data or address values that were accepted are retained. When more than one address is typed they may be separated

by either a comma or a space. For clarity in this document only commas are shown. When an operator requires an address, it will ignore leading spaces, i.e.:

W ssss, eeee (CR)

### **Console Interrupt**

The console interrupt may be used to terminate the D, R, V, and W operations, return control to AROS and type a carriage return, line feed, bell, and at sign (@). If the console interrupt is activated when control is residing in AROS (waiting for an operator), an exit is made to the resident TOS. When using the serial teletype interface, the exit is not taken until one character is typed on the keyboard to force completion of the IBS instruction.

### **OPERATORS**

### Card Read: C

The C operator causes AROS to load a program card deck into reference ROS. The format of the cards must be as described in the AP800 Assembly Program manual. Loading is terminated and control is returned to AROS, when a card is read containing a blank in column 5. If a blank card is read, any character other than a hexadecimal character is read, or a card reader malfunction occurs; the message ERR will be typed and control will return to AROS. Loading may continue, by correcting the error condition, backing up one card, starting the reader, and typing a C. Since no information goes through the reader when a blank card is read or when a pick failure occurs, it is not necessary to back up one card.

# Dump: D ssss, eeee (CR)

The D operation causes the contents of AROM to be dumped on the teletype printer starting with the address ssss and ending with the address eeee. AROS types the four digit address at the left margin followed by eight 16-bit words of AROM. This operation is terminated when the contents of the last AROM location has been typed, or the console interrupt is activated. Typing a (CR) after the second address will start the operation.

## End of Tape: E

The E operation punches an end of tape record consisting of a zero record size, a zero address, and a zero checksum followed by six inches of tape containing channel eight punches only.

#### Leader: L

The L operator will cause the punching device to punch six inches of tape containing channel eight punches only.

#### Print Reference ROS: P ssss.

The P operator causes the reference ROS address specified by ssss to be typed out on a new line followed by the contents of that location. A dash is typed after the value to indicate that it may be changed by typing in one to four hexadecimal digits. When a comma or space is typed, after the new data or after the dash, the next sequential reference ROS address and its contents are typed on a new line. A (CR) terminates the operation.

#### Read: R

The R operator causes AROS to load a formatted tape into reference ROS. The tape must be inserted into the teletype reader with the leader (any frame with channel 8 present) placed at the read station before the R is typed. When the loader encounters an end of tape record, the loading process is terminated and control is returned to AROS. If an end of tape record is not read, loading will continue until the reader is empty or until the console interrupt is activated. A checksum is calculated for each record loaded, and if it doesn't equal the checksum read with the record, the letters 'CE' will be typed and control will return to AROS. By backing up the tape to the previous separator and typing an R, another attempt may be made to load the tape.

### Transfer: T ssss, eeee (CR)

The T operation causes a clock of reference ROS starting with location ssss and ending with location eeee to be transferred to the corresponding locations in AROM. The operation is started by typing a (CR) following the second address and is terminated when the contents of the last location specified is transferred. There is no verification or check of the data written made by this operator.

### Verify: V ssss, eeee (CR)

The V operation causes a block of AROM starting with location ssss and ending with location eeee to be read and compared with the corresponding locations in reference ROS. All variances will be displayed along with their associated address. The operation is started by typing a (CR) following the second address. Termination occurs when the last specified location is checked and a message is typed or the console interrupt is activated.

# Write: W ssss, eeee (CR)

The W operation causes the contents of reference ROS starting with location ssss and ending with location eeee to be written on the standard output device, normally the teletype punch. Each record of the output will contain 64<sub>10</sub> 16-bit words, except the last record, which will contain the number of words equal to the total word count modulo 64<sub>10</sub>. Typing a (CR) following the second address will start the operation.

# Zero: Z ssss, eeee (CR)

The Z operator causes the reference ROS locations starting with ssss and ending with eeee to be set to zero. Typing a (CR) following the second address will start the operation.

### PROGRAM TAPE FORMAT

The binary paper tape format (Figure 22) can be generated by the MAP800 assembler, by the O operator of the simulator and by the W operator of AROS. This format allows for variable length records of up to 64<sub>10</sub> 16-bit words (punched as 128 bytes), a record load address (address X 2), and a record checksum. Each record contains a byte count of the number of data bytes and the address at which loading is to start. The last byte of each record is a checksum which is the summation of the byte count, load address, and data bytes formed on an eight bit basis with overflow added into the least significant bit of the sum.



Figure 22. Binary Paper Tape Format

### SUMMARY OF AROS OPERATORS

C

SSSS XXXX-,

ssss xxxx-nnnn (CR)

Underlined items are typed out by AROS:

|                   | ROS.                                                                                                                                              |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| D ssss, eeee (CR) | Dump the contents of AROM locations ssss through eeee onto the teletype printer. Each line will contain an address and up to eight 16-bit values. |
| <b>E</b> .        | Write an end of tape record into formatted paper tape.                                                                                            |
| L.                | Punch six inches of paper tape leader (channel 8 only).                                                                                           |
| P ssss,           | Print the content of reference ROS loca-                                                                                                          |

Print the content of reference ROS location ssss, leave the location unaltered and display the content of location ssss+1. Change the content of ssss+1 to nnnn and terminate the operation.

Read a program card deck into reference

| R                                                                           | Read a formatted paper tape into reference ROS. After loading, control returns to AROS.                                             |
|-----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|
| T ssss, eeee (CR)                                                           | Transfer the block of reference ROS from ssss to eeee to the corresponding locations in AROM.                                       |
| V ssss, eeee (CR) <u>LOC ROM REF</u> <u>ssss xxxx yyyy</u> Verify Completed | Verify the block of AROM from ssss to eeee to the corresponding locations in reference ROS. An error is indicated at location ssss. |
| W ssss, eeee (CR)                                                           | Write the contents of reference ROS loca-                                                                                           |

tions ssss through eeee into formatted paper tape.

Set the contents of reference ROS loca-Z ssss, eeee (CR)

tions ssss through eeee to zero.

### PROGRAM CHECKOUT AND DEBUGGING

After a program has been written and assembled, the program debugging phase begins. Depending on the size and complexity of the program, and the care used in preparing the program, this phase may be routine, requiring only a few hours, or it may require many days.

The simulator is very useful for debugging because commands can be easily modified to correct errors or to help in finding errors. This also applies to the Alterable Read Only Storage (AROS).

Programs can also be checked and modified quite easily even if they have already been put in diode read only memory.

This discussion of checkout and debugging is divided into four sections:

General Checkout Procedures Checkout with Simulator Checkout with AROS Checkout with Diode Read Only Storage

#### General Checkout Procedures

There are a number of programming errors which might possibly occur, and are sometimes very difficult to detect. These are the kind that represent valid program commands as far as the assembler and simulator are concerned, thus are not flagged as errors by these two programs. Being aware of the typical errors and their effect on a program helps considerably in locating them.

Some of the error types can definitely cause any one of the symptoms, and these should be checked out first. The procedures for detection and checkout of error symptoms differ for use of the simulator, alterable read only, or diode board, and for that reason will be discussed separately.

### Simulator

The simulator is useful for checking internal programs for correct sequences, correctness of results of algorithms, math routines, etc. and for input output sequences. Since the simulator does not run in real time, it is limited in its ability to test the entire program in normal operation. Also, since it is simulated, it is not possible to step through the program by means of the clock switch and observe the L count and ROS outputs. With the simulator, the ROS can be checked using the teletype, and all files, etc. can be set up using the teletype. Then breakpoints can be placed in the routines and the program can be started at convenient points to test individual routines, or combinations of routines, after the breakpoint is reached.

Some of the more common errors and error symptoms are listed in Table 12.

The reason why all of these are mentioned is that they become the base for establishment of a growing check list which should always be referred to during program checkout. As errors are found in different categories not on the list, they are added to the list. For certain phases of a checkout process, such as checking individual subroutines, obviously all of the error categories don't apply so only selected ones need to be considered.

Many times hours and even days are wasted trying to track down an apparent error cause when a few minutes spent going through the check list would show that a few other items could cause the same symptom. The diagnostic effectiveness of the check list is increased by putting it in the form of a table which relates errors to symptoms, or symptoms to errors. For most cases this table is applicable to checkout with the simulator, AROS, or diode board.

One big advantage of firmware checkout over software checkout is that firmware errors don't cause the program to destroy itself, thus wiping out the error symptoms.

The program error check list relating symptom to error takes on the form shown in the example of Table A. The X's indicate the most likely relations between program errors and symptoms, although under certain conditions any one of the symptoms might be caused by any of the program error types. The various files, registers and flags are tested to see if the routines operated correctly. Once error symptoms are detected, the program errors can be tracked down by the relationships illustrated in Table A.

In Table A the general functions such as algorithms, flow charts, and transfer of flow chart information to coding can introduce errors causing any of the listed symptoms. Therefore, these parts require special checkout on paper before committing to read only storage. One method which proves quite successful in many cases is to define the algorithm and flow chart, and do the coding in MICRO 810, 811 or 820 software as close in format as possible to the firmware coding, and check out these routines first before committing to firmware. This works satisfactorily except for the real time limitation in high speed operations.

#### Use of the Simulator to Check Subroutines

Two simple subroutines have been selected to illustrate use of the simulator for checkout. The first routine sets files 1-E to 'AA', and the second routine does a simple 8-bit positive number multiply.

The simulator operators to be used for these two examples are as follows:

- a. DN Display files, registers, and flags.
- G ssss, tttt, uuuu (CR) Execute a program starting at ssss, with traps at tttt, and uuuu.
- c. P ssss Prints out and permits loading of ROS commands starting at location ssss.
- d. Z Resets flags used by the simulator.
- e. D (CR) Display all Files and Registers.

#### Routine 1 - Set files 1-E to 'AA'

The U register is used for file indexing. File F is used to contain, and update the U register value. The machine code for this program is as follows:

Example 1. Set files I-E=AA

| Counter<br>Address | Command      | Operation                                          |
|--------------------|--------------|----------------------------------------------------|
| 000<br>001         | 2FB0<br>8F46 | U Reg. Code to File F.<br>Update File F and U Reg. |
| 001                | 11AA         | Set T=AA                                           |
| 003                | 0020         | Execute Command (Effectively copy T)               |
| 004                | 6F42         | Compare for last file value                        |
| 005                | 1401         | Jump to repeat loop                                |
| 006                | 1780         | Halt*                                              |
|                    |              | *For demo only usually a jum                       |

<sup>\*</sup>For demo only, usually a jump or subroutine exit.

# **Simulator Operations**

L

1. Z - to initialize the simulator.

| 2. P 00 | 0,       |         |      |   |
|---------|----------|---------|------|---|
| 000     | xxxx     | 2FB0,   |      |   |
| 001     | xxxx     | 8F46,   |      |   |
| 002     | XXXX     | · 11AA, | •    |   |
| 003     | xxxx     | 0020,   |      |   |
| 004     | xxxx     | 6F42,   |      |   |
| 005     | XXXX     | 1401,   |      |   |
| 006     | XXXX     | 1780    | (CR) |   |
|         | <b>~</b> | J       |      | _ |

This part is printed out by simulator.

New commands are typed in followed by

comma until last command.

3. G 000 (CR) execute program without traps.

For correct operation program halts and prints out an H followed by 0007 which is L register +1.

 Use of D<sub>1</sub>, followed by commas, will cause the teletype to print out the content of the files:

D<sub>1</sub> AA-, AA-, AA, etc.

# Typical errors and symptoms:

- 001 8F06 instead of 8F46 File F not incremented. Program will never exit from loop to halt instruction. No files will be loaded with AA.
- 004 6F41 File F incremented once too often. Program will loop one extra time, setting file F=AA, which will then cause additional loops storing T into memory at locations determined by M & N. Then program will repeat loading AA into files. Program will never exit loop.
- 3. 005 1400 or 1402 File F will either be reinitialized every time or nonincremented, so loop will never be exited.

Routine 2 - 8 bit positive number multiply.

 $x * y \rightarrow Z_U, Z_L$ file 2 = Xfile 3 = Y and  $Z_L$ file  $4 = Z_U$ file 5 = Shift Count

#### Machine Code

| L Counter<br>Address                                               | Command                                                                              | Operation                                                                                                                                                            |
|--------------------------------------------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000<br>001<br>002<br>003<br>004<br>005<br>006<br>007<br>008<br>009 | 2508<br>C201<br>2400<br>4301<br>8420<br>F420<br>F3A0<br>9550<br>5004<br>1403<br>1780 | Shift count = 8  Move X to T Register Clear ZU Test Y for odd/even Add T to TU Shift ZU Shift ZL Decrement Shift Count Zero Condition Test Jump to repeat loop Halt* |

<sup>\*</sup>For demo only.

#### Simulator

- 1. Z to initialize this simulator.
- 2. P 000, 000 xxxx 2508, 001 xxxx C201,

Complete until entire program up to 00A 1780 is loaded.

3. D2, xx-02  
D3, xx-04 
$$\begin{cases} x = 2 \\ y = 4 \\ Z_L = 8, Z_U = 0 \end{cases}$$

4. G 000 (CR) Execute, with no traps.

### 5. Results



Typical errors and symptoms:

### 1. 008 - 4004 instead of 5004

The requirement is to skip on zero shift count which would seem like Test Zero is correct. However, the zero condition flag is being tested. This must be =1 when shift cound is 0. A 4004 would cause program not to loop.

# 2. 007 - 9540 Condition flag not updated.

Subroutine will never exit because zero condition flag will never be set. If flag had been set when routine was entered, exiting would occur on first pass.

### 3. 006 - F320 Link not entered.

With this error, the program would loop properly and exit to the halt, but the  $Z_{\perp}$  value in file 3 would always be 0.

As larger and more complex subroutines and entire programs consisting of many subroutines are checked out, more of the error sources included in Table A must be considered.

Many times, if a timing error for memory access or I/O is found, it can be corrected without addition of instructions requiring relocation by changing the order of instructions or changing a no-op to a jump to next instruction to increase a delay factor.

Consider the following example:



Assume that this is a programming error because the value in fX is not supposed to be stored until the 2nd memory write cycle shown. The routine could be changed to the following:



The same number of instructions are required, but instruction 2 which causes modification of N will cause a delay until the first memory cycle is complete, thus causing f(X) to go into memory on the 2nd cycle. Changes of this type are particularly important when the program being checked is in diode read only memory.

Checkout of an applications microprogram can be facilitated by preparation of simple programs for display of registers and core memory and placing these in the upper part of the read only memory.

Also checkout of short firmware subroutines is facilitated by using a MICRO 810, 811, or 820 having an additional ROS which is electrically alterable by the program. Then the software programs can be used to test core memory and to display most of the file registers.

# Checking Subroutines with the Alterable Read Only Storage

An alterable read only storage (AROS) has the advantages of running in real time as well as ease of command modification.

Programs can be checked out by manually clocking one step at a time while testing the L counter for proper looping, by preparing and testing one subroutine at a time using halt instructions to break up loops, and test partial routine functions. Real time I/O operations can be tested by looping on I/O subroutines, or looping on small groups of subroutines. When the individual routines have been checked, it becomes much easier to assemble and to test the entire program.

# Checkout of Programs in Diode Read Only Storage

Programs in diode read only memory should first be manually clocked to see if the L counter follows the correct branching paths, and to check each command in read only storage. File registers are checked at various points in the routine by switching to front panel control and setting command switches to Cf00 and display to D. To bypass loops, the L count is set to the next instruction after the loop. Those items in Table 12 causing all possible symptoms to occur should be checked first. This includes the

diode map, instruction op codes and functions to flow charts, to coding. When stepping through a program, I/O timing cannot be tested in real time, nor can omissions of U register modification delay be detected, therefore these two areas should be thoroughly checked on the flow charts and coding sheets.

To facilitate checkout with diode boards, temporary halt, or loop instructions can be put in the program, and easily changed after the subroutines have been checked out.

Many times in the firmware development phases it is possible to correct an error or omission by placing a jump instruction to an unused part of read only storage, programming the fix there, and jumping back to the first correct instruction after the error. These detours or patches can then be eliminated in the firmware production phase after the firmware program has been checked out.

| Unexpected conditions causing subroutine to be incorrect or incomplete. | Inadvertent double use of file register. | Lack of provision for crossing page boundaries (in core or ROS). | Delay after changing U register absent. | Memory access time delays unaccounted for. | Unexpected conditional timing constraints or processing time load. | Omission of a command from a routine. | Incorrect transfer of function from flow chart to code sheet. | Error in, or omission of flow chart function. | Flow chart organiztion error. | Algorithm error (logical, arithmetic, etc.) | Incorrect functional definition in program. | Table 12. Program Error Check Lis  Programming Error  Error Symptom    |
|-------------------------------------------------------------------------|------------------------------------------|------------------------------------------------------------------|-----------------------------------------|--------------------------------------------|--------------------------------------------------------------------|---------------------------------------|---------------------------------------------------------------|-----------------------------------------------|-------------------------------|---------------------------------------------|---------------------------------------------|------------------------------------------------------------------------|
| ×                                                                       |                                          |                                                                  | ×                                       | ×                                          | ×                                                                  | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Incorrect or Missing I/O Data                                          |
| ×                                                                       | ×                                        |                                                                  | ×                                       | ×                                          | ×                                                                  | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Incorrect Results but Correct Files Modified                           |
|                                                                         | ×                                        |                                                                  | ×                                       |                                            |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Incorrect Files Modified                                               |
|                                                                         |                                          |                                                                  |                                         |                                            | ×                                                                  | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Program Hangs up in a Loop                                             |
|                                                                         |                                          |                                                                  |                                         |                                            |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Program Fails to Loop in a Subroutine                                  |
|                                                                         |                                          |                                                                  |                                         |                                            |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Program Exits a Subroutine Loop too early or too late                  |
|                                                                         |                                          | ×                                                                |                                         |                                            |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Incorrect Core Memory Storage Locations                                |
|                                                                         |                                          | ×                                                                |                                         |                                            |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Core Data/Flags Destroyed                                              |
| ×                                                                       |                                          |                                                                  | ×                                       | ×                                          |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Incorrect Data/Flags Stored                                            |
|                                                                         |                                          | ×                                                                |                                         |                                            |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Incorrect or No Return From Subroutine                                 |
|                                                                         |                                          | ×                                                                |                                         |                                            |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Program Never gets to Correct Subroutine                               |
|                                                                         | ×                                        |                                                                  |                                         |                                            | ×                                                                  | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Intermittent Program Errors                                            |
|                                                                         | ×                                        |                                                                  |                                         | ×                                          |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Program Does Not Enter a Loop<br>According to Expected Flags or Status |
|                                                                         | ×                                        |                                                                  |                                         | ×                                          |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Program Enters Loop when Conditions Say it Should Not                  |
|                                                                         |                                          |                                                                  |                                         |                                            | ×                                                                  | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Incorrect or Lack of I/O<br>Control Pulses                             |
|                                                                         |                                          | ×                                                                |                                         |                                            |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Program Stays in One Page of ROS                                       |
|                                                                         |                                          | ×                                                                |                                         |                                            |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Program Follows Unexpected Mean-<br>ingless Path Through Routines      |
|                                                                         |                                          | ×                                                                |                                         |                                            |                                                                    | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Program Jumps to an<br>Unused ROS Area                                 |
|                                                                         |                                          |                                                                  |                                         | ×                                          | ×                                                                  | ×                                     | ×                                                             | ×                                             | ×                             | ×                                           | ×                                           | Timing Errors                                                          |
|                                                                         |                                          |                                                                  |                                         |                                            |                                                                    |                                       |                                                               |                                               |                               |                                             |                                             |                                                                        |

| Incorrect timing, sequences, truth tables, or complement in interface. | Inadvertent modification of flag bits in a file. | Errors or omissions in initialization functions. | Incorrect or omitted term in c field of command. | Incorrect literal in conditional jump command. | Omission of file write inhibit. | Miscounting for loop exit test. | Not changing jump addresses after routing relocation, or selecting wrong address. | Error in time delay routine calculation. | Destination register error or omission. | Improper I/O timing. | Incorrect skip condition (mainly double inversion). | Unexpected overflow condition. | Table 12. Program Error Check List (Continued)  Programming Error  Error Symptom |
|------------------------------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|------------------------------------------------|---------------------------------|---------------------------------|-----------------------------------------------------------------------------------|------------------------------------------|-----------------------------------------|----------------------|-----------------------------------------------------|--------------------------------|----------------------------------------------------------------------------------|
| ×                                                                      |                                                  |                                                  | ×                                                |                                                |                                 |                                 |                                                                                   | ×                                        | ×                                       | ×                    |                                                     | ×                              | Incorrect or Missing I/O Data                                                    |
|                                                                        | ×                                                | ×                                                | ×                                                |                                                | ×                               |                                 |                                                                                   |                                          | ×                                       |                      |                                                     | ×                              | Incorrect Results but Correct Files Modified                                     |
|                                                                        |                                                  |                                                  |                                                  |                                                |                                 | ×                               | ×                                                                                 |                                          |                                         |                      |                                                     |                                | Incorrect Files Modified                                                         |
|                                                                        |                                                  | ×                                                | ×                                                | ×                                              |                                 |                                 | ×                                                                                 | ×                                        | ×                                       |                      |                                                     |                                | Program Hangs up in a Loop                                                       |
|                                                                        |                                                  | ×                                                | ×                                                | ×                                              |                                 |                                 |                                                                                   |                                          |                                         |                      | ×                                                   |                                | Program Fails to Loop in a<br>Subroutine                                         |
|                                                                        |                                                  | ×                                                |                                                  | ×                                              | ×                               | ×                               |                                                                                   |                                          |                                         |                      |                                                     |                                | Program Exits a Subroutine<br>Loop too early or too late                         |
|                                                                        |                                                  |                                                  | ×                                                |                                                | ×                               | ×                               |                                                                                   |                                          | ×                                       |                      |                                                     |                                | Incorrect Core Memory Storage Locations                                          |
|                                                                        |                                                  |                                                  | ×                                                |                                                | ×                               | ×                               |                                                                                   |                                          | ×                                       |                      |                                                     |                                | Core Data/Flags Destroyed                                                        |
|                                                                        |                                                  |                                                  | ×                                                |                                                |                                 |                                 |                                                                                   |                                          | ×                                       |                      |                                                     | ×                              | Incorrect Data/Flags Stored                                                      |
|                                                                        |                                                  |                                                  |                                                  | ×                                              |                                 |                                 | ×                                                                                 |                                          | ×                                       |                      |                                                     |                                | Incorrect or No Return From Subroutine                                           |
|                                                                        |                                                  |                                                  |                                                  |                                                |                                 |                                 | ×                                                                                 |                                          | ×                                       |                      |                                                     |                                | Program Never gets to Correct Subroutine                                         |
|                                                                        | ×                                                |                                                  |                                                  |                                                |                                 |                                 |                                                                                   | ×                                        |                                         |                      |                                                     |                                | Intermittent Program Errors                                                      |
|                                                                        | ×                                                |                                                  | ×                                                | ×                                              |                                 |                                 |                                                                                   |                                          |                                         |                      |                                                     |                                | Program Does Not Enter a Loop<br>According to Expected Flags or Status           |
|                                                                        | ×                                                |                                                  | ×                                                | ×                                              |                                 |                                 |                                                                                   |                                          |                                         |                      |                                                     |                                | Program Enters Loop when Conditions<br>Say it Should Not                         |
| ×                                                                      |                                                  |                                                  | ×                                                |                                                |                                 |                                 |                                                                                   | ×                                        |                                         | ×                    |                                                     |                                | Incorrect or Lack of I/O<br>Control Pulses                                       |
|                                                                        |                                                  |                                                  |                                                  |                                                |                                 |                                 |                                                                                   |                                          |                                         |                      |                                                     |                                | Program Stays in One Page of ROS                                                 |
|                                                                        |                                                  |                                                  |                                                  |                                                |                                 |                                 | ×                                                                                 |                                          |                                         | <u> </u>             |                                                     | -                              | Program Follows Unexpected Mean-<br>ingless Path Through Routines                |
|                                                                        |                                                  |                                                  |                                                  |                                                |                                 |                                 | ×                                                                                 |                                          |                                         |                      |                                                     |                                | Program Jumps to an<br>Unused ROS Area                                           |
| ×                                                                      |                                                  |                                                  |                                                  |                                                |                                 | ×                               |                                                                                   | ×                                        |                                         | -                    |                                                     |                                | Timing Errors                                                                    |
|                                                                        |                                                  |                                                  |                                                  |                                                |                                 |                                 |                                                                                   |                                          |                                         |                      |                                                     |                                |                                                                                  |

| Unplanned modification of link bit or a condition flag between command which sets it and command which uses it. | Diodes or bits incorrectly placed in ROS. | Not setting M register after N register. | Use of incorrect command op code. | Incorrect accounting for internal flags. | Incorrect subroutine jump pointer usage. | Selection of wrong entry point for multiple entry subroutines. | Not accounting for special results, such as 1's introduced by shift right 4 command. | Incorrect setting of sense switches. | Table 12. Program Error Check List (Continued)                      |  |
|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------------------------------|-----------------------------------|------------------------------------------|------------------------------------------|----------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------|---------------------------------------------------------------------|--|
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          |                                          |                                                                |                                                                                      |                                      | Incorrect or Missing I/O Data Incorrect Results but Correct         |  |
| ×                                                                                                               | ×                                         |                                          | ×                                 |                                          |                                          | ×                                                              | ×                                                                                    |                                      | Files Modified                                                      |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          |                                          | ×                                                              | ×                                                                                    |                                      | Incorrect Files Modified                                            |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          |                                          | ×                                                              |                                                                                      | ×                                    | Program Hangs up in a Loop                                          |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          |                                          | ×                                                              |                                                                                      |                                      | Program Fails to Loop in a<br>Subroutine                            |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          |                                          |                                                                |                                                                                      |                                      | Program Exits a Subroutine<br>Loop too early or too late            |  |
|                                                                                                                 | ×                                         | ×                                        | ×                                 |                                          |                                          | ×                                                              |                                                                                      |                                      | Incorrect Core Memory Storage Locations                             |  |
|                                                                                                                 | ×                                         | ×                                        | ×                                 | ×                                        |                                          | ×                                                              |                                                                                      |                                      | Core Data/Flags Destroyed                                           |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          |                                          | ×                                                              |                                                                                      |                                      | Incorrect Data/Flags Stored                                         |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          | ×                                        |                                                                |                                                                                      |                                      | Incorrect or No Return From Subroutine                              |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          | ×                                        |                                                                | ×                                                                                    |                                      | Program Never gets to Correct Subroutine                            |  |
| ×                                                                                                               | ×                                         |                                          | ×                                 |                                          |                                          |                                                                |                                                                                      |                                      | Intermittent Program Errors                                         |  |
|                                                                                                                 | ×                                         |                                          | ×                                 | ×                                        |                                          |                                                                |                                                                                      | ×                                    | Program Does Not Enter a Loop According to Expected Flags or Status |  |
| ×                                                                                                               | ×                                         |                                          | ×                                 |                                          |                                          |                                                                |                                                                                      |                                      | Program Enters Loop when Conditions<br>Say it Should Not            |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          |                                          |                                                                |                                                                                      |                                      | Incorrect or Lack of I/O Control Pulses                             |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          |                                          |                                                                |                                                                                      |                                      | Program Stavs in One Page of ROS                                    |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          |                                          |                                                                | -                                                                                    |                                      | Program Follows Unexpected Mean-<br>ingless Path Through Routines   |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          | ×                                        |                                                                | ×                                                                                    |                                      | Program Jumps to an Unused ROS Area                                 |  |
|                                                                                                                 | ×                                         |                                          | ×                                 |                                          |                                          |                                                                |                                                                                      | ·                                    | Timing Errors                                                       |  |

### CHAPTER 7

# **TECHNIQUES AND EXAMPLES**

#### TECHNIQUES FOR EFFICIENT MICROPROGRAMMING

In many aspects microprogramming is similar to assembly language software programming of small computers. There are basic arithmetic, logic, I/O, control, and memory functions. Programs are organized with executives and subroutines. Jumps and return jumps can be made. The basic differences are as follows:

- There are no variable addressing modes at the microcommand level. Memory accesses must be programmed on a step-by-step basis, with commands to set memory address, and to transfer data to and from T, which is the memory transfer register.
- Execution of commands is much faster than in a software machine.
- I/O functions must be programmed on a step-by-step basis, including setting up device connect codes in T, and programming input and output strobe pulses.
- Return jumps must be set up by storing return addresses in a file register.
- Arithmetic shift, control and logic functions are all register oriented, and are limited in scope, such as shift one bit position, add 8 bits, 8 bit logic, skip only one location, etc.
- The command or instruction memory is semi-permanent read only memory with a limited capacity, so that much care must be taken to conserve the number of commands or instructions in the program.
- The commands or instructions are much more intimately related to the machine architecture, and to bit patterns, therefore some knowledge of logic Boolean algebra, and small computer organization is highly desirable, and is applied to the programs.
- Interrupts are monitored by status sampling rather than hardware interrupts as found in software programmed machines.
- All commands or instructions are single word (16 bits) and relate to files, or register.
- Commands are organized in such a manner as to make is possible sometimes to do more than one function on a command, and this is necessary many times to conserve commands.
- The flexibility of programmable alteration commands is not as great as with software programs. A special register, called the U register, is necessary for this function.
- There are two levels of high-speed storage the file register and core memory. The files are general purpose at the microprogramming level.
- There are special commands in microcode not normally found in software commands, such as shift right 4, load zero, and literal to register, which simplify many functions.
- There are certain timing constraints related to I/O, memory, skips, jumps, and U register applications, which must be taken into account when preparing microprograms.

Even with all of the above constraints, it is possible to have microprograms which are 10-50 times as fast as equivalent software programs and which require the same or fewer instructions than a software program.

In order to make full use of the power of microprogramming a large number of techniques are possible to reduce the number of instructions, and/or to reduce execution time.

The following techniques are discussed in this next section:

- Generation of delays for memory accesses, U register applications, and input/output.
- 2. Double functions on a single command.
- 3. Uses, setting and testing of Link.
- 4. Uses of U register.
- 5. Setting and using of condition flags.
- 6. Use of loops vs straight line programming.
- 7. Small general purpose subroutines.
- 8. Use of shift right 4 instruction (generated with and without U).
- 9. Use of files for flags, counters, and reference data.
- Organization of Op codes, file, and core allocations to reduce instructions.
- 11. Saving diodes by selection of instructions and files.
- 12. Saving jump instructions when branching.
- 13. Reducing two branches to one by multifunction commands, and commands which become effective No Ops in one branch.
- 14. Interlacing vs cascading of routines.
- 15. Uses of inhibit file write.
- 16. Moving data from file to register.
  - 1. Generation of delays for memory accesses, U register applications and input/output.

Each of these items requires a delay of 1 to 3 clock times after the command. The desirable thing to do is some required function which provides the delay with no error. For example, on a memory write, T must not be written into for 4 clock times. On the 32-bit input example (#2) the write memory command is followed by reset DIXX, a skip test, and a jump. None of these affect T, so the entire memory delay is achieved with no loss of execution time. The memory time is then reduced from 1.1 µs to .22 µs. Also in this same example, the one clock delay after DIXX, prior to data input is achieved by advancing the byte address counter, thus avoiding a No Op. Most of the input and output delays can be generated by updating program counters, and addresses, etc. Microprogram Example No. 10 contains many of this type command. Microprogram Example No. 12A shows an example of placing a memory access command after updating U to provide a delay without a No Op.

# 2. Double functions on a single command.

The following double functions can be done, and should always be used when possible:

- a. Clear both a file and register with a copy 0 command. Similar techniques can be used to set both equal to 01, OR, FF.
- b. Update a file or register on a memory command. (This does not have to be a memory register.)
- Update a file, or register on an I/O control command. (Output moves only.)

# 3. Uses, setting and testing Link.

Link is used to indicate carry for an arithmetic function, or the shifted out bit on a shift function. It is used for multibyte arithmetic, shifting, or memory address incrementing.

Link can be preset by shifting a file, with inhibit file write. If link is to be set specifically to 1 or 0, it may be accomplished by subtracting zero or adding zero to any selected file regardless of its contents. For sign extension on a shift, link is preset to whatever value is in the end bit of the designated file.

The state of link can be tested without disturbing a file by executing a shift right command with the following c field functions: inhibit file write, enter link, and update the condition flags. The link appears in the MSB which sets or resets the negative condition flag. If the condition flags must be saved, then link can be entered into MSB or LSB of a file, and tested. Link can also be tested by entering into a file using the copy command as well as the shift command.

If link is used in a routine, care must be taken to avoid setting or resetting it on a function before the time it is to be tested.

# 4. Uses of the U register.

The U register is used for file indexing, and command modification. It is ORed with the upper 8 bits of the execute command or operate commands (except control) which select destination register value 7. Typical modifications are as follows:

### a. Execute 0020

The 2 in the c field selects T for add, subtract, logic functions, and copy. Therefore the 0020 can be used for multi-purpose command execution, by loading U with the desired Op code, and file register number.

For moving, loading or clearing a group of files, the Op code will remain fixed, and only the file number will change. In this case, the Op code for copy ('B') or move ('C') can be used with a 0 for the file number.

When U has been set, the new value does not become effective until the second clock. Sometimes two entirely different functions can be implemented using U. For example, if it is necessary to move the upper 4 bits or alternately the lower 4 bits of a file to the T register, this can be done as follows:



Case one: move upper 4

(U) = 74

Case two: Move lower 4

U = E4

with C = 2 this becomes E421 And f₄ with T——►T

If a number of different functions are to be done to a register in one pass through a loop, the operate command with destination code 7 is used. This can not be used if a destination register is required.

# 5. Setting and using condition flags.

The three condition flags are overflow, negative, zero. The condition flags remain unchanged unless the c field in an operate command is set for updating condition flags, or a control command is executed. The zero condition flag is used to test for arithmetic zero conditions, and for end of a subroutine loop. Condition flags can be set without changing files. Some of the techniques are as follows:

- a. fa+0—►C by inhibiting file write, and adding 0, the condition flags for a file state can be set.
  - b. T——f0, C by copying T and inhibiting file write, the condition flags for a T state can be tested.
  - c. enter sense switches to f0——C Sense switch 4 can be used to set the negative condition flag without affecting any register.
  - d.  $fA + T \longrightarrow C$  setting C for normal add function.
  - e. Copy Link——C Set negatitive, and zero condition flags.

# 6. Use of loops vs straight line programming

The two main factors of consideration are execution time and number of commands. If the number of commands using a straight line approach is five or less, there are no command savings using a loop because four commands are required to set up the loop as shown:



The loop takes much longer than the straight line approach. A typical loop is shown in Example 7. In this routine there would be nine functional commands per input byte for a total of 36 for four bytes. Using a loop reduces the command count to 12 commands. The straight line approach takes 7.94 us instead of 10.56 us as in Example 7. Therefore if time were very critical it might be desirable to use the straight line approach.

### 7. Small general purpose subroutines.

To reduce the total number of commands in a microprogram, subroutines can be used in a manner similar to software programs.

To jump to a routine on the same page requires 2 or 3 instructions, one for the return address, one for the jump, and usually one to set a flag, pointer, etc., for the subroutine. Therefore if the subroutine requires only 4 or 5 instructions it is not worth making as a standard. If the routine, such as a general purpose I/O routine requires 10 or so instructions and is used more than once, then it is definitely of value to make the routine general purpose.

### 8. Use of shift right 4 command.

This command is used to transfer the upper four bits of a file to the lower four in the file and/or to a destination register. The upper four are replaced with 1's, which may or may not have to be cleared. To clear the 1's, simply add '10' to the file after shifting. If the value is an Op code to be tested, the 1's can be treated as a constant. If the result is to be subtracted from another value obtained by similar means, the 1's will cancel.

### 9. Use of file register for flags, counters, and reference data.

File registers are used for routine control words as well as data. When it is necessary to conserve files, flags, etc., are sometimes stored in core between routines so that file register meanings may change during a microprogram. Also files can sometimes serve a dual function by judicious location of flags. In Example 19, there is a subroutine which must perform differently on alternate passes. On one pass there is an effective shift right 4 leaving 1's to be cleared. One file contains a flag to indicate which pass it is. This flag is also placed in bit position 4; therefore the file content can be added to the file containing 1's to be cleared, thus serving a dual function. Also a file assigned to update U can be used as the loop program counter.

# Organization of Op codes, file register numbers, and core memory addresses to minimize commands.

Many times it is possible to use particular files to make their addresses correspond to memory addresses, such as in Example 12A. This will save both files and commands. Also locating a block of data in one page saves an instruction. Use of file F for an instruction which may be either a shift or add will minimize instructions, as shown in Example 19.

# 11. Saving of diodes by selection of files and instructions.

If possible files used very often should have numbers which have the least number of diodes. If there is a choice of TZ, TN, or using condition flags vs. testing the file directly, the method which requires the fewest diodes should be used, particularly if there are very many ROM's to be built using discrete diodes.

# 12. Saving jump instructions when branching.

This example shows that if there are two branches, each having two or more commands, doing one of the branches first reduces the number of commands by two.



# 13. Reducing two branches to one by multi-function commands which become effective No Ops in one branch.

Many times a function varies with program state, such as moving upper or lower half of a byte in BCD manipulations. Sometimes widely varying functions can be combined by organizing the routine for the worst case function, and having some of its steps become effective no ops for the simpler functions.

This is illustrated in Example 19.



The odd state is for moving the upper byte. The even for the lower byte. If odd, the pertinent state when entering 'move' is

With this stage the value in U becomes 7f

This causes a shift R 4 at 1 with result to T, which nullifies command 2

If the state is even, the state of fe2, entering the move is E0. This causes U to become Ef which is the And function. This causes the contents of f to be Anded with (f) with result to T. In this case the '0F' loaded in T causes selection of only the lower half of (f). The next instruction 3 fe1+T $\longrightarrow$ T adds '10' to T if in the odd state, which clears the 1's resulting from the shift R. If in the even state, fe1 contains '00' so command 3 is an effective no OP.

### 14. Interlacing vs. cascading of subroutines.

What this means is entering a subroutine and remaining until an operation is complete, vs. doing parts of routines, and moving on to subsequent routines before finishing. Cascading results in the fewest instructions, but can drastically reduce throughput, if the routines are time paced by external devices, such as card readers, serial teletypes, line printers, in which case the microprogram must wait for data to be supplied by the interface. For example, teletype lines should be monitored by the microprogram on a bit sample basis instead of assembling an entire character. More commands are required to store and fetch pointers and status bits and to test for status, but the throughput improvements are worth the extra coding, and sometimes an absolute necessity.

# 15. Use of inhibit file write.

Inhibit file write is used for the following functions:

- a. Setting registers without changing the content of a file.
- b. Presetting Link using shift or arithmetic functions.
- c. Presetting the condition flags without changing the state of a file.

# 16. Moving data from a file to a register.

Normally data is moved from a file to a register using the OR function because it doesn't affect link. If the state of link is not needed, the move can be implemented using the Add 0 to file with a savings of one diode and always resetting Link.

# MICROPROGRAMMING EXAMPLES

The following Microprogramming Examples illustrate basic microprogramming techniques. Many routines, such as the 8-bit positive number multiply have been simplified from standard routines by omitting such capabilities as handling negative numbers as well as positive numbers. For a more detailed description of typical subroutines, and an entire program, refer to Part IV—MICRO 810 firmware reference manual.

Most of the routines do not contain the linkages to an executive program, such as setting return addresses, etc., because these vary with the type of executive in which the routine may be used.

Some of the routines were selected only as examples to illustrate certain microprogramming techniques, and may not use the simplest possible algorithm.

The examples are done in flow chart and assembly language coding, along with comments. For normal programming, the comments are not usually as detailed as these examples. Execution times are included to illustrate the high processing rates possible using microprogramming. Machine code is included for the first 15 examples.

# The names of the example subroutines are as follows:

- 1. Multiply 2 Positive 8 Bit Numbers
- 2. Subroutine Jumps
- 3. Time Delay Routine
- 4. Input Data from 4 External Registers
- 5. Load 8 Successive File Registers from 8 Successive Core Locations
- 6. 16-bit Addition, Core to File Register
- 7. Input a 32-Bit Word From an External Device to Core Memory
- 8. 16-Bit Right Shift with End Around Carry
- 9. A ORed with B, Result to A
- 10. Update a 10 BCD Digit Display From Core
- 11. Clear a Block of Core Memory
- 12. Read and Write Between 8 Files and 8 Consecutive Core Locations
- 13. Output From 8 Files to 8 Shift Registers
- 14. Input From 8 Shift Registers to 8 Files.
- 15. Input a Block of Data to Core From an A to D Converter
- 16. BCD to Binary Conversion
- 17. Binary to BCD Conversion
- 18. General Purpose Multiple File Shift Routine
- 19. Hexadecimal to ASCII Conversion Routine
- 20. General Purpose Code Conversion by Table Lookup
- 21. Binary Multiply (16 bits)
- 22. Generate Cyclic Redundancy Code for one 8-Bit Data Byte
- 23. Generate ASCII Parity

# **Multiply Two Positive Numbers**

### X \* Y = z

# Specific Considerations

- Each number 8 bits maximum including sign.
- Result to occupy two 8-bit file registers.
- Numbers to be in file registers before multiply routine.

# General Approach

Use Add and Shift Algorithm.

# File Register Assignments

F2 = X

F3 = Y, and Z Lower

F4 = Z Upper

F5 = Loop Counter

# Data Flow





Functional Flow Chart for Multiply

# Program for Multiply routine:

| Mad                                                                | chine Code                                                                           | As   | sembly Langu                                          |                                                                                                       |                                                                                                                               |
|--------------------------------------------------------------------|--------------------------------------------------------------------------------------|------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| L                                                                  | Command                                                                              | Name | Operation                                             | Operand                                                                                               | Comments                                                                                                                      |
| 000<br>001<br>002<br>003<br>004<br>005<br>006<br>007<br>008<br>009 | 2508<br>C201<br>2400<br>4301<br>8420<br>F420<br>F3A0<br>9550<br>5004<br>1403<br>1780 | ADD  | LF<br>MT<br>LF<br>TZ<br>A<br>H<br>D<br>TN<br>JP<br>LS | 5, X'08'<br>2<br>4, X'00'<br>3, X'01'<br>4, T<br>4, R<br>3, L, R<br>5, C<br>0, X'04'<br>ADD<br>X '80' | Set Loop Ctr = 8 Move X to T Reg. Clear ZU Y Bit 0 = 1 Add X to Z Shift ZU Shift ZL Decrement Ctr Loop Ctr = 0 Jump Loop Halt |

### For Simulator:

1. Load ROS: P000, 2508, C201, etc.

2. Data Values: Set file 2, f<sub>3</sub>

D2, type in X D3, type in Y

3. Execute: G0000 CR

4. Display results with D2, D3, D4.

 $\begin{array}{lll} \text{BINARY} & \text{DECIMAL VALUES} \\ \text{BIT BY BIT} & \text{X} = 89 \\ \text{EXAMPLE OF} & \text{Y} = 106 \\ \text{MULTIPLY} & \text{Z} = 9434 \end{array}$ 

Binary Values Initially Y, this ends up as Z lower ADDO 1. SHIFT Least significant ADDX bit is tested each SHIFT time to deter-ADDO Q mine if X should 3. SHIFT be added or not. **ADDX** SHIFT ADDO 5. SHIFT ADDX SHIFT ADDX 7. SHIFT **ADDO** 8. SHIFT 

FINAL RESULT = 9434

This program loops 8 times.

Execution time = 14.74 microseconds.

#### MICROPROGRAM EXAMPLE NO. 2

### Subroutine Jumps

Return jumps to subroutines can easily be implemented in microprograms. Two examples are shown below. One is for return jumps to programs on the same page, and the other is for return jumps to another page. A page is 256 locations.

a. Return Jump to Routine on same page (or pair of pages).



To do a return jump to the same page (or pair of pages), the address of the next command after the jump command 3 is loaded into a temporary file register, called W in this example. 1 Then the jump is made to the first command of the subroutine 2. The return jump command 4 moves the return address (stored in W for this example) into L or K. (K is simply L with the page bit set to 1.) This command causes L to jump to the programmed return jump location.

# b. General Return Jump

To jump to any location in the read only memory requires an additional step besides that described in example a. It is necessary to have an additional return address for page identification. One way to mechanize a general scheme for return jumping to subroutine is to have a pointing command on each page and to use an indirect jumping technique.

This is illustrated by the following read only memory map. The indirect jump location is at the same address on each page (FF for this example).

Two files are assigned for return addresses, one contains the page, and the other the return address on the page. Both of these must be set



prior to making the jump. RP is the page pointer. If for a number of commands there is no multiple re-entry points, or multiple nesting across page boundaries, RP can be set, and left set for a number of commands.

The return jump to originating PAGE is accomplished using the execute command with the U register. Since the intermediate jump locations are all at XFF, it is only necessary to load U with the X (or page identifier) from RP. This is mechanized as follows:

RP = file E RJ = file F

# Page 0 for Jump Command

| 015<br>016<br>017 | 2E14<br>2F18<br>1D41 | LF<br>LF<br>JP |      | RP, X'14'<br>RJ, X'18'<br>SUB | Return Page to RP<br>Return Address |
|-------------------|----------------------|----------------|------|-------------------------------|-------------------------------------|
| 018               |                      | Next           | comn | nand after subre              | outine                              |
| 341               | 2104                 | SUB            | LF   | 1, X'04'                      | Any command may be here             |
|                   |                      |                |      |                               |                                     |
| 350               | CE01                 |                | ΜU   | RP                            | Set Page into U                     |
| 351               | 8000                 |                | Α    | 0                             | No Op delay, to use U               |
| 352               | 00FF                 |                | ES*  | 0, 15                         | Execute to interpret RP value       |
|                   |                      |                |      | •                             | as page jump command                |

Execute command:

0 0 F F Execute
1 4 III U Register
1 4 F F effective command

Jump to Page 0 location FF

at Page 0 location FF

OFF CF04 ML RJ

This loads L with return address in RJ.

# **MICROPROGRAM EXAMPLE NO. 3**

# **Time Delay Routine**

Nested loop program to generate a time delay, such as can be used to sample serial teletype data.

## Specific Considerations

- Two nested loops, with file 1 assigned to inner loop and file 2 assigned to outer loop.
- File 0, zero condition flag, is used to indicate zero count for both loops.

# Functional Flow Chart:



## Program for Time Delay Routine:

| Machine Code |         | As                 | sembly Langu |            |                                   |
|--------------|---------|--------------------|--------------|------------|-----------------------------------|
| L            | Command | Name Operation     |              | Operand    | Comments                          |
| 000          | 22 ②    |                    | LF           | 2, X" ② '  | Set outer loop                    |
| 001          | 21 ①    | Γ <del>≻</del> LP2 | LF           | 1, X ' ① ' | Set inner loop                    |
| 002          | 9150    | ►LP1               | D            | 1, C       | Decrement inner loop file 1 Set C |
| 003          | 5004    |                    | TN           | 0, X'04'   | Zero count?                       |
| 004          | 1402    |                    | JP           | LP1        | Jump inner loop                   |
| 005          | 9250    |                    | D            | 2, C       | Decrement outer loop file 2 Set C |
| 006          | 5004    |                    | TN           | 0, X'04'   | Zero count                        |
| 007          | 1401    |                    | — JP         | LP2        | Jump outer loop                   |
|              |         |                    |              |            |                                   |

- ② outer link count
- nner link count

# Calculation of delay:

The delay of this routine can be calculated by preparing a flow graph with the number of clock times for each branch in the graph. The graph for this routine is as follows:

# Flow Graph for Time Delay Routine:



Number of clock times, 
$$C = 8 + 8 (m - 1) + 4m (n - 1)$$
  
= 4m (1 + n)

$$t = .22 C microseconds = .88m (1 + n)$$

where

m = outer loop countsn = inner loop counts

This equation is valid for 1 < m, n < 255.

If m or n = 0, their effective value becomes 256.

Examples of clock time calculations:

| m | n | С  | t (microseconds) |
|---|---|----|------------------|
| 1 | 1 | 8  | 1.76             |
| 1 | 2 | 12 | 2.64             |
| 2 | 1 | 16 | 3.52             |
| 2 | 2 | 24 | 5.28             |

Example of derivation of m and n:

Calculate m and n for a time delay of 20 milliseconds = 20,000 microseconds.

# Solution:

.88m (1 + n) = 20,000  
pick m = 20,000 = 142 decimal = '8E' hexadecimal  
then .88 x 142 (1 + n) = 20,000  
n = 
$$\frac{20,000}{.88 \times 142}$$
 - 1 = 160-1 = 159 decimal = '9F' hex.

## **Data Input from 4 External Registers**

Input data from 4 registers (at device '08', '28', '48', '68') to core locations '0200', '0201', '0202', '0203'.

#### Flow Chart:



Program for Input Date Byte Routine:

| Martin Oada Amerika Larana |                |      |              |           |                                          |
|----------------------------|----------------|------|--------------|-----------|------------------------------------------|
| Machine Code               |                | As   | sembly Langu |           |                                          |
| L                          | Command        | Name | Operation    | Operand   | Comments                                 |
| 000                        | 2A08           |      | LF           | 10, X'08' | Set Register<br>Address                  |
| 001                        | 1202           |      | LM           | X'02'     | Set M Address register = '02'            |
| 002                        | 2BFF           |      | LF           | 11, X'FF' | Set N Address<br>register = Int.<br>Add1 |
| 003                        | CA01           | ADD  | MT           | 10        | Register Address<br>to T                 |
| 004                        | 7090           |      | K            | 0, 9      | Set COXX                                 |
| 005                        | 1000           |      | LZ           | X'00'     | No Op Delay*                             |
| 006                        | 7080           |      | K .          | 0, 8      | Reset COXX                               |
| 007                        | 70E0           |      | K            | 0, E      | Set DIXX                                 |
| 800                        | 21FF           |      | LF           | 1, X'FF'  | Set Data Mask                            |
| 009                        | ABD3           |      | WN           | 11, I     | Update N, start a write                  |
| 00A                        | 7181           |      | KT           | 1, 8      | Input to T, reset DIXX                   |
| 00B                        | 3A20           |      | AF           | 10, X'20' | Update register address                  |
| 00C                        | 6A80           |      | СР           | 10, X'80' | Skip if $(f_A) > 68$                     |
| 00D                        | 1403           |      | JP           | ADD       | Jump Loop                                |
| 00E                        | E Next command |      |              |           |                                          |

<sup>\*</sup>If LZ is used for a special interface, it may not be usable as a No Op.

# Load 8 successive file registers (f<sub>1</sub>-f<sub>8</sub>) from 8 successive core locations (0301-0308)

Use the execute command for loading files. The U register will be loaded with a value which has a Copy T as an Op code. Use file 9 to contain and update U register values. File 9 will also act as a loop counter. Use file A to contain and update N address register value.



# Program for Loading 8 Successive Files from Core:

| Machine Code |          | А     | ssembly Lang |           |                                            |
|--------------|----------|-------|--------------|-----------|--------------------------------------------|
| L            | Command  | Name  | Operation    | Operand   | Comments                                   |
| 000          | 29B0     |       | LF           | 9, X'B0'  | Initial U value -1                         |
| 001          | 1203     |       | LM           | X'03′     | M address                                  |
| 002          | 2A00     |       | LF           | 10, X'00' | Initial N address -1                       |
| 003          | 8946     | LP1   | AU           | 9, I      | Update file 9 and<br>U register            |
| 004          | AAC3     |       | RN           | 10, I     | Read memory and update N, and file 10      |
| 005          | 0020     |       | E            | 0, 2      | Copy T to file register 1 to 8 in sequence |
| 006          | 6948     |       | СР           | 9, X'48'  | (fg) > B7                                  |
| 007          | 1403     |       | JP           | LP1       | Jump Loop                                  |
| 800          | Next con | nmand |              |           |                                            |

# Effective command at 005:

| Execute<br>U register | 0020<br>B1 |                  |
|-----------------------|------------|------------------|
| Effective             | B120       | Copy T to file 1 |

# 16 Bit add (core to file)

This routine adds the contents of files  $A_U$ ,  $A_L$  to a 16 bit word in core memory at the address contained in  $O_U$ ,  $O_L$  and places the result in  $A_U$ ,  $A_I$ .

## File designations:

Temp. register  $S = f_1$ 

Data in files AU = f4, AL = f5

Core memory address in  $O_U = fg$ ,  $O_L = fg$ 

Result in file  $AU = f_4$ ,  $AL = f_5$ 

## Memory Location:

Data in Dij and Di (successive bytes in core)

The condition flags are set by this routine to indicate negative result, overflow, or linked zero test over multiple bytes.



This routine has 8 microcommands, and takes 2.86 microseconds\* to execute. There is an effective 3 clock delay after the 1st memory command, due to changing N and selecting T, and a 2 clock delay after 2nd memory command due to selecting T.

<sup>\*</sup>Not including return jump.



# Input a 32 bit word from an external device to core memory.

This routine causes the data in a 32-bit word to be partitioned into 4 bytes which are input to 4 consecutive core locations designated by  $O_U$  and  $O_L$ .

# File Designations:

 Core memory address for data is in O<sub>U</sub> = fg, O<sub>L</sub> = fg. Byte address is in F<sub>B</sub> = f<sub>B</sub>.

Byte Addresses: 01, 21, 41, 61.

# Memory Locations:

4 successive bytes starting with the 1st location in O[], O[.



In order to save microcommands some of the functions shown in the top level flow chart are dispersed and combined with other functions as shown in the detailed flow chart.

The write memory command is deliberately placed before the data point command in the detailed flow chart to allow memory to start prior to changing T.

This routine has 12 microcommands and takes 10.56 µs to execute, which includes all I/O and memory access timing, but does not include return jump.



16 bit right shift with end around carry with the shift count in file register S.

# File Designations:

- Data to be shifted in files AU, AL
- Shift count in file S.





File S = f<sub>1</sub> A<sub>U</sub> = f<sub>4</sub> A<sub>L</sub> = f<sub>5</sub>

This subroutine has 6 commands. The execution time is  $1.54 \,\mathrm{N}^*$  microseconds, where n = number of bit positions shifted.

\*Not including return jump.



The number of bytes shifted can be increased by adding one command per byte which is .22 ns/byte per loop additional time.

#### A ORed with B to A

Logic Symbol

A ∨ B—►A

In this routine the contents of  $A_U$  and  $A_L$  is logically ORed on a bit-by-bit basis with the content of  $B_U$  and  $B_L$ . The result is placed in  $A_U$ ,  $A_L$ .

## File Register Designations:

Data Files 
$$A_U = f_4$$
,  $A_L = f_5$   
Files  $B_U = f_6$ ,  $B_1 = f_7$ 

| DETAILED FLOW<br>CHART |     | HINE<br>. CODE |    |    | LANGUAGE<br>R OPERAND | COMMENTS     |
|------------------------|-----|----------------|----|----|-----------------------|--------------|
| BL — T                 | 000 | C701           | OR | мт | BL                    | Move B → T   |
| ALVT - AL, C           | 001 | C530           |    | o  | AL, T, C              | OR AL with T |
| <u>₩</u><br>Bu → T     | 002 | C601           |    | мт | BU                    | Move BU → T  |
| AUVT — Au, C           | 003 | C4B0           |    | o  | AU, T, C, L           | OR AU with T |

The last operand includes L to provide a linked zero test over multiple bytes.

This routine has 4 commands and takes .88 microseconds, not including return jump.

#### **MICROPROGRAM EXAMPLE NO. 10**

# Update 10 BCD digit display from core.

For this routine a 5-byte packed BCD image of the digital display is maintained at all times in core. This image is updated by other programs. Periodically this routine is utilized to transfer the image out to the display lamps. The routine uses the standard COXX, DOXX procedures, which output a device and function code, strobed by COXX, followed by a data value (in this case two packed BCD digits) strobed by DOXX. Two digits are updated by each output byte.

#### **Data Characteristics:**

- 2 digit packed BCD per byte in core in consecutive locations.
- Data sequenced to display one byte at a time, display logic automatically sequences through latches.
- Data sequencer enabled by 1st byte containing all 1's, and disabled by last data byte.
- Core location addresses in O<sub>U</sub> = f<sub>6</sub>, O<sub>L</sub> = f<sub>7</sub>.
- Display output byte address is in F<sub>B</sub> = f<sub>B</sub>.
- Standard I/O logic is used which automatically disconnects after each byte is transferred.
- Display byte count is in F<sub>C</sub> = f<sub>C</sub>.
- Data from memory is temporarily held in FD = fD.



This routine has 14 commands and takes 13.42 microseconds to execute.



## Clear a block of core memory.

This routine causes a selected block of core memory to be set to all zeros.

# File Register Designations:

Starting of current address  $SU = f_8$ ,  $SL = f_9$ Ending address  $EU = f_A$ ,  $EL = f_B$ Zero value in  $FZ = f_1$ 



On a write memory command, data in  $\ensuremath{\mathsf{T}}$  is stored in the memory location set by  $\ensuremath{\mathsf{M}}$  and  $\ensuremath{\mathsf{N}}.$ 

This routine has 12 commands. It takes 3.52 microseconds to clear the first byte, plus 3.08 microseconds for each additional byte. Clearing a fixed length block in one page takes only 1.1 µs per additional byte.



## Read 8 consecutive core locations into 8 consecutive file registers.

This routine is used to move a block of data from core to the files.

# File Designations:

Files 1-8 to receive data

File E Memory address and file index.

U register is used to index through the files.

## **Dedicated Core Locations:**

All on page 0, with  $N = 01, 02, 03, 04, \dots 08$ .



6 commands are required. Execution time is 14.08  $\mu s$ .



#### Write 8 consecutive files into 8 consecutive core locations.

This routine is similar to 7a except for use of a write command and a move to T command, which requires the execute command to have T as a destination. File U ( $f_E$ ) contains the Op code for a move, so it can't be used for the memory address if N = 01, 02, etc.

7 commands are required. Execution time is 10.78  $\mu$ s.



# Output from 8 files to 8 shift registers.

#### 8a. File to register bit order the same.

This routine provides the microprogramming for utilization of the minimum number of logic chips to get 64 lines out from the computer. These lines can be used to drive displays, printers, etc.

This routine is used where the order of bits shifted out is important or where the number of output shift registers is less than 8 so there is no symmetry.

The next Example (8b) shows much simpler coding to interface with 8 shift registers without pattern rotation.

#### File Allocations:

| Files 1-8 | Data                    |
|-----------|-------------------------|
| File 9    | Shift assembly register |
| File E    | File index register     |
| File F    | Shift count register    |

Since this is a minimum hardware interface, the load zero command (CGOX) will be used to strobe the data directly out of T.





This routine has 12 commands.

It takes 107.36 microseconds to execute this routine.

This routine used in conjunction with routine 7 for loading core to files requires 19 commands total, and 118.14 microseconds to output 8 core locations to 8 output bytes with an 8-chip interface.



## File to register; with hardware rotation of bit pattern.

In most cases, such as for updating digital displays, etc., it doesn't matter if the pattern in the 8 file registers is "rotated" with respect to the 8 output shift registers. In the example below, file 8 becomes disassembled into 1 bit in each of the 8 output shift registers. By changing the connection of wires to the display, the effective rotation can be cancelled. By allowing for rotation, the microprogram becomes much simpler than the example in 8a.



## File Register Designations:



This routine requires 7 instructions, and takes 10.78 microseconds to execute. So there is a tremendous time savings over the 8a example which requires pattern rotation by the microprogram.



<sup>\*</sup>In this routine FE and U are updated after the execute command to avoid an extra delay which is required after updating U. In this case the delay is accomplished by the test and jump instruction.

# Input from 8 shift registers to 8 files in MICRO 800.

This routine is somewhat similar to routine 13B except that data is input. The shift registers in the interface are parallel in, serial out.

Interface Block Diagram:



# File Register Designations:

file 1 - file 8 data file registers

file E file index



This routine has 10 instructions and takes 14.52 microseconds to execute.



## Input block of data to core from A to D converter.

This routine shows a method for inputting a series of 16-bit data words from an ADC. The sample rate is controlled by the read time clock option. The data words are placed in consecutive core locations. A software flag is set when the sample data block is complete.

# Block Diagram:



# File Register Designations:

 $S_{i,j} = f_4$ ,  $S_{i,j} = f_5$  Starting (or current), address in data block.

 $E_{11} = f_6$ ,  $E_{1} = f_7$  End address in data block.

 $F_F = f_F$  Bit 0 software flag.

FE = fE Input routine file index.

 $D_U = f_2$ ,  $D_L = f_3$  Temporary files for input data.

 $F_S = f_1$  Input status file.  $F_B = f_B$  Byte address file.

'FF' and COXX = Digitize Command.

The microprogram tests the input status byte for conversion complete before inputting data.

TESTING FOR REAL TIME CLOCK INT. INTERRUPT N EXIT 1 -JUMP **ENTER INTERNAL STATUS** RT CLOCK N EXIT 2 JUMP DATA JUMP BLOCK FLAC RESET EXIT 3 ENTER DATA INPUT ROUTINE **OUTPUT DIGITIZE COMMAND** INPUT STATUS BYTE FOLLOWED BY TWO DATA BYTES . N CON-VERSION COMP STORE INPUT DATA ADVANCE CURRENT ADDRESS REGISTER CUR-RENT AD SET DATA **EXIT** DRESS = **BLOCK FLAG END EXIT** 

This routine has 40 commands including the real time clock test.

The execution time is approximately 26 microseconds per sample, including time for conversion, and testing real time clock.

The time delay from digitize command to conversion complete could be used for housekeeping if it can be worked in at that time in the program. This would result in an effective time reduction for this routine.

A status byte and two data bytes are input and then status byte is tested. If conversion is not complete, the two input bytes are discarded, and another sample of data and status is taken.





Notice in this routine that after the two write commands, M is deliberately made the destination register of a command, to generate a delay prior to modifying T.

# Conversion of 3 digit BCD plus sign into Binary.

Given 3 digits in the registers BU and BL. Binary result will be in AU and AL.



other files used: Op = file 1 Digit value

V = file A Power of 10 Binary W = file B Return Address

The basic technique is to multiply each BCD digit by its power of 10 expressed in binary, and to add each converted digital value in an accumulator. The top level flow is as follows:



## BCD to Binary Program:

| Name | Operation                            | Operand                                                   | Comments                                                                                                                                                                                                                                                                                |
|------|--------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CB   | LF<br>MT<br>N C<br>C K<br>LT<br>N LF | AL,X'0F' BL AL, T AU OP, T OP, 2 X'0F' OP, T V, 10 W, CB1 | Set Mask for lower BCD Digit. Move Lower 2 Digits to T. Mask, select lower Digit of AL. Clear A upper. Copy lower 2 digits from T to Op. Shift OP right 4, move 2nd digit to LSD. Load Mask in T. Mask out all but 2nd digit. Put Binary value for 10 in V. Load Return Address into W. |
| CB1  | JP<br>LF<br>MT<br>N<br>LF<br>LF      | CB4<br>OP,X'0F'<br>BU<br>OP, T<br>V, 100<br>W, CB2        | Jump to Multiply Routine. Set Mask in Op for 100's digit. Move 100's digit to T. Mask out all but 100's digit. Put Binary value for 100 in V. Load Return Address into W.                                                                                                               |
| CB2  | JP<br>TN<br>JP<br>X<br>I             | CB4<br>BU,X'80'<br>CB3<br>AL, T, F<br>AL<br>AU, T, F      | Jump to Multiply Routine. Test for Sign bit in B. Exit if Positive Sign. Ones Complement AL. Add one for 2's complement. Ones complement AU.                                                                                                                                            |
| СВЗ  | A<br>MU<br>A<br>ES*                  | AU, L<br>RP<br>0<br>0, 15                                 | Add carry for 2's complement.<br>Set up Page Jump.<br>No OP after changing U.<br>Execute implements gen. Page Jump.                                                                                                                                                                     |
| *    |                                      | MULTIPLY R                                                | OUTINE                                                                                                                                                                                                                                                                                  |
| CB4  | MK<br>MT<br>A<br>D<br>JP             | OP,X'FF'<br>MK W<br>MT V<br>AL, T<br>AU, L<br>OP<br>CB4   | Test to see if Op has reached 0. Return from Multiply Routine. Move power of 10 binary to T. Add power of 10 to accumulator. Add carry to AU. Decrement Op. Jump Loop until Multiply over.                                                                                              |

The multiply routine selected for this example (at CB4) is designed for minimum commands rather than minimum execute time. The multiply routine execution time is dependent on the size of the digit being converted.

The BCD digit is put into one register, and the power of 10 in another register. The BCD digit is decremented once each time the binary value for the power of 10 is added to the accumulator. When the digit is decremented to 0, the loop is exited. The average number of times through the loop per digit is 4. This is 35 clock times or about 7 microseconds.

The total average conversion time for 3 digit BCD numbers to binary is about 22 microseconds.

#### Binary to BCD Conversion.

Convert a positive binary number with a value equal to or less than 999 (decimal) into a 3-digit packed BCD integer.

**Conversion Algorithm:** Binary number will be successively divided by powers of 10 (starting with 100) with quotient equal to BCD value, and remainder to be divided by next lower power of 10.



## File Register Assignments:

1. Binary number is initially in Au and Au.



2. BCD result is in DU and DL.



- 3. AU, AL, BU, BL, CU, CL are used for dividing registers as follows:
  - A and B are an extended accumulator containing the dividend, C contains the divisor.
  - b. After the divide, the quotient is in B, and the remainder is in A.
  - c. Prior to the divide, the content of A is moved to B, and A is cleared.

# 4. The flow of data through the registers is as follows:



Binary to BCD conversion routine flow chart:



This routine (including the two divides), takes 47 commands, and approximately 150 microseconds to execute.

The divide routine used for this example is for positive binary integers only. It is implemented with a shift and subtract algorithm.



This divide algorithm will actually handle larger numbers than occurring in this example but is the simplest routine from a command count standpoint. For numbers the size used in this example, the divide operation could be speeded up by shifting right 6 times before starting to subtract the divisor.

# Assembly Language Program to

# Convert Positive Binary, 10 Bit Integer in A to 3 Digit Packed BCD Integer in D.

Uses simplified Divide Routine.

| Name | Operation | Operand     | Comments                            |
|------|-----------|-------------|-------------------------------------|
| CV   | LF        | CU, 0       | Clear C upper.                      |
|      | LF        | CL, 100     | 100's coefficient to CL.            |
|      | LF        | W, CV1      | Set return address.                 |
|      | JP        | CV3         | Jump to divide set up routine.      |
| CV1  | MT        | BL .        | Move most significant digit to DU.  |
|      | С         | DU, T       | wove most significant digit to bo.  |
|      | LF        | CL, 10      | 10's coefficient to CL.             |
|      | LF        | W, CV2      | Set return address.                 |
|      | JP        | CV3         | Jump to divide set up routine.      |
| CV2  | MT        | AL `        | Move least significant digit to DL. |
|      | С         | DL,T        | wove least significant digit to DE. |
|      | Н         | BL )        |                                     |
|      | Н         | BL          | Shift the 10's digit left one digit |
|      | H ·       | BL          | position.                           |
|      | HT        | BL          |                                     |
|      | 0         | DL, T       | Move middle digit to DL.            |
|      | MK        | Υ           | Return.                             |
| CV3  | MT        | AL )        | -                                   |
|      | С         | BL, T       | Move (A) to B.                      |
|      | _ MT      | AU          | move (7 ty to 5.                    |
|      | С         | BU, T       |                                     |
|      | С         | AL )        | Clear A.                            |
|      | С         | AU <b>J</b> |                                     |
|      | LF        | RJ, CV4     | Set return address.                 |
|      | JP        | DV          | Jump to divide routine.             |
| CV4  | MK        | W           | Return to binary to BCD.            |

The calling sequence for this routine is LF Y, RET JP CV

Divide routine is on the same page as conversion routine.



# General purpose multiple file shift routine.

This routine provides a general purpose capability for shifting a group of contiguous file registers with a number of variations as indicated below.

The following items are program variable:

- Number of bytes 1-8, always starting with file 1.
- Number of positions shifted 1 to 256.
- Direction left or right.
- Enter one of following into vacated bit: 0, 1, LSB, MSB; which provides the capability for arithmetic or logic shifts with sign extension, end around carry, clearing, or setting to 1's.

#### RIGHT SHIFT



For a right shift, entering MSB causes sign extension and LSB causes end around carry.

#### LEFT SHIFT:



For a left shift, entering MSB causes end around carry, while LSB causes odd/even extension.

# File Register Designations:

File 1-8 Shift registers as selected by the instruction.

File 9 Byte count, and shift mode.

| 7                                           | 4      | 3 |            | 0 |
|---------------------------------------------|--------|---|------------|---|
| 0                                           | 3 BITS | 0 | 3 BITS     |   |
| BYTE COUNT<br>(NUMBER OF FILE<br>REGISTERS) |        |   | SHIFT MODE | _ |

| Shift<br>Mode    | Direction | Enter into vacated bit |
|------------------|-----------|------------------------|
| 000              | L         | enter 0                |
| <sup>-</sup> 001 | L         | enter 1                |
| 010              | L         | enter LSB              |
| 011              | L         | enter MSB              |
| 100              | R ·       | enter 0                |
| 101              | , R       | enter 1                |
| 110              | R         | enter LSB              |
| 111              | R         | enter MSB              |

File A Shift count

File B File index (f())

#### TOP LEVEL FLOW CHART



### **Presetting Link**

Link is preset by one of the following:

- 1. Shifting right file 9 to preset link with 0 of 1.
- 2. Shifting left file 1 to preset link with MSB.
- 3. Shifting right the highest numbered file of the shift register to preset link with LSB.

In all cases, inhibit file write is used to preserve the value in the file.

For the actual right or left shift, the execute command is used, with the file register number in U.

The byte count in file 9 is shifted right 4 and placed in T and U at the beginning of the program. The all 1's left in the upper 4 bits can be left there because they conveniently form the Op code for shift. T is used to hold the maximum file register number for reference purposes.

Since link is used extensively for holding shifted out bits for the next shift command, special care was taken in preparing the program to avoid commands other than the shift commands which affect link.

This routine has 29 commands.

The execution time is approximately

[5.94 + 1.32 x (byte count)] x (bit count) microseconds

For example 1 8 bytes, 4 bits

Time = 66 microseconds

For example 2 2 bytes, 1 bit

Time = 8.58 microseconds.





#### Hexadecimal to ASCII Conversion Routine.

This routine converts an 8 bit binary number (which is also 2 hexadecimal digits) into two ASCII characters, and also generates an ASCII equivalent for a space. The 3 characters are assembled for sequencing to an output device for print out.

#### Data Flow:



## Typical print out sequence:

Data values and flags are maintained and updated in dedicated locations in core memory. If new characters are ready for output before converted characters are printed out, any queueing will be provided by a different routine. This routine will provide a flag to indicate when it's ready to receive a new character, and sets a flag for output request. Output is done by another routine, which monitors the output request flag of this routine and resets it after outputting a character.

## Core Memory Requirements:

| File register |
|---------------|
|---------------|

|   | COLE |                                                 |
|---|------|-------------------------------------------------|
| 1 | 0001 | Flags                                           |
| 2 | 0002 | Binary word                                     |
| 3 | 0003 | ASCII for blank                                 |
| 4 | 0004 | ASCII for least significant digit               |
| 5 | 0005 | ASCII for most significant digit and for output |

Next character to be transferred counter MSD 11 LSD 10 Blank 01 None 00

Zero count here and in bit 2 indicates ready for new character.

## Flag word:





#### Command Count 53.

Execution time for conversion of character is approximately 20 microseconds.

# A. Routines already described.

# 1. Get flags and data words from core.

This subroutine is the same as subroutine example 7a with the one modification to change the file count from 8 to 5.6 commands required.

# 2. Restore flags and data words to core.

This routine is similar to example 7b except that the file count is changed from 8 to 5, 8 commands required.

## B. Detailed flow charts for remaining routines:





#### **DETAILED FLOW** ASSEMBLY LANGUAGE CHART NAME OPER OPERAND COMMENTS Ν (fu) = '72' (NOT 'E2') TZ fu, X'10' Test bit 4 to indicate '72' vs 'E2'. JUMP JP BLK Jump to load ASCII for blank. **'72'** -X'72' Set U for control command to do SR4. <u>'10' -</u> → FD LF FD, X'10' Set fd for MSD. (D) JP JUMP MSK ► F<sub>3</sub> ASCII for Blank. BLK LF F<sub>3</sub>, X'A0' 'FC' **→** T LT X'FC' Set bits 0 and 1 in f1=0 to clear next character to be transferred counter. $F_1 \wedge T \longrightarrow F_1$ F<sub>1</sub>, T JUMP JP SET



# General Purpose Code Conversion by Table Translation.

This routine will convert a string of characters from any one of 64 characters into any of 64 other characters (character capacity easily changed). The translation table which is in core memory can be loaded with any desired code.

The general approach is to use the character as a displacement value and index into a table to obtain the corresponding character. This type of code conversion is useful where there is no simple mathematical relationship between the two character sets (as with BCD to ASCII, for instance).

## Table organization in core:



# File Assignments:

LL = Lower 8-bits of data list address.

LU = Upper 7-bits of data list address.

TL = Lower 8-bits of translation table address.

TU = Upper 7-bits of translation table address.

CNT = Number of characters in data list.

FT = Mask to limit the table to 64 entries.



This routine uses 13 commands, and takes 4.18 microseconds per character for translation.



## Binary Multiply (16 bits)

This routine multiplies two 16 bit positive or negative numbers. The two byte operand in X is multiplied by the contents of A and the result is placed in the 32 bit A - B registers. The multiply is an integer type, and the 30 bit resultant magnitude occupies the 30 low order bits of A and B, and a double sign bit occupies the two high order bits.

This example is the same as the routine used in the MICRO 810 firmware except for deletion of memory referencing, concurrent I/O servicing, and linking to the 810 program.

The basic algorithm for this routine consists of testing the LSB of B, and adding X to A whenever LSB of B=1; then shifting the accumulation right one place, as well as shifting B right one place. Then the next LSB of B is tested. This is repeated until all parts of A have been tested.



To simplify programming, A is first transferred to B, then A is cleared. The contents of A are not tested for sign until after it has first been transferred to B. This is only for convenience of programming. If B is negative, both numbers are 2's complemented. If X is negative, the sign is maintained by sign extension, during shifting.



file registers
AU, AL Multiplicand (1st)
BU, BL Multiplicand (2nd)
XU, XL Multiplier
S<sub>2</sub> Shift Count

AU, AL BU, BL Product

- 1 Link is set to provide for sign extension of the partial accumulation.
- ② If there is overflow, link is already set to the correct sign value, which may not = MSB of A.

This routine has 32 commands, and takes the following approximate time: Max. 60 microseconds; Average 54 microseconds.





## Generate Cyclic Code for one 8 bit data byte.

This routine generates the CRC 16 cyclic redundancy code used in bisynchronous communication.

The byte operand in  $S_1$  is entered into the 16 bit cyclic code contained in the A register. The polynomial used for generating the cyclic code is  $x_16 + x_15 + x_2 + 1$ 

The general algorithm is to shift the 16 bit code in A, and to exclusive OR bits 15, 13, and 0 with the result of a comparison between the least significant bits of the cyclic code in A and the least significant bit of  $S_1$  shifted once for each comparison.

This is a microprogram rendition of the feedback shift registers which are used to implement polynomial divisions for generating cyclic codes.

At the beginning of a character string, A should be cleared.

For each 8 bit data byte the top level flow is as follows:



This routine takes 15 commands and takes the following approximate time:

| t max. | 30 microseconds |
|--------|-----------------|
| t avg. | 28 microseconds |

file registers

| CRC code      |
|---------------|
| Data byte     |
| Save Link     |
| Shift Counter |
|               |

This routine is the same as that used in the MICRO 820 except for the omission of memory referencing and linking to the main firmware.



#### Generate ASCII Parity.

This routine will generate and attach an odd parity bit to bit 7 of a character contained in file  $S_2$ . It will also generate a block longitudinal parity LRC for this character, by exclusive ORing with an LRC being accumulated in AL. This routine is the same as used in the 820 except for omission of memory referencing and linking with the main 820 firmware. Parity is generated by shifting and testing the bits in  $S_1$  and toggling a bit in  $S_2$  for each bit = 1 is  $S_1$ .



## **CHAPTER 8**

# **MICRO 810 FIRMWARE MANUAL**

The basic steps for development of a general purpose computer architecture using a microprogrammed computer are as follows:

- 1. Functional Definition
  - Input/Output Characteristics.
  - Operating Registers Assignments (Accumulator, Index, Program Counter, etc.).
  - Word Length (Fixed and Variable).
  - Core Memory Addressing Modes for Jumps and Operand Fetching.
  - Instruction Repertoire.
  - Instruction and Data Formats (Number of Bytes, Sign Extension, Op Codes, etc.).
  - Interrupt System (External/Internal).
  - Desired Instruction Execution Times.
  - Bootstrap Load Technique.
- 2. Hardware Modification (if any).

Modifications or additions may be required (particularly in the interface) to achieve the desired specs. For example if a 16-bit I/O path were required in the emulator, an I/O expander would be required on the MICRO 800. For the MICRO 810 emulation, no hardware changes are required, since the byte I/O scheme is a direct mechanism of the MICRO 800 byte I/O channel.

3. Analysis and Selection Algorithms.

Definition of subroutines, organization of routine hierarchy and preparation of top level flow chart.

- 4. Detailed derivation of each algorithm to be used.
- 5. Preparation of detailed flow charts for each subroutine.
- 6. Assembly language coding.
- 7. Assembly of program, diode map generation, and checkout.

To illustrate these steps, annotation flow charts and the assembly language program for the \*original version of the MICRO 810 except for compare, multiply, and divide instructions are included, along with a summary of the 810 processor characteristics which affect the firmware.

The MICRO 810 is an example of an emulation. Its characteristics as related to the microprogram are described in the following paragraphs. The first step in development is to define the basic functions.

#### MICRO 810 Functions

Six operational registers:

- Accumulator (A) 16 bits.
- Auxiliary accumulator (B) 16 bits.
- Index register (X) − 16 bits.
- Program counter (P) 15 bits.
- Overflow (O) − 1 bit.
- Word length control (W) − 2 bits.



Semiconductor Read-Only Memory Expandable from 768 Words to 2,048 Words.



Diode Matrix 256-Word Read-Only Memory.

Extensive, powerful instruction set including 89 individual operations:

- Multiply and divide (2).
- Control (17).
- Multi-bit arithmetic and logical shifts (12).
- Conditional jumps (16).
- Input/Output (8).
- Inter-register (16).
- Memory reference including jump, compare and variable word length operations — (18).

# Eight operand addressing modes including:

- Direct to page 0 (first 256 bytes).
- Direct relative to P (±128 bytes).
- Indirect to page 0 (first 256 bytes).
- Indirect relative to P (±128 bytes).
- Indexed (to 32,768 bytes).
- Indexed with bias (to 32,768 bytes).
- Extended address (to 32,768 bytes).
- Literal.

Multi-precision 1, 2, 3, or 4 byte load, store, and arithmetic operations. Flexible I/O facilities including:

- programmed transfers to/from A and B registers and memory to byte I/O.
- concurrent buffered I/O.
- serial I/O channel for local teletype.

Expandable priority interrupt system Processor options which include:

- real-time clock.
- power-fail detect and automatic restart.
- memory parity detect and interrupt.

Built-in bootstrap loader in non-volatile read only store.

\*(Later MICRO 810 versions have modified interrupt, concurrent I/O and control firmware.)

To provide all of this capability only 710 micro instructions were required. This leaves capability for addition of 314 additional microinstructions for special functions.

# FILE REGISTER ASSIGNMENTS

The MICRO 810 contains six operational registers which are accessible to the programmer. These operational registers occupy nine of the 16 file registers of the basic MICRO 800 hardware; the remaining seven hardware registers are not accessible by the MICRO 810 instructions although specially designed macros could make use of these at the micro-level.

### A REGISTER (file registers 4 and 5)

The 16-bit A register is the accumulator with which most operations are performed. The A register holds the upper portion of 24- or 32-bit data words and all of 8- and 16-bit data words. The A register may be shifted by itself or in conjunction with the B register.

#### B REGISTER (file registers 6 and 7)

The 16-bit B register is the auxiliary accumulator and is used mainly as an extension of the accumulator to hold the lower 16 bits of 24- and 32-bit data. The B register may be shifted by itself or in conjunction with the A register.

## X REGISTER (file registers 2 and 3)

The 16-bit X register is an index register used in address modification. It can communicate directly with memory, be incremented, and compared with the A register.

# P REGISTER (file registers A and B)

The 15-bit P register is the program counter which holds the address of next memory instruction to be executed.

## W REGISTER (bit 2 of file register F)

The 2-bit W register holds the word length mode. It is loaded by a control instruction and sets the byte length of the operand for all variable word length instructions.

# O REGISTER (bits 1, 0 of file register F)

The one-bit 0 register holds the overflow flag. The overflow is set by arithmetic instructions when an overflow occurs, by execution of a control instruction, or by the compare instruction. It may be reset by execution of a control instruction or by a conditional jump instruction that tests for an overflow condition.

Files 8, 9 are for the operand address.

Files C, D, E are used for temporary storage.

File 0 is for condition flags.

File 1 is the instruction register.

The file register assignments are completely accomplished by microprogramming. There are no internal wiring modifications to convert a MICRO 800 to a MICRO 810 other than the arrangement of matrix diodes on the read only memory boards.

#### INFORMATION FORMATS

The basic element of information is an 8-bit byte in which the bit positions are numbered from 7 through 0, left to right. Both instructions and data occupy a variable number of bytes for maximum storage efficiency. A word is a 16-bit element of information consisting of two bytes. The accumulator and index register both hold a 16-bit word.

#### DATA FORMAT

Data in the MICRO 810 is variable precision of 8, 16, 24, or 32-bit length. Negative numbers are represented in 2's complement.



To have variable word length operations, the microprogram must test the instruction Op code, bit 3 to see if variable word length is specified. It must then test file register F, bit 2 for which word length is set. Then the instruction is carried out by the microprogram according to the settings of these two bits. Testing and variable word length execution are done in the designated memory reference microprogram subroutine.

# ADDRESS WORD FORMAT FOR MEMORY REFERENCE INSTRUCTIONS

A 16-bit address word containing a 15-bit memory address and an index flag as shown below. The address may be a direct or indirect address as dictated by the instruction operation code. The value of the address word

is equal to the contents of bits 14-0 and is equal to the contents of bits 14-0 plus the contents of the x register if bit 15 is a 1-bit.



In the operand address subroutine, the address is determined by the microprogram and placed into the operand address register.

## **INSTRUCTION FORMAT**

Instruction formats are one to five bytes, but in all cases the first contains an eight-bit operation code which defines the operation class, the sub-operation code, and any modifiers. Succeeding byte(s) contain such information as:

Single byte absolute or relative address. Double byte address word.
Single byte shift count.
Single byte I/O function and device address.
1, 2, 3, or 4 byte literal data.

### OPERAND ADDRESSING MODES

The memory reference instructions defined in the following section each have eight possible modes of addressing an operand in memory. The number of bytes in the instruction format varies with the mode. The additional bytes of the instruction contain addresses, partial addresses, or data (literals).

The basic memory reference instruction is one byte containing two fields as follows:



The 5-bit operation code defines the basic instructions; the 3-bit m field specifies the address mode. Additional bytes contain the address of an operand, an indirect address, a base address, or a literal depending on the addressing mode. The effective operand address is the memory location specified after all indirect and/or index modifications have been performed.

For variable word length instructions, such as Load A versus Load Variable, bit 3 is used to indicate whether variable word length is to be used. The microprogram tests this bit. For fixed word length instructions, such as multiply/divide, bit 3 indicates the instruction type.

When an indirect address mode is specified, the location of the indirect address word is the first byte of a two-byte word having the format shown below:



**Indirect Address Word Format** 

For indirect addressing, the microprogram fetches the first referenced word, which points it to the actual address word, to which may be added the contents of the index register.

Bit 7 of the first byte (x) defines whether or not the indirect address word will be modified by the contents of the index register:

If x = 0, the 15-bit number formed by y and z is the effective operand address.

If x = 1, the 15-bit number formed by y and z is a base address to which is added the contents of the X register. The result is the effective operand address.

The individual addressing modes and the memory reference instruction format for that mode are defined below. The microprogram has a sub-routine called operand addressing which examines the subsequent bytes of memory reference instructions, and uses this information to determine the operand address.

#### DIRECT PAGE 0 (m=0)



The effective operand address is given by the contents of the second byte of the instruction (y) with seven high order zero bits appended. This mode provides direct addressing of operands in the first 256 memory locations.

The microprogram clears the upper byte of the operand address register, and places byte y in the lower byte of the operand address register.

# DIRECT RELATIVE (m=1)



The effective operand address is given by the sum of the contents of the second byte (y) with its high order sign bit (bit 7) extended and the contents of the P register. The contents of the P register at the time the addition is performed is the address of the memory location following y. This

mode provides for addressing from 127 locations ahead to 128 locations behind the memory location of the next instruction.

The microprogram sets the P register to the next instruction location, adds the byte in y to p and places the result in the operand address register.

#### INDIRECT PAGE 0 (m=2)



An indirect address word is specified by the contents of the second byte (y) of the instruction with seven high order zero bits appended. The 2-byte indirect address word addressed is located in the first 256 memory locations. The effective operand address is given by the contents of the indirect address word if the index flag (bit 15) is a 0-bit, or by the sum of the contents of the indirect address word and the X register if the index flag (bit 15) is a 1-bit.

The microprogram fetches the two byte address from page 0 designated by byte Y. It adds the contents of the index register (if bit 15=1), and places the result in the operand address register.

# INDIRECT RELATIVE (m=3)



An indirect address word is specified by the sum of the contents of the second byte (y) with its high order bit (bit 7) extended and the contents of the P register. The contents of the P register at the time the addition is performed is the address of the memory location following y. The effective operand address is given by the contents of indirect address word if the index flag (bit 15) is a 0-bit or by the sum of the contents of the indirect address word and the X register if the index flag (bit 15) is a 1-bit.

The microprogram advances the P counter to the next instruction location, adds the content of byte y, fetches the 2 byte address from the resultant location, adds content of index (if bit 15=1) and places the result in the operand address register.

#### INDEXED (m=4)



The effective operand address is given by the contents of the X register.

The microprogram loads the content of  $\boldsymbol{X}$  into the operand address register.

#### INDEXED WITH BIAS (m=5)



The effective operand address is given by the sum of the contents of the X register and the contents of the second byte (y) of the instruction.

The microprogram adds the content of X to byte Y, and places the result in the operand address register.

#### EXTENDED ADDRESS (m=6)



A 16-bit address word is located in the second and third byte of the instruction. The effective operand address is given by the contents of the address word if the index flag bit in bit 15 is an 0-bit, or by the sum of the contents of the address word and the X register if the index flag is a 1-bit.

The microprogram takes bytes Y, and Z and adds the contents of index if bit X=1 and places the result in the operand address register.

# LITERAL (m=7)



The effective operand address is given by the contents of the P register. The operand is located in from 1-4 bytes following the first byte of the instruction, depending upon the operand precision. The P register is incremented for each operand byte accessed. The Jump and Return Jump memory referencing instructions do not have a literal mode.

The microprogram places the contents of the P register into the operand address register.

### JUMP/RETURN JUMP INDIRECT EXTENDED ADDRESS (m=7)



A 16-bit direct address word is located in the second and third bytes of the instruction. This word addresses an indirect address word located at the address given by the contents of the second and third bytes if bit 15 of the address word is a 0-bit or by the sum of the contents of the second and third bytes and the X register if the index flag bit in bit 15 is a 1-bit.

The effective jump address is given by the contents of the indirect address word if the index flag in bit 15 of the indirect address word is a 0-bit, or by the sum of the contents of the indirect word and the X register if the index flag bit in bit 15 of the indirect address word is a 1-bit.

The microprogram tests to see if mode = 7, and the command is a jump or return jump. If all of these conditions are so, the microprogram fetches the bytes Y, Z (with index if bit X=1) and places them in the operand address register.

## MICRO 810 INSTRUCTIONS

| OPERATION<br>CODE                                                                                                          | MNEMONIC                                                                                                            | INSTRUCTION NAME                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CONTROL (o                                                                                                                 | ne byte)                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 00<br>01<br>02<br>03<br>04<br>05<br>06<br>07<br>08<br>09<br>0A<br>0B<br>0C<br>0D<br>0E<br>0F<br>34                         | HLT<br>TRP<br>ESW<br>PMP<br>DIN<br>EIN<br>DRT<br>ERT<br>RO1<br>RO2<br>RO3<br>RO4<br>SO1<br>SO2<br>SO3<br>SO4<br>NOP | Halt Trap Enter Sense Switches Protect Memory Page Disable Interrupt System Enable Interrupt System Disable Real Time Clock Enable Real Time Clock Reset Overflow and Set Word Length to 1 Reset Overflow and Set Word Length to 2 Reset Overflow and Set Word Length to 3 Reset Overflow and Set Word Length to 4 Set Overflow and Set Word Length to 1 Set Overflow and Set Word Length to 1 Set Overflow and Set Word Length to 2 Set Overflow and Set Word Length to 3 Set Overflow and Set Word Length to 3 Set Overflow and Set Word Length to 3 Set Overflow and Set Word Length to 4 No Operation |
| CONDITIONA                                                                                                                 | L JUMP (2 byte                                                                                                      | es)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 10 XX<br>11 XX<br>12 XX<br>13 XX<br>14 XX<br>15 XX<br>16 XX<br>17 XX<br>18 XX<br>19 XX<br>1A XX<br>1B XX<br>1C XX<br>1D XX | JOV JAZ JBZ JXZ JAN JXN JAB JAX NOV NAZ NBZ NKZ NAN NXN NAN                                                         | Jump if Overflow Set Jump if A Equal to Zero Jump if A Equal to Zero Jump if X Equal to Zero Jump if A Negative Jump if X Negative Jump if A Equals B Jump if A Equals X Jump if Overflow not Set Jump if A not Equal to Zero Jump if B not Equal to Zero Jump if X not Equal to Zero Jump if A not Negative Jump if X not Negative Jump if A not Negative Jump if A not Equal to B                                                                                                                                                                                                                       |

XX is a relative jump address (plus or minus hex 7F from the first byte

Jump if A not Equal to X

after the jump instruction.

NAX

1F XX

| <b>OPERATION</b> |          |                  |  |
|------------------|----------|------------------|--|
| CODE             | MNEMONIC | INSTRUCTION NAME |  |

# SHIFT (2 byte instruction)

| 20 XX | LLA  | Logical Left A        |
|-------|------|-----------------------|
| 21 XX | LLB  | Logical Left B        |
| 22 XX | LLL  | Logical Left Long     |
| 24 XX | °LRA | Logical Right A       |
| 25 XX | LRB  | Logical Right B       |
| 26 XX | LRL  | Logical Right Long    |
| 28 XX | ALA  | Arithmetic Left A     |
| 29 XX | ALB  | Arithmetic Left B     |
| 2A XX | ALL  | Arithmetic Left Long  |
| 2C XX | ARA  | Arithmetic Right A    |
| 2D XX | ARB  | Arithmetic Right B    |
| 2E XX | ARL  | Arithmetic Right Long |

Where: XX is

XX is shift count.

# INPUT/OUTPUT (2 and 4 byte instruction)

| 30 | 00 |      | IBS | Input Byte Serially            |
|----|----|------|-----|--------------------------------|
| 31 | XX |      | IBA | Input Byte to A                |
| 32 | XX |      | IBB | Input Byte to B                |
| 33 | XX | AAAA | IBM | Input Byte to Memory           |
| 38 | 00 |      | OBS | Output Byte Serially           |
| 39 | XX |      | OBA | Output Byte from A             |
| 3A | XX |      | OBB | Output Byte from B             |
| 3В | XX | AAAA | OBM | <b>Output Byte from Memory</b> |
|    |    |      |     |                                |

Where:

 $\mathsf{XX}$  is a 3-bit function code and 5-bit device address. AAAA is a core memory address.

# **REGISTER OPERATE (one byte)**

| Group 1 |     |                             |
|---------|-----|-----------------------------|
| 40      | ORA | OR B with A                 |
| 41      | XRA | Exclusive — OR B with A     |
| 42      | ORB | OR A with B                 |
| 43      | XRB | Exclusive — OR A with B     |
| 44      | INX | Increment X                 |
| 45      | DCX | Decrement X                 |
| 46      | AWX | Add Word Length to X        |
| 47      | SWX | Subtract Word Length from X |
| Group 2 |     |                             |
| 48      | INA | Increment A                 |
| 49      | INB | Increment B                 |
| 4A      | OCA | One's Complement A          |
| 4B      | OCB | One's Complement B          |
| 4C      | TAX | Transfer A to X             |
| 4D      | TBX | Transfer B to X             |
| 4E      | TXA | Transfer X to A             |
| 4F      | TXB | Transfer X to B             |

# MEMORY REFERENCE (1, 2, 3, 4, 5 byte)

| 60<br>68<br>70<br>78<br>80<br>88 | JMP<br>RTJ<br>IWM<br>DWM<br>LDX<br>STX | Jump Return Jump Increment Word in Memory Decrement Word in Memory Load X Store X |  |
|----------------------------------|----------------------------------------|-----------------------------------------------------------------------------------|--|
| 90                               | MUL                                    | Multiply                                                                          |  |
| 98                               | DIV                                    | Divide                                                                            |  |
| A0                               | ADA                                    | Add to A                                                                          |  |
| A8                               | ADV                                    | Add Variable                                                                      |  |
| B0                               | SBA                                    | Subtract from A                                                                   |  |
| B8                               | SBV                                    | Subtract Variable                                                                 |  |
| CO                               | CAP                                    | Compare A                                                                         |  |
| C8                               | CPV                                    | Compare Variable                                                                  |  |
| D0                               | ANA                                    | And                                                                               |  |
| D8                               | ANV                                    | And Variable                                                                      |  |
| E0                               | LDA                                    | Load A                                                                            |  |
| E8                               | LDV                                    | Load Variable                                                                     |  |
| F0                               | STA                                    | Store A                                                                           |  |
| F8                               | STV                                    | Store Variable                                                                    |  |

#### INTERRUPTS

The MICRO 810 has firmware to process both external and internal interrupts. The firmware tests for interrupts, acknowledges them, and executes a return jump to the designated software routine for each interrupt channel.

#### CONCURRENT I/O

The concurrent I/O allows for block transfers between the external device on the Byte I/O bus and memory at a maximum rate of 20,000 bytes per second. The transfers are fully automatic, and once started proceed without program intervention. Concurrent I/O takes priority over instruction execution and forces momentary sequence breaks during execution of long instructions such as multiply, divide and shifts to insure that concurrent I/O displays are not excessive.

#### SERIAL INPUT/OUTPUT INSTRUCTIONS

Two instructions are provided for bit serial transfers of data between the A register and a serial I/O device. In the MICRO 810, these instructions are standardly timed to transfer bits at the rate of 110 bits/second for interface with a serial teletype. However, the timing can be easily altered by a simple change of firmware to handle another type of serial device.

#### IBS INPUT BYTE SERIALLY



An eight-bit byte is assembled from the serial teletype interface and placed in the eight low order bits of the A register. The eight high order bits of A remain unchanged. The execution time of this instruction terminates when a complete teletype character has been received. The instruction must be accessed before the start of the teletype input for proper assembly of the character. Sampling of the teletype line and assembly of bits is done by a microprogram subroutine, which includes its own delay routine to time out the bits as shown below.

## OBS OUTPUT BYTE SERIALLY



The eight low order bits of the A register are disassembled and output serially as a teletype character to the serial teletype interface. The eight low order bits of A will be set to one. The eight high order bits remain unchanged. The execution of this instruction terminates when a complete byte has been transmitted.

Affected: A

#### BYTE INPUT/OUTPUT INSTRUCTIONS

Byte programmed input/output operations provide transfers of data, control and status over the Byte I/O channel. This multiplex channel permits intermixed program and concurrent I/O transfers. More than one device on the bus may be operating in a concurrent block transfer mode at the same time. A maximum of 32 devices may normally be addressed on the Byte I/O bus.

The second byte of the instruction is a control byte which provides a three-bit device order and a five-bit device number as follows: The microprogram causes the second byte to be placed on the output bus, and generates a control output strobe called COXX. In the output mode, the data is placed on the output bus and strobed out with DOXX. For input, data on the input bus is strobed in by DIXX.



Byte input/output is basically a two-phase operation. First the control byte is placed on the output bus before the actual transfer of data. All devices examine the transmitted device number. The device whose assigned number is the same as contained in the control word accepts the control byte and sets for a subsequent data byte transfer. The second phase consists of the input or output of a single byte. When a device order does not require a data transfer, the second byte is disregarded by the device controller.

#### TOP LEVEL FLOW CHART

The purpose of the top level flow chart is to define the microprogram subroutines, and their interrelationship. This flow chart shows all of the basic paths that the microprogram can follow as it goes through its repetitive looping operation.

The top level flow chart can be divided into six major areas for discussion purposes.

- Instruction fetching
- Interrupt and Concurrent I/O Processing
- Operand Addressing
- Nonmemory Reference Instruction Execution
- Memory Reference Instruction Execution
- Bootstrap Load

### Instruction Fetching

MICRO 810 instructions, stored in core, contain from 1 to 5 bytes, depending on the instruction. During the instruction fetch routine, only the first byte is fetched from core. This byte contains the basic Op code of the instruction, which identifies whether the instruction is memory reference or not, and what the specific instruction is.

First byte format.



The Op code identifies the class of instruction for nonmemory reference instructions, and the type of instruction for memory references.\*

The sub Op code identifies the type instruction for nonmemory reference, and the address mode, and fixed versus variable word length for the memory reference instructions.

The Op codes are organized so that all memory reference instructions have Op codes 6. The microprogram makes use of this fact when testing to see if the instruction is memory reference.

During the instruction fetch subroutine, the Op code is tested for memory reference, and a jump table number is set up to jump into the subroutine corresponding to the Op code.

Other things done during instruction fetch are testing for interrupt, and advancing the program counter.

The instruction fetch routine contains a cold start portion which initializes the program counter, tests for internal interrupts, and tests for bootstrap load.

<sup>\*</sup>On some of the memory reference instructions the sub Op code is also required to indicate type of instruction.

The instruction fetch routine has many different entry points, which are a function of the state of the P register as determined by the previous subroutine that the microprogram executed.

# Interrupt Processing

If there is an internal or external interrupt, the microprogram services it immediately. Servicing consists of acknowledging the interrupt, inputting the device address (if external), and jumping to the interrupt routine, or transferring a data byte if concurrent I/O. When this is done, the microprogram returns to the instruction fetch cycle. At this time, the interrupt routine address will be in the program counter.

# **Operand Addressing**

This microprogram subroutine prepares the absolute address of the operand of a memory reference instruction, and places it in the operand address register. The address modes are identified in the sub Op code. Address information is contained in the 2nd and 3rd bytes of the instruction.

The addressing modes are as follows:

### 1. Direct Page 0 (1st 256 bytes)

The second byte is placed directly in the operand address register by the microprogram.

#### 2. Direct Relative

The second byte is added to the P counter, and the result is placed in the operand address register.

#### 3. Indirect Page 0 (1st 256 bytes)

The address indicated by the second byte is fetched from Page 0 and added with the contents of the index register (if bit 15 is set), and placed in the operand address register. If bit 15 is not set, the address is placed directly in the operand address register.

#### 4. Indirect Relative

The second byte is added to the P counter. This address is used to fetch the indirect address, which is added to the content of the index register (if bit 15 is set), and placed in the operand address register. If bit 15 is not set, the indirect address is placed directly in the operand address register.

#### Indexed

The address in the index register is transferred to the operand address register.

#### 6. Indexed With Bias

The 2nd byte is added to the index register and placed in the operand address register.

# 7. Extended Address (Absolute Address)

The 2nd and 3rd bytes of the instruction are added to the index register (if bit 15 is set) and placed in the operand address register. If bit 15 is not set, the 2nd and 3rd bytes are placed directly in the operand address register.

#### 8. Literal

The P counter is incremented and placed in the operand address register.

# Non-memory Reference Instruction

The non-memory reference instructions consist of the following:

- Conditional Jumps
- Input/Output a byte of data (Parallel or Serial)
- Control Operations
- Register Shifts
- Register Operations

Since none of these involve an operand to be fetched from memory, the operand addressing function is bypassed by the microprogram.

# **Memory Reference Instructions**

The memory reference instructions are grouped as follows:

- Load, Add, And, Subtract
- Store
- Unconditional Jump
- Return Jump
- Increment or Decrement Word in Memory
- Compare
- Multiply, Divide

The operand for each of these operations is fetched from the address location contained in the operand address register.

# **Bootstrap Load**

This microprogram is entered from the cold start part of the instruction fetch routine. It loads a program load routine which is on paper tape.

# **Detailed Flow Charts**

The next step after preparing the top level flow chart is to prepare the detailed flow charts for the individual subroutines. At this time it is necessary to have a detailed definition of the procedures, equations, and algorithms to be executed in each subroutine. The basic microprogramming approaches must be identified, such as use of the U register, combining multiple functions into the same routine, a definition of microprogram jump and return jump procedures.

There is no set rule for the detail level of symbology to be used in microprogram flow charts. The general considerations for detail level are as follows:

- 1. Ease of identifying and defining procedures.
- 2. Ability to communicate program organization and steps to others.
- 3. Ease of coding program from flow charts.

To provide a detailed description of the MICRO 810 firmware selected, detailed flow charts, comments, and functional grouping indications are included in the following pages, along with a table of symbol definitions to facilitate reading the charts. Microcode addresses are included on the flow charts to facilitate relating the steps in the flow chart to the instructions in the assembly listing.

# Glossary of Flow Chart Symbols for MICRO 810 Firmware

#### A. File Registers Fo File 0 Flag Register. File 1 Instruction Register (for first byte of instruction). XL File 2. Upper and Lower Bytes of Index Register. XU File 3 File 4 AL Upper and Lower Bytes of A Register. ΑU File 5 BL File 6 Upper and Lower Bytes of B Register. BU File 7 OL File 8 Upper and Lower Bytes of Operand Address OU File 9 Register. PL File A Upper and Lower Bytes of Program Counter PU File B Register. S<sub>1</sub> File C. Temporary, Always Used for Subroutine Return Address. $S_2$ File D Temporary. S3 File E OV/W File F Overflow and Word Length. F1 File 1 Used for execute command reference Register for selecting odd file. This does not actually select file 1 because of the U register modification. $U_{L}$ , $U_{tr}$ Designates a command selecting U register modification with File 0 reference, and modified by U register.

# B. Other Registers

T T Register

U U Register

L Register (also referred to as K in assembly language)

m,M M Register Upper Memory Address Register

n,N N Register Lower Memory Address Register

L.LK Also defined as LINK

C Update condition Flags.

#### C. Miscellaneous Mnemonics

SS4

RN1

OP

#### D. Symbols for Constants

1. Constants to go into U Register for Instruction Modification

LDAL Loading A using 'B4' op code which is COPY T to A.

ANAL AND A using 'C4' op code which is AND to A.

SBAL Subtract A using '94' op code which is Subtract from A.

ADAL Add A using '84' op code which is ADD to A.

LDXL Load X using 'B2' op code which is Copy T to X.

STAL Store A using 'A4' op code which is Memory op code.

STXL Store X using 'A2' op code which is Memory op code.

STBL Store B using 'A6' which is memory op code.

# 2. Jump Table Constants

OTAB = '10' Main table jump reference to location 100. The '10' is used to clear the upper 4 ones in the op

code which has been shifted right 4 places.

JTBL = '4E'

Jump base reference constant used in conditional Jump routine, to go to the selected con-

ditional jump subroutine.

CTBL = '15'

Jump base reference constant used in control routine for jumping to selected control function.

# E. Miscellaneous Symbols

SR4 Shift Right 4

SS4 Sense Switch 4

CTL Control Subroutine

CJ Conditional Jump Subroutine

SH Shift Routine

IO Input Output Routine

REG Register Operate Routine

SP . Spare

RNI Read Next Instruction

JMP Jump

RTJ Return Jump

IND 1 INDX Entry points to perform indexing

ADDR, ADRO Entry points in operand addressing routine

OP Op Code

SOF Set Overflow

SET Set Mask

OCK Test for Overflow set

LDA Load A

ANA And A

SBA Subtract A

ADA Add to A

MR1 Memory Reference Entry from LDX

LDX Load X

STA Store A

IWM Increment Word in Memory

M Address Mode (sometimes M Register)

@ Shift

V OR Logic Symbol

∧ And Logic Symbol

₩ Exclusive OR Logic Symbol

# F. Microprogram Command Symbols

| ′00′ <del></del> OV, m                            | Load OV and m registers with '00' to clear them.                                                                                   |
|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Pu —→ Pu, m                                       | Move content of Pu to m (back to Pu is immaterial but saves a diode).                                                              |
| PL → P1, n<br>(READ)                              | Initiate a read memory cycle and also move content of PL to n Register.                                                            |
| I SR4 ─►T                                         | Shift right file 4 and put result in T.                                                                                            |
| PL+1──PL, n                                       | Increment (PL) and put result in n and PL.                                                                                         |
| W∧ T —► T                                         | 'AND' (W) with (T) and put result in T.                                                                                            |
| U <sub>L</sub> (F) T → U <sub>L</sub> , C         | General Purpose Command. UL Selectable file by U register. F Selectable command by U register. T Operand, Up date condition flags. |
| NOP N                                             | No Operation.                                                                                                                      |
| JP*+1                                             | Jump to next location (2 clock delay).                                                                                             |
| U <sub>u</sub> ──► T<br>(Write)                   | Execute command with memory op code in U register, T destination and write bit set in C field.                                     |
| BL(F)T──►BL                                       | Execute command selecting B register, with variable op code in U register. T register operand.                                     |
| S <sub>1</sub> @+1──► S <sub>1</sub> , U          | Shift file $S_1$ right, enter 1 into vacated bit, place result in $S_1$ and $U$ .                                                  |
| U <sub>L</sub> +1 → U <sub>L</sub>                | Incrementing selected register with file address modified by content of U Register.                                                |
| CTBL → SI                                         | Load file $S_1$ with constant identified as CTBL.                                                                                  |
| $\overline{U}_L \longrightarrow U_L$              | Complement selected file.                                                                                                          |
| I∀T, T→LK                                         | Exclusive OR (I) with T and $\overline{T}$ thus complementing (I).                                                                 |
| BL@+LK <b>⊸</b> BL                                | Shift (BL) left, enter (LINK).                                                                                                     |
| U <sub>u</sub> @+LK <del>···</del> U <sub>u</sub> | Shift selected file right, enter link. File designated by contents of U.                                                           |
| S <sub>1</sub> →L                                 | Move $(S_1)$ to L (a jump command).                                                                                                |
| I@ <del>←</del> T                                 | Shift (I) left, result to T.                                                                                                       |

On the flow charts, the machine code address of each instruction is placed next to the box containing the instruction, as close as possible. Since jump instructions are not shown in the boxes, a dot is placed in the flow line having the jump and identified with the machine code address for the jump instruction. When the jump destination is indicated with INT, the machine code address of the jump destination is placed by the circle as follows 1F8 INT2

The flow charts are shown in Figures 23 through 39.



Figure 23. 810 Top Level Flow Chart



Figure 24. Read Next Instruction



Figure 25. Operand Addressing



Figure 26. Operand Addressing (Continued)



Figure 27. Memory Reference



Figure 28. Memory Reference (Continued)



Figure 29. Jump and Return Jump

290





Figure 32. Conditional Jumps



Figure 33. Shifts



Figure 34, Bootstrap Loader



Figure 35. Input-Output



Figure 36. Serial Teletype

# SERIAL TELETYPE DELAYS DELAY 2 DELAY COUNTER BIT COUNT EXIT FROM DELAYS EXIT FROM SIO SET OUTER LOOP COUNT 106 DLY1 SET INNER **-** 0∟ 1C7 DELAY IS ACHIEVED BY NESTED LOOP 1CA ► 0L.C DECREMENT INNER LOOP. SET COND FLAGS. 1C9 INNER LOOP OL • 0 JUMP REPEAT YES DECREMENT OUTER LOOP COUNTER 1CB 1CC 1CD NO OUTER LOOP 1 = 0 JUMP REPEAT RETURN TO BOOTSTRAP LOAD, OR RNI VIA INPUT/OUTPUT ROUTINE YES 1CF 1CE SHIFT COUNT Ou - 0 NO 100 DECREMENT SHIFT COUNT AND SHIFT IN A BIT TO A AL @ + 1 1D1

Figure 37. Serial Teletype Delays

CLEAR I/O BIT AND RETURN TO SAMPLING I/O CLEAR IS USED FOR OUTPUTTING SERIAL DATA

1 D2

I/O CLEAR



Figure 38. Interrupts



Figure 39. Concurrent Input/Output

# MICRO 810 ASSEMBLY LISTINGS

The assembly language program with machine code and comments is included for reference from the flow charts. To illustrate the flow of micro commands for 810 operations, the dotted line flow is for a load A register direct relative address mode instruction.

#### Load A Direct Relative Address Mode

For this example, the op code in MICRO 810 machine language is:

0200 E1 0201 18

The E signifies load,

The 1 in binary is 0001

Fixed Word Length Direct Relative

The 18 specifies a relative address 18 hex from the P count of the next instruction, which is 0202 + 18 = 021A.

In the RNI loop the op code, E1 is fetched and tested for memory reference. E 5 means memory reference. Therefore the operand address mode is entered. The 1 says direct relative, so the relative address 18 is fetched from core and added to 0202 and the result, 021A, is placed in the operand address register.

Then the microcommand jumps, via the jump table at 100, to the memory reference routine, entering at LDA. The 1 in the Op code signifies fixed word length (two bytes) so two bytes are fetched from core, starting at the location in the operand address register (021A) and placed in the A register. Then the microprogram returns to RNI to advance the P counter and fetch the next instruction.

The sequence of both of these examples can be seen by following the solid or dotted flow lines on the listing.

#### **FUNCTION FLOW EXAMPLES OF A MICRO 810 INSTRUCTION**

#### Load A direct relative

Machine Code of MICRO 810 Instruction Stored in Memory:

01FF 34 No op 0200 E1 Load A Dir. Rel. 0201 18 Rel. Address The instruction is located at P=0200 in core memory. For the example it is assumed that the previous instruction was a no Op, and there were no interrupts, or concurrent I/O requests. Therefore, the read next instruction routine will be entered at RNI.

The MICRO 810 instruction bit configuration is as follows:



The relative address '18' is a positive displacement. This instruction will cause a 16-bit number located at 021A to be loaded into the A register (files 4 and 5).

The basic functions (omitting tests and skips) for implementation of this instruction within the MICRO 800 are shown in the following flow chart:



The sequence of micro instructions is traced out in the following coding which was lifted from the MICRO 810 Firmware reference manual.

```
MICRO 810 SYSTEM
                                                                                                                            FILE ALLOCATION
                                                                              0000
                                                                                                                FO
                                                                                                                                          EQU
                                                                                                                                                                                                                        CONDITION FLAGS
INSTRUCTION REGISTER
                                                                              0001
                                                                             0002
                                                                                                                                           EQU
                                                                                                                                                                                                                          INDEX REGISTER
                                                                                                                 XU
                                                                                                                                           FOU
                                                                              0004
                                                                                                                 ÂL
                                                                                                                                           EQU
                                                                                                                                                                                                                        ACCUMULATOR
                                                                              0006
                                                                                                                 BL
                                                                                                                                           EOU
                                                                                                                                                                                                                        EXTENDED ACCUMULATOR
                                                                              0008
                                                                                                                 OL OU PL PU S1 S2 S3 OV
                                                                                                                                          EQU
                                                                                                                                                                                                                        OPERAND ADDRESS
                                                                              0009
                                                                                                                                           EQU
                                                                                                                                                               16
11
                                                                              DODA
                                                                                                                                                                                                                        PROGRAM COUNTER
                                                                              000B
                                                                              0000
                                                                                                                                           EQU
                                                                                                                                                                                                                         TEMPORARY STORAGE
                                                                              000D
                                                                                                                                           EQU
                                                                                                                                                               14
15
1
                                                                              DODE
                                                                                                                                           EQU
                                                                                                                                                                                                                         OVERFLOW AND WORD LENGTH
USED WITH EXECUTE FOR ODD FILE
SIZE OF BASIC LOADER
                                                                              DOOF
                                                                                                                                           EQU
                                                                                                                 F1
SIZE
                                                                              0001
                                                                                                                                           ORG
                                                                                                                                                                                                                        BOARD 1
                                                                                                                                                                                                                      CLEAR OV/W AND M-REGISTERS
CLEAR P COUNTER UPPER
CLEAR P COUNTER LOWER
INTERNAL INTERRUPT
YES, JUMP TO INTERRUPT ROUTINE
ENTER SENSES SWITCHES
SWITCH 4 ON THE SENSES SWITCHES
SWITCH 4 ON THE SENSES SWITCHES
WITCH 4 ON THE SENSES SWITCHES
SWITCH SENSES SWITCHES
THE SWITCH
                                                                                                                            READ NEXT INSTRUCTION
                                                                                                                 RNIO
                                                                                                                                                              OV
PU, X'00'
PL, X'00'
FÖ, X'10'
INT2
                                                        000
                                                                              BF 02
                                                                                                                                          CH
LF
TZ
JP
                                                        001
002
003
004
005
006
007
                                                                             2800
2400
                                                                             4010
15F8
7110
4180
1574
                                                                                                                                           K
TZ
JP
                                                                                                                                                                1.1
1.X.80
                                                                                                                                                               LOAD
                                                                                                                                                              OV,X'00'
PU
PL
RN16
                                                        008
                                                                              2F 00
                                                                                                                 RNI1
                                                                                                                                           LF
                                                                             CB02
AA03
1410
BA43
EXAMPLE
                                                        009
00A
00B
                                                                                                                 RN15
                                                                                                                                           HH
RN
JP
  LOAD A
                                                                                                                                                              RNI6
PL
PU,L
FÖ,K'98'
INT
I,T
SI,OTAB+16
I,2
SI,T
I,X'AU'
SI
                                                        00C
                                                                                                                 RNI
                                                                                                                                           IN
                                                     -000
                                                                             AB82
4098
15D3
                                                                                                                 RN13
RN12
RELATIVE
                                                                                                                                           RH
                                                        00E
                                                                                                                                           TZ
                                                                                                                                                                                                                        TEST FOR INTERRUPTS
SERVICE REQUEST BY JUMP TO INT. ROUTINE
SAVE OP CODE STILL INT AFTER FETCH
BASE ADDRESS TO SHIFTED OP
SMIFT RIGHT 4
ADD BASE ADDRESS TO SHIFTED OP
MEMORY REFERENCE IF OP. GT, SF
NO, GO DIRECTLY TO JUMP TABLE
                                                                                                                                           JP
                                                                             9120
2C10
7129
8C20
                                                                                                                                           JP
C
LF
KT•
                                                                                                                 RNI6
                                                        010
                                                     +011
-012
-013
                                                                                                                                          A
CP
MK
                                                        014
                                                                             61 AD
                                                                                                                                             GET OPERAND ADDRESS
                                                                                                                            OPERAND
                                                                                                                                                       ADDRESSING
                                                                            8901
4104
142E
8A43
AB82
                                                                                                                                                                                                                       CLEAR OU AND T
M .LT. 4 (FIRST 4 ADDRESSING MODES)
NO, MODE .GT. 4
GET ADDRESS BYTE FOR PAGE ZERO OR RELATIVE
                                                                                                                 ADDR
                                                                                                                                          TZ
JP
                                                     -016
                                                                                                                                                               Ōυ
                                                                                                                                                               1,X'04'
                                                      -017
                                                  018
-019
-01A
-01B
                                                                                                                                           IN
                                                                                                                                                               PL
PU.L
                                                                              8833
                                                                                                                                           CN
                                                                                                                                                                OL.T.C
                                                                                                                                                                                                                         SET CONDITION CODE FOR SIGN OF DISPLACEMENT
                                                                                                                                                                                                                       SET CONDITION CODE FOR SIGN OF DISPLACEMEN PAGE ZERO ADDRESS MODE YES, JUMP TO INDIRECT TEST ADD RELATIVE VALUE TO LAND N DISPLACEMENT MEASTER RELATIVE VALUE TO LAND N DISPLACEMENT MEASTIVE (C SET AT 0.18) YES, JUMP TO NES, DISPLACEMENT CAI CULATION ADD CAMPY FOR PAGE BOUNDARY TRANSFER RESULT TO OU INDIRECT ADDRESS MODE NO, EXIT TO JUMP TABLE READ UPPER BYTE OF INDIRECT ADDRESS ADVANCE POINTER TO LOWER RYTE
                                                      -01C
                                                                             5101
1424
8A69
                                                                                                                                           TN
                                                                                                                                                                I.X'01'
                                                                                                                                           JP
AT●
                                                                                                                                                               PL.I.T
                                                     -01E
                                                    +01F
+020
                                                                              B823
4002
                                                                                                                                           CN
TZ
                                                                                                                                                                F0, X1021
                                                       021
-022
                                                                              142C
8889
                                                                                                                                                               ADR3
PU,L
OU,T
                                                                                                                                           ĴΡ
                                                                                                                                           AT.
C
TN
                                                                                                                 ADR1
ADR2
                                                    -023
-024
-025
026
027
028
029
024
                                                                              8920
                                                                                                                                                               1.X'02'
                                                                              5102
                                                                              CC 05
                                                                                                                                           MK
RH
                                                                                                                                                               0 Ū
                                          ➂
                                                                              8840
                                                                                                                                                                0 L
                                                                                                                                           I
A
C
R
N
J
P
                                                                             8840
8982
8920
A803
1439
                                                                                                                                                               OU.L
                                                                                                                                                                                                                       GET UPPER ADDRESS BYTF (READ AT 026)
READ LOWER BYTE OF INDIRECT ADDRESS
GO CHECK FOR POST INDEXING
BORROW FROM UPPER ADDRESS
GO TO INDIRECT ADDRESS ROUTINE
M.EG. 4 INDEX MODE
YES, GO TO INTEX FUNCTION
ADVANCE P COUNTER
CET 2ND BYTE OF INSTRUCTION FROM CORE
M.EG. 5 INDEXED WITH BIAS
WESC. A EYYENDER ADDRESS
                                                                                                                                                               OL
IND1
                                                        02C
                                                                                                                 ADRS
                                                                                                                                                               PULL
                                                                             1423
5103
1442
8A43
                                                        02D
02E
                                                                                                                                           JP
TN
JP
                                                                                                                                                               ADR1
1,X'03'
                                                                                                                 ADR4
                                                        02F
030
                                                                                                                                                                ADR7
                                                                                                                  INDX
                                                                                                                                                                PL
                                                                             AB82
5102
1442
                                                                                                                                                               PULL
                                                        031
                                                                                                                                           RM
                                                        032
033
034
035
                                                                                                                                                                1.X'02'
                                                                                                                                                               ADR7
1,X'01'
                                                                                                                                                                                                                        M .EG. 6 EXTENDED ADDRESS
                                                                                                                                           JP
                                                                             4101
                                                                                                                                           ΤΖ
JP
                                                                                                                                                                                                                        NO
GET UPPER ADDRESS BYTE (READ AT 031)
GET JAPD AVEC P COUNTER
GET JAPD BYTE FROM CORE
TRANSFER JAPD BYTE TO OL
INDEXED (BIT 15 LEQ. 1)
NO, EXIT
                                                                            8920
8A43
AB82
B823
                                                        036
                                                                                                                 ADR5
                                                                                                                                                               ου, τ
                                                                                                                                           ĬN
                                                                                                                                                               PL.
                                                        038
039
                                                                                                                                          RM
CN
TN
                                                                                                                                                               PU.L
                                                                                                                 IND1
                                                        03A
03B
                                                                              5980
                                                                                                                                                              00,x'80'
                                                                              CC05
                                                                                                                                          MK
AF
MT
                                                                            3980
C201
8823
C301
89A0
                                                        030
                                                                                                                                                               00.x.80'
                                                                                                                                                                                                                        REMOVE BIT BY CARRY OUT, LEAVING A ZERO
ADD X TO ADDRESS FOR INDEXING
HOVE X INTO OPERAND ADDRESS REGISTER
                                                                                                                ADR6
                                                                                                                                                               OL.T
                                                        03E
                                                        03F
040
041
042
043
                                                                                                                                                               ΧU
                                                                                                                                                               0U.L.T
                                                                                                                                                              S1
OL,T
ADR6
I,X'98'
                                                                             CC05
                                                                                                                                          Řĸ
                                                                                                                                                                                                                        EXIT TO JUMP TABLE
GET BIAS (T .EQ. 0, WHEN H .EO. 4)
                                                                                                                ADR7
                                                                             143D
6190
                                                                                                                                          JP
CP
                                                                                                                LIT
                                                                                                                                                                                                                         JMP, RTJ, IRM, OR ORM (TEST NON LITERAL MODE)
                                                        045
046
047
048
049
04A
04R
                                                                             1436
CA01
                                                                                                                                          JP
HT
                                                                                                                                                                ADR5
                                                                                                                                                                                                                        YES
LITERAL MODE
                                                                                                                                                               PL
                                                                                                                                          CN
                                                                             8823
                                                                                                                                                               OL.T
                                                                                                                                                                                                                                                                                                MOVE P TO OPERAND
                                                                             CB01
                                                                                                                                                                                                                                                                                          ADDRESS REGISTER
                                                                                                                                                               PU
                                                                            8920
6160
1453
5108
                                                                                                                                          CP
                                                                                                                                                               0U.T
                                                                                                                                                                                                                        FIXED WORD LENGTH INSTRUCTION
                                                                                                                                                               ADR9
                                                                                                                                                                                                                         YES
VARIABLE WORD LENGTH HODE
```

IDENT M810

ADR9

040

```
1103
EF29
8A20
8B80
                         04E
04F
                                                                                      X1031
                                                                                                                      SET MASK TO SELECT WORD LENGTH
WORD LENGTH TO T REGISTER
ADJUST P FOR NEXT INSTRUCTION
                                                                                     OV,T
PL,T
PU,L
Sī
                                                                         NT.
                          050
                                                           ADRA
                                                                         A
HK
LT
JP
                         051
052
053
054
                                      CC 05
                                                                                                                       EXIT TO JUMP TABLE
1 TO T FOR ADDING 1 TO P
WITH FIXED WORD LENGTH TYPE
                                      1101
                                                           ADR9
                                                                                      X101'
                                                                                      ABRE
                                                                 MEMORY REFERENCE
                                     1684
1450
1684
1450
1694
1450
                                                                                                                      SET U WITH LOAD (COPY) OP CODE
GO TO READ OPERANDS
SET U WITH LOGICAL AND OP CODE
GO TO READ OPERANDS
SET U WITH SUBTRACT OP CODE
GO TO READ OPERAND
SET U WITH ADD OP CODE
READ BYTE FROM MEMORY
                         -055
-056
057
                                                                         LU
JP
                                                           LDA
                                                                                      X184
                                                                                     HR1
X'E4'
                                                           ANA
                                                                         Ļυ
JP
                         058
                                                                                      HR1
X1941
                                                                         Į.
                         059
05A
05B
                                                           SBA
                                                                                     HR1
X'84'
                                                           ADA
HR1
                                                                         Lυ
                                      A902
5108
                                                                                      OU
1.X'08'
HR2
                         -050
                                                                         RINDRA
                                                                                                                      WARTABLE MORD LEMOTH
NO, (FIXED LENGTH OPERANDS)
W.EG O OR 1 (2 BYTES MAXIMUM)
YES
GET AN OPERAND
                         -05E
-05E
                                      1461
5F 01
                                                                                     0V,X'01'
                       060
-061
-062
-063
-064
-065
                                                                                      S1.T
                                      BC20
                                                           HR2
                                      8643
A982
8000
5108
1480
5F02
                                                                                                                      GET AN OPERAND
ADVANCE OPERAND ADDRESS AND
READ NEXT BYTE FROM MEMORY
RESET LINK FOR COPY (LOAD) FUNCTION
VARIABLE WORD LENOTH
                                                                         IN
RH
                                                                                      OL
                                                                                      00,L
F0
1,x'08'
                                                           HR3
                                                                         A
                                                                                     HR8
0V,X'02'
HR7
                                                                          JP
TN
                                                                                                                      NO HOLT. 2 (2 BYTES MAXIMUM)
YES
GET AN OPERAND
                         066
                  ➅
                          068
                                      147E
8020
                                                                                      $2.T
                          069
                                                                                                                                                                FFTCH 2ND AND 3RD
OR 3RD AND 4TH
OPERANDS DEPENDING
ON WORD LENGTH
                          06A
                                      8843
                                                                          ĬN
                                                                                      ÕŪ,L
                         068
                                      A982
                                                                         RM
                         06C
06D
                                      BE20
8843
                                                                         CIN
                                                                                      53,7
                                                                                                                       GET AN OPERAND
                                                                                      OL.
                                                                                      OU.L
                         06E
06F
                                      A982
                                                                                                                      RESET LINK FOR COPY (LOAD) FUNCTION OPERATE ON RL (FUNCTION IN U) MOVE OPERATE ON BU (FUNCTION IN U) OPERATE ON AL OF OPERATE ON AL W. EQ. 0 GR 2 (1 OR 2 BYTES)
                                                                         Ê
                          070
                                      0620
CE01
                                                                                      BL,2
                                                                         ЙT
                         071
                         072
073
074
075
                                      07AD
CD01
                                                                                      BŲ,10
                                                                         ЙT
                                                                                      Sż
                                      00B0
5F01
1482
CC01
                                                                         E
TN
                                                                                      F0,11
                                                                                     0V,X'01'
HR9
Si
                  € 076
                                                                                                                       YES
HOVE OPFRAND TO T
OPERATE ON AU OR XU (FUNCTION IN U)
OVERFLOW SET
                                                           MR5
                                                                                     F1,11
F0,X'01'
RNI
X'04'
                                      01B0
5001
                       -07B
                                                           OCK
                                                                         ŤN
                                      140C
1104
CF20
140C
RETURN
                         -07A
                                                                         JP
LT
                                                                                                                       NO
SET MASK
TO RNI
                          079
                          070
                                                           SOF
                                                                         ō
                                                                                      OV.T
                                                                                                                       SET BIT IN OV
                          070
                                                                         JP
E
                                                                                     F0.3
MR4
F0.2
MR5
                                      0030
                                                           MR7
                                                                                                                       OPERATE ON AL (FUNCTION IN U)
                         07E
07F
                                                                         JP
JP
LF
TZ
                                      0020
1477
2500
4480
C560
                                                                                                                       OPERATE ON AL OR XL (FUNCTION IN U)
                        -080
                                                           MRS
                        -081
082
                                                                                     AU, X'00'
AL, X'80'
AU, T, F
OCK
                  Ō
                                                           HRO
                                                                                                                       CLEAR AU
                                                                                                                                                            SIGN EXTENSION FOR VARIABLE WORD LENGTH TYPE
                                                                                                                                                               SIGN EXTENSION
FOR VARIABLE
                         083
084
                                                                                                                       RESULT POSITIVE
                                                                         0
                                                                                                                       FF TO AU
                                      1479
1682
                                                                         LU
                                                                                      XIB21
                                                                                                                       SET U WITH LOAD X (COPY) OP CODE
                         086
                                                          INY
                                      5108
145C
                                                                                      1,X'08'
                                                                                                                      STORE
NO, GO READ OPERANDS
SET U WITH STORE X OP CODE
CLEAR I FOR STORE OPERATION
GO STORE OPERANDS
SET U WITH STORE A OP CODE
                                                                                     HR1
X'A2'
I,X'00'
ST1
X'A4'
                          naa
                                                                          JP
                                                                         LU
                                      2100
148D
16A4
                          084
                                                           ST4
                                                                         JP
LU
                          088
                                                           STA
ST1
                          080
                          nan
                                      C902
                                                                                      οu
                                                                                     1,X'08'
                         08E
                                      5108
                                                                         ΤN
                                                                                                                       VARIABLE
                                                                                     1,X'08'
ST2
OV,X'01'
ST3
F1,1
                         DAF
                                      1492
                                                                         JP
TN
                                                                                                                       NO
                         090
                                      5F01
                                                                                                                      NU W.EQ. 0 OR 2
YES
STORE UPPER BYTE USING EXECUTE WITH U MOD
                         091
                                     1495
0111
8843
                                                           512
                         093
                                                                         ĪΝ
                                                                                     0L
                                                                                                                       INCREMENT OPERAND ADDRESS REGISTER TO 2ND
                         094
095
096
                                      8982
                                                                         AM
ET
TN
                                                                                     OULL
                                                                                                                       OPERAND BYTE
                                     0011
5108
                                                           ST3
                                                                                     F0.1
1.X'08'
                                                                                                                      STORE LOWER BYTE
                                                                                                                      VARIANO
W .EQ. 0 OR 1
YES
                                      140C
5F02
                                                                         JP
TN
                                                                                     RNI
OV.X'82'
RNI
                         097
                         099
094
                                     140C
16A6
8843
                                                                         JP
                                                                                                                      YES
SET U WITH STORE H OP CODE
INCREMENT OPERAND ADDRESS REGISTER
                                                                         Ľυ
                                                                                     X'46'
                         09B
09C
09D
                                                                                     0L .L
                                                                         ΪN
                                      8980
                                                                                     ST4
X'00'
S2.T.F
I.X'08'
                                                                         ĴР
                                     1484
                                                                                                                      GO STORE R REGISTER
                                                                                                                      GO STORE R REGISTE
CLEAR U
SET FOR DECREMENT
TEST FOR INCREMENT
SET FOR INCREMENT
                         09E
                                     1600
CD60
                                                                         ō
                                     5108
BD46
                         DAO
                         0 A 1
                                                                        CU
                                                                                     52.1
                                     884B
A9AA
BC29
AC77
                                                                        IN.
                                                                                     οĹ
                                                                                                                      HALF READ OPERAND TO T REGISTER
+1 OR -1 FOR INCREMENT OR DECREMENT
WRITE AND DECR S2 IF AN INCREMENT HAS DONE
                         0 A 3
                                                                                     011.L.H
S2,T
                         0A4
0A5
                                                                                     $1.D.H
                                                                         WS.
                        0A6
0A7
                                     C803
                                                                         MN
                                                                                     οĹ
                                     A922
                                                                                     0U.H
                                                                                                                      HALF READ UPPER BYTE TO T
ADD CARRY TO UPPER BYTE AND SET COND. FLG.
HALF WRITE
                                                                        RM
                        0A8
0A9
                                     8081
4030
                                                                                     S2,L,T,C
                                                                         ĴΡ
                         DAA
                                                                                                                      CHECK FOR OVERFLOW
                                                                JUMP AND
                                                                                   RETURN JUMP
                                                          JHP
                        DAR
                                     D160
                                                                                     1,T,F
1,X'07'
                                                                                                                     COMPLEMENT INSTRUCTION REGISTER M .EQ. 7 EXTENDED INDIRECT NO
                                     0160
4107
1485
A902
8840
8982
B920
A803
                        DAD
                                                                        JP
RM
                                                                                     JH1
                         DAE
                                                                                     ου
                                                                                                                      READ UPPER BYTE OF INTIRECT ADDRESS
                                                                                                                     INCREMENT OPERAND
ADDRESS REGISTER
GET HIGH RYTE WHICH IS IN T
READ LOWER BYTE OF INDIRECT ADDRESS
SET INDIRECT RETURN
                         DAF
                                                                                    0L
0U,L
0U,T
                        0B0
                                                                        ĀM
                                                                        RN
                                                                                     OL
S1,PTR3
                        082
                                     2C18
                                                                                                                      CHECK FOR POST INDEXI'G
```

IND1

```
I,X'08'
JM2
PL
PU,L
085
            4108
14BF
8A40
                                  JH1
                                               TZ
JP
I
                                                                                             RETURN JUMP
086
087
                                                                                              ADJUST P FOR NEXT INSTRUCTION
088
089
             8881
                                                                                              AFTER RTJ INSTRUCTION
                                                                                                       R RTJ INSTRUCTION

E PU. STURE PROGRAM COUNTER
AT FIRST TWO LOCATIONS

PL OF ROUTINE CALLED BY
RTJ, TRP, OR INTERRIPT
SET OPERAND ADDRESS TO
             A912
8843
A992
                                                            OU
                                                WH
                                                IN
OBA
                                                            OL
                                                            QU.L
                                                                                             STORE PL
ner
                                                            PL
            8840
OBD
                                                                                                       SET OPENAND ADDRESS TO
FIRST INSTRUCTION IN
CALLED SUBROUTINE AND
PLACE THE VALUE INTO THE
PROGRAM COUNTER TO BEGIN
             8982
                                               AH CH
                                                            ÕŨ,L
OBF
             C901
                                                            Ou
                                                            PU.T
OL
PL.T
 0C0
             8822
             C801
0C1
 002
             BA20
                                                                                             EXECUTION OF THE SUBROUTINE RETURN TO RNI
0C3
             140A
                                       REGISTER
                                                          OPERATE
                                                            Si,I,R
I,X'08'
REG3
                                                                                             CLEAR T AND S2
LOAD U WITH AND OP CODE (80)
             BC01
                                 REG
                                                CT
            FC66
4108
14DE
4101
0C5
0C6
0C7
                                                HU
TZ
JP
                                                                                              NO
                                                            I,X'01'
X'10'
I,X'04'
 008
                                                                                              SUB OR XOR INSTRUCTIONS
                                               TZ LUZ JPZ JPT OS MTS
            1610
4104
14D8
4102
14D3
OCA
OCB
                                                                                              INDEX CONTROL INSTRUCTION
                                                            REG2
 OCC
                                                            I.X'02'
                                                                                              A REG DESTINATION INSTRUCTION
                                                                                              ÑO
OCD
                                                            RFG1
OCE
            C601
                                                                                              B OR A TO A, USING U REG. MOD
                                                            AL,T
OCF
             C701
 000
                                                                                              9 XOR A TO A, USING U REG. HOD
 0D1
                                                             AU,T
             140C
C401
C627
                                                JP
HT
OS
HT
002
                                                            RNI
003
                                 REG1
                                                                                             A OR B TO B. USING U REG. MOD
                                                            AL
BL.T
AU
0D4
0D5
            C627
C501
C727
140C
4102
1103
EF29
                                                                                             A XOR B TO B, USING U REG. MOD
                                                            AU
BU,T
RNI
I,X'02'
X'03'
CV.T
XL,I,T
XU,L,C
                                               OS
JP
TZ
LT
NT•
0D6
0D7
                                                                                              WORD LENGTH CONTROL
YES, SET MASK FOR WORD LENGTH BITS
WITH AND COMMAND
0.08
                                 REG2
OD9
                                                                                              MITH AND COMMAND
ADD OR SUBTRACT HORD LENGTH, INCREMENT
OR DECREMENT X (DEPENDING ON U REGISTER)
CHECK FOR OVERFLOW
B_REGISTER TO BE MOVED OR MODIFIED
ODB
            8267
8397
                                                AS
AS
                                                            XU,L,C
OCK
I,X*01'
$1,X*02'
$1,X*04'
RMG5
I,X*02
REG4
 ODD
             1479
4101
                                                JP
TZ
AF
HU
TZ
                                 REG3
ODE
ODF
OEO
            3C02
                                                                                              YES
SET U WITH BASIC OF CODE
 0E1
             4104
                                                                                              INTER REGISTER TRANSFERS
            14EB
4102
14E8
0440
                                                JP
0E2
                                                                                              YES
                                                                                              COMPLEMENT A OR B REGISTER
                                                                                             VES
ADD 1 TO INCREMENT A OR B
ADD CARRY TO UPPER BYTE
CHECK FOR OVERFLOW
1'S COMPLEMENT A OR B REGISTER
0E4
                                               ĮΡ
                                                            AL.4
             0590
                                                Ē
0E6
                                                            AU, V
OČK
AL, T, F
AU, T, F
RNI
I, X 102 *
REG6
0E7
0E8
0E9
            1479
D467
D567
                                                JP
XS
                                 REG4
                                               XS
JP
TZ
JP
ET
C
ET
C
            140C
4102
14F2
0401
8220
DEB
                                 REAS
                                                                                              X REGISTER SOURCE FOR TRANSFER
DEC
                                                                                              A OR B TO T
T TO X
A OR B TO T
T TO X
DED
                                                            AL
OEE
                                                                                                                                       TRANSFER A OR B TO X
DEPENDING ON U REGISTER
                                                            XL.T
            0501
8320
OFO
                                                            χύ, T
            140C
C201
B427
C301
B527
0F1
0F2
0F3
0F4
                                               JP
HT
CS
HT
CS
JP
                                                            RNI
                                                                                                 TO T
TO A
TO T
                                 REG6
                                                            XL
                                                            ÂĻ,T
XÚ
                                                                                                           OR B
                                                                                                                                       TRANSFER X TO A OR B
DEPENDING ON U REGISTER
 OF 5
                                                            AU.T
                                                                                                            OR B
                                                            RNI
            4908
F10F
F1A7
F0A7
5902
                                               TZ
HS•
HS
HS
                                                           00, X 1 08 .
Fi.L.R
FO,L.R
OU, X 102 !
                                                                                             LOGICAL SHIFT
NO, SET LINK WITH SIGN
RIGHT 1
RIGHT 1
REGISTER (A OR B)
0F7
0F8
0F9
OF A
                                                                                             LONG SHIFT
            1564
F7A0
F6A0
                                                JP
OFC
                                                                                             NO
RIGHT 1
                                                            SH1
OFD
OFE
OFF
                                                            BU,L,R
                                                                                                                                   SHIFT RIGHT
                                               H
JP
                                                            BL,L,R
SH1
                                                                                              REPEAT SHIFTS
                                                                                             BOARD 2
                                               ORG
                                                            256
                                                        JUMP TABLE
                                             CODE
JP
JP
                                       OP
                                                            CTL
101
            1531
155A
1586
14C4
1C00
14AB
149E
1486
1C01
145B
1459
                                                            CJ
                                                                                             CONDITIONAL JUMPS
SHIFTS
                                                JP
JP
JP
103
104
105
106
107
                                                                                              INPUT/OUTPUT
                                                            10
                                                                                             INPUT/OUTPUT
REGISTER OPERATE
SPARE INSTRUCTION OP CODE
JUMP AND RETURN JUMP
INCREMENT AND DECREMENT MEMORY
LOAD AND STORE X
NULTIPLY/DIVIDE
                                                            REG
                                                JP
JP
                                                            SP.
                                                            THE
108
                                                JP
JP
                                                            LDX
                                                            MUL
                                                            ADA
SBA
CPA.
ANA
10A
                                                                                              ADD
                                                JP
JP
JP
                                                                                             SUBTRACT
10B
10C
10D
            1459
1002
1457
1455
1480
                                                                                              COMPARE
                                               JP
                                                            LDA
STA
                                                                                              LOAD A
                                                                                             STORE A
                                       CONTROL
                                                                                             TEST FOR GROUP 1 OR 2
OVERFLOW AND WORD LENGTH EXIT
SET UP JUMP TABLE VALUE
ADD WITH RASE ADDRESS
TABLE JUMP.
MALT (INCREMENT P COUNTER)
            4108
152D
F109
2C15
8C25
110
111
                                               TZ
JP
                                                            1.x'08'
                                                            GP2
112
                                               HT.
                                                            SI,CTBL
                                 CTAL
                                                            PL
```

```
152A
15E4
14B5
7510
140C
                                                                                            JHP TO HALT ROUTINE
TRAP INSTRUCTION (SAME AS CONSOLE INT.)
IND FROM ADDR TO JUMP (NOT PART OF CONTROL)
116
117
118
119
11A
11C
11D
11E
11F
                                               JP
JP
JP
                                PTR3
                                                           JH1
                                               K
JP
MM
                                                           AU,1
                                                                                            ENTER SENSE SWITCHES
                                                           RNI
            C402
                                                           AL
PMP
                                                                                            PROTECT HEMORY PAGE
            1527
1704
1524
                                               JP
LS
JP
LS
JP
                                                           X'04'
Ec1
X'08'
Ec1
X'10'
                                                                                            DISABLE INTERPUPT SYSTEM
            1708
                                                                                            ENABLE INTERRUPT SYSTEM
121
            1710
                                               LS
                                                                                            DISABLE REAL TIME CLOCK
                                                           EC1
X'20'
PL
                                                                                            ENABLE REAL TIME CLOCK
SET P TO NEXT INSTRUCTION ADDRESS
AND FETCH INSTRUCTION BYTE
BY PASS INTERRUPT CHECK
SELECTED PROTECT BITS TO T
123
124
             1720
8A43
                                               LS
IN
                                EC1
                                                           PU,L
RNI6
125
126
127
            AB82
1410
C701
                                               RM
                                 PMP
                                               ЙT
                                                           BU
X1401
            1740
140C
8880
1780
128
                                                                                            SET PROTECT STATUS
                                               JP
                                                           RNI
PU.L
X:80'
                                                                                            ADD CARRY TO ADJUST P UPPER FOR NEXT INSTR.
                                               LS
JP
LT
128
120
120
                                 HLT1
             1409
                                                           RNI5
                                 GP2
                                                                                            SET MASK (TO SAVE UPPER HALF OF OVEN)
            11F0
12E
12F
                                                                                            CLEAR OV/W STATUS
PUT OV/W SETTING INTO T
            EF20
                                               N
HT
                                                           OVIT
            C101
                                                           SOF
130
            1470
                                               JP
                                                                                            GO SET NEW STATUS FOR DV/W
                                                           L JUHPS
X'07'
I,T
S1,JT8L
X'02'
                                       CONDITIONAL
                                                                                           MASK FOR CONDITION
REMOVE OP CODE
BASE TABLE ADDRESS
SET FOR X REGISTER
SET TO SELECT A. OR B ON ZEPO TEST
DO A TABLE JUMP
OVERFLOW TEST
                                               LT
NT•
132
133
134
            E129
2C4E
1602
                                               Ľυ
 135
            RC60
                                                           S2.1.T
136
137
138
            8C25
5F04
                                                           S1, T
0V, X'04'
                                 JO
            1540
1104
DF 20
                                                           CJ3
X'04'
                                               .IP
                                                                                            NO
139
134
                                                                                            OVERFLOW RESET BIT TO T
RESET OVERFLOW BY TOGALING
                                                           0v,T
CJ2
F0,C
F1,L,C
F0,X'04'
             153F
138
130
                                               JP
MS
                                                                                           TEST LOW SYTE
TEST HIGH SYTE
TEST HIGH SYTE
LINKED ZERO
YES, FLIP TEST BIT SY COMPLEMENT
GET DISPLACEMENT WHICH IS 2ND
BYTE OF INSTRUCTION
                                                                                                                                TEST A OR B WITH
            C017
                                 J3
13D
13E
13F
140
             C197
                                               HS
TZ
                                 CJ1
            D160
141
             AB82
5108
                                               RH
                                                           PULL
                                                                                            CONDITION MET
                                                            1,X'08'
            140C
8A63
B030
5002
                                               JP
AN
C
TN
143
144
145
146
147
148
149
                                                           RNI
PL,I,T
                                                                                            ADD DISPLACEMENT
                                                                                            LOOK AT T
T NEGATIVE
NO
ADJUST PAGE IF BOUNDARY CROSSED
                                                           F0.T.C
F0.X'02'
                                               JP
RH
             140D
                                                           PU.D
RNI2
             AB 42
            140E
C117
4002
                                               JP
14A
14B
                                               HS
TZ
                                                                                            LOOK AT AU OR XU FOR SIGN TEST
                                 J5
                                                           F0.X'02'
                                                                                            NEGATIVE
                                               JP
JP
                                                           CJ2
 1 4 D
            1540
                                                                                            ΝO
                                       CONDITI
                                                     ONAL
                                                               JUHP TABLE
            1537
                                                                                            OVERFLOW
14F
14F
150
151
152
153
154
155
156
157
158
                                                           X 1001
            1000
                                                                                            NOP
                                                           S2
J3
X1041
            FD06
                                                                                            SET-FOR A OR B
                                               JP.
            1604
154A
                                                                                            SET FOR A
                                                           J5
X1061
                                               .IP
            1606
C401
D03F
                                               LU
HT
XS•
                                                                                            SET FOR B
                                 J7
                                                           AL
FD,T,C
                                                                                                                                    TEST FOR A=B OR A=X
DEPENDING ON U REG.
                                                                                            COMPARE LOWER
            C501
                                               MT
XS.
                                                           AU
F1,L,T,C
                                                                                            COMPARE UPPER
TEST RESULT OF COMPARISON
            DIBE
            153E
                                               JP
                                                           CJ1
                                       SHIFTS
                                                                                            SAVE OP CODE IN OPERAND
ADDRESS REGISTER
SET ADDR FOR CONCURRENT 1/0 TEST
GET SHIFT COUNT (2ND BYTE IN INSTRUCTION)
15A
15B
15C
15D
15E
15F
            C101
                                 SH
                                               MT
C
            B920
2C66
8A43
AB82
1604
                                                           OU.T
                                               ĻF
                                                           $1,5H2
                                                           PL
PU,L
X'04'
                                               IN
                                                                                            SET U FOR SHIFTING A REGISTER
                                               LU
TZ
                                                                                            SET U FOR SHIFTING A REGISTER
TEST FOR A OR B SHIFT
SET U FOR SHIFTING B REGISTER
MOVE SHIFT COUNT TO Q.
AND COMPLEMENT IT FOR LODP CONTROL.
CONCUPRENT I/O REDUEST
YES (SERVICF CONC I/O DURING SHIFT)
AND 1 TO COUNT AND RESET LINK
COUNT NEGATIVE
160
             4901
                                                           0U, X'01'
                                                           00,X'0
X'06'
OL,T
OL,T,F
161
            1606
                                               C
X
162
163
            B820
            D860
164
             4008
                                 SH1
                                               TZ
JP
TN
JP
TZ
JP
                                                           F0, X'08'
            1014
8840
5880
                                                           CIO
                                                           OL
                                 SH2
 166
 167
                                                           OL . X'80'
             140C
 168
                                                                                            NO
LEFT SHIFT
NO, JUMP TO RIGHT SHIFT ROUTINE
LOGICAL SHIFT
YES, SET LINK WITH LOW ORDER RIT
LONG SHIFT
                                                           0U.X'04'
169
164
168
            4904
14F7
5908
                                                           011. ** 08
                                               HS .
            F10F
5902
                                                           F1
(", X'02)
 16D
                                              TP H H
            1571
F680
F780
F087
16E
                                                                                            NO
LEFT 1
                                                            SL1
                                                                                                                                SHIFT B LEFT FOR LONG SHIFT SHIFT A, OR B LEFT, DEPENDING ON U
                                                           BL.L
170
171
172
                                                           BU.L
                                                                                            LEFT 1
                                 SL1
                                               HS
                                                                                            LEFT 1
REPEAT SHIFTS
            1564
                                               JP
                                                           SH1
                                       BOOTSTRAP
                                                           LOADER
                                                                                            SHIFT RIGHT (RIGHT JUSTIFY OP CODF)
REMOVE BITS BY CAUSING CARRY ON UPPER BITS
SET LOADER SIZE .EQ. 256
SERIAL HODE
174
175
            7120
3108
                                 LOAD
                                               K
                                                           1,2
1,x'08'
            2A00
5101
157F
176
177
                                               LF
TN
                                                           PL.SIZE
                                 LODI
178
179
                                                           F0D3
                                               ĴΡ
                                                                                            VES
                                               ĽT
                                                                                            SET FOR STATUS IN
                                 LOD5
             1120
```

```
SET RETURM
GET STATUS
CHARACTER READY
17A
17R
17C
                   2070
1580
5402
                                                                         LF
                                                                                             S1,L002
                                                                                            FUN
AL,X'02'
                                                                          JP
TN
                                                   1002
170
170
                                                                                             LOD5
X'00'
                                                                                                                                               NO
SET FOR DATA IN
SET RETURN
                    1579
                                                                         JP
LT
LF
JP
HT
                    1100
                   2C81
158B
 175
                                                    LODS
                                                                                             Si.LOD4
                                                                                                                                               GET DATA
SET DATA IN T
 180
                                                                                              INA
                                                                                            AL
PL.D
PL,X'FF'
                    C401
                                                    LOD4
187
183
184
                   AA53
4AFF
1577
                                                                         WN
TZ
JP
JP
                                                                                                                                                STORE BYTE
                                                                                                                                                DONE LOADING
                                                                                            LOD1
RNI5
                                                                                                                                                NO
                    1409
                                                                                                                                                YES
                                                             INPUT-DUT
                                                                                          PUT
                   4104
140C
8A43
AB82
2CA3
186
187
188
189
                                                    10
                                                                                            1.X'04'
                                                                         TZ
                                                                                                                                                NOP
                                                                                                                                               YES
GET DEVICE ADDRESS HHICH IS
SECOND BYTE OF INSTRUCTION
RETURN TO RNI
                                                                                            RNI
PL
                                                                                            PU,L
$1,10K5
I,X'03'
$10
188
180
180
                   5103
1584
7090
                                                    INA
                                                                         TN
JP
K
L
JP
                                                                                                                                                SERIAL MODE
                                                                                                                                                YES
                                                                                                                                               CONTROL OUT
                                                                                            F0.9
X'00'
                                                   FIIN
18F
                    1000
                                                                                                                                                                                                              COXX CONTROL
185
                                                                                            101
F0.8
I.X'08'
                   1590
190
                   7080
                                                    101
                                                                         K
                                                                                                                                               CLEAR
INPUT
192
                   15A4
70E0
                                                                                                                                               DATA IN
                                                                                             F0,14
194
                   1595
BD21
                                                                         ĴP
CT
                                                                                             102
                                                                                                                                                                                                              DIXX INPUT
                                                                                            $2.T
F0.8
                                                    102
                                                                                                                                               GET DATA
                                                                                                                                                                                                              STROBE
                   7080
5102
15A0
5101
196
197
198
                                                                         K
                                                                                                                                               CLEAR
                                                                                                                                                                                                             TEST FOR INPUT TO A OR INPUT TO B OR INPUT TO MEMORY
                                                                                                                                               H .EQ.
                                                                         JP
TN
                                                                                             104
1.X'01
199
                                                                                                                                               M .EQ. 2
19A
                   15A2
                                                                         JP
LF
                                                                                             105
                                                                                            $1,103
                                                                                                                                                                                                         SET ADDR FOR INPUT TO MEMORY AND STORE BYTE
190
190
190
196
                   1430
A912
CC01
140C
                                                                         JP
WH
                                                                                                                                               GET STORE ADDRESS
                                                    103
                                                                                             Ou
                                                                         MT
JP
C
                                                                                            S2
RNI
                                                                                                                                                STORE BYTE
1A0
1A1
1A2
                   B420
                                                    104
                                                                                             ALIT
                                                                                                                                               PUT BYTE IN A
                                                   104A
105
                   CCOS
                                                                        HK
C
JP
JP
TN
                                                                                             S1
                   B620
                                                                                             BL.T
1A3
1A4
1A5
1A6
                   140C
5102
15AD
5101
15B2
                                                                                                                                               M .EQ. 1
YES
                                                    IOK5
                                                                                            RNI
1.X'02'
                                                                                                                                                                                                             TEST FOR CUTPUT IROM
                                                                                             I.X'01
                                                                                                                                                M → EQ. 2
1A7
1A8
1A9
1AA
1AB
                                                                                             1010
S1,106
INDX
                                                                          .IP
                                                                                                                                               YES
                   2CAA
1430
A902
2C9F
15AE
                                                                         LF
                                                                                                                                                                                                         FETCH OUTPUT
BYTE FROM MEMORY
                                                                                                                                               GET OUTPUT ADDRESS
                                                                                            00
S1,104-1
                                                    106
                                                                         RH
LF
JP
MT
K
                                                                                                                                               SET RETURN
                                                                                             108
                   C401
70A0
1000
1AE
1AF
                                                    107
                                                                                            AL
F0,10
X'00'
                                                                                                                                               A TO T
OUTPUT
NOP
                                                                                                                                                                                                               DOXX OUTPUT
                                                                         LAKET
180
181
                   1581
7085
                                                                                            109
S1,8
                                                                                                                                                                                                                STROBE
                                                                                                                                               CLEAR AND EXIT
                                                    109
182
                   C601
                                                    1010
                                                                                             BL
Ins
                                                           SERIAL
D LF
TZ
                                                                                          LETYPE
                   290A
4108
15C4
9940
                                                                                            0U,X'0A'
184
185
186
187
188
189
184
188
                                                    510
                                                                                                                                               SET BIT COUNT
                                                                                                                                                INPUT
                                                                                           SOUT
OU
X'01'
F0,X'40'
S10!
X'48'
S2,S10!
DLY1
X'01'
F0,X'40'
AL,X'80'
DLY2
S2,L'01'
F0:11
                                                                                                                                                NO
                                                                                                                                                ADJUST BIT COUNT FOR INPUT SAMPLING
                                                                                                                                               ADJUST OF THE SERIAL TITY (INPUT A SAMPLE)
START BIT
NO, REPEAT SAMPLE
SET DELAY COUNT (220 MS)
SET DELAY RETURN
                   1701
5040
                                                                          LS
                                                   S101
                   1588
2148
2DBE
                                                                        JP LF LF
180
180
186
                   15C7
                                                   SIDI
                                                                         LS
                                                                                                                                               ENABLE SERIAL TTY
                                                                                                                                               ENABLE SERIAL I
SPACE
YES, REMOVE BIT
GO, DELAY
GET LINK RIT
18F
1C0
1C1
1C2
                   4040
3480
                                                                         JP
H
                   15C6
                                                    $100
103
104
105
106
                   5001
7080
                                                                                                                                               CURRENT BIT, A ZERO
YES, SPACE
SET DELAY RETURN
SET DELAY COUNT (220 MS)
                                                                          ΤN
                                                    SOUT
                                                                         K LF LF D N JP
                   2DC2
                                                    DLÝ2
                                                                                            OL, X'46'
OL, C
FO, X'04'
1C7
                   2846
9850
                                                   DLY1
DL1
                                                                                                                                                REDUCE LOW COUNTER
1C9
1CA
1CB
1CC
                   5004
1508
                                                                                                                                                COUNTER ZERO
                                                                                            DL1
1.C
F0,X'04'
DLY1
OU,X'0F'
                                                                                                                                                NO
                   9150
5004
                                                                         D
TN
                                                                                                                                               REDUCE UPPER COUNTER
COUNTER ZERO
1CD
                   15C7
590F
                                                                         JP
                                                                                                                                               NO
BIT COUNTER ZERO
                   CC05
9940
F460
                                                                         HK
D
H
                                                                                                                                               YES, EXIT /
REDUCE BIT COUNTER
SHIFT LOW BIT TO LINK
CLEAR AND EXIT (MARK)
1CF
                                                                                             Sĩ
100
                                                                                             011
1D1
                                                                                             ĂĽ,I,R
102
                   7D85
                                                                         KK
                                                                                            $2.8
                                                             INTERRUPTS
1D3
                    4F80
                                                                                            0V.X'80*
                                                                                                                                               POWER FAIL IN PROGRESS
                   47 80
1410
4010
15E3
4008
1C13
70D0
2800
1D4
1D5
                                                                         JP
TZ
                                                                                                                                                YES
                                                                                            FO, X'10'
                                                                                                                                                INTERNAL
1D6
1D7
                                                                         JP
TZ
                                                                                                                                                YES
                                                                                                                                               CONCURRENT 1/0
                                                                                             C101
 108
                                                                         JP
K
LF
                                                                                            F0,13
OL,X'n0'
X'01'
Si,T
Fn,8
1D9
                                                                                                                                                ACKNOWLEDGE
                                                    EXT
                                                                                                                                               CLEAR OL
SET FOR PAGE 1
GET ANDRESS
                                                                                                                                                                                                              ITAK INTERRUPT
                   1201
RC20
7080
AC03
1DB
                                                                         ĽM
C
                                                                                                                                                                                                              ACKNOWLEDGE
STROBE
                                                                         K
RN
 100
                                                                                                                                               CLEAR
                                                    INT1
                                                                                             51
 1 DE
                                                                                             OU.T
                                                                                                                                               GET UPPER ADDRESS
```

```
1E0
                     ACC3
                                                                                                    S1.I
OL.T
RJP
                                                                                                                                                           GET LOMER ADDRESS AND RESET LINK
DO A PETURN JUMP
GET INTERNAL STATUS
CLEAR OL AND M
CONSOLE INTERPUPT OR THAP
                     8823
1488
7140
                                                                                AN
JP
K
1E1
1E2
1E3
                                                         INTO
                                                                                                     1.4
1E4
1E5
                     B802
                                                                                                    OL
1.X'01'
                                                        TRP
                                                                                4101
                                                                                                    S1, X'A0'
1, X'02'
S1, X'A2'
1E6
1E7
1E8
                                                                                                                                                            YES
SPARE
                     2082
                                                                                                    S1, X ' A2 '
| X ' O 4 '
| S1, X ' O 0 '
| X ' O 0 '
| X ' Y O 6 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X ' Y O 7 '
| X '
1E9
1EA
1EB
                      4104
                                                                                                                                                            REAL TIME CLOCK
                     2C00
                                                                                                                                                            YFS
                                                                                                                                                            MEMORY PROTECT
1EC
                     2088
                                                                                                                                                            MEMORY PARITY
1ED
                     4110
208A
                                                                                                                                                            YES
MEMORY RUNNDARY
1EE
                     4120
2080
150
                                                                                                                                                            YES
1F1
1F2
1F3
1F4
                                                                                                                                                            POWER FAIL
                                                                                                     I,X'80'
                      4180
                     1003
                                                                                                    1,X'40'
HLT1
S1,X'80'
                                                                                                                                                            CONSULE HALT
                                                                                                                                                            REAL TIME CLOCK
1F5
                      4080
1F6
1F7
1F8
                     15DE
                      1006
7140
                                                                                                     INT4
                                                        INT2
                                                                                                     1,4
                                                                                                                                                            GET INTERNAL STATUS
                                                                                                     1.X'80'
                                                                                JP
JP
1F9
1FA
                     5180
15E4
                                                                                                                                                            POWER RESTART
                      1010
                                                                                                     INTS
                                                       PTR4
                                                                  INDIRECT
                                                                                                 POINTERS
1FC
                                                                                JP
                                                                                                     C102
                                                                                                                                                            INDIRECT FROM CIO OR 10 TO CIO2
INDIRECT FROM CIO TO MULTIPLY
INDIRECT FROM CIO TO DIVIDE
                     1038
                                                       PTR1
                     107E
109B
1 F D
                                                                                                     MIII 3
                                                                                                     DIVE
                                                                                                                                                            BOARD 3
                                                       .
SP.
                                                                                                   OP CODE TABLE
                                                                 SECONDARY
                                                                                                                                                            SPECIAL (ERROR HALT)
200
                     1780
                                                                               JP
JP
                                                                                                                                                            MULTIPLY/TIVINE
                     1062
                                                       HUL.
                                                                  INTERRUPT OPTIONS (PWFL/RESTART AND RTC)
                                                                                                    OV, X'80'

OV, X'80'

INT1

S1, X'84'

S1, I, H

OL, I, T, C

F0, H

F0, L, T, C

S1, I, H

F0, X'04'
                     3F80
2C8E
15DE
2C84
ACE3
                                                                                AF
LF
JP
LF
203
204
205
206
207
208
209
20A
20B
                                                        PHRE
                                                                                                                                                            SET FLAG FOR POWER FAIL
                                                                                                                                                            SET COUNTER ADDRESS
GET LOWER HALF OF COUNTER
ADD 1 AND SET COND CODE
PUT BACK
GET UPPER HALF OF COUNTER
ADD CARRY AND SET COND CODE
PUT BACK
COUNTER ZERO
YES, GO TO SERVICE ROUTINE
NO, GO RE-FETCH INSTRUCTION
CLEAR OL.
                                                         INT4
                      8879
A030
                                                                                 ATO
                      AC6B
BOB1
                                                                                CT
H
TZ
JP
JP
LF
LF
20C
                      ACFO
20E
                      15DE
1038
                                                                                                     INT1
C102
210
                      2800
                                                         INTS
                                                                                                     OL, X'00'
Si, X'90'
                      2090
150E
                                                                  CONCURRENT INPUT-OUTPUT
1 LF Si,PTR4
                                                                                                                                                            INDIRECT RETURN ADDRESS FROM
CONCURRENT I/O, ENTERED
FROM NORMAL INTERRUPT/CONC I/O
TEST ROUTINE
ACKNOWLEDGE REQUEST
                      2CFC
                                                         CIOI
                                                                                                    F0.13
X'00'
X'00'
I.T
F0.8
I.I.C
                    70D0
1000
1200
B120
214
215
216
217
218
219
21A
218
                                                         ČIO
                                                                                 ĸ
                                                                                                                                                            NOP
SET FOR PAGE ZERO
GET ADDRESS
                                                                                                                                                                                                                                                   CONCURRENT
                                                                                LLCKHRORCTJR
                                                                                                                                                                                                                                                   I/O AC
STROBE
                                                                                                                                                                                                                                                                ACKNOWLEDGE
                     7080
F150
                                                                                                                                                            CLEAR
ADJUST AND REMOVE I/O FLAG BY SHIFTING
                      A103
BE20
                                                                                                     I
$3,7
                                                                                                                                                            GET CURRENT ADDRESS LOWER
                                                                                                    S3.T
I.D
F0.T
F0.X'01'
C104
S3
F0.T
F0.10
C103
S3
21C
21D
21E
21F
                      A148
                                                                                                                                                            GET CURRENT ADDRESS UPPER
INPUT (TEST OVERFLOW COND. FLAG.)
                     5001
1038
AE03
                                                                                                                                                            TES
READ OUTPUT BYTE FROM MEMORY
WAIT FOR DATA (DELAY)
 220
                      8020
70A0
                                                                                C
221
                                                                                                                                                                                                                                            DOXX STROBE FOR CONCURRENT OUTPUT
                                                                               K JP
                                                                                                                                                            OUTPUT
223
224
225
                      1C24
8E40
                                                                                                                                                            DELAY
ADJUST CURRENT LOWER
DOXX STROBE
CONCURRENT
CLEAR
SET FOR PAGE ZERO (CONC I/O POINTER)
GET CURRENT ADDRESS UPPER
ADJUST (ADD CARRY)
PUT BACK
COMPARE LOWER
COMPARE CON BYTES
STORE CURRENT LOWER
                                                                                                                                                            DELAY
                                                       C103
                                                                                                     S3
F0.8
X'00'
I.D.H
F0.L.T
I.I.H
                      7080
                                                                                LH
RN=
CT
                    1200
A16B
B0A1
A1F0
A1CB
226
227
228
22A
22B
22C
                                                                                 RN.
                                                                                RNO
SO
WN
HT
RNO
CN
                     9E38
                                                                                                     SS.T.C
                                                                                                     1 . D
                     CE01
A14B
                                                                                                     $3
1,D
22E
22F
230
                                                                                                                                                            GET CURRENT UPPER
                     BE20
A1C3
                                                                                                     $3,T
                                                                                                                                                            BET ENDING UPPER
COMPARE HIGH BYTES
RESULT .LT. 0 (LINKED ZERO TEST)
GET TO SECOND PAGE TO EXIT
ADJUST DEVICE ADDRESS
                                                                                                     1.1
                    9EB0
4006
15A1
F120
                                                                                S
TZ
JP
H
                                                                                                     $3,L,T,C
F0,X'06'
231
232
233
234
                                                                                                     1.R
1.1.R
1.X'09
                                                                                                                                                                                                                                                                END OF BLOCK DISCONNECT
235
                    F161
2109
                                                                                 ΗT
                                                                                                                                                            PUT IN FUNCTION CODE
236
                                                                                LF
237
                      158D
                                                                                                     FUN
                                                                                                                                                            DISCONNECT DEVICE
                                                                                                    PL
PÚ
RNI2
Fő,14
X:00'
238
239
23A
23B
23C
23D
                     CA03
                                                       C102
                                                                                HN
RH
                                                                                                                                                            GET CURRENT INSTRUCTION
                    AB02
140E
70E0
                                                                                ĴP
K
                                                       C104
                                                                                                                                                            INPUT
                                                                                                                                                                                                                            CONCURRENT DATA
                    1000
AE13
                                                                                                                                                            NOP
STORE INPUT DATA
                                                                                HN
                                                                                                    F0.T
23E
23F
                    B021
                                                                                CT
                                                                                                                                                            GET INPUT BYTE
```



# PART IV MICRO 1600 REFERENCE MANUAL

# CHAPTER 1

# **MICRO 1600 DESIGN FEATURES**

The MICRO 1600 is a microprogrammable digital computer with the capability to satisfy a broad range of application requirements through the use of both expandable high-speed control memory and magnetic core main memory.

The high-speed control memory continuously sequences preprogrammed microcommands which generate control and timing signals to perform all control operations and data manipulations in the computer.

Using application programming at the micro level, the MICRO 1600 can be used directly as a hard-wired controller. When the 1600 emulates the operation of a general purpose computer which executes software instructions stored in core memory, macroinstructions are fetched and interpreted by the microprogram with corresponding operations carried out by execution of microprogrammed routines in the control memory.

Basic macroinstruction sets are available which are significantly more powerful than conventional minicomputers. Individual users can add to or modify the basic macroinstruction set and basic input/output structure by a simple addition or change of firmware in the control memory to increase the flexibility and utility of the machine.

Control memory can be implemented in bipolar read-only memory (BROM), programmable read-only memory (PROM) or alterable read-only memory (AROM) devices. BROM is low cost and is appropriate for volume production of field-proven firmware. PROM permits microprograms to be installed at the factory or in the field with fast turn-around time and low initial set-up costs. It is intended for use in low production volume. AROM permits dynamic microprogramming and/or the debugging of firmware in a real-time environment before implementation into the more permanent BROM and PROM control memories.

There are 30 general-purpose file registers which are implemented with MSI/LSI semiconductor devices. Under program control, these registers are typically assigned functions such as I/O buffer registers, accumulators, index registers, and program counters.

The internal data paths and I/O are byte-oriented with eight-bit word lengths. Under control of microcommands, effective word lengths are variable.

Owing to its inherent flexibility, the MICRO 1600 can be applied as a direct function processor, general-purpose computer, special-purpose computer, emulator or language processor.

The MICRO 1600's control memory can be expanded to 16,384 16-bit words. This will permit implementation of languages such as BASIC, COBOL, FORTRAN, or equivalent complex firmware requirements. Direct language implementation will eliminate intermediate compile operations and results in an interpretive processor or a compile-and-go capability with performance exceeding conventional minicomputers.

Packaging variations permit operations ranging from a stripped-down low-cost minicomputer with three printed circuit boards and a card cage to a "super" computer with multiprocessor capability.

# GENERAL CHARACTERISTICS

Advanced features and operating characteristics include:

- 65,536 bytes of memory in basic enclosure
- 4096 and 8192 byte core memory modules
- 1 microsecond main core memory speed (full cycle)
- Dual processors with common main memory
- Macro processors

Standard macro processors, the 1600/10, 1600/20 and 1600/21 are available. These permit users to apply the machine using conventional software programming while providing advanced system features.

Alterable read-only memory

Alterable read-only memory permits firmware programmers to operate new microprograms in a true on-line environment.

Supporting standard software including special firmware development packages.

AP1600 — Micro language cross-assembler written in FORTRAN MAP1600 — Micro language assembler written for use on the

MICRO 1600/20 and 1600/21 computers.

SIM1600 — MICRO 1600 simulator written for use on the

ICM1600 — Integrated circuit memory MAP generator permits direct conversion of AP/MAP1600 outputs to control memory bit

ROM Diagnostics – Pluggable standard CPU diagnostics in read-only memory.

AROS1600 — Alterable read-only memory operating system for control of AROM used for firmware checkout and debug.

Direct memory access (DMA)

patterns.

- 30 general purpose eight-bit file registers plus eight-bit status register
- Up to 16,384 words of read-only memory in 256-word modules
- 200-nanosecond microcommand execution time

MICRO 1600/20 and 1600/21 computers.

- Real-time clock (optional)
- Standard automatic shutdown in event of power failure and automatic startup when power returns
- Operating temperature range 0 to 50°C
- Dimensions: 10-1/2 inches high, 19 inches wide, 20 inches deep
- Power: 115/230 VAC, 47-63 Hz, 350 watts
- Optional 16-level stack for recursive firmware

#### **CHAPTER 2**

#### SYSTEM DESCRIPTION

The MICRO 1600 is an eight-bit computer employing microprogram control. The computer incorporates eight-bit registers and data paths, executing with every clock pulse a 16-bit microcommand stored in a high-speed semiconductor control memory. The major elements of the system are shown in Figure 1.

This chapter describes the registers, data flow, memory and control. The microcommands are described in Chapter 3 and the input/output in Chapter 4.

#### REGISTERS

All registers except the file registers have specific functions in the machine. The file registers are used by the programmer for general purpose use. Description of the processor's registers follow.



Figure 1. MICRO 1600 Block Diagram

#### T Register

The eight-bit T Register serves as an operand register for most operate commands and a buffer register for data being written into the memory and output on the byte I/O bus. The contents of the T Register are transferred to the MD or OD Registers on memory write or output respectively, thus freeing the T Register for other uses. Memory read operations cause the accessed data to be placed in the T Register 400 nanoseconds after the memory read is initiated.

#### M Register

The eight-bit M Register holds the 8 high-order bits of the processor's 16-bit memory address.

# N Register

The eight-bit N Register holds the 8 low-order bits of the processor's 16-bit memory address.

# **U** Register

The eight-bit U Register is used to modify the 8 high-order bits of the control memory output. The contents of the U Register are ORed with the Control Memory output on the R-Bus as it is gated into the R Register for those commands which have zeros in bits 15-12 or zeros in bits 2-0 and a 1 in bit 15. The U Register permits efficient use of control memory by allowing a common routine to be used for different operations, when the operations differ by only a few commands.

# File Registers

Two files of 16 registers each provide storage for internal flags, and user's data. Typical assignments include program counters, accumulators, index registers, temporary buffers, etc. The primary or secondary file is selected by command and the primary file is selected after reset or power-on.

Only registers 1-15 are available to the user. Register 0 is common to both files and contains flags as described later. This register cannot be written into but can be used as a source of data. Readout of register 0 does not alter its contents.

# Link Register

The two-bit LINK Register holds the carryout of the high-order bit position of the adder for Add, Increment, Subtract, Decrement and Compare commands and the shifted off end bit for Shift commands. The ML link bit is selected and/or set when the M or N Registers have been selected as a destination, otherwise the AL link bit is used.

# IC Register

The three-bit IC Register is the I/O Control Register which specifies the I/O bus control signal to be enabled. The output of this register is decoded within I/O device controllers into three output control signals and four input control signals. The register is loaded and cleared by microcommands, therefore the timing of control signals on the bus is up to the microprogram. When the IC Register contains a value of 4-7 one of the

input modes is specified and the Input bus is substituted for the T Register on any commands which select T or the complement of the T.

# L Register

The 12-bit L Register holds the address of the next control word in sequence and provides for direct addressing of 4096 words of control memory. The register is incremented by one as each instruction is executed unless it is loaded by a new value which will effect a jump in the sequence. There are no restrictions in incrementing the L Register. The register can be loaded by a Jump command which alters the 10 low-order bits, a Jump Extended command which alters all 12 bits, a Return command which alters all 12 bits, or by specifying the L Register as the destination which alters the 9 low-order bits.

When the extended control memory option is included in the machine a Bank Select Register allows addressing to 16K. In this case the 2 high-order bits are set by the Bank Select command. A third bit is available, in the basic architecture, for future expansion to 32K words.

#### L Save Register

The 12-bit L Save Register saves the incremented contents of the L Register when a Jump Extended command is executed, unless this has been inhibited by prior execution of an Inhibit L Save command. Execution of a Return command causes the contents of the L Save Register to be transferred back to the L Register. In this manner the L Save Register acts as a linkage register allowing one level of subroutine.

When the L Save stack option is included in the machine the L Save Register is replaced by an L Save Stack of 16 12-bit registers which perform the same function. Selection of the current stack register is under command control.

# R Register

The 16-bit R Register holds the microcommand currently being executed. The input to the R Register is from the R-Bus which is normally the output of the control memory, but may also be the console switches.

# **MD** Register

This eight-bit register is a buffer which holds data being written into memory. It is not directly accessible to the programmer, but automatically copies the contents of the T Register 350 nanoseconds after the write operation is initiated. This frees the T Register for other uses.

# **OD Register**

This eight-bit register is a buffer which holds data being output on the Byte I/O Bus. It is not directly accessible to the programmer, but automatically copies the contents of the T Register when the IC Register is set to a non-zero value. This frees the T Register for other uses.

#### **DATA FLOW**

# Arithmetic/Logic Unit

The arithmetic/logic unit (ALU) is the heart of the processor's data flow. All transfers and manipulation of data are done through this unit. The operations that it performs include: add, subtract, AND, OR, exclusive-OR, transfer and shifting. The two inputs to the ALU are the selected file register and the operand placed on the B Bus.

#### A and B Buses

The output of the ALU is placed on the A Bus where it can be routed to all the processor's registers. Other inputs to the A Bus are the internal status byte, the four sense switches on the front panel and a selected file register shifted four bits to the right. The information on the A Bus is routed to a register implied by the operation code of the command, or optionally to the selected file register and a designated register.

The B Bus is the second input to the ALU. Sources of data on the B Bus are the literal in the eight low-order bits of the command and the true or complement of the contents of the T Register or the data on the Input Bus. The Input Bus is substituted for the T Register as a selected source when the I/O control IC Register is in an input mode. After a switchable delay after placing the I/O control in an input mode, data from an I/O unit will be available on the Input Bus.

#### **Arithmetic and Memory Link Bits**

Two link bits are provided in a register commonly referred to as LINK. These bits store the carry out of the high-order bit position of the ALU on arithmetic and compare commands, and the shifted off end bit in shift commands. The Memory Link (ML) is used when the M or N Registers are selected as the destination register; otherwise the Arithmetic Link (AL) is used. The two link bits permit intermixed memory address and data arithmetic operations.

# T Register

The T Register is a transient working register used to hold operands for the ALU, receive data from memory, write data to memory and output data to external units. The T Register is backed up by the MD and OD Registers which buffer data being written in memory and output respectively. The purpose of these two buffers is to free the T Register for other operations during the relatively lengthly write and output operations. The T Register, and sometimes its complement constitute selectable operands on the B Bus. If the T Register is not selected in those commands which have that option the operand on the B Bus will be zero. If both the true and complement of the contents of the T Register are selected, the operand is all 1's. Data read from memory is set into the T Register two clock intervals after the read is initiated. Commands which select T Register as the source of operand during the first two clocks of the read operation are delayed until the third clock.

#### **REGISTER 0 FLAGS AND INTERNAL STATUS**

#### Register 0 Flags

Register 0 which is common to both the primary and secondary files contains a set of flags which reflect the result of a previous operation and external conditions which require frequent testing. The flags in bits 0-2 are the result condition flags and are updated when the C modifier (bit 4) of the operate instructions is a one. A description of the Register 0 flags follows:

- Overflow Condition: The overflow condition flag stores the overflow condition of an Add, Increment, Subtract, Decrement, or Copy command. Arithmetic overflow occurs when carry out of the high-order bit of the adder differs from the carry into it. The over-flow also stores the shifted off end bit of shift commands.
- 1 Negative Condition: The negative condition flag stores the high-order bit of the result. When overflow occurs this flag will be the complement of the true sign.
- 2 Zero Condition: The zero condition flag stores the zero condition of the result. The zero test can be linked over multiple byte operations under control of the L modifier (bit 7) of operate instructions. When this bit is 1, the zero condition flag may not be set to indicate the zero condition of the current byte, but may only be reset to indicate a non-zero result. For this flag to indicate zero over multiple bytes it must be set by a zero result on the first operation which will have the L modifier zero and not be reset by non-zero conditions on succeeding bytes which will have the L modifier a one.
- 3 I/O Request: The I/O request flag is turned on by one or more external I/O units requesting an I/O operation.
- 4 Internal Interrupt: The internal interrupt flag is turned on when an internal interrupt condition is present. The internal interrupt is identified in the internal status (Table 1).

Table 1. Internal Status

| Bit | Status Meaning                 |  |  |  |  |  |  |
|-----|--------------------------------|--|--|--|--|--|--|
| 0   | Panel Interrupt                |  |  |  |  |  |  |
| 1   | DMA Termination                |  |  |  |  |  |  |
| 2   | Real Time Clock Interrupt      |  |  |  |  |  |  |
| 3   | Spare                          |  |  |  |  |  |  |
| 4   | Spare                          |  |  |  |  |  |  |
| 5   | Spare                          |  |  |  |  |  |  |
| 6   | Panel Step Switch              |  |  |  |  |  |  |
| 7   | Power fail (Restart Interrupt) |  |  |  |  |  |  |

- 5 I/O Reply: The I/O reply flag is turned on by the external I/O unit currently communicating with the processor. This flag is normally not used in MICRO 1600 I/O units.
- 6 Serial TTY or Stack Overflow: The serial teletype input flag indicates the state of the serial teletype input. A zero indicates that the input is in a MARK state. This flag is used for MICRO 800 compatibility. The stack overflow flag is turned on when the L Save Stack has overflowed.
- 7 External Interrupt: The external interrupt flag is turned on by one or more external I/O units requesting an interrupt. This flag must result in a command which reads the address of the interrupt vector and resets the request.

#### Internal Status

The internal status reflects the state of the internal interrupts. When any of these functions is requesting an interrupt, bit 4 of the register 0 flag is turned on. Most of the internal interrupt status signals are turned off when the status is read. The status can be read by an Enter Internal Status command. The assignment of the internal status bits is as shown in Table 1.

#### CONTROL

The sequential control of the processor is obtained from a microprogram stored in a 16-bit control memory. Each word accessed from the control memory is placed in the R Register where it directly controls selection of operands, ALU function, register enables and the determination of the next control memory location. In effect the contents of control memory control the action of the processor at each clock. Because the Micro 1600 is a microprogrammed type of computer there is a minimal amount of command decoding and each command is executed in a single clock period, unless there is a delay imposed by the memory.

# Control Memory

The control memory is a 16-bit high-speed memory implemented with semiconductor read-only memory (ROM) devices, or read-write memory providing an alterable control memory (ACM). The standard MICRO 1600 can be expanded to 4096 words of control memory. Control memory can be added in 256 word pages. An option allows expansion to 32,768 words of control. The control memory can be randomly accessed with an access time, including logic delays of less than 200 nanoseconds.

The execution of commands and the accessing of the control memory are overlapped. While one command is in the R Register being executed the next command in sequence is being accessed and the L Register has been incremented to the address of the command being accessed. When the normal sequence is altered by a jump a delay of 200 nanoseconds takes place to allow reading of the first command at the start of a new sequence.

Two types of ROM devices are used for control memory. The first has the ones and zeros pattern of the microprogram built into the device by a special masking used in the manufacturing process. These devices are used for standard Microdata firmware. The other type is a similar ROM device, but can be programmed after device manufacturing by selectively burning out fuses corresponding to the bits of the desired program. This type of device is commonly called a programmable read-only memory (PROM) and costs considerably more than the masked ROM. Each board of control memory can accommodate up to 2048 words in 256-word increments.

The ACM provides for a dynamically alterable control memory. This type of memory is very useful when debugging firmware. The memory initially is treated as an external unit on the I/O bus when it is loaded and then treated as an extension of the control memory in the processor. ACM modules may contain up to 1024 words. Use of ACM modules in the system require additional cooling and +5-volt power supply current. Each 256 words of ACM requires approximately 2.0 ampere.

# L Save Stack and Extended Addressing Option

The L Save Register can be expanded to 16 15-bit L Save Registers by means of a stack option permitting multilevel subroutines. When this option is included the L Save Register in the processor is disabled. Along with this feature is a 2-bit Bank Select Register permitting the full 16,386 words of control memory to be addressed. The 2-bits of the Bank Select Register are controlled by the Bank Select command which must be followed by a Jump Extended. Associated with the L Save Stack registers is a 4-bit stack pointer which points to the next available stack register. Incrementing and decrementing of this pointer is done by command. It is reset to register zero on power-up and with the panel reset switch. This stack and extended addressing option is included with a 2048-word control memory module. Only one stack may be used in a system.

### **Timing**

The processor is controlled by a 10 MHz crystal oscillator which is divided by two to produce a 5 MHz clock. This frequency may be reduced if desired. However, all timing will be delayed including timing delays which may be coded in the program.

#### MEMORY

# Memory Interface

The memory modules receive their address over a set of 16 address lines on the printed circuit backplane. This address is derived from the M and N Registers of the processor or the Direct Memory Access (DMA) option. A set of eight data lines on the backplane provides for transfer of data between the memory and processor or between the memory and DMA. Data read from the memory under control of the processor is transferred to the processor's T Register which is cleared one clock time after the start of the memory read operation. Data to be written into the memory is placed on the data lines by the processor's MD Register which receives its input from the T Register.

#### Memory Modules

The standard memory is a 4096 or 8192-byte core memory module built on a single printed circuit board. The memories make use of lithium cores for operation over a wide temperature range. The memories may be operated in either a full or half cycle mode. Full cycle operation provides for a read-restore or clear-write type of operation with the program initiating only one operation. The half cycle operation allows the read and write operations to be programmed separately. This is normally used to effect a read-modify-write type of operation. After performing a half cycle read the addressed location is left in an all ones state.

#### Memory Addressing

Addressing is available to a maximum of 65,536 bytes. Normally the high-order address line is disabled and forced to zero limiting addressing to 32,768 bytes. This is done because standard Microdata macro computer configurations use the high-order bit of address words for indexing control, leaving only 15 bits for address. Full 16 bits of address may be used for special applications. Core memory modules of different sizes may be intermixed within a system. However, only one 4096-byte module can be used in conjunction with one or more 8192-byte modules.

# **Memory Timing**

The memory cycle time is 1.0 microseconds with an access time of 400 nanoseconds until data is in the T Register. The half cycle time is 600 nanoseconds with an access time of 400 nanoseconds. Execution of commands which specify that the M or N Register are to receive data is delayed if the memory is busy. These commands are executed on the last clock of the cycle, i.e., the fifth clock on a full cycle operation and the third clock on a half cycle operation. Operate commands which select the contents of the T Register are not executed at the first or second clock following the initiation of a read operation. This allows the accessed data to be placed in the T Register before the command is executed. Two exceptions to this imposed delay occur when either an OR, Exclusive OR, or AND command selects both the T Register and its complement or when a command selects either the T Register or its complement with the input buss enabled. For these operations the command will execute in one machine cycle and the memory data will be loaded into the T Register as previously specified.

# Direct Memory Access (DMA)

A Direct Memory Access (DMA) channel allows external devices to directly communicate with memory at data transfer rates up to 1 million bytes/second.

# **POWER FAIL - AUTO RESTART**

Standard with the MICRO 1600 is a feature which provides for detection of loss of AC power and an orderly startup when power is turned on. Both power fail and restart are indicated by a 1 in bit 7 of the internal status, which in turn turns on the Internal Interrupt flag of file register 0.

#### Power Fail

The standard power supplies are equipped with circuitry for detecting low AC line voltage. When low AC line is detected the Internal Status bit 7 is turned on. The microprogram must periodically test for internal interrupts. After the low line is detected the power supply will hold all voltages within operating range for a minimum of one millisecond. After sensing the power fail interrupt the microprogram should save all volatile registers containing valid data in core memory and bring the processor to a halt. When the processor halts a reset is applied to the system to provide for an orderly loss of power.

#### Restart

When power is applied a reset is applied to the system until the power supply voltages stabilize at their operating values. This reset initializes the system, sets the L Register to zero, sets internal status bit 7 and prevents accidental operation of the core memory. The microprogram can distinguish the restart from the power fail by testing internal status bit 7 soon after starting execution when the reset is removed. This test should not be used later when there is a chance that the status bit will reflect power fail.

#### **CHAPTER 3**

# MICROCOMMAND REPERTOIRE

This chapter contains a description of all MICRO 1600 microcommands. With each description is a diagram showing the format of the command and its operation code given in hexadecimal. Above the diagram is the command's mnemonic and the name of the command. Under each diagram is a description of the command, followed by a list of the registers and indicators that can be affected by the command. The timing of each command is 200 nanoseconds except as noted, or if memory timing delays described in Chapter 2 are encountered.

#### COMMAND FORMATS

There are five basic command formats. Each command is 16 bits in length and is stored in a single control memory location.

#### **Literal Commands**

The literal classes of commands have the following formats:



The operation code occupies the four high-order bits. Bits 11-8 contain the file register designator. Bits 7-0 contain an eight-bit literal which is transferred as an operand.



The operation code occupies the eight high-order bits. Bits 7-0 contain an eight-bit literal which is transferred as an operand.



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

The operation code occupies the four high-order bits. Bits 11-0 contain a 12-bit literal which is transferred as a control memory address. (This format is used for Jump Extended only.)

# **Operate Commands**

The operate class of commands have the following format:



The operation code occupies the four high-order bits. Bits 11-8 contain the file register designator (f). Bits 7-4 contain the control (C) field designator.

# C-Field Designators

| C-Field Bit Position | Designator | <u>Definition</u>     |  |  |  |  |  |
|----------------------|------------|-----------------------|--|--|--|--|--|
| 1000                 | L          | Link control/Add Link |  |  |  |  |  |
| 0001                 | С          | Modify Cond. Codes    |  |  |  |  |  |
| 0010                 | T          | Select T              |  |  |  |  |  |
| 0100                 | . <b>F</b> | Select T Complement   |  |  |  |  |  |
| 0100                 | 1          | Add 1/Increment       |  |  |  |  |  |
| 0100                 | D          | Decrement             |  |  |  |  |  |

Bit 3 is file inhibit. When bit 3 is set to a one the resultant operation of the command is inhibited from being transferred to the designated file. Symbolically, this is specified to the assembler programs by appending an to the command mnemonic. The destination register (r) is specified in the three low-order bits, 2-0. When the designator is L or K the command requires 400 nanoseconds to execute.

# r Field Destination Register Designators

| Bit Configuration | Designator | Register Designated               |
|-------------------|------------|-----------------------------------|
| 000               |            | None                              |
| 001               | Т          | T Register                        |
| 010               | M          | M Register                        |
| 011               | N          | N Register                        |
| 100               | · L        | L Register (adds 200 nanoseconds) |
| 101               | K          | K Register (adds 200 nanoseconds) |
| 110               | · U        | U Register                        |
| 111               | S          | U Register ORed into upper        |
| •                 |            | 8 bits of commands with           |
|                   |            | OP codes 8 through F.             |

#### Generic Commands

The generic class of commands have the following Formats:



The operation code occupies all 16 bits of the microcommand.

#### JE



The contents of the 12-bit address field are placed in the L Register. If an inhibit L Register Save command has not been executed since the last Jump Extended, the following operation will also take place. The old contents of the L Register are stored in the L Save Register, or when the L Save Stack option is present, the L Register is stored in the 12 low-order bits of the current stack level, and the contents of the control memory bank Select Register is stored in the upper three bits of the current stack level. A Jump Extended command requires 400 nanoseconds to execute.

This command permits jumping anywhere within 4096 words of control memory in the basic machine. When the L Save Stack and extended control memory option is included, this command controls jumping anywhere within the current selected 4096-word bank of control memory. To jump from one bank of control memory to another, a Bank Select command (BSL) is executed followed by a Jump Extended command to the desired location in the selected 4096-word bank of control memory.

The Jump Extended command is assigned an operation code of 0 and is a special form of the Execute command which OR's the contents of the U Register into the eight high-order bits of the command. In order to obtain an operation code of 0 in the R Register, the four high-order bits of the U Register must be set to zero. If desired the four low-order bits of the U Register may be used to set bits 8-11 of the L Register; otherwise they should also be set to zero.

# LZ LOAD ZERO CONTROL



The load zero control command's eight-bit literal field is used to specify combined operations of the load zero group of generic instructions. If the literal field is 00 no operation (NOP) occurs. When multiple bits are specified, the designated control functions will execute.

This single command in a "vertical" sequence of microprogramming, contains "horizontal" microprogramming characteristics with the ability to perform multiple operations in a single 200 nanosecond clock interval.

#### Load Zero Literal Field

| Bit Configuration | Code | Mnemonic — Operation                         |
|-------------------|------|----------------------------------------------|
| 0000 0000         | 00   | NOP - No Operation                           |
| 0000 0001         | 01   | ECR — Enable Communication Rate Generators   |
| 0000.0010         | 02   | DCR — Disable Communication Rate Generators  |
| 0000 0100         | 04   | ICR — Input Communication Rate<br>Generators |
| 0000 1000         | 08   | Unassigned                                   |
| 0001 0000         | 10 ` | Unassigned                                   |
| 0010 0000         | 20   | RTN - Return                                 |
| 0100 0000         | 40   | SPF — Select Primary Files                   |
| 1000 0000         | 80   | SSF — Select Secondary Files                 |

Example: LZ 62 combines the three operations — DCR (disable rates), RTN (return) and SPF (SELECT primary files).

Note: If two commands with opposite functions are executed the existing state is changed to the opposite. Example: LZ 03 defines both enable and disable communication rate generators. When this command is executed the status of the communication rate generator control is complemented. If it was on, it is turned off. If it was off, it is turned on.

# NOP NO OPERATION 1000 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

This command performs no operation and can be used to insert a delay of 200 nanoseconds.

# ECR ENABLE COMMUNICATION RATE GENERATORS 1001 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

The optional communication rate generators are enabled. These four hardware strappable time interval counters may be used for input bit sampling and output bit updating by microprograms performing serial to parallel and parallel to serial conversions.

#### DCR DISABLE COMMUNICATION RATE GENERATORS

1002

The optional communication rate generators are disabled.

#### ICR INPUT COMMUNICATION RATE GENERATORS

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

If the communication rate generators are enabled, and one or more rate is requesting service; bit 5 of the internal status byte will be set to a one and file zero, bit 3 will be set to a 1 indicating the presence of an internal interrupt.

This command allows the four communication rate generator flags to be read and reset by following it immediately with an Enter Internal Status (EIS) command. Bits 5-2 of this status byte will contain the current state of the four rate generators, and bits 7, 6, 1, and 0 should be ignored. The state of the internal status byte is not affected by this two command sequence.

#### RTN RETURN

1020

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

The contents of the L Save Register are placed in the L Register or when the L Save Stack option is present, the low-order 12 bits of the current stack level are placed in the L Register and the high-order three bits of the current stack level are placed in the control memory bank select register. Execution requires 600 nanoseconds and the Inhibit L Save mode is cleared, if set, causing further Jump Extended commands to save the current contents of the L Register.

#### SPF SELECT PRIMARY FILE

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

This command causes the primary file of registers to be selected for further file register operations. The primary file is also selected after a power on or by pressing master reset on the front panel.

#### RSP RETURN AND SELECT PRIMARY FILE

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

This command combines the functions of Return (RTN), and Select Primary File (SPF), and executes in 600 nanoseconds.

#### SSF SELECT SECONDARY FILE

1080

This command causes the secondary file of registers to be selected for further file register operations. This set will remain selected until execution of a Select Primary File command, or the occurrence of a master reset.

# RSS RETURN AND SELECT SECONDARY FILE



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

This command combines the functions of Return (RTN), and Select Secondary File (SSF), and executes in 600 nanoseconds.

The following commands provide for loading eight-bit literals into registers.

#### LT LOAD T



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

The contents of the eight-bit literal field are placed in the T Register. The condition flags and LINK are not affected.

# LM LOAD M



The contents of the eight-bit literal field are placed in the M Register at a time when the memory is not busy. The condition flags and LINK are not affected.



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

The contents of the eight-bit literal field are placed in the N Register and the M Register is cleared at a time when the memory is not busy. The condition flags and LINK are not affected.



The contents of the eight-bit address field are placed in the eight low-order bits of the L Register, bits 8 and 11 of the command are placed in bits 8 and 9 of the L Register respectively. Bits 10 through 12 of the L Register and the optional control memory bank select register remain unchanged. The location of the next command is the address specified by the new contents of the L Register. These jump commands provide for jumping within a four-page block of 1024 words whose starting address is zero modulo 1024. The assembler program selects the proper command code from the address which must be in the 1024-word block containing the command. The command executes in 400 nanoseconds.



The contents of the eight-bit literal field are placed in the U Register. The condition flags and LINK are not affected. Due to look-a-head access method of the control memory, the new contents of the U Register are not available for command modification during the machine cycle immediately following the Load U command.

#### LS LOAD SEVEN CONTROL

| 17                    | Literal  |
|-----------------------|----------|
| 15 14 13 12 11 10 9 8 | 76543210 |

The individual bits of the literal field control independent functions. Any number of bits in the literal field may be one's. A number of the control functions are given mnemonics and are described later in this section. The function of each bit is as follows:

| Bit<br>Position                      | <u>Function</u>                                                                                                                                                                                             |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7 | (unassigned and unavailable) (unassigned and unavailable) Disable External Interrupts Enable External Interrupts Disable Real Time Clock Enable Real Time Clock (unassigned and unavailable) Halt Processor |

#### DEI DISABLE EXTERNAL INTERRUPTS

|         |         |    |   | 17 | 04 | ļ |   |   |   |   |   |   |
|---------|---------|----|---|----|----|---|---|---|---|---|---|---|
| 15 14 1 | 3 12 11 | 10 | 9 | 8  | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

This command causes the external interrupt system to be disabled. Interrupts are not lost when the interrupt system is disabled, but cannot be recognized by the processor.

#### EEI ENABLE EXTERNAL INTERRUPTS



The external interrupt system is enabled allowing the processor to recognize external interrupts.

#### DRT DISABLE REAL-TIME CLOCK

| f        |          |   |    |    |   |   |   |   | _ |   | $\neg$ |
|----------|----------|---|----|----|---|---|---|---|---|---|--------|
|          |          |   | 17 | 10 | ) |   |   |   |   |   |        |
| 15 14 13 | 12 11 10 | 9 | 8  | 7  | 6 | 5 | 4 | 3 | , | 1 | ᅮ      |

The real-time clock and interrupt are disabled.

#### ERT ENABLE REAL-TIME CLOCK

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

The real-time clock and interrupt are enabled. The first interrupt will occur after a full interrupt interval.



The processor is halted stopping all microcommand execution. However, the Direct Memory Access channel, if activated, will continue its operation until completion.

# LE LOAD EIGHT CONTROL

| 18                    | Literal  |
|-----------------------|----------|
| 15 14 13 13 11 10 0 P | 76542210 |

This command is not implemented in the standard MICRO 1600. It can be defined for special user applications employing techniques similar to those used in Load Zero Control Group and Load Seven Control Group.

# RLT RETURN AND LOAD T

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

This command combines the functions of Return (RTN), and Load T (LT) and executes in 600 nanoseconds.

#### MLC MODIFY LOWER COMMAND



This command causes the contents of the Output Data Buffer to be ANDed with 8 low-order bits of the next command accessed from the control memory. If the IC Register is set to 0, the contents of the Output

Data Buffer will be the same as the T Register. If the IC Register is not set to 0, the Output Data Buffer will contain the value that was in the T Register at the time the IC Register was set non-zero.



This command inhibits the saving of the L Register in the L Save Register or the Bank Select Register and the L Register in the current level of the L Save stack until execution of a Return command.



The contents of the four-bit stack pointer register are incremented by one to select the next level in the stack for saving the contents of the L Register during the next Jump Extended. If the modified contents of the register are greater than 15, bit 6 in file 0 will be set; otherwise it will be reset.



The contents of the four-bit stack pointer register are decremented by one to select the previous level in the stack for a return operation. If the modified contents of the register are less than zero, bit 6 in file 0 will be set; otherwise it will be reset.

#### CSP CLEAR STACK POINTER (optional)

1B04

The contents of the four bit stack pointer register are set to zero.

#### BSL BANK SELECT (optional)

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

The bank select register is set to zero selecting the first 4096-word bank of control memory. The actual selection of the new bank takes place when the next Jump Extended command is executed. As shown below, variations of this command are used to select up to four individual banks.

| BSL 0 | 1B08  | Select bank 0 | (0-4095)        |
|-------|-------|---------------|-----------------|
| BSL 1 | 1B 09 | Select bank 1 | (4096-8191)     |
| BSL 2 | 1B 0A | Select bank 2 | (8192-12,287)   |
| BSL 3 | 1B 0B | Select bank 3 | (12,288-16,383) |

# SSP SELECT STACK POINTER (optional)

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

This command causes loading and reading of the four-bit Stack Pointer Register. Execution of this command with the IC Register cleared causes the contents of the four low-order bits of the T Register to be placed in the stack pointer. Execution of this command following a stack input command places the contents of the stack pointer on the four low-order bits of the input bus.

#### SSU SELECT STACK UPPER (optional)

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

This command causes loading and reading of the upper seven bits of the selected L Save Stack register. Execution of this command with the IC Register cleared causes the contents of the T Register to be placed in the upper seven bits of the current L Save Stack level. Execution of the command following a stack input command places the contents of the upper seven bits of the current L Save Stack level on the input bus.

# SSL SELECT STACK LOWER (optional)



This command causes loading and reading of the lower eight bits of the selected L Save Stack register. Execution of this command with the IC Register cleared causes the contents of the T Register to be placed in the lower eight bits of the current L Save Stack level. Execution of the command following a stack input command places the contents of the lower eight bits of the current L Save Stack Level on the input bus.

# LF LOAD FILE REGISTER



The contents of the eight-bit literal field are placed in the file register designated by f. Since file register 0 is not used for general storage, it is not to be loaded by this command. The condition flags and LINK are not affected.

# AF ADD TO FILE REGISTER

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

The contents of the eight-bit literal field are added to the contents of the file register designated by f. Since file register 0 is not used for general storage, it is not altered by this command. Two's complement subtraction may be performed by placing the two's complement of the operand in the literal field. The condition flags and LINK are not affected.

The following three test commands provide for arithmetic comparison and logical testing of bits. When the compare or test condition is met the next command in sequence is treated as a no operation, and there is a delay of 200 nanoseconds before executing the next command.



If, for all the one bits of the literal field, the corresponding bits of the file register designated by f are zero, the next command is not executed. This command performs the logical product of the literal and the contents of the file register and tests for zero result. The condition flags, LINK and designated file register are not affected.

#### TN TEST IF NOT ZERO



If, for any one bit in the literal field, the corresponding bit of the file register designated by f is also a one, the next command is not executed. This command performs a logical product of the literal and the contents of file register and tests for not zero. The condition flags, LINK and designated file register are not affected.



If the sum of the contents of the literal field and the file register designated by f is greater than 255, the next command is not executed. The condition flags and designated file register are not affected. The LINK stores the carry out of the adder. This means that if the skip is not taken, the content of LINK will be a 0, or if the skip is taken, the content of LINK will be set to a 1.

All forms of command seven unconditionally update the arithmetic condition codes in file 0, but do not affect the LINK. A destination of seven is undefined for these commands. In other words, the U Register may not be used to modify the command. All permissible variations of the basic command seven are explained. Unlisted c field values, (bits 7-4), are not assigned assembler mnemonics and will not be executed by the simulator.

The following four commands provide special data flow operations.



The status of the four console sense switches, with four low-order one bits appended, are placed in the file register designated by f, if \* is zero, and in the register designated by r. The status of a switch is a one, when the switch is set.



The four high-order bits of the file register designated by f are placed in the four low-order bits of that file, if \* is zero, and in four low-order bits of the register designated by r. The four high order bits of the result are set to ones.



The eight internal status bits are placed in the file register designated by f, if \* is zero, and in the register designated by r. The internal interrupt flag in file 0 is reset by this command, along with the console interrupt, real time clock, and power fail/restart status bits. Console step is reset upon release of the console switch and spare bits are controlled according to their individual implementation in hardware.

**ECS** 

#### **ENTER CONSOLE SWITCHES**

7070

The contents of the eight low-order console command switches are ANDed with the eight low-order bits of the next command. The value of a switch is a one, when the switch is set. If the switch is either not set, or, as in the case of a basic panel, not there, its value is a zero. File register 0 and destination register 0 must be selected because data movement is not permitted.

The command could be used to implement eight additional sense switches. This is done by following the Enter Console Switches command with a Load Register or Load File command that has a literal value of all ones.

The next eight command descriptions explain control of the input/output buss for standard Microdata peripheral controllers. If a system is to contain only special controllers, these signals could be assigned any desired function subject to the following rule. Whenever the value in the I/O Control Register (IC), is set to four, five, six, or seven, the input buss is enabled in the CPU. This means that the input buss will be substituted for the T Register by any command that selects the T Register or its complement.



A value of 0 is placed in the I/O Control Register (IC), which removes all control signals from the I/O buss. This places the buss in the no activity mode. All standard Microdata peripheral controllers require the K Register to return to the zero state after each non-zero setting. When the current contents of the IC Register is 0, 1, 2, or 3, the file register designated by f is moved to the register designated by r. When the current contents of the IC Register is 4, 5, 6, or 7, the contents of the input buss are ANDed with the file register designated by f. The result is placed in the file register, if \* is zero, and in the register designated by r.



A value of 1 is placed in the IC Register which enables the control output signal until removed by a Clear I/O command. The contents of the file register designated by f are moved to the register designated by r.



A value of 2 is placed in the IC Register which enables the data output signal until removed by a Clear I/O command. The contents of the file register designated by f are moved to the register designated by r.

#### SOX SPARE OUTPUT



A value of 3 is placed in the IC Register which enables the spare output signal until removed by a Clear I/O command. This command also removes the MARKing current from the serial I/O channel causing a SPACEing condition. The contents of the file register designated by f are moved to the register designated by r.

# CAK CONCURRENT ACKNOWLEDGE



A value of 4 is placed in the IC Register which enables the concurrent acknowledge signal until removed by a Clear I/O command. Upon removal of this signal, the requesting controller will reset the concurrent request flag bit in file 0. The contents of the file register designated by f are moved to the register designated by r.

# IAK INTERRUPT ACKNOWLEDGE



A value of 5 is placed in the IC Register which enables the interrupt acknowledge signal until removed by a Clear I/O command. Upon removal of this signal, the requesting controller will reset the external interrupt request flag bit in file 0. The contents of the file register designated by f are moved to the register designated by r.

# DIX DATA INPUT



A value of 6 is placed in the IC Register which enables the data input signal until removed by a Clear I/O command. The contents of the file register designated by f are moved to the register designated by r.

# SIX

STACK INPUT



A value of 7 is placed in the IC Register which enables the stack input signal until removed by a Clear I/O command. If the L Save stack is not in the machine, this signal may be used as a spare input.

The following commands operate on a specified file register. In addition some other operation such as input or memory control may take place. Some commands in this section are adaptations of others. For example, the Increment command is a form of the Add command. These adaptations are provided with their own mnemonics because of their frequent use and to simplify programming.



The sum of the contents of the file register designated by f and the selected operand is formed. The sum is placed in the file register if \* is zero and in the register designated by r. The state of the carry out of the high-order bit position of the adder is placed in LINK. The five Modifier bits perform the following control:

- L Link Control: The content of LINK is added to the sum. When
  this flag is a one the zero condition flag can be reset but not
  set. This allows for propagation of the zero test over multiple
  byte operations, the first of which would have this bit off.
- 1 Increment: One is added to the sum.
- T Select T: The contents of the T Register or the input bus is selected as the B-bus operand. If this bit is off the operand is zero.
- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The result is not placed in the file register.

# 

This command is a form of the Add command. The contents of the file register designated by f are incremented and the result is placed in the file register if \* is zero and in the register designated by r. The state of the carry out of the high-order bit position of the adder is placed in LINK. The two modifier bits perform the following control:

- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The result is not placed in the file register.

SUBTRACT (Two's complement)

SBT



The two's complement difference of the contents of the file register designated by f and the selected operand is formed. The difference is placed in the file register if \* is zero and in the register designated by r. The state of the carry out of the high-order bit position of the adder is placed in LINK. The four modifier bits perform the following control:

- L Link Control: The content of LINK is added to the one's complement difference. When this flag is a one the zero condition flag can be reset but not set. This allows for propagation of the zero test over multiple byte operations, the first of which would have this bit off.
- T Select T: The contents of the T Register or the Input Bus is selected as the B Bus operand. If this bit is off the operand is zero.
- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The result is not placed in the file register.

# SBO SUBTRACT (One's complement)



The one's complement difference of the contents of the file register designated by f and the selected operand is formed. The difference is placed in the file register if \* is zero and in the register designated by r. The state of the carry out of the high-order bit position of the adder is placed in LINK. The four modifier bits perform the following control:

- L Link Control: The content of LINK is added to the difference.
   When this flag is one the zero condition flag can be reset but not set. This allows for propagation of the zero test over multiple byte operations, the first of which would have this bit off.
- T Select T: The contents of the T Register or the Input Bus is selected as the B Bus operand. If this bit is off the operand is zero.
- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The result is not placed in the File register.

#### DEC DECREMENT



The contents of the file register designated by f is decremented by one and the result is placed in the file register if \* is zero and in the register designated by r. The state of the carry out of the high-order bit position of the adder is placed in LINK. The two modifier bits perform the following control:

- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The result is not placed in the file register.

# RMF READ MEMORY, FULL CYCLE



The contents of the file register designated by f in unaltered, incremented or decremented form as determined by m, is placed in the file register if \* is zero and in the register designated by r. The condition flags and LINK are not affected. Subsequently a full cycle memory read is initiated at the location specified by the contents of the M and N Registers. Command execution is delayed if the memory is busy when the command is accessed. The T register is set to zero and the accessed data is placed into it 400 nanoseconds after the command is executed. The addressed memory location is left unaltered.

The contents of the file register are modified as follows:

<u>m</u>

- No flag 00 The contents of the selected file register are transferred unaltered to the specified destination register.
  - D 01 Decremented: The contents of the file register minus 1 are routed as specified unless the M register is specified to receive the result. When the M register is selected the contents of the file register, minus 1, plus the content of LINK are routed.
  - L 10 Add Link: The content of LINK is added to the contents of the file register and the sum is routed as specified.
  - 1 11 Increment: The contents of the file register is incremented by 1 and the result is routed as specified.

#### RMH RE

#### READ MEMORY, HALF CYCLE



The contents of the file register designated by f in unaltered, incremented or decremented form as determined by m, is placed in the file register if \* is zero and in the register designated by r. The condition flags and LINK are not affected. Subsequently a half cycle memory read is initiated at the location specified by the contents of the M and N Registers. Command execution is delayed if the memory is busy when the command is accessed. The T register is set to zero and the accessed data is placed into it 400 nanoseconds after the command is executed. The memory location is left in an all one's condition.

The contents of the file register are modified as follows:

<u>m</u>

- No flag 00 The contents of the selected file register are transferred unaltered to the specified destination register.
  - D 01 Decremented: The contents of the file register minus 1 are routed as specified unless the M Register is specified to receive the result. When the M Register is selected the contents of the file register, minus 1, plus the content of LINK are routed.
  - L 10- Add Link: The content of LINK is added to the contents of the file register and the sum is routed as specified.
  - I 11 Increment: The contents of the file register is incremented by one and the result is routed as specified.

#### WMF

#### WRITE MEMORY, FULL CYCLE



The contents of the file register designated by f in unaltered, incremented or decremented form as determined by m is placed in the file register if \* is zero and in the register designated by r. The condition flags and LINK are not affected. Subsequently a full cycle memory write operation is initiated at the location specified by the contents of the M and N Registers. Command execution is delayed if the memory is busy when the command is accessed.

The data to be written must be in the T Register at the time the command is executed, or must be entered into the T Register with the next command. The T Register may be used for other uses with the second command after the WMF.

The contents of the file register are modified as follows:

m

- No flag 00 The contents of the selected file register are transferred unaltered to the specified destination register.
  - D 01 Decremented: The contents of the file register minus 1 are routed as specified unless the M Register is specified to receive the result. When the M Register is selected the contents of the file register, minus 1, plus the content of LINK are routed.
  - L 10 Add Link: The content of LINK is added to the contents of the file register and the sum is routed as specified.
  - 1 11 Increment: The contents of the file register is incremented by one and the result is routed as specified.

#### WMH WRITE MEMORY, HALF CYCLE



The contents of the file register designated by f in unaltered, incremented or decremented form as determined by m is placed in the file register if \* is zero and in the register designated by r. The condition flags and LINK are not affected. Subsequently a half cycle memory write operation is initiated at the location specified by the contents of the M and N Registers. Command execution is delayed if the memory is busy when the command is accessed. The data to be written must be in the T Register when the command is executed. The contents of the addressed memory location must be all one bits for a proper write to take place, because there will be an ANDing of the original contents of the memory location and the contents of the T Register. The T Register may be used for other purposes with the first command after WMH.

The contents of the file register are modified as follows:

<u>m</u>

- No flag 00 The contents of the selected file register are transferred unaltered to the specified destination register.
  - D 01 Decremented: The contents of the file register minus 1 are routed as specified unless the M Register is specified to receive the result. When the M Register is selected the contents of the file register, minus 1, plus the content of LINK are routed.
  - L 10 Add Link: The content of LINK is added to the contents of the file register and the sum is routed as specified.
  - 11 Increment: The contents of the file register are incremented by one and the result is routed as specified.

#### CPY COPY



The selected operand is placed in the file register designated by f if \* is zero and in the register designated by r. The LINK is not affected. The 5 modifier bits perform the following control:

- L Link Control: The content of LINK is added to the operand.
   When this bit is a one the zero condition flag can be reset but not set. This allows for propagation of the zero test over multiple byte operations, the first of which would have this bit off.
- I Increment: One is added to the operand.
- T Select T: The contents of the T Register or the input bus is selected as the B Bus operand. If this bit is zero the operand is zero.
- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The result is not placed in the file register.

### ZOF ZERO FILE



A value of zero is placed in the file register designated by f if \* is zero and in the register designated by r. The LINK is not affected. The two modifier bits perform the following control:

- C Condition Flag Update: The condition flags are updated according to the zero data.
- \* File Write Inhibit: The zero is not placed in the file register.

#### POF PLUS ONE TO FILE



A value of plus one is placed in the file register designated by f if \* is zero and in the register designated by r. The LINK is not affected. The two modifier bits prefer the following control:

- C Condition Flag Update: The condition flags are cleared.
- \* File Write Inhibit: The plus one is not placed in the file register.

#### LOR LOGICAL OR



The logical inclusive-OR of the contents of the file register designated by f and the selected operand is placed in the file register if \* is zero and the register designated by r. The LINK is not affected. The five modifier bits perform the following control:

- L Link Control: When this bit is a one the zero condition flag can be reset but not set. This allows for propagation of the zero test over multiple byte operations, the first of which would have this bit off.
- F Select T Complement: The one's complement of the contents of the T Register or input bus are selected as the B Bus operand.
   If the T Register is also selected the effective operand contains all one's.
- T Select T: The contents of the T Register or the Input Bus is selected as the B Bus operand. If both the T and F bits are off the selected operand is zero.
- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The result is not placed in the file register.

#### MOV MOVE



The contents of the file register designated by f are moved to the register designated by r. The LINK is not affected. The three modifier bits perform the following control:

- L Link Control: When this bit is a one the zero condition flag can be reset but not set. This allows for propagation of the zero test over multiply byte operations, the first of which would have this bit off.
- C Condition Flag Update: The condition flags are updated according to the contents of the file register.
- \* File Write Inhibit: The result is not placed in the file register.

#### XOR EXCLUSIVE-OR



The exclusive-OR of the contents of the file register designated by f and the selected operand is placed in the file register if \* is zero and in the register designated by r. The LINK is not affected. The five modifier bits perform the following control:

- L Link Control: When this bit is a one the zero condition flag can be reset but not set. This allows for propagation of the zero test over multiple byte operations, the first of which would have this bit off.
- F Select T Complement: The one's complement of the contents of the T Register or Input Bus are selected as the B Bus operand.
   If the T Register is also selected the effective operand contains all one's.
- T Select T: The contents of the T Register or the Input Bus is selected as the B Bus operand. If both the T and F bits are off the selected operand is zero.
- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The result is not placed in the file register.

#### AND AND



The logical product (AND) of the contents of the file register designated by f and the selected operand is placed in the file register if \* is zero and in the register designated by r. The LINK is not affected. The five modifier bits perform the following control:

- L Link Control: When this bit is a one the zero condition flag can be reset but not set. This allows for propagation of the zero test over multiple byte operations, the first of which would have this bit off.
- F Select T Complement: The one's complement of the contents of the T Register or Input Bus are selected as the B Bus operand.
   If the T Register is also selected the effective operand contains all one's.
- T Select T: The contents of the T Register or the Input Bus is selected as the B Bus operand. If both the T and F bits are off the selected operand is zero.
- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The result is not placed in the file register.

## SFL SHIFT LEFT



The contents of the file register designated by f are shifted one bit position to the left and placed in the file register if \* is zero and the register designated by r. The high-order bit which is shifted out is placed in LINK. A zero or the content of LINK is shifted into the vacated bit position as determined by the L modifier bit. The three modifier bits perform the following controls:

- L Link Control: LINK content is shifted into low-order bit of result. When this bit is a one the zero condition flag can be reset but not set. This allows for propagation of zero test over multiple byte operations, the first of which would have this bit off.
- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The shifted register contents are not placed in the file register.

#### SLI SHIFT LEFT AND INSERT



The contents of the file register designated by f are shifted 1 bit position to the left and placed in the file register if \* is zero and the register designated by r. The high-order bit which is shifted out is placed in LINK. A one is inserted in the vacated low-order bit position. The two modifier bits perform the following control:

- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The shifted register contents are not placed in the file register.

## SFR SHIFT RIGHT



The contents of the file register designated by f are shifted one bit position to the right and placed in the file register if \* is zero and the register designated by r. A zero or the content of LINK is shifted into the vacated bit position as determined by the L modifier bit. The low-order bit which is shifted out is placed in LINK. The three modifier bits perform the following control:

- L Link Control: LINK content is shifted into low-order bit of result. When this bit is a one the zero condition flag can be reset but not set. This allows for propagation of zero test over multiple byte operations, the first of which would have this bit off.
- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The shifted register contents are not placed in the file register.

#### SRI

#### SHIFT RIGHT AND INSERT



The contents of the file register designated by f are shifted 1 bit position to the right and placed in the file register if \* is zero and the register designated by r. A one is inserted into the vacated high-order bit position. The low-order bit which is shifted out is placed in LINK. The two modifier bits perform the following control:

- C Condition Flag Update: The condition flags are updated according to the result of the current operation.
- \* File Write Inhibit: The shifted register contents are not placed in the file register.

The two Execute commands are special commands which cause the eight high-order bits of the U Register to be ORed with the eight high-order bits of control memory output. The ORing is performed before the command is gated into the R register. The actual command executed is a combination of the bits in the U Register and those read out of control memory. The Execute command is designated by zero in the four high-order bits of the command in control memory. An effective command with zeros in these bits is a Jump Extended. The 12 remaining bits of the Execute command can be coded as needed. The same effect as the Execute command can be obtained by coding destination register 7 on operate commands.

The Execute command is used for command modifications generally to save on the number of commands needed in a program. Three uses of this feature are:

- Indexing of file registers in a loop.
- Selection of alternate file register depending on program variables.
- Performing different functions such as load, add, subtract etc. in a common string of coding.

An example is shown below. The X'81' contents of the U Register merge with the execute command in control memory to form an Add to file register 5.

| U Register        | '81'   |
|-------------------|--------|
| Control Memory    | '0420' |
| Effective Command | '8520' |

## **EOT EXECUTE, OPERATE TYPE**

| 0           | f. |    | С |   | * | r |   |   |   |   |   |   |
|-------------|----|----|---|---|---|---|---|---|---|---|---|---|
| 15 14 13 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

The eight-bit contents of the U Register are ORed with the eight high-order bits of the command to form an effective command which is then executed. The f, C, \*, and r fields are used as described for the desired effective command. In coding the c-field bits any modifier may be used.

## ELT EXECUTE, LITERAL TYPE



The eight-bit contents of the U Register are ORed with the eight high-order bits of the command to form an effective command which is then executed. The f and Literal fields are used as described for the desired effective command.

## **CHAPTER 4**

## **CONTROL PANEL OPERATION**

The MICRO 1600 system console control panel (Figure 2) provides for control of the running of the processor, display of register contents and execution of commands. The panel is very useful in debugging microprograms and can also be used for macro level machine control and software debugging. The control panel can be replaced by a minimum basic console control panel which eliminates the display and manual command execution.

All console panels are pluggable and fully interchangeable without modification of the computer.

#### SYSTEM CONSOLE

The system console provides control plus a selectable display of all hardware registers in the machine including the files. It is designed for maintenance operations and for installations where system development and firmware checkout is being performed.



Figure 2. MICRO 1600 System Console

#### **DISPLAYS**

#### Data Display

The 16-bit data indicators (16 lamps on console) display the 8-bit A Bus, Memory Address, 16-bit Control Memory Output, or 12-bit Control Memory Address as selected by the Display Selector switches.

#### Run

The RUN indicator is on when the processor is running.

#### Halt

The HALT indicator is on when the power is applied and the processor is not running.

#### Lock

The LOCK indicator is on when the panel is disabled.

#### **Panel**

The PANEL indicator is on when the command switches are enabled and substituting for the control memory.

#### Scan

The SCAN indicator is on when in the SCAN mode. This takes place with the PANEL switch off and command switch 14 is on.

#### Address Stop

The ADST indicator is on when command switch 15 is in the down position indicating that the C - Address stop operation is enabled.

#### **SWITCHES**

## **Display Selector**

The four interlocked switches located in the upper right hand corner select one of the four displays as follows:

- D Data: This 8-bit display is the processor's A Bus. The data on the A bus when the processor is halted and in the panel enable mode depends on the setting of the command switches.
- M Memory Address: This 16-bit display is of the memory address lines. This is normally the contents of the M and N registers.
- Control Memory Address: This 12 display is the contents of the L Register.
- C Control Memory: This 16-bit display is of the output of the control memory. When the processor is halted the R Register contains the same data.

#### **Command Switches**

These 16 locking switches are substituted for the control memory when the PANEL switch is in the down position. When the processor is halted the switch setting is constantly clocked into the R Register and depressing the CLOCK switch causes the command set in the switches to be executed. The command may also be executed repeatedly by depressing the RUN switch. These switches are used to gate registers onto the A Bus for display and for entering data into registers.

#### Panel Switch

This locking switch selects the source of commands. When in the normal up position the control memory is used and when in the down position the 16 command switches on the panel are substituted for the control memory.

#### Sense Switches

The four locking sense switches are available on the control panel. These switches may be read by an Enter Sense Switch command.

#### Run

This momentary contact switch places the processor in the run mode causing it to execute microcommands.

## Step

This momentary contact switch places the processor in the run mode and as long as the switch is depressed causes an internal interrupt. The halt internal interrupt is bit 7 of the internal status. This switch is normally microprogrammed to cause a processor halt. Since the processor is forced to run when the switch is depressed, the machine can be microprogrammed to cause a single macro instruction to be executed.

#### Interrupt

This momentary contact switch places the processor in the run mode and causes an internal interrupt. The console interrupt is bit 0 of the internal status. This switch is normally microprogrammed to cause a console interrupt.

#### Clock

This momentary contact switch causes the processor to execute a single microcommand. If the processor is running at the time the switch is depressed, the processor will come to a forced halt following the current microcommand execution.

#### Reset

This momentary contact switch halts the processor and clears the L register, I/O control register and other control flip-flops. The reset is made available to I/O devices. Since the current microcommand execution will not be completed, the computer should not be stopped by this switch.

## On-Off-Lock

A three-position key lock switch applies power and disables the panel. The key can be removed in any position. In the QFF position AC power is turned off. In the ON position power is applied and the panel is active. In the LOCK position power remains on, but the panel switches are not active except for the sense switches.

#### **Control Memory Scan**

When the PANEL switch is off and command switch 14 is depressed the

processor is in a control memory scan mode and the SCAN indicator is turned on. This mode allows advancing the L Register without executing a command by depressing the CLOCK switch. In this manner the operator can sequentially step through control memory addresses and view its contents on the data display indicators.

## L-Address Stop

The processor can be stopped at a particular control memory L-address. Command switch 15 enables the L-address stop mode. The AST indicator is lighted as long as command switch 15 is actuated.

The twelve command switches (11 through 0) are set to the L-address at which a stop is desired and command switch 15 is depressed to enable the address stop. When the contents of the L-register are the same as the address set into the command switches, the address stop sequence is activated. The processor will halt at an L-address depending upon the following conditions:

- Selected L-address location contains micro command not requiring skips or jumps and the program executes this command, the processor halts at selected L-address plus one.
- Selected L-address location contains a skip type micro command (TZ, TN, CP) and micro program executes this command, the processor halts at selected L-address plus one when skip is not taken and will halt at selected L-address plus two when skip is taken.
- Selected L-address location contains a jump type micro command and the program executes this command, the processor halts at L-address specified by the address field of this command, or in case of return jump type, by contents of the L-Save register.
  - However, when the micro command preceding the jump type command is a skip type and the skip is taken, that is, jump type command is not executed; the processor halts at selected L-address plus one.
  - Selected L-address location contains Execute or Modify Lower Command (MLC) type micro command and micro program executes this command, the processor halts at selected L-address plus one without executing this command.
  - When selected L-address specifies location of micro command following an Execute or MLC command, this command is modified and executed. The processor then halts at L-address location which is dependent upon effective command derived from modification.

L-address stop will not operate if the selected L-address stop location is the starting address location of the micro program (from which the processor is set to run mode from the halt mode) or if the micro program does not jump back to this address.

#### Address Sync

A sync jack is mounted on the rear of the front panel for maintenance purposes. A positive pulse of 200 nanosecond duration is obtained when the contents of the L Register are the same as the address set into command switches 14-0.

#### REGISTER DISPLAY AND ENTRY

## Display

The processor registers can be displayed directly by selecting the proper display selector or indirectly by use of commands set into the command switches to cause the register to be gated to the A Bus where it can be displayed by selecting 'D'.

The R, U, MD and OD Registers cannot be displayed, but the R Register will hold the same information as on the R Bus when the processor is halted. The M, N and L Registers can be displayed by selecting them with the display selector.

The file registers, T Register and LINK can be displayed indirectly by setting the commands shown below into the command switches and selecting the data display (A Bus).

| Register                 | Command Setting |
|--------------------------|-----------------|
| Selected File Register X | CX00            |
| T Register               | B020            |
| LINK (AL)                | B080            |
| LINK (ML)                | B082            |

#### Enter

Information can be entered into a register by executing a command from the panel. This requires turning on the PANEL switch, setting the command into the command switches and pressing the CLOCK switch. In addition control functions such as interrupt enable or file select can be performed by executing the appropriate command. The commands for placing the literal 'ZZ' in a register are shown below:

| Register        | Command                           |
|-----------------|-----------------------------------|
| Т               | 11ZZ                              |
| M               | 12ZZ                              |
| N ·             | 13ZZ                              |
| <b>U</b> ,      | 16ZZ                              |
| File Register X | 2XZZ                              |
| <b>L</b> .      | 0ZZZ (U Register must be cleared) |

#### CHAPTER 5

## MICRO ASSEMBLER PROGRAM

The Micro Assembly Program, MAP1600, is a two-pass symbolic program which assembles MICRO 1600 microprograms on MICRO 820, 821, 1600/20 or 1600/21 computers with 8K bytes of core memory. The basic assembler is designed for use on ASR33 teletype with paper tape reader and punch. Other versions of the program permit use of a high-speed paper tape reader and punch, a card reader, or a line printer.

Output from the assembler consists of an assembly listing and a binary program tape. This program tape is used as the input to the Micro 1600 simulator, SIM1600, for static environmental checkout and, if necessary, as input into the electrically alterable read only memory system, AROS1600, for system checkout in a dynamic environment. When a final, debugged, version of the microprogram is assembled, the program tape is the input to a utility program, ICM1600, that generates the memory maps necessary for manufacturing of either bipolar integrated circuits or field programmable read-only memories.

The MAP1600 assembly language includes the following features:

Address Arithmetic — Decimal and hexadecimal numbers, symbolic addresses, and arithmetic expressions.

Listing Control — The format of the listing is automatically controlled and comment statements may be included.

Diagnostics — Diagnostics for source statement errors are included in the output listing.

#### SOURCE LANGUAGE

The source language is a sequence of symbolic commands called statements, which are punched on paper tape or cards. Each statement may consist of from one to four entries: a name field, an operation field, an operand field, and a comments field. The maximum length of a statement is 72 characters.

Source program paper tapes that are prepared off-line on a teletype may be in a free form format. This means they may have one or more spaces between fields. All paper tape statements must be terminated by a carriage return, line feed, and two rub-out characters. If the first character of a statement is a left arrow  $\leftarrow$ , it is treated as an end of tape indicator and the assembler will halt to permit another tape to be inserted before continuing. This allows large programs to be separated into several smaller tapes to make editing easier. Source program tapes also may be prepared using the Tape Editor; the tapes will be in a compressed format that removes strings of blank characters.

#### STATEMENT FORMAT

#### Name Field

The name field entry is a symbol composed of from one to six characters starting with character position 1 and terminating with the first blank. Only the first three characters are retained, therefore, they must be unique. The first character of a symbol is alphabetic or a period; subsequent characters may be alphabetic, numeric or a period. A name entry is usually optional and the type of command determines the legal content of the name field. The symbol takes on the current value of the assembler's location counter unless assigned another value by an assembler instruction. When an asterisk (\*) appears in character position 1, the remainder of the line is considered as comment and is not processed by the assembler except to place it on the listing.

#### **Operation Field**

The operation field entry consists of a two or three-character mnemonic operation code specifing the machine command or assembler instruction. Class one commands may use a special symbol (\*) suffixed to the mnemonic which indicates that updating of the source file is to be inhibited. All other commands are followed by blanks. The field begins with the first non blank character following the name field in paper tape or with column 8 in cards, and is a minimum of 4 characters in length. Two or three character commands are considered to have a blank as the third and fourth character of the mnemonic.

## **Operand Field**

The operand field entries identify and describe registers of data to be acted upon by a command. One or more operands may be written, depending on the needs of the command. No blanks may appear within the operand field. In the classes of commands requiring source file operands, a comma is required to separate the source file operand from any following operand entries. The operand field may start anywhere between the first and third characters following the operation field. When punched in cards, column 14 is the normal column. It is terminated by the first blank.

## **C-Field Designators**

C-Field designators are only allowed in Class One commands. These C-Field designators must be preceded by a source file operand and/or a comma separator, and must proceed any destination register designator. Only specific C-Field designators are allowed and the operation field regulates their use. C-Field designators may be separated by commas for clarity, if desired.

Following are the legal C-Field designators:

| Designator | Definition             | Bit Value |  |  |
|------------|------------------------|-----------|--|--|
| С          | Modify Condition Codes | 0001      |  |  |
| T          | Select T Register      | 0010      |  |  |
| F          | Select T Complement    | 0100      |  |  |
| •          | Add One/Increment      | 0100      |  |  |
|            | for Read/Write Memory  | 1100      |  |  |
| D          | Decrement              | 0100      |  |  |
| . L        | Link Control/Add Link  | 1000      |  |  |

## **Destination Register Designators**

The destination register designators are only allowed in Class One Commands. If specified, it may follow either the C-Field designators, or the source file operand if no C-Field designators are specified. The destination register is enclosed by parenthesis.

Following is a list of the legal destination register designators enclosed by parenthesis:

| Designator | Register                                 |  |  |
|------------|------------------------------------------|--|--|
| (T)        | T register                               |  |  |
| (M)        | M register                               |  |  |
| (N)        | N register                               |  |  |
| (L)        | L register (even address pages)          |  |  |
| (K)        | L register (odd address pages)           |  |  |
| (U)        | U register                               |  |  |
| (S)        | Or U with command (op codes 8 to F only) |  |  |

## Inhibit Source File Update

This indicator is only allowed by Class One commands. The indicator is an asterisk (\*) following the three character operation field. When punched on cards, this indicator is located in column 11.

#### Comments Field

Comments describing the information about the program may be inserted between the end of the operand field and column 72. All characters, including spaces, may be used in writing a comment. If the listing is printed on a teletype, only the first 53 characters of the source line are printed.

#### **OPERAND FIELD EXPRESSIONS**

## Source File and Literal Expressions

Expressions in the operand field are made up of one or more terms which are connected by + and - arithmetic operators. No parenthetical expressions are allowed. Each term of the expression represents a value. Values may be assigned by the assembler program (symbols), or they may be inherent in the term itself (constants). The range of values depends on the operand and the command.

#### **Symbols**

A symbol is composed of one to six characters, but only the first three are recognized, and therefore must be unique. The first character must be alphabetic or a period; subsequent characters may be numeric, alphabetic, or a period. Imbedded blanks are not allowed and the assembler stops scanning the symbol with the first character which is not alphanumeric or a period. All symbols, except the special symbol (\*) used in an operand field, must be defined by a single appearance in the name field of statement within the program.

## Special Symbol

The special symbol (\*) represents the momentary value of the assembler's location counter. It may be used as any other symbol in an expression but must never appear in the name field.

#### Constants

The values of the constant terms are not assigned by the assembler program but are inherent in the terms. There are two types of constant terms: decimal and hexadecimal.

## a. Decimal Constant

A decimal constant is an unsigned decimal number. The value must be less than 65,536.

#### b. Hexadecimal Constants

A hexadecimal constant is an unsigned hexadecimal number of up to four characters written as a sequence of hexadecimal digits. The digits are enclosed in single quotation marks and preceded by the letter X. Each hexadecimal digit represents a four-bit binary number. The characters A through F are used to identify the hexadecimal integers 10 through 15.

#### MACHINE COMMANDS

Machine commands occupy one word (16 bits) of read-only memory. These commands are divided into five classes or formats. All classes allow a name, operation, and comments field, while the operand field contents is defined by class.

The five classes are defined as follows:

#### **CLASS ONE**

The Operation Field may contain the Source File update inhibit designator (\*). The operand field consists of:

- 1. Source file Expression (f)
- 2. C-Field designators if allowed by the particular operation code. (c)
- 3. Destination register designator, (r)

The Operand field must contain a Source file expression first and it must be separated from the remaining operand field by a comma. Either or both

the C-Field designators and Destination register designator are then specified if desired.



## **CLASS TWO**

The operand field consists of:

- 1. Source file Expression (f)
- 2. Literal expression

The source file expression must be followed by a comma if a literal expression follows. If no literal expression is specified it is assumed to be zero. Only an 8-bit literal value is expressed in the object code.



#### **CLASS THREE**

The operand field consists of a literal expression. Only an 8-bit literal value is expressed in the object code.



#### **CLASS FOUR**

The generic class of commands occupy all 16 bits of the microcommand format.



#### **CLASS FIVE**

The operand field is a literal expression of which the low-order 12-bit value is expressed in the object code.



The only Class Five Op Code mnemonic is JE.

#### ASSEMBLER INSTRUCTIONS

Five assembler instructions are included for control of the assembly process and the output listing.

#### ORG - Set Location Counter

The ORG assembler instruction alters the setting of the location counter. The name field entry, if any, will be assigned the value of the program counter after it is altered. The operand field of ORG must contain an expression whose value will be placed in the location counter. All symbols in the expression must have been previously defined when the instruction is first encountered. The next comma which places object code in the program is forced to begin a new object record.

## EQU — Equate Symbol

The EQU assembler instruction is used to define a symbol by assigning to it the value of the operand field expression. Any symbols appearing in the expression must have been previously defined when the instruction is first encountered. A name field entry must be present.

#### DC — Define Constant

The DC assembler instruction is used to generate any 16-bit value in order to create a command that is not symbolically recognized by the assembler. The operand field may contain any expression.

## EJE - Page Eject

The EJE assembler instruction is only recognized in Pass 2. When encountered, it ejects the assembler listing to the next page and prints the page heading. Two or more consecutive EJE statements yield only one top of form operation.

## END — End Assembly

The END assembler instruction terminates the assembly of a program and must be the last statement in a source program. Any operand field entry is ignored.

#### ASSEMBLY LISTING

A listing generated during the second pass of the assembly supplies a side-by-side representation of source statements, generated object code, control memory address of the command, and diagnostic messages. The format locates the various items at fixed positions across the printed page to produce a columnar organization. Print positions for listing are shown below.

#### FORMAT

| Printer Columns | Contents                                       |
|-----------------|------------------------------------------------|
| 1 - 4           | Memory address of assembled command.           |
| 6 - 15          | Hexadecimal digits of one word of object code. |
| 17 - 18         | Diagnostic message identifiers.                |
| 20 - 25         | Name field of source statement.                |
| 27 - 29         | Operation code of source statement.            |
| 30              | Source File update inhibit designator.         |
| 33 - 72         | Operand field and comment section.             |

Source paper tapes that are punched in the free form or compressed format will be listed in above fixed form format.

#### ERROR FLAGS

Diagnostic messages are indicated by single character identifiers appearing in columns 17 or 18. If more than two errors are detected for a single source statement, only the last two encountered will be listed. The diagnostic symbols are as follows:

#### A - Address Error

This error occurs when an address expression in the operand field is incorrectly written or the value is out of range for one of the operands. An error flag will occur for each operand in error or out of range.

#### C - C-Field Error

This error occurs when an illegal C-Field designator is encountered with class one commands.

#### D - Destination Register Error

This error occurs when an illegal Destination register designator is encountered with class one commands.

#### F - Name Table Full

This error occurs when the name table is full. The name or operand in this statement was not entered into the table.

## M - Multidefined Symbol Error

This error occurs when the symbol in the name field has been previously defined by appearing in the name field of another instruction. During pass 1, this error references the statements with name field errors, while operand field occurrences of the multidefined names are indicated on pass 2.

### N - Name Field Error

This error flag occurs when the symbol in the name field starts with a character other than alphabetic or period or contains a non-alphanumeric or non-period character.

## O — Operation Mnemonic Error

This error occurs when the assembler does not recognize the contents of the operation field. A 16-bit zero value is assembled to allow patching.

## R - Range Error

This error occurs when the expression in the operand field of a JP operation is beyond the current 1K block of read-only memory.

#### S - Source File Error

This error occurs when the value of a Source file expression exceeds 15.

## U — Undefined Symbol Error

This error occurs when the symbol encountered in an expression of the operand field is not defined by an appearance in the name field.

#### PROGRAM TAPE FORMAT

The binary paper tape format generated by the assembler is shown in Figure 3. This format allows for variable length records of up to 64<sub>10</sub> 16-bit microcommands. Each record contains a count of the number of data bytes in the record, (2 bytes per command), the 15-bit address where loading is to start, and a checksum byte. The last byte of each record is the checksum. It is the summation of the byte count, load address, and data bytes formed on a signed eight bit basis with any overflow added into the least significant bit of the sum.

The END assembler instruction causes an end of tape record to be attached. This record contains a byte count, load address, and checksum of all zeros.



Figure 3. Binary Paper Tape Format

#### SAMPLE LISTING

The two sample listings show the format of a listing and provides examples of how to write each command type, literals, constants, and assembler instructions. Nine types of error conditions are also illustrated.

Upon completion of Pass 1, all undefined symbols will be printed. For the programmers information, a list of all unused symbols will also be printed.

```
LF
                 16,107
                                   FILE NUMBER .GT. 15
           *HO
                 AM, I
                                   UNDEFINED MNEMONIC
0
   MM
           LF
                  6,2
                                    ILLEGAL NAME
   MLT
           T٧
                  0.2
                                    MULTIPLE DEFINED NAME
¢
           ADD
                                    ILLEGAL FOR ADD
                  5,F
Ċ
           INC
                  6 . T
                                    ILLEGAL FOR INCREMENT
0
           MOV
                  7,(X)
                                    ILLEGAL DESTINATION REG
A
           LF
                  3
                                    MISSING
                                            LITERAL
           ĹF
                                    MISSING LITERAL
                  4.
           ĹF
                  NF.
                                   UND. FILE, MISSING LIT.
UNDEFINED NAMES
OUT
NG
NF
UNUSED NAMES ....
```

#### PASS 2 PAGE 201 EXAMPLE OF ALL ASSEMBLER ERROR DIAGNOSTICS EXCEPT NAME TABLE FULL 3320 2064 FILE NUMBER .GT. 15 UNDEFINED SYMBOL S LF 16,100 0301 0000 U MLT JΕ OUT 3335 6666 UNDEFINED MNEMONIC 0 MM WHO AM, I 2023 2602 1 LF 6,2 ILLEGAL NAME 2324 3701 ĀF MULTIPLE DEFINED NAME MULTIPLE DEFINED NAME м 7, MLT 0335 5002 4LT TN 0,2 2326 9520 c ADD 5 . F ILLEGAL FOR ADD 3337 8642 C INC 6,1 ILLEGAL FOR INCREMENT 2338 C700 D MOV ILLEGAL DESTINATION REG OUTSIDE CURRENT 1K WORDS 7, (X) 2209 1420 R JΡ X14001 330A 2300 A ĹF MISSING LITERAL 230B 2420 LF Δ 4, MISSING LITERAL 333C 2530 U ĹF 5,NG NF, UNDEFINED LITERAL 0300 2000 LF UA UND. FILE, MISSING LIT. 0000 3660 END EXAMPLE OF HOW TO CODE VARIOUS MICROCOMMANDS CLASS 1 FORMAT 0300 2026 EOT 0, T, (U) COULD BE A COPY T TO U 3301 7129 SRF+ 1.(T) SHIFT RIGHT 4 TO T 3332 73A0 DOX DATA OUTPUT I/O SIGNAL 2023 8261 ADD 2, IT, (T) FILE 2+1+T TO FILE 2, T 2024 8350 FILE 3+1 WITH COND CODE INC 3,0

```
FILE 4-T TO FILE 4
2225 9420
                                SBT
                                        4 . T
0006 9543
                                DEC
                                        5,(N)
                                                           FILE 5-1 TO FILE 5, N
                                                           FILE 6-1+LINK, FULL READ
FILE 7 TO M, HALF READ
0337 A642
                                RMF
                                        6,D,(M)
                                RMH
0008 A722
                                        7,(M)
                                                            FILE 8-1 TO N FULL WRITE
2029 A853
                                WMF
                                        8, D, (N)
                                                           FILE 9 TO T, HALF WRITE T+LINK TO FILE 10
388A A931
                                WMH
                                        9,(T)
300B BAA0
                                CPY
                                        10,LT
                                                            ZERO TO FILE 11 AND T
222C BB01
                                ZOF
                                        11,(T)
                                                           PLUS 1 TO FILE 12 AND N
OR FILE 13 WITH T COMP
MOVE FILE 14 TO U
                       POF
2020 BC43
                                POF
                                        12, (N)
338E CD48
                                LOR
                                        13.F
200F CE06
                                MOV
                                        14, (U)
                                       15,T,C
2010 DF38
                                XOR*
                                                            IF FILE 15=T, RESULT 0
                                                           FILE 1 ANDEO WITH T
SHIFT LEFT, INSERT LINK
SHIFT LEFT, INSERT A 1
SHIFT RIGHT, INSERT A 0
LSB SAVED IN OVERFLOW
0011 E120
                                AND
                                        1,T
0012 F280
                                SFL
                                        2,L
2213 F340
                                SLI
0014 F420
                                SER
0015 F570
                                SRI
                                        5,C
                           CLASS 2 FORMAT
3316 0618
                                ELT
                                        6,24
                                                           COULD BE LOAD FILE 6
                                        7,POF
0817 270D
                                LF
                                                            ADDRESS OF POF COMMAND
3318 3826
                                ĀF
                                                            ADD 6 TO FILE 8
                                        8,6
3319 4001
                                ΤZ
                                        0, X'01'
                                                            SKIP IF OVERFLOW COND
                                        TEN,1
                                                           SKIP IF FILE 10 IS ODD
SKIP IF FILE 11 ,GT, 239
2014 5A01
                                TN
331B 6B10
                                CP
                                        11,-240
                           CLASS 3 FORMAT
                                LT
801C 1121
                                       1
                                                            1 TO T
                                                           2 TO M
3 TO N. CLEAR M
3310 1282
                                LM
001E 1303
                                LN
JP
                                       3
                                       .XY
                                                           JUMP WITHIN 1024 WORDS
331F 142C
2320 164B
                                LU
                                                            HEX 'AB' TO U
2721 1728
                                LS
                                        X1281
                                                           ENABLE RTC AND EXT. INT.
3322 19AB
                                RLT
                                       XIARI
                                                           HEX 'AØ' TO T AND RETURN
0323 180A
                                88L
                                                           SELECT 3RD BANK OF 4396
                                        2
                          CLASS 4 FORMAT
3024 1000
                                                            USED FOR 200NS DELAY
                                NOP
3025 1020
                       RTN
                                RTN
                                                            RETURN FROM LAST JE SAVE
                                                           SELECT PRIMARY FILES
RETURN, SELECT PRIMARY
0026 1040
0027 1060
                                SPF
                                RSP
0028 1080
                                33F
                                                            SELECT SECONDARY FILES
                                R89
                                                           RETURN, SELECT SECONDARY HALTS CPU, BUT NOT DMA
0029 10A0
332A 1782
                                HLT
222B 1A22
                                MLC
                                                           OD ANDED ON NEXT COMMAND
002C 1801
                       . X Y
                                ISP
                                                           MOVE STACK TO NEXT LEVEL
J32D 7070
                                EC3
                                                           PANEL SWITCHES ANDED
                           CLASS 5 FORMAT
032E 2700
                                JΕ
                                       ORG
                                                            JUMP AND SAVE FOR RETURN
                          ASSEMBLER INSTRUCTIONS
0730
                       ORG
                                ORG
                                       X17001
                                EQU
                                       10
      320A
                       TEN
                                                           SYMBOLIC NAME FOR A FILE
3703 3000
                                DC
                                        а
                                                           FILLER FOR UNUSED ROM
3731 3888
                                END
```

## MICROCOMMANDS (CLASS ORDER)

Class 1 — Mnemonic/File Inhibit — File Name, C-Field Design (Destination Reg. Design)

| COMMAND                        | MNEMONIC | OPERAND<br>FIELD |
|--------------------------------|----------|------------------|
| EXECUTE, OPERATE TYPE          | EOT*     | f,LCTIFD(r)      |
| ENTER SENSE SWITCHES           | ESS*     | f,(r)            |
| SHIFT FILE RIGHT 4             | SRF*     | f,(r)            |
| ENTER INTERNAL STATUS          | EIS*     | f,(r)            |
| CLEAR I/O MODE                 | CIO*     | f,(r)            |
| CONTROL OUTPUT                 | cox*     | f,(r)            |
| DATA OUTPUT                    | DOX*     | f,(r)            |
| SPARE OUTPUT                   | SOX*     | f,(r)            |
| CONCURRENT ACKNOWLEDGE         | CAK*     | f,(r)            |
| INTERRUPT ACKNOWLEDGE          | IAK*     | f,(r)            |
| DATA INPUT                     | DIX*     | f,(r)            |
| STACK/SPARE INPUT              | SIX*     | f,(r)            |
| ADD FILE                       | ADD*     | f,LITC(r)        |
| INCREMENT FILE                 | INC*     | f,C(r)           |
| SUBTRACT FILE, TWOS COMPLEMENT | SBT*     | f,LTC(r)         |
| SUBTRACT FILE, ONES COMPLEMENT | SBO*     | f,LTC(r)         |
| DECREMENT FILE                 | DEC*     | f,C(r)           |
| READ MEMORY, FULL CYCLE        | RMF*     | f,LID(r)         |
| READ MEMORY, HALF CYCLE        | RMH*     | f,LID(r)         |
| WRITE MEMORY, FULL CYCLE       | WMF*     | f,LID(r)         |
| WRITE MEMORY, HALF CYCLE       | WMH*     | f,LID(r)         |
| COPY                           | CPY*     | f,LITC(r)        |
| ZERO FILE/REG.                 | ZOF*     | f,C(r)           |
| +1 TO FILE/REG.                | POF*     | f,C(r)           |
| LOGICAL OR WITH FILE           | LOR*     | f,LFTC(r)        |
| MOVE FILE                      | MOV*     | f,LC(r)          |
| EXCLUSIVE OR WITH FILE         | XOR*     | f,LFTC(r)        |
| AND WITH FILE                  |          | f,LFTC(r)        |
| SHIFT FILE LEFT                | SFL*     | f,LC(r)          |
| SHIFT FILE LEFT AND INSERT     | SLI*     | f,C(r)           |
| SHIFT FILE RIGHT               | SFR*     | f,LC(r)          |
| SHIFT FILE RIGHT AND INSERT    | SRI*     | f,C(r)           |

Class 2 - Mnemonic - File Name, Literal

| COMMAND                | MNEMONIC | OPERAND<br>FIELD |
|------------------------|----------|------------------|
| EXECUTE, LITERAL TYPE  | ELT      | f,n              |
| LOAD FILE WITH LITERAL | LF       | f,n              |
| ADD FILE WITH LITERAL  | AF       | f,n              |
| TEST IF ZERO           | TZ       | f,n              |
| TEST NOT ZERO          | TN       | f,n              |
| COMPARE FILE           | CP       | f,n .            |

Class 3 - Mnemonic - Literal

| MNEMONIC         | 8 BIT<br>OPERAND                              |
|------------------|-----------------------------------------------|
| LZ               | n                                             |
| L <sub>,</sub> T | n                                             |
| LM               | n                                             |
| LN               | n                                             |
| JP               | n                                             |
| LU               | n                                             |
| LS               | n                                             |
| LE               | n                                             |
| RLT              | n                                             |
| BSL              | n                                             |
|                  | LT<br>LM<br>LN<br>JP<br>LU<br>LS<br>LE<br>RLT |

Class 4 - Mnemonic Only - No Operand Field

| COMMAND                       | MNEMONIC |
|-------------------------------|----------|
| NO OPERATION                  | NOP      |
| ENABLE COMM. RATES            | ECR      |
| DISABLE COMM. RATES           | DCR      |
| INPUT COMM. RATES             | ICR      |
| RETURN                        | RTN      |
| SELECT PRIMARY FILE           | SPF      |
| RETURN, SELECT PRIMARY FILE   | RSP      |
| SELECT SECONDARY FILE         | SSF      |
| RETURN, SELECT SECONDARY FILE | RSS      |
| DISABLE EXTERNAL INTERRUPTS   | DEI      |
| ENABLE EXTERNAL INTERRUPTS    | EEI      |

| COMMAND                 | MNEMONIC |
|-------------------------|----------|
| DISABLE R.T. CLOCK      | DRT      |
| ENABLE R.T. CLOCK       | ERT      |
| HALT                    | HLT      |
| MODIFY LOWER COMMAND    | MLC      |
| INHIBIT L SAVE          | ILS      |
| INCREMENT STACK POINTER | ISP      |
| DECREMENT STACK POINTER | DSP      |
| CLEAR STACK POINTER     | CSP      |
| SELECT STACK POINTER    | SSP      |
| SELECT STACK UPPER      | SSU      |
| SELECT STACK LOWER      | SSL      |
| ENTER CONSOLE SWITCHES  | ECS      |

## Class 5 - Mnemonic - Literal

| COMMAND       | MNEMONIC | OPERAND<br>FIELD<br>(12 BIT<br>LITERAL) |
|---------------|----------|-----------------------------------------|
| JUMP EXTENDED | JE       | n                                       |

## Assembler Instructions — Mnemonic — Operand Field

|           | COMMAND | MNEMONIC | OPERAND<br>FIELD |
|-----------|---------|----------|------------------|
| ORIGIN    |         | ORG      | n                |
| DEFINE CO | NSTANT  | DC       | n                |
| ** EQUATE | •       | EQU      | n                |
| EJECT     | •       | EJE      |                  |
| END       |         | END      |                  |

<sup>\*\*</sup> The EQU statement must contain a name field, all other statements may contain a name field.

\* = File update inhibit
f = File Expression
(r) = Destination Register Designator
n = Literal Expression
L,C,T,F,I,D = C-Field Designators

#### **CHAPTER 6**

## INPUT/OUTPUT

#### GENERAL DESCRIPTION

The CPU provides an extremely fast elementary input/output capability. The data paths and control functions are simple elements that are sequenced from the control memory with flexible disciplines. The fact that the control memory is very fast, 200 ns/step, means that microprograms (firmware) in the control memory can implement facilities with a high degree of versatility in timing, data paths and I/O capabilities such as priority interrupts, fully buffered data channels, macroprogrammable transfers, and special purpose communication multiplexer channels. This basic I/O element called the "Byte I/O Bus" is described in the following paragraphs. In addition, the direct memory occurs (DMA) and serial data interface are described.

## BYTE I/O BUS

The byte I/O facility allows for data transfers over a party-line I/O bus under microprogram control. This I/O facility consists of a byte input bus, a byte output bus, and a three-bit I/O control register.

The contents of the I/O control register define an I/O bus mode. The I/O control register outputs may be decoded to form individual control signals defining the type of transfer being performed on the byte I/O bus and the state of the serial interface output. Of the eight possible states of the I/O control register, one represents no activity on the bus, three are output modes, and four are input modes. One of the output modes removes the MARKing current from the serial interface to output a SPACE to the serial data interface.

The I/O control register is loaded by the control command, an operatetype command with an operation code of 7. When the c field of this instruction equals hexadecimal 8-F, the operations are associated with external input/output, and the three low order bits of c are placed in the I/O control register. The control functions of this instruction are shown in Table 2.

Table 2. Byte I/O Control Modes

| Control C   | omman   | d |     |     |   |   |     |    |   |     |     |      |                              |
|-------------|---------|---|-----|-----|---|---|-----|----|---|-----|-----|------|------------------------------|
| 7           | f       |   |     | С   |   | * |     | r  |   |     |     |      |                              |
| 15 14 13 12 | 11 10 9 | 8 | 7 6 | 5   | 4 | 3 | 2   | 1  | 0 |     | нех | Mode | Control Activity             |
|             |         | - | 0 0 | 0   | 0 |   |     |    |   |     | 0   |      | No Operation                 |
|             |         | ( | 0 ( | 0 0 | 1 |   |     |    |   |     | 1   |      | Enter Sense Switches         |
|             |         | ( | 0 ( | 1   | 0 |   |     |    |   |     | 2   |      | Shift "f" Right Four Places  |
|             |         | ( | 0 1 | 10  | 0 |   |     |    |   |     | 4   |      | Enter Internal Status        |
|             |         | - | 0 ' | 1 1 | 1 |   |     |    |   |     | 7   |      | Enter Console Switches (0-7) |
| NO ACT      | IVITY   |   | 1 ( | 5 ō | 0 |   |     |    | _ |     | - 8 |      | Clear I/O Mode               |
| OUTPUT      |         |   | 1 ( | 0   | 1 |   |     |    |   |     | 9   | 1    | SPARE (*)                    |
| FUNCTION    | ONS     |   | 1 ( | 1   | 0 |   |     |    |   |     | Α   | 2    | SPARE (*)                    |
|             |         |   | 1 ( | 1   | 1 |   |     | /O |   | ROL | В   | 3    | Space Serial Interface       |
| _           |         |   | 1   | 1 0 | 0 |   | - ( | וט | v | HUL | С   | 4    | SPARE (*)                    |
| INPUT       |         |   | 1 1 | 10  | 1 |   |     |    |   |     | Ď   | 5    | SPARE (*)                    |
| FUNCTION    | ONS     |   | 1 ' | 1 1 | Ó |   |     |    |   |     | E   | 6    | SPARE (*)                    |
| . 5.4611    | 0.43    |   | 1 ' | 1 1 | 1 |   |     |    |   |     | F   | 7    | SPARE                        |

<sup>\*</sup>These functions are used in the MICRO 1600/10 and 1600/20 I/O systems.

To summarize the I/O control modes set by the control command:

| Mode | Control Activity | Comments                                                                                                                                                                                                                                                                           |
|------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | Clear I/O Mode:  | The I/O control register is cleared. Data from<br>the designated file or Input bus can be<br>transferred to the designated file register and<br>register (r).                                                                                                                      |
| 1-7  | Set I/O Mode:    | The I/O Control register is loaded with the three low order bits of c placing it in one of seven I/O bus or serial interface modes. These modes are described above. Data from the designated file or Input bus can be transferred to a designated file register and register (r). |

NOTE: Once an I/O control register mode has been SET, an I/O clear mode must be executed to change the I/O control register mode of operation.

The three output modes and four input modes are distinguished by the high order bit of the I/O control register, which is referred to as the input flag. During execution of some of the operate-type commands, (including the control command) the source of data is the input bus if this input flag is a 1-bit, and the T register otherwise.

#### **Bus Lines**

The byte I/O bus consists of

- input data lines
- input control lines
- output data lines
- output control lines

The electrical implementation of the input and output bus lines is shown in Figure 4.



TRANSMITTERS

RECOMMENDED CONFIGURATION
N≤ TEN GATES
M≤ FIFTEEN GATES

Figure 4. Bus Lines

## Input Lines

The input data lines are inputs to the B bus gating. The input control lines are inputs to bits of file register 0. The input lines are ground TRUE signals which are properly terminated at the processor. If the bus is carried out of the basic enclosure it also must be terminated at the remote end. Each peripheral device gates information onto the bus by means of open collector type 944 DTL drive circuits. Up to 15 drivers may be connected to each line.

The logic level on the twisted pairs are:

One -0 Volts Zero -+3 Volts

There are three input control lines. They are used in standard 1600/10 and 1600/20 systems for the following purposes:

# Typical Input Control Line Definitions (1600/10 and 1600/20)

#### Control Lines In

Use in the System

External Interrupt (EINT/):

A peripheral device makes this line low to request an interrupt of the macroprogram. The microprogram must respond with an interrupt acknowledge (mode 5) signal. This line is bit 7 of the file register 0 where a 1-bit indicates an external interrupt request.

I/O Reply (ERPY/):

A peripheral device makes this line low in response to an I/O operation when closed-loop operation is required. This line is bit 5 of the file register 0.

I/O Request (ECIO/):

A peripheral device makes this line low in order to request a concurrent data transfer. The microprogram must respond with an concurrent acknowledge (mode 4) signal. This line is bit 3 of the file register 0.

The file register 0 bits are defined as follows:

## File Register 0 Flags

| Bit | Flag                                                        |
|-----|-------------------------------------------------------------|
| 0   | Overflow result Condition                                   |
| 1 . | Negative Result Condition                                   |
| 2   | <ul> <li>Zero Result Condition</li> </ul>                   |
| 3   | <ul> <li>Concurrent I/O Request Line* or (SPARE)</li> </ul> |
| 4   | – Internal Interrupt                                        |
| 5   | <ul> <li>I/O Reply Line* or (SPARE)</li> </ul>              |
| 6   | Serial Interface                                            |
| 7   | <ul> <li>External Interrupt Line* or (SPARE)</li> </ul>     |

<sup>\*</sup>If a standard 1600/10 or 1600/20 CPU interface is not used, these flags may be used as SPARE bits.

## **Output Lines**

The output data lines originate with the FALSE output of the Output Data register. The output control lines originate with the I/O control register. If all peripheral devices on the bus are local to the enclosure, and the bus does not leave the enclosure, then the bus is standard logic levels and no DTL drivers and terminations are used. It may be necessary to repower the signals, if the bus leaves the enclosure. An I/O control board is required in this case to provide output drivers and to decode the control register. The cable length can be up to 30 feet in length, must use twisted pairs and must be terminated at the remote end. Up to 15 receivers can be accommodated. The levels on the twisted pairs are:

One -0 Volts Zero -+3 Volts

The I/O control register is decoded within standard 1600/10 and 1600/20 device interface controllers to provide seven control terms:

# Typical Byte I/O Control Modes (1600/10 and 1600/20)

| Mode | Control Activity       | Term  |
|------|------------------------|-------|
| 0    | None*                  | None  |
| 1    | Control Output         | COXX/ |
| 2    | Data Output            | DOXX/ |
| 3    | Space Serial Interface | SP1X/ |
| 4    | Concurrent Acknowledge | CACK/ |
| 5    | Interrupt Acknowledge  | IACK/ |
| 6    | Data Input             | DIXX/ |
| 7    | Spare*                 | SP2X/ |

<sup>\*</sup>These terms are used by the L-Save Stack option.

## Typical Byte I/O Interface

To illustrate byte I/O programming, a typical interface has been selected which has minimum functions for transferring bytes in and out of the computer. A more complex device, such as a tape controller, or card reader, using the byte I/O function would contain logic similar to this for transferring control, status, and data between the controller and the MICRO 1600.

The byte I/O interface described contains the following basic functions.

- Line receivers and drivers
- Device address decoder
- Function latch and decoder
- Connection latch
- Input multiplexer

- Input selection gates
- Output latches
- Control decoder

These items are shown in block diagram form in Figure 5.



Figure 5. I/O Interface Block Diagram

For summary purposes the logic terms used in the I/O interface example (which are standard for MICRO 1600 interfaces) are defined in Table 3.

Table 3. Definition of Terms in I/O Interface Block Diagram

| coxx | FUNCTION AND DEVICE CODE OUTPUT CONTROL PULSE              |
|------|------------------------------------------------------------|
| DOXX | DATA OUTPUT CONTROL PULSE                                  |
| DIXX | DATA INPUT CONTROL PULSE                                   |
| KIXX | INTERFACE CLOCK PULSE FORMED BY ORing COXX, DOXX, AND DIXX |
| DAXX | DETECTED DEVICE ADDRESS ENABLED BY COXX                    |

Table 3. Definition of Terms in I/O Interface Block Diagram (Cont)

| OD00-OD07   | OUTPUT DATA LINES (COMPLEMENT OUTPUTS<br>OF 1600 OUTPUT DATA FROM MICRO REGISTER)        |
|-------------|------------------------------------------------------------------------------------------|
| FN0X-FN7X   | LATCHED AND DECODED FUNCTIONS ENABLED BY CONN                                            |
| FD05-FD06   | LATCHED BUT UNDECODED FUNCTION BITS                                                      |
| CONN        | CONNECT LATCH INDICATING THAT THE I/O<br>BOARD HAS RECEIVED ITS DEVICE CODE<br>WITH COXX |
| MRES        | MASTER RESET FROM MICRO 1600                                                             |
| · 101X-103X | 3 BITS FROM OUTPUT CONTROL REGISTER                                                      |
| DIG MUX     | DIGITAL MULTIPLEXER                                                                      |

## Description of Functional Block Diagram (Figure 5)

The control decoder receives the IOnX lines from the control line receivers and first decodes them into COXX, DOXX, and DIXX. These three are ORed to produce KIXX which is used to set and reset function and connect latches.

The device address decoder becomes active whenever the board's address appears on the OD00-OD04 lines. DAXX is active only when COXX is active. Otherwise DAXX would become active every time the device address appeared on the output data lines.

The function latches set or reset every time there is a KIXX pulse. The output functions FNOX, etc., are not enabled unless CONN is active. The functions are used to enable the output latch.

The connection latch is set when the board detects its device address and COXX is active. It is reset on the trailing edge of the next DIXX or DOXX pulse.

The connection latch enables the functions and the input selection gate.

The input selection gates place the input data onto the input bus during DIXX whenever the CONN latch has been set indicating that this board has been addressed.

The output latches are updated to the values on the OD0X lines during DOXX whenever the corresponding function code FNNX is active.

#### **EXAMPLES OF I/O MICROPROGRAMMING**

For the following examples assume that the device code is binary 00001. In the standard 1600/10 and 1600/20 the function code sent to a device

interface controller is combined with the device interface's address to form a two-character (hex) device and function code. This results in the following device and function codes:

| Function | on Code | Device and Fund | ction Code |
|----------|---------|-----------------|------------|
| Binary   | Hex     | Binary          | Hex        |
| 000      | 0       | 000 0 0001      | 01         |
| 001      | 1       | 001 0 0001      | 21         |
| 010      | 2       | 010 0 0001      | 41         |
| 011      | . 3     | 011 0 0001      | 61         |

Example 1. For the first Input/Output example the timing of events and the microprogram routine are described for outputting a byte from the MICRO 1600 to latch 0 in the interface board with device code 01.

## Timing Diagram:



## Microprogram:

Example 1.

| 1                                              | 1           | 1            | 1          |               |
|------------------------------------------------|-------------|--------------|------------|---------------|
| FLOW CHART                                     |             | INE CODE     | ASSEMBLY   | LANGUAGE CODE |
| <u> </u>                                       | L           | COMMAND      |            |               |
| DEVICE & FUNCTION CODE T AND OD '01' T AND OD  | 040         | 1101         | LT         | X'01'         |
| SET COXX                                       | 041         | 7090         | cox        | 0             |
| 3 CLOCK DELAY*<br>NO OP +<br>JMP TO NEXT COMM. | 042<br>043  | 1000<br>1444 | NOP<br>JP  | X'044'        |
| RESET COXX                                     | 044         | 7080         | CIO        | <b>o</b> .    |
| SET OUTPUT DATA '55' → T AND OD                | 045         | 1155         | LT         | X'55'         |
| SET DOXX                                       | 046         | 70A0         | DOX        | 0             |
| 3 CLOCK DELAY*                                 | 047<br>048  | 1000<br>1449 | NOP<br>JP  | X'49'         |
| RESET DOXX                                     | 049         | 7080         | CIO        | 0             |
| NEXT COMMAND                                   | 04A<br>— AN | Y COMMAND    | CAN BE NEX | кт            |
| ▼                                              |             |              |            |               |

<sup>\*</sup>This is the standard delay in the MICRO 1600/10 or 1600/20 to generate an 800 ns COXX and DOXX. It could be shorter if the interface is in the main computer chassis. Housekeeping can be done on delay clocks.

Example 2. For the second input/output example, the timing of events and the microprogram are described for inputting a byte from input byte 2 of device 01 to file register 1 and T.

## Timing Diagram:



## Microprogram:

| FLOW CHART                                    | MACHINE CODE |              | ASSEMBLY  | LANGUAGE CODE |
|-----------------------------------------------|--------------|--------------|-----------|---------------|
|                                               | L            | COMMAND      |           |               |
| DEVICE & FUNCTION CODE TO T AND OD            | 060          | 1141         | LT        | X'41'         |
| SET COXX                                      | 061          | 7090         | cox       | 0             |
| 3 CLOCK DELAY<br>NO OP +<br>JMP TO NEXT COMM. | 062<br>063   | 1000<br>1464 | NOP<br>JP | X'64'         |
| RESET COXX                                    | 064          | 7080         | CIO       | 0             |
| SET DIXX                                      | 065          | 70E0         | DIX       | 0             |
| 2 CLOCK DELAY                                 | 066          | 1467         | JP        | X'67'         |
| INPUT DATA USING COPY T COMMAND               | 067          | B121         | CPY       | 1,Т,(Т)       |
| RESET DIXX                                    | 068          | 7080         | CIO       | 0             |
| NEXT COMMAND                                  | 069          | ANY COM      | MAND CAN  | BE·NEXT       |

## Example 3. Special Input Function

To achieve minimum input time and still achieve one clock delay after setting DIXX use the following:

| DIX | 0        | Set DIXX                                                        |
|-----|----------|-----------------------------------------------------------------|
| LF  | 1, X'FF' | Set file 1 = all ones and generate<br>1 clock delay             |
| CIO | 1        | Reset DIXX and simultaneously 'and' the input bus with (file 1) |
|     |          |                                                                 |

#### Serial Interface

The processor contains a serial interface capable of communicating with a full duplex teletype. The input from the teletype appears as bit 6 of file register 0 where a 1-bit indicates that the teletype is transmitting a SPACE. The output to the teletype normally transmits a 20 milliampere MARKing current which can be keyed off to send a SPACE signal by placing the I/O control register in mode 3. Character assembly and disassembly, including all timing and synchronization, are performed by microprogramming.

The serial interface is standard. A teletype or CRT wired for 4-wire full duplex 20 milliampere operation may be directly connected to the cable provided with the machine. Other types of serial I/O devices also may use this condition.

## **Direct Memory Access**

The direct memory access (DMA) interface allows for direct connection to the memory address, data and control busses. The DMA may be installed in any slot within the machine enclosure. This board may contain a channel to which a number of peripheral devices are connected, or a device controller which has direct memory access capability. Generally the DMA system will be customized for special applications.

The maximum data transfer rate is 1 million bytes per second. The DMA I/O takes precedence over the processor for memory operations. The DMA must supply its own address control.

## Computer Backplane Pin Definitions

The backplane pin connections for the Byte I/O bus, serial data interface and DMA are shown in Figure 6. Connectors J2 and J3 are used for the CPU. Connectors J4-J13 are available for use by memory modules, ROM modules, and device interface controllers. (In an extended backplane option, connectors J4-J17 are available for these purposes.)



Figure 6. CPU Input/Output Signals

### **CHAPTER 7**

### PHYSICAL CHARACTERISTICS AND SYSTEM POWER

### MECHANICAL CONFIGURATIONS

### **Enclosures**

A variety of enclosures is available to cover a range of requirements for both OEM and end users.

The basic OEM package provides a simple card cage which may be rack-mounted. Optional rails are available for 24 through 30-inch deep cabinets. The user may install rear-mounted fans or may use vertical convection cooling as desired.

A rack-mounted package is available which provides wrap-around enclosures with controlled air flow. This package can be specified to go into 24 through 30-inch deep cabinets.

A distinctive, attractive table-top enclosure is available when appearance is a consideration. When the back panel is removed from this version, power is automatically turned off. In addition, a variety of 63-inch high custom-styled cabinets are available.

Rack-mounted and table-top enclosures are shown in Figures 7, 8, 9 and 10.

### **Universal Backplanes**

The printed-circuit backplanes provide simple point-to-point strapping of all connector pins.

Two versions are available. The first contains 13 connector slots and an integral power supply.

To make larger system configurations possible, a second version contains 17 connector slots and a remote power supply.

Specifications and characteristics of various packaging options are shown in Table 4.

All MICRO 1600 printed circuit boards are equipped with handles which make possible convenient card extraction, insertion and lockdown. All cards are fully accessible from the rear and may be easily extended for trouble-shooting operations. Convenient flat cables are used for connection to I/O devices, with cable routing and strain relief facilities built into the rack-mounted and table-top enclosures.

### SYSTEM POWER

Power supplies of the MICRO 1600 are available both integrally or as a remote system and furnish power to all basic and optional component subsystems plugged into printed circuit connectors in the computer enclosures.





Figure 9. Rack-Mounted Enclosure With Cooling



Figure 10. Table Top Enclosure With Internal Power Supply and Cooling. (UL Approval Pending)

| Specifications             | Characteristics                                                                                                                                                                                                           |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PHYSICAL/<br>ENVIRONMENTAL |                                                                                                                                                                                                                           |
| Packaging                  | Three packages available:                                                                                                                                                                                                 |
|                            | <ol> <li>OEM Package — basic rack mountable<br/>card cage containing all mechanical<br/>and electrical facilities except for<br/>wrap-around and side panels.</li> </ol>                                                  |
|                            | <ol> <li>Systems Package — Adds wrap-around<br/>enclosure to OEM package for controlled<br/>air flow via plenum chambers (side<br/>and rear panel exhaust/intake with<br/>the computer cabinet.</li> </ol>                |
|                            | <ol> <li>Table-Top Package — Adds side panels<br/>and pedestals to system package<br/>for attractive, convenient desk-top<br/>installations.</li> </ol>                                                                   |
| Dimensions                 | Standard rack mount, 10.5 inch panel height, 20 inch depth. The enclosure provides 13 or 17 connectors which may be used to mount CPU, core and control memory, DMA, and I/O modules. Two slots are dedicated to the CPU. |
| Power Voltages             | 115/230VAC, ±10%, 47-63 Hz, 350 watts                                                                                                                                                                                     |
| Environment                | 0-50 <sup>o</sup> C (ambient); 10 to 90% relative humidity without condensation.                                                                                                                                          |
| CIRCUITS                   |                                                                                                                                                                                                                           |
| Туре                       | Integrated LSI, MSI, and SSI circuit design throughout; TTL internal and DTL input/output drivers.                                                                                                                        |
| Internal Logic<br>Levels   | FALSE = 0v; TRUE = +5v (nominal)                                                                                                                                                                                          |
| I/O Logic Levels           | FALSE = +3v; TRUE = 0v (nominal)                                                                                                                                                                                          |

Power is distributed in `the system via etched conductors on the printed circuit backplane in the integral system. A power distribution printed circuit module for remote power supply operation also is available.

The power supply is designed with ample spare capacity to power most system configurations which use MSI and LSI circuit modules. User-designed modules may also draw power from the supply if current ratings are not exceeded.

The integral power supply physically mounts in the MICRO 1600 enclosures along the lefthand side (from rear) by sliding into standard card guide assembly (see Figures 11 and 12). A direct plug-in to the backplane via a standard printed circuit connector supplies dc voltages directly to the circuit boards via etched conductors.

The remote power supply is operated by means of an extension cable. It requires no cooling over its rated range of operating temperature.

Summary specifications for both power supplies are given in Table 5. Detailed specifications are available in Microdata Specification No. CS 20001003.

### Power Configuration

Peak current consumption for the subsystem components are given in Table 6. A typical system configuration of the MICRO 1600/20 requires the following +5V current:

| Subsystem                  | Current        |
|----------------------------|----------------|
| CPU                        | 5.0 amp        |
| System Console             | 0.9 amp        |
| 768-word bipolar ROM       | 1.5 amp        |
| 4096/8192-byte core memory | <u>0.9</u> amp |
| Total                      | 8.3 amp        |

These current requirements use only three of the available 12 integral power supply card slots. The total +5V capacity is 20 amps, leaving 13.5 amps available for expansion. This is an average of 1.5 amps per connector, which is sufficient to handle a reasonable mix of interface boards and other modules.

For example, assume a fully expanded configuration such as the following:

| Subsystem                 | Card Slots | +5V Current |
|---------------------------|------------|-------------|
| Basic system              | . 3        | 8.6         |
| Additional 8192-byte core | 1          | 0.7         |
| Mag. Tape controller      | 2          | 2.2         |
| Byte I/O controller       | 1          | 1.5         |
| Card reader controller    | 1 .        | 0.8         |
| I/O bus and parallel TTY  | 1          | 1.3         |
| DMA                       | 2          | 1.8         |
| Modem interface           | _1         | 1.2         |
| Total                     | 12         | 18.1        |



Figure 11. Rear View of Typical MICRO 1600 Card Cage Configuration Showing Integral Power Supply



Figure 12. Integral Power Supply of the MICRO 1600

In an extreme case, the system power supply may be unable to handle total current equipments of all modules which could be installed in the available space. In such cases, the user should consult Microdata for the best alternative. Particular care should be used where very large amounts of control memory are to be used since the current is relatively high for these devices, and additional system cooling and increased power may be needed.

Table 5. Power Supply Specifications

| Specification            | Characteristics                                                                                                            |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------|
| Туре                     | Series regulator dc power supply, 3 regulated outputs, designed for integral or remote operation with Micro 1600 computer. |
| AC Input                 | 115/230 VRMS ±10%, 47-63 Hz, single phase; 105 VAC tap also provided.                                                      |
| DC Outputs               | 1. +12VDC, 1.5A, ±5%, adjustable                                                                                           |
| (regulated)              | 2. +5VDC, 20A, +0.5V adjustable                                                                                            |
|                          | 3. $-16.75$ VDC, 3.5A, $\pm 2\%$ adjustable                                                                                |
| Overload/<br>Overvoltage | <ol> <li>Overvoltage: 7VDC limit on +5VDC<br/>output</li> </ol>                                                            |
|                          | 2. Overload: current limiting with<br>automatic recovery                                                                   |
| Power Fail Detect        | Power fail indicator drops 2ms before loss of dc regulation; automatic return after ac returns.                            |
| Line Filtering           | Input line filter for ac line transient protection integral to supply.                                                     |
| Components               | Hermetically sealed semiconductors and ceramic integrated circuits used throughout.                                        |
| Size                     | 4.8" X 8.6" X 16.3"                                                                                                        |
| Remote (Rack<br>Mounted) | 8-3/4" X 19" X 10.5"                                                                                                       |
| Weight                   | 25lbs. (approximate)                                                                                                       |
| Temperature Range        | 0-50°C                                                                                                                     |

Table 6. MICRO 1600 Power Configuration

| Subsystem                                           | +5v | +12v | -16.75v |
|-----------------------------------------------------|-----|------|---------|
| CPU, Data Board, Control Board                      | 5.0 | 0    | 0       |
| System Control Panel                                | 1.2 | 1.2  | 0       |
| Bipolar Read-Only Memory<br>(BROM), 256 Words       | 0.5 | 0    | 0       |
| Programmable Read-Only Memory (PROM), 256 Words     | 0.5 | 0    | ,       |
| Alterable Read-Only Memory (AROM), 1024 Words*      | 7.5 | 0    | 0       |
| First Unit, 4096 or 8192-Byte<br>Core Memory Module | 0.9 | 0    | 1.7     |
| Additional 4096 or 8192-Byte<br>Core Memory Modules | 0.5 | 0    | 0.1     |
| 4 Channel TTY, 20 ma Out                            | 1.5 | 0    | 0       |
| 4 Channel TTY, 60 ma Out                            | 2.6 | 0    | 0       |
| 32X32 I/O Expander                                  | 2.4 | 0    | 0       |
| Mag Tape Controller                                 | 1.7 | 0    | 0       |
| I/O Bus and Parallel TTY                            | 1.3 | 0.1  | 0.1     |
| Priority Interrupt                                  | 1.1 | - 0  | 0       |
| Byte I/O Controller **                              | 1.5 | 0    | 0       |
| Card Reader Controller                              | 8.0 | 0    | 0       |
| 8-Way Async Modem                                   | 0.7 | 0.6  | 0.4     |
| DMA Selector Channel                                | 1.6 | 0    | 0       |

<sup>\*</sup> Use of separate power distribution for AROM is optional.
\*\* Used for paper tape reader/punch, line printers, cassette I/O.

# APPENDIX A. MICROCOMMAND REFERENCE TABLE (NUMERICAL ORDER)

| OBJECT<br>BASE | COMMAND                       | MNEMONIC | CLASS | PAGE |
|----------------|-------------------------------|----------|-------|------|
| 0000           | EXECUTE, LITERAL TYPE         | ELT      | 2     | 351  |
| 0000           | EXECUTE, OPERATE TYPE         | EOT      | 1     | 351  |
| 0000           | JUMP EXTENDED                 | JE       | 5     | 323  |
| 1000           | LOAD ZERO CONTROL             | LZ       | 3     | 323  |
| 1000           | NÓ OPERATION                  | NOP      | 4     | 324  |
| 1001           | ENABLE COMM. RATES            | ECR      | 4     | 324  |
| 1002           | DISABLE COMM, RATES           | DCR      | 4     | 325  |
| 1004           | INPUT COMM, RATES             | ICR      | 4     | 325  |
| 1020           | RETURN                        | RTN      | 4     | 325  |
| 1040           | SELECT PRIMARY FILE           | SPF      | 4     | 325  |
| 1060           | RETURN, SELECT PRIMARY FILE   | RSP      | 4     | 326  |
| 1080           | SELECT SECONDARY FILE         | SSF      | 4     | 326  |
| 10A0           | RETURN, SELECT SECONDARY FILE | RSS      | 4     | 326  |
| 1100           | LOAD T                        | LT       | 3     | 326  |
| 1200           | LOAD M                        | LM       | 3     | 326  |
| 1300           | LOAD N                        | LN       | 3     | 327  |
| 1400           | JUMP IN 1K                    | JP       | 3.    | 327  |
| 1600           | LOAD U                        | LU       | 3     | 327  |
| 1700           | LOAD SEVEN CONTROL            | LS       | 3     | 328  |
| 1704           | DISABLE EXTERNAL INTERRUPTS   | DEI      | 4     | 328  |
| 1708           | ENABLE EXTERNAL INTERRUPTS    | EEI      | 4     | 328  |
| 1710           | DISABLE R.T. CLOCK            | DRT      | 4     | 328  |
| 1720           | ENABLE R.T. CLOCK             | ERT      | 4     | 329  |
| 1780           | HALT                          | HLT      | 4     | 329  |
| 1800           | LOAD EIGHT CONTROL            | LE       | 3     | 329  |
| 1900           | RETURN, LOAD T                | RLT      | 3     | 329  |
| 1A00           | MODIFY LOWER COMMAND          | MLC      | 4     | 329  |
| 1B00           | INHIBIT L SAVE                | ILS      | 4 .   | 330  |
| 1B01           | INCREMENT STACK POINTER       | ISP      | 4     | 330  |
| 1B02           | DECREMENT STACK POINTER       | DSP      | 4     | 330  |
| 1B04           | CLEAR STACK POINTER           | CSP      | 4     | 331  |
| 1B08           | BANK SELECT                   | BSL.     | 3     | 331  |
| 1B90           | SELECT STACK POINTER          | SSP      | 4     | 331  |
| 1BA0           | SELECT STACK UPPER            | SSU      | 4     | 332  |
| 1BC0           | SELECT STACK LOWER            | SSL      | 4     | 332  |

| OBJECT<br>BASE | COMMAND                        | MNEMONIC | CLASS | PAGE |
|----------------|--------------------------------|----------|-------|------|
| 2000           | LOAD FILE WITH LITERAL         | LF       | 2     | 332  |
| 3000           | ADD FILE WITH LITERAL          | AF       | 2     | 332  |
| 4000           | TEST IF ZERO                   | TZ       | 2     | 333  |
| 5000           | TEST NOT ZERO                  | TN       | 2     | 333  |
| -6000          | COMPARE FILE                   | СР       | 2     | 333  |
| 7010           | ENTER SENSE SWITCHES           | ESS*     | 1     | 334  |
| 7020           | SHIFT FILE RIGHT 4             | SRF*     | 1     | 334  |
| 7040           | ENTER INTERNAL STATUS          | EIS*     | . 1   | 334  |
| 7070           | ENTER CONSOLE SWITCHES         | ECS      | 4     | 335  |
| 7080           | CLEAR I/O MODE                 | CIO*     | 1     | 336  |
| 7090           | CONTROL OUTPUT                 | COX*     | 1     | 336  |
| 70A0           | DATA OUTPUT                    | DOX*     | 1     | 336  |
| 70B0           | SPARE OUTPUT                   | SOX*     | 1     | 337  |
| 70C0           | CONCURRENT ACKNOWLEDGE         | CAK*     | 1     | 337  |
| 70D0           | INTERRUPT ACKNOWLEDGE          | IAK*     | 1     | 337  |
| 70E0           | DATA INPUT                     | DIX*     | 1     | 337  |
| 70F0           | STACK/SPARE INPUT              | SIX*     | 1     | 338  |
| 8000           | ADD FILE                       | ADD*     | 1     | 339  |
| 8040           | INCREMENT FILE                 | INC*     | 1     | 339  |
| 9000           | SUBTRACT FILE, TWOS COMPLEMENT | SBT*     | 1     | 340  |
| 9040           | SUBTRACT FILE, ONES COMPLEMENT | SBO*     | 1     | 340  |
| 9040           | DECREMENT FILE                 | DEC*     | 1     | 341  |
| A000           | READ MEMORY, FULL CYCLE        | RMF*     | 1     | 341  |
| A020           | READ MEMORY, HALF CYCLE        | RMH*     | 1     | 342  |
| A010           | WRITE MEMORY, FULL CYCLE       | WMF*     | 1     | 343  |
| A030           | WRITE MEMORY, HALF CYCLE       | WMH*     | 1     | 344  |
| B000           | COPY                           | CPY*     | 1     | 345  |
| B000           | ZERO FILE/REG.                 | ZOF*     | 1     | 345  |
| B040           | +1 TO FILE/REG.                | POF*     | 1     | 346  |
| C000           | LOGICAL OR WITH FILE           | LOR*     | 1     | 346  |
| C000           | MOVE FILE                      | MOV*     | 1     | 347  |
| D000           | EXCLUSIVE OR WITH FILE         | XOR*     | 1     | 347  |
| E000           | AND WITH FILE                  | AND*     | 1     | 348  |
| F000           | SHIFT FILE LEFT                | SFL*     | 1     | 348  |
| F040           | SHIFT FILE LEFT AND INSERT     | SLI*     | 1     | 349  |
| F020           | SHIFT FILE RIGHT               | SFR*     | 1     | 349  |
| F060           | SHIFT FILE RIGHT AND INSERT    | SRI*     | 1     | 350  |



### **PART V**

# SYSTEM DESIGN PROCEDURES USING MICROPROGRAMMING



### INTRODUCTION

Computer system design is greatly simplified by adherence to a basic sequence of activities. Each step is essential to the overall success. It is necessary to thoroughly simplify subsequent steps and to reduce the amount of revision to previous steps. Many of the procedures listed below appear to be removed from the computer considerations because they deal with the system as a whole. However, it turns out that to obtain full advantage of the cost savings and system enhancement capabilities of a microprogrammable processor it is absolutely necessary to start considering the computer characteristics right at the beginning during the preliminary system functional definition phase.

### **Outline of System Definition Procedures**

1. System Functional Definition:

Operations
Inputs and Outputs
Control Functions
Basic Functional Units/Tasks

### 2. System Configuration Definitions:

System Block Diagram
Basic Data Flow Definition
Subunit Functional Definitions

### 3. Detailed System Performance Specification:

Data Rates Accuracies Data Processing Functions Data Formats Number of Channels Characteristics of Peripheral Devices

### 4. Interface Specifications:

Number of Lines
Data Rates
Interface Procedures
Status Lines
Control Lines
Control Codes
Device Addresses

### 5. Program Specifications:

Processing Functions
Data Rates
Data Characteristics
General Subroutine Definition
Mathematical Function Definition
Nonmathematical Process Definition
Input and Output Data Content and Formats

### 6. Tradeoff Analysis:

Software Firmware Hardware

### 7. Processor and Interface Hardware Specifications:

Architecture Number of Lines

- 8. Software/Firmware Program Specifications.
- 9. Detailed Program Functions, Analysis and Definition:

Top Level flow of System Program
Algorithm Selection and Definition
Memory Allocations
Interface Address and Functions Assignments
Subroutine Hierarchy Definition
Determination of Data Tables, Pointers, etc.
Coding, Assembly
Preparation of Diode Map
Prepare Read Only Memory
Prepare Software Programs (if any)
System Checkout

These steps are considered only in their relation to the programming requirements. There are many other steps related to hardware design and component selection that are not covered here.

To illustrate the preceding points a generalized example of a computer system has been selected. This system would typically be used in a monitor and control system. It has the following functions:

Multichannel Analog Input

**Dual Channel DAC Output** 

High Speed Paper Tape Reader for Entering Programs Locally

Communications Channel for Remote Status Reports

High Speed Printer for Local Status and Data Printout

Status Switch Closure Monitor

Control Relay Output

Operating Mode Control and Status Display Panel

Core Memory for Data and Storage Instruction

Real Time Clock and Power Fail Detect Option

Computer

Read Only Memory

### 1. System Functional Definition

In this section the following functions are defined for the example system:

a. Operational characteristics of system to be controlled:

Block Diagrams
Graphs
Transfer Functions for Control equations
Timing Diagrams for Response Time
Sequence Diagrams for Control Algorithms

b. Function of each Analog Input Channel:

Range Rates Accuracy Relation of Data to System Operation Signal Profile

c. Function of each Analog Control Channel:

Range
Rates
Accuracy
Signal Profile
Effect of Data on System Operation

d. Definition of Status Switches:

Functions Rates to be Monitored Meaning

e. Control Relay Functional Definition

Latch vs. Non Latch Effect of Each Relay on System Operation

f. Communications Requirements

Message Characteristics Data Rates Hand Shaking Procedure Formats

g. Panel Control and Display Functions:

Number and Meaning of Control Switches Quantity, Type and Meaning of Status Displays

h. Printer

Message Formats Printout rate Message Line Size

### 2. System Configuration Definition

The System Block Diagram for the controller is as shown in Figure 40 with basic data flow indicated on the block diagram as well as subunit functional definitions.

### 3. Detailed System Performance Specifications

Typical factors which affect the programming are as follows:

- ADC Conversion Accuracy (Number of Bits)
- ADC Sample Rate, and Conversion Time
- DAC Update Rate
- Code Conversions
- Scaling Requirements
- Curve Fitting Characteristics
- Transfer Function Calculations
- Averaging
- Communication Link Requirements

Rates

Formats

Controllers

Handshaking

Polling Procedures

- Printout Message Requirements
- Processing Variations Relative to Status and Control Panel Inputs
- Control Point Output Requirements
- Initialization of Cold Start Requirements



Figure 40. System Example Block Diagram

### 4. Interface Performance Specifications

After the peripheral hardware has been selected and defined in detail, the specifications for the interface to the computer can be defined. This consists of identifying data, status, and control lines from each peripheral device. Line groupings for each category are established, so they can be most efficiently organized to match the byte I/O characteristics of the computer control and data transfer. Timing and sequence requirements for each interface are also defined. This information is used to help determine the degree of hardware vs. microprogramming to be used for the interface.

### 5. Program Specifications

The program specs define all processing functions. They include a list of all functional subroutines, data processing rates, organization of the executive routine, tables or lists of input and output data categories, and definition of the mathematical, logical, and algorithmic processes to take place, and the order in which these processes occur.

A typical list of routines might be as follows:

- Application Routines
- Cold Start
- Main Loop
- Determine Next Processing State
- Output Analog Control Parameters to DAC's
- Linear Interpolation
- Calculate Basic Control Parameters
- Sample Console Settings
- Sample Analog Parameters and Convert to System Units
- Compute System RPM
- Update System Status Display
- Process Interrupts
- Communications Routine
- Status Message Printout Routine
- Paper Tape Reader Input Routine
- Code Conversion Routine
- System Status Monitor Routine
- Relay Control Update Routine
- Utility Routines (If Microprogram Is Used)
- Multiply
- Store X
- Load X
- Divide
- BCD to binary
- Binary to BCD
- Shift Left N bits
- Shift Right N bits
- Square Root
- Input/Output
- Printout
- Integrate
- Data Average

The general organization of these routines is defined at this stage of analysis, along with an estimate and definition of core memory requirements for flags, buffers, partially processed data, console and status switch memory maps, and system status information.

Also, the processing time for the various routines are estimated and defined along with an estimate of micro instruction requirements.

### 6. Tradeoffs

Before the detailed hardware and program specifications are tied down it is necessary to conduct a tradeoff analysis to assure that the cost/performance requirements for the system are being met. Here the tradeoff is related to application of hardware, firmware, and software to the various internal and interface functions of the computer. The areas of cost reduction to be considered are as follows:

- Interface Hardware Complexity
- New hardware Design Requirements
- Microprogram Size
- Core Memory Requirements
- Complexity of Peripheral Devices
- Availability of Existing Programs
- Program Development Times

A large number of factors must be included in the tradeoff analysis. The most important ones related to program development are listed below:

- Overall data throughput requirements including peak and average data loads.
- Variability of program functions, including operating modes, data formats, status combinations, processing states, number of I/O channels, operating ranges, etc.
- Permanence of program structure, once defined, and need to avoid having to load program on site.
- Speed and complexity of peripheral devices and processing functions.
- Existing standard interfaces, and the extent of microprogramming required for these interfaces.
- Number of systems to be developed and available development time (affecting nonrecurring costs ratio, and development staffing requirements).
- Special processing requirements with high speed or complexity in the fields of arithmetic, logic data manipulation, character assembly, control functions, hand shaking, etc.
- Overall program size.

- Existing standard firmware and software routines which are applicable to the system.
- Operating complexity, maintenance and training requirements.
- System reliability, including failure rates, and equipment redundancy requirements, which may dictate the requirement for self contained hardware functions.

The result of the tradeoff study will be the following:

- Use of sophisticated interfaces not requiring firmware, or use of extremely simple interfaces which do require firmware. (Tradeoff factors: Read only memory capacity for interface functions, speed of data transfer, interface control sequences, available process time.)
- Use of software program for entire operation.
- Use of software program with special I/O or processing routines added to microprogram.
- Development of special instruction set for the application.
- Combined use of special firmware, special hardware interfaces, and special hardware processing functions such as hardware multiply/ divide.

Typical functions which may be completely or partially done by two or three of the following: Software, firmware or hardware, depending on data processing rates, hardware complexity, system throughput requirements, read only memory capacity, thus must have tradeoff analysis applied for selection.

- Serial data character assembly/disassembly
- Card reader control and data transfer
- Binary to BCD or ASCii conversion
- BCD to binary Conversion
- Multiply or divide
- Digital filtering
- Magnetic tape controller functions
- High-speed line printer control
- ADC control and data input
- Message Switching
- Remote monitor functions
- Synchronous modem control
- Image scanning
- Disc controller
- Error detection, and code generation
- Table lookup
- Communications line polling/handshaking
- Console parameter input/scaling

### Tradeoff Examples:

### Example 1

Firmware can be used to interface with a card reader having minimum readout electronics. However if the firmware must monitor the high-speed stroke pulses from the card reader to synchronize with the reader data lines, the firmware becomes too tied down to service other peripherals. Therefore the card reader interface should have some character synch. even with firmware if multiple peripheral devices must operate simultaneously.

### Example 2

Display lamps could be scanned by firmware to avoid using latches to hold display parameters. In a system of any size this will tie up the computer considerably, and the cost of the firmware may be as much as the latches.

### Example 3

Firmware can be used to control a disk without using DMA except for character shifting for transfer to and from the track. However if there is a requirement to simultaneously interface with the disk and another peripheral device, even firmware may not be fast enough.

### 7. Hardware Specs

The hardware specs of interest here are for the interfaces and special processing functions and relate to the programming requirements. They include the following:

- Definition of standard interfaces, including complete identification of data input and output channels, control line functions, status lines, device and function codes, and timing requirements for dynamic data or control lines.
- Definition of special interfaces including all of the factors for standard interfaces plus special control sequences and special data input/output sequences which must be microprogrammed. These definitions must be in terms of the standard control and byte transfer functions of the computer.
- Definition of special processing hardware units, such as hardware multiply/divide, buffers, fast fourier processor, digital filter, etc. Again, the basic interest for this document is the programming required to transfer data and initiate the special processor operation.

### 8. Software or Firmware Program Specifications

These include a detailed functional description of all subroutines, executive routine, data, control, status words, memory requirements, data tables, flags, pointers, etc.

### 9. Detailed Program Functions Analysis Definitions and Programming

The general steps to be followed in the programming phase should be adhered to simplify the entire task and to assure the best program results.

- Top level flow chart
- Detailed algorithm definition
- Memory allocations (data, flags, pointers, etc.)
- Interface address and function tabulation
- Definition of subroutine, hierarchy (looping, branching, nesting).
- Preparation of tables and formats for data, status, flags, pointers, scale factors, address pointers.
- Top level flow charts for subroutines.
- File register assignments.
- Detail subroutine subcharts.
- Coding, assembly, checkout, etc.

These steps are illustrated in the emulator example which follows and in the microprogram subroutine examples in the microprogrammers manual.

The last step consists of converting the flow chart functions into routines that are ready for implementation in hardware to yeild the system firmware. These steps include translating the MICRO 800 instructions selected for each routing into the mnemonic or machine language code, loading them into an operating system, and eliminating any errors that may have been made during the previous steps. Microdata Corporation furnishes a software program (Simulator Operating System) for use on one of the 800 series computers which simulates the user's microprogram and provides operator control for debugging and evaluation procedures. The completed program is printed in the form of a diode map to simplify the placement of diodes on the read only memory circuit boards which contain the complete microprogram.

### Microprogramming Aids

The software aids for microprogramming, furnished by Microdata Corporation are briefly described in Figure 41. Several methods are available to convert the microprogram source statements to the final diode map for hardware implementation. These methods incorporate different programs according to the processing equipment available to the user. For instance, the MAP800 program is used with a MICRO 811 computer to enter source statements and assemble the listings. The AP800 program is used on a large-scale computer to produce an object program. Variations in methods also permit selection of media for recording and communicating the program information including punched cards, paper tape, printed documents, etc.



Figure 41. Microprogramming Generation

The final step in the process is the implementation of the microprogram by loading the signal diodes on the ROM circuit boards. This process consists of inserting diodes in the board at locations designated by the diode map and corresponding to the logical 1's in the machine language code. The absence of a diode indicates a logical 0. When the complete microprogram has been implemented in diodes on the ROM boards, the "new" computer is assembled by inserting these boards into the standard MICRO 800 enclosure which houses the hardware components furnished by Microdata Corporation.

# PART VI PRODUCT CATALOG

### MICRO 400 COMPUTER

The MICRO 400 is a low-cost, high-performance, general-purpose computer designed to fill the gap between conventional minicomputers and special purpose digital hardware. Applications heretofore denied the use of a computer because of high cost can now realize the advantages of a fully programmable processor. With powerful computing ability, a wide range of peripherals and complete support software, the MICRO 400 is truly a systems processor, while its totally modular construction and ease of system integration make it the perfect computer for OEM applications.

Through the use of MSI circuitry and printed circuit packaging techniques, the entire processing unit is contained on a single circuit board, as is the core memory (up to 4096 bytes). All system components are interconnected using a unique MICRObus concept consisting of a single flat cable instead of expensive wired backplanes. This single cable "daisychains" to all system components for simplicity and economy of system expansion.

The modular design of the MICRO 400 means added economy for the OEM user. The central processor, memory modules, peripheral interfaces



### **MICRO 400 COMPUTER**

The MICRO 400 is a low-cost, high-performance, general-purpose computer designed to fill the gap between conventional minicomputers and special purpose digital hardware. Applications heretofore denied the use of a computer because of high cost can now realize the advantages of a fully programmable processor. With powerful computing ability, a wide range of peripherals and complete support software, the MICRO 400 is truly a systems processor, while its totally modular construction and ease of system integration make it the perfect computer for OEM applications.

Through the use of MSI circuitry and printed circuit packaging techniques, the entire processing unit is contained on a single circuit board, as is the core memory (up to 4096 bytes). All system components are interconnected using a unique MICRObus concept consisting of a single flat cable instead of expensive wired backplanes. This single cable "daisychains" to all system components for simplicity and economy of system expansion.

The modular design of the MICRO 400 means added economy for the OEM user. The central processor, memory modules, peripheral interfaces



and control console can be purchased separately on an as-required basis. Thus, the customer may buy only what is actually needed for his specific application.

The net result of these packaging/price/performance breakthroughs is a general purpose, programmable computer at a price which allows use of the MICRO 400 as a digital controller or true systems computer, available in a form tailored to the needs of the OEM customer.

### SPECIFICATIONS SUMMARY

The MICRO 400 in a general purpose digital computer designed for controller, control system, data collection, communications, data terminal and stand alone applications.

### Memory

Magnetic core, 8-bit word length, 1.6 microseconds full cycle, 400 nanoseconds access. Expandable from 1024 to 65,536 bytes. Each memory module contains data and address registers and 1K or 4K bytes of core memory.

### Byte Length

8 bits.

### Addressing

Direct to 4096 bytes Indexed to 65,536 bytes Base register addressing to 65,536 bytes (optional).

### Instructions

118 standard instructions, 49 optional:

| Туре                             | Execution Time (cycles) |
|----------------------------------|-------------------------|
| Load/Store                       | 3                       |
| Arithmetic/Logical               | 1                       |
| Memory Modify/Skip               | 3-4                     |
| Register Transfer                | 1                       |
| Jump/Jump Mark                   | 2-4                     |
| Skip                             | 2-3                     |
| Control                          | , 1                     |
| Input/Output                     | 2                       |
| Load/Store Indexed               | 3                       |
| Index Register Control           | 2                       |
| Base Register Control (optional) | 2                       |

### **Operational Registers**

| Р | Register | program counter, 12 bits     |
|---|----------|------------------------------|
| 1 | Register | instruction register, 8 bits |
| D | Register | holding, 8 bits              |
| X | Register | index, 16 bits               |

MA Register memory address, 12 bits

MD Register memory data, 8 bits

(MA and MD registers are contained within each 1024- or 4096-byte memory block.)

### **Accumulators**

A Register accumulator and input/output, 8 bits
B Register accumulator and input/output, 8 bits

### Input/Output

Programmed Data Transfer:

Single byte to/from both accumulators External control functions, 8 per device External sense functions, 8 per device

Automatic Data Transfer (optional):

Direct Memory Access at 625,000 bytes per second

**Priority Interrupt:** 

One level, standard Eight levels, optional

### Control Panel

Twelve display indicators and data entry switches for all operational registers except I, D and X.

Four control indicators (LINK, OVERFLOW, STEP, and RUN)

Two sense switches

Five control switches (INITIALIZE, STEP, RUN, EXECUTE and ON/OFF)

Note:

The MICRO 400 will operate without the control panel which, if used can be installed up to 2 feet from the processor and is designed for mounting in the OEM user's equipment.

### **Dimensions**

 $\begin{array}{lll} \text{CPU} & \text{One PC board } 12.5^{\prime\prime} \times 18^{\prime\prime} \\ \text{Memory} & \text{One PC board } 12.5^{\prime\prime} \times 18^{\prime\prime} \\ \text{Power Supply} & 19^{\prime\prime} \operatorname{deep} \times 3.5^{\prime\prime} \operatorname{wide} \times 3.25^{\prime\prime} \operatorname{high} \\ \text{Enclosure} & 3.5^{\prime\prime} \operatorname{high} \times 17.5^{\prime\prime} \operatorname{wide} \times 21^{\prime\prime} \operatorname{deep} \\ \end{array}$ 

### Weight

Complete MICRO 400 with power supply, console, 8192 words memory: 23 pounds

MICRO 400 without power supply: 10 pounds

### Power

Requirements

2 amps, 105 VAC to 125 VAC, 47 to 63 Hz, single

phase (other frequencies available on special order)

Dissipation

170 watts (typical)

### **Enclosure**

The basic MICRO 400 enclosure houses the complete computer: CPU board, up to 8192 words of memory, TTY or modem controller, automatic bootstrap loader, MICRObus, base register index module, power fail/restart, priority interrupts, I/O bus, power supply, and operators console. Matching expansion enclosures available for additional memory and I/O controllers.

### Installation

Desk or tabletop mountable Brackets suppled for mounting in standard 19-inch rack

### **Environmental**

Operating Temperature

0°C to 50°C

Storage Temperature

(32°F to 122°F) -40°C to +80°C

Relative Humidity

(-40°F to +176°F) 0 to 90 percent, no condensation

### MICRO 800 COMPUTER

The MICRO 800 is a high-speed microprogrammed computer whose flexibility, functional modularity and system-oriented packaging make it ideally suited for dedicated volume applications.

The MICRO 800's flexibility permits the computer system to be expanded or reduced to the exact configuration needed for any application. For example, the computer can be used without a core memory as an inexpensive controller or data concentrator. When memory is required for storage of variable parameters, tables or data, high-speed core memory may be added to the system.

The MICRO 800 also can be microprogrammed to emulate other general or special-purpose computers enabling the software of these machines to be compatible with the MICRO 800. In such a case, additional interface hardware can be furnished to provide plug-to-plug compatibility with other computers.

In addition to low unit cost, the MICRO 800 system also can reduce overall system cost. The high-speed execution of firmware routines allows the processor logic to be time-shared to minimize input/output interface hardware.



Microprogramming also provides exceptionally high performance with an unusually small amount of internal hardware. The basic computer consists of two identical data boards, each of which is a 4-bit slice of the computer's data paths and registers, and a single control board which provides command decoding and timing.

Main frame options including memory parity, power fail/automatic restart, real-time clock and input/output interfaces are implemented on card modules which plug into the basic MICRO 800 enclosure.

With its 1.1 microsecond core memory cycle time and 220 nanosecond command execution time, the MICRO 800 is the fastest machine in its class. Core memory is expandable from 0 to 32,768 bytes in 4,096 byte or 8192 byte increments. A 1,024 byte core memory also is available for small, inexpensive systems. Weight is 75 pounds.

### MICRO 810 COMPUTER

The MICRO 810 is a general purpose computer which is a microprogrammed adaptation of the MICRO 800. Microprogrammed subroutines, configured in the read only memory, interpret macro instructions of programs stored in the core memory.

A powerful macro level computer, the MICRO 810 also retains all the modular and functional advantages of the MICRO 800.

The MICRO 810 has available considerably larger programs than most machines in its class, combined with ease of programming and programming flexibility. Some of the advantages of the MICRO 800 can be obtained by adding problem-oriented instructions or firmware subroutines to the MICRO 810. Multiply/divide instructions are standard.

The MICRO 810 features 1.1 microsecond cycle time and 220 nanosecond execution time in the ROM. Core memory is field-expandable to 32,768 Bytes (8, 9 or 10 bits). Extra memory bits may be used for memory parity and special applications. A 1024-byte by 9-bit core memory also is available. Weight is 75 pounds.

### **MICRO 820 COMPUTER**

The MICRO 820 is a high-speed microprogrammed general-purpose computer that provides a comprehensive instruction repertoire and a powerful input/output facility. System architecture is byte oriented. This allows variable precision operations and character manipulation to be highly efficient in both speed and memory utilization.

The MICRO 820 system is designed to accommodate additional standard and special firmware inexpensively, thereby permitting the user to specify augmented capabilities such as multiply/divide instructions, BCD arithmetic, floating point arithmetic, trigonometric and transcendental functions, and fully buffered communication multiplexers.

### STANDARD FEATURES

Variable precision operations Character/string manipulation

Stack processing

Memory addressing to 32,768 bytes 4096 and 8192 byte plug-in memory modules 32,768 bytes of memory in basic enclosure 1.1 microsecond memory cycle time

Six operational registers
Accumulator (A) 16 bits
Auxiliary accumulator (B) 16 bits
Index register (X) 16 bits
Program counter (P) 15 bits

Overflow (O) 1 bit

Word length control (W) 2 bits

Comprehensive instruction set including 102 basic operations

Control (16)

Multi-bit arithmetic and logical shifts (12)

Conditional jumps (17)

Input/Output (6)

Inter-register (19)

Stack control (8)

Character/string manipulation (4)

Memory reference including jump, compare and variable word length operations (20)

Eight operand addressing modes

Direct to page 0 (first 256 bytes)

Direct relative to P (± 128 bytes)

Indirect to page 0 (first 256 bytes)

Indirect relative to P (± 128 bytes)

Indexed (to 32,768 bytes)

Indexed with bias (to 32,768 bytes)

Extended address (to 32,768 bytes)

Literal

Multi-precision 1, 2, 3 or 4 byte load, store and arithmetic operations

Flexible I/O facilities

Programmed transfers to/from A register, B register and memory

Concurrent buffered I/O

Direct memory access

Expandable priority interrupt system

**Processor options** 

Real-time clock

Power-fail detect and automatic restart

Built-in bootstrap loader in non-volatile read-only memory

Standard supplied software

Loaders

Teletype debug and operating system

Two pass assembler

Text editor

Diagnostics

Optional Software Available

"Basic" programming language

Executive program

File management program

Data management program

TTL integrated circuitry

Power: 115/230 vac, 47-63 cycle, 380 watts

Environment: 0-50°C

Dimensions: 8% inches high, 19 inches wide, 23 inches deep

## MICRO 800 SERIES COMPUTER SYSTEM ELEMENTS AND OPTIONS

### Magnetic Core Memory

| ltem | Description                                          |
|------|------------------------------------------------------|
| 8218 | 1,024 Byte (8 bit) core memory module. (P/N10001040) |
| 8208 | 4,096 Byte (8 bit) core memory module. (P/N 1000588) |
| 8288 | 8,192 Byte (8 bit) core memory module. (P/N1000925)  |

### **Central Processor Options**

| ltem | Description                                                                                                                       |
|------|-----------------------------------------------------------------------------------------------------------------------------------|
| 8413 | Power Fail/Auto-Restart, and Real Time Clock (P/N0594004)                                                                         |
| 8421 | Communications Multiplexer (firmware) Power Fail/Auto-Restart, Reat Time Clock, and Communications Rate Generators. (P/N10001038) |

### General Purpose and Utility Interfaces

| Item | Description                                                                                                                                                                                                                                                                                    |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8920 | Teletype Controller and Interface, employs serial/parallel conversion and buffering, transfers are programmed control. (P/N0813002)                                                                                                                                                            |
| 8722 | General Purpose Wire-Wrap Board including 64 each 16-pin sockets and 6 each 24-pin sockets, occupies one Input/Output slot. (P/N1000755)                                                                                                                                                       |
| 8703 | Priority Interrupt Board, provides eight levels of priority interrupt expansion with individual arm/disarm and request storage. (P/N1000781)                                                                                                                                                   |
| 8704 | Direct Memory Access (DMA)—Selector channel, block or multiple buffer modes, includes end of transfer interrupt, will accommodate up to four devices. (P/N1000833)                                                                                                                             |
| 8705 | General Purpose I/O Interface—provides 32 input and 32 output lines under program control: can be used for interfacing incremental tape drives, MUX-ADC's, DAC's and other low speed peripheral devices. (P/N0637001)                                                                          |
| 8710 | General Purpose Byte I/O System, provides independent Input/Output controllers each with 8-bit data transfers in the programmed, concurrent I/O or interrupt modes. Is used as interface for paper tape reader and punch, buffered line printer, and character oriented devices. (P/N10001033) |

| 8705                      | General Purpose I/O Interface—provides 32 input and 32 output lines under program control: can be used for interfacing incremental tape drives, MUX-ADC's, DAC's and other low speed peripheral devices. (P/N0637001)                                                                                                                                                                                                                                |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8710                      | General Purpose Byte I/O System, provides independent Input/Output controllers each with 8-bit data transfers in the programmed, concurrent I/O or interrupt modes. Is used as interface for paper tape reader and punch, buffered line printer, and character oriented devices. (P/N10001033)                                                                                                                                                       |
| Communications Interfaces |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Item                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 8800                      | Full Duplex Synchronous Modem Interface, provides dual independent control for the transmission and receiving elements of synchronous modems operating up to 9600 baud. Each control element includes programmed, concurrent I/O, and interrupt data transfer modes. The unit will accommodate programmed sync patterns 5, 6, 7, or 8-bit character size, and standard baud rates to 9600. Interface signals are EIA Standard RS-232-C. (P/N1000825) |
| 8801-1                    | Synchronous Modem Interface with Auto-Call/Answer unit provides full duplex operation in the programmed transfer mode or half full duplex operating in the concurrent I/O mode with 201 Series modems or other synchronous modems up to 9600 baud with EIA Standards RS-232-C levels. (P/N1000858)                                                                                                                                                   |
| 8803-1                    | Eight Channel Low Speed Modem Interface—provides eight full duplex RS-232-B interfaces. (P/N0437001)                                                                                                                                                                                                                                                                                                                                                 |
| 8803-2                    | Sixteen Channel Low-Speed Modem Interface—provides sixteen full duplex RS-232-B interfaces. (P/N0437002)                                                                                                                                                                                                                                                                                                                                             |
| 8803-3                    | Eight Channel Low-Speed Modem Interface—provides eight full duplex RS-232-B interfaces and modem control interfaces. (P/N0437003)                                                                                                                                                                                                                                                                                                                    |

- 8804-1 Eight channel teletype control-provides eight full duplex 20ma teletype interfaces. (P/N0496001) 8804-2 Sixteen channel teletype control—provides sixteen full duplex 20ma teletype interfaces. (P/N0496002) 8805 Four Channel Communications Interface and character buffered Controller, provides simultaneous operation of four full duplex asynchronous lines with four independent controllers. Each controller is programmable for eight combinations of baud rate from 75 to 2400 and character lengths from 7.5 to 10 bits. EIA Standard RS-232-C or teletype 20ma current loop can be selected. (P/N1000991) 8806 Eight Channel Communications Interface and character buffered Controller provides simultaneous operation of 8 full duplex asynchronous lines. Eight combinations of baud rate from 75 to 2400 and character lengths from 7.5 to 10 bits can
- Teletype 20ma current loop can be selected. (P/N1000994)

  8807 Automatic Call Unit Interface and Controller, provides control functions for either four Bell Model 801 Automatic Call Units or one 16-channel single port unit with EIA Standard RS-232-C Interface Levels. (P/N1000829)

be selected, will apply to all 8 lines. EIA Standard RS-232-C or

### Peripheral Device Interfaces

| Item   | Description                                                                                                                                                                                                                                                                               |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8941   | Line Printer. 80 column, 64 character set, 150 LPM. Cables and output controller included.                                                                                                                                                                                                |
| 8942   | Line Printer. 132 column, 64 character set, 250 LPM. Cables and output controller included.                                                                                                                                                                                               |
| 8955   | Disc System including: disc drive with moving head removable cartridge, 2.4 million bytes, 75ms average random access, 200 KC byte transfer rate, 63" computer cabinet, cables, DMA selector channel and I/O controller. Requires two assembly slots in the computer.                     |
| 8956   | Disc System including: disc drive with moving head, one fixed plus one removable cartridge, 4.9 million bytes, 95ms average random access, 200 KC byte transfer rate, 63" computer cabinet, cables, DMA selector channel and I/O controller. Requires two assembly slots in the computer. |
| 8960   | Magnetic Tape System consisting of I/O controller which will accommodate up to four magnetic tape transports, cables, one transport; 7" reel, 12.5 IPS, 9 track, 800 BPI, read-write dual gap head, transfer rate is 10,000 bytes/see via concurrent I/O channel.                         |
| 8960-7 | Same as 8960 above, transport is 7 track.                                                                                                                                                                                                                                                 |

- Magnetic Tape System consisting of I/O controller which will accommodate up to four magnetic tape transports, cables, one transport; 7" reel, 25 IPS, 9 track, 800 BPI, read-write dual gap head, transfer rate is 20,000 bytes/sec via concurrent I/O channel.
- 8961-7 Same as 8961 above, transport is 7 track.
- Magnetic Tape Transport, 7" reel, 12.5 IPS, 9 track, 800 BPI, read-write dual gap head. (P/N A20002820)
- 2820-7 Magnetic Tape Transport, 7" reel, 12.5 IPS, 7 track, 800 BPI, read-write dual gap head. (P/N A20002820-1)
- Magnetic Tape Transport, 7" reel, 25 IPS, 9 track, 800 BPI, read-write dual gap head. (P/N A20002821)
- 2821-9 Magnetic Tape Transport, 7" reel, 25 IPS, 7 track, 800 BPI, read-write dual gap head. (P/N A20002821-1)
- 8971 Card Reader, Cable and Input Controller. 300 CPM, 80 column cards, 1,000 card hopper, 1,000 card stacker. Controller occupies one computer assembly slot.
- Paper Tape System consisting of: 300 CPS fanfold 8-channel paper reader, 75 CPS fanfold 8-channel paper tape punch, cables, and I/O controller. Unit is rack mountable 10.5" space, I/O interface occupies one computer assembly slot.

#### **MICRO 1600 COMPUTER**

Newest and most advanced of Microdata Corporation's families of computers is the MICRO 1600, a companion product line to the MICRO 800 which provides significant performance improvements in both speed and function.

Both the 1600 and 800 are functionally compatible, enabling established MICRO 800 users to use the 1600 directly without redevelopment of firmware, software or system peripherals or interfaces.

However, new and revised firmware can achieve significant performance improvements at both the micro and macro levels of programming.

The MICRO 1600 is an economical machine with unequalled flexibility which can be tailored to fit almost any application. Modular design of core memory, processor, microprogram control memory and input/output modules provides easy, economical expansion of all functional areas of the computer.

Extra space and power in the basic enclosure permits growth from a minimum to a fully expanded configuration without the need for special or expansion enclosures. User-designed interfaces can be installed in the computer cabinet.

The widest range of hardware, firmware and software options in the industry is available to augment the MICRO 1600.

Improved features of the MICRO 1600 are higher speed, processor options which are part of the CPU, additional general-purpose registers, control memory expansion to 16,384 words, core memory expansion to 65,000 words, dual processor capability, memory data buffer, data output buffer, memory address link bit and expanded control panel facilities. This is accomplished through maximum use of the most advanced MSI and LSI technology.

Control memory cycle time is 1 microsecond, 200 nanosecond command execution rate.



#### MICRO 1600/21 COMPUTER

The MICRO 1600/21 offers economy, high speed, microprogrammed architecture and flexibility through which the user can tailor the machine to his specific requirements.

Featuring a comprehensive instruction repertoire and efficient input/output, the MICRO 1600/21's system architecture is byte-oriented, resulting in highly variable precision operations and character manipulation.

Efficient utilization of core memory and high throughput are achieved by the use of a large repertoire of macro instructions. High-speed read-only control memories reduce the number of CPU circuits which otherwise would be needed for the MICRO 1600/21's instructions. The system uses TTL monolithic integrated circuits, including a large number of medium and large-scale integration types.

Modular design of core memory, read-only memory, processor options and input/output elements permits inexpensive system expansion within the compact basic enclosure.

#### STANDARD FEATURES

Variable precision operations

Character/string manipulation

Stack processing

Memory addressing to 32,768 bytes

4096 and 8192 byte plug-in memory modules 32,768 bytes of memory in basic enclosure

1.0 microsecond memory cycle time

Six operational registers

Accumulator (A) - 16 bits

Auxiliary accumulator (B) - 16 bits

Index register (X) - 16 bits

Program counter (P) - 15 bits

Overflow (0) - 1 bit

Word length control (W) -2 bits

Extensive, powerful instruction set including 107 different operations:

Control (16)

Multi-bit arithmetic and logical shifts (12)

Conditional jumps (17)

Input/Output (6)

Inter-register (19)

Stack control (8)

Character string manipulation (5)

Multiply/divide (2)

Decimal arithmetic (add and subtract instructions) (2)

Memory reference including jump, compare and variable word length operations (20)

Eight operand addressing modes, including:

Direct to page 0 (first 256 bytes)

Direct relative to P (±128 bytes)

Indirect to page 0 (first 256 bytes) Indirect relative to P (±128 bytes)

Indexed (to 32,768 bytes)

Indexed with bias (to 32,768 bytes)

Literal

Multi-precision 1, 2, 3 or 4-byte load, store and arithmetic operations

Flexible I/O facilities including:

Programmed transfers to/from A register, B register and memory

Concurrent buffered I/O

Direct memory access

Expandable priority interrupt system

Standard power fail detect automatic restart and interrupt

Optional Real-time clock

Built-in bootstrap loader in nonvolatile read-only memory .

Standard software, including:

Loaders

Teletype debug and operating system

Two-pass assembler

Text editor

Diagnostics

Power: 115/230 vac ±10%, 47-63 Hz, Average Configuration less than 400

watts

Environment: 0-50 C

Dimensions: Table-top configuration, 10½ inches high, 19 inches wide, 20

inches deep

# MICRO 1600 COMPUTER SERIES SYSTEM ELEMENTS AND OPTIONS

## **Packaging**

| Item | Description                                                                                                                                                                                 |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2001 | Rack mountable enclosure for:  24 inch Cabinet (P/N A20002001)  26 inch Cabinet (P/N A20002001-1)  28 inch Cabinet (P/N A20002001-2)  30 inch Cabinet (P/N A20002001-3)                     |
| 2002 | Table top enclosure (P/N A20002002)                                                                                                                                                         |
| 2003 | Rack Mounting Hardware for nonenclosed Card Cage for: 24 inch Cabinet (P/N A20002003) 26 inch Cabinet (P/N A20002003-1) 28 inch Cabinet (P/N A20002003-2) 30 inch Cabinet (P/N A20002003-3) |
| 2004 | Computer Cabinet, 63" Vertical Height X 19" wide X 24" deep; full length rear door, desk height work surface front, and 300 CFM blower.                                                     |

## **Control Panels**

| Item | Description                                                                                                                                                        |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2101 | Basic panel with run-halt indicators, four sense switches, six control switches, power switch. (P/N A2002101)                                                      |
| 2102 | System Panel, includes Run-Halt Indicators, four Sense Switches, six Control Switches, Power Switch, Register Display, and 16-bit Switch Register. (P/N A20002102) |

## Magnetic Core Memory

| ltem | Description                                           |
|------|-------------------------------------------------------|
| 2204 | 4096 Byte (8 Bit) Core Memory Module (P/N A20002204)  |
| 2208 | 8192 Byte (8 Bit) Core Memory Module (P/N A20002208). |

## **Control Memories**

| Item                | Description                                                                                                                                                                                                                                 |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>2310</b> -nnnn . | Programmed read only memory (PROM) with customer supplied firmware.                                                                                                                                                                         |
| 2320-nnnn           | Bipolar read only memory (BROM) with customer supplied firmware.                                                                                                                                                                            |
|                     | Customer supplied firmware to be submitted to Microdata in the form of card deck output, AP1600, or paper tape output, MAP1600, assembly programs. PROM and BROM may be intermixed both within systems and on single P.C. board assemblies. |
| 2330-1              | Firmware Set/11, 512 words BROM (bipolar read only memory) (P/N A20002330-1)                                                                                                                                                                |
| 2330-2              | Firmware Set/10, 768 words BROM (Bipolar Read Only Memory) (P/N A20002330-2)                                                                                                                                                                |
| 2331-1              | Firmware Set/20, 768 words BROM (Bipolar Read Only Memory) (P/N A20002331-1)                                                                                                                                                                |
| 2331-2              | Firmware Set/21, 1024 words BROM (Bipolar Read Only Memory) (P/N A20002331-2)                                                                                                                                                               |
| 2380-1              | Alterable Read Only Memory (AROM), 512 words. (P/N A20002380-1)                                                                                                                                                                             |
| 2380-2              | Alterable Read Only Memory (AROM), 1024 words (P/N A20002380-2)                                                                                                                                                                             |
| 2381                | Alterable ROM control panel and cooling unit (P/N A20002381-2)                                                                                                                                                                              |
| 2382                | Alterable ROM power supply provides power for two 2380 AROM modules.                                                                                                                                                                        |
| Central Proces      | esar Ontions                                                                                                                                                                                                                                |

## **Central Processor Options**

| Item | Description                     |  |
|------|---------------------------------|--|
| 2401 | Real time clock (P/N A20002401) |  |

## **General Purpose and Utility Interfaces**

| Item | Description                                                                                                                                                          |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2500 | General purpose wire wrap board accommodates up to 135 units of 14 or 16 pin IC sockets or 24 units of 24 pin IC sockets. Requires 2 assembly slots. (P/N 1000 1058) |
| 2501 | General purpose I/O wire wrap board including 64 each 16 pin sockets and six each 24 pin sockets; occupies one I/O slot. (P/N A20002501)                             |
| 2502 | I/O cable (10 feet) and connector. (P/N A20002502)                                                                                                                   |

| 2510 | Byte I/O Controller provides independent input controller and output controller each with eight-bit data transfers operating in the programmed concurrent I/O or interrupt modes. (P/N A20002510) |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2511 | Full word I/O interface provides 32 input lines and 32 output lines; data transfers are under program control. (P/N A20002511)                                                                    |
| 2512 | Priority Interrupt Board provides eight levels of priority interrupt with individual arm/disarm. (P/N A20002512)                                                                                  |
| 2513 | Selector channel operates via direct memory access (DMA); will accommodate up to four I/O devices. (P/N A20002513)                                                                                |

## **Communications Interfaces**

| Item | Description                                                                                                                                                                                                                                                                                              |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2600 | Full duplex synchronous modem interface and control operating in programmed, concurrent I/O and interrupt data transfer modes, accommodates standard rates up to 9600 baud, EIA Standard RS-232-C. (P/N A20002600)                                                                                       |
| 2601 | Synchronous modem interface with auto-call/answer unit operating full duplex in the programmed transfer mode or half-full duplex in the concurrent I/O mode. Accommodates standard rates up to 9600 baud, EIA Standard RS-232-C levels. (P/N A20002601)                                                  |
| 2610 | Asynchronous communications controller and interface. Transfers are programmed, concurrent I/O or interrupt or input character ready. Standard rates from 110 to 9600 baud and EIA standard RS-232-C or 20ma current loop interface are to be specified at time of order. (P/N A20002610)                |
| 2611 | Four-channel communications interface and controller provides simultaneous operation of four full duplex asynchronous lines. Each channel is programmable at rate from 75 to 2400 baud. EIA standard RS-232-C or teletype 20ma current loop can be selected. (P/N A20002611)                             |
| 2612 | Eight-channel communications interface and controller provides simultaneous operation of eight full duplex asynchronous lines. Standard rates from 75 to 2400 baud can be selected — will apply to all eight lines. EIA standard RS-232-C or teletype 20ma current loop can be selected. (P/N A20002612) |
| 2620 | Modem/communications control provides 16 discrete inputs and 16 discrete outputs, EIA standard RS-232-C interface. (P/N 0437002)                                                                                                                                                                         |
| 2630 | Automatic call unit controller provides control functions for four Bell Model 801 automatic call units, EIA standard RS-232-C interface levels. (P/N 10002630)                                                                                                                                           |

## **Peripheral Systems**

| Item   | Description                                                                                                                                                                                                                                                                               |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2710   | Paper tape system consisting of: 300 CPS fanfold 8-channel paper reader, 75 CPS fanfold 8-channel paper tape punch, cables, and I/O controller. Unit is rack mountable 10.5" space, I/O interface occupies one computer assembly slot. (P/N A20002710)                                    |
| 2720   | Card reader, cable and input controller. 300 CPM, 80 column cards, 1000 card hopper, 1000 card stacker. Controller occupies one computer assembly slot. (P/N A20002720)                                                                                                                   |
| 2731   | Line printer, 80 column, 64 character set, 150 LPM. Cables and output controller included. (P/N A20002731)                                                                                                                                                                                |
| 2732   | Line printer. 132 Column, 64 character set, 250 LPM. Cables and output controller included. (P/N A20002730)                                                                                                                                                                               |
| 2810   | Magnetic tape system consisting of I/O controller which will accommodate up to four magnetic tape transports, cables, one transport; 7 inch reel, 12.5 IPS, nine track, 800 BPI, read-write dual gap head, transfer rate is 10,000 bytes/sec via concurrent I/O channel. (P/N A20002810)  |
| 2810-7 | Same as 2810 above, transport is 7 track. (P/N A20002810-7)                                                                                                                                                                                                                               |
| 2811   | Magnetic tape system consisting of I/O controller which will accommodate up to four magnetic tape transports, cables, one transport; 7 inch reel, 25 IPS, nine track, 800 BPI, read-write dual gap head, transfer rate is 20,000 bytes/sec via concurrent I/O channel. (P/N A20002811)    |
| 2811-7 | Same as 2811 above, transport is seven track. (P/N A20002811-7)                                                                                                                                                                                                                           |
| 2820   | Magnetic tape transport, 7 inch reel, 12.5 IPS, nine track, 800 BPI, read-write dual gap head. (P/N A20002820)                                                                                                                                                                            |
| 2820-7 | Magnetic tape transport, 7 inch reel, 12.5 IPS, seven track, 800 BPI, read-write dual gap head. (P/N A20002820-1)                                                                                                                                                                         |
| 2821   | Magnetic tape transport, 7 inch reel, 25 IPS, nine track, 800 BPI, read-write dual gap head. (P/N A20002821)                                                                                                                                                                              |
| 2821-7 | Magnetic tape transport, 7 inch reel, 25 IPS, seven track, 800 BPI, read-write dual gap head. (P/N A20002821-1)                                                                                                                                                                           |
| 2851   | Disc system, including disc drive with moving head removable cartridge, 2.4 million bytes, 75 ms average random access, 200 KC byte transfer rate, 63 inch computer cabinet, cables, DMA selector channel and I/O controller. Require two assembly slots in the computer. (P/N A20002851) |

2852

Disc system, including disc drive with moving head, one fixed plus one removable cartridge, 4.9 million bytes, 95 ms average random access, 200 KC byte transfer rate, 63 inch computer cabinet, cables, DMA selector channel and I/O controller. Requires two assembly slots in the computer. (P/N A20002852)

## Standard Software Packages

| Item        | Description                                                                         |
|-------------|-------------------------------------------------------------------------------------|
| AP1621      | Cross assembler written in FORTRAN for operation on numerous large-scale computers. |
| MAP1621     | Machine language symbolic assemblers for use on MICRO 1600/21 computer.             |
| TOS1621     | Teletype operating system.                                                          |
| TED1621     | Tape editor.                                                                        |
| Diagnostics | CPU, memory and peripheral interface diagnostics for MICRO 1600/21 computer.        |

#### FIRMWARE TRAINING SYSTEM

The firmware trainer is a valuable tool for classroom teaching of microprogramming techniques. Small firmware routines can be quickly set up and checked out with the aid of the comprehension switch panel layout and the built-in visual display. Firmware alterations and corrections are made quickly and efficiently, permitting the student to concentrate on the problem rather than the hardware.

The system consists of a MICRO 800 computer with a utility read-only memory, a switch matrix read-only memory, a 4096 byte magnetic core memory, a TTY/display controller and an I/O display panel.

The MICRO 800 computer includes a special interface wired to a panel with 512 switches. Each switch connects a diode to the computer to designate a logical 1 for binary values of the microprogram command sequence. A maximum of 32 commands may be used at one time on the panel.

As an aid in demonstration and training activities, the preprogrammed utility ROM is included to facilitate input/output functions without expending instructions on the ROM switch panel. Six utility routines are included to permit display and recording of data obtained during execution of microprograms.

A 30-page operations manual and 50 copies of the microprogramming handbook are included with the firmware trainer system. Price for the system is \$10,000.





#### MICROPROGRAMMING SYSTEM

Microdata's Microprogramming System is designed for users who wish to develop firmware for either the MICRO 800 or MICRO 1600 computers.

The system includes a Model 1600/21 general-purpose computer with 8192 bytes of core memory; a 1024-word alterable read-only memory; an alterable read-only memory control unit, and an ASR teleprinter interface. The system is available on a short-term rental basis to customers requiring its use for short periods of time.

The basic system provides adequate power and cooling for significant memory expansion without modifying the system, and will accommodate up to 32,768 bytes of main core memory, an additional 1024 words of alterable ROM and up to 4096 words of fixed ROM. In addition, several I/O interface boards can be included which can add a dynamic dimension to the system.

#### CONTROLS

Three control switches are used to operate the Microprogramming System. They are the Link Control Switch, Manual Operate switch and Control Mode switch. Each has two operational positions.

The Link Control switch operates at the combined or separate setting. In MICRO 800 applications, arithmetic and addressing functions are combined in one link bit, making necessary use of the combined setting. The combined setting must also be used in the MICRO 1600/21 to operate the load/verify mode.

The separate setting is used for MICRO 1600 operation, since this computer has two separate link bits — one for arithmetic and one for addressing.

The Manual Operate switch can be set for load/verify or execute. When the switch is set in the load/verify position, the AROM is connected as an I/O device to the MICRO 1600/21.

The Control Mode switch can be positioned at manual or program settings. When the switch is in the manual mode setting, it enables the Manual Operate switch, at which time either load/verify or execute modes can be selected. When the Control Mode switch is in the program position, commands in the computer under program control automatically select the load/verify or execute mode.

#### **OPERATIONAL MODES**

The AROM section of the system is operated in two basic modes — as an I/O device in the load verify mode or as integral control memory in the execute mode. Starting addresses of AROM modules can be strapped to "0000" for new computer architecture developments starting from scratch or the address can be set to the next sequential address from existing fixed control memory which is to be supplemented. An example of supplementary firmware development would be the addition of high-level

mathematical instructions to the MICRO 1600/21 instruction set or the addition of an application-oriented high-speed data channel.

When used in application as a dynamically changeable extension of fixed ROM architecture or as a completely independent new architecture the AROM load verify or execute modes are set by I/O commands. Typical operation of load AROM from disc and change control to AROM is implemented initially by a software program in the fixed ROM. Control change back to fixed ROM programs depends on specific application requirements or system hardware reset.

## **Load/Verify Operations**

The I/O section of the Microprogramming System interfaces to the byte I/O channel of the computer and obeys all the rules for a MICRO 1600/21 I/O device. The unit is designed to handle programmed I/O transfers only (i.e., concurrent and interrupt modes are not provided). Thus, if MICRO 1600/21 firmware is provided in the fixed read-only memory of the system, then load/verify operations involving the AROM are handled using normal MICRO 1600/21 byte I/O instructions.

#### Addressing

When operating as control memory in the execute mode, the AROM memory section receives addresses from the L counter (microprogram location) and places the contents of that location on the R bus (microcommand bus). The absolute address of the first word on the board may be selected to be anywhere between 0000-2048<sub>10</sub> at increments of 256 words (i.e., 0, 256, 512, etc.). The unit is pre-etched to have its starting location at 0. However, by changing appropriate jumper connections, the starting address may be set as described. All memory locations on a single AROM module are contiguous.

## **Control Memory Operation**

The unit interfaces to the timing and control circuits of the MICRO 1600 via the L counter and R bus. The L counter supplies a 12-bit address specifying the location of a microcommand word to be read from control memory. The microcommand read from memory is placed on the R bus for execution by the CPU control. The upper three bits of the L counter input are strappable, permitting the first word in the random access memory to be addressed at any increment of 256<sub>10</sub> up to 2048<sub>10</sub>. When the unit is not being addressed by the L counter, there is no output to the R bus.

Circuitry is provided to recognize when the AROM is being accessed for a control word, and an I/O inhibit signal is generated to prevent any I/O operation from taking place via the byte I/O bus. Therefore, the microcommands contained in the AROM cannot be used to access the AROM via the byte I/O bus (i.e., the program in AROM cannot access itself); thus, all I/O operations affecting the AROM must be contained in another control memory module.

Control memory operations of the AROM are completely transparent to the system. There is no functional difference between microprogram control operations and those of another form of control memory.

The I/O instructions recognized by the AROM are as follows:

| Instruction                                                           | Operation                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IBA 0,31<br>OBA 1,31<br>IBA 1,31<br>OBA 2,31<br>OBA 3,31<br>OBA 4,31* | Transfer upper data byte (Bits 8-15) to AROM. Transfer upper data byte (Bits 8-15) from AROM. Transfer lower data byte (Bits 0-7) to AROM. Transfer lower data byte (Bits 0-7) from AROM. Load upper AROM address byte (Bits 8-10) Load lower AROM address byte (Bits 0-7) Load Verify, enable AROM I/O; Disable R Bus. |
| OBA 5,31*                                                             | Execute, enable R Bus; Disable AROM I/O.                                                                                                                                                                                                                                                                                |

\*If the system is operating in the manual mode, these commands cannot be executed by the computer. The position in which load/verify and execute switches are placed forces the functions indicated.

#### Alterable Read-Only Operating System

The unit is also supplied with an operating program called AROS (Alterable Read-Only Operating System).

AROS is combined with a comprehensive firmware development and software package.

Included in this package are:

MAP 1600 and MAP 800 micro language assemblers.

SIM1600 or SIM800 for micro simulation.

ICM1600 or ICM800 integrated circuit memory MAP generators which supply control memory bit patterns for implementing fixed integrated circuit ROM's.





## Microdata

Microdata Corporation 644 East Young Street Santa Ana, California 92705 (714) 540-6730 TWX: 910-595-1764