All system/360 functional characteristics having programming significance are completely and concisely described.

The description, which is formal rather than verbal, is accomplished by a set of programs, interacting through common variables, used in conjunction with auxiliary tables.

The language used in the programs involves operators and notation selected from mathematics and logic, together with additional operators and conventions defined to facilitate system description.

Although the formal description is complete and self-contained, text is provided as an aid to initial study.

Examples to illustrate the application of the formal description are given in an appendix.

## A formal description of SYSTEM/360

by A. D. Falkoff, K. E. Iverson, and E. H. Sussenguth

This paper presents a precise formal description of a complete computer system, the IBM SYSTEM/360. The description is functional: it describes the behavior of the machine as seen by the programmer, irrespective of any particular physical implemention, and expressly specifies the state of every register or facility accessible to the programmer for every moment of system operation at which this information is actually available.

The work is based on the system/360 manual<sup>1</sup> and on interpretations and revisions furnished by the system architects, some of whom have assisted in a thorough audit of the present description.<sup>2</sup>

The formal description comprises a set of programs and auxiliary tables, all of which are grouped for easy cross-reference beginning on page 240.<sup>2</sup> These provide a complete, self-contained description of the system which, after some familiarity with the notation and programs is gained, will be found more convenient for reference than verbal description. An appendix furnishes examples of reference use of the material. The remainder of the text is designed primarily as a guide and aid in the initial reading of the programs.

The second and third sections describe the central processing unit and the input/output system, respectively. The first section defines the notation employed and illustrates its use. Further illustrations may be found in the references 4, 5, 6.

### The notation

A system is described by a collection of interacting programs, each program consisting of a list of statements executed in an alterable, but specified, sequence. The interaction between programs occurs through shared variables and through direct alteration of the sequence in one program by another.

Statements are of two major types, called specification and branch. A specification statement incorporates a left-pointing arrow and implies that its execution respecifies the value of the variable to the left of the arrow by the value of the expression to the right of the arrow. Thus, if x and y have values 3 and 4, respectively, the execution of the specification statement

$$z \leftarrow x + y$$

sets the variable z to the value 7.

The statements of a program are numbered serially from zero and are executed in serial order except that the execution of a branch statement may interrupt the sequence. One type of branch has the form

$$\rightarrow \alpha$$
, n

and implies that Program  $\alpha$  immediately executes its statement numbered n (to be referred to hereafter as line n) and proceeds from there. If the foregoing branch statement occurs in Program  $\beta$ (where  $\beta \neq \alpha$ ), the sequence in Program  $\beta$  is not affected. For example, the execution of line 1 of IPL, the initial program load program (page 259) resets CPU, the central processing unit program, to its line 0 but does not affect the sequence in IPL, which continues to line 2.

In the more familiar case the branch statement  $\rightarrow \alpha$ , n occurs in Program  $\alpha$ , and the program name is elided to yield the form  $\rightarrow n$ . Line 11 of the CPU program furnishes an example, causing a branch to one of lines 12, 14, 13, 17, or 19 according to which component of the vector (12, 14, 13, 17, 19) is selected by the index  $n_2$ . The statement itself completely specifies the branch, and the broken arrows from line 11 to each of its potential successors are provided merely as a graphic aid to comprehension.

Solid arrows from line to line are, however, used as an alternative specification of branching within a given program. An unlabelled arrow denotes an unconditional branch; thus line 12 of the CPU program is invariably followed by line 16. A solid arrow labelled with a relation R and emanating from a line containing a statement of the form

#### x:y

implies that the branch arrow is followed if and only if the relation  $x \Re y$  holds. Thus line 40 of the CPU is followed by line 1 if  $p_{14} = 0$ , and by line 25 if  $p_{14} \neq 0$ . In following branch arrows that cross, the path does not change direction at a crossing.

199

|                       | 1 Notation                                                                                                                    |                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       | Operation                                                                                                                     | Notation (1)                                                                                                                                                                                                                                                                                      | Definition <sup>3</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| NDS                   | Scalar<br>Vector                                                                                                              | x<br>x                                                                                                                                                                                                                                                                                            | $x \equiv x_0, x_1, \dots, x_{(\nu x)-1}$ $\nu x \equiv \text{number of components}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| OPERANDS              | Matrix                                                                                                                        | X                                                                                                                                                                                                                                                                                                 | $X \equiv \begin{bmatrix} X_0^0 & \cdots & X_{(\nu,X)-1}^0 \\ \vdots & \vdots & \vdots \\ X_0^{(\mu,X)-1} & \cdots & X_{(\nu,X)-1}^{(\mu,X)-1} \end{bmatrix} \begin{cases} X^i \equiv i \text{th row vector} \\ X_j \equiv j \text{th column vector} \\ \mu X \equiv \text{number of rows} \\ \nu X \equiv \text{number of columns} \end{cases}$                                                                                                                                                                                                                                                                                                                                                                                                               |
| LOGICAL and NUMERICAL | Arithmetic  Absolute value Floor Ceiling Residue modulo $m$ And Or                                                            | $+ - \times \div$ $z \leftarrow \mid x$ $k \leftarrow \mid x$ $k \leftarrow \mid x$ $k \leftarrow m \mid n$ $w \leftarrow u \wedge v$ $w \leftarrow u \vee v$                                                                                                                                     | Usual definitions $z = \text{maximum of } x \text{ and } -x$ $k \le x < k + 1$ $k - 1 < x \le k$ $n = (m \times q) + k,$ $0 \le k < m$ $\begin{cases} u = 1 \text{ and } v = 1 \\ u = 1 \text{ or } v = 1 \end{cases}$ All operations are extended component-by-component to dimensionally compatible vectors and matrices. If one of the operands is a scalar, it is treated as a vector or matrix of appropriate dimension whose components are all equal. Examples: $z \leftarrow x + y$                                                                                                                                                                                                                                                                    |
| LOGIC                 | $egin{array}{ll} 	ext{Negation} & \left\{  ight. \end{array}$ Relation                                                        | $w \leftarrow \bar{u}$ $w \leftarrow \sim u$ $w \leftarrow x \Re y$                                                                                                                                                                                                                               | $ \begin{cases} w = 1 & \text{if } \\ u = 0 \\ x + x + y \\ w \leftarrow u \wedge v \\ w \leftarrow x \neq y \\ w \leftarrow x < y \end{cases} $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| REDUCTION             | Reduction<br>Row reduction<br>Column reduction<br>Matrix product                                                              | $z \leftarrow \bigcirc/X$ $z \leftarrow \bigcirc/X$ $z \leftarrow \bigcirc//X$ $z \leftarrow \bigcirc//X$ $Z \leftarrow X \stackrel{\circ}{\circ}, Y$                                                                                                                                             | $ z = x_0 \odot x_1 \odot \cdots \odot x_{(\nu x)-1} $ $\odot$ is any binary operator or relation. The case $X \stackrel{\star}{\sim} Y$ is the ordinary matrix product. The expressions $X \stackrel{\circ}{\circ}_{1} Y$ , and $x \stackrel{\circ}{\circ}_{1} Y$ are treated as in matrix algebra. Thus $x \stackrel{\star}{\sim} y$ is the scalar product.                                                                                                                                                                                                                                                                                                                                                                                                  |
| BASE VALUE            | Base 10 value Base 2 value { Representation base 10                                                                           | $z \leftarrow 10 \perp x$ $z \leftarrow \perp u$ $z \leftarrow \perp U$ $z \leftarrow \perp U$                                                                                                                                                                                                    | z is the base-10 value of the vector $x$ z is the base-2 value of the vector $u$ $z_i \equiv \perp U^i$ $pz \equiv n \text{ and } 10 \perp z \equiv 10^n \mid j$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| SELECTION             | base 2  Catenation Row catenation Compression vector row column row list Row list expansion  Mask  Indexing  { Maximum prefix | $u \leftarrow (n)     j$ $z \leftarrow x, y$ $Z \leftarrow x \oplus y$ $z \leftarrow u/x$ $Z \leftarrow u/X$ $Z \leftarrow u//X$ $z \leftarrow E/X$ $X \leftarrow E(m, n) \setminus z$ $z \leftarrow /x; u; y/z$ $z \leftarrow x_m$ $z \leftarrow X^m$ $z \leftarrow X_m$ $w \leftarrow \alpha/u$ | $\begin{array}{l} \nu u \equiv n \text{ and } \underline{\qquad} u \equiv 2^n \mid j \\ \\ z \equiv x_0, x_1, \cdots, x_{(\nu X)-1}, y_0, y_1, \cdots, y_{(\nu y)-1} \\ Z_0 \equiv x; Z_1 \equiv y \\ \\ z \text{ obtained by suppressing from } x \text{ each } x_i \text{ for which } u_i \equiv 0 \\ Z' \equiv u/X; \\ Z_j \equiv u/X; \\ z \equiv X^0, X^1, \cdots, X^{(\mu X)-1} \\ \mu X \equiv m, \nu X \equiv n, \text{ and } E/X \equiv z. \text{ Thus } X \equiv \begin{bmatrix} z_0 & \cdots & z_{n-1} \\ z_n & \cdots & \cdots \\ \vdots & \vdots & \vdots & \vdots \\ x_i \equiv z_{m_i} \\ Z_i \equiv X^m; \\ Z_i \equiv X_{m_i} \\ w \equiv \alpha^{i}(\nu u) \text{ and } j \text{ is maximum for which } \wedge /w/u \equiv 1 \\ \end{array}$ |
| SHIFTING              | Left rotation<br>Right rotation<br>Left shift<br>Right shift                                                                  | $z \leftarrow k \uparrow x$ $z \leftarrow k \downarrow x$ $z \leftarrow k \uparrow x$ $z \leftarrow k \uparrow x$ $z \leftarrow k \downarrow x$                                                                                                                                                   | $ \begin{aligned} z_i &= x_i; j = (\nu x) \mid i + k \\ z_i &= x_i; j = (\nu x) \mid i - k \end{aligned}                                $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| SPECIAL VECTORS       | Full Characteristic Prefix Suffix Random  { Interval                                                                          | $w \leftarrow \epsilon(n)$ $w \leftarrow \epsilon^{i}(n)$ $w \leftarrow \alpha^{i}(n)$ $w \leftarrow \omega^{i}(n)$ $w \leftarrow ?$ $w \leftarrow ?(n)$ $w \leftarrow ?^{i}(n)$ $z \leftarrow v^{i}(n)$                                                                                          | $\begin{array}{l} w_i \equiv 1 \\ w_i \equiv ( \vee / i = j ) \\ w_i \equiv ( i < j ) \\ w_i \equiv ( (n-i) \leq j ) \\ w \equiv 0 \text{ or } 1 \text{ (arbitrary)} \\ w_i \equiv 0 \text{ or } 1 \text{ but } +/w \equiv j \\ z \equiv j, j+1, \cdots, j+n-1 \end{array}$ Dimension of $\boldsymbol{w}$ is $n$ . The $n$ may be omitted if it is clear from context.                                                                                                                                                                                                                                                                                                                                                                                         |

- ① The notation for each operation is only the portion to the right of the specification arrow; the variable to the left facilitates definition.
- ② Throughout this paper elementary operations occurring in compound expressions are, except as indicated by parentheses, executed in strict order from right to left. In this table the symbol ≡ is used instead of = to denote equality, since the latter denotes an operator of the class
- 3 The following arguments are used in the examples:

```
a \equiv 7, -6, 5, -4, 3
                                                T0 1 2 3 47
b \equiv 3, 2, 1
                                        A = \begin{vmatrix} 1 & 2 & 3 & 4 & 5 \end{vmatrix}
c = 0, 0, 1, 1, 0, 1, 1, 1
                                                [2\ 3\ 4\ 5\ 6]
n \equiv \text{any logical vector}
      (n_i \equiv 0 \text{ or } 1)
                                       P = \begin{bmatrix} 0 & 1 & 1 \\ 1 & 0 & 1 \end{bmatrix}
p = 1, 0, 1, 0, 1
q \equiv 1, 0, 1
r = +, -, \times, \div
```

#### Examples 3

```
a_1 = -6
                                                        b + q = 4, 2, 2
                                                                                                                   A_0 = 0, 1, 2
             r_0 \equiv +
                                                         b r_0 q = 4, 2, 2
                                                                                                                  P^1 = q
                                                                                                       a - A^0 \equiv 7, -7, 3, -7, -1

|a - A^0 \equiv 7, 7, 3, 7, 1
     2 \times \boldsymbol{b} \equiv \boldsymbol{b} \times 2 \equiv 6, 4, 2
                                                        b \times b = 9, 4, 1
    -3.6 = 3.6
                                                      | q - 3 \equiv 2, 3, 2
                                                      \begin{bmatrix} -3.6 = -4 \\ -3.6 = -3 \end{bmatrix}

\begin{bmatrix}
3.6 &\equiv 3 \\
3.6 &\equiv 4
\end{bmatrix}

                                                                                                          \lfloor a \div 2 \equiv 3, -3, 2, -2, 1
                                                                                                         a \div 2 = 4, -3, 3, -2, 2
                                                         7 \mid 21 \equiv 0
                                                                                                              2 \mid a = 2 \mid a \times a = 1, 0, 1, 0, 1
      7 \mid 19 \equiv 5
                                                       q \wedge P^0 \equiv 0, 0, 1
   p_0 \wedge q_0 \equiv 1
                                                                                                       q \wedge 2 \mid b \equiv q \equiv A_1^0 \wedge q
   p_0 \vee q_0 \equiv 1
                                                       q \vee P^0 = 1, 1, 1
                                                                                                       q \vee 2 \mid b = q
                                                    \sim q \wedge P^0 \equiv \bar{q} \vee \bar{P}^0 \equiv 1, 1, 0
\bar{q}_0 = \sim q_0 = 0
                                                      \hat{b} < A_1 \equiv 0, 0, 1
                                                                                                           q_0 \neq p \equiv \bar{p} \equiv \sim q_0 = p
   a_4 \leq b_0 = 1
                                                       2 < A_1 \equiv 0, 0, 1
```

$$P \stackrel{\triangle}{=} 2 4 6 8 10 \qquad P \stackrel{\triangle}{=} q = \sim P \stackrel{\vee}{\downarrow} q = 0, 1$$

$$P = (0, 1) \oplus (1, 0) \oplus (1, 1) = \epsilon^{1}(2) \oplus \epsilon^{0}(2) \oplus \epsilon^{0.1}(2)$$

$$A = \iota^{0}(3) \oplus \iota^{1}(3) \oplus \iota^{2}(3) \oplus \iota^{2}(3) \oplus \iota^{4}(3)$$

$$p, b = 1, 0, 1, 0, 1, 3, 2, 1 \qquad q/b = 3, 1$$

$$(2 \mid A^{0})/A^{1} = 2, 4 \qquad (a > 0)/a = 7, 5, 3$$

$$p/A = \begin{bmatrix} 0 & 2 & 4 \\ 1 & 3 & 5 \\ 2 & 4 & 6 \end{bmatrix} = A_{0,2,4}$$

$$q//A = \begin{bmatrix} 0 & 1 & 2 & 3 & 4 \\ 2 & 3 & 4 & 5 & 6 \end{bmatrix} = A^{0,2}$$

$$E/A = 0, 1, 2, 3, 4, 1, 2, 3, 4, 5, 2, 3, 4, 5, 6$$

$$E(4, 2) \setminus a, b = \begin{bmatrix} 7 - 6 \\ 5 - 4 \\ 3 & 3 \\ 2 & 1 \end{bmatrix}$$

 $/a; p; A^{0}/\equiv 0, -6, 2, -4, 4$  $/b; p_0; q/ \equiv q$  $a_{12(2)} \equiv 5, -4$  $a_{0,3,1} \equiv 7, -4, -6$  $b_q = 2, 3, 2$  $\alpha/p = 1, 0, 0, 0, 0$  $\alpha/\bar{c} = 1, 1, 0, 0, 0, 0, 0, 0$  $+/\alpha/\bar{n} =$  number of leading zeros in  $n = \nu n$  or index of leading 1 in n

For brevity, branch and specification statements are sometimes combined in the form

$$z: y \leftarrow x$$

implying that y is specified by x and is then compared with z to determine a branch.

The operand types and elementary operators employed are defined in Table 1, together with examples. These examples permit Table 1 to be studied by itself before proceeding to the more complex expressions in the programs.

In a compound expression such as

$$(x \times y + z) - q \wedge \sim r$$

the order of execution of the elementary operations is determined by parentheses in the usual way and any remaining ambiguity is resolved by proceeding from right to left, *no priorities* being accorded to multiplication or any other operator. This convention applies, in particular, to Table 1 itself.

The convenience of the right-to-left order of execution is indicated by the paucity of parentheses in the programs. As an example, consider line 5 of the *CPU* program:

$$\omega^{24}/p \leftarrow (24) \top 2 + \perp \omega^{24}/p$$
.

Proceeding from right to left, the last 24 bits of the vector p are selected, the base-2 value of the resulting vector is taken and added to 2, and finally the 24-bit representation of the sum respecifies the last 24 bits of p.

In complex logical expressions, the right-to-left convention permits convenient interpretation from left to right; for example, the expression

$$p \lor q \lor r \land s \land t = 3$$

is interpreted as indicated by the tree shown in Figure 1.

No elision of operator symbols is permitted; consequently, the names of variables can, without ambiguity, consist of any number of alphabetic characters, including spaces. For brevity, single characters are used for all variables except for those which occur infrequently, such as the panel switches occurring in CP, the control panel program. All variable names are in italics: light-face lower case for scalars, boldface lower case for vectors, and boldface upper case for matrices. Literal alphabetic values (e.g., "stop" and "operate" on lines 12 and 13 of the CP program) are denoted by roman type.

In order to reduce the number of variable symbols assigned to local counters and other intermediate variables, certain symbols (including i, j, k, i, j, and k) will be used only as local variables, i.e., the value of any such variable will be relevant only in the program in which it occurs and will not affect or be affected by any variable of the same name occurring in another program. A family of matrices will be denoted by a pre-superscript as, for

Figure 1 Tree representation of a compound statement



example, 'J, in line 20 of MAC' (j; k), the memory access program.

The system description comprises a set of tables and programs. Programs include system programs and defined operations. All system programs operate concurrently and continuously, with precisely one line active in each program at all times. This active line will often be a dwell of the form shown in Figure 2. The program breaks from the dwell only when the variable x is set to a nonzero value by some other program in the system.

A defined operation is a program which operates only when invoked by some other program. It can be distinguished from a system program by the presence of exit arrows. When called, a defined operation constitutes the active line of the program it is serving, and will itself have precisely one line active at a time until an exit is reached.

Variables occurring in the name of a defined operation (for example, j and k in the case of  $MAC^i(j;k)$ ) are dummy variables whose values are determined by the values of the variables occurring in any particular use of the defined operation. Thus, the performance of line d3 of EXC (that is,  $MAC^0$  ( $a_2$ , 2, f, d;  $\omega^{16}/R^{a_1}$ )) executes  $MAC^0$  with  $j=(a_2, 2, f, d)$  and with  $k=\omega^{16}/R^{a_1}$ . A study of MAC will show that this causes 2 bytes of data, fetched from the memory location starting at  $a_2$ , to be transferred to the last sixteen positions of the general register whose index is  $a_1$ .

All components of the formal system are listed in Table 2. The text and figures, and the tables not listed, are intended for exposition only.

Table 2 Components of formal description

| System p    | rograms                                   |                 |                 |                                  |            |
|-------------|-------------------------------------------|-----------------|-----------------|----------------------------------|------------|
|             |                                           | page            |                 |                                  | page       |
| BMT         | Burst-mode timer                          | 261             | HFC $c$         | Hardware failure in channels     | <b>261</b> |
| $CH^{c}$    | Channels                                  | <b>26</b> 1     | IOIE            | I/O interruption entry           | 261        |
| CP          | Control panel                             | 259             | IPL             | Initial program load             | 259        |
| CPU         | Central processing unit                   | 259             | MCIE            | Machine check interruption entry | 259        |
| EIE         | External interruption entry               | <b>259</b>      | T               | Timer                            | 259        |
| EP          | Emergency pull                            | 259             | $TOL^{c}$       | Time-out limiters                | 261        |
| ES          | External signals                          | 259             | TU              | Timer update                     | 259        |
| Defined o   | perations                                 | page            |                 |                                  | page       |
| DELA        | Y                                         | *               | MODEI           | L-DEPENDENT RESET                | *          |
| DIAGN       | IOSE                                      | *               | POWEI           | R-OFF SEQUENCE                   | *          |
| EXC         | Instruction execution                     | 240             | POWEI           | R-ON SEQUENCE                    | •          |
| MAC'        | j; k) Memory access                       | 259             | RESET           | •                                | <b>259</b> |
| MALF        | UNCTION RESET                             | *               | SYSTE           | M STOP                           | *          |
| * These ope | rations are not detailed in this descript | ion.            |                 |                                  |            |
| Tables      |                                           |                 |                 |                                  | page       |
| Table 3     | System reference table for pro            | grams and var   | riables: symbol | and dimension columns only       | 250        |
| Table 5     | Navigation matrix $N$ and refe            | rence table: fi | rst 11 columns  | (navigation matrix) only         | 256        |
| Table 6     | Operation decoding matrix O:              | numerical ent   | tries only      |                                  | 258        |

Figure 2 Dwell

x:0

# Table 4 Central processing unit

|                                      | CPU   |
|--------------------------------------|-------|
| Functions                            | lines |
| Initial-program-load<br>dwell        | 0     |
| Instruction fetch                    | 1-7   |
| Instruction interpre-                | 8-10  |
| tation                               |       |
| Effective address cal-<br>culation   | 11–19 |
| Instruction execution                | 20-21 |
| Entry of program interruption        | 22-24 |
| Interruption service                 | 25-33 |
| Single-step, stop, and<br>wait tests | 34–36 |

**CPU** program

instruction fetch (lines 1—7)

instruction interpretation (lines 8—10)

## The central processing unit

The central processing system comprises the nine system programs shown on page 259, and the defined operations listed in Table 2. An overall view of the system can be gained from Table 3, which lists all variables occurring in the programs, indicates the meaning or significance of each symbol and the dimensions of each vector or matrix variable, and provides reference to every program statement (or entire program) in which each variable is specified or used. Since the range of each variable is readily deduced from its use in the programs, ranges are not explicitly specified in the table. Most of the variables are logical (i.e., have the range 0, 1), but some, such as the components of a, m, and N, are not. The ranges of the components of some arrays (e.g., N) are not all alike.

Although Table 3 is designed for reference, it will also repay careful initial study. It shows, for example, that the memory M behaves as a 9-bit wide memory of at most  $2^{24}$  8-bit bytes with parity, that each block of  $2^{11}$  bytes of M may be protected by a 4-bit protection key  $K^i$ , and that 16 single-word general registers R and 4 double-word floating-point registers F are provided. All of the more detailed information on the treatment of the variables (such as the formats used in instruction addresses) is immediately available in the programs.

The core of the system is the CPU program, which describes the sequencing and execution of instructions and the servicing of interruptions. The functional segments of this program are listed in Table 4.

An instruction may be 1, 2, or 3 half-words long and is fetched by lines 3-7 (using the MAC operation detailed on page 259), two bytes at a time, from memory locations specified by the instruction counter represented by  $\omega^{24}/p$ , the last 24 bits of the program status word p. For each half-word fetched, the instruction length code  $(p_{32,33})$  is augmented by 1 (line 4) and the instruction address by 2. The sum of the first 2 bits of the first half-word plus 1 determines (on line 7) the number of half-words fetched.

Line 2 enters a specification exception if the protection feature is not installed ( $m_0 = 0$ ) and any of positions 8-11 of p are nonzero. Addressing and specification exceptions are detected by lines 7-8 of the MAC operation and are entered (MAC line 15) into  $t_5$  and  $t_6$ , respectively. Either of these errors subsequently causes a branch from CPU line 6 to line 24, skipping the instruction execution phase and any remaining portion of the fetch.

If the fetch concludes without error, lines 8-9 interpret the instruction by selecting from the navigation matrix N (Table 5) a row  $N^i$  to specify the vector n used in the subsequent control of the instruction execution phase. The row of N selected is determined by the particular element of the operation decoding matrix O (Table 6) selected by the 8-bit operation code in the first byte of the instruction. Table 6 displays the mnemonics

used for the instructions as well as the index to N, which is the only formal part of the matrix O. Similarly, Table 5 includes much informal information in addition to the formal specification of the matrix N.

Except for its first two components, the navigation vector n is of formal interest only, since the sequences it determines in the CPU program (line 11) and in the EXC operation are also indicated informally by broken-line arrows and labels. If the 8-bit operation code corresponds to no installed operation, then  $n_0 = 0$  and an operation exception exists (line 10); if the operation is privileged ( $n_1 = 1$ ) and if  $p_{15} = 1$  (that is, the processor is in the problem state as opposed to the supervisor state), a privileged operation exception exists.

The manner of specifying the operands of an instruction is a function of the format of that instruction. Most instructions specify two operands; the effective addresses of the first and second operands are computed as  $a_1$  and  $a_2$ , respectively. Normally, the addresses are used to select two general registers (RR format), a register and storage in memory (RS), a register and storage with a second register for indexing (RX), two areas in storage (SS) or storage and immediate data from the instruction itself (SI), all as indicated in Table 7. However, since many exceptions exist, Table 7 should be considered as a guide only, all operands being explicitly defined in EXC. Some instructions in the RS format use a third address  $a_3$ . A terminal R and a terminal I in instruction mnemonics usually indicate the RR and SI formats, respectively.

For instructions in the SS format, the lengths of the operands are defined by line 17;  $l_1 + 1$  and  $l_2 + 1$  are the lengths (in bytes) of the first and second operands, and  $l_0 + 1$  is the length for some instructions in which a single length is required. Again, the matrix N (and hence n) provides (via CPU line 11) the formal specification of the format used by each instruction.

The calculation of the effective addresses is straightforward and will be discussed only for the RX and RS cases. In the latter case, the second operand address  $a_2$  is determined by the second half-word of the instruction and is formed by adding to the value of its last 12 bits  $(\perp \omega^{12}/I^1)$  the value of the general register selected by its first 4 bits  $(\perp R^{\perp \alpha^*/I^*})$ , unless the zeroth register is selected  $(0 = \perp \alpha^4/I^1)$ , in which case zero is added. Finally, the residue of this sum modulo  $2^{24}$  specifies  $a_2$ . The first and third operand addresses are determined by the values of groups of 4 bits in the first half-word,  $\perp \alpha^4/\omega^4/I^0$  and  $\perp \omega^4/I^0$ , respectively. The RX format differs only in that the index quantity contained in the general register selected by the last 4 bits of the first half-word is (again, unless the zeroth register is selected) also added to the sum used to determine  $a_2$ , and in that the third address is not applicable.

The calculation of the effective address is immediately followed by a use of the defined operation EXC on line 20. This operation begins with a branch from line 0 to line  $n_3$ , that is, to the segment

effective address calculation (lines 11—19)

instruction execution (lines 20—21)

of the EXC operation appropriate to the particular instruction being executed. For example, if the instruction is LR, then  $n_3$  is specified by  $N_3^{71}$ , and  $n_3 = d0$ . This is also indicated informally by the "LR" written to the left of line d0.

To continue the example, line d0 specifies the value of general register  $R^{a_1}$  by the value of  $R^{a_2}$ , and the exit arrow on the same line indicates that EXC is complete.

The execute instruction (EX) beginning on line b0, furnishes a somewhat more complex example of the execution phase. Except that the length code  $p_{32,33}$  and the instruction counter  $\omega^{24}/p$  are not disturbed, lines b0-3 are like the instruction fetch (CPU 3-7) and therefore load the instruction register with the data beginning at byte address  $a_2$  in memory. Since  $n_3 = b0$  in this case, line 21 of CPU subsequently causes (unless a program interruption has been entered in t, either on line b5 or by use of MAC on line b1) a branch to line 8, thus interpreting and executing the instruction just fetched by the ex instruction, without disturbing the instruction counter. If this subject instruction is itself an Ex. it has the operation code 0100 0100, and line b5 therefore enters an execute exception and line 21 does not cause a branch, thus aborting the execution of the subject ex instruction. The phrase  $\bar{t}_5 \wedge \bar{t}_6$  in line b5 prevents a spurious execute exception if addressing or specification exceptions have already occurred.

If the first operand address of EX is nonzero, then line b4 will or the last byte of general register  $R^{a_1}$  with the last byte of the first half-word of the subject instruction. This permits a programmer to specify such parameters as length, index, or immediate data in the subject instruction indirectly via  $R^{a_1}$ .

If no program interruption has been generated by the preceding fetch and execution, each component of t will be zero, and lines 23 and 24 will be skipped. Otherwise line 24 presents the interruption by setting  $h_1$  to 1 and entering an appropriate code in positions 16-31 of p. Thus, if the interruption is occasioned by an addressing exception,  $t_5 = 1$ , the expression  $t/\tau^0$  yields 5, and its base 2 representation (namely, 0000 0000 0000 0101) is entered in p. If multiple causes of program interruption occur, then one of the appropriate codes will be selected at random and stored in p. For example, if  $t_5 = t_6 = 1$ , then  $t/\tau^0 = (5, 6)$  and  $t/\tau^0 = (5, 6)$  selects one of 5 and 6.

If the cause of the program interruption entry is neither  $t_4$  nor  $t_5$  (that is, neither a protection nor an addressing exception), then the instruction length code  $p_{32,33}$  is unchanged by line 23; otherwise line 23 may set the length code to zero.

Other types of interruptions are entered in other components of h by other programs (listed in the reference column of Table 3) whose details will be considered later.

An interruption service places an appropriate code in bits 16-31 of p, stores p in memory at one of five fixed locations determined by the type of interruption (line 31), and finally respecifies p (line 32) from one of five other fixed memory locations. Since

entry of program interruption (lines 22—24)

interruption service (lines 25—33)

this respecifies the instruction counter  $\omega^{24}/p$ , it occasions an alteration in the normal sequence of instructions.

Interruption servicing is skipped if the expression

$$\vee/h \wedge (0, 1, 1, p_7, (\alpha^7/p) \times B_8)$$

(line 25) has the value zero. The vector  $(0, 1, 1, p_7, (\alpha^7/p) \times B_8)$  is therefore a mask which causes certain components of h to be ignored. Thus  $h_0$  (machine check interruption) is always ignored at this point,  $h_1$  and  $h_2$  (program and supervisor call interruptions) never are,  $h_3$  (external) is ignored if  $p_7 = 0$ , and  $h_4$  (I/O) is ignored unless an interruption is being presented (in  $B_8$ ) by one of the channels for which the corresponding mask bit in  $\alpha^7/p$  is set to 1.

If there is an acceptable interruption, then line 26 determines h as the index (in h) of the interruption to be serviced. The queue discipline in h is not first-in first-out but rather strict priority (according to position in h) of the unmasked components of h presented.

If h = 0, 3, or 4 (machine check, external, or I/O), then  $g_0$  is set to signal the appropriate program (MCIE, EIE, or IOIE) to enter the appropriate data in bits 16–31 of p, while the CPU program dwells on line 28. Then the accepted interruption indication is reset on line 29. In certain situations, an I/O channel is unable to present an indicated interruption at the time it is accepted by the CPU; this is signalled by the IOIE program by setting  $g_1$  to 1 before resetting  $g_0$  to 0, thus aborting the interruption by the branch on line 30. In any event, line 25 is executed again so that all outstanding unmasked interruptions are serviced in turn before continuing to line 34.

Whenever the program status word p is loaded from memory, bits 16-33 (the interruption code and instruction length code) are indeterminate as shown by CPU 33, IPL 8, and EXC a26.

If the operating state is set to "stop", then the CPU dwells on line 35 with the manual light "on". Events which set the operating state are listed in Table 3. These include line 34 of the CPU which sets it to "stop" if the rate switch is not set to "process", e.g., if set to "single-step".

Subsequent to the dwell on line 35, the behavior is determined by the wait bit  $p_{14}$ ; if  $p_{14} = 0$ , the wait light is turned "off" and the next instruction fetch is begun (branch from line 36 to line 1); if  $p_{14} = 1$ , the wait light is turned "on" and the interruption service phase is entered at line 25. Hence if  $p_{14} = 1$ , the CPU "waits", executing no further instructions until an external or I/O interruption or initial program load replaces p with a value such that  $p_{14} = 0$ .

The computer memory is initially loaded by the IPL program which resets (line 1) the CPU to the dwell at line 0, where it remains until the loading (effected by an I/O channel) is complete, as signalled by the setting of the variable ipl to zero. The branch to line 25 shows that when loading is complete, operation is resumed with interruption service rather than with the instruction fetch.

single-step, stop and wait tests (lines 34—36)

initial-programload dwell (line 0) memory access operation

The MAC operation, which occurs in the instruction fetch and throughout the EXC operation, serves to fetch from or store in memory a specified number of bytes beginning at a specified address. Because it incorporates certain tests and other functions, it warrants a detailed scrutiny.

The general form of the MAC operation is  $MAC^{i}$  (j; k), where i specifies one of nine identical but independent MAC programs, i = 9 for the CPU memory-access, i = 8 for the interval timer, and i = 0-6 for the channels; where k is the vector involved in the transfer to or from memory; and where j is a four-component vector specifying the address in memory  $(j_0)$ , the number of bytes transferred  $(j_1)$ , the performance of a fetch  $(j_2 = f)$  or store  $(j_2 = s)$ , and the type of address being treated  $(j_3 = d)$  for data address, i for instruction address, i for a machinegenerated [i.e., fixed] address, and i for hold, which prevents any of the other  $MAC^{i}$  programs from operating until the current  $MAC^{i}$  program has been used again with  $j_3 \neq h$ ).

memory access priority

Since the several  $MAC^i$  programs all use the same memory, they must observe a queue discipline. It is controlled by the queue vector  $\mathbf{q}$  and the request vector  $\mathbf{r}$ . When  $MAC^i$  is invoked by any system program (e.g.,  $MAC^0$  in CPU line 3), then a request for service is entered (line 0) by setting  $\mathbf{r}_i$  to 1. If the queue is empty, the request is also entered in  $\mathbf{q}_i$ . In any case, the  $MAC^i$  program dwells on line 1 until i is recognized as the "first" nonzero entry in the queue. The queue discipline is not first-in first-out, but is in order by position in a permutation of  $\mathbf{q}$  specified by the vector  $\mathbf{rank}$ , which gives priority according to the index i, except that i = 0 (the multiplexor channel) may be assigned out of order. This implies that the channels have priority over the interval timer which has priority over the CPU.

Any request for service which is not entered directly in q on line 0 is entered from r by line 24. If  $j_3 \neq h$ , then q is respecified by r (with  $r_i$  already set to zero by line 2) except that a CPU request is entered in  $q_0$  only if w=0. The variable w is controlled (line 2) only by  $MAC^8$ , the timer update memory-access, and it remains at 0 or 1 according to whether the last use of  $MAC^8$  was for a store or for a fetch. This excludes the CPU from memory during the updating of the interval counter (TU lines 1, 3) and prevents the inadvertent overwriting (by TU line 3) of a new setting of the interval timer counter by a CPU "store" instruction. However, the use of memory by I/O is not excluded by w.

If  $j_3 = h$ , line 24 leaves q unchanged and therefore prevents any other MAC from being executed until after the next use of the same MAC with  $j_3 \neq h$ . The use of  $j_3 = h$  occurs only in the instruction TS (test and set) as follows (EXC lines a29, 30)

$$MAC^{9}(a_{1}, 1, f, h; u)$$
  
 $MAC^{9}(a_{1}, 1, s, d; \epsilon(8)).$ 

Thus, the addressed byte is set immediately following a test of its value, before any other access to memory can occur.

The first  $2^{12}$  bytes of memory are normally used for special purposes by the machine (e.g., 48, 40, 32, 24, and 56 are used to store p on line 31 of the CPU program) and by the supervisory program. Any address  $j_0$  in this region is automatically prefixed (MAC lines 3,4) by a 12-bit prefix selected from either the main or alternate prefix (having wired-in values) according to the setting of the prefix trigger, which is set during the initial program loading (IPL line 3). It must be emphasized that every memory address (including those used in I/O) below  $2^{12}$  is modified in this way, although this fact will not be referred to again in the text.

The effect of line 6 is to set the operating state to "stop" if all but the last bits of the address switch on the console agree with the specified address  $j_0$ , but line 6 is skipped if the address compare switch is on "normal" or if it is set to "instruction" and  $j_3$  does not specify that  $j_0$  is an instruction address.

Lines 7-11 specify three types of exception conditions. A specification exception is indicated (line 7) if the address  $j_0$  is not divisible by the number of bytes  $j_1$ . An addressing exception is indicated (line 8) if the address  $j_0$  exceeds the size of memory, and in this event the address  $j_0$  is respecified for all subsequent purposes by an arbitrary value within the range of the memory (line 9). A protection exception is indicated (lines 10,11) if the machine has the protection feature ( $m_0 = 1$ ) and the memory-access is of the store data type ( $j_{2,3} = s$ , d) and the keys  $u_0$  and  $u_1$  differ and neither is zero, where  $u_0$  is the protection key in the memory bank addressed by  $j_0$ , and  $u_1$  is either the protection key in p (in the case of a CPU memory-access) or the protection key in the appropriate channel address word (in an I/O memory-access).

If there are multiple exceptions, line 13 chooses some one of them to enter into s and thence into the program exceptions vector t (in the case of CPU or timer memory-access) or in the channel status word S' (in the case of a channel). If the error is a specification exception ( $s_0 = 1$ ) or if the operation is a store, then line 17 skips all further steps except to respecify the queue (line 24). Otherwise, i.e., on a fetch operation with an addressing exception, in which the address  $j_0$  has been respecified arbitrarily (line 9), the (meaningless) fetch from memory proceeds.

If no exception occurs, or if a machine-generated address is being treated, line 12 skips the entry of exceptions, branching directly to line 18 which chooses line 23 for store and 19 for fetch. Line 23 stores the specified vector k together with the appropriate parity bits in the specified rows of M. Line 19 fetches the appropriate rows of M to specify the matrix  $^{i}J$ . The row list of the last 8 columns of  $^{i}J$  specifies k, and the parity bits are available (e.g. to the channel) in  $^{i}J_{0}$ . In the case of a CPU or a TU memory-access, line 22 checks the parity of the data fetched from memory and signals an error by setting component 9 or 8 of the machine failure vector f.

address modification and comparison

exceptions

other central processing system programs

control panel and emergency pull programs

external interruption entry program

machine check interruption entry program

The details of the control panel, the interruption entries, the interval timer, the initial program load, and the EXC operation will now be treated in that order. At this point, however, the reader should be equally prepared to approach them in any other desired order. It must be re-emphasized that all system programs, including the CPU program, run concurrently.

The normal dwell of the CP program (lines 4,5) is broken by depression of the power-off key (line 4) or by depression of a console button  $b_i$  or by a pulse on one of the IPL in-lines  $e_4$  or  $e_5$ . Line 6 determines b as the index (with respect to  $e_4$ ,  $e_5$ , b) of the signal to be serviced, line 7 dwells until the signal returns to zero, and line 8 branches to the appropriate program segment.

The last four buttons are ineffective if the machine is in the "operate" state (line 13), but otherwise perform the straightforward functions detailed in lines 15–25. The stop key (line 12) causes the CPU to dwell the next time it reaches line 35; the interrupt key sets the console interrupt which (as indicated in Table 3) is used in the EIE program to enter an external interruption; the IPL in-lines, the load key and the reset key all reset the system (line 9), and all but the latter set ipl, releasing the IPL program from its normal dwell.

The *EP* program serves to stop the entire system until the *emergency pull switch* is restored, whereupon it sets the *CP* program to line 1, to dwell until the *power-on key* is depressed.

The timing signal in-lines  $\omega^6/E^3$  are momentary pulses ( $\frac{1}{2}$  to 1 microsecond) supplied from some data transmission line, perhaps the output signals  $E^2$  of some co-operating computer. The ES program shows the latches external signals being set by  $\omega^6/E^3$ . Similarly, EIE shows the timer alarm, console interrupt, and external signals being entered as interruptions. If any of these signals appear, EIE line 0 sets  $h_3$ . The CPU program will eventually recognize  $h_3$  and set h=3 and  $g_0=1$  (lines 26,27), thus breaking the dwell on lines 0 and 1 of the EIE program. Line 2 then enters the eight external interruptions in p and line 3 resets those signals entered, but does not reset any which may have come on during the brief interval since the entry operation on the preceding line. The reset of  $g_0$  on line 4 frees the CPU from its dwell on line 28.

The entry of a machine check (i.e., a hardware failure) is radically different, since, after setting  $h_0$ , it preempts the CPU by causing a branch to CPU line 26. The MCIE program also sends a momentary signal on the machine-check out-line  $e_3$  (which may be connected as an input to some co-operating computer), enters zeros as the interruption code in p, performs a diagnosis, stores certain machine registers (referred to as cpu status) in memory beginning at byte 128, and finally resets  $g_0$  (to free the CPU), the failure vector f, and any outstanding program and supervisor call interruptions (but not external or I/O interruptions). The machine failure is serviced (line 0) only when the machine check mask  $p_{13} = 1$ .

Indications of machine failure are entered in f from various sources, but only two are shown in this description. One occurs on line 4 of HFC for hardware failures in certain I/O channels. The second occurs on line 22 of MAC, and detects parity errors in data fetched from memory for the CPU or the interval timer. Parity checks are also made on R, F, and p, and at other points, but none of these are shown explicitly in the programs. Their inclusion would merely encumber the description.

The TU program is activated by the signal tick from the T program, but only if the CPU is not stopped at the dwell on lines 36-37, the rate switch is set to "process", and an RDD (read direct) instruction is not awaiting a hold-in signal on  $e_2$ . When activated, line 1 fetches the four bytes representing the interval timer counter, line 2 decreases it (modulo  $2^{32}$ ) by an amount dependent on the timer frequency which drives the T program, line 3 restores the new count to memory, and line 4 sets the timer alarm if the count has passed through zero. The execution of  $MAC^8$  on lines 1 and 3 will, of course, be deferred until all I/O requests for memory access have been serviced. Moreover, no CPU memory-access can intervene between TU lines 1 and 3 (see MAC lines 2, 24).

The IPL program dwells at line 0 until ipl (set only by CP line 10) becomes 1, whereupon the CPU is forced to its dwell at line 0, and the  $load\ light$  is turned "on". The further behavior depends upon which agency (IPL in-lines or load key) initiated the action. If it were the load key, the program would dwell (line 5) awaiting a satisfactory error-free channel-end signal from the I/O unit designated by the setting of the  $load\ unit\ switch$ , store  $load\ unit\ switch$  in memory at address 2, and load p from memory at address 0. If the initiating agency were one of the IPL in-lines, only the loading of p would be performed.

If a machine failure occurs in the loading, the *IPL* program dwells on line 9, regardless of the value of the machine check mask; otherwise, line 10 turns the load light to "off", the operating state to "operate", and ipl to zero. The role of I/O in the initial program load will be clarified in the third section; here it will suffice to remark that the I/O channels are reset by the *RESET* occurring on line 9 of the *CP* program, and the I/O unit designated by the load unit switch then begins to perform a read.

The 143 machine instructions described by the defined operation *EXC* are grouped in twelve families. Because there is little interaction with other programs, the interpretation is straightforward, and textual comment will therefore be limited to the more difficult cases.

Table 5 can facilitate reference in many ways. The final columns indicate the effect of each type of interruption on each instruction; it may *suppress* the instruction so that none of the result variables are affected, *terminate* it after some but not necessarily all of the results are respecified (and all results must be

timer and timer update programs

initial-program-load program

instruction execution operation considered unreliable), or allow it to *complete*. Since a protection exception  $t_4$  is occasioned only by storing in memory, the corresponding column of Table 5 can be used to identify all "store" type instructions; similarly, column  $t_5$  identifies all instructions which refer to memory. Other columns of Table 5 identify those instructions which set the condition code, general registers, and floating point registers.

status switching, read/write direct, diagnose (lines a0—34) ssm (set system mask) is a privileged operation executable only in the supervisor mode ( $p_{15} = 0$ ) as shown by the exit on line a1 and the setting of  $t_2$  on CPU line 10. Isk (insert storage key) and ssk (set storage key) are also privileged and are also suppressed (line a4) if the protection feature is not installed (that is,  $m_0 = 0$  and hence  $t_1 = \overline{n}_0 = \overline{m}_0 = 1$ ), if the address  $\pm \omega^{24}/R^{a_2}$  is outside the range of the memory, or if any of the last 4 bits of  $R^{a_2}$  are nonzero.

These last 4 bits of  $R^{a_2}$  are not otherwise relevant to ISK and SSK (see lines a6, 7) and the specification error test is intended to prevent the programmer from using them for other purposes, and hence to reserve them for use in possible modifications of SYSTEM/360, such as an extension of the length of the protection keys. The devious programmer can, of course, use a nonzero final half-byte in  $R^{a_2}$  to force a specification exception, but the prudent programmer will not. Similar tests will be found elsewhere (e.g., on the format of channel commands) and serve a similar function.

Since ssm, ssk, and isk are privileged instructions, only the supervisor program can set the system mask or set or refer to the memory protection keys  $K^i$ . spm (set program mask) is not privileged.

WRD (write direct) transfers one byte from memory to the direct control out-lines  $E^0$  and the immediate data byte from the instruction register to the timing signal out-lines  $E^2$ , and sets the write-out signal  $e_0$  to 1. The signals  $E^2$  and  $e_0$  are momentary;  $E^0$  remains unchanged until another WRD is executed. The test for suppression of the instruction (line a9) includes the term  $t_1$  because the direct control feature is optional and may not be installed, and the term  $t_2$  because WRD is privileged. Except for the dwell on line a17, the behavior of RDD (read direct) is similar. Normally, the outputs  $E^0$  and  $E^2$  of one computer are connected into the inputs  $E^1$  and  $E^3$  of a co-operating computer. Programs ES and EIE enter any nonzero signal on  $E^3$  as an interruption.

The diagnose instruction is privileged (as indicated by the presence of  $t_2$  on line a20) and may also be suppressed by an unsatisfactory address  $a_1$ . It performs a certain diagnosis of the hardware and then, for certain models, loads p using 8 bytes beginning at 112. LPSW (load program status word), which is also privileged, performs a similar load from memory at address  $a_1$ .

svc (supervisor call) forces an interruption by setting  $h_2$ ; the interruption code is the immediate data byte  $\omega^8/I^0$ , prefixed by 8 zeros.

Ts (test and set) simply fetches one byte u from memory (a29), sets the condition code to  $(0, u_0)$ , and sets the same byte in memory to all 1's. The significant characteristic of this instruction is that (because of the "hold" h in the first use of MAC) it sets the tested byte in memory before any other reference to memory can occur.

EX (execute) was discussed in conjunction with the CPU program. TM (test under mask) sets the condition code as shown on line b7. Thus, the code is (0, 0) if the immediate data byte  $(\omega^8/I^0)$  is entirely zero; otherwise, the first bit is set to 1 if all bits of  $(\omega^8/I^0)/u$  are 1, whereas the second bit is set if any bit of  $(\omega^8/I^0)/u$  is 1. The expression  $(\omega^8/I^0)/u$  denotes the components of the byte u from memory which are extracted by the nonzero bits of the immediate data byte.

The branch instructions set the instruction counter  $\omega^{24}/p$  conditionally as shown, and can therefore be used to alter the normal sequence of instruction execution. A full appreciation of BXH (branch on index high) and BXLE depends upon a knowledge of the 2's complement representation of signed numbers, which is also used in the fixed-point arithmetic instructions.

A logical vector (register)  $\boldsymbol{u}$  of dimension d represents any integer n in the range  $-2^{d-1}$  to  $2^{d-1}-1$  in the form

$$n = (\perp \mathbf{u}) - \mathbf{u}_0 \times 2^d.$$

For example, if d=3 the representation scheme is given in Table 8.

It is easily verified that the representation of a number n in the appropriate range is given by the statement

$$\boldsymbol{u} \leftarrow /(d) \top n; (n < 0); \sim (d) \top |n + 1/.$$

Arithmetic operations (such as the summation occurring in BXH (line b20)) may, however, produce a result outside the representable range. The representation shown above is, however, used even in this case. The matter is illustrated in Table 9 by examples computed for a dimension d=4.

For the BXH instruction, lines b17-19 show the specification of  $k_0$ ,  $k_1$ , and  $k_2$  as the signed numbers represented in general registers  $a_1$ ,  $a_3$ , and either  $a_3 + 1$  (if  $a_3$  is even) or  $a_3$  (if  $a_3$  is odd). Register  $a_1$  is then respecified by the 2's complement representation of the sum  $k_0 + k_1$ . The value of this result is compared with  $k_2$  (line b23) to determine whether to branch to  $a_2$ .

The four I/O instructions are all privileged (line c0), determine a channel address from the first three of the last eleven bits of the first operand address, test whether the indicated channel is operational (line c2), and conclude by setting the condition code to (1, 1) if it is not. If the channel selected is the multiplexor channel (i = 0) and a "burst mode" timer has not run out, then c5 dwells for a maximum of about 100 microseconds before testing (line c6) whether the channel is busy.

If the channel is busy, the condition code is set to (1, 0) on

branches, execute, test under mask (lines b0—24)

Table 8

| <i>n</i> | u     |
|----------|-------|
| 3        | 0 1 1 |
| $^2$     | 0 1 0 |
| 1        | 0 0 1 |
| 0        | 0 0 0 |
| -1       | 1 1 1 |
| -2       | 1 1 0 |
| -3       | 1 0 1 |
| -4       | 100   |

Table 9

| - Tuble 7                                                                                                  |                                                                |                                                                                               |
|------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| n                                                                                                          | Repre-<br>senta-<br>tion                                       | Inter-<br>preta-<br>tion                                                                      |
| $ \begin{array}{r} 2^{3} + 1 \\ 2^{3} \\ 2^{3} - 1 \\ -2^{3} \\ -(2^{3} + 1) \\ -(2^{3} + 2) \end{array} $ | 1 0 0 1<br>1 0 0 0<br>0 1 1 1<br>1 0 0 0<br>0 1 1 1<br>0 1 1 0 | $   \begin{array}{r}     -6 \\     -7 \\     +7 \\     -8 \\     +7 \\     +6   \end{array} $ |
|                                                                                                            |                                                                |                                                                                               |

input/output (lines c0—15)

line c7, and all instructions but Hio (halt I/O) conclude; Hio proceeds to signal the channel to stop by setting  $B_{10}^i$  and then dwells until the channel resets it to zero.

If the channel is not busy, line c11 branches to conclude on line c12 for TCH (test channel), and otherwise to set  $B_{10}^i$  and dwell (c14, 15) awaiting a response from the channel. The dwell endures until either  $B_{10}^i$  is reset by the channel or until (in the case of the multiplexor channel only) the channel becomes busy ( $B_0^i = 1$ ). The latter case is followed by a repetition of the sequence from line c4. This repetition could recur many times due to short bursts of activity in the multiplexor channel instigated by I/O units already in operation. Further discussion of the I/O instructions will be deferred to the third section.

load and store general registers (lines d0—24) LH (load halfword) loads the last two bytes of  $R^{a_1}$  from memory and then, unless a specification exception has occurred in the fetch from memory, extends the sign bit  $R^{a_1}_{16}$  to the left to give the correct 2's complement representation in the entire register.

LPR (load positive), LNR (load negative), LTR (load and test) and LCR (load complement) illustrate the use of the 2's complement representation. Since line d11 sets the condition code to (1, 1) only in the event of overflow, line d12 indicates a fixed point overflow only if the overflow mask  $p_{36} = 1$ .

STM (store multiple) stores a number of general registers beginning with  $a_1$  and continuing in cyclic order through register  $a_3$ . A specification exception suppresses the instruction since it occurs on the first execution of line d14 before any data has been transferred, but in the event of either a protection or addressing exception all of the result field becomes unreliable (d19-24). LM (load multiple) behaves similarly except that a protection exception cannot occur.

shifts (lines e0—15) All single-length shifts operate on  $R^{a_1}$ ; all double-length shifts operate on the combined quantity  $R^{a_1}$ ,  $R^{a_1+1}$  and cause a specification error (which suppresses the instruction) if  $a_1$  is odd. The amount of shift is the residue modulo 64 of  $a_2$ ; zeros are introduced in the evacuated positions for all except the arithmetic right shifts.

All of the arithmetic shifts shift the entire quantity except the first bit (e8, 10) and set the condition code to (0, 1), (0, 0), or (1, 0) according as the result is <, =, or > zero, except that the left shifts set it to (1, 1) if a significant digit (i.e., in the 2's complement representation, one which differs from the leading bit) is lost in the shift (e7). In this event the left shifts also set a fixed point overflow exception (e9) if mask  $p_{36} = 1$ . The right shifts extend the sign bit (e11) to fill evacuated positions to give the correct representation of the result in 2's complement form.

This family comprises four operations (compare logical, or, and, and exclusive-or) in four formats (RX, RR, SI, and SS). The first three formats are treated in lines f0-13. cl, clr, and cli merely set the condition code (f7); the rest perform the appropriate logical operation (f8) and set the condition code as shown on line f13, except that in the SI format the setting of the condition code

logical operations, compare logical (lines f0—32) is suppressed (f12) by a protection or addressing exception.

The SS format for logical operations (f14-32) operates byteby-byte from left to right. As in the LM and STM instructions, a protection or addressing exception will make the entire result field and the condition code unreliable (f27-32).

The instructions in this group treat the operands byte-by-byte, the first three (MVO, PACK, UNPK) in right-to-left order and the rest left-to-right. The single-byte uses of MAC involved cannot produce a specification exception; protection or addressing exceptions make unreliable the entire result field in memory, as well as the condition code when it is a result.

MVO (move with offset) moves the second field to the first field, off-setting it one-half byte to the left to leave the rightmost half-byte of the result field unchanged. Zero fill occurs (g9, 10) when the source field is exhausted, and conclusion occurs (g6) when the result field is exhausted.

PACK converts a decimal number in zoned format (one digit per byte with  $\alpha^4/byte$  as the zone bits, except for the low-order byte in which  $\alpha^4/byte$  represents the sign) into packed format (two digits per byte, namely,  $\alpha^4/byte$  and  $\omega^4/byte$ , except for the low-order byte in which  $\omega^4/byte$  represents the sign). Five operations, selected by the variable i (line g15), are used in constructing the packed bytes as follows:

- 0 the sign and digit of the low-order byte are interchanged;
- 1 the digit is placed in the right half of the byte;
- 2 the digit is placed in the left half of the byte;
- 3 a zero digit is placed in the left half of the byte;
- 4 zero digits are placed in both halves of the byte.

The variable i respecifies itself (line g16) by the ith component of (4, 3, 4, 4, 4) if the source field is exhausted, or by (1, 2, 1, -, -), if it is not. The process ends (g21) when the result field is completed.

UNPK (unpack) performs the operation converse to PACK. The program is analogous but simpler, since i has only four states.

The remaining instructions in this group scan the fields from left to right. TRT (translate and test) uses successive bytes from the first field as relative addresses in the second field until the byte fetched therefrom is nonzero; this byte and the current address to the first field are then stored in  $R^2$  and  $R^1$ , respectively (g43), and the condition code is set. TR (translate) replaces each byte of the first field by its correspondent selected from the second field. Mvz (for which  $I_6^0 = 1$ ) moves only the zone portion (i.e., the left half) of each byte; MvN moves the numeric portion.

ED uses the first field both as result and as a pattern to select successive bytes from the second source field and from a fill byte specified (h13) by the first byte of the pattern field. Each pattern byte is classified (h12) as "digit select", "significance start", "field separator", or "other" (class = 0, 1, 2, or 3); class then controls the subsequent assembly of the result byte.

move, pack, translate (lines g0—62)

edit (lines h0-37)

Except for a byte with a sign (i.e., a non-numeric right half), bytes from the source field are used one half-byte at a time, each half being prefixed by a standard zone j selected by  $p_{12}$  (lines h2, 17–22). The source byte thus constructed is used (h24–26) only if the numeric part is nonzero or if the current portion of the field is already significant (s = 1); otherwise the fill byte is used. The byte is constructed, and the source field is advanced, only when the class of the pattern byte is either a "digit select" or a "significance start" (h14). If the class is "other" and s = 1, the pattern byte is left unchanged (h15); otherwise the fill byte is inserted (h16).

The significance trigger s is set only on line h8. It is set to zero if j=0, that is, at the outset (h1) and also if the last byte used was from the source field and the numeric part was a plus sign (h9, 23). If j=1, then s is set according to the class of the preceding pattern byte, s changing from 1 to 0 only in the case of a "field separator" (class = 2), and from 0 to 1 only in the case of "significance start" (class = 1) or in the case of "digit select" if the last byte was chosen from the source field and was nonzero, as seen from the setting of  $\boldsymbol{u}$  on lines h10 and h21.

The final setting of the condition code is determined (h3) by s and i. The latter is set by a nonzero digit (h27) and reset (h7) by a "field separator." A data exception ( $t_7$ ) occurs if the left half of a source byte is non-numeric (h20), and terminates (h4) in the manner of protection and addressing exceptions. Since ED is an optional (decimal) feature, it is aborted (h0) if  $t_1 = 1$ , and is treated as an "undefined operation" by branching to line 10. EDMK (edit and mark) differs only in that the byte address of the first nonzero digit in the last nonzero field is entered (h30) in  $\mathbb{R}^1$ .

In this group of instructions, the first operand is taken from one or two general registers, determined by  $a_1$ . The second operand is chosen as  $R^{a_2}$  for the RR format instructions, as 2 bytes from memory at  $a_2$  for the half-word instructions, or as 4 bytes from memory for all others.

The arguments  $k_1$  and  $k_2$  are derived from the operands in two ways: as the base-2 value (i5, 16) in the "logical" group AL, ALR, SL, SLR, and as the 2's complement value (i4, 10) for all others.

A specification exception suppresses the instruction (i10). An addressing exception makes the result k questionable (i11, 12); otherwise k is the true result of the appropriate arithmetic operation on  $k_1$  and  $k_2$  (line i17).

The specification of the final result is illustrated by line i19. The treatment of results outside the representable range has already been discussed in the section devoted to branch instructions. The setting of the condition code and the exception conditions  $t_8$  and  $t_9$  is straightforward.

The intermediate result k is obtained (j22) by applying the appropriate arithmetic operation to the arguments  $k_1$  and  $k_2$  or,

fixed-point arithmetic (lines i0—30)

decimal arithmetic

in the case of ZAP (zero and add) and CVB (convert to binary), by using the single argument  $k_2$  directly. CVD also involves a single argument only (i1).

convert (lines j0--55

The argument  $k_i$  is determined (j19) as the signed base-10 value of the vector  $\mathbf{\sigma}^1/\mathbf{v}$  of decimal digits,  $\mathbf{v}$  being assembled (j15) by catenating the base-2 values of half-bytes from field i. The last half-byte determines the sign (j19), a negative sign being represented by 13 (that is, 1101) in the extended BCD code ( $\mathbf{p}_{12} = 0$ ), and by 11 in the American Standard code. For example, if  $\mathbf{p}_{12} = 0$ ,  $\mathbf{l}_1 = 1$  and the bytes at  $\mathbf{M}^{a_1}$  and  $\mathbf{M}^{a_{1+1}}$  are 0101 0000 and 1001 1101, respectively, then  $\mathbf{v} = 5$ , 0, 9, 13, and  $\mathbf{k}_1 = -509$ .

The result k is converted to the decimal representation and stored (j34-42) and, except for DP (divide decimal), the operations end on line j43. Because of the setting of j on line j33, the quotient k is stored only in the first  $(l_1 + 1) - (l_2 + 1)$  bytes of the first field, leaving space of length  $(l_2 + 1)$  for the remainder, which is computed on line j47 and converted and stored by repeating from line j35.

CVD produces an 8-byte result (j2), and CVD and CVB produce specification exceptions (j39, 3) if the argument address is not at an 8-byte boundary. For MP and DP, a specification exception is occasioned (j9) if the length of the second field exceeds either 8 bytes or the length of the first (i.e., the result) field. All specification exceptions suppress the instruction; except for CVD, in which the result field remains unchanged, all other errors make the relevant result fields unreliable (j48–55). A data exception  $t_7$  occurs in ZAP (j8) if the fields overlap such that the right-hand end of the second field is to the right of the right-hand end of the first. Data exceptions caused by improper overlapping in the other instructions are detected and entered on line j18.

Two floating-point representations are used; the *short* (oneword) and long (two-word) representations utilize logical vectors  $\boldsymbol{u}$  of dimensions 32 and 64, respectively. A number n, represented by  $\boldsymbol{u}$ , is evaluated as follows:

```
u_0 is the sign (0 for +, and 1 for -);

\perp \overline{\alpha}^1/\alpha^8/u is the characteristic c;

2^{-\nu \overline{\alpha}^*/u} \times \perp \overline{\alpha}^8/u is the fraction f;

c - 64 is the exponent e; and

|n| is equal to f \times 16^c.
```

The program comprises three major segments, the fetching of operands u and v (lines k0-16), the computation of the results (k17-65), and the storing of results and the setting of the condition code and of (lost) significance ( $t_{14}$ ) and exponent underflow ( $t_{13}$ ) exceptions (k66-73).

Floating point register i is selected by the address  $2 \times i$ , and the relevant addresses (both  $\mathbf{a}_1$  and  $\mathbf{a}_2$  in the RR format) are therefore subject to a specification exception check (k1) which suppresses the instruction. Specification exceptions occasioned by MAC also suppress the instruction (k14).

floating-point arithmetic (lines k0—73) The behavior of the computation phase will be illustrated by AD (add normalized (long)). The argument with the smaller characteristic is shifted right (k21-23) by four times the difference in the characteristics, since the characteristic is taken to be the exponent of 16, and one hexadecimal digit comprises four bits.

The appropriate common characteristic determines j on line k24. Lines k28-30 show the determination of the arguments  $k_1$  and  $k_2$  as the signed values of the fractional parts of u and v, and the determination of the result k therefrom. The sign of the result is determined on line k32, and the fraction and possible fraction overflow i on line k33.

If fraction overflow occurs, line k37 shifts the fractional part of the result right one hexadecimal digit and prefixes it with hexadecimal 1 (thus restoring the overflow), and the next line increases the characteristic accordingly. If exponent overflow results (k39), the entire vector  $\boldsymbol{u}$  is questionable (k40); otherwise, the characteristic is specified by j on line k48. If fraction overflow does not occur, the program continues with line k41.

The treatment of a zero result fraction depends on the (lost) significance mask  $p_{39}$ ; if  $p_{39} = 1$ , the fraction is combined with the normal characteristic j (lines k41, 48); if  $p_{39} = 0$ , it is combined with a zero characteristic (i.e., the most negative possible exponent) and a positive sign (k42, 47).

A nonzero fraction is normalized (k44, 45), the amount of shift i (in hexadecimal digits) being determined as the integral part of one-fourth of the number of leading zeros. The characteristic is reduced accordingly; if it becomes negative, the entire result field is set to zeros (k47) and the exponent underflow exception ( $t_{13}$ ) is set conditionally on line k73.

Because the tests for the various exception conditions appropriate to a given class of instructions (including the check on the legitimacy of the operation code) may proceed concurrently, addressing and specification exceptions may be presented even for an undefined operation code. The undefined operation exception  $t_1$  will, of course, be presented (CPU line 10), but in the event of multiple exceptions any one of the exceptional conditions may actually be recognized (CPU line 24).

If the first half of the operation code byte has any of the values 0, 1, 4, etc., listed on line 10, no spurious exception conditions can occur. Any other codes may (as indicated by the question marks) set  $t_5$  and  $t_6$  as shown by lines 14–5. For example, the first half-byte of the illegitimate code 0011 0101 has the value 3 and is treated, for error check purposes, the same as the floating-point instructions occurring in row 3 of the operation decoding matrix O. Thus  $t_5$  is set to zero and  $t_6$  may be set to the value  $i_4 \vee i_5$ . In other words, this case may present a specification exception if either of the effective addresses do not designate a valid index to a floating-point register. The format used for the calculation of the effective addresses is determined by  $\perp I_{0.1}^0$  as shown by  $N_2^0$ .

undefined operation codes (lines 10—5)

### Input/output

The system/360 input/output included in this formal description comprises five system programs:  $CH^c$  (channel c), IOIE (I/O interruption entry),  $HFC^c$  (hardware failure in channel c),  $TOL^c$  (time-out limiter for channel c), and BMT (burst-mode timer). The description extends as far as the interface between a channel, which communicates directly with the CPU and the system memory M, and control units, which are closely associated with input/output devices.

Channels are of two major types, multiplexor and selector, and a system has at most one of the former and six of the latter. Both types are encompassed in the general program  $CH^c$ , where c is the channel number, the number zero being reserved for a multiplexor channel. In a formal reading of the program, the value of c is fixed, and the single program  $CH^c$  represents several independent programs, one for each channel in the system. The behavior of a multiplexor channel (c = 0) differs significantly from that of a selector channel; the differences appear wherever a statement involves the terms (c = 0) or ( $c \neq 0$ ) or involves a branch based on the variable c. For example, because of the branch on c line 46, lines 47 and 48 apply only to the multiplexor channel, a point emphasized by the use of the superscript 0 rather than c.

The programs  $TOL^c$  and  $HFC^c$  also represent a multiplicity of similar, but not necessarily identical, programs for different values of c. However, operational differences in these programs depend not upon distinctions between multiplexor and selector channels, but rather upon model-dependent factors such as the degree to which a particular channel shares physical facilities with the CPU. These factors are reflected in the "channel model" matrix CM.

At this point, Table 3 merits further study for the information it yields with regard to the logical structure of the input/output system. It will be found that most of the channel variables are formally matrices, with the rows indexed by the channel number. The rows are therefore completely independent in their behavior, and a column is of interest per se only in the case of pending interruptions  $(B_8)$ , as shown in CPU line 25 and IOIE line 1. Analogously, matrix V possesses one row for each control unit on the system, and CH line 37 uses columns  $V_8$  and  $V_{12}$ .

A channel resembles an independent computer insofar as it executes a sequence of special fixed-length (8-byte) instructions, called *commands*, stored in the system memory M. To this end it possesses a sequence counter  $\omega^{24}/CAW^c$ , (initially set by an I/O instruction of the CPU) and a command register  $C^c$ . The commands themselves are limited, so far as the channel is concerned, to the transfer of information to or from M, known respectively as read and write, and a respecification of the next command address ( $\omega^{24}/CAW^c$ ), or transfer in channel (tic). Special

cases of read and write are, respectively, sense and control, but these are distinguished as such only at the control unit or device level.

The execution of a sequence of commands (of length greater than one) is called *chaining*, and is signalled by the flags  $C_{32}^c$  and  $C_{33}^c$ . Data-chaining causes a respecification of the data address  $(\omega^{24}/\alpha^{32}/C^c)$ , the flags  $(C_{32,33,34,35,36}^c)$ , and the byte count  $(\omega^{16}/C^c)$ , but does not disturb the command code  $(\alpha^8/C^c)$  and hence merely continues the operation in progress. Command-chaining, which takes place only when an operation is completed, causes all of  $C^c$  to be replaced and thus may initiate a different kind of operation. A tic may occur in either type of chaining, but this affects  $C^c$  only indirectly. Any chained sequence of commands relates to a fixed device address, that initially set by the sio instruction.

Direct communication between the CPU and a channel is initiated either by the CPU through an I/O instruction, or by the channel through an I/O interruption. This communication with the CPU involves the variable  $\mathbf{B}^c$ , and in particular the four central bits,  $\mathbf{B}^c_{8,9,10,11}$ . The suffix  $(\boldsymbol{\omega}^8/\mathbf{B}^c)$  and prefix  $(\boldsymbol{\alpha}^8/\mathbf{B}^c)$  bytes hold, respectively, a device address and device status information for the indicated device.

 $B^c$  is formally identified with channel c, as distinguished from subchannel c, which is formally identified with the variables necessary for sustaining an I/O operation. These are  $C^c$  and  $CAW^c$ , introduced above, and  $S^c$ , which has a structure similar to that of  $B^c$ . The address ( $\omega^s/S^c$ ) in this case is the address of the device currently being serviced, and the byte  $\alpha^s/S^c$  holds channel status information associated with this device. The variables  $C^c$ ,  $CAW^c$ , and  $S^c$  comprise the only active subchannel associated with a channel  $B^c$ ; in particular, the interruption-pending and working states of the channel and of the subchannel are given, respectively, by  $B^c_s$ ,  $B^c_g$ ,  $S^c_s$ , and  $S^c_g$ .

A multiplexor channel has a number of facilities  $T^i$ , each of which can store the active subchannel variables and respecify them when required. It is, therefore, said to have  $\mu T$  subchannels, and it can sustain  $\mu T$  simultaneous data transfer operations by time-sharing its active facilities. At any instant only one device can be in contact with a multiplexor channel and the operational information associated with this device will at that time preempt  $C^0$ ,  $CAW^0$ , and  $S^0$  long enough to transfer a characteristic number of bytes or to perform an initiation or termination sequence.

A selector channel differs from a multiplexor channel primarily in having no subchannel storage other than  $C^c$ ,  $CAW^c$ , and  $S^c$ , so that only one data transfer operation can be in progress at any time. Once an operation with a particular device is initiated on a selector channel, that device will stay connected at least until all data called for by the operation have been transferred, or until the operation is countermanded by an Hio instruction. There is no interleaving of data transfers from different devices, but between the termination of a sequence of commands with

one device and the initiation of a new sequence, the channel will service requests from devices that have outstanding status information to transmit.

A selector channel always works in the "burst" mode, and the characteristic operation of a multiplexor channel is the "multiplex" mode. However, a multiplexor channel is said to operate in the burst mode if a particular device monopolizes its facilities for more than approximately 100 microseconds. This does not imply a difference in channel operation, but relates only to the question of availability, since efficient operation requires that the CPU be able to distinguish between a current operation that is likely to keep the channel busy for a relatively long time and one that will soon be over. In terms of the variables used here, it is a question of how long  $B_9^0$  remains equal to 1.

The interface between a channel and its attached control units or devices is represented by the variables  $U^c$  and  $P^c$ . The suffix  $\omega^9/U^c$  is a bus that carries a byte of information  $(\omega^8/B^c)$  and a bit  $(U_7^c)$  for odd parity. The prefix  $\alpha^3/U^c$  comprises three tag bits which specify the type of information on the bus. When the interplay bit  $U_3^c = 1$ , information on the bus is outgoing (from channel to control units) and the tags are, in order, command-out service-out, and address-out; when  $U_3^c = 0$ , information is ingoing and the tags are status-in, service-in, and address-in. In operation only one tag may be set at a time, and its significance depends, in part, on the state of the channel. The remaining elements of  $U^c$ are concerned with establishing and holding a logical connection between the channel and a particular control unit. They are suppress-out  $(U_4^c)$  and operational-out  $(U_5^c)$  which are set only by the channel, and operational-in  $(U_6^c)$ , which is set only by the control unit. The polling line  $P^c$  is a vector that has a position for each control unit on the interface, in the order in which they are connected.  $P_0^c$  is called select-out and  $P_{w_c}^c$ , where  $w_c$  has a value equal to the number of control units connected, is called select-in.

Control units may be physically separate from or integral with their associated devices; a multiplicity of similar devices may be connected to a single control unit or, conversely, a device may communicate with more than one control unit. Although the present formal description does not include details of this side of the interface, it will sometimes be necessary to refer to it in the text. The term "device" will usually be used when speaking of specific tasks that devices perform once an active connection has been established between device and channel, and "control unit" will usually be used when emphasis is on the establishment of such a connection.

The formal description shows the generation and processing of all results of channel operation to which a programmer has access, including the data transferred to or from memory, a condition code setting  $(p_{34,35})$  for I/O operations, an interruption code setting  $(p_{1.4(16)})$ , and a channel status word (CSW) which comprises  $CAW^c$ , a device status byte  $\alpha^8/B^c$ , a channel status

byte  $\alpha^8/S^c$ , and a byte count  $\omega^{16}/C^c$ .

In the discussion that follows, major phases of the CH program will be outlined, certain critical portions will be examined in detail, and the operation of the four auxiliary programs will be summarized. As before, the discussion is intended as a guide and introduction only, the complete description of channel operation being embodied in the programs.

channel program

data transfer (lines 7-31, 59-65)

| Channel              | nnel   State |   |         |         |  |  |
|----------------------|--------------|---|---------|---------|--|--|
| type                 | $B_8^c$      |   | $S_8^c$ | $S_9^c$ |  |  |
| mpx                  | ?            | 1 | ?       | 1       |  |  |
| $\operatorname{sel}$ | ?            | 1 | 0       | 1       |  |  |

Functional segments of CH are listed in Table 10 in the order in which they will be considered. The table gives the extent of each segment, its entry and exit points, and the channel and subchannel states that predominate when the segment is active.

It is assumed initially that the channel is actively engaged in data transfer, i.e., a byte has been transferred either to memory (line 18) or from memory (line 11). If an invalid address has been indicated in  $S_2^c$  by the use of MAC on line 11, then line 12 branches to line 7 to place a signal on the interface that will be interpreted by the device as an order to stop data transmission. If instead the normal branch to line 13 is taken, a parity failure in the byte from memory will be recorded as a channel data check  $(S_4^c)$  in the channel status byte, but it will not cause termination of the operation. In line 14 the data byte is placed on the interface, together with the (possibly incorrect) parity bit  ${}^{\circ}J_{0}^{0}$  and the serviceout tag  $U_1^c$ . The interplay bit  $U_3^c$  is set to 1, indicating that this is an outgoing transmission. The unconditional branch to line 19 updates the memory address, and line 20 reduces the byte count. Had the operation been a read ( $C_7^c = 0$ ) rather than a write  $(C_7^c = 1)$ , a parity error on the interface would have been noted in line 15 and the receipt of the byte acknowledged to the device on line 16 before the attempt to store the byte on line 18. Following this MAC, however, read and write are treated identically until they separate again on line 10 during the next byte cycle.

Certain actions are peculiar to the read operation. First, there is a conditional setting of  $U_4^c$  on line 16 which will be discussed in connection with data chaining. Second, certain options are available during read: the skip flag  $C_{35}^c$  determines (line 17) whether the received byte should actually be stored; and if the last four bits of the command code are 1100, indicating a backward read, the address will be decreased by one, rather than increased (line 19).

If data chaining is not indicated by the test on line 21, the action moves to line 59 to test for a program controlled interruption (pci). If the need for a pci is indicated by  $S_0^c$ , and if no prior interruption request is pending ( $B_8^c = 0$ ), then an interruption request is initiated on line 60 by setting  $B_8^c$  to 1 and loading into the appropriate parts of  $B^c$  an all-zero device status byte and the address of the working device ( $\omega^8/S^c$ ).

It is noteworthy that in a selector channel a prior interruption pending at this point can only be a pci entered at an earlier time in the execution of the current sequence of commands, but in a multiplexor channel it could be any kind of interruption. However, if the device for which the interruption is pending in a multiplexor channel is the device that is involved in the current sequence  $((\omega^s/B^0) = \omega^s/S^0)$ , then the interruption is necessarily a pci.

The foregoing remarks can be confirmed by a study of the general topology of the CH program: if  $c \neq 0$  the entry to line 59 from outside the data transfer segment can come only from lines 69 or 130; moreover, the entry from line 69 occurs only during command chaining and therefore belongs to the execution of the current sequence of commands. The entry from line 130. however, represents the initiation of a new command, and if this is not part of a sequence of chained commands, its source can be traced back through lines 94 and 96, which together assure that  $B_8^c$  will be zero upon entry into a new command sequence in a selector channel. On the other hand, for a multiplexor channel entering through line 130, line 96 is skipped and a sequence of tests and settings in lines 97-100 may allow  $B_8^c$  to remain set. More broadly, however, for c = 0 the entry to line 59 may have come from lines 50 or 32, in which case nothing can be said about  $B_8^0$  except that it retains its previous setting, whatever the source.

Treatment of the pci is followed by a dwell at lines 61 and 62. A multiplexor channel at this point examines the state of  $U_6^c$  (operational-in) to determine whether the presently connected device wishes to extend the current burst of information transfer. If  $U_6^c = 0$ , exit is made from line 61 to line 58, storing the state of the active subchannel, making the channel not busy  $(B_9^o \leftarrow 0)$ , and resetting the burst timer control  $(g_2 \leftarrow 0)$ . In a selector channel, or in a multiplexor channel where the device is maintaining the connection, line 62 controls the dwell. Here the channel waits for a response from the interface, indicated by  $U_3^c = 0$ ; for an order from the CPU to halt the I/O operation, indicated by  $B_{10}^c \wedge \bar{g}_0$ ; or for a signal that the device response time has been excessive and there may be trouble on the interface, indicated by an interface control check  $(S_6^c)$  set, for example, by a TOL program.

If the escape from line 62 was not for Hio or an interface control check, and no improprieties were found on line 63, then the subsequent decision at line 65 depends on whether the device desires data transfer ( $U_1^c = 1$ ) or has sent in status information ( $U_1^c = 0$  and  $U_0^c = 1$ ). Data transfer takes the program to line 1 where an incorrect length indication ( $S_1^c$  may be generated, and then to line 9 where the channel decides to terminate or continue the operation. Termination at this point—where continued data transfer has been requested by the device—may be caused by a zero byte count (regardless of the setting of  $S_1^c$ ), or by a previously recognized but unfulfilled Hio, signalled by  $S_8^c$  (possible only on a multiplexor channel), or by the presence of a nonzero channel status bit other than  $S_0^c$  (pci) or  $S_4^c$  (data check). A program or protection check generated by MAC during the previous

byte cycle on a read operation first takes effect at this point. If termination is not required, data transfer is effected as before, beginning with the branch from line 10 for read or write.

At different moments in the discourse across the interface between a channel and a device only certain responses from the device are valid. Thus, upon escaping from the dwell on line 62 because of a response on the interface, the channel expects either status-in ( $U_0^c$ ) or service-in ( $U_1^c$ ), and a properly operating control unit will return only one of these tags and no others. Any other response must be considered an interface error, and is so recorded on line 63, which also includes a test for parity failure on a status byte. The action to be taken in case of interface control check and other error conditions will be discussed more fully in the treatment of HFC, but it may be remarked here that the branch to the HIO sequence (line 78) is the mildest action appropriate under the circumstances.

The data transfer cycle has been described here as a strictly byte-by-byte operation, although in most implementations a channel will buffer a certain number of bytes in order to use the central memory more efficiently. While this may have a noticeable effect on the timing of I/O operations, the only observable effect of such buffering on the static results is found in the case of termination due to a program or protection check. In this case the byte count subsequently stored as part of a channel status word will not necessarily reflect the actual amount of data transferred, a state of affairs indicated by the expression ?(16) appearing in lines 136 and 154, and in IOIE, line 24.

The number of bytes specified in a channel command word will always be transferred to or from contiguous memory locations, as shown in line 19. When the count becomes zero, however, the operation may be continued by fetching a new channel command word with a new count and a new memory address. Such a continuation is signalled on line 21, which tests for a zero count and the presence of the *chain data* flag  $C_{22}^c$ .

Line 23 fetches the double word indicated by the address in  $CAW^c$ , and the address is updated on line 24. The four-bit pattern in the command code detected by line 25 signals a tic (transfer in channel) which, if present, causes the replacement of the address in  $CAW^c$  (line 31) and a repetition of the fetch, line 23. If this produces another tic, a program check is recorded on line 30 because of the prior setting of j on line 31, and the process is stopped by a branch to line 29. Line 30 also checks for a specification or addressing error in the address field of the tic command. This test, which would normally occur in the succeeding MAC on line 23, is done explicitly at this point in order to preserve the address of a faulty tic for diagnostic purposes, since the tic address would not be recoverable after the execution of line 31.

If the command code field of the double word fetched on line 23 does not specify a tie, its overall format is checked on line 26, and if satisfactory it is used to respecify all but the command

data chaining (lines 22—31)

| Channel | Stat    |         |         |                   |
|---------|---------|---------|---------|-------------------|
| type    | $B_8^c$ | $B_9^c$ | $S_8^c$ | $\mathcal{S}_9^c$ |
| both    | ?       | 1       | 0       | 1                 |

code in  $C^c$  (line 27). The pci bit is set if called for by  $C_{36}^c$ , and channel overrun  $(S_7^c)$  is recorded if a read operation is in progress and the device has already signalled on the interface.

The setting of  $U_4^e$  on line 16 is a signal that data chaining is about to take place during a read operation. Certain devices can respond to this signal by delaying the transmission of the next byte until  $U_4^e$  becomes zero (line 29), thus avoiding the possibility of channel overrun. Otherwise, overrun is a function of the relative speeds of device, channel, and memory, as well as of the current memory activity.

A channel cannot break out of the data transfer phase on its own initiative unless it recognizes an interface control check (line 63). In normal operation it must wait for a stop order (HIO) from the CPU or a status byte from the device, even though it may have initiated the termination by issuing the command-out tag on line 7. A multiplexor channel will leave from line 61 any time during data transfer if the connected device sets  $U_6^e = 0$ , but this is not a termination of the operation; the channel will return to line 59 and continue in the data transfer phase the next time the device requests service and is reconnected.

The first action in a normal termination (line 66) is a setting of the incorrect length indication for a long count (i.e. when termination occurs with a non-zero count). A prior setting, possibly incurred on line 8 for a short count, will be preserved. In both cases the setting depends on the state of the control flags in  $C^c$ , if data chaining is indicated ( $C^c_{32} = 1$ ), the wrong length indication cannot be suppressed by  $C^c_{34}$ . However, if a program, specification, or channel-overrun check has occurred, the indication of wrong length may fail to appear (as shown by the conjunction with  $\sqrt[2]{V} \sim \sqrt{S^c_{2,3,7}}$ ).

If the possibility of command chaining is ruled out on line 67, termination of device operation proceeds with the setting of the subchannel state  $S_{8,9}^c$  to "interruption pending" and "not working" on line 71. The interruption condition must now be entered in the channel, if possible, and to this end it is necessary to ensure that a previously pending interruption is not at this instant being serviced by the CPU through IOIE. Line 72 is an interlock for this purpose.

The test on line 73 is vacuous for a selector channel, which always proceeds through the next two lines, setting up the channel interruption and branching to line 57 and then to line 56, where it waits for service from the CPU. A multiplexor channel, however, may be unable to accept the status byte and consequent interruption at this time. If so, it skips lines 74 and 75 and, because of the setting of j, returns command-out rather than service-out on the interface (line 76). The former is interpreted by the device as an order to stack (i.e., save) the information just transmitted; the latter, as permission to clear (i.e., destroy) the status and go about other business which may, in fact, be the completion of a phase of the current operation that does not require channel

termination (lines 66—81, 56—58)

| Channel | Stat    | le      |         |         |
|---------|---------|---------|---------|---------|
| type    | $B_8^c$ | $B_9^c$ | $S_8^c$ | $S_9^c$ |
| both    | 1       | 0       | 1       | 0       |

facilities. In either case, the multiplexor places the device address in the field of the no-longer-needed data address (line 77), returns to line 59, passes through line 61 as soon as the device disconnects ( $U_6^0 = 0$ ), stores the subchannel information and makes the channel not-busy (line 58), and goes into the idle phase (lines 35–55).

It will be observed that a selector channel will not have signalled on the interface at this time, thus keeping the device connected. The channel itself is not available for anything but a clearance of the interruption just set. This can be seen by tracing IOIE and the I/O instructions of the CPU with  $B_8^i$ ,  $B_9^i$ ,  $S_8^i$ ,  $S_9^i$  set to 1, 0, 1, 0, respectively. A TIO addressed to the proper device, or an interruption service, will cause program CH to follow the path  $\cdots$ , 56, 82, 83, 87, 88, 89, 92, 153, 154, 155, 160,  $\cdots$ , which clears the interruption condition and releases the device, and then goes on to make the channel available for new work. A TIO for another device, or an SIO, is rejected by the sequence  $\cdots$ , 56, 82, 83, 87, 88, 89, 92, 93, 138, 134, 135, 32, 33, 56,  $\cdots$ , and leaves the channel state unchanged.

Termination due to the instruction HIO is indicated when the CPU tries to contact a channel through  $B_{10}^{i}$  when the channel is busy  $(EXC ext{ c6-9})$ . This is sensed in line 62 and causes a branch from line 64 to line 78, where a signal to the device to disconnect is transmitted on the interface ( $U_2^c = 1$  when  $P^c$  is all zeros). The possibility of command chaining is then erased and the CPU is released (line 79). A multiplexor channel will then return to line 35 through line 59, as described for normal termination, and contact with the device will eventually be reestablished when the device has come to a stopping point and generated a status byte and a request for service. To the multiplexor channel this request will be indistinguishable from a service request for additional data transfer or normal termination. In contrast, a selector channel at line 80 proceeds very much as if termination had been signalled by the device, combining the operations of lines 66, 71 and 74 in line 81, and returning to lines 57 and 56. The significant difference is the specification of zeros as the device status byte  $(\alpha^8/B^c)$ .

There is a two-level hierarchy for device status bytes: those associated with a termination (evidenced by the state of  $S_s^e$ ) have an irrevocable hold on the channel interrupt signal ( $B_s^e$ ) until cleared; others, externally generated or arising after the device is disconnected from the channel, may be displaced, without being accepted by the CPU, to allow a new operation to start (in which case the information must be saved by the device). Non-displaceable status bytes are usually characterized by the presence of channel end  $((\alpha^s/B^c)_4)$ , but exceptions occur when a sequence is terminated during command chaining and when, as just noted, HIO is issued to a busy selector channel. In the first case channel end may never appear; in the second case, the channel-end byte, when it is received, will have the same significance for

channel operation as any other status byte submitted after termination.

Each device status byte implies the formation of a channel status word (CSW), either by means of an interruption, a TIO, or an sio. The execution of Hio by a busy selector channel will, therefore, cause an extra CSW to be generated, for a possible total of four associated with the subject command sequence. The three nonzero device status bytes which are always possible would contain, respectively, bits designating channel end, control unit end, and device end, together with whatever other conditions happened to be present. Any two, or all three, end conditions may appear in the same byte, but in any case an operation is not actually completed until device end for it has been submitted and cleared at the device. Control unit end is supplied only under special circumstances but, apart from the exceptions possible during command chaining, channel end and device end are made available at the termination of every sequence, and will appear in a CSW.

Command chaining (the execution of a sequence of operations by the same device) is initiated (line 68) if the tests in line 67 are satisfied: the flag settings  $C_{32,33}^c$  must be 01, no bit other than pci  $(S_0^c)$  may be present in the channel status byte, and the device status byte on  $U^c$  must conform to one of the allowed patterns listed. (In the absence of hardware failures it is possible, coming from line 66, for any but the busy bit  $(\omega^8/U^c)_3$  to be present in addition to channel end  $(\omega^8/U^c)_4$ .) The inception of command chaining is signalled to the device on line 68 using the same signal as was used to signify data chaining (line 16), but this time it is in response to status-in rather than service-in. In response to this signal the device will clear the status, but the channel must note the presence of device-end to decide the branch on line 69. If device end is present (j = 1), initiation of the next command takes place immediately, starting with line 70, where the address in  $CAW^c$  of the next command word is increased one double word if the status modifier bit  $(\omega^8/U^c)_1$  had been sent with device end. The program then branches to line 104 where it joins the sio sequence described below under "CPU service". If device end has not been received, line 69 causes a branch to line 59, after which a selector channel dwells at lines 61 and 62, and a multiplexor channel exits at line 61 when the device disconnects by setting  $U_6^c$  to zero.

When a device disconnects from a channel (for any one of a variety of reasons on a multiplexor channel, but only following the acceptance of a terminating device status byte on a selector channel), the channel is free to respond to calls from the CPU or to service requests from its devices. Line 37 shows a dwell on the two possibilities, and line 38 shows that requests from devices take precedence over CPU requests. The expression  $V/V_8 \wedge V_{12} = c$  corresponds to request-in, and rests upon the following formulations. Each control unit on a system is asso-

command chaining (lines 68—70)

| Channel | State   |         |         |         |  |
|---------|---------|---------|---------|---------|--|
| type    | $B_8^c$ | $B_9^c$ | $S_8^c$ | $S_9^c$ |  |
| both    | ?       | 1       | 0       | 1       |  |

channel idle (lines 35—55)

| Channel         |         |         |         |         |
|-----------------|---------|---------|---------|---------|
| Channel<br>type | $B_8^c$ | $B_9^c$ | $S_8^c$ | $S_9^c$ |
| mpx             | ?       | 0       | ?       | ?       |
| sel             | 0       | 0       | 0       | 0       |

ciated with a row of a matrix V. Control unit u, desiring service for one of its attached devices, sets  $V_s^u = 1$  and at the same time indicates the channel wanted by holding the channel number in  $V_{12}^u$ . If  $V_s^u = 1$  and  $V_{12}^u = c$ , this clearly represents a call for channel c, and all such possibilities are monitored by the or over the conjunction. The numbers available to control unit u for  $V_{12}^u$  must, of course, be restricted to those of the channels on whose interfaces the control unit is indeed connected.

In response to request-in the channel attempts to establish a working connection with a device by setting select-out  $(P_0^c)$  to 1 with the tags  $\alpha^3/U^c$  set to zeros (line 39). Control units are connected serially on the interface with respect to select-out. Only the first control unit will sense  $P_0^c$ , and it will pass the signal on (setting  $P_1^c = 1$  and  $P_0^c = 0$ ) if it does not require service. Successive control units will pass the signal on in a similar way until either a control unit responds with address-in or the last control unit, passing the signal on in turn, sets select-in  $(P_{w_c}^c)$  to 1. A tag other than address-in, or wrong parity on an incoming address, will cause an interface control check (line 41).

For a multiplexor channel, two major types of request for service from a device are possible:

- 1. from a device still in the data transfer state ( $S_{\theta}^{e}$  was 1 last time it disconnected at line 61);
- 2. a) from a device for which a termination status byte was stacked,
  - b) from a device for which device end is due, or
  - c) from a device presenting an externally generated signal such as *attention* or a change from *not-ready* to *ready* (which will be indicated as device-end).

For a selector channel, only types 2b and 2c are possible.

A multiplexor channel always honors requests of the first type, but attempts to suppress others if the interruption buffer  $(\alpha^8/B^0)$  and  $\omega^8/B^0$ ) is loaded, as indicated by  $B_8^0=1$ . This is shown in lines 36 and 39 where suppress-out  $(U_4^c)$  is set to the value of  $B_8^c$ . When  $U_4^c=1$ , a control unit must either suppress requests of the second kind by not activating  $V_8^u$  and  $V_{12}^u$  or else pass along select-out when the channel tries to establish a connection under these circumstances. On a selector channel,  $B_8^c$  is zero during the idle phase and all requests are, therefore, honored.

If a connection is established ( $U_3^c$  becomes 0 and  $U_2^c$  becomes 1, lines 40, 42), a multiplexor channel will immediately set select-out to zero (line 44), giving the device control over the connection. Operational-in ( $U_6^c$ ) will have become 1 with  $U_2^c$ , and now the channel (always passing through lines 59 and 61 before returning to idle) will be constrained to hold the connection as long as  $U_6^c = 1$ .

Line 44 has no effect on a selector channel, which simply continues by placing the device address in the working address register  $\omega^8/S^c$  (line 45), acknowledging its receipt with commandout (line 49), waiting for the next response (line 51), which this time must be status-in (line 52), and loading both status byte and address into the channel registers as an interruption request (line 53). It then dwells at line 56 waiting for a call from the CPU.

A multiplexor channel has a slightly more complex sequence after line 45. It first uses the device address just received to generate an index to the subchannel storage facilities (line 47). All eight bits of the address are used to generate this index if the zeroth bit is a zero. If not, only bits one, two, and three are used, thus allowing several devices to share a sub-channel, i.e., a storage location in T. The stored operational information is then loaded into the active subchannel facilities, the channel is put into the working state by setting  $B_9^0$  to 1, and BMT (burst mode timer) is released from its dwell by setting  $g_2$ . The device is signalled to proceed (line 49), and the state of  $S_9^0$  is sensed (line 50) to determine which phase of operation the device is in.

If  $S_9^0 = 0$ , the device is requesting service of the second kind and the program proceeds much as in the case of a selector channel. An additional malfunction is recognized in this case if the control unit overlooks suppress-out and accepts service when  $B_8^0 = 1$ (line 52). If no malfunction is recognized, an interruption request is entered on line 53 and receipt of the status is acknowledged on line 55. The earlier remarks concerning line 76 are relevant here, since the device may still be required to stack the information in spite of the fact that the interruption facilities are now available. The criterion this time is whether the byte just received is termination status stacked at the time of generation. The state of  $S_s^0$ determines this, and so is used to choose between command-out  $(U_0^0)$  and service-out  $(U_1^0)$ , allowing the device to clear the status if  $S_8^0 = 1$ . As noted before, the need to stack arises because nontermination status information can be displaced from  $B^c$  without entry into a CSW. Finally, the branch to line 59 returns the channel to idle status through lines 61 and 58.

If  $S_0^0 = 1$  in line 50, there is an immediate branch to line 59, and the dwell at lines 61 and 62 would await a response on the interface, just as if the device had never disconnected from the channel. The device may be at any stage in its operation and it is possible that it will transmit status information rather than data at this time. This would, of course, lead into the termination sequence, as previously outlined. If data remains to be transferred, the device will transmit or accept its characteristic number of bytes and then set  $U_0^c$  to zero, allowing the channel to return to idle.

Certain channel models, when idling, continuously scan their interfaces for service requests rather than waiting for requestin to rise. This difference is shown by the branch at line 35. The continuous-scan type follows the loop  $\cdots$ , 39, 40, 41, 42, 43, 35, 39,  $\cdots$ , skipping the dwell at line 37 and responding (line 43) to the CPU interlock  $B_{10}^c$  after each non-response from the interface ( $U_2^a = 0$ , line 42). The other type, largely described above,

CPU service (lines 82—165, 32—34)

| Channel | l   State |         |         |         |  |
|---------|-----------|---------|---------|---------|--|
| type    | $B_8^c$   | $B_9^c$ | $S_8^c$ | $S_9^c$ |  |
| both    | ?         | ?       | ?       | ?       |  |

state analysis (lines 82—101)

| Channel type | $B_8^c$ | $oldsymbol{B_9^c}$ | $S_8^c$ | $S_9^c$ |
|--------------|---------|--------------------|---------|---------|
| mpx<br>sel   | ?       | 0                  | ?       | ?       |

would mainly dwell at line 37, and normally proceeds through  $\cdots$ , 38, 39, 40, 41, 42, 44,  $\cdots$  for a device request, or leaves at line 38 for a CPU request. For certain control units, however, a non-response even after request-in has risen is a normal possibility, so the loop via line 43 may be followed. Interface control checks arising in this phase of channel operation have again been shown in their weakest form, simply causing a return to line 35, repetition of interface scan, and testing of  $B_{10}^c$ .

The channel responds to the CPU in executing the SiO, TiO of HIO instructions and in processing interruptions. Provision is made in IOIE for servicing certain interruptions, but otherwise interruption processing is very like TiO. Although the initiation of a new command by command chaining is not strictly part of CPU service, it is almost identical with SiO and they will be treated together, where appropriate.

Except for command chaining, it is assumed in what follows that  $B_{10}^i$  has been set to 1 in EXC line c13 or IOIE line 8, and has caused  $CH^c$  to branch to line 82 from line 38, 43, or 56.

The first phase of CPU service starts by setting a working device address either from the effective address  $a_i$  supplied by the CPU or from the interruption register  $\omega^8/B^c$  (line 82). A selector channel passes over tests in lines 83, 87 and 88 (and line 89 if not Hio), and continues to line 92. The branch to line 153 is taken for interruption service ( $g_0 = 1$ ) or for the with termination status ( $S_8^c = 1$ ) available for the addressed device. (Note that if  $g_0 = 1$ , then  $\omega^8/S^c$  would have been set by  $\omega^8/B^c$  on line 82. The requirement that this be termination status is not imposed on interruption service, because the desideratum here is the availability of status information at the channel level, a condition that is always satisfied when  $B_s^c = 1$  in a selector channel.) Failing the branch to line 153, line 93 merely checks, for  $c \neq 0$ , the state of the subchannel, and if it is holding termination status, the branch to line 138 will be taken. Otherwise, information is not available at the channel level and the path through line 94 is followed, leading ultimately to the selection of a device on the interface.

A multiplexor channel leaving line 82 must first determine the index to its subchannel storage (line 84), and an invalid index causes a branch to line 140. Otherwise, the active subchannel facilities are loaded and a series of inquiries are undertaken to determine, as in the selector channel, whether the necessary information is available at the channel level.

For interruption service a totally inactive subchannel (line 87) implies that it is necessary to go to the interface, but  $S_8^0 = 1$  or  $S_9^0 = 1$  imply, respectively, that termination status or a pei is available at the channel level, and the branch from line 88 to line 136 is followed. For the total follow the same path requires, as in a selector channel, that the channel be holding termination status for the addressed device. In this case  $S_8^0 = 1$  alone does not distinguish the termination state, since the case  $S_8^0 = 1$ 

and  $S_9^0 = 1$  is used to denote a pending order to stop, set on line 145 or 148 by a previously issued HIO, to be honored (line 2) the next time the device requests service. If  $\omega^8/S^0$  and  $\omega^8/B^0$  do not agree, it is still possible for a termination status condition to be cleared, but only by going to the interface and selecting the device. This situation is treated on line 93, which is reached by a multiplexor channel if the sequence to line 89 is followed and the case is not HIO. For both SIO and TIO at line 93, a multiplexor will proceed to line 94 if the subchannel is both not working and not holding an interruption. For TIO the additional possibility of clearing an interruption is signalled by the same criteria as in line 88, except that  $\omega^8/S^0$  must now match the address previously stored in the address field of C in line 77.

If there is an HIO at line 89 and the subchannel has an interruption pending (line 90), no action is taken in either type of channel, and the branch to line 161 sets the condition code. If no interruption is pending, the possibility of command chaining (in a multiplexor channel) is cancelled (line 91) and a branch to the interface selection sequence (line 115) occurs. Ultimately, an order to stop will be issued on the interface (line 151) or, for a multiplexor, the subchannel will be set (line 145) to stop the operation the next time the device requests service.

Lines 94–100 cancel interruption conditions arising from non-termination status, as discussed in regard to termination. A selector channel must order the device to stack the information at this point (line 96), but a multiplexor channel does not, since it accepted non-termination status only provisionally in the first instance (line 55). Line 100 indicates that under some (indeterminate) circumstances, a multiplexor channel may not cancel a non-termination interruption condition.

At line 101, sio and the only possible cases. The causes a branch to line 115, but she proceeds through lines 102 and 103, to join command chaining at line 104. A channel address word is fetched in line 102 from a fixed location in main storage. It is checked for protection key and format (line 103) and any non-conformity is recorded as a program check  $(S_2^c)$  in the channel status byte. In line 104, the local variable j, set to zero for command chaining  $(B_9^c = 1)$ , will be used as in data chaining to prevent two successive tic's. Setting j to 1 for sho, (when  $B_9^c = 0$ ), precludes the possibility of a tic as the first or only command of a sequence. The pci bit is set, if necessary, on line 114.

Lines 105-114 correspond closely to the data chaining segment, lines 23-31. The differences are largely in error indications, including an added aspect of the format check (compare lines 26 and 109), but the most significant difference occurs in line 113 (as compared to line 27) where k now respecifies all of  $C^c$  including the command code portion.

All program checks, including a faulty  $CAW^c$ , cause a branch to line 112, which is entered only if there is a program check. From there, command chaining will cause a branch to line 115,

start I/O (lines 102—114)

| Channel | State   |         |         |         |
|---------|---------|---------|---------|---------|
| type    | $B_8^c$ | $B_9^c$ | $S_8^c$ | $S_9^c$ |
| mpx     | ?       | 0       | 0       | 0       |
| sel     | 0       | 0       | 0       | 0       |

command chaining (lines 104—114)

| Channel | State          |   |         |         |
|---------|----------------|---|---------|---------|
|         | B <sub>8</sub> |   | $S_8^c$ | $S_9^c$ |
| both    | ?              | 1 | 0       | 1       |

channel-initiated selection (lines 115--130)

| Channel | State   |         |         |         |
|---------|---------|---------|---------|---------|
| type    | $B_8^c$ | $B_9^c$ | $S_8^c$ | $S_9^c$ |
| mpx     | ?       | ?       | ?       | ?       |
| sel     | ?       | ?       | 0       | ?       |

CSW and condition code setting (lines 136—165)

| Channel $type$ | Stat<br>B <sub>8</sub> |   | $S_8^c$ | $S_9^c$ |
|----------------|------------------------|---|---------|---------|
| mpx<br>sel     | ?                      | 0 | ?       | ?       |

whereas sio may or may not, depending upon the channel model and immediate circumstances. The alternative for sio is the branch to line 139 which stores the status byte portion of the CSW.

At line 115, the possible cases are command chaining, SIO, TIO, OF HIO for any type of channel, and interruption service for a multiplexor channel. Selection is started by setting select-out, as in line 39, but the working address is now on the interface bus  $(\omega^8/U^c)$  and address-out  $(U_2^c)$  is set. The dwell on line 116 differs from line 40 in the added term  $S_6^c$ , which will be set by the TOL (time-out limiter) program (line 0) if the response from the device is delayed beyond a maximum interval specified for the particular channel model. The interface control check  $S_6^c$  may also be set (line 117) if this is an interruption service  $(g_0 = 1)$  or command chaining  $(B_9^c = 1)$  and no control unit acknowledges the address or address-in does not rise in response; if any combination of incoming tags appears other than  $U_0^c$  or  $U_2^c$  alone; if there is a parity error on the incoming interface; or if an address received in response does not match the address sent out.

For command chaining, the minimal response to an interface control check at this point is the branch from line 118 to the disconnect sequence starting at line 78, just as for an interface control check in the data transfer phase on line 63. The corresponding response for CPU service is the branch to line 143 and storage of a complete CSW for interruption service or TIO (142), or of the status portion only for SIO or HIO (144). Line 142 also may be entered by the sequence  $\cdots$ , 85, 140, 141, 142,  $\cdots$  in the case of an invalid subchannel index during interruption service.

The branch to line 119 for  $S_6^c = 0$  implies that all subsequent tests are for normal possibilities. Thus, if  $P_{w_c}^c = 1$  in line 119 or  $U_0^c = 1$  in line 120, it must be that Sio, Tio, or Hio are under consideration, for only in these cases is a "not-operational" response or a "control-unit-busy" response possible without error. The consequent action in each case is shown by the respective branches to lines 145 and 147.

At line 145, which is also entered by the sequence ..., 85, 140, 145, ..., hio on a multiplexor channel sets the subchannel to terminate as soon as it requests service, and in line 146 the condition code is set to indicate "not-operational" in response to whichever of hio, sio or to may be current.

At line 147, which is entered only in the case of a control-unitbusy response, there is a division (like that on line 143) between interruption service and TIO on one hand, and SIO and HIO on the other. For the former, the entire CSW is again specified (line 150), although useful information will appear only in the status portion, which is the only part stored (line 149) by the SIO and HIO. For a multiplexor channel HIO again sets the subchannel to terminate (line 148). The device status byte stored at this point contains the busy bit and status modifier only ( $\epsilon^{1.3}$ ). In the case of SIO, the channel status byte is zero, except for a possible program check ( $S_2^c$ ). In line 121 a multiplexor channel sets  $P^c$  to zero. If Hio has lasted to this point, it implies that the device is able to accept the order to disconnect, and line 122 branches to line 151 to issue this order. The terms  $B_a^c$  and  $\bar{g}_0$  in line 122 ensure that this is truly Hio and not a fortuitous value of  $I^0$  during command chaining or interruption service.

The command byte is specified in line 123 in preparation for its transmission to the device in line 124. The last terms of line 123 ensure that, regardless of the command code in  $C^c$ , a programming error ( $S_2^c = 1$ ) carried over from line 112 will cause an all-zero byte (the interface command code for TIO or interruption service) to be transmitted. The only legitimate response to a command code is a status byte with correct parity (line 126) and, when this response arrives (within the allowed time-out limit), the program branches (line 127) to line 153 for CPU service.

At line 153 the possibility of an interruption pending in the subchannel is checked. This could arise either because line 153 was entered directly from line 92 by a selector channel, as noted earlier, or because the special condition for a multiplexor channel in line 92 had been satisfied. In both cases a TIO must be in progress and a full CSW is stored in line 154. For a selector channel the interruption pending in the subchannel must have also been pending in the channel, and so both are cleared in line 155. For a multiplexor channel, however, the subchannel interruption could not have been in the channel, or the branch from line 88 to line 136 would have been taken before reaching line 93, so in this case (c = 0) the state of  $B_8^c$  is left untouched. Line 155 is followed by line 160, which releases the device. The need for an interface signal is obvious for a multiplexor channel because the status has just been transmitted; and, for the selector channel, it will be recalled that the interruption was entered in line 74 and simply held by the channel with no return signal to the device at that time.

The sequence just described, and the sequence  $\cdots$  88, 136, 137,  $\cdots$  both relate to the formation of a CSW with termination status. The latter sequence, which obtains only in a multiplexor channel, may also be followed for a pci while the subchannel is still working. In this case the combination  $S_8^0 = S_9^0 = 1$  would, as usual, be the result of a prior HIO, and it would be improper to reset  $S_8^0$  in line 137. But  $B_8^0$  is unconditionally reset, providing a double contrast with the action in line 155. In both line 136 and line 154 the count field of the CSW is indeterminate if there has been a program or protection check, and in line 136 this is also true for a pci.

If  $S_8^c = 0$  in line 153, further possibilities are checked in line 156. If this is not interruption service  $(g_0 = 0)$ , and there has been no programming error  $(S_2^c = 0)$ , and either the status byte on the interface  $(\omega^s/U^c)$  is all zero or this is 510 with command chaining indicated, and the status byte conforms to one of three allowable patterns, then the branch is taken to line 161. Otherwise the case is either interruption service to clear a non-termina-

Table 11 Device status bytes stored in CSW

|                |                    |                        | channel activity and CH<br>line on which stored |                |               |               |                   |                   |        |                   |       |  |
|----------------|--------------------|------------------------|-------------------------------------------------|----------------|---------------|---------------|-------------------|-------------------|--------|-------------------|-------|--|
| atten-<br>tion | status<br>modifier | control<br>unit<br>end | busy                                            | channel<br>end | device<br>end | unit<br>check | unit<br>exception | inter-<br>ruption | TIO    | sio               | HIO   |  |
| 0              | 0                  | ?                      | 0                                               | 1              | 0             | ?             | ?                 | 136               |        | 136               |       |  |
| ?              | ?                  | ?                      | 0                                               | ?              | 1             | ?             | ?                 | 154               | 158    | 154               | \ /   |  |
| 0              | 0                  | 1                      | 0                                               | 0              | 0             | ?             | ?                 | 158               |        | 159               | \ /   |  |
| 0              | 9                  | 0                      | 0                                               | 0              | 0             | ?             | ?                 | IOIE 17           | $\geq$ | 109               | I X   |  |
| 1              | 0                  | 0                      | 1                                               | 0              | 0             | ?             | ?                 | 1012 1            |        | $\supset \subset$ | 1 / \ |  |
| 1              | 0                  | 0                      | 0                                               | 0              | 0             | ?             | 9                 | 159               | 158    | 159               | ]/ \  |  |
| 0              | 0                  | 0                      | 1                                               | 0              | 0             | 0             | 0                 |                   |        | 105               | ν `   |  |
| 0              | 1                  | 0                      | 1                                               | 0              | 0             | 0             | 0                 |                   | 149    | 150               | 149   |  |

tion status from a device, sio or tio to a device that is working or holding status information, or a rejected sio. The status bytes subsequently stored in line 158 or line 159 will indicate the situation: no device status at this point should contain channel end; a busy device will return the busy bit to sio or tio; a device holding status information will include the busy bit in response to sio but not tio (in both cases the device will be cleared, as in interruption service); and the status for a rejected sio will contain a unit check or unit exception.

All possible configurations of device status bytes that may appear in a CSW are shown in Table 11. As usual, the symbol? denotes the possibility of a zero or one in that position; the first line, for example, represents 8 possible status bytes. Altogether, 94 possibilities are represented.

At line 161 an Hio from line 90 may be present as well as sio or the from line 156. In all cases a condition code of zero is specified. Hio leaves immediately at line 162, the leaves at line 164 after signalling on the interface. If this is sio, a command has been successfully initiated and the channel and subchannel state variables are set in line 165 to reflect this. For a multiplexor channel the timer is started. If the status byte is all zero (line 129), service-out is signalled on the interface (line 130) and the data transfer phase is entered at line 59. A non-zero status byte for sio at line 129 indicates an *immediate* command, usually a control operation that can be executed without help from the channel. It also means that command chaining was indicated by the bits in  $C^c$ . Both of these factors were checked in line 156, which strongly resembles line 67, and the branch from line 129 therefore goes to line 68 to prepare for command chaining.

If command chaining had been in progress at line 127, the branch to line 128 would have been followed. Here, either a non-zero status byte or a program check will cause a branch to line 67 where the choice is made between termination and further com-

mand chaining. Alternatively, the branch from line 128 to 130 leads to the data transfer phase, as in 810.

A program check during command chaining may produce one of the odd situations alluded to in the section on termination. The device involved in the sequence of commands is available to the channel at this point and it will ordinarily respond to the command actually issued—see line 123) with zero status. But  $S_2^c$  will be detected on line 67 and the termination sequence starting at line 71 will be entered. The termination status byte may now be zero, and both channel end and device end will have been lost.

All exits in the segment 137–164 go to line 131 if a CSW has been stored, otherwise to line 134. At line 131 the channel status byte is cleared, and except in interruption service, the condition code is set to (0, 1) in line 133 to signify that CSW information is available. Except for interruption service, then, all entries to line 134 occur immediately after a setting of the condition code. Line 135 is an interlock with IOIE, followed by a return to line 32. As usual, a multiplexor channel returns to idle through line 59, whereas a selector channel either returns to the dwell at line 56 or sets  $P^c$  to zero and goes on to idle.

A channel that is not operational is shown as dwelling at line 1. If it is on a system, it can be moved from this dwell only by system reset or some other external agency. A forced branch to line 2 (by RESET line 4) clears the various channel and subchannel facilities and places on the interface a system reset signal  $(U_{4.5}^c = 0, 0)$  which is recognized as such by all control units attached to the channel. A multiplexor channel also resets the state bits and status bytes in subchannel storage (line 4).

The channel selected for initial program loading recognizes its number in the *load unit switch* (line 5) and sets its working registers with the canonical information specified in line 6. It then branches to the selection sequence starting at line 115, from which point on it cannot be distinguished from any other sio. If the loading fails for any reason, a new attempt must be mounted at the control panel, causing another system reset and returning the channel to line 2.

The dwell at lines 1 and 2 of *IOIE* responds to the CPU program. When the dwell is broken, the interruption retraction bit  $g_1$  is set to 0 and the unmasked channel of highest priority with an interruption pending is selected for service (line 4).  $B_{10}^i$  is set to 1 on line 8 if the channel is not working, with consequences that have been explored above. If the channel is working it will not be able to respond to  $B_{10}^i$  directly. This bit can therefore be used as an interlock, and is set on line 11 for this purpose (see CH line 72).

A selector channel, or a busy multiplexor channel with working and interruption addresses that match, could only be holding a pei at this point. This is cleared in line 14 following the formation of a CSW in line 13. The return to line 0 then sets  $B_8^i$  to zero,

end of CPU service (lines 131—135, 32—34)

| Channel | Stat    | te      |         |         |
|---------|---------|---------|---------|---------|
| type    | $B_8^c$ | $B_9^c$ | $S_8^c$ | $S_9^c$ |
| mpx     | ?       | 0       | ?       | ?       |
| sel     | ?       | 0       | ?       | 0       |

system reset and IPL (lines 0—6)

| Channel | Stat | te      |         |         |
|---------|------|---------|---------|---------|
| type    |      | $B_9^c$ | $S_8^c$ | $S_9^c$ |
| both    | 0    | 0       | 0       | 0       |

other I/O system programs

input/output interruption entry loads the condition code in p, and signals the CPU by setting  $q_0$  to zero.

A busy multiplexor channel with non-matching addresses must check the subchannel storage location indicated by the interruption address and, if the interruption is for a pei or termination (line 15), generate a CSW and clear the subchannel (lines 18 and 19) much like CH lines 136 and 137. If the subchannel test (line 16) results in the branch to line 17, the bit  $g_1$  is set to 1 and the program returns to line 0 as in the other cases. However, the CPU will recognize  $g_1$  (line 30) as an indication that information for the proffered interruption was not available and it will not execute the usual interruption procedure.

BMT is a time-limiting clock with two ways of stopping. It is started by setting  $g_2$  in  $CH^0$ , line 48 or 165, and it runs until stopped by  $B_2^0 = 0$  (line 5) or by its counter running out (line 4).

Where performance requirements permit, channels make use of CPU facilities and controls to varying degrees. The effect of this on the logical behavior of the channels is confined to the recognition of hardware failures and consequent corrective action. Program  $TOL^c$  is relevant where CPU controls are preempted for channel interface operations, so that an independent means for preventing indefinite delays is required. Two such levels are distinguished in  $TOL^c$ . If  $CM_2^c = 1$ , channel c uses CPU controls for all interface operations other than polling in the channel idle phase, and if  $CM_3^c = 1$ , it uses these controls for polling as well. Thus if  $CM_2^c = 1$ , the dwell on line 1 is broken each time  $U_3^c = 1$  and either  $CM_3^c = 1$  or one of the interface tag lines is nonzero. (The polling during channel idle is distinguished from all other interface operations by  $U_3^c = 1$  and  $(\vee/\alpha^3/U^c) = 0$ .)

In  $TOL^c$  there are two time-limiting clocks in series. The first clock, which is started in line 2, times either the establishment of a connection ( $U_6^c = 1$ ), or the return of select-in ( $P_{w_e}^c = 1$ ), or any response at all ( $U_3^c = 0$ ). The maximum time for the dwell encompassing lines 3-5 is of the order of 32 microseconds. When a connection is established ( $U_6^c = 1$ ) (possibly, in the case of data transfer, even before the first clock is started), the maximum time is of the order of 500 milliseconds. This clock is stopped either by  $U_3^c = 0$ , indicating a response of some kind from the device, or by  $U_6^c = 0$ , indicating that the device wishes to disconnect. If either clock runs out before it is stopped, an interface control check is set in line 0 and detected in  $CH^c$  in one of lines 63, 117, or 126, or in HFC line 1.

hardware failure in channel

burst mode timer

and time-out limiter

Program  $HFC^c$  distinguishes between the case where the channel shares both data paths and controls with the CPU ( $CM_1^c = 1$ ) on the one hand, and all other degrees of sharing and independence on the other. Thus, in line 1, the dwell is broken in all cases for a channel control check<sup>10</sup> ( $S_5^c$ ), but is not disturbed for either a channel data check ( $S_4^c$ ) or interface control check ( $S_6^c$ ) unless  $CM_1^c = 1$ . Whereas an interface control check will be acted upon by program  $CH^c$  in any case, a channel data check will not, and hence

it has no effect on a current operation unless CPU hardware is involved. If the dwell is broken and  $CM_1^c = 1$  (line 2) the branch to line 3 is taken, stopping  $CH^c$  abruptly by a forced branch to its line 0. A machine check is then entered (line 4), which will be recognized by program MCIE. The subsequent branch to line 0 invokes the defined operation MALFUNCTION RESET (not detailed in this description) which will carry out the (model-dependent) recovery procedure called for by the prevalent circumstances, taking into account the fact that MCIE has been alerted by  $f_c = 1$ . Whatever else it does, line 0 must ultimately cause  $CH^c$  to leave the dwell on line 1 with  $S^c$  reset to zero.

Channels that do not use CPU hardware for data transfer disregard  $S_4^c$  and, if they leave line 1, branch to line 5, where a malfunction reset signal ( $U_{4.5}^c = 1$ , 0) may be issued on the interface.

If the channel is not working directly with the CPU at this moment (line 6), the program returns to line 0. Otherwise,  $CH^c$  is immobilized (line 7) and HFC generates a CSW (line 8) in which any field may be set to zero if there happens to be a parity error in the associated register. After storing either all or part of the CSW (lines 10 or 11) the model-dependent reset is executed on line 1 before returning to the normal dwell.

#### **Appendix**

This appendix furnishes a number of examples to illustrate the use of the programs and Tables 3 and 5 for reference in answering specific questions concerning the operation of SYSTEM/360.

What events can cause the CPU to enter the stopped state; in particular, can the stopped state be entered with any interruptions pending? Table 3 shows that operating state can be set by CPU line 34 (to "stop" if the console rate switch is not at "process"), by CP lines 12 and 15 (of which line 12 sets it to "stop" when the stop key is depressed), by MAC line 6 (if the current address to memory agrees with the setting of the address switch and other conditions (line 5) are met), by IPL line 10 (during initial program load), and by RESET line 1. The stopped state (CPU line 35) is actually entered only by a branch from line 25 or by a forced branch (RESET line 2). In the former case the branch is taken only after all pending interruptions are exhausted, while in the latter case all pending interruptions are cancelled by the reset of h on RESET line 0.

Can any of the effective addresses constructed in the instruction fetch phase be captured and stored? A scan of the EXC program (limited to the references to  $a_1$  and  $a_2$  indicated in Table 3) shows that LA places the second effective address (prefixed by zeros) in a general register. LA also provides a convenient means of setting any register  $R^{a_1}$  to zero.

By what instructions can the system mask  $\alpha^8/p$  be set? Table 3 shows that all of p is set on EXC line a26 (that is, by LPSW) and that  $\alpha^8/p$  is set on EXC line a2 (that is, by SSM). Since both

instructions are suppressed by  $t_2$  (lines a1 and a25), both are privileged and could, in a normal operating system, be executed only in the supervisor program.

What instructions are included in the floating-point feature? Table 3 shows that the feature options are specified by the machine characteristics vector m, and that  $m_2$  identifies the floating-point option. The occurrences of  $m_2$  in column  $N_0$  of Table 5 therefore identify the floating-point instructions.

Can data be transferred directly (i.e., not via memory) between a general register  $R^i$  and a floating-point register  $F^i$ ? Comparing the "Results" column of Table 5 with column  $N_0$  shows that F is set only by floating-point instructions and R is never set by floating-point instructions. Since R is set only by non-floating-point instructions and since Table 3 shows that F is referred to only in floating-point instructions (segment K of EXC), direct transfer from K to K is impossible. Similarly, since K is set only by segment K of EXC, it remains only to scan the argument fetch portion (K0–16) to see that K does not occur.

Under what circumstances does the interval timer fail to record elapsed time? The entry for timer alarm in Table 3 refers to the TU program whose dwell on line 0 contains the conditions of interest. In particular, the last term prevents normal decrementation during the dwell on line a17 of the read direct instruction. Moreover, normal decrementation is delayed by the use of  $MAC^s$  on TU line 1 if the channels (which have a higher priority) keep the memory-access facility occupied.

Can the console operator display the contents of the interval timer and tell if it is decreasing appropriately by watching the display lights flicker? Line 18 of the CP program shows that any memory location (in this case 80) selected by the *address switch* can be displayed. However, this segment of the program (15–25) can, because of line 13, be reached only if the CPU is first stopped. Any displayed value is therefore fixed. In particular, the timer is not updated when the CPU is stopped (TU line 0).

How are program interruptions caused by shift instructions; what determines the amount of shift? Line e1 sets  $t_6$  (which the footnote to Table 5 shows to be the "specification exception") for an odd first address in instructions SLDA, SRDA, SLDL, and SRDL. Line e9 sets  $t_8$  (fixed point overflow) for instructions SLA and SLDA if the mask  $p_{36}$  is on and a significant (differing from the sign) bit has been lost in the shift. The shifting is performed on lines e5, e6, e8 and e10, and the amount of shift is determined on line e3 as the residue modulo 64 of the second effective address.

What instructions employ three specifiable addresses? Table 3 refers to EXC b18, 19, d17, 23 for effective address  $a_3$ ; the instructions involved are therefore BXH, BXLE, LM, and STM.

### ACKNOWLEDGMENT

We are greatly indebted to many of our colleagues: to W. C. Carter of the Data Systems Division for suggesting the work; to C. H. Liu

for assistance in the early stages; to IBM SYSTEM/360 architects G. A. Blaauw and A. Padegs for the patient exposition and checking of countless points; to J. C. McPherson, Director of the IBM Systems Research Institute for an opportunity to present the material in a course; and to members of the Institute class for helpful comments and corrections.

#### CITED REFERENCES AND FOOTNOTES

- IBM SYSTEM/360 Principles of Operation, Form A22-6821-0, IBM CORP., 1964.
- 2. The present description is carefully checked against the specifications of IBM SYSTEM/360 available in August, 1964. It is, however, not official; because of normal revisions of the system and possible errors in the present paper, the machine manuals issued by IBM will, as usual, be the final arbiters of system specifications.
- The programs and tables have been reprinted on large display sheets to facilitate study. Copies may be obtained on request to the IBM Systems Inversal
- 4. K. E. Iverson, A Programming Language, John Wiley and Sons, 1962.
- A. D. Falkoff, "Algorithms for Parallel-Search Memories", Journal of the ACM 9, No. 4, 488, (October, 1962).
- K. E. Iverson, "Programming notation for systems design", IBM Systems Journal 2, 117, (June, 1963).
- 7. To provide complete freedom in the attachment of devices in SYSTEM/360, the hardware for the interface has been standardized with respect to both electrical characteristics and logical behavior. The correspondence between this hardware and the representation used here is as follows. The hardware has a separate bus and separate tags for each direction of data flow, and therefore has no need for U<sub>3</sub><sup>c</sup>. There is an exact correspondence between physical control lines and each of U<sub>4,5,6</sub><sup>c</sup>, and P<sup>c</sup>. The hardware has, in addition, two lines not represented by U<sup>c</sup> or P<sup>c</sup>. A line called "hold-out" is not needed here because its function has been incorporated in the treatment of P<sup>c</sup>, which differs in detail from the hardware selectout; and a line called "request-in" appears in lines 37 and 38 of CH only as a logical function of the variables V<sub>8</sub> and V<sub>12</sub> which are set by the control units.
- 8. The hardware analog of this formulation is derived by identifying with each channel number available to a control unit a wire from it to the appropriate channel. Within each channel all such wires are ored together. Putting a number in  $V_{12}^u$  and setting  $V_8^u$  then corresponds to selecting an outgoing wire in the control unit and signalling on it.
- 9. "If [a] device is currently communicating over the I/O interface, the device immediately disconnects from the channel. Data transfer and any operation using the facilities of the control unit are immediately terminated, and the I/O device is not necessarily positioned at the beginning of a block. Mechanical motion not involving the use of the control unit, such as rewinding magnetic tape or positioning a disk access mechanism, proceeds to the normal stopping point, if possible. The device remains unavailable until the termination of mechanical motion or the inherent cycle of operation, if any, whereupon it becomes available. Status information in the device and control unit is reset, and no interruption condition is generated upon completing the operation." (Ref. 1, p. 90).
- 10. Like machine checks in other parts of the system, which depend upon sensing the parity in various machine registers and data paths, the generation of  $S_5^c$  is not shown in this description.
- 11. This reset signal is detected only by a device that is connected to the channel at the time, and will cause this device and its control unit to react exactly as for a system reset (see note 9), except that an interruption condition may be generated when a mechanical operation is completed.





















Table 3 System reference table for programs and variables

| symbol                                          | dimension    | significance                       | references: set, used, [via local variable]                                                                   |
|-------------------------------------------------|--------------|------------------------------------|---------------------------------------------------------------------------------------------------------------|
| BMT                                             |              | burst mode timer                   |                                                                                                               |
| CH                                              |              | channel                            | HFC 3, 7; RESET 3                                                                                             |
| CP                                              |              | control panel                      | EP 3                                                                                                          |
| CPU                                             |              | central processing unit            | IPL 1; MCIE 2; RESET 2                                                                                        |
| EIE                                             |              | external interruption entry        |                                                                                                               |
| EP                                              |              | emergency pull                     |                                                                                                               |
| ES                                              |              | external signals                   |                                                                                                               |
| HFC                                             |              | hardware failure in channel        |                                                                                                               |
| IOIE                                            |              | input/output interruption<br>entry |                                                                                                               |
| IPL                                             |              | initial program load               | RESET 4                                                                                                       |
| MCIE                                            |              | machine-check interruption entry   |                                                                                                               |
| T                                               |              | timer                              |                                                                                                               |
| TOL                                             |              | time-out limiter                   |                                                                                                               |
| TU                                              |              | timer update                       |                                                                                                               |
| DELAY (k units)                                 |              | time delay                         | BMT 3; EXC a11, 15; MCIE 4; T 0; TOL 3, 7                                                                     |
| DIAGNOSE                                        |              | recovery procedure                 | EXC a21; MCIE 7                                                                                               |
| EXC                                             |              | instruction execution              | CPU 20                                                                                                        |
| $MAC^{i}\left( oldsymbol{j};oldsymbol{k} ight)$ |              | memory access                      | CH 11, 18, 23, 102, 105, 136–159; CP 18, 23;<br>CPU 3, 31, 32; EXC; IOIE 13, 18; IPL<br>6, 7; MCIE 8; TU 1, 3 |
| $MALFUNCTION \ RESET$                           |              | channel recovery procedure         | HFC 0                                                                                                         |
| MODEL-DEPEND-<br>ENT RESET                      |              | model-dependent system reset       | RESET 6                                                                                                       |
| POWER-OFF<br>SEQUENCE                           |              | power-off sequence                 | CP 0                                                                                                          |
| POWER-ON<br>SEQUENCE                            |              | power-on sequence                  | CP 2                                                                                                          |
| RESET                                           |              | system reset                       | CP 3, 9                                                                                                       |
| SYSTEM STOP                                     |              | system shutdown                    | EP 1                                                                                                          |
| В                                               | $\leq$ 7, 20 | channel state                      |                                                                                                               |
| $lpha^8/B$                                      |              | device status byte                 | CH2, 53, 60, 74, 81, 136; HFC 8; IOIE 18; IPL 5                                                               |
| $\boldsymbol{B}_{0}$                            |              | attention                          |                                                                                                               |
| $B_1$                                           |              | status modifier                    | CH 70 [i]                                                                                                     |
| $B_2$                                           |              | control unit end                   |                                                                                                               |
| $B_3$                                           |              | busy                               |                                                                                                               |
| $B_4$                                           |              | channel end                        |                                                                                                               |
| $B_5$                                           |              | device end                         | CH 69 [j]                                                                                                     |
| $B_6$                                           |              | unit check                         |                                                                                                               |
| $B_7$                                           |              | unit exception                     |                                                                                                               |
| $B_8$                                           |              | interruption pending in<br>channel | CH 2, 33, 36, 39, 52, 53, 59, 60, 73, 74, 81, 94, 96, 98, 100, 137, 155; CPU 25, 26; EXC c12; IOIE 0, 1, 4    |

Table 3 Continued

| symbol                                    | dimension     | significance                                           | references: set, used, [via local variable]                                                   |
|-------------------------------------------|---------------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| B <sub>9</sub>                            |               | channel working                                        | BMT 5; CH 2, 48, 57, 58, 104, 112, 115, 117, 118, 122, 127, 165; EXC c6, 14; IOIE 7, 9        |
| $B_{10}$                                  |               | interplay with CPU                                     | CH 2, 37, 43, 56, 62, 64, 72, 79, 134, 165; EXC<br>c9, 10, 13, 15; HFC 6; IOIE 8, 10, 11, 14  |
| $B_{11}$                                  |               | not operational                                        | CH 0, 1, 2; EXC c2                                                                            |
| $\omega^8/B$                              |               | device address for interruption                        | CH 53, 60, 73, 74, 81, 82, 88, 92, 97, 99; IOIE 0, 12, 15                                     |
| $\boldsymbol{c}$                          | <b>≤7, 64</b> | channel command                                        | CH 2, 6, 27, 48, 58, 86, 113                                                                  |
| $\alpha^8/C$                              |               | command code                                           | CH 2, 6, 19, 25 [k], 48, 86, 108 [k], 111 [k], 113, 123                                       |
| $C_7$                                     |               | read/write                                             | CH 10, 28                                                                                     |
| $\omega^{24}/lpha^{32}/	extbf{	extit{C}}$ |               | data address                                           | CH 11, 18, 19                                                                                 |
| $\omega^8/lpha^{32}/C$                    |               | device address (temporary)                             | CH 77, 93                                                                                     |
| $C_{32}$                                  |               | chain-data                                             | CH 8, 16, 21, 66, 67, 81, 156                                                                 |
| $C_{33}$                                  |               | chain-command                                          | CH 67, 79, 91, 156                                                                            |
| $C_{34}$                                  |               | suppress length indication                             | CH 8, 66, 81                                                                                  |
| $C_{35}$                                  |               | skip                                                   | CH 17                                                                                         |
| $C_{36}$                                  |               | program-controlled<br>interruption                     | CH 28, 114                                                                                    |
| $C_{37,38,39}$                            |               | unused positions                                       | $CH \ 26 \ [k], \ 111 \ [k]$                                                                  |
| $C_1^{40}$ (8)                            |               | ignored positions                                      |                                                                                               |
| $\omega^{16}/C$                           |               | count                                                  | CH 8, 9, 16, <b>20</b> , 21, 26 [k], 66, 81, 111 [k], 136, 154; HFC 8                         |
| CAW                                       | <b>≤7,</b> 32 | channel address word                                   | CH 2, 48, 58, 86, 102, 136, 154; HFC 8; IOIE 13                                               |
| $\alpha^4/CAW$                            |               | protection key                                         | CH 103; MAC 10                                                                                |
| $CAW_{4,5,6,7}$                           |               | unused positions                                       | CH 103                                                                                        |
| $\omega^{24}/CAW$                         |               | command address                                        | CH 6, 23, 24, 31, 70, 105, 106, 110                                                           |
| CM                                        | <b>≤7, 4</b>  | channel model characteristics                          | · ·                                                                                           |
| $CM_0$                                    |               | scan always/on request-<br>in only                     | CH 35                                                                                         |
| CM <sub>1,2,3</sub>                       |               | degrees of hardware sharing between $CPU$ and channels | HFC 1, 2; TOL 1                                                                               |
| E                                         | 4, 8          | external lines                                         |                                                                                               |
| $E^0$                                     |               | direct control out                                     | EXC a10                                                                                       |
| $E^{\scriptscriptstyle 1}$                |               | direct control in                                      | EXC a18                                                                                       |
| $E^2$                                     |               | timing signal out                                      | EXC a10, 12, 14, 16                                                                           |
| $E^3$                                     |               | timing signal in                                       | ES                                                                                            |
| F                                         | 4, 64         | floating-point registers                               | <i>CP</i> 20, 25; <i>EXC</i> k 3–13, 69, 70; Table 5                                          |
| I                                         | 3, 16         | instruction register                                   | CPU <b>3</b> , 12–19; EXC b <b>1</b> ; EXC                                                    |
| $\alpha^8/I^0$                            |               | instruction code                                       | CH 88-93, 101, 122, 123, 143-163; CPU 7, 8;<br>EXC b1, 3, 5, d9, g58, k1, 19, l0, 4, 5; HFC 9 |
| $\omega^8/I^0$                            |               | immediate data byte                                    | EXC a10, 14, 27, b4, 7, f4, g53                                                               |
| iJ                                        | -, 9          | from memory in MAC <sup>i</sup> operation              | CH 13, 14; MAC 19, 20, 22                                                                     |

Table 3 Continued

| symbol                  | dimension                    | significance                                                   | references: set, used, [via local variable]                                     |
|-------------------------|------------------------------|----------------------------------------------------------------|---------------------------------------------------------------------------------|
| K                       | ≤2 <sup>13</sup> , 4         | memory protection keys (one per bank of 2 <sup>11</sup> bytes) | EXC a6, 7; MAC 10                                                               |
| M                       | <b>≤</b> 2 <sup>24</sup> , 9 | main memory                                                    | CH 30, 109; EXC a3, 19, 11; MAC 8, 9, 19, 23<br>Table 5 Cols. A and <b>P</b>    |
| $M_0$                   |                              | parity column                                                  | $CH \ 13, \ 14 \ [ \cdot J_0 ]$                                                 |
| N                       | 144, 11                      | navigation matrix                                              | CPU 9                                                                           |
| 0                       | 16, 16                       | decoding matrix                                                | CPU 8                                                                           |
| <b>P</b>                | ≤7, 9                        | polling lines                                                  | CH 2, 34, 39, 40, 44, 78, 115, 116, 117, 119<br>121; TOL 5                      |
| R                       | 16, 32                       | general registers                                              | CP 19, 24; CPU 14-19; EXC; Table 5                                              |
| S                       | ≤7, 18                       | active subchannel status                                       |                                                                                 |
| $\alpha^8/S$            |                              | channel status byte                                            | CH 2, 9, 48, 58, 67, 86, 131, 136–159; HFC 8<br>IOIE 13; IPL 5                  |
| $S_0$                   |                              | program-controlled<br>interruption                             | CH 28, 59, 114, 136; IOIE 14                                                    |
| $S_1$                   |                              | incorrect length                                               | CH 8, 66, 81                                                                    |
| $S_2$                   |                              | program check                                                  | CH 12, 26, 30, 66, 81, 103, 107, 109, 111, 123<br>128, 136, 154, 156; MAC 16    |
| $S_3$                   |                              | protection check                                               | CH 66, 81, 136, 154; MAC 16                                                     |
| $S_4$                   |                              | channel data check                                             | CH 13, 15; HFC 1                                                                |
| $S_5$                   |                              | channel control check                                          | HFC 1                                                                           |
| $S_{\epsilon}$          |                              | interface control check                                        | CH 41, 51, 52, 62, 63, 116, 117, 125, 126, 141<br>HFC 1; TOL 0                  |
| $S_7$                   |                              | chaining check                                                 | CH 28, 66, 81                                                                   |
| $S_8$                   |                              | interruption pending in<br>subchannel                          | CH 2, 9, 48, 55, 58, 71, 81, 86, 87–93, 136, 137<br>145, 148, 153, 155          |
| $S_{9}$                 |                              | subchannel working                                             | CH 2, 48, 50, 58, 71, 81, 86, 87–93, 137, 145<br>  148, 165                     |
| $\omega^8/S$            |                              | working-device address                                         | CH 6, 45, 47, 53, 60, 73, 74, 77, 81, 82, 84, 88 92, 93, 115, 117; IOIE 12      |
| T                       | $\leq$ 256, 110              | subchannel storage                                             | CH 4, 48, 58, 85, 86, 99; IOIE 16, 18, 19                                       |
| U                       | <b>≤7, 16</b>                | channel/control unit<br>interface                              | CH 7, 14, 16, 39, 49, 55, 68, 76, 78, 96, 115, 124, 130, 151, 160, 164          |
| $U_0$                   |                              | command-out or status-in                                       | CH 36, 41, 52, 63, 117, 120, 126; TOL 1                                         |
| $U_1$                   |                              | service-out or service-in                                      | CH 36, 41, 52, 63, 65, 117, 126; TOL 1                                          |
| $U_2$                   |                              | address-out or address-in                                      | CH 36, 41, 42, 52, 63, 117, 126; TOL 1                                          |
| $U_3$                   |                              | interplay in/out                                               | CH 28, 40, 41, 51, 52, 62, 63, 116, 117, 125<br>TOL 1, 5, 9                     |
| $U_4$                   |                              | suppress-out                                                   | CH 2, 29, 36; HFC 5                                                             |
| $oldsymbol{U}_{5}$      |                              | operational-out                                                | CH 2; HFC 5                                                                     |
| $U_6$                   |                              | operational-in                                                 | CH 61; TOL 5, 9                                                                 |
| $U_7$                   |                              | parity bit for bus                                             | CH 15, 41, 52, 63, 117, 126                                                     |
| $\omega^8/	extcolor{U}$ |                              | bus for data or device<br>status                               | CH 11, 13–15, 18, 41, 45, 52, 53, 63, 67, 68, 74<br>117, 126, 128, 129, 149–159 |
| V                       | <b>≤</b> 56, 21              | control unit status                                            |                                                                                 |
| $V_8$                   |                              | service request                                                | CH 37, 38                                                                       |
| $V_{12}$                |                              | channel number                                                 | CH 37, 38                                                                       |

Table 3 Continued

| a a a a a a a a a a a a a a a a a a a         | 4              | effective addresses temporary address first address second address | CH 82; CPU 16, 19; EXC a, b11, b, c1, d, e<br>f, g, h, i0-5, 19-30, j, k1-13, 69, 70, l1-3<br>CPU 12, 15, 18; EXC a3-7, b1, 2, 13, 14, 23 |
|-----------------------------------------------|----------------|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| a1<br>a2<br>a3<br>address sw<br>alternate pfx |                | first address                                                      | f, g, h, i0-5, 19-30, j, k1-13, 69, 70, l1-3                                                                                              |
| a2<br>a3<br>address sw<br>alternate pfx       |                |                                                                    | f, g, h, i0-5, 19-30, j, k1-13, 69, 70, l1-3                                                                                              |
| a <sub>s</sub><br>address sw<br>alternate pfx |                | second address                                                     | CPU 12, 15, 18; EXC 93-7 b1 2 13 14 23                                                                                                    |
| address sw<br>alternate pfx                   |                |                                                                    | 24, d6, d, e3, f0, 1, 16, 18, g, h18, 19, i7–9, j0–16, k1–12, l1–3                                                                        |
| alternate pfx                                 |                | third address                                                      | CPU 13; EXC b18, 19, d17, 23                                                                                                              |
| = -                                           | 24             | address switch                                                     | CP 16-25; MAC 6                                                                                                                           |
| b                                             | 12             | alternate prefix                                                   | MAC 4                                                                                                                                     |
|                                               | 8              | console buttons                                                    | CP 5-7                                                                                                                                    |
| $\boldsymbol{b}_{\mathtt{0}}$                 |                | load key                                                           |                                                                                                                                           |
| $\boldsymbol{b}_1$                            |                | reset key                                                          |                                                                                                                                           |
| $oldsymbol{b}_2$                              |                | interrupt key                                                      |                                                                                                                                           |
| $\boldsymbol{b_3}$                            |                | stop key                                                           |                                                                                                                                           |
| $b_4$                                         |                | start key                                                          |                                                                                                                                           |
| $b_{\mathfrak{b}}$                            |                | set-instruction-counter key                                        |                                                                                                                                           |
| $b_6$                                         |                | display key                                                        |                                                                                                                                           |
| $b_7$                                         |                | store key                                                          |                                                                                                                                           |
| cpu status                                    | $8 \times m_6$ | CPU registers stored in diagnosis                                  | MCIE 8                                                                                                                                    |
| data sw                                       | 32             | data switch                                                        | CP 16, 23–25                                                                                                                              |
| display lights                                | 32             | display lights                                                     | CP 18-21                                                                                                                                  |
| e                                             | 6              | external signal lines                                              |                                                                                                                                           |
| $e_0$                                         |                | write out                                                          | EXC a10, 12                                                                                                                               |
| $e_1$                                         |                | read out                                                           | EXC a14, 16                                                                                                                               |
| $\boldsymbol{e}_2$                            |                | hold in                                                            | EXC a17; TU 0                                                                                                                             |
| $e_3$                                         |                | machine-check out                                                  | MCIE 3, 5                                                                                                                                 |
| e <sub>4,5</sub>                              |                | IPL in-lines                                                       | CP 5-7                                                                                                                                    |
| external signals                              | 6              | set by E³                                                          | EIE 0, 2, 3; ES 0                                                                                                                         |
| f                                             |                | failures (parity, etc.)                                            | HFC 4; IPL 9; MAC 22; MCIE 0, 9;<br>RESET 0                                                                                               |
| fill                                          | 8              | fill character                                                     | EXC h13, 16, 25                                                                                                                           |
| g                                             | 3              | general interlock bits                                             | RESET 0                                                                                                                                   |
| <i>g</i> <sub>0</sub>                         |                | interruption interlock                                             | CH 62, 64, 72, 82, 87–92, 117, 122, 123, 132–157; CPU 27, 28; EIE 1, 4; HFC 9; IOIE 0, 2; MCIE 9                                          |
| $oldsymbol{g}_1$                              |                | I/O interruption retraction                                        |                                                                                                                                           |
| $oldsymbol{g}_2$                              |                | burst-timer control                                                | BMT 0, 1; CH 48, 58, 165; EXC c5; IOIE 6                                                                                                  |
| ħ                                             | 5              | interruption holder                                                | CPU 25, 26, 29; RESET 0                                                                                                                   |
| $h_0$                                         |                | machine check                                                      | MCIE 1                                                                                                                                    |
| $h_1$                                         |                | program check                                                      | CPU 24; MCIE 9                                                                                                                            |
| $h_2$                                         |                | supervisor call                                                    | EXC a27; MCIE 9                                                                                                                           |
| $h_3$                                         |                | external                                                           | EIE 0                                                                                                                                     |
| h <sub>4</sub>                                |                | I/O                                                                | IOIE 1                                                                                                                                    |

Table 3 Continued

| symbol                        | dimension | significance                                        | references: set, used, [via local variable]         |
|-------------------------------|-----------|-----------------------------------------------------|-----------------------------------------------------|
| i, j, k                       |           | local variables                                     |                                                     |
| !                             | 3         | field lengths                                       | CPU 17; EXC f22, 26, 31, g, h5, 36, j               |
| load unit sw                  | 11        | load unit switch                                    | CH 5, 6; IPL 5, 6                                   |
| m                             | 11        | machine (model) char-<br>acteristics                |                                                     |
| $m_0$                         |           | protection feature                                  | CH 103; CPU 2; MAC 11; N <sub>0</sub>               |
| $m_1$                         |           | decimal feature                                     | $N_0$                                               |
| $m_2$                         |           | floating-point feature                              | $N_0$                                               |
| $m_3$                         |           | direct control feature                              | $N_0$                                               |
| $m_4$                         |           | interlock feature                                   | $N_0$                                               |
| $m_5$                         |           | memory width in bytes                               | CP 18, 23; MAC 6                                    |
| $m_6$                         |           | number of bytes in<br>machine check                 | MCIE 8                                              |
| $m_7$                         |           | number of final 0's in diagnose                     | EXC a19                                             |
| $m_8$                         |           | diagnose completion option                          | EXC a22                                             |
| $m_9$                         |           | set IC key option                                   | CP 16                                               |
| $m_{10}$                      |           | burst mode interval                                 | BMT 2                                               |
| main þfx                      | 12        | main prefix                                         | MAC 4                                               |
| n                             | 11        | navigation vector                                   | CPU 9                                               |
| $n_0$                         |           | instruction set options $(m_0, m_1, m_2, m_3, m_4)$ | CPU 10                                              |
| $n_1$                         |           | privileged operations                               | CPU 10                                              |
| $n_2$                         |           | format (RR, RX, RS, SS, SI)                         | CPU 11                                              |
| $n_3$                         |           | starting line in EXC                                | CPU 21; EXC 0; TU 0                                 |
| $\bar{\alpha}^4/n$            |           | branch control in EXC                               | EXC                                                 |
| Þ                             | 64        | program status word                                 | CPU 31, 32; EXC a26; IPL 7                          |
| α <sup>8</sup> / <b>p</b>     |           | system mask                                         | CPU 25, 26; EXC a2; IOIE 4                          |
| p <sub>8,9,10,11</sub>        |           | protection key                                      | CPU 2; MAC 10                                       |
| <b>p</b> <sub>12</sub>        |           | (extended BCD/Ameri-<br>can standard) code          | EXC g24, h2, j19, 36                                |
| <b>p</b> 12                   |           | machine check mask                                  | MCIE 0                                              |
| <b>p</b> <sub>14</sub>        |           | (running/wait) state                                | CPU 36                                              |
| <b>p</b> <sub>18</sub>        |           | (supervisor/program)<br>state                       | CPU 10                                              |
| <b>p</b> 1 <sup>16</sup> (16) |           | interruption code                                   | CPU 24, 33; EIE 2, 3; EXC a27; IOIE 0 IPL 8; MCIE 6 |
| <b>p</b> 32,23                |           | instruction length code                             | CPU 1-7, 23, 33; EXC b10; IPL 8                     |
| <b>p</b> 34,35                |           | condition code                                      | CH 133, 138, 146, 161; EXC b10, b11; Table 3        |
| <b>p</b> <sub>36</sub>        |           | fixed-point overflow mask                           | EXC a0, b10, d12, e9, i24                           |
| <b>p</b> <sub>37</sub>        |           | decimal overflow mask                               | EXC a0, b10, j29                                    |
| <b>p</b> <sub>38</sub>        |           | exponent underflow mask                             |                                                     |
| <b>p</b> <sub>39</sub>        |           | lost significance mask                              | EXC a0, b10, k41, 42, 72                            |
| $\omega^{24}/p$               |           | instruction address                                 | CP 16, 21; CPU 3, 5; EXC b10, 13, 14, 23, 2         |
| pattern                       | 8         | character from pattern<br>field                     | EXC h11, 12, 13                                     |

Table 3 Continued

| symbol                 | dimension | significance                                                              | references: set, used, [via local variable]                                                                                 |
|------------------------|-----------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| q                      | 10        | memory-access queue                                                       | MAC 0, 1, 24                                                                                                                |
| r                      | 10        | memory-access request                                                     | MAC 0, 2, 24                                                                                                                |
| rank                   | 10        | MAC priority (7 channels with 0 in arbitrary position, timer update, CPU) | IOIE 4; MAC 1                                                                                                               |
| s                      |           | local variable                                                            |                                                                                                                             |
| source                 | 8         | character from source field                                               | EXC h18, 20–23                                                                                                              |
| $\frac{t}{t_i}$        | 16        | program exceptions exception with code $i$                                | CPU 1-10, 21-24; EXC; MAC 15; Table 5                                                                                       |
| time-out limit<br>u, v | 2         | time limits<br>local variables                                            | TOL 2, 6                                                                                                                    |
| w                      | ≤7        | number of control units on interface                                      | CH 40, 116, 117, 119; TOL 5                                                                                                 |
| address compare sw     |           | address compare switch                                                    | MAC 5                                                                                                                       |
| b                      |           | index of console button<br>being serviced                                 | CH 5; CP 6, 7–14; IPL 3, 4                                                                                                  |
| c                      |           | channel index                                                             | CH 5, 37, 38; CH; HFC; TOL                                                                                                  |
|                        |           | distinction between se-<br>lector and multiplexor<br>channels             | CH 3, 32, 36, 39, 44, 46, 50, 52, 54, 61, 73, 75, 80, 83, 87–95, 121, 145, 148, 155, 165; EXC [i] c4, 14; IOIE [i] 5, 9, 12 |
| class                  |           | (digit select/significance<br>start/field separator/<br>other)            | EXC h7, 8, 12, 14, 15                                                                                                       |
| console interrupt      |           | set by interrupt key                                                      | CP 11; EIE 0, 2, 3                                                                                                          |
| emergency pull sw      |           | emergency pull switch                                                     | EP 0, 2                                                                                                                     |
| h                      |           | index of interruption being serviced                                      | CPU 26, 27-32; EIE 1; IOIE 2                                                                                                |
| i                      |           | local variable                                                            |                                                                                                                             |
| ipl                    |           | initial program load                                                      | CH 5; CP 10; CPU 0; IPL 0, 10; RESET 1                                                                                      |
| j, k                   |           | local variables                                                           | 6                                                                                                                           |
| load light             |           | on during initial program                                                 | IPL 2, 10; RESET 5                                                                                                          |
| manual light           |           | on when CPU stopped                                                       | CPU 35, TU 0                                                                                                                |
| operating state        |           | CPU operate or stop                                                       | CP 12, 13, 15; CPU 34, 35; IPL 10; MAC 5, 6; RESET 1                                                                        |
| pfx sw                 |           | prefix select switch                                                      | IPL 3                                                                                                                       |
| $pfx \ tgr$            |           | prefix trigger                                                            | IPL 3; MAC 4                                                                                                                |
| power-off key          |           | power-off key                                                             | CP 4                                                                                                                        |
| power-on key           |           | power-on key                                                              | CP 1                                                                                                                        |
| rate sw                |           | rate switch                                                               | CPU 34; TU 0                                                                                                                |
| 8                      |           | local variable                                                            | ·                                                                                                                           |
| storage select sw      |           | storage select switch                                                     | CP 17, 22                                                                                                                   |
| t                      |           | subchannel index                                                          | CH 47, 48, 58, 84, 85, 86, 97                                                                                               |
| tick                   |           | timer pulse                                                               | T 1; TU 0, 5                                                                                                                |
| timer alarm            |           | interval timer alarm                                                      | EIE 0, 2, 3; TU 4                                                                                                           |
| timer frequency        |           | 50, 60, 300 $\times$ 2 <sup>i</sup> c.p.s. (0 $\leq$ i $\leq$ 8)          | T~0;TU~2                                                                                                                    |
| $\boldsymbol{w}$       |           | wait for timer update                                                     | MAC 2, 24                                                                                                                   |
| wait light             |           | on during wait state                                                      | CPU <b>36</b>                                                                                                               |

Table 5 Navigation matrix and reference table

|                                                                                                                | No                                   | avigat                                         | tion matrix N(1)                                                                                                                                                             |                                                          |                                               | Machine instruction ②                                                                                                                                                                           |                                                          | Results 3                                           |                                  |        |   | P                          | rogra                                                    | m | exce   | ption | s <b>①</b> |             |                  |                |
|----------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------|----------------------------------|--------|---|----------------------------|----------------------------------------------------------|---|--------|-------|------------|-------------|------------------|----------------|
| 0                                                                                                              | 1                                    | 2                                              | 3 4 5 6 7 8 9 10                                                                                                                                                             | Index                                                    | Mne-<br>monic                                 | Name                                                                                                                                                                                            | Code                                                     | R F \$24,35                                         |                                  |        |   |                            |                                                          |   |        |       |            |             |                  | LS FK<br>14 15 |
| 0<br>1<br>m <sub>2</sub><br>m <sub>2</sub><br>m <sub>2</sub><br>1<br>1<br>1<br>m <sub>1</sub>                  | 0<br>0<br>0<br>0<br>0<br>0<br>0      | 1 1 0 1 1 0 3                                  | 10                                                                                                                                                                           | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8                | A AD ADR AE AER AH AL ALR AP                  | undefined operation codes Add Add Normalized (Long) Add Normalized (Long) Add Normalized (Short) Add Normalized (Short) Add Normalized (Short) Add Halfword Add Logical Add Logical Add Decimal | 5A<br>6A<br>2A<br>7A<br>3A<br>4A<br>5E<br>1E<br>FA       | 1 4 1 4 1 4 4 1 4 1 4 4                             | S<br>S<br>S<br>S<br>S            | -      | T | S<br>T<br>T<br>T           | \$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$             | ( | c<br>c | c     |            | T<br>T<br>T | $_{C}^{C}$       | $_{c}^{c}$     |
| 1<br>m <sub>2</sub><br>m <sub>2</sub><br>m <sub>2</sub><br>1<br>1<br>1<br>1                                    | 0 0 0 0 0 0 0 0                      | 0<br>1                                         | $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                         | 10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18       | AR AU AUR AW AWR BAL BALR BC BCR BCT          | Add Unnormalized (Short) Add Unnormalized (Short) Add Unnormalized (Long) Add Unnormalized (Long) Branch and Link Branch and Link Branch on Condition Branch on Condition Branch on Condition   | 1A<br>7E<br>3E<br>6E<br>2E<br>45<br>05<br>47<br>07<br>46 | 1 4 ½ 4 ½ 4 1 4 1 4 1 1 1 1 1 1 1 1 1 1             | 8<br>8<br>8<br>8                 |        |   | T<br>T                     | 8<br>8<br>8<br>8                                         | • | c      |       |            | T<br>T<br>T |                  | с<br>с<br>с    |
| 1<br>1<br>1<br>1<br>m <sub>2</sub><br>m <sub>2</sub><br>m <sub>2</sub><br>m <sub>2</sub><br>1                  | 0 0 0 0 0 0 0 0 0                    | 2                                              | -b8 0 1                                                                                                                                                                      | 20<br>21<br>22<br>23<br>24<br>25<br>26<br>27<br>28<br>29 | BCTR BXH BXLE C CD CDR CE CER CH CL           | Branch on Count Branch on Index High Branch on Index Low or Equal Compare Compare (Long) Compare (Long) Compare (Short) Compare (Short) Compare Halfword Compare Logical                        | 06<br>86<br>87<br>59<br>69<br>29<br>79<br>39<br>49<br>55 | 1<br>1<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3<br>3 | 8<br>8<br>8                      |        |   | T<br>T<br>T                | \$<br>\$<br>\$<br>\$<br>\$<br>\$                         |   |        |       |            |             |                  |                |
| 1 1 1 m <sub>1</sub> 1 1 1 1 m <sub>2</sub> m <sub>2</sub>                                                     | 0 0 0 0 0 0 0 0 0                    | 3<br>4<br>0<br>3<br>0<br>1<br>1<br>1<br>1      | f14 0                                                                                                                                                                        | 30<br>31<br>32<br>33<br>34<br>35<br>36<br>37<br>38<br>39 | CLC CLI CLR CP CR CVB CVD D DD DDD            | Compare Logical Compare Logical Compare Logical Compare Decimal Compare Convert to Binary Convert to Decimal Divide Divide (Long) Divide (Long)                                                 | D5<br>95<br>15<br>F9<br>19<br>4F<br>4E<br>5D<br>6D<br>2D | 3<br>3<br>3<br>3<br>3<br>1                          | s                                |        | s | T<br>T<br>T<br>S<br>T<br>T | S 2 S S S S S                                            |   |        |       |            | T<br>T      |                  | s<br>s         |
| m <sub>2</sub> m <sub>2</sub> 1 m <sub>1</sub> 1 m <sub>1</sub> 1 m <sub>1</sub> m <sub>1</sub> m <sub>2</sub> | 0<br>0<br>1<br>0<br>0<br>0<br>0<br>0 | 1<br>0<br>4<br>3<br>0<br>3<br>3<br>1<br>0      | $\begin{array}{c} k0\ 4\ 3\ -1\ 1\ 1\ 2\\ k0\ 5\ 3\ -1\ 1\ 1\ 2\\ a19\\\ i0\ 0\ 3\ 3\ -0\ 1\\ h0\ 0\ 1\\\ h0\ 1\ 0\\\ k0\ 9\ 0\\ 1\ 2\ 0\\ k0\ 6\ 0\\ 1\ 1\ 0\\ \end{array}$ | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49 | DE DER diagnose DP DR ED EDMK EX HDR HER      | Divide (Short) Divide (Short) Diagnose Divide Decimal Divide Edit Edit and Mark Execute Halve (Long) Halve (Short)                                                                              | 7D<br>3D<br>83<br>FD<br>1D<br>DE<br>DF<br>44<br>24<br>34 | 2<br>3<br>1† 3                                      | \$<br>\$<br>\$<br>\$<br>\$<br>\$ | s      | T | T<br>S<br>T<br>T<br>T<br>S | \$ \$ \$ \$ \$ \$ \$ \$ \$ \$ \$ \$ \$ \$ \$ \$ \$ \$ \$ | ľ | ,      | S     | S          | T<br>T      |                  | S<br>S         |
| 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>m <sub>2</sub><br>m <sub>2</sub><br>1<br>m <sub>2</sub>                | 1<br>0<br>1<br>0<br>0<br>0<br>0<br>0 | 4<br>1<br>0<br>1<br>1<br>0<br>0<br>0<br>0      | c0 1 1 d7 f a3 1 0 0 0 d1 f k0 9 1 0 2 0 d8 k0 1 f k0 1 f k0 1 f k0 1 f k0 3                                                    | 50<br>51<br>52<br>53<br>54<br>55<br>56<br>57<br>58<br>59 | HIO IC ISK L LA LCDR LCER LCER LCR LD LDR     | Halt I/O Insert Character Insert Storage Key Load Load Address Load Complement (Long) Load Complement (Short) Load Complement Load (Long) Load (Long)                                           | 9E<br>43<br>09<br>58<br>41<br>23<br>33<br>13<br>68<br>28 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1               | s<br>s<br>s                      | s<br>s |   | T<br>S<br>T                | 8<br>8<br>8<br>8                                         |   | c      |       |            |             |                  |                |
| m <sub>2</sub> m <sub>5</sub> 1 1 m <sub>2</sub> m <sub>2</sub> 1 m <sub>2</sub> 1 m <sub>2</sub> 1            | 0<br>0<br>0<br>0<br>0<br>0<br>0      | 1<br>0<br>1<br>2<br>0<br>0<br>0<br>0<br>0      | k0 0 f k0 2 d13 d13 f 0 d13 f 0 k0 9 1 0 1 0 d8 d 2 0 k0 6 1 0 1 0 d8 d 2 0 d8 d 60 6 1 0 1 0 d8 d 60 6 1 0 1 0 d8 d 60 6 1              | 60<br>61<br>62<br>63<br>64<br>65<br>66<br>67<br>68<br>69 | LE LER LH LM LNDR LNER LNR LPDR LPER LPER LPR | Load (Short) Load (Short) Load Halfword Load Multiple Load Negative (Long) Load Negative (Short) Load Positive (Long) Load Positive (Long) Load Positive (Short) Load Positive (Short)          | 78<br>38<br>48<br>98<br>21<br>31<br>11<br>20<br>30<br>10 | 1 2 1 2 1 2 1 2 1 2 1 3                             | s<br>s<br>s<br>s                 |        |   | T<br>T<br>T                | S<br>S<br>S<br>S<br>S<br>S                               |   | c      |       |            |             |                  |                |
| 1<br>1<br>m <sub>2</sub><br>m <sub>2</sub><br>1<br>1<br>m <sub>2</sub><br>m <sub>2</sub><br>m <sub>2</sub>     | 1<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 4<br>0<br>0<br>0<br>0<br>0<br>1<br>1<br>0<br>1 | $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                         | 70<br>71<br>72<br>73<br>74<br>75<br>76<br>77<br>78<br>79 | LPSW LR LTDR LTER LTER M MD MDR MDR ME MER    | Load PSW Load Load and Test (Long) Load and Test (Short) Load and Test Multiply Multiply (Long) Multiply (Long) Multiply (Short) Multiply (Short)                                               | 82<br>18<br>22<br>32<br>12<br>5C<br>6C<br>2C<br>7C<br>3C | 1 3 ½ 3 1 3 2 1 1 1 ½ ½ ½                           | s<br>s<br>s<br>s                 | S      |   | T<br>T<br>T                | \$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$<br>\$             |   |        |       |            | T           | c<br>c<br>c<br>c |                |

Table 5 Continued

| Nav                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | igation matrix N <sub>1</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                    |                                                                           | Machine instruction 3                                                                                                                                                                                 |                                                          | Results 3                         |                                 |          |                                         | Prog                                 | ram (  | excepti | ons( |        | •          |                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------|---------------------------------|----------|-----------------------------------------|--------------------------------------|--------|---------|------|--------|------------|--------------------------------------------|
| 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 2 3 4 5 6 7 8 9 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Index                                                              | Mne-<br>monic                                                             | Name                                                                                                                                                                                                  | Code                                                     | R F p <sub>34,2</sub>             |                                 |          | EX P A                                  |                                      |        |         |      |        |            |                                            |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1 i4 2 2 0 3 1 3 j5 1 0 2 3 0 4 - 0 i0 0 2 2 - 0 0 - 3 g54 1 2 3 g54 0 2 | 80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88                 | MH MP MR MVC MVI MVN MVO MVZ N NC                                         | Multiply Halfword Multiply Decimal Multiply Move Move Move Numerics Move with Offset Move Zones And And                                                                                               | 4C<br>FC<br>1C<br>D2<br>92<br>D1<br>F1<br>D3<br>54       | 1 2 1 2 2                         | s                               |          | T T T S S S T T T T T T T T T T T T     | s<br>s<br>s                          |        |         |      |        |            |                                            |
| 1 0<br>1 0<br>1 0<br>1 0<br>1 0<br>1 0<br>m <sub>2</sub> 1<br>1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 4 f3 1 0 1 0 f1 1 0 0 1 f0 1 1 0 3 f14 1 1 4 f3 1 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 90<br>91<br>92<br>93<br>94<br>95<br>96<br>97<br>98                 | NI<br>NR<br>O<br>OC<br>OI<br>OR<br>PACK<br>RDD<br>S<br>SD                 | And And Or Or Or Or Pack Read Direct Subtract Subtract Normalized (Long)                                                                                                                              | 94<br>14<br>56<br>D6<br>96<br>16<br>F2<br>85<br>5B<br>6B | 1 2 1 2 2 2 1 2 1 2 1 1 4 1 4 1 4 | s<br>s                          | S        | S S  T T T S S  T T T T T T T T T T T T | s                                    | c      |         |      | T      | " <i>c</i> | · c                                        |
| m <sub>2</sub> 0<br>m <sub>2</sub> 0<br>1 0<br>1 1<br>1 0<br>1 0<br>1 0<br>1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0 k0 8 2 2 1 0 2 1<br>1 k0 4 2 0 1 0 1 1<br>0 k0 5 2 0 1 0 1 1<br>1 i4 2 1 0 2 1<br>4 c0 0 2<br>2 e0 2 0<br>2 e1 2 1<br>2 e0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 100<br>101<br>102<br>103<br>104<br>105<br>106<br>107<br>108<br>109 | SDR<br>SE<br>SER<br>SH<br>SIO<br>SL<br>SLA<br>SLDA<br>SLDA<br>SLDL<br>SLL | Subtract Normalized (Long) Subtract Normalized (Short) Subtract Normalized (Short) Subtract Halfword Start I/O Subtract Logical Shift Left Single Shift Left Double Logical Shift Left Single Logical | 2B<br>7B<br>3B<br>4B<br>9C<br>5F<br>8B<br>8F<br>8D<br>89 | 1 4 1 4 1 4 1 3 1 4 2 4 1         | S<br>S<br>S                     | s        | T<br>T                                  | \$<br>\$<br>\$<br>\$<br>\$<br>\$     | c<br>c | ,       |      |        | , c        |                                            |
| m <sub>1</sub> 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 i5 0 1 0 1 2 3 i5 2 0 1 2 0 3 - 0 a0 0 i4 0 1 0 2 0 2 e 0 3 0 2 e 1 1 1 2 e 0 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 110<br>111<br>112<br>113<br>114<br>115<br>116<br>117<br>118<br>119 | SLR<br>SP<br>SPM<br>SR<br>SRA<br>SRDA<br>SRDL<br>SRL<br>SSK<br>SSM        | Subtract Logical Subtract Decimal Set Program Mask Subtract Shift Right Single Shift Right Double Shift Right Double Logical Shift Right Single Logical Set Storage Key Set System Mask               | 1F<br>FB<br>04<br>1B<br>8A<br>8E<br>8C<br>88<br>08       | 1 3 4 4 1 3 2 3 2 1               | s                               | s<br>s   | T T                                     | s<br>s                               | T C    | Ó       |      |        |            |                                            |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1 d1 s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 120<br>121<br>122<br>123<br>124<br>125<br>126<br>127<br>128<br>129 | ST<br>STC<br>STD<br>STE<br>STH<br>STM<br>SU<br>SUR<br>SVC<br>SW           | Store Store (Long) Store (Long) Store (Short) Store Halfword Store Multiple Subtract Unnormalized (Short) Subtract Unnormalized (Short) Supervisor Call Subtract Unnormalized (Long)                  | 50<br>42<br>60<br>70<br>40<br>90<br>7F<br>3F<br>0A<br>6F | 1 4<br>1 4                        | s<br>s<br>s                     |          | S S S S S S S S T T T T                 | S<br>S<br>S<br>S<br>S<br>S<br>S<br>S |        |         |      | T<br>T |            | $\begin{array}{c} c \\ c \\ c \end{array}$ |
| 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0 k0 8 2 3 1 0 2 1<br>4 c0 0 0<br>4 b6<br>3 g46 - 2<br>4 a28<br>3 g23<br>1 f0 1 2 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 130<br>131<br>132<br>133<br>134<br>135<br>136<br>137<br>138<br>139 | SWR<br>TCH<br>TIO<br>TM<br>TR<br>TRT<br>TS<br>UNPK<br>WRD<br>X            | Subtract Unnormalized (Long) Test Channel Test 1/O Test under Mask Translate Translate and Test Test and Set Unpack Write Direct Exclusive Or                                                         | 2F<br>9F<br>9D<br>91<br>DC<br>DD<br>93<br>F3<br>84<br>57 | 1 4 4 4 3 3 2 1 2 1 2             | s<br>s                          | s<br>s   | T T T T S T T T T T                     | S                                    |        |         |      | T      |            | C                                          |
| 1 0 d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 3 f14 1 2 4 f3 1 2 1 5 f1 1 2 0 6 j5 0 1 - 2 0 3 -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 140<br>141<br>142<br>143                                           | XC<br>XI<br>XR<br>ZAP                                                     | Exclusive Or<br>Exclusive Or<br>Exclusive Or<br>Zero and Add                                                                                                                                          | D7<br>97<br>17<br>F8                                     | 1 2<br>4                          | s                               |          | T T S S                                 |                                      | T      | c       |      |        |            |                                            |
| O Feature options 1 Privileged operation 2 Format 3 Starting line in EXC 4-10 Branches in EXC  The mnemonics, names, and hexadecimal codes assigned in Reference 1.  O Specifies the number of general and floating-point registers set, and the number of distinct values to which the condition code may be set.  † R is set (not specified by address)  † R and R are set (not specified by address)  † R and R are set (not specified by address)  † R one to sixteen cyclically contiguous registers are set.  O Definal Divide to the condition of the condition code may be set.  † R and R are set (not specified by address)  † R one to sixteen cyclically contiguous registers are set.  O Definal Divide to the condition of the condition code are code abbr name    1 OP Operation |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                    |                                                                           |                                                                                                                                                                                                       |                                                          |                                   | zerflivide<br>low<br>e<br>rflow | ow<br>ow |                                         |                                      |        |         |      |        |            |                                            |

|                         |    |               |      |      |                |      |      | Secon | nd Hexad | lecimal I | Digit         |     |          |            |             |      |           |          |
|-------------------------|----|---------------|------|------|----------------|------|------|-------|----------|-----------|---------------|-----|----------|------------|-------------|------|-----------|----------|
|                         | ,  | 0             | 1    | 2    | 3              | 4    | 5    | 6     | 7        | 8         | 9             | A   | В        | C          | D           | E    | F         |          |
|                         | 0  |               |      |      |                | SPM  | BALR | BCTR  | BCR      | SSK       | ISK           | svc |          |            |             |      |           | <u> </u> |
|                         |    | 0             | 0    | 0    | 0              | 112  | 16   | 20    | 18       | 118       | 52            | 128 | 0        | 0          | 0           | 0    | 0         |          |
|                         | 1  | LPR           | LNR  | LTR  | LCR            | NR   | CLR  | OR    | XR       | LR        | CR            | AR  | SR       | MR         | DR          | ALR  | SLR       | l        |
|                         |    | 69            | 66   | 74   | 57             | 91   | 32   | 95    | 142      | 71        | 34            | 10  | 113      | 82         | 44          | 8    | 110       | RR       |
|                         | 2  | LPDR          | LNDR | LTDR | LCDR           | HDR  |      |       |          | LDR       | CDR           | ADR | SDR      | MDR        | DDR         | AWR  | swr       | 1        |
|                         | -  | 67            | 64   | 72   | 55             | 48   | 0    | 0     | 0        | 59        | 25            | 3   | 100      | 77         | 39          | 14   | 130       | ļ        |
|                         | 3  | LPER          | LNER | LTER | LCER           | HER  |      |       |          | LER       | CER           | AER | SER      | MER        | DER         | AUR  | SUR       |          |
|                         |    | 68            | 65   | 73   | 56             |      | 0    | 0     | 0        |           | 27            | 5   | 102      | 79         | 41          | 12   |           | Ì        |
|                         | 4  | STH           | LA   | STC  | IC             | EX   | BAL  | BCT   | BC       | LH        | CH            | AH  | SH       | MH         |             | CVD  | CVB       | )        |
|                         |    | 124           | 54   | 121  | 51             |      | 15   |       |          |           | 28            | 6   | 103      | 80         | 0           |      | 35        |          |
|                         | 5  | $\mathbf{ST}$ |      |      |                | N    | CL   | О     | X        | L         | С             | A   | S        | M          | D           | AL   | SL        | ]        |
|                         |    | 120           | 0    | 0    | 0              | 88   | 29   | 92    | 139      |           | 23            | 1   | 98       | 75         | 37          | 7    | 105       | RX       |
|                         | 6  | STD           |      |      |                |      |      |       |          | LD        | CD            | AD  | SD       | MD         | DD          | AW   | sw        |          |
| )igit                   |    | 122           | 0    | 0    | 0              | 0    | 0    | 0     | 0        | LE        | CE CE         | 2   | 99<br>SE | 76<br>ME   | 38<br>DE    | AU   | 129<br>SU |          |
| nal I                   | 7  | STE           |      |      | 0              | 0    | 0    | 0     | 0        |           |               | AE  |          |            |             |      |           |          |
| First Hexadecimal Digit |    | 123<br>SSM    | 0    | LPSW | diagnose       |      | RDD  | BXH   | BXLE     |           | SLL           | SRA | SLA      | 78<br>SRDL | SLDL        | SRDA | SLDA      | ,        |
| exac                    | 8  | 119           | 0    | 70   | diagnose<br>42 |      | 97   | 21    | 22       | 117       | 109           | 114 | 106      | 116        | 108         | 115  | 107       |          |
| rst H                   |    | STM           | TM   | MVI  | TS 42          | NI   | CLI  | OI OI | XI       | LM        | 109           | 114 | 100      | SIO        | TIO         | HIO  | TCH       |          |
| Ħ                       | 9  | 125           | 133  | 84   | 136            |      | 31   | 94    | 141      | 63        | 0             | 0   | 0        | 104        | 132         | 50   | 131       | RS       |
|                         |    |               |      | 01   | 130            | - 00 | 01   |       |          |           | ļ- <b>-</b> - | -   |          | 101        |             |      | 101       | or<br>SI |
|                         | A  | 0             | 0    | 0    | 0              | 0    | 0    | 0     | 0        | 0         | 0             | 0   | 0        | 0          | 0           | 0    | 0         | 1 21     |
|                         |    |               |      |      |                |      |      |       |          | <u> </u>  | -             |     |          |            | <u> </u>    |      |           | 1        |
|                         | В  | 0             | 0    | 0    | 0              | 0    | 0    | 0     | 0        | 0         | 0             | 0   | 0        | 0          | 0           | 0    | 0         |          |
|                         | _  |               |      |      |                |      | -    |       |          |           | i             |     |          |            |             |      |           | í        |
|                         | C  | 0             | 0    | 0    | 0              | 0    | 0    | o     | 0        | 0         | 0             | 0   | 0        | 0          | 0           | 0    | 0         | 1        |
|                         | _  |               | MVN  | MVC  | MVZ            | NC   | CLC  | oc    | xc       |           |               |     |          | TR         | TRT         | ED   | EDMK      | 1        |
|                         | D. | 0             | 85   | 83   | 87             | 89   | 30   | 93    | 140      | 0         | 0             | 0   | 0        | 134        | 135         | 45   | 46        |          |
|                         | _  |               |      |      |                |      |      | _     |          |           |               |     |          |            | <del></del> |      |           | SS       |
|                         | E  | 0             | 0    | 0    | 0              | 0    | 0    | 0     | 0        | 0         | 0             | 0   | 0        | 0          | 0           | 0    | 0         |          |
|                         | F  |               | MVO  | PACK | UNPK           |      |      | _     |          | ZAP       | CP            | AP  | SP       | MP         | DP          |      |           |          |
|                         | г  | 0             | 86   | 96   | 137            | 0    | 0    | 0     | 0        | 143       | 33            | 9   | 111      | 18         | 43          | 0    | 0         | J        |

Table 7 Normal uses of effective addresses

| -                  | Format                      | First operand          | Second operand         |
|--------------------|-----------------------------|------------------------|------------------------|
| $\overline{ m RR}$ | (register, register)        | $R^{a_1}$ or $F^{a_1}$ | $R^{a_2}$ or $F^{a_2}$ |
| RX                 | (register, storage indexed) | $R^{a_1}$ or $F^{a_1}$ | $M^{a_z}$              |
| RS                 | (register, storage)         | $R^{a_1}$              | $M^{a_2}$              |
| $\mathbf{SI}$      | (storage, immediate)        | $M^{a_1}$              | $\omega^{_8}/I^{_0}$   |
| SS                 | (storage, storage)          | $M^{a_1}$              | $M^{a_2}$              |

#### MCIE, machine check interruption entry system program

```
0: p_{13} \wedge \vee /f
                                                                                                       0
h_0 \leftarrow 1
                                                                                                        1
\rightarrow CPU; 26
                                                                                                        2
e_3 \leftarrow 1
                                                                                                        3
DELAY (\frac{1}{2} to 1 microsecond)
                                                                                                        4
                                                                                                        5
p_{i^{16}(16)} \leftarrow \tilde{\epsilon} (16)
                                                                                                       6
DIAGNOSE
                                                                                                       7
MAC^{9}(128, m_6, s, g; cpu status)
                                                                                                       8
h_1, h_2, g_0, f \leftarrow \bar{\epsilon}
                                                                                                       9
```

## EIE, external interruption entry system program

```
 \begin{array}{l} \Longrightarrow & h_3 \leftarrow \sqrt{\text{timer alarm, console interrupt, external signals}} & 0 \\ 0: g_0 \wedge (h=3) & 1 \\ p_{1^{16}(16)} \leftarrow \bar{\epsilon}(8), \text{ timer alarm, console interrupt, external signals} & 2 \\ \text{timer alarm, console interrupt, external signals} \leftarrow & 3 \\ \text{(timer alarm, console interrupt, external signals)} \wedge \bar{p}_{1,24}(8) \\ & g_0 \leftarrow 0 & 4 \\ \end{array}
```

#### ES, external signals system program

```
external signals \leftarrow (\omega^6/E^3) \lor external signals 0
```

#### TU, timer update system program

```
0: tick \land (manual light = off) \land (rate sw = process) \land 0

(\sim e_2 \land n_3 = a13)

MAC^8(80, 4, f, g; j) 1

k \leftarrow (32) \top (\perp j) - 2^s \times 300 \div timer frequency 2

MAC^8(80, 4, s, g; k) 3

timer alarm \leftarrow timer alarm \lor (\perp k) > \perp j 4

tick \leftarrow 0 5
```

#### T, timer system program

```
DELAY ((1 \div timer frequency) seconds) 0
tick \leftarrow 1 1
```

#### RESET, reset defined operation

```
f, g, h, q, r, w \leftarrow \bar{\epsilon} \qquad 0
operating state, ipl \leftarrow \text{stop}, 0
\rightarrow CPU; 35 \qquad 2
\rightarrow (CH^{0}, CH^{1}, CH^{2}, CH^{3}, CH^{4}, CH^{5} CH^{6}); 2 \qquad 3
\rightarrow IPL; 0 \qquad 4
load light \leftarrow off
MODEL-DEPENDENT RESET \qquad 6
```



```
r_i, q_i \leftarrow 1, \sim \vee/q
\neq i: (q_{rank}/rank)_0
       r_i, s, w \leftarrow \bar{\epsilon}(4), /w; i = 8; j_2 = f/
 \geq j_0 : 2^{12}
                                                                                                                                       3
       j_0 \leftarrow \perp / main \ pfx; \ pfx \ tgr; \ alternate \ pfx/, \ (12) \top j_0
      1: (operating state = stop) \vee (address compare sw = normal) \vee
                    (address\ compare\ sw\ =\ instruction)\ \land\ (j_3 \neq i)
       operating state \leftarrow /operate; \wedge /\bar{\omega}^{m_5} / address sw = (24) <math>+ j_0; stop/
       \mathbf{s}_0 \leftarrow 0 \neq j_1 | j_0
      0: \mathbf{s}_1 \leftarrow j_0 \geq \mu \mathbf{M}
      j_0 \leftarrow (\mu \mathbf{M}) \mid \perp ?(24)
                                                                                                                                      9
      u \leftarrow (\perp K^{\perp \alpha^{13}/(24) \, \text{Ti}_0}), \, \perp/p_{8,9,10,11}; i \leq 7; \, (\alpha^4/\textit{CAW}^i)/
                                                                                                                                    10
      \mathbf{s_2} \leftarrow \mathbf{m_0} \, \wedge \, (\mathbf{j_{2,3}} \, \, \underline{\wedge} \, \mathbf{s}, \, \mathbf{d}) \, \wedge \, (\mathbf{u_0} \neq \mathbf{u_1}) \, \wedge \, (\mathbf{u_0} \neq \mathbf{0}) \, \wedge \, (\mathbf{u_1} \neq \mathbf{0})
                                                                                                                                    11
                                                                                                                                    12
      1: (j_3 = g) \vee \sim \vee /s
      s \leftarrow \epsilon^{?^1/s/\iota^0}(3)
                                                                                                                                    13
                                                                                                                                    14 |≤
      i:7
                                                                                                                                    15
      t_{4,5,6} \leftarrow t_{4,5,6} \vee s_{2,1,0}
      S_{2,3}^i \leftarrow S_{2,3}^i \vee s_{1,2}
                                                                                                                                    16
                                                                                                                                    17
      1: s_0 \lor (j_2 = s)
                                                                                                                                    18
      j_2:s
      ^{i}J \leftarrow (j_{0} \downarrow \alpha^{j_{1}})//M
                                                                                                                                    19
      k \leftarrow E/\omega^8/^iJ
                                                                                                                                    20
      i:7
                                                                                                                                    21
                                                                                                                                    22
      f_i \leftarrow \vee/\sim \neq/^i J
     (j_0 \downarrow \alpha^{i_1})//M \leftarrow (=/E(j_1, 8)\backslash k) \oplus E(j_1, 8)\backslash k
                                                                                                                                    23
      q \leftarrow /r \wedge \bar{w} \vee \bar{\epsilon}^9; j_3 = h; q/
```



TOL°, time-out limiter system program



 $HFC^{\circ}$ , hardware failure in channel c system program



260 a

| Segmeni                        | Channel<br>type |   |   | ate<br>S | S;     | Extent         | Enter                                                  | Evil                                                                  |
|--------------------------------|-----------------|---|---|----------|--------|----------------|--------------------------------------------------------|-----------------------------------------------------------------------|
| data transfer                  | mpx<br>sel      | ? | 1 | ?        | i<br>1 | 7-31, 59-65    | 59                                                     | 61, 63, 64, 65                                                        |
| data chaining                  | both            | ? | 1 | ò        | I      | 22-31          | 22                                                     | 29                                                                    |
| termination                    | both            | 1 | 0 | 1        | 0      | 66-81, 56-58   | 56, 66, 67, 68, 78                                     | 58, 69, 70, 77, 80                                                    |
| command chaining               | both            | ? | 1 | 0        | 1      | 68-70          | 68                                                     | 69, (70)                                                              |
| channel idle                   | mpx<br>sel      | ? | 0 | ?<br>0   | ?      | 35-55          | 35                                                     | 38, 43, 50, 54, 55                                                    |
| CPU service                    | both            | ? | ? | ?        | ?      | 82-165, 32-34  | 82, 104                                                | 128, 129, 130, 32, 33, 3-                                             |
| state analysis                 | mpx<br>sel      | ? | 0 | ?        | ?      | 82-101         | 82                                                     | 85, 87, 88, 90, 91, 92, 93<br>101                                     |
| sio                            | mpx<br>sei      | ? | 0 | 0        | 0      | 102-114        | 102, 104                                               | 112, 114                                                              |
| command chaining               | both            | ? | 1 | 0        | 1      | 104-114        | (104)                                                  | 112, 114                                                              |
| channel-initiated<br>selection | mpx<br>sel      | ? | ? | ?        | ?      | 115-130        | 115                                                    | 118, 119, 120, 122, 127,<br>128, 129, 130                             |
| CSW and condition code setting | mpx             | ? | 0 | ?        | ?      | 136-165        | 136, 138, 139, 140,<br>143, 145, 147,<br>151, 153, 161 | 137, 138, 139, 142, 144,<br>146, 149, 150, 152,<br>160, 162, 164, 165 |
| end of CPU service             | mpx<br>sel      | ? | 0 | ?        | ?      | 131–135, 32–34 | 131, 134                                               | 32, 33, 34                                                            |
| ystem reset and IPL            | both            | 0 | 0 | 0        | 0      | 0-6            | 0, 2                                                   | 5, 6                                                                  |

# $\mathit{CH}^c$ , channel c system program



