# COO-3077-157

# Courant Mathematics and Computing Laboratory

U.S. Department of Energy

# The Structure of the Puma Computer System Overview and the Central Processor

Ralph Grishman

U.S. Department of Energy Report

Prepared under Contract EY-76-C-02-3077 with the Office of Energy Research

Mathematics and Computing November 1978



COO-3077-157

New York University

Courant Mathematics and Computing Laboratory New York University

Mathematics and Computing COO-3077-157 THE STRUCTURE OF THE PUMA COMPUTER SYSTEM Overview and the Central Processor

Ralph Grishman

November 1978

U. S. Department of Energy

Contract EY-76-C-02-3077

UNCLASSIFIED

...

·

## CONTENTS

|    |                                         | Page |
|----|-----------------------------------------|------|
| 1. | Project objectives                      | 1    |
| 2. | A chronology                            | 3    |
| 3. | System structure                        | 5    |
| 4. | Central processor structure             | 7    |
| 5. | Microprogramming the PUMA               | 29   |
| 6. | The microprogram for CDC 6600 emulation | 46   |

© Copyright 1978, Ralph Grishman

.

#### 1. Project objectives

Because of the rapidly decreasing cost of digital electronics, it has become possible in the last few years to assemble substantial digital computing elements at a modest component cost. In 1974, in response to these continuing hardware developments, we considered several possible digital design projects; we felt that such a project could develop a valuable expertise at the Courant Computing Laboratory and produce a useful product. We selected as our project an emulator for the Control Data 6600 central processor.

This choice was based on several considerations. Emulation of an existing machine would make a large amount of software immediately available. The CDC 6600, in addition to being available at the Laboratory, has a simple instruction set which is therefore easy to emulate. Finally, the projected materials cost for the project was relatively low. For a machine with perhaps half the computing power of a 6600, the estimated cost (exclusive of peripherals) was roughly \$100,000 — about 2 or 3% of the original price of a 6600. Because of further decreases in component prices since then, the total cost for components and wiring of circuit boards proved to be somewhat lower (in the vicinity of \$65,000 for a machine with one million bytes of memory).

Low component costs are not very helpful unless manpower expenditures can be kept comparably low. This can be done only through a highly automated system for design, assembly, and testing. A large part of the project effort has been invested in developing such a system. Using this system, all circuits are thoroughly simulated prior to assembly; wiring lists are prepared by machine and circuit boards are wired automatically; assembled boards are tested by comparison with a simulated circuit. This system is described in detail in a separate report.

The system we have built has been dubbed the PUMA Computer System. Officially, PUMA is an acronym for Processing Unit with Microprogrammed Arithmetic, but the name is also intended to convey the grace of its design and the power of the system. As of the issuance of this report (Nov. 1978), PUMA serial number 1 has been running programs on a limited production basis for about four months and construction has begun on serial number 2. A briefy chronology of the PUMA project is given in Chapter 2.

This report focusses primarily on the structure of the PUMA system at the register and microprogram level. Chapter 3 briefly describes the overall system structure, while Chapter 4 goes into much greater detail regarding the central processor. Chapter 5 describes the microprogramming language of the PUMA, and can serve as an introduction for the microprogrammer. Finally, Chapter 6 presents the microprogram for emulation of the Control Data 6600.

# 2. <u>A Chronology</u>

<u>1974</u>

| July 1  | brief initial proposal circulated              |
|---------|------------------------------------------------|
| Oct. 14 | more detailed proposal, with some microcode    |
|         | sequences, prepared                            |
| Nov. 8  | proposal presented at Computer Science Seminar |

| through May | microprogram revised and completed              |  |
|-------------|-------------------------------------------------|--|
|             | 4-bit ECL slice, used as decimal counter, wired |  |
| June        | J. Fisher joins project                         |  |
|             | chip-level design of arithmetic unit (AU)       |  |
|             | circuit simulator coded and tested              |  |
| July        | ECL slice tested at 30 MHz                      |  |
|             | testing of AU design with simulator begins      |  |
| Fall        | debugging of AU design and microprogram         |  |
|             | chip placement for AU                           |  |
|             | design of board testing system                  |  |
| Nov. 24     | level-converter board for test system sent      |  |
|             | for wiring                                      |  |
| 1976        |                                                 |  |
| Jan. 23     | testing of AU design and microprogram completed |  |
|             | AU board sent for wiring; chips ordered         |  |
| Spring      | software for board-testing system developed     |  |
|             | (Generale)                                      |  |
|             | board testing system tested                     |  |
| May 19      | last chips for AU received                      |  |
| June-Sept.  | AU tested                                       |  |
| Aug. 3      | instruction unit sent for wiring                |  |
| Fall        | slow control unit designed                      |  |
|             | memory and memory switch designed (Bianchini)   |  |
| 1977        |                                                 |  |
| Jan. 17     | slow control unit sent for wiring               |  |
| FebMarch    | software for testing processor ("PUMA utility") |  |
|             | developed on H-316 (Generale)                   |  |

|          | small memory (16 K words max) and memory       |  |  |  |
|----------|------------------------------------------------|--|--|--|
|          | switch built (Bianchini et al.)                |  |  |  |
| April    | system integrated                              |  |  |  |
|          | initial, very low speed processor tests        |  |  |  |
| Summer   | microprogram debugged                          |  |  |  |
|          | POS (Puma Operating System) installed on H-316 |  |  |  |
|          | (Kenner)                                       |  |  |  |
| October  | large memory (131 K words) operational         |  |  |  |
|          | (Bianchini)                                    |  |  |  |
|          | fast control unit simulation begins            |  |  |  |
| (Grad)   |                                                |  |  |  |
| Dec. 15  | fast control unit sent for wiring              |  |  |  |
| 1978     |                                                |  |  |  |
| January  | PDP-11/34 installed                            |  |  |  |
|          | PUMA Utility written on PDP-ll                 |  |  |  |
| February | PROMs for fast control unit programmed         |  |  |  |
|          | (Grad)                                         |  |  |  |
| March    | PUMA running with fast control unit            |  |  |  |
| Мау      | Puma Operating System installed on PDP-11      |  |  |  |
| (Kenner) |                                                |  |  |  |
|          |                                                |  |  |  |

#### 3. System structure

In our system, as in the Control Data 6600, separate processors have been provided for executing user programs and managing peripherals. We are keeping open the option of duplicating the 6600 architecture, with its set of ten peripheral processors. However, our initial approach has been to use a single commercially available minicomputer for controlling the peripherals.

This approach has a number of disadvantages. The largest is that all operating system functions currently performed by peripheral processors will have to be redesigned and recoded to run on theminicomputer or the central processor. Another possible problem is that a single minicomputer of modest price (about the same cost as the central processor we have built) may not be able to transmit data at a rate sufficient to keep the central processor busy.

There are several countervailing advantages to our approach. Most obviously, it means that we have to design and build less in order to obtain a working computer system. Moreover, the motivation — in purely hardware terms — is less strong for building peripheral processors than for building a central processor. High-speed, large word size scientific processors are still quite expensive, so the potential saving from a new, simple design is large. The slower, small-word-size machines suitable as peripheral processors, on the other hand, are now being mass-produced and have become quite inexpensive; the potential saving there is much smaller. Furthermore, the market for minicomputer-compatible peripheral controllers is very competitive, and consequently these controllers have become quite inexpensive. (In contrast, controllers compatible with Control Data peripheral processors are single-sourced and in some cases would be as expensive as the central processor and memory.)

Work on a set of compatible peripheral processors is currently underway at Brookhaven National Laboratories.

<sup>5</sup> 

The gross structure of our computer system is shown in Figure 1. A central processor (PUMA) and a peripheralmanaging minicomputer (MINI) can each address all of a large central memory (CM). All data transfers to and from peripherals go through the minicomputer into central memory.

References to central memory go through a memory switch (MS). The memory itself has 60 data bits plus 4 parity bits per word. The path to PUMA is 60 bits wide, to the minicomputer 16 bits wide; the memory switch includes registers for assembling four 16-bit words into a 60-bit word when writing memory, and correspondingly disassembling words when reading. In addition, the memory switch provides direct data paths between PUMA and the minicomputer; these can be used by the minicomputer to control PUMA (start it, stop it, or switch tasks) and to run diagnostic tests of PUMA.



Figure 1. Gross Structure of the PUMA Computer System

#### 4. Central processor structure

As we noted earlier, this project was prompted by developments in digital integrated circuit technology. The specific family of circuits we have used in our central processor is 10,000 series ECL (emitter-coupled logic). This family possesses two characteristics essential to our project: low gate propagation delay and availability of medium-scale integration chips.

The propagation delay of discrete gates in this series is 1.5 - 2.5 ns; gates included in larger functions have effective delay times closer to 1 ns. This represents a threeor four-fold increase in speed over the CDC 6600. Although somewhat faster logic families are available (with delay times for discrete gates below 1 ns) they provide a smaller variety of functions and are more difficult to interconnect (because of the high signal frequency).

The ECL 10,000 series includes a number of logic functions in 4-bit wide slices. Among the chips available are: a 4-bit shift register, a 4-bit counter, a 4-bit arithmetic-logic unit, and a 4-bit, 16-word register file. This level of integration makes it possible, for example, to build a 60-bit carry-look-ahead adder from 20 integrated circuit chips.

Because of the faster circuitry, we believed that we could build a machine nearly as fast as the 6600 using a very simple design with a minimum of parallelism. The design we have adopted, requiring fewer than 700 chips for the entire central processor, is described below.

The PUMA central processor is composed of three *units*: an arithmetic unit, an instruction unit, and a control unit (Figure 2). The arithmetic unit contains all the user programmable registers (A, B, and X registers), a number of registers for holding intermediate results in instruction interpretation, and the hardware for performing addition, subtraction, and Boolean operations on data. The instruction unit contains



Figure 2. Units and main data paths of the PUMA central processor.

the logic for decoding instructions. In addition, it contains the P register (program counter), and a register for holding the next instruction word, which is fetched while the current instruction word is being executed. The control unit, of horizontal microprogrammed design, generates all control signals for the arithmetic and instruction units.

Figure 2 also shows the main data paths of PUMA. Data from memory (a 60-bit path) comes to the instruction unit. If it represents an instruction to be executed, it is held in the instruction unit; if it represents data to be loaded into an arithmetic register, it is sent through the instruction unit to the arithmetic unit. (Although this does add a few nanoseconds to the register load time, it avoids the need for a separate path from memory to the arithmetic unit. Because of the wide data path (60 bits), minimizing the number of such paths has been an important design consideration.) Data to be stored in memory originates only in the arithmetic unit, so the data path goes from the arithmetic unit to memory. Memory addresses may be generated either in the arithmetic unit (for register loads and stores) or in the instruction unit (for instruction fetches), so the address path goes from the arithmetic unit to the instruction unit and from the instruction unit to the memory. Instruction fields are transmitted from the instruction unit to the arithmetic unit (over the 60-bit data path) and to the control unit.

4.1 The Arithmetic Unit

The arithmetic unit is divided into two sections, a main arithmetic unit and an exponent arithmetic unit. The main unit is 60 bits wide, the exponent unit 12 bits wide. The exponent unit is used for counting and, as its name indicates, for exponent calculations in floating-point instructions.

Figure 3 shows the stucture of the main arithmetic unit. In the narrative which follows we shall slowly work our way from left to right in the figure.



Figure 3. PUMA central processor: main arithmetic unit.

Near the left of the figure are the A, B, X, and Y registers. Each is a set of eight registers, named A0 through A7, B0 through B7, X0 through X7, and Y0 through Y7. The A and B registers are 20 bits wide, the X and Y registers 60 bits. The A, B, and X registers correspond to the userprogrammable registers of the same names on the CDC 6600; the Y registers hold intermediate results during instruction interpretation. (The particular register configuration was dictated in part by the 16 word X 4 bit size of the ECL register chip. Thus, compatability with the 6600 required A and B registers of only 18 bits, but the 19<sup>th</sup> and 20<sup>th</sup> bits were "free". Similarly, we probably could have managed with just eight 60-bit registers, but eight more were available, so we wrote the microprogram to make good use of them.)

The output of the register array is fed to the unpack logic. The unpack logic is a hardware implementation of the 6600 unpack instruction, which separates a 6600-format floating point number into a coefficient (sign-extended to a 60-bit number) and an exponent. The exponent is sent to the exponent arithmetic unit. Operation of the unpack logic is controlled by a signal from the control unit — if not selected, the output of the registers passes through unchanged.

The output of the unpack logic goes to a 60-bit buffer register BUF. The presence of a buffer register between the register array and the arithmetic and shifting logic permits a limited degree of parallelism in the main arithmetic unit: an arithmetic operation can be performed on one operand while the next operand is being fetched from the register array or the previous result is being stored in the register array. (If the buffer register were not present, a number could be read out of the register array and used as an operand in an arithmetic operation in a single clock cycle. This would mean that certain sequences of operations could be performed in fewer clock cycles. However, each cycle would have to be considerably longer, since it would have to allow for both

register array access time and arithmetic operation time. In consequence, the effective speed of the machine would probably be significantly reduced.)

The box labeled ALU in the figure is a row of fifteen ALU (arithmetic and logic unit) chips, each four bits wide. One operand of the ALU comes from the BUF register, the other from the AC register. The ALU can perform addition, subtraction, and all sixteen Boolean operations.

For addition and subtraction, the ALU acts as a *subtractive* adder. A subtractive adder may best be though of as a circuit which first complements both operands, then adds them in the way in which you are familiar, and then complements the result. For two's complement arithmetic, a subtractive adder works just like a normal adder; for one's complement arithmetic, it has the feature that the sum of a number and its complement is plus zero (rather than minus zero for a normal adder). It is important to keep in mind, however, that when carry in, carry out, group generate, and group propagate are discussed, they are with respect to an addition being performed on the complements of the operands.

Several variations are possible on the addition and subtraction operations. The normal mode of addition is one's complement addition (carry out of the high-order bit is propagated end-around). One variant (the "no propagate" option), disables the end-around carry, so there is no carry into the low-order bit (this has the effect of a normal two's complement adder with a carry forced into the low-order bit). Another variant (the "generate" option), disables the end-around carry but forces a carry into the low-order bit (this has the effect of a normal two's complement adder without a carry into the low-order bit). A third variant is designed to facilitate 120-bit one's complement addition. Whenever an addition or subtraction is performed, the 60-bit group generate and propagate values can be saved in two flip-flops SAVEP and SAVEG. These flip-flops can then be used to control the end-around carry in a subsequent arithmetic operation, as follows:

let  $C_{60}$  be the carry out of the high order bit; then, under this variant, the carry brought around to the low-order bit will be

# (C<sub>60</sub> ^ SAVEP) v SAVEG

So, to compute the low-order half of a 120-bit sum, one first saves the P and G values for the high-order halves of the operands and then adds the low-order halves using the saved P and G to control the end-around carry. The high-order half of the sum is similarly obtained.

One further variant performs 18-bit arithmetic. In this mode, the low 18 bits of AC and BUF are added (or subtracted) in what is effectively an 18-bit adder, and the sign bit of the result is extended to the high 42 bits. This mode matches the "increment unit" arithmetic of the 6600.

The output of the ALU is wire-ored with data coming from the instruction unit and from register E0 of the exponent arithmetic unit. These signals, together with the output of 60-bit register MQ, are fed into a 120-bit shifter. This is a combinatorial shifter made out of 4-way multiplexers. It can send the data straight through (no shift) or shift it to the right by 4, 16, or 60 bits. The 4 and 16-bit shifts can be either circular or arithmetic (high bit of ALU output extended to fill vacated positions); the 60-bit shift is always circular (interchanges ALU and MQ outputs). (Considerable thought during machine design was given to the selection of the best combination of shifts. An increase in the number of different shifts would have considerably speeded up the machine but was deemed too great an increase in the processor size. For example, a shifter which could shift any number of positions from 0 to 63 would have increased the size of the shifter from 60 to 180 chips, nearly a 20% increase in total processor size.)

The output of the shifter feeds a pair of 60-bit registers, AC and MQ. Each of these registers is itself a parallel entry shift register, so each, in addition to loading the output of

the shifter, can shift its data one bit to the left or right. On a one-bit left shift, the low bit of the AC receives the high bit of the MQ; the low bit of the MQ receives either the high bit of the AC or a constant 0 or 1, depending on select lines from the control unit. On a one-bit right shift, the high bit of the AC receives either the low bit of the MQ (circular shift) or remains unchanged (arithmetic shift); the high bit of the MQ receives the low bit of the AC.

The AC is the central register of the processing unit. The output of the AC is directly connected by cables to the memory switch; data to be written into memory is first loaded into the AC. By appropriately setting the memory switch, the minicomputer can read these signals and hence read the AC. This feature makes it easy to trace the processor during single-stepped execution. The low 20 bits of the AC are also routed to the instruction unit and are used to transmit the memory address for register loads and stores. Finally, the AC feeds the register array, so data to be stored in the register array must first go into the AC. On the path from the AC to the register array is the pack logic. This performs the inverse function from the unpack logic: it combines a coefficient in AC and a signed exponent in register E0 into a floating point number. This operation is performed only if selected by the control unit (using the same select line which controls the unpack logic).

Figure 4 shows the structure of the exponent arithmetic unit. The unit contains three 12-bit registers, E0, E1, E2. Register E0 has a preferred status, inasmuch as it feeds the pack logic and is the only exponent register which can be loaded directly into AC or MQ.

At the center of the figure is a l2-bit one's complement adder/subtracter. Like the one in the main arithmetic unit, it is a subtractive adder. Even though this adder (like the one in the main unit) uses carry look-ahead, one clock cycle is not sufficient time to perform an add and gate the results



Figure 4. PUMA central processor: exponent arithmetic unit.

into an E register — two cycles must be allotted. As a result, a fast addition mode is also provided. In hardware terms, the adder consists of three 4-bit ALU chips and the fast mode disables the carry into each chip. In net effect, this means that bits 0-3, 4-7, and 8-11 are added independent-ly by two's complement adders with a carry forced into each low bit (bits 0, 4, and 8). The fast mode is useful in a number of situations, such as when a count smaller than 16 is being decremented.

One of the operands of the adder can be any of the E registers or a constant sent from the control unit. The other operand can be any E register or

the low 12 bits of the AC
a count of the number of 1 bits in the
 low 4 bits of the AC
the low 4 bits of the MQ in bits 0-3 and
 the complement thereof in bits 4-7
the jk field (6 bits) of the current instruction
minus zero (all 1 bits)

The output of the adder and the output of the unpack logic in the main arithmetic unit are sent to a multiplexer which transmits one of these two signals to the E register inputs.

4.2 The Instruction Unit

Figure 5 shows the structure of the instruction unit. This unit holds the current instruction and the next instruction in sequence. It also contains the P register (program counter) and MA register, which holds the address for memory references.

The data path from memory is connected to the input of the NIW (next instruction word) register. While one instruction word is executing, the next word is requested from memory. When the word is delivered by the memory, the NIW is clocked to load it. When execution of the current instruction word is



Figure 5. PUMA central processor: instruction unit.

complete, the next instruction word is transferred from the NIW to the CIW (current instruction word) register.

Lines from CIW transmit the high 15 bits (f,m,i,j, and k fields of the first instruction) to the arithmetic and control units. In addition, bits 30 to 47 (the K field of the first instruction) can be routed to the arithmetic unit and or-ed with the low 18 bits of the ALU output. The CIW is wired to perform 15-bit left shifts. After a short instruction (15 bits) is executed, one shift is performed; after a long instruction (30 bits), two shifts.

Controlling the data sent to the arithmetic unit (or-ed with the ALU) is a 4-way multiplexer. One input, as we just mentioned, is the K field of the current instruction. The second is the data sent from memory, the third is the P register, and the fourth is zero.

On the right side of the figure is the address path. Although the 6600 design only has 18 bits for addresses, the PUMA address path has been made 20 bits throughout to accommodate a million words of memory (this involved almost no extra cost, since all the chips involved are 4-bit slices). The P register is a counter — it can be incremented, decremented, or set from the low 20 bits of the AC register. The P register can be directly read by the minicomputer. The MA register holds the address for memory references. It can be loaded from the output of the P register or from the low 20 bits of AC.

For PUMA serial number 2, some additional logic was included in the address path. This logic is controlled from the memory switch and so is invisible at the PUMA microprogram level. Two registers have been added for relocation and memory protection: a reference address (RA) register and a field length (FL) register. The output of the MA register is continuously compared to FL; an address out of range signal is sent to the memory switch if MA  $\geq$  FL. The output of MA is added to RA to obtain the absolute memory address, which is sent to the memory switch. Both RA and FL can be set only by

the minicomputer through the memory switch. Finally, to reduce the number of data paths leaving the PUMA, the absolute memory address, P, RA, and FL registers are multiplexed onto a single 20-bit data path under control of the memory switch.

### 4.3 The Control Unit

The control unit generates the signals which control the arithmetic and instruction units. It must generate these signals in the proper sequence to interpret and emulate CDC 6600 instructions.

The control unit of the PUMA is microprogrammed — all information about the sequencing of control signals is stored in a *microprogram memory*. The microprogram consists of a series of *microinstructions*. Each microinstruction specifies the values of the control signals during a single clock cycle and contains sequencing information which determines the microinstruction to be used in the following cycle. This sequencing information consists of

> a condition number, which selects one of 48 conditions to test the address of the microinstruction to be executed next if the condition is true the address of the microinstruction to be executed next if the condition is false

Including a conditional branch in every microinstruction requires a much wider microinstruction than would having separate operation and branch microinstructions. However, because of the highly branched nature of the microprogram, including the conditional branch in each microinstruction makes the microprogram much shorter and hence much faster. Since speed is paramount in this design, this approach has been selected.

We have designed two versions of the control unit. One version incorporates a 1024-word writeable microprogram memory. This version has been used to debug the microcode for 6600 emulation, and will probably be used in the future to test experimental microprograms. This version has the disadvantage of being relatively slow — the clock period is 250 ns. In the second version of the control unit, the microprogram is stored in a programmable read-only memory. This memory is smaller (512 words) and, of course, cannot be changed once programmed, but makes for a much faster control unit — a clock period of about 50 ns. We shall refer to these two versions as the slow and fast control units, respectively.

The microinstructions are of a horizontal or decoded form. That is, there is (with a few exceptions) a one-to-one correspondence between bits in the microinstruction and signals coming out of the control unit. We may also note here that the entire processor uses a single (one-phase) clock, and that control signals remain constant during a clock period.

We shall now proceed to a detailed description of the control units — first the slow version, and then the fast.

The gross structure of the slow control unit is shown in Figure 6. At this heart is a microprogram memory of 1024 85-bit words (the memory is built from 1024-bit static RAM chips with a 70 ns maximum access time). The memory and the microinstruction sequencing logic are all TTL rather than ECL, because of the low cost and ready availability of the TTL RAMs (low-cost ECL 1024-bit RAMs were just becoming available when the slow unit was built).

Each 85-bit microinstruction has two parts: a 28-bit group (consisting of a condition field and two branch addresses) which determines the next microinstruction address, and a 57-bit group which determines the value of all control lines during a cycle. These control lines go to the arithmetic and instruction units and a few circuits on the control unit, to be described later. Since the other units require ECL-level control lines, the output of these bits of the microprogram



Figure 6. Gross structure of slow control unit.

memory must go through TTL to ECL level converters.

Writing of the microprogram memory is under the control of the minicomputer. The minicomputer has three 12-bit paths to the control unit: a path for data into the control unit, a path for data out of the control unit, and a path for function signals (to start the clock or write a microinstruction). The minicomputer can write a word of the microprogram memory by sending eight 12-bit data words, together with the appropriate function signals.

Figure 7 shows the details of the next microinstruction sequencing logic. As is our usual habit, we shall work our way through this diagram from left to right. Coming in on the left is the 28-bit group from the current microinstruction. This group is composed of three fields:

a 6-bit condition field

an ll-bit true-branch-address field

an ll-bit false-branch-address field

The high-order bit of each branch address has a special function: if it is set, the low 6 bits of that branch address are to be replaced by the opcode of the instruction currently being interpreted (the high 6 bits of register CIW). This feature permits a rapid transfer to the appropriate microcode sequence for each new instruction.

The condition field selects the signal to be tested by the current microinstruction. There are 47 conditions in PUMA: 31 test lines on the arithmetic unit; 16 test signals generated on the control unit. These 47 signals are fed into a giant multiplexer circuit (actually distributed between the arithmetic and control units), whose output is the signal to be tested. This signal in turn feeds a multiplexer which selects between the true-branch-address and the false-branchaddress. The output of this multiplexer is the address of the next microinstruction to be executed. This address is gated into the microinstruction address register (MAR) and is also available to be read by the minicomputer.



Figure 7. Microinstruction sequencer.

A final multiplexer selects between the microinstruction address register and the external microstore address register (Ext. MAR). The external address register can be set by the minicomputer, and the select line of this multiplexer is under minicomputer control. The external address register is selected when the microprogram memory is being written, and for the first cycle when the processor is being started. When the processor is running, the microinstruction address register is selected. The output of this multiplexer finally feeds the address lines of the microprogram memory.

There are a few exceptions to the rule that each control line is directly controlled by one microinstruction bit. These exceptions are detailed in Figure <sup>8</sup>.

One exception is the set of "special functions". These are control signals which are changed relatively infrequently in the microprogram. They are: the lines controlling the NIW, P, and MA registers; the lines controlling memory requests; and the line to the "save PG" flip-flops in the main arithmetic unit. To save some space in the microinstruction word, the bits of the microinstruction which are used as the constant in the exponent arithmetic unit also control the special func-The circuit works as follows: the microinstruction tion lines. includes a special function bit. If this bit is 0, the special function lines are all forced to 1 (which causes all the registers to hold their previous contents). If this bit is 1, the special function lines are controlled by bits of the constant field. Thus the only constraint imposed by this scheme is that the constant field cannot be used in the same cycle as a special function (unless the constant required just happens to be that produced by the pattern of special functions).

The other irregularity concerns the lines which control the register number in the main arithmetic unit. The microinstruction can specify this number by a constant in the



Figure <sup>3</sup>. Details of microprogram memory output logic.

microinstruction, or it can specify that the i, j, or k field of the current instruction (bits 51-53, 48-50, or 45-47 of CIW) be used as the register number. Accordingly, there is a 3-bit, 4-to-1 multiplexer feeding the register number. Note also the 3-bit register ILATCH, which is loaded with the i field of the current instruction (bits 51-53 of CIW). ILATCH makes it possible to retain the i field of the current instruction while rotating CIW in preparation for executing the next instruction. (The j and k fields are not similarly latched because the i field is frequently used at the end of the microcode sequences for instruction interpretation, whereas the j and k fields are most often used at the beginning of such sequences.)

The fast control unit has been designed to minimize the machine cycle time. One way in which this was done was to use a very fast chip in the microprogram memory. The chip we have chosen is a 256 word  $\times$  4 bit PROM (programmable read-only memory) with a maximum access time of 25 ns. Another way in which we speeded up the control unit was to overlap operations in the arithmetic unit with the fetch of the next microinstruction. This is a bit tricky, since the next microinstruction selected may be determined by a condition which depends on the result of an arithmetic operation. What we were forced to do was fetch *both* possible successor microinstructions and then, near the end of the clock cycle (when the value of the condition was known) select one of the two as the actual successor.

The circuit which achieves this overlap in the fast control unit is shown in Figure <sup>9</sup>. The microprogram memory is divided into two banks which can be accessed concurrently. We require that the false-branch-address always be in bank 0 and the true-branch-address always be in bank 1. In this way the two possible successors of a microinstruction can always be fetched concurrently. (This means that microinstructions which occur as the false-branch-address of one microinstruction and the true-branch-address of another microinstruction



Figure 9. Fast control unit.

will have to appear twice in microprogram memory, once in each bank. In practice, however, the number of microinstructions which must be thus duplicated is quite small.) The multiplexer which permits branching on the current opcode is included only in bank 0.

During the first 35 ns or so of a clock cycle, the arithmetic operation is performed and both potential successor microinstructions are fetched. The specified condition is then selected by the condition multiplexer. The output of this multiplexer is used as the select input of a 2-way, 81-bit multiplexer to select the next microinstruction, which is then gated into the microinstruction register. This takes about 15 ns, for a total cycle time of about 50 ns.

In contrast to the slow control unit, this design does not provide a multiplexer for introducing an external microprogram address. Instead, the minicomputer can disable the microprogram memory and write the microinstruction register directly. Thus, to start the machine the minicomputer would load the first microinstruction into the microinstruction register and then start the clock running. This facility for writing the microinstruction register makes it possible to try microinstructions not in the microprogram memory; this may be useful for diagnostic purposes.

### 5. Microprogramming the PUMA

For convenience in microprogramming the PUMA, we have provided a microassembly language similar in style to a register transfer language or algebraic programming language. In this chapter we shall describe the PUMA micro-operation repertoire in terms of this microassembly language. An appendix to this chapter describes the structure of the assembler microinstructions, explaining the significance of each bit.

The microassembly language is processed by a microassembler. The microassembler was originally written in SNOBOL 4; the current version was coded in CIMS PL/I by Erdwin Chua. The output of the microassembler may be fed to one of two postprocessors. One postprocessor, for the slow control unit, has the task of permuting the microinstructions so that the first microinstruction in the sequence which interprets opcode n (n=0,...,77<sub>8</sub>) is placed at location n of the microprogram memory. The other postprocessor, for the fast control unit, has the *additional* task of assigning microinstructions to one or both banks of the control store, based on an analysis of branching in the microprogram.

To summarize the data register complement of the PUMA central processor: the PUMA provides 16 60-bit registers numbered X0-7, Y0-7; 16 20-bit registers numbered A0-7, B0-7; a 60-bit transfer register BUF; a 120-bit AC:MQ register pair consisting of the two separately usable halves AC and MQ, and 3 12-bit registers used for exponent arithmetic and miscellaneous counting operations, which are numbered E0, E1, and E2. Within an n-bit register, the least-significant bit is labeled bit 0 and the most-significant bit is labeled bit n-1. The micro-operations of the PUMA are as follows: (a) Write to register:

or  $\{A \mid B \mid X \mid Y\} \quad \{r \mid I \mid J \mid K \mid M \mid N\} = AC$   $= E0:AC \quad (pack option)$ 

Here and below, r is a digit between 0 and 7; I, J, and K

designate the 3-bit I, J, and K fields of the current instruction; whereas M and N use bits from the El register, with some encoding, in the following special way (designed for the multiply routines):

M: if bit 7 of El is on, select register using bits
0-2 of El, otherwise no register store takes place
N: if bit 3 of El is on, select register using bits
4-6 of El, otherwise no register store tackes place.

For a pack option write to register, bits 0-47 and 59 of E0:AC are set from AC, and bits 48-58 from E0, with bit 58 being complemented. In addition, if bit 59 of AC is on, the exponent bits 48-58 are complemented before the write. This option stores in the register the 6600 floating-point representation of the number whose integer coefficient is in AC and exponent is in E0.

(b) Read from register:

These operations have BUF as their target; register read and write operations cannot both be performed on the same cycle. Microcode forms are

or

 $BUF = \{A \mid B \mid X \mid Y\} \{r \mid I \mid J \mid K \mid M \mid N\}$ 

Ei:BUF =  $\{A \mid B \mid X \mid Y\}$   $\{r \mid I \mid J \mid K \mid M \mid N\}$  (unpack option) i=0,1 or 2 Here r,I,J,K,M,N are as above; in the M (resp. N) case 0 will be loaded into BUF if bit 7 (resp. bit 3) of El is off. In the case of a read from an A or B register, bits 20-59 of BUF will be set to 0.

On the unpack option, the sign of the quantity being read is extended to fill bits 48-58 of BUF, while Ei is set as follows: Ei(0-9) = source(48-57)/source(59); Ei(10)=Ei(11) = not(source(58)/source(59)), where "/" indicates exclusive-or. This option separates a number in 6600 floating-point representation into its integer coefficient (BUF) and exponent (Ei).

(c) Set AC and MQ:

A 60-bit arithmetic-logical unit can compute any of several functions of AC and BUF. The output of the arithmeticlogical unit, together with the output of the MQ register, is fed to a 120-bit-wide shift unit capable of shifting 60, 16, 4 or 0 bit positions. The two halves of the AC:MQ register are separately setable from the output of the shift unit.

Several inputs besides the functions of AC and BUF can be fed to the shift unit. In addition, AC:MQ can act by itself as a shift register, shifting one bit at a time in either direction. Any of these operations can be performed in parallel with a BUF load or register-write operation. Logical operations can be performed in one cycle; arithmetic operations, however, require two cycles.

The microcode forms for these operations are:

 $\{AC | MQ | AC: MQ | (AC)\} = f$ 

or = SHIFT(f:MQ, longsh)
or = MQ
or = SHIFT(AC:MQ, shortsh)

The left side of the assignment indicates which of AC and MQ will be loaded on this cycle; "(AC)" indicates that a function should be computed by the arithmetic-logical unit, but not loaded into either register half on this cycle. This is necessary for arithmetic functions, which take two cycles to compute. For example, to add BUF to AC the two-cycle microinstruction sequence

$$(AC) = AC + BUF$$
  
AC = AC + BUF

is required; the sum is not loaded into the AC until the end of the second cycle.

"f" may be any Boolean function of AC and BUF; mnemonics are currently provided in the microassembler for the following:

AC BUF AC  $\land$  BUF AC  $\lor$  BUF AC  $\checkmark$  BUF AC  $\land$  BUF  $\neg$  AC  $\neg$  BUF  $\neg$  AC  $\neg$  BUF 0 - 0 (all ones)

"f" may also be one of the following arithmetic operations.

AC + BUF AC - BUF AC + 0 AC - 0

Addition is normally done in 60-bit one's complement arithmetic using a subtractive adder; that is, the sum is effectively computed by complementing both operands, performing an addition with end-around carry, and complementing the result. This scheme, which is also used on the 6600, yields +0 when adding a number and its complement. Several arithmetic options are available and are indicated by appending one or more of the following microcode suffices to the operation.

| [18]     | perform 18-bit l's complement arithmetic,          |
|----------|----------------------------------------------------|
|          | with the sign of the result extended to the        |
|          | high-order 42 bits                                 |
| [NOP]    | suppress end-around carry ("no propagate")         |
| [G]      | force carry into low bit ("generate")              |
| [SAVEPG] | save 60-bit carry generate and propagate bits      |
|          | (does not affect result of current operation)      |
| [USEPG]  | make end-around carry conditional on values        |
|          | of P and G saved by SAVEPG:                        |
|          | carry into low bit = (carry out of high bit ^ P)VG |
|          | (SAVEPG and USEPG are provided to perform 120-bit  |
|          | one's complement addition efficiently.)            |
|          |                                                    |

Finally, "f" can be one of the following.

- K l8-bit K field of instruction in bits 0-17, with bits l8-59 zero
- P contents of P register (address of current instruction word + 1) in bits 0-19 with bits 20-59 zero
- E0 contents of E0 in bits 0-11, with sign bit extended into bits 12-17 and zeroes in bits 18-59

CMRD word of data read from central memory

"longsh" may indicate one of the following four shifts to be performed by the shift unit.

| R4  | right circular shift 4 bits                  |
|-----|----------------------------------------------|
| R16 | right circular shift 16 bits                 |
| A4  | arithmetic right shift 4 bits (the sign bit, |
|     | AC bit 59, is extended to fill vacated bit   |
|     | positions)                                   |
| A16 | arithmetic right shift 16 bits               |

The shift unit can also perform a 60-bit circular shift, directing the output of the arithmetic-logical unit to the MQ and the output of the MQ to the AC. This shift is selected by the microinstructions

| -   | AC | = | MQ |
|-----|----|---|----|
| and | MQ | = | f  |

which may be executed simultaneously.

AC:MQ can also act as a 120-bit shift register, performing a one-bit shift on each cycle. In one-bit shifts, data does not pass through the arithmetic-logical and shift units. "shortsh" may select one of the following one-bit shifts.

| Rl | right circular shift l bit   |
|----|------------------------------|
| Al | right arithmetic shift 1 bit |
| Ll | left circular shift l bit    |
| Z1 | left shift 1 bit, zero fill  |
| 01 | left shift 1 bit, one fill   |

## (d) Exponent unit operations:

The exponent unit performs addition and subtraction of 12-bit quantities using a one's complement subtractive adder. Exponent unit operations may proceed in parallel with register and AC:MQ operations, with one exception: because only one exponent register may be loaded in any cycle, a BUF load with unpack option excludes a simultaneous exponent unit assignment.

The form of an exponent unit operation is

or

```
[Ei] = \{Ej|const\} \pm \{Ek|AC|JK|-0|MM|BC\}[Ei] = \{E_j|const|AC|JK|MM|BC\}, \quad i,j,k=0,1 \text{ or } 2
```

Here,

| const | is a 12-bit octal constant                     |
|-------|------------------------------------------------|
|       | (the microassembler interprets -const          |
|       | as the one's complement)                       |
| AC    | bits 0-11 of AC                                |
| JK    | 6-bit jk field of current instruction in       |
|       | bits 0-5; zeros in bits 6-11                   |
| -0    | all one bits                                   |
| MM    | in bits 0-3, MQ bits 0-3; in bits 4-7,         |
|       | complement of MQ bits 0-3; in bits 8-11, zeros |
| BC    | bit count of low 4 bits of AC                  |

(The operand -0 is not explicitly available to the microassembly language programmer. However, the single-operand assignments

$$E_{i} = \{E_{j} \mid const\}$$

are assembled as

$$E_{i} = \{E_{j} \mid \text{const}\} + (-0)$$
  
since -0 = 7777<sub>8</sub> is the additive identity. Similarly,  
$$E_{i} = \{AC \mid JK \mid MM \mid BC\}$$

is assembled as

```
E_{1} = 7777 + \{AC | JK | MM | BC \}.)
```

As in the case of the main arithmetic-logical unit, addition and subtraction require two cycles. An empty left-hand side indicates that the arithmetic operation is to begin but no result is to be stored on this cycle; thus a two-cycle add might be

```
= AC + 1E0 = AC + 1
```

A "fast add" option, indicated by [F] after the operation, is also provided; a fast add can be performed in one cycle. In a fast add, the carry into bit position 0, 4, and 8 is blocked (set to 0), so the 12-bit adder acts like three separate 4-bit adders.

(e) Tests and transfers in the microcode:

A test can be used during any PUMA microinstruction cycle to select one of two microcode successor addresses for a given instruction. The general test form is IF t THEN L1 ELSE L2, where L1 and L2 are the labels fof two microinstructions.

The following 48 tests are provided:

| 5                    | £                                                 |
|----------------------|---------------------------------------------------|
| NULL                 | false                                             |
| EALU(11)             | EALU highbit on                                   |
| EALU(0) v EALU(1)    | EALU lowbits not zero                             |
| EALU(2) V EALU(3)    | EALU bits 2-3 not both zero                       |
| EALU(4) v EALU(5)    | EALU bits 4-5 not both zero                       |
| EALU(0-3)            | EALU bits 0-3 not all zero                        |
| EALUPOUT             | carry propagate bit for EALU on                   |
| EALUPOUT ^ EXOP2.10  | EALU carry propagate and EALU 2nd op,             |
|                      | bit 10                                            |
| EALUPOUT A TEXOP2.10 | EALU carry propagate and not EALU                 |
|                      | 2nd op bit 10                                     |
| FOFL                 | floating overflow: EALU output                    |
|                      | outside valid range of <u>+</u> 2000 <sub>8</sub> |
| XFOFL                | extreme floating overflow; EALU                   |
|                      | output outside range <u>+</u> 3000 <sub>8</sub>   |
| REG(59)              | sign bit on in selected register                  |
| REG(17)              | bit 17 on in selected register                    |
| BUF(59)              | sign bit on in BUF                                |
|                      |                                                   |

REG (59) / BUF (59) sign bit of selected register  $\neq$  sign bit of BUF AC sign bit on AC(59) AC bit 49 on AC(49) AC bit 47 on AC(47) AC bit 46 on AC(46) MQ(59) MQ sign on MQ bit 50 on MQ(50) MO bit 49 on MO(49) ALU(59) ALU sign bit on ALU bit 49 on ALU(49) ALU(47) ALU bit 47 on ALU sign different from ALU bit 47 ALU(59)/ALU(47) ALU sign different from ALU bit 48 ALU(59)/ALU(48) propagate output on in ALU POUT generate output on in ALU G low 4 bits of MO exceed 7 Μ (used in multiply routine) low 4 bits of MQ exceed 8 M > 8(used in multiply routine) weird condition used in divide AC << BUF  $\land \neg MQ(50)$ routine, see divide documentation OPCODE(0)low bit of opcode on bit 1 of opcode on OPCODE(1) bit 2 of opcode on OPCODE(2) low bit of I field on I(0) bit 1 of I field on I(1)bit 2 of I field on I(2)I field 0 I = 0I field exceeds 5 I > 5 J = 0J field 0 external line (set by PP) MODE 2 MODE 4 external line (set by PP) CMDONE memory operation complete next instruction word buffer empty (see NIWEMPTY below) last parcel of instruction word LASTPARCEL LASTPARCEL V (NIWEMPTY  $\Lambda$  CMDONE) ICHECK external line (set by PP) EXTINT 36

The propagate outputs of the arithmetic-logical unit and the exponent unit adder are very useful in performing selective bit tests. The propagate output when adding A and B is

$$(\bar{A}_0 \vee \bar{B}_0) \wedge (\bar{A}_1 \vee \bar{B}_1) \wedge \dots \wedge (\bar{A}_n \vee \bar{B}_n)$$

(the A and B bits are complemented because this is a subtractive adder), while for subtracting A - B it is

 $(\bar{\mathtt{A}}_0 \ \mathtt{v} \ \mathtt{B}_0) \ \mathtt{A} \ (\bar{\mathtt{A}}_1 \ \mathtt{v} \ \mathtt{B}_1) \ \mathtt{A} \ \ldots \ \mathtt{A} \ (\bar{\mathtt{A}}_n \ \mathtt{v} \ \mathtt{B}_n)$ 

Thus, to test that certain bits in B are all 1, we set the corresponding bits in A to 1, compute A - B and test the propagate output.

Similarly, to test that certain bits in B are all 0, we set the corresponding bits in A to 1, compute A + B and test the propagate output. A number of conditions which are tested in this way and used in the microcode have been assigned separate mnemonics; these include

| AC = 0       | all bits of $AC = 0$                                    |
|--------------|---------------------------------------------------------|
| INDEF(Ei)    | Ei has the value 7777 <sub>8</sub>                      |
|              | (= -0, the "indefinite" exponent)                       |
| INF(Ei)      | Ei has the value 1777 <sub>8</sub> or 5777 <sub>8</sub> |
|              | (the exponent for floating-point                        |
|              | infinity)                                               |
| ILL(Ei)      | INF(Ei) V INDEF(Ei)                                     |
| ZERO(Ei)     | Ei has the value 2000 <sub>8</sub> or 6000 <sub>8</sub> |
|              | (the exponent for floating-point zero)                  |
| E0(6-10) = 0 | bits 6 through 10 of E0 are off                         |
| E2(7-11) = 0 | bits 7 through ll of E2 are off                         |
| E2(6-11) = 0 | bits 6 through ll of E2 are off                         |
| E2 = 0       | all bits of E2 are off                                  |

Note that the first of these conditions requires the use of the arithmetic-logical unit and the remainder the use of the exponent unit.

In addition to the basic form

IF t THEN L1 ELSE L2

the assembler allows the form

IF 7t THEN L3 ELSE L4

which is assembled as

IF t THEN L4 ELSE L3,

and the form

IF t THEN L5

which is assembled as

IF t THEN L5 ELSE next instruction.

Finally, the form

GO L6

is allowed to indicate unconditional transfer.

A microinstruction transfer to the special label OPCODEBRANCH is detected by the hardware and causes a branch to microinstruction  $0-77_8$ , as determined by the opcode field of the current instruction.

(f) Central memory communication:

A central memory operation is initiated by passing the relevant memory address from AC into the memory address register MA, and then setting one of the memory control flip-flops READ/FF, WRITE/FF to signal the operation desired, for which the two micro operations READ and WRITE are provided. On a WRITE operation, the data written is taken from the AC, which should be set from BUF no later than the cycle on which the WRITE operation is executed; AC must then remain unchanged until the memory unit signals completion of the write operation. The normal initiation of write and read respectively is therefore

(write) MA = AC; AC = BUF; WRITE
(read) MA = AC; READ

The memory unit signals the availability of a read result or the acceptance of write-data by raising a CMDONE flipflop. In the case of a read operation, the microprogram must load the data from memory by executing AC = CMRD. The microprogram then acknowledges to the memory its receipt of the CMDONE signal by clearing the READ and WRITE FFs with the CLEAR micro-operation. The memory concludes the cycle and signals its availability by dropping the CMDONE signal.

The basic microprogram sequence for a read, beginning with the address in AC and ending with the data in AC, is

| LOWAIT1 | IF | CMDONE | THEN   | LOWAIT1   |
|---------|----|--------|--------|-----------|
|         | MA | = AC;  | READ   |           |
| LOWAIT2 | IF | CMDON  | E THEN | J LOWAIT2 |
|         | AC | = CMRD | ; CLH  | EAR       |

For a write the sequence, beginning with the address in AC and the data in BUF, is

| STRWAIT1 | IF  | CMDONE THEN STRWAIT1        |
|----------|-----|-----------------------------|
|          | MA  | = AC; AC = BUF; WRITE       |
| STRWAIT2 | IF  | <b>CMDONE THEN STRWAIT2</b> |
|          | CLI | EAR                         |

Address relocation and address-out-of-range detection is the responsibility of the memory unit, not the microprogram.

(g) Instruction fetch logic:

In PUMA, instructions are read out of a 60 bit CIW (current instruction word) register which is addressed in 15 bit parcels by a parcel counter. A 60 bit backup register NIW ("next instruction word") is also provided. A 20 bit P register contains the address of the current instruction + 1. Operations available at the microprogram level are

| NEWPARCEL  | (shift CIW left 15, decrement parcel counter |
|------------|----------------------------------------------|
|            | by 1)                                        |
| CIW = NIW  | (move instruction backup word to CIW;        |
|            | set NIW empty and parcel counter = 4)        |
| NIW = CMRD | (fill instruction backup word, set NIW full) |

| P = P + 1 | (increment instruction counter)                |
|-----------|------------------------------------------------|
| P = AC    | (set instruction counter from AC, i.e. branch) |
| MA = P    | (set memory address register from P)           |
| LATCH I   | (load I-field latch)                           |

The opcode and J and K fields of the current instruction are read directly from the CIW register. References to the I-field, however (in register reads and writes and in conditions), actually use the contents of the I latch. The I latch is loaded from the I field of the current instruction by the LATCH I micro-operation. This latch was included in PUMA because it was desirable in the microcode to reference the I field of the current instruction after the CIW had been rotated to the next instruction by a NEWPARCEL operation.

Testable conditions involving the instruction unit are

| LASTPARCEL | parcel counter = 0                            |
|------------|-----------------------------------------------|
| NIWEMPTY   | NIW empty (CIW = NIW was done with no concur- |
|            | rent or subsequent NIW = CMRD)                |
| ICHECK     | LASTPARCEL V (NIWEMPTY A CMDONE)              |

The utility of condition ICHECK is discussed in the next chapter.

## Microassembler input format

A microinstruction is a set of one or more microoperations to be performed in a single clock cycle. The form of a microinstruction is

[label] micro-operation [; micro-operation] ...

A microinstruction must be punched starting on a new card. If the instruction has a label, the label must begin in column 1 and must be separated from the first micro-operation by one or more blanks. If there is no label, column 1 must be blank, and the first micro-operation may start in or after column 2. Except for these restrictions, input is free-format within columns 1 to 80 and blanks may be freely used to improve readability; blanks may not appear, however, within labels, keywords, or register names. An instruction which does not fit on one card may be continued by placing a '+' in column 1 of the following card and continuing the instruction in or after column 2. Anything following an \* on a card is treated as a comment.

The two-digit labels 00 through 77<sub>8</sub> have a special significance: the instruction labeled ij should be the first microinstruction in the sequence for processing the machine language instruction with opcode ij; this microinstruction will be placed in location ij of the microprogram memory.

## APPENDIX

PUMA MICRUÍNSTRUCTIÚN FIELDS

THE FIELD NAMES LISTED ARE THE NAMES OF THE CORRESPONDING CONTROL LINE NAMES IN PUMA SER. NO. 1. THE BIT POSITIONS GIVEN ARE THOSE FOR THE SLOW CONTROL UNIT; THOSE FOR THE FAST CONTROL UNIT DIFFER IN HAVING 8-BIT BRANCH ADDRESSES (FIELDS BRADUKO AND BRADDRI) AND NU OPCUBRI FIELD.

| FIELD            | (width     | IN 81TS)                                                                                                      | SIGNIFICANCE                                                                                                                                                                                          | BIT PO                                                       | OSITION  |
|------------------|------------|---------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|----------|
| MAIN AU          |            |                                                                                                               |                                                                                                                                                                                                       |                                                              |          |
| REGISTERS        |            |                                                                                                               |                                                                                                                                                                                                       |                                                              |          |
| READTP           | (1)        | GAWRIT- REC                                                                                                   | SISTER, IPREAD REGISTER                                                                                                                                                                               |                                                              | 37       |
| XYS-TP           | (1)        |                                                                                                               | REGISTERS, INSELECT AB                                                                                                                                                                                | REGISTERS                                                    | 36       |
| YBSTP            | (1)        |                                                                                                               | REGISTERS, INSELECT BY                                                                                                                                                                                |                                                              | 35       |
|                  |            |                                                                                                               | CONSTANT REGISTER NUMBER                                                                                                                                                                              | REGISTERS                                                    | 22       |
| REGENST          |            |                                                                                                               |                                                                                                                                                                                                       |                                                              |          |
| 1 JK SEL         | (2)        | 07058<br>17058<br>27058                                                                                       | -BIT) FIELD WHICH DETERMI<br>E K FIELD OF CURRENT INST<br>E J FIELD OF CURRENT INST<br>E CONTENTS OF I LATCH<br>E REGONST FIELD OF MICROI                                                             | RUCTION                                                      | 25       |
| MUKNSTP          | (1)        | 17USE M OR                                                                                                    | N AS REGISTÉR NUMBER                                                                                                                                                                                  |                                                              | 65       |
| NREGSTP          | (1)        | OPSELECT M                                                                                                    | AS REG. NO., INSELECT N                                                                                                                                                                               | AS REG. NO.                                                  | 66       |
|                  |            |                                                                                                               | I UR N IS TO BE USED AS R                                                                                                                                                                             |                                                              |          |
|                  |            |                                                                                                               | JLD = 3 AND REGENST=0                                                                                                                                                                                 |                                                              |          |
| BUF              |            |                                                                                                               |                                                                                                                                                                                                       |                                                              |          |
| EXLSTP           | (1)        |                                                                                                               | (PUNENT EXTRACT (OUT OF R<br>ERGE (INTO REGISTER)                                                                                                                                                     | EGISTER) AND                                                 | 56       |
| LDBUFTP          | (1)        | OPLOAD BUFF                                                                                                   |                                                                                                                                                                                                       |                                                              | 64       |
| ALU              |            |                                                                                                               |                                                                                                                                                                                                       |                                                              | • •      |
| ALUSTP           | (5)        | UF THE 1018<br>0 0 1<br>9 0 1<br>15 0<br>16 0<br>19 0<br>21 0<br>25 0<br>26 0<br>27 0<br>28 0<br>30 0<br>31 0 | AC-BUF<br>AC-BUF<br>AC-O<br>-AC<br>-C<br>-EUF<br>AC/EUF [EXCLUSIVE-OR]<br>BUF<br>AC~BUF<br>U<br>AC~BUF<br>AC~BUF<br>AC~BUF<br>AC~BUF                                                                  |                                                              | NS 42    |
| ALU18TP<br>PGSTP | (1)<br>(2) | NOTE: OUT<br>EO TO AC GA<br>ZERO FUNCT<br>OUTPUT FROM<br>Offo BIT AN<br>CONTRUES EN                           | PUT OF ALU IS OR-ED WITH<br>ATES AND DATAIN MULTIPLEX<br>ION OF ALU (28) MUST BE S<br>1 ONE OF THESE OTHER SOUR<br>RITHMETIC; 1716 BIT ARIT<br>ND-AROUND CARRY PROPAGATI<br>NO END-AROUND CARRY PROPA | OR ON IU, SO<br>ELECTED WHEN<br>CES IS USED<br>HMETIC<br>ON: | 34<br>62 |

|                                   |            | I ₽ PRUPAGATE CARRY END-ARDUND<br>2 ₽ GENERATE CARRY INTO LOW BIT EGI<br>3 ₽ USE SAVED P AND G EUSEPGI                                                                                                                                                                                              |          |
|-----------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| *SAVETP-                          | (1)        | OPHOLD LAST SAVED GENERATE AND PROPAGATE VALUES<br>IPSAVE NEW GENERATE AND PROPAGATE VALUES FROM ALU                                                                                                                                                                                                | 77       |
| E TOACTP<br>SHIFTER               | (1)        | 1PGATE EO UNTU LUW 12 BITS OF ALU DUTPUT BUS                                                                                                                                                                                                                                                        | 61       |
| SHSTP                             | (2)        | DETERMINES AMOUNT OF SHIFT:<br>O P NU SHIFT<br>I P SHIFT 4 BITS RIGHT<br>2 P SHIFT 16 BITS RIGHT<br>3 P SHIFT 60 BITS                                                                                                                                                                               | 51       |
| LSHSTP                            | (2)        | FOR RIGHT SHIFTS, SELECTS TYPE OF SHIFT:<br>O, 1 UK 2 P KIGHT CIRCULAR SHIFT [R]<br>3 P RIGHT ARITHMETIC SHIFT [A]<br>FOR 1-BIT LEFT SHIFTS, DONE IN AC:MO, DETERMINES<br>BIT TO FILL LOW BIT OF MQ:<br>0 P FILL WITH 1 BIT [0]<br>1 DR 3 P FILL WITH 0 BIT [Z]<br>2 P FILL WITH VALUE OF AC.59 [L] | 67       |
| AC+MQ<br>ACFTP                    | (2)        | AC FUNCTION:                                                                                                                                                                                                                                                                                        | 47       |
| ACTIP                             | (2)        | Ú P LOAD<br>1 P LEFT SHIFT 1 BIT<br>2 P RIGHT SHIFT 1 BIT<br>3 P HOLD                                                                                                                                                                                                                               | 71       |
| MQFTP<br>Exponent Au<br>Eau Adder | (2)        | MQ FUNCTION (SAME CODES AS ACFTP)                                                                                                                                                                                                                                                                   | 49       |
| OPISTP                            | (2)        | SELECTS FIRST OPERAND OF EXPONENT ADDER<br>O & CONSTANT FIELD OF MICROINSTRUCTION<br>1 & EO<br>2 & E1<br>3 & E2                                                                                                                                                                                     | 57       |
| UP2STP                            | (3)        | SELECTS SECOND OPERAND OF EXPONENT ADDER<br>O # ALL ONES<br>1 # E0<br>2 # E1<br>3 # E2<br>4 # LOW 12 BITS OF AC<br>5 # JK FIELD OF CURRENT INSTRUCTION<br>5 # BIT COUNT OF LOW 4 BITS OF AC<br>7 # MM                                                                                               | 53       |
| E SUBTP<br>E FASTTP               | (1)<br>(1) | EXPONENT ADDER FUNCTION: OPADD, 1PSUBTRACT<br>Opnormal Add, 1p FAST Add: Suppress carries into<br>BITS 0, 4, and 8 OF Adder                                                                                                                                                                         | 59<br>60 |
| EXPONENT R                        | EGISTERS   | STIJ VY TY AND O OF ADDEK                                                                                                                                                                                                                                                                           |          |
| EOCLKTP                           |            | O∂STURE IN EC; I∂DON≠T STORE IN EO                                                                                                                                                                                                                                                                  | 82       |
| EICLKTP                           | (1)        | OPSTORE IN E1; 1000N≠T STORE IN E1                                                                                                                                                                                                                                                                  | 83       |
| EZCLKTP                           | (1)        | O⇒STURE IN L2; I⇒DON≠T STORE IN E2                                                                                                                                                                                                                                                                  | 84       |
| CONSTANT                          |            | TO DIT CONCTANT FOR EXECUTIVE LODGE                                                                                                                                                                                                                                                                 |          |
| C DN TP<br>I U                    | (12)       | 12-BIT CONSTANT FOR EXPONENT ADDER                                                                                                                                                                                                                                                                  | 69       |
| DATSTP                            | (2)        | CONTROLS DATA FED TO AU (DATA IS ORED WITH                                                                                                                                                                                                                                                          | 40       |

|                      |         | BUTPUT OF ALU):                                                             |     |
|----------------------|---------|-----------------------------------------------------------------------------|-----|
|                      |         | O P DATA FROM MEMORY [CMRD]                                                 |     |
|                      |         | 1 ∂ ALL ZEROS<br>2 ∂ 10-BIT K FIELD OF CURRENT INSTRUCTION                  |     |
|                      |         | 3 P REGISTER                                                                |     |
| *NIWCLK1             | [P-(1)  | CPHOLD, 1PLUAD NIW                                                          | 78  |
| CIWSTP               | (2)     | CIW FUNCTION:                                                               | 38  |
|                      |         | O 🕫 LOAD FROM NIW                                                           | ••• |
|                      |         | 1 → NEWPARCEL (LEFT SHIFT 15)                                               |     |
|                      |         | 3 P HOLD                                                                    |     |
| *MADSTP              | (1)     | SELECTS INPUT TO MA: CALOW BITS OF AC, 1AP REG.                             | 74  |
| *MADCLKT<br>*PRGSTP- |         | OPHOLD, 1PLOAD MA                                                           | 73  |
| TPROSIF-             | - (2)   | P REGISTER FUNCTION:<br>O → HOLD                                            | 75  |
|                      |         | 1 P INCREMENT                                                               |     |
|                      |         | 2 P DECREMENT                                                               |     |
|                      |         | 3 P LUAD FROM AC                                                            |     |
| +CMFCN               | (2)     | CENTRAL MEMORY FUNCTION:                                                    | 79  |
|                      |         | 0 P H010                                                                    |     |
|                      |         | 1 → CLEAR REQUEST                                                           |     |
|                      |         | 2 P ISSUE READ REQUEST                                                      |     |
|                      | ( 7 )   | 3 P ISSUE WRITE REQUEST                                                     |     |
| LATCHI               | (1)     | OPLOAD I LATCH WITH I FIELD OF CURRENT INSTRUCTION<br>IPHOLD                | 27  |
| MICROPROGRAM         | ADDRESS |                                                                             |     |
| CNDSTP               | (6)     | SELECTS CONDITION TO BE TESTED                                              | 28  |
|                      |         | 0 → FALSE                                                                   | 20  |
|                      |         | 1 → EXPONENT ALU PRUPAGATE DUTPUT                                           |     |
|                      |         | 2 ∂ EALU P OUTPUT Y ⊐ EALU OPERAND 2 BIT 10                                 |     |
|                      |         | 3 → ÉALU P OUTPUT → EALU OPERAND 2 BIT 10                                   |     |
|                      |         | 4 → EXPONENT ALU BIT 11                                                     |     |
|                      |         | 5 P EXPONENT ALU BIT 0 A BIT 1                                              |     |
|                      |         | 6 ₽ EXPONENT ALU BIT 2 ^ BIT 3<br>7 ₽ EXPONENT ALU BIT 4 ^ BIT 5            |     |
|                      |         | IO P FOFL                                                                   |     |
|                      |         | LI & XFOFL                                                                  |     |
|                      |         | 12 → M (LUW 4 BITS OF MQ) > 7                                               |     |
|                      |         | 13 PM (LUW 4 BITS OF MQ) > 8                                                |     |
|                      |         | 14 # EALU BITS O THROUGH B NOT ALL O                                        |     |
|                      |         | 15 P REGISTER UUTPUT BIT 59                                                 |     |
|                      |         | 16 P REGISTER OUTPUT BIT 17                                                 |     |
|                      |         | $17 \rightarrow BUF BIT 59$                                                 |     |
|                      |         | 20 7 AC BIT 59<br>21 7 AC BIT 49                                            |     |
|                      |         | $22 \rightarrow AC B1T 47$                                                  |     |
|                      |         | 23 P AC B1T 46                                                              |     |
|                      |         | 24 → ALU OUTPUT BIT 59 ≠ BIT 47                                             |     |
|                      |         | 25 → ALU PROPAGATE OUTPUT                                                   |     |
|                      |         | 26 P MQ BIT 59                                                              |     |
|                      |         | 27 A MQ BIT 50                                                              |     |
|                      |         | $30 \rightarrow MQ B1T 49$                                                  |     |
|                      |         | 31 ∂ ALU OUTPUT BIT 59<br>32 ∂ ALU OUTPUT BIT 48 ≠ BIT 59                   |     |
|                      |         | 32 ₩ ALU DUTFUT BIT 48 ¥ BIT 34<br>33 ₩ BUF BIT 59 ¥ REGISTER DUTPUT BIT 59 |     |
|                      |         | JUNE DOT DEL JY FREDEDIER DOTTOT DEL J7                                     |     |

|         |                | 34 ₽ ALU GENERATE JUTPUT                     |     |
|---------|----------------|----------------------------------------------|-----|
|         |                | 35 🕫 ALU UUTPUT BIT 49                       |     |
|         |                | 36 @ ALU OUTPUT BIT 47                       |     |
|         |                | 37 P AC << BUF ~ 7 MQ(49)                    |     |
|         |                | 40 → OPCODE B1T O                            |     |
|         |                | 41 & OPCODE BIT 1                            |     |
|         |                | 42 P OPCODE BIT 2                            |     |
|         |                | $43 \rightarrow 1$ LATCH BIT O               |     |
|         |                | 44 P I LATCH BIT 1                           |     |
|         |                | $45 \neq 1$ LATCH BIT 2                      |     |
|         |                |                                              |     |
|         |                | $40 \rightarrow I LATCH = 0$                 |     |
|         |                | 47 🕫 I LATCH > 5                             |     |
|         |                | 50 A CURFENT INSTRUCTION J FIELD = 0         |     |
|         |                | 51 ₽ MODEZ (cXTERNALLY SET FLAG)             |     |
|         |                | >2 → MODE4 (EXTERNALLY SET FLAG)             |     |
|         |                | >3 → CMDDNE (SET BY CENTRAL MEMORY)          |     |
|         |                | 54 P LASTPARCEL                              |     |
|         |                | 55 P NIWEMPTY                                |     |
|         |                | 56 P ICHECK                                  |     |
|         |                | 57 P EXTINT (EXTERNALLY SET FLAG)            |     |
| BRADDRO | (10)           | BRANCH ADDRESS IF CONDITION IS FALSE         | • • |
|         | · <u>-</u> · · |                                              | 11  |
| OPCDBRO | (1)            | IPREPLACE LOW & BITS OF BRADDRO BY OPCODE OF | 21  |
|         |                | CURRENT INSTRUCTION                          |     |
| BRADDR1 | (10)           | BRANCH ADDRESS IF CONDITION IS TRUE          | 0   |
| OPCDBR1 | (1)            | I∂REPLACE LOW 6 BITS OF BRADDR1 BY OPCODE OF | 11  |
|         |                | CURRENT INSTRUCTION                          |     |
| SPCLFCN | (1)            | IPENABLE SPECIAL FUNCTIONS (SEE FOOTNOTE)    | 81  |
|         | -              |                                              |     |

NOTE: A MICROINSTRUCTION CONTAINS &5 BITS, NUMBERED O TO 84. EACH FIELD OCCUPIES A CONSECUTIVE GROUP OF BITS IN A MICROINSTRUCTION; THE BIT POSITION COLUMN SPECIFIES THE NUMBER OF THE LOWEST-NUMBERED BIT IN THE GROUP.

\* FIELDS MARKED WITH AN \* ARE SPECIAL FIELDS. THE EFFECTIVE VALUE OF A SPECIAL FIELD IS OBTAINED BY ANDING ITS BITS IN THE MICROINSTRUCTION WITH THE SPECIAL FUNCTION FIELD, -SPCLECN+. THE SPECIAL FIELDS OCCUPY BIT POSITIONS ALSO USED BY THE CONSTANT FIELD OF THE EXPONENT AU. IF A CONSTANT IS NEEDED IN A MICROINSTRUCTION, SPCLECN IS SET TO 0 AND ALL SPECIAL FIELDS ARE EFFECTIVELY O. IF A NON-ZERO SPECIAL FIELD IS REQUIRED IN A MICROINSTRUCTION, SPCLECN IS SET TO 1 AND THE SPECIAL FIELDS ARE SET TO THEIR REQUIRED VALUES; PRESUMABLY IN THIS CIRCUMSTANCE THE FIELD WILL NOT SIMULTANEOUSLY BE USED AS A CONSTANT BY THE EXPONENT AU, SINCE IT IS MOST UNLIKELY THAT THE BIT PATTERN PRODUCED BY COMBINING THE SPECIAL FIELDS WILL BE A USEFUL CONSTANT.

## 6. The microprogram for CDC 6600 emulation

Presented below is the complete PUMA microprogram for emulation of the Control Data 6600 central processor, consisting of 454 microinstructions. This microcode was originally developed by the author concurrently with the design of the PUMA, and was subsequently improved by R. Kenner and annotated by A. Czerniakiewicz.

Although the microcode is extensively commented, at least one point deserves separate mention here. When the instructions in one word have been executed, CIW = NIW will be performed to bring the next instruction word into CIW. The microprogram will then immediately issue a read request for the following word to fill NIW, which is now empty. This read operation will proceed concurrently with the execution of the first instructions in the instruction word. The condition NIWEMPTY  $\land$  CMDONE indicates that memory is ready with data which is to be loaded into NIW. This condition will be checked at the end of the microprogram sequence defining each 6600 operation. Thus the last instruction of each such sequence will include the test

IF ICHECK THEN ICHECK ELSE OPCODEBRANCH

where ICHECK serves both as the mnemonic for the condition LASTPARCEL V (NIWEMPTY ^ CMDONE) and the label for the code handling the condition. This code sequence appears on the third page of the microcode. If LASTPARCEL is not true (have not executed last instruction in a word), the microprogram will load the next instruction word into NIW and then continue with execution of the current instruction word.

Because the fetch of data for NIW occurs concurrently with instruction execution, every microcode sequence which involves a memory access must check whether this fetch is still going on (whether NIWEMPTY). If it is, the microcode must complete this fetch before beginning the next memory operation. The sequences which perform this check are: the branch sequence (executed whenever a branch is taken);

the return jump (opcode 01); and register load/store (opcodes 50 to 57).

This emulator differs functionally from the CDC 6600 in a few minor respects:

 Rounded floating-point instructions produce their results by post-rounding (adding 1/2 to the final coefficient). In some circumstances this may produce a more accurate result than the 6600, which uses pre-rounding.

2. Floating-point runs are computed using an effective 110-bit accumulator, whereas the 6600 uses a 98-bit accumulator. In consequence, double-precision sums may differ from their 6600 counterparts by 1 in the low-order bit.

| ******   | *************************                                       | k        |
|----------|-----------------------------------------------------------------|----------|
| *        |                                                                 |          |
| т<br>    |                                                                 | -        |
| *        | EXCHANGE JUMP                                                   | P.       |
| *        | ,                                                               | ×.       |
| *        | THROUGH AN EXCHANGE JUMP SEQUENCE, THE PERIPHERAL PROCESSOR     | ŧ.       |
| *        | CAN CAUSE THE CENTRAL PROCESSOR TO EXCHANGE THE CURRENT VALUES  | ŧ        |
| *        | OF THE P, X, A, AND B REGISTERS WITH VALUES STORED IN MEMORY.   | •        |
| *        |                                                                 | ŧ        |
| +        | OF THE CENTRAL PROCESSOR FROM ONE USER-S JOB TO ANOTHER.        | Ξ.       |
| <b>T</b> |                                                                 |          |
| *        | THE TREATS IN HERBYL AND STORES IN A TO ROAD SECOND AS TOEEONS. | ŧ.       |
| *        |                                                                 | ŧ        |
| *        | IN BITS 18 TO 35, AO                                            | ŧ.       |
| *        | IN BITS O TO 17, BO = $O$                                       | ŧ        |
| *        | IN WORD I, 1=1 TO 7 IN BITS 18 TO 35, A(I)                      | *        |
| *        | IN BITS O TO 17, B(I)                                           | *        |
| *        | IN WORD 1, 1=8 TO 15 X(1-8)                                     | Å.       |
| +        |                                                                 | 2        |
| *        |                                                                 |          |
| *        | THE SEQUENCE OF OPERATIONS INVOLVED IN AN EXCHANGE JUMP ARE:    | *        |
| *        | 1) THE PP RAISES THE EXTERNAL INTERRUPT (EXTINT) LINE           | ŧ.       |
| *        | 2) THE CP STUPS EXECUTING INSTRUCTIONS AT THE END OF THE        | <b>*</b> |
| *        | CURRENT INSTRUCTION WORD, AND SETS P=-O AS A SIGNAL             | ŧ        |
| *        | TO THE PP                                                       | *        |
| *        | 3) THE PP PUTS THE ADDRESS OF THE EXCHANGE PACKAGE UNTO         |          |
| +        |                                                                 | 1        |
| *        | THE CMRD LINES. ON MACHINES WITH AN RA AND FL, THE PP           |          |
| *        | WILL ALSO RESET THESE REGISTERS (SINCE THE EXCHANGE             | ₽.       |
| *        | PACKAGE WILL NORMALLY BE GUTSIDE THE USER-S FIELD               | ŧ.       |
| *        | LENGTH).                                                        | ŧ.,      |
| *        | 4) THE PP LOWERS THE EXTINT LINE, SIGNALLING THE CP TO          | ŧ.       |
| *        | BEGIN THE REGISTER EXCHANGE                                     | *        |
| *        | 5) THE CP SETS P=0 TO SIGNAL THE COMPLETION OF THE REGISTER     | *        |
|          | EXCHANGE.                                                       | ÷        |
| +        |                                                                 | Ξ.       |
| *        | 6) THE PP NOW RESETS RA AND FL TO THE REFERENCE ADDRESS         |          |
| *        | AND FIELD LENGTH OF THE NEW USER PROGRAM, AND THEN              | Ŧ        |
| *        | RAISES AND DROPS LINE EXTINT ONCE MORE TO SIGNAL TO             | *        |
| *        | THE CP TO START INSTRUCTION EXECUTION                           | *        |
| *        |                                                                 | *        |
| *******  | ***************************************                         | ŧ        |
| *        |                                                                 |          |
| *        | WHEN THE CP IS POWERED UP, MICRUPROGRAM EXECUTION WILL NORMALLY |          |
| *        | BE INITIATED STARTING WITH MICROINSTRUCTION -WAIT               |          |
|          |                                                                 |          |
| *        | E1 IS SET TU ACCESS REGISTER NUMBER ZERO (A, B)                 |          |
| WAIT     | AC=CMRD; E1=270; IF EXTINT THEN WAIT ELSE XJP1 * PICK UP CMRD.  |          |
| XJP      | AC=-O; IF ¬CMDONE THEN XJP                                      |          |
|          | MQ=P; P=AC; CLEAR; GO WAIT                                      |          |
| XJP1     | MA=AC; P=AC; AC%MQ=SHIFT(AC%MQ,01); CLEAR                       |          |
| XJP2     | IF CMDONE THEN XJP2                                             |          |
| *        | POINT TO START OF PACKAGE. NUW BUILD 18 BITS MASK FOR           |          |
| *        |                                                                 |          |
| Ŧ        | LATER USE IN EXTRACTING REGISTERS FROM PACKAGE.                 |          |
|          | READ; AC%MQ=SHIFT(AC%MQ,R1) * RECREATE MQ.                      |          |
|          | AC=SHIFT(AC%M0,A1); BUF=AG; E0=12                               |          |
| XJPSL    | AC=SHIFT(AC%MQ,A4); EO=EO-1[F]; IF EALU(O-3) THEN XJPSL         |          |
| *        | NOW SAVE MASK AND OLD P-REGISTER VALUE.                         |          |
|          | YO=AC; AC=MQ                                                    |          |
|          | Y1=AC; MQ=O; GU XJPENT                                          |          |
|          | ta nay ne oy oo norent                                          |          |

THIS IS THE FIRST LOOP OF THE EXCHANGE JUMP CODE. THIS LOOP INSERTS THE A AND B REGISTERS INTO THE NEW EXCHANGE PACKAGE AND EXTRACTS THEM FROM THE OLD PACKAGE. XJPL1 AC%MQ=SHIFT(BUF%MQ)R16)AC%MQ=SHIFT(AC%MQ,R1) AC%MQ=SHIFT(AC%MQ,K1); BUF=AM X J P E N T AC%MQ=SH1FT(BUF%MQ,R16) AC2MQ=SHIFT(AC2MQ,R1) \* GET OLD P. AC%MQ=SHIFT(AC%MQ,K1); BUF=Y1 AC%MQ=SHIFT(BUF%MQ,R16) AC%MQ=SH1FT(AC%MQ,K4) AC2MQ = SH1FT(AC2MQ)K4)AC=MQ; IF ¬CMOONE THEN XJPWT1 XJPWT1 MQ=CMRD; CLEAR XJPWT2 IF CMDJNE THEN XJPWT2 WRITE NOW WAIT FOR WRITE ACCEPT. XJPWT3 IF ¬CMDDNE THEN XJPWT3 CLEAR; AC=MQ; BUF=Y0 \* GET MASK. Y2=AC; AC=ACA-BUF BM=AC; MQ=0 \* STORE B REGISTER. BUF=Y2 AC=SHIFT(BUF%MQ,R16) AC = SHIFT(AC % MQ R1)AC=SHIFT(AC%MQ,R1); BUF=YO  $Y2=AC; AC=AC^{-}BUF; P=P+1$ SET -A- REGISTER AND SEE IF MUST EXTRACT P. AM=AC; =7+E1; IF EALUPOUT- THEN XJEXTP E1=E1+7760[F]; AC=0 \* INCREMENT NUMBER AND CLEAR AC XJPWT4 BUF=BM; 1F CMDUNE THEN XJPWT4 \* WAIT FOR MEMORY. Y1=AC; MA=P; READ =E1; IF EALU(0-3) THEN XJPL1 ELSE XJPCON NOW WE HAVE THE #APPENDAGES# FOR THE ABOVE ROUTINE. WE HAVE THE CODE TU EXTRACT THE NEW VALUE OF THE P REGISTER FROM THE FIRST WORD OF THE EXCHANGE PACKAGE. IT IS SAVED IN Y4. XJEXTP BUF=Y2; E1=E1+7760[F] AC=SHIFT(BUF%NQ,k16) AC=SHIF1(AC%MQ,R1) AC=SHIFT(AC2MQ,F1); OUF=Y0 \* GET MASK. AC = AC - BUFY4=AC; AC=U; GU XJP#T4 NOW CONTINUE WITH THE MAIN CODE. NOW GET THE X REGISTERS. XJPCON El=270; BO=AC \* CLEAR BO; RESET REGISTER NUMBER. XJPLOOP2 BUF=XM; MQ=CMFD; IF ¬CMDONE THEN XJPLOOP2 XJPWT6 AC=BUF; CLEAR; IF CMDDNE THEN XJPWT6 WRITE; P=P+1 XJPWT7 IF -CMOUNE THEN XJFWT7 MA=P; AC=MQ; BUF=Y4; CLEAR XM=AC; AC=0; E1=E1+7760[F]; IF ¬EALU(0-3) THEN XJPDONE XJPWT8 IF CMDUNE THEN XJPWTS

READ; GO XJPLOOP2 XJPDONE P=AC; IF PEXTINT THEN XJPDONE AC=BUF; IF EXTINT THEN WAITI ELSE BR2 WAIT1 \*\*\*\*\*\*\* ICHECK SEQUENCE% BRANCH HERE WHEN ALL INSTRUCTIONS IN AN INSTRUCTION WORD HAVE BEEN EXECUTED, OR WHEN NEXT INSTRUC-TION WORD IS AVAILABLE TO LUAD INTO NIW. \*\*\*\*\*\* ICHECK IF LASTPARCEL THEN ADVANCEP NIWEMPTY ~ CMDONE IS TRUE; FETCH NEXT INSTRUCTION WORD AND GO TO NEXT INSTRUCTION NIW=CMRD; CLEAK; LATCH 1; GO UPCODEBKANCH CURRENT INSTRUCTION WORD IS COMPLETE HAS NEXT INSTRUCTION WORD BEEN FETCHED? ADVANCEP P=P+1; IF NIWEMPTY THEN KNIWAIT YES, PUT NEXT INSTRUCTION WURD INTO CIW LOADCIW CLEAR; CIW=NIW; IF CMDUNE THEN LOADCIW INITIATE READ OF NEXT INSTRUCTION WORD AND BRANCH TO \* EXECUTE FIRST INSTRUCTION OF CURRENT WORD \* MA=P; READ; LATCH 1; IF FEXTINT THEN UPCODEBRANCH RNI EXTERNAL INTERRUPT HAS BEEN RAISED, RESET P TO ADDRESS OF NEXT \* INSTRUCTION TO BE EXECUTED WHEN EXECUTION OF THIS PROGRAM RESUMES, AND ENTER EXCHANGE JUMP SEQUENCE. P=P-1; GO XJP RNIWAIT NIW=CMRD; IF ¬CMDONE THEN KNIWAIT ELSE LOADCIW \* \* BRANCH SEQUENCE \*\*\*\*\*\* COMPLETE FETCH OF NEXT INSTRUCTION IN SEQUENCE BRANCH IF -NIWEMPTY THEN BR2 BRWAITI NIW=CMRD: IF ¬CMDUNE THEN BEWAITI \* EMPTY NIW, RESET P, WALT FOR CMDUNE TO GO LOW CLEAR; CIW=NIW; P=AC; IF ¬CMDONE THEN BK3 BR2 BRWAIT2 IF CMDONE THEN BRWAIT2 BR3 MA=P; READ; P=P+1; GU RNIWAIT \* ERROR STOP: STORE MODE AND ADDRESS OF CURRENT INSTRUCTION + 1 IN WORD O AND JUMP TO O. MODE BIT + 2000 SHOULD BE IN EO ON ENTRY \* MODES: O= PROGRAM STOP \* 2= INFINITE OPERAND 4= INDEFINITE OPERAND

```
EKRUR
         AC=P; E2=36
         MQ=0; IF ¬NIWEMPTY THEN ERRURLP
EPRWT
         IF -CMDDNE THEN ERRWT
           ***
           * P (ADDRESS OF CURRENT INSTRUCTION + 1) IS SHIFTED LEFT 30 BITS
           * AND THEN PACKED WITH EU. PACK OPERATION STRIPS THE 2000 BIT
              FRUM 20, LEAVING MUDE BIT AND P IN YO.
           *
           ***
         YO = EOZAC; AC = SHIFT(ACZMQ,L1); = E2-1
ERRORLP
         E2=E2-1; IF TEALU(11) THEN ERROREP
ERKSTORE CLEAR; BUF=Y(; AC=0; IF CMDDNE THEN ERRSTORE
         MA=AC; AC=3UF; WRITE
ERRORWED IF SCHOONE THEN ERRORWED
           ***
*
*
           * SET P = 0 AND LOOP WAITING FOR EXTINT (EXTERNAL INTERRUPT)
*
           * * *
        \Delta C = 0
HALT
        PEAC; IF EXTINT THEN XJP ELSE HALT
*
*****
¥
*
           SPECIAL FLOATING POINT RESULTS
*
*****
*
*
           ***
*
             FLRESFLU: EXPONENT OVER/UNDERFLOW - ON ENTRY, EXPONENT IN EO.
*
           *
                  EOKU: UNDERFLOW, STORE O IN XI
*
           *
                  EO>0: OVERFLOW, STURE INFINITY IN XI
*
           *
                  (FLKSFLON -- SAME PLUS DO NEWPARCEL)
           ***
FLESFLON =E0; NEWPARCEL; IF CALU(11) THEN AXIZERD ELSE WXIINF
FLRESFLU =E0; IF EALU(11) THEN WXIZERO ELSE WXIINF
*
           ***
*
           * WXIZEKO: ZERO RESULT
           ***
WXIZLRON AC=0; NEWPARCLL; GO WXI
WX1ZERD AC=0
WXI
        XI=AC; LATCH 1; IF ICHECK THEN ICHECK ELSE OPCODEBRANCH
*
           * * *
           * WXIINDEF: INDEFINITE RESULT. 1.E. EXPONENT OF XI EQUAL 1777.
*
           ***
WX1INDEF AC=0; E0=7777
WXIFLOAT XI=EO%AC; LATCH I; IF ICHECK THEN ICHECK ELSE OPCODEBRANCH
本
          ***
*
           *
             WXIINF : INFINITE RESULT. SIGN DETERMINED BY SIGN DF AC.
*
           *
*
           *
                      TEST AC(59) CHECKS SIGN OF AC ON ENTRY:
*
          *
                            IF AC(59)=0 (I.E. POS.) WHEN PACKING: AC= 0 ; E0=1777
*
          *
                                        GIVES EXP. 3777 = PLUS INFINITY.
#
           *
                            IF AC(59)=1 (I.E. NEG.), WHEN PACKING: AC=-0 ;E0=1777
*
                                        GIVES EXP. 4000 = MINUS INFINITY
```

```
***
        NEWPARCEL; AC=O; MQ=SHIFT(AC%MQ, U1); EO=1777;
WXIINEN.
        IF AC(59) THEN WXIMIINE ELSE WXIFLUAT
        AC=0; MQ=SHIFT(AC%MQ, 01); EC=1777;
WX1INF
        IF AC(59) THEN WXIMIINF ELSE WXIFLOAT
4
WXIMIINE AC=SHIFT(AC%MQ, R1); GD WXI
          ***
          * INDEFOP: INDEFINITE OPERAND ; ONE (OR BOTH) OF THE EXPONENTS IN
                     E1 AND E2 ARE INDEFINITE
          ***
INDEFORN EO=2004; NEWPARCEL; IF MODE4 THEN ERROR ELSE INDEFOR
INDEFOP E0=2004; IF MODE4 THEN ERKOR
INDEFOP2 IF INF(E1) THEN INFOPTOD
        IF ¬INF(E2) THEN WXIINDEF
INFOPTOD E0=2002; IF MODE2 THEN ERROR ELSE WXIINDEF
ster
*
NEWINSLO NEWPARCEL; IF ICHECK THEN ICHECK
NEWINSTR LATCH I; IF ICHECK THEN 1CHECK ELSE OPCODEBRANCH
*****
  PS. OP OO . PROGRAM STUP.
*****
        EO=2000; GD ERROR . + STURES MODE = 0 IN EO.
00
*
*****************
 RJ K : RETURN JUMP. OP 01 .
        WHEN A RETURN JUMP OCCURS AT LOCATION SHERES TO LOCATION STHERES THE
        FOLLOWING HAPPENS:
        STEP 1: AT LOCATION <THERE > 15 STORED & JUMP TO <HERE + 1 > (I.E.
               0400 P ) AND
        STEP 2: CONTROL TRANSFERS TU <THERE + 1>
******
        MQ=P; E0=2400
01
*
          SHIFT P INTO HIGH 30 BITS OF AC
        AC_{MQ} = SHIFT(O_{MQ} \in 10)
        AC%MQ=SHIFT(AC%MQ,R16)
        AC%MQ=SHIFT(AC%MQ,L1)
        AC%MO=SHIFT(AC%MO,L1)
          STORE 0400 P TEMPORARILY IN YO
        YO=EOZAC; IF -NIWEMPTY THEN UISTURE
        IF -CMDONE THEN OIWT
01WT
        BUF=YO; AC=K; CLEAR; IF CMDUNE THEN DISTORE
OISTORE
        P=AC; MA=AC; AC=BUF; WRITE
OIWAIT
        IF -CMDONE THEN UIWAIT
        P=P+1; CIW=NIW; CLEAR; GO 6RWAIT2
******
```

\* JP BI+K : JUMP TO BI+K- OP 02- VALUE BI+K WILL BE COMPUTED IN AC. \*\*\*\*\*\*\*\*\*\*\* BUF=BI; AC=K; IF 1=0 THEN BEANCH 02 =AC+8UF[18] AC=AC+BUF[18]; IF NIWEMPTY THEN BEWAITLELSE BE2 \*\*\*\*\*\*\*\*\* CC XJyK (CC=ZR)NZ)PLNNG)IR)UR)DF)IU). OP O 30-037CONDITION CODES: WHEN XJ SATISFILS SPECIFIED COND., CONTROL TRANSFERS TD K. ZR:CONTROL TRANSFERS TO K IF XJ IS ZERO (BOTH PLUS ZERO AND MINUS ZERO SATISFY CONDITION). NZ:BRANCH WHEN XJ CUNTAINS ANYTHING UTHER THAN PLUS AND MINUS ZERU PLETRANSFER TO K IF XJ IS PUSITIVE (1.6.8IT 59 IS ZERO) NG:BRANCH IF XJ IS NEGATIVE (I.E.BIT 59 IS 1). ILLEGAL EXPONENTS: IR: JUMP TO K IF XJ IS IN RANGE (1.12 HIGH BITS OF XJ ARE NOT 3777 DR 4000. DR: JUMP TO K IF XJ IS OUT OF RANGE (1.2. 12 HIGH BITS OF XJ ARE 3777\* DR 4000. DF: JUMP TO K IF XJ IS DEFINITE (1.e.12 HIGH BITS OF XJ ARE NOT 1777 OR 6000. ID:JUMP TO K IF XJ IS INDEFINITE (1.8.12 HIGH BITS OF XJ ARE 1777 DR 5000. CONDITIONS 1(X), X=0, 1, 2, BELUM, KEFER TO I FIELD (BITS 21-23) OF OP, AND WHEN SET WILL INDICATE WHICH OF OP 030-037 IS INDICATED THUTH TABLE: T=TRUE=1, F=FALSE=0 1D DF 0R 18 NG PL. NZ ZR (iP) 037 036 035 034 033 032 031 030 I(2) Т T Т T F F F F I(1)Т Т F F τ Т F Ē I(0) F Т F T F T T F \*\*\*\*\* \*BRANCH OCCURS FOR OP 034-037 03 AC=K; IF I(2) THEN FLUATBR \*IN ANY CASE AC≠ K BUF=XJ; MQ=AC; IF 1(1) THEN POSNEGER +1(1) TRUE MEANS OP 032 AND 031. **\*IN ANY CASE BUF= XJ > MQ= K**. AC=BUF; NEWPARCEL; IF I(0) THEN 031 \*\*\*\*\*\*\*\* 030: ZR XJ,K .BRANCH WHEN EITHER XJ =+0 OK XJ = -0. \* \* \* \* \* \* \* \* \* \* \* \* \* NEWPARCEL; IF AC=0 THEN MQBRANCH \*\*\* MOBRANCH: WHEN ADDRESS HAS BEEN KEPT WAITING IN MO, AND IT HAS TO

```
BE TRANSFERED FIRST TO AC.
*
*
          IF AC ≠ +0, CHECK FBR -0.
          * * *
        AC = -AC
        IF AC=0 THEN MOBRANCH ELSE NEWINSTR
          ***
          * BUTH +O AND -O HAVE BEEN CHECKED AND BRANCH DDES NOT OCCUR.
*
          ***
******
* 031: NZ XJ•K •BRANCH WHΣN BOTH XJ ≠ +0 AND XJ ≠ −0•
*****
        NEWPARCEL; IF AC=0 THEN NEWINSTR
031
        AC =-AC
        IF AC=O THEN NEWINSTK ELSE MQBRANCH
          ***
            PUSNEGBR: CURKESPUNDS TO OP 032 AND 033.
*
          *
                      UN ENTRY: BUF = XJ , MQ = K .
          ***
POSNEGBR AC=BUF; NEWPARCEL; IF I(C) THEN 033
*****
* C32: PL XJOK . BRANCH IF XJ IS POSITIVE.
******
                          IF FAC(59) THEN BRANCH ELSE NEWINSTR
        AC=MQ; NEWPARCEL;
                            *BRANCHING DECURS WHEN AC = XJ IS NON NEGATIVE
*
                            *ADDRESS OF BRANCH IS PASSED FROM MQ.
** * * * * * * * * * * *
* 033: NG XJ•K • BRANCH IF XJ IS NEGATIVE
*****
033
        AC=MQ; NEWPARCEL; IF AC(59) THEN BRANCH ELSE NEWINSTR
*
          * * *
*
          * FLUATBR: OP CODES FOR ILLEGAL OPERANDS, I.E. INFINITE AND
                      INDEFINITE OFEFANDS.
*
          * * *
FLUATER ED:BUF=XJ; 1F I(1) THEN INDEFER * 1(1) TRUE MEANS OP 036 AND 037
        NEWPARCEL; IF I(0) THEN 035
*****
≠ 034: IR XJ,K •IN RANGE BRANCH• I•E• BRANCH WHEN 12 BITS OF XJ ARE
              NOT 3777 BR 4000.
*****
        NEWPARCEL; IF FINE(E) THEN BRANCH ELSE NEWINSTR
******
* 035: OR XJ,K . OUT OF RANGE BRANCH. 1.5. BRANCH WHEN 12 HIGH BITS OF XJ
               ARE 3777 UR 4000.
******
```

NEWPARCEL; IF INF(EO) THEN BRANCH ELSE NEWINSTR 035 INDEFBR NEWPARCEL; IF I(0) THEN 037 \*\*\*\*\* DEFINITE BRANCH -- BRANCH WHEN 12 HIGH BITS OF XJ \* 636: DF XJ.K ARE NOT 1777 UR 6000 本 \*\*\*\*\* NEWPARCEL; IF -INDEF(EU) THEN BRANCH ELSE NEWINSTR \*\*\* INDLFINIT\_ 3-ANCH -- BRANCH WHEN 12 HIGH BITS OF XJ \* C37: 10 XJ+K ARE 1777 OK 5000 章 \*\*\*\*\* NEWPARCIL; IF INDEF(\_O) THEN BRANCH LLSE NEWINSTR 037 \*\* \* \* \* \* \* \* \* \* \* \* \* \* \* \* FO BI,BJ,K - OP 04- ERANCH WHEN BI=FJ ( B REGISTERS HAVE ONLY 18 BITS). SINCE THE CASE OF EW X IS SO COMMOND WE WILL TEST FOR IT TO SAVE 2 (UF THE 4) LYCLES. \* \*\*\*\*\* BUF=B1; MQ=K; IF J=U THEN U4EJZEKU 04 AC=BUF; BUF=BJ; KEWPAKCEL AC=AC/BUF == \*EXCLUSIVE DR, I.E. AC=O DNLY WHEN BI AND BJ COINCIDE \* \* \* \* AT THIS PUINT MU = K . \*\*\* AC=MQ; NEWPARCEL; IF AC=O THEN BRANCH ELSE NEWINSTR U4TEST \* THE TEST AC \* O REFERS TO PREVIOUS CONTENTS \* OF AC, 1.t. BI/3J. \* \* IN AC=MQ, AC IS GIVEN ADDRESS OF BRANCH. \* 048JZERU AC=BUF; NEWPARCEL; IF I=0 THEN MUBRANCH ELSE O4TEST \*\*\*\* \* NE BIJBJJK -OP 05. BRANCH WHEN BIFDJ. \*\*\*\*\*\* BUF=BI; MQ=K; IF J=O THEN OSBJZERD 05 AC=BUF; BUF=BJ; NEWPAKCEL AC=AC/BUF AC=MQ; NEWPARCEL; IF FAC=0 THEN BRANCH ELSE NEWINSTR 05TÉST O5BJZERD AC=BUF; NEWPARCEL; IF I=0 THEN NEWINSLO ELSE O5TEST \*\*\*\*\* \* GE BI,BJ,K -OP OG- BRANCH WHEN BI IS GREATER THAN OR EQUAL TO BJ. \*\*\*\*\*\*\* MQ=K; IF K=G(17) THEN UBBINEG 06 BUF=BI; \* REG(17) TRUE MEANS BI(ONLY 18 BITS) IS NEGATIVE. \* AC=BUF; BUF=EJ; NEWPARCEL; IF REG(17) THEN MQBRANCH \* BRANCHING OCCURS BECAUSE BJ IS NEGATIVE, BI IS \* ★ POSITIVE, HENCE BI ≥ BJ.

\* IT IS MOBRANCH BECAUSE WE NEED ADDRESS OF BRANCH \* FROM MO. \*\*\* AT THIS POINT: AC = BI , BUF = BJ , MQ = K . OGSUBTE IS DONE WHEN EITHER BOTH ARE POSITIVE OF BOTH ARE NEGATIVE \* \*\*\* 06SUBTR =AC-BUF[18]; NEWPARCEL; IF NIWEMPTY THEN OGEMPTY AC=MQ; =AC-BUF[16]; IF ALU(59) THEN NEWINSTR ELSE BR2 AC=MQ; =AC-BUF[18]; IF ALU(59) THEN NEWINSTR ELSE BRWAIT1 O6EMPTY \* ALU(59) TRUE MEANS BJ > BT. \*\*\* \* AT THIS POINT: BUF = BI , MQ= K . \* O6BINEG : WE GET HERE WHEN BI IS NEGATIVE. \*\*\* O6BINEG AC=BUF; BUF=BJ; NEWPARCEL; IF REG(17) THEN O6SUBTR ELSE NEWINSLO \* WHEN BJ < O, SINCE BI <O, SUBTRACT THEM, ELSE \* WHEN BJ ≥ O, BRANCH DDES NOT DCCUR. \*\*\*\*\* \* LT BIJBJJK - OP 07 - INSTRUCTIONS ARE SIMILAR TO OP 06. \*\*\*\*\* BUF=BI; MQ=K; IF REG(17) THEN O7BINEG 07 AC=BUF; BUF=BJ; NEWPARCEL; IF TREG(17) THEN O7SUBTR ELSE NEWINSLO O7SUBTR =AC-BUF[18]; NEWPARCEL; IF NIWEMPTY THEN O7EMPTY AC=MQ; =AC-BUF[18]; IF ALU(59) THEN BR2 ELSE NEWINSTR 07EMPTY AC=MQ; =AC-BUF[18]; IF ALU(59) THEN BRWAITI ELSE NEWINSTR 07BINEG AC=BUF; BUF=BJ; NEWPARCEL; IF ¬REG(17) THEN MQBRANCH ELSE O7SUBTR MQBRANCH AC=MQ; IF NIWEMPTY THEN BRWAIT1 ELSE BR2 BOOLEAN INSTRUCTIONS \* OP 10- BXI XJ - TRANSFER A 60-BIT WURD FROM XJ TO XI. 0P 11-BXI XJ\*XK - LUGICAL PRODUCT OF XJ AND XK IS PASSED TO XI-(BIT IN XI IS I WHEN CORRESPONDING BITS IN BOTH XJ AND XK ARE 1). OP 12-BXI XJ+XK - LUGICAL SUM OF XJ AND XK TO XI-(BIT IN XI IS 1 WHEN \* CORRESPONDING BIT IN EITHER XJ OR XK IS 1). \* OP 13- BXI XJ-XK - LOGICAL DIFFERENCE (EXCLUSIVE OR) OF XJ AND XK TO XI\* \* (BIT IN XI 1S I WHEN CURRESPONDING BITS IN XJ AND XK ARE UNLIKE) \* OP 14-BXI -XK - TRANSMIT THE COMPLEMENT OF XK TO XI-\* OP 15-BXI -XK\*XJ- - THE LOGICAL PRODUCT OF XJ AND THE COMPLEMENT OF XK IS PASSED TO XI OP 16- BXI -XK+XJ- - THE LOGICAL SUM OF XJ AND THE COMPLEMENT OF XK IS \* PASSED TO X1. OP 17- BXI -XK-XJ- - THE LOGICAL DIFFERENCE OF XJ AND THE COMPLEMENT DF\* \* XK TO XI. 

```
BXI XJ (3 CYCLES)
•
        BUF = XJ
10
        AC=BUF: NEWPARCEL; GO WXI
WXIBUF
          BXI
               XJ×XK (4 CYCLES)
*
        BUF=XK
11
        AC=BUF; BUF=XJ
        AC=ACABUF; NEWPARCEL; GO WXI
AND.
               XJ+XK (4 CYCLES)
*
          BX1
12
        BUF=XK
        AC = BUF; BUF = XJ
        AC=AC-BUF; NEWPARCEL; GU WX1
OR-
*
          BXI
               XJ-XK (4 CYCLES)
        BUF=XK
13
        AC=BUF; BUF=XJ
        AC=AC/BUF; NEWPARCEL; GO WXI
EXDR
          BXI -XK (3 CYCLES)
*
14
        BUF=XK
        AC=-BUF; NEWPARCEL; GU WX1
          BXI
                -XK +XJ (4 CYCLES)
15
        BUF = XK
        AC=-BUF; BUF=XJ; GJ AND
                -XK+XJ (4 CYCLES)
*
          BXI
        BUF=XK
16
        AC=-BUF; BUF=XJ; UJ OR
               -XK-XJ (4 LYCLES)
          BXI
*
17
        BUF=XK
        AC=-BUF; BUF=XJ; GU EXOR
*
 LXI JX - OP 20 - LEFT CIRCULAR SHIFT X1, JK PLACES.
         -SINCE ONLY BIG RIGHT CIRCULAR SHIFTS ARE PERFORMED BY THE MACHINE,
          JK-LEFT IS FIRST TRANSFORMED INTO A (74(OCTAL)-JK)-RIGHT SHIFT, OR,
          WHEN JK>00 INTO (120 - JK)-RIGHT SHIFT. EO CARRIES THE RIGHT SHIFT
          COUNT.
         -NQ AND AC WILL BUTH CONTAIN XI.
         -SHIFTING (U UNITS) IS DONE AT THE SAME TIME THAT THE EXPONENT IS
                                                                             *
*
          BEING REDUCED (BY U UNITS), THEREFORE, CALLING N THE NUMBER OF RIGHT *
×
          SHIFTS NEEDED, N WILL BE REDUCED BY 16, 4 OR 1 UNTIL IT BECOMES ZERO*
*
          ACCORDING TO THE FULLOWING ALGURITHM:
夲
*
                                                                             *
*
              IF (N < 16) GO TO TRY4
                                                                             *
*
              N = N - 16
      SHIFTI6
                                                                             *
              SHIFT RIGHT 16
≭
                                                                             *
*
              IF (N ≥ 16) GO TO SH1FT16
                                                                             *
              1F (N < 4) GO TO TRY1
卒
      TRY4
                                                                             *
*
      SHIFT4
              N = N - 4
                                                                             *
ŧ
              SHIFT RIGHT 4
                                                                             *
*
渖
              IF (N ≥ 4) GU TO SHIFT4
*
      TRY1
              IF N =0 GO TO WRITEXI
                                                                             *
*
              N = N - 1
      SHIFT1
                                                                             *
*
              SHIFT RIGHT 1
              1F (N > 0 ) GO TO SH1FT1
```

```
WRITEXI END
    *******
        BUF=XI; =74-JK
20
        AC=BUF; EO=74-JK;
                          NEWPARCEL; IF EALU(11) THEN BIGSHIFT
                           *IF EALU(11) IS SET, NUMBER OF SHIFTS WAS BIGGER
*
                           *THAN 60 HENCE WE WILL SHIFT RIGHT (120 - JK).
          ***
            AT THIS POINT AC = X1, EU = 60-JK, AND WE ARE READY
          *
           TO START THE SHIFT.
          ***
LSHIFT
        MQ=AC; =EO; IF \neg(calu(4)\veeEALU(5)) THEN 20TRY4
                           * TRUE MEANS EALU(4)=EALU(5)=0, I.E.U≤EU < 16
*
205H16
        AC%MQ=SHIFT(AC%MQ)+15); EU=EU-2U[F]; IF EALU(4)-EALU(5) THEN 20SH16
                           * I.E. 1F EITHER EALU(4)=1 DR EALU(5)=1, EO ≥ 16
                           * AND WE CAN STILL REDUCE BY 16 = 20 (DCTAL).
        =EO; IF ¬(EALU(2) VEALU(3)) THEN 20TRY1
20TRY4
                           # IF BUTH EALU(2) = EALU(3) = 0, 0 ≤ E0 ≤ 4
20SH4
        AC%MQ=SHIFT(AC%MQ)R4); EU=EC-4[F]; IF EALU(2)~EALU(3) THEN 20SH4
                           * GO ON SHIFTING BY 4 WHENEVER EALU(2)=1 OR
                           * EALU(3)=1, I_*E_* 4 \leq EO < 16 .
        =EO; IF =(EALU(0) =EALU(1)) THEN #XI
20TRY1
                           * IF BUTH EALU(U)=EALU(I)=U, N=U AND WE ARE DONE.
20SH1
        AC%MQ=SHIFT(AC%MQ,E1);=0=E(-1[F];1F EALU(0)VEALU(1) THEN 20SH1 EESE WXI
          ***
          * BIGSHIFT: WHEN JK>60, SET E0=120- JK
          ***
BIGSHIFT =E0+74; MQ=AC
        EO=EO+74; IF -(EALU(4)-EALU(5)) THEN 2JTKY4 ELSE 20SH16
************************
 - AXI JK - OP 21 - ARITHMETIC SHIFT RIGHT X1, JK PLACES.(I.E. WITH SIGN EXT.)
        -PROCEDURE IS SIMILAR TO DP 20, BUT SIMPLER BECAUSE EO = JK NOW
         GIVES RIGHT SHIFTS.
        -CONTENTS OF MQ NOW DO NOT MATTER BECAUSE THE SHIFT IS RIGHT WITH
         SIGN EXTENSION.
             *
21
        BUF=XI; EO=JK; NEWPARCEL
        AC=BUF; =EO; IF ¬(EALU(4) VEALU(5)) THEN 21TRY4
RSHIFT
        AC%MQ=SHIFT(AC%MQ,A16); EC=EC-2C[F]; IF EALU(4)~EALU(5) THEN 21SH16
21SH16
        ■EO; IF ¬(EALU(2) VEALU(3)) THEN 21TRY1
21TRY4
21SH4
        ACZMQ=SHIFT(ACZMQ,A4); EO=EC-4[F]; IF EALU(2)VEALU(3) THEN 21SH4
21TRY1
        =EO; IF ¬(EALU(0)YEALU(1)) THEN WXI
21SH1
        AC%MQ=SHIFT(AC%MQJA1);E0=E0-1[F];IF EALU(0)VEALU(1) THEN 21SH1 ELSE WXI
* LXI BJ•XK - OP 22 - LEFT CIRCULAR SHIFT XK NÛMINALLY BJ PLACES TO XI•
```

```
* AXI BJ, XK -OP 23- ARITHMETIC RIGHT SHIFT XK NOMINALLY BJ PLACES TO XI.
        -IF BJ IS POSITIVE THESE INSTRUCTIONS ACT JUST LIKE THE SHIFTS OF
        OP 20 AND 21, WITH THE LOW SIX BITS OF BJ TAKEN AS SHIFT COUNT.
        -IF ANY OF THE BITS & THEOUGH 10 OF BJ ARE NON-ZERO, THE NOMINAL
         RIGHT SHIFT WILL, INSTEAD OF PERFORMING THE SHIFT, SET XK TO ZERO.
        -IF BJ IS NEGATIVE, EACH INSTRUCTION ACTS AS THE OTHER WOULD WITH
         THE COMPLEMENT OF SJ.
******
******** LXI
              B J 🗴 X K
22
        BUF=BJ; E0=77; 1F REG(17) THEN 22RIGHT
                            * WHEN BJ <0, IT IS A RIGHT SHIFT
*
                            * 77(OCTAL) FORMS A MASK IN EO THAT WILL GUARANTEE
                            * THAT AC CONTAIN EXACTLY 6 LOW BITS OF BJ.
        AC = FO
        AC=AC-BUF
22LSHIFT =74-AC; BUF=XK; IF AC=0 THLN #XIBUF
        ED=74-AC; AC=BUF; NEWPARCEL; IF EALU(11) THEN BIGSHIFT ELSE LSHIFT
          ***
          * AT THIS FOINT BUF = BJ IS NEGATIVE
          * * *
        AC = - BUF
22RIGHT
22KSHIFT ED=AC; BUF=XK; IF AC=0 THEN WXIBUF
        AC=0; NEWPARCEL; IF LO(0-10)=0 THEN RSHIFT ELSE WXI
                            * SINCE BJ <0 , EU= -BJ . IF ANY OF BITS 6-10
                            * OF LO ARE NONZERO, THIS BEING A RIGHT SHIFT,
                            * IT KETURNS ZERO.
******** AXI
              8 J • XK
*
        BUF=BJ; EO=77; IF KEG(17) THEN 23LEFT
23
        AC=BUF; GD 22RSHIFT
          ***
          * AT THIS POINT BUF = BJ < O , EC = 77(OCTAL) CONTAINS A MASK
          ***
23LEFT
        AC = c O
        AC=AC-BUF; GO 22L3HIFT
* NXI BJ9XK . OP 24 . NORMALIZE XK INTO XI AND BJ.
                 -XK IS SHIFTED LEFT BIT BY BIT UNTIL THE MOST SIGNIFICANT
                  BIT IS IN BIT 47 . POSITIONS VACATED ON THE RIGHT ARE FILLED*
                  WITH ZERDS (BINARY ONES IF THE NUMBER IS NEGATIVE).
                 -FOP EACH BIT THAT THE COEFFICIENT IS SHIFTED, THE EXPONENT
*
                  IS DECREMENTED BY ONE.
                 -THE NORMALIZED NUMBER IS PUT IN THE XI REGISTER, AND THE
*
                  NUMBER OF SHIFTS REQUIRED FOR NORMALIZATION IS LEFT IN BJ *
*
         NORMALIZING & ZERO COEFFICIENT ENDS WITH A SHIFT COUNT
*
         BJ = 48(DECIMAL), AND XI CLEARED TO ZERO.
```

ZXI BJ•XK - OP 25 -ROUND AND NJRMALIZE XK INTO XI AND BJ• -BEFORE NORMALIZING, THIS INSTRUCTION ATTACHES A 1 BIT TO THE RIGHT OF THE BINARY POINT. \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* \* EO2BUF=XK; MQ=0; IF REG(59) THEN NORMNEG 24 \* IF REG(59)=1, XK < 0. \* AC=BUF; IF ILL(E0) THEN 24ILL ELSE NORMZT \* ILL(EG) MEANS INFINITE OR INDEFINITE EXPONENT AC=-BUF; IF ILL(E0) THEN 24ILL ELSE NORMZT NORMNEG \*\*\* AT THIS POINT AC = ABS (XK) , EO = EXP(XK) , BUF= XK , MQ = O \* \* NORMZT CHECKS WHETHER XK = 0. \*\*\* NORMZT E2=60; IF AC=C THEN NORMWXI2 \*\*\* NOSHTEST CHECKS WHETHER XK IS ALREADY NORMALIZED IF NOT, E2 STARTS SHIFT COUNT. \* NORMLOOP WILL KEEP SHIFTING 1 LEFT UNTIL AC(46)=1 : TEST CHECKS \* WHETHER NUMBER WILL BE NORMALIZED (I.E. AC(47)=1) AFTER \* \* THE PRESENT SHIFT \*\*\* NOSHTEST E2=0: IF AC(47) THEN 24SHETDN NORMLOUP AC%MQ=SHIFT(AC%Mu,L1); =E2+2; IF AC(46) THEN 24PLUS1 \* IF AC(40)=1 WE STILL NEED TO INCREASE E2 BY 1 AC%MQ=SHIFT(AC%MQ,L1); E2=E2+2; IF ¬AC(46) THEN NORMLUOP \* SHIFT COUNT IS INCREASED BY 2. \*\*\* \* 24SHFTDN : WE HAVE FINISHED \* \* \* 24SHFTDN =E0-E2; IF BUF(59) THEN 24KECUMP \* PROCEDURE NORMALIZES ABS(XK) - SINCE BUF = XK 🗩 \* WHEN NEGATIVE, WE NEED TO COMPLEMENT THE RESULT EO=EO-E2; IF FOFL THEN NORMUFLO \* EO REPRÉSENTS NEW EXPONENT \* FOFL CHECKS WHETHER NEW EXPONENT \* IS GUT DF RANGE. \* \* \* NORMWX1 SHIFT IS FINISHED AND WE STORE THE RESULT WHEN J=0, BJ = BO = 0 ALWAYS -WHEN J≠O WE LEAVE NUMBER OF SHIFTS IN BJ. \* \*\*\* XI=EO%AC; IF J=O THEN NEWINSLD NORMWXI 24WBJ EO = E224WBJ2 AC = EOBJ=AC; NEWPARCEL; GO NEWINSTR \*\*\* \* NEXT INSTRUCTIONS REPRESENT SPECIAL TESTS \*\*\* \*\*\* \* 24RECOMP :USED WHEN XK < O AND WE ARE DONE NORMALIZING ABS(XK). \*\*\*

```
24RECOMP AC=-AC; E0=E0-E2; IF FOFL THEN NORMUFLO ELSE NORMWXI
         ***
         * NORMUFLO : USED WHEN THERE IS AN EXPONENT UNDERFLOW
                     WHLN SUBTRACTING E0-E2 . LEAVES XI=0.
         * * *
NORMUFLO AC=0
NORMWXIZ EO=E2; X1=AC; IF J=O THEN NEWINSLO ELSE 24WBJ2
         ***
         * 24PLUS1 : USED WHEN THE FINAL NUMBER OF SHIFTS IS ODD, BECAUSE THE
                   NORMALIZE LOOP INCREASES SHIFT COUNT BY 2.
         ***
24PLUS1
       ≠±2+1
       E2=E2+1; G0 24SHFTDN
         ***
         * 241LL :USED WHEN EXP(XK) IS ILLEGAL-
                 FIRST AC = BUF = XK IS RESET, SD INSTRUCTION CAN BE USED
                 BOTH FOR POSITIVE AND NEGATIVE XK.
                 -SHIFT COUNT IS SET TO O, AND XK, UNTOUCHED, IS LEFT IN XI
         *
         ***
       AC=BUF; E2=0; GU NURMWXI
24ILL
******** 2XI BJ•XK
*
         * * *
*
         *
               FULLOWING 2 INSTRUCTIONS SET HIGH BIT OF MO
         ***
÷
25
       MQ=0; £0=10
       MQ=SHIFT(E0%MQ,R4); E0%bUF=XK; IF REG(59) THEN ZNORMNEG
       AC=BUF; IF ILL(E0) THEN 24ILL ELSE NOSHTEST
ZNORMNEG AC=-BUF; IF ILL(E0) THEN 241LL ELSE NOSHTEST
********
* UXI BJ,XK - OP 26 - UNPACK XK TO X1 AND BJ
                -COEFFICIENT OF X1 IS LEFT IN XK (WITH SIGN EXTENSION) AND
                 THE UNBIASED EXPONENT IN BJ.
* PXI BJ,XK - OP 27 - PACK XI FROM XK AND BJ-
                -INSTRUCTION IS THE CONVERSE OF OP 26.
******** UXI
             вЈэХК
26
       EO%BUF=XK; IF J=( THEN WXIBUF
       AC = EO
       BJ#AC; AC=BUF; NEWPARCEL; GO WXI
******** PXI BJ,XK
27
       BUF=BJ
       AC=BUF; BUF=XK; NLAPARCLL
       ED=AC; AC=BUF; GU WXIFLOAT
```

```
* FLOATING POINT ADDITION AND SUBIRACTION
        A FLOATING POINT ADD OF TWO GO BIT NUMBERS INVOLVES THE FOLLOWING:
        STEP 1: THE NUMBER WITH THE SMALLER EXPONENT IS CHANGED BY
                                                                             *
                SHIFTING IT, SU THAT BOTH NUMBERS HAVE THE SAME EXPONENT.
                AFTER SHIFTING, THE SMALLER ADDEND IS A 96 BIT NUMBER.
        STEP2 : COEFFICIENTS ARE ADDED, GIVING A RESULT WITH DOUBLE
                PRECISION ACCURACY
        STEP3 : NORMALIZE THE RESULT IF UVERFLOW.
 FXI XJ+XK - OP 30 - FLOATING SUM UF XJ AND XK TÚ XI.
 FXI XJ-XK - OP 31 - FLOATING DIFFERENCE OF XJ AND XK TO XI.
*
                  -BOTH FLUATING SUM AND DIFFERENCE GIVE THE MOST SIGNIFICANT *
                   48 BITS OF THE RESULT.
 DXI XJ+XK - OP 32 - FLOATING DOUBLE PRECISION SUM OF XJ AND XK TO XI
 DXI XJ-XK - OP 33 - FLOATING DJUBLE PRECISION DIFFERENCE OF XJ AND XK TO XI
                  -DOUBLE PRECISION SUM AND DIFFERENCE GIVE THE LOW ORDER
                   48 BITS OF RESULT. EXPONENT HAS TO BE REDUCED BY 48
                   FROM EXPONENT FOR FLOATING SUM/DIFFERENCE.
 RX1 XJ+XK -OP 34 - ROUND FLOATING SUM OF XJ AND XK TO XI.
 RXI XJ-XK -OP 35 - ROUND FLOATING DIFFERENCE OF XJ AND XK TO X1
                  -GIVES THE MOST SIGNIFICANT 48 BITS OF THE RESULT,
                   AFTER REUNDING
**********
*
********* FXI
                X J + X K
30
        E0%BUF=XK
30A
        AC=BUF; E1%BUF=XJ;
                             IF ILL(EU) THEN BOILLEXP
*
                             * ILL(E0) TRUE MEANS EXP(XK) IS ILLEGAL.
30B
                         IF ILL(E1) THEN BOILLEXP
        MQ=BUF;
                 YO = AC:
                             * ILL(EG) TRUE MEANS EXP(XJ) IS ILLEGAL.
*
        AC=MQ;
                MQ=AC: =EC-E1
          ***
             AT THIS POINT YO=MQ=BUF= XK > AC= XJ = EXP(XK) = E1 = EXP(XJ).
          *
          *
             NEXT INSTRUCTION COMPARES THE EXPONENTS AND . IF NECESSARY (I.E.
             GOING TO BOXKSMAL) INTERCHANGES XK AND XJ SO THAT BEFORE BEGINNING
*
          * -
             BOLDADBUF, YO AND MQ CUNTAIN NUMBER WITH HIGHER EXPONENT AND
          *
            AC CONTAINS NUMBER WITH SMALLER EXPONENT
          ***
        E2=E0-E1; IF EALU(11) THEN BOXKSMAL
```

```
BUF=YO; MQ=O; IF AU(59) THEN BUNEGAC
                              * NUMBER WITH SMALLER EXPONENT MAY BE NEGATIVE.
           ***
             E2 CONTAINS THE DIFFERENCE BETWEEN EXPONENTS, SO IT COUNTS THE
           *
                 NUMBER OF SHIFTS REQUIRED TO ALIGN THE COEFFICIENTS.
            TINYTEST: \neg_22(7-11)=0 MEANS E2 \ge 128 . IN THIS CASE THE
           *
                        DIFFERENCE IN EXPONENTS IS TOO BIG FOR BOTH FLOATING
                        AND DP-SUM SO NUMBER WITH SMALLER EXPONENT IS LIKE O.
            THE SIX INSTRUCTIONS FOLLOWING TINYTEST PERFORM THE SHIFT. THEY
                        ARE THE SAME USED IN OP 21 SINCE AC: MQ CONTAIN THE
                        NUMBER TO BE SHIFTED AND E2 CONTAINS THE SHIFT COUNT.
           *
           ***
TINYTEST IF -E2(6-11)=( THEN BOADDSML
30SHIFT =E2; IF -LALU(4)-LALU(2) THEN 30TRY4
         AC&MQ=SHIFT(AC&NQ;Alo); E2=E2-20EF]; IF EALU(4)~EALU(5) THEN 30SH16
305H16
        =E2; IF -LALL(2)-LALU(3) THEN BUTRYI
30TEY4
30SH4
         ACZMQ=SHIFT(ACZMQ)A4); c2=L2-4[F]; IF EALU(2)VEALU(3) THEN 30SH4
30TRY1
        =E2; IF ¬EALU(0) VEALU(1) THEN BUSHFTDN
        ACZMQ=SHIFT(ACZMQ,A1); E2=E2-1[F]; IF EALU(0)~EALU(1) THEN 30SH1
30SH1
*
           ***
              AT THIS PUINT, THE SMALLER ADDEND IS IN AC:MQ, PROPERLY SHIFTED
              AND BUF CUNTAINS THE BIGGER ADDEND.
           *
              SINCE WE ARE ADDING TWO 120-BITS NUMBERS, WE NEED TO SET THE
           *
           *
            PG TO THE PROPAGALE AND CARRY VALUES OF THE LOWER SUM (I.E. OF
             MO + C WHEN BUP ≥ D JUK UF MO-O WHEN BUP IS NEGATIVE).THIS IS
           *
              DUNC BY INSTRUCTIONS THROUGH 30ADD, WHICH SET PG BUT DO NOT
             CHANGE THE REGISTERS.
±
           *
           * * *
30SHFTUN AC=MQ; MQ=AC; IF BUF(59) THEN BONEGBUF ELSE BOPOSBUF
30NEGBUF (AC) = AC-UESAVEPG]; JU 30ADD
30PDSBUF (AC) = AC+OESAVEPG]
30ADD
        AC=MQ; MU=AC; IF UPCUDE(2) THEN BODP2
                              * JPCODE(2)=1 GIVES OP 34 THROUGH 37
*
           * WE NOW COMPUTE THE HIGHER SUM USING THE P AND G VALUES JUST SAVED
*
        #AC+BUFLUSEPG]; IF OPCODE(1) THEN 30DP
                              * OPCLDE(1)=1 GIVES OP 32 AND 33
                                       =Eu+1; IF ¬ALU(59)/ALU(48) THEN WXIFLOAT
        NEWPARCEL; AC=AC+BUF[USEPG];
                              ★ AFTLR ADDITION ALU(48) ≠ ALU(59) (I.E.
                              ★ ALU(59)/ALU(48) ±1) IF AND ONLY IF OVERFLOW HAS
                              * HAPPENED.
           * * *
             300FLO : THERE HAS BEEN AN OVERFLOW FROM COEFFICIENT TO EXPONENT
                       AND WE NEED TO SHIFT RESULT 1 RIGHT (WITH SIGN EXTENSION)
                       AND CORRECT VALUE OF EXPONENT.
*
           * WXIFLUAT: STORES FLOATING RESULT IN XI.
*
           ***
         AC=SHIFT(AC%MQ,A1); EO=EO+1; GD WXIFLOAT
           AT THIS POINT, E2 CONTAINS THE DIFFERENCE OF EXPONENTS,
*
           WHICH AS BEEN DETERMINED TO BE >= 64. AC HAS NUMBER
*
           WITH SMALLER EXPONENT. NO IS FILLED WITH SIGN BIT OF AC.
30ADDSML MQ=AC; AC=MQ; IF ¬E2(7-11) = 0 THEN 30ADDZRO
           127 >= E2 >= 64; SHIFT CDEFFICIENT RIGHT 64 AND THEN CONTINUE
*
           IN MAIN SHIFT SEQUENCE.
         MQ=SHIFT(AC%MQ, A4); = E2; IF EALU(4)~EALU(5) THEN 30SH16 ELSE 30TRY4
```

```
E2 >= 128; FILL AC AND MQ WITH SIGN BIT.
30ADDZRD MQ≖AC; IF BUF(59) THEN 30NEGEUF ELSE 30PUSBUF
           ***
×
             BONEGAC : USED WHEN SMALLER ADDEND IS NEGATIVE
           sk
           sie.
                         WHEN 12(7-11)≠0, THE SMALLER ADDEND IS LIKE -0.SET AC=-0
           ***
30NEGAC
         MQ=-0; IF E2(6-11)=0 THEN BOSHIFT ELSE BUADDSML
1
           ***
*
           本
              30XKSMALL: XK IS SMALLER ADDEND AND WE INTERCHANGE OPERANDS.
×.
           sk.
                         ON = ENTRY YO = NQ = XK = AC = XJ = EO = EXP (XK) = E1 = EXP(XJ)
           *
                                   E2 = EXP(XK) - EXP(XJ) < 0
           ***
*
30XKSMAL YO=AC; AC+MQ; MQ=AC; E2=7777-E2EF]
         EO=E1; BUF=YO; MQ=0; 1F AC(59) THEN BONEGAC ELSE TINYTEST
*
           ***
*
              30ILLEXP : WHEN ONE OF BOTH EXPONENTS ARE ILLEGAL
*
                       • ON ENTRY: AC= XK • BUF= XJ• EO = EXP(XK)• EL= EXP(XJ)•
           xk.
                         WHEN EXIT OCCURS BECAUSE OF AN INFINITE RESULT, AC(59)
                         CONTAINS THE SIGN OF RESULT (PLUS OR MINUS INFINITY).
                     ALGORITHM :
                         IF (XK = INDEF) GO TO INDEFOP
                         IF (XJ = INDEF) GO TO INDEFUP
                            IF WE GET HERE EITHER XK OR XJ(OR BOTH) ARE INFINITY
                         IF (XK ≠ INF) GO TO WXIINF
                            IF WE GET HERE XK IS INFINITY
                        IF (XJ ≠ INF) GO TO WXIINF
                            IF WE GET HERE BOTH XJ AND XK ARE INFINITY
                         LET AC = SIGN ( XK / XJ ) + EXCLUSIVE OR
                         IF AC = 1 GG TO INDEFOR
                         GO TO WXIINE.
           ***
30ILLEXP E2=E0
         IF INDEF(EO) THEN INDEFORM
         MQ=BUF; IF INDEF(E1) THEN INDEFORM
                 * AT THIS POINT, EXP(XK) IS IN EQ, COEF(XK) IN AC
                                   EXP(XJ) IS IN EL, COEF(XJ) IN BUF AND MQ
         NEWPARCEL; IF MODE2 THEN INFORTOD
         AC=MQ:
                MQ=AC; IF TINF(ED) THEN WXIINF
                        IF TINE(E1) THEN WXIINE
         AC=MQ;
                 MQ=AC;
         #AC/BUF: IF ALU(59) THEN WXIINDEF ELSE WXIINF
           ***
           *
              FOLLOWING CODE USED FUR UP AND ROUNDED SUM TO COMPUTE FULL
           *
             96 BIT SUM.
           *
              ON ENTRY AC:MQ = SMALLER ADDEND, SHIFTED ; BUF = BIGGER ADDEND
           *
                        EO = EXP OF SUM ; PG SET TO VALUES OF LOWER SUM.
           * * *
30DP2
         #AC+BUFEUSEPG]
30DP
         MQ=AC+BUF[USEPG][SAVEPG]; AC=MQ; IF BUF(59) THEN 30NEGBF2
                               * AT THIS PUINT AC = LOW BYTE OF SMALLER ADDEND,
                               * MQ = HIGH BYTE OF SUM ; PG SET TO VALUES OF
                               * UPPER SUM.
         (AC)=AC+O[USEPG]
```

```
MQ=AC+OEUSEPG]; AC=MQ; GO 30TUFL02
           ***
           * BONEGREPS : IS THE EQUIVALENT OF THE PREVIOUS 2 INSTRUCTIONS
          36
                        WHEN BUF IS NEGATIVE.
           * * *
30NEGBF2 (AC) = AC-OEUSEFG]
        MQ=AC-OEUSEPG]; AC=MQ
           ***
           * 30TOFLU2 : SUM IS DONE, CHECK FOR OVERFLOW
          ***
30TUFLD2 =E0+1; (AC)=AC; IFRALU(59)/ALU(46) THEN 30NODFLD
         AC2MO=SHIFT(AC2MD+Al): EG=F0+1
           * * *
±
           * AC:MQ NOW CUNTAINS THE 95 BIT SUM
           ***
30NDDFLU NEWPARCEL; IF SPCODE(2) THEN 30RND
           * * *
            EPILOG FOR DOUGLE PRECISION ADD: SHIFT LOWER SUM RIGHT
                    12 BITS, REDUCE EXPONENT BY 60(OCTAL).
           *
           ***
        AC=MQ; MQ=O; IF TAC(59) THEN BUSUMPDS
                   * USED WHEN SUM IS NEGATIVE.
        MQ==0
30SUMPUS AC=SHIFT(AC%MQ,R4); =LO-6C
        AC=SHIFT(AC%MQ,R4); LO=E0-60; IF FOFL THEN FLRESFLO
         AC=SHIFT(AC%MQ,R4); GU WXIFLOAT
          ***
           * EPILOG FOR ROUNDED ADD.
            - 30KNDFLO :THIS INSTRUCTION WILL BE REACHED FROM THE FOLLOWING
           *
           *
                        INSTRUCTIONS WHEN OVERFLOW OCCURS.
           ***
30RNDFLO AC%MQ=SHIFT(AC%MQ≥AI); EO≖EC+1; GO WXIFLOAT
                              * CAN DVERFLOW DCCUR MORE THAN DNCE ≥, IF SD: MUST
*
                              * TEST FUR EXPONENT OUT OF RANGE HERE.
*
30RND
        IF AC(59) THEN SURNANES
        (AC)=AC+O[NUP]; X1=EU%AC; IF ¬MQ(59) THEN NEWINSTR
        AC=AC+O[NOP]; =EO+1; IF ALU(59)/ALU(48) THEN 30RNDFLO ELSE WXIFLOAT
           * * *
            - 30KNDNEG: IN KOUNDING A NEGATIVE SUM, 1 IS SUBTRACTED FROM
                        AC wHEN MQ(59)=0.
           *
           ***
30KNDNEG (AC)=AC-O[G]; X1=EU%AC; 1F MQ(59) THEN NEW1NSTR
        AC=AC-O[G]; =EO+1; IF ALU(59)/ALU(48) THEN 30RNDFLD ELSE WXIFLDAT
*****
* FX1 XJ-XK - OP 31
*****
31
        EU2BUF=XK
31A
        AC=-BUF; E1%BUF=XJ; IF ILL(E0) THEN 30ILLEXP ELSE 30B
*****
* DXI XJ+XK - DP 32
```

```
******
      EO%BUF=XK; GO 30A
32
*****
* DXI XJ-XK - OP 33
******
33
      EO%BUF=XK; GO 31A
*****
* RXI XJ+XK - DP 34
*****
34
     EOZBUF=XK; GO 30A
******
* RXI XJ-XK - OP 35
*********
35
    EO%BUF=XK; GO 31A
*****
* IXI XJ+XK - OP 36- INTEGER SUM OF XJ AND XK TO XI.
          (5 CYCLES)
*****
*
36
      BUF=XK
      AC=BUF; BUF=XJ
LONGADD =AC+BUF; NEWPARCEL
      AC=AC+BUF; GO WXI
*****
* IXI XJ-XK - OP 37- INTEGER DIFFERENCE OF XJ AND XK TO XI.
          (5 CYCLES)
*****
37
      BUF=XK
       AC=-BUF; BUF=XJ; GO LONGADD
*******
* FLOATING POINT MULTIPLICATION OF XJ AND XK
```

\*

MULTIPLICATION (OF PUSITIVE NUMBERS) IS PERFORMED BY FIRST COMPUTING XJ, 2\*XJ,..., 7\*XJ, E\*XJ, STURING THEM IN Y1, Y2,..., Y7 AND Y0, RESPECTIVELY,\* AND THEN PROCESSING 4 BITS OF XK AT A TIME. WHEN THE PROCESSING BEGINS AC:MQ = 0:XK > AND AFTER EACH CYCLE, AC:MQ WILL\* CONTAIN BOTH THE PARTIAL RESULT OF THE MULTIPLICATION IN THE UPPER BITS . AND\* WHAT IS LEFT TO PROCESS OF XK IN THE LOWER BITS. THE RIGHMUST 4 BITS OUT OF MQ, I.E. O ≤ M ≤ 15. AS WE DEFINE Μ IN EACH CYCLE, AC:MQ IS SHIFTED 4 (ARITHMETIC) RIGHT, SO WHEN ADDING TO THE AC THE PROPER MULTIPLE OF XJ (IN BUE), ADDITION IS PROPERLY ALIGNED. BASICALLY THE ALGORITHM IS AS FOLLOWS: IF O ≤ M ≤ 8 JONE ADDS BUF = M \*(XJ) TU AC. IF 9 ≤ M ≤ 15, ONE SUBTRACTS BUF =(16 - M)\*(XJ) FROM AC AND ADDS AN EXTRA XJ IN THE NEXT CYCLE (WHICH IS EQUIVALENT TO ADDING 16\*(XJ)). THE ACTUAL COMPUTATION HAS TO TAKE INTO ACCOUNT WHETHER THE PREVIOUS CYCLE WAS AN ADD OR A SUBTRACT. THE NUTATION 40A, 40S, 40AA, ETC., REPRESENTS\* THE DIFFERENT PUSIBILITIES ACCORDING TO AN ADD OR A SUBTRACT CYCLE. FOR EXAMPLE:40AS INDICATES PREVIOUS CYCLE 15 ADD AND PRESENT CYCLE SUBTRACT. TABLE FOR THE SELECTION FUNCTION PRESENT SET BUF = PREVIOUS VALUE UF (YM OR YN) CYCLE CYCLE Μ M+(XJ) USMSU ADD ADD 8 < M ≤ 15 SUBTR (16-M)\*(XJ)  $0 \le M \le 7$ (M+1)\*(XJ) ADD \*\*\*\*  $7 \leq M \leq 14$  (16-(M+1))\*(XJ) SUBTR SUBTR SUBTR M=15 Û THE SELECTION OF BUF = YM OK YN IS DONE FROM E REGISTER AS FOLLOWS: • MM ARE 8 BITS FORMED BY SETTING BITS 0-3 EQUAL TO M BITS 4-7 EQUAL TO THE 1 COMPLEMENT OF -M+ • YM MEANS: IF E1(7) IS SET FETCH Y REGISTER WHOSE NUMBER IS GIVEN BY BITS 0-2 OF E1, ELSE FETCH O • YN MEANS: IF E1(3) IS SET FETCH Y REGISTER WHOSE NUMBER IS GIVEN BY BITS 4-6 OF E1, ELSE FETCH O . [F] INDICATES THAT THE ADDITION IN E1 IS DONE AS IF E1 CONSISTED OF 3 SEPARATE WORDS OF 4 BITS EACH WITH NO CARRY AND NO PROPAGATE. ADDITION AC+BUFEGI OR SUBTRACTION AC-BUFENOPJ IS DONE IN 2-COMPLEMENT REPRESENTATION TO AVOID THE PROBLEM OF THE END AROUND CARRY.

```
THERE ARE THREE TYPES OF FLOATING MULTIPLICATION, FLOATING, ROUND
FLOATING AND DOUBLE PRECISION FLUATING.
**************
*****
* FXI XJ*XK -OP 40 -FLOATING PRODUCT OF XJ AND XK TO XI.
*****
40
        E1%BUF=XJ; MQ=0; IF REG(59) THEN 40XJNEG ELSE 40XJPDS
40XJPOS
        AC=BUF; E2%BUF=XK; IF ILL(E1) THEN 401LLEXP ELSE 40FORMMP
40 X JNEG
        AC=-BUF; E2%BUF=XK; IF ILL(E1) THEN 401LLEXP
          * * *
*
          * AT THIS PUINT AC=ABS(XJ);dUF=XK; E1= EXP(XJ); E2=EXP(XK);
          * AND WE PROCEED TO SET Y1=ABS(XJ),Y2= 2*ABS(XJ),...,Y7= 7*ABS(XJ).
          * YO = 8*AES(XJ).
          ***
40FDRMMP Y1=AC; AC=SHIFT(AC%MQ;L1); IF ILL(E2) THEN 40ILLEXP
        Y2=AC; AC=SHIFT(AC%MQ)L1); IF BUF(59) THEN 40XKNEG
        BUF=Y1: MQ=BUF:
                        60 408
40XKNEG
        BUF=Y1; MQ=-BUF
408
        Y4=AC; AC=SHIFT(AC%MQ)L1)
        YO=AC: =AC-BUF
        BUF=Y2;
                AC = AC - BUF
        Y7=AC; =AC-BUF
        AC=AC-BUF; IF ZERD(E1) THEN 40XJZERD
        Y5=AC; =AC-BUF; IF ZERD(E2) THEN WXIZERON
        AC=AC-BUF; =E1+E2
        Y3=AC; AC=SH1FT(AC%MQ;L1); E0=E1+E2; IF XFDFL THEN FLRSFLDN
40INTMUL Y6#AC:
                AC=0: E2=15
          ***
          *
            AT THIS POINT, Y REGISTLES CONTAIN APPROPRIATE MULTIPLES OF
            ABS(XJ), MQ = ABS(XK), AC= 0, EQ = EXPONENT OF THE PRODUCT.
          *
            E2 = 15 (OCTAL) HAS BEEN INITIALIZED TO COUNT THE NUMBER OF
          *
          *
            CYCLES REQUIRED TO PROCESS XK.
          * START MAIN MULTIPLY LOOP.
          ***
*
                  START MAIN MULTIPLY LOOP
        AC%MQ=SHIFT(AC%MQ)A4); El=MM+17[F]; IF M>& THEN 40S
        ACZMQ=SHIFT(ACZMQ)A4);BUF=YM;E1=MM+ 17[F];IF M>8 THEN 40AS ELSE 40AA
40S
        AC%MQ=SHIFT(AC%MQ)A4);BUF=YN;E1=MM+360[F];IF M>7 THEN 405S ELSE 40SA
4044
        =AC+BUF[G]; L2=E2-1(F]; IF "EALU(0-3) THEN 40ADONE
        AC%MQ=SHIFT(AC+BUF%Mu,A4)[6];
                                       BUF=YA:
                           E1=MM+ 17[F]; IF M>8 THEN 40AS ELSE 40AA
40AS
        =AC+BUF[G]; E2=E2+1[F]; IF ¬EALU(0-3) THEN 40ADDNE
        AC%MQ=SHIFT(AC+BUF%MQ,A4)[G];
                                       BUF=YN;
                           cl=MM+360LF]; IF M>7 THEN 40SS ELSE 40SA
40 S A
        =AC-BUF[NOP]; E2=E2-1[F]
        AC%MQ=SHIFT(AC-BUF%MQ,A4)[NOP];
                                         BUF=YM;
                           cl=MM+ 17[F]; IF M>8 THEN 40AS ELSE 40AA
40SS
        #AC-BUF[NOP]; E2=E2-1[F]
```

\*

```
ACZMQ=SHIFT(AC-BUFZMJ,A4)[NUP];
                                            BUF=YN:
                             E1=MM+36C[F]; IF M>7 THEN 40SS ELSE 40SA
         ***
                        MULTIPLICATION OF COEFFICIENTS IS COMPLETED ON THIS
           + 40ADENE:
                        CYCLL. PRODUCT IS IN LOW-ORDER 48 BITS OF AC AND
*
*
                        HIGH-ORDER 48 BITS OF MO.
*
                        . IF ALU(47)=1 PRODUCT IS ALREADY NORMALIZED,
*
                                      GO TO 4CNOSHET
*
                        •1F ALU(47)=0 PRODUCT IS NOT NORMALIZED. IT SHOULD
*
                                      BE NORMALIZED (BY A 1 BIT LEFT SHIFT)
*
                                      UNLY IF BOTH OPERANDS WERE NORMALIZED.
         ***
*
40 ADONE
         AC=AC+BUF[G]; BUF=XJ; IF ALU(47) THEN 40NDSHFT
         BUF=XK; =3UF; IF PALU(59)/ALU(47) THEN 40NDSHFT
                              * ¬(ALU(59)/ALU(47)) CHECKS WHETHER BUF =XJ
*
                              * IS NORMALIZED.
*
         =BUF; =E0-1; IF TALU(59)/ALU(47) THEN 40NDSHFT
                              # ¬(ALU(59)/ALU(47)) CHECKS WHETHER BUF = XK IS
                              * NORMALIZED.
         AC&MQ=SHIFT(AC&MQ,L1); E0=E(-1; IF DPCDDE(1) THEN 40DP
40NDSHFT 1F OPCODE(1) THEN 400P; =E0+60
         IF OPCODE(0) THEN 40ROUND; E0=E0+60; BUF=XJ
           ***
*
           ±
            40 SETSGN: NEXT TWO INSTRUCTIONS SET AC TO SIGNED PRODUCT.
*
                        ON ENTRY : EUF(59)=SIGN(XJ)
*
           *
*
           *
                                     AC= ABS(PRODUCT).
           * * *
40SETSGN BUF=XK; IF THEG(54)/BUF(59) THEN 40WX1
40SETNEG AG=-AC; NEWPARCEL; IF FORL(EC) THEN FLRESFLO ELSE WXIFLOAT
40wXI
         XI=EO%AC; NEWPARCEL; IF FOFL(EO) THEN FLRESFLD ELSE NEWINSTR
           ***
*
*
           * FOR DP AND ROUND MULTIPLY
*
           ***
40RDUND
         (AC)=AC+O[NJP]; IF ¬MQ(59) THEN 40SETSGN
                              * IF MQ(59)=1,TO ROUND THE RESULT WE ADD 1 TO AC
*
         AC=AC+O[NUP]; =E0+1; IF ¬ALU(59)/ALU(48) THEN 40SETSGN
         AC=SHIFT(AC%MQ,A1); EU=EO+1; BUF=XK;
         IF REG(59)/BUF(59) THEN 40SETNEG ELSE 40WX1
+
           ***
幸
*
           * 400P: INSTRUCTIONS ARE SIMILAR TO THOSE OF DP ADD.
           ***
*
40DP
         MQ=0: AC=MO
         AC%MQ=SHIFT(AC%MQ,R4)
         AC%MQ=SH1FT(AC%MQ,R4); BUF=XJ
         AC%MQ=SHIFT(AC%MU,K4); BUF=XK;
         IF REG(59)/BUF(59) THEN 405ETNEG ELSE 40WX1
           ***
*
           *
              SPECIAL RESULTS FOR ZERG AND ILLEGAL EXPONENTS.
             ON ENTRY ELE EXP(XJ), ELE EXP(XK).
*
           *
           *
             ALGORITHM:
*
           *
丰
           *
*
                   IF (XJ = INDEF) GU TO INDEFOP
                  IF (XK = INDEF) GO TO INDEFOP
*
           *
           *
                      IF WE GET HERE EITHER XJ OR XK (OR BOTH) ARE INFINITE
*
                 *
```

IF (XJ = INF) GO TO XJINFCHECK FOR ZERO BECAUSE XK IS INFINITY IF (XJ = 0 ) GO TO WXIINDEF \*  $A^{\circ}C = Sign(XK/XJ)$ \* GO TO WXIINE \* \* XJINF IF (XK = 0 ) GD TO WXIINDEF \* \* AC = SIGN(XK/XJ)GO TO WXIINE \*XI=INFINITY, SIGN GIVEN BY AC. \* \*\*\* 40ILLEXP BUF=XJ; IF INDEF(E1) THEN INDEFORM AC=BUF; BUF=XK; IF INDEF(E2) THEN INDEFUPN AC=AC/BUF; E(=2002; IF MUDE2 THEN ERROR IF INF(E1) THEN 40XJINF NEWPARCEL; IF ZERO(E1) THEN WXIINDEF ELSE WXIINF NEWPARCEL; IF ZERO(12) THEN WXIINDEF ELSE WXIINF 40XJINF 40XJZERO Y5=AC; =AC-BUF; IF ¬ZERO(E2) THEN WXIZERON AC=AC-BUF; IF -OPCOD=(1) THEN #XIZERON Y3=AC; AC=SHIFT(AC&MQ,LI); LU=6000; GD 40INTMUL \*\*\*\*\* \* RXI XJ\*XK — OP 41-ROUND FLUATING PRUDUCT UF XJ AND XK TO XI \*\*\*\*\*\*\*\*\*\* E1%BUF=XJ; MG=0; IF KEG(59) THEN 40XJNEG ELSE 40XJPUS 41 \*\*\*\*\*\* \* DXI XJ\*XK - OP 42. FLOATING DUUBLE FRECISION PRODUCT OF XJ AND XK TO XI \*\*\*\*\*\*\*\*\*\* 42 E1%BUF=XJ; MQ=O; IF REG(59) THEN 40XJNEG ELSE 40XJPDS \*\*\*\*\*\*\*\*\* \* MXI JK - OP 43 - FORM MASK IN XI, JK BITS -INSTRUCTION SLTS HIGH DEDER JE BITS OF XI TO ONE. \* -FIRST THREE INSTRUCTIONS SET HIGH ORDER BIT OF AC AND SO, \* AN AKITHMETIC RIGHT SHIFT (OP 21) JK-1 PLACES, \* GIVES THE DESIRED RESULT. \*\*\*\*\* \* 43 AC=0: =0-JK AC%MQ=SHIFT(AC%MQ)D1); E0=0-JK; NEWPARCEL; IF →EALU(11) THEN WXIZERD AC%MQ=SHIFT(AC%MQ,R1); =7776-E0 E0=7776-E0; IF EALU(4) VEALU(5) THEN 21SH16 ELSE 21TRY4 \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* \* FLOATING POINT DIVISION TO DIVIDE XJ BY XK (BOTH POSITIVE NUMBERS) FIRST XJ IS PLACED IN AC AND

\*

```
* XK IN THE BUF. THE 56 BIT QUOTIENT WILL APPEAR IN MQ.
                                                                              *
    IF WE DENOTE BY AC(HIGH) AND BUF(HIGH) BITS 45-48 OF AC AND BUF, RESPEC-
                                                                              *
 TIVELY, THE DIVIDE ALGORITHM FOLLOWS:
                                                                              *
                                                                              *
               AC = XJ
                                                                              *
               BUE= XK
                                                                              *
               MQ = Q
                             * CARRIES QUOTIENT
                                                                              *
                             * INITIALIZES SHIFT COUNT
                                                                              *
               SHC= C
              \Delta C = \Delta C + 2
                                                                              *
        LOGP1
               MQ = ML + 2
                                                                              *
                                                                              *
        LOOP12 SHC = SHC + 1
               1F (SHC = 50) GU TO DONE
                                                                              *
               IF ( AC(HIGH) < BUF(HIGH)) GO TO LOOPI
                                                                              ¥
                                                                              *
               AC = AL - BUF
               IF (AC < 0 ) GO TO READD * AC WAS SMALLER THAN BUF AND
                                                                              *
                                          * SUBTRACTION WAS NOT INDICATED
                                                                              *
                AC = 4C + 2
                                                                              *
                10 = (NQ + 2) + 1
                                         * RECORDS QUOTIENT
                                                                              *
                                                                              ŧ
                GU TU LUUP12
                AC = AC + BUF
                                                                              *
        READD
                                                                              *
                GO TO LOOPI
                                                                              *
                END.
        DONE
                                                                              *
*
    TO IMPLEMENT THIS ALGORITHM IN THE MACHINE WE PROCEED AS FOLLOWS:
                                                                              *
*
                                                                              *
  1.AC = (AC + 2) AND MG = (MQ + 2) IS DUNE BY AC:MQ=SHIFT(AC:MQ=Z1)
                                                                              *
*
*
  2.AC =(AC * 2) AND MQ = (MQ *2)+1 IS DONE BY AC:MQ=SHIFT(AC:MQ.01)
                                                                              *
                                                                              *
  3.MQ WILL CARRY BOTH, THE WUDTIENT AND THE SHIFT COUNT, NAMELY, BEFORE
                                                                              ٠
*
    STARTING DIVISION PROCESS, A 1 BIT IS FURGED INTO BIT O OF MQ, SO THAT
                                                                              ŧ
*
    SHC = 50 IS EQUIVALENT TO MO(49)=1.
                                                                              *
                                                                              ŧ
¥
  4.THE TEST AC << BUF COMPARES BITS 44-47 OF AC AGAINST BITS 45-48 OF BUF
                                                                              *
    BECAUSE TEST IS CHECKING A CONDITION EXISTING PRIOR TO SHIFTING
                                                                              *
                                                                              *
  5.60 WILL CARKY THE EXPONENT OF THE QUOTIENT, I.E. THE DIFFERENCE OF THE
                                                                              *
    EXPONENTS MINUS 60(OCTAL) (BECAUSE MINUEND WAS SHIFTED 48 BITS LEFT).
******
 FXI XJ/XK - OP 44- FLOATING DIVIDE XJ BY XK TO XI
******
          ***
          * SET YOF ABS(XK), SIGN(YI)= SIGN OF RESULT, AC= ABS(XJ).
          * * *
44
        E22BUF=XK; IF REG(59) THEN 44XKNEG
44 X K P O S
        AC=BUF; E1%BUF=XJ; IF ILL(E2) THEN 441LLEXP
        YO=AC; AC=BUF; IF ILL(E1) THEN 44ILLEXP ELSE 44A
          * * *
*
```

44XKNEG: WHEN XK <0,SETTING AC=Y1= -XJ MAKES Y1 HAVE SIGN ŧ UF RESULT. \* \* \* 44XKNEG AC=-BUF; El%puF=XJ; IF ILL(L2) THEN 441LLEXP YO=AC; AC=-BUF; IF ILL(E1) THEN 44ILLEXP 44A Y1=AC; MQ=0; IF ZERJ(E1) THEN 44XJZERO BUF=YO: IF ZERD(c2) THEN WXIINEN \* IF ZERD(E2) IS TRUE, XJ IS FINITE, XK=0, \* QUOTIENT IS INFINITE. =E1-22; IF AC(59) THEN 44COMP E0=E1-22; IF XFOLL THEN FLKSFLON ELSE 44B 44COMP ED=E1-E2; AC=-AC; IF XFOFL THEN FLRSFLON  $= \pm 0 - 50;$  AC2MQ=SH1FT(AC2MQ;A1) 44B 卒 \*\*\* \* \* NEXT TWO INSTRUCTIONS FORCE A 1 BIT IN ZERO BIT OF MO TO START \* SHIFT COUNT. \* \* \* \* \* EO = EO = 60; AC % AQ = SH1FT(AC% Q, O1); IF AC<<BUFA-MQ(49) THEN 44LUUP ELSE 44SUBTR ACZMQ=SHIFT(AC%MQ,Z1); IF AC<<BUFA-MQ(49) THEN 44LOOP 44L00P 44SUBTK =AC-BUF; IF MQ(50) THEN 4400NE AC=AC-BUF; IF ALU(59) THEN 44KEADD AC&MQ=SHIFT(AC&MQ)U1); IF AC<<BUFA=MQ(49) THEN 44LOOP ELSE 44SUBTR 44KLADD =AC+BUF AC=AC+SUF; GJ 44LUUP AT THIS PUINT MQ(0-49) HAVE A 50-BIT QUDTIENT, MQ(51)=1 44DUNE AC=MQ; BUF=Y1; IF MQ(44) THEN 44SHIFT (AC)=AC+OENDP3; IF DPC3D2(0) THEN 44ROUND \*\*\* 44NORNO: WE GET HERE IF M(49)=0. SHIFT ARITHMETIC 1 RIGHT \* \* \* \* GIVES JUGTIENT. \*\*\* 44NORNO NEWPARCEL; AC=SHIFT(AC&MQ,A1); IF BUF(59) THEN 44NEGRES XI=EO%AC; IF FOFL(=0) THEN FLRESFLD ELSE NEWINSTR 44NEGRES AC=-AC; IF FUFE(EC) THEN FERESFLD ELSE WXIFLOAT \*\*\* \* 44541FT: WHEN NG(49)=1,SINCE MQ CONTAINS A 50 BIT QUOTIENT, \* \* \* 2 SHIFTS RIGHT ARE REQUIRED TO OBTAIN ANSWER. \*\*\* 44SHIFT =EC+1; AC=SHIFT(AC&AQAA1) (AC)=AC+O[NOP]; {u=cu+1; IF OPCODE(0) THEN 44ROUND ELSE 44NORND \* \* \* \* \* \* 4480UND: ADD I TO LOWER BIT AND CHECK FOR OVERFLOW. \*\*\* 44KÜUND AC=AC+O[NOP]; GU 44 VOKND \* \* \* \* \* \* 44XJZERO: COMES FRUM LINE 44A WHEN NUMERATOR IS ZERO. \* \* \* 44XJZERO NEWPARCEL; IF ZERO(22) THEN WXIINDEF ELSE WXIZERO 奉 \* \* \* ¥ \* AT THIS POINT UNE OR BOTH 21 AND 22 ARE INFINITE. \*\*\* 44ILLEXP BUF=XJ; IF INDEF(L1) THEN INDEFORN AC=BUF; BUF=XK; NEWPARCEL; IF INDEF(E2) THEN INDEFOP

```
AC=AC/BUF; E(=2002; IF MODEL THEN ERROR
        IF TINF(E1) THEN WXIZERJ
        IF INF(E2) THEN WALLNOLF LESS WALLNE
*****
 RXI XJ/XK . OP 45. RUJAD FLJATING UIVID, XJ BY XK TO XI.
*****
45
        E2%BUF=XK; IF REG(34) THEF 44XKNEG ELSE 44XKPUS
*
*****
 NO . DP 46 . NO OPERATION
*******
        NEWPARCEL; IF ICHECK THEN ICHECK ELSE NEWINSTR
46
*****
 CXI XK - OP 47 - COUNT OF THE NUMBER OF 1 BITS IN XK TO XI
                  BC COURTS THE NUMELA OF I SITS IN THE LOW 4 BITS OF AC
                  . IF XK IS PUSITIVE, LUAD XK INTO AC AND ACCUMULATE IN EQ
                   A COUNT OF THE 1 EITS IN AC
                  . IF XK IS NEGATIVE, LOAD -XK INTO AC AND ACCUMULATE IN EQ
                   60 - COUNT JE I BITS IN AC = 60 - COUNT OF O BITS IN XI
                   = COUNT OF 1 BITS IN XI
******
*
47
        BUF=XK; MQ=O; NEWPARCEL; IF REG(59) THEN 47XKNEG
        AC=BUF; EO=0
47L 00P
        FEC+BC; IF AC=0 THEN 47END
        EO=EO+BC; AC=SHIFT(AC&MQ,R4); GU 47LOOP
        AC=EO; GO WX1
47END
        AC=-BUF; EC=74
47XKNEG
       =EO-BC; IF AC=0 THEN 47END
47NL00P
        E0=E0-dC; AC=SHIFT(AC&MQ,R4); G0 47NL00P
           *****
 SAI GRUUP -OP 50 - SAI AJ+K SET AL TU AJ+K
                                                                             *
                                                                             ∗
               51 - SAI BJ+K SET AT TO BJ+K
               52 - SAL XJ+K SET AL TU XJ+K
*
                                                                             * * * * *
*
               53 - SAL XJ+BK SET AL TO XJ+BK
               54 - SAI AJ+3K SET AL TJ AJ+3K
               55 - SAI AJ-3K SET AL TU AJ-8K
*
*
               56 - SAI BJ+BK SET AI TO BJ+BK
*
               57 - SAL BJ-BK SET AL TO BJ-BK
*
*
         INSTRUCTIONS SET AT TO THE SPECIFIED ADDRESS-
*
         SETTING AT THROUGH AS TO AN ADDRESS EDADS CONTENTS OF THAT
*
               LOCATION INTO ASSOCIATED X REGISTER.
```

SETTING A6 OK A7 STURES CONTENTS OF THE X REGISTER AT THE SPECIFIED LOCATION SETTING AO CAUSES NO MEMORY REFERENCE \*\*\*\*\*\*\*\* \*\* \* 50 BUF=AJ; AC=K; NÉWPARCEL SAADD #AC+BUF[18]; NEWPARCEL; IF 1=0 THEN NOLDAD AC=AC+BUF[18]; IF "NIWEMPTY THEN TESTI IF RNI IS NUT COMPLETE, WAIT FUR CMDDNE AND THEN LOAD NIW NIW=CMRD; IF ¬CMDONE THEN LOWAITI LDWAIT1 TESTI CLEAR; Al=AC; IF 1>5 THEN STORE LOAD SEQUENCES \* ak i WALT FOR CMOUNE TO DROP IF CMDONE THEN LOAD LOAD ISSUE READ REQUEST MA=AC; READ; IF LASTPARCEL THEN LOLASTP WAIT FOR CM FLTCH TO COMPLETE AC=CMRD; IF -CMDDNE THEN LUWAIT2 LDWAIT2 STORE FETCHED DATA IN XI XI=AC; CLEAR; LATCH I; GU OPCUDEBRANCH LDLASTP AC=CMRD; IF ¬CMDDNE THEN LOLASTP XI=AC; CLEAR; P=P+1; GU LUADCIW STORE SEQUENCES sk. GET WORD TO STOKE (XI); WALT FOR CMDONE TO DROP STORE BUF=X1; IF CMDONE THEN STOKE ISSUE WRITE REQUEST AC=BUF; MA=AC; wRITE; IF LASTPARCEL THEN STLASTP WAIT FOR CM TE ACCEPT DATA STWAIT IF -CMDDNE THEN STWAIT CLEAR; LATCH 1; GO UPCUDEBFANCH STLASTP IF -CMDONE THEN STLASTP CLEAR; P=P+1; GU LUADCIW I=O CASE% NO LOAD OR STORE NOLOAD AC = AC + BUF[18]AI=AC; LATCH 1; IF ICHECK THEN ICHECK ELSE UPCODEBRANCH 51 BUT=BJ; AC=K; NEWPARCEL; GU SAADD 52 BUF=XJ; AC=K; NEWPARCEL; GO SAADD 53 BUF=BK AC=BUF; BUF=XJ; GU SAADD BUF=BK 54 AC=BUF; BUF=AJ; GU SAADU 55 BUF≠BK AC=-BUF; BUF=AJ; GJ SAADD 56 BUF=BK AC=BUF; BUF=BJ; GD SAADD 57 BUF=BK AC=-BUF; BUF=BJ; GO SAAUL \*\*\*\*\*\*\*\*\*\* \* SBI GROUP -OP 60 - SEL AJ+K SET E1 TJ AJ+K 61 - SEI BJ+K SET BI TO BJ+K \* 62 - SEI XJ+K SET BI TO XJ+K

```
63 - Sel XJ+3K SET EL TO XJ+8K
              64 - SEL AJ+BK SET EI TO AJ+BK
              65 - SET AJ-SK SET BI TO AJ-BK
              66 - Srl 3J+6K SET 61 TU 6J+3K
              67 - SUI OJ-DK SET BI TO BJ-BK
                                                                        *
                                                                        *
         INSTRUCTIONS SET &1 TO SPECIFIED ADDRESS.
         BU IS PERMANENTLY SET TO ZERO
*****
*
60
        BUF=AJ; AC=K; NC+FAKCEL
        =AC+BUFE18]; NEWPARGEL; IF 1=0 THEN NEWINSTR
SBADD
        AC = AC + 3UF[13]
        BI=AC; LATCH 1; IF ICHECK THEN ICHECK ELSE UPCODEBRANCH
        SUF=BJ; AC=K; NL+PAKCEL; GO SHADD
61
        BUF=XJ; AC=K; NE#PARCEL; GU SBADD
62
        BUF=BK; IF I=C THEN NEWINSLO
63
        AC=BUF; BUF=XJ; GU SOADD
        BUF=BK; IF I=C THEN NEWINSLU
64
        AC=BUF; BUF=AJ; GH SBAUD
        BUF=BK; IF I=C THEN NEWINSLD
65
        AC=-BUF; BUF=AJ; GO SJAUD
        BUF=3K; IF 1=C THEN NEWINSLU
66
        AC=BUF; BUF=BJ; GJ SBADD
        BUF=BK; IF I=( THUN NEWINSLU
67
        AC=-BUF; BUF=BJ; BU SHAUE
         * SXI GROUP -OP 70 - SXI AJ+K SET XI TO AJ+K
              71 - SXI BJ+K SET XI TO BJ+K
              72 - SXI XJ+K SET X1 TU XJ+K
              73 - SXI XJ+BK SET XI TO XJ+BK
              74 - SXI AJ+BK SET XI TU AJ+BK
              75 - SXI AJ-BK SET XI TO AJ-BK
                                                                        *
              76 - SXI BJ+BK SET XI TU BJ+BK
              77 - SXI BU-BK SET XI TO BU-BK
         INSTRUCTIONS SET X1 TO SPECIFIED ADDRESS.
         IN ALL CASUS, AN 15-BIT UNE≠5-COMPLEMENT ADDITION IS PERFORMED
         AND THE SIGN BIT IS THEN EXTENDED TO THE HIGH-ORDER 42 BITS TO
*
         FORM A 60-31T SUM.
          *****
70
        BUF=AJ; AC=K;
                      NEWPARCEL
SXADD
        =AC+BUF[18]
        AC=AC+BUF[18]; NEWPARCEL; GO WXI
71
        BUF=BJ; AC=K;
                        NEWPARCEL; GD SXADD
                                   GO SXADD
72
        BUF=XJ; AC=K;
                        NEWPARCEL;
73
        BUF=BK
        AC=BUF; BUF=XJ; GO SXADD
74
        BUF=BK
```

|            | AC=BUF;  | BUF=AJ;   | GU SXADD |
|------------|----------|-----------|----------|
| 75         | BUF=BK   |           |          |
|            | AC=-BUF; | BUF=AJ;   | GO SXADD |
| <b>7</b> 6 | BUF=BK   |           |          |
|            | AC=BUF;  | BUF=BJ;   | GU SXADD |
| 77         | BUF=BK   |           |          |
|            | AC=-BUF; | BUF = BJ; | GO SXADD |
| *          |          |           |          |

This report was prepared as an account of Government sponsored work. Neither the United States, nor the Administration, nor any person acting on behalf of the Administration:

- A. Makes any warranty or representation, express or implied, with respect to the accuracy, completeness, or usefulness of the information contained in this report, or that the use of any information, apparatus, method, or process disclosed in this report may not infringe privately owned rights; or
- B. Assumes any liabilities with respect to the use of, or for damages resulting from the use of any information, apparatus, method, or process disclosed in this report.

As used in the above, "person acting on behalf of the Administration" includes any employee or contractor of the Administration, or employee of such contractor, to the extent that such employee or contractor of the Administration, or employee of such contractor prepares, disseminates, or provides access to, any information pursuant to his employment or contract with the Administration, or his employment with such contractor.

. \* .

| This book may be kept<br>FOURTEEN DAYS<br>A fine will be charged for each day the book is kept overtime. |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                                                                                                          |  |  |  |  |  |
|                                                                                                          |  |  |  |  |  |
|                                                                                                          |  |  |  |  |  |
| <br>                                                                                                     |  |  |  |  |  |

Grishman The structure of the PUMA comp. systems.

> N.Y.U. Courant Institute of Mathematical Sciences 251 Mercer St. New York, N. Y. 10012

