## Instruction sets and instruction times for the Elliott 502 computer.

Note: all references are listed in section E4/X5.

## Elliott 502 instruction set.

The instruction set for the Elliott 502 offers a rich variety of addressing modes for a relatively straightforward repertoire of ALU operations. Each 20-bit instruction occupies one word, as follows:

| 1 | 1 | 6 | 2 | 10 |
| :---: | :---: | :---: | :---: | :---: |
| $\mathbf{L}$ | $\mathbf{M}$ | $\mathbf{F}$ | $\mathbf{K}$ | $\mathbf{N}$ |
| Interrupt <br> lock | Store <br> mode | Op code | Modifier <br> source | Literal or <br> address |

If $L=1$ then interrupts are inhibited, or locked, until the succeeding instruction has been obeyed. (Note that, somewhat confusingly, the symbol S was used for this bit in the original Elliott documentation).

M is the Store Mode bit, whose interpretation also depends upon the actual instruction being obeyed (as explained below). If $M=0, N$ represents either an address in fast RAM or $N$ represents a literal (constant). If $M=1, N$ represents either an address in main RAM or an address in fast RAM that holds the address of an operand in main RAM (ie indirect addressing into main RAM).

F is the 6-bit Function (or Op.code), specifying two octal digits as used in the tables below.
K specifies the source of the address-modifier, thus:
if $\mathrm{K}=0$, no modification takes place;
if $K=1$, use the contents of the $B$ register;
if $K=2$, use the contents of the accumulator, $A$;
if $K=3$, use the contents of the Sequence Control Register (or Program Counter), S , which always points to the next instruction to be obeyed.

The N bits in the Elliott 502 are generally interpreted in one of four possible ways, depending upon the M bit and the instruction being obeyed, as follows:
for Group $0 \& 1$ orders: $\quad$ when $\mathrm{M}=0$ then N is a positive fraction (ie literal);
when $M=1$ then $N$ is a main store address;
for Group $2 \& 3$ orders: when $\mathrm{M}=0$ then N is a fast store address;
when $M=1$ then the contents of the fast store address is
used indirectly to address a location in main store;
for Group 7 instructions, N is used to specify a peripheral device.

In the Elliott 502 instruction tables given below, the following abbreviations are used:
$a, a^{\prime} \quad$ the old and new contents of the accumulator register, $A$;
$\mathrm{b}, \mathrm{b} \quad$ the old and new contents of the modifier register, B ;
s, s' the old and new contents of the Sequence Control Register, S;
$r, r^{\prime} \quad$ the old and new contents of the auxiliary register, R;
ar, a'r' the old and new contents of the double-length accumulator $\{A, R\}$
$N \quad$ the N -bits when used as a constant (ie literal);
( N ), ( N$)^{\prime} \quad$ the old and new contents of main store address N ;
( n ), ( n$)^{\prime} \quad$ the old and new contents of fast store address N ;
$((n)),((n)) \quad$ the old and new contents of main store address (n), ie when the main store is being accessed indirectly via a fast store location.
OV the Overflow indicator (a single-bit register).
T data (eg a 5-bit character) read in from an input device.
Instructions in Groups 0 to 3 include simple short arithmetical operations on the accumulator and on the $B$ register. The action of instructions in Groups 0 to 3 is dependent upon the setting of the store-mode bit, M , as follows.

| Function | when $\mathrm{M}=0$ | when $M=1$ | explanation |
| :---: | :---: | :---: | :---: |
| 00 | $\mathrm{b}^{\prime}=\mathrm{b}+N$ | $\mathrm{b}^{\prime}=\mathrm{b}+(\mathrm{N})$ | ADD B |
| 01 | $\mathrm{b}^{\prime}=\mathrm{b}^{\prime}-N$ | $\mathrm{b}^{\prime}=\mathrm{b}-(\mathrm{N})$ | SUBTRACT B |
| 02 | $\mathrm{b}^{\prime}=N-\mathrm{b}$ | $\mathrm{b}^{\prime}=(\mathrm{N})-\mathrm{b}$ | REVERSE SUBTRACT B |
| 03 | $\mathrm{b}^{\prime}=N$ | $\mathrm{b}^{\prime}=(\mathrm{N})$ | LOAD B |
| 04 | - | $(\mathrm{N})^{\prime}=\mathrm{b}+(\mathrm{N})$ | ADD B to store |
| 05 | - | $(\mathrm{N})^{\prime}=\mathrm{b}-(\mathrm{N})$ | SUBTRACT B from store |
| 06 | - | $(\mathrm{N})^{\prime}=(\mathrm{N})-\mathrm{b}$ | REVERSE SUBTRACT B from store |
| 07 | - | $(\mathrm{N})^{\prime}=\mathrm{b}$ | STORE B |
| 10 | $\mathrm{a}^{\prime}=\mathrm{a}+N$ | $\mathrm{a}^{\prime}=\mathrm{a}+(\mathrm{N})$ | ADD A |
| 11 | $\mathrm{a}^{\prime}=\mathrm{a}-N$ | $\mathrm{a}^{\prime}=\mathrm{a}-(\mathrm{N})$ | SUBTRACT A |
| 12 | $\mathrm{a}^{\prime}=N-\mathrm{a}$ | $\mathrm{a}^{\prime}=(\mathrm{N})-\mathrm{a}$ | REVERSE SUBTRACT A |
| 13 | $\mathrm{a}^{\prime}=N$ | $\mathrm{a}^{\prime}=(\mathrm{N})$ | LOAD A |
| 14 | - | $(\mathrm{N})^{\prime}=\mathrm{a}+(\mathrm{N})$ | ADD A to store |
| 15 | - | $(\mathrm{N})^{\prime}=\mathrm{a}-(\mathrm{N})$ | SUB A from store |
| 16 | - | $(\mathrm{N})^{\prime}=(\mathrm{N})-\mathrm{a}$ | REV SUBTRACT A from store |
| 17 | - | $(\mathrm{N})^{\prime}=\mathrm{a}$ | STORE A |
| 20 | $\mathrm{b}^{\prime}=\mathrm{b}+(\mathrm{n})$ | $\mathrm{b}^{\prime}=\mathrm{b}+((\mathrm{n})$ ) | ADD B |
| 21 | $\mathrm{b}^{\prime}=\mathrm{b}-(\mathrm{n})$ | $\mathrm{b}^{\prime}=\mathrm{b}-((\mathrm{n})$ ) | SUBTRACT B |
| 22 | $\mathrm{b}^{\prime}=(\mathrm{n})-\mathrm{b}$ | $\mathrm{b}^{\prime}=((\mathrm{n})$ ) - b | REVERSE SUBTRACT B |
| 23 | $\mathrm{b}^{\prime}=(\mathrm{n})$ | $\mathrm{b}^{\prime}=((\mathrm{n})$ ) | LOAD B |
| 24 | $(\mathrm{n})^{\prime}=\mathrm{b}+(\mathrm{n})$ | $((\mathrm{n}))^{\prime}=\mathrm{b}+((\mathrm{n})$ ) | ADD B to store |
| 25 | $(\mathrm{n})^{\prime}=\mathrm{b}-(\mathrm{n})$ | $((\mathrm{n}))^{\prime}=\mathrm{b}-((\mathrm{n})$ ) | SUBTRACT B from store |
| 26 | $(\mathrm{n})^{\prime}=(\mathrm{n})-\mathrm{b}$ | $((\mathrm{n}))^{\prime}=((\mathrm{n}) \mathrm{l}-\mathrm{b}$ | REVERSE SUBTRACT B from store |
| 27 | $(\mathrm{n})^{\prime}=\mathrm{b}$ | $((\mathrm{n}))^{\prime}=\mathrm{b}$ | STORE B |
| 30 | $\mathrm{a}^{\prime}=\mathrm{a}+(\mathrm{n})$ | $\mathrm{a}^{\prime}=\mathrm{a}+((\mathrm{n})$ ) | ADD A |
| 31 | $\mathrm{a}^{\prime}=\mathrm{a}-(\mathrm{n})$ | $\mathrm{a}^{\prime}=\mathrm{a}-((\mathrm{n})$ ) | SUBTRACT A |

32
33
34
35
36
37
$\mathrm{a}^{\prime}=(\mathrm{n})-\mathrm{a}$
$\mathrm{a}^{\prime}=((\mathrm{n}))-\mathrm{a}$
$a^{\prime}=(n) \quad a^{\prime}=((n))$
REVERSE SUBTRACT A
LOAD A
$(n)^{\prime}=a+(n)$
$((n))^{\prime}=a+((n))$
$((n)))^{\prime}=a-((n))$
$((\mathrm{n}))^{\prime}=((\mathrm{n}))-\mathrm{a}$
$((\mathrm{n}))^{\prime}=\mathrm{a}$

ADD A to store
SUBTRACT A from store
REVERSE SUBTRACT A from store STORE A

Note: for Group 3 instructions, the overflow marker OV is set if the result of any operation is outside the range -1 to $+\left(1-2^{-19}\right)$.

Group 4 instructions: transfer of control.

40 if $b \neq 0$ then $b^{\prime}=b+1$ and $s^{\prime}=N$
42
43
44
45
46
47
$41 \quad$ if $b \neq 0$ then $b^{\prime}=b-1$ and $s^{\prime}=N$
if $b=0$ then $s^{\prime}=N$
$b^{\prime}=s$ and $s^{\prime}=N$
if $a \geq 0$ then $s^{\prime}=N$
if $\mathrm{a}<0$ then $\mathrm{s}^{\prime}=\mathrm{N}$
if $\mathrm{a}=0$ then $\mathrm{s}^{\prime}=\mathrm{N}$
if $\mathrm{OV}=1$ then $\mathrm{s}^{\prime}=\mathrm{N}$ and $\mathrm{OV}=0$

Jump if $b$ not equal to zero and INC $B$ Jump if $b$ not equal to zero and DEC B
Jump if $b=0$
Subroutine entry
Jump if acc $\geq 0$
Jump if acc < 0
Jump if acc = 0
Jump if overflow

Note: for Group 4 instructions and for instructions 50 and 51, the jump-to address is in fast RAM when $M=0$ and in main RAM when $M=1$. Following the 43 instruction, the mostsignificant digit of $B$ is zero if the instruction is in fast RAM and one if it is in main RAM.

Group 5 and 6 instructions: miscellaneous and double-length arithmetic.

## Function

when $M=0$
$\mathrm{s}^{\prime}=(\mathrm{n})$

## when $M$ = 1

50
51
52
53
54
55
56
57
60
61
62
63
64
65
66 67
$\mathrm{S}^{\prime}=(\mathrm{N})$
$\left.\mathrm{s}^{\prime}=\mathrm{s}-\mathrm{n}\right) \quad \mathrm{s}^{\prime}=(\mathrm{N})$
$\mathrm{a}^{\prime}=\mathrm{a}$ \& ( n$) \quad \mathrm{s}^{\prime}=\mathrm{a}$ \& (N)
$r^{\prime}=(n)$
$\mathrm{r}^{\prime}=(\mathrm{N})$
$(\mathrm{n})^{\prime}=(\mathrm{n})+1 \quad(\mathrm{~N})^{\prime}=(\mathrm{N})+1$
$(n)^{\prime}=(n)-1$
$(\mathrm{N})^{\prime}=(\mathrm{N})-1$
$(\mathrm{n})^{\prime}=\mathrm{a} \&(\mathrm{n})$
$(\mathrm{N})^{\prime}=\mathrm{a} \&(\mathrm{~N})$
$(\mathrm{n})^{\prime}=\mathrm{r}$
$(N)^{\prime}=r$
... shift A logically $N$ places left ...
... shift A arith. N places left ...
... shift $\{\mathrm{A}, \mathrm{R}\}$ arith. $N$ places left ...
$\mathrm{a}^{\prime}=\operatorname{SQRT}(\mathrm{a}+(\mathrm{n})) \quad \mathrm{a}=\operatorname{SQRT}(\mathrm{a}+(\mathrm{N}))$
$a^{\prime} r^{\prime}=a \times(n) \quad a^{\prime} r^{\prime}=a \times(N)$
$a^{\prime}=a x(n) \quad a^{\prime}=(N)$
$\{a, r\} /(n)$ or $\{a, r\} /(N) ; r^{\prime}=$ quotient; $a^{\prime}=r e m$.
$a^{\prime}=\{a, r\} /(n) \quad a^{\prime}=\{a, r\} /(N)$

## explanation

absolute unconditional jump
relative branch
logical AND
load R
memory INC
memory DEC
memory logical AND
store R
logical shift left
arithmetical shift left
double-length arithmetical shift
Square root
Multiply, double-length
Multiply single-length; R cleared
Divide double-length
Divide single-length; R cleared

Note: at the conclusion of instruction 64, AR holds the product as a 38-bit signed fraction, the most-significant bit of $R$ being cleared. At the start of instructions 66 and 67, AR together hold a 38-bit signed fraction.

Group 7 instructions: input/output.
$a^{\prime}=a+T$
Unallocated; causes a dynamic stop.
Unallocated; causes a dynamic stop.
$\mathrm{a}^{\prime}=\mathrm{T} \quad$ read data from input device $N$
Used to control autonomous transfer devices; no details have yet come to light.
Unallocated; causes a dynamic stop.
Causes a Program Break; re-enter at n or N .
a is output to device $N$ write acc to output device $N$

Note: for instructions 70, 73, 74 and $77, \mathrm{~N}$ specifies the identity of the peripheral device. Amongst the values of $N$ used for standard devices for the 502, the following are known to have applied. Clearly, other peripherals specific to the classified radar application at RRE would have had their own identities.

$$
\begin{aligned}
& N=0 \text { the } 502 \text { 's Operator's Console; } \\
& N=1 \text { the } 5 \text {-track paper tape reader; } \\
& N=2 \text { the Program Control Register, PCR. }
\end{aligned}
$$

Further details of the PCR are given above in section 2. In summary, to quote the Elliott 502's manual (reference 3): "... PCR contains an indication of where a given program has been prevented from running; instructions $70 / 2$ or $73 / 2$ can be used to determine this, while instruction 77/2 can activate or inhibit a programme". Note that a Program Break normally occurs as a result of an external demand (interrupt); the 76 instruction is an alternative software method of achieving the same action.

The effect of a 76 instruction is that:

- the S register is set to n or N ;
- the stimulus for the current operating priority level is cleared.

This then causes a Program Break. The new priority level will normally be lower than the current one. The address of the 76 instruction will have been stored as the re-entry address to be used when the former priority level is re-stimulated. The 502 console includes switches that can enable or mask each program stimulus (in addition to the control provided by the PCR) and a push-button for emulating each stimulus.

The Elliott 502 was required to handle significant amounts of input/out for the special real-time, on-line applications for which it was designed. The width of the highways for each form of input/output is given below.

## Programme Stimuli (ie Interrupts):

| Demands | 7 bits | into the 502 |
| :--- | :--- | :--- |
| Replies | 7 bits | out of the 502 |


| Direct Input/Output transfers and device control transfers: |  |  |
| :--- | :--- | :--- |
| Data | 20 bits | bi-directional |
| Address | 4 bits | out of the 502 |
| Function $(70 / 73,74$ or 77$)$ | 3 bits | out of the 502 |
| Reply \& Busy | 2 bits | into the 502 |

## Autonomous Data Transfers:

| Data | 40 bits | bi-directional |
| :--- | :--- | :--- |
| Control | 12 bits | out of the 502 |
| Control | 12 bits | into the 502 |
| Priority Control | 36 bits | into the 502 |
| Priority Control | 12 bits | out of the 502. |

The Elliott 502's autonomous transfer facility, which is similar to techniques referred to in later years as Direct Memory Access or Cycle-stealing, allows Input/Output to take place in parallel with normal program operation. The mechanism is that when a Priority Control signal from a peripheral indicates that transfer of a word is required the computer will, between instructions, automatically access a pointer and a counter held in memory for the peripheral concerned, transfer a word to or from the location indicated by the pointer and then adjust the pointer and counter. Thus, transfer of a block of words is effected without program action. The Elliott 502's 74 instruction is used to indicate to the peripheral the type of action required and to set it in progress. For the Elliott 502, it is up to a program to ascertain the progress of a transfer before using or changing the data concerned. However, on the Elliott 503, for compatibility with 803 programs, an additional memory bit in each word is used to inhibit access to it while the word is involved in an autonomous transfer.

## Elliott 502 instruction times.

The approximate times in microseconds for various instructions (see reference 3) are as follows:

## Instruction(s) operand Instr. in fast RAM Instr. in main RAM

Groups 0 \& 1 literal operand
Groups 0 \& 1
Groups 2 \& 3
Groups 2 \& 3
Group 4; 50 \& 51
52 to 57
52 to 57
60 \& 61
62
63
64 to 67
70, 73, 77
76
74 main RAM operand
fast RAM operand main RAM, indirect
fast RAM operand
main RAM operand

33 to 45
18 to 24
4 to 6
12 to 15
5 to 8

$$
(2.8+0.5 N)
$$

3.8
2.3
8.2
3.3
4.3
4.8
1.5 to 3.0
8.2
2.5 to 4.1

## 4.3

8.2

$$
(3.2+0.9 N)
$$

$(4.0+0.5 \mathrm{~N})$
$(4.4+0.9 N)$

