This volume is intended to be used together with the P800M publications concerning programming.

Part 1 describes in great detail the powerful instruction set for the P800M computers and shows the programmer the functional operation, the syntax, the setting of the condition register, the instruction time and examples.

The instructions are grouped in the following operational categories :

Load and store instructions
Arithmetic instructions
Logical instructions
Character handling instructions
Branch instructions
Shift instructions
Table handling instructions
External transfer instructions
Control instructions
I/O instructions
String instructions

## Table of Contents

| Preface                         |       |                                 | 111                             |
|---------------------------------|-------|---------------------------------|---------------------------------|
| PART 1                          | ti    | NSTRUCTION SET                  |                                 |
| Chapter                         | 1     | Introduction                    | 1.1                             |
| Instruction Registers Type of I | on Fo |                                 | 1.1<br>1.2<br>1.4<br>1.5<br>1.6 |
| Chapter                         | 2     | Load and Store Instructions     | 1.7                             |
| Chapter                         | 3     | Arithmetic Instructions         | 1,21                            |
| Chapter                         | 4     | Logical Instructions            | 1.61                            |
| Chapter                         | 5     | Character Handling Instructions | 1.73                            |
| Chapter                         | 6     | Branch Instructions             | 1.83                            |
| Chapter                         | 7     | Shift Instructions              | 1.99                            |
| Chapter                         | 8     | Table Handling Instructions     | 1.115                           |
| Chapter                         | 9     | External Transfer Instructions  | 1.119                           |
| Chapter                         | 10    | Control Instructions            | 1.131                           |
| Chapter                         | 11    | Input/Output Instructions       | 1.137                           |
| Chapter                         | 12    | String Instructions             | 1.151                           |



## PART 1

# **INSTRUCTION SET**



Introduction

#### Key to symbols used in the instruction set

Identifier, or label, consisting of max. 6 characters of which the first must Label always be a letter. All instructions, and most of the assembler directives, may be preceded by a label Asterisk, Indicates: - indirect addressing - current value of location counter The syntactic item(s) between these brackets may be omitted 11 1.1 Choose one of the items between these brackets. r1 Register A1 . . . A15 r2 Register A1... A15. Used as an index register in memory reference instructions. r3 Register A1...A7 Memory expression m k Constant in bits 8-15 (short constant) lk Constant or address in bits 0-15 of the word following the instruction (long constant) Р P-register, (Instruction counter) T1 Register to register operation. T2 Long constant instruction, T.3 Register addressing. **T3A** Register r2 is not the stackpointer A15 T3B Register r2 is the stackpointer A15 TxS The result must be stored in memory T4 Direct addressing T5 Indexed addressing **T6** Indirect addressing T7 Indirect indexed addressing T8 Short constant instruction Load/store indicator. Load: bit 15 = 0 1/5 Store: bit 15 = 1 MD Addressing mode Logical AND ۸. V Logical OR Exclusive DR •• Compare/ Divide 1 Multiply

×

Add

#### Instruction formats

Machine instructions conform to one of the following two formats:

- format 0
- format 1.

#### Format 0 instructions

Instructions of this type consist of one word, where the 16 bits indicate the following functions:

| bit | 0 | 1      | 4 | 5   | 7 | 8 | 1 | 5      |
|-----|---|--------|---|-----|---|---|---|--------|
|     | 0 | opcode |   | r3  |   |   |   |        |
|     |   |        | _ | CND |   |   |   | $\Box$ |

#### where

bit 0 - indicates the instruction format

bits 1-4 - operation code

bits 5-7 — one of the registers A1-A7 or the condition value in a Branch instruction.

bits 8-15 — the contents of this field varies according to the type of instruction and may contain one of the following values:

- an 8-bit positive constant (constant instruction)

- an even displacement value (branch instruction)

-an indication of the shift required (shift instruction)

- device address (I/O instruction) + function bits

- fixed parameters (miscellaneous instruction)

#### Format 1 instructions

Format 1 instructions perform a number of operations by reference to two of the 16 registers available for user access: one of these registers may point to a data item either in a word following the instruction or elsewhere in memory as it is possible to use that register as an index register.



This type of instruction may be followed by a data word (16 bits) containing an address (m) or a positive or negative value. In the case of an address, bit 15 is not significant, except for character handling instructions.

The binary values of bits 5 through 8 in r1 and 11 through 14 for r2 are: 4.2.1.8, and in r3 4.2.1.

Example: A3 in r1 or r2 is written as 0110 and A12 as 1001. For r3 this is 011. A12 cannot be specified in the field r3.

#### Registers

16 registers are available for use by the programmer. These 16 registers, which have the predefined symbols A0 through A15, are called the scratchpad. They may be addressed from either the instruction being carried out or from the toggle switches on the control panel.

The specific designation of registers within the scratchpad is:

#### P-register (A0)

This register is used to hold the address of the next instruction to be executed. It is incremented in steps of two if the program is to carry out in sequence, or altered to hold the required new address if a branch is to be performed.

The instruction counter (P) points always already to the next instruction before execution of an instruction.

#### Working registers (A1-A14)

The working registers may be used in any of the following ways:

- as accumulator where the data to be processed can be found in a register.
- as pointers where the contents of the specified registers contain the operand address rather than the operand itself.
- as index registers where the contents of the specified registers and the contents of the word following the instruction are summed to produce the operand address.

#### Register A15

This register is used by the interrupt system as the stackpointer and, as such, it is updated by the system whenever it is used for memory addressing.

It may be addressed by instruction in the same way as the registers A1 through A14.

#### Type of instruction

The instruction in the instruction set may use various methods of forming one of the operands to be used. To make a clear distinction between these methods, each instruction in the instruction set description has received a notation T1 thru T8 to indicate the manner in which the operand is formed. The latter is usually governed by the values of the format, address mode and the r2 field (bits 11 thru 14) in the instruction. The result of this operation may be an address which is called the effective memory address.

| Туре                 | Format | Mode | r2 field   | Description                                                                                      |
|----------------------|--------|------|------------|--------------------------------------------------------------------------------------------------|
| T1                   | 1      | 00   | ≠ 0        | Register to register operation                                                                   |
| T2                   | 1      | 01   | 0000       | Long constant instruction                                                                        |
| T3<br>(T3A)<br>(T3B) | 1      | 01   | <b>+</b> 0 | Address in register r2<br>(The register specified is not A15)<br>(The register specified is A15) |
| T4                   | 1      | 10   | 0000       | Address in next word (direct addressing)                                                         |
| <b>T</b> 5           | 1      | 10   | <b>#</b> 0 | Indexed addressing                                                                               |
| Т6                   | 1      | 11   | 0000       | Indirect addressing                                                                              |
| <b>T</b> 7           | 1      | 11   | <b>≠</b> 0 | Indexed indirect addressing                                                                      |
| ТВ                   | 0      | _    | _          | Short constant                                                                                   |

#### T1 Register to register operation

The operand is the value in the register specified by r2.

#### T2 Long constant instruction

The operand is the value contained in the least significant word of the double length instruction.

#### T3 Address in register

The operand is held in memory. The memory address of the operand is the value in the register specified by r2.

T3A r2 # A15

T3B r2 = A15

#### T4 Address in next word (direct addressing)

The operand is held in memory. The memory address of the operand is the value in the least significant word of the double length instruction.

#### T5 Indexed address in next word (indexed addressing)

The operand is held in memory. The memory address of the operand is found by adding the value in the register specified by r2 to the value in the least significant word of the double length instruction.



Syntax:

The contents of the register specified by r1 are replaced by the contents of the effective memory address. This effective memory address can be found as follows:

| Type | Function          | MD   | Syntax        |
|------|-------------------|------|---------------|
| T4   | (m) → r1          | 10   | LD r1, m      |
| T5   | (m + (r2)) - r1   | 10   | LD r1, m, r2  |
| T6   | ((m)) + r1        | l 11 | LD* r1, m     |
| T7   | ((m + (r2))) → r1 | 11   | LD* r1, m, r2 |

Condition register:

$$CR = 0 \text{ if } (r1) = 0$$
  
 $1 \text{ if } (r1) > 0$   
 $2 \text{ if } (r1) < 0$ 



Remark:

Restricted to system mode if r1 = A15.

LDR

#### Load register/register

LDR

P851M P852M P856M P857M

Syntax:

The 16 bits of the register specified by r1 are replaced either by the contents of the register specified by r2 (direct addressing) or by the contents of the effective memory address which can be found in the register specified by r2 (indirect addressing). In the last addressing mode, if r2 specifies the A15 register, the latter is assumed to be the stack. In this case, the pointer is updated (i.e. incremented by one word to point to the latest entry) before the transfer of data occurs.

| Type | Function                             |       | MD | Syntax       |
|------|--------------------------------------|-------|----|--------------|
| T1   | ( r2 )                               | -+ r1 | 00 | LDR r1, r2   |
| T3A  | ((r2))                               | → r1  | 01 | LDR* r1, r2  |
| T3B  | $(A15) + 2 \rightarrow A15, ((A15))$ | → r1  | 01 | LDR* r1, A15 |

# Condition register:

$$CR = 0 \text{ if } \{r1\} = 0$$
  
 $1 \text{ if } \{r1\} > 0$   
 $2 \text{ if } \{r1\} < 0$ 



#### Remark:

Restricted to system mode if r1 = A15 or if type 3B.

LDK LDKL

#### Load constant

LDK LDKL P851M P852M P856M P857M

Syntax:

- The positive constant k is loaded into bits 8 through 15 of the register specified in r3. The bits 0 through 7 are reset to zero.
- T2 The positive or negative constant, which can be found in the word following the instruction, replaces the contents of the register specified by r1.

| Type             | Function                                         |                          | Syntax      |   |
|------------------|--------------------------------------------------|--------------------------|-------------|---|
| TB<br><b>T</b> 2 | $k \rightarrow r3_{n-15}$<br>$1k \rightarrow r1$ | $0 \rightarrow r3_{n-7}$ | LDK<br>LDKL | , |

Condition register:





Remark:

Restricted to system mode if r1 = A15.

ST

Store register

ST

P851M P852M P856M P857M

Syntax:

The 16 bits of the register specified by r1 replace the contents of the effective memory address.

| Type | Function                      | MD | Syntax        |
|------|-------------------------------|----|---------------|
| T4   | (r1) → m                      | 10 | ST r1, m      |
| T5   | (r1) -+ m + (r2)              | 10 | ST r1, m, r2  |
| T6   | (r1) → (m)                    | 11 | ST* r1, m     |
| T7   | $(r1) \rightarrow (m + (r2))$ | 11 | ST* r1, m, r2 |

### Condition

register:

Unchanged



Remark:

Restricted to system mode if r1 = A15.

STR

#### Store register/register

STR

P851M P852M P856M P857M

Syntax:

$$\{label\} \cup STR \cup r1, r2$$

The 16 bits of the register specified by r1 replace the contents of the memory address indicated in the register specified by r2 (indirect addressing). If A15 (stack pointer) is specified by r2 it is updated.

| Type | Function                      | Syntax      |
|------|-------------------------------|-------------|
| T3A  | (r1) - (r2)                   | STR r1, r2  |
| T38  | (r1) · (A15), (A15) - 2 · A15 | STR r1, A15 |

### Condition

register:

Unchanged



#### Remark:

- An interrupt 'stack overflow' is generated when, for T3B type, the address reached by the pointe/ = </100. Bit 13 is set to 1 in PSW.</li>
- \* Restricted to system mode if/r1 = A15 or if type 3B.

ML

#### Multiple load

ML

P851M P852M P856M P857M

(softw.

The contents of n consecutive registers (the first one being A1) are replaced by the contents of n consecutive memory locations (the first location is indicated by the effective memory address).

| Type                                   | Function                              |          |       | MD | Syntax       |  |
|----------------------------------------|---------------------------------------|----------|-------|----|--------------|--|
| T4                                     | (m) (m + n)                           | <b>→</b> | A1 An | 10 | ML n, m      |  |
| T5                                     | (m + (r2)) (m + (r2) + n)             | <b>→</b> | A1 An | 10 | ML n, m, r2  |  |
| T6                                     | ((m)) ((m) + n)                       | -•       | А1 Ап | 11 | ML*n,m       |  |
| Т7                                     | $\{(m + (r2))\} \{(m + \{r2\}) + n\}$ | <b>→</b> | A1 An | 11 | ML* n, m, r2 |  |
| n = number of registers (1 through 15) |                                       |          |       |    |              |  |

Condition register:



#### Remark:

Restricted to system mode if n = 15.

MLK

### Multiple load constant

MLK

P851M P852M P856M P857M

(softw. sim

Syntax:

The contents of n successive registers are replaced by n values which must be given immediately after this instruction by means of a data statement. If n = 0 the instruction is trapped.

lk1, lk2,..., lkn → A1, A2,..., An

Syntax MLK n DATA x,...,xn

n = number of registers (1 through 15)

Condition



#### Remark:

Restricted to system mode if n = 15.

MLR

Multiple load/register

MLR

P851M P852M (sc P856M P857M

(softw. sim)

Syntax: [label] \_ MLR \_ n, r2

The contents of n consecutive registers (the first one being A1), are replaced by the contents of n consecutive memory locations. The first address of those locations is indicated by the contents of r2. If r2 is the stackpointer A15, the system stackpointer is updated.

Type Function Syntax

T3A 
$$((r2))$$
  $\rightarrow$  A1 MLR n, r2

 $((r2) + 2)$   $\rightarrow$  A2

 $((r2) + 2n - 2)$   $\rightarrow$  An

T3B  $(A15) + 2n$   $\rightarrow$  A15 MLR n, A15
 $((A15))$   $\rightarrow$  A1
 $((A15))$   $\rightarrow$  A2
 $((A15)$   $\rightarrow$  A2
 $((A15)$   $\rightarrow$  An

n - number of registers (1 through 15)

# Condition register:



#### Remark:

- \* Restricted to system mode if n = 15 or if r2 = A15
- \* If 3B type, the contents must be even (P851M).

MS

Multiple store

MS

P851M P852M P856M P857M

(softw. sim)

Syntax:

The contents of n consecutive memory locations (the first one is given by the effective memory address) are replaced by the contents of n consecutive registers.

| Type | Function                                       | MD         | Syntax       |
|------|------------------------------------------------|------------|--------------|
| T4   | A1 An → m, , m + n                             | 10         | MS n, m      |
| T5   | A1An $\rightarrow$ m + (r2),,m + (r2) + n      | 10         | MS n, m, r2  |
| T6   | A1An $\rightarrow$ (m),, (m) + n               | <b>1</b> 1 | MS* n, m     |
| T7   | A1An $\rightarrow$ {m + {r2}},, (m + (r2)) + n | 11         | MS* n, m, r2 |

n = number of registers (1 through 15)

Condition

register:

Unchanged



Remark:

Restricted to system mode if n = 15.

MSR

Multiple store register

MSR

P851M P852M P856M P857M

(softw, sim

Syntax: [label] \_ MSR \_ n, r2

The contents of n consecutive registers (the first one is register A1) replace the contents of n consecutive memory locations. The first address of those locations is specified in r2. If r2 = the system stackpointer A15, the stackpointer is updated by the contents of n registers.

Type Function Syntax

T3A 
$$|A1\rangle \rightarrow (r2)$$
 MSR n, r2

 $|A1\rangle \rightarrow (r2) + 2$ 
 $|A1\rangle \rightarrow (r2) + 2$ 
 $|A1\rangle \rightarrow (r2) + 2n - 2$ 

T3B  $|A1\rangle \rightarrow (A15) \rightarrow (A15) - 2$ 
 $|A1\rangle \rightarrow (A15) - 2n + 2$ 

n = number of registers (1 through 15)

### Candition

register:

Unchanged



#### Remark:

- An interrupt 'stack overflow' is generated when, for type T3B, the address reached by the pointer > </100. Bit 13 in PSW is set to 1.</li>
- Restricted to system mode when n = 15 or r2 = A15.
- \* If 3B type, the A15 contents must be even (P851M).

EL

### Extended load (MMU option)

EL

P857M

Syntax:

The 16-bit contents of the effective memory address, specified in m and translated by the MMU, are loaded in register r1.

| Type | Function              |      | MD | Syntax        |
|------|-----------------------|------|----|---------------|
| T4   | (m) extended          | → r1 | 10 | EL r1, m      |
| T5   | (m + (r2)) extended   | → r1 | 10 | EL r1, m, r2  |
| T6   | ((m)) extended        | → r1 | 11 | EL* r1, m     |
| T7   | ((m + (r2))) extended | → r1 | 11 | EL* r1, m, r2 |

# Condition register:

CR = 0 if 
$$(r1)$$
 = 0  
1 if  $(r1)$  > 0  
2 if  $(r1)$  < 0



#### Remark:

ELR

Extended load/reg. (MMU option)

ELR

P857M

Syntax:

The 16-bit contents of the effective memory address pointed to in register r2, and translated by the MMU, are loaded in register r1.

Type Function

T3 ((r2)) extended -- r1

Condition

register:

CR = 0 if 
$$(r1) = 0$$
  
1 if  $(r1) > 0$   
2 if  $(r1) < 0$ 



#### Remark:

ES

#### Extended store (MMU option)

ES

P857M

Syntax:

The 16-bit contents of register r1 replace the contents of the effective memory address as translated by the MMU.

| Type | Function                                   | MD | Syntax        |
|------|--------------------------------------------|----|---------------|
| T4   | (r1) → m, extended                         | 10 | ES r1, m      |
| T5   | $(r1) \rightarrow m + (r2), extended$      | 10 | ES r1, m, r2  |
| T6   | (r1) → (m), extended                       | 11 | ES* r1, m     |
| T7   | $\{r1\} \rightarrow (m + (r2))$ , extended | 11 | ES* r1. m. r2 |

# Condition register:

#### Unchanged



#### Remark:

**ESR** 

#### Extended store/reg. (MMU option)

ESR

P857M

Syntax:

This instruction replaces the contents of the memory address specified in r2, and translated by the MMU, by the 16-bit contents of register r1.

Type Function

T3 (r1) - (r2) extended

Condition

register: Unchanged



Remark:

LDA

Load address

LDA

P853 P854 P858 P859

Syntax:

[label] LDA r1.D.r2

This instruction loads the address specified in r2, incremented by the value D from the second instruction word, into the register specified by r1.

Type Function T1  $(r2) + D \Rightarrow r1$ 

Condition register:

Unchanged

bit 4 5 6 9 10 11 14 15 1 ı 0 1 0 0 ι2 0 1 1 D

#### Remark

- \* r1 must be #0
- \* restricted to system mode if r1 = A15

ADK ADKL

Add constant

ADK ADKL P851M P852M P856M P857M

Syntax:

- The positive constant k is added to the contents of the register specified in r3. The result of the addition is placed in r3.
- T2 The positive or negative constant lk is added to the contents of the register specified in r1. The result of the addition is placed in r1.

| Type | Function                  | Syntax      |
|------|---------------------------|-------------|
| T8   | $(r3) + k \rightarrow r3$ | ADK r3, k   |
| T2   | (r1) + lk → r1            | ADKL r1, lk |

# Condition register:



Remark:

Restricted to system mode if r1 = A1\$.

| ADR  |  |
|------|--|
| ADRS |  |

#### Addition register/register

ADR ADRS P851M P852M P856M P857M

Syntax:

The contents of the register specified by r1 are added either to the contents of the register specified by r2 (direct addressing), in which case the sum is always placed in the register specified by r1, or to the contents of the memory address indicated in the register specified by r2 (indirect addressing). In that case the sum is placed either in the register specified by r1 (the I/s indicator being 0) or in the memory address  $\{I/s = 1\}$ .

| Type | Function                         | MD | 1/s  | Syntax      |
|------|----------------------------------|----|------|-------------|
| T1   | $(r1) + (r2) \rightarrow r1$     | 00 | n.s. | ADR r1, r2  |
| T3   | $(r1) + ((r2)) \rightarrow r1$   | 01 | 0    | ADR* r1, r2 |
| T3   | $(r1) + ((r2)) \rightarrow (r2)$ | 01 | 1    | ADRS r1, r2 |

#### Condition

register:



#### Remarks:

- \* When I/s = 1 (store), r1 must be ≠ 0.
- Restricted to system mode if r1 = A15.

| AD  |  |
|-----|--|
| ADS |  |

#### Addition

| AD  |  |
|-----|--|
| ADS |  |

P851M P852M P856M P857M

Syntax:

The contents of the effective memory address are added to the contents of the register specified by r1.

The sum is placed either in the register specified by r1, in which case the load/store must be 0, or in the effective memory address when the load/ store indicator is 1.

| Type       | Function                                     | MD | 1/s | Syntax         |
|------------|----------------------------------------------|----|-----|----------------|
| T4         | $(r1) + (m) \rightarrow r1$                  | 10 | 0   | AD r1, m       |
| T4         | $(r1) + (m) \rightarrow m$                   | 10 | 1   | ADS r1, m      |
| T5         | $(r1) + (m + (r2)) \rightarrow r1$           | 10 | 0   | AD r1, m, r2   |
| <b>T</b> 5 | $(r1) + (m + (r2)) \rightarrow m + (r2)$     | 10 | 1   | ADS r1, m, r2  |
| T6         | $(r1) + (\{m\}) \rightarrow r1$              | 11 | 0   | AD* r1, m      |
| T6         | (r1) + ((m)) -> (m)                          | 11 | 1   | ADS* r1, m     |
| T7         | $(r1) + ((m + (r2))) \rightarrow r1$         | 11 | 0   | AD* r1, m, r2  |
| T7         | $(r1) + ((m + (r2))) \rightarrow (m + (r2))$ | 11 | 1   | ADS* r1, m, r2 |

#### Condition register:



- \* When I/s = 1, r1 must be ≠ 0.
- Restricted to system mode if r1 = A15.

IMR

#### Increment memory/register

IMR

P851M P852M P856M P857M

Syntax:

[label]... IMR ... r2

The contents of the effective memory address indicated in the register specified by r2 (indirect) are increased by one.

Type Function Syntax T3  $((r2)) + 1 \rightarrow (r2)$  IMR r2

Condition

register: CR = 0

CR = 0 if result = 0 1 if result > 0 2 if result < 0 3 in case of overflow

bit 0 1 4 5 8 9 10 11 14 15 1 0 0 1 0 0 0 0 0 1 r2 1

IM

#### Increment memory

IM

P851M P852M P856M P857M

Syntax:

This instruction increases by 1 the contents of the effective memory address, after which the value of the effective memory address is replaced by the new value.

| Type | Function                                  | MD | Syntax    |
|------|-------------------------------------------|----|-----------|
| T4   | (m)+1 → m                                 | 10 | IM m      |
| T5   | $(m + (r2)) + 1 \rightarrow m + (r2)$     | 10 | IM m, r2  |
| T6   | $((m)) + 1 \rightarrow (m)$               | 11 | IM° m     |
| T7   | $((m + (r2))) + 1 \rightarrow (m + (r2))$ | 11 | IM* m, r2 |

### Condition



SUK SUKL

#### Subtract constant

SUK SUKL P851M P852M P856M P857M

Syntax:

- The positive constant k is subtracted from the contents of the register specified in r3. The result is placed in r3.
- T2 The positive or negative constant lk is subtracted from the contents of the register specified in r1. The result is placed in r1.

| Type | Function          | Syntax      |
|------|-------------------|-------------|
| T8   | $\{r3\} = k + r3$ | SUK r3, k   |
| T2   | (r1) lk → r1      | SUKL r1, lk |

Condition

register:



Remark:

Restricted to system mode if r1 = A15.

SUR SURS

#### Subtract register/register

SUR SURS P851M P852M P856M P857M

Syntax:

The contents of the register specified by r2 (direct addressing) or the contents of the memory address indicated in the register specified by r2 (indirect addressing) are subtracted from the contents of the 16-bit register specified by r1. The result of this operation is placed:

- (direct addressing) : in the register specified by r1

- (indirect addressing): either in the register specified by r1 (1/s = 0) in

the memory address indicated in the register

specified by r2 (1/s = 1).

| Type | Function                         | MD | I/s | Syntax      |
|------|----------------------------------|----|-----|-------------|
| T1   | $(r1) - (r2) \rightarrow r1$     | 00 | 0   | SUR r1, r2  |
| T3   | $(r1) - ((r2)) \rightarrow r1$   | 01 | 0   | SUR* r1, r2 |
| T3   | $(r1) = ((r2)) \rightarrow (r2)$ | 01 | 1   | SURS r1, r2 |

# Condition register:



#### Remark:

- " When 1/s = 1, r1 must be  $\neq 0$
- " Restricted to system mode if r1 = A15.

| _ |     |
|---|-----|
|   | SU  |
|   | ••  |
|   | SUS |
| I | 000 |

#### Subtract word

| SU  |  |
|-----|--|
| SUS |  |

P851M P852M P856M P857M

Syntax:

The contents of the effective memory address are subtracted from the contents of the register specified by r1. The result is placed in the register specified by r1, when the 1/s bit is 0, or in the effective memory address when 1/s is 1

| $T_{YP}e$ | Function                                     | MD | 1/s | Syntax | Syntax    |  |  |  |
|-----------|----------------------------------------------|----|-----|--------|-----------|--|--|--|
| T4        | (r1) - ( m ) → r1                            | 10 | 0   | SU     | r1, m     |  |  |  |
| T4        | (r1) = ( m ) · m                             | 10 | 1   | SUS    | r1, m     |  |  |  |
| T5        | (r1) = (m + (r2)) + r1                       | 10 | 0   | SU     | r1, m, r2 |  |  |  |
| T5        | $(r1) - \{m + \{r2\}\} - m + \{r2\}$         | 10 | 1   | SUS    | r1, m, r2 |  |  |  |
| T6        | $(r1) - ((m)) \rightarrow r1$                | 11 | 0   | SU*    | rt, m     |  |  |  |
| T6        | (r1) = {{m}} → (m)                           | 11 | 1   | SUS*   | r1, m     |  |  |  |
| T7        | $(r1) = ((m + (r2))) \cdot r1$               | 11 | 0   | SU*    | r1, m, r2 |  |  |  |
| T7        | $(r1) = ((m + (r2))) \rightarrow (m + (r2))$ | 11 | 1   | SUS*   | r1, m, r2 |  |  |  |

### Condition

register:

| bit | 0 | 1 |   |   | 4 | 5 |    | 8 | 9  | 10 | 11 |    | 14 | 15  |
|-----|---|---|---|---|---|---|----|---|----|----|----|----|----|-----|
|     | 1 | 0 | 0 | 1 | 1 |   | r1 |   | MD |    |    | r2 |    | 1/5 |
|     |   |   |   |   |   |   |    |   | _  |    |    |    |    |     |

#### Remark:

- \* When the I/s bit +1, r1 must be  $\neq 0$
- \* Restricted to system mode if r1 = A15.

CWK

Compare word with constant

**CWK** 

P851M P852M P856M P857M

Syntax:

[label] 
$$\sqcup$$
 CWK  $\sqcup$  r1, lk

The contents of the register specified by r1 are compared with the constant. The result of this comparison is stored in the condition register.

Condition

$$CR = 0 \text{ if } (r1) = lk$$
  
1 if  $(r1) > lk$   
2 if  $(r1) < lk$ 



Remark:

Restricted to system mode if r1 = A15.

**CWR** 

Compare words register/register

CWR

P851M P852M P856M P857M

Syntax:

The contents of the 16-bit register specified by r1 are compared with the contents of the 16-bit register specified by r2 (direct addressing) or with the contents of the memory address held in the register specified by r2 (indirect addressing).

The result of the comparison is stored in the condition register.

| Type | Function           | MD | 1/5 | Syntax      |
|------|--------------------|----|-----|-------------|
| T1   | (r1) ↔ ( r2 ) → CR | 00 | 0   | CWR r1, r2  |
| T3   | (r1) ↔ ((r2)) → CR | 01 | 0   | CWR* r1, r2 |

# Condition register:



#### Remark:

Restricted to system mode if r1 = A15.

CW

## Compare words

CW

P851M P852M P856M P857M

Syntax:

The contents of the 16-bit register specified by r1 are compared with the contents of the effective memory address which is found in the word following the instruction.

The result of this comparison is stored in the condition register.

| Түре | Function                                           | MD | Syntax        |
|------|----------------------------------------------------|----|---------------|
| T4   | (r1) ↔ ( m ) → CR                                  | 10 | CW r1, m      |
| T5   | $(r1) \leftrightarrow (m + (r2)) \rightarrow CR$   | 10 | CW r1, m, r2  |
| T6   | (r1) ↔ ((m)) → CR                                  | 11 | CW" r1, m     |
| T7   | $(r1) \leftrightarrow ((m + (r2))) \rightarrow CR$ | 11 | CW* r1, m, r2 |

# Condition

register:

| bit | 0 | 1 |   |   | 4 | 5 |            | 8 | 9 | 10 | 11 |    | 14 | 15 |   |
|-----|---|---|---|---|---|---|------------|---|---|----|----|----|----|----|---|
|     | 1 | 1 | 1 | 0 | 1 |   | r <b>1</b> |   | M | ID |    | r2 |    | 0  |   |
|     |   |   |   |   |   |   | _          |   |   |    |    |    |    |    | 1 |

### Remark:

Restricted to system mode if r1 = A15.

|   | C1  |
|---|-----|
| 1 | C1S |

# Ones complement

| C1S | ( | 21 | l |
|-----|---|----|---|
|     | ( | 21 | S |

P851M P852M P856M P857M

Syntax:

Logic

Complement: One bits in the specified word or register become 0 and vice versa. The logic complement of the effective memory address replaces either the contents of the 16-bit register specified by r1 or the contents of the effective memory address, depending on the state of the I/s indicator.

| Type       | Function   |                          | MD | 1/5 | Syntax        |
|------------|------------|--------------------------|----|-----|---------------|
| T4         | ( m )      | → r1                     | 10 | 0   | C1 r1, m      |
| T4         | (m)        | → m                      | 10 | 1   | C1S m         |
| T5         | (m + (r2)) | → r1                     | 10 | 0   | C1 r1, m, r2  |
| <b>T</b> 5 | (m + (r2)) | -+ m + {r2}              | 10 | 1   | C1S m, r2     |
| T6         | ((m))      | → r1                     | 11 | 0   | C1* r1, m     |
| T6         | ((m))      | → (m)                    | 11 | 1   | C1S* m        |
| T7         | (m + (r2)) | → r1                     | 11 | 0   | C1° r1, m, r2 |
| <b>T</b> 7 | (m + (r2)) | $\rightarrow$ (m + (r2)) | 11 | 1   | C1S* m, r2    |

### Condition

register:



- When I/s = 0, r1 must be = 0
- \* Restricted to system mode when r1 = A15.

C1R C1RS

## Ones complement register/register

C1R C1RS P851M P852M P856M P857M

Syntax:

Logic

complement: Bits which contained 1 in the specified register become 0, and vice versa.

The logic complement of the contents of the 16-bit register specified by r2 (direct addressing) or the contents of the memory address indicated in the register specified by r2 replaces the contents of:

- (direct addressing) : the register specified by r1

- (indirect addressing): either the register specified by r1 (1/s = 0) or the

memory address indicated in the register specified

by r2 (1/s = 1).

If r1 is not specified, the default value will be P.

| Type | Function                  | MD | 1/s | Syntax      |
|------|---------------------------|----|-----|-------------|
| T1   | (r2) → r1                 | 00 | 0   | C1R r1, r2  |
| Т3   | $((r2)) \rightarrow r1$   | 01 | 0   | C1R* r1, r2 |
| T3   | (( <del>r2))</del> → (r2) | 01 | 1   | C1RS r2     |

# Condition

register:



- When I/s = 0, r1 must be ⅓ 0
- \* Restricted to system mode when r1 = A15.

NGR

# Negate register

NGR

P851M P852M P856M P857M

Syntax:

Twos complement.

Zero bits become one and vice versa, +1.

The twos complement of the contents of the register specified by r2 replaces the contents of the register specified by r1.

Type Function
$$\begin{array}{ll}
T_1 & 0 - (r_2) \rightarrow r_1
\end{array}$$

Syntax

Condition register:



- " r1 must be ≠ 0
- \* Restricted to system mode when r1 = A15 (not for P851M).

C2R

# Twos complement/register

C2R

P851M P852M P856M P857M

Syntax: [label] ☐ C2R ☐ r2

Twos complement.

Zero bits become one and vice versa, +1,

The twos complement (or negative) of the contents of the effective memory address replaces the old contents of this address.

Type Function Syntax
$$\begin{array}{ccc}
T3 & 0 - (tr2) \rightarrow (r2) & C2R & r2
\end{array}$$

Condition register:



C2

## Twos complement

C2

P851M P852M P856M P857M

Syntax:

Twos complement.

Zero bits become one and vice versa, +1.

The twos complement (or negative) of the contents of the effective memory address, indicated by the word following the instruction, replaces the old contents.

| Type | Function                                  | MD | Synt | ЭX    |
|------|-------------------------------------------|----|------|-------|
| T4   | $0 - (m) \rightarrow m$                   | 10 | C2   | m     |
| T5   | $0 - (m + (r2)) \rightarrow m + (r2)$     | 10 | C2   | m, r2 |
| T6   | $0-(\{m\}) \rightarrow (m)$               | 11 | C2*  | m     |
| T7   | $0 - ((m + (r2))) \rightarrow (m + (r2))$ | 11 | C24  | m, r2 |

### Condition

register:

bit 0 1 4 5 8 9 10 11 14 15 1 0 0 0 0 MD r2 1

CMR

# Clear memory/register

CMR

P851M P852M P856M P857M

Syntax:

[label] \_ CMR \_ r2

The contents of the memory address specified in the register specified

by r2 are reset to 0.

Type

Function

Syntax

T3  $0 \rightarrow (r2)$ 

CMR r2

Condition

register:

Unchanged

bit 0 1 4 5 8 9 10 11 14 15 1 0 1 0 0 0 0 0 0 0 1 r2 1

CM

# Clear memory

CM

P851M P852M P856M P857M

Syntax:

The contents of the effective memory address are reset to 0.

| Type | Function           | MD | Syntax    |
|------|--------------------|----|-----------|
| T4   | 0 → m              | 10 | CM m      |
| T5   | 0 → m + (r2)       | 10 | CM m, r2  |
| T6   | 0 → (m)            | 11 | CM* m     |
| T7   | $0 \to (m + (r2))$ | 11 | CM* m, r2 |

Condition

register: Unchanged



MUK

Multiply with constant

MUK

P851M P852M P856M P857M

(softw. sim)

Syntax:

[label] \_ MUK \_ lk

The constant lk is multiplied by the constant of register A2. The result of the multiplication is loaded as a 31-bit product in registers A1 and A2. Bit 0 of A2 is reset to zero. The sign bit of A1 is the sign of the result. Overflow occurs if the result  $> 2^{30} - 1$ . In that case the two registers contain only the 30 least significant bits

while the sign bit may or may not be correct.

Type

**Function** 

T2

(A2) x lk → A1, A2

Condition register:

CR = 0 if result = 0

1 if result > 0

2 if result < 0

3 in case of overflow

bit 10 11 14 15 0 0

MUR

### Multiply register/register

MUR

P851M P852M P856M P857M

Syntax:

The contents of the register specified by r2 (direct addressing), or the contents of the memory address indicated in r2 (indirect addressing) are multiplied by the contents of A2. The result is loaded as a 31-bit product in A1, A2. The most significant bit of A2 is reset to zero. The sign of the product is stored in the sign bit of A1.

Overflow occurs if the result  $> 2^{30} - 1$ .

In that case the two registers contain only the 30 least significant bits while the sign bit may or may not be correct.

| Type | Function             |          | MD | Syntax |    |
|------|----------------------|----------|----|--------|----|
| T1   | $(A2) \times (r2)$   | → A1, A2 | 00 | MUR    | r2 |
| T3   | $(A2) \times ((r2))$ | • A1, A2 | 01 | MUR*   | r2 |

## Condition

register:



# Multiply

MU

P851M P852M P856M P857M

(softw. sim)

Syntax:

The contents of register A2 are multiplied by the contents of the effective memory address. The result of this multiplication is loaded as a 31-bit product in registers A1, A2. The most significant bit of A2 is reset to zero. The sign of the product is stored in the sign bit of register A1.

Overflow occurs if result  $> 2^{30} - 1$ .

In that case the two registers contain only the 30 least significant bits while the sign bit may or may not be correct.

| Type | Function                   |          | MD | Syntax    |
|------|----------------------------|----------|----|-----------|
| T4   | (A2) x ( m )               | → A1, A2 | 10 | MU m      |
| T5   | $(A2) \times (m + (r2))$   | • A1, A2 | 10 | MU m, r2  |
| T6   | (A2) x ((m))               | • A1, A2 | 11 | MU* m     |
| T7   | $(A2) \times ((m + (r2)))$ | → A1. A2 | 11 | MU* m. r2 |

# Condition

register:

3 in case of overflow

| bit | 0 | _ 1 |   |   | 4 | 5 |   |   | 8 | 9 | 10 | 11 |    | 14 | 15 |   |
|-----|---|-----|---|---|---|---|---|---|---|---|----|----|----|----|----|---|
|     | 1 | 1   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | N | 1D |    | г2 |    | 0  |   |
|     |   |     |   |   |   |   |   |   |   |   |    |    |    |    |    | Y |

DVK

Divide by constant

DVK

P851M P852M P856M P857M

(softw. sim)

Syntax:

label] ت DVK ال [label]

The contents of the registers A1, A2 are divided by the constant lk. The quotient is placed in register A2, the remainder in register A1. Overflow occurs when the quotient exceeds 15 bits. In that case the contents of A1 and A2 are not significant. See also the note under DV on page 3.0.24.

Type

**Function** 

Q F

T2

(A1, A2) / lk

A2 A1

Condition

register:

CR = 0 if (A2) = 0

1 if (A2) > 0

2 if (A2) < 0 3 in case of overflow

bit

| 0 | 1 |   |   | 4 | 5 |   |   | 8 | 8 | 10 | 11 |   |   | 14 | 15 |
|---|---|---|---|---|---|---|---|---|---|----|----|---|---|----|----|
| 1 | 1 | 0 | Q | 1 | 0 | 0 | 0 | 0 | 0 | 1  | 0  | 0 | 0 | 0  | 0  |
|   |   |   |   |   |   |   |   |   |   |    |    |   |   |    |    |

DVR

# Divide register/register

DVR

P851M P852M P856M P857M

(softw. sim

Syntax: [label] = DVR(\*) = r2

The contents of the registers A1 and A2 are divided by the contents of r2 (direct addressing), or the contents of the memory address indicated in r2 (indirect addressing). The quotient is placed in register A2, the remainder in A1.

Overflow occurs if the quotient exceeds 15 bits. In that case the contents of A1 and A2 are not significant.

See also the note under DV on page 3.0.24.

| Туре | Function          | Q    | R  | MD | Syntax |    |
|------|-------------------|------|----|----|--------|----|
| T1   | (A1, A2) / (r2)   | → A2 | A1 | 00 | DVR    | r2 |
| T3   | (A1, A2) / ((r2)) | → A2 | A1 | 01 | DVR*   | r2 |

# Condition register:

3 in case of overflow

| bit | 0 | 1 |   |   | 4 | 5 |   |   | 8 | 9 | 10 | 11 |    | 14 | 15 |  |
|-----|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|--|
|     | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | M | 1D |    | r2 |    | 0  |  |
|     |   |   |   |   |   |   |   |   |   |   |    |    |    |    |    |  |

DV Divide

DV

P851M P852M P856M P857M

(softw. sim)

Syntax: [label] DV[•] m[, r2]

The contents of the registers A1 and A2 are divided by the contents of the effective memory address. The quotient is placed in register A2. The remainder in register A1.

The sign of the remainder is equal to the original sign of A1, A2, except when the remainder is equal to zero (always positive).

Overflow occurs when the quotient exceeds 15 bits. In that case the contents of A1 and A2 are destroyed except when the division is equal to

zero.

| Type       | Function                | 0    | R  | MD | Syntax    |
|------------|-------------------------|------|----|----|-----------|
| T4         | (A1, A2) / ( m )        | → A2 | A1 | 10 | DV m      |
| T5         | (A1, A2) / (m + (r2))   | → A2 | Α1 | 10 | DV m, r2  |
| T6         | (A1, A2) / ((m))        | - A2 | Α1 | 11 | DV* m     |
| <b>T</b> 7 | [A1, A2] / ((m + (r2))) | → A2 | A1 | 11 | DV* m, r2 |

### Condition

register:



#### Note:

An erroneous result is given when the most significant word of the dividend is equal to the two complement of the divisor.

DAK

Double add with constant

DAK

P851M P852M P856M P857M

(softw. sim)

Syntax:

A constant consisting of 32 bits (bit 0 of first word is sign bit; bit 0 of second word is not used) is added to the contents of registers A1 and A2. The sum is placed in A1, A2. Bit 0 of A2 is set to zero. Bit 0 of A1 is the sign bit.

Type Function

T2 lk1, lk2 + (A1, A2) → A1, A2

Condition

register:

3 in case of overflow

DAR

Double add register/register

DAR

P851M P852M P856M

P857M

(softw.

Syntax:

The contents of two consecutive registers, the first one specified in r2 (direct addressing), or the contents of two consecutive words. The address of the first one being indicated in r2 (indirect addressing) are added to the contents of A1 and A2. Bit 0 of A2 is set to zero. The sign bit of the result is the sign bit of A1.

| Type | Function                                     | MD | Syntax  |
|------|----------------------------------------------|----|---------|
| T1   | $(r2, r2 + 1) + (A1, A2) \rightarrow A1, A2$ | 00 | DAR r2  |
| T3   | ((r2), (r2) + 2) + (A1, A2) - A1, A2         | 01 | DAR* r2 |

Condition register:

$$CR = 0$$
 if result = 0

2 if result 
$$< 0$$

3 in case of overflow

| bit | 0 | 1 |   |   | 4 | 5 |   |   | 8 | 9 | 10 | 11 |    | 14 | 15 |
|-----|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|
|     | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | М | D  |    | г2 |    | 0  |
|     |   |   |   |   |   |   |   |   |   |   |    |    |    |    |    |

DA

Double add

DA

P851M P852M P856M

P857M

(softw. sim)

Syntax:

The contents of the effective memory address and the contents of the effective memory address + 2 are added to the contents of the registers A1 and A2. The sum is placed in those registers.

The sign bit in A2 is set to zero. The sign bit of the parameters and result is the sign bit of A1.

| Type | Function                                |            | MD | Syntax    |
|------|-----------------------------------------|------------|----|-----------|
| T4   | ( m, m + 2) + (A1, A2)                  | → A1, A2   | 10 | DA m      |
| T5   | (m + (r2), m + (r2) + 2) + (A1, A2)     | -• A1, A2  | 10 | DA m, r2  |
| T6   | ((m),(m)+2)+(A1,A2)                     | → A1, A2   | 11 | DA • m    |
| T7   | ((m + (r2)), (m + (r2) + 2)) + (A1, A2) | ) → A1, A2 | 11 | DA* m, r2 |

# Condition

register:



DSK

### Double subtract with constant

DSK

P851M P852M (sc P856M

P857M

(softw. sim)

Syntax:

[label] 
$$\cup$$
 DSK  $\cup$  lk<sub>1</sub>, lk<sub>2</sub>

A constant consisting of 32 bits (bit 0 of first word is sign bit; bit 0 of second word is not used) is subtracted from the contents of registers A1, A2. The result is placed in A1, A2. Bit 0 of A2 is set to zero. Bit 0 of A1 is the sign bit.

Type Function

T2 
$$(A1, A2) = lk1, lk2 \rightarrow A1, A2$$

Condition

register:



DSR

Double subtract reg./reg.

DSR

P851M P852M P856M P857M

(softw. sim)

Syntax: [label] \_ DSR[•] \_ r2

The contents of two consecutive registers, the first one being specified in r2 (direct addressing), or the contents of two consecutive words, the address of the first one being indicated in r2 (indirect addressing) are subtracted from the contents of the registers A1 and A2. Bit 0 of A2 is reset to zero, Bit 0 of A1 is the sign bit.

| Type | Function                                                 | MD | Syntax  |
|------|----------------------------------------------------------|----|---------|
| T1   | $(A1, A2) - (r2, r2 + 1) \rightarrow A1, A2$             | 00 | DSR r2  |
| T3   | $\{A1, A2\} - \{\{r2\}, \{r2 + 1\}\} \rightarrow A1, A2$ | 01 | DSR* r2 |

# Condition register:



DS

Double subtract

DS

P851M P852M P856M P857M

(softw. sim

Syntax:

The contents of the effective memory address and the contents of the effective memory address + 2 are subtracted from the contents of the registers A1 and A2. The result is placed in A1, A2. The sign bit in A2 is set to zero.

The sign bit of the parameters and the result is the sign bit of register A1.

| Type       | Function                                                     | MD   | Syntax    |
|------------|--------------------------------------------------------------|------|-----------|
| T4         | $(A1, A2) - (m, m+2) \rightarrow A1, A2$                     | 10   | DS m      |
| <b>T</b> 5 | $(A1, A2) = (m + (r2), m + (r2) + 2) \rightarrow A1, A2$     | 10   | DS m, r2  |
| T6         | $(A1, A2) - ((m), (m) + 2) \rightarrow A1, A2$               | 11   | DS* m     |
| <b>T</b> 7 | $(A1, A2) = ((m + (r2)), (m + (r2)) + 2) \rightarrow A1, A2$ | 2 11 | DS* m, r2 |

# Condition

register:



FFL

Integer to floating point (F.P.P. option)

FFL

P857M

Syntax:

[label] \_ FFL

The contents of the registers A1, and A2, being a double precision integer, are sent to the Floating Point Processor where the integer is converted into a floating point operand. The result is stored in three accumulators FPA1, FPA2 and FPA3 on the Floating Point Processor.

Condition register:



**FFX** 

FFX

P857M

Syntax:

[label] ... FFX

The floating point operand contained in three accumulators FPA1, FPA2 and FPA3, situated on the Floating Point Processor, is converted into a double precision integer. The result is placed in the registers A1 and A2. During this operation the number may be truncated (loss of least significant bits).

An overflow occurs if the integer is greater than  $2^{30} - 1$  or smaller than  $-2^{30}$ . An interrupt is generated by the Floating Point Processor when an abnormal condition occurs. CR is set to 3

Type Function

T1 (FPA1, FPA2, FPA3) → integer → A1, A2

Condition

register:

CR = 0 if result = 0

1 if result > 0

2 if result < 0

3 abnormal condition:

- arithmetic overflow (exponent > 30)

bit

| 0 | 1 |   |   | 4 | 5 |   |   | 8 | 9 | 10 | 11 |   |   | 14 | 15 |
|---|---|---|---|---|---|---|---|---|---|----|----|---|---|----|----|
| 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0  | 0  | 0 | 0 | 0  | 1  |
|   |   |   |   |   |   |   |   |   |   |    |    |   |   |    |    |

FADR FADRS

# Floating point addition/register (F.P.P. option)

FADR FADRS P857M

Syntax:

[label] FADR[S] r2



The floating point operand contained in three accumulators FPA1, FPA2 and FPA3 on the Floating Point Processor, is added to the floating point operand present in three consecutive memory locations. The first memory location is indicated by r2. The result is placed either in FPA1, FPA2 and FPA3 or in three consecutive memory locations, depending on the state of the I/s indicator.

An interrupt is generated by the Floating Point Processor when an abnormal condition occurs. CR is set to 3,

# Condition register:

1 if result > 0

2 if result <0

3 abnormal conditions:

- unnormalized operand (operation aborted)
- arithmetic overflow (result exponent > or =  $2^{15}$ )
- arithmetic underflow (result exponent  $< -2^{15}$ )



Syntax:  $[label] \cup FAD[S](\cdot) \cup m[, r2]$ 

The floating point operand contained in the floating point accumulators FPA1, FPA2, FPA3 on the Floating Point Processor, is added to the floating point operand contained in three consecutive memory locations, the first one being indicated by the effective memory address. The sum is placed either in accumulators FPA1, FPA2 and FPA3 or in three consecutive memory locations pointed to by the effective memory address, depending on the state of the I/s indicator.

An interrupt is generated by the Floating Point Processor when an abnormal condition occurs, CR is set to 3.

```
Type
       Eunction
T4
        (FPA1,FPA2,FPA3) + ( m ),( m + 2 ),( m + 4 ) - FPA1,FPA2,FPA3
T45
        (FPA1.FPA2.FPA3) + (m).(m+2).(m+4) \rightarrow m.m+2.m+4
T5
        (FPA1,FPA2,FPA3) + (m + (r2)),(m + (r2) + 2), (m + (r2) + 4) \rightarrow
                                                        → FPA1,FPA2,FPA3
T5S
       (FPA1,FPA2,FPA3) + (m + (r2)),(m + (r2) + 2),(m + (r2) + 4) \rightarrow
                                       \rightarrow m + (r2), m + (r2) + 2, m + (r2) + 4
T6
        (FPA1.FPA2.FPA3) + ((m)).((m + 2)).((m + 4)) \rightarrow FPA1.FPA2.FPA3
T6S
        (FPA1,FPA2,FPA3) + ((m)),((m+2)),((m+4)) \rightarrow (m), (m+2), (m+4)
T7
        (FPA1,FPA2,FPA3) + ((m + (r2))),((m + (r2) + 2)),((m + (r2) + 4)) \rightarrow
                                                        → FPA1.FPA2.FPA3
T7S
        (FPA1.FPA2.FPA3) + ((m + (r2))).((m + (r2) + 2)).((m + (r2) + 4)) \rightarrow
                                  \rightarrow (m + (r2)), (m + (r2) + 2), (m + (r2) + 4)
Type
       MD
               1/5
                       Syntax
T4
        10
               0
                       FAD
                                m
T4S
        10
               1
                       FADS
                                m
T5
        10
               0
                       FAD
                                m. r2
T5S
        10
               1
                       FADS
                                m, r2
T6
        11
               ٥
                       FAD*
                                m
T6S
        11
               1
                       FADS*
                                m
```

# Condition

T7

T75

11

11

0

1

register.

FADS\* m, r2

FAD\*

m, r2



**FSUR FSURS** 

### Floating point subtract/register (F.P.P. option)

FSUR **FSURS** 

P857M

[label] FSUR[S] \_ r2 Syntax:

> The floating point operand contained in three consecutive memory locations, the first one being specified by r2, is subtracted from the floating point operand in the three accumulators FPA1, FPA2 and FPA3 on the Floating Point Processor. The result is placed either in FPA1, FPA2, FPA3 or in three consecutive memory locations.

depending on the state of the I/s indicator.

An interrupt is generated by the Floating Point Processor when an abnormal condition occurs. CR is set to 3.

Type Function **T**3

 $(FPA1,FPA2,FPA3) - ((r2)),((r2) + 2),((r2) + 4) \rightarrow FPA1,FPA2,FPA3$ T3S  $(FPA1,FPA2,FPA3) = ((r2)) \cdot ((r2) + 2) \cdot ((r2) + 4) \rightarrow (r2) \cdot (r2) + 2 \cdot (r2) + 4$ 

Type 1/5 Syntax T.3 n FSUR r2 **T3S** 1 FSURS r2

# Condition

register:

CR = 0 if result = 0

1 if result > 0

2 if result < 0

- 3 abnormal condition:
  - unnormalized operand (operation aborted)
  - arithmetic overflow (result exponent > or = 215)
  - arithmetic underflow (result exponent  $< -2^{15}$ )



Syntax: [label] FSU[S][\*] m[, r2]

The floating point operand contained in three consecutive memory locations, the first of which is specified by the effective memory address, is subtracted from the floating point operand present in three accumulators FPA1, FPA2 and FPA3 on the Floating Point Processor. The result is placed either in FPA1, FPA2 and FPA3 or in three consecutive memory locations pointed to by the effective memory address, depending on the state of the l/s indicator. An interrupt is generated by the Floating Point Processor when an abnormal condition occurs.

```
Type
       Function
Τ4
       \{FPA1,FPA2,FPA3\} = \{m\}, \{m+2\}, \{m+4\} \rightarrow FPA1,FPA2,FPA3\}
T4S
       (FPA1,FPA2,FPA3) = (m),(m+2),(m+4) \rightarrow m,m+2,m+4
T5
       (FPA1,FPA2,FPA3) - (m + (r2)),(m + (r2) + 2),(m + (r2) + 4) \rightarrow
                                                        → FPA1,FPA2,FPA3
T5S
       (FPA1.FPA2.FPA3) = (m + (r2)).(m + (r2) + 2).(m + (r2) + 4) +
                                       \rightarrow m + (r2), m + (r2) + 2, m + (r2) + 4
T6
       (FPA1,FPA2,FPA3) = ((m)),((m + 2)),((m + 4)) - FPA1,FPA2,FPA3
T6S
       (FPA1,FPA2,FPA3) = ((m))_{1}((m + 2))_{2}((m + 4)) \rightarrow (m)_{2}(m + 2)_{3}(m + 4)
T7
       (m + (r2)) \cdot ((m + (r2) + 2)) \cdot ((m + (r2) + 4)) \rightarrow
                                                       → FPA1,FPA2,FPA3
T7S
       (FPA1,FPA2,FPA3) - ((m + (r2))),((m + (r2) + 2)),((m + (r2) + 4)) \rightarrow
                                  \rightarrow (m + (r2)), (m + (r2) + 2), (m + (r2) + 4)
Type
       MD
               I/s
                       Syntax
T4
        10
               0
                       FSU
                              m
T4S
        10
               1
                       FSUS
                              m
T5
        10
               O
                       FSU
                              m. r2
T5S
        10
               1
                       FSUS m, r2
T6
        11
               0
                       FSU* m
T6S
        11
               1
                       FSUS* m
T7
        11
               0
                       FSU* m, r2
T7S
        11
               1
                       FSUS* m. r2
```

## Condition

rugister:

CR = 0 if result = 0
1 if result > 0
2 if result < 0
3 abnormal condition:
- unnormalized ope

- unnormalized operand (operation aborted)
- arithmetic overflow (result exponent > or = 215)
- arithmetic underflow (result exponent  $< -2^{15}$ )

| bit | 0 | 1 |   |   | 4 | 5 |   |   | 8 | 9 | 10 | 11 |     | 14 | 15_ |
|-----|---|---|---|---|---|---|---|---|---|---|----|----|-----|----|-----|
|     | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | ٨ | 1D |    | г2. |    | I/s |
|     |   |   |   |   |   |   |   |   |   |   |    |    |     |    |     |

FMUR FMURS

# Floating point multiply/register (F.P.P. option)

FMUR FMURS

P857M

Syntax: [label] FMUR[S] r2

The floating point operand contained in the floating point accumulators FPA1, FPA2, FPA3 is multiplied by the floating point operand present in three consecutive memory locations, the first one being indicated in r2. The result is placed either in FPA1, FPA2, FPA3 or in three consecutive memory locations, pointed at by r2, depending on the state of the I/s indicator.

An interrupt is generated by the Floating Point Processor when an abnormal condition occurs, CR is set to 3.

Type Function

T3 (FPA1,FPA2,FPA3) 
$$\times$$
 ((r2)),((r2) + 2),((r2) + 4)  $\leftarrow$  FPA1,FPA2,FPA3  
T3S (FPA1,FPA2,FPA3)  $\times$  ((r2)),((r2) + 2),((r2) + 4)  $\leftarrow$  (r2),((r2) + 2,(r2) + 4

Type I/s Syntax

T3 0 FMUR r2 T3S 1 FMURS r2

Condition

register:

CR = 0 if result = 0

1 if result > 0

2 if result < 0

3 abnormal condition:

- unnormalized operand (operation aborted)
- arithmetic overflow (result exponent > or  $-2^{15}$ )
- arithmetic underflow (result exponent  $< -2^{15}$ )



Syntax:  $[label] \perp FMU[S][\bullet] \perp m[, r2]$ 

The floating point operand contained in the floating point processor accumulators FPA1, FPA2, FPA3, is multiplied by the floating point operand present in three consecutive memory locations, the first of which is indicated by the effective memory address. The result is placed either in FPA1, FPA2 and FPA3 or in three consecutive memory locations, pointed at by the effective memory address, depending on the state of the I/s indicator.

An interrupt is generated by the Floating Point Processor when an abnormal condition occurs. CR is set to 3.

```
Type
        Function
T4
        (FPA1,FPA2,FPA3) \times (m) \cdot (m+2) \cdot (m+4) \rightarrow FPA1,FPA2,FPA3
T4S
        (FPA1.FPA2.FPA3) \times (m) (m+2) (m+4) \rightarrow m, m+2, m+4
        (FPA1,FPA2,FPA3) \times (m + (r2)),(m + (r2) + 2),(m + (r2) + 4) \rightarrow
T5
                                                             → FPA1.FPA2.FPA3
T5S
        (FPA1.FPA2.FPA3) \times (m + (r2)).(m + (r2) + 2).(m + (r2) + 4) \rightarrow
                                           \rightarrow m + (r2), m + (r2) + 2, m + (r2) + 4
        (FPA1,FPA2,FPA3) \times ((m)),((m + 2)),((m + 4)) \rightarrow FPA1,FPA2,FPA3
T6
T6S
        (FPA1,FPA2,FPA3) \times ((m)),((m+2)),((m+4)) \rightarrow (m),(m+2),(m+4)
T7
        (FPA1,FPA2,FPA3) \times ((m + (r2))),((m + (r2) + 2)),((m + (r2) + 4)) \rightarrow
                                                             → FPA1.FPA2.FPA3
        (FPA1,FPA2,FPA3) \times ((m + (r2))),((m + (r2) + 2)),((m + (r2) + 4)) \rightarrow
T7S
                                     \rightarrow (m + (r2)), (m + (r2) + 2), (m + (r2) + 4)
```

| Type | MID | 1/3 | Sylmux |       |
|------|-----|-----|--------|-------|
| T4   | 10  | 0   | FMU    | m     |
| T4S  | 10  | 1   | FMUS   | m     |
| T5   | 10  | 0   | FMU    | m, r2 |
| T5S  | 10  | 1   | FMUS   | m, r2 |
| T6   | 11  | 0   | FMU*   | m     |
| T6S  | 11  | 1   | FMUS*  | m     |
| T7   | 11  | 0   | FMU*   | m, r2 |
| T7S  | 11  | 1   | FMUS*  | m. r2 |

1/e

Suntar

### Condition register:

CR = 0 if result = 0 1 if result > 0 2 if result < 0

Type

MAD

- 3 abnormal condition:
  - unnormalized operand (operation aborted)
  - arithmetic overflow (result exponent > or = 2<sup>15</sup>).
  - arithmetic underflow (result exponent  $< -2^{15}$ )

| - arithmetic underflow (result exponent < -2") |    |   |   |   |   |   |   |   |   |   |    |    |    |    |     |
|------------------------------------------------|----|---|---|---|---|---|---|---|---|---|----|----|----|----|-----|
| bit                                            | 0_ | 1 |   |   | 4 | 5 |   |   | 8 | 9 | 10 | 11 |    | 14 | 15  |
|                                                | 1  | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | N | 1D |    | r2 |    | I/s |
|                                                |    |   |   |   |   |   |   |   |   | • |    |    |    |    |     |

FDVR FDVRS

# Floating point divide/register (F.P.P. option)

FDVR FDVRS

P857M

Syntax: [label] \_\_ FDVR[S] \_\_ r2

The floating point operand contained in the floating point processor accumulators FPA1, FPA2, FPA2, is divided by the floating point operand present in three consecutive memory locations, the first of which is indicated by r2.

The quotient is placed either in FPA1, FPA2, FPA3 or in three consecutive memory locations, pointed at by r2, depending on the state of the I/s indicator.

An interrupt is generated by the Floating Point Processor when an abnormal condition occurs. CR is set to 3.

Type Function

T3 (FPA1, FPA2,FPA3) / ((r2)), ((r2) + 2),  $((r2) + 4) \rightarrow$  FPA1, FPA2,FPA3 T3S (FPA1, FPA2,FPA3) / ((r2)), ((r2) + 2),  $((r2) + 4) \rightarrow$  (r2), (r2) + 2, (r2) + 4

Type I/s Syntax

T3 0 FDVR r2 T3S 1 FDVRS r2

#### Condition

register:

CR = 0 if result = 0

1 if result > 0

2 if result < 0

- 3 abnormal condition:
  - -- unnormalized operand (operation aborted)
  - arithmetic overflow (result exponent > or = 215)
  - arithmetic underflow (result exponent  $< -2^{15}$ )
  - Divisor = 0



**FDV** 

[label] \_\_ FDV[S] [+] \_\_ m[, r2] Syntax:

> The floating point operand contained in the floating point processor accumulators FPA1, FPA2, FPA3, is divided by the floating point operand present in three consecutive memory locations, the first one being pointed at by the effective memory address. The result is placed either in FPA1 FPA2 FPA3 or in the three consecutive memory locations pointed at by the effective memory address, depending on the state of the l/s indicator.

An interrupt is generated by the Floating Point Processor when an abnormal condition occurs. CR is set to 3.

```
Type
        Function
T4
        (FPA1,FPA2,FPA3) / ( m ) ( m + 2 ) ( m + 4 ) • FPA1,FPA2,FPA3
T4S
        (FPA1,FPA2,FPA3) / (m), (m+2), (m+4) \rightarrow m, m+2, m+4
        (FPA1,FPA2,FPA3) / (m + (r2)), (m + (r2) + 2), (m + (r2) + 4) \rightarrow
T5

    FPA1 FPA2 FPA3

T5S
        (FPA1,FPA2,FPA3) / (m + (r2)), (m + (r2) + 2), (m + (r2) + 4) \rightarrow
                                         \rightarrow m + (r2), m + (r2) + 2, m + (r2) + 4
T6
        (FPA1,FPA2,FPA3) / ((m)),((m + 2)),((m + 4)) \rightarrow FPA1,FPA2,FPA3
T6S
        (FPA1.FPA2.FPA3) / ((m)).((m + 2)).((m + 4)) \rightarrow (m).(m + 2).(m + 4)
T7
        (FPA1,FPA2,FPA3) / ((m + (r2))),((m + (r2) + 2)),((m + (r2) + 4))
                                                          → FPA1.FPA2.FPA3
T75
        (FPA1,FPA2,FPA3) / ((m + (r2))),((m + (r2) + 2)),((m + (r2) + 4)) \rightarrow
                                   \rightarrow (m + (r2)), (m + (r2) + 2), (m + (r2) + 4)
```

| Type | MU | 1/5 | Syntax |       |
|------|----|-----|--------|-------|
| T4   | 10 | 0   | FDV    | m     |
| T4S  | 10 | 1   | FDVS   | m     |
| T5   | 10 | 0   | FDV    | m, r2 |
| T5S  | 10 | 1   | FDV\$  | m, r2 |
| T6   | 11 | 0   | FDV*   | m     |
| T6S  | 11 | 1   | FDVS*  | ITI   |
| T7   | 11 | 0   | FDV*   | m, r2 |
| T7S  | 11 | 1   | FDVS*  | m, r2 |

#### Condition

register:

- unnormalized operand (operation aborted)
- arithmetic overflow (result exponent > or = 2<sup>15</sup>).
- arithmetic underflow (result exponent < -211)</li>
- Divisor 0



ANK ANKL

Logical AND with constant

ANK ANKL P851M P852M P856M P857M

Syntax:

### Logical product

| Bit in r3 or r1 | Bit in k or lk | Logical product |  |  |
|-----------------|----------------|-----------------|--|--|
| 0               | 0              | 0               |  |  |
| 0               | 1              | 0               |  |  |
| 1               | 0              | 0               |  |  |
| 1               | 1              | 1               |  |  |

- The logical product of k and the contents of bits 8—15 of the register specified by r3 is placed in bits 8—15 of r3.

  Bits 0—7 of this register are set to 0.
- T2 The logical product of lk and the contents of the register specified by r1 is placed in r1.

| Type | Function                                      |                          | Syntax      |
|------|-----------------------------------------------|--------------------------|-------------|
| T8   | (r3) <sub>6-15</sub> ∧ k → r3 <sub>5-15</sub> | $0 \rightarrow r3_{0-7}$ | ANK r3, k   |
| T2   | (r1) ∧lk → r1                                 |                          | ANKL r1, lk |

Condition register:

| bit | 0 | 1 |   |   | 4 | 5 |    | 8 | 9 | 10 | 11 |   |   | 14 | 15 |
|-----|---|---|---|---|---|---|----|---|---|----|----|---|---|----|----|
| T2  | 1 | 0 | 1 | 0 | 0 |   | r1 |   | 0 | 1  | 0  | 0 | 0 | 0  | 0  |
|     |   |   |   |   |   |   |    |   |   |    |    |   |   |    |    |

- \* If T8, r3 must be # 0. If T2, r1 must be # 0.
- \* Restricted to system mode if r1 = A15.

ANR ANRS

## Logical AND register/register

ANR ANRS P851M P852M P856M P857M

Syntax:

### Logical product

| Bit in r1 | Bit in 2nd operand | Logical product |
|-----------|--------------------|-----------------|
| 0         | 0                  | 0               |
| 0         | 1                  | 0               |
| 1         | 0                  | 0               |
| 1         | 1                  | 1               |
|           |                    |                 |

The logical product of the contents of the register r1 and the contents of the register specified by r2 (direct addressing) or the contents of the memory address indicated in the register specified by r2 (indirect addressing) is stored in:

- (direct addressing) : register specified by r1

- (indirect addressing): either in register specified by r1 (I/s = 0) or in

the memory address indicated in the register

specified by r2 (1/s - 1).

| Type | Function                            | MD | 1/5 | Syntax |        |
|------|-------------------------------------|----|-----|--------|--------|
| Ti   | (r1) ∧ ( r2 ) → r1                  | 00 | 0   | ANR    | r1, r2 |
| T3   | $(r1) \wedge ((r2)) \rightarrow r1$ | 01 | 0   | ANR*   | r1, r2 |
| T3   | (r1) ∧ ((r2)) → {r2}                | 01 | 1   | ANRS   | r1, r2 |

# Condition register:

| bit | 0 | 1 |   |   | 4 | 5 |    | 8_ | 9  | 10 | 11 |    | 14 | 15  |
|-----|---|---|---|---|---|---|----|----|----|----|----|----|----|-----|
|     | 1 | 0 | 1 | 0 | 0 |   | r1 |    | MD |    |    | r2 |    | I/s |
|     |   |   |   |   |   |   |    |    |    |    |    |    |    |     |

- \* If T1, then r1 must be  $\neq$  0. If T3, and  $1/s \neq$  0 then r1 must be  $\neq$  0.
- \* Restricted to system mode if r1 = A15.

| AN  |  |
|-----|--|
| ANS |  |

## Logical AND

| AN  |
|-----|
| ANS |

P851M P852M P856M P857M

Syntax:

[label] \_ AN[S][+] \_ r1, m[, r2]

### Logical product

| Bit in r1 | Bit in 2nd operand | Logical product |
|-----------|--------------------|-----------------|
| 0         | 0                  | 0               |
| 0         | 1                  | 0               |
| 1         | 0                  | 0               |
| 1         | 1                  | 1               |

The logical product of the contents of the effective memory address and the contents of the register specified by r1, is placed in this register, when the I/s indicator 0, or in the effective memory address, when I/s is 1.

| Type       | Function                                         | MD | 1/5 | Syntax | r         |
|------------|--------------------------------------------------|----|-----|--------|-----------|
| T4         | (r1) ∧( m ) → r1                                 | 10 | 0   | AN     | rl, m     |
| T4         | (r1) ∧( m ) → m                                  | 10 | 1   | ANS    | r1, m     |
| T5         | $\{r1\} \land \{m + (r2)\} \rightarrow r1$       | 10 | 0   | AN     | r1, m, r2 |
| T5         | $(r1) \land (m + (r2)) \rightarrow m + (r2)$     | 10 | 1   | ANS    | r1, m, r2 |
| T6         | (r1) ∧({m}) + r1                                 | 11 | 0   | AN*    | r1, m     |
| T6         | (r1) ∧((m)) →(m)                                 | 11 | 1   | ANS*   | r1, m     |
| <b>T</b> 7 | (r1) ∧((m + (r2))) → r1                          | 11 | 0   | AN*    | r1, m, r2 |
| <b>T</b> 7 | $(r1) \land ((m + (r2))) \rightarrow (m + (r2))$ | 11 | 1   | ANS*   | r1, m, r2 |

Condition register:



- \* If 1/s = 0 then r1 must be  $\neq 0$ .
- Restricted to system mode if r1 = A15.

ORK ORKL

### Logical OR with constant

ORK ORKL P851M P852M P856M P857M

Syntax:

[label] \_ ORK \_ r3, k - T8 [label] \_ ORKL \_ r1, lk - T2

Logical union:

| Bit in r3 or r1 | Bit in k or lk | Logical union |
|-----------------|----------------|---------------|
| 0               | 0              | 0             |
| 0               | 1              | 1             |
| 1               | 0              | 1             |
| 1               | 1              | 1             |

- T8 A logical OR is performed on the contents of bits 8-15 of the register specified by r3 and the value of the constant k.

  The result is placed in bits 8-15 of the register specified by r3.

  Bits 0-7 of this register are set to zero.
- T2 A logical OR is performed on the contents of the register specified by r1 and the value of the constant lk. The result of this operation is placed in the register specified by r1.

| $T_{VP}e$ | Type Function                                                               |                   |           |             |   |  |  |
|-----------|-----------------------------------------------------------------------------|-------------------|-----------|-------------|---|--|--|
| T8<br>T2  | $(r3)_{a-15} \lor k \Rightarrow r3_{a-15}$<br>$(r1) \lor lk \Rightarrow r1$ | r3 <sub>0-7</sub> | unchanged | ORK<br>ORKL | • |  |  |

Condition register:

| bit        | 0 | 1 |   |   | 4 | 5 |    | 7 | 8 |  |   |   | 15 |
|------------|---|---|---|---|---|---|----|---|---|--|---|---|----|
| <b>T</b> 8 | 0 | 0 | 1 | ٥ | 1 |   | r3 |   |   |  | k | - |    |
|            |   |   |   |   |   |   |    |   |   |  |   |   |    |

| bit | 0 | 1 |   |   | 4 | 5  | 8 | 9 | 10 | 11 |   |   | 14 | 15 |
|-----|---|---|---|---|---|----|---|---|----|----|---|---|----|----|
| T2  | 1 | 0 | 1 | 0 | 1 | r1 |   | 0 | 1  | 0  | 0 | 0 | 0  | 0  |
|     |   |   |   |   |   |    |   |   |    |    |   |   |    |    |

- \* If 1/s = 0 then r1 must be  $\neq 0$ .
- \* Restricted to system mode if r1 = A15.

ORR ORRS

## Logical OR register/register

| _ | R | R  |
|---|---|----|
| 0 | R | RS |

P851M P852M P856M P857M

Syntax:

[label] \_\_ ORR [+] \_\_ r1, r2 [label] \_\_ ORRS \_\_ r1, r2

Logical union:

| Bit in r1 | Bit in 2nd operand | Logical union |
|-----------|--------------------|---------------|
| 0         | 0                  | 0             |
| 0         | 1                  | 1             |
| 1         | 0                  | 1             |
| 1         | 1                  | 1             |

The logical OR of the contents of the 16-bit register specified by r1 and the contents of the 16-bit register specified by r2 (direct addressing) or the contents of the memory address indicated by the register specified by r2 (indirect instruction) is placed:

- (direct addressing) : in the register specified by r1

- (indirect addressing): either in the register specified by r1 (I/s = 0) or in

the memory address indicated in the register

specified by r2 (1/s = 1).

| Type       | Function                            | MD | 1/s | Syntax |        |
|------------|-------------------------------------|----|-----|--------|--------|
| <b>T</b> 1 | (r1) ∨ ( r2 ) → r1                  | 00 | 0   | ORR    | r1, r2 |
| T3         | (r1) ∨ ((r2)) r1                    | 01 | 0   | ORR*   | r1, r2 |
| T3         | $(r1) \lor ((r2)) \rightarrow (r2)$ | 01 | 1   | ORRS   | r1, r2 |

## Condition

register:

| bit | 0 | _1_ |   |   | 4 | 5 |    | 8 | 9 | 10 | 11 |    | 14 | 15  |
|-----|---|-----|---|---|---|---|----|---|---|----|----|----|----|-----|
|     | 1 | 0   | 1 | 0 | 1 |   | r1 |   | N | 1D |    | r2 |    | 1/s |
|     |   |     |   |   |   |   |    |   |   |    |    |    |    |     |

- \* If 1/s = 0 then r1 must be  $\neq 0$ .
- \* Restricted to system mode if r1 = A15.

| OR  |  |
|-----|--|
| ORS |  |

## Logical OR

| OR  |  |
|-----|--|
| ORS |  |

P851M P852M P856M P857M

Syntax:

[label] \_ OR(S) [+] \_ r1, m[, r2]

## Logical union:

| Bit in r1 | Bit in 2nd operand | Logical union |
|-----------|--------------------|---------------|
| 0         | 0                  | 0             |
| 0         | 1                  | 1             |
| 1         | 0                  | 1             |
| 1         | 1                  | 1             |

The logical OR of the contents of the effective memory address and the contents of the register specified by r1 is placed either in the r1 register, when 1/s bit = 0, or in the effective memory address, when 1/s bit = 1.

| Туре | Function                                        | MD | 1/s | Syntax |           |
|------|-------------------------------------------------|----|-----|--------|-----------|
| T4   | $(r1) \lor (m) \rightarrow r1$                  | 10 | 0   | OR     | r1, m     |
| T4   | $(r1) \lor (m) \rightarrow m$                   | 10 | 1   | ORS    | r1, m     |
| T5   | (r1) ∨ ( m → (r2)) → r1                         | 10 | 0   | OR     | r1, m, r2 |
| T5   | $(r1) \lor (m + (r2)) \rightarrow m + (r2)$     | 10 | 1   | ORS    | r1, m, r2 |
| T6   | $(r1) \lor ((m)) \rightarrow r1$                | 11 | 0   | OR*    | r1, m     |
| T6   | (r1) ∨ ((m)) → (m)                              | 11 | 1   | ORS*   | r1, m     |
| T7   | $(r1) \lor ((m + (r2))) \rightarrow r1$         | 11 | 0   | OR*    | r1, m, r2 |
| T7   | $(r1) \lor ((m + (r2))) \rightarrow (m + (r2))$ | 11 | 1   | ORS*   | r1, m, r2 |

# Condition register:



- r1 must be ≠ 0.
- \* Restricted to system mode if r1 = A15.

XRK XRKL

#### Exclusive OR with constant

XRK XRKL P851M P852M P856M P857M

Syntax:

Exclusive OR:

| Bit in r3 or r1 | Bit in k or ik | Exclusive OR |  |  |
|-----------------|----------------|--------------|--|--|
| 0               | 0              | 0            |  |  |
| 0               | 1              | 1            |  |  |
| 1               | 1 0            | 1            |  |  |
| 1               | 1              | 0            |  |  |

- The exclusive OR on the contents of bits 8-15 of the register specified by r3 and the value of k is placed in the register specified by r3.
  - Bits 0-7 of this register remain unchanged.
- T2 The exclusive OR on the contents of the register specified by r1 and lk is placed in the register specified by r1.

| Type     | Syntax                                                                           |                   |           |  |                 |
|----------|----------------------------------------------------------------------------------|-------------------|-----------|--|-----------------|
| T8<br>T2 | $\{r3\}_{n-1}, \forall k \rightarrow r3_{n-1}, \{r1\}  \forall k \rightarrow r1$ | r3 <sub>6-1</sub> | unchanged |  | r3, k<br>r1, lk |

## Condition

register:

| bit | 0 | 1 |   |   | 4 | 5 |    | 7 | 8 |   |    |            |   |   |    | 15 |
|-----|---|---|---|---|---|---|----|---|---|---|----|------------|---|---|----|----|
| T8  | 0 | 0 | 1 | 1 | 0 |   | r3 |   |   |   |    | k          |   |   |    |    |
|     |   |   |   |   |   |   |    |   |   |   |    |            |   |   |    |    |
| bit | 0 | 1 |   |   | 4 | 5 |    |   | 8 | 9 | 10 | 1 <b>1</b> |   |   | 14 | 15 |
|     | 1 | 0 | 1 | 1 | 0 |   | r1 | _ |   | 0 | 1  | 0          | 0 | 0 | 0  | 0  |
|     |   |   |   |   |   |   |    |   |   |   |    |            |   |   |    |    |

- r1 and r3 must be ≠ 0.
- \* Restricted to system mode if r1 = A15.

| XR  |  |
|-----|--|
| XRS |  |

### Exclusive OR

| XR  |  |
|-----|--|
| XRS |  |
|     |  |

P851M P852M P856M P857M

Syntax:

[label] \_ XR(S) [\*] \_ r1, m[, r2]

## Exclusive OR:

| Bit in r1 | Bit in 2nd operand | Exclusive OR |
|-----------|--------------------|--------------|
| 0         | 0                  | 0            |
| 0         | 1                  | 1            |
| 1         | 0                  | 1            |
| 1         | 1                  | 0            |

The exclusive OR of the contents of the effective memory address and the contents of the register specified by r1 is placed either in the register specified by r1, when the l/s bit = 0 or in the effective memory address, when 1/s = 1.

| Туре | Function                                            | MD | 1/s | Syntax         |
|------|-----------------------------------------------------|----|-----|----------------|
| T4   | (r1) ∀( m ) + r1                                    | 10 | 0   | XR r1, m       |
| T4   | (r1) √ ( m ) → m                                    | 10 | 1   | XRS r1, m      |
| T5   | $\{r1\} + (m + (r2)) \rightarrow r1$                | 10 | 0   | XR r1, m, r2   |
| T5   | $(r1) + (m + (r2)) \rightarrow m + (r2)$            | 10 | 1   | XRS r1, m, r2  |
| T6   | (r1) ∀((m)) → r1                                    | 11 | 0   | XR* r1, m      |
| T6   | (r1) ∀({m)) → (m)                                   | 11 | 1   | XRS" r1, m     |
| T7   | (r1) ∀((m + (r2))) → r1                             | 11 | 0   | XR* r1, m, r2  |
| T7   | $\{r1\} \neq (\{m + (r2)\}) \rightarrow (m + (r2))$ | 11 | 1   | XRS* r1, m, r2 |

# Condition register:



- \* r1 must be # 0.
- \* Restricted to system mode if r1 = A15.

| XR | R  |
|----|----|
| XR | RS |

### Exclusive OR register/register

|   | <b>KR</b> | R  |
|---|-----------|----|
| > | (R        | RS |

P851M P852M P856M P857M

Syntax:

[label] ∴ XRR [+] ∴ r1, r2 [label] ∴ XRRS ∴ r1, r2

Exclusive OR:

| Bit in r1 | Bit in 2nd operand | Exclusive OR |
|-----------|--------------------|--------------|
| 0         | 0                  | 0            |
| 0         | 1                  | 1            |
| 1         | 0                  | 1            |
| 1         | 1                  | 0            |

The exclusive OR of the contents of the 16-bit register specified by r1 and the contents of the 16-bit register specified by r2 (direct addressing) or the contents of the memory address indicated in the register specified by r2 (indirect addressing) are placed as follows:

- (direct addressing) : in the register specified by r1

- (indirect addressing): either in the register specified by r1 (I/s = 0) or

in the memory address indicated by the register specified by r2 (I/s = 1).

| Type | Function                               | MD | 1/5 | Syntax      |
|------|----------------------------------------|----|-----|-------------|
| T1   | $(r1) \neq (r2) \rightarrow r1$        | 00 | 0   | XRR r1, r2  |
| T3   | $(r1) \forall ((r2)) \rightarrow r1$   | 01 | 0   | XRR* r1, r2 |
| T3   | $(r1) \forall ((r2)) \rightarrow (r2)$ | 01 | 1   | XRRS r1, r2 |

## Condition register:

| bit | 0 | 1 |   |   | 4 | 5 |    | 8 | 9 | 10 | 11 |    | 14 | 15     |
|-----|---|---|---|---|---|---|----|---|---|----|----|----|----|--------|
|     | 1 | 0 | 1 | 1 | 0 |   | r1 |   | N | 10 |    | r2 |    | I/s    |
|     |   |   |   |   |   |   |    |   |   |    |    |    |    | $\neg$ |

- r1 must be ≠ 0.
- \* Restricted to system mode if r1 = A15.

| TM | Test mask | TM | P851M |
|----|-----------|----|-------|
|    |           |    | P852M |
|    |           |    | P856M |
|    |           |    | P857M |

Syntax: [label] TM \_ r1, r2

The logical product (AND) of the contents of the register specified by r1 and the contents of the register specified by r2 is compared to zero. The result of the comparison is stored in the condition register. The contents of the register specified by r1 and r2 remain unchanged.

Type Function

T1 
$$[(r1) \land (r2)] \leftrightarrow 0 \rightarrow CR$$

# Condition register:



- " r1 must be  $\neq$  0.
- Restricted to system mode if r1 = A15.

TNM

Test not mask

TNM

P851M P852M P856M P857M

Syntax:

The exclusive OR of the contents of the register specified by r1 and the contents of the register specified by r2 is compared with zero. The result of the comparison is stored in the condition register.

The initial contents of the register specified by r1 and the register specified by r2 remain unchanged.

Type Function

T1 
$$[\{r1\} \forall \{r2\}] \leftrightarrow 0 \rightarrow CR$$

# Condition register:



- \* r1 must be ≠ 0.
- \* Restricted to system mode if r1 = A15.

TSB

Test and Set Bit

TSB

P853 P854 P858 P859

Syntax [label] TSB[\*] m[ r2]

This instruction tests a bit in a bitstring, sets the condition register to the value of that bit, and sets the bit to 1.

The address of the first character of the bitstring is the instruction operand, found as follows:

| Type | address    |
|------|------------|
| T4   | m          |
| T5   | m + (r2)   |
| T6   | (ന)        |
| T7   | (m + (r2)) |

The bit position in the string must be specified in register A2; in addressing the operand it is used as shown below:



The bit displacement  $A2_{0-15}$  is split up in the character displacement D and the bit number B

The function of the instruction is:

| Type       | Function                                                                                     | Mode | Syntax |      |
|------------|----------------------------------------------------------------------------------------------|------|--------|------|
| T4         | (m + D) <sub>B</sub> → CR                                                                    | 10   | TSB    | m    |
| T5         | 1 $(m + D)_B$<br>$(m + (r2) + D)_B \rightarrow CR$                                           | 10   | TSB    | m,r2 |
| Т6         | 1 → (m + (r2) + D) <sub>B</sub><br>((m) + D) <sub>B</sub> → CB<br>1 → ((m) + D) <sub>B</sub> | 11   | TSB.   | m    |
| <b>T</b> 7 | ((m + (r2)) + D)B - CR<br>1 - ((m + (r2)) + D)B                                              | 11   | TSB.   | m,r2 |

Condition register

CR = 0 if tested bit was 0 CR = 1 if tested bit was 1

bit 0 1 4 5 8 9 10 11 14 15 1 1 0 0 0 0 0 0 0 mode r2 1 **TSBR** 

Test and Test Bit / Register

TSBR

P853 P854 P858 P859

Syntax:

[label] TSBR r2

This instruction tests a bit in a bitstring, sets the condition register to the value of that bit, and sets the bit to 1.

The address of the first character of the string is contained in the register specified by r2.

The bit position in the string must be specified in register A2; in addressing the operand it is used as shown below:



The bit displacement A2 $_{0-15}$  is split up in the character displacement D and the bit number B

The function of the instruction is:

Type Function  
T3 
$$((r2) + D)_B \rightarrow CR$$
  
 $1 \rightarrow ((r2) + D)_B$ 

Condition register:

CR = 0 if the tested bit was 0 CR = 1 if the tested bit was 1

bit 0 1 4 5 8 9 10 11 14 15 1 1 1 0 0 0 0 0 0 0 0 0 1 r2 1

TRB

Test and Reset Bull

TRB

P853 P854 P858 P859

Syntax [label] TRB[1] m[.r2]

This instruction tests a bit in a bitstring, sets the condition register to the value of that bit, and resets the bit to 0

The address of the first character of the bitstring is the instruction operand, found as follows:

| Type | Address    |
|------|------------|
| T4   | m          |
| T5   | m + (r2)   |
| T6   | (m)        |
| T7   | (m + (r2)) |

The bit position in the string must be specified in register A2; in addressing the operand it is used as shown below.



The bit displacement  $A2_{0-15}$  is split up in the character displacement D and the bit number B.

The function of the instruction is:

| Туре | Function                                                                                        | Mode | Syntax |      |
|------|-------------------------------------------------------------------------------------------------|------|--------|------|
| T4   | (m + D) <sub>B</sub> → CR                                                                       | 10   | TAB    | m    |
| T5   | 0 - (m + D)B<br>(m + (r2) + D) B - CR                                                           | 10   | TRB    | m,r2 |
| 16   | $0 \rightarrow (m + (r2) + D)_B$<br>$((m) + D)_B \rightarrow CR$<br>$0 \rightarrow ((m) + D)_B$ | 11   | TRB.   | m    |
| T7   | $((m + (r2)) + D)_B \rightarrow CR$<br>0 $\rightarrow ((m + (r2)) + D)_B$                       | 11   | TRB.   | m,r2 |

Condition register

CR = 0 if tested bit was 0 CR = 1 if tested bit was 1

| bit | 0 | 1 |   |   | 4 | 5 |   |   | 8 | 9 10 | 11 14 | 15 |
|-----|---|---|---|---|---|---|---|---|---|------|-------|----|
|     | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | mode | 12    | 1  |

TRBR

### Test and Reset Bit / Register

TRBR

P853 P854 P858 P859

Syntax.

[label] TRBR r2

This instruction tests a bit in a bitstring, sets the condition register to the value of that bit, and resets the bit to 0.

The address of the first character of the string is contained in the register specified by r2

The bit position in the string must be specified in register A2; in addressing the operand it is used as shown below:



The bit displacement A2<sub>0-15</sub> is split up in the character displacement D and the bit number B.

The function of the instruction is:

Type Function

T3 
$$((r2) + D)_B \rightarrow CR$$
 $0 \rightarrow ((r2) + D)_B$ 

Condition register:

CR = 0 if the tested bit was 0 CR = 1 if the tested bit was 1

TB

Test Bit

TB

P853 P854 P858 P859

Syntax.

[iabel] TB[\*] m[.r2]

This instruction tests a bit in a bitstring, and sets the condition register to the value of that bit

The address of the first character of the bitstring is the instruction operand, found as follows.

| Type       | Addiess    |
|------------|------------|
| T4         | m          |
| T5         | m + (r2)   |
| <b>T</b> 6 | (m)        |
| <b>T</b> 7 | (m + (r2)) |

The bit position in the string must be specified in register A2; in addressing the operand it is used as shown below:



The bit displacement  $A2_{0-15}$  is split in the character displacement D and the bit number  $\theta$ .

The function of the instruction is:

| Type | Function                            | Mode | Synta | tx   |
|------|-------------------------------------|------|-------|------|
| T4   | (m + D) <sub>R</sub> → CR           | 10   | тв    | m    |
| T5   | $(m + (r2) + D)_B \rightarrow CR$   | 10   | TB    | m.r2 |
| T6   | ((m) + D) <sub>B</sub> → CR         | 11   | TB.   | m    |
| T7   | $((m + (r2)) + D)_R \rightarrow CR$ | 11   | TB.   | m.r2 |

Condition register

CR = 0 if tested bit was 0 CR = 1 if tested bit was 1

bit 14 4 5 8 9 10 11 15 1 0 0 0 mode 0 ٥ 0 r2 1 1

TBR

Test Bit / Register

TBR

P853 P854 P858 P859

Syntax

[label] TBR r2

This instruction tests a bit in a bitstring, sets the condition register to the value of that bit.

The address of the first character of the string is contained in the register specified by r2

The bit position in the string must be specified in register A2; in addressing the operand it is used as shown below:



The bit displacement  $A2_{0-15}$  is split up in the character displacement D and the bit number B

The function of the instruction is:

Type Function  
T3 
$$((r2) + D)_R \rightarrow CR$$

Condition register:

CR = 0 If the tested bit was 0 CR = 1 if the tested bit was 1

## Character Handling Instructions

ECR

Exchange characters register/register

ECR

P851M P852M P856M P857M

Syntax:

The left and right-hand characters contained in the register specified by r2 are exchanged and then placed in the register specified by r1. The old contents of the register specified by r2 are not changed.

Type Function  
T1 
$$(r2)_1 \rightarrow r1_r$$
 and  $(r2)_r \rightarrow r1_1$ 

# Condition register:

Unchanged



- " r1 must be ≠ 0.
- \* Restricted to system mode if r1 = A15.

LCK

## Load character with constant

LCK

P851M P852M P856M P857M

Syntax:

[label] LCK ... r1, lk

The left-hand character (bits 0-7) of the constant lk is copied to bits 8-15 (right-hand character) of the register specified by r1, Bits 0-7 of r1 remain unchanged.

Type Function  $lk_1 \rightarrow r1_r$ 

Condition

Unchanged register:

T2



- r1 must be ≠ 0.
- \* Restricted to system mode if r1 = A15.

LCR

## Load character/register

LCR

P851M P852M P856M P857M

Syntax:

The right-hand (odd address) 8-bit contents or the left-hand (even address) 8-bit contents of the effective memory addresses, specified in r2, substitute the least significant 8 bits of the register specified by r1, Bits 0–7 of r1 remain unchanged.

Type Function
$$T3 \qquad ((r2))_{1/r} \rightarrow r1_r$$

## Condition

register:

Unchanged



- \* r1 must be ≠ 0.
- \* Restricted to system mode if r1 = A15.

LC

Load character

LC

P851M P852M P856M P857M

Syntax:

This instruction allows to transfer the right-hand character of the contents of the effective memory address (odd address) or the left-hand character (even address) to bits 8—15 of the register specified by r1.

Bits 0—7 of r1 remain unchanged,

| Type       | Function                |                   | MD | Synta | 3 <i>X</i> |
|------------|-------------------------|-------------------|----|-------|------------|
| <b>T</b> 4 |                         | → rl <sub>e</sub> | 10 | LC    | r1, m      |
| T5         | $(m''' + \{r2\})_{l/r}$ | → r1,             | 10 | LC    | r1, m, r2  |
| T6         | ((m)) <sub>[/r</sub>    | → r1,             | 11 | LC*   | r1, m      |
| T7         | $((m'' + (r2)))_{1/r}$  | → r1,             | 11 | LC.   | r1, m, r2  |

## Condition

register:

Unchanged



- " r1 must be # 0.
- \* Restricted to system mode if r1 = A15.

SCR

## Store character/register

SCR

P851M P852M P856M P857M

Syntax:

The least significant bits of the register specified by r1 replace the right-hand (odd address) or the left-hand (even address) 8 bit contents of the effective memory address indicated by r2.

Type Function  
T3 
$$(r1)_r \rightarrow (r2)_{r/l}$$

## Condition

register:

Unchanged



- r1 must be ≠ 0.
- " Restricted to system mode if r1 = A15.

SC

Store character

SC

P851M P852M P856M P857M

Syntax:

The least significant 8 bits of the register specified by r1, when address is odd, replace the right-hand 8 bits of the contents of the effective memory address or the left-hand 8 bits, when the address is even.

The unaffected half of the address remains unchanged.

| Type | Function                         | MD | Synta | 3 <i>X</i> |
|------|----------------------------------|----|-------|------------|
| T4   | (r1) <sub>r</sub> → m,r/l        | 10 | SC    | r1, m      |
| T5   | (r1) <sub>r</sub> → m + (r2) l/r | 10 | SC    | r1, m, r2  |
| T6   | $(r1)_r + (m) r/1$               | 11 | SC*   | r1, m      |
| T7   | $(r1)_1 - (m + (r2)) 1/r$        | 11 | sc.   | r1, m, r2  |

## Condition

register:

Unchanged



- \* r1 must be # 0.
- \* Restricted to system mode if r1 = A15.

CCK

## Compare character with constant

CCK

P851M P852M P856M P857M

Syntax:

Bits 8–15 (the right-hand character) of the register specified by r1 are compared with bits 0–7 (the left-hand character) of the constant lk. The most significant bit of a character is not a sign bit. The result of the comparison is stored in the condition register.

Type Function  
T2 
$$\{r1\}_r \leftrightarrow |k| \rightarrow CR$$

## Condition

$$\begin{array}{rl} \mathsf{CR} &= 0 \; \text{if} \; \{r1\}_{\Gamma} = \; |k_{\parallel}| \\ & 1 \; \text{if} \; \{r1\}_{\Gamma} > \; |k_{\parallel}| \\ & 2 \; \text{if} \; \{r1\}_{\Gamma} < \; |k_{\parallel}| \end{array}$$



- r1 must be ≠ 0.
- \* Restricted to system mode if r1 = A15.

|    | _ |
|----|---|
| CC | 0 |
| ·  | n |

## Compare character/register

| $\sim$ | ^ | n        |
|--------|---|----------|
| ٠.     | L | <b>m</b> |

P851M P852M P856M P857M

Syntax:

The 8 least significant bits of the register specified by r1 are compared with the right-hand (if odd address) or left-hand (if even address) 8 bits of the contents of the effective memory address indicated in r2. The result of the comparison is stored in the condition register. The most significant bit of a character is considered not to be a sign bit.

Type Function
$$T3 \qquad (r1)_r \leftrightarrow ((r2))_{1/r} \leftrightarrow CR$$

## Condition

register:

CR = 0 if 
$$|r1\rangle_r = (\langle r2\rangle)_{1/r}$$
  
1 if  $|r1\rangle_r > (\langle r2\rangle)_{1/r}$   
2 if  $|r1\rangle_r < (\langle r2\rangle)_{1/r}$ 

| bit | 0 | 1 |   |   | 4 | 5 |    | 8 | 9 | 10 | 11 | 14 | 15 |
|-----|---|---|---|---|---|---|----|---|---|----|----|----|----|
|     | 1 | 1 | 1 | 0 | 1 |   | r1 |   | 0 | 1  | r: | 2  | 1  |
|     |   |   |   |   |   |   |    |   |   |    |    |    |    |

- \* r1 must be # 0.
- Restricted to system mode if r1 = A15.

CC

## Compare characters

CC

P851M P852M P856M P857M

Syntax:

The 8 least significant bits of the register specified by r1 are compared with the right-hand character of the contents of the effective memory address (odd address) or with the left-hand character of the contents of the effective memory address (even address).

The result of the operation is stored in the condition register.

The most significant bit of a character is considered not to be a sign bit.

| Type       | Function                                                   | MD | Syntax        |
|------------|------------------------------------------------------------|----|---------------|
| T4         | $(r1)_r \leftrightarrow (m)_{1/r} \rightarrow CR$          | 10 | CC r1, m      |
| <b>T</b> 5 | $(r1)_r \leftrightarrow (m + (r2))_{1/r} \rightarrow CR$   | 10 | CC r1, m, r2  |
| T6         | $(r1)_r \leftrightarrow ((m))_{1/r} \rightarrow CR$        | 11 | CC* r1, m     |
| T7         | $(r1)_r \leftrightarrow ((m + (r2)))_{1/r} \rightarrow CR$ | 11 | CC* r1, m, r2 |

# Condition register:



- \* r1 must be ≠ 0.
- Restricted to system mode if r1 = A15.

The branch instructions AB, ABL, ABR, ABI, RB and RF branch to an address or the contents of an address or register when a certain condition is fulfilled. If that condition does not arise the program determines the next instruction to be executed.

The condition is given by a number from 1 through 7 or by one or two letters.

The following table gives a survey:

#### Condition Notation

| Cond. reg.  | (cnd)             |                              |                                      |                                       |  |  |  |
|-------------|-------------------|------------------------------|--------------------------------------|---------------------------------------|--|--|--|
| contents    | GENERAL           | ARITHM.                      | COMPARE                              | , 1/0                                 |  |  |  |
| 0<br>1<br>2 | (0)<br>(1)<br>(2) | (Z) Zero · (P) Pos. (N) Neg. | (E) Equal<br>(G) Greater<br>(L) Less | (A) Accepted<br>(R) Refused<br>—      |  |  |  |
| 3           | (3)               | (O) Overfl.<br>NOT – C       |                                      | (U) Unknown                           |  |  |  |
|             |                   | 1001 - 0                     |                                      |                                       |  |  |  |
| ≠0<br>≠1    | (4)<br>(5)        | (NZ) Not Zero (NP) Not Pos.  | (NE) Not Equal (NG) Not Greater      | (NA) Not Accepted<br>(NR) Not Refused |  |  |  |
| <b>≠2</b>   | (6)               | (NN) Not Neg.                | (NL) Not Less                        |                                       |  |  |  |
| n.s.        | (7)               |                              | Unconditional                        |                                       |  |  |  |

#### Note:

The instruction counter P always points to the next instruction to be executed. Wherever in the description the notation (P) + 2 (or 4) appears, the hardware function is meant. When the following program must be assembled calculate the displacement in locations as follows:

where ++4 refers to ABL

4-4 refers to SUK

4-8 refers to LDK

When the same program is to be put in memory with the toggle switches the value for RF(Z) ++4 is 5002 and not 5004 as the P register is already pointing to the next instruction.

The value for RB • -4 must be 5F06 and not 5F04, as the P-register is already pointing to the next instruction.

The address in the ABL instruction must be the relative address pointing to LDK.

The values put in memory for the program listed above must be:

| 207F | START | HLT   |              |
|------|-------|-------|--------------|
| 010A |       | LDK   | A1,/000A     |
| 1902 |       | SUK   | A1,2         |
| 5002 |       | RF(2) | •+4          |
| 5F06 |       | RB    | •_4          |
| 8F20 |       | ABL   | • <i>-</i> 8 |
| 0002 |       |       |              |
|      |       | END   | START        |
|      |       |       |              |

| AB  |  |
|-----|--|
| ABL |  |

### Absolute conditional branch

AB ABL P851M P852M P856M P857M

Syntax:

[label] 
$$\triangle$$
 AB [(cnd)]  $\triangle$  k  $\longrightarrow$  TB [label]  $\triangle$  ABL[(cnd)]  $\bigcirc$  lk  $\longrightarrow$  T2

This instruction means that the next instruction to be executed is found either at the address specified by the constant (k indicating one of the first 256 addresses of the memory, lk being specified in the word following the instruction) or in normal sequence, depending on the (cnd) and the contents of the condition register.

If (cnd) is equal to (7) the next instruction is at the effective mamory address. Note that if (cnd) is omitted, the default value is (7).

The least significant bit in either constant, is always zero (word addressing). See also table and note on page 6.0.1.

Effective branch:

T2 lk → P

No branch: Type Function

T8  $(P) + 2 \rightarrow P$ T2  $(P) + 4 \rightarrow P$ 

Condition

register: Unchanged



ABR

## Absolute conditional branch to register

ABR

P851M P852M P856M P857M

Syntax:

This instruction indicates that the address of next instruction to be executed is found either in the register specified by r2 or at the memory address indicated by the register or in normal sequence depending on (cnd) and the contents of the condition register.

If (cnd) = (7), the next instruction is at the effective memory address

(unconditional branch).

If (cnd) is omitted, the defauti value is (7). See also table and note on page 6.0.1.

Effective branch:

| Type | Function                | MD | i/s  | Syntax     |    |
|------|-------------------------|----|------|------------|----|
| Ti   | ( r2 ) → P              | 00 | n.s. | ABR(cnd)   | г2 |
| Т3   | $((r2)) \rightarrow P$  | 01 | 0    | ABR(cnd) * | r2 |
| Type | Function                | MD | I/s  |            |    |
| T1   | (P) + 2 → P             | 00 | n.s. |            |    |
| T3   | $(P) + 2 \rightarrow P$ | 01 | 0    |            |    |

Condition

No branch:

register: Unchanged



ABI

### Absolute branch indirect

ABI

P851M P852M P856M P857M

Syntax:

The address of the next instruction to be executed is found either at the effective memory address or in the next instruction, depending on (cnd) and the contents of the condition register.

If (cnd) = (7) (see below) the instruction branched to is always at the effective memory address (unconditional branch).

In all other cases the program must first fulfil a condition before the branch takes place. If (cnd) is omitted, the default value is (7).

See also table and note on page 6.0.1.

| Effective |
|-----------|
| branch:   |

| Type | Function     |     | MD | Syntax    |       |
|------|--------------|-----|----|-----------|-------|
| T4   | (m)          | → P | 10 | ABI(cnd)  | m     |
| T5   | (m + (r2))   | → P | 10 | ABI(cnd)  | m, r2 |
| T6   | ((m))        | → P | 11 | ABI(cnd)* | m     |
| T7   | ((m + (r2))) | → P | 11 | ABI(cnd)* | m. r2 |

7 8

10 11

г2

MD

15

0

No branch:

| Type | Function                | MD |
|------|-------------------------|----|
| T4   | (P) + 4 → P             | 10 |
| T5   | $(P) + 4 \rightarrow P$ | 10 |
| T6   | (P) + 4 → P             | 11 |
| T7   | (P) + 4 → P             | 11 |

Condition

register: Unchanged



RF

#### Relative forward conditional branch

RF

P851M P852M P856M P857M

Syntax:

This instruction indicates that the next instruction to be executed is found either at the effective memory address or in normal sequence, depending on (cnd) and the contents of the condition register. If (cnd) = {7} the next instruction can be found at the effective memory address (unconditional relative branch).

If (cnd) is omitted, the default value of (7) is assumed.

The assembler calculates from the effective memory address, a displacement D relative (forwards) to the current value of the instruction counter (P). This value is stored in bits 8-15 of the instruction as a positive number. Thus its maximum is 255. In programming terms, this means that this instruction can only be used to branch by  $\leqslant$  128 words.

See also table and note on page 6.0.1.

Type Function

T8  $(P) + 2 + D \rightarrow P$  (branch effective)

T8  $(P) + 2 \rightarrow P$  (no branch)

Example:

RF(Z) END

RF(3) •+12

Condition register:

Unchanged



RB

Relative backwards conditional branch

RB

P851M P852M P856M P857M

Syntax: [label] RB[(cnd)] m

This instruction means that the next instruction to be executed is found either at the effective memory address or in normal sequence, depending on (cnd) and the contents of the condition register. If (cnd) = (7) the next instruction to be executed is found at the effective memory address. If (cnd) is omitted, the defaut value of (7) is assumed.

The assembler calculates from the effective memory address, a displacement D relative (backwards) to the current value of the instruction counter (P). This value is stored in bits 8–15 of the instruction as a positive number. Thus its maximum is 255. In programming terms, this means that this instruction can only be used to branch backwards by  $\leq$  128 words.

It should be noted that

\_ RB (cnd) \_ "

is equivalent to branch to itself and causes a continuous loop.

See also table and note on page 6.0.1.

Type Function

T8  $[P] + 2 - D \rightarrow P$  (branch effective)

TB  $\{P\}+2 \rightarrow P \text{ (no branch)}$ 

Example:

RB(4) LABEL RB(NE) •-2

Condition register:

Unchanged



ı

| CF | Call function | CF | P851M   |
|----|---------------|----|---------|
|    |               |    | P852M   |
|    |               |    | P856M   |
|    |               |    | 1 P857M |

Syntax: (label)... CF ... r1, lk

This instruction provides a link to a subroutine by storing successively the contents of the P-register and the program status word (PSW) in a memory stack. The PSW contains, amongst other things, the priority level and condition register. The stack pointer is held in the register specified by r1 and is automatically updated. Then a branch is made to the address specified by lk.

The subroutine must be terminated by an RTN instruction to branch back to the main program.

Type Function

T2 (P) 
$$\rightarrow$$
 (r1),(r1) - 2  $\rightarrow$  r1 (PSW)  $\rightarrow$  (r1),(r1) - 2  $\rightarrow$  r1 lk  $\rightarrow$  P

Condition register:

Unchanged. Its contents shows the result of a previous operation and is stored in the memory stack for use on return from the subroutine.



Remark:

An interrupt 'stack overflow' is generated when r1 = A15 and the word address reached by the pointer = </100. Bit 13 is set in PSW.

- \* r1 must be ≠ 0.
- Restricted to system mode if r1 = A15.
- The system stack and user stack are both built towards the lower addresses.

P is stored first and next PSW.

CFR

Call function register

CFR

P851M P852M P856M P857M

Syntax:

This instruction provides a link to a subroutine by storing successively the contents of the P-register, which points to the next instruction of the main program, and the contents of the program status word (PSW) in a memory stack. The PSW contains, amongst other things the priority level and the condition register. The stack pointer held in the register specified by r1 is automatically updated by decreasing the stack pointer by 2, as the stack pointer is filled from the higher address towards the lower address. Next a branch is made to the effective memory address specified by the contents of a register specified by r2.

The subroutine must be terminated by an RTN instruction to branch back to the main program.

| Type | Function                                                     | MD | Syntax |
|------|--------------------------------------------------------------|----|--------|
|      | (P) $+ (r1), (r1) = 2 + r1$<br>(PSW) $+ (r1), (r1) = 2 + r1$ |    |        |

then:

T1 
$$(r2) \cdot P$$
  
T3  $\{(r2)\} \rightarrow P$ 

00 CFR r1, r2 01 CFR r1, r2

Condition register:

Unchanged. Its contents shows the result of a previous operation and is stored in the memory stack for use on return from the subroutine.



- An interrupt 'stack overflow' is generated when r1 A15 and the word address reached by the pointer - < /100. Bit 13 in the PSW is set to 1.</li>
- \* r1 must be ≠ 0.
- Restricted to system mode if r1 = A15.

CFI

#### Call function indirect

CFI

11

CFI\* r1, m, r2

P851M P852M P856M P857M

Syntax:

The instruction provides a link to a subroutine by storing successively the contents of the P-register, which points to the next instruction of the main program, and the contents of the program status word (PSW) in a memory stack. The PSW contains, amongst other things, the priority level and condition register. The stack pointer held in the register specified by r1 is automatically updated by decreasing the stack pointer by 2, as the stack pointer is filled from the higher address towards the lower address. Next a branch is made to the contents of the effective memory address, i.e. the subroutine which has to be executed.

The subroutine must be terminated by an RTN instruction to branch back to the main program.

| Type     | Function                                                                                               | MD       | Syntax                     |
|----------|--------------------------------------------------------------------------------------------------------|----------|----------------------------|
| •        | $(P) \rightarrow (r1)$ $(r1) = 2 \rightarrow r1$<br>$(PSW) \rightarrow (r1)$ $(r1) = 2 \rightarrow r1$ |          |                            |
| then:    |                                                                                                        |          |                            |
| T4<br>T5 | ( m )                                                                                                  | 10<br>10 | CFI r1, m<br>CFI r1, m, r2 |
| T6       | ((m)) → P                                                                                              | 11       | CFI* r1, m                 |

Condition register:

Unchanged. Its contents shows the result of a previous operation and is stored in the memory stack for use on return from subprogram,



#### Remark:

**T**7

- An interrupt 'stack overflow' is generated when r1 = A15 and the word address reached by the pointer = </100. Bit 13 of the PSW is set to 1.
- r1 must be ≠ 0.

 $\{(m + (r2))\} \rightarrow P$ 

\* Restricted to system mode if r1 = A15.

RTN

Return from function (A1...A14)

RTN

P851M P852M P856M P857M

Syntax:

This instruction allows the return from a subroutine to the main program. It must be the last instruction of such a routine. The instruction reloads the P-register and CR-register which have previously been loaded into a memory stack by a Call Function instruction.

Type Function

T3 
$$(r2) + 2 \rightarrow r2$$
 $((r2))_{0-8} \rightarrow PLR$ 
 $((r2))_{4-7} \rightarrow CR$ 
 $(r2) + 2 \rightarrow r2$ 
 $((r2)) \rightarrow P$ 

## Condition register:

Reloaded from stack, bits 6 and 7 of the PSW + CR.

| bit | 0 | 1 |   |   | 4 | 5 |   |   | 8 | 9 | 10 | 11 | 14 | 15 |
|-----|---|---|---|---|---|---|---|---|---|---|----|----|----|----|
|     | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1  | r2 |    | 0  |
|     |   |   |   |   |   |   |   |   |   |   |    |    |    |    |

Remark:

r2 must be  $\neq$  0.

RTN

Return from function (A15)

RTN

P851M P852M P856M P857M

Syntax:

[label]\_\_ RTN \_\_ A15

This instruction allows the return from an interrupt routine, a trap routine or subroutine. It must therefore be the last instruction of that routine. The instruction reloads the PSW and P-register which have previously been loaded into a memory stack by a Call Function instruction. The stack-pointer A15 is automatically updated.

On the P852M bit 9 of the PSW (ENB) is always set to 1. On the other computers bit 9 must be set, if required.

Note: By forcing bit 15 of the PSW to 1, the user may switch the machine from system mode to user mode (P851M, P856M and P857M).

| Type | Function (P852M)      |        | Function (other, | l     |
|------|-----------------------|--------|------------------|-------|
| T3   | (A15) + 2             | - A15  | (A 15) + 2       | → A15 |
|      | ((A15)) 0-5           | -• PLR | ((A15)) 0-5      | → PLR |
|      | ((A15)) 6,7           | → CR   | ((A15)) 6,7      | → CR  |
|      | bit 9 is set to 1     | → ENB  | ((A15)) 9        | - ENB |
|      | SU bit does not exist |        | ((A15)) 15       | -∙ SU |
|      | (A 15) + 2            | - A15  | (A15) + 2        | → A15 |
|      | ((A15))               | -• P   | ((A 15))         | → P   |

| bit | 0 | 1 |   |   | 4 | 5 |   |   | 8 | 9 | 10 | 11 |   |   | 14 | 15 |
|-----|---|---|---|---|---|---|---|---|---|---|----|----|---|---|----|----|
|     | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1  | 1  | 1 | 1 | 1  | 0  |
|     |   |   |   |   |   |   |   |   |   |   |    |    |   |   |    |    |

Remark: r2 must be # 0.

EXR

### Execute register

EXR

P851M P852M P856M P857M

Syntax:

[label] \_ EXR[+] \_ r2

This instruction executes the instruction in r2 (T1) or pointed to by the contents of r2 (T3). r2 may not contain a double word instruction, a CF instruction, RTN instruction or another EXR, EX or EXK instruction.

| Type | Function           | MD | Syntax |    |
|------|--------------------|----|--------|----|
| T1   | (r2) is executed   | 00 | EXR    | r2 |
| T3   | ((r2)) is executed | 01 | EXR*   | r2 |

Condition register:

CR is set by the instruction in {r2}.



EXK

### Execute constant

EXK

P851M P852M P856M P857M

Syntax:

[label] \_ EXK \_ lk

This instruction performs the operand instruction contained in lk. The memory address may not contain a double word instruction, a CF instruction, RTN instruction or another EXK, EX or EXR instruction.

Type Function

T2 lk is executed

Condition

register: CR is set by the instruction in lk.

bit 0 1 4 5 8 9 10 11 14 15 1 1 1 1 1 0 0 0 0 0 0 1 0 0 0 0 1

| EX | Execute | EX | P851M<br>P852M |
|----|---------|----|----------------|
|    |         |    | P856M          |
|    |         |    | P8571          |

Syntax: [label] \_ EX[+] \_ m[, r2]

This instruction executes the operand instruction contained in the effective memory address. The memory address may not contain a double word instruction, a CF instruction, RTN instruction or another EX, EXK, or EXR instruction.

| Type | Function     | MD          | Syntax |     |       |
|------|--------------|-------------|--------|-----|-------|
| T4   | (m)          | is executed | 10     | EX  | m     |
| T5   | (m + (r2))   | "           | 10     | EX  | m, r2 |
| T6   | ((m))        | "           | 11     | EX* | m     |
| T7   | ((m + (r2))) | "           | 11     | EX* | m, r2 |

# Condition register:

CR is set by the instruction in the effective memory address.



SLA

Single left arithmetic shift

SLA

P851M P852M P856M P857M

Syntax:

[label] \_ SLA \_, r3, n

The bits of the register specified by r3 are shifted left n bit positions. Overflow occurs when the sign bit was modified during the operation. Vacant bits are filled with zeroes.



# Condition register:



Remark: r3 ≠ 0.

SRA

Single right arithmetic shift

SRA

P851M P852M P856M P857M

Syntax:

[label] SRA \_ r3, n

The contents of the register specified by r3 are shifted right n bit positions. The sign bit is not changed. It is shifted into the vacant position(s) of the register. The vacant bit positions are filled with the same values as the sign bit, i.e. either 0 or 1.

If n > 15, all bits of the register will be the same as the sign bit.



# Condition register:



Remark: r3 ≠ 0.

SLL

Single left logical shift

SLL

P851M P852M P856M P857M

Syntax:

[label] \_ SLL \_ r3, n

The bits of the register specified by r3 are shifted left n bit positions. Vacant bits become zero. After 16 or more shifts the whole register contains zero.



Condition

register:



Remark:  $r3 \neq 0$ .

SRL

Single right logical shift

SRL

P851M P852M P856M P857M

Syntax:

[label] \_ SRL \_ r3, n

The contents of the register specified by r3 are shifted right n bit positions. Vacant bits become zero. After 16 or more shifts the register contains zero.



### Condition

register:



Remark:

r3 ≠ 0.

SLC

### Single left circular shift

SLC

P851M P852M P856M P857M

Syntax:

The contents of the register specified by r3 are shifted left, end around, n bit positions.



# Condition register:



Remark:

r3 ≠ 0.

SRC

Single right circular shift

SRC

P851M P852M P856M P857M

Syntax:

[label] \_\_ SRC \_\_ r3, n

The contents of the register specified by r3 are shifted right, end around, n bit positions.



Condition register:



Remark: r3 ≠ 0. SLN

Single left and normalize shift

SLN

P851M P852M P856M P857M

Syntax:

[label] \_ SLN . , r3, r2

The contents of the register specified by r3 are shifted left until the two most significant bits differ. The sign bit remains unaffected; zero bits are inserted in the least significant positions. The number of shifted positions is placed in the register specified by r2.



### Condition

register:

Unchanged



- "  $r3 \neq 0$ .
- " If (r3) = 0 the number of shifted positions will be 16.
- \* Restricted to system mode if r2 = A15.

SRN

Single right and normalize shift

SRN

P851M P852M P856M P857M

Syntax:

[label] \_ SRN \_ r3, r2

The contents of the register specified by r3 are shifted right until a 1-bit appears in bit 15 of that register.

The sign bit is not changed and is copied each time a shift is given. The number of times a shift had to be performed is placed in the register specified in r2.



## Condition

register:

Unchanged



- \* r3 ≠ 0.
- If (r3) = 0 the number of shifted positions will be 16.
- Restricted to system mode if r2 = A15.

DLA

Double left arithmetic shift

DLA

P851M P852M P856M P857M

(Softw. sim.)

Syntax:

[label] \_ DLA \_ n

This instruction treats the A1 and A2 register as one 31-bit register (bit 0 of A2 is set to zero). The contents are shifted left n positions and zeroes are placed from the right in vacated positions.

Overflow occurs when the sign bit is changed during execution of this instruction.



Condition register:

3 in case of overflow

DRA

Double right arithmetic shift

DRA

P851M P852M P856M P857M

(Softw. sim.)

Syntax:

[label] \_ DRA \_ n

This instruction treats the A1 and A2 registers as one 31-bit register. The contents are shifted right n positions and zeroes or ones are propagated into vacated positions depending on the value of the sign bit of A1.

After 30 or more shifts the two registers are filled the value of the sign bit (all zeroes or ones), except for the sign bit of A2 which is always set to 0.



Condition register:



DLL

Double left logical shift

DLL

P851M | (Softw. sim.) P856M | P857M |

Syntax:

[label]\_ DLL\_ n

This instruction treats the registers A1 and A2 as one 32-bit register. The contents are shifted left n positions. Zeroes are propagated into vacated positions of A1 and A2.



Condition register:



DRL

Double right logical shift

DRL

P851M P852M P856M P857M

(Softw. sim.)

Syntax:

[label] \_ DRL \_ n

The A1 and A2 registers are treated as one 32-bit register. The contents are shifted right n positions. Zeroes are propagated into vacated positions. The max. number of shifts is 31.



Condition

register:



DLC

Double left circular shift

DLC

P851M P852M P856M

P857M

(Softw. sim.)

Syntax:

[label] \_ DLC \_ n

The A1 and A2 registers are treated as one 32-bit register. The contents are shifted left, end around, n positions.



Condition register:



DRC

Double right circular shift

DRC

P851M P852M P856M P857M

(Softw. sim.)

Syntax:

[label] \_ DRC \_ n

The A1 and A2 registers are treated as one 32-bit register. The contents are shifted right, end around, n positions.



Condition

register:

DLN

Double left and normalize shift

DLN

P851M P852M P856M P857M

(Softw. sim.)

Syntax:

[label]\_ DLN .\_ r2

The A1 and A2 registers are treated as one 31-bit register. Its contents are shifted left until bit zero and bit one have a different value. Zeroes are shifted, from the right hand side on, into vacated positions of the register. The sign bit of register A1 remains unchanged. The number of shifted positions is stored in register r2. The sign bit of A2 becomes zero.



Condition register:

Unchanged



Remark:

Restricted to system mode if r2 = A15.

DRN

Double right and normalize shift

DRN

P851M P852M P856M P857M

(Softw. sim.)

Syntax:

[label] ... DRN ... r2

The A1 and A2 registers are treated as one 31-bit register. The contents are shifted right until a 1-bit appears in the least significant position of the register. The sign bit is shifted to the right each time a shift takes place. The number of shifted postions is stored in register r2. The sign bit of A2 becomes zero.



Condition register:

Unchanged



Remark:

Restricted to system mode if r1 = A15.

MVF

Move Table Forward

MVF

P857M

Syntax:

[label] \_ MVF \_ r2

This instruction copies a string of consecutive words from one memory area into another area, beginning with the last location from the buffer to be copied towards the start address of that buffer. Should the buffer to be copied and the receiving buffer overlap, the user must take care not to overwrite the contents of the locations in the buffer to be copied. Use in that case the instruction MVB.

- register A1 must be loaded with the start address of the memory area to be copied.
- register A2 must be loaded with the start address of the receiving buffer
- register r2 must contain the number of characters to be copied (the number must be even and unsigned).

The execution of this instruction may be interrupted after any word transfer. When the interrupt is accepted the contents of the instruction counter, which is pointing to this instruction, are saved in the stack. The contents of A1 and A2 remain unchanged.

Register (2 contains the remaining number of characters to be transferred. The execution of this instruction is resumed when the interrupt has been serviced. When the execution is terminated A1 and A2 contain the initial values.

Type Function  
T8 
$$(r2) - 2 + r2$$
,  $((A1) + (r2)) \rightarrow (A2) + (r2)$   
-  
0  $\rightarrow r2$ ,  $((A1)) \rightarrow (A2)$ 

Condition register:

Unchanged

| bit |   |   |   |   |   |   |   |   |   |   | 10 |    | 14 |   |
|-----|---|---|---|---|---|---|---|---|---|---|----|----|----|---|
|     | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0  | r2 |    | 0 |
|     |   |   |   |   |   |   |   |   |   |   |    |    |    |   |

- When used in system mode r2 A15 or ≠ A15.
- When used in user made r2 / A15.
- r2 must be ≠ 0.

Syntax: [label] \_ MVB \_ r2

This instruction copies a string of consecutive words from one memory area into another area, beginning with the first location of the buffer to be copied towards the last location of that buffer. Should the buffer to be copied and the receiving buffer overlap, the user must take care not to overwrite the contents of locations in the buffer to be copied. Use in that case the instruction MVF.

- register A1 must contain the start address of the huffer to be copied.
- register A2 must contain the start address of the receiving buffer.
- register r2 must contain the number of characters to be copied. (The number must be even and unsigned.)

The execution of this instruction may be interrupted after any word transfer. When the interrupt is accepted the contents of the instruction counter, which points to this instruction, are saved in the stack. The contents of registers A1 and A2 point to the first location to be transferred when resuming the execution. Register r2 contains the remaining number of characters to be transferred.

The execution of the instruction is resumed when the instruction interrupt has been serviced. When the execution is terminated A1 and A2 point to the first address after the buffer.

Type Function

T8 
$$\{(A1)\}$$
  $\rightarrow \{A2\}$   $\{(r2)\}-2$   $\rightarrow r2$ ;  $\{A1\}+2$   $\rightarrow A1$ ;  $\{A2\}+2$   $\rightarrow A2$ ;  $\{(A1)\}$   $\rightarrow \{A2\}$ 

## Condition register:

Unchanged

| bit | 0 | 1 |   |   | 4 | 5 |   | 7 | 8 | 9 | 10 | 11 |    | 14 | 15 |
|-----|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|
|     | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0  |    | (2 |    | 0  |
|     |   |   |   |   |   |   |   |   |   |   |    | -  |    |    |    |

- When used in system mode r2 A15 or ≠ A15.
- \* When used in user mode r2 ≠ A15.
- 12 must be ≠ 0.

**MVUS** 

# Move Table from User to System area (MMU option)

MVUS

P857M

Syntax: [label] \_ MVU\$ \_ r2

This instruction is used to copy a table of consecutive words from a user area (sending buffer) to a system area (receiving buffer), beginning with the first location towards its last location.

- register A1 must contain the logical start address (MMU) of the buffer to be copied.
- register A2 must contain the physical start address (NO MMU) of the receiving buffer.
- register r2 must be loaded with the number of characters to be copied.
   This number must be even and not signed.

The execution of this instruction may be interrupted after any word transfer. When the interrupt is accepted the contents of the instruction counter, which points to this instruction, are saved in the stack. The contents of A1 and A2 point to the first location to be transferred when the execution is resumed.

Register r2 contains the remaining number of characters to be transferred. The execution of this instruction is resumed when the interrupt is serviced. When the execution is terminated A1 and A2 point to the first address after the receiving buffer.

Type Function

T8 
$$((A1)) \rightarrow (A2)$$
 $(r2) - 2 \rightarrow r2; (A1) + 2 \rightarrow A1; (A2) + 2 \rightarrow A2; ((A1)) \rightarrow (A2)$ 
 $0 \rightarrow r2; (A1) + 2 \rightarrow A1; (A2) + 2 \rightarrow A2$ 

## Condition register:

Unchanged

| bit | 0 | 1 |   | _ | 4 | 5 |   | 7 | 8 | 9 | 10 | 11 |    | 14 | 15 |
|-----|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|
|     | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0  |    | r2 |    | 0  |
|     |   |   |   |   |   |   |   |   |   |   |    |    |    |    |    |

- When used in system mode r2 = A15 or ≠ A15.
- When used in user mode r2 f A15. In that case or if MMU is not available
  this instruction is the same as the MVB instruction.
- r2 must be ≠ 0.

MVSU

# Move Table from System to User area (MMU option)

MVSU

P857M

Syntax:

This instruction is used to copy a table of consecutive words from a system area (sending buffer) to a user area (receiving buffer), beginning with the last location of the sending area towards the first location.

- register A1 must contain the physical start address (NO MMU) of the sending buffer.
- register A2 must contain the logical start address (MMU) of the receiving buffer.
- register r2 must be loaded with the number of characters to be copied (this number must be even and unsigned).

The execution of this instruction may be interrupted after any word transfer. When the interrupt is accepted the contents of the instruction counter, which points to this instruction, are saved in the stack. The contents of registers A1 and A2 remain unchanged.

Register r2 contains the remaining number of characters to be transferred. The execution of the instruction is resumed when the interrupt is serviced. When the execution is terminated A1 and A2 contain their initial values.

Type Function

T8 
$$(r2) - 2 \rightarrow r2$$
,  $((A1) + (r2)) \rightarrow (A2) + (r2)$ 

-
-
0 \rightarrow r2 ,  $((A1)) \rightarrow (A2)$ 

# Condition register:

Unchanged



- When used in system mode r2 = A15 or ≠ A15.
- When used in user mode r2 ≠ A15. In that case or if MMU is not available this instruction is the same as the MVF instruction.
- \* r2 must be ≠ 0.

WER

Write external register

WER

P851M P852M P856M P857M

Syntax:

(label) \_ WER \_ r3, address

The contents of the register specified by r3 are transferred to the external register whose address is specified in bits 8–15. The contents of the register specified by r3 and the condition register remain unchanged.

Two WER instructions must be used to send two control words, one containing a buffer address and the second one containing the number of words or characters to be transferred, to two registers on the I/O Processor.

1st control word



where:

bit 0 = 0 if char, mode

1 if word mode

bit 1 = 0 if transfer is CU → MEM 1 if transfer is MEM → CU

bits 2, 3 are used to extend the memory address in 2nd control word to > 32K.

bits 4 through 15 - transfer length in words or characters.

2nd control word



where:

bits 0 through 14 = memory address

bit 15 (if char, mode) = 0 left hand character 1 right hand character

The layout of bits 8 through 15 of the WER instruction is:

| 0 | pro | address | sub | 0/1 |    |
|---|-----|---------|-----|-----|----|
| 8 | 9   | 11      | 12  | 14  | 15 |

bit 8 = 0

bits 9 through 11 must be set to zero for the P851M (only one processor connection.

On P852M, P856M or P857M it may be a number from 0 through 7.

bits 12 through 14 device address

bit 15 = 0 WER instruction for the 1st control word

1 WER instruction for the 2nd control word

Note: When a device must be addressed via a multiple control unit card, specify the lowest address.

Example:

Output on cassette

LDK A1,/0084 Send 132 characters.

LDKL A2, BUFFER Take the contents of 'BUFFER'.

WER A1,/A The cassette has address /05 and is connected to

I/O Processor numero 0. Bit 15 = 0 (1st control

word).

WER A2,/B Send the 2nd control word. Bit 15 = 1.

Type Function

T8 (r3) → extern reg.

## Condition

register: Unchanged



- r3 must be ≠ 0.
- This instruction may only be used in system mode.

### Read external register

RER

P851M P852M P856M P857M

Syntax:

[label] \_ RER \_ r3, address

The contents of the external register, specified by its address, are transferred to the register specified by r3. The contents of the external register remain unchanged, Bits 6 and 7 of the external register are copied to the condition register.

Through this instruction the user can check how many characters or words have been transferred.

Type Function

T8 (extern reg) • r3

## Condition register:

(extern reg 6,7) · CR



- " r3 must be ≠ 0.
- \* This instruction may only be used in system mode.

TLR

# Segment Table Load/register (MMU option)

TLR

P857M

Syntax:

This instruction loads 16 consecutive registers, TR0 through TR15, which are located on the MMU, with the contents of 16 consecutive memory locations, the first one being indicated in register r2.

## Condition register:

Unchanged



### Remark:

TL

# Segment Table Load (MMU option)

TL

P857M

Syntax:

This instruction loads 16 consecutive registers, TR0 through TR15, which are located on the MMU, with the contents of 16 consecutive memory locations.

The address of the first memory location is indicated by the effective memory address.

| Турв       | Function                           |            | Synta | ) X   |
|------------|------------------------------------|------------|-------|-------|
| T4         | (m)(m + 15x2)                      | → TROTR15  | TL    | m     |
| <b>T</b> 5 | ( m + (r2)) , , ( m + (r2) + 15x2) | → TR0 TR15 | TL    | m, r2 |
| T6         | ((m)) ((m) ÷ 15x2)                 | → TROTR15  | TL4   | m     |
| T7         | ((m+(r2)))((m+(r2))+15x2)          | → TROTR15  | TL*   | m, r2 |

# Condition register:

### Unchanged



#### Remark:

TSR

# Segment Table Store/register (MMU option)

TSR

P857M

Syntax:

This instruction places the contents of 16 consecutive registers, TR0 through TR15, located on the MMU, in 16 consecutive memory locations. The first memory location is indicated by the contents of register r2.

### Condition

register:

Unchanged



#### Remark:

TS

### Segment Table Store

TS

P857M

Syntax:

The contents of 16 consecutive registers, TR0 through TR15, located on the MMU, replace the contents of 16 memory locations. The first memory location is indicated by the effective memory address.

| Type       | Function | •                               | Syntax | ۲     |
|------------|----------|---------------------------------|--------|-------|
| T4         | (TRO)    | → m                             |        |       |
|            | (TR1)    | - m + 2                         |        |       |
|            | -        |                                 |        |       |
|            | (TR15)   | → m + 15x2                      | T\$    | m     |
| <b>T</b> 5 | (TRO)    | • m + (r2)                      |        |       |
|            | (TR1)    | → m + (r2) + 2                  |        |       |
|            | -        |                                 |        |       |
|            | (TR15)   | -+ m + (r2) + 15x2              | TS     | m, r2 |
| T6         | (TRO)    | (m)                             |        |       |
|            | (TR1)    | +(m + 2)                        |        |       |
|            | _        |                                 |        |       |
|            | (TR15)   | (m + 15x2)                      | TS*    | m     |
| <b>T</b> 7 | (TRO)    | (m + (r2))                      |        |       |
|            | (TR1)    | +(m + (r2) + 2)                 |        |       |
|            | ~        |                                 |        |       |
|            | (TR15)   | $\rightarrow$ (m + (r2) + 15x2) | TS*    | m, r2 |

# Condition register:

Unchanged



#### Remark:

FLDR

# Floating Point Load/register (F.F.P. option)

FLDR

P857M

Syntax:

[label] ... FLDR ... r2

The contents of three consecutive memory locations are loaded into three accumulators FPA1, FPA2, FPA3 on the Floating Point Processor.

The first memory location is indicated in the register r2.

Type Function

T3 ((r2)) → FPA1 ((r2) + 2) → FPA2 ((r2) + 4) → FPA3

Condition register:

CR = 0 if floating point operand = 0 1 if floating point operand > 0 2 if floating point operand < 0

FLD

### Floating Point Load (F.F.P. option)

FLD

P857M

Syntax: [label] \_ FLD[+] \_ m[, r2]

The contents of three consecutive memory locations are loaded into three accumulators FPA1, FPA2 and FPA3 on the Floating Point Processor. The first memory location is indicated by the effective memory address.

| Type | Function                           |                  | MD    | Syntax     |
|------|------------------------------------|------------------|-------|------------|
| T4   | ( m )                              | - FPA1           | 10    | FLD m      |
|      | (m + 2)<br>(m + 4)                 | → FPA2<br>→ FPA3 |       |            |
| T5   | (m + (r2))                         | → FPA1           | 10    | FLD m, r2  |
|      | ( m + (r2) + 2)<br>( m + (r2) + 4) | → FPA2<br>→ FPA3 |       |            |
| T6   | ((m))                              | → FPA1           | 11    | FLD* m     |
|      | ((m) + 2)                          | → FPA2           |       |            |
| Т7   | ((m) + 4)<br>((m + (r2)))          | → FPA3<br>→ FPA1 | 11    | FLD* m, r2 |
|      | ((m + (r2)) + 2)                   | → FPA2           | • • • | ,          |
|      | ((m + (t2)) + 4)                   | → FPA3           |       |            |

## Condition

register:

- CR = 0 if floating point operand = 0
  - 1 if floating point operand > 0
  - 2 if floating point operand < 0
  - 3 unnormalized operand (operation aborted)



**FSTR** 

# Floating Point Store/register (F.F.P. option)

FSTR

P857M

Syntax:

The contents of three accumulators FPA1, FPA2 and FPA3 on the Floating Point Processor replace the contents of three consecutive memory locations. The first location is indicated in register r2.

Type Function

T3 (FPA1) → (r2) (FPA2) → (r2) + 2 (FPA3) → (r2) + 4

Condition register:

Unchanged



FST

# Floating Point Store (F.F.P. option)

FST

P857M

Syntax: [label] FST(+] m[, r2]

The contents of three accumulators FPA1, FPA2 and FPA3 on the floating point processor replace the contents of three consecutive memory locations. The first location is indicated by the effective memory address.

| Type | Function | 1                            | MD | Syntax | ۲     |
|------|----------|------------------------------|----|--------|-------|
| T4   | (FPA1)   | -• m                         | 10 | FST    | m     |
|      | (FPA2)   | → m + 2                      |    |        |       |
|      | (FPA3)   | > m + 4                      |    |        |       |
| T5   | (FPA1)   | -+ m + (r2)                  | 10 | FST    | m, r2 |
|      | (FPA2)   | $\rightarrow$ m + (r2) + 2   |    |        |       |
|      | (FPA3)   | + m + (r2) + 4               |    |        |       |
| T6   | (FPA1)   | → (m)                        | 11 | FST*   | m     |
|      | (FPA2)   | →(m) + 2                     |    |        |       |
|      | (FPA3)   | →(m) + 4                     |    |        |       |
| T7   | (FPA1)   | →(m + (r2))                  | 11 | FST*   | m, r2 |
|      | (FPA2)   | -+(m + (r2) + 2)             |    |        | •     |
|      | (FPA3)   | $\rightarrow$ (m + (r2) + 4) |    |        |       |

### Condition

register:

Unchanged



**Control Instructions** 



Syntax:

[label]교 HLT

This instruction sets the machine to halt mode. No further instructions or interrupts will be serviced until the RUN button is pressed.

*Type* TB

Condition register:

Unchanged



Remark:

This instruction may only be used in system mode.

INH

Inhibit interrupt

INH

P851M P852M P856M P857M

Syntax:

[label] \_ INH

This instruction resets the permit interrupt to prohibit all interrupts

(including Power Failure/Automatic Restart).

INH is automatically set by any hardware interrupt.

Type

T8

# Condition

register:

Unchanged

bit 0 1 5 8 9 10 15 0 0 1 0 0 0 0 1 ō 1 1 1 1 1 1

# Remark:

This instruction may only be used in system mode,

**ENB** 

# Enable interrupt

ENB

P851M P852M P856M P857M

Syntax:

[label] → ENB

This instruction sets the machine to permit interrupt.

Note: Though the instruction is accepted in user mode it is only useful

when working in system mode as in user mode all interrupts are

enabled.

Турв

T8

Condition

register: Unchanged

bit D 1 4 5 7 8 15

0 0 1 0 1 0 0 0 0 1 0 0 0 0 0

LKM

#### Link to monitor

LKM

P851M P852M P856M P857M

Syntax:

[label] LKM

This instruction sets a program interrupt flip-flop, which sets the CPU from user mode to system mode.

If the Interrupts are inhibited then the next instruction is executed. If the interrupts are enabled then a branch is made to the address in the interrupt table, provided by the user, corresponding with LKM.

*Type* T8

Condition

register: Unchanged

bit 0 1 4 5 7 8 15
0 0 1 0 1 0 0 0 0 0 0 0 0 1 0 0

RIT

## Reset internal interrupt

RIT

P851M P852M P856M P857M

Syntax:

k ب RIT الـ [label]

This command is used to clear one of the internal interrupt bits which is

indicated by a zero-bit in the k field (other bits being one).

k is a 5-bit hexadecimal constant. This instruction may only be used in system mode.

Internal Interrupts

Hexa value k

are:

bit number 10 = control panel /0F
11 = power failure/automatic restart /17
12 = real time clock /18
13 = program error /1D

*Type* T8

Condition register:

Unchanged



# Remark:

This instruction may only be used in system mode.

SMD

Set mode

SMD

P856M P857M

Syntax:

[label]\_SMD

This instruction switches the machine from system mode to user mode to allow a user program to run.

On the P852 there is only the system mode.

Note: 1, See also the note under RTN A15.

On the P856M and P857M the switch from system mode to user mode can also be made with a RTN A15 instruction.

*Туре* Т8

Condition

register: Unchanged

bit 0 1 4 5 7 8 9 10 15
0 0 1 0 1 0 0 0 0 0 0 0 0 1

CIO

Control Input/Output

CIO

P851M P852M P856M P857M

Syntax:

[label] 
$$\subseteq$$
 CIO  $\subseteq$  r3,  $\begin{Bmatrix} 0 \\ 1 \end{Bmatrix}$ , dev

This instruction permits to start or to stop an I/O operation on a peripheral device, depending whether bit 9 is set (start) or reset (stop),

During the execution of this instruction the contents of bit 10-15 are sent, via the bus, to the control unit addressed, together with the contents of the register r3, which contains additional information for the control unit. A survey of the information which may be given in r3 for each control unit is given on the following pages.

A start an I/O operation command is not accepted if the address specified is unknown or if the corresponding device is busy. The stop a data transfer command is always accepted.

# Example:

Start an input operation: LDK A1.1

CIO A1,1,/10 start input on teletype RB(NA) ·-2 wait until accepted

LDK A1.0 Start an output operation:

CIO A1.1/10start output on teletype wait until accepted

RB(NA) \*-2

Stop the I/O operation: CIO A1.0./10

Type Syntax

T8 CIO r3, 1, address start input or output

T8 CIO r3, 0, address stop I/O

Condition register:

CR = 0 command accepted 1 command not accepted 3 address unknown 7 bit o 5 10 1/ 12 15 0 0 г3 0 Remark:

r3 must be ≠ 0.

This instruction may only be used in system made.

Information which must be given in r3 and in the CIO instruction, if required:

**ASR** 

bit 15 = 1 input 0 output

PUNCHED TAPE READER.

r3 not significant

TAPE PUNCH

r3 not significant

SERIAL CU

CIO READ

bit 10 = 1 echo mode 0 no echo mode

bit 13 14

1 1 7 data bits + parity bit (odd)
1 0 7 data bits + parity bit (even)
0 1 7 data bits, no parity

0 0 8 data bits

bit 15 = 1

CIO WRITE

bit 13 14 see CIO READ

bit 15 = 0

CARD READER

r3 not significant

LINE PRINTER

r3 not significant

CASSETTE

In CIO instruction must be specified:

bit 10,11 drive no bits 12 thru 15 address

| in r | -              |        |       |              |                                       |
|------|----------------|--------|-------|--------------|---------------------------------------|
| bit  |                | 13     | 14    | 15           |                                       |
|      | 0              | 0      | 0     | 0<br>1       | unlock<br>erase                       |
|      | Ö              | 0      | 1     | ò            | backspace                             |
|      | ō              | 1      | Ó     | 1            | write a block forward                 |
|      | 0              | 1      | 1     | 1            | read a block forward                  |
|      | 1              | 0      | 0     | 0<br>1       | rewind<br>write tape mark             |
|      | i              | ŏ      | 1     | Ö            | search tape mark backward             |
|      | 1              | 0      | 1     | 1            | search tape mark forward              |
| DK   | 1215           |        |       |              |                                       |
|      |                |        | tion  | must be      | e specified:                          |
|      | 10,11          |        |       | disk n       | _                                     |
| DIL  | 12 th          | ru 15  |       | addre        | 55                                    |
| In r |                |        |       |              |                                       |
|      | SEE            |        |       |              | les no Octions                        |
|      | 4 thr          |        |       | cyline       | ler ⊓o, 0 <n<203< td=""></n<203<>     |
|      | 14  •<br>15  = |        |       |              |                                       |
| CIC  | SEE            | K TO   | ZEI   | 30           |                                       |
| bit  | 14- =          | - 1    |       |              |                                       |
| bit  | 15 =           | = 1    |       |              |                                       |
| CIC  | WR             | ITE A  | SEC   | ROTS         |                                       |
| bit! | 9 thr          | ս 13   |       | sector       | address from 0 to 31                  |
| bit  | 14 =           | - 0    |       |              |                                       |
| bit  | 15 =           | - 1    |       |              |                                       |
| CIC  | RE/            | AD A   | SEC   | TOR          |                                       |
| bit  | 9 thr          | u 13   |       | secto        | address from 0 to 31                  |
| bit  | 14 =           | = O    |       |              |                                       |
| bit  | 15 =           | = 0    |       |              |                                       |
| PR   | OG R.          | АММ    | . REA | AL TIM       | E CLOCK                               |
| r3 s | pecif          | ies th | e int | errupt r     | ate selection                         |
| bit  | 0 :            | • 0    |       |              |                                       |
|      |                |        |       | 15 =         |                                       |
|      |                |        |       | 14 =<br>13 - | 1 5 milliseconds<br>1 10 milliseconds |
|      |                |        | bit   |              | 1 20 milliseconds                     |

bit 0 = 1 bit 1 thru 15 the number of milliseconds

#### MAGNETIC TAPE

| bit | 10 | 11 | 12 | 13 | 14 | 15 |                                |
|-----|----|----|----|----|----|----|--------------------------------|
|     | 0  | 0  | 0  | 0  | 1  | 1  | write                          |
|     | 0  | 1  | 0  | 0  | 0  | 1  | write file mark                |
|     | 0  | 1  | 1  | 0  | 0  | 1  | erase gap                      |
|     | 0  | 0  | 1  | 0  | 1  | 0  | read one block                 |
|     | 0  | 0  | 0  | 0  | 1  | 0  | read with check characters     |
|     | 0  | 0  | x  | 0  | 0  | 0  | forward space block            |
|     | 0  | 0  | ×  | 1  | Q  | 0  | backward space block           |
|     | 0  | 1  | ×  | Q  | 0  | 0  | search file mark forward       |
|     | 0  | 1  | x  | 1  | 0  | 0  | search file mark backward      |
|     | 1  | ×  | ×  | 1  | X  | ×  | rewind                         |
|     | 1  | x  | x  | 0  | ×  | ×  | off line                       |
|     | 1  | ×  | 1  | 1  | x  | ×  | load and on line (for 1600BPI) |

{x = not significant)

# SERIAL CU P851M

| bit | 12   | 13 |             |
|-----|------|----|-------------|
|     | х    | 0  | no parity   |
|     | 0    | 1  | even parity |
|     | 1    | 1  | odd parity  |
| bit | 15 = | 0  | output      |
|     |      | 1  | input       |

# SALCU

| bit 11 = 0<br>1 | without echo<br>with echo |
|-----------------|---------------------------|
| bit 12 13       |                           |
| x 0             | no parity                 |
| 0 1             | even parity               |
| 1 1             | odd parity                |

Input is always on even address.

Output is always on input address + 1.

### **HDLC**

# CIO Start input

| bit | 12 | 13 | 14 | 15 |                                 |
|-----|----|----|----|----|---------------------------------|
|     | ×  | 0  | 0  | 1  | disconnect modem                |
|     | ×  | 0  | 1  | O  | connect modem                   |
|     | ×  | 0  | 1  | 1  | wait for call                   |
|     | 0  | 1  | 0  | 1  | receive data (prog. chan)       |
|     | 0  | 1  | 0  | 0  | alarm receive data (prog. chan) |
|     | 1  | 1  | 0  | 1  | receive data (I/O proc)         |
|     | 1  | 1  | 0  | 0  | alarm receive data (I/O proc)   |

## **CIO Start output**

bit 4 5 6 7 12 13 14 15 no, of true data O 0 0 transmit 4 wire (Prog. Chan) 1 bits. If zero, the 0 1 transmit 2 wire (Prog. Chan) 0 1

length of last word 1 0 1 0 transmit 4 wire (I/O Proc) to be sent is 16 bits 1 0 1 transmit 2 wire (I/O Proc)

not sign. 1 0 0 idle "1"

not sign. 0 0 1 no "request to send"

#### FLOPPY DISK

In CIO instruction must be specified:

bit 10,11 drive number

bit 12 thru 15 control unit address

The r3 contents must be:

#### WRITE

bit 0, 1 n+1 records will be written successively

bit 2 thru 12 record number (from 0 to 2001)

bit 13 14 15 0 0 1

#### WRITE AND VERIFY

bit 0 thru 12 see WRITE

bit 13 14 15 1 0 1

#### WRITE WITH DELETED DATA ADDRESS MARKS

bit 0 thru 12 see WRITE

bit 13 14 15

0 1 0

#### WRITE WITH DELETED ADDRESS MARKS AND VERIFY

bit 0 thru 12 see WRITE

bit 13 14 15

# READ

bit 0 thru 12 see WRITE

bit 13 14 15 0 0 0

#### SEARCH KEY

bit 0 thru 4 (

bit 5 thru 12 number of 8-bit characters of the key

number = 1 to 128

bit 13 = 1 search with mask
0 search without mask

bit 14 15

1 1

# 

DOOR UNLOCK

bit 0 thru 10 0 bit 11 12 13 14 15 0 1 1 0 0

# input/output instructions for integrated Serial Control Unit

In I/O instructions for the P858M/P859M integrated serial control unit, the following parameter values apply:

- · device address for the integrated serial control unit is /10
- the contents of 'r3' in a CIO Start instruction must be:



X = : not significant

E : 0 = no echo mode not significant 1 = echo mode if bit 15 = 0

PA: 00 = no parity

01 = even parity

11 = odd parity

F : 0 = output 1 = input INR

Input to register

INR

P851M P852M P856M PB57M

Syntax:

[label] 
$$\sqcup$$
 INR  $\sqcup$  r3,  $\begin{bmatrix} 0 \\ 1 \end{bmatrix}$ , dev

This instruction allows to transfer one word or character from a device to the register specified in r3.

When a character is transferred the 8 bits are stored in bits 8-15 of register r3 and bits 0-7 are reset to zero.

When a word is transferred all 16 bits of the register r3 are significant. Bit 9 may be used to give a particular input function which depends on the peripheral used.

This instruction is accepted when the device control unit is in the exchange state. If not accepted the contents of the register are destroyed.

Note: On certain peripherals, e.g. teletype, an ASCII character may or may not be accompanied with a parity bit, depending on the parity chosen. This parity bit can be found in bit 8 of the register r3. When this bit is not systematically reset to zero, e.g. with ANK r3,/7F, the information in memory may be different from the ASCII pattern expected.

Syntax Type

T8 INR r3, 0, address

INR r3, 1, address depending on control unit

Condition register:

CR = 0 command accepted

1 command not accepted

3 device address unknown

| bit | 0 | 1 |   |   | 4 | 5  | 7 | 8 | 9 | 10 |     | 15 |
|-----|---|---|---|---|---|----|---|---|---|----|-----|----|
|     | 0 | 1 | 0 | 0 | 1 | r3 |   | 0 | F |    | dev |    |
|     |   |   | 1 |   |   |    |   | 1 |   | -  | 1   |    |

- \* r3 ≠ 0.
- This instruction may only be used in system mode.

Output from register

| OTR |
|-----|
|-----|

P851M P852M P856M P857M

Syntax:

[label] 
$$\square$$
 OTR  $\square$  r3,  $\begin{bmatrix} 0 \\ 1 \end{bmatrix}$ , dev

When this instruction is accepted, only if the device control unit is in the exchange state, a data word or character is sent from the register specified by r3 to the peripheral device with address day. During execution "F" and dev fields are sent to the device via the GP bus. Bit 9 (F) may be used to specify a particular output function which depends on the type of peripheral used.

Type Syntax

T8 OTR r3, 0, address

OTR r3, 1, address depending on control unit

Condition register:

CR = 0 command accepted

1 command not accepted

3 device address unknown



- \* r3 # 0.
- \* This instruction may only be used in system mode.

#### Send status

SST

P851M P852M P856M P857M

Syntax:

[label] \_ SST \_ r3, dev

This instruction is used to know the status of the control unit addressed and should be programmed after an I/O sequence e.g. after CIO STOP. The instruction is accepted when the control unit addressed is in the Wait State, after which a status word is sent to the register r3.

The following conditions are indicated by fixed bit positions (if significant for the control unit concerned); see following pages.

After a not accepted SST instruction the contents of r3 is not significant.

Note: For the programmable real time clock the SST is not significant.

Type Syntax

T8 SST r3, address

Condition register:

CR = 0 command accepted

1 command not accepted

3 device address unknown



- \* r3 must be ≠ 0.
- \* Address must be # 0.
- \* This instruction may only be used in system mode.

CU status configuration:

| Not operable x x X Throughput error x x X Parity error Data fault FCS error Incorrect length Program error Frage detection* Program error Tape low | * |      |   |   |   | Ī |   |   |   |   |   | 200 |
|----------------------------------------------------------------------------------------------------------------------------------------------------|---|------|---|---|---|---|---|---|---|---|---|-----|
| ×                                                                                                                                                  |   | ×    | × | × | × | × | × | × | × |   | × | ×   |
|                                                                                                                                                    |   | v in | × |   | × | × | × | × |   |   | × | ×   |
|                                                                                                                                                    |   | ×    |   |   | × |   |   | × |   | × | × |     |
|                                                                                                                                                    |   |      |   |   |   | × | × |   | × |   |   |     |
|                                                                                                                                                    |   |      |   |   |   |   |   |   |   |   |   | ×   |
|                                                                                                                                                    |   |      | × | _ | × | × | × | × | × |   |   | ×   |
|                                                                                                                                                    |   | ×    |   |   |   |   |   |   |   |   |   |     |
|                                                                                                                                                    |   |      |   |   | × | × | × |   | × |   |   |     |
|                                                                                                                                                    |   |      |   |   | × | × |   |   |   |   |   |     |
|                                                                                                                                                    | × |      |   |   |   |   |   |   |   |   |   |     |
| End of reception                                                                                                                                   |   | ×    |   |   |   |   |   |   |   |   |   |     |
| Hopp./Stack. empty/full                                                                                                                            |   |      | × |   |   |   |   |   |   |   |   |     |
| End of carr, detection                                                                                                                             |   |      |   |   |   |   |   |   |   |   | × | ×   |
|                                                                                                                                                    |   |      |   |   |   |   |   |   | × |   |   |     |
| Calling indicator                                                                                                                                  |   |      |   |   |   |   |   |   |   |   | × | ×   |
| Dev/tape/drive no.                                                                                                                                 |   |      |   |   | × | × | × | × | × |   |   |     |
| Dev/tape/drive no.                                                                                                                                 |   |      |   |   | × | × | × |   | × |   |   |     |
| Device ready                                                                                                                                       |   | ×    |   |   |   |   |   |   |   |   |   |     |
| Break detection                                                                                                                                    |   |      |   |   |   |   | - |   |   | × | × |     |
| 1=A side/0=B side                                                                                                                                  |   |      |   |   | × |   |   |   |   |   |   |     |
| 4-7 No. of true data bits                                                                                                                          |   |      |   |   |   |   |   |   |   |   |   | ×   |
| Write protected                                                                                                                                    |   |      | ٠ |   | × | × |   |   | × |   |   |     |
|                                                                                                                                                    |   |      |   |   |   |   | × | × |   |   |   |     |
| 4-7 No. of true data bits                                                                                                                          |   |      |   |   |   |   |   |   |   | _ |   | ×   |

CU status configuration (contd):

| Bit Description           | ASH | PTR | ртр | s.cu | CR | LP | CAS | MT | DK1215 | DK1215 DK40MB | OKFL | scuz | SALCU | HDLC |
|---------------------------|-----|-----|-----|------|----|----|-----|----|--------|---------------|------|------|-------|------|
| Begin of tape/load point  |     |     |     |      | -  |    | ×   | ×  |        |               |      |      |       |      |
|                           |     |     |     |      |    |    |     |    | ×      |               |      |      |       |      |
| 4-7 No. of true data bits |     |     |     |      |    |    |     |    |        |               |      |      |       | ×    |
| Record not found          |     |     |     |      |    |    | ×   |    |        | ×             | ×    |      |       |      |
| Del, data addr, mark      |     |     |     |      |    |    |     |    |        |               | ×    |      |       |      |
| 4-7 No. of true data bits |     |     |     |      |    |    |     |    |        |               |      |      |       | ×    |
| Tape mark detection       |     |     |     |      |    |    | ×   |    |        |               |      |      |       |      |
| File mark detection       |     |     |     |      |    |    |     | ×  |        |               |      |      |       |      |
|                           |     |     |     |      |    |    |     |    |        |               |      |      |       | ×    |
|                           |     |     |     |      |    |    |     | ×  |        |               |      |      |       |      |
|                           |     |     |     |      |    |    |     |    |        |               |      |      |       | ×    |
| Flag bad data track       |     |     |     |      |    |    |     |    |        | ×             |      |      |       |      |
|                           |     |     |     |      |    |    |     |    |        |               | ×    |      |       |      |
| 1 Unit rdy after not rdy  |     |     |     |      |    |    | ×   | ×  | ×      | ×             | ×    |      |       |      |
|                           |     |     |     |      |    |    |     |    |        |               |      |      |       |      |

TST

Test status

TST

P851M P852M P856M P857M

[label] \_\_ TST \_\_ r3. dev Syntax:

> This instruction may be used before starting an I/O operation to test whether the control unit addressed is busy. The instruction is always accepted. During the execution of the TST instruction a status word is sent from the control unit to register r3,

> A 1 bit is set in bit 15 of the status word sent (busy) for the following control units:

ASR

**PUNCHED TAPE READER** 

TAPE PUNCH

SERIAL CONTROL UNIT P852, P856, P857M

CARD READER LINE PRINTER

CASSETTE

MAGNETIC TAPE

DK1215

DK40MB

DKFLOPPY

PROG. REAL TIME CLOCK

For some control units additional information may be expected in the status word:

MAGNETIC TAPE: bit 14 = 1 tape transport ready (for

1600 BSD

PROG. REAL TIME CLOCK: bit 14 = 1 previous command accepted.

This bit may be forced to zero.

DK40MB: bit 14 = least significant bit of the total record length

> bit 1 = most significant bit of the total record length

bit 0 = 0

Note: The serial control unit P851M, the HDLC control unit and

SALCU return no significant information when a TST.

instruction is sent.

Type Svntax

TB. TST r3, address

Condition

register: CR = 0 accepted

3 device address unknown

| bit | 0 | 1 |   |   | 4 | 5  | 7 | 8 | 9 | 10 |     | 15 |
|-----|---|---|---|---|---|----|---|---|---|----|-----|----|
|     | 0 | 1 | 0 | 0 | 1 | r3 |   | 1 | 0 |    | dev |    |
|     |   |   |   |   |   |    |   |   |   |    |     |    |

- r3 must be ≠ 0.
  This instruction may only be used in system mode.

The character string handling instructions are coded in the new 'D' format:

| _0 | 1 |   |   | 4 | 5 7 | 8 |          | 15 |
|----|---|---|---|---|-----|---|----------|----|
| 0  | 1 | 1 | Q | 1 | r3  |   | function |    |

in which '13' specifies one of the registers A0 to A7 (for the currently available instructions this field =0) and 'function' qualifies the operation code

The parameters for a 'D' format instruction must be loaded into registers before the instruction is executed. The instructions MVS and CS use registers A2, A3 and A4; MVA uses registers A1, A2 and A4. CA uses registers A1, A2 and A3.

An attempt to execute a not wired 'D' format instruction (i.e. OPC = 1101, but 'function' #/00,/40,/60 or /A0) causes an indirect branch via /7C; this trap action can be used for software simulation of 'D' format instructions not available in the instruction set.

In the P853M, all instructions with OPC = 1101 (i.e. character string instructions) are trapped.

MVS

Move string

MVS

P854 P858 P859

Syntax: [label] MVS

This instruction copies a string of consecutive characters from one memory area into another area. The parameters for the instruction must be specified in registers A2, A3 and A4;

- register A3 must be loaded with the first address of the string to be copied
- register A4 must be loaded with the first address of the receiving area
- register A2 must be contain the number of characters to be moved.

To avoid overwriting, the instruction compares the contents of registers A3 and A4, and decides on the direction of the move: if (A3) < (A4), characters are moved from higher addresses towards lower addresses, if (A3) > (A4), characters are moved from lower addresses towards higher addresses.

The execution of this instruction may be interrupted after any character transfer; execution is resumed when the interrupt has been serviced.

When execution of the instruction is terminated, register A2 contains 0, and the contents of registers A3 and A4 are not significant.

Type **Function** T8D if (A3) > (A4) the string is moved forward:  $((A3)) \rightarrow (A4)$ (A3) + 1 - A3this sequence is repeated  $(A4) + 1 \Rightarrow A4$ until(A2) = 0(A2) - 1 + A2scan interrupts if (A3) < (A4) the register contents are modified:  $(A3) + (A2) - 1 \rightarrow A3$  $(A4) + (A2) - 1 \rightarrow A4$ and the string is moved backward:  $((A3)) \rightarrow (A4)$  $(A3) - 1 \rightarrow A3$ this sequence is repeated  $(A4)-1 \Rightarrow A4$ until(A2) = 0 $(A2)-1 \rightarrow A2$ scan interupts

Note: A3 and A4 contain character addresses, so in each move step one character is moved.

# Condition register:

Unchanged

bit 0 1 4 5 7 8 15 0 1 1 0 1 0 0 0 0 0 0 0 0 0 0

| 8.5  | VA. |
|------|-----|
| 44.1 | * ^ |

#### Move A11

MVA

P854 P858 P859

Syntax:

(label) MVA

This instruction loads the character specified in bit 8-15 of register A1 into all character locations of the memory area defined by the start address specified in register A4 and the length specified in register A2.

The execution of this instruction may be interrupted after any character. transfer: execution is resumed when the interrupt has been serviced.

When the execution of this instruction is terminated, register A2 contains 0. and register A4 contains (start address + length); register A1 remains unchanged.

Туре

Function

TSD

 $(A1)_{8-15} - (A4)$  $(A4) + 1 \rightarrow A4$ 

this sequence is repeated until (A2) = 0

(A2) - 1 - A2

scan interrupts

Condition register:

Unchanged

bit

| 0 | 1 |   |   | 4 | 5 |   | 7 | 8 |   |   |   |   |   |   | 15 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|
| 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0  |

CS

# Compare Strings

CS

P854 P858 P859

Syntax: [label] CS

This instruction compares the contents of two character strings, character by character, until a difference is detected.

The parameters for the instruction must be specified in registers A2, A3 and A4:

- register A3 must be loaded with the first address of string 1
- register A4 must be loaded with the first address of string 2
- register A2 must be contain the number of characters in string 2

The instruction compares the two strings, until a difference is detected or all characters have been compared. The condition register is set to indicate the difference.

The execution of this instruction may be interrupted after any character transfer; execution is resumed when the interrupt has been serviced.

When execution of this instruction is terminated, registers A3 and A4 point to the addresses where the difference was detected, and A2 contains the remaining length. If no difference was detected, registers A3 and A4 point to the next address after the specified areas, and A2 = 0.

Type Function

T8D 
$$0 + CR$$
 $((A3)) \longrightarrow ((A4))$ 
if  $((A3)) = ((A4))$ :  $(A3) + 1 \rightarrow A3$  this sequence is repeated until  $(A2) - 1 \rightarrow A2$  a difference is scan interrupts detected

if  $((A3)) \neq ((A4))$ : if  $((A3)) > ((A4)) + CR$ 
if  $((A3)) \neq ((A4)) + CR$ 

Condition register:

CR = 0 if all compared characters are identical

CR = 1 if character in string 1 > character in string 2

CR = 2 if character in string 1 < character in string 2



CA

### Compare A11

CA

P854 P858 P859

Syntax:

[label] CA

This instruction compares a single character with all characters in a character string, until a difference is detected.

The parameters for the Instruction are specified in registers A1, A2 and A3:

- register A1 must contain a character value in bits 8-15
- register A3 must contain the first address of the string
- register A2 must contain the string length (in characters).

If all characters in the string are identical to the character in register A1, the condition register is set to 0; if a difference is detected, register A3 points to the character that is different from the value in A1, and the condition register is set to indicate the difference.

The execution of this instruction may be interrupted after any character transfer; execution is resumed when the interrupt has been serviced.

The function of the instruction is:

Type Function

T8D 
$$0 \Rightarrow CR$$

(A3)  $\Rightarrow$  (A1)

if (A3) = (A1): (A3) + 1  $\Rightarrow$  A3 this sequence is repeat until A2 = 0 or (A3) # (A1)

if (A3) # (A1): if (A3) < (A1) 1  $\Rightarrow$  CR

if (A3) > (A1) 2  $\Rightarrow$  CR

Condition register:

CR = 0 if all compared characters are identical CR = 1 if character in string 1 < character in A2 CR = 2 if character in string 1 > character in A2

