BUGS

## META 4A Principles of Operation

This publication is one of the machine reference manuals for the Brown University Graphics System (BUGS). The META 4A is the general-purpose processor component of BUGS. Readers are assumed to have a knowledge of the principles of operation of the IBM System/360.1

#### April 7, 1975

<sup>1</sup>The research for this project was done under a grant from the National Science Foundation (GJ-28401X) and a contract from the Office of Naval Research (n00014-67-A-0191-0023). Reproduction in whole or in part is permitted for any purpose of the United States Government.

# TABLE OF CONTENTS

| 1 Information<br>1.1 Formats Operand<br>1.2 Addressing<br>1.3 Arithmetic                                                                                                                                                                                                                                                                                    | 1<br>1<br>1<br>1 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| <pre>2 Central Processing Unit (CPU)<br/>2.1 Registers.<br/>2.2 Instruction Formats.<br/>2.2.1 RI Format.<br/>2.2.2 Address Generation.<br/>2.2.3 BX Format.<br/>2.2.4 FSS (SVCD) Field.<br/>2.2.5 VSS length Field.<br/>2.3 Program Counter (PC).<br/>2.4 Machine Status Register (MSR).</pre>                                                             | 2223444455       |
| 3 Arithmetic Instructions. 3.1 Load Instructions. 3.2 Add Instructions. 1 3.3 Subtract Instructions. 1 3.4 Arithmetic Compare Instructions. 1 3.5 Multiply Instructions. 1 3.6 Divide Instructions. 1 3.7 Convert Instructions. 1 3.8 Store Instructions. 1 3.9 Move Halfword Instructions. 1 3.10 Swap Instructions. 1 3.11 Arithmetic Shift Instructions. | 770245678990     |
| <pre>4 Logical Instructions</pre>                                                                                                                                                                                                                                                                                                                           | 3335678800245    |
| 5 Branching Instructions                                                                                                                                                                                                                                                                                                                                    | 9                |
| o Status-Switching Instructions4                                                                                                                                                                                                                                                                                                                            | 4                |

| 7 Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>8 Input/Ouput Operations.<br/>8.1 I/O Units.<br/>8.1.1 Local Units.<br/>8.1.2 The S/360.<br/>8.2 Control of Local Units.<br/>8.2.1 Unit Information.<br/>8.2.2 Starting I/O.<br/>8.3 I/O Interrupts.<br/>8.4 I/O to the S/360.<br/>8.4.1 General Information.<br/>8.4.2 S/360 Interface Addresses.<br/>8.4.3 S/360 UCB Format.<br/>8.4.4 Firmware Operations.<br/>8.4.4.1 Initial Status Presentation.<br/>8.4.4.2 Data Transfer.<br/>8.4.4.3 Ending Status Presentation.<br/>8.4.4.4 System or Selective Reset.<br/>8.4.5 S/360 Instructions.</pre>                                             | 49<br>49<br>49<br>49<br>49<br>49<br>49<br>50<br>52<br>52<br>52<br>52<br>52<br>52<br>52<br>53<br>53<br>53<br>53<br>55<br>55<br>55<br>55<br>56<br>56<br>56<br>56<br>56<br>56<br>57 |
| 9 Local I/O Unit Descriptions.<br>9.1 3461 Card Reader (unit address 00100)<br>9.1.1 Description.<br>9.1.2 I/O Control Commands.<br>9.1.3 USH Format.<br>9.2 Terminal Interface (unit address 00110)<br>9.2.1 Description.<br>9.2.2 Control Commands.<br>9.2.3 USH Format.<br>9.3 /360 Terminal Interface (unit address 00011)<br>9.3.1 Description.<br>9.4 Model 1444 Disk Storage Unit (unit address 0<br>9.4.1 Description.<br>9.4.1.1 Storage Capacity.<br>9.4.1.2 Data Organization.<br>9.4.2 1444 I/O Control Commands.<br>9.4.3 USH Format.<br>9.5 META 4A Control Panel (unit address 00101). | 59<br>59<br>59<br>59<br>60<br>61<br>61<br>61<br>61<br>61<br>61<br>62<br>63<br>00010<br>64<br>64<br>64<br>64<br>64<br>64<br>65<br>67<br>68                                        |
| <ul> <li>9.5.1 Description.</li> <li>9.5.2 System Control Functions.</li> <li>9.5.3 User Intervention Facilities.</li> <li>9.5.4 I/O to the Control Panel.</li> <li>9.5.4.1 Panel IOCCS.</li> <li>9.5.4.2 USH Format.</li> <li>9.6 META 4B (unit address 00001).</li> <li>9.6.1 Description.</li> <li>9.6.2 I/O Control Commands.</li> <li>9.6.3 Typical Communication Sequence.</li> <li>9.7 Common I/O Control Commands.</li> <li>9.7.1 No Operation.</li> </ul>                                                                                                                                    |                                                                                                                                                                                  |

| 9.7.2 Invalid I/O Control Commands74               |
|----------------------------------------------------|
| 10 Appendix I: Operation Program interrupt storage |
| 11 Appendix II: Operation Codes and Timings        |
| 12 Appendix IV: Lavout of Lower Memory             |

#### 1 INFORMATION

#### 1.1 FORMATS OPERAND

Information on the META 4A is stored in main memory in 8-bit units, called "bytes", as in the S/360. Bytes may be handled separately or grouped together in fields. The most common field consists of 2 bytes, and is sometimes called a "halfword"; these halfwords are the basic building block of CPU instructions and also the size of the fixed-point 2's complement numbers operated upon by arithmetic instructions. These instructions require the halfwords to be located on an even byte boundary. Other instructions operate upon variable length fields of bytes, called "character strings". These character strings may be located anywhere in memory and may be of any length.

#### 1.2 ADDRESSING

Bytes in main storage are addressed consecutively from 0. The META 4A uses a 16-bit address, allowing for a maximum of 64K bytes. Currently we have only 32K, and addresses wrap from "X'7FFF' to 0. A field of bytes (1 or more) is usually addressed by its leftmost byte.

#### 1.3 ARITHMETIC

All arithmetic on the META 4A is performed on 16-bit 2's complement binary numbers using 2's complement arithmetic. Any overflow that occurs is ignored in some operations (such as address computation), but causes program action in certain others (such as the Add instructions).

-1-

2.19:76

# 2\_CENTRAL\_PROCESSING\_UNIT\_(CPU)

#### 2.1 REGISTERS

Instructions can address information in 16 registers, 3 of which serve special purposes. Registers have a capacity of 1 halfword and are addressed by a 4-bit number from 0 to 15. Register 0 is called the Machine Status Register (MSR), register 1 is the Program Counter (PC), and register 15 is the Stack Frame Pointer (SFP). These will be explained later.

# 2.2\_INSTRUCTION\_FORMATS

The META 4A has 8 instruction formats, denoted by the mnemonics RR, RI, RS, RX, BX, SI, FSS, and VSS. The formats are as follows:

Register-Register (RR) R1,R2

0 8 12 15

Register-Immediate (RI) R1S,R1F,I2

| 1 | OP | IR1S |    | - <del></del> | τ 2      |      |
|---|----|------|----|---------------|----------|------|
| L |    |      |    |               | 12 .<br> | <br> |
| 0 |    | 8    | 12 | 16            |          | 31   |

Register-Storage (RS) R1,R3,D2(B2)

| r | ang alata dilik dilik dila di |   |    | - | pip ans age a |   |    |    | و بروید دیدو خدب خرک هاره افاه ک |    |  |
|---|-------------------------------|---|----|---|---------------|---|----|----|----------------------------------|----|--|
| 1 | OP                            | 1 | R1 | 1 | R3            | i | B2 | i  | D2.                              | i  |  |
| L | n alfa ann ann ains da        | d |    |   |               |   |    |    |                                  |    |  |
| 0 |                               | 1 | 8  |   | 12            |   | 16 | 20 |                                  | 31 |  |

| Register-indexed storage (RX)<br>R1,D2(X2,B2) |                                                   |                 |                                 |               |                     |                                     |                           |    |    |                                |      |  |
|-----------------------------------------------|---------------------------------------------------|-----------------|---------------------------------|---------------|---------------------|-------------------------------------|---------------------------|----|----|--------------------------------|------|--|
|                                               | OP                                                | R1              | X2                              | B2            | I                   | D2                                  | ، صلك محدد درين متين :    |    |    |                                |      |  |
| 0                                             |                                                   | 8               | 12                              | 16            | 20                  | lian érilő ésrő dist esse esső      | 3.1                       | J  |    |                                |      |  |
| Bra                                           | nch in                                            | deXed<br>R1,D2  | (BX)<br>2 (X2)                  |               |                     |                                     | a<br>a                    |    |    |                                |      |  |
|                                               | OP                                                | R1              | X2                              | 1             |                     | D2                                  |                           | ]  |    |                                |      |  |
| 0                                             |                                                   | 8               | 12                              | 16            | annan ann ann ann a |                                     | 31                        | 3  |    |                                |      |  |
|                                               |                                                   |                 | ~ *                             | ·             |                     |                                     |                           |    |    |                                |      |  |
| Sto                                           | Storage-Immediate (SI)<br>D1(B1),I2               |                 |                                 |               |                     |                                     |                           |    |    |                                |      |  |
| i                                             | OP                                                | 12              | 2                               | B1            | 1                   | D1                                  | ة حية حيد غنة تس          | 1  |    |                                |      |  |
| 0                                             | ž.                                                | 8               |                                 | 16            | 20                  | ang gan gan ann inn inn inn inn ann | 31                        |    |    |                                |      |  |
| Fix                                           | eđ Sto                                            | rage-S<br>D1(B1 | tora<br>),D2                    | ge (1<br>(B2) | rss)                |                                     |                           |    |    |                                |      |  |
| 1                                             | OP                                                | (500            | D)                              | в1            | ļ                   | D 1                                 |                           | B2 | 1  | D2                             | <br> |  |
| 0                                             |                                                   | 8               | an tanan data data d            | 16            | 20                  |                                     | 6001 entre entre europ el | 32 | 36 |                                | 47   |  |
| Var                                           | Variable Storage-Storage (VSS)<br>D1(L,B1),D2(B2) |                 |                                 |               |                     |                                     |                           |    |    |                                |      |  |
|                                               | OP                                                | I               |                                 | B1            | 1                   | D1                                  |                           | B2 | r  | D2                             |      |  |
| 0                                             |                                                   | 8               | - <del>man sija</del> saa daa d | 16            | 20                  | in 649 into alta ann ann dan c      |                           | 32 | 36 | ارد کنید مکرد منزع مربع مستریب | 4 7  |  |
|                                               |                                                   |                 |                                 |               |                     |                                     |                           |    |    |                                |      |  |

The various instruction formats and fields will be referred to by the above mnemonics.

# 2.2.1 RI FORMAT

Most RI format instructions are 3-address; whenever the first operand must be fetched, it is fetched from the R1F register. Whenever it must be stored, it is stored into the R1S register. Certain instructions perform only R1 fetches (i.e., TMI, STDI, CLI, and CI), thus ignoring the R1S field, while LI and LDI perform only a store and ignore the R1F field. Both registers will be referred to as Operand 1. Operand 2 is always the 16-bit immediate halfword.

#### 2.2.2 ADDRESS GENERATION

Operand addresses are generated for all instructions except those in BX format by taking the contents of the base register (B1/B2) and the displacement (D1/D2) (expanded to 16 bits by adding 4 high-order 0's) and performing 2's complement addition on them. Furthermore, in the case of the RX format, the contents of the index register (X2) is also added in. The resulting sum is the address of the operand. If a base and/or index register of 0 is specified in an instruction, the contents of the MSR is <u>not</u> used in the address computation, but rather a 0 is added.

#### 2.2.3 BX FORMAT

The branch address in a BX format instruction is obtained by adding the signed immediate Displacement to the contents of the Program Counter (the next instruction address). Optionally on all intructions except BXH and BXLE, the contents of the X2 register is added in as an index, unless the X2 field is zero (as in RX format).

#### 2.2.4 FSS (SVCD) FIELD

This field is ignored except in the SVCD instruction.

#### 2.2.5 VSS LENGTH FIELD

The VSS format is used to operate upon character strings. The "length" field in the instruction specifies the length of the strings. Each VSS instruction has 2 operation codes, 1 allowing the length to be specified immediately as a number from 0 to 255 (actual length, unlike the S/360). The other ignores bits (9) through 11 and uses bits 12 through 15 as the number of a register containing the length, and will have the same mnemonic as the immediate type with an appended "L", for "Long". Thus, any length character string can be operated upon with only 1 instruction.

#### 2.3 PROGRAM COUNTER (PC)

The PC (register 1) is the Program Counter (or instruction address register) for the META 4A. It is incremented by 2, during instruction fetching, for each halfword of the instruction fetched. During parsing and execution, it will contain the address of the next sequential instruction. It may be operated upon, in all respects, just as any of the other registers, although the effects upon program execution should be obvious. For the purpose of fetching instructions, bit 15 of the PC is always ignored and assumed to be 0.

# 2.4 MACHINE STATUS REGISTER (MSR)

The MSR, register 0, contains the information required for proper program control and execution. It format is:

- soon to be Ploating points bit

|   | 22 F | IILC | I W | PR | ojs |      | tø |    | IS | P  |  |
|---|------|------|-----|----|-----|------|----|----|----|----|--|
| 0 | 3    | 4    | 6   | 7  | 8 9 | 1011 | 12 | 13 | 14 | 15 |  |

COC1C2: This is the 3-bit Condition Code, which is set by various instructions. The 3 bits will be referred to as CO, C1, and C2. An instruction may affect none, some, or all of these bits.

F: This bit is undefined but may be used as a flag since it can be tested by the Branch Condition instructions (see Section 5).

ILC: These 2 bits are significant only when the MSR is stored after an SVC or Program interrupt (see Section 7), when they will specify the length, in halfwords, of the instruction that caused the interrupt. The ILC will never be set to 0.

9

012

45

W: This bit, when on, specifies that the META 4A is to be kept in wait state until the occurrence of some sort of I/0 or S/360 interrupt.

PR: This bit is the Privilege bit, which must be on to perform an I/O or S/360 instruction. If this convention is violated, a Privilege Program interrupt will occur. See Section 8 for a more detailed explanation.

O: This is the Overflow interrupt mask. When off, arithmetic and conversion overflows on those instructions for which they are significant merely set the Condition Code. When on, they also cause a Program interrupt and the contents of the operand which was to receive the result remains unchanged.

S: This is the Stack Overflow/Underflow interrupt mask. When off, stack overflow or underflow merely sets the Condition Code. When on, either of these 2 conditions also causes a Program interrupt.

12 I/O: This bit controls the ability of local I/O units to cause an I/O interrupt. If off, these units cannot interrupt the CPU, and the interrupt request remains pending.

14

15

6

7

8

9

IS: This bit controls S/360 Initial Select interrupts. If 1, an initial selection causes an immediate interrupt. If 0, the interrupt is held pending.

P: This bit controls Parity Check interrupts. When on, Parity Checks cause an I/O interrupt. When off, the interrupt is kept pending.

-6-

LOAD

### <u>3 ARITHMETIC INSTRUCTIONS</u>

The description of each instruction includes a list of possible Program integrupts that can occur. These interrupts are explained in Section 7.

#### 3.1 LOAD INSTRUCTIONS

Load Register LR R1, R2 33 [ R1 R2 1 0 8 12 15 Load hex digit LX E1, R2 23 | R1 R2 | I 0 8 12 15 Load Deferred Register LDR R1, R2 13 | R1 | R2 | 1 0 8 12 15 Load Immediate LI R1S, R1F, I2 **B**3 IR1S RAF 1 0 8 12 16 Load Deferred Immediate LDI R1S, R1F, I2

| 1 | в8 | R1S | R1F |    | 12                             | /  |  |
|---|----|-----|-----|----|--------------------------------|----|--|
| 0 |    | 8   | 12  | 16 | a ann aife ann ann ann ann ann | 31 |  |

12

31

LOAD

| Loa                                   | đ                                |          |        |     |          |                                |       |  |  |  |  |
|---------------------------------------|----------------------------------|----------|--------|-----|----------|--------------------------------|-------|--|--|--|--|
| L                                     |                                  | R 1', D: | 2 (X2, | B2) |          |                                |       |  |  |  |  |
| <br> <br>                             | 73                               | R1       | X2     | B2  | T        | D2                             | <br>  |  |  |  |  |
| 0                                     | •                                | 8        | 12     | 16  | 20       | ، های های دیک باین مین میگ     | 31    |  |  |  |  |
| Loa<br>LD                             | Load Deferred<br>LD R1,D2(X2,B2) |          |        |     |          |                                |       |  |  |  |  |
|                                       | 53                               | R1       | X2     | B2  | r        | D2                             | 7<br> |  |  |  |  |
| 0                                     |                                  | 8        | 12     | 16  | 20       | una elan puna affer ann aire e | 31    |  |  |  |  |
| Load Signed Byte<br>LSB R1,D2 (X2,B2) |                                  |          |        |     |          |                                |       |  |  |  |  |
| 1                                     | 5B                               | R1       | X2     | B2  | <b>r</b> | D2                             | 7<br> |  |  |  |  |
| 0                                     | ana info ann ann ann an a        | 8        | 12     | 16  | 20       |                                | 31    |  |  |  |  |

The second operand is placed in the first operand location. The second operand for LX is the R2 field expanded with 0's to 16 bits, while the second operand for LDR is the halfword pointed to by the contents of R2. The LDI instruction uses the immediate halfword operand as the address of the halfword to load. LD adds an extra level of indirectness by using the second operand as an address to pick up still another halfword. LSB loads a byte, propagating its sign through bits 0 to 7 of the register. Alignment interrupts can occur for L, LD, LDR, LZ, and LDI.

| Loa<br>LZ | id and | Ze | ero<br>R <b>1,</b> 1 | D2 | (X2) | , B2 | 2) |    |                                   | 5  |
|-----------|--------|----|----------------------|----|------|------|----|----|-----------------------------------|----|
| [         | 5E     | 1  | R 1                  | 1  | X2,  | 1    | B2 | ļ  | D 2                               |    |
| 0         |        | 6  | 3                    |    | 12   | 1    | 16 | 20 | a quan main difer class char main | 31 |

The second operand halfword is placed in R1. Following this load, the halfword is zeroed. An Alignment interrupt can occur.

LOAD

| 0           |      | 8     | 12         | 16    | 20   |    | 31                 |
|-------------|------|-------|------------|-------|------|----|--------------------|
| 1 4         | E    | R1    | X2         | B2    | <br> | D2 | يبير حلة حلت عند م |
| LC          |      | R1,D  | 2(X2,      | B2)   |      | 2  |                    |
| Load        | Comp | lemen | t          |       |      |    |                    |
| 0           |      | 8     | 12 1       | 5     |      |    |                    |
|             | )E   | R1    | R2         |       |      |    |                    |
| LOad<br>LCR | Comp | R1,R  | t Reg<br>2 | ister |      |    |                    |
|             |      |       |            |       |      |    |                    |

The 2's complement of the second operand is placed in the first operand location. C1 is set if overflow occurs, or reset otherwise. Arithmetic Overflow and Alignment (LC only) interrupts can occur.

Load Positive Register LPR R1,R2

| í | 0C | R 1. | I R2 | -7 |
|---|----|------|------|----|
| L |    |      | 1    | Ĺ_ |
| 0 |    | 8    | 12   | 15 |

Load Positive

LP R1, D2 (X2, B2)

| [ | 4C                  | 1 | R 1 | 1 | X 2 | 1 | B2 | 1 | Ď2 | ۲<br>ا  |
|---|---------------------|---|-----|---|-----|---|----|---|----|---------|
| 0 | 999 600 600 600 600 | 8 | -   | 1 | 2   | 1 | 6  | 2 | 0  | J<br>31 |

The absolute value of the second operand is placed in the first operand location. C1 is set if overflow occurs, or reset otherwise. Arithmetic Overflow and Alignment (LP only) interrupts can occur.

Load Negative Register LNR R1,R2

| r | a dana afin atau ana a |   |     |   |    | - | 1 |
|---|------------------------|---|-----|---|----|---|---|
| 1 | 0 D                    | 1 | R 1 | 1 | R  | 2 | İ |
| L |                        |   |     | _ |    |   |   |
| 0 |                        |   | 8   | : | 12 | 1 | 5 |
|   | 2 · · · ·              |   |     |   |    |   |   |

ADD

| Loa               | d Neg               | jative |         |      |    |                                 |         |
|-------------------|---------------------|--------|---------|------|----|---------------------------------|---------|
| LN                |                     | R1, D  | 2 (X.2, | B2)  |    |                                 |         |
| r                 | 4 D                 | I R1   | X 2     | I B2 | i  | D2                              | 1<br>   |
| <u>ل</u> ہے۔<br>0 | reya das das disens | 8      | 12      | 16   | 20 | a aina dala adip terus azas ape | J<br>31 |

The 2's complement of the absolute value of the second operand is placed in the first operand location. An Alignment interrupt can occur for LN.



The set of registers from R1 to R3 (wrapping from register 15 to the MSR if necessary) is loaded from consecutive halfwords at the second operand address (LM) or at the address specified by the second operand halfword (LMD). If R1 specifies the MSR, no I/O or S/360 interrupts can occur after execution. An Alignment interrupt can occur.

#### 3.2 ADD INSTRUCTIONS

Add Registers AR R1, R2 1 34 | R1 | R2 | 0 8 12 15

Add hex digit AX R1, R2 24 R1 R2 1 0 8 12 15 Add Immediate AI R15, R1F, I2 **B4** R1S |R1F 12 1 0 8 12 16 31 Add A R1, D2 (X2, B2) 74 R1 X2 B2 D2 0 8 12 16 20 31 Add to Halfword Immediate AHI D1(B1),I2 84 12 B1 D1 0 8 16 20 31 Add Halfwords AH D1(B1), D2(B2) F4 0 B1 D1 B2 D2 1 1 0 8 1.6 20 32 36 47

The second operand is added using 2's complement arithmetic to the first operand, and the sum is put in the first operand location. The second operand for AX is the R2 field treated as a 4-bit number from 0 to 15. For AHI, the second operand is the immediate byte extended with 8 high-order 0's. C1 is set to the overflow condition resulting from the addition. Arithmetic Overflow and Alignment (except for AR, AX, and AI) interrupts can occur.

ADD

#### Subtract

| Ađđ<br>ALR | Logic                            | al Re<br>R1,R   | giste<br>2     | rs          |                      |                     |         |
|------------|----------------------------------|-----------------|----------------|-------------|----------------------|---------------------|---------|
| <br> <br>  | 3C                               | R1              | R2             | ר<br> <br>ו |                      |                     |         |
| 0          |                                  | 8               | 12 1           | 5           |                      |                     |         |
| Add<br>Ali | Logic                            | al Imi<br>R1S,1 | nedia<br>R1F,I | te<br>2     |                      |                     |         |
| 1          | BC                               | R1S             | R1F            |             | I2                   |                     |         |
| 0          |                                  | 8               | 12             | 16          | 99 anis ans an an an |                     | 31      |
| Add<br>AL  | Logica                           | al<br>R1,D2     | 2 (X2,1        | <u>3</u> 2) |                      |                     |         |
| 1          | 7c                               | R1              | ·X2            | В2          | <b>19</b>            | D2                  |         |
| 0          | ar provinski saka dapa dapa dapa | 8               | 12             | 16          | 20                   | ana ana ana ana ana | J<br>31 |

The second operand is logically added to the first, and the result is placed in the first operand location. C1 is set to the resulting carry out. An Alignment interrupt can occur for AL.

# 3.3\_SUBTRACT\_INSTRUCTIONS

Subtract Registers SR R1, R2 r 35 1 R1 R2 | L 0 8 12 15 Subtract hex digit SX R1, R2 25 R1 R2 L 1 0 8 12 15

Subtract.

| Sub<br>SI    | tract                      | Immed:<br>R1S,I         | iate<br>R1F,I        | 2      |                    |                                                |                          |    |    |    |                         |
|--------------|----------------------------|-------------------------|----------------------|--------|--------------------|------------------------------------------------|--------------------------|----|----|----|-------------------------|
| 1            | B5                         | R1S                     | R1F                  | 1      | I                  | 2                                              | i dang ang ang ang ang a |    |    |    |                         |
| 0            |                            | 8                       | 12                   | 16     | NA CAN BER SHE SHE | liten eran gan dila akin ada                   | 31                       | 5  |    |    |                         |
| Sub<br>S     | tract                      | R1,D:                   | 2 (X2,               | B2)    |                    |                                                |                          |    |    |    |                         |
| [<br>        | 75                         | R 1                     | X2                   | B2     |                    | D2                                             |                          |    |    |    |                         |
| 0            | dia 414 dia 614 dia 415 am | 8                       | 12                   | 16     | 20                 | ith <del>ann cup ann</del> d <del>ao ain</del> | 31                       |    |    |    |                         |
| Sub<br>SHI   | tract                      | from H<br>D <b>1(</b> B | Halfw<br>1),I2       | ord II | nmedi              | ate                                            |                          |    |    |    |                         |
| 1            | 85                         | į i:                    | 2                    | B1     |                    | D <b>1</b>                                     |                          |    |    |    |                         |
| 0            |                            | 8                       | na dha mar ana ask a | 16     | 20                 | 929 420 Hans Hans Anny 4240                    | 31                       |    |    |    |                         |
| Sub<br>SH    | tract                      | Halfwo<br>D1(B          | ords<br>1),D2        | (B2)   |                    |                                                |                          |    |    |    |                         |
|              | F5                         | 1 (                     | <u>)</u>             | B1     |                    | D 1                                            | 1                        | В2 |    | D2 | <del>و من خم</del><br>ا |
| 0            |                            | 8.                      |                      | 16     | 20                 |                                                |                          | 32 | 36 |    | 4 7                     |
| <b>m</b> 1 - |                            | -                       |                      |        |                    |                                                |                          |    |    |    |                         |

The second operand is subtracted from the first, and the result replaces the first operand. The SX second operand is the R2 field treated as a 4-bit number from 0 to 15. For SHI, the second operand is the immediate byte extended with 8 high-order 0's. C1 is set to the overflow condition resulting from the subtraction. Arithmetic Overflow and Alignment (except for SR, SX, and SI) interrupts can occur.

Subtract Logical Registers SLR R1,R2

| r |    |    |                 |   |    | - | -  |
|---|----|----|-----------------|---|----|---|----|
| 1 | 3D | 1  | R 1             | Ì | R  | 2 | i  |
| L |    | L. | ma qana-qana et |   |    |   | Ĺ. |
| 0 |    | 1  | 8               | 1 | 12 | 1 | 5  |

COMPARE

| Sul<br>SLI | otrace<br>I                              | Logic<br>R1S,          | al Im<br>R <b>1</b> F,I | media<br>2 | te |                |         |
|------------|------------------------------------------|------------------------|-------------------------|------------|----|----------------|---------|
|            | BD                                       | R1S                    | R1F                     | 1          | I2 | 2              |         |
| 0          |                                          | 8                      | 12                      | 16         |    |                | 31      |
| Sul<br>SL  | otract                                   | Logic<br>R <b>1,</b> D | al<br>2(X2,             | B2)        |    |                |         |
|            | 7 D                                      | R1                     | X2                      | B2         | I  | D2             |         |
| 0          | <del>fo mi an</del> <del>an anan</del> o | 8                      | 12                      | 16         | 20 | - <del>7</del> | J<br>31 |

The second operand is logically subtracted from the first, and the result replaces the first operand. C1 is set to the resulting carry. An Alignment interrupt can occur on SL. Note that carry is the complement of borrow.

# 3.4 ARITHMETIC COMPARE INSTRUCTIONS

| 0             | 8              | 12             | 16         | 20                  |    | 31 |
|---------------|----------------|----------------|------------|---------------------|----|----|
| 70            | R1             | 1 X 2          | <b>B</b> 2 |                     | D2 |    |
| Compare<br>C  | R1,I           | )2 (X2,        | ,B2)       |                     |    |    |
| 0             | 8              | 12             | 16         |                     |    | 31 |
| во            | R1S            | R1F            | 1          | n Alla enn eind die | 12 |    |
| Compare<br>CI | Immed:<br>R1S  | iate<br>,R1F,1 | [2         |                     |    |    |
| 0             | 8              | 12 1           | 15         |                     |    |    |
| 30            | R1             | R2             |            |                     |    |    |
| Compare<br>CR | Regist<br>R1,1 | ters<br>R2     |            |                     |    |    |

MULTIPLY

| Comµ<br>CHI | pare H | alfword to<br>D1(B1),I2 | Imme | liate |    |               |    |         |                               |     |
|-------------|--------|-------------------------|------|-------|----|---------------|----|---------|-------------------------------|-----|
| [<br>[      | 80     | 1 12                    | 1 B1 |       | D1 |               |    |         |                               |     |
| 0           |        | 8                       | 16   | 20    |    | 31            |    |         |                               |     |
| Com p<br>CH | pare H | alfwords<br>D1(B1),D2   | (B2) |       |    |               |    | 14<br>1 |                               |     |
|             | F0     | 0                       | B1   |       | D1 |               | B2 |         | D2                            |     |
| 0           |        | 8                       | 16   | 20    |    | 19 ano any 48 | 32 | 36      | nina 4964 anna mula dany inis | 4 7 |

The first operand is compared algebraically with the second, and the result determines the setting of the Condition Code: CO, C1, and C2 are reset and then CO is set if equal, C1 if first operand greater, or C2 if less. The second operand for CHI is the immediate byte treated as an 8-bit signed number. Alignment interrupts can occur for C, CHI, and CH.

#### 3.5 MULTIPLY INSTRUCTIONS

Multiply Registers MR B1.82

| r | e quane anno anno de                | τ, | public contra-rititado es |   |    | ٦   |
|---|-------------------------------------|----|---------------------------|---|----|-----|
| 1 | 36                                  | 1  | R 1                       | 1 | R2 | 2 1 |
| L | • • • • • • • • • • • • • • • • • • |    |                           |   |    |     |
| 0 |                                     |    | 8                         |   | 12 | 15  |

Multiply Immediate MI R1S,R1F,I2

| r | any any day any or | *********************************** |     |            | يحجه وزهرة ملبقة فالبلة فالبلة فالبلة وتحته ورواه ويتبل والتب |    |
|---|--------------------|-------------------------------------|-----|------------|---------------------------------------------------------------|----|
| 1 | B6                 | R 1S                                | R1F | 1          | I2                                                            | i  |
| L |                    |                                     |     | - <b>L</b> | هيه حداد جريد جريد حرف مين حريد مريد                          |    |
| 0 |                    | 8                                   | 12  | 16         | 1                                                             | 31 |

Multiply

Μ

R1, D2 (X2, B2)

| <br> | 76 | 1 | R 1 | 1 | X.2 |   | В <b>?</b> | 1 |    | D2                                    |    |
|------|----|---|-----|---|-----|---|------------|---|----|---------------------------------------|----|
| 0    |    | 1 | 3   |   | 12  | 1 | 16         |   | 20 | · · · · · · · · · · · · · · · · · · · | 31 |

DIVIDE

| Mul<br>MH | tiply | Hal<br>D1 | fwords<br>(B1),I | 5<br>)2 <b>(</b> B2 | :) |    |  | ,  |    |    |    |
|-----------|-------|-----------|------------------|---------------------|----|----|--|----|----|----|----|
|           | F6    | 1         | 0                | I E                 | 31 | Ď1 |  | в2 |    | D2 |    |
| 0         |       | 8         |                  | 16                  | 2  | 0  |  | 32 | 36 |    | 47 |

The first and second operands are multiplied and the 2-halfword (32-bit) product is placed in the first operand location and the following register or halfword. C1 is reset unless the product requires more than 16 bits, in which case it is set. An Alignment interrupt can occur for M and MH, and a Register Specification interrupt for MR and M if register 15 is specified as the first operand or for MI if register 15 is specified in the R1S field.

3.6 DIVIDE INSTRUCTIONS

| Divide<br>DR | Registe<br>R1,E          | ers<br>R2                 |       |                     |                                                              |                     |     |         |    |        |   |
|--------------|--------------------------|---------------------------|-------|---------------------|--------------------------------------------------------------|---------------------|-----|---------|----|--------|---|
| 37           | R1                       | R2                        | 1     |                     |                                                              |                     |     |         |    |        |   |
| 0            | 8                        | 12 1                      | 5     |                     |                                                              |                     |     |         |    |        |   |
| Divide<br>DI | r1s,                     | ate<br>,R1F,I             | 2     |                     |                                                              |                     |     |         |    |        |   |
| В7           | R1S                      | R1F                       | 1     |                     | I2                                                           | 1                   |     |         |    |        |   |
| 0            | 8                        | 12                        | 16    | dana dalaratana dan | a mua tana dina tanà ana amin' dana ami                      | 31                  |     |         |    |        |   |
| Divid∈<br>D  | R <b>1,</b> I            | 02 <b>(</b> X2,           | B2)   |                     |                                                              |                     |     |         |    |        |   |
| 77           | R1                       | X2                        | В2    | 1                   | D2                                                           | ļ                   |     |         |    |        |   |
| 0            | 8                        | 12                        | 16    | 2 0                 | in annan amgin ainan antan kaina annan <sup>annan</sup> dain | 31                  |     |         |    |        |   |
| Divide<br>DH | Halfwon<br>D <b>1(</b> ] | rds<br>31),D2             | (B2)  |                     |                                                              |                     | -   |         |    |        |   |
| F            | '                        | 0                         | B1    | 1                   | D1                                                           | 1                   | В2  |         | D2 |        |   |
| 0            | 8                        | na dan amu baw nawana ana | 16    | 20                  | n diga man atlan ann man ann ann ann                         | n men one data alla | 32  | 36      | -  | 4 7    |   |
| The do       | uble rea                 | gister.                   | /half | word                | (32-bit                                                      | ) fi                | rst | operand | is | divide | d |

by the second operand and the quotient and remainder,

CONVERT

respectively, replace the 2 registers/halfwords of the first operand. Alignment interrupts can occur for D and DH, Register Specification interrupts for DR, DI, and D (if register 15 is specifed as the first operand), and Division by O and Arithmetic Overflow interrupts for all 4 formats. C1 is set to the overflow condition.

#### 3.7 CONVERT INSTRUCTIONS

ConVert to Binary CVB R1,D2(X2,B2)

|   | EO                          |   |    | T |     | Ţ  |    |    |    |    |
|---|-----------------------------|---|----|---|-----|----|----|----|----|----|
| 1 | 55                          | 1 | RI | 1 | XZ  |    | BZ | 1  | D2 |    |
| L | a mana kanta anna anna anna |   |    |   |     | جك |    |    |    | L  |
| 0 | ·                           | 1 | 8  |   | 1.2 | 1  | 6  | 20 |    | 31 |

This instruction takes a string of EBCDIC digit characters (with optional leading blanks and/or minus sign) and converts the number to binary, placing it in R1. Register 2 is set to the address of the first invalid character following the digits. C0, C1, and C2 are initially set to 0. C0 is set if there were no valid digits, C1 is set if there was overflow (the result required more than 16 bits to represent), or C2 is set if the instruction was completed successfully. A Conversion Overflow interrupt can occur.

| ConVert | to I | eci | mal  |     |
|---------|------|-----|------|-----|
| CVD     | R1   | ,D2 | (12, | B2) |

| L | 9 <b>4 10 4 40 40 40 40 40 40 40</b> 40 10 |     |                |   |    | - | an ontro engle entro        | T  |         | <b>r</b> |
|---|--------------------------------------------|-----|----------------|---|----|---|-----------------------------|----|---------|----------|
| 1 | 51                                         | 1   | R 1            | 1 | X2 | 1 | B2                          | 1  | D2      | I        |
| L | -                                          |     | un anto anto a | 1 |    |   | <del>//// //// ////</del> / |    | <b></b> |          |
| 0 |                                            | . 1 | в              |   | 12 | 3 | 16                          | 20 | ,       | 31       |

This instruction takes the contents of R1 and converts it to a 6-digit EBCDIC decimal number with leading 0's replaced by blanks and a floating minus sign, if appropriate. Register 2 is set to the absolute address of the first non-blank generated, while register 3 is set to the length of the remaining string.

STORE

3.8 STORE INSTRUCTIONS

STore Deferred Register STDR R1,R2

|   | `  |   |     | -  |     |  |
|---|----|---|-----|----|-----|--|
| 1 | 12 | 1 | R 1 | R  | 2 1 |  |
| L |    |   |     | L  |     |  |
| 0 |    | 8 |     | 12 | 15  |  |

STore Deferred Immediate STDI R1S,R1F,I2

| r |                        | 1.77 | NT.     |    |                                                         | L  |
|---|------------------------|------|---------|----|---------------------------------------------------------|----|
| 1 | B1                     | RIS  | R1F     | 1  | I2                                                      | 1  |
| L | a nina mpo mpo nipo og |      | <u></u> |    | وبيه فادبه وبواد وزول الاتلاء فاشد قاتلك الالك وكانه فت |    |
| 0 |                        | 8    | 12      | 16 |                                                         | 31 |

STore

ST R1, D2 (X2, B2)

| r | 72                       | 1 | R 1 | 1 | X2 | 1 | B2 | ī |    | D2 | <br> |
|---|--------------------------|---|-----|---|----|---|----|---|----|----|------|
| 0 | uga anna dinth cung donn | 1 | 3   | 1 | 12 | 1 | 6  |   | 20 |    | 31   |

STore Deferred STD P1,D2(X2,B2)

| <b></b>    |    |            | -   |   |    |   |    |    | -  |    |
|------------|----|------------|-----|---|----|---|----|----|----|----|
| 1          | 52 | Ĩ          | R 1 | i | X2 | i | B2 | i  | D2 | i  |
| L. app and |    | a ana alba |     |   |    |   |    |    |    | J  |
| 0          |    | 1          | в   |   | 12 | 1 | 6  | 20 |    | 31 |

STDR stores the contents of R1 at the halfword location pointed to by R2. The STDI instruction uses the immediate operand as the address of where to store the register. ST stores R1 at the RX address. STD stores R1 at the halfword location whose address is Operand 2. An Alignment interrupt can occur.

STore Multiple

• STM R1,R3,D2(B2)

| <b>Г</b> |    |   |                          | T |    | -    |    |    |    | and a state data data data dita data |    |
|----------|----|---|--------------------------|---|----|------|----|----|----|--------------------------------------|----|
| 1        | 92 | 1 | R1                       | 1 | R3 | 1    | B2 | 1  |    | D2                                   | i  |
| L        |    |   | utte datavas etamate eta |   |    | . L. |    | _L |    |                                      | j  |
| 0        |    | 1 | 3                        |   | 12 | 1    | 16 |    | 20 |                                      | 31 |

SWAP

| STO   | ore M | ulti | lple   | 9 1 | Defe | err | ed |           |                            |      |
|-------|-------|------|--------|-----|------|-----|----|-----------|----------------------------|------|
| STI   | MD    | I    | R 1, E | 23  | ,D2  | (B2 | )  |           |                            |      |
| [<br> | 90    |      | R1     | i   | R3   | I   | B2 | <br> <br> | D2                         | <br> |
| 0     |       | 8    | 3      | 1   | 12   | 1   | 6  | 20        | ite data sigd-stas societa | 31   |

The set of registers from R1 to R3 (wrapping from register 15 to the MSR, if necessary) is stored in consecutive halfwords at the second operand location (STM) or at the address specified by the second operand halfword (STMD). An Alignment interrupt can occur.

## 3.9 MOVE HALFWORD INSTRUCTIONS

MoVe to Halfword Immediate MVHI D1(B1),I2

| r |    |   |                           |   |    | +  |    |       |
|---|----|---|---------------------------|---|----|----|----|-------|
| 1 | 83 | 1 | I2                        | 1 | В1 | Ì  | D1 | 1     |
| L |    |   | متقوري فتعاويهم حتارة تتت |   |    |    |    | أحصصم |
| 0 |    | 8 |                           |   | 16 | 20 |    | 31    |

MoVe Halfword MVH D1(B1), D2(B2)

|   |    |   |                     |      |    |                                          | - |    |    |                                                                                                                |    |
|---|----|---|---------------------|------|----|------------------------------------------|---|----|----|----------------------------------------------------------------------------------------------------------------|----|
| į | F3 | Í | 0                   | I B1 | Ì  | D <b>1</b>                               | 1 | В2 | ļ  | D2                                                                                                             |    |
| 0 |    | 8 | ann dhiann ann da a | 16-  | 20 | මහතා සලංක සොරේ දියලා අයයා හැංග හැදුළ අතන |   | 12 | 36 | 9 (1000 - 1910) 4000 (1000 - 1000 - 1000 - 1000 - 1000 - 1000 - 1000 - 1000 - 1000 - 1000 - 1000 - 1000 - 1000 | 47 |

The second operand is placed in the first operand halfword. The second operand for MVHI is the immediate signed byte expanded to a halfword. An Alignment interrupt can occur.

# 3.10\_SWAP\_INSTRUCTIONS

11.18,75

| SWAP<br>SWPR | Regi | .51 | ters<br>R1, H | 5<br>R2 |    |   |   |
|--------------|------|-----|---------------|---------|----|---|---|
| 387          | 3-8  | 1   | R 1           | 1       | R  | 2 | 1 |
| 0            |      | 1   | 3             | 1       | 12 | 1 | 5 |

SHIFT

| Swal<br>SWP | 5                                    | 1 | R1,I | 2 | (X2, | B         | 2) |    |                                                                                                                 |    |
|-------------|--------------------------------------|---|------|---|------|-----------|----|----|-----------------------------------------------------------------------------------------------------------------|----|
| r           | 78                                   |   | R 1  | 1 | X2   | 1         | E2 |    | D2                                                                                                              |    |
| 0           | nia anto estas estas estas estas est | 1 | 8    |   | 12   | us allana | 16 | 20 | n datan dalam d | 31 |

The contents of the first operand register is interchanged with the contents of the second operand register/halfword. An Alignment interrupt can occur for SWP.

# 3.11 ARITHMETIC SHIFT INSTRUCTIONS

| Shift Le<br>SLAI | ft Ale<br>R1,1  | gebrai<br>R2     | c Imm    | ediate | I                            |    |
|------------------|-----------------|------------------|----------|--------|------------------------------|----|
| [ 1c             | I R1            | R2               |          |        |                              |    |
| 0                | 8               | 12 1             | 5        |        |                              |    |
| Shift Le<br>SLA  | ft Alc<br>R1,1  | gebrai<br>R3,D2( | c<br>B2) |        |                              |    |
| 90               | R1              | R3               | B2       | r      | D2                           |    |
| 0                | 8               | 12               | 16       | 20     | refiel anna dhia caan agua g | 31 |
| Shift Ri<br>SRAI | ght A1<br>R1, H | Lgebra<br>R2     | ic Im    | mediat | е                            |    |
| 1 D              | R1              | R2               | 1        |        |                              |    |
| 0                | 8               | 12 1             | 5        |        |                              |    |

Shift Right Algebraic SRA R1,R3,D2(B2)

| [ | 9D |   | R 1 | R3 | I B2 | 1  | D2                            | [  |
|---|----|---|-----|----|------|----|-------------------------------|----|
| 0 | •  | I | 8   | 12 | 16   | 20 | in ann ann aith ann cuirdin e | 31 |

SHIFT

| Shift Lef<br>SLDAI  | t Doul<br>R1,R2 | ole A:<br>2      | lgebra        | aic 1 | Immediat | e  |
|---------------------|-----------------|------------------|---------------|-------|----------|----|
| [ 1E                | R1              | R2               | 1<br> <br>1   |       |          |    |
| 0                   | 8               | 12 19            | 5             |       |          |    |
| Shift Lef<br>SLDA   | t Doul<br>R1,R3 | ole A:<br>3,D2(1 | lgebra<br>B2) | aic   |          |    |
| 9È                  | R1              | (R3              | B2            |       | D2       | 1  |
| 0                   | 8               | 12               | 16            | 20    |          | 31 |
| Shift Rig!<br>SRDAI | ht Dou<br>R1,R2 | ible 1<br>2      | Algebi        | caic  | Immedia  | te |
| 1 F                 | R1              | R2               |               |       |          |    |
| 0                   | 8               | 12 19            | 5             |       |          |    |
| Shift Rig<br>SRDA   | ht Dou<br>R1,R3 | 1ble 1<br>3,D2(1 | Algeb<br>32)  | caic  |          |    |
| 9F                  | R 1             | R3               | B2            |       | D2       |    |
| 0                   | 8               | 12               | 1.6           | 20    |          | 31 |

The register or pair of registers specifed by R1 is shifted left or right the number of bits specified by the R2 field for the RR form, or by the 5 low order bits of the computed address for the RS form. Right shifts cause vacated bit positions to be filled with the original sign bit. For left shifts, if a bit unlike the sign bit is shifted out of bit position 1 of R1, overflow is set into C1 and Arithmetic Overflow interrupts can occur. C2 is set to the last bit shifted out. Register Specification interrupts occur for double shifts if R1 is specified as register 15.

Shift for Divide SD , R1,R2

|   | . 17 | ]<br> | R 1 | 1 | R | 3/ | ľ. |
|---|------|-------|-----|---|---|----|----|
| 0 |      | 8     |     | 1 | 2 | 1  | 5  |

The register specified by R1 is shifted right into the next higher register, and its sign is propagated through R1. This instruction can be used to set up a 32-bit dividend for a divide instruction. C2 is set to the original bit 0 of the

SHIFT

next higher register. Register Specification interrupts can occur if R1 specifies register 15.

. . 

## Logical Instructions

#### COMPARE

Compare Logical Immediate R15, R1F, I2 CLI BF LRIS IRIF 12 0 8 12 16 31 Compare Logical CL R1, D2 (X2, B2) 7F R1 X2 I B2 D2 0 8 12 16 20 31 Compare Logical to Byte CLB R1, D2 (X2, B2) 5F R1 X2 B2 D2 1 0 8 12 16 20 31 Compare Logical Byte to Immediate CLBI D1(B1),I2 8F12 B1 D1 0 8 20 16 31 Compare Logical Halfwords CLH D1(B1), D2(B2) 0 FB **B1** D1 B2 D2 8 16 20 32 36 47 Compare Logical Characters (Long) CLC/CLCL D1(L,B1), D2(B2) CF/DF L B1 D1 B2 D2 0 8 16 20

The first operand is compared logically with the second, and the result determines the setting of the Condition Code as in the algebraic compares. For CLB, Operand 1 is the low order byte of R1. CLC/CLCL causes register 2 to be set to the in Operand 1 of the first unequal byte, unless an address equal compare occurs. An equal compare always occurs if the length specified is zero, as two null strings are considered equal. An Alignment interrupt can occur for CL and CLH.

32

36

47

1 24

AMP

VST

# 4.3 AND INSTRUCTIONS

x

| AND Registers         NR       R1,R2         39       R1       R2         0       8       12         aNd Immediate       R1s,R1F,I2         B9       R1s       R1F         0       6       12         0       6       12         0       6       12         0       6       12         0       6       12         0       8       12       16         31       31         aNd       R1,D2(X2,B2)       D2         1       79       R1       X2       B2       D2         0       8       12       16       20       31         aNd to Byte Immediate       NBI       D1(B1),I2       16       20       31         aNd to Byte Immediate       NBI       D1(B1),I2       16       20       31         aNd Characters (Long)       NC/NCL       D1(L,B1),D2(B2)       31         C9/D9       L       B1       D1       B2       D2 | 47  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| ANd Registers         NR       R1,R2         39       R1       R2         0       8       12         0       8       12         aNd Immediate       R1S,R1F,I2         B9       R1S       R1F         0       8       12       16         0       8       12       16         aNd       R1,D2(X2,B2)       D2       1         0       8       12       16       20       31         aNd to Byte Immediate       D1(B1),I2       D1       1       1         0       8       16       20       31         aNd Characters (Long)       NC/NCL       D1(L,B1),D2(B2)       D1       1                                                                                                                                                                                                                                                |     |
| And Registers         NR       R1,R2         39       R1       R2         0       8       12       15         and Immediate       R1S,R1F,I2       I2         B9       R1S       R1F       I2         0       8       12       16       31         and       R1,D2(X2,B2)       D2       31         0       8       12       16       20       31         and to Byte Immediate       D1(B1),I2       D1       0       31         0       8       16       20       31                                                                                                                                                                                                                                                                                                                                                           |     |
| ANd Registers         NR       R1,R2         39       R1       R2         0       8       12       15         aNd Immediate       R1S,R1F,I2       I       B9       R1S [R1F]       I2         0       8       12       16       31         aNd       R1,D2 (X2,B2)       I       D2         0       8       12       16       20         0       8       12       16       20         0       8       12       16       20         0       8       12       16       20         0       8       12       16       20         1       79       R1   X2   B2   D2       D2         0       8       12       16       20         0       8       12       16       20       31         aNd to Byte Immediate       D1(B1),I2       D1       I       I         89       1       12       B1       D1       I                        |     |
| And Registers         NR       R1,R2         39       R1       R2         0       8       12       15         and Immediate       R1s,R1F,I2       12         I       B9       R1s  R1F         I2         0       8       12       16       31         and       R1,D2 (X2,B2)       16       31         I       79       R1   X2   B2         D2       1         0       8       12       16       31         and to Byte Immediate       D1(B1),I2       10       31                                                                                                                                                                                                                                                                                                                                                          | 21  |
| And Registers         NR       R1,R2         39       R1         39       R1         0       8         and Immediate         NI       R1S,R1F,I2         B9       R1S         0       8       12         0       8       12         0       8       12         0       8       12         0       8       12         0       8       12         1       79       R1         1       79       R1         1       16       20         31       31                                                                                                                                                                                                                                                                                                                                                                                  | 8.6 |
| And Registers         NR       R1,R2         39       R1   R2         0       8       12 15         and Immediate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
| And Registers       NR     R1,R2       39     R1       0     8       12     15       and Immediate       NI     R1S,R1F,I2       B9     R1S       0     8       12     16       31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | KX. |
| And Registers       NR     R1,R2       39     R1       39     R1       0     8       12     15       and Immediate       NI     R1S,R1F,I2       B9     R1S       0     8       12     16       31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |
| ANd Registers   IR   R1,R2   39   R1   39   R1   <                                                                                                                                                                                                                                                                                                                                                          |     |
| AND REGISTERS<br>IR R1,R2<br>39   R1   R2  <br>0 8 12 15<br>AND Immediate<br>NI R1S,R1F,I2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | KI  |
| ANd Registers         NR       R1,R2         39       R1       R2         39       R1       R2         0       8       12       15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0   |
| ANd Registers       IR     R1,R2       39     R1       R2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| NA REGISTERS<br>NR R1,R2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RR  |
| N1 Depterburg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |

The first operand is ANDed with the second and the result replaces the first operand. CO is set to 1 if the result is all O's or the length is O, to O otherwise. An Alignment interrupt can occur for N. OR

4.4 OR INSTRUCTIONS

| Or<br>OR  | Regist          | ers<br>R1,R2             | 2               | 2              |    |            |    |    |    |    |    |
|-----------|-----------------|--------------------------|-----------------|----------------|----|------------|----|----|----|----|----|
| 1         | 3 A             | R1                       | R2              | 1              |    |            |    |    |    |    |    |
| 0         |                 | 8                        | 12 1            | 5              |    |            |    |    |    |    |    |
| Or<br>OI  | Immedia         | ate<br>R1S,E             | 1 <b>F</b> ,I   | 2              |    |            | S. | A  |    |    |    |
| i<br>L    | ВÁ              | P1S                      | R·1F            | l<br>1         | I2 |            | ×  |    |    |    |    |
| 0         |                 | 8                        | 12              | 16             |    |            | 31 |    |    |    |    |
| Or<br>O   |                 | R1, D2                   | 2 (X2,1         | 32)            |    |            |    |    |    |    |    |
| <br>      | 7 A             | R1                       | X 2             | B2             | 1  | D2         |    | -  |    |    |    |
| 0         |                 | 8                        | 12              | 16             | 20 |            | 31 |    |    |    |    |
| Or<br>OBI | to Byte         | e Imme<br>D <b>1(</b> B1 | ediate<br> ),I2 | 9              |    |            |    |    |    |    |    |
| 1         | 8 A             | IZ                       | 2               | в1             | 1  | D <b>1</b> |    |    |    |    |    |
| 0         | • 2 0           | 8                        |                 | 16             | 20 |            | 31 |    |    |    |    |
| Or<br>OC/ | Charact<br>/OCL | D1(L,                    | (Long)<br>B1),I | 02 <b>(</b> B2 | )  |            |    |    |    |    |    |
| 1         | CA/DA           | II                       |                 | B1             | 1  | D1         |    | В2 | 1  | D2 |    |
| 0         | 2002            | 8                        |                 | 16             | 20 |            |    | 32 | 36 |    | 47 |

The first operand is ORed with the second and the result replaces the first operand. CO is set to 1 if the result is all O's or the length is O, to O otherwise. An Alignment interrupt can occur for O.

EXCLUSIVE OR

4.5\_EXCLUSIVE\_OR\_INSTRUCTIONS

| eXclusive<br>XR      | or Regist<br>R1,R2               | ers               |                                         |                                    | Ċ.             |    |    |                                          |    |
|----------------------|----------------------------------|-------------------|-----------------------------------------|------------------------------------|----------------|----|----|------------------------------------------|----|
| 1 3B                 | R1 R2                            | ר<br> <br>נ       |                                         |                                    |                |    |    |                                          |    |
| o<br>eXclusive<br>XI | 8 12 1<br>or Immedi<br>R1S,R1F,I | s<br>ate<br>2     |                                         |                                    |                |    |    |                                          |    |
| BB                   | R1S R1F                          | 1                 | I2                                      | na dila dan siya diya dan d        |                |    |    |                                          |    |
| 0                    | 8 12                             | 16                | 19 FAID 6319 6329 6340 6340 6340 6349 6 | min antan anna anna anna anna anna | 31             | L  |    |                                          |    |
| eXclusive<br>X       | or<br>R1,D2(X2,                  | B2)               |                                         |                                    |                |    |    |                                          |    |
| 7B                   | R1 X2                            | B2                |                                         | D2                                 |                |    |    |                                          |    |
| 0                    | 8 12                             | 16                | 20                                      |                                    | 31             |    |    |                                          |    |
| eXclusive<br>XBI     | or to Byt<br>D1(B1),I2           | e Imme            | ediate                                  |                                    |                | 9  |    |                                          |    |
| 8B                   | 12                               | B1                | ge ange-angé anta entre siret et        | D1                                 | 7              |    |    | ~                                        |    |
| 0                    | 8                                | 16                | 20                                      | na dovela con tra dos              | 31             |    |    |                                          |    |
| exclusive<br>XC/XCL  | or Charac<br>D1(L,B1),           | ters (<br>D2 (B2) | (Long)                                  |                                    |                |    |    |                                          |    |
| CB/DB                | L                                | B1                | n estis entre entre data disse en       | D1                                 | ·              | в2 | 1  | D2                                       |    |
| 0                    | 8 .                              | 16                | 20                                      | ga santi mwa anna mwa anka a       | •• ••• ••• ••• | 32 | 36 | an a | 47 |

The first operand is EXCLUSIVE OREd with the second and the result replaces the first operand. CO is set to 1 if the result is all 0's or the length is 0, to 0 otherwise. An Alignment interrupt can occur for X.

Logical Instructions

BYTE

1

4.6 TEST UNDER MASK INSTRUCTIONS

Test under Mask Register TMR R1,R2 32 | R1 | R2 |

|   |   |    | -7 | - |
|---|---|----|----|---|
| 0 | 8 | 12 | 1  | 5 |

Test under Mask Immediate TMI R1S,R1F,I2 B2 R1S R1F II2 0 8 12 16 31

11,18.25

TMBI

| Test | Byte | under   | Mask | Imm | ediate |  |
|------|------|---------|------|-----|--------|--|
| TBAI |      | D1 (B1) | ,12  |     |        |  |
| r    |      | Ŧ       |      |     | T      |  |
|      | 00   |         |      | - 4 |        |  |

|   | 82 | 1 | 12 · | <b> </b> B | 1 | 1  | D 1                                  | - ° 1 |
|---|----|---|------|------------|---|----|--------------------------------------|-------|
|   |    |   |      | ~ <b></b>  | - | L  | و مدين جريبي جملي جريبي خاني جريبي ه |       |
| 0 |    | 8 |      | 16         |   | 20 |                                      | 31    |

The 1 bits in the second operand mask select the corresponding bits in the first operand. These bits are then tested and the Condition Code is set as follows: all bits are reset and then CO is set if the tested bits were all O's or the mask was C, C1 is set if all tested bits were 1, or C2 is set if they were mixed O's and 1's.

#### 4.7 BYTE INSTRUCTIONS

Insert Byte IB R1, D2 (X2, B2) 58 R 1 X2 1 1 | B2 D2 0 8 12 **16** 20 31 Load Byte R1, D2 (X2, B2) LB 5A | R1 | X2 | B2 D2 1 0 8 12 16 20 31

BYTE

The byte at the second operand location is placed into bits 8 through 15 of R1, and bits 0 to 7 are left the same (IB) or zeroed (LB).

STore Byte STB R1,D2(X2,B2)

| ſ |    | - |    | 1  |            | 77 |    |   | an alam dans di |    | L      |
|---|----|---|----|----|------------|----|----|---|-----------------|----|--------|
| 1 | 59 | 1 | R1 | 1  | <u>x</u> 2 | 1  | B2 | 1 |                 | D2 | 1      |
| L |    |   |    | 1. |            |    |    |   |                 |    | لـــــ |
| 0 |    | 1 | 8  |    | 12         | 1  | 16 | 2 | 2 0             |    | 31     |

Bits 8 to 15 of R1 are stored as a byte into the second operand location.

FILL (Long) FILL FILLL D1(L,B1),D2(B2)

| 1 | C8/D8 | 1        | L | <del>~ 1 -</del> | B1 | T  | D1                                         | T-<br> | в2 | ╵╋╼╼╼╤╸    | D2                            |    |
|---|-------|----------|---|------------------|----|----|--------------------------------------------|--------|----|------------|-------------------------------|----|
| L |       | <b>_</b> |   | <b>-</b>         |    | L  | و جنوب وروب وروب مردو ماردو و مرود والده و | <br>1- |    | _ <b>L</b> | بليد طري سند مند منه أحدد مرد | L  |
| 0 |       | 8        |   | 1                | 6  | 20 |                                            | 3      | 2  | 36         |                               | 47 |

The first operand, character string is filled with the low-order byte of the second operand <u>address</u>.

Load and eXchange Bytes Register LXBR R1,R2

| 1 | 0 F                       | 1   | R 1 | 1   | R2 | 2 1 |
|---|---------------------------|-----|-----|-----|----|-----|
| L | 0-0110 \$550 4340 4380 43 | L   |     | _   |    | J   |
| 0 |                           | . 1 | в   | ÷ 3 | 12 | 15  |

Load and eXchange Bytes LXB R1,D2(X2,B2)

|   | 4 F | 1 | R 1 | I | <u>x</u> 2 | 1 | В2 | 1  | D2 |    |
|---|-----|---|-----|---|------------|---|----|----|----|----|
| 0 |     | 1 | 8   |   | 1 2        |   | 16 | 20 |    | 31 |

The second operand halfword is loaded into R1, with its 2 bytes exchanged. An Alignment interrupt can occur for LXB. Logical Instructions

#### TRANSLATE and SCAN-

# 4.8 ADDRESS MANIPULATION INSTRUCTIONS

| LA       | ad Addı | ress<br>R1,D  | 2 (X2,       | B2)  |    |    |    |
|----------|---------|---------------|--------------|------|----|----|----|
|          | 5D      | I R1          | X 2          | В2   |    | D2 |    |
| 0        |         | 8             | 12           | 16   | 20 |    | 31 |
| Su<br>SA | btract  | Addre<br>R1,D | ss<br>2 (X2, | B2)  |    |    |    |
|          |         |               |              |      |    |    |    |
|          | 5C      | Į R1          | X.2          | I B2 | 1  | D2 |    |

The computed RX address is loaded into (LA) or subtracted from (SA) R1.

# Move Address

MVA D1(1, B1), D2 (B2)

| r      | £7 | -T    | n | - <u>ŕ</u> | D 1 | - <b>T</b> | <br>                                      |    | - <del></del> | <br>د<br>C -ر |   |      |
|--------|----|-------|---|------------|-----|------------|-------------------------------------------|----|---------------|---------------|---|------|
| ۱<br>۱ | F- | ן<br> |   | ا<br>      | D   |            | ا<br>ــــــــــــــــــــــــــــــــــــ | DZ | سیسی ا        | DZ            |   | <br> |
| 0      |    | 8     |   | 1          | 6   | 20         | 1                                         | 32 | 36            |               | 4 | 7    |

The computed second operand address is moved to the first operand location.

#### 4.9 TRANSLATE AND SCAN INSTRUCTIONS

TRanslate (Long) TR/TRL D1(L,E1),D2(B2)

|   | CE/DE | 1 | L | 1 | в1 | <br> | D 1 | <br>В2 | 1  | D2                                             |    |
|---|-------|---|---|---|----|------|-----|--------|----|------------------------------------------------|----|
| 0 |       | 8 |   | 1 | 6  | 20   |     | <br>32 | 36 | in anna daoin aigine agus daoin a cuise anna a | 47 |

The bytes at the first operand location are used as arguments to reference 1 of the 256 bytes in the second operand table, by adding each argument byte to the second operand address. The resulting byte then replaces the original argument in Operand 1.

TRANSLATE and SCAN

| Scan<br>STR/ | usind<br>STRL            | g Table Ric<br>D1(L,B1),1 | ght (1<br>D2(B2) | Long) |                                         |    |    |    |    |
|--------------|--------------------------|---------------------------|------------------|-------|-----------------------------------------|----|----|----|----|
|              | D/DD                     | L                         | B <b>1</b>       | P     | D <b>1</b>                              | B2 |    | D2 |    |
| 0            |                          | 8                         | 16               | 20    |                                         | 32 | 36 |    | 47 |
| SCan<br>STL/ | using<br>STLL            | Table Let                 | Et (Lo<br>D2(B2) | ong)  |                                         |    |    |    |    |
|              | C/DC                     | L                         | ВÎ               |       | D1                                      | В2 |    | D2 |    |
| 0            | n den den sekenne ader a | 8                         | 16               | 20    | afir ato eta ese ese ese ese an an an e | 32 | 36 |    | 47 |

Each byte of Operand 1 is used (as in TR) to reference a byte in the table pointed to by Operand 2. If the byte thus referenced is 0, referencing continues. If it is non-0, it is loaded into register 3 (the high-order byte of which is zeroed), the argument byte address is placed in register 2, and C2 of the Condition Code is set. If all referenced bytes are 0 or the length is 0, C2 is reset to 0. STL addresses Operand 1 by its rightmost byte.

```
Scan Right Equal (Long)
```

| SRE/SREL | D1 ( | L,BT | , D2 | (82) |  |
|----------|------|------|------|------|--|
|          |      |      |      |      |  |

| C1/D1                      | L                       | B1                | D1         | B2 |               | D2                               |                         |
|----------------------------|-------------------------|-------------------|------------|----|---------------|----------------------------------|-------------------------|
| 0                          | 8                       | 16                | 20         | 32 | 36            | raine aires generates dans verse | 47                      |
| Scan Righ<br>SRNE<br>SRNEL | t Not Equa<br>D1(L,B1), | l (Lo)<br>D2 (B2) | ng)        |    |               |                                  |                         |
| C3/D3                      | I L                     | B1                | D1         | B2 | - <del></del> | D2                               |                         |
| 0                          | 8                       | 16                | 20         | 32 | 36            | ويرين برايان مريب وريان مريب     | 4 7                     |
| Scan Left<br>SLE<br>SLEL   | Egual (Lo<br>D1(L,B1),  | ng)<br>D2 (B2)    | )          |    |               |                                  |                         |
| C0/D0                      | l L                     | в1                | D1         | B2 | 1             | D2                               | allen alain eine eine e |
| 0                          | 8                       | 16                | 2 0<br>2 0 | 32 | 36            |                                  | 47                      |

#### Logical Instructions

SHIFT

| Scan Left | t Not Equ | al (Long) |                                                  |       |                                                            |      |
|-----------|-----------|-----------|--------------------------------------------------|-------|------------------------------------------------------------|------|
| SLNEL     | D1(L,B1   | ),D2(B2)  |                                                  |       |                                                            |      |
| C2/D2     | L         | B1        | D1                                               | B2    | D2                                                         | <br> |
| 0         | 8<br>8    | 16 20     | nya alifa dala jaka kika nya dila dila dia aka d | 32 36 | न्त्राल गुप्ता गुर्मन नाम द्वापन काम स्वाप केला केला काम क | 4 7  |

This instruction uses the low-order byte of the second operand <u>address</u> as a character to scan Operand 1. A scan for equality (xxE) or inequality (xxNE) is performed. If the scan is satisfied, the absolute address of the satisfying character in Operand 1 is placed in register 2 and C2 is set. If it is not, C2 is reset to 0 (C2 is always reset if the length is 0). The scan can be performed from left to right (xRxx) or right to left (xLxx), in which case Operand 1 is addressed by its rightmost byte.

#### 4.10 LOGICAL SHIFT INSTRUCTIONS

Shift Left Logical Immediate SLLI R1, R2 18 | R1 1 R2ı 0 8 12 15 Shift Left Logical SLL R1, R3, D2 (B2) 98 . | R1 | R3 | B2 | D2 0 8 12 16 20 31 Shift Right Logical Immediate SRLI R1, R2 19 | R.1 R2 1 0 8 12 '15
SHIFT

| Shift Rig<br>SRL    | ht Loc<br>R1,R3 | gical<br>B,D2(B | 32)          |              |    |
|---------------------|-----------------|-----------------|--------------|--------------|----|
| 99                  | R1              | R3              | В2           | D2           |    |
| 0                   | 8               | 12              | 16           | 20           | 31 |
| Shift Lef           | t Doul<br>R1,R2 | ole Lo          | ogica:       | l Immediate  |    |
| 1 1A                | R1              | R2              |              |              |    |
| 0                   | 8               | 12 15           | ;            |              |    |
| Shift Lef           | t Doub<br>R1,R3 | ole Lo<br>,D2(E | gica:<br>32) | 1            | 8  |
| 9A                  | R1              | R3              | В2           | D2           | 1  |
| 0                   | 8               | 12              | 16           | 20           | 31 |
| Shift Rigl<br>SRDLI | nt Dou<br>R1,R2 | ble I           | ogica        | al Immediate |    |
| 1 · 1B              | R1              | R2              |              |              |    |
| 0                   | 8               | 12 15           | i            |              |    |
| Shift Rig!<br>SRDL  | nt Dou<br>R1,R3 | ble I<br>,D2(E  | ogica<br>2)  | al .         |    |
| 9B                  | R1              | R3              | B2           | D2           | 1  |
| 0                   | 8               | 12              | 16           | 20           | 31 |

A left or right shift is performed on the register or contiguous pair of registers indicated by R1. The shift count is specifed by bits 12 to 15 of the instruction for the RR formats, or by the low order 5 bits of the Operand 2 <u>address</u> for the RS formats. C2 is set to the last bit shifted out. A Register Specification interrupt can occur on a double shift if R1 specifies register 15.

### Logical Instructions

STACK

4.11 STACK INSTRUCTIONS

PuSH Multiple PSHM R1,R3,D2(B2)

| r<br> | 96 |   | R 1 | -+- | R3 | 1          | B2 | - <del>+</del> -<br> | D2  | <br> |
|-------|----|---|-----|-----|----|------------|----|----------------------|-----|------|
| L     |    | - |     | _ــ |    | _ <b>_</b> |    |                      |     |      |
| 0     |    |   | 8   |     | 12 | 1          | 6  | 2                    | 2 0 | 31   |

PuSH Halfwords PSHH

PSHHL D1(L, B1), D2 (B2)

| <b>r</b> | ufen apus etxes anno attes della dei | - T        | na mu uya data maaqda co |   |     |    | n mitan danka anjang kalana angga danka anjan dalap d |   |    | - T | nia dan dan gan ana ana ana            |    |
|----------|--------------------------------------|------------|--------------------------|---|-----|----|-------------------------------------------------------|---|----|-----|----------------------------------------|----|
| 1        | C6/D6                                | 1          | L                        | 1 | B 1 | 1  | D1                                                    | i | B2 | Ì   | D2                                     | i  |
| L,       |                                      | - <u> </u> |                          |   |     |    | و دورو خده هداو مورو میده دساه دیده د                 |   |    |     | هیک داخله هرین دیده دوره دیده خده اندی |    |
| 0        |                                      | 8          |                          | 1 | 6   | 20 |                                                       |   | 32 | 36  | ,                                      | 47 |

These instruction are used to push data into the stack described by the Stack Descriptor Block (SDB) pointed to by the second operand address. The format of an SDB is:

| L           | hay and a flat over out a second to see a second the over the office states over any second to be a second to b |       |       |
|-------------|-----------------------------------------------------------------------------------------------------------------|-------|-------|
| current top | stack address                                                                                                   | stack | limit |
| L           |                                                                                                                 |       |       |
| 0           | 2                                                                                                               | 4     | 6     |

- current top: This halfword will always point to the top halfword in the stack.
  - stack address: This is the address of the stack itself and controls the amount of popping that can be performed.
  - stack limit: This is the address of the highest halfword that can be used as part of the stack. A pushing limit is thus established and checked.

PSHM causes the registers from R1 to R3 (wrapping from the SFP to the MSR if necessary) to be pushed into the stack and the current top pointer to be updated to point at the top halfword. PSHH/PSHHL pushes the number of bytes specified by the length field (rounded up to the next higher even number if odd) into the stack and leaves the current top pointer pointing at the last halfword pushed. These bytes are treated as a sequence of halfwords and thus must be aligned. It is obvious that the stack top should be initialized to 2 less than the stack address.

Before any pushing is performed, the stack limit is checked to ensure that it will not be exceeded. If it is not, C1 is reset; if it is, C1 is set and a Stack Overflow Interrupt occurs if enabled.

LINKED LIST

| POP Multi<br>POPM | ple<br>R1,R3,D2 | (B2)      |    |                                                         |    |    |                            |      |
|-------------------|-----------------|-----------|----|---------------------------------------------------------|----|----|----------------------------|------|
| 97                | R1 R3           | I B2      | r  | D2                                                      |    |    |                            |      |
| 0                 | 8 12            | 16        | 20 | 31                                                      |    |    |                            |      |
| POP Halfw<br>POPH | ords            |           |    |                                                         |    | u. |                            |      |
| POPHL             | D1(L,B1),       | , D2 (B2) | )  | ×                                                       |    |    |                            |      |
| C7/D7             |                 | B1        |    | D1                                                      | B2 | 1  | D2                         | <br> |
| 0                 | 8               | 16        | 20 | allan dalar allan dara dara dara dara dara dara dara da | 32 | 36 | तान देवादी कारक दागत व्यूक | 4 7  |

POP instructions perform the complement of the pushing ones. The current top is first checked against the stack address to see if enough halfwords exist in the stack to do the pop. If not, C1 is set and a Stack Underflow interrupt occurs if enabled. If it is, C1 is reset and the halfwords are popped into the registers (POPM) or to the first operand address (POPH/POPHL). The current top is then decremented so as to point to the new top of the stack. The Operand 2 address is that of the SDB, as described above. An Alignment interrupt can occur.

### 4.12 LINKED LIST INSTRUCTIONS

SeaRCH

| 0   | ین درون درون درون درون درون |     | 2 series dans dans again dans a | 16      | 20 |            | 32 | 36 | <del></del> | 47 |
|-----|-----------------------------|-----|---------------------------------|---------|----|------------|----|----|-------------|----|
|     | F9                          | 1   | 0                               | I B1    | 1  | D <b>1</b> | B2 |    | D2          |    |
| SRC | СН                          | D 1 | (B1),1                          | D2 (B2) |    |            |    |    |             |    |

This instruction is used to search a table or a linked list for a key which holds some relation to a search argument. The table or linked list is described by an Entry Descriptor Block (EDB) pointed to by the second operand address, in addition to the contents of certain registers. An EDB looks as follows:

For a table

# 1118.25

Logical Instructions

TOCC field ? It I is 9, a Test under Mask is done on the key and search arguments It I is 0, a Compare Logical IV done, COC is & mask for the condition code,

LINKED LIST

| 5  |       |        |   | illi anto illin atto dato a | un ann ann affa ann am at |   |                                |                                           |       |     |
|----|-------|--------|---|-----------------------------|---------------------------|---|--------------------------------|-------------------------------------------|-------|-----|
| 1  | entry | length | 1 | key                         | disp.                     | 1 | key                            | length                                    | 10/TC | CCI |
| L. |       |        |   |                             |                           |   | د.<br>بله جداله هذا المداد مدا | ر.<br>محمد محمد مواد معد محمد محمد محمد ا |       |     |
| (  | )     |        | 2 |                             |                           | 4 |                                |                                           | 6     | 7   |

For a linked list

| <b>-</b> |         |       |   | alan dala dalar sustan |       |     |     |                                     |      |     |
|----------|---------|-------|---|------------------------|-------|-----|-----|-------------------------------------|------|-----|
|          | pointer | disp. | i | key                    | disp. | I   | key | length                              | 1/TC | cci |
| 0        |         | _     | 2 |                        |       | . 4 |     | an dan sida sida ana aga din siya a | 6    | 7   |

entry length: This is the length in bytes of each entry in the table.

- pointer disp.: This gives the offset in bytes of a halfword containing the relative address of the next entry in the linked list, called the "forward pointer". The address is relative to the area base as described below.
- key disp.: This is the offset in bytes to the key in an entry.
- key length: This is the length in bytes of the key in an entry and of the search argument.

The information in the EDB will most likely remain constant throughout the program. The search argument is pointed to by the first operand address and has a length equal to the key length. Registers 2 through 5 must be initialized prior to issuing a SRCH, as follows:

- register 2: This register contains the relative address of the first entry to be searched. For a table it merely points to some entry, while for a linked list it must point to the forward pointer in the predecessor of the first entry to be searched. In order to start searching at the first entry, therefore, a "dummy pointer" to it must be available.
- register 3: This contains a count of the number of entries to be searched and will be decremented by 1 after each entry checked unsuccessfully A 0 count causes the instruction to be ignored except for setting C1 as described below.
- register 4: This is the area base address. It is added to all addresses pertaining to the table or linked list, including the initial entry address (in register 2) and all forward pointers. This allows relocatable linked lists (useful in computer graphics), or, if set to 0, absolute addressing.
- register 5: When the search is completed, register 5 will be set to the relative address of the last entry searched, while register 2 will have been updated to contain the relative address of the previous entry. There are two exceptions to this, the first being

Logical Instructions

#### LINKED LIST

when the initial count in register 3 is 0 or the forward pointer in the initial entry for a linked list is null (0), in which case both registers 2 and 5 will point to the initial entry. The other exception if for tables when the count is exhausted; register 2 will point to the last entry and register 5 to the first byte following the table.

If the search was successful, C2 will be set. Otherwise, C1 will be set if the entry count in register 3 was decremented to or initially 0, or C0 if a null forward pointer (0) was encountered in a linked list. For key lengths of 0, or for arguments of all 0's on a TM SRCH, a successful match occurs on the first entry if the criterion specifies equal or 0's; the search is unsuccessful otherwise. An Alignment interrupt can occur.

NOTE: SRCH can be used to perform a PL/I-like INDEX or an LSD-like FIND.

ENQueue

| ENQ | D | 1(B1), | D2 (E | 32) |    |                                           |  |    |    |                                      |
|-----|---|--------|-------|-----|----|-------------------------------------------|--|----|----|--------------------------------------|
| F   | 8 | 0      |       | B1  | 1  | D1                                        |  | в2 | 1  | D2                                   |
| 0   | 8 |        | 1     | 6   | 20 | a alla ann ann stàrr alla ann ann ann ann |  | 12 | 36 | o adreants and app adrease the one a |

The first operand address plus the area base address in register 4 points to a new entry, which is be inserted into the linked list described by the EDB at the second operand address. The area base plus the relative address in register 2 gives the address of the forward pointer in the entry which is to become the predecessor of the new inserted entry. Note that SRCH sets up register 2 so that an ENQ or DEQ can be executed immediately. An Alignment interrupt can occur.

DEQueue DEQ R1,D2 (X2,B2) 48 | R1 | X2 | B2 | D2 0 8 12 16 20 31

The second operand address points to an EDB describing a linked list from which an entry is to be removed. The contents of register 4 (the area base address) plus the relative address in register 2 give the address of some entry's forward pointer; the next entry is removed from the list and CO is reset. In case this forward pointer is null, no Logical Instructions

LINKED LIST

dequeueing is performed and CO is set. An Alignment interrupt can occur.

5 BRANCHING INSTRUCTIONS

No RR format branching instructions cause a branch if R2 specifies register 0.

Test and Branch Positive Register TBPR R1,R2

| 1 | 29 | 1 | R 1 | I | R2 | 1     |  |
|---|----|---|-----|---|----|-------|--|
| L |    |   |     |   |    | اليب. |  |
| 0 |    | 1 | 8   | 1 | 12 | 15    |  |

Test and Branch Positive TBP R1,D2(X2)

| r |    |   |     | T        |    | -T |                                                               | 1  |
|---|----|---|-----|----------|----|----|---------------------------------------------------------------|----|
| 1 | A9 | 1 | R 1 | 1        | Х2 | 1  | D 2                                                           | 1  |
|   |    |   |     | <u> </u> |    |    | م منها معنه جمع عند الله موجه ماده مده ماده موده موجه معنه مع | J  |
| 0 |    |   | 3   |          | 12 | 10 | <b>b</b>                                                      | 31 |

Test and Branch Not Positive Register TBNPR R1,R2

| r |    |   |     | T         |    | 7   |
|---|----|---|-----|-----------|----|-----|
| 1 | 2E | 1 | R 1 | 1         | R2 | 2 1 |
| L |    |   |     | <b></b> _ |    |     |
| 0 |    |   | B   | 1         | 12 | 15  |

| Tes<br>TBN | t and<br>P | Branch<br>R1,D2 | n Not<br>2(X2) | Positive |    |
|------------|------------|-----------------|----------------|----------|----|
| 1          | AE         | R1              | X2             | D2       |    |
| 0          |            | 8               | 12 -           | 16       | 31 |

Test and Branch Zero Register TBZR R1,R2

| 1 | 21 | 1 | R 1 | 1 | ŔŻ | 2  |
|---|----|---|-----|---|----|----|
| L |    |   |     |   |    | ]  |
| 0 |    | 1 | 8   |   | 12 | 15 |

Test and Branch Zero R1, D2 (X2) TBZ D2 | R1 | X2 | AA 1 31 0 8 12 16 Test and Branch Not Zero Register TBNZR R1, R2 | R1 | R2 2D 12 15 8 0 Test and Branch Not Zero TBNZ R1, D2 (X2) | R1 | X2 D2 AD 8 12 16 31 0 Test and Branch Minus Register R1, R2 TBMR | R1 | R2 2C 12 15 8 0 Test and Branch Minus TBM R1, D2 (X2) D2 AC | R1 | X2 | 1 12 31 16 0 8 Test and Branch Not Minus Register TBNMR R1, R2 2B R1 R2 12 15 0 8 Test and Branch Not Minus R1, D2 (X2) TBNM R1 X2 D2 AB 31 8 12 16 0

address in

A branch is taken to the contents of R2 (RR format) or to the second operand address (BX form) if the condition of R1 is as specified by the instruction.

| Branch<br>BCZR | Conditio<br>R1,R | ons Zei<br>2     | co R | egister |      |
|----------------|------------------|------------------|------|---------|------|
| 26             | 1 R1             | R2               |      |         |      |
| 0              | 8                | 12 15            |      |         |      |
| Branch<br>BCZ  | Conditio<br>R1,D | ons Zei<br>2(X2) | ro   |         |      |
| A6             | R 1              | X2               |      | D2      |      |
| 0              | 8                | 12               | 16   |         | 31 ` |
| Branch<br>BCOR | Conditi<br>R1,R  | on One<br>2      | Reg  | ister   |      |
| 27             | R1               | R2               |      |         |      |
| 0              | 8                | 12 15            |      |         |      |
|                |                  |                  |      |         |      |

Branch Condition One BCO R1, D2(X2)

| F | eo espo tatto está está es | - | to ens allh-s |   | - 110 - 110 | the state of the s |    |     |
|---|----------------------------|---|---------------|---|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
| 1 | A7                         | 1 | R 1           | 1 | X2          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | D2 | i i |
| L |                            |   |               | 1 |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |     |
| 0 |                            | 1 | 8             |   | 12          | 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    | 31  |
|   |                            |   |               |   |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |     |

The R1 field is used as a mask to select any of the Condition Code bits or bit 3 in the MSR. If all selected bits are 0 for a BCZ(R), or if 1 or more are 1 for BCO(R), then a branch is taken to the contents of R2 (RR form), or to the second operand address (BX). Otherwise no branch is taken. If  $R1_{2}O_{2}$  then the branch is always taken.

Branch and Link Register BALR R1,R2

|   | 28 | 1 | R 1 | 1 | R2 | 2  |
|---|----|---|-----|---|----|----|
| 0 |    | 1 | 8   | 1 | 2  | 15 |

2,10,76

Branching Instructions

| Bra<br>BAI | anch<br>L                                    | and | Lin<br>R <b>1,</b> E | nk<br>2 (X2) | )  |    |    |
|------------|----------------------------------------------|-----|----------------------|--------------|----|----|----|
| r          | A8                                           |     | _R 1                 | X.2          | 1  | D2 |    |
| 0          | 14 Al an |     | 8                    | 12           | 16 |    | 31 |

The branch address (contents of R2 for RR form or second operand address for BY form) is computed and saved. The PC is then copied into R1 and a branch is taken to the saved address.

Branch on CounT Register BCTR R1,R2

| [<br>[ | 2F | 1 | R <b>1</b> | <br>R2 | 2 | 1 |
|--------|----|---|------------|--------|---|---|
| L      |    |   | ~          | <br>   | - | L |
| 0      |    | 1 | в          | 12     | 1 | 5 |

| Bra<br>BCI | nch | on                      | Cour<br>R1,I | η <u>π</u><br>22 | (12) |    |                                                          |    |
|------------|-----|-------------------------|--------------|------------------|------|----|----------------------------------------------------------|----|
|            | AF  | 1                       | R 1          | 1                | ¥2   | 1  | D2                                                       |    |
| 0          |     | anto essas esses divisi | 8            |                  | 1 2  | 16 | nine anna dinis anna dinis anna arta signi faire anna an | 31 |

R1 is decremented by 1, and if the result is positive, a branch is taken to the contents of R2 (RR form) or to the second operand address (BX). If the result is minus or 0, no branch is taken.

| Branc<br>BXH  | h on                | R1,D2          | Y High<br>2(X2) | 1  |                                                      |                       |
|---------------|---------------------|----------------|-----------------|----|------------------------------------------------------|-----------------------|
| A             | 0                   | R1             | X2              |    | D2                                                   | u tao isa ang tao dia |
| 0             |                     | 8              | 12 ,            | 16 | nna éidir ainn man gga ann ann an                    | 31                    |
| Branc<br>BXLE | h on                | inde:<br>R1,D: | X Low<br>2(X2)  | or | Equal                                                |                       |
| A             | 1                   | R1             | X2              |    | D2                                                   | 1                     |
| L             | -950 4000 4000 4000 |                |                 |    | وه مادهه هيچه جروبه ماده هيد واري قولي جروبه هيده دو |                       |

The contents of X2 is added algebraically to R1 and the result is compared algebraically to the <u>previous</u> contents of X2 (if it is an odd-numbered register) or to the contents of the next higher register (if X2 is even-numbered). A branch is taken to the second operand address if R1 is greater than the compare register (BXH) or if it is less than or equal to it (BXLE). Otherwise no branch is taken.

# EXecute EX R1,D2(X2,B2) 54 R1 X2 B2 D2 0 8 12 16 20 31

This instruction causes execution of the single instruction at the second operand address. The contents of R1 is temporarily ORed with the first halfword of this subject instruction before it is executed, unless R1 specifies register 0. Control is eventually returned to the instruction following the EX, unless the subject instruction modifies the PC. An Alignment interrupt can occur. Any Program interrupts that can occur for the executed instruction are possible. I/O and S/360 Initial Select interrupts cannot occur between and EX and its executed instruction. An Execute interrupt occurs if the subject of an EX instruction is another EX.

#### 6 STATUS-SWITCHING INSTRUCTIONS

| SVC          | erViso                            | r Call<br>I1      |                      |               |     |          |    |    |
|--------------|-----------------------------------|-------------------|----------------------|---------------|-----|----------|----|----|
| r            | 31                                | i I1              |                      |               |     |          |    |    |
| 0            | 999 - 200 - 200 - 200 - 200 - 200 | 8                 | 15                   |               |     |          |    |    |
| Supe<br>SVC: | erViso<br>S                       | or Call<br>D1(B1) | Single-r<br>,I2      | egister       |     |          |    |    |
| [            | 81                                | I 12              | i B1                 | T             | D 1 | <b>–</b> |    |    |
| 0            |                                   | 8                 | 16                   | 20            | 3   | 1        |    |    |
| Supe<br>SVC: | erVisc<br>D                       | DT Call<br>D1(B1) | Double-r<br>,D2(B2), | egister<br>I3 |     |          |    |    |
| 1            | F 1                               | I I3              | f B1                 | +<br>!        | D1  | B2       | D2 | 1  |
| 0            |                                   | 8                 | 16                   | 20            |     | 32 3     | 6  | 47 |

This instruction causes a Supervisor Call (SVC) interrupt using the second byte of the instruction as the interrupt code. Before causing the interrupt, SVCS loads the first operand address into register 2. SVCD does this also, plus loads register 3 with the second operand address.

Test and Set Lock TSL D1(B1),I2

| г<br>1  | 87 | T     | т2 | ī        | B | 1 | r<br>1 | <u></u> 1 | a dina dina qui |   |
|---------|----|-------|----|----------|---|---|--------|-----------|-----------------|---|
| 1.<br>L |    | !<br> |    | <u>.</u> |   | d | Lannen |           |                 |   |
| 0       |    | 8     |    | 1        | 6 |   | 20     |           | 31              | L |

The bits of the first operand byte selected by the second operand mask are tested, and the Condition Code is set as for the TM instructions. If the test indicates 0's, the mask is ORed into the first operand. Memory accessing by local I/O units is prevented between testing and modification.

|                     | ENTer subr<br>ENT                                    | R15,              | ne<br>R <b>1</b> F,I2               | 2                                                |                                 |                                 |                              |                     |                           |                             |                           |                          |          |
|---------------------|------------------------------------------------------|-------------------|-------------------------------------|--------------------------------------------------|---------------------------------|---------------------------------|------------------------------|---------------------|---------------------------|-----------------------------|---------------------------|--------------------------|----------|
|                     | BE                                                   | R1S               | R1F                                 |                                                  | 12                              |                                 |                              |                     |                           |                             |                           |                          |          |
|                     | 0                                                    | 8                 | 12                                  | 16                                               |                                 |                                 | 31                           |                     |                           |                             |                           |                          |          |
|                     | This instr<br>allocation<br>a subrouti<br>"Stack Fra | n. I<br>ine ame", | on cau<br>t is o<br>nd as:<br>which | uses say<br>generally<br>sumes that<br>h must be | ve ar<br>y exe<br>at th<br>e on | cea c<br>ecute<br>ne SF<br>a ha | hain<br>d as<br>P (r<br>lfwo | ing<br>the<br>regis | and<br>fir<br>ter<br>ound | auto<br>sti<br>15)<br>lary: | matic<br>nstruc<br>point: | stora<br>ction<br>s intc | of<br>of |
|                     | SFP>                                                 | > pre             | vious                               | pointer                                          | 1                               |                                 |                              |                     |                           |                             |                           |                          |          |
|                     |                                                      | l n               | ext p                               | ointer                                           | 1                               |                                 |                              |                     |                           |                             |                           |                          |          |
| SEE<br>GMS<br>Manua | j.                                                   |                   | call<br>save :                      | er's<br>area                                     | 4<br> <br> <br> <br> <br>       |                                 |                              | `                   |                           |                             |                           |                          |          |
| ¥                   | -                                                    | i<br>1<br>1       | calla<br>autom<br>stor              | er's<br>atic<br>age                              | <br> <br> <br>                  |                                 |                              |                     |                           |                             |                           |                          |          |
|                     |                                                      | <br> <br>         | len                                 | gth                                              | -<br>-<br>                      |                                 |                              |                     |                           |                             |                           |                          |          |

11.18.75

The immediate halfword operand specifies the number of bytes of automatic storage desired. This number (rounded to the next higher halfword, if necessary) plus 30 bytes for a register save area plus 4 bytes for the new pointers is compared against the length, which specifies the remaining space in the Frame (including itself). If not enough space exists, a Stack Frame Overflow interrupt occurs. If there is space, it is allocated to the subroutine, and a new, updated length field is built below it. The caller's MSR through register 14 are saved in the save area in his storage (with the PC set equal to register 14. the return address), The old length field is replaced by the contents of the SFP (a previous pointer), the halfword following the length is set to point at the newly built length field (a next pointer), and finally the SFP is updated to point to the new save area:



An Alignment interrupt can occur.

RETurn from subroutine RET R1,R2

0 8 12 15

RET is executed to return from a subroutine and to free the save area and automatic storage gotten by ENT. It first checks to see if the back pointer (the SFP is assumed to be left as set up by ENT) points to a save area which points forward to the current one. If not, a Stack Frame Underflow interrupt occurs. If so, registers 2 through 13 are reloaded from the current save area, the old length and 0 fields are rebuilt at the top of it (so as to free it), the SFP is backed up to the previous save area, and a branch is taken to the new contents of register 13, the return address. An Alignment interrupt can occur.

#### 7 INTERRUPTS

There are four types of interrupts on the META 4A: SuperVisor Call (SVC), Program, I/O, and S/36O. When an interrupt is detected, and if it is not disabled by the MSR or I/O Mask, the following sequence occurs:

- 1) The current MSR and PC are stored in 2 halfwords in low core (see table below), and an interrupt code is generated and stored. If the interrupt is an SVC or Program check, the ILC field in the stored MSR will contain the length, in halfwords, of the instruction causing the interrupt.
- 2) A new MSR and PC are loaded from 2 other halfwords in low core.
- 3) Execution continues with this new machine status.

The low core locations reserved for these MSR's, PC's, and interrupt codes are as follows:

#### address contents

| 4                          | SVC                             | old                       | MSR                            |            |
|----------------------------|---------------------------------|---------------------------|--------------------------------|------------|
| 6                          | SVC                             | old                       | PC                             |            |
| 8                          | SVC                             | inte                      | rrup                           | t code     |
| Α                          | SVC                             | new                       | MSR                            |            |
| С                          | SVC                             | new                       | PC                             |            |
|                            |                                 |                           |                                |            |
| E                          | Prog                            | ram                       | old                            | MSR        |
| 10                         | Prog                            | Fram                      | old                            | PC         |
| 12                         | Prog                            | ram                       | inte                           | rrupt code |
| 14                         | Prog                            | ram                       | new                            | MSR        |
| 16                         | Prog                            | ram                       | new                            | PC         |
| 18<br>1A<br>1C<br>1E<br>20 | I/0<br>I/0<br>I/0<br>I/0<br>I/0 | old<br>old<br>inte<br>new | MSR<br>PC<br>rrup<br>MSR<br>PC | ot code    |
| <u> </u>                   | 5/36                            | 0 01                      | a MS                           | R          |
| 24                         | 5/36                            | 50 01                     |                                | •          |
| 26                         | 5/36                            | 50 in                     | torr                           | unt code   |
| 28                         | 5/36                            | 0 no                      |                                | ape code   |
| 20                         | 0/00                            | $\frac{1}{2}$             |                                |            |
| ZA                         | 3/30                            | o ne                      | W PC                           |            |

The SVC interrupt code is determined by the second byte of the SVC instruction that caused the interrupt. Program interrupt codes are determined by the type of Program interrupt, as follows:

- Operation (2): An instruction with an invalid operation code was encountered. When this occurs, various information is stored in low core before the interrupt occurs. See Appendix I for a description of this information.
- Stack Frame Overflow (4): On an ENT instruction, no room existed in the stack frame for the registers and the requested automatic storage.

Stack Frame Underflow (6): On a RET instruction, the previous save area was not in the same stack frame as the current one.

- Arithmetic Overflow (8): Overflow occurred on an arithmetic instruction and was not masked out by the MSR. The resulting value was not stored.
- Conversion Overflow (A): On a CVB instruction, the resulting number required more than 16 bits and the interrupt was not masked out in the MSR. The resulting binary number was not loaded into R1.

Division by 0 (C): An attempt was made to divide by 0. Alignment (E): A halfword was not located on a even byte

- Alignment (E): A halfword was not located on a even byte boundary where required.
- Register Specification (10): Register 15 was specified in some double register operation.
- Privilege (12): An I/O instruction was attempted with the privilege bit in the MSR off. See Section 8.
- Stack Overflow (14): On a PSHM or PSHH/PSHHL, there was not enough room in the stack for the requested data, and the interrupt was not masked out in the MSR.
- Stack Underflow (16): On a POPM or POPH/POPHL, there was not enough data in the stack to fill the pop request, and the interrupt was not masked out in the MSR.
- Execute (18): The subject of an EX instruction was another EX. This situation cannot be handled by the firmware.
- Invalid Unit Address (1A): Some error was detected in the unit address portion of an IOCC. See Section 8.
- Invalid UCB Address (1C): The UCB address in the UCBT for the unit specified in an IOCC, or for the S/360, was 0 or odd. See Section 8.

I/O and S/360 interrupts are described in more detail in the next Section.

#### 8 INPUT/OUPUT OPERATIONS

#### 8.1 I/O UNITS

The META 4A can communicate with various external I/O units. These units consist of some number of local I/O units and the S/360.

#### 8.1.1 LOCAL UNITS

The local I/O units which can be operated by the META 4A include a Disk, Card Reader, Keyboard/Typewriter, Control Panel, and META 4B (the graphics processor of BUGS). Up to a total of 11 local units can be supported by the firmware. The instructions used to perform I/O with these are SIOP and SIO.

#### 8.1.2 THE S/360

The META 4A can also communicate with an IBM S/360. The S/360 regards the META 4A as a standard unit, performing I/O with it via a Multiplexor Channel and the standard IBM S/360 Interface. The instructions offered by the firmware to support S/360 communication are SS, TRB, OST, IST, and EXCC.

#### 8.2 CONTROL OF LOCAL UNITS

#### 8.2.1 UNIT INFORMATION

An I/O unit is designated by an I/O address. This address is a 5-bit binary number ranging from x0000 through x1010 (the first bit is ignored; 0 will be assumed here). Associated with each unit is a Unit Control Block (UCB). This storage block can contain all the information necessary to operate the unit, its status, I/O request queue, etc. Its format as regarded by the firmware is as follows:

| 0 | 0000000000000xaddr |
|---|--------------------|
| 2 | USH                |
| 4 | variable           |
|   | 1                  |

The UCBs, because of their varying number and length, are not located in fixed memory locations. Instead, there exists the Unit Control Block Table (UCBT), which contains 12 pointers to UCBs. The first pointer corresponds to unit 00000, the second to unit 00001, etc. (hence, twice a unit's address is the UCBT offset of its UCB pointer), while the twelfth pointer is for the S/360 UCB. The UCBT occupies core locations 30 through 47. The only common UCB entries are the unit address and the Unit Status Halfword (USH). This halfword contains flags describing the current operating status of the associated unit (e.g., offline, busy, I/O error, etc.). The exact bit meanings will be described with each unit.

#### 8.2.2 STARTING I/O

| SIO    | R  | R1, R2 |     |   |    |    |  |
|--------|----|--------|-----|---|----|----|--|
| [<br>[ | 16 |        | R 1 | 1 | R2 | 2  |  |
| 0      |    | 1      | 8   |   | 12 | 15 |  |

Start I/O P1 D2/Y2 B2

STO

| 510 |                                     |   |     | 12       | (   | , D | 21 |     |                                      |    |
|-----|-------------------------------------|---|-----|----------|-----|-----|----|-----|--------------------------------------|----|
| [   | 56                                  | ļ | R 1 | l        | ¥.2 | 1   | В2 | 1   | D 2                                  |    |
| 0   | 9 <del>4929 4349 4349 6380</del> 63 |   | 8   | an align | 1 2 |     | 16 | 2 0 | an dabin soon shine (n'ny pana anin' | 31 |

These instructions cause I/O to be initiated at a specified unit. In order to specify the type of I/O, a 2-halfword I/O Control Command (IOCC) is required. Operand 2 of SIO is

this IOCC, while, for SIOR, the first halfword is in R1, and the second in R2. An IOCC has the following format:

| <br>address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | xaddr   | ор        | mod       |              |          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------|-----------|--------------|----------|
| <br>and the set of the second set of the second set of the second sec | 16      | 21        | 2931      |              |          |
| address: T                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | he use  | of this   | field v   | aries from   | IOCC to  |
| IOCC.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | It norm | ally spe  | ecifies a | memory add   | fress or |
| is unus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ed.     |           |           |              |          |
| xaddr: This                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | is the  | 5-bit un  | nit addre | ss of the :  | I/O unit |
| on whic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | h the   | I/O is to | o be per  | formed. If   | the UCB  |
| pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | in the  | UCBT for  | r this un | nit is 0 or  | odd, an  |
| Invalid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | UCB Ad  | dress Pro | ogram int | errupt will  | l occur. |
| Further                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | more,   | if no     | unit wi   | th the sp    | pecified |
| address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | is in   | stalled,  | or if t   | he unit add  | dress in |
| the cor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | respond | ing UCB   | does not  | : match, an  | Invalid  |
| Unit Ad                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | dress i | nterrupt  | will oc   | cur, with    | the unit |
| address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | in e    | rror bei  | ng store  | ed in core 1 | location |
| 50.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |           |           |              |          |
| op: this                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 8-bit   | code sp   | ecifies   | the type     | of I/O   |
| operati                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | on to b | e perfor  | med.      |              |          |
| mode thig                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | nontio  | n of th   | TOCC P    | be pobiword  | ditional |

mod: this portion of the IOCC provides additional information for the unit and operation specified.

Once an IOCC is initiated, a new USH is automatically sensed and stored in the UCB. In addition, a bit is set in the Condition Code (the others being reset) as follows:

- CO- Busy or Offline. The unit was found to be in Busy status or offline at the time of IOCC initiation.
- C1- Unit Operating. An I/O operation was begun which will, upon completion at a later time, produce an I/O interrupt. The new USH will indicate Busy.
- C2- Immediate Operation Complete. The operation performed completed immediately. The unit can now respond to another SIO(R).

An Alignment interrupt can occur on an SIO(R) for the following reasons:

- The IOCC was not on a halfword boundary. This can only occur for SIO.
- The address portion of the IOCC is to be used as a memory address, but is not on a halfword boundary.

A Privilege interrupt can also occur for both formats if the Privilege bit is not on; this prevents user programs from "accidentally" performing I/O.

### 8.3 I/O INTERRUPTS

At the completion of an interrupting I/O operation, for which C1 was set at SIO(R), or upon an externally caused interrupt, the operating unit requests an I/O interrupt. At this time, the META 4A performs the following functions:

- Checks the I/O interrupt bit in the MSR. If off, the interrupt is kept pending until such time as the bit is set on.
- 2) Next checks the I/O Mask in location 2E. There exists one bit for each of the 11 possible I/O units, the unit address being the bit position. If the bit for the interrupting unit is off, the interrupt is again kept pending until such time as the mask bit is set on.
- 3) If the interrupt can be allowed, an I/O interrupt occurs with the interrupt code equal to the unit address (see Section 7). A new USH is stored in the UCB, unless the UCB address in the UCBT is odd or 0, in which case the USH is ignored <u>and</u> bit 0 of the I/O interrupt code is set on. Finally, the unit interrupt request is reset.

If two or more units compete for an interrupt at the same time, they are taken in priority order by ascending unit address.

#### 8.4 I/O TO THE S/360

#### 8.4.1 GENERAL INFORMATION

Viewed from either the META 4A or the S/360, I/O to the other processor differs from I/O to other units in several respects. While most I/O consists of a program issuing a particular set of unit with commands to a characteristics, S/360 I/O consists of a program in one processor communicating with another program in the other. Since this communication takes place over a S/360 channel, it is relatively simple and allows high data rates. However, it is also rigidly defined by the channel hardware, and deviations from the established protocol can have dire consequences for other devices sharing the channel and for CP. For this reason, before I/O between the S/360 and the META 4A is attempted, the descriptions of I/O in the System/360 Principles of Operation manual should be thoroughly understood.

The META 4A is connected to the S/360 Multiplexor channel through an interface housed within BUGS. In the interface are the logic circuits necessary for address recognition, automatic propagation of Select Out, and command byte and status transfer. Two 16-bit registers in the interface reflect the current state of the tag and bus lines from the channel, along with certain other status flags. Although these registers can be directly controlled (via the IST and OST instructions), there will rarely be any need to do so.

### 8.4.2 S/360 INTERFACE ADDRESSES

The S/360 interface will respond to initial selections directed to any device address in the range 050 to 05F. However, only the first four of these (050 to 053) are treated as valid by the META4A, and I/O to an address higher than 053 should never be attempted. The four valid device addresses correspond to META 4A unit addresses 01011 through 01110, but these unit addresses are effectively ignored, and the device address is specified in the S/360 I/O instruction by the low order digit of the S/360 address (i.e., 0 to 3).

#### 8.4.3 S/360 UCB FORMAT

Each of the S/360 UCBs has the following format:



Last Data address: The address of the last data byte read or written by an EXCC instruction.

Residual Count: The count remaining if the EXCC instruction was prematurely terminated.

Sense Bytes 0-5: 6 sense bytes. (The firmware only references the first of these. The rest are software defined.)

Initial Status Table: There is one initial status byte for every possible command which can be received from the S/360. Note that the first byte i the

table (for a commad byte of 0) is not used. A 0 command (Test I/O) will cause the curret status byte to be sent as initial status.

#### 8.4.4 FIRMWARE OPERATIONS

There are 3 basic functions which must be performed in handling the S/360 interface: initial status presentation, data transfer, and ending status presentation. These are now described:

### 8.4.4.1 Initial Status Presentation

When an Initial Selection occurs, the firmware examines the command byte, the UCB table, the UCB, and the MSR to determine what initial status should be sent to the S/360. The following situations can occur:

- Test I/O and valid UCB pointer: The current status bye is used as initial status and then reset to O (except possible for busy). Since no interrupt is generated, the state of the initial Select bit in the MSR is ignored.
- Test I/O and invalid UCB address: An initial status of busy is sent.

Non-zero command and Initial Select disabled: initial status of Busy is sent.

Non-zero command and initial selection enabled: The UCB pointer for the appropriate device is checked. If it is valid (even and non-zero), the current status field is checked. If the current status field is non-zero, it is ORed with busy, sent as initial status, and then reset. If the current status field is 0, then initial status byte for the command is found in the initial status table and sent. The command byte is then stored in the UCB and a S/36C interrupt occurs, the interrupt code being the device address with bit 2 on.If the UCB pointer for the device is found to be invalid, unit exception is sent as initial status, and the device address with bit 0 on serves as the interrupt code.

#### Input/Output

### 8.4.4.2 Data Transfer

Once the software has been given an Initial Select interrupt, it must examine the device address and command fields of the UCB to determine what action to take. For operations involving data transfer between the META 4A and the S/360, a choice can be made between proceeding in "burst mode" or in "byte mode". In the first case, control is returned to the firmware via an EXecute Channel Command (EXCC) instruction. The firmware then retrieves a data address and count from the UCB and proceeds with the data transfer as indicated by the command byte which was previously stored in the UCB. On termination of the command, the condition code is set appropriately (see description of EXCC below), and the program is continued.

In byte mode, the software explicitly requests each data byte transfer. using the TRansfer Byte (TRB) instruction. While slower than the use of EXCC, this allows more flexibility in the placement of data in META 4A memory, for example.

# 8.4.4.3 Ending Status Presentation

At the termination of data transfer (due either to the count from the UCB reaching 0 or to Interface Stop), ending status must be sent to the channel with the Send Status (SS) instruction. Normal ending status consists of Channel End and Device End. Unusual conditions encountered during data transfer (such as Bus-Out Check) are indicated by ORing the appropriate bits in the status byte.

### 8.4.4.4 System or Selective Reset

If the S/360 performs a System or Selective Reset, a S/360 interrupt will unconditionally occur with an interrupt code of 2. Whatever instruction was executing on the META 4A at this time is <u>aborted</u>, thus this is an irrecoverable condition.

#### 8.4.5 S/360 INSTRUCTIONS

Input/Output S or T register IOST R1, R2

|   | 20 | I R1 | I R2       |    |
|---|----|------|------------|----|
| Ĺ |    |      | _ <u>i</u> |    |
| 0 |    | 8    | 12         | 15 |

This instruction is used for direct control of the interface S and T registers. The R1 field refers to the META 4A register which is to be snet to or loaded from the interface. The R2 field contains the operation to be performed, as follows:

0: The contents of S are placed into R1. 1: The contents of R1 are loaded into S. 2: The contents of T are placed into R1.

3: The contents of R1 are loaded into T.

Bits 12 and 13 of the R2 field are ignored.

EXecute Channel Command EXCC R1,R2

| 1 | 22 | 1 | R 1 | i | R  | 2 1 |
|---|----|---|-----|---|----|-----|
| L |    |   |     |   |    |     |
| 0 |    | 1 | 8   | 1 | 12 | 15  |

This instruction is used to perform block data transfers to and from the S/360. The address and length of this data are found in the S/360 UCB, for the device whose address is in the R1 field. Bit 7 of the Command byte determine the direction of data transfer: 1 means from the S/360, 0 means to it. If a Bus-Out Check is encountered during transfer, transfer is stopped and the error is recorded in bit 2 of Sense Byte 0 and in bit 6 (Unit Check) of the Current Status (Cur Stat). Transfer is also halted if Stop or Halt I/O is received from the channel. In whatever manner transfer is completed, the Final Data Address will be set to the address of the last byte transferred plus 1, while the Residual Count is set to the number of bytes remaining to be transferred. The Condition Code will be set as follows:

C0 - Transfer successful or Bus-Out Check. C1 - Stop received. C2 - Halt I/O received.

Privilege and Invalid UCB Address interrupts can occur.

| TRA<br>TRI | ansfer<br>B | By | yte<br>R1,I | 2 | (X2) | <b>,</b> B | 2) | •  |                                 |    |
|------------|-------------|----|-------------|---|------|------------|----|----|---------------------------------|----|
|            | 62          | 1  | R 1         | 1 | X2   | I          | В2 | 1  | D 2                             |    |
| 0          |             | ŧ  | 3           |   | 12   |            | 16 | 20 | a anna anna anta atta anna anna | 31 |

This instruction operates exactly as EXCC except that the Data Count is assumed to be 1 and the byte to be transferred is found at the Operand 2 address. Because only 1 byte is transferred, the Final Data Address and Residual Count fields are not modified. Invalid UCB Address and Privilege interrupts can occur.

Send Status

SS R1, D2 (X2, B2)

| L | واللو جمعت حصب مسترد متقا |   |           | - |    | - |    |           |                                              |    |
|---|---------------------------|---|-----------|---|----|---|----|-----------|----------------------------------------------|----|
| 1 | 55                        | 1 | R 1       | Ì | X2 | i | B2 | i         | D2                                           | i  |
| L | ann ann ann ann ann       | - | ~ ~ ~ ~ ~ |   |    |   | -  | _ <u></u> | والمراجع والمراجع والمراجع والمراجع والمراجع |    |
| 0 |                           | 8 | 3         | 1 | 12 |   | 16 | 20        |                                              | 31 |

This instruction causes a status byte to be sent from the device specified by the B1 field to the S/360. The status byte is either the low order byte of the second operand <u>address</u> or the current status field of the UCB. If the second operand address is non-zero, it is taken as the status byte, and the status is considered to be asynchronous (e.g., suppressable). If the address is 0, the current status field is examined. If this is also zero, CO is set and nothing more is done. If the current status is non-zero, it is sent to the S/360. In either case, if status field of the UCB and C2 is set. (The program can then either try to re-issue the SS instruction or assume that the channel will eventually request the stacked status.) The Condition Code is set as follows:

C0 - Status accepted. C1 - Status was suppressed or stacked. C2 - Halt I/O received.

Privilege and Invalid UCB Address Program Interrupts can occur.

9 LOCAL I/O UNIT DESCRIPTIONS

### 9.1 3461 CARD READER (UNIT ADDRESS 00100)

OBSOLETE

#### 9.1.1 DESCRIPTION

The D.S.C. Model 3461 Card Reader provides punched card input for the META 4A processor. It is rated at a maximum throughput of 300 cards per minute, reading serially column by column. The 3461 reads cards in Hollerith image only; no code translation is provided by it or the firmware. A column image is stored in bits 0 through 11 of a halfword; bits 12 through 15 are set to 0.

### 9.1.2 I/O CONTROL COMMANDS

The 3461 is addressed by the 5-bit unit address 0010°. It utilizes a single IOCC wich is an Initiate Read, to start up a card read cycle:

Initiate Read IOCC (X'2620')

|   | buffer | address | 00 10 | 0111000 | 0100/// |
|---|--------|---------|-------|---------|---------|
| C | )      |         | 16    | 21      | 2931    |

The address portion of the IOCC specifies the halfword memory address of the read buffer. The first halfword of the buffer designates the number of columns to be read. This count ("n" in the diagram below) is located in bit positions 9 through 15 and should never exceed 80 (information in succeeding memory locations will be destroyed). The halfwords following the count will receive the column data.

Buffer



Once the card reading operation is complete, the 3461 will request an Operation Complete I/O interrupt.

# 9.1.3 USH FORMAT

The format of the USH for the 3461 and the meanings of the bits are as follows:

| 111 | I// EC    | LCIOC1//1//////////// B 10B                                                                                                                                                |
|-----|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | LL<br>1 2 |                                                                                                                                                                            |
|     | EC:       | Error Check. This indicates a feed check or a read check. It will appear along with OC.                                                                                    |
|     | LC:       | Last Card. This bit comes on after the last card<br>is read and will appear with OC. It remains on                                                                         |
|     | 0C:       | Operation Complete. This bit is set just prior<br>to the request for an I/O interrupt after card                                                                           |
|     |           | that is stored in conjunction with the I/O interrupt.                                                                                                                      |
| ÷   | B:        | Busy. This indicates that a card read is in<br>progress and therefore another read cannot be<br>initiated. This indicator turns off when the                               |
|     | OB:       | Operation Complete interrupt occurs.<br>Offline or Busy. Offline is on when the Read<br>Stop light is lit on the 3461. This bit is also<br>on when the B (Busy) bit is on. |

# 9.2 TERMINAL INTERFACE (UNIT ADDRESS 00110)

# 9.2.1 DESCRIPTION

The Terminal Interface provides a means of interactive communication between the META 4A processor and a terminal. Any terminal which conforms to the RS232-C conventions may be plugged into this interface. This unit also controls the black plexiglass box (hereafter called the magic box) connected to the terminal cable. The input and output codes are right justified ASCII.

### 9.2.2 CONTROL COMMANDS

The Terminal Interface is addressed by the 5-bit unit address 00110. The control IOCC uses a set of status codes to control the ablitity of the Terminal Interface to interrupt the CPU, and to control the lights on the terminal and the magic box.

Control IOCC (X'3430')

| <br> | status | codes 0 | 011 | 0110000 | 110 000 |
|------|--------|---------|-----|---------|---------|
| 0    |        | 1       | 6   | 21      | 2931    |

Status Codes Format:

| oc | IR /// | /////////PR//////FLILIRL                                                                  |
|----|--------|-------------------------------------------------------------------------------------------|
| 0  | 1 2    | 3 4 5 6 7 8 13 14 15                                                                      |
|    | 0C:    | Output Complete Enable. If this bit is on, the output complete interrupt will be enabled. |
|    | IR:    | Input Complete Enable. If this bit is on, the input complete interrupt will be enabled.   |
|    | PR:    | Proceed. If the terminal has a wait/proceed                                               |
|    | FL:    | Flash Light. If on, the light on the left side of the magic box will flash                |
|    | LL:    | Left Light. If this bit is on, the left hand<br>light on the magic box will be on         |
|    | RL:    | Right Light. If this bit is on the light on the right side of the magic box will be on.   |

#### Read Command

When the user stikes a key on the terminal, an Input Ready interrupt will occur if a previous Control IOCC enabled the interrupt. At this time, a Read IOCC should be performed to store the ASCII character into a halfword in core. This IOCC has the following format:

Read IOCC (X'3208')

| [ | memory | address | 00110 | 01000001 | 000  |
|---|--------|---------|-------|----------|------|
| 0 |        |         | 16    | 21       | 2931 |

#### Output Command

The Write IOCC will write one ASCII character to the terminal plugged into the interface.

Initiate Write IOCC (X'3130')

|   | ASCII | character | 00110 | 001001 | 10 000 |
|---|-------|-----------|-------|--------|--------|
| C | )     | ,         | 16    | 21     | 2931   |

### 9.2.3 USH FORMAT

The format of the USH for the Terminal Interface and the meanings of the bits are as follows:

| oc | IRBR | AT TB TO PE OR /////////////////////////////////// |
|----|------|----------------------------------------------------|
| 0  | 1 2  | 3 4 5 6 7 8 13 14 15                               |
|    | OC:  | Output Complete. This bit is set when the          |
|    |      | interface is ready for another character.          |
|    |      | Following the setting of this bit, an I/O          |
|    |      | interrupt is requested by the Terminal Interface.  |
|    | IR:  | Input Ready. This bit comes on after the user      |
|    |      | has hit a key and just prior to the request by     |
|    |      | the interface for an I/O interrupt. A Read IOCC    |
|    |      | should be performed after receiving this           |
|    |      | interrupt.                                         |
|    | BR:  | Break. This bit is set when the user strikes the   |
|    |      | BREAK key on the terminal. It is provided as a     |

means of signalling an attention to the META 4A. An I/O interrupt will occur after the setting of this bit.

- AT: Attention: This bit is set when the button on the magic box is pressed. An I/O interrupt will be requested after this bit is set.
- TB: Terminal Busy. When on, this indicates that the interface is busy transmitting a character.
- **TB:** Terminal Offline or Busy. This bit is off when the terminal is powered on and plugged into the interface.
- PE: Parity Error. This bit is set when a parity error is detected in a received character.
- OR: Overrun. This bit is set when the interface detects an overrun condition.

### 9.3 /360 TERMINAL INTERFACE (UNIT ADDRESS 00011)

### 9.3.1 DESCRIPTION

The /360 Terminal Interface is almost identical to the interface described in 9.2 above. It provides an interface to the /360 so that BUGS can look to CP as though it were a terminal. Only the differences in operation from the description above will be shown here.

Control IOCC (X'1C30')

| r | status                             | codes | 000 | 1111000 | 011010001 |
|---|------------------------------------|-------|-----|---------|-----------|
| L | fe ann ann ann ann tafe aith ann a |       |     |         |           |
| 0 |                                    |       | 16  | 21      | 2931      |

The status codes are identical to those described in , with the exception that turning bit 2 on in the status codes will transmit a BREAK to the /360.

Read IOCC (X'1A08')

|   |        |         | 100011 | 10100000 | 10001 |
|---|--------|---------|--------|----------|-------|
| 1 | memory | address | 00011  | 0100000  | 1000  |
| L |        |         | .L     | 1        | J     |
| ( | )      |         | 16     | 21       | 2931  |

Initiate Write IOCC (X'1930')



### 9.4 MODEL 1444 DISK STORAGE UNIT (UNIT ADDRESS 00010)

#### 9.4.1 DESCRIPTION

The Model 1444 Disk Storage Unit provides the META 4A Computing System with a large<sup>(3)</sup> sequential or random access data store. The features of this store are described in the following paragraphs.

### 9.4.1.1 Storage Capacity

The storage capacity provided by the 1444 is 1,024K (1,043,576) bytes per disk cartridge. A single cartridge may be mounted on the drive at any one time; but cartridges may be interchanged in a matter of minutes.

### 9.4.1.2 Data Organization

The disk access mechanism, called the carriage, is moved back and forth by programmed I/O Control Commands and can be placed over any one of 203 cylinders, numbered from 0 to 202. Each cylinder is divided into 8 sectors, numbered 0 to 7. Sectors 0 through 3 are located on the upper surface of the disk, while sectors 4 through 7 are on the lower surface. Each sector contains 642 bytes of information and is the largest segment of data that can be read/written with a single IOCC.

> 207×8×642= 1013326 1042608

#### 9.4.2 1444 I/O CONTROL COMMANDS

The 1444 is addressed by the unit address 00010, and is controlled by 4 IOCCs. The first of these is a Control, and is used to position the carriage over one of the 203 cylinders of the cartridge. Its format is:

Control IOCC (X' 1430')

| //////increment | 00010 | 100001 | 10 D//I |
|-----------------|-------|--------|---------|
| L               |       | L      | L       |
| 0               | 16    | 21     | 2931    |

The increment specifies the number of cylinders to move the carriage <u>relative</u> to its current position. If bit 29 (D) is 0, the carriage is moved toward the higher cylinders (the center of the cartridge); if 1, it is moved toward the lower cylinders (the edge of the cartridge). When movement is complete, an Operation Complete interrupt occurs, unless the increment was 0. Because movement is relative, it is necessary to keep in the UCB the current cylinder position, so that increments can be computed correctly.

The second IOCC is an Initiate Write, used for recording information on a particular sector of the current cylinder. Its format is:

Initiate Write IOCC (X'1520')

|   | memory | address | 10 | 0010 | 10100100 |   | ec  |  |
|---|--------|---------|----|------|----------|---|-----|--|
| ( | )      |         | 1  | 6    | 21       | 2 | 931 |  |

The memory address specifies the address of a buffer on a halfword boundary from which data is written on the sector specified by the 3-bit number sec. The buffer has the following format:

Buffer



The count specifies the number of halfwords of data to be written on the sector, and is followed by the halfwords themselves. If less than 642 bytes (321 halfwords) is written, the remaining bytes on the sector are zeroed. An Operation Complete interrupt occurs after the Write operation is finished.

Finally, there are 2 Initiate Read IOCCs. The first of these is used to read all or part of a sector into memory. Its format is:

Initiate Read IOCC (X'1620')

|   | memory | address | 10 | 0010 | 11000 | 100 sec |
|---|--------|---------|----|------|-------|---------|
| C | ) .    |         | 1  | 6    | 21    | 2931    |

The memory address points to a buffer (in the same format as that for Initiate Write) which specifies a count of the number of halfwords to be read from the sector specified by the 3-bit number sec. An Operation Complete interrupt occurs after data transfer is complete.

The second of these, Initiate Read-Check, performs exactly the same function as Initiate Read, except that no data is stored in memory. Therefore, no data halfwords need follow the count in the buffer. A Read-Check is used to check the validity of data written on the disk and should follow every Write if maximum reliablilty is to be maintained.

Initiate Read-Check IOCC (X'16A0')

| 1 | memory | address                                             | 10 | 00101 | 11010100 | Is | e | C | 1       |  |
|---|--------|-----------------------------------------------------|----|-------|----------|----|---|---|---------|--|
| 0 |        | ið filmi fölltratilt allala enter kikle enter filda | 1  | 6     | 21       | 2  | 9 | 3 | ר.<br>1 |  |

NOTE: If a count of 0 is specified on any of the last 3 IOCCs, unpredictable results will occur.

9.4.3 USH FORMAT

The format of the USH for the 1444 is as follows:

| IE ' | IOC OB   | IB [C0]////////////////////////////////////      |
|------|----------|--------------------------------------------------|
| L    | <u> </u> |                                                  |
| 0    | 1 2      | 3 4 5 6 7 8 13 14 15                             |
|      | E        | Error. This bit can appear at Operation Complete |
|      |          | IOF the following reasons:                       |
|      |          | Pead-Check                                       |
|      |          | 2) More than 642 bytes (321 halfwords) were      |
|      |          | specified by the count field. A sector is the    |
|      |          | maximum segment that can be transferred by 1     |
|      |          | IOGC.                                            |
|      |          | 3) The carriage was moved to cylinder 0 or 202   |
|      |          | by a Control IOCC, but the increment specified   |
|      |          | still more movement. The current D.S.C. 1444     |
|      | 20       | controller circuitry goes berserk when this      |
|      | 00.      | Situation occurs.                                |
|      | 00:      | USH after an Operation Complete interput         |
|      | OB.      | Offline or Busy This hit is on when the 1/1/1/   |
|      | 01.      | drive is powered down, not up to speed, or when  |
|      |          | the unit is busy executing a previous IOCC.      |
|      | B:       | Busy. This bit is on when the unit is busy       |
|      |          | executing a previous IOCC. OB will also be on in |
|      |          | this case.                                       |
|      | C0:      | Carriage at 0. This bit is always down unless    |
|      | 66.      | the carriage is positioned over cylinder 0.      |
|      | SC:      | sector count. These 2 bits specify the sector    |
|      |          | under the Read/Write Heads on the carriage If a  |
|      |          | program can be arranged to read/write either of  |
|      |          | these sectors next, rotational delay will be     |
|      |          | minimized.                                       |
|      |          |                                                  |
|      |          |                                                  |
|      |          |                                                  |

### 9.5 META 4A CONTROL PANEL (UNIT ADDRESS 00101)

#### 9.5.1 DESCRIPTION

The Control Panel contains the switches, dials, and lights necessary to operate and control the META 4A and the whole BUGS system. In addition it is possible for a running program to perform limited I/O to the Panel.

### 9.5.2 SYSTEM CONTROL FUNCTIONS

POWER ON (black): This key is pressed to initiate a power-on sequence of the whole BUGS system.

- POWER OFF (red): The Power Off key is pushed to initiate the power-off sequence of BUGS. The 1444 disk should be in SAFE state when this key is pressed.
- STOP: This button causes all processing to stop after the completion of the current instruction. The META 4B is signalled to stop also, but other initiated I/O operations are allowed to come to completion. It is necessary for the META 4A to be in this "stopped" state if any Panel manipulations are to be performed. NOTE: If S/360 Initial Select interrupts are disabled and the META 4A is online, the STOP
  - button is ignored. This is to prevent Multiplexor Channel and CP crashes.
- RESET: This button resets the META 4A and all online local I/O units; in other words, the whole BUGS system. All pending interrupts are cleared, Parity Checks are corrected, and the system is placed in an initialized state. The contents of the memory and registers after RESET are unpredictable.
- IPL: This button provides a means of initially loading a program into memory and beginning execution. Before initiating an IPL, BUGS should be reset and the data switches set to specify from where the initial program should be obtained:
- all off: bytes 2 through 641 of cylinder 0, sector 0 on the 1444.
- switch 0 up: bytes 2 through 641 of cylinder 202, sector 0 on the 1444.
switch 1 up: a variable number of bytes from the S/360.

- The IPL sequence involves lighting the IPL-ING light, loading the initial program starting at location 0, and obtaining the initial MSR and PC from locations 0 through 3 to start execution. Once the IPL is complete, the IPL-ING light is extinguished, unless an error occurs. If the light remains on, IPL should be re-attempted.
- IPL-ING light: This light is on during an IPL sequence, as described above.
- CPU RUN light: This light is on when the META 4A CPU is running. The CPU is considered to be running at all times except during panel manipulations performed after the STOP button is pressed.

WAIT light: This light is on when the META 4A CPU is running but the MSR indicates wait state.

#### 9.5.3 USER INTERVENTION FACILITIES

Whenever the BUGS system has entered "stopped" state due to the STOP button being pressed, the user may execute one or more of the above control functions. In addition the Panel provides him with facilities to display and modify various components of the META 4A.

- Displaying and Loading the MSR: The user can display the current contents of the MSR on the lower lights by setting the REGISTER SELECT (RS) dial to MSR and the MODE SELECT (MS) dial to DISPLAY. Furthermore, by turning the MS dial to LOAD, he may modify these contents by setting the desired halfword on the 16 data switches. The CLEAR switch will at all times zero the contents of the register currently being loaded.
- Displaying and Loading the PC: This operation is completely synonomous to that for the MSR, except that the RS dial is set to the PC postion.
- Displaying, and Modifying the Next Sequential Instruction (NSI): The NSI is the first halfword of the instruction currently pointed to by the PC. This halfword may be manipulated exactly as the MSR and PC by setting the RS dial to NSI.
- Displaying and Modifying Memory: In order to select a memory location for displaying or modification, a special register, called the Display Counter, is used. The RS dial has a COUNTER position, so that this register can be treated just as the MSR, PC and NSI explained above. Following the

setting of the Display Counter to the desired address, the RS dial is turned to MEMORY DATA, and the halfword pointed to by the Display Counter is shown on the lower lights, with the Display Counter itself on the uppers. The memory halfword may then be modified by the normal procedure. If the START switch is depressed during a memory display, the Display Counter is incremented by 2 and the next halfword displayed. Displaying and Modifying Registers: As you may have guessed, this operation is identical to that for memory, except that the RS dial is turned to REGS. Only bit 12 through 15 of the Display Counter are used to select the register.

- Clearing Memory: A firmware memory clear may be performed by setting the RS dial to MEMORY DATA, the MS dial to LOAD, and depressing the IPL, CLEAR, and START buttons simultaneously. Memory is completely zeroed in approximately one-half second.
- Starting the META 4A after Stopping: This is accomplished by setting the MS dial to STEP, RUN or INT RUN (described below), and pressing the START switch. RUN causes normal CPU execution to continue, while STEP causes "stopped" state to be re-entered after execution of for debugging system programs "interactively".

9.5.4 I/O TO THE CONTROL PANEL

### 9.5.4.1 Panel IOCCs

The Panel is addressed by the unit number 00101. 2 IOCCs are available to the programmer - the first of these is used to read the setting of the 16 data switches:

Read IOCC (X'2A08')

| 1 | memory | address                   | 00101 | 101000 | 001/// |
|---|--------|---------------------------|-------|--------|--------|
| - | 0      | an ann ann ann ann ann an | 16    | 21     | 2931   |

The halfword switch setting is stored at the memory address specified.

The other IOCC is used for setting the lights to a certain value. This can be useful for operating system error halts or what have you. Its format is: Write IOCC (X'2800')

| <br> <br>L. | memory | address | 0010 | 100000 | 000 / LU |
|-------------|--------|---------|------|--------|----------|
| , (         | )      |         | 16   | 21     | 2931     |

The halfword at the memory address is set on the lower lights if L is on, the uppers if U is on, or both if both modifiers are set.

## 9.5.4.2 USH Format

The format of the USH for the Panel is:

| r  |    | -   |      |            | ,<br> |      |      |       |       |       | 22      |            |       |
|----|----|-----|------|------------|-------|------|------|-------|-------|-------|---------|------------|-------|
| IR | IB | I P | 1//  | <u>//i</u> | ////  | 111  | 111  | 1111  | ////  | ////  | 1/1     |            |       |
| 0  | 1  | 2   | 3    | 4          | 56    | 7    | 8    |       | 1     | 3 14  | 15      |            |       |
|    | Ι  | R:  | Thi  | s b        | it is | s se | t af | ter a | a Par | nel   | interr  | upt c      | aused |
|    |    |     | by   | ru         | nning | y in | INT  | erru  | pt :  | RUN   | mode.   | This       | mode  |
|    |    |     | of   | ex         | ecuti | Lon  | caus | es a  | an i: | nter  | rupt a: | fter       | every |
|    |    |     | lns  | tru        | ction | 1.   |      |       |       |       |         |            |       |
|    | I  | B:  | Thi  | S          | bit w | vi11 | be   | set   | aft   | er a  | Panel   | inte       | rrupt |
|    |    |     | cau  | sed        | by 1  | nitt | ing  | the : | INTE  | RRITP | r butte | <b>n</b> . | -     |
|    | Ρ  | :   | This | bi         | tis   | se   | t af | ter a | a Par | nel   | interr  | upt c      | aused |
|    |    |     | by   | a          | Pari  | Lty  | Che  | ck.   | The   | e PA  | R STOI  | Pilia      | ht is |
|    |    |     | aut  | oma        | tical | lly  | set  | by    | the   | fi    | rmware  | when       | this  |
|    |    |     | che  | ck         | is    | det  | ecte | đ, a  | and   | an    | intern  | cupt       | then  |
|    |    |     | occ  | urs        | , unl | ess  | dis  | abled | l by  | the   | MSR.    |            |       |

# 9.6 META 4B (UNIT ADDRESS 00001)

## 9.6.1 DESCRIPTION

The META 4B is the graphics processor of the BUGS configuration - a CPU of the same power as the META 4A, but with target instructions oriented towards graphic data manipulation and display. A complete description can be found in the META 4B Principles of Operation. This section

describes the IOCCs used in communication between the 2 processors. It should be realized that the META 4B can perform equivalent operations (although they are programmed differently), thus completing the communications link.

9.6.2 I/O CONTROL COMMANDS

There are 3 IOCCs used to communicate with the META 4 B. These IOCCs manipulate registers in a special inter-processor interface, The Inter-Processor Interrupt (IPI). The IPI is addressed as unit 00000 The first IOCC is a Write:

Write IOCC (X'0930')

| /////////////////////////////////////// | 0000 | 100100 | 0110/// |
|-----------------------------------------|------|--------|---------|
| 0                                       | 16   | 21     | 2931    |

This IOCC sends an interrupt request to the META 4B.

The second IOCC is a Read, whose function is to allow the META 4A to read back its own USH. Its format is:

Read IOCC (X'0208')

| memory | address | 00001 | 0100000 | 1/// |
|--------|---------|-------|---------|------|
| 0      |         | 16    | 21      | 2931 |

The USH is placed in the halfword at the memory address.

The final IOCC, a Control, is used by the META 4A to reset bits in the B's USH:

Control IOCC (Y'0430')

| 111111111111111111111111111111111111111 | 00001 | 10000100 | ///  |
|-----------------------------------------|-------|----------|------|
| 0                                       | 16    | 21       | 2931 |

This IOCC acknowledges an interrupt from the META 4B.

## 9.6.3 TYPICAL COMMUNICATION SEQUENCE

Let us assume that the META 4B wants to interrupt the META 4A. The following sequence of events might occur:

- META 4B: Initiates the equivalent of a Write to set its USH to the interrupt code and request an interrupt at the A.
- META 4B: Goes into a loop reading its USH and testing for 0 to wait for the A to acknowledge the interrupt.
- META 4A: Receives the interrupt and so as to avoid a continuous interrupt request, Controls the actual META 4B USH (stored in the UCB upon interrupt) to the B so as to clear its USH and the interrupt request.
- META 4A: Branches off on the USH code to perform requested function.
- META 4B: Drops out of the read loop and continues operation.

NOTE: The <u>only</u> way to clear an interrupt request is to zero the META 4B's USH by a Control IOCC. Not even the B can clear its request (by writing a USH of 0, for example).

### 9.7 COMMON I/O CONTROL COMMANDS

#### 9.7.1 NO OPERATION

The No Operation IOCC is common to all I/O units. It performs no I/O at the unit and therefore completes immediately with Condition Code C2. It does, however, (as do all SIO(R)/IOCC combinations) cause the post-SIO(R) USH to be stored in the UCB, and can optionally be used to clear a pending I/O interrupt.

No Operation IOCC

| [////////////////////////////////////// | ////xaddr | 111100 | 0111//// |
|-----------------------------------------|-----------|--------|----------|
| L                                       |           |        |          |
| 0                                       | 16        | 21     | 2931     |

If bit 31 (C) is on, and an interrupt from the addressed unit has been requested but kept pending due to the MSR or I/O Mask, that interrupt request is cleared. This bit is ignored when the META 4B is addressed.

## 9.7.2 INVALID I/O CONTROL COMMANDS

If an IOCC with an invalid operation code is initiated, unpredictable results will occur at the I/O unit, along with possible spurious I/O interrupts. Such operation codes should therefore never be used for any purposes whatsoever. 10 APPENDIX I: OPERATION PROGRAM INTERRUPT STORAGE

As mentioned in Section 7, certain extra information is stored in low core when an Operation Program interrupt occurs. This information facilitates simulating extended machine instructions in software. There are 5 halfwords of information stored in memory locations 52 through 5B; the exact nature of the halfwords stored depends on the format of the invalid instruction as shown in the following table:

| FIRST HEX  | FORMAT | <u>52</u>                           | <u>5</u> 4 | <u>LOCATION</u><br>56 | <u>58</u>                        | 5 <u>A</u>                                                     |
|------------|--------|-------------------------------------|------------|-----------------------|----------------------------------|----------------------------------------------------------------|
| 0,1,2,3 RR |        | First<br>halfword of<br>instruction |            | 4*R1                  | 4*R2                             |                                                                |
| В          | RI     | 11                                  |            | 4* <u>R</u> 1S        |                                  | Operand 2<br>(immediate<br>data)                               |
| 9          | RS     | "                                   |            | 4*R 1                 | Operand 2<br>address             |                                                                |
| 4,5,6,7    | RX     | "                                   |            | 4*R1                  | Operand 2<br>address             |                                                                |
| A          | BX     | н                                   |            | 4*R1                  | Operand 2<br>(branch)<br>address |                                                                |
| 8          | SI     | 11                                  |            | Operand 1<br>address  |                                  | Operand 2<br>(immediate<br>data) in<br>locaton 51<br>(0 in 50) |
| G,F        | FSS    | "                                   |            | Operand 1<br>address  | Operand 2<br>address             | (0 11 30)                                                      |
| C, D       | VSS    | 11                                  | length     | Operand 1<br>address  | Operand 2<br>address             |                                                                |

NOTE: Blank entries in the table signify that the contents of the location are undefined, or too ridiculous to mention.

# 11 APPENDIX II: OPERATION CODES AND TIMINGS

# 11.1 OPERATION CODES AND INSTRUCTION EXECUTION TIMES

| Instruction | <u>Çode</u> | <u>Execution Time (in mics.)</u> |
|-------------|-------------|----------------------------------|
| Α           | 74          | 4.62 (assuming no overflow)      |
| AH          | F4          | 7.62                             |
| AHI         | 84          | 5.37                             |
| AI          | B4          | 3.54                             |
| AL          | 7C          | 4.77 (average)                   |
| ALI         | BC          | 3.69                             |
| ALR         | 3C          | 3.36                             |
| AR          | 34          | 3.21                             |
| AX          | 24          | 3.30                             |
| BAL         | A 8         | 3.75                             |
| BALR        | 28          | 3.42                             |
| BCO         | A7          | 3.65                             |
| BCOR        | 27          | 3.32                             |
| BCT         | AF          | 3.99                             |
| BCTR        | 2F          | 3.66                             |
| BCZ         | A6          | 3.65                             |
| BCZR        | 26          | 3.32                             |
| BXH         | AO          | 5.25                             |
| BXLE        | A 1         | 5.25                             |
| C           | 70          | 5.14 (average)                   |
| СН          | FO          | 7.42                             |
| CHI         | 80          | 5.38                             |
| CI          | в0          | 3.96                             |
| CL          | 7F          | 4.83                             |
| CLB         | 5F          | 4.89                             |
| CLBI        | 8F          | 4.83                             |
| CLC         | CF          | 7.56 + 2.04N (N is the number of |
|             |             | characters compared)             |
| CLCL        | DF          | 7.83 + 2.04N                     |
| CLH         | FB          | 7.11)                            |
| CLI         | BF          | 3.75                             |
| CLR         | 3F          | 3.42                             |
| CR          | 30          | 3.53                             |
| CVB         | 50          | 5.43 + 1.80N (N is the number of |
|             |             | characters converted)            |
| CVD         | 51          | 17.75 (average)                  |
| D           | 77          | 12.75                            |
| DEQ         | 48          | 7.08                             |
| DH          | F7          | 16.71                            |
| DI          | в <b>7</b>  | 12.09                            |

| DR         | 37          | 11.34                              |
|------------|-------------|------------------------------------|
| ENQ        | F8          | 9.24                               |
| ENT        | BE          | 23.88                              |
| EX         | 54          | 5.01 + normal time of subject      |
|            |             | instruction (R1=0)                 |
|            |             | 5.10 + normal time of subject      |
|            |             | instruction (R1≠0)                 |
| EXCC       | 22          |                                    |
| FTLL       | C8          | 7.11 + 2.041. (I. is the number of |
|            | 0.0         | bytes specified by the length      |
|            |             | field.)                            |
| RTTTT      | 50          | $7 38 + 2 0 \mu T$                 |
| LB         | 58          | u 71                               |
| TCM        | 20          | 3 15 Javorago - one register       |
| 791        | 20          | 0)                                 |
| т          | 73          | 0)                                 |
| <b>د د</b> | 5           | 4. 32                              |
| LA         | 50          | 4.25                               |
| LB         |             | 4.41                               |
| LC         | 4 E<br>0 D  |                                    |
| LCR        | 0 E         | 3.63                               |
| LD         | 53          | 4.92                               |
| LDI        | B8          | 4.03                               |
| LDR        | 13          | 3.63                               |
| LI         | B3          | 3.24                               |
| LM         | 93          | 5.64 + 1.02R (R is the number of   |
|            | - 1.1 M M M | registers specified)               |
| LMD        | 91          | 5.85 + 1.02R                       |
| LN         | 4 D         | 4.44 (if already negative)         |
|            |             | 4.62 (if positive)                 |
| LNR        | 0 D         | 3.15                               |
|            |             | 3.33                               |
| LP         | 4C          | 4.56                               |
|            |             | 5.04                               |
| LPR        | 00          | 3.27                               |
|            |             | 3.75                               |
| LR         | , 33        | 2.91                               |
| LSB        | 5B          | 4.80                               |
| LX         | 23          | 3.09                               |
| LXB        | 4 F         | 4.41                               |
| LXBR       | OF          | 3.12                               |
| LZ         | 5E          | 5.25                               |
| M          | 76          | 10.77                              |
| MH         | F6          | 13.22                              |
| MI         | B6          | 9.81                               |
| MR         | 36          | 9.36                               |
| MVA        | 62          | 7.06                               |
| MVBT       | 80          | 5.61 (2.1)                         |
| MVC        | C L         | 7.32 + 1.08L (both addresses       |
|            | T V         | even)                              |
|            |             | $7.23 \pm 3.061$ (otherwise)       |
| MVCT.      | D4          | 7.59 + 1.08L                       |
| 11101      |             |                                    |

|        |     | 7.50 + 3.06L                         |
|--------|-----|--------------------------------------|
| MVCN   | C5  | 7.53 + 1.08L (address1 <             |
|        |     | address2 and both even)              |
|        |     | 7.80 + 3.06L (otherwise)             |
| MVCNL  | D5  | 7.80 + 1.081                         |
|        |     | 8.07 + 3.061                         |
| MVH    | FЗ  | 7.41                                 |
| MVHT   | 83  | 5 37                                 |
| N      | 79  | (1.80 (avona co)                     |
| NBT    | 80  | 6 21 (average)                       |
| NC     | C9  | 7 11 + 2 0/7                         |
| NCI    | 0   | 7.11 + 3.00L                         |
| NT     | D 9 |                                      |
| ND     | 89  | 3.72                                 |
| N K    | 39  | 3.39                                 |
| ODT    | / A | 4.89                                 |
| OBT    | 8 A | 6.33                                 |
| 0C     | CA  | 7.11 + 3.06L                         |
| OCL    | DA  | 7.38 + 3.06L                         |
| OI .   | BA  | 3.84                                 |
| OR     | ЗA  | 3.51                                 |
| POPH   | C7  | 9.03 + 1.08L (L is the number of     |
|        |     | bytes specified by the length        |
|        |     | field)                               |
| POPHL  | D7  | 9.30 + 1.08L                         |
| POPM   | 97  | $7.53 \pm 1.02R$ (R is the number of |
|        |     | registers specified)                 |
| PSHH   | C6  | 9.51 + 1.081                         |
| PSHHT. | D6  | $9.78 \pm 1.081$                     |
| PSHM   | 96  | $7.35 + 1.1 \mu P$                   |
| RET    | 0 B | 21 00                                |
| S      | 75  |                                      |
| 51     | 50  | 4.72                                 |
| SD     | 17  | 9 70                                 |
| SH     |     |                                      |
| CUT    | r D |                                      |
| CT     | 85  | 5.58                                 |
| TC.    | 85  | 3.75                                 |
| SIU    | 56  | 10.7 (approximate average)           |
| SIUR   | 16  | 8.5                                  |
| SL     | 7D  | 4.86                                 |
| SLA    | 9C  | 6.72 + .30B (B is the number of      |
| 1      |     | bit positions specified)             |
| SLAI   | 1C  | 5.10 + .30B                          |
| SLDA   | 9E  | 7.02 + .30B                          |
| SLDAI  | 1E  | 5.40 + .30B                          |
| SLDL   | 9 A | 6.93 + .30B                          |
| SLDLI  | 1A  | 5.31 + .30B                          |
| SLE    | CO  | $7.29 \pm 1.02N$ (N is the number of |
|        |     | bytes searched in the first          |
|        |     | operand)                             |
| SLEL   | DO  | 7.56 + 1.02N                         |
| SLI    | BD  | 3.90                                 |
|        |     |                                      |

| SLL<br>SLNE<br>SLNE<br>SLNEL<br>SLR<br>SRA<br>SRAI<br>SRCH<br>SRCH<br>SRDAI<br>SRDL<br>SRDLI<br>SRE<br>SREL<br>SRLI<br>SRLI<br>SRNE |   | 98<br>18<br>C2<br>D2<br>3D<br>35<br>9D<br>1D<br>F9<br>9F<br>1F<br>9B<br>1B<br>C1<br>99<br>19<br>C3 | 6.63 + .30B<br>5.01 + .30B<br>7.29 + 1.02N<br>7.56 + 1.02N<br>3.57<br>3.42<br>6.63 + .21B<br>5.01 + .21B<br>9.75 + 1.25N (see later note)<br>6.84 + .21B<br>5.22 + .21B<br>5.22 + .21B<br>5.13 + .21B<br>7.20 + 1.02N<br>7.47 + 1.02N<br>6.54 + .21B<br>4.92 + .21B<br>7.20 + 1.02N |
|-------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SRNEL                                                                                                                               |   | D3                                                                                                 | 7.47 + 1.02N                                                                                                                                                                                                                                                                        |
| SS<br>ST                                                                                                                            |   | 55<br>72                                                                                           | 5, 16                                                                                                                                                                                                                                                                               |
| STB                                                                                                                                 |   | 59                                                                                                 | 5.40                                                                                                                                                                                                                                                                                |
| STD                                                                                                                                 |   | 52                                                                                                 | 5.37                                                                                                                                                                                                                                                                                |
| STDI                                                                                                                                |   | B1                                                                                                 | 4.41                                                                                                                                                                                                                                                                                |
| STDR                                                                                                                                |   | 12                                                                                                 | 4.08                                                                                                                                                                                                                                                                                |
| STL                                                                                                                                 |   | CC                                                                                                 | 7.29 + 2.04N                                                                                                                                                                                                                                                                        |
| STLL                                                                                                                                |   | 00                                                                                                 | 7.50 + 2.04N                                                                                                                                                                                                                                                                        |
| STH                                                                                                                                 |   | 92                                                                                                 | $5 \cdot 70 + 1 \cdot 14K$<br>5 01 + 1 100                                                                                                                                                                                                                                          |
| STR                                                                                                                                 |   | CD                                                                                                 | 7 20 + 2 0 4                                                                                                                                                                                                                                                                        |
| STRL                                                                                                                                |   |                                                                                                    | 7.47 + 2.04N                                                                                                                                                                                                                                                                        |
| SVC                                                                                                                                 |   | 31                                                                                                 | 8.70 (This reflects the time                                                                                                                                                                                                                                                        |
|                                                                                                                                     |   |                                                                                                    | until the first instruction of                                                                                                                                                                                                                                                      |
|                                                                                                                                     |   |                                                                                                    | the SVC interrupt handler is                                                                                                                                                                                                                                                        |
|                                                                                                                                     |   |                                                                                                    | fetched.)                                                                                                                                                                                                                                                                           |
| SVCD                                                                                                                                | 2 | F1                                                                                                 | 12.33                                                                                                                                                                                                                                                                               |
| SVCS                                                                                                                                |   | 81                                                                                                 |                                                                                                                                                                                                                                                                                     |
| SWP                                                                                                                                 |   | 78                                                                                                 | 5.10                                                                                                                                                                                                                                                                                |
| SWPR                                                                                                                                |   | 20                                                                                                 | 3 51                                                                                                                                                                                                                                                                                |
| Ψ R M                                                                                                                               |   | 25                                                                                                 | 3.63                                                                                                                                                                                                                                                                                |
| TBMR                                                                                                                                |   | 20                                                                                                 | 3.30                                                                                                                                                                                                                                                                                |
| TBNM                                                                                                                                |   | AB                                                                                                 | 3.63                                                                                                                                                                                                                                                                                |
| TBNMR                                                                                                                               |   | 2B                                                                                                 | 3.30                                                                                                                                                                                                                                                                                |
| TBNP                                                                                                                                |   | AE                                                                                                 | 3.63                                                                                                                                                                                                                                                                                |
| TBNPR                                                                                                                               |   | 2 E                                                                                                | 3.30                                                                                                                                                                                                                                                                                |
| TBNZ                                                                                                                                |   | A D                                                                                                | 3.63                                                                                                                                                                                                                                                                                |
| TBNZR                                                                                                                               |   | 2D                                                                                                 | 3,30                                                                                                                                                                                                                                                                                |
| TBP                                                                                                                                 |   | A 9                                                                                                | 3.63                                                                                                                                                                                                                                                                                |
| TBPR                                                                                                                                |   | 29                                                                                                 | 3.30                                                                                                                                                                                                                                                                                |
| TBZ                                                                                                                                 |   | AA                                                                                                 | 3.03                                                                                                                                                                                                                                                                                |

| TBZR | 2 A        | 3.30   |           |
|------|------------|--------|-----------|
| TMBI | 82         | 4.83   | (average) |
| TMI  | B2         | 3.75   |           |
| TMR  | 32         | 3.42   |           |
| TR   | CE         | 7.02 + | 3.18L     |
| TRB  | 62         |        |           |
| TRL  | DE         | 7.29 + | 3.18L     |
| TSL  | 87         | 5.94   |           |
| X    | <b>7</b> B | 4.80   |           |
| XBI  | 8B         | 6.42   |           |
| XC   | CB         | 7.11 + | 3.06L     |
| XCL  | DB         | 7.38 + | 3.06L     |
| XI   | BB         | 3.84   |           |
| XR   | 3B         | 3.51   |           |

The times shown reflect instruction fetching and parsing as well as individual execution time. For instructions like ST, which perform a memory operation late in the execution routine, the time shown includes the full memory cycle.

A non-0 base register is assumed wherever appropriate. Deduct .09 microseconds for each 0 base register. For FX and BX instructions, a 0 index register is assumed. Add .42 microseconds for each non-0 RX index and .39 microseconds for each non-0 BX index. For branches, the time shown is the average for a successful and an unsuccessful branch. The execution time for any instruction may be lengthened if a cycle-stealing I/O operation is in progress.

For SRCH, N is the number of memory reads that must be performed during searching. This is defined as follows: There is one memory read for each forward pointer fetched. For a TM search, there is one memory read for fetching the key in each entry. The argument is <u>not</u> refetched each time. For each entry in a CLC search, the argument and the key are each fetched one byte at a time until the strings are discovered to be unequal, or the key length is exhausted. One memory read is required for each byte fetched.

### 11.2 OTHER TIMINGS

A local I/O interrupt takes 9.60 microseconds between detection and the fetch of the first instruction of the I/O interrupt handler. A disabled local I/O interrupt adds .51 microseconds to each instruction. An Operation Program interrupt takes 11.58 microseconds between the end of its parsing and the fetch of the first instruction of the Program interrupt handler. An invalid unit address or UCB address interrupt takes 6.48 microseconds between detection and the fetch of the first instruction of the Program interrupt handler. Any other program interrupt takes 6.18 microseconds after detection.

The times for instruction fetch and parsing alone are:

## Format Time (in mics.)

RR 2.61 2.94 RI RX 3.90 RS 4.32 SI 3.93 3.15 BX 6.06 FSS VSS 6.69 Long VSS 6.96

The assumptions made in earlier timing figures concerning base and index registers also apply here.

### 11.3 COMMENTS AND PROGRAMMING HINTS

To zero one or more registers, a sequence of instructions like:

| LY | R3,0   |
|----|--------|
| LR | R4, R3 |
| LR | R5, R3 |
|    |        |

should be used. Do not use a sequence of SRs.

For SRCH, note that a TM is significantly faster than a CLC.

Logical compares are faster than corresponding arithmetic compares and thus should be used to test for equality whenever it is not important to distinguish between arithmetically greater and arithmetically less.

For loading a constant into a register, note that LX < LI << LA.

For adding a constant to a register, note that AX < AI < ALI < LA. Arithmetic adds and subtracts are faster than logical adds and subtracts.

Remember that LDR and STDR take less core and less time than L and ST and thus should be used whenever the address of the operand is in a register. LDI and STDI are also faster than L and ST and can be used whenever indexing is not required. However, they are less easily relocatable than L and ST.

To determine if an area of core contains all zeroes, do <u>not</u> use an NC or OC. Use SRNE to an X'00' and then check the Condition Code.

Wherever it is certain than two string will not overlap, use MVC instead of MVCN. Not only is setup time faster, but there is a greater chance that the string will be moved a halfword at a time.

Doing a LI into the PC is the fastest way of executing an unconditional branch.

# 12 APPENDIX IV: LAYOUT OF LOWER MEMORY

1.11

The following is a map of the various firmware-defined locations in lower memory:

| Location | Contents                             |
|----------|--------------------------------------|
| 0        | IPL new MSR                          |
| 2        | IPL new PC                           |
| 4        | SVC old MSR                          |
| 6        | SVC old PC                           |
| 8        | SVC interrupt code                   |
| A        | SVC new MSR                          |
| С        | SVC new PC                           |
| E        | Program interrupt old MSR            |
| 10       | Program interrupt old PC             |
| 12       | Program interrupt code               |
| 14       | Program interrupt new MSR            |
| 16       | Program interrupt new PC             |
| 18       | I/O interrupt old MSR                |
| 1 A      | I/O interrupt old PC                 |
| 1C       | I/O interrupt code                   |
| 1 E      | I/O interrupt new MSR                |
| 20       | I/O interrupt new PC                 |
| 22       | S/360 interrupt old MSR              |
| 24       | S/360 interrupt old PC               |
| 26       | S/360 interrupt code                 |
| 28       | S/360 interrupt new MSR              |
| 2 A      | S/360 interrupt new PC               |
| 2C-21    | D reserved for use by firmware       |
| 2E       | I/O interrupt mask                   |
| 30       | Interval Timer UCB address           |
| 32       | META 4B UCB address                  |
| 34       | 1444 Disk Storage Unit UCB address   |
| 38       | 3/161 Card Poader IICB addrogg       |
| 20       | Control Danel UCB address            |
| 36       | 4132 Kovhoard/Tynewriter NCB address |
| 31-41    | The should the street of address     |
| 46       | S/360 device 050 UCB ADDRESS         |
|          |                                      |

| 48<br>4A<br>4C<br>4E<br>50 | S/360 device 051 UCB address<br>S/360 device 052 UCB address<br>S/360 device 053 UCB address<br>Interval Timer |
|----------------------------|----------------------------------------------------------------------------------------------------------------|
| 52 <b>-</b> 5B             | Program interrupt scan-out area - 5 halfwords                                                                  |

## Acknowledgements

We would like to thank the following people for their help in designing and implementing the META 4A:

Wolfgang W. Millbrandt (We are pleased to Mr.) Robert G. Munck William B. Rothman George M. Stabler John E. Stockenberg Richard C. Waters

And a special thanks to all those dear friends in Holland, without whom register 0 would have been fixed at 0.

> Paul Constantine Anagnostopoulos Gary Howard Sockut