## COMPUTER SYSTEMS

THE NORD-5 INSTRUCTION SET
September 1971

THE NORD-5 INSTRUCTION SET

September 1971

## TABLE OF CONTENTS

$+{ }_{+}^{+}$
Page
INTRODUCTION ..... iii
1 GENERAL DEFINITIONS ..... 1-1
1.1 Word ..... 1-1
1.2 Instruction ..... 1-1
1.3 Integer ..... 1-1
1.4 Bits and Bit fields ..... 1-1
1.5 Floating Word ..... 1-2
1.6 Floating Point Number ..... 1-2
1.7 Integer Arithmetic ..... 1-3
1.8 Floating Point Arithmetic ..... 1-3
1.9 Register Structure of NORD-5 ..... 1-3
1.10 Syntax of Instruction Descriptions ..... 1-6
1.11 Execution Times ..... 1-8
2 MEMORY REFERENCE INSTRUCTIONS ..... 2-1
2.1 Introduction ..... 2-1
2.2 Instruction Word ..... 2-1
2.3 Memory Addressing ..... 2-2
2.4 Instruction List ..... 2-3
3 INTER REGISTER INSTRUCTIONS ..... 3-1
3.1 Introduction ..... 3-1
3.2 Instruction Layout ..... 3-1
3.3 Inter register Instruction Descriptions ..... 3-2
4 ARGUMENT INSTRUCTIONS ..... 4-1
4.1 Introduction ..... 4-1
4. 2 Argument Instruction Layout ..... 4-1
4.3 Instruction Description ..... 4-1
5 SUMMARY OF INSTRUCTIONS ..... 5-1

## INTRODUCTION

The NORD-5 is designed to be an auxiliary computer in a general computer system called the NORDIC system or the NORD Integrated Computer System

In NORDIC, NORD-5 works as a slave computer being monitored by two or more NORD-1 computers.

One of the main design criteria for NORD-5 was high performance on number crunching, but in addition NORD-5 is an effective general purpose computer. The intention of this manual is to describe the NORD-5 instruction set only, not the connection of NORD-5 to the general system.

The wordlength of NORD-5 is 32 bits for instructions and integers. A floating point number is represented in a 64 bit floating word (two consecutive 32 bit words). Cfr. Section 1.5, Floating Word.

The central processing unit (CPU) contains 64 general registers, each 32 bits long. 16 of the registers may be used as base or index registers, and to each of them is associated one modification register which may contain increments used in certain jump instructions.

64 bit registers for holding floating point numbers are formed by connecting the general registers two by two to obtain floating registers. Cfr. Section 1. 9.4, Floating Register.

The instructions are classified in three groups: The memory reference instructions, the inter register instructions, and the argument instructions. The memory reference instructions normally affect one register and one memory word. The memory addressing may be direct or indirect. Up to 16 levels of indirect addressing may be used.

The inter register operations normally use two operand registers called source register A and source register B. The result is stored in a third register, the destination register. These three registers may be any of the general registers. The inter register floating point instructions affect pairs of registers.

The argument instructions are generally two-operand instructions with one of the operands contained in the instruction itself.

The memory cycle time is approximately $1 \mu \mathrm{~s}$. An inter register multiply of floating point numbers takes about $1 \mu \mathrm{~s}$; a floating divide takes about $8 \mu \mathrm{~s}$.
1.1 Word

The word is the basic storage unit, both in memory and in the central processing unit, CPU. The wordlength of NORD-5 is 32 bits.

Each word in NORD-5 has a unique name which is the name of a register or an address to a word in menory. The content of a word is denoted: (name of word).

### 1.2 Instruction

Contents of a word interpreted as an instruction to the central processor, CPU.

The instructions in NORD-5 are always one word long. The instructions are divided into three groups as follows:
a) memory reference instructions, Section 2
b) inter-register instructions, Section 3
c) argument instructions, Section 4.

### 1.3 Integer

Contents of a word interpreted as a binary number.
Negative integers are represented in two's complement. Arithmetic is performed in two's complement.

One's complement is obtained by setting each bit in the word to its opposite value. Two's complement is obtained by adding one to the one's complement of the word.
1.4 Bits and Bit fields

Each bit in a word or floating word has an unique index as follows.
The least significant bit is bit 0 . The most significant bit is bit 31 . In floating words bit 63 is bit 31 in the first of the two words making the floating words. Bit 0 in the floating word is bit 0 in the second of the two words.

The content of bit i in a word is denoted: (name of wordi ${ }_{i}$ ). A number of contiguous bits in a word is called a bit field. The bit field ranging from bit $i$ to bit $j$ is denoted: name of word ${ }_{i-j}$. The content of a bit field is denoted: (name of word ${ }_{i-j}$ ).

### 1.5 Floating Word

A floating word consists of two contiguous 32 bit words in memory, logically connected to give one 64 bit word. The first word of the floating word is called the left portion word, the second word is called the right portion word. Thus, bit field $0-31$ is in the right portion word and bit field 32-63 is in the left portion word of the floating word. The address of a floating word is the address of its left portion word. Cfr. Section 1.9.4, Floating Register.

Relation between words and floating words in memory:

| bit $_{31}$ | word $_{i}$ | bit $_{0}$ | bit $_{31}$ | word $_{i+1}$ | bit $_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- |
| bit $_{63}$ |  | floating word |  |  |  |

In the description of the instructions, floating point word ${ }_{i}$ will be denoted: word $_{i}$, word $_{i+1}$.
1.6 Floating Point Number

A floating point number is given by its mantissa, $m$, and exponent, $n$, as follows:

$$
\text { number }=m \cdot 2^{\mathrm{n}}
$$

A floating point number is stored in a floating word, cfr. Section 1.5, Floating Word.

The representation of $m$ and $n$ in the floating word is as follows:

```
bit 0-51 mantissa,m
bit 52-62 exponent ,n
bit 63 sign of mantissa, m}\mathrm{ is negative if bit 63=1
```

The range of the exponent is from -2000 to +17778 making the range of the floating point number approximately from $-10^{308}$ to $10^{308}$. The exponent is represented in a 11 bit field but is biased by $2000_{8}$; i.e., $2000_{8}$ is added to the exponent to make it a positive number.

The length of the mantissa is 52 bits, which corresponds to about 15.5 decimal digits.

The floating point numbers have to be normalized before CPU can operate properly on them. A floating point number is said to be on normalized form when $m$ and $n$ have values so that $1>m \geqslant 0.1_{2}$.

### 1.7 Integer Arithmetic

Integer operands are always one word. Negative numbers are represented in two's complement.

In inter register arithmetic the add and subtract functions may affect or be affected by a carry bit, $C B$, if the proper subcode is specified.

A multiply instruction will affect an overflow register, OR, which will contain the 32 most significant bits of the product. A divide instruction will affect a remainder register, $R R$, which will contain a 32 bits remainder after the division.

Arithmetical overflow or a positive product where OR is non-zero (OR is all ones for negative products) may, if specified, cause a monitor call.
1.8 Floating Point Arithmetic

The results of the floating add and subtract functions are rounded. As rounding indicator is used the most significant of the bits which are shifted out to keep a 52 bit mantissa.

In floating multiply, bit 0 in the final result is normally set to one Bit 0 is not set to one if the eight most significant shifted-out bits are all zero.

In floating divide, bit 0 in the final result is normally set to one. Bit 0 is not set to one if the remainder is zero.
1.9 Register Structure of NORD-5

Registers are storage cells in the central processing unit, CPU. The register used by the programmers in NORD-5 is one word long ( 32 bits) or one floating word long ( 64 bits).

### 1.9.1 P-Register

The program counter, $P$, contains the address of the instruction being read from meory for execution by the CPU. P is one word long. All instructions affect $P$. The instructions increment $P$ by one, except the stop, jump and skip instructions.

### 1.9.2 Instruction Register

The instruction register, IR, contains the instruction being executed by the CPU. IR is one word long.

### 1.9.3 General Registers

The NORD-5 CPU has 64 general single word registers. These 64 word registers may also be used as 32 general floating registers.

The general registers are normally usei by the programs as storage cells for operands and results.

Some of the registers may be used as base registers, index registers and modification registers. Cfr. Section 1.9.4-Floating Register, Section 1.9.5-Base Register, Section 1.9.6-Index Register, and Section 1.9.7-Modification Register.

The 64 general registers are denoted $\mathrm{GR}_{0}, \mathrm{GR}_{1}, \ldots, \mathrm{GR}_{63}$ in the descriptions.

Note: $\mathrm{GR}_{0}$ always contains zero. This implies that $\left(\mathrm{FR}_{\mathrm{O}}\right)=0$, $\left(\mathrm{BR}_{0}\right)=0$, $\left(\mathrm{XR}_{0}\right)=0$ and that $\mathrm{MR}_{0}$ cannot be used as modification register to $\mathrm{GR}_{0}$.

### 1.9.4 Floating Register

A floating register has the storage capacity of one floating word. It is used to store floating point number operands and results.

There are 32 floating registers $\mathrm{FR}_{0}-\mathrm{FR}_{31}$. The floating registers are organized from the general registers as f8llows:
$F R_{i \text { left }}=G R_{i}, F R_{i \text { right }}=G R_{i+16} \quad$ when $0 \leq i<16,32 \leq i<48$

We shortly write this as:
$\mathrm{FR}_{\mathbf{i}}=\mathrm{GR}_{\mathbf{i}}, \mathrm{GR}_{\mathbf{i}+16}$
when $0 \leqslant \mathrm{i}<16,32 \leqslant \mathrm{i}<48$

### 1.9.5 Base Registers

The 16 first general registers may be used as base register, BR.
$\mathrm{BR}_{\mathbf{i}}=\mathrm{GR}_{\mathbf{i}} \quad 0 \leqslant \mathrm{i}<16$
Cfr. Section 2.3-Memory Addressing - for further description.
1.9.6 Index Registers

The 16 first general registers may be used as index registers, XR.
$\mathrm{XR}_{\mathrm{i}}=\mathrm{GR}_{\mathrm{i}} \quad 0 \leqslant \mathrm{i}<16$
Cfr. Section 2.3-Memory Addressing - for further description.
If the register has been used as a destination register of a floating point arithmetic operation or double shift, the result cannot be used as a base or index address modification.

### 1.9.7 Modification Registers

Associated with each of the first 16 general registers there is one modification register, MR. The modification registers are organized from the general registers as follows:
$\mathrm{MR}_{\mathrm{i}}=\mathrm{GR}_{\mathrm{i}+16}$
$0 \leqslant \mathrm{i}<16$

The modification registers are used to hold an increment to base or index registers in certain jump instructions. Cfr. Section 2 - Memory Reference Instruction.

### 1.9.8 Auxiliary Register

The overflow register, OR, is used to hold the upper 32 bit part of the product of a multiplication.

The remainder register, $R R$, is used to hold the remainder after a division. OR and RR can be read by an RIO-instruction.
1.10 Syntax of Instruction Descriptions
1.10.1 $:=$ Assignment Operator

Set data element to the left of := equal to the data element at the right side of :=.
1.10.2 $\pm,-*, /$ Arithmetical Operators

The mode of arithmetic operation is showed by using integer word indicators for integer arithmetic and floating word indicators for floating point arithmetic.

### 1.10.3 $\geq \geqslant \neq \neq \leqslant \leqslant$ Relation Operators

The relation operators are used to show arithmetical relations. A relation has the value true or false.

### 1.10.4 Logical Operators

The logical operations are done by using two operands, each one word long, giving a one word result. However, the logical operations are by its nature single bit operations. They are done on pairs of operand bits, which are made by taking the bits with same bit address from the two operand words. The result is stored in the same bit position in the result word.

Following is a description of the logical operations as single bit operations.
Logical OR , V

| A | 0 | 0 | 1 | 1 |
| :---: | :---: | :---: | :---: | :---: |
| B | 0 | 1 | 0 | 1 |
| $\mathrm{~A} \overline{\mathrm{~B}}$ | 0 | 1 | 1 | 1 |

Logical exclusive OR , $\forall$

| A | 0 | 0 | 1 | 1 |
| :---: | :---: | :---: | :---: | :---: |
| B | 0 | 1 | 0 | 1 |
| $\mathrm{~A} \forall \mathrm{~B}$ | 0 | 1 | 1 | 0 |

Logical AND , $\wedge$

| $A$ | 0 | 0 | 1 | 1 |
| :---: | :---: | :---: | :---: | :---: |
| $B$ | 0 | 1 | 0 | 1 |
| $\mathrm{~A} \wedge \mathrm{~B}$ | 0 | 0 | 0 | 1 |

Logical Complement , - (one's complement)

| $A$ | 0 | 0 | 1 | 1 |
| :---: | :---: | :---: | :---: | :---: |
| $\bar{A}$ | 1 | 1 | 0 | 0 |

The logical complement is a one operand operation. Each bit is set to its opposite value. The one's complement of a word is not its corresponding negative value. Negative integer numbers are represented in two ' complement.

### 1.10.6 Non-conditional Instructions

A non-conditional instruction is described by one or more assignment statements. If there are more than one assignment statement, they will be connected by the word AND. The assignment statement is executed in the sequence they are shown.

Note: In all instructions P is incremented by one unless otherwise specified.

### 1.10.7 Conditional Instructions

The conditional instructions are described as follows:
IF relation is true
THEN non-conditional instructions Instruction finished

ELSE non-conditional instructions Instruction finished

If there are statements before the conditional phase, the word AND is used to connect the "IF. . . ." to the rest of the description.
1.11 Execution Times

Timing for each instruction is found in the instruction descriptions.

### 1.11.1 Time Definitions

1.11.1.1 Memory Cycle Time, TMC

Time necessary to read or write one word in memory, $T M C=1.0 \mu \mathrm{~s}$.
1.11.1.2 Read Instruction Time, TRI

Time necessary to read one instruction from memory to control processor, $\mathrm{TRI}=\mathrm{TMC}$
1.11.1.3 Read Single Word Operand Time, TSW

Time necessary to load or store one single word operand in memory, $\mathrm{TSW}=\mathrm{TMC}$
1.11.1.4 Read Floating Word Operand Time, TFW

Time necessary to load or store one floating word operand in memory, $T F W \leq 2 * T M C$.
1.11.1.5 Central Processor Time, TCP

Time used by central processor to perform a specified operation when all operands are available in processor registers (Time used to store the result not included). TCP depends on the specified instruction.
1.11.1.6 Execution Time (T).

Total time used to execute one instruction; i.e., time used from the read instruction cycle starts until the result is in the specified register or memory word.

Introduction
The memory reference instructions have in common that the execution of an instruction involves calculation of a memory address. In some of the memory reference instructions the memory address is used as operand, i.e., jumps and remote execution.
2.2 Instruction Word

Instruction Word, IW

| I | X | B | FC | $\mathrm{R} / \mathrm{F}$ | D |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 31 | 27 |  | 23 |  | 18 |  | 0 |

Indirect Address Word of level $j, I A W_{j}$

| $\mathrm{I}_{\mathrm{j}}$ | $\mathrm{X}_{\mathrm{j}}$ | $\mathrm{B}_{\mathrm{j}}$ | 0 | $\mathrm{D}_{j}$ |
| :--- | :--- | :--- | :--- | :--- |
| 31 | 27 |  | 20 | 0 |

IW : Instruction Word
I : Indirect addressing flag
$\mathrm{X} \quad$ : Index register designator
B : Base register designator
FC : Function Code
$\mathrm{R} / \mathrm{F}$ : General register or floating register designator
D : Displacement $0 \leqslant \mathrm{D}<4096$
$I_{A W} \quad:$ Indirect Address Word at level $j$
$\mathrm{I}_{\mathrm{j}} \quad:$ Indirect addressing flag in IAW $\mathrm{I}_{\mathrm{j}} \mathrm{I}_{0}=\mathrm{I}$
$\mathrm{X}_{\mathrm{j}} \quad:$ Index register designator in $\mathrm{IAW}_{\mathrm{j}}$
$\mathrm{B}_{\mathbf{j}} \quad:$ Base register designator in $\mathrm{IAW}_{\mathrm{j}}$
$\mathrm{D}_{\mathrm{j}} \quad: \quad$ Displacement in IAW $_{\mathrm{j}}, \quad 0 \leqslant \mathrm{D}_{\mathrm{j}}<1048576$
2.3 Memory Addressing

All memory reference instructions calculate a memory address. The result of this calculation is called the effective address, Ea.

The memory addressing may be direct or indirect. When the addressing is direct, Ea is calculated without memory reference (except for the read of the instruction). When indirect addressing, the CPU has to reference the memory for operands to the calculation of Ea. We say that each memory reference, which is done to calculate Ea in one instruction, requires one level of indirect addressing. The maximum number of levels possible in the NORD-5 is 16 in addition to the read of the instruction.

The algorithm for calculating Ea is as follows: (symbols defined in 2.2)

$$
\begin{aligned}
& E a_{0}=\left(R_{B}\right)+\left(R_{X}\right)+D \\
& \text { if } I=0, \text { then } E a=E a_{0} \\
& E a_{1}=\left(R_{B_{1}}\right)+\left(R_{X_{1}}\right)+D_{1}, I A W_{1}=\left(E a_{0}\right) \\
& E a_{j}=\left(R_{B_{j}}\right)+\left(R_{X_{j}}\right)+D_{j}, I A W_{j}=\left(E a_{j-1}\right) \\
& E a=E a_{j}, I_{j}=0,0<j \leqslant 16, I_{i}=1,0 \leqslant i<j
\end{aligned}
$$

Note:
Each level of indirect addressing adds one "read instruction time" to the execution time.

A store operation to the location immediately following the storing instruction will have a special effect. The storing will be executed correct, but the next instruction will be the old content of the location. Example: STR REG, * +1 .

Indirect addressing is not allowed for the instruction EXC.
2.4 Instruction List

FC
2.4.1 $0 \quad$ Refer to inter register and argument instructions.
2.4.2 1 RTJ : Return Jump
$(\mathrm{R}):=(\mathrm{P})+1$ AND
$(\mathrm{P}):=\mathrm{Ea}$

$$
\mathrm{T}=2 \mu \mathrm{~s}
$$

2.4.3 2 EXC : Remote Execute (Two instructions)
$R=0, \quad(\mathrm{IR}):=(\mathrm{Ea})$
$\mathrm{T}=3 \mu \mathrm{~s}$
$\mathrm{R}=1, \quad(\mathrm{IR}):=\mathrm{Ea}$
$T=2 \mu s$
2.4.4 3 MIN : Memory Increment

$$
\begin{aligned}
& (\mathrm{Ea}):=(\mathrm{Ea})+(\mathrm{R})+1 \text { AND } \\
& \mathrm{IF}(\mathrm{Ea}):=0 \mathrm{THEN}(\mathrm{P}):=(\mathrm{P})+2 \\
& \operatorname{ELSE}(\mathrm{P}):=(\mathrm{P})+1 \quad \mathrm{~T}=3 \mu \mathrm{~s}
\end{aligned}
$$

2.4.5 $4 \quad$ CRG : Skip if register is greater or equal memory word
IF. $(\mathrm{R}) \geqslant(\mathrm{Ea})$ THEN $(\mathrm{P}):=(\mathrm{P})+2$
$\operatorname{ELSE}(\mathrm{P}):=(\mathrm{P})+1 \quad \mathrm{~T}=2 \mu \mathrm{~s} \quad$ No skip $\mathrm{T}=3 \mu \mathrm{~S} \quad$ Skip
2.4.6 $5 \quad$ CRL : Skip if register is less than memory word $\mathrm{IF}(\mathrm{R})<(\mathrm{Ea})$ THEN $(\mathrm{P}):=(\mathrm{P})+2$
i $\operatorname{ELSE}(\mathrm{P}):=(\mathrm{P})+1$

$$
\begin{array}{ll}
\mathrm{T}=2 \mu \mathrm{~S} & \text { No skip } \\
\mathrm{T}=3 \mu \mathrm{~S} & \text { Skip }
\end{array}
$$

2.4.7 $6 \quad$ CRE $\quad$ Skip if register and memory word is equal
$\operatorname{IF}(\mathrm{R})=(\mathrm{Ea}) \operatorname{THEN}(\mathrm{P}):=(\mathrm{P})+2$
$\operatorname{ELSE}(\mathrm{P}):=(\mathrm{P})+1 \quad \mathrm{~T}=2 \mu \mathrm{~s} \quad$ No skip $\mathrm{T}=3 \mu \mathrm{~S} \quad$ Skip
2.4.8 $7 \quad$ CRD $\quad$ : Skip if register not equal memory word
IF $(\mathrm{R}) \neq(\mathrm{Ea})$ THEN $(\mathrm{P}):=(\mathrm{P})+2$
$\operatorname{ELSE}(\mathrm{P}):=(\mathrm{P})+1$

$$
\begin{array}{ll}
\mathrm{T}=2 \mu \mathrm{~S} & \text { No skip } \\
\mathrm{T}=3 \mu \mathrm{~S} & \text { Skip }
\end{array}
$$

FC

2.4.9 $8 \quad$ JRP $:$|  | Jump if register is positive |
| ---: | :--- |
|  | $\operatorname{IF}(\mathrm{R}) \geqslant 0 \operatorname{THEN}(\mathrm{P}):=\mathrm{Ea}$ |
|  | $\operatorname{ELSE}(\mathrm{P}):=(\mathrm{P})+1$ |

$$
\begin{array}{ll}
\mathrm{T}=1 \mu \mathrm{~s} & \text { No jump } \\
\mathrm{T}=2 \mu \mathrm{~s} & \text { Jump }
\end{array}
$$

2.4.10 $9 \quad$ JRN $:$ Jump if register is negative
$\operatorname{IF}(\mathrm{R})<0$ THEN $(\mathrm{P}):=\mathrm{Ea}$
$\operatorname{ELSE}(P):=(P)+1$

| $\mathrm{T}=1 \mu \mathrm{~s}$ | No jump |
| :--- | :--- |
| $\mathrm{T}=2 \mu \mathrm{~S}$ | Jump |

2.4.11 $10 \quad \mathrm{JRZ}$ : Jump if register is zero
$I F(R)=0$ THEN $(\mathrm{P}):=\mathrm{Ea}$
$\operatorname{ELSE}(\mathrm{P}):=(\mathrm{P})+1$
$\mathrm{T}=1 \mu \mathrm{~s} \quad$ No jump
$\mathrm{T}=2 \mu \mathrm{~s} \quad$ Jump
2.4.12 11 JRF : Jump if register is non-zero

IF $(R) \neq 0$ THEN $(\mathrm{P}):=\mathrm{Ea}$
$\operatorname{ELSE}(\mathrm{P}):=(\mathrm{P})+1$

$$
\begin{array}{ll}
\mathrm{T}=1 \mu \mathrm{~S} & \text { No jump } \\
\mathrm{T}=2 \mu \mathrm{~S} & \text { Jump }
\end{array}
$$

2.4.13 12 JPM : Modify register by its modification register. If register is positive, then jump.
$(\mathrm{R}):=(\mathrm{R})+\left(\mathrm{M}_{\mathrm{R}}\right)$ AND
$\operatorname{IF}(\mathrm{R}) \geqslant 0 \mathrm{THEN}(\mathrm{P}):=\mathrm{Ea}$
$\operatorname{ELSE}(\mathrm{P}):=(\mathrm{P})+1$
$\mathrm{T}=1 \mu \mathrm{~s} \quad$ No jump
$\mathrm{T}=2 \mu \mathrm{~s} \quad$ Jump
2.4.14 13 JNM : Modify register by its modification register. If register is negative, then jump.

$$
(R):(R)+\left(M_{R}\right) A N D
$$

$\mathrm{IF}(\mathrm{R}),<0$ THEN $(\mathrm{P}):=\mathrm{Ea}$
$\operatorname{ELSE}(\mathrm{P}):=(\mathrm{P})+1$

| $\mathrm{T}=1 \mu \mathrm{~s}$ | No jump |
| :--- | :--- |
| $\mathrm{T}=2 \mu \mathrm{~S}$ | Jump |

2.4.15 14 JZM : Modify register by its modification register. If register is zero, then jump.
$(\mathrm{R}):=(\mathrm{R})+\left(\mathrm{M}_{\mathrm{R}}\right)$ AND
$\operatorname{IF}(\mathrm{R})=0$ THEN $(\mathrm{P})=\mathrm{Ea}$
$\operatorname{ELSE}(P)=(P)+1$
$T=1 \mu \mathrm{~s} \quad$ No jump $\mathrm{T}=2 \mu \mathrm{~s} \quad$ Jump

| $2.4 .16 \quad 15 \quad$ JFM $:$ | Modify register by its modification <br>  <br>  <br>  <br>  <br> is nogister, If contents of register |
| :--- | :--- |
|  | $(\mathrm{R}):=(\mathrm{R})+\left(\mathrm{M}_{\mathrm{R}}\right)$ |
|  | $\mathrm{IF}(\mathrm{R}) \neq 0 \mathrm{THEN}(\mathrm{P}):=\mathrm{Ea}$ |
|  | $\mathrm{ELSE}(\mathrm{P}):=(\mathrm{P})+1$ |.

$$
\begin{array}{ll}
\mathrm{T}=1 \mu \mathrm{~S} & \text { No jump } \\
\mathrm{T}=2 \mu \mathrm{~S} & \text { Jump }
\end{array}
$$

2.4.17 $16 \quad \mathrm{ADD} \quad:$ Add content of memory word to
2.4.18 17 SUB : Subtract content of memory word from register

$$
(R):=(R)-(E a) \quad T=2 \mu s
$$

2.4.19 $18 \quad$ AND : Make "logical AND" between memory word and register. Result in register.

$$
(R):=(R) \wedge(E a)
$$

$$
\mathrm{T}=2 \mu \mathrm{~s}
$$

2. 4.20

19
LDR : Load content of memory word to register.

$$
(\mathrm{R}):=(\mathrm{E} a)
$$

$$
\mathrm{T}=2 \mu \mathrm{~s}
$$

2.4.21 $20 \quad$ ADM : Add contents of register: to memory word

$$
(\mathrm{Ea}):=(\mathrm{Ea})+(\mathrm{R})
$$

$$
\mathrm{T}=3 \mu \mathrm{~s}
$$

2.4.22 21 Instruction set aside for future extensions. .
2.4.23 22 XMR : Exchange contents of registers and memory word

$$
\begin{array}{ll}
(\mathrm{R}):=(\mathrm{Ea}) \text { AND } & \\
(\mathrm{Ea}):=(\mathrm{R}) & \mathrm{T}=3 \mu \mathrm{~s}
\end{array}
$$

FC.


| 2.4.27 $26 \quad$ LDF $\quad:$Load floating register with con- <br> tent of floating word |  |  |
| :--- | :--- | :--- | :--- |
|  | $(\mathrm{F}):=($ Ea, Ea +1$)$ | $\mathrm{T}=3 \mu \mathrm{~s}$ |

2.4.28 27 STF : Store content of floating register in floating word

$$
(E a, E a+1):=(F) \quad T=3 \mu s
$$

2.4.29 28 FAD : Add content of floating word to content of floating register

$$
(F):=(F)+(E a, E a+1) \quad T=3 \mu s
$$

2.4.30 29 FSB : Subtract content of floating word from floating register

$$
(F):=(F)-(E a, E a+1) \quad T=3 \mu \mathrm{~s}
$$

## FC

2.4.31 30 FMU : Multiply content of floating word by floating register. Result in floating register,
$(\mathrm{F}):=(\mathrm{F}) *(\mathrm{Ea}, \mathrm{Ea}+1) \quad \mathrm{T}=3 \mu \mathrm{~s}$
2.4.32 31 FDV : Divide content of floating register by content of floating word. Result in floating register.

$$
(\mathrm{F}):=(\mathrm{F}) /(\mathrm{Ea}, \mathrm{Ea}+1) \quad \mathrm{T}=10 \mu \mathrm{~s}
$$

3
3. 1
3.2

Instruction Layout
Instruction Word, IW

| 0 | RFC | RSC | 0 | DR/FDR | SRA/FSRA | SRB/FSRB |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| 31 | 27 | 23 | 18 |  | 12 | 6 |

IW : Instruction Word
RFC : Inter-Register Function Code
RSC : Inter-Register Sub-function Code
SRA : Source Register A designator
FSRA : Floating Source Register A designator
SRB : Source Register B designator
FSRB : Floating Source Register B designator
DR : Destination Register designator
FDR : Destination Floating Register designator

The following abbreviations will also be used:

| BN | : Bit Number |
| :--- | :--- |
| SC | : Shift Count |

3.3 Inter-register Instruction Descriptions

### 3.3.1 STOP

Stop NORD-5 CPU and call monitor program in NORD-1.


### 3.3.2 RIO: Register Input/Output

Transfer contert of a specified external register to a specified register.


| 1 | $:$ | Overflow, OR-register |
| :--- | :--- | :--- |
| 3 | $:$ | Remainder, RR-register |

### 3.3.3 SHR: Shift Register

Copy content of $S R$ to $D R$ and shift DR.

| 0 | 2 | I | R | SM | 0 | DR | SRA |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 31 | 272625 | 23 | 18 | 12 | SC |  |  |

RSC : divided in three fields, $L, R$, and SM.
$\mathrm{L}=1$ : Shift left
R = 1 : Shift right
SM : Shift mode
$\mathrm{SM}=0 \quad:$ Rotate register
SMI=1 : Rotate register
$\mathrm{SM}=2:$ Arithmetical shift. For left shift same as logical. For right shift bit 31 is copied to each bit shifted in (sign extension)

SM = $3 \quad:$ Logical shift. The bits which are shifted out of the word are lost and zeroes are put in the other end.
$0 \leqslant \mathrm{SC} \leqslant 31$
$(\mathrm{DR}):=(\mathrm{SR}) \mathrm{AND}$
$(\mathrm{DR}):=(\mathrm{DR}) * 2^{\mathrm{SC}}$
If both $L=1$ and $R=1$, then the right shift will be performed first and then the left shift.

$$
\mathrm{T}=1 \mu \mathrm{~s}
$$

### 3.3.4 SHF: Shift Floating Register

Copy FSRA to FDI: and shift FDR.

| 0 | 3 | L | R | SM | 0 | FDR | FSRA | SC |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 31 | 272625 | 23 |  | 18 | 12 |  | 6 | 0 |

Description as for SHR, Section 3.3.3, except $0 \leqslant S C \leqslant 63$.

$$
\mathrm{T}=1 \mu \mathrm{~s}
$$

### 3.3.5 BST: Bit Set

Copy SRA to DR and set specified bit in DR to one.


### 3.3.6 BCL: Bit Clear

Copy SRA to DR and set specified bit in DR to zero.


### 3.3.7 BSZ: Bit Skip on Zero

Copy $\operatorname{SRA}$ to DR and skip if specified bit in DR is zero.


### 3.3.8 BSO: Bit Skip on One

Copy SRA to DR and skip if specified bit in DR is one.


### 3.3.9 FIX: Convert Floating to Integer

Convert floating point number in FSRA to integer and place result in DR.

| 0 | 8 | $R$ | 0 | DR | FSRA | 0 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| 31 | 27 |  |  |  |  |  |
| 20 | 18 | 12 | 6 | 0 |  |  |

The converted number is truncated if $R=0$; if $R=10$, it is rounded.

$$
\mathrm{T}=1 \mu \mathrm{~s}
$$

### 3.3.10 FLO: Convert Integer to Floating

Convert the integer number in SRA to a floating point number in FDR

| 0 | 9 | 2 | 0 | FDR | SRA |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 31 | 27 | 18 | 0 |  |  |

### 3.3.11 LRO: Logical Register Operation

| 0 | 10 | CA | CB | LO | 0 | DR | SRA | SRB |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 31 | 27 | 26 | 25 | 23 |  | 18 |  | 12 |
| 0 |  |  |  |  |  |  |  |  |

The RSC is divided in 3 fields, $C A, C B$ and LO. If CA is set, the operand in SRA is complemented before the logical operation is performed. CB has the same effect on SRB.

The complementation of the operands does not affect the original contents of SRA and SRB.


$$
\partial T=1 \mu \mathrm{~S}
$$

The inter-register instruction with $R F C=11$ is saved for future usage.
3.3.13

IRO: Inter-Register Arithmetic

| 0 |  | 12 SC | AC | AF | 0 | DR |  | SRA |  | SRB |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 31 | 272625 |  |  | $23-18$ |  |  | 12 |  | 6 |  |
|  |  |  |  | : Arithmetical function |  |  |  |  |  | . |
|  | AF $=0$ |  | 0 | $(\mathrm{DR}):=(\mathrm{SRA})+(\mathrm{SRB})$ |  |  |  |  | T $=$ |  |
|  |  |  |  | (DR) : | SR |  |  |  | $\mathrm{T}=$ |  |
|  |  |  |  | (DR) : | SR |  |  |  | $\mathrm{T}=$ |  |
|  |  |  |  | (DR) : | SR |  |  |  | T |  |

The inter-register add and subtract may affect or be affected by a one bit register called the Carry Bit, CB.

If $\mathrm{SC}=1$, the content of CB will be set to its proper value after the arithmetical operation. If $\mathrm{AC}=1$, the content of CB will be added to the result of the arithmetical function.

The carry bit may be used to simulate multiple precision arithemtic. Using SC=1 will have the same effect as extending the operands with one bit containing zero. The result register will be extended by one bit containing one or zero, according to the arithmetical contlition.

Integer multiply and divide will affect the auxiliary registers. OR will contain the upper 32 bit part of the 64 bit product. $R R$ will contain a 32 bit remainder after an integer divide.

In all integer axithmetic, overflow conditions may occur. If so specified, an overflow condition may cause a monitor call. Overflow occurs when the result of an arithmetical operation is in size greater than ${ }^{ \pm}\left(2^{23}-1\right)$.

### 3.3.14 FRO: Floating Point Arithmetic

| 0 | 13 | 0 | AF | 0 | FDR | FSRA | FSRB |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 31 | 27 |  | 25 | 23 |  | 18 | 12 |  |

AF : Arithmetical function

$$
\begin{array}{rll}
\mathrm{AF}=0 & (\mathrm{FDR}):=(\mathrm{FSRA})+(\mathrm{FSRB}) & \mathrm{T}=1 \mu \mathrm{~s} \\
\mathrm{AF} & 1 & (\mathrm{FDR}):=(\mathrm{FSRA})-(\mathrm{FSRB}) \\
2 & (\mathrm{FDR}):=(\mathrm{FSRA}) *(\mathrm{FSRB}) & \mathrm{T}=1 \mu \mathrm{~s} \\
& 3 & (\mathrm{FDR}):=(\mathrm{FSRA}) /(\mathrm{FSRB})
\end{array}
$$

Cfr. Section 1.8, Floating Point Arithmetic.

| 0 | 14 | RL | AF | 0 | DR | SRA | SRB |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 31 | 27 | 25 | 23 | 18 | 12 | 6 | 0 |

The inter-register skip is a general arithmetical instruction followed by a relation between the result and zero.

$$
\begin{array}{ll}
\text { AF } & \text { Arithmetical function } \\
A F=0 & \text { Add } \\
1 & \text { Subtract }
\end{array}
$$

```
RL : Relation between result and zero
\(R L=0 \quad\) result \(\geqslant 0\)
    1 result \(<0\)
    2 result \(=0\)
    3 result \(\neq 0\)
\((\mathrm{DR}):=(\mathrm{SRA})\) arithmetical operation (SRB) AND
    IF relation THEN \((\mathrm{P}):=(\mathrm{P})+2\)
        \(\operatorname{ELSE}(\mathrm{P}):=(\mathrm{P})+1\)
```

Normally, $D R$ will be affected, but if general register 0 is specified as DR, no destination register is affected. However, the relation on the result will still be effective.

When $D R=0$ and $A F=1$, the $\operatorname{IRS}$ operation is a traditional skip.

$$
\begin{array}{ll}
\text { Skip } & 2 \mu \mathrm{~s} \\
\text { No skip } & 1 \mu \mathrm{~s}
\end{array}
$$

### 3.3.16 FRS: Floating Register Skip

| 0 | 15 | RL | AF | 0 | FDR | FSRA | FSRB |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 27 |  | 25 | 23 | 18 |  | 12 | 6 |

The description of FRS is the same as for IRS, Section 3.3.15, except that the arithmetic is performed on floating registers in floating point mode.

Introduction
Typical for the argument instruction is that one of the operands is contained in the instruction itself; it is called the argument, A. The other operand is contained in one of the general registers.

The argument is a 16 bit positive number. Before the specified operation takes place, the argument is extended to a 32 bit number with the 16 upper bits all equal to zero.
4.2

Argument Instruction Layout

| 1 | AFO | DR | 0 | ASF | A |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 31 | 29 |  | 23 |  | 18 | 16 |

A : Argument, 16 bits
AFC : Argument instruction function code
DR : Destination register
ASF : Argument instruction sub-function code
4.3 Instruction Description
4.3.1 DLR: Direct Logical Operation


$$
\mathrm{T}=1 \mu \mathrm{~s}
$$

### 4.3.2 DAR: Direct Arithmetic Function



### 4.3.3 DSK: Direct Skip

| 1 | 1 | CM | DR | 0 | RL | A |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 313029 | 23 | 18 16 |  |  |  |  |



## MEMORY REFERENCE INSTRUCTIONS

$$
\begin{gathered}
+++ \\
+
\end{gathered}
$$

MNEMONIC
ACTION

SECTION
2.4.2
2.4.3
2.4.4
2.4.5
2.4. 6
2.4.7
2.4.8
2.4.9
2.4. 10
2.4.11
2. 4. 12
2. 4.13
2.4.14
2. 4.15
2.4. 16
2. 4.17
2. 4.18
2.4. 19
2. 4.20
2. 4.21
2.4.23
2.4. 24
2.4. 25
2.4. 26
2. 4.27
2.4. 28
2.4. 29
2.4.30
2.4. 31
2.4. 32

INTER REGISTER OPERATIONS

## 1 SHIFT JNSTRUCTIONS

MNEMONIC
ACTION
SECTION
SLR Left rotational shift $\quad$ 3.3.3
SRR Right rotational shift
SLA Left arithmetical shift "
SRA Right arithmetical shift -"
SLL Left logical shift "
SRL Right logical shift .. "
SLRD Left rotational floating register shift
SRRD Right rotational floating register shift
SLAD Left arithmetical floating register shift
SRAD Right arithmetical floating register shift
SLLD Left logical floating register shift "
SRLD Right logical floating register shift "

2 MISCELLANEOUS OPERATIONS
BST
Bit Set
BCL
Bit clear
3. 3.5

Bit skip on zero
3. 3.6

BSZ
Bit ship on one
3. 3.7

BSO
Convert floating to integer
3. 3.8

FIX
Convert integer to floating
3.3.9
3. 3.10

3 ARITHMETIC OPERATIONS

| RAD | Register add | 3.3 .13 |
| :--- | :--- | :---: |
| RSB | Register subtract | $"$ |
| RMU | Register multiply | $"$ |
| RDV | Register divide | " |
| RAF | Floating register add | 3.3 .14 |
| RSF | Floating register subtract | $"$ |
| RMF | Floating register multiply | " |
| RDF | Floating register divide | " |

4 TEST AND SKIP

| MNEMONIC | ACTION |  |  |  |  |  |  | SEC TION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SGR | Subtract registers and skip if result $\geqslant 0$ |  |  |  |  |  |  | 3.3 .15 |
| ASG | Add | " | " | " | " | " | $\geqslant 0$ | " |
| SLE | Subtract | " | " | " | " | " | $<0$ | " |
| ASL | Add | " | " | " | " | " | $<0$ | " |
| SEQ | Subtract | " | " | " | " | " | $=0$ | " |
| ASE | Add | " | " | " | " | " | $=0$ | " |
| SUE | Subtract | " | " | " | " | " | * 0 | " |
| ASU | Add | " | " | " | " | " | $\neq 0$ | " |
| SGF | Subtract floating registers and skip if |  |  |  |  |  |  |  |
| ASGF | Add | " | " |  | " | " | $\geqslant 0$ | " |
| SLF | Subtract | " | " |  | " | " | $<$ | " |
| ASLF | Add | " | " |  | " | " | $<0$ | " |
| SEF | Subtract | " | " |  | " | " | = | " |
| ASEF | Add | " | " |  | " | " |  | " |
| SUF | Subtract | " | " |  | " | " | \# | " |
| ASUF | Add | " | " |  | " | " |  | " |

5 LOGICAL OPERATIONS

| MNEMONIC | ACTION | SECTION |
| :--- | :--- | :---: |
| RND | Register AND | 3.3 .11 |
| RNDA | Register AND, use complement of (SRA) | $"$ |
| RNDB | Register AND, use complement of (SRB) | $"$. |
| RXO | Register exclusive OR | $"$ |
| RXOA | Register exclusive OR, use complement | $"$ |
| of (SRA) | $"$ |  |
| RXOB | Register exclusive OR, use complement | $"$ |
| ROR (SRB) | $"$ |  |
| RORA | Register OR | $"$ |
| RORB | Register OR, use complement of (SRA) | $"$ |
| SZR | Register OR, use complement of (SRB) | $"$ |

ARGUMENT INSTRUCTIONS

| XORA | Exclusive or |
| :---: | :---: |
| ANDA | And |
| ORA | Or |
| SETA | Set register |
| SECA | Set register to complement |
| ADDA | Add |
| ADCA | Add complement |
| DDP | Skip if (DR) $\geqslant \mathrm{ARG}$ |
| DDN | " " " < " |
| DDZ | " " " = " |
| DDF | " " " 才 " |
| DSP | Skip if (DR) $\geqslant-\mathrm{ARG}$ |
| DSN | " " " < " |
| DSZ | " " " = " |
| DSF | " " " 11 |



| 0 | 0 | 0 |  | 0 | MESSAGE |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 |  | 0 | 000000 | DR | SR | EXT.REG.NO |
| 0 | $0 \quad 0 \quad 10$ | L R | SM | 000000 | DR | SR | SHIFT COUNT |
| 0 | 00.11 | L R | SM | $\begin{array}{lllll}0 & 0 & 0 & 0 & 0\end{array}$ | DR | SR | SHIFT, COUNT |
| 0 | $\begin{array}{llll}0 & 1 & 0 & 0\end{array}$ | 1. 1 | 0 C | $\begin{array}{lllll}0 & 0 & 0 & 0 & 0\end{array}$ | DR | SR | BITNO |
| 0 | $0 \begin{array}{llll}0 & 1 & 1\end{array}$ | 11 | 0 C | $\begin{array}{lllll}0 & 0 & 0 & 0 & 0\end{array}$ | D R | SR | BITNO |
| 0 | 0 l | 11 | 00 | $0 \quad 00000$ | DR | SR | BITNO |
| 0 | 01181 | 11 | $0 \quad 0$ | 0 | DR | SR | BITNO |
| 0 | $1 \begin{array}{llll}1 & 0 & 0 & 0\end{array}$ | R 0 | $0 \quad 0$ | 0 | DR | F SR | 0 |
| 0 | $1 \begin{array}{llll}1 & 0 & 0 & 1\end{array}$ |  | 10 | 0 | FDR | SR | 0 |
| 0 | $1 \begin{array}{llll}1 & 0 & 1 & 0\end{array}$ | $C A \mid C B$ | L0 | $\begin{array}{lllll}0 & 0 & 0 & 0 & 0\end{array}$ | DR | SRA | SRB |
| 0 | $1 \begin{array}{llll}1 & 0 & 1 & 1\end{array}$ |  |  | 0000000 |  |  |  |
| 0 | 1100 | SC AC | AF | 000000 | DR | SRA | SRB |
| 0 | $1 \begin{array}{llll}1 & 1 & 0 & 1\end{array}$ | $0 \quad 0$ | AF | 0 | FDR | FSRA | FSRB |
| 0 | $1 \begin{array}{llll}1 & 1 & 1 & 0\end{array}$ | RL | AF | $\begin{array}{lllll}0 & 0 & 0 & 0 & 0\end{array}$ | DR | SRA | SRB |
| 0 | $\begin{array}{llll}1 & 1 & 1 & 1\end{array}$ | RL | AF | 0 | FDR | FSRA | FSRB |
| I | X |  | B | $\begin{array}{lllll}0 & 0 & 0 & 0 & 1\end{array}$ | R |  | D |
| I | X |  | B | $\begin{array}{lllll}0 & 0 & 0 & 1 & 0\end{array}$ | R |  | D) |
| I | X |  | B | $\begin{array}{llllll}0 & 0 & 0 & 1 & 1\end{array}$ | R |  | D |
| I | X |  | B | $\begin{array}{llllll}0 & 0 & 1 & 0 & 0\end{array}$ | R |  | D |
| I | X |  | B | $\begin{array}{llllll}0 & 0 & 1 & 0 & 1\end{array}$ | R |  | D |
| I | X |  | B | $\begin{array}{llllll}0 & 0 & 1 & 1 & 0\end{array}$ | R |  | D |
| I | X |  | B | $\begin{array}{llllll}0 & 0 & 1 & 1 & 1\end{array}$ | R |  | D |
| I | X |  | B | $\begin{array}{llllll}0 & 1 & 0 & 0 & 0\end{array}$ | R |  | D |
| I | X |  | B | $\begin{array}{lllll}0 & 1 & 0 & 0 & 1\end{array}$ | R |  | D |
| I | X |  | B | $\begin{array}{llllll}0 & 1 & 0 & 1 & 0\end{array}$ | R |  | D |
| I | X |  | B | $\begin{array}{llllll}0 & 1 & 0 & 1 & 1\end{array}$ | . R |  | D |

STOP
RIO
SHR
SHF
BST
BCL
BSZ
BSO
FIX
FLO
LRO
Not used
IRO
FRO
IRS
FRS
RTJ
EXC
MIN
CRG
CRL
CRE
CRD
JRP
JRN
JRZ
JRF


| I | X | B | $0 \begin{array}{lllll}0 & 1 & 1 & 0 & 0\end{array}$ |  | R | D | JPM |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| I | X | B | $\begin{array}{llllll}0 & 1 & 1 & 0 & 1\end{array}$ |  | R | D | J NM |
| I | X | B | $\begin{array}{llllll}0 & 1 & 1 & 1 & 0\end{array}$ |  | R | D | J ZM |
| I. | X | B | $\begin{array}{llllll}0 & 1 & 1 & 1 & 1\end{array}$ |  | R | D | JFM |
| I | X | B | $1 \begin{array}{lllll}1 & 0 & 0 & 0 & 0\end{array}$ |  | R | D | ADD |
| I | X | B | 1. 0000001 |  | R | D | SUB |
| I | X | B | $1 \begin{array}{lllll}1 & 0 & 0 & 1 & 0\end{array}$ |  | R | D | AND |
| I | X | B | $\begin{array}{lllll}1 & 0 & 0 & 1 & 1\end{array}$ |  | R | D | LJ R |
| I | X | B | $\begin{array}{lllll}1 & 0 & 1 & 0 & 0\end{array}$ |  | R | D | ADM |
| I | X | B | $\begin{array}{lllll}1 & 0 & 1 & 0 & 1\end{array}$ |  | R | D | Not used |
| I | X | B | $\begin{array}{lllll}1 & 0 & 1 & 1 & 0\end{array}$ |  | R | D | XMR |
| I | X | B | $\begin{array}{lllll}1 & 0 & 1 & 1 & 1\end{array}$ |  | R | D | STR |
| I | X | B | $\begin{array}{lllll}1 & 1 & 0 & 0 & 0\end{array}$ |  | R | D | MPY |
| I | X | B | $1 \begin{array}{lllll}1 & 1 & 0 & 0 & 1\end{array}$ |  | R | D | DIV |
| I | X | B | $\begin{array}{lllll}1 & 1 & 0 & 1 & 0\end{array}$ |  | FR | D | LDF |
| I | X | B | $\begin{array}{llllll}1 & 1 & 0 & 1 & 1\end{array}$ |  | FR | D | STF |
| I | X | B | $1 \begin{array}{lllll}1 & 1 & 1 & 0 & 0\end{array}$ |  | FR | D | FAD |
| I | X | B | $\begin{array}{lllll}1 & 1 & 1 & 0 & 1\end{array}$ |  | FR | D | FSB |
| I | X | B | $\begin{array}{lllll}1 & 1 & 1 & 1 & 0\end{array}$ |  | FR | D | FMU |
| I | X | B | $\begin{array}{llllll}1 & 1 & 1 & 1 & 1\end{array}$ |  | FR | D | FDV |
| $\mathrm{Ij}_{j}$ | $\mathrm{X}_{\mathrm{j}}$ | Bj | $0 \quad 00$ |  |  | Dj | $\begin{aligned} & \text { Ind.addr } \\ & \text { word } \end{aligned}$ |
| 1 | 00 | DR | 000000 | LF |  | A | DLR |
| 1 | 01 | DR | 000000 | AF |  | A | DAR |
| 1 | 1 CM | DR | $\begin{array}{lllll}0 & 0 & 0 & 0 & 0\end{array}$ | RL |  | A | DSK |

