# M 83-SERIES <br> MODELS 8/32,8/32C,AND 8/32D PROCESSORS USER MANUAL 

# PERKIN-ELMER 

Computer Systems Division<br>2 Crescent Place<br>Oceanport. N. J. 07757

PAGE REVISION STATUS SHEET (Sheet 1 of 2)
PUBLICATION NUMBER 29-428
TITLE M83-Series Models 8/32, 8/32C and 8/32D Processors REVISION R06 User Manual DAt́ May 1978

| Page | REV. | DATE | PAGE | REV. | DATE | PAGE | REV. | DATE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| i | R06 | 5/78 | 2-40 |  |  | 5-11 | R06 | 5/78 |
| ii |  |  | thru |  |  | 5-12 | R02 | 2/77 |
| thru |  |  | 2-46 | R02 | 2/77 | 5-13 | R02 | 2/77 |
| v | R01 | 1/76 | 2-47 | R01 | 1/76 | 5-14 | R06 | 5/78 |
| vi | R02 | 2/77 | 2-48 |  |  | 5-15 | R01 | 1/76 |
| vii | R06 | 5/78 | thru |  |  | 5-16 | R02 | 2/77 |
| viii | RO1 | 1/76 | 2-51/ |  |  | 5-17 | R01 | 1/76 |
|  |  |  | 2-52 | R02 | 2/77 | 5-18 | R02 | 2/77 |
| 1-1 |  |  |  |  |  | 5-19 | R02 | 2/77 |
| thru |  |  | 3-1 | ROl | 1/76 | 5-20 | R01 | 1/76 |
| 1-3 | R06 | 5/78 | 3-2 | R02 | 2/77 | 5-21 | R02 | 2/77 |
| 1-4 |  |  | 3-3 | R02 | 2/77 | 5-22 | R01 | 1/76 |
| thru |  |  | 3-4 | R06 | 5/78 | 5-23 | R02 | 2/77 |
| 1-6 | R02 | 2/77 | 3-5 | R02 | 2/77 | 5-24 | R06 | 5/78 |
| 1-7 | R01 | 1/76 | 3-6 | R02 | 2/77 | 5-25 | R02 | 2/77 |
| 1-8 | R01 | 1/76 | 3-7 |  |  | 5-26 | R06 | 5/78 |
| 1-9 |  |  | thru |  |  | 5-27 |  |  |
| thru |  |  | 3-24 | R05 | 5/78 | thru |  |  |
| 1-19/ |  |  |  |  |  | 5-33 | R02 | 2/77 |
| 1-20 | R06 | 5/78 | 4-1 | R02 | 2/77 | 5-34 | R06 | 5/78 |
|  |  |  | 4-2 | R05 | 5/78 | 5-35/ |  |  |
| 2-1 | R01 | 1/76 | 4-3 | R01 | 1/76 | 5-36 | R02 | 2/77 |
| 2-2 | R02 | 2/77 | 4-4 | R02 | 2/77 |  |  |  |
| 2-3 | R01 | 1/76 | 4-5 | R06 | 5/78 | 6-1 | R02 | 2/77 |
| 2-4 | R01 | 1/76 | 4-6 |  |  | 6-2 | R02 | 2/77 |
| 2-5 |  |  | thru |  |  | 6-3 | R01 | 1/76 |
| thru |  |  | 4-12 | R02 | 2/77 | 6-4 | R02 | 2/77 |
| 2-7 | R02 | 2/77 | 4-13 | R06 | 5/78 | 6-5 | R02 | 2/77 |
| 2-8 | R05 | 5/78 | 4-14 | R02 | 2/77 | 6-6 | R01 | 1/76 |
| 2-9 |  |  | 4-15 | R02 | 2/77 | 6-7 | R04 | 5/78 |
| thru |  |  | 4-16 | R06 | 5/78 | 6-8 | R06 | 5/78 |
| 2-18 | R02 | 2/77 | 4-17 |  |  | 6-9 | R06 | 5/78 |
| 2-19 | R06 | 5/78 | thru |  |  | 6-10 | R06 | 5/78 |
| 2-20 | R06 | 5/78 | 2-231 |  |  | 6-11 | R06 | 5/78 |
| 2-21 |  |  | 4-24 | R02 | 2/77 | 6-12 |  |  |
| thru |  |  |  |  |  | thru |  |  |
| 2-26 | R02 | 2/77 | 5-1 | R02 | 2/77 | 6-16 | R02 | 2/77 |
| 2-27 | R06 | 5/78 | 5-2 | R01 | 1/76 |  |  |  |
| 2-28 |  |  | 5-3 | R01 | 1/76 | 7-1 | R04 | 5/78 |
| thru |  |  | 5-4 | R01 | 1/76 | 7-2 | R06 | 5/78 |
| 2-33 | R02 | 2/77 | 5-5 | R02 | 2/77 | 7-3 | R01 | 1/76 |
| 2-34 | R06 | 5/78 | 5-6 | R01 | 1/76 | 7-4 |  |  |
| 2-35 | R02 | 2/77 | 5-7 | R06 | 5/78 | thru |  |  |
| 2-36 |  |  | 5-8 | R02 | 2/77 | 7-15 | R02 | 2/77 |
| thru |  |  | 5-9 | R01 | 1/76 | 7-16 | R01 | 1/76 |
| 2-39 | R06 | 5/78 | 5-10 | R02 | 2/77 | 7-18 | R01 | 1/76 |

PAGE REVISION STATUS SHEET (Sheet 2 of 2)
PUBLICATION NUMBER 29-428
TITLE M83-Series Models 8/32, 8/32C, and 8/32D Processor. User Manual
REVISION R06 DATE May 1978

| PAGE | REV. | DATE | PAGE | REV. | DATE | Page | REV. | dATE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7-19 | R06 | 5/78 | 11.-5 |  |  |  |  |  |
| 7-20 | R02 | 2/77 | thru |  |  |  |  |  |
| 7-21 | R02 | 2/77 | 11-10 | R01 | 1/76 |  |  |  |
| 7-22 | R02 | 2/77 | 11-11/ |  |  |  |  |  |
| 7-23 | R06 | 5/78 | 11-12 | R02 | 2/77 |  |  |  |
| 7-24 | R02 | 2/77 |  |  |  |  |  |  |
| 7-25 |  |  | Al-1 | R06 | 5/78 |  |  |  |
| thru |  |  | Al. -2 | R06 | 5/78 |  |  |  |
| 7-271 |  |  |  |  |  |  |  |  |
| 7-28 | R01 | 1/76 | A2-1 |  |  |  |  |  |
| 8-1 | R01 | 1/76 | A2-4 | R02 | 2/77 |  |  |  |
| 8-2 | R02 | 2/77 |  |  |  |  |  |  |
| 8-3 | R01 | 1/76 | A3-1 |  |  |  |  |  |
| 8-4 | R06 | 5/78 | thru |  |  |  |  |  |
| 8-5 | R06 | 5/78 | A3-5/ |  |  |  |  |  |
| 8-6 | R01 | 1/76 | A3-6 | R02 | 2/77 |  |  |  |
| 8-7/ |  |  |  |  |  |  |  |  |
| 8-8 | R06 | 5/78 | A4-1 | R02 | 2/77 |  |  |  |
|  |  |  | A 4-2 | R02 | 2/77 |  |  |  |
| 9-1 | R06 | 5/78 |  |  |  |  |  |  |
| 9-2 | R06 | 5/78 | A5-1 | R06 | 5/78 |  |  |  |
| 9-3 | R01 | 1/76 | A5-2 | R01 | 1/76 |  |  |  |
| 9-4 | R02 | 2/77 | A5-3 | R01 | 1/76 |  |  |  |
| 9-5 | R02 | 2/77 | A5-4 | R02 | 2/77 |  |  |  |
| 9-6 | R06 | 5/78 | A5-5 | R01 | 1/76 |  |  |  |
| 9-7/ |  |  | A5-6 | R01 | 1/76 |  |  |  |
| 9-8 | R02 | 2/77 |  |  |  |  |  |  |
| 10-1 | R06 | 5/78 | thru |  |  |  |  |  |
| 10-2 | R02 | 2/77 | A6-8 | R03 | 1/78 |  |  |  |
| 10-3 | R01 | 1/76 |  |  |  |  |  |  |
| 10-4 | R02 | 2/77 | A7-1 | R06 | 5/78 |  |  |  |
| 10-5 | R02 | 2/77 | A7-2 | R01 | 1/76 |  |  |  |
| 10-6 | R01 | 1/76 | A7-3 | R06 | 5/78 |  |  |  |
| 10-7 | R01 | 1/76 |  |  |  |  |  |  |
| 10-8 | R02 | 2/77 | A8-1 | R01 | 1/76 |  |  |  |
| 10-9 | R06 | 5/78 | A8-2 | R02 | 2/77 |  |  |  |
| 10-10 | R01 | 1/76 | A8-3 | R01 | 1/76 |  |  |  |
| 11-1 | R06 | 5/78 | A8-4 | R01 | 1/76 |  |  |  |
| 11-2 | R01 | 1/76 | I-1 | R06 | 5/78 |  |  |  |
| 11-3 | R06 | 5/78 | I-2 |  |  |  |  |  |
| 11-4 | R06 | 5/78 | $\begin{aligned} & \text { thru } \\ & \mathrm{I}-6 \end{aligned}$ | R01 | 1/76 |  |  |  |

## TABLE OF CONTENTS

CHAPTER 1 SYSTEM DESCRIPTION ..... 1-1
PROCESSOR ..... 1-4
Program Status Word ..... 1-4
Wait State (W) ..... 1-4
Immediate Interrupt/Auto Driver Channel Mask (I) ..... 1-4
Machine Malfunction Interrupt Mask (M) ..... $1-5$
Arithmetic Fault Interrupt Mask (A) ..... 1-5
Relocation Protection Interrupt Mask ( $\mathrm{R} / \mathbf{P}$ ) ..... 1-5
System Queue Service Interrupt Mask (Q) ..... 1-5
Protect Mode (P) ..... 1-5
Register Set Select (R) ..... 1-5
Condition Code (CVGL) ..... 1-5
Location Counter (LOC) ..... 1-5
General Register ..... 1-7
Floating Point Register ..... 1-7
Processor Interrupts ..... 1-7
Reserved Memory Locations ..... 1-7
Processor Operations ..... 1-8
DATA FORMATS ..... $1-8$
Fixed Point Data ..... 1-8
Floating Point Data ..... 1-8
Logical Data ..... 1-9
DATA ALIGNMENT ..... 1-9
INSTRUCTION FORMATS ..... 1-10
Branch Instruction Formats ..... 1-11
Programming Examples. ..... 1-11
Register to Register (RR) Format ..... 1-11
Short Form (SF) Format ..... 1-11
Register and Indexed Storage One (RX1) Format ..... 1-13
Register and Indexed Storage Two (RX2) Format ..... 1-14
Register and Indexed Storage Three (RX3) Format ..... 1-16
Register and Immediate Storage One (RI1) Format ..... 1-17
Register and Immediate Storage Two (RI2) Format ..... 1-18
CHAPTER 2 LOGICAL OPERATIONS ..... 2-1
DATA FORMATS ..... 2-1
OPERATIONS ..... 2-2
Boolean Operations ..... 2-2
Translation ..... 2-2
List Processing ..... 2-3
LuGICAL INSTRUCTION FORMATS ..... 2-4
LOGICAL INSTRUCTIONS ..... 2-4
Load ..... 2-5
Load Register ..... 2-5
Load Immediate ..... 2-5
Load Immediate Short ..... 2-5
Load Complement Short ..... 2-5
Load Half word ..... 2-6
Load Halfword Immediate ..... 2-6
Load Address ..... 2-7
Load Real Address ..... 2-8
Load Halfword Logical ..... 2-9

TABLE OF CONTENTS (Continued)
Load Multiple ..... 2-10
Load Byte ..... 2-11
Load Byte Register ..... 2-11
Exchange Halfword Register ..... 2-12
Exchange Byte Register ..... 2-13
Store ..... 2-14
Store Halfword ..... 2-15
Store Multiple ..... 2-16
Store Byte ..... 2-17
Store Byte Register ..... 2-17
Compare Logical ..... 2-18
Compare Logical Register ..... 2-18
Compare Logical Immediate ..... 2-18
Compare Logical Halfword ..... 2-19
Compare Logical Halfword Immediate ..... 2-19
Compare Logical Byte ..... 2-20
AND ..... 2-21
AND Register ..... 2-21
AND Immediate ..... 2-21
AND Halfword ..... 2-22
AND Halfword Immediate ..... 2-22
OR ..... 2-23
OR Register ..... 2-23
OR Immediate ..... 2-23
OR Halfword ..... 2-24
OR Halfword Immediate ..... 2-24
Exclusive OR ..... 2-25
Exclusive OR Register ..... 2-25
Exclusive OR Immediate ..... 2-25
Exclusive OR Halfword ..... 2-26
Exclusive OR Halfword Immediate ..... 2-26
Test Immediate ..... 2-27
Test Halfword Immediate ..... 2.28
Shift Left Logical ..... 2-29
Shift Left Logical Short ..... 2-29
Shift Right Logical ..... 2-30
Shift Right Logical Short ..... 2-30
Shift Left Halfword Logical ..... 2-31
Shift Left Halfword Logical Short ..... 2-31
Shift Right Halfword Logical ..... 2-32
Shift Right Halfword Logical Short ..... 2-32
Rotate Left Logical ..... 2-33
Rotate Right Logical ..... 2-34
Test and Set ..... 2-35
Test Bit ..... 2-36
Set Bit ..... 2-37
Complement Bit ..... 2-38
Reset Bit ..... 2-39
Cyclic Redundancy Check Modulo 12 ..... 2-40
Cyclic Redundancy Check Modulo 16 ..... 2-40
Translate ..... 2-42
Add to Top of List ..... 2-45
Add to Bottom of List ..... 2-45
Remove from Top of List ..... 2-46
Remove from Bottom of List ..... 2-46
CHAPTER 3 BRANCHING ..... 3-1
OPERATIONS ..... 3-1
Decision Making ..... 3-1
Subroutine Linkage ..... 3-1

## TABLE OF CONTENTS (Continued)

BRANCH INSTRUCTION FORMATS ..... 3-1
BRANCH INSTRUCTIONS ..... 3-2
Branch on True Condition ..... 3-3
Branch on True Condition Register ..... 3-3
Branch on True Condition Backward Short ..... 3-3
Branch on True Condition Forward Short ..... 3-3
Branch on False Condition ..... 3-4
Branch on False Condition Register ..... 3-4
Branch on False Condition Backward Short ..... 3-4
Branch on False Condition Forward Short ..... 3-4
Branch and Link ..... 3-5
Branch and Link Registe: ..... 3-5
Branch on Index Low or Equal ..... 3-6
Branch on Index High ..... 3-7/3-8
CHAPTER 4 FIXED POINT ARITHMETIC ..... 4-1
DATA FORMATS ..... 4-1
FIXED POINT NUMBER RANGE ..... 4-1
OPERATIONS ..... 4-2
CONDITION CODE ..... 4-2
FIXED POINT INSTRUCTION FORMATS ..... 4-3
FIXED POINT INSTRUCTIONS ..... 4-3
Add ..... 4-4
Add Register ..... 4-4
Add Immediate ..... 4-4
Add Immediate Short ..... 4-4
Add Halfword ..... 4-5
Add Halfword Immediate ..... 4-5
Add to Memory ..... 4-6
Add Halfword to Memory ..... 4-7
Subtract ..... 4-8
Subtract Register ..... 4-8
Subtract Immediate ..... 4-8
Subtract Immediate Short ..... 4-8
Subtract Halfword ..... 4-9
Subtract Halfword Immediate ..... 4-9
Compare ..... 4-10
Compare Register ..... 4-10
Compare Immediate ..... 4-10
Compare Halfword ..... 4-1:
Compare Halfword Immediate ..... 4-11
Multiply ..... 4-12
Multiply Register ..... 4-12
Multiply Halfword ..... 4-13
Multiply Halfword Register ..... 4-13
Divide ..... 4-14
Divide Register ..... 4-14
Divide Halfword ..... 4-16
Divide Halfword Register ..... 4-16
Shift Left Arithmetic ..... 4-18
Shift Left Halfword Arithmetic ..... 4-19
Shift Right Arithmetic ..... 4-20
Shift Right Halfword Arithmetic ..... 4-21
Convert Halfword Value Register ..... 4-22

## TABLE OF CONTENTS (Continued)

CHAPTER 5 FLOATING POINT ARITHMETIC ..... 5-1
INTRODUCTION ..... 5-1
FLOATING POINT NUMBER ..... 5-3
Floating Point Number Range ..... 5-4
Normalization ..... 5-4
Equalization ..... 5-5
True Zero ..... 5-5
Exponent Overflow ..... 5-6
Exponent Underflow ..... 5-6
Data Formats ..... 5-6
Guard Digit and Rounding ..... 5-7
Conversion from Decimal ..... 5-8
CONDITION CODE ..... 5-8
FLOATING POINT INSTRUCTION FORMATS ..... 5-8
FLOATING POINT INSTRUCTIONS ..... 5-8
Load Floating Point ..... 5-10
Load Floating Point Register ..... 5-10
Load Floating Point Multiple ..... 5-11
Store Floating Point ..... 5-12
Store Floating Point Multiple ..... 5-13
Add Floating Point ..... 5-14
Add Floating Point Register ..... 5-14
Subtract Floating Point ..... 5-16
Subtract Floating Point Register ..... 5-16
Compare Floating Point ..... 5-18
Compare Floating Point Register ..... 5-18
Multiply Floating Point ..... 5-19
Multiply Floating Point Register ..... 5-19
Divide Floating Point ..... 5-21
Divide Floating Point Register ..... 5-21
Fix Register ..... 5-23
Float Register ..... 5-24
Load Double Precision Floating Point ..... 5-25
Load Register Double Precision Floating Point ..... 5-25
Load Multiple Double Precision Floating Point ..... 5-26
Store Double Precision Floating Point ..... 5-27
Store Multiple Double Precision Floating Point ..... 5-28
Add Double Precision Floating Point ..... 5-24
Add Register Double Precision Floating Point ..... 5-29
Subtract Double Precision Floating Point ..... 5-30
Subtract Register Double Precision Floating Point ..... 5-30
Compare Double Precision Floating Point ..... 5-31
Compare Register Double Precision Floating Point ..... 5-31
Multiply Double Precision Floating Point ..... 5-32
Multiply Register Double Precision Floating Point ..... 5-32
Divide Double Precision Floating Point ..... 5-33
Divide Register Double Precision Floating Point ..... 5-33
Fix Register Double Precision ..... 5-34
Float Register Double Precision ..... 5-35/5-36
CHAPTER 6 STATUS SWITCHING AND INTERRUPTS ..... $6-1$
PROGRAM STATUS WORD ..... 6-1
Wait State ..... 6-2
Protect Mode ..... 6-2
Register Set Selection ..... 6-2

## TABLE OF CONTENTS (Continued)

INTERRUPT SYSTEM ..... 6-3
Immediate Interrupt ..... 6-6
Console Interrupt ..... 6-7
Simulated Interrupt ..... 6-7
Machine Malfunction Interrupt ..... 6-8
Arithmetic Fault Interrupt ..... 6-9
Relocation/Protection Interrupt ..... 6-9
System Queue Service Interrupt ..... $6-10$
Protect Mode Violation Interrupt ..... 6-10
Illegal Instruction Interrupt ..... 6-10
Supervisor Call Interrupt ..... 6-10
STATUS SWITCHING INSTRUCTION FORMATS ..... 6-11
STATUS SWITCHING INSTRUCTIONS ..... 6-11
Load Program Status Word ..... 6-12
Load Program Status Word Register ..... 6-13
Exchange Program Status Register ..... 6-14
Simulate Interrupt ..... 6-15
Supervisor Call ..... 6-16
CHAPTER 7 INPUT/OUTPUT OPERATIONS ..... 7-1
INTRODUCTION AND CONFIGURATION OF I/O SYSTEM ..... 7-1
DEVICE CONTROLLERS ..... 7-1
Device Addressing ..... 7-2
Processor/Controller Communication ..... 7-2
Device Priorities ..... 7-2
INTERRUPT SERVICE POINTER TABLE ..... 7-2
I/O INSTRUCTION FORMATS ..... 7-3
I/O INSTRUCTIONS ..... 7-3
Sense Status ..... 7-5
Sense Status Register ..... $7-5$
Output Command ..... 7-4
Output Command Register ..... 7-4
Read Data ..... 7-6
Read Data Register ..... $7-6$
Read Halfword ..... $7-7$
Read Halfword Register ..... 7-7
Read Block ..... 7-8
Read Block Register ..... 7-9
Write Data ..... 7-10
Write Data Register ..... 7-10
Write Halfword ..... 7-11
Write Halfword Register ..... 7-11
Write Block ..... 7-12
Write Block Register ..... 7-13
Autoload ..... 7-14
Simulate Channel Program ..... 7-15
CONTROL OF.I/O OPERATIONS ..... 7-16
STATUS MONITORING I/O ..... 7-16
INTERRUPT DRIVEN I/O ..... 7-17
SELECTOR CHANNEL $1 / 0$ ..... 7-18
Selector Channel Devices ..... 7-18
Selector Channel Operation ..... 7-18
Selector Channel Programming ..... 7-19
AUTO DRIVER CHANNEL ..... $7-19$
CHANNEL COMMAND BLOCK ..... 7-20
Subroutine Address ..... 7-20
Buffer ..... 7-21
Translation ..... 7-21
Check Word ..... 7-21
Channel Command Word ..... 7-22
Status Mask ..... 7-22
Execute Bit (E) ..... $7-22$
Fast Bit (F) ..... 7-22
Read/Write Bit (R/W) ..... 7.22
Translate Bit (T) ..... 7.22
Check Type Bit (C) ..... 7-23
Cyclic Check Type Bit (S) ..... 7.23
Buffer Switch Bit (B) ..... 7-23
Valid Channel Command Codes ..... 7-23
CHAPTER 8 MEMORY MANAGEMENT ..... 8-1
PROGRAM ADDRESS SPACE ..... 8-1
RELOCATION ..... 8-1
PROTECTION .....  8-1
MAC REGISTERS ..... 8-4
Definition of MAC Register Fields ..... 8-5
Segmentation Register ..... 8-5
Interrupt Status Register ..... 8-6
CHAPTER 9 WRITABLE CONTROL STORE INSTRUCTIONS ..... 9-1
WRITABLE CONTROL STORE INSTRUCTIONS ..... 9-2
Write Control Store ..... 9-4
Read Control Store ..... 9-5
Branch to Control Store ..... 9-6
Enter Control Store ..... 9-7/O-8
CHAPTER 10 DATA HANDLING INSTRUCTIONS ..... 10-1
DATA HANDLING INSTRUCTION FORMATS ..... 10-1
DATA. HANDLING INSTRUCTIONS ..... 10-1
Process Byte ..... 10-2
Process Byte Register ..... 10-4
Move and Process Byte String Register ..... 10-5
CHAPTER 11 M71-102 HEXADECIMAL DISPLAY PANEL AND
M71-101 BINARY DISPLAY PANEL PROGRAMMING SPECIFICATION ..... 11-1
INTRODUCTION ..... $11-1$
CONFIGURATION ..... 11-1
Display Registers and Indicators ..... 11-2
Key Operated Security Lock ..... 11-3
Control Keys ..... 11-3

## TABLE OF CONTENTS (Continued)

OPERATING PROCEDURES ..... 11-5
Power Up ..... 11-5
Power Down ..... 11-5
Memory Read ..... 11-5
Memory Write ..... 11-5
General Register Display ..... 11-6
Floating Point Register Display ..... 11-6
Floating Point Register Display (later versions of 8/32) ..... 11-6
Program Status Word Display and Modification ..... 11-6
Program Execution ..... 11-7
Program Termination ..... 11-7
Console Interrupt ..... 11-7
Switch Register ..... 11-7
Power Fail ..... 11-7
DATA FORMAT ..... 11-8
PROGRAMMING INSTRUCTIONS ..... 11-9
Input/Output Programming ..... 11-9
Wait State ..... 11-9
PROGRAMMING SEQUENCES ..... $11-9$
Programming Note ..... 11-11/11-12
INDEX ..... I-1

## ILLUSTRATIONS

Figure 1-1 Model 8/32 Processor Block Diagram ..... 1-2
Figure 1-2 Program Status Word ..... 1-4
Figure 1-3 Register Set Numbering ..... 1-6
Figure 1-4 Instruction Formats ..... 1-9
Figure 1-5 32-Bit Instruction Format Examples ..... 1-12
Figure 2-1 Logical Data ..... 2-1
Figure 2-2 Translation Table Entry ..... 2-2
Figure 2-3 Circular List Definition ..... 2-3
Figure 2-4 Circular List ..... 2-3
Figure 2-5 Flow Chart for CRC Generation ..... $2-4$
Figure 2-6 Processing Instructions ..... 2-47
Figure 4-1 Fixed Point Data Words Formats ..... 4-1
Figure 5-1 Single Precision Floating Point Number Fields ..... 5-2
Figure 5-2 Exponent Overflow ..... 5-6
Figure 5-3 Exponent Underflow ..... 5-6
Figure 6-1 Program Status Word ..... 6-1
Figure 6-2 Interrupt System Block Diagram ..... 6-5
Figure 7-1 Channel Command Block ..... 7-20
Figure 7-2 Channel Command Word ..... 7-22
Figure 7-3 Micro Code Flow Chart of Auto Driver Channel ..... 7-24
Figure 8-1 Segmentation Registers ..... 8-6
Figure 9-1 Model 8/32 Block Diagram ..... 9-2
Figure 9-2 Model 8/32 Instruction Formats ..... 9-3
Figure 10-1 Flow Chart of MPBSR Instruction ..... 10-6
Figure 11-1 Hexadecimal Display Panel ..... 11-1
Figure 11-2 Display Registers and Indicators ..... 11-2
Figure 11-3 Hexadecimal Display Panel Data Transfers ..... 11-8

## TABLES

```
TABLE 4-1 FIXED POINT FORMAT RELATIONS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-1
TABLE 5-1 FLOATING/FIXED POINT RANGES . . . . . . . . . . . . . . . . . . . . . . . . . . 5-4
INTERRUPT SYSTEMS5-4
```

TABLE 6-1 INTERRUPT SYSTEMS ..... 6-4
TABLE 11-1 dISPLAY STATUS AND COMMAND ..... 11-11/11-12
APPENDICES


## CHAPTER 1 SYSTEM DESCRIPTION

All references to the Model $8 / 32$ processor in this manual are applicable to the basic Model $8 / 32$, Model 8/32C and Model 8/32D unless otherwise specified.

The M83-Series $8 / 32$ processors are designed to meet the need for high-performance 32-bit minicomputers. Through the use of 32 -bit general registers and a comprehensive instruction set, the Model $8 / 32$ provides fullword data processing power and direct memory addressing up to a limit of one million bytes. The 8/32 System is shown, in block diagram form, in Figure 1-1.

The instruction set includes arithmetic and logical operations, list processing, floating point, cyclic redundancy checking, and bit and byte manipulation. Through this repertoire and direct memory addressing, coding and debugging time is reduced to a minimum.

Two sets (optionally expandable to 8 ) of sixteen 32 -bit General Registers are provided. Register set selection is controlled by bits in the Program Status Word. Register-to-Register instructions permit operations between any of the 16 registers in the current set, eliminating redundant loads and stores; the multiple register set organization eliminates the overhead incurred in saving and restoring registers when responding to interrupts.

The Memory Access Controller (MAC) provides automatic program segmentation, relocation, and protection. The Processor Protect mode enables detection of privileged instructions. These two features are invaluable in process control, data communication, and time-sharing operations to guarantee that a running program cannot interfere with the integrity of the system.

In addition to conventional means of programmed I/O, the Model $8 / 32$ automatically acknowledges all I/O interrupts and performs much of the required overhead prior to activating an Interrupt Service Routinc. The Auto Driver Channel can perform data transfers with character translation, longitudinal or cyclic redundancy checking and data buffer chaining without interrupting the running program.

The reader should refer to the following manuals for further information:
Common Assembler Language (CAL) User's Manual, Publication Number 29-375.
ESELCH Program ning Manual, Publication Number 29-529.
EDMA Bus Universal Interface Instruction Manual, Publication Number 29-423.
M83-Series Models 8/32, 8/32C, and 8/32D Processors Micro Instruction Reference Manual Publication Number 29-438.

M83-Series Models 8/32, 8/32C, and 8/32D Processors Maintenance Manual, Publication Number 29-394.

Common Microcode Assembler Language (MICROCAL) User's Manual, Publication Number 29-478

WCS User's Guide, Publication Number 29-479.


Figure 1-1. 8/32 System Block Diagram

The following are major differences between the Model 7/32 and the Model 8/32 Processors from a programmer's point of view:

1. The Model $7 / 32$ Processor has two General Register sets while the Model $8 / 32$ Processor can have two or eight General Register sets depending on the option selected.
2. The Model 7/32 Processor has no I/O Priority Levels while the Model 8/32 Processor can have up to four effective I/O Priority Levels depending on the number of optional register sets selected.
3. Earlier versions of the Model 7/32 Processor have a capability of executing some of the programs written for the INTERDATA 16-Bit Processors. The later versions of the Model $7 / 32$ Processors and the Model 8/32 Prosessors have no such capability.
4. The Model 7/32 Processor does not have an optional writable control store and related instructions as does the Model 8/32 Processor.
5. Fullword operations: In the Model 8/32 Processor, to fetch/store a fullword from/into memory, the fullword data must be aligned on a fullword boundary. This is not the case in the current versjon of the Model $7 / 32$ Processor. In the Model $7 / 32$, it is sufficient that a fullword data be aligned on a halfword boundary. Thus, a program that executes correctly on the current Model 7/32 may not do so when tried in the Model 8/32. The mnemonics for the instructions that may introduce such a discrepancy are:

| A | CL | LME | RBL | STE |
| :--- | :--- | :--- | :--- | :--- |
| ABL | D | LRA | RTL | STM |
| AD | DD | M | S | STMD |
| AE | DE | MD | SCP | STME |
| AM | L | ME | SD | SVC |
| ATL | LD | N | SE | TLATE |
| C | LE | O | ST | WB |
| CD | LM | RB | STD | X |
| CE | LMD |  |  |  |

6. In the Model 8/32 Processor fullword data read/write on a halfword boundary forces the address to the fullword boundary and then the data is read/written. The machine gives no indication of this occurring, except that fetched/stored fullword data is incorrect.

In the current Model 7/32, fullword data read/write on a halfword boundary causes the data to be read from/written into the consecutive halfwords.
7. Memory Access Controller (MAC): In the Model $7 / 32$ the MAC is optional and traps 256 bytes. For Model 8/32, the MAC is part of the basic prosessor and tapes 72 bytes. Refer to Chapter 8.
8. On the average, the Model 8,32 is 2 to 2.5 times faster than the Model $7 / 32$.

NOTE
For a detailed description of the Model 7/32, refer to the Model 7/32 Processor User's Manual, Publication Number 29-405.

## PROCESSOR

The Central Prosessing Unit (CPU), or Processor, controls activities in the system. Refer to Figure 1-1. It executes instructions in a specific sequence and performs arithmetic and logical functions. Included in the Processor's components are:

Program Status Word register
General registers Floating point registers Hardware multiply and divide Floating point hardware

## Program Status Word

The 64 bit Program Status Word (PSW) defines the state of the Processor at any given time. (See Figure 1-2.)


Figure 1-2. Program Status Word

Bits 0:31 are reserved for status information and interrupt masks. Bits 40:63 contain the Location Counter. Unassigned Program Status Word bits must not be used and must always be zero. Status information and interrupt mask bits are defined as follows:

| Bit 16 | Wait state |
| :--- | :--- |
| Bit 17 | Immediate interrupt/Auto Driver Channel (ADC) Mask |
| Bit 18 | Machine malfunction interrupt mask |
| Bit 19 | Arithmetic fault interrupt mask |
| Bit 20 | Immediate Interrupt/ADC mask |
| Bit 21 | Relocation/protection interrupt mask |
| Bit 22 | System queuc service interrupt mask |
| Bit 23 | Protect mode |
| Bits 24:27 | Register set select bits |
| Bits 28:31 | Condition Code |

## Wait State (W)

When this bit is set, the Processor halts normal program execution. It is still responsive to machine malfunction and immediate interrupts, if enabled.

## Immediate Interrupt/Auto Driver Channel Mask (I)

Program Status Word Bits 17 and 20 together define the enable state of the Processor to requests for service from devices on the Multiplexor Bus. Interrupt requests from external devices are arranged on four priority levels. Level zero is the highest priority; Level three is the lowest. When interrupts on any levels are enabled, the Processor is responsive to interrupt requests on those levels. When interrupts on any levels are disabled, interrupt requests on those levels are queued until the Processor is able to recognize them. Refer to Chapter 6 for details of Immediate Interrupt processing.

## Machine Malfunction Interrupt Mask (M)

This bit controls interrupts generated when power fails, when power returns, when parity ehecking indicates a memory parity error, or when fullword data is read/written on halfword boundary.

## Arithmetic Fault Interrupt Mask (A)

This bit controls internal interrupts caused by arithmetic faults: fixed-point quotient overflow or division by zero; or floating point overflow, underflow, or division by zero. If this bit is set, the interrupt is taken. If it is reset, the error condition is ignored.

## Relocation Protection Interrupt Mask (R/P)

This bit serves two purposes. It enables the memory access and protect controller so that program addresses are automatically relocated. It also enables the relocation/protection interrupt which is generated by the memory access and protect controller.

## System Queue Service Interrupt Mask (Q)

This bit controls the interrupt generated when the system queue requires service. Refer to Chapter 6.

## Protect Mode (P)

The Prosessor operates in either the Supervisor or User mode. The state is determined by this bit. If it is set, the Processor is in the protect mode, and only non-privileged instructions may be exeeuted, to protect the integrity of the system. If this bit is reset, the Processor is in the Supervisor mode, and the currently running program may execute any legal instruction.

## Reaister Set Select (R)

Bits 24:27 of the Program Status Word are used to designate the current register set. All Series 32 machines have at least two register sets. Register sets are numbered 0 through 15. When fewer than 16 sets are implemented, the last set is always nambered 15 . The Model $8 / 32$ may have 2 or 8 sets of general registers. (See Figure 1-3).

## Condition Code (CVGL)

Bits 28:31 of the Program Status Word contain the Condition Code. As part of the execution of certain instructions, the state of the Condition Code may be changed to indicate the nature of the result. Not all instructions affect the Condition Code. The state of the Condition Code may be tested with Conditional Bransh instructions. Nach bit in the Condition Code is set if the corresponding condition oceurred on the last instruction. The normal interpretation of these bits is:

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 |
| 0 | 1 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 0 | 0 | 1 |

Arithmetic carry, or borrow, or shifted earry Arithemtic overflow
Greater than zero
Less than zero

## Location Counter (LOC)

The Location Counter controls the sequencing of instruction execution. In normal sequential operation, the Location Counter contains the address of the next instruction to be executed. The instruction is fetched from memory. While the instruction is being executed, the Location Counter is incremented by either two, or four, or six, depending on the length of the instruction. Upon completion of instruction execution, the next instruction is fetched from the location specified by the incremented Location Counter, and the process is repeated.

This sequential mode of operation is altered by Branch instructions, the Load Program Status Word (LPSW and LPSWR) instructions, and by interrupts. Branch instructions cause the Location Counter to be roplaced by a new value derived from the instruction. The LPSW and LPSWR instrustions, and interrupts cause the entire Program Status Word to be replaced by a new Program Status Word.

| REGISTER SET <br> NUMBER | DESIGNATION |
| :---: | :---: |
| 0 | EXECUTIVESET |
|  | OPTIONAL <br> REGISTER <br> SETS |
| 7 8 9 10 11 12 13 14 | UNIMPLEMENTED <br> SETS |
| 15 | USER SET |

Figure 1-3. Register Set Numbering

## GENERAL REGISTERS

The Model $8 / 32$ can have either 2 or 8 register sets. If there are only 2 sets present, they are numbered 0 and 15. If there are 8 register sets, they are numbered 0 through 6 and 15 . (see Figure 1-3.) Each register is 32 bits wide. Register set selection is determined by the state of Bits $24: 27$ of the current Program Status Word. Registers 1 through 15 of any set may be used as index registers.

When interrupts occur, the Processor loads pertinent information into preselected registers of the register set selected by the new program status word. The details of this operation are described in Chapter 6. Register set 15, the user set, does not have any specific functional assignments.

## Floating Point Registers

There are eight optional single-precision floating point registers, each 32 bits wide. The registers are identified by the even numbers 0 through 14. Floating point operations must always specify the registers with even numbers.

There are eight optional double-precision floating point registers each 64 bits wide. These registers are identified by the even numbers 0 through 14, and are completely separate from the single-precision floating point registers.

## Processor Interrupts

Interrupt conditions cause the entire Program Status Word to be replaced by a new Program Status Word, thus breaking the usual sequential flow of instruction exccution. When an interrupt. condition occurs, the Processor saves its current Program Status Word either in memory or in a pair of general registers belonging to the register set selected by the new PSW. It loads information related to the interrupt condition in other registers of this same set. It loads a new Program Status Word from a memory location reserved for the specific interrupt condition. (The immediate interrupt is an exception to the rule. The status portion of the new Program Status Word, Bits 0:31, is forced to a preset value. The Location Counter is loaded from a memory location reserved for the interrupting device. Refer to Chapter 6 for details on interrupt processing.)

## Reserved Memory Locations

The following memory locations are reserved for interrupt pointers, Program Status Words, and system constants.

| $\mathrm{X}^{\prime} 000000^{\prime}$ | - $\mathrm{X}^{\prime} 00001 \mathrm{~F}^{\prime}$ | Reserved (Single Precision Floating Point Register, if equipped, Save Area) |
| :---: | :---: | :---: |
| $\mathrm{X}^{\prime} 000020^{\prime}$ | - X'000027' | Machine malfunction interrupt old PSW |
| $\mathrm{X}^{\prime} 000028^{*}{ }^{*}$ | - X'00002F' | Not used, must be zero |
| $\mathrm{X}^{\prime} 000030^{\prime}$ | - X'000037' | Illegal instruction interrupt new PSW |
| $\mathrm{X}^{\prime} 000038^{\prime}$ | - X'00003F' | Machine malfunction interrupt new PSW |
| $\mathrm{X}^{\prime} 000040^{\prime}$ | - X'000047' | Not used, must be zero |
| $\mathrm{X}^{\prime} 000048^{\prime}$ | - $\mathrm{X}^{\prime} 00004 \mathrm{~F}^{\prime}$ | Arithmetic fault interrupt new PSW |
| $\mathrm{X}^{\prime} 000050^{\prime}$ | - X'00007F' | Bootstrap loader and device definition table |
| $\mathrm{X}^{\prime} 000080^{\prime}$ | - X'000083' | System queue pointer |
| $\mathrm{X}^{\prime} 000084^{\prime}$ | - X'000085 ${ }^{\prime}$ | Power Fail PSW save pointer |
| $\mathrm{X}^{\prime} 000086^{\prime}$ | - X'000087' | Power Fail Register save pointer |
| $\mathrm{X}^{\prime} 000088^{\prime}$ | - $\mathrm{X}^{\prime} 00008 \mathrm{~F}^{\prime}$ | System queue service interrupt new PSW |
| $\mathrm{X}^{\prime} 000090^{\prime}$ | - X'000097' | Relocation/protection interrupt new PSW |
| $\mathrm{X}^{\prime} 000098^{\prime}$ | - $\mathrm{X}^{\prime} 00009 \mathrm{~B}^{\prime}$ | Supervisor call new PSW status |
| $\mathrm{X}^{\prime} 00009 \mathrm{C}^{\prime}$ | - $\mathrm{X}^{\prime} 0000 \mathrm{BB}^{\prime}$ | Supervisor call inter rupt now PSW location counter values |
| $\mathrm{X}^{\prime} 0000 \mathrm{BC}{ }^{\prime}$ | - $\mathrm{X}^{\prime} 0000 \mathrm{CF}^{\prime}$ | Not used, must be zero |
| $\mathrm{X}^{\prime} 0000 \mathrm{D} 0^{\prime}$ | - $\mathrm{X}^{\prime} 0002 \mathrm{CF}{ }^{\prime}$ | Interrupt service pointer table |
| $\mathrm{X}^{\prime} 0002 \mathrm{D} 0^{\prime}$ | - $\mathrm{X}^{\prime} 0004 \mathrm{CF}{ }^{\prime}$ | Expanded interrupt service pointer table |
| X'0004D0' | - $\mathrm{X}^{\prime} 0008 \mathrm{CF}{ }^{\prime}$ | Expanded interrupt service pointer table |

These reserved locations play an important role in both interrupt and input/output processing. For details on these subjects refer to Chapters 6 and 7. In addition to the above, certain locations are reserved for use by the Memory Access Controller. Refer to Chapter 8 for details.

The power down save areas for general registers and PSW must be completely contained within the first 64 KB of memory. All new location Counter values are subject to MAC relocation if the new PSW enables MAC (Bit $21=1$ ). All other pointers contain absolute addresses not subject to MAC relocation.

## Processor Operations

Fixed point arithmetic and logical operations are performed between:
The contents of two fullword registers.
The contents of a fullword register and the contents of a fullword located in memory.
The contents of a fullword register and the contents of a halfword located in memory.
Where the second operand is contained in memory, it may be located in the instruction stream (immediate operation), or it may be located in indexed storage.

In fixed point arithmetic and logical operations between a fullword register and a halfword operand in memory, the halfword operand is expanded to a fullword by propagating the most significant bit into the high order bits before the operation is started. This permits the use of halfword to fullword operations with consistent results, and it provides space economy in that small values do not require fullword locations.

Arithmetic operations on fixed point halfword quantities may produce results that are not entirely consistent with the results that arc obtained in a 16 bit Processor. Where this is a problem, the Convert to Halfword Value Register Instruction (CHVR) may be used to adjust the result and the Condition Code so that they are consistent with the same operations in a 16 bit Processor.

Floating point operations take place between the contents of two floating point registers, or between the contents of a floating point register and a floating point operand contained in a fullword or double word in memory. Following floating point operations, the Condition Code is set to indicate the nature of the result.

## DATA FORMATS

The Processor performs logical and arithmetic operations on single bits, 8 bit bytes, 16 bit halfwords, 32 bit fullwords, and 64 bit double words. This data may represent a fixed point number, a floating point number, or logical information.

## Fixed Point Data

Fixed point arithmetic operands may be either 16 bit halfwords or 32 bit fullwords. In fullword multiply and divide operations, 64 bit operands are manipulated. Fixed point data are treated as 15 bit signed integers in the halfword format, and as 31 bit signed integers in the fullword format. Positive numbers are expressed in true binary form with a Sign bit of zero. Negative numbers are represented in two's complement form with a Sign bit of one. The numerical value of zero is represented with all bits zero. Refer to Chapter 4 for details on fixed point data representation.

## Floating Point Data

A floating point number consists of a signed exponent and a signed fraction. The quantity expressed by this number is the product of the fraction and the number 16 raised to the power represented by the exponent. Each floating point value requires a 32 bit fullword or a 64 bit double word, of which eight bits are used for the sign and exponent, and the remaining bits are used for the fraction. Refer to Chapter 5 for details on floating point data representation.

## Logical Data

Logical operations manipulate 8 bit bytes, 16 bit halfwords, and 32 bit fullwords. In addition, it is possible to perform logical operations on single bits located in bit arrays. Refer to Chapter 2 for details on logical data representation.

## DATA ALIGNMENT

Locations in main memory are numbered consectively, beginning at address ' 00000 '. While it is said that memory is addressable and alterable to the byte level, machine accesses to memory involve only halfwords or fullwords. Those instructions that require a single byte access actually access a halfword and then manipulate the appropriate byte within the halfword.

Because memory can only be accessed to the halfword level, bit 31 of the address is truncated at the memory. A halfword fetch at address '00051' gives you exactly the same halfword as you get when you access location $\mathrm{X}^{\prime} 00050^{\prime}$. There is also no mechanism for warning the program that it is accessing halfwords on the odd byte boundary.

The CAL Assembler will generate an error flag if it sees halfword operations directed to an odd byte address. It also generates an error flag if it sees fullword operations directed to other than a fullword address.

Bytes of information are addressed by their specific hexadecimal address. Two bytes form a halfword. Halfwords have an even address, the address of the left most byte in the pair. Two halfwords comprise a fullword. The address of a fullword is a multiple of 4 (four bytes) and it is the address of the left most halfword in the pair. The hardware actually truncates the least significant two address bits on fullword accesses, forcing proper alignment. In later versions of the $8 / 32$, a machine malfunction interrupt is generated if a fullword access is directed to an address that has bit 30 set. The memory doesn't see bit 31 , so no error is generated for a fullword access to address '00301' for example. Addresses '00302' and '00303', however, will generate the interrupt.

Two fullwords form a double word. The address of a double word is a multiple of 8 (8bytes) and is the address of the left most fullword in the pair. For the present, double word alignment is imposed only by the CAL Assembler and is not a genuine hardware restriction.

User Level instructions are always aligned on halfword boundaries. Any halfword address is valid regardless of the size of the instruction word.

Most instructions in the extended series may be expressed in two or more formats. This feature provides flexibility in data organization and instruction sequencing.

When working with the Interdata Common Assembler Language (CAL) assembler, it is not necessary to specify the instruction format explicitly. The assembler chooses the most economical format and supplies the required bits in the machine code. When double indexing is implicd, the assembler always chooses the RX3 format. Refer to the Common Assembler Language (CAL) Manual, Publication Number 29-375.

## Branch Instruction Formats

The Branch instructions use the RR, SF, and all variations on the RX formats. However, in the Conditional Branch instructions, the R1 field does not specify a register. Instead, it contains a mask value (labelled M1 in the instruction descriptions), which is tested with the Condition Code. The INTERDATA CAL assembler provides a series of Extended Branch Mnemonics which make it possible to specify a Conditional Branch without specifying the mask value explicitly. For a summary of the Extended Branch Mnemonics, see Appendix 4.

## Programming Examples

Each of the following programming examples refers to the sample assembly language program shown in Figure 1-5. Note the use of symbolic equates for general registers. Machine code generated and the result of each instruction are dependent upon the physical and logical placement of the instructions, respectively.

Register to Register (RR) Format


In this 16 bit format, Bits $0: 7$ contain the operation code. Bits 8:11 contain the R1 field, and Bits $12: 15$ contain the R2 field. In most RR instructions, the register specified by R1 contains the first operand, and the register specified by R2 contains the second operand. For example:


Short Form (SF) Format


This 16 bit format provides space economy when working with small values. Bits $0: 7$ contain the operation code. Bits 8:11 contain the R1 field. Bits 12:15 contain the N field. In arithmetic and logical operations, the register specified by R1 contains the first operand. The N field contains a four bit immediate value $(0: 15)$ used as the second operand. For example:

Machine Code


Label
SF

First Operand
Load Immediate Short "LIS' Instruction Op-Code


Figure 1-5. 32-Bit Instruction Format Examples
(CAL Assembly Listing)


This is a 32 bit format in which Bits $0: 7$ contain the operation code, Bits 8:11 contain the R1 field, Bits 12:15 contain the X2 field, Bits 16 and 17 must be zero, and Bits 18:31 contain the D2 field. In general, the register specified by R1 contains the first operand. The second operand is located in memory at the address obtained by adding the contents of the second operand index register, specified by X2, and the 14 bit absolute address contained in the D2 field. For example:

| Machine Code | Label | Assembler Notation |
| :---: | :---: | :---: |
| $4050 \quad 1000$ | RX1. EX1 | STII R5, X ${ }^{\prime} 1000^{\prime}$ |
|  | Defines Second Operand Address |  |
|  | No Index Register Specified |  |
|  | First Operand |  |
|  | Store Hallword 'STH' Instruction |  |

The Second Operand address is calculated as follows:
Bits


No indexing is specified. Therefore, the second operand address is $\mathrm{X}^{\prime} 1000^{\prime}$.

| Machine Code | Label | Assembler Notation |
| :---: | :---: | :---: |
| 4056 0FF2 | RX1.EX2 | STH R5, X'0FF2'(R6) |
| Defines Second Operand Address |  |  |
| Register 6 to be used for Indexing |  |  |
| First Operand |  |  |

The Second Operand address is calculated as follows:


Second Operand Address
$=$ contents of D2 field + contents of the Index Register 6 (see Figure 1-5)
$=X^{\prime} 0 F F 2^{\prime}+Y^{\prime} 0000000 E^{\prime}$
$=Y^{\prime} 00001000^{\prime}$


This format provides relative addressing capability in a 32 bit instruction word. Bits 0:7 contain the operand code. Bits $8: 11$ contain the R1 specification. Bits $12: 15$ contain the X2 specification. Bit 16 must always be one. Bits $17: 31$ contain the relative displacement, D2.

In the RX2 format, the register specificd by $R 1$ contains the first operand. The address of the second operand, in memory, is calculated by adding the value contained in the incremented location counter (the address of the next sequential instruction) and the sum of (1) the 32-bit representation of the 15 -bit signed number contained in the D 2 field, and (2) the contents of the index register specified by X2. Negative numbers in the D2 field are expressed in two's complement notation. For example:


The Second Operand address is calculated as follows:


Second Operand Address
$=32-$ bit Expansion of contents of D2 field + contents of incremented Location Counter (see Figure 1-5).
$=Y^{\prime} 00000004^{\prime}+Y^{\prime} 00000010^{\prime}$
$=Y^{\prime} 00000014^{\prime}$


The Second Operand address is calculated as follows:

Bits


Second Operand Address
$=32-$ bit Expansion of contents of D2 field + contents of incremented Location Counter (see Figure 1-5).
$=Y^{\prime}$ FFFFFFE4 ${ }^{\prime}+Y^{\prime} 00000030^{\prime}$
$=Y^{\prime} 00000014^{\prime}$


The Second Operand address is calculated as follows:

Bits


Second Operand Address
$=32-$ Bit Expansion of D2 field + contents of incremented Location Counter + contents of Index Register 6 (See Figure 1-5).
$=Y^{\prime}$ FFFFFFD2' $+Y^{\prime} 00000034^{\prime}+Y^{\prime} 0000000 \mathrm{E}^{\prime}$
$=Y^{\prime} 00000014^{\prime}$


This is a 48 bit format in which double indexing is permitted. Bits $0: 7$ contain the operation code. Bits $8: 11$ contain the R1 specification. Bits $12: 15$ contain the first index specification, FX2. Bit 16 must be zero. Bit 17 must be one. Bits $18: 19$ must be zero. Bits $20: 23$ contain the second index specification, SX2. Bits $24: 47$ contain a 24 bit address, A2. Second level indexing is allowed even if first level indexing is not specified.

In general, the first operand is contained in the register specified by R1. The second operand is located in memory. Its memory address is obtained by adding the contents of the first index register and the contents of the second index register, and then adding to this result the contents of the A2 field. For example:


The Second Operand address is calculated as follows:


Second Operand Address
$=$ Contents of A2 field
$=Y^{\prime} 00010000^{\prime}$


The Second Operand address is calculated as follows:

Bits


Second Operand Address
$=$ contents of A2 field + contents of Index Register 6

+ contents of Index Register 5 (see Figure 1-5).
$=\mathrm{Y}^{\prime} 0001 \mathrm{FFE} 4^{\prime}+\mathrm{Y}^{\prime} 0000000 \mathrm{E}^{\prime}+\mathrm{Y}^{\prime} 0000000 \mathrm{E}^{\prime}$
$=\mathrm{Y}^{\prime} 00020000^{\prime}$
Register and Immediate Storage One (RI1) Format


This format represents a 32 bit instruction word. Bits 0:7 contain the operation code. Bits 8:11 contain the R1 specification. Bits 16:31 contain the 16 bit immediate value, I2.

In this format, the register specified by R1 contains the first operand. The 32 -bit effective second operand is obtained by adding together the 32 -bit representation of the signed 16 -bit value contained in the I2 field, and the contents of the register specified by X2. For example:


The Second Operand is calculated as follows:


Sign Bit
Second Operand
$=32$-Bit representation of $\mathrm{X}^{\prime} 8000^{\prime}$
$=Y^{\prime}$ FFFF8000'

| Machine Code | Label | Assembler Notation |
| :---: | :---: | :---: |
| C895 8000 | RI1. EX2 | LHI R9, $\mathrm{X}^{\prime} 8000{ }^{\prime}$ (R5) |
|  | V alue |  |
|  | Specified |  |
|  |  |  |

The Second Operand is calculated as follows:

Bits $\quad$| 16 | 20 | 24 | 27 |
| :--- | :--- | :--- | :--- |
| 1000 | 0000 | 0000 | 0000 |

Sign Bit
Second Operand

```
= 32-Bit representation of X'8000' + the contents of Index Register 5 (See Figure 1-5).
= Y'FFFF8000'+ Y'00000000E'
= Y'FFFF800E'
```

Register and Immediate Storage Two (RI2) Format

| 0 | ${ }^{7}$ | 11 |  |  |
| :--- | :--- | :--- | :--- | :--- |
| OP | $R 1$ | $\times 2$ |  |  |

This is a 48 bit instruction format. Bits $0: 7$ contain the operation code. Bits 8:11 contain the R1 specification. Bits 12:15 contain the X2 specification. Bits $16: 47$ contain the 32 bit immediate value, I2.

The first operand is contained in the register specified by R1. The second operand is obtained by adding the contents of the index register, specified by X 2 , and the 32 bit immediate value contained in the I2 field. For example:

| Machine Code |  | Label | Assembler Notation |
| :---: | :---: | :---: | :---: |
| F8A0 0000 | 8000 | RI2. EX1 | LI R10, $\mathrm{X}^{\prime} 8000{ }^{\prime}$ |
|  | - | Field |  |
|  |  | Specified |  |
|  | - |  |  |

The Second Operand is calculated as follows:

Bits


Second Operand
$=$ Contents of I2 Field
$=Y^{\prime} 00008000{ }^{\prime}$


The Second Operand is calculated as follows:

Bits


Second Operand
$=$ Contents of I2 Field + contents of Index Register 10 (See Figure 1-5).
$=\mathrm{Y}^{\prime} 00017 \mathrm{FFE}^{\prime}+\mathrm{Y}^{\prime} 00008000^{\prime}$
$=Y^{\prime} 0001 \mathrm{FFFE}$

## CHAPTER 2 LOGICAL OPERATIONS

The set of logical instructions provides a means for the manipulation of binary data. Many of the instructions grouped with the logical set may also be used in arithmetic and other operations. These instructions include loads, stores, compares, shifts, list processing, translation, and cyclic redundancy checks.

## DATA FORMATS

Logical data can be organized as bytes, halfwords, fullwords, or bit arrays of up to $2^{31}$ bits as shown in Figure 2-1.


Figure 2-1. Logical Data

## OPERATIONS

In logical operations between the contents of a general register and a halfword operand, the halfword operand is expanded to a fullword before the operation starts. The halfword is expanded by propagating the most significant bit through Bits 15:0 of the fullword.

## Boolean Operations

The Boolean operators AND, OR, and Exclusive OR (XOR) operate on halfword and fullword quantities. All bits in both operands participate individually. The Boolean functions are defined as follows:

| 0 AND $0=0$ |  |
| :--- | :--- |
| 0 AND $1=0$ | (logical product) |
| 1 AND $=0$ |  |
| 1 AND $1=1$ |  |
| 0 OR $0=0$ |  |
| 0 OR $1=1$ |  |
| 1 OR $0=1$ |  |
| 1 OR $1=1$ |  |
| 0 XOR $0=0$ |  |
| 0 XOR $1=1$ |  |
| 1 XOR $0=1$ |  |
| 1 XOR $1=0$ |  |

## Translation

The translate instruction is used to translate a character directly, or to effect an unconditional branch to a special translate subroutine. Associated with the translate instruction is a translation table. The entries in the table are halfwords as shown in Figure 2-2.


Figure 2-2. Translation Table Entry

The character to be translated is a byte of logical data. This unsigned quantity is doubled and used as an index into the table. If the corresponding entry has a one in bit Position zero, then Bits $8: 15$ contain the character to be substituted for the data character. If there is a zero in bit Position zero, then Bits $1: 15$ contain the address, divided by two, of the translate routine. When the translate instruction results in a branch, this value is doubled to produce the address of the routine. Because this result is a 16 bit address, the software routine must be located in the first 64 KB of the program. (The program can reside anywhere in memory if it is relocated by the Memory Access Controller (MAC). The translate table can contain up to 256 entries. However, if the data characters are always less than eight bits, fewer entries are required.

## List Processing

The list processing instructions manipulate a circular list as defined in Figure 2-3.


Figure 2-3. Circular List Definition

The first four halfwords contain the list parameters. Immediately following the parameter block is the list itself. The first fullword in the list is designated Slot 0 . The remaining slots are designated $1,2,3$, etc., up to a maximum slot number which is equal to the number in the list minus one. An absolute maximum of 65,535 fullword slots may be specified. (Slots are designated 0 through X'FFFE'.)

The first parameter halfword indicates the number of slots (fullwords) in the entire list. The second parameter halfword indicates the current number of slots being used. When this halfword equals zero, the list is empty. When this halfword equals the number of slots in the list, the list is full. Once initialized, this halfword is maintained automatically. It is incremented when elements are added to the list and decremented when elements are removed.

The third and fourth halfwords of the list parameter block specify the current top of the list and the next bottom of the list respectively. These pointers are also updated automatically. See Figure 2-4.


Figure 2-4. Circular List

## LOGICAL INSTRUCTION FORMATS

The logical instructions use the Register to Register (RR), the Register and Indexed Storage (RX), and the Register and Immediate Storage (RI) instruction formats.

## LOGICAL INSTRUCTIONS

The instructions described in this section are:

| L | Load | OI | OR Immediate |
| :--- | :--- | :--- | :--- |
| LR | Load Register | OH | OR Halfword |
| LI | Load Immediate | OHI | OR Halfword Immediate |
| LIS | Load Immediate Short | X | Exclusive OR |
| LCS | Load Complement Short | XR | Exclusive OR Register |
| LH | Load Halfword | XI | Exclusive OR Immediate |
| LHI | Load Halfword Immediate | XH | Exclusive OR Halfword |
| LA | Load Address | XHI | Exclusive OR Halfword Immediate |
| LRA | Load Real Address | TI | Test Immediate |
| LHL | Load Halfword Logical | THI | Test Halfword Immediate |
| LM | Load Multiple | SLI | Shift Left Logical |
| LB | Load Byte | SLLS | Shift Left Logical Short |
| LBR | Load Byte Register | SRL | Shift Right Logical |
| EXHR | Exchange Halfword Register | SRLS | Shift Right Logical Short |
| EXBR | Exchange Byte Register | SLHL | Shift Left Halfword Logical |
| ST | Store | SLHLS | Shift Left Halfword Logical Short |
| STH | Store Halfword | SRHL | Shift Right Halfword Logical |
| STM | Store Multiple | SRHLS | Shift Right Halfword Logical Short |
| STB | Store Byte | RLL | Rotate Left Logical |
| STBR | Store Byte Register | RRL | Rotate Right Logical |
| CL | Compare Logical | TS | Test and Set |
| CLR | Compare Logical Register | TBT | Test Bit |
| CLI | Compare Logical Immediate | SBT | Set Bit |
| CLH | Compare Logical Halfword | CBT | Complement Bit |
| CLHI | Compare Logical Halfword Immediate | RBT | Reset Bit |
| CLB | Compare Logical Byte | CRC12 | Cyclic Redundancy Check Modulo 12 |
| N | AND | CRC16 | Cyclic Redundancy Check Modulo 16 |
| NR | AND Register | TLATE | Translate |
| NI | AND Immediate | ATL | Add to Top of List |
| NH | AND Halfword | ABL | Add to Bottom of List |
| NHI | AND Halfword Immediate | RTL | Remove from Top of List |
| O | OR | RBL | Remove from Bottom of List |
| OR | OR Register |  |  |

## INSTRUCTIONS

Load (L)
Load Register (LR)
Load Immediate (LI)
Load Immediate Short (LIS)
Load Complement Short (LCS)

## Assembler Notation

| L | R1, D2 (X2) |
| :--- | :--- |
| L | R1, A2 (FX2, SX2) |
| LR | R1, R2 |
| LI | R1, I2 (X2) |
| LIS | R1, N |
| LCS | R1, N |

Op-Code
58 58
08
F8
24
25

## Format

RX1, RX2
RX3
RR
RI2
SF
SF

## Operation

The second operand replaces the contents of the register specified in R1.

## Condition Code

| C | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Value is ZERO
Value is not ZERO
Value is not ZERO

## Programming Notes

The Load Immediate Short instruction causes the four bit second operand to be expanded to a 32 bit fullword with high order bits forced to ZERO. This fullword replaces the contents of the register specified by R1.

The Load Complement Short instruction causes the four bit second operand to be expanded to a 32 bit fullword with high order bits forced to ZERO. The two's complement value of this fullword replaces the contents of the register specified by R1.

When the Load instructions operate on fixed point data, the Condition Code indicates ZERO (no flags), negative (L flag), or positive (G flag) value.

In the RR format, if R1 equals R2, the Load instruction functions as a test on the contents of the register.

In the RX formats, the second operand must be located on a fullword boundary.

## Example LCS

| Assembler Notation | Machine Code |  |
| :---: | :---: | :---: |
| LCS $\quad$ REG8, 7 | 2587 | $\frac{\text { Comments }}{}$ |

## Result of LCS Instruction:

$($ REG8) $=$ FFFF FFF9
Condition Code $=0001 \quad(\mathrm{~L}=1)$

## INSTRUCTIONS

Load Halfword (LH)
Load Halfword Immediate (LHI)

## Assembler Notation

| LH | R1, D2 (X2) |
| :--- | :--- |
| LH | R1, A2 (FX2, SX2) |
| LHI | R1, I2 (X2) |

Op-Code
48
48
C8

Format
RX1, RX2
RX3
RII

## Operation

The halfword second operand is expanded to a fullword by propagating the most significant bit through Bits 15:0. This fullword replaces the contents of the register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Value is ZERO
Value is not ZERO
Value is not ZERO

## Programming Notes

When the Load Halfword instructions operate on fixed point data, the Condition Code indicates zero (no flags), negative (L flag), or positive (G flag) value.

In the RX formats, the second operand must be located on a halfword boundary.
In the RI1 format, the 16 -bit I2 field is extended to a fullword by propagating the sign bit through bits 0:15. The contents of the index register specified by X2 are then added to form the fullword second operand.

Load Address (LA)

Assembler Notation

| LA | R1, D2 (X2) |
| :--- | :--- |
| LA | R1, A2 (FX2,SX2) |

Op-Code
E6
E6

Format
RX1, RX2
RX3

## Operation

The effective address of the second operand ( 24 bits) replaces Bits $8: 31$ of the register specified by R1. Bits 0:7 of the register specified by R1 are forced to ZERO.

## Condition Code

Unchanged

## Programming Note

The length of the address quantity depends on the internal structure of the particular machine. Thus, in a Processor with a maximum address length of 20 bits, the calculated address replaces bits $12: 31$ of the register specified by R1, and bits $0: 11$ are forced to ZERO. In a Processor with maximum address length of 24 bits, the calculated address replaces bits $8: 31$ of the register specified by R1, and bits 0:7 are forced to ZERO.

## INSTRUCTION

Load Real Address (LRA)

| Assembler Notation |  | Op-Code | Format |
| :---: | :---: | :---: | :---: |
| LRA | R1, D2 (X2) | 63 | RX1, RX2 |
| LRA | R1, A2 (FX2, SX2) | 63 | RX3 |

## Operation

This instruction simulates the operation of a memory access controller. (Refer to Chapter 8 for a detailed description of MAC.) The register specified by R1 contains a program address (not relocated). The second operand address points to a relocation/protection module parameter block.

The address contained in the register specified by R1 is relocated, using the appropriate parameters. The relocated address replaces the contents of the register specified by R 1 .

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| I | 0 | 0 | 0 |

> No restrictions
> Not exccutable
> Not writable
> Not present
> Not mapped (Limit violation)

The condition code is determined on a priority basis with Not Mapped having highest priority, Not Present second, Not Writable third, and Not Executable having lowest priority.

## Programming Note

If the address is not mapped or not present, the register specified by R1 is unchanged.
The second operand location must specify a fullword boundary.
This instruction is supported by the microcode revision R03 and above. It is therefore not supported in all the models.

## Example: LRA

This example performs an address translation in the same manner as the MAC.
For this example, Register 1 contains $\mathrm{X}^{\prime} 54341^{\prime}$, MACREG is the starting address of a copy of the MAC Register. The fifth fullword entry located at MACREG+X'14' contains X'0FF24170'.

| Assembler Notation | Machine Code |
| :---: | :---: |
| LRA $\quad$ REG1, MACREG | 63108100 |

Comments
The first digit of the 20 bit program address (5) is used to index into MACREG

## Result of LRA Instruction:

$($ REG1 $)=28441 \quad(24100+04341)$
MACREG = Unchanged
Condition Code $=0010$ (not writable)

## INSTRUCTION

Load Halfword Logical (LHL)
Assembler Notation

## Op-Code

 73 73
## Format

RX1, RX2
RX3

## Operation

The halfword second operand replaces Bits $16: 31$ of the register specified by R1. Bits $0: 15$ of the register specified by R1 are forced to ZERO.

## Condition Code



## Programming Note

The second operand must be located on a halfword boundary.

## INSTRUCTION

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :---: |
| LM | R1, D2 (X2) |  | RX1, RX2 |
| LM | R1, A2 (FX2, SX2) | D1 | RX3 |

## Operation

Successive registers, starting with the register specified by R1, are loaded from successive memory locations, starting with the location specified as the effective address of the second operand. Each register is loaded with a fullword from memory. The process stops when Register 15 has been loaded.

## Condition Code

Unchanged

## Programming Note

The second operand must be located on a fullword boundary.
The second operand address is formed before any registers are loaded. Therefore, X2, FX2, and SX2 can be among the registers loaded.

## INSTRUCTIONS

Load Byte (LB)
Load Byte Registex (LBR)

Assembler Notation
LB R1,D2 (X2)
LB R1, A2 (FX2,SX2)
LBR R1,R2

Op-Code
D3
D3
93

Format
RX1, RX2
RX3
RR

## Operation

The eight-bit second operand replaces the least significant bits (Bits 24:31) of the register specified by R1. Bits 0:23 of the register are forced to ZERO.

## Condition Code

Unchanged

## Proaramming Note

In the Load Byte Register instruction, the second operand is taken from the least significant eight bits (Bits 24:31) of the register specified by R2.

## INSTRUCTION

I
Exchange Halfword Register (EXHR)

| Assembler Notation | Op-Code | Format |  |
| :---: | :---: | :---: | :---: |
| EXHR | R1, R2 | 34 | RR |

## Operation

Bits 0:15 of the register specified by R2 replace Bits $16: 31$ of the register specified by R1. Bits 16:31 of the register specified by R2 replace Bits $0: 15$ of the register specified by R1.

## Condition Code

Unchanged

## Programming Note

If R1 equals R2, the two halfwords contained within the register are exchanged. If R1 does not equal R2, the contents of R2 are unchanged.

## Example: EXHR

| Assembler Notation |  | Machine Code |  | Comments |
| :--- | :--- | :--- | :---: | :---: |
| LI REG5, Y'0ABCDEF9' | F850 0ABC DEF9 | (REG 5) = 0ABCDEF9 |  |  |
| LI REG7, Y'12345678' | F870 12345678 | (REG 7) $=12345678$ |  |  |
| EXHR REG5, REG7 | 3457 |  |  |  |

Result of EXHR Instruction:
(REG 5) $=56781234$
$($ REG 7) $=12345678$
Condition Code $=$ Unchanged

## INSTRUCTION

Exchange Byte Register (EXBR)

Assembler Notation
EXBR R1,R2

## Op-Code

94

Format
RR

## Operation

The two eight-bit bytes contained in Bits 16:31 of the register specified by R2 are exchanged and loaded into Bits 16:31 of the register specified by R1. Bits 0:15 of the register specified by R1 are unchanged. The register specified by R2 is unchanged.

## Condition Code

Unchanged

## Programming Note

R1 and R2 may specify the same register. In this case, the two bytes in Bits 16:31 of the register specified by R2 are exchanged.

## Example: EXBR

| Assembler Notation |  | Machine Code |
| :--- | :--- | :--- |

## Result of EXBR Instruction:

$($ REG7 $)=5$ A6B3412
$($ REG3 $)=98761234$
Condition Code $=$ Unchanged

## INSTRUCTION

Store (ST)

Assembler Notation
ST R1,D2 (X2)
ST R1, A2 (FX2,SX2)

## Op-Code

50
50

Format
RX1, RX2
RX3

## Operation

The 32 bit contents of the register specified by R1 replace the contents of the memory location specified by the effective address of the second operand.

## Condition Code

Unchanged

## Programming Note

The second operand location must be on a fullword boundary.

## INSTRUCTION

- Store Halfword (STH)

| Assembler Notation | Op-Code | Format |  |
| :---: | :--- | :---: | :---: |
|  |  |  |  |
| STH | R1, D2 (X2) | 40 | RX1, RX2 |
| STH | R1, A2 (FX2, SX2) | 40 | RX3 |

## Operation

Bits 16:31 of the register specified by R 1 replace the contents of the memory location specified by the effective address of the second operand.

## Condition Code

Unchanged

## Programming Note

The second operand location must be on a halfword boundary.

## INSTRUCTION

Store Multiple (STM)

| Assembler Notation | Op-Code | Format |  |
| :---: | :--- | :---: | :---: |
|  |  |  |  |
| STM | R1, D2 (X2) | D0 | RX1, RX2 |
| STM | R1, A2 (FX2, SX2) | D0 | RX3 |

## Operation

The fullword contents of registers, starting with the register specified by R1, replace the contents of successive memory locations, starting with the location specified by the effective address of the second operand. The process stops when Register 15 has been stored.

## Condition Code

## Unchanged

## Programming Note

The second operand location must be on a fullword boundary.

## INSTRUCTIONS

Store Byte (STB)
Store Byte Register (STBR)

| Assembler Notation | Op-Code | Format |  |
| :---: | :--- | :---: | :---: |
|  |  |  |  |
| STB | R1, D2 (X2) | D2 | RX1, RX2 |
| STB | R1, A2 (FX2, SX2) | D2 | RX3 |
| STBR | R1, R2 | 92 | RR |

## Operation

The least significant eight bits (Bits 24:31) of the register specified by R1 are stored in the second operand location.

## Condition Code

Unchanged

## Programming Note

In the Store Byte Register instruction, the eight bit quantity is stored in Bits 24:31 of the register specified by R2. Bits 0:23 of the register are unchanged.

Example: STBR

| Assembler Notation |  | Machine Code |
| :--- | :--- | :--- |$\quad$| Comments |
| :--- |
| LI REG4, Y'13577531' |

## Result of STBR Instruction:

$($ REG4 $)=13577531$
$($ REG3 $)=24688631$
Condition Code $=$ Unchanged

## INSTRUCTIONS

Compare Logical (CL)
Compare Logical Register (CLR)
Compare Logical Immediate (C.LI)

Assembler Notation

| CL | R1, D2 (X2) |
| :--- | :--- |
| CL | R1, A2 (FX2, SX2) |
| CLR | R1, R2 |
| CLI | R1, I2 (X2) |

## Op-Code

| 55 | RX1, RX2 |
| :--- | :--- |
| 55 | RX3 |
| 05 | RR |
| F5 | RI2 |

## Operation

The first operand, the contents of the register specified by R1, is compared logically to the second operand. The result is indicated by the Condition Code setting. Neither operand is changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | X | 0 | 0 |
| 1 | X | 0 | 1 |
| L | X | 1 | 0 |
| 0 | X | 0 | 1 |
| 0 | X | 1 | 0 |

First operand equal to second First operand less than second First operand less than second First operand greater than second First operand greater than second

## Programming Note

In the RX formats, the second operand must be located on a fullword boundary.
The state of the V flag is undefined.
It is meaningful to check the following condition code mask (M1) after a logical comparison:

| Mask | True/False* | Inference |
| :---: | :--- | :--- |
|  | False | First operand equal to second |
| 3 | True | First operand not equal to second |
| 3 | False | First operand greater than second |
| 8 | True | First operand less than second |
| 8 |  |  |

*Refer to page 3-1 for True/False concept in branch instructions.

Compare Logical Halfword (CLH)
Compare Logical Halfword Immediate (CLHI)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :--- |
| CLH | R1, D2 (X2) |  |  |
| CLH | R1, A2 (FX2, SX2) | 45 | RX1, RX2 |
| CLHI | R1,I2 (X2) | 45 | RX3 |
|  |  | C5 | RI1 |

## Operation

The halfword second operand is expanded to a fullword by propagating the most significant bit through Bits 15:0. The first operand, the contents of the register specified by R1, is compared to this fullword. The result is indicated by the Condition Code setting. Neither operand is changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | X | 0 | 0 |
| 1 | X | 0 | 1 |
| I | X | 1 | 0 |
| 0 | X | 0 | 1 |
| 0 | X | 1 | 0 |

First operand equal to second First operand less than second First operand less than second First operand greater than second First operand greater than second

## Programming Note

In the RX formats, the second operand must be located on a halfword boundary.
In the RI1 format, the 16 -bit 12 field is extended to a fullword by propagating the sign bit through bits $0: 15$. The contents of the index register specified by X2 are then added to form the fullword second operand.

The state of the V flag is undefined.
It is meaningful to check the following condition code mask (M1) after a logical comparison:

| Mask | True/False* | Inference |
| :---: | :--- | :--- |
| 3 | False | First operand equal to second |
| 3 | True | First operand not equal to second |
| 8 | False | First operand equal to or greater than second |
| 8 | True | First operand less than second |

*Refer to page 3-1 for True/False concept in branch instructions.

## INSTRUCTION

- Compare Logical Byte (CLB)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :---: |
|  |  |  |  |
| CLB | R1, D2 (X2) | D4 | RX1, RX2 |
| CLB | R1, A2 (FX2, SX2) | D4 | RX3 |

## Operation

The byte quantity, contained in Bits 24:31 of the register specified by R1, is compared with the 8 -bit second operand. The result is indicated by the Condition Code setting. Neither operand is changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | X | 0 | 0 |
| 1 | X | 0 | 1 |
| 1 | X | 1 | 0 |
| 0 | X | 0 | 1 |
| 0 | X | 1 | 0 |

First operand equal to second First operand less than second First operand less than second First operand greater than second First operand greater than second

## Programming Note

It is meaningful to check the following condition code mask (M1) after a logical comparison:

| Mask | True/False* | Inference |
| :---: | :---: | :--- |
|  |  |  |
| 3 | False | First operand equal to second |
| 3 | True | First operand not equal to second |
| 8 | False | First operand equal to or greater than second |
| 8 | True | First operand less than second |

*Refer to page 3-1 for True/False concept in branch instructions.

## INSTRUCTIONS

AND (N)
AND Register (NR)
AND Immediate (NI)

## Assembler Notation

Op-Code
54
54
04
F4

Format
RX1, RX2
RX3
RR
RI2

Operation
The logical product of the 32 bit second operand and the contents of the register specified by R1 replace the contents of the register specified by R1. The 32 logical bit product is formed on a bit-by-bit basis.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Result is ZERO
Result is not ZERO
Result is not ZERO

## Programming Note

In the RX formats, the second operand must be located on a fullword boundary.
When operating on fixed-point data, the Condition Code indicates ZERO (no flags), negative ( L flag) or positive (G flag) result.

## INSTRUCTIONS

AND Halfword (NH)
AND Halfword Immediate (NHI)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :--- |
|  |  |  |  |
| NH | R1, D2 (X2) | 44 | RX1, RX2 |
| NH | R1, A2 (FX2, SX2) | 44 | RX3 |
| NHI | R1, I2 (X2) | C4 | RI1 |

## Operation

The halfword second operand is expanded to a fullword by propagating the most significant bit through Bits 15:0. The logical product of this 32 bit quantity and the contents of the register specified by R1 replace the contents of the register specified by R1. The 32 bit logical product is formed on a bit-by-bit basis.

## Condition Code

| $\mathbf{C}$ | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Result is ZERO
Result is not ZERO
Result is not ZERO

## Programming Note

In the RX formats, the second operand must be located on a halfword boundary.
In the RII format, the 16 -bit 12 field is extended to a fullword by propagating the sign bit through bits $0: 15$. The contents of the index register specified by X2 are then added to form the fullword second operand.

When operating on fixed-point data, the Condition Code indicates ZERO (no flags), negative (Lflag) or positive (G flag) result.

## INSTRUCTIONS

OR (O)
OR Register (OR)
OR Immediate (OI)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :--- |
|  |  |  |  |
| O | R1, D2 (X2) | 56 | RX1, RX2 |
| O | R1, A2 (FX2, SX2) | 56 | RX3 |
| OR | R1, R2 | 06 | RR |
| OI | R1, I2 (X2) | F6 | R12 |

## Operation

The logical sum of the 32 bit second operand and the contents of the register specified by R1 replace the contents of the register specified by R1. The logical sum is formed on a bit-by-bit basis.

## Condition Code

| $\mathbf{C}$ | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Result is ZERO
Result is not ZERO
Result is not ZERO

## Programming Note

In the RX formats, the second operand must be located on a fullword boundary.
When operating on fixed-point data, the Condition Code indicates ZERO (no flags), negative (L flag) or positive ( G flag) result.

## INSTRUCTIONS

OR Halfword ( OH )
OR Halfword Immediate (OHI)

## Assembler Notation

| OH | $\mathrm{R} 1, \mathrm{D} 2$ (X2) |
| :--- | :--- |
| OH | $\mathrm{R} 1, \mathrm{~A} 2$ (FX2, SX2) |

$\mathrm{OH} \quad \mathrm{R} 1, \mathrm{~A} 2$ (FX2,SX2)
OHI R1, I2 (X2)

Op-Code
46
46
C6

## Format

RX1,RX2
RX3
RI1

## Operation

The halfword second operand is expanded to a fullword by propagating the most significant bit through Bits 15:0. The logical sum of this 32 bit quantity and the contents of the register specified by R1 replace the contents of the register specified by R1. The 32 bit sum is formed on a bit-by-bit basis.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Result is ZERO
Result is not ZERO
Result is not ZERO

## Programming Note

In the RX formats, the second operand must be located on a halfword boundary.
In the RI1 format, the 16 -bit I2 field is extended to a fullword by propagating the sign bit through bits $0: 15$. The contents of the index register specified by $X 2$ are then added to form the fullword second operand.

When operating on fixed-point data, the Condition Code indicates ZERO (no flags), negative (L flag) or positive (G flag) result.

## NSTRUCTIONS

Exclusive OR (X)
Exclusive OR Register (XR)
Exclusive OR Immediate (XI)

## Assembler Notation

| X | $\mathrm{R} 1, \mathrm{D} 2$ (X2) |
| :--- | :--- |
| X | $\mathrm{R} 1, \mathrm{~A} 2$ (FX2, SX2) |
| XR | $\mathrm{R} 1, \mathrm{R} 2$ |
| XI | $\mathrm{R} 1, \mathrm{I} 2$ (X2) |

## Op-Code

57
57
07
F7

Format

RX1, RX2
RX3
RR
RI2

## Operation

The logical difference of the 32 bit second operand and the contents of the register specified by R1 replace the contents of the register specified by R1. The 32 bit difference is formed on a bit-by-bit basis.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Result is ZERO<br>Result is not ZERO<br>Result is not ZERO

## Programming Note

In the RX formats, the second operand must be located on a fullword boundary.
When operating on fixed-point data, the Condition Code indicates ZERO (no flags), negative (L flag) or positive (G flag) result.

## INSTRUCTIONS

Exclusive OR Halfword (XH)
Exclusive OR Halfword Immediate (XHI)

## Assembler Notation

| XH | $\mathrm{R} 1, \mathrm{D} 2$ (X2) |
| :--- | :--- |
| XH | $\mathrm{R} 1, \mathrm{~A} 2$ (FX2, SX2) |
| XHI | $\mathrm{R} 1, \mathrm{I} 2$ (X2) |

## Op-Code

47
47
C7

## Format

RX1, RX2
RX3
RI1

## Operation

The halfword second operand is expanded to a fullword by propagating the most significant bit through Bits 15:0. The logical difference of this 32 bit quantity and the contents of the register specified by R1 replace the contents of the register specified by R1. The 32 bit difference is formed on a bit-by-bit basis.

## Condition Code

| C | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Result is ZERO
Result is not ZERO
Result is not ZERO

## Programming Note

In the RX formats, the second operand must be located on a halfword boundary.
In the RII format, the 16 -bit 12 field is extended to a fullword by propagating the sign bit through bits $0: 15$. The contents of the index register specified by X2 are then added to form the fullword second operand.

When operating on fixed-point data, the Condition Code indicates ZERO (no flags), negative ( L flag) or positive (G flag) result.

Test Immediate (TI)

Assembler Notation

TI R1,I2 (X2)

## Op-Code

F3

Format

RI2

## Operation

Each bit of the second operand is logically ANDed with the corresponding bit in the register specified by R1. Neither operand is changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Result is ZERO
Result is not ZERO
Result is not ZERO

## Example: TI

This example tests if Bit 16 of Register 9 is set.
$($ REG 9$)=7$ EFBC 230

## Assembler Notation

TI R9, $\mathrm{Y}^{\prime} 09008009^{\prime}$

## Comments

Test Bit 16

## Result of TI Instruction

(REG 9) unchanged
Condition Code $=0010 \quad(\mathrm{G}=1)$

## INSTRUCTION

Test Halfword Immediate (THI)

Assembler Notation
THI R1,I2 (X2)

Op-Code

C3

Format

RI1

## Operation

The halfword second operand is expanded to a fullword by propagating the most significant bit through Bits 15:0. Each bit in this quantity is logically ANDed with the corresponding bit contained in the register specified by R1. Neither operand is changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Result is ZERO
Result is not ZERO
Result is not ZERO

## Programming Notes

When operating on fixed-point data, the Condition Code indicates ZERO (no flags), negative (L flag) or positive ( G flag) result.

In the RII format, the 16-bit I2 field is extended to a fullword by propagating the sign bit through bits $0: 15$. The contents of the index register specified by X 2 are then added to form the fullword second operand.

## INSTRUCTIONS

Shift Left Logical (SLL)
Shift Left Logical Short (SLLS)

## Assembler Notation

SLL R1, I2 (X2)
SLLS R1,N

Op-Code

ED
11

Format

RI1
SF

## Operation

The first operand, the contents of the register specified by R1, is shifted left the number of places specified by the second operand. Bits shifted out of Position 0 are shifted through the carry flag of the Condition Code and then lost. The last bit shifted remains in the carry flag. Zeros are shifted into Position 31.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| I | 0 | X | X |

Result is ZERO
Result is not ZERO
Result is not ZERO
Carry

## Programming Notes

In the RI formats, the shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31 .

In the SF format, the maximum shift count is 15 .
The state of the C flag indicates the state of the last bit shifted out of Position 0 .
If the second operand specifies a shift of zero places, the Condition Code is set in accordance with the value contained in the register. The C flag is reset in this case.

When the register specified by R1 contains fixed point data, the L flag set indicates a negative result, the G flag set indicates a positive result.

## INSTRUCTIONS

Shift Right Logical (SRL)
Shift Right Logical Short (SRLS)

Assembler Notation
SRL R1, I2 (X2)
SRLS R1, N

Op-Code
EC
10

Format

RI1
SF

## Operation

The first operand, the contents of the register specified by R 1 , is shifted right the number of places specified by the second operand. Bits shifted out of Position 31 are shifted through the carry flag of the Condition Code and then lost. The last bit shifted remains in the carry flag. Zeros are shifted into Position 0.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| B | 0 | X | X |

Result is ZERO
Result is not ZERO
Result is not ZERO
Carry

## Programming Notes

In the RIl format, the shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31 .

In the SF format, the maximum shift count is 15 .
The state of the C flag indicates the state of the last bit shifted out of Position 31.
When the register specified by R1 contains fixed point data, the $L$ flag set indicates a negative result, the G flag set indicates a positive result.

If the second operand specifies a shift of zero places, the Condition Code is set in accordance with the value contained in the register. The C flag is reset in this case.

## INSTRUCTIONS

Shift Left Halfword Logical (SLHL)
Shift Left Halfword Logical Short (SLHLS)

## Assembler Notation

| SLHL | R1, I2 (X2) |
| :--- | :--- |
| SLHLS | R1,N |

## Op-Code

CD
91

## Format

RI1
SF

## Operation

Bits 16:31 of the register specified by R1 are shifted left the number of places specified by the second operand. Bits shifted out of Position 16 are shifted through the carry flag and lost. The last bit shifted remains in the carry flag. Zeros are shifted into Position 31. Bits $0: 15$ of the first operand remain unchanged.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| I | 0 | X | X |

Result is ZERO<br>Result is not ZERO<br>Result is not ZERO<br>Carry

## Programming Notes

The condition code setting is based on the halfword (bits $16: 31$ ) result.

In the Ril format, the shift count is specified by the least significant four bits of: the second operand. The maximum shift count is 15 .

The state of the C flag indicates the state of the last bit shifted out of Position 16.

When the register specified by R1 contains fixed point data, the L flag set indicates a negative result, the G flag set indicates a positive result.

If the second operand specifies a shift of zero places, the condition code is set in accordance with the value contained in bits 16:31 of the register. The C flag is reset in this case.

## INSTRUCTIONS

Shift Right Halfword Logical (SRHL)
Shift Right Halfword Logical Short (SRHLS)

## Assembler Notation

SRHL R1,I2 (X2)
SRHLS R1,N

Op-Code
CC
90

Format RI1 SF

## Operation

Bits 16:31 of the register specified by R1 are shifted right the number of places specified by the second operand. Bits shifted out of Position 31 are shifted through the carry flag and lost. The last bit shifted remains in the carry flag. Zeros are shifted into Position 16. Bits 0:15 of the first operand remain unchanged.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| I | 0 | X | X |

Result is ZERO
Result is not ZERO
Result is not ZERO
Carry

## Programming Notes

The condition code setting is based on the halfword (bits $16: 31$ ) result.
In the RII format, the shift count is specified by the least significant four bits of the second operand. The miximum shift count is 15 .

The state of the C flag indicates the state of the last bit shifted out of the Position 31.
When the register specified by R1 contains fixed point data, the L flag set indicates a negative result, the G flag set indicates a positive result.

If the second operand specifies a shift of zero places, the Condition Code is set in accordance with the halfword value contained in bits $16: 31$ of the register. The $C$ flag is reset in this case.

Rotate Left Logical (RLL)

| Assembler Notation | Op-Code | Format |  |
| :---: | :---: | :---: | :---: |
| RLL | R1, I2 (X2) | EB | RI1 |

## Operation

The 32 bit first operand, contained in the register specified by R1, is shifted left, end around, the number of positions specified by the second operand. Bits shifted out of Position 0 are shifted into Position 31.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Result is ZERO
Result is not ZERO
Result is not ZERO

## Programming Notes

The shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31 .

When the register specified by R1 contains fixed point data, the $L$ flag set indicates a negative result, the G flag set indicates a positive result.

If the second operand specifies a shift of zero places, the Condition Code is set in accordance with the value contained in the register specified by R1.

Example: RLL

## 1. Assembler Notation

LI REG9, $\mathrm{Y}^{\prime} 56789 \mathrm{ABC}^{\prime}$
RLL REG9, X'0004'

Machine Code
F890 56789ABC EB90 0004

Comments
$($ REG 9$)=56789 \mathrm{ABC}$

## Result of RLL Instruction:

$(\operatorname{REG} 9)=6789 \mathrm{ABC} 5$
Condition Code $=0010 \quad(\mathrm{G}=1)$

2
Machine Code
Comments
LI REG9, Y'88880000'
F890 88880000
$(\operatorname{REG} 9)=88880000$ RLL REG9, X'03' EB90 0003

## Result of RLL Instruction:

$($ REG 9$)=44400004$
Condition Code $=0010 \quad(\mathrm{G}=1)$

## INSTRUCTION

Rotate Right Logical (RRL)

| Assembler Notation | Op-Code | Format |  |
| :---: | :---: | :---: | :---: |
| RRL | R1, I2 (X2) | EA | RI1 |

## Operation

The 32 bit first operand, contained in the register specified by R1, is shifted right, end around, the number of positions specified by the second operand. Bits shifted out of Position 31 are shifted into Position 0.

## Condition Code

| C | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Result is ZERO
Result is not ZERO
Result is not ZERO

## Programming Notes

The shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31 .

When the register specified by R1 contains fixed point data, the L flag set indicates a negative result, the G flag set indicates a positive result.

If the second operand specifies a shift of zero places, the Condition Code is set in accordance with the value contained in the register specified by R1.

## Example: RRL

1. Assembler Notation

LI REG4, Y'12345678'
RRL REG4, X'04'

## Machine Code

F'840 12345678 EA40 0004

## Comments

$($ REG4 $)=12345678$

## Result of RRL Instruction

$($ REG4 $)=81234567$
Condition Code $=0001 \quad(\mathrm{~L}=1)$
2.
Assembler Notation

Machine Code
$($ REG 4 $)=00001111$

## Comments

F'840 00001111
LI REG4, Y'00001111'
EA40 0001

## Result of RRL Operation:

$($ REG4 $)=' 800000888^{\prime}$
Condition Code $=0001 \quad(\mathrm{~L}=1)$

## INSTRUCTION

Test and Set (TS)

Assembler Notation
$\begin{array}{ll}\text { TS } & \text { D2 (X2) } \\ \text { TS } & \text { A2 (FX2,SX2) }\end{array}$

## Op-Code

E0
E0

## Format

RX1, RX2
RX3

## Operation

The halfword second operand is read from memory and, on the same cycle, written back with the most significant bit set. The most significant bit of the second operand is tested. The Condition Code reflects the state of this bit at the time of the memory read. The other bits in the halfword are undefined.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | X | X | 0 |
| X | X | X | 1 |$\quad$| Most significant bit reset |
| :--- |

## Programming Notes

The Test and Set instruction provides a mechanism for software synchronization.
The Test and Sot instruction can be used in a single processor enviromment as follows: Two or more aser tasks ruming uader an Operating System share a halfword. This halfword is located in a memory area referced to as Task Common. Eash task can access the halfword using the TS instruction. The synchronization sequence may be as follows:

TASK 1: Sets the most significant bit using the TS instruction.

TASK 2: Senses the most significant bit using the TS instruction; sees that it is set; performs the necessary software synchconization; and then resets the most significant bit of the halfword.

The Test and Set instruction can be used in a multi-processor system as follows: Two or more processors share a halfword. This halfword is located in a memory area referred to as Shared Memory. Each processor can access the halfword using the TS instruction. The synchronization sequence can be exactly as explained for user tasks with the following subtle difference. Whereas TASK1 and TASK2 cannot ancess the halfword the same (real) time; two processors can. The access is granted according to the priority.

The hardware/iirmware ensures that no other accesses to the halfword have been made during the execution of the TS instruction.

## INSTRUCTION

I
Test Bit (TB'T)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :---: |
|  |  |  | RBT |
| TBT | R1, D2 (X2) | 74 | RX1, RX2 |
| TBT | R1, A2 (FX2, SX2) | 74 | RX3 |

## Operation

The second operand address points to a bit array starting on a halfword boundary. The value contained in the register specified by R1 is the bit displacement into the array. Bits in the array are counted from left to right starting with bit zero. The argument bit is located and tested. The test does not change the bit.

## Condition Code

| $\mathbf{C}$ | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |

Tested bit is ZERO
Tested bit is ONE

Example: TBT

| Assembler Notation | Machine Code |
| :--- | :--- |
| $\quad$ REG8, 3 | 2483 |
| LBT $\quad$ REG8, LABEL | 7480 OBC4 |

## Comments

$($ REG 8$)=3$
LABEL = Halfword
in memory $=\mathrm{X}^{\prime} \mathrm{B} 34 \mathrm{~A}^{\prime}$

## Result of TBT Instruction:

Memory Location X'BC4' unchanged
(REG 8) unchanged
Condition Code $=0010 \quad(\mathrm{G}=1)$

## INSTRUCTION

Set Bit (SBT)

| Assembler Notation |  | Op-Code | Format |
| :---: | :---: | :---: | :---: |
|  |  |  |  |
| SBT | R1, D2 (X2) | 75 | RX1, RX2 |
| SBT | R1, A2 (FX2, SX2) | 75 | RX3 |

## Operation

The second operand address points to a bit array starting on a halfword boundary. The value contained in the register specified by $R 1$ is the bit displacement into the array. Bits in the array are counted from left to right starting with bit zero. The argument bit is located and forced to one.

## Condition Code

| C | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |

Previous state of bit was ZERO
Previous state of bit was ONE

## Example: SBT

Assembler Notation

| LIS | REG5, 8 |
| :--- | :--- |
| SBT | REG5, LABEL |

Machine Code

2458
75501520

## Comments

$($ REG 5) $=8$
LABEL Located at X'1520'. It contains $X^{\prime} 2134^{\prime}$.

## Result of SBT Instruction:

Contents of LABEL $=21 \mathrm{~B} 4$
(REG 5) unchanged
Condition Code $=0000 \quad(\mathrm{G}=0)$

## INSTRUCTION

Complement Bit (CBT)

Assembler Notation

| CBT | R1, D2 (X2) |
| :--- | :--- |
| CBT | R1, A2 (FX2, SX2) |

Op-Code
77
77

## Format

RX1, RX2
RX3

## Operation

The second operand address points to a bit array starting on a halfword boundary. The value contained in the register specified by R1 is the bit displacement into the array. Bits in the array are counted from left to right starting with bit zero. The argument bit is located anc complemented.

## Condition Code

| C | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |

Previous state of bit was ZERO
Previous state of bit was ONE

Example: CBT

## Assembler Notation

Machine Code
2493
7790 0C4A

## Comments

$(\operatorname{REG} 9)=3$
LABEL located at $\mathrm{X}^{\prime} \mathrm{C} 4 \mathrm{~A}^{\prime}$. It contains X'2813'.

Result of CBT Instruction:
Contents of LABEL $=3813$
(REG9) unchanged
Condition Code $=0000 \quad(\mathrm{G}=0)$

## INSTRUCTION

Reset Bit (RBT)

| Assembler Notation |  | Op-Code | Format |
| :---: | :---: | :---: | :---: |
| RBT | R1, D2 (X2) | 76 | RX1, RX2 |
| RBT | R1, A2 (FX2, SX2) | 76 | RX3 |

## Operation

The second operand address points to a bit array starting on a halfword boundary. The value contained in the register specified by R 1 is the bit displacement into the array. Bits in the array are counted from left to right starting with bit zero. The argument bit is located and forced to ZERO.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |

Previous state of bit was ZERO
Previous state of bit was ONE

Example: RBT

Assembler Notation Machine Code Comments

| LIS | REG2, 3 | 2423 |
| :--- | :--- | :--- |
| RBT | REG2,LABEL | 76201 A 42 |

$($ REG 2) $=3$
LABEL located at $\mathrm{X}^{\prime} 1 \mathrm{~A} 42$ ' contains X'3143'

## Result of RBT Instruction:

Contents of LABEL $=2143$
(REG 2) unchanged
Condition Code $=0010 \quad(\mathrm{G}=1)$

## INSTRUCTIONS

Cyclic Redundancy Check Modulo 12 (CRC 12)
Cyclic Redundancy Check Modulo 16 (CRC 16)

| Assembler Notation | Op-Code | Format |  |
| :---: | :--- | :---: | :--- |
|  |  |  |  |
| CRC12 | R1, D2 (X2) | 5 E | RX1, RX2 |
| CRC12 | R1, A2 (FX2, SX2) | 5 E | RX3 |
| CRC16 | R1, D2 (X2) | 5 F | RX1, RX2 |
| CRC16 | R1, A2 (FX2, SX2) | 5 F | RX3 |

## Operation

These instructions are used to generate either a 12 bit or a 16 bit Cyclic Redundancy Check (CRC) character. The register specified by R1 contains, in Bits 24:31, the next data character to be included in the CRC. The second operand is the accumulated (old) CRC. The polynominal used for the 12 bit CRC generation is:

$$
\mathrm{x}^{12+} \mathrm{x}^{11}+\mathrm{x}^{3}+\mathrm{x}^{2+} \mathrm{x}+1
$$

The polynomial used for the 16 bit CRC generation is:

$$
\mathrm{X}^{16_{+}} \mathrm{X}^{15_{+}} \mathrm{X}^{2_{+}} 1
$$

The second operand is replaced by the generated CRC character.

## Condition Code

Unchanged

## Programming Note

The register specified by R1 remains unchanged.
The second operand must be located on a halfword boundary.
Figure 2-5 illustrates a Flow Chart for CRC generation.

$\begin{array}{llll}\text { FOR CRC } 16 \text { ALGORITHM, USE: } & \mathrm{R} 1_{24: 31} & \text { INSTEAD OF R1 } 26: 31 & \text { IN STEP } 1 \\ & 8 & \text { INSTEAD OF } 6 & \text { IN STEP } 2 \\ & \mathrm{X}^{\prime} \mathrm{A001} & \text { INSTEAD OF X'OF01' } & \text { IN STEP } 4\end{array}$

Figure 2-5. Flow Chart for CRC Generation

## INSTRUCTION

Translate (TLATE)

| Assembler Notation | Op-Code | Format |  |
| :---: | :--- | :---: | :---: |
|  |  | R1, D2 (X2) | E7 |

## Operation

The least significant bits (Bits 24:31) of the register specified by R1 contain the character to be translated. The fullword location specified by the second operand address contains the address of a translation table. The table is made up of 256 halfwords. The character contained in the register specified by R1 is used as an index into the table.

If Bit 0 of the table entry corresponding to the index character is one, then Bits $8: 15$ of the table entry replace the index character, and the next sequential instruction is executed.

If Bit 0 of the table entry is zero, then Bits $1: 15$ of the table entry contain the address, divided by two, of a special handling routine. In this case, no translation takes place. The address contained in Bits $1: 15$ is shifted left by one, (multiplied by two). This address replaces the current Location Counter, thereby effecting an unconditional branch.

## Condition Code

Unchanged

Programming Note
The second operand address must be aligned on a fullword boundary.


0 (CHAR. HANDLING ROUTINE ADDRESS)/2

## Example: TLATE

This example illustrates the use of the TLATE instruction. The translation tabie must either be initialized or assembled to contain up to a total of 256 halfword entries. In this example, the table is initialized to contain 2 entries:

| Label | Assembler Notation |  |
| :--- | :--- | :--- |
|  | Comments |  |
|  | LHI | REG5, X'8052' |

Since a program is normally assembled as a relocatable program, the Address of TRANLAB is not known, but for illustrative purposes assume address of TRANLAB is $\mathrm{X}^{\prime} 864$.

0

TABLE+0
TABLE+2
TABLE+4 TABLE+6 TABLE+8
TABLE+10
TABLE+1. 2
TABLE+508


At TABLE+A is the address of TRANLAB divided by 2 ( $\mathrm{X}^{\prime} 864{ }^{\prime} / 2$ )

1. Using this table, this example translates the character in Register 2.

Label

Assembler Notation
LIS REG2, 2
TLATE REG2,TABADR

## Comments

$($ REG 2) $=00000002$

## Result of TLATE Instruction:

$($ REG2 $)=00000052$
Condition Code $=$ Unchanged
The entry used = Contents at Address of (2 times contents of REG 2) + TABLE

$$
\begin{aligned}
& =\text { Contents at address TABLE }+4 \\
& =X^{\prime} 8052^{\prime}
\end{aligned}
$$

Since first bit of entry $=1$, Direct translation is used and the contents of REG2 are replaced by X'0000 0052'
2. Using the table, the following example shows how the TLATE instruction can be used to branch to a special character handling routine:

## Label

## Assembler Notation

LIS REG5, 5
TLATE REG5, TABADR

TLATE REG5, TABADR
-
-
-
-

TRANLAB
$\begin{array}{lll}\text { LHR } & \text { R6, R5 } & \text { THESE INSTRUCTIONS } \\ \text { LB } & \text { R3, } 0 \text { (R6) } & \text { OPERATE ON THE SPECIAL } \\ & & \text { CHARACTER. }\end{array}$

Comments
REG5 $=00000005$

## Result of TLATE Instruction:

$($ REG5 $)=00000005$
Condition Code $=$ Unchanged
Control is Transferred to subroutine at address TRANLAB ( $\mathrm{X}^{\prime} 864^{\prime}$ ).
The entry used = Contents at Address of (2 times contents of REG 5) + TABLE

$$
=\text { Contents at Address TABLE }+\mathrm{A}
$$

$$
=X^{\prime} 0432^{\prime}
$$

Since the first bit of entry $=0$, the microcode multiplies the entry by 2 and transfers to TRANLAB (at address $\mathrm{X}^{\prime} 864^{\prime}$ ) and continues executing instructions from the new address.

Alternately, the table may be assembled with the proper constant values. The "T" type constant may be used to assemble the subroutine addresses in the proper formst.

For example:
ALIGN 2
TABLE EQU *
DO 256
DC $\mathrm{H}^{\prime} \mathbf{0}^{\prime}$
ORG TABLE+4
DC X'8052'
ORG TABLE+X'A'
DC T(TRANTAB)
ORG TABLE+512

Add to Top of List (ATL)
Add to Bottom of List (ABL)

## Assembler Notation

| ATL | R1, D2 (X2) |
| :--- | :--- |
| ATL | R1, A2 (FX2, SX2) |
| ABL | R1, D2 (X2) |
| ABL | R1, A2 (FX2,SX2) |

## Op-Code

64
64
64
65
65

## Format

RX1, RX2
RX3
RX1, RX2
RX3

## Operation

The register specified by R1 contains the fullword element to be added to the list. The list is located in memory at the address of the second operand. The number of slots used tally is compared with the number of slots in the list. If the number of slots used equals the number of slots in the list, an overflow condition exists. The element is not added to the list and the overflow flag in the Condition Code is set. If the number of slots used tally is less than the number of slots in the list, it is incremented by one, the appropriate pointer is changed, and the element is added to the list. Refer to Figure 2-4.

## Condition Code

| C | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 0 |

## Element added successfully <br> List overflow

## Programming Notes

These instructions manipulate circular lists as described in the introduction to this chapter.
The second operand location must be on a fullword boundary.
The add to top of list instruction manipulates the current top pointer in the list. If no overflow occurs, the current top pointer, which points to the last element added to the top of the list, is decremented by one and the element is inserted in the slot pointed to by the new current top pointer. If the current top pointer was zero on entering this instruction, the current top pointer is set to the maximum slot number in the list. This condition is referred to as list wrap.

The add to bottom of list instruction manipulates the next bottom pointer. If no overflow occurs, the element is inserted in the slot pointed to by the next bottom pointer, and the next bottom pointer is incromented by one. If the incremented next bottom pointer is greater than the maximum slot number in the list, the next bottom pointer is set to zero. This condition is referred to as list wrap.

See examples in the next section.

## INSTRUCTIONS

Remove from Top of List (RTL)
Remove from Bottom of List (RBL)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :--- |
|  |  |  |  |
| RTL | R1, D2 (X2) | 66 | RX1, RX2 |
| RTL | R1, A2 (FX2, SX2) | 66 | RX3 |
| RBL | R1, D2 (X2) | 67 | RX1, RX2 |
| RBL | R1, A2 (FX2, SX2) | 67 | RX3 |

## Operation

The element removed from the list replaces the contents of the register specified by R1. The list is located at the address of the second operand. If, at the start of the instruction execution, the number of slots used tally is ZERO, the list is already empty and the instruction terminates with the overflow flag set in the Condition Code. This condition is referred to as list underflow; in this case, R1 is undefined. If underflow does not occur, the number of slots used tally is decremented by one, the appropriate pointer is changed, and the element is extracted and placed in the register spocified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |

List now empty
List is not yet empty
List was already empty

## Programming Notes

These instructions manipulate circular lists as described in the introduction to this chapter.

The second operand location must be on a fullword boundary.
In the case of list underflow, the contents of the register specified by R1 are undefined.
The remove from top of list instruction manipulates the current top pointer. If no underflow occurs, the current top pointer points to the element to be extracted. The element is extracted, and placed in the register specified by R1. The current top pointer is incremented by one and compared to the maximum slot number. If the current top pointer is greater than the maximum slot number, the current top pointer is set to ZERO. This condition is referred to as list wrap.

The remove from bottom of list instruction manipulates the next bottom pointer. If no underflow occurs, and the next bottom pointer is ZERO, it is set to the maximum slot number (list wrap); otherwise, it is decremented by one, and the element now pointed to is extracted and placed in the register specified by $R 1$.

The following are examples of the use of the four list processing instructions.
The original list is normally set up as shown in Figure 2-6.

where HALFWORDS at

| LIST | $=\#$ of total slots |
| ---: | :--- |
|  | $=5$ (in this example) |
| LIST +2 | $=\#$ of entries used |
|  | $=0$ |
| LIST +4 | $=$ current top of list |
|  | $=$ slot 0 |
| LIST +6 | $=$ next bottom of list |

$=s \operatorname{slot} 0$

Figure 2-6. List Processing Instructions

Labels
Assembler Notation

LIS REG0, 0
STH REG0, LIST+2 INITIALIZE \# OF ENTRIES USED TO 0
ST REG0, LIST +4
LIS REG1, 1
LIS REG2,2
LIS REG3, 3
LIS REG4, 4
LIS REG5,5
LIS REG6, 6
STH REG5, LIST

Results and Comments INITLALIZE POINTERS TO 0 REGISTERS 1 THRU 6 CONTAIN

1 THRU 6 RESPECTIVELY

TOTAL \# OF ENTRIES $=5$

| LIST | 0005 | 0001 |
| :---: | :---: | :---: |
|  | 0004 | 0000 |
| SLOT 0 | UNDE FINED |  |
| SLOT 1 | UNDEFINED |  |
| SLOT 2 | UNDEFINED |  |
| SLOT 3 | UNDEFINED |  |
| SLOT 4 | 00000001 |  |

Condition Code $=0000$
Current Top Pointer $=$ Slot 4
Next Bottom Pointer $=\operatorname{Slot} 0$

REF2
ATL REG2, LIST


Condition Code $=0000$
Current Top Pointer $=$ Slot 3
Next Bottom Pointer $=$ Slot 0

REF3 ATL REG3, LIST

| LIST | 0005 | 0003 |
| :---: | :---: | :---: |
|  | 0002 | 0000 |
| SLOT 0 | UNDEFINED |  |
| SLOT 1 | UNDEFINED |  |
| SLOT 2 | 00000003 |  |
| SLOT 3 | 00000002 |  |
| SLOT 4 | 00000001 |  |

Condition Code $=0000$
Current Top Pointer = Slot 2
Next Bottom Pointer $=$ Slot 0

REF4 ABL REG4, LIST

REF5 ABL REG5, LIST

| LIST | 0005 | 0005 |
| :---: | :---: | :---: |
|  | 0002 | 0002 |
| SLOT 0 | 0000 | 0004 |
| SLOT 1 | 0000 | 0005 |
| SLOT 2 | 0000 | 0003 |
| SLOT 3 | 0000 | 0002 |
| SLOT 4 | 0000 | 0001 |

Condition Code $=0000$
Current Top Pointer = Slot 2
Next Bottom Pointer $=$ Slot 2

REF6
ABL REG6, LIST

| LIST | 0005 | 0005 |
| :---: | :---: | :---: |
|  | 0002 | 0002 |
| SLOT 0 | 0000 | 0004 |
| SLOT 1 | 0000 | 0005 |
| SLOT 2 | 0000 | 0003 |
| SLOT 3 | 0000 | 0002 |
| SLOT 4 | 0000 | 0001 |

Condition Code $=0100 \quad$ (List overflow)
Current Top Pointer $=$ Slot 2 Next Bottom Pointer $=$ Slot 2

$X=$ Entry removed from list, and is not accessible through further manipulation of list instructions.


X= Entry removed from list, and is not accessible through further manipulation of list instructions.

## CHAPTER 3 BRANCHING

In normal operations, the Processor executes instructions in sequential order. The Branch instructions allow this sequential mode of operation to be varied, so that programs can loop, transfer control to subroutines, or make decisions based on the results of previous operations.

## OPERATIONS

The second operand in Branch instructions is the address of the memory location to which control is transferred. The address may be contained in a register or it may be specified in the instruction as the second operand address.

## Decision Making

The Conditional Branch instructions permit the program to make the decisions based on previous results. In these instructions, the R1 field contains a four bit mask, M1, which is tested against the Condition Code. The result of the test determines whether the branch is taken, or the next sequential instruction is executed.

The following examples show previous Condition Code, mask specified in a branch instruction, and the result of the test on which branch or no branch decision is made.

| Previous <br> Condition Code | Mask(M1) | Result <br> of Test | (Truc/False) |
| :---: | :---: | :---: | :---: |
| 0000 | 0010 | 0000 | (False) |
| 0001 | 1010 | 0000 | (False) |
| 1001 | 1000 | 1000 | (True) |
| 0100 | 0100 | 0100 | (True) |
| 1010 | 0010 | 0010 | (True) |
| 0010 | 0011 | 0010 | (True) |
| 0010 | 0000 | 0000 | (False) |

## Subroutine Linkage

The Branch and Link instructions allow branching to subroutines in such a way that a return address is passed to the subroutine. In these instructions, the address of the instruction immediately following the Branch instruction is saved in the register specified by R1.

## BRANCH INSTRUCTION FORMATS

The Branch instructions use the Register to Register (RR), the Short Form (SF), and the Register and Indexed Storage (RX) formats.

## BRANCH INSTRUCTIONS

The instructions described in this section are:

| BFC | Branch on False Condition |
| :--- | :--- |
| BFCR | Branch on False Condition Register |
| BFBS | Branch on False Condition Backward Short |
| BFFS | Branch on False Condition Forward Short |
| BTC | Branch on True Condition |
| BTCR | Branch on True Condition Register |
| BTBS | Branch on True Condition Backward Short |
| BTFS | Branch on True Condition Forward Short |
| BAL | Branch and Link. |
| BALR | Branch and Link Register |
| BXLE | Branch on Index Low or Equal |
| BXH | Branch on Index High |

Refer to Appendix 4 for the list of additional branch mnemonics recognized by the Assembler.

## INSTRUCTIONS

Branch on True Condition (BTC)
Branch on True Condition Register (BTCR)
Branch on True Condition Backward Short (BTBS)
Branch on True Condition Forward Short (BTFS)

| Assembler Notation |  | Op-Code |  |
| :---: | :--- | :---: | :--- |
|  |  | Format |  |
| BTC | M1, D2 (X2) | 42 | RX1, RX2 |
| BTC | M1, A2 (FX2, SX2) | 42 | RX3 |
| BTCR | M1, R2 | 02 | RR |
| BTBS | M1,N | 20 | SF |
| BTFS | M1, N | 21 | SF |

## Operation

The Condition Code of the Program Status Word is tested for the conditions specified by the mask field, M1. If any of the conditions tested are found to be true, a branch is executed to the second operand location. If none of the conditions tested is found to be true, the next sequential instruction is executed.

## Condition Code

Unchanged

## Programming Notes

In the RR format, the branch address is contained in the register specified by R 2 .
In the SF format, the N field contains the number of halfwords to be added or subtracted from the current Location Counter to obtain the branch address.

In the $R R$ and $R X$ formats, the branch address must be located on a halfword boundary.

## Example: BTC

| Asse | Notation | Machine Code | Comments |
| :---: | :---: | :---: | :---: |
| LH | R1, $\mathrm{X}^{\prime} 100^{\prime}$ | 48100100 | Load halfword ( $\mathrm{X}^{\prime} 1234^{\prime}$ ) located at $\mathrm{X}^{\prime} 100$ ' Condition Code is set to |
| BTC | 3, LOC | 4230 ABC0 | CVGL $=0010$ Mask is 3, i.e., M1 $=0011$. Perform logical AND between CVGL and M1, i. e., 0010 and 0011. The result is 0010 , i. e., true; therefore, a branch is taken to LOC. |

## INSTRUCTIONS

Branch on False Condition (BFC)
Branch on False Condition Register (BFCR)
Branch on False Condition Backward Short (BFBS)
Branch on False Condition Forward Short (BFFS)

| Assembler Notation |  | Op-Code |  |
| :---: | :--- | :---: | :--- |
|  |  | Format |  |
| BFC | M1, D2 (X2) | 43 | RX1, RX2 |
| BFC | M1, A2 (FX2, SX2) | 43 | RX3 |
| BFCR | M1, R2 | 03 | RR |
| BFBS | M1, N | 22 | SF |
| BFFS | M1, N | 23 | SF |

## Operation

The Condition Code of the Program Status Word is tested for the conditions specified in the mask field, M1. If all conditions tested are found to be false, a branch is executed to the second operand location. If any of the conditions tested is found to be true, the next sequential instruction is executed.

## Condition Code

Unchanged

## Programming Notes

In the RR format, the branch address is contained in the register specified by R2.
In the SF format, the N field contains the number of halfwords to be added to or subtracted from the current Location Counter to obtain the branch address.

In the RR and RX formats, the branch address must be located on a halfword boundary.

## Example: BFC

| Assembler Notation |  | Machine Code |
| :--- | :--- | :--- | :--- |
|  |  |  |
| LCS | R1,2 | 2512 |
| BFC | 9, LOC | 4390 ABC 0 |

Comments
(R1) = FFFFFFFFE. Condition Code,
CVGL $=0001$ Mask is 1001 . Perform
logical AND between mask and
CVGL, i. e., 1001 and 0001 . The
result is 0001, i.e., true, there-
fore, a branch is not taken in LOC.

## INSTRUCTIONS

Branch and Link (BAL)
Branch and Link Register (BALR)

| Assembler Notation |  | Op-Code | Format |
| :---: | :---: | :---: | :---: |
| BAL | R1, D2 (X2) | 41 | RX1, RX2 |
| BAL | R1, A2 (FX2, SX2) | 41 | RX3 |
| BALR | R1, R2 | 01 | RR |

## Operation

The address of the next sequential instruction is saved in the register specified by R1, and a branch is taken to the second operand address.

## Condition Code

Unchanged

## Programming Notes

The second operand location must be on a halfword boundary.
The branch address is calculated before the register specified by R1 is changed. R1 may specify the same register as X2, FX2, SX2, or R2.

## Example: BAL

The following example illustrates the use of the BAL instruction. The instruction causes control to be transferred to a subroutine called SUBROUT. After completion of the subroutine, the linking register is used to branch back to the next sequential instruction after the BAL; i.e., the instruction labelled RETURN.

|  | Label | Assembler Notation | Comments |
| :---: | :---: | :---: | :---: |
|  | BEGIN | BAL REG4, SUBROUT | TRANSFER TO SUBROUT |
| MAIN | RETURN | XR R6, R6 |  |
| PROG |  | STII R6, LAB +4 |  |
|  | SUBROUT | LHL R8, LOC | THE RETURN ADDRESS OF THE SUBROUTINE IS IN REG4 |
| SUBROUTINE |  | AHI R8, 10 |  |
|  | RTNEND | BR REG4 | RETURN TO XR INST. |

NOTE
Within the subroutine, the linking register (REG4 in the example) should not be used.

## Result of BAL Instruction:

Condition Code $=$ Unchanged

## INSTRUCTION

Branch on Index Low or Equal (BXLE)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :---: |
|  |  | R1, D2 (X2) | C1 |
| BXLE | R1, A2 (FX2, SX2) | C1 | RX3 |

Set Up

|  |
| :--- | :--- |
| R1 |
| R1 +1 |
| $R 1+2$ |$\quad$ Starting index value

Prior to execution of this instruction, the register specified by R1 must contain a starting index value. The register specified by $R 1+1$ must contain an increm ent value. The register specified by $R 1+2$ must contain a comparand (limit or final value). All values may be signed.

## Operation

Execution of this instruction causes the increment value to be added to the index value. The result is logically compared to the limit or final value. If the index value is less than or equal to the limit value, a branch is executed to the second operand location. If the index value is greater than the limit value, the next sequential instruction is executed.

## Condition Code

Unchanged

## Programming Notes

The incremented index value replaces the contents of the register specified by R1.
The register numbers wrap around, i.e., three consecutive registers used by this instruction, may be $6,7,8$ or $14,15,0$ or $15,0,1$, etc.

The second operand location must be on a halfword boundary.
The branch address is calculated before incrementing the starting index value contained in the register specified by R1.

The register specified by R1 may be the same as X2, FX2 or SX2.

## Example: BXLE

Transfer 10 bytes in memory starting at Memory Location Labelled BUF0 to memory location labelled BUF1.

| Labels | Assembler Notation |  |
| :---: | :---: | :---: |
| AGAIN | LIS | REG3, 0 |
|  | LIS | REG4, 1 |
|  | LIS | R5, 9 |
|  | LB | REG0, BUFO(R3) |
|  | STB | REG0, BUF1(R1) |
|  | BXLE | R3, AGA.IN |
|  | - |  |
|  | - |  |
| BUF0 | DS | 10 |
| BUF1 | DS | 10 |

## Comments

(REG 3) $=$ STARTING INDEX VALUE $=0$
(REG 4) $=$ INCREMENT VALUE
(REG 5) $=$ FINAL VALUE $=9$
(REG 0) $=1$ BYTE FROM BUF0 COPY 1 BYTE TO BU F1 IF (REG 3) $=$ (REG 5), DONE

Result of BXLE Instruction:
Condition Code $=$ Unchanged by BXLE Instruction
$($ REG3 $)=0000000 \mathrm{~A}$
$($ REG4 $)=00000001$
$($ REG5 $)=00000009$

## INSTRUCTION

Branch on Index High (BXH)

| Assembler Notation | Op-Code | Format |  |
| :---: | :--- | :---: | :---: |
| BXH | R1, D2 (X2) | C 0 | RX1, RX2 |
| BXH | R1, A2 (FX2, SX2) | C 0 | RX3 |

## Set Up

| R1 | Starting index ralue |
| :---: | :---: |
| $\mathrm{R} 1 \div 1$ | Increment value |
| R1-2 | Limit or final value |

Prior to execution of this instruction, the register specified by R1 must contain a starting index value. The register specified by R1+1 must contain an increment value. The register specified by $\mathrm{R} 1+2$ must contain a comparand (limit or final value). All values may be signcd.

## Operation

Execution of this instruction causes the increment value to be added to the index value. The result is logically compared to the limit or final value. If the index value is greater than the limit value, a branch is executed to the second operand location. If the index value is equal to or less than the limit value, the next sequential instruction is executed.

## Condition Code

Unchanged

## Programming Notes

The incremented index value replaces the contents of the register specified by R1.
The register numbers wrap around, i.e., three consecutive registers and by this instruction may be $6,7,8$ or $14,15,0$ or $15,0,1$ etc.

The second operand location must be on a halfword boundary.
The branch address is calculated before incrementing the starting index value contained in the register specified by R1.

The register specified by R1 may be the same as X2, FX2 or SX2.

## Example: BXH

The following example shows how to set up a counter (1-9) using the BXH instruction.

| Label | Assembler Notation |  | Comment |
| :---: | :---: | :---: | :---: |
| BEGIN | LIS | REG1, 1 | (REG 1) $=00000001$ (INDEX) |
|  | LIS | REG2, 1 | $($ REG 2) $=00000001$ (INCREMENT) |
|  | LIS | REG3, 9 | $(\mathrm{REG} \mathrm{3})=00000009$ (COMPARAND) |
|  | BXH | REG1, LABEL | COMPARE INDEX WITH COMPARAND |
|  | LH | R6, COUNT |  |
|  | - |  |  |
|  | - |  |  |
|  | - |  |  |
| LABEL | B | BEGIN | BRANCH TO BXH INSTRUCTION |
|  | LA | R8, RTN | EXIT FROM BXH |
|  | ST | R8, MIEM |  |

## Result of BXH Instruction:

Code between the instructions labelled BEGIN and LABEL will be executed 8 times.
Condition Code $=$ Unchanged by BXH instruction
$($ REG1 $)=00000010$
$($ REG2) $=00000001$
$($ REG3 $)=00000009$

## EXTENDED BRANCH MNEMONICS

The CAL Assembler supports 14 extended branch mnemonics that generate the branch op-code (true or false conditional) and the condition code mask required. The programmer must supply the second operand address (symbolic or absolute). In the case of short format (SF) branch instructions, the second operand branch address must be within +15 halfwords of the current location counter. The CAL Assembler determines the backward or forward relationship of the second operand address and generates the appropriate operation code.

Examples of extended branch mnemonic:

|  | LH | R5, L00P1 |
| :--- | :--- | :--- |
|  | BNZ | LOERR |
| LAP | SRLS | R6, |
|  | BNCS | LAP |
| LOERR | BS | CONTIN |
| ERROR1 | LIS | R6,0 |
|  | AIS | R6,1 |
|  | SIS | R5, |
|  | BPS | ERROR1 |
|  | SIS | R8,1 |
|  | BO | ERROR2 |
| CONTIN | LH | R1, TIME |

Appendix 4 lists the extended branch mnemonics and the proper operand form to be used with each mnemonic. The actual machine code generated is also listed.

The instructions described in this section are:

| BC | Branch on Carry | BP | Branch on Plus |
| :---: | :---: | :---: | :---: |
| BCR | Branch on Carry Register | BPR | Branch on Plus Register |
| BCS | Branch on Carry Short | BPS | Branch on Plus Short |
| BNC | Branch on No Carry | BNP | Branch on Not Plus |
| BNCR | Branch on No Carry Register | BNPR | Branch on Not Plus Register |
| BNCS | Branch on No Carry Short | BNPS | Branch on Not Plus Short |
| BE | Branch on Equal | BO | Branch on Overflow |
| BER | Branch on Equal Register | BOR | Branch on Overflow Register |
| BES | Branch on Equal Short | BOS | Branch on Overflow Short |
| BNE | Branch on Not Equal | BNO | Branch on No Overflow |
| BNER | Branch on Not Equal Register | BNOR | Branch on No Overflow Register |
| BNES | Branch on Not Equal Short | BNOS | Branch on No Overflow Short |
| BL | Branch on Low | BZ | Branch on Zero |
| BLR | Branch on Low Register | BZR | Branch on Zero Register |
| BLS | Branch on Low Short | BZS | Branch on Zero Short |
| BNL | Branch on Not Low | BNZ | Branch on Not Zero |
| BNLR | Branch on Not Low Register | BNZER | Branch on Not Zero Register |
| BNLS | Branch on Not Low Short | BNZS | Branch on Not Zero Short |
| BM | Branch on Minus |  |  |
| BMR | Branch on Minus Register | B | Branch (Unconditional) |
| BMS | Branch on Minus Short | BR | Branch Register (Unconditional) |
| BNM | Branch on Not Minus |  |  |
| BNMR | Branch on Not Minus Register |  |  |
| BNMS | Branch on Not Minus Short | NOP | No Operation |
|  |  | NOPR | No Operation Register |

## INSTRUCTION

Branch on Carry (BC)
Branch on Carry Register (BCR)
Branch on Carry Short (BCS)

| Assembler Notation |  | Op-Code + M1 |  |
| :---: | :--- | :--- | :--- |
|  |  |  | Format |
| BC | D2(X2) | 428 | RX1, RX2 |
| BC | (A2(FX2, SX2) | 428 | RX3 |
| BCR | R2 | 028 | RR |
| BCS | A | 208 (Backward) | SF |
|  |  | 218 (Forward) |  |

## Operation

If the Carry (C) flag is in the Condigion Code is set, a branch is taken to the second operand location. If the Carry flag is not set, the next sequential instruction is executed.

## Condition Code

Unchanged

## Programming Note

The branch address must be located on a halfword boundary.
In the RR format, the branch address is contained in the register speciried by R2.

Example: BCS

| Assembler Notation |  |  | Machine Code |
| :--- | :--- | :--- | :--- |
| SHIFT | SLLS | R9,1 | 1191 |
|  | BCS | SHIFT | 2081 |

## Comments <br> Register 9 is shifted left until the first zero bit is shifted out left.

## NSTRUCTION

Branch on No Carry (BNC)
Branch on No Carry Register (BNCR)
Branch on No Carry Short (BNCS)

Assembler Notation

| BNC | D2 (X2) |
| :--- | :--- |
| BNC | A2(FX2, SX2) |
| BNCR | R2 |
| BNCS | A |

Op-Code + M1

438
438
038
228 (Backward)
238 (Forward)

## Format

RX1, RX2
RX3
RR
SF

## Operation

If the Carry (C) flag in the Condition Code is not set, a branch is taken to the second operand location. If the Carry flag is set, the next sequential instruction is executed.

Condition Code
Unchanged

## Programming Note

The branch address must be located on a halfword boundary.
In the RR format, the branch address is contained in the register specified by R 2 .

## INSTRUCTION

Branch on Equal (BE)
Branch on Equal Register (BER)
Branch on Equal Short (BES)

Assembler Notation

| BE | D2(X2) |
| :--- | :--- |
| BE | A2(FX2, SX2) |
| BER | R2 |
| BES | A |

Op-Code + M1
433
433
033
223 (Backward)
233 (Forward)

Format
RX1, RX2
RX3
RR
SF

## Operation

If the G flag and the L flag are both reset in the Condition Code, a branch is taken to the second operand location. If either flag is set, the next sequential instruction is executed.

## Condition Code

Unchanged

## Programming Note

The branch address must be located on a halfword boundary.
In the RR format, the granch address is contained in the register specified by R2.
Example: BE

| Assembler N |  | Machine Cod |
| :---: | :---: | :---: |
| C LHI | R4, X'23' | C540 0023 |
| BE | OPTIN | 4330 0A00 |

Comments
If R4 contains X'23' a branch is taken to location $\mathrm{X}^{\prime} \mathrm{A} 00^{\prime}$. Otherwise the next sequential instruction is executed.

## INSTRUCTION

Branch on Not Equal (BNE)
Branch on Not Equal Register (BNER)
Branch on Not Equal Short (BNES)
Assembler Notation
$\underline{\text { Op-Code }+ \text { M1 } \quad \text { Format }}$

| BNE | D2(X2) | 423 | RX1, RX2 |
| :--- | :--- | :--- | :--- |
| BNE | A2(FX2, SX2) | 423 | RX3 |
| BNER | R2 | 023 | RR |
| BNES | A | 203 (Backward) | SF |
|  |  | 213 (Forward) |  |

## Operation

If the G flag or the L flag is set in the Condition Code, a branch is taken to the second operand locationl If neither flag is set, the next sequential instruction is executed.

Condition Code
Unchanged
Programming Note
The branch address must be located on a halfword boundary.
In the RR format, the branch address is contained in the register specified by R 2 .

## INSTRUCTION

Branch on Low (BL)
Branch on Low Register (BLR)
Branch on Low Short (BLS)

| Assembler Notation |  | Op-Code + M1 |  |
| :---: | :--- | :--- | :--- |
|  | Format |  |  |
| BL | D2 (X2) | 428 | RX1, RX2 |
| BL | A2(FX2, SX2) | 428 | RX3 |
| BLR | R2 | 028 | RR |
| BLS | A | 208 (Backward) | SF |
|  |  | 218 (Forward) |  |

## Operation

If the Carry (C) flag in the Condition Code is set, a Branch is taken to the second operand address. If the Carry flag is not set, the next sequential instruction is executed.

## Condition Code

Unchanged

## Programming Note

The branch address must be located on a halfword boundary.
In the RR format, the branch address is contained in the register specified by R2.
Example: BL


## INSTRUCTION

Branch on Not Low (BNL)
Branch on Not Low Register (BNLR)
Branch on Not Low Short (BNLS)

Assembler Notation
BNL D29X2) 438
BNL A2(FX2, SX2) 438
BNLR R2 03
BNLS A

| Op-Code + M1 | Format |
| :--- | :--- |
| 438 | RX1, RX2 |
| 438 | RX3 |
| 038 | RR |
| 228 (Backward) | SF |
| 238 (Fowward) |  |

## Operation

If the Carry (C) flag in the Condition Code is reset, a branch is taken to the second operand address. If the Carry flay is set, the next sequential instruction is executed.

## Condition Code

unchanged

## Programming Note

The branch address must be located on a halfword boundary.
In the RR format, the branch address is contained in the register speciried by $R 2$.

## INSTRUCTION

Branch on Minus (BM)
Branch on Minus Register (BMR)
Branch on Minus Short (BMS)

Assembler Notation

| BM | D2(X2) |
| :--- | :--- |
| BM | A2(F X2, SX2) |
| BMR | R2 |
| BMS | A |

Op-Code + M1
421
421
021
201 (Backward)
211 (Forward)

Format
RX1, RX2
RX3
RR
SF

## Operation

If the Less Than (L) flag in the Condition Code is set, a branch is taken to the second operand location. If the L flag is not set, the next sequential instruction is executed.

## Condition Code

Unchanged

## Programming Note

The branch address must be located on a halfword boundary.
In the $R R$ format, the branch address is contained in the register specified by R2.
Example: BM

| Assembler Notation |  |
| :--- | :--- |
| SIS | R3, 1 |
| BM | CONTINUE |

Machine Code
2631
4210 10A0

## Comments

If R3 is less than 0 after the subtraction, a branch is taken to $\mathrm{X}^{\prime} 10 \mathrm{~A} 0^{\prime}$.

## INSTRUCTION

Branch on Not Minus (BNM)
Branch on Not Minus Register (BNMR)
Branch on Not Minus Short (BNMS)

Assembler Notation

| BNM | D2 (X2) | 431 | RX1, RX2 |
| :--- | :--- | :--- | :--- |
| BNM | A2(FX2, SX2) | 431 | RX3 |
| BNMR | R2 | 031 | RR |
| BNMS | A | 221 (Backward) | SF |
|  |  | 231 (Forward) |  |

Operation
If the Less Than ( L ) flag in the Condition Code is reset, a branch is taken to the second operand location. If the L flag is set, the next sequential instruction is executed.

## Condition Code

Unchanged
Programming Note
The branch address must be located on a halfword boundary.
In the RR format, the branch address is contained in the register specified by R2.

## INSTRUCTION

Branch on Plus (BP)
Branch on Plus Register (BPR)
Branch on Plus Short (BPS)
Assembler Notation
BP D2(X2)
BP A2(FX2,SX2)
BPR R2
BPS A

Op-Code + M1

| Op-Code + M1 | Format |
| :--- | :--- |
|  | RX1, RX2 |
| 422 | $\mathrm{RX3}$ |
| 022 | RR |
| 202 (Backward) | SF |
| 21,2 (Forward) |  |

## Operation

If the Greater Than (G) flag in the Condition Code is set, a branch is taken to the second operand location. If the G flag is not set, the next sequential instruction is executed.

## Condition Code

Unchanged

## Programming Note

The branch address must be located on a halfword boundary.
In the RR format, the branch address is contained in the register specified by R2.

## INSTRUCTION

Branch on Not Plus (BNP)
Branch on Not Plus Register (BNPR)
Branch on Not Plus Short (BNPS)

Assembler Notation

BNP D2(X2)
BNP A2(FX2, SX2)
BNPR R2
BNPS A

Op-Code + M1
432
432
032
222 (Backward)
232 (Forward)

Format
RX1, RX2
RX3
RR
SF

Operation
If the Greater Than (G) flag in the Condition Code is reset, a branch is taken to the second operand location. If the G flag is set, the next sequential instruction is executed.

Condition Code
Unchanged
Programming Note
The branch address must be located on a halfword boundary.
In the RR format, the branch address is contained in the register specified by R2.

## INSTRUCTION

Branch on Overflow (BO)
Branch on Overflow Register (BOR)
Branch on Overflow Short (BOS)

| Assembler Notation | Op-Code + M1 | Format |  |
| :--- | :--- | :--- | :--- |
| BO | D2 (X2) | 424 | RX1, RX2 |
| BO | A2 (FX2, SX2) | 424 | RX3 |
| BOR | R2 | 024 | RR |
| BOS | A | 204 (Backward) | SF |
|  |  | 214 (Forward) |  |

## Operation

If the Overflow (V) flag in the Condition Code is set, a branch is taken to the second operand location, If the V flag is reset, the next sequential instruction is executed.

## Condition Code

Unchanged

## Programming Note

The branch address must be located on a halfword boundary.

In the $R R$ format, the branch address is contained in the register specified by R2.

## INSTRUCTION

Branch on No Overflow (BNO)
Branch on No Overflow Register (BNOR)
Branch on No Overflow Short (BNOS)
Assembler Notation
Op-Code + M1

| BNO | D2 (X2) | 434 | RX1, RX2 |
| :--- | :--- | :--- | :--- |
| BNO | A2(FX2, SX2) | 434 | RX3 |
| BNOR | R2 | 034 | RR |
| BNOS | A | 224 (Backward) | SF |
|  |  | 234 (Forward) |  |

## Operation

If the Overflow (V) flag in the Condition Code is reset, a branch is taken to the second operand location. If the $V$ flag is set, the next sequential instruction is executed.

Condition Code
Unchanged
Programming Note
The branch address must be located on a halfword boundary.
In the RR format, the branch address is contained in the register specified by R 2.

## INSTRUCTION

Branch on Zero (BZ)
Branch on Zero Register (BZR)
Branch on Zero Short (BZS)

## Assembler Notation

| DZ | $\mathrm{D} 2(\mathrm{X} 2)$ |
| :--- | :--- |
| BZ | $\mathrm{A} 2(\mathrm{FX} 2, \mathrm{SX} 2)$ |
| BZR | R 2 |
| BZS | A |


| Op-Code + M1 | Format |
| :--- | :--- |
| 433 |  |
| 433 | RX1, RX2 |
| 033 | RX3 |
| 223 (Backward) | RR |
| 233 (Forward) | SF |
|  |  |

## Operation

If the $G$ and $L$ flags are both reset in the Condition Code, a branch is taken to the second operand location. If the G or L flag is set, the next sequential instruction is executed.

## Programming Note

The branch address must be located on a halfword boundary.
In the RR format, the branch address is contained in the register specified by R2.

## INSTRUCTION

Branch on Not Zero (BNZ)
Branch on Not Zero Register (BNZ)
Branch on Not Zero Short (BNZS)

Assembler Notation
Op-Code + M1

## BNZ D2(X2) 423

BNZ A2(FX2,SX2) 423
BNZR R2 023 023 RR
203 (Backward) 213 (Forward)

## Format

RX1, RX2
RX3
RR
SF

## Operation

If the G or L flag in the Condition Code is set, a branch is taken to the second operand address. If the G and L flags are both reset, the next sequential instruction is executed.

Condition Code
Unchanged

## Programming Note

The branch address must be located on a halfword boundary.
In the RR format, the branch address is contained in the register specified by R2.

Branch (Unconditional) (B)
Branch Register (Unconditional) (BR)
Branch Short (Unconditional) (BS)

| Assembler Notation |  | Op-Code + M1 | Format |
| :---: | :--- | :--- | :--- |
|  | B | D2(X2) | 430 |
| B | A2(FX2, SX2) | 430 | RX1, RX2 |
| BR | R2 | 030 | RX3 |
| BS | A | 220 (Backward) | RR |
|  |  | 230 (Forward) | SF |

## Operation

A branch is unconditionally taken to the second operand address.

## Condition Code

Unchanged

## Programming Note

The branch address must be located on a halfword boundary.

In the $R R$ format, the branch address is contained in the register specified by $R 2$.
Example: B

| Assembler Notation | Machine Code |  | Comments |
| :--- | :--- | :--- | :--- |
|  | OPTIN | 43000 A 00 | An unconditional branch is <br> taken to location $\mathrm{X}^{\prime} 0 \mathrm{~A}^{\prime} 00^{\prime}$. |

## INSTRUCTION

No Operation (NOP)
No Operation Register (NOPR)
Assembler Notation

Op-Code + M1
420
020

## Format

RX
RR

Operation
After a short delay (instruction decode time), the next sequential instruction is executed.

Condition Code
Unchanged
Programming Note
(D2(X2) and R2 are ignored and usually equal to zero (0).
Example: NOP, NOPR

| Assembler Notation |  |  | Comments |
| :--- | :--- | :--- | :--- |
|  | 0 | 42000000 | No Operation |
| NOP | 0 | 0200 | No Operation |

## CHAPTER 4 <br> FIXED POINT ARITHMETIC

Fixed Point Arithmetic instructions provide a complete set of operations for calculating addresses and indexes, for counting, and for general purpose fixed point arithmetic.

## DATA FORMATS

There are three formats for fixed point data: the halfword, the fullword, and the double word. In each of these formats, the most significant bit (Bit 0 ) is the Sign bit. The remaining bits, either 15, 31 or 63 , represent the magnitude.


Figure 4-1. Fixed Point Data Words Formats
Positive values are represented in true binary form with a Sign bit of ZERO. Negative values are represented in two's complement form with a Sign bit of ONE. To change the sign of a number, the two's complement of the number is produced as follows:

1. Change ail zeros to ones, and all ones to zeros.
2. Add one.

## FIXED POINT NUMBER RANGE

Fixed point numbers represent integers. Table 4-1 shows relation between different formats along with decimal values.

TABLE 4-1. FIXED POINT FORMAT RELATIONS

| DOUBLE WORD | FULLWORD | HALFWORD | DECIMAL |
| :---: | :---: | :---: | :---: |
| 8000000000000000 <br> (MOST NEGATIVE) |  |  | -9223372036854775808 |
|  | 80000000 <br> (MOST NEGATIVE) |  | -2147483648 |
|  |  | 8000 (MOSTNEGATIVE) |  |
| FFFFFFFFFFFFFFFF | FFFFFFFF | FFFF (LEFT NEGATIVE) | -32768 |
| 000000000000000 |  |  |  |
| 0000000000000001 | 00000000 |  |  |
|  | 00000001 | 0001 | -1 |
|  | 7FFFFFFF |  |  |
| (MOST POSITIVE) |  | 1 |  |
| 7FFFFFFFFFFFFFFF |  |  | 2147483647 |
| (MOST POSITIVE) |  |  | 9223372036854775807 |

## OPERATIONS

The Fixed Point instructions include both fullword and halfword operations. Fullword operations take place between (a) the contents of two general registers, or (b) between the contents of a general register and a fullword stored in memory, or (c) between the contents of a general register and a fullword obtained from the instruction stream. Fullword multiply produces a double word result which is contained in two adjacent registers. Fullword divide operates on a double word contained in two adjacent registers.

Halfword operations take place between a fullword contained in one of the general registers and a halfword contained in memory. Before the operation is started, the halfword in memory is expanded to a fullword by propagating the most significant bit (Sign bit) into the high order bits of the fullword. (The Halfword Multiply and Divide instructions are exceptions to this rule.)

## CONDITION CODE

All Fixed Point Arithmetic instructions except Multiply and Divide affect the Condition Code. The Condition Code indicates the effect of the operation on the 32 bit result.

In fixed point Add and Subtract operations, because the arguments are represented in two's complement form, all bits, sign included, participate in forming the result. Consequently, the occurrence of a carry or borrow has no real arithmetic significance.

For example, an Add operation between a minus one (FFFF FFFF) and a plus two (0000 0002) produces the correct result of plus one $(00000001)$ and a carry. The Condition Code is set to 1010 ( $\mathrm{C}=1$ and $\mathrm{G}=1$ ). "Carry only" means that the complete result, which in this case would have been 100000001 , would not fit in 32 bits.

An overflow occurs when the result does not fit in 31 bits. Note that bit "zero" must be reserved for the sign of the result. For example, adding one to the largest positive fixed point value will produce an overflow:

7FFF FFFF

| $+0000 \quad 0001$ |
| ---: |
| $=80000000$ |

the condition code is $0101(\mathrm{~V}=1$ and $\mathrm{L}=1)$
The result, 80000000 , is logically correct, but because the sign bit is negative when the result should be positive, the overflow condition exists.

The columns of the Condition Code table show the state of the C, V, G and L flags for the specific result.

The ' X ' in the Condition Code column means that particular flag is not defined, i. e., the flag can be 0 or 1 . Hence, no inference should be drawn by testing that particular flag.

## FIXED POINT INSTRUCTION FORMATS

The fixed point instructions use the Register to Register (RR), the Short Form (SF), the Register and Indexed Storage (RX), and the Register and Immediate (RI) instruction formats.

## FIXED POINT INSTRUCTIONS

The fixed point instructions described in this section are:

| A | Add | CI | Compare Immediate |
| :--- | :--- | :--- | :--- |
| AR | Add Register | CH | Compare Halfword |
| AI | Add Immediate | CHI | Compare Halfword Immediate |
| AIS | Add Immediate Short | M | Multiply |
| AH | Add Halfword | MR | Multiply Register |
| AHI | Add Halfword Imme iate | MH | Multiply Halfword |
| AM | Add to Memory | MHR | Multiply Halfword Register |
| AHM | Add Halfword to Memory | D | Divide |
| S | Subtract | DR | Divide Register |
| SR | Subtract Register | DH | Divide Halfword |
| SI | Subtract Immediate | DHR | Divide Halfword Register |
| SIS | Subtract Immediate Short | SLA | Shift Left Arithmetic |
| SH | Subtract Halfword | SLHA | Shift Left Halfword Arithmetic |
| SHI | Subtract Halfword Immediate | SRA | Shift Right Arithmetic |
| C | Compare | SRIIA | Shift Right Halfword Arithmetic |
| CR | Compare Register | CHVR | Convert to Halfword Value Register |

## INSTRUCTIONS

Add (A)
Add Register (AR)
Add Immediate (AI)
Add Immediate Short (AIS)

Assembler Notation

| A | R1, D2 (X2) |
| :--- | :--- |
| A | R1, A2 (FX2, SX2) |
| AR | R1, R2 |
| AI | R1, I2 (X2) |
| AIS | R1, N |

Op-Code

| 5 A | RX1, RX2 |
| :--- | :--- |
| 5 A | RX3 |
| 0A | RR |
| FA | RI2 |
| 26 | SF |

## Operation

The second operand is added algebraically to the contents of the register specified by R1. The result of this 32 bit addition replaces the contents of the register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | X | X |
| 1 | X | X | X |

Result is ZERO
Result is less then ZERO
Result is greater than ZERO
Arithmetic overflow
Carry

## Programming Notes

The second operand for the Add Immediate Short instruction is obtained by expanding the four bit data field, N , to a 32 bit fullword by forcing the high order bits to zero.

In the RX formats, the second operand must be located on a fullword boundary.
Example: A
Add contents of memory location labelled LAB to the contents of (REG) 4.

1. Register 4 Contains X'7F341234:'

Fullword in Memory at LAB contains X'7F124321'

## Assembler Notation

A REG4, LAB

Comments
ADD (LAB) TO (REG 4)

## Result of A Instruction

$($ REG4 $)=$ X'FE465555 $^{\prime}$
(LAB) $=$ unchanged by this instruction
Condition Code $=0101(\mathrm{~V}=1, \mathrm{~L}=1)$
2. Register 5 Contains $X^{\prime} 80000001^{\prime}$

Fullword in memory at LAB contains $X^{\prime} 80000002^{\prime}$

Assembler Notation
A REG5, LAB

## Comments

ADD (LAB) TO (REG 5)

## Result of A Instruction

$($ REG5 $)=X^{\prime} 00000003^{\prime}$
(LAB) $=$ unchanged by this instruction
Condition Code $=1110(\mathrm{C}=1, \mathrm{~V}=1, \mathrm{G}=1)$

## INSTRUCTIONS

Add Halfword (AH)
Add Halfword Immediate (AHI)

| Assembler Notation |  |  | Op-Code |
| :---: | :--- | :---: | :--- |

## Operation

The 16 bit second operand is expanded to a 32 bit fullword by propagating the most significant bit through Bits 15:0 of the fullword. The fullword operand is added to the fullword contents of the register specified by R1. The result replaces the contents of the register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | X | X |
| $\mathbf{1}$ | X | X | X |

## Result is ZERO

Result is less than ZERO
Result is greater than ZERO
Arithmetic overflow
Carry

## Programming Note

In the RX formats, the second operand must be located on a halfword boundary.
In the RI1 format, the 16 -bit I2 field is extended to a fullword by propogating the sign bit through bits 0:15. The contents of the index register specified by X 2 are then added to form the fullword second operand.

## Example: AH

This example adds the halfword at memory location labelled LAB to the contents of Register 4.

1. Register 4 contains $X^{\prime} 00230002^{\prime}$

Halfword at memory location LAB contains X'FFFF'

## Assembler Notation

AHI REG4, LAB
Result of Instruction
$($ REG4 $)=$ '00230001'
$(\mathrm{LAB})=$ unchanged by this instruction
Condition Code $=1010$ ( $\mathrm{C}=1, \mathrm{G}=1$ )
2. Register 5 contains X'FFFF FFF5'

LAB contains X'FFF2'

## Assembler Notation

AH REG5, LAB

## Comments

ADD (LAB) TO (REG 4)

## Comments

ADD LAB TO REG5

## Result of Instruction

(REG5) $=$ 'FFFF FFE7'
$(\mathrm{LAB})=$ unchanged by this instruction
Condition Code $=1001(\mathrm{C}=1, \mathrm{~L}=1)$

## INSTRUCTION

Add to Memory (AM)
Assembler Notation

| Op.Code | Format |
| :---: | :--- |
| 51 | RX1, RX2 |
| 51 | RX3 |

## Operation

The fullword second operand is added algebraically to the contents of the register specified by R1. The result replaces the fullword second operand in memory. The contents of the register specified by R 1 are not changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | X | X |
| 1 | X | X | X |

Result is ZERO
Result is less than ZERO
Result is greater than ZERO
Arithmetic overflow
Carry

## Programming Note

The second operand must be located on a fullword boundary.
Example: AM

1. Add contents of register 8 to memory location labelled LOC:

Register 8 contains $X^{\prime} 00000008^{\prime}$
Fullword in memory at LOC contains X'034289AB'
Assembler Notation Comments
AM REG8, LOC ADD (REG 8) TO (LOC)

Result of AM Instruction
$($ REG8 $)=X^{\prime} 00000008^{\prime}$
$(\mathrm{LOC})=\mathrm{X}^{\prime} 034289 \mathrm{~B}^{\prime}$
Condition Code $=0010(\mathrm{G}=1)$
2. Add contents of register 7 to memory location labelled LOC:

Register 7 contains X'7F341234'
Fullword in memory at LOC contains X'7F124321'

## Assembler Notation

AM REG7, LOC

Comments

ADD (REG 7) TO (LOC)

## Result of AM Instruction

(REG7) $=$ unchanged by this instruction
$($ LOC $)=X^{\prime}$ FE465555 ${ }^{\prime}$
Condition Code $=0101$ ( $\mathrm{V}=1, \mathrm{~L}=1$ )

## INSTRUCTION

Add Halfword to Memory (AHM)

Assembler Notation
$\begin{array}{ll}\text { AHM } & \text { R1, D2 (X2) } \\ \text { AHM } & \text { R1, A2 (FX2, SX2) }\end{array}$

Op-Code

## 61

61

Format
RX1, RX2
RX3

## Operation

The second operand is expanded to a fullword by propagating the most significant bit through Bits $15: 0$. This fullword is added algebraically to the contents of the register specified by R1. The 32 bit result is truncated to 16 bits by removing the most significant bits (Bits $0: 15)$. The 16 bit result replaces the contents of the memory location specified by the effective address of the second operand. The contents of the register specified by R1 are not changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | X | X |
| 1 | X | X | X |

Result is ZERO
Result is less than ZERO
Result is greater than ZERO
Arithmetic overflow
Carry

## Programming Note

The second operand must be located on a halfword boundary.
The Condition Code settings are based on the halfword result.

## Example: AHM

This example adds the contents of Register 5 to the contents of memory location LAB.

1. Register 5 contains $X^{\prime} 00230002^{\prime}$

Halfword in memory at LAB contains X'FFFF'

## Assembler Notation

AHM REG5, LAB

## Comments

ADD (REG 5) TO (LAB)

## Result of AHM Instruction

(REG5) $=$ unchanged by this instruction
$(\mathrm{LAB})=0001$
Condition Code $=1010(\mathrm{C}=1, \mathrm{G}=1)$
2. Register 6 contains X'FFFF FFF5' LAB contains X'FFF2'

Assembler Notation
Comments
AHM REG6, LAB
ADD (REG 6) TO (LAB)

Result of AHM Instruction:
(REG6) $=$ unchanged by this instruction
$(\mathrm{LAB})=$ FFE7
Condition Code $=1001(\mathrm{C}=1, \mathrm{~L}=1)$

## INSTRUCTIONS

Subtract (S)
Subtract Register (SR)
Su'Jtract Immediate (SI)
Subtract Immediate Short (SIS)

## Assembler Notation

| S | R1, D2 (X2) |
| :--- | :--- |
| S | R1, A2 (FX2, SX2) |
| SR | R1, R2 |
| SI | R1, 12 (X2) |
| SIS | R1, N |


| Op-Code | Format |
| :---: | :--- |
| $5 B$ | RX1, RX2 |
| $5 B$ | RX3 |
| 0B | RR |
| FB | RI2 |
| 27 | SF |

## Operation

The fullword second operand is subtracted algebraically from the contents of the register specified by R1. The result replaces the contents of the register specified by R1.

## Condition Code

| C | V | G | I |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | I | X | X |
| I | X | X | X |

## Result is ZERO

Result is less than ZERO
Result is greater than ZERO
Arithmetic overflow
Borrow

## Programming Note

The second operand for the Subtract Immediate Short instruction is obtained by expanding the four bit data field, N , to a 32 bit fullword by forcing the high order bits to zero.

In the $R X$ formats, the second operand must be located on a fullword boundary.

## Examples:

This example subtracts the fullword at memory location LOC from the contents of Register 9 .

1. REG9 contains X'44444444'

LOC contains X'44444444'

## Assembler Notation

S REG9, LOC

Comments
Subtract contents of (LOC) from (REG 9)

## Result of S Instruction

$($ REG9) $=0$
LOC $=X^{\prime} 44444444^{\prime}$
Condition Code $=0000$
2. REG9 contains X'23456789'

LOC contains X'FFFF4321'

## Assembler Notation

S REG9, LOC

Comments

Subtract contents of (LOC) from (REG 9)

Result of S Instruction
(REG9) - 23462368
$($ LOC $)=$ FFFF4321
Condition Code $=1010 \quad(\mathrm{C}=1, \mathrm{G}=1)$

## INSTRUCTIONS

Subtract Halfword (SH)
Subtract Halfword Immediate (SHI)

| Assembler Notation |  |
| :---: | :--- |
| SH | R1, D2 (X2) |
| SH | R1, A2 (FX2, SX2) |
| SHI | R1, I2 (X2) |


| Op-Code | Format |
| :---: | :--- |
|  |  |
| 4B | RX1, RX2 |
| 4B | RX3 |
| CB | RI1 |

## Operation

The 16 bit second operand is expanded to a 32 bit fullword by propagating the most significant bit through Bits 15:0. This fullword is subtracted from the contents of the register specified by R1. The result replaces the contents of the register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | X | X |
| 1 | X | X | X |

Result is ZERO
Result is less than ZERO
Result is greater than ZERO
Arithmetic overflow
Borrow

## Programming Notes

In the RX formats, the second operand must be located on a halfword boundary.
In the RII format, the 16 -bit I2 field is extended to a fullword by propogating the sign bit through bits $0: 15$. The contents of the index register specified by X 2 are then added to form the fullword second operand.

## Example: SH

This example subtracts the halfword at memory location LOC from the contents of register 9.

1. REG9 contains $X^{\prime} 00123456{ }^{\prime}$

LOC contains X'FFF4'

Assembler Notation
SII REG9, LOC

## Comments

Subtract contents of (LOC) from (REG 9)

## Result of SH Instruction

$($ REG9) $)=00123462$
$(\mathrm{LOC})=\mathrm{FFF} 4$
Condition Code $=1010$
2. REG9 contains $X^{\prime}$ FFFF4567'

LOC contains $\mathrm{X}^{\prime} \mathbf{2 3 4 5}{ }^{\prime}$

Assembler Notation
SH REG9, LOC

## Comments

Subtract contents of (LOC) from (REG 9)

## Result of SH Instruction

$($ REG9 $)=$ FFFF2222
$(\mathrm{LOC})=2345$
Condition Code $=0001$

## INSTRUCTIONS

Compare (C)
Compare Register (CR)
Compare Immediate (CI)

Assembler Notation
C R1, D2 (X2)
$\mathrm{C} \quad \mathrm{R} 1, \mathrm{~A} 2$ (FX2, SX2)
CR
$\mathrm{Cl} \quad \mathrm{R} 1, \mathrm{I} 2(\mathrm{X} 2)$

Op-Code

| 59 | RX1, RX2 |
| :--- | :--- |
| 59 | RX3 |
| 09 | RR |
| F9 | RI2 |

## Operation

The first operand, contained in the register specified by R1, is compared algebraically to the 32 bit second operand. The result is indicated by the Condition Code setting. Neither operand is changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | X | 0 | 0 |
| 1 | X | 0 | 1 |
| 0 | X | 1 | 0 |

First operand is equal to second operand
First operand is less than second operand
First operand is greater than second operand

## Programming Notes

In the RX formats, the second operand must be located on a fullword boundary.

The state of the V flag is undefined.
Example: C
This example compares the contents of Register 3 to the contents of the fullword in memory location LAB.

Register 3 contains X'44567894'
Fullword at LAB contains X'04321243'

## Assembler Notation

C REG3, LAB

## Comments

Compare (REG 3) to (LAB)

## Result of C Instruction

(REG3) $=$ unchanged by this instruction (LAB) $=$ unchanged by this instruction Condition Code $=0010(\mathrm{G}=1)$

## INSTRUCTIONS

Compare Halfword (CH)
Compare Halfword Immediate (CHI)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :--- |
| CH | R1, D2 (X2) | 49 | RX1, RX2 |
| CH | R1, A2 (FX2, SX2) | 49 | RX3 |
| CHI | R1, I2 (X2) | C9 | RI1 |

## Operation

The halfword second operand is expanded to a fullword by propagating the most significant bit through Bits 15:0. This fullword is compared algebraically with the first operand, the contents of the register specified by R 1 . The result is indicated by the Condition Code setting. Neither operand is changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | X | 0 | 0 |
| 1 | X | 0 | 1 |
| 0 | X | 1 | 0 |

First operand is equal to second operand
First operand is less than second operand
First operand is greater than second operand

## Programming Notes

In the RX formats, the second operand must be located on a halfword boundary.
In the RII format, the 16 -bit I2 field is extended to a fullword by propogating the sign bit through bits $0: 15$. The contents of the index register specified by X2 are then added to form the fullword second operand.

Condition code settings are based on the fullword comparison. The state of the V flag is undefined.

## Example: CH

This example compares the contents of REG8 to the halfword at LAB.
REG8 contains X' ${ }^{\prime} 4567891^{\prime}$
Halfword at LAB contains X'3123'

Assembler Notation
Comments
CH REG8, LAB
Compare (REG 8) to (LAB)

## Result of CH Instruction

(REG8) $=$ unchanged by this instruction
(LAB) $=$ unchanged by this instruction
Condition Code $=1001$ ( $\mathrm{C}=1, \mathrm{~V}=1$ )

## INSTRUCTIONS

Multiply (M)
Multiply Register (MR)

## Assembler Notation

Op-Code

R1, D2 (X2)
R1, A2 (FX2, SX2)
R1, R2

5 C
5C
1C

## Format

RX1,RX2
RX3
RR

## Operation

The R1 field of these instructions specifies an even numbered register.
The fullword first operand, contained in the register specified by R1+1, is multiplied by the fullword second operand. The 64 bit result is stored in the registers specified by R1 and R1 +1 .

## Condition Code

Unchanged

## Programming Notes

The Rl field of these instructions must specify an even numbered registex.
【 If the R1 field of these instructions is odd, the result is undefined.

In the RX formats, the second operand must be located on a fullword boundary.
The most significant bits of the result are placed in the register specified by R 1 , the least significant bits of the result are placed in the register specified by $\mathrm{Rl}+1$.

- The sign of the result is determined by the rules of algebra.


## Example: M

This example multiplies the contents of Register 9 by the contents of memory location LOC and places the answer in the Registers 8 and 9 ( 64 bits).

- REG8 contains X'nmmanan'

REG9 contains X'00002431'
Fullword at location LOC contains $X^{\prime} 43120000{ }^{\prime}$

## Assembler Notation

- M REG8, LOC


## Comments

Multiply (REG 9) by (LOC)

## Result of M Instruction

- REG8 and REG9 together contain the answer
$($ REG8, REG9) $=0000097 \mathrm{~B}, 5 \mathrm{E} 720000$
$(\mathrm{LOC})=$ unchanged by this instruction
Condition Code $=$ unchanged by this instruction


## INSTRUCTIONS

Multiply Halfword (MH)
Multiply Halfword Register (MHR)

## Assembler Notation

| MH | R1, D2 (X2) |
| :--- | :--- |
| MH | R1, A2 (FX2, SX2) |

MHR R1,R2

Op-Code

4C
4 C
0 C

## Format

RX1, RX2
RX3
RR

## Operation

The first operand, contained in Bits 16:31 of the register specified by R1, is multiplied by the 16 bit second operand, taken from memory or from Bits 16:31 of the register specified by R2. Both operands are 16 bit signed two's complement values. The 32 bit result replaces the contents of the register specified by R1.

## Condition Code

Unchanged

## Programming Note

In the RX formats, the second operand must be located on a halfword boundary.
The sign of the result is determined by the rules of algebra.

## Example: MH

This example multiplies the halfword contents of Register 8 by the halfword in memory location LAB.

REG8 contains X'ABCD 0045'
Halfword at memory location LAB contains X'8674'

Assembler Notation
Comments
MH REG8, LAB
Multiply least significant half of (REG8) by (LAB)

## Result of MH Instruction

(REG8) = FFDF3D44
(IAB) $=$ unchanged by this instruction
Condition Code $=$ unchanged by this instruction

## INSTRUCTIONS

Divide (D)
Divide Register (DR)

Assembler Notation
$\mathrm{D} \quad \mathrm{R} 1, \mathrm{D} 2(\mathrm{X} 2)$
$\mathrm{D} \quad \mathrm{R} 1, \mathrm{~A} 2$ (FX2,SX2)
DR

R1, R2

Op-Code

5D
5D
1D

## Format

RX1, RX2
RX3
$R \mathrm{R}$

## Operation

The 64 bit dividend contained in the register specified by R1 and the register specified by $\mathrm{R} 1+1$ is divided by the fullword divisor. The 32 bit signed remainder replaces the contents - of the register specified Dy R1. The 32 bit sigied quotient replaces the contents of the register specified by R1+1.

## Condition Code

Unchanged

## Programming Notes

The R1 field of these instructions must specify an even numbered register.

If the R1 field of these instructions is odd, the result is undefined.
The most significant bits of the dividend must be contained in the register specified by R1. The least significant bits of the dividend must be contained in the register specified by R1 +1 .

In the RX formats, the second operand nust be iocated on a fullword boundary.
If the divisor is equal to zero, the instruction is not executed, the operand registers are unchanged, and the arithmetic fault interrupt is taken, if enabled by Bit-19 of the current program status word. If the inter rupt is not enabled, the next sequential instruotion is executed.

If the value of the quotient is greater than $X^{\prime} 7 F F F F F F F$ or less than (more negative than) X'80000000', quotient overflow is said to occur. If quotient overflow occurs, the operand registers are not changed, and the arithmetic fault inter rupt is taken, if enabled by the Bit-19 of the current program status word. If the interrupt is not enabled, the next sequential instruction is executed.

The sign of the quotient is determined by the rules of algebra. The sign of the remainder is the same as the sign of the dividend.

## Example: D

This example divides the contents of Registers 8 and 9 by the fullword contents of memory location LOC.

1. REG8 contains $\mathrm{X}^{\prime} 12345678^{\prime}=$ First Half of Dividend REG9 contains X'98765432' = Second Half of Dividend LOC contains X'34343434' = Divisor

## Assembler Notation

Comments
Divide (REG 8, 9) by (LOC)

## Result of D Instruction

(REG8) $=$ 1E1E1E1E $=$ Remainder
(REG9) $=59455459=$ Quotient
$($ LOC $)=34343434$
Condition Code $=$ unchanged by this instruction
2. REG8 contains X'FFFF1234' = First Half of Dividend REG9 contains $X^{\prime} 00000000^{\prime}=$ Second Half of Dividend LOC contains X'12345678' = Divisor

Assembler Notation

D REG8, LOC

## Comments

Divide (REG 8,9) by (LOC)

## Result of D Instruction

(REG8) $=$ F250D9E0 $=$ Remainder
(REG9) $=$ FFF2EFFC $=$ Quotient
LOC $=12345678$
Condition Code $=$ unchanged by this instruction
3. REG8 contains $X^{\prime} 43657898^{\prime}=$ First Half of Dividend REG9 contains X'12123456' = Second Half of Dividend LOC contains $X^{\prime} 00000000^{\prime}=$ Divisor

## Assembler Notation

D REG8, LOC

## Comments

Divide (REG8, 9) by (LOC)

## Result of D Instruction

Division by zero causes arithmetic fault to be taken if Bit 19 of PSW is enabled.
Operands and Condition Code remain unchanged by this instruction.

```
4. REG8 contains X'80000000' = First Half of Dividend REG9 conatins X'00000001' = Second Half of Dividend LOC contains \(\mathrm{X}^{\prime} 00000001^{\prime}=\) Divisor
```

Assembler Notation

D REG8, LOC

Comments

Divide (REG 8,9) by (LOC)

## Result of D Instruction:

Quotient overflow causes arithmetic fault to be taken if Bit-19 of PSW is enabled. Operands and Condition Code remain unchanged by this instruction.

## INSTRUCTIONS

Divide Halfword (DH)
Divide Halfword Register (DHR)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :--- |
|  | R1, D2 (X2) |  |  |
| DH | R1, A2 (FX2, SX2) | 4 D | RX1, RX2 |
| DHR | R1, R2 | 4 D | RX3 |
|  | DR | RR |  |

## Operation

The 32 bit divident contained in the register specified by R1 is divided by a 16 bit signed, two's complement divisior taken from memory or from Bits 16:31 of the register specified by R2. The 16 bit remainder is expanded to a fullword by propagating the Sign bit through Bits 15:0 and is stored in the register specified by R1. The 16 bit quotient is expanded to a fullword by propagating the Sign bit through Bits 15:0 and is stored in the register specified by $\mathrm{R} 1+1$.

## Condition Code

U'nchanged

## Programming Notes

In the RX formats, the second operand must be located on a halfword boundary.
If the divisor is equal to zero, the instruction is not executed, the operand registers are unchanged, and the arithmetic fault interrupt is taken, if enabled by Bit-19 of the current program status word. If the intermpt is not enabled, the next sequential instruction is executed.

If the value of the quotient is greater than $X^{\prime} 7 F F F^{\prime}$ or less than (more negative than) $\mathrm{X}^{\prime} 8000$, quotient overflow is said to occur.

If quotient overflow occurs, the operand registers are not changed, and the arithmetic fault interrupt is taken, if enabled by Bit-19 of the current program status word. If the interrupt is not enabled, the next sequential instruction is executed.

The sign of the quotient is determined ory the rules of algebra. The sign of the remainder is the same as the sign of the dividend.

## Example: DH

This example divides the contents of Register 7 by the halfword contents of memory location LOC.

1. REG7 contains $X^{\prime} 00009054^{\prime}=$ Dividend

LOC contains X'0008 = Divisor

## Assembler Notation

DH REG7, LOC
Comments

Divide (REG 7) b; (LOC)

Result of DH Instruction
$($ REG7 $)=00000004=$ Remainder
(REG8) $=0000000 \mathrm{~A}=$ Quotient
$($ LOC $)=0008$
Condition Code $=$ unchanged by this instruction
2. REG7 contains $X^{\prime} 12345678^{\prime}=$ Dividend

LOC contains $X^{\prime} 0000^{\prime}=$ Divisor

Assembler Notation
Comments
DH REG7, LOC
Divide (REG 7) by (LOC)

Result of DH Instruction
Division by zero causes arithmetic fault to be taken if Bit-19 of PSW is enabled. Operands and Condition Code remain unchanged by this instruction.
3. REG7 contains $\mathrm{X}^{\prime} 8000$ 0002 ${ }^{\prime}=$ Dividend LOC contains X ${ }^{\prime} 0001^{\prime}$

Assembler Notation
DH REG7, LOC

Comments
Divide (REG 7) by (LOC)

Result of DH Instruction
Quotient overflow causes arithmetic fault to be taken if Bit-19 of PSW is enabled. Operands and Condition Code remain unchanged by this instruction.

## INSTRUCTION

Shift Left Arithmetic (SLA)

Assembler Notation
SLA R1,I2 (X2)

Op-Code
EF

Format
RII

## Operation

Bits 1:31 of the first operand, contained in the register specified by R1, are shifted left the number of places specified by the second operand. The Sign bit (Bit 0), remains unchanged. Bits shifted out of Position 1 are shifted through the carry flag and then lost. The last bit shifted remains in the carry flag. Zeros are shifted into Position 31.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |

Result is ZERO
Result is less than ZERO
Result is greater than ZERO

## Programming Notes

The state of the C flag indicates the state of the last bit shifted.
The shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31 .

A shift of zero places causes the Condition Code to be set in accordance with the value contained in the register specified by R1. The C flag is reset in this case.

## Example: SLA

This example shifts the bits in Register 5 left by the number specified by the second operand.

REG5 contains X'80005647'

## Assembler Notation

SLA REG5,4

Comments
Shift Left 4 Places

## Result of Instruction:

$($ REG5) $=80056470$
Condition Code $=0001(\mathrm{~L}=1)$

## INSTRUCTION

Shift Left Halfword Arithmetic (SLHA)

Assembler Notation

SLHA R1,I2 (X2)

Op-Code
CF

Format
RI1

## Operation

Bits 17:31 of the register specified by R1 are shifted left the number of places specified by the second operand. Bit 16 of the register, the halfword Sign bit, remains unchanged. Bits shifted out of Position 17 are shifted through the carry flag and then lost. The last bit shifted remains in the carry flag. Zeros are shifted into Position 31. Bits 0:15 of the first operand register remain unchanged.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | $\mathbf{1}$ | 0 |

## Result is ZERO

Result is less than ZERO
Result is greater than ZERO

## Programming Notes

The Condition Code settings are based on the halfword, Bits 16:31, result.
The state of the C flag indicates the state of the last bit shifted.
The shift count is specified by the least significant four bits of the second operand. The maximum shift count is 15 .

A shift of zero places causes the Condition Code to be set in accordance with the halfword value contained in Bits 16:31 of the register. The C flag is reset in this case.

## INSTRUCTION

Shift Right Arithmetic (SRA)

| Assembler Notation | Op-Code | Format |  |
| :---: | :---: | :---: | :---: |
| SRA | R1, I2 (X2) | EE | RI1 |

## Operation

Bits 1:31 of the first operand, contained in the register specified by R1, are shifted right the number of places specified by the second operand. The Sign bit (Bit 0), remains unchanged and is propagated right as many positions as specified by the second operand. Bits shifted out of Position 31 are shifted through the carry flag and lost. The last bit shifted remains in the carry flag.

## Condition Code

| $\mathbf{C}$ | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |

Result is ZERO
Result is less than ZERO
Result is greater than ZERO

## Programming Notes

The state of the C flag indicates the state of the last bit shifted.
The shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31 .

A shift of zero places causes the Condition Code to be set in accordance with the value contained in the register. The C flag is reset in this case.

A shift of zero places causes the Condition Code to be set in accordance with the value contained in the register. The state of the C flag in undefined in this case.

## Example: SRA

This example shifts the contents of Register 9 right the number of places specified by the second operand.

REG9 contains X'800004256'

## Assembler Notation

SRA REG9, 8

## Comments

Shift (REG 9) right 8 bits

## Result of Instruction

(REG9) $=$ X'FF800042' $^{\prime}$
Condition Code $=0001(\mathrm{~L}=1)$

Shift Right Halfword Arithmetic (SRHA)

| Assembler Notation |  | Op-Code | Format |
| :---: | :---: | :---: | :---: |
| SRHA | R1, I2 (X2) | CE | RI1 |

## Operation

Bits 17:31 of the register specified by R1 are shifted right the number of places specified by the second operand. Bit-16 of the register, the halfword Sign bit, remains unchanged and is propagated right the number of positions specified by the second operand. Bits shifted out of Position 31 are shifted through the carry flag and lost. The last bit shifted remains in the carry flag. Bits $0: 15$ of the first operand register remain unchanged.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |

Result is ZERO
Result is less than ZERO
Result is greater than ZERO

## Programming Notes

The condition code settings are based on the halfword; Bits 16:31, result.
The state of the C flag indicates the state of the last bit shifted.
The shift count is specified by the least significant four bits of the second operand. The maximum shift count is 15 .

If the second operand specifies a shift of zero places, the C flag is reset in this case.

## INSTRUCTION

Convert Halfword Value Register (CHVR)

Assembler Notation
CHVR R1,R2

## Op-Code

12

Format

RR

## Operation

The halfword second operand, (Bits $16: 31$ ) of the register specified by R2, is expanded to a fullword by propagating the most significant bit (Bit 16) through Bits 15:0. This fullword replaces the contents of the register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | X | 0 | 0 |
| X | X | 0 | 1 |
| X | X | 1 | 0 |
| X | 1 | X | X |
| 1 | X | X | X |
| 0 | X | X | X |

Result is ZERO<br>Result is less than ZERO<br>Result is greater than ZERO<br>Source operand cannot be represented by a 16 bit signed number<br>Carry flag was set in previous Condition Code<br>Carry flag was reset in previous Condition Code

## Programming Note

The V flag is set when Bits 0:15 of the second operand are not the same as Bit-16 of the second operand. (In this case, the G and L flags reflect the algebraic value of Bits 16:31 of the second operand.)

Execution of this instruction following halfword operations guarantees results identical with those that would be obtained if the program were run on an INTERDATA 16 bit machine. For example, assume that location A in memory contains the halfword value of $X^{\prime} 7 \mathrm{FFF}^{\prime}$ (decimal 32767 ) then,

| LII | R1, A | R1 contains $\mathrm{X}^{\prime} 00007 \mathrm{FFF}^{\prime}$ |
| :--- | :--- | :--- |
| AIS | R1, 1 | R1 contains $\mathrm{X}^{\prime} 00008000^{\prime}$ |

Following the add operation, the Condition Code is:

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | 0 |

indicating a result greater than zero, which is correct for fullword operations. If the same sequence were executed on a 16 bit Processor, as:

$$
\begin{array}{cll}
\text { LII } & \text { R1, A } & \text { R1 contains } X^{\prime} 7 F F F^{\prime} \\
\text { AIS } & \text { R1,1 } & \text { R1 contains X' } 8000^{\prime}
\end{array}
$$

Following this, the Condition Code in the halfword Processor is:

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 1 |

indicating overflow and a negative result. Going back to the original sequence and adding the Convert Halfword Value instruction produces the following:

| LII | R1, A | R1 contains $\mathrm{X}^{\prime} 00007 \mathrm{FFF}{ }^{\prime}$ |
| :---: | :---: | :---: |
| AIS | R1, 1 | R1 contains $\mathrm{X}^{\prime} 00008000^{\prime}$ |
| CHVR | R1, R1 | R1 contains X'FFFF8000 |

Following this sequence, the Condition Code is:

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 1 | 0 | 1 |

which is identical to that of the 16 bit Processor, and can be tested in the same manner.

## CHAPTER 5 <br> FLOATING POINT ARITHMETIC

Floating Point Arithmetic instructions provide a means for rapid manipulation of scientific data expressed as floating point numbers. Single Precision as well as Double Precision Floating Point Instructions are described in this chapter. The comprehensive set of instructions includes load and store floating point numbers; add, subtract, multiply, divide and compare two floating point numbers; convert fixed point to floating point and vice versa.

## INTRODUCTION

Floating point is a means of respresenting a quantity in any numbering system. Consider a decimal number (base $=10$ ), 123 which can be represented in the following forms:

| 123.0 | x | $10^{\circ}$ |
| :--- | :--- | :--- |
| 1.23 | x | $10^{2}$ |
| 0.123 | x | $10^{3}$ |
| 0.0123 | x | $10^{4}$ |

Note that in this example, the decimal point moved. Hence we have a floating point. In actual floating point representation the significant digits are always fractional and are collectively referred to as fraction. The power to which the base number is raised is called the exponent. For example, in the number ". $45678 \times 10^{2 / 1}, 45678$ is the fraction and 2 is the exponent. Both the fraction and the exponent may be signed. If we have a floating point representation as,
(sign of fraction) (exponent) (fraction)
then the following representation applies:

## Number

Floating point

| Sign | Exponent/Fraction |  |
| :---: | :---: | :---: |
| + | +2 | 3294 |
| - | +8 | 2376 |
| + | -4 | 59 |
| - | -8 | 92073 |

The convenience with which extremely large or small numbers can be expressed in floating point makes it ideally suitable for scientific computation. Note the compactness of floating point notation in the above examples.

The floating point representation in the Model $8 / 32$ is similar to the above representation. 'ine differences are as follows:

Hexadecimal, instead of decimal, numbering system is used.
Physical size of the number and hence the magnitude and the precision is limited.


Figure 5-1. Single Precision Floating Point Number Fields

## FLOATING-POINT NUMBER

In the Model 8/32 Processor a floating point number is represented in the following form:

| Sign | Exponent | Fraction |
| :--- | :--- | :--- |

Sign The most significant bit of a floating point number is a sign bit. The sign bit is zero for positive numbers and one for negative numbers. The floating point value of zero always has a positive sign.

Exponent The 7-Bit field, Bits $1: 7$, is designated as the exponent field. The exponent field contains the true value of the exponent plus $\mathrm{X}^{\prime} 40^{\prime}$ (decimal 64 ). This helps to represent very small magnitudes between 0 and 1 . The exponent is said to be expressed in excess 64 notation. Some of the exponent values are as follows:

| Exponent in <br> Excess 64 notation | True <br> exponent in <br> hexadecimal | True <br> exponent in <br> decimal | Multiply <br> fraction by |
| :---: | :---: | :---: | :---: |
| 00 | -40 | -64 | $16^{-64}$ |
| 3 F | -1 | -1 | $16^{-1}$ |
| 40 | 0 | 0 | 1 |
| 41 | 1 | 1 | 16 |
| 7 F | 3 F | 63 | $16^{+63}$ |

The exponent field for true zero is always 00

Fraction The fraction field is 6-hexadecimal digits for single precision floating point numbers (thus limiting the precision) and 14 -hexadecimal digits for double precision floating point numbers. As in any other fraction, the floating point fraction is expressed with most precision when the most significant digit (not necessarily the most significant bit) is non-zero. The floating point number with such a fraction is called a normalized floating point number. In the model 8/32 Processor, normalized numbers are always used to obtain maximum possible precision. For hexadecimal fraction conversion, refer to Appendix 6.

Examples: The following examples illustrate the sign, exponent and fraction concept of a floating point number.

| Numbers in Hex integer-fraction notation | Sign-exponent-fraction shown for clarity |  |  | Single Precision <br> Floating point number |
| :---: | :---: | :---: | :---: | :---: |
|  | S | E | F |  |
| +1.3A25678 | 0 | 41 | 13 A 25678 | 4113 A 256 |
| -6.89 F 2 C | 1 | 41 | 689 F 2 C | C1689F2C |
| + 1A. C 39 D 21 | 0 | 42 | 1 AC 39021 | 421 AC39 |
| -3C1 DF. 82 A 3 | 1 | 45 | 3 C 1 DF 82 A 3 | C53C1 DF8 |
| + ABCDEF12.9AC | 0 | 48 | ABCDEF129 A C | 48 ABCDEF |
| $+0.0032 \mathrm{~A} 9 \mathrm{CF} 2$ | 0 | 3E | 32 A 9 CF 2 | 3 E 32 A 9 CF |
| -0.000002C7B5 | 1 | 3B | 2C 7 B 5 | B B 2 C 7 B50 |

Refer to Appendix 6 for examples of similar conversion to double precision floating point numbers.

## Floating Point Number Range

The range of magnitude (M) of a normalized floating point number is as follows.

| Single precision: | $16^{-65} \leq M \leq\left(1-16^{-6}\right) * 16^{63}$ |
| :--- | :--- |
| Double precision: | $16^{-65 \leq M \leq\left(1-16^{-14}\right) * 16^{63}}$Approximately for both: |
| $.4 * 10^{-79}<M<7.2 * 10^{75}$ |  |

Table 5-1 shows the single precision point range in relocation to the fixed point range along with the decimal values.

TABLE 5-1 FLOATING/FIXED POINT RANGES

|  | Floating Point <br> numbers | Fixed Point <br> integer | Decimal <br> numbers |
| :--- | :---: | :---: | :---: |
| (most negative) | FFFF FFFF |  | $-7.2 * 10^{75}$ |
|  | C 8800000 |  |  |
|  | C111000 | 80000000 (most negative) | -2147483648 |
| FFFF FFFF (least negative) | -1 |  |  |
| (least negative) | 80100000 |  |  |
| (true zero) | 00000000 | 00000000 | $-5.4 * 10^{-79}$ |
| (least positive) | 00100000 |  | 0 |
|  | 41100000 | 00000001 (least positive) | $+5.4 * 10^{-79}$ |
|  | 487 FFFFF | 7 FFF FFFF (most positive) | +1 |
| (most positive) | 7 FFFFFFF |  | +2147483647 |

## Normalization

Normalization is a process of making non-zero the most significant digit (F1) of the fraction of a floating point number. In the normalization process, the floating point fraction is shifted left hexadecimally (i.e., four bits at a time), and its exponent is decremented by one for each hexadecimal shift until the most significant digit (not necessarily the most significant bit) of the fraction is nonzero.


Except LE, LER, LD, LDR instructions, all the floating point operations assume and require normalized operands for consistent results. The LE, LER, LD and LDR instructions normalize an unnormalized operand.

Example:

Operands
After normalization

| 1. | 4 | 2 | 0 | 1 | 2 | 3 | 4 | 5 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 2. | 21 | 0 | 0 | 0 | $A$ | $B$ | $C$ |  |
| 3. | C 90 | 0 | 0 | F E | 1 | 2 |  |  |
| 4. | 6 | $C$ | 0 | 0 | 0 | 0 | 0 | 0 |
| 5. | 8 | 2 | 0 | 0 | 0 | A 6 | 7 |  |

41123450
1 EABC 000
C7FE1200
4. 6 C 000000

00000000 (true zero)
5. 82000 A 67

00000000 (exponent underflow)

In example 4, the fraction of the operand is zero. During the normalization process, such a fraction is detected and the floating point number is set to true zero.

In example 5, the exponent of the operand is very small. During the normalization process, the exponent is decremented from 00 to 7 F . Such a transition results in exponent underflow and the floating point number is set to true zero.

In floating point operations, assuming that the operands are normalized, normalized results are always produced. Results of operations between unnormalized aumbors are undefined.

## Equalization

Equalization is a process of making equal the exponents of two floating point numbers. The fraction of the floating point number with the smaller exponent is shifted right hexadecimally, i. e., four bits at a time, and its exponent is incremented by one for each hexadecimal shift until the two exponents are equal.


During the floating point addition and subtraction two floating point operands are equalized.

## Example:

|  | Floating point operands | After equalization |
| :---: | :---: | :---: |
| 1. | 43123456 | 43123456 |
|  | 3 F789ABC | 43000078 |
| 2. | C 7 F E 1234 | C 900 FE 12 |
|  | 4956789 A | 4956789 A |

In this example, normalized floating point numbers are shown because addition and subtraction require normalization. Note that if the exponents differ by 6 or more the significance of the lower exponent floating point number is lost in the process of equalization.

## True Zero

A floating point number is said to be true zero when the exponent and the fraction fields are all zeroes. In other words, all data bits must be zero. A value of zero always has a positive sign. In general, zero values participate as normal operands in all floating point operations.

A true zero may be used as an operand or may result from an arithmetic operation that caused an exponent underflow, in which case the entire number is forced to true zero. Secondly, if an arithmetic operation produces a result whose fraction digits are all zeroes (sometimes referred to as loss of significance), the entire number is forced to true zero.
l:xamples:

| Numbers | Operation | Result | Reason |
| :---: | :--- | :---: | :--- |
| 030000 AB | Normalize | 00000000 | exponent <br> underflow |
| 41 ABCDEF | Subtract | 00000000 | loss of <br> significance |

## Exponent Overflow

In floating point operations, exponent overflow may occur. Exponent overflow occurs when a resulting exponent is greater than +63 . If overflow occurs, the exponent and fraction bits of the result are set to all 1 s , the largest possible magnitude and therefore the closest possible answer. The sign of the result is not affected by the overflow. Figure 5-2 illustrates exponent overflow using a line representation of numbers.


Figure 5-2. Exponent Overflow

If overflow occurs, the V flag in the Condition Code is set, and an arithmetic fault interrupt is taken, if enabled by the current PSW.

## Exponent Underflow

The normalization process, during a floating point operation, may produce an exponent underflow. Exponent underflow occurs when a result exponent would be less than -64. If underflow occurs, the entire result is set to true zero, the closest possible answer. Figure 5-3 illustrates exponent underflow using a line representation of numbers.



Figure 5-3. Exponent Underflow

If underflow occurs, the V flag in the Condition Code is set, and an arithmetic fault interrupt is taken, if enabled by the current PSW.

## Data Formats

In the model $8 / 32$ Processor, floating point numbers occur in one of two formats, single precision and double precision. The single precision format requires a fullword ( 32 bits) in one of the 8 single precision floating point registers or on a fullword address boundary, in memory. The sign (s), exponent (x) and fraction (consisting of digits F1, F2, F3, F4, F5 and F6) fields are designated as follows:


The double precision format requires a doubleword ( 64 bits ) in one of the 8 double precision floating point registers or on a doubleword address boundary in memory. The sign (s), exponent ( x ) and fraction (consisting of digits F1 through F14) fields are designated as follows:


The value of a single (and similarly double) precision floating point number can be expressed as follows:

$$
\operatorname{sign}\left(\mathrm{F} 1.16^{-1}+\mathrm{F} 2.16^{-2}+\mathrm{F} 3.16^{-3}+\mathrm{F} 4.16^{-4}+\mathrm{F} 5.16^{-5}+\mathrm{F} 6.16^{-6}\right) 16^{\mathrm{X}-\mathrm{x}^{\prime} 40^{\prime}}
$$

## Guard Digit and Rounding

A guard digit is an extra hexadecimal digit provided to the right of the least significant fraction digit of a floating point number. In the model $8 / 32$, only single precision floating point numbers can have a guard digit. The guard digit is produced and used during the processing of intermediate results of a floating point operation. The guard digit does not appear in the final result. However, the guard digit helps rounding the final result, thus increasing the precision slightly. In the absence of a guard digit, as is the case in double precision floating point numbers, the final result is simply truncated.

## NOTE

The basic 8/32 Processor, which does not have the double precision floating point option, does not have a guard digit for single precision floating point numbers. Hence the results are truncated, not rounded.

A guard digit is produced during the equalization phase of an Add and Subtract single precision floating point operation. Then the operation is performed to obtain an intermediate result. The guard digit participates in the operation. If the guard digit of the intermediate result is 0 through 7 , no rounding is done. If it is 8 through $F$, one (1) is added to the fraction of the intermediate result to obtain the final result fraction, unless such an addition produces a carry into the exponent field. The following example illustrates the rounding procedure.


A guard digit is also produced during the Multiply and Divide single precision floating point operations. The intermediate product or the quotient is rounded as shown here to obtain the final result.

## Conversion from Decimal

The process of converting a decimal number into the excess 64 notation used internally by the Processor involves the following steps:

1. Separate the decimal integer from the decimal fraction:

$$
182.375_{10}=(182+.375)_{10}
$$

2. Convert each part to hexadecimal by referring to the Integer conversion table and the Fraction conversion table in Appendix 5.

$$
182_{10}=\mathrm{B} 6_{16} \quad .375_{10}=.6_{16}
$$

3. Combine the hexadecimal integer and fraction:

$$
\text { B6. } 6_{16}=\left(\mathrm{B} 6.6 \times 16^{0}\right)_{16}
$$

4. Shift the radix point:

$$
\left(\mathrm{B} 6.6 \times 16^{0}\right)_{16}=\left(. \mathrm{B} 66 \times 16^{2}\right)_{16}
$$

5. Add $64,\left(X^{\prime} 40^{\prime}\right)$, to the exponent

$$
40_{16}+2_{16}=42_{16}
$$

6. Convert the exponent field and fraction to binary allowing 1 bit for the sign, 7 bits for the exponent field, and 24 or 56 bits for the fraction.

$$
42 \mathrm{~B} 66=0100 \quad 0010 \quad 1011 \quad 0110 \quad 0110 \quad 0000
$$

## CONDITION CODE

Following floating point operations, including load, the Condition Code indicates the result of the operation.

## FLOATING POINT INSTRUCTION FORMATS

The Floating Point instructions use the Register to Register (RR), and the Register and Indexed Storage (RX) instruction formats. In all of the RR formats, except for Fix and Float, the R1 and the R2 fields specify one of the floating point registers. There are eight single precision floating point registers, and 8 double precision floating point registers numbered $0,2,4,6,8,10$, 12, and 14. Except FXR and FXDR instructions, the R1 field always specifies a floating point register.

## FLOATING POINT INSTRUCTIONS

The floating point arithmetic operations, excluding loads and stores, require normalized operands to ensure correct results. If the operands are not normalized, the results of these operations are undefined. Floating point results are normalized. The Floating Point Load instruction normalizes floating point data extracted from memory.

The single precision floating point instructions described in this section are:

| LE | Load Floating Point | CE | Compare Floating Point |
| :--- | :--- | :--- | :--- |
| LER | Load Floating Point Register | CER | Compare Floating Point Register |
| LME | Load Floating Point Multiple | ME | Multiply Floating Point |
| STE | Store Floating Point | MER | Multiply Floating Point Register |
| STME | Store Floating Point Multiple | DE | Divide Floating Point |
| AE | Add Floating Point | DER | Divide Floating Point Register |
| AER | Add Floating Point Register | FXR | Fix Register |
| SE | Subtract Floating Point | FLR | Float Register |
| SER | Subtract Floating Point Register |  |  |

The double precision floating point instructions described in this section are:

| LD | Load DPFP | CD | Compare DPFP |
| :--- | :--- | :--- | :--- |
| LDR | Load Register DPFP | CDR | Compare Register DPFP |
| LMD | Load Multiple DPFP | MD | Multiply DPFP |
| STD | Store DPFP | MDR | Multiply Register DPFP |
| STMD | Store Multiple DPFP | DD | Divide DPFP |
| AD | Add DPFP | DDR | Divide register DPFP |
| ADR | Add Register DPFP | FXDR | Fix Register DPFP |
| SD | Subtract DPFP | FLDR | Float Register DPFP |
| SDR | Subtract Register DPFP |  |  |

## INSTRUCTIONS

Load Floating Point (LE)
Load Floating Point Register (LER)

## Assembler Notation

| LE | R1, D2 (X2) |
| :--- | :--- |
| LE | R1, A2 (FX2, SX2) |
| LER | R1, R2 |

Op-Code
68
68
28

## Format

RX1, RX2
RX3
RR

## Operation

The floating point second operand is normalized, if necessary, and placed in the floating point register specified by R1.

## Condition Code

| C | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |

Floating point value is ZERO
Floating point value is less than ZERO
Floating point value is greater than ZERO
Exponent underflow

## Programming Notes

If the fraction is zero, the result is forced to $\mathrm{X}^{\prime} 00000000^{\prime}$
Normalization may produce exponent underflow. In this event, the result is forced to zero, $\mathrm{X}^{\prime} 00000000^{\prime}$, the V flag in the Condition Code is set, the G and L flags are reset and, if enabled by Bit 19 of the current PSW, the arithmetic fault interrupt is taken.

In the RX formats, the second operand must be located on a fullword boundary.

## Example: LE

This example normalizes the fullword at memory location LOC and places it in Floating Point Register 8.

Floating Point Register 8 = undefined
LOC $=X^{\prime} 42001000^{\prime}$

| Assembler Notation | $\underline{\text { Comments }}$ |
| :--- | :--- | :--- |
| LE REG8, LOC | Normalize contents of LOC |

## Result of LE Instruction

| (Floating Point Register 8) | $=40100000$ |
| :--- | :--- |
| $($ LOC | $=$ unchanged by this instruction |
| Condition Code | $=0010$ |

## INSTRUCTION

Load Floating Point Multiple (LME)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :--- |
| LME | R1, D2 (X2) |  |  |
| LME | R1, A2 (FX2, SX2) | 72 | RX1, RX2 |
|  | 72 | RX3 |  |

## Operation

Successive floating point registers, starting with the register specified by R1, are loaded from successive memory locations starting with the address of the second operand. The process stops when Floating Point Register 14 has been loaded.

## Condition Code

Unchanged

## Programming Notes

Values loaded into the floating point registers assumed to be normalized and no test or adjustment is performed.

The second operand must be located on a fullword boundary.

## INSTRUCTION

Store Floating Point (STE)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :---: |
|  |  |  | R1, D2 (X2) |

## Operation

The floating point first operand, contained in the floating point register specified by R1, is placed in the memory location specified by the second operand address. The first operand is unchanged.

## Condition Code

Unchanged

## Programming Note

The second operand must be located on a fullword boundary.

Store Floating Point Multiple (STME)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :---: |
|  |  |  |  |
| STME | R1, D2 (X2) | 71 | RX1, RX2 |
| STME | R1, A2 (FX2, SX2) | 71 | RX3 |

## Operation

The contents of successive floating point registers, starting with the register specified by R1, are stored in successive memory locations, starting with the address of the second operand. The operation stops when the contents of Floating Point Register 14 have been stored.

## Condition Code

Unchanged

## Programming Note

The second operand must be located on a fullword boundary.

## INSTRUCTIONS

Add Floating Point (AE)
Add Floating Point Register (AER)

## Assembler Notation

| AE | R1, D2 (X2) |
| :--- | :--- |
| AE | R1, A2 (FX2,SX2) |
| AER | R1, R2 |

Op-Code

6A
6A
2A

## Format

RX1, RX2
RX3
RR

## Operation

The exponents of the two operands are compared. If the exponents differ, the fraction with the smaller exponent is shifted right hexadecimally (four bits at a time), and its exponent is incremented by one for each hexadecimal shift until the two exponents are equal. The hexadecimal digits (of four bits each) are shifted through the guard digit. The guard digit contains the last shifted hexadecimal digit. If no shift occurs it is zero. The fractions are then added algebraically.

If the addition of fractions produces a carry, the exponent of the result is incremented by one and the fraction of the result is shifted right one hexadecimal digit. The carry bit is shifted back into the most significant hexadecimal digit of the fraction, producing a normalized result. This result replaces the contents of the register specified by R1.

If the addition of fractions does not produce a carry, the result is normalized, if necessary, and replaces the contents of the register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | 0 | 1 |
| X | 1 | 1 | 0 |
| X | 1 | 0 | 0 |

Floating point result is ZERO
Floating point result is less than ZERO
Floating point result is greater than ZERO
Exponent overflow, Result is negative
Exponent overflow, Result is positive
Exponent underflow

## Programming Notes

When the addition of the fractions produces a carry, incrementing the exponent of the result by one may produce exponent overflow. In this case, the result is forced to the maximum value, $\pm X^{\prime} 7$ FFF FFFF', the V flag, along with the G or L flag is set in the Condition Code and, if enabled by Bit 19 of the current PSW, the arithmetic fault interrupt is taken.

Normalization of the result may produce exponent underflow. In this case, the result is forced to zero, $\mathrm{X}^{\prime} 00000000^{\prime}$. The V flag is set in the Condition Code. The G and the L flags are always reset, and if enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.
If the guard digit is $0: 7$, the result is not rounded. If the guard digit is $8: F$, the result is rounded by adding 1 to the fraction of the result unless rounding produces a carry into the exponent field.
In the RX formats, the second operand must be located on a fullword boundary.

## Example: AE

This example adds the contents of LOC to the contents of the Floating Point Register 8 and places the answer in Floating Point Register 8.

Floating Point Register 8 contains X'7EFF FFFF'
LOC contains X'7EFF FFFF'

| Assembler Notation | Comments |
| :--- | :--- |
| AE REG8, LOC | ADD (REG 8) to (LOC) |

## Result of AE Instruction

```
(Floating Point Register 8) = 7F1F FFFF
(LOC) = unchanged by this instruction
Condition Code = 0010
```


## INSTRUCTIONS

Subtract Floating Point (SE)
Subtract Floating Point Register (SER)

## Assembler Notation

| SE | R1, D2 (X2) |
| :--- | :--- |
| SE | R1, A2 (FX2, SX2) |
| SER | R1,R2 |

## Op-Code

6B
6B
2B

Format

RX1, RX2
RX3
RR

## Operation

The exponents of the two operands are compared. If the exponents differ, the fraction with the smaller exponent is shifted right hexadecimally (four bits at a time), and its exponent is incremented by one for each hexadecimal shift until the two exponents are equal. The hexadecimal digits (of four bits each) are shifted through the guard digit. The guard digit contains the last shifted hexadecimal digit. If no shift occurs it is zero. The second operand fraction is then subtracted algebraically from the first operand fraction.

If the subtraction of fractions produces a carry, the exponent of the result is incremented by one and the fraction of the result is shifted right one hexadecimal digit. The carry bit is shifted back into the most significant hexadecimal digit of the fraction, producing a normalized result. This result replaces the contents of the register specified by R1.

If the subtraction of fractions does not produce a carry, the result is normalized. The normalized result replaces the contents of the register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | 0 | 1 |
| X | 1 | 1 | 0 |
| X | 1 | 0 | 0 |

Floating point result is ZERO
Floating point result is less than ZERO
Floating point result is greater than ZERO
Exponent overflow, Result is negative
Exponent overflow, Result is positive
Exponent underflow

## Programming Notes

When the subtraction of the fractions produces a carry, incrementing the exponent of the result by one may produce exponent overflow. In this case, the result is forced to the maximum value, $\pm \mathrm{X}^{\prime} 7 \mathrm{FFF}$ FFFF', the V flag, along with the G or L flag is set in the Condition Code and, if enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.

Normalization of the result may produce exponent underflow. In this case, the result is forced to zero, X'00000000'. The V flag is set in the Condition Code. The G and the L flags are always reset and, if enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.

The shifted hexadecimal digits (if any) participate in subtraction and produce a guard digit. If the guard digit is $0: 7$, the result is not rounded. If the guard digit is $8: \mathrm{F}$, the result is rounded by adding 1 to the fraction of the result unless rounding produces a carry into the exponent field.

In the RX formats, the second operand must be located on a fullword boundary.

Example: SE

This example subtracts the contents of LOC from the contents of Floating Point Register 8 and places the result in Floating Point Register 8.

Floating Point Register 8 contains X'7FEF FFFF'
LOC
contains X'7A10 0000'

## Assembler Notation

SE REG8, LOC

## Comments

Subtract (LOC) from REG8

## Result of Instruction

(Floating Point Register 8) $=7$ FEF FFFE
(LOC) $\quad=$ unchanged by this instruction
Condition Code $=0010$

## INSTRUCTIONS

Compare Floating Point (CE)
Compare Floating Point Register (CER)

Assembler Notation

| CE | $\mathrm{R} 1, \mathrm{D} 2$ (X2) |
| :--- | :--- |
| CE | $\mathrm{R} 1, \mathrm{D} 2$ (FX2, SX2) |
| CER | $\mathrm{R} 1, \mathrm{R} 2$ |

CER R1,R2

Op-Code

69
69
29

Format

RX1, RX2
RX3
RR

## Operation

The first operand is compared to the second operand. Comparision is algebraic, taking into account the sign, fraction, and exponent of each number. The result is indicated by the Condition Code setting. Neither operand is changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | X | 0 | 0 |
| 1 | X | 0 | 1 |
| 0 | X | 1 | 0 |

First operand is equal to second operand
First operand is less than second operand First operand is greater than second operand

## Programming Note

The state of the V flag is undefined.
In the RX formats, the second operand must be located on a fullword boundary.

## INSTRUCTIONS

Multiply Floating Point (ME)
Multiply Floating Point Register (MER)

Assembler Notation

| ME | R1, D2 (X2) |
| :--- | :--- |
| ME | R1, A2 (FX2,SX2) |
| MER | R1, R2 |

## Op-Code

6 C
6 C
6C
2C

Format
RX1, RX2
RX3
RR

## Operation

The exponents of each operand, as derived from the excess 64 notation used in floating point representation, are added to produce the exponent of the result. This exponent is converted back to excess 64 notation. The fractions are then multiplied.

If the result is zero, the entire floating point value is forced to zero, X'0000 0000'. If the product is not zero, the result is normalized. The sign of the result is determined by the rules of algebra. The result replaces the contents of the register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | 0 | 1 |
| X | 1 | 1 | 0 |
| X | 1 | 0 | 0 |

Floating point result is ZERO
Floating point result is less than ZERO Floating point result is greater than ZERO Exponent overflow, Result is negative Exponent overflow, Result is positive Exponent underflow

## Programming Notes

The addition of exponents may produce exponent overflow. In this case, the result is forced to the maximum value, $\pm \mathrm{X}^{\prime} 7 \mathrm{FFF}$ FFFF'. The V flag in the Condition Code is set, along with either the G or the L flag, depending on the sign of the result. An arithmetic fault interrupt is taken, if enabled by Bit-19 of the current PSW.

The addition of exponents or the normalization process can produce exponent underflow. In this case, the result is forced to zero, X'0000 $0000^{\prime}$. The V flag in the Condition Code is set. The G and L flags are reset, and if enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.

Multiplication of two 6-hexadecimal digit fractions effectively produces a result of 6-hexadecimal digits and a guard digit. If the guard digit is $0: 7$, the result is not rounded. If the guard digit is $8: \mathrm{F}$, the result is rounded by adding 1 to the fraction of the result, unless rounding produces a carry into the exponent field.

In the RX formats, the second operand must be located on a fullword boundary.

This example multiplies the contents of LOC by the contents of the Floating Point Register 8 and places the result in Floating Pointer Register 8.

Floating Point Register 8 contains X'5FFF FFFF'
LOC contains X'60FF FFFF'

Assembler Notation

ME REG8, LOC

## Comments

Multiply (REG 8) by (LOC)

Result of ME Instruction

| (Floating Point Register 8) | $=$ | 7FFF FFFE |
| :--- | :--- | :--- |
| (LOC) | $=$ | unchanged by this instruction |
| Condition Code | $=0010$ |  |

## INSTRUCTIONS

Divide Floating Point (DE)
Divide Floating Point Register (DER)

Assembler Notation

| DE | R1, D2 (X2) |
| :--- | :--- |
| DE | R1, A2 (FX2, SX2) |
| DER | R1, R2 |

Op-Code
6D
6D
2D

Format
RX1, RX2
RX3
RR

## Operation

The exponents of each operand, as derived from the excess of 64 notation used in floating point representation, are subtracted to produce the exponent of the result. This exponent is converted back to excess 64 notation.

The first operand fraction is then divided by the second operand fraction. Division continues until the quotient is normalized, adjusting the exponent for each additional division required. No remainder is returned. The sign of the quotient is determined by the rules of algebra. The quotient replaces the contents of the register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 0 |

Floating point result is ZERO
Floating point result is less than ZERO
Floating point result is greater than ZERO
Exponent overflow, Result is negative
Exponent overflow, Result is positive
Exponent underflow
Divisor equal to zero

## Programming Notes

Before starting the divide operation, the divisor is checked. If it is equal to zero, the operation is aborted. Neither operand is changed. The $C$ and the $V$ flags of the Condition Code are set. The $G$ and $L$ flags are reset. If enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.

The subtraction of exponents may produce exponent overflow. In this case, the result is forced to the maximum value, $\pm \mathrm{X}^{\prime} 7 \mathrm{FFF}$ FFFF'. The V flag in the Condition Code is set, along with either the G or the L flag, depending on the sign of the result. An arithmetic fault interrupt is taken, if enabled by Bit-19 of the current PSW.

The subtraction of exponents or the division process can produce exponent underflow. In this case, the result is forced to zero, $\mathrm{X}^{\prime} 00000000^{\prime}$. The V flag in the Condition Code is set. The G and L flags are always reset, and if enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.

The 6-hexadecimal digit first operand fraction is divided by the 6-hexadecimal digit second operand effectively producing the 6 -hexadecimal digit quotient along with a guard digit. If the guard digit is $0: 7$, the quotient is not rounded. If the guard digit is $8: F$, the quotient is rounded by adding 1 to the fraction of the result unless rounding produces a carry into the exponent field.

In the RX formats, the second operand must be located on a fullword boundary.

This example divides the contents of Floating Point Register 4 by the contents of memory location LOC and places the result in Floating Pointer Register 4.

Floating Point Register 4 contains X ${ }^{\prime} 44$ FF FFFF' $=$ Dividend
LOC contains X'0611 1111 = Divisor

Assembler Notation

DE REG4, LOC

Comments

Divide (LOC) into (REG 4)

## Result of DE Instruction:

```
(Floating Point Register 4) = 7FF0 0000
(LOC) = unchanged by this instruction
Condition Code = 0010
```


## INSTRUCTION

Fix Register (FXR)

Assembler Notation

FXR R1,R2

## Operation

R1 specifies one of the general purpose registers. R2 specifies one of the floating point registers. The floating point number contained in the floating point register is converted to a two's complement notation integer value by shifting and truncating. The result is stored in the register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | 0 | 1 |
| X | 1 | 1 | 0 |

Result is ZERO or underflow Result is less than ZERO
Result is greater than ZERO
Overflow, Result is negative
Overflow, Result is positive

## Programming Notes

The range of floating point magnitudes M that produces a non-zero integral result is:

$$
\pm \mathrm{X}^{\prime} 48800000^{\prime}>\mathrm{M} \geq \pm \mathrm{X}^{\prime} 41100000^{\prime}
$$

Floating point magnitudes greater than $+\mathrm{X}^{\prime} 487 \mathrm{FFFFF}$ ' cause overflow. The result is forced to $\mathrm{X}^{\prime} 7 \mathrm{FFF}$ FFFF' if positive or to $\mathrm{X}^{\prime} 80000001^{\prime}$ if negative. The V flag is set in the Condition Code along with either the G or L Flag, depending on the sign of the result.

Floating point magnitudes less than $+X^{\prime} 41100000^{\prime}$ cause underflow and the result is forced to zero.

In the event of overflow or underflow, the Arithmetic Fault Interrupt is not taken, even if enabled in the current PSW.

## Example: FXR

This example converts the contents of the Floating Point Register 8 to a fixed point number and places it in Register 3.

Floating Point Register 8 contains X'46FF FF00'
Register 3 contains undefined
Assembler Notation
Comments

FXR REG3, REG8
Convert (REG 8) to fixed point

## Result of FXR Instruction

| $($ REG3 $)$ | $=00 \mathrm{FFFF00}$ |
| :--- | :--- |
| (Floating Point Register 8$)$ | $=$ unchanged by this instruction |
| Condition Code | $=0010$ |

## INSTRUCTION

Float Register (FLR)

## Assembler Notation

FLR R1,R2

Op-Code

2F

Format

RR

## Operation

R1 specifies one of the floating point registers. R2 specifies one of the general purpose registers. The integer value contained in the register specified by R 2 is converted to a floating point number and stored in the floating point register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |

Result is ZERO
Result is less than ZERO
Result is greater than ZERO

## Programming Note

The full range of fixed point integer values may be converted to floating point. The fixed point value $X^{\prime} 7$ FFF FFFF', the largest positive integer, converts to a floating point value of $\mathrm{X}^{\prime} 487 \mathrm{~F}$ FFFF'. The fixed point value $X^{\prime} 80000000$ ', the most negative integer, converts to a floating point value of $\mathrm{X}^{\prime} \mathrm{C} 8800000^{\prime}$. The result in R1 is normalized, and truncated if necessary to fit in the six fraction digits.

## Example: FLR

This example converts the Fixed point contents of Register 4 to a Floating Point number and places it into Floating Point Register 8.
Register 4 contains X'7FFF FFF0'

Floating Point Register 8 contents undefined

Assembler Notation
FLR REG8, REG4

## Comments

Convert REG4 to Floating Point

Result of FLR Instruction:

| (Floating Point Register 8) | $=487$ FFFFF |
| ---: | :--- |
| (REG4) | $=$ unchanged by this instruction |
| Condition Code | $=0010$ |

## INSTRUCTIONS

Load Double Precision Floating Point (LD)
Load Register Double Precision Floating Point (LDR)

## Assembler Notation

| LD | R1, D2(X2) |
| :--- | :--- |
| LD | R1, A2, (FX2, SX2) |
| LDR | $R 1, R 2$ |

Op-Code
78
78
38

Format

RX1, RX2
RX3
RR

## Operation

The floating point second operand is normalized, if necessary, and placed in the double precision floating point register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |

Double precision value is ZERO
Double precision value is less than ZERO
Double precision value is greater than ZERO
Exponent underflow

## Programming Notes

If the fraction is zero, the result is forced to $\mathrm{X}^{\prime} 0000000000000000^{\prime}$.
Normalization may produce exponent underflow. In this event, the result is forced to $\mathrm{X}^{\prime} 0000$ $000000000000^{\prime}$, the $V$ flag in the Condition Code is set, the G and L flags are reset and, if enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.

In the RX formats, the second operand must be located on a double word boundary.

## INSTRUCTION

Load Multiple Double Precision Floating Point (LMD)

| Assembler Notation |  | Op-Code | Format |
| :---: | :---: | :---: | :---: |
|  |  |  |  |
| LMD | R1, D2(X2) | $7 F$ | RX1, RX2 |
| LMD | R1, A2(FX2, SX2) | $7 F$ | RX3 |

## Operation

Successive double-precision floating point registers, starting with the register specified by R1, are loaded from successive memory locations starting with the address of the second operand. The process stops when Double Precision Floating Point Register 14 has been loaded.

## Condition Code

Unchanged

## Programming Notes

Values loaded into the double precision floating point registers are assumed to be normalized and no test or adjustment is performed.

The second operand must be located on a double word boundary.

## INSTRUCTION

Store Double Precision Floating Point (STD)

Assembler Notation
$\begin{array}{ll}\text { STD } & \text { R1, D2, (X2) } \\ \text { STD } & \text { R1, A2(FX2, SX2) }\end{array}$

Op-Code
70 RX1, RX2
70

Format

RX3

## Operation

The floating point first operand, contained in the double precision floating point register specified by R1 is placed in the memory location specified by the second operand address. The first operand is unchanged.

## Condition Code

Unchanged.

## Programming Notes

The second operand must be located on a double word boundary.

## INSTRUCTION

Store Multiple Double Precision Floating Point (STMD)

## Assembler Notation

STMD R1, D2(X2)

STMD R1, A2 (FX2, SX2)

Op-Code
$7 E$
$7 E$

Format
RX1, RX2
RX3

## Operation

The contents of successive double precision floating point registers, starting with the register specified by R1, are stored in successive memory locations, starting with the address of the second operand. The operation stops when the contents of Double Precision Floating Point Register 14 have been stored.

## Condition Code

Unchanged

## Programming Note

The second operand must be located on a double word boundary.

## INSTRUCTIONS

Add Double Precision Floating Point (AD)
Add Register Double Precision Floating Point (ADR)

| Assembler Notation | Op-Code | Format |
| :---: | :---: | :--- |
|  | 7 A | RX1, RX2 |
| AD | 7 A | RX3 |
| AD R1, A2(FX2, SX2) | 3 A | RR |

## Operation

The exponents of the two operands are compared. If the exponents differ the fraction with the smaller exponent is shifted right hexadecimally (four bits at a time), and its exponent is incremented by one for each hexadecimal shift until the two exponents are equal. The fractions are then added algebraically.

If the addition of fractions produces a carry, the exponent of the result is incremented by one and the fraction of the result is shifted right one hexadecimal position. The carry bit is shifted back into the most significant hexadecimal digit of the fraction, producing a normalized result. This result replaces the contents of the double precision floating point register specified by R1.

If the addition of fractions does not produce a carry, the result is normalized, if necessary, and placed in the double precision floating point register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | 0 | 1 |
| X | 1 | 1 | 0 |
| X | 1 | 0 | 0 |

Double Precision Result is ZERO
Double Precision Result is less than ZERO
Double Precision Result is greater than ZERO
Exponent Overflow, Result is negative
Exponent Overflow, Result is positive
Exponent Underflow

## Programming Notes

When the addition of fractions produces a carry, incrementing the exponent of the result by one may produce exponent overflow. In this case, the result is forced to the maximum value, $\pm \mathrm{X}^{\prime} 7 \mathrm{FFF}$ FFFF FFFF FFFF', the V flag, along with the G or L flag is set in the Condition Code and, if enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.

Normalization of the result may produce exponent underflow. In this case, the result is forced to zero, X'0000 000000000000 '. The V flag is set in the Condition Code, and the G and L flags are reset, and if enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.

In the RX formats, the second operand must be located on a double word boundary.

## INSTRUCTIONS

Subtract Double Precision Floating Point (SD)
Subtract Register Double Precision Floating Point (SDR)

Assembler Notation

| SD | $R 1, \mathrm{D} 2(\mathrm{X} 2)$ |
| :--- | :--- |
| SD | $\mathrm{R} 1, \mathrm{~A} 2(\mathrm{FX} 2, \mathrm{SX} 2)$ |

SDR R1, R2

Op-Code 7B 7B 3B

Format
RX1, RX2
RX3
RR

## Operation

The exponents of the two operands are compared. If the exponents differ, the fraction with the smaller exponent is shifted right hexadecimally (four bits at a time), and its exponent is incremented by one for each hexadecimal shift until the two exponents are equal. The second operand fraction is then subtracted algebraically from the first operand fraction.

If the subtraction of fractions produces a carry, the exponent of the result is incremented by one and the fraction of the result is shifted right one hexadecimal position. The carry bit is shifted back into the most significant hexadecimal digit of the fraction producing a normalized result. This result replaces the contents of the double precision floating point register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | 1 | 0 |
| X | 1 | 0 | 1 |
| X | 1 | 0 | 0 |

Double Precision Result is ZERO
Double Precision Result is less than ZERO
Double Precision Result is greater than ZERO
Exponent Overflow, Result is positive
Exponent Overflow, Result is negative
Exponent Underflow,

## Programming Note

When the subtraction of fractions produces a carry, incrementing the exponent of the result by one may produce exponent overflow. In this case, the result is forced to the maximum value, $\pm \mathrm{X}^{\prime} 7 \mathrm{FFF}$ FFFF FFFF FFFF', the V flag, along with the G or L flag is set in the Condition Code, and if enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.

Normalization of the result may produce exponent underflow. In this case, the result is forced to zero, X'0000 $000000000000^{\prime}$. The V flag is set in the Condition Code, the G and L flags are reset, and if enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.

In the RX formats, the second operand must be located on a double word boundary.

## INSTRUCTIONS

Compare Double Precision Floating Point (CD)
Compare Register Double Precision Floating Point (CDR)

## Assembler Notation

| CD | $\mathrm{R} 1, \mathrm{D} 2(\mathrm{X} 2)$ |
| :--- | :--- |
| CD | $\mathrm{R} 1, \mathrm{~A} 2(\mathrm{FX} 2, \mathrm{SX} 2)$ |
| CDR | $\mathrm{R} 1, \mathrm{R} 2$ |

Op-Code

79
79
39

Format

RX1, RX2
RX3
RR

## Operation

The first operand is compared to the second operand. Comparison is algebraic, taking into account the sign, exponent and fraction of each number. The result is indicated by the Condition Code setting. Neither operand is changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | X | 0 | 0 |
| L | X | 0 | 1 |
| 0 | X | I | 0 |

First operand is equal to second operand
First operand is less than second operand First operand is greater than second operand

## Programming Notes

The state of the overflow flag is undefined.
In the RX formats, the second operand must be located on a double word boundary.

Multiply Double Precision Floating Point (MD)
Multiply Register Double Precision Floating Point (MDR)

## Assembler Notation

```
MD R1,D2(X2)
MD R1, A2(FX2,SX2)
MDR R1, R2
```


## Op-Code

## 7 C

7 C
3C

## Format

RX1, RX2
RX3
RR

## Operation

The exponents of the two operands, as derived from the excess 64 notation used in floating point representation, are added to produce the exponent of the result. This exponent is converted back to excess 64 notation. The fractions are then multiplied.

If the product is zero, the entire double precision value is forced to zero, X'0000 $000000000000^{\prime}$. If the product is not zero, the result is normalized if necessary. The sign of the result is determined by the rules of algebra. The result replaces the contents of the double precision floating point register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | 1 | 0 |
| X | 1 | 0 | 1 |
| X | 1 | 0 | 0 |

Double precision result is ZERO
Double precision result is less than ZERO
Double precision result is greater than ZERO
Exponent overflow, Result is positive
Exponent overflow, Result is negative
Exponent underflow

## Programming Notes

The addition of exponents may produce exponent overflow. In this case, the result is forced to the maximum value, $\pm X^{\prime} 7 F F F$ FFFF FFFF FFFF'. The V flag in the Condition Code is set, along with either the G or L flag, depending on the sign of the result. An arithmetic fault interrupt is taken, if enabled by Bit-19 of the current PSW.

The addition of exponents or the normalization process can produce exponent underflow. In this case, the result is forced to zero, $\mathrm{X}^{\prime} 0000000000000000^{\prime}$. The V flag in the Condition Code is set, the G and L flags are reset, and if enabled by Bit 19 of the current PSW, the arithmetic fault interrupt is taken.

In the RX formats, the second operand must be located on a double word boundary.

Divide Double Precision Floating Point (DD)
Divide Register Double Precision Floating Point (DDR)

## Assembler Notation

| DD | $\mathrm{R} 1, \mathrm{D} 2(\mathrm{X} 2)$ |
| :--- | :--- |
| DD | $\mathrm{R} 1, \mathrm{~A} 2(\mathrm{FX} 2 \mathrm{SX} 2)$ |
| DDR | $\mathrm{R} 1, \mathrm{R} 2$ |

Op-Code

7D
7D
3D

Format

RX1, RX2
RX3
RR

## Operation

The exponents of the two operands, as derived from the excess 64 notations used in floating point representation, are subtracted to produce the exponent of the result. This exponent is converted back to excess 64 notation.

The second operand fraction is then divided into the first operand fraction. Division continues until the quotient is normalized, adjusting the exponent for each additional division required.

No remainder is returned. The sign of the result is determined by the rules of algebra. The quotient replaces the contents of the double precision floating point register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 0 |

Double precision result is ZERO
Double precision result is less than ZERO
Double precision result is greater than ZERO
Exponent overflow, Result is negative
Exponent overflow, Result is positive
Exponent underflow
Divisor was zero

## Programming Notes

Before starting the divide operation, the divisor is checked. If it is equal to zero, the operation is aborted. Neither operand is changed. The C and V flags in the Condition Code are set, the G and L flags are reset, and if enabled by Bit 19 of the current PSW, the arithmetic fault interrupt is taken.

The subtraction of exponents may produce exponent overflow. In this case, the result is forced to the maximum value, $\pm$ X'7FFF FFFF FFFF FFFF'. The V flag in the Condition Code is set, along with either the G or L flag, depending on the sign of the result. An arithmetic fault interrupt is taken, if enabled by Bit-19 of the current PSW.

The subtraction of exponents or the division process may produce exponent underflow. In this case, the result is forced to zero, $\mathrm{X}^{\prime} 0000000000000000^{\prime}$. The V flag in the Condition Code is set, the G and L flags are reset, and if enabled by Bit-19 of the current PSW, the arithmetic fault interrupt is taken.

In the RX formats, the second operand must be located on a double word boundary.

## INSTRUCTION

Fix Register Double Precision (FXDR)

Assembler Notation
FXDR R1,R2

Op-Code

3E

Format

RR

Operation
R1 specifies one of the general purpose registers. R2 specifies one of the double precision floating point registers. The floating point number contained in the floating point register is converted to an integer value by truncating. The result is placed in the general register specified by R1.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |
| X | 1 | 0 | 1 |
| X | 1 | 1 | 0 |

Result is ZERO or underflow Result is less than ZERO Result is greater than ZERO Overflow, Result is negative Overflow, Result is positive

## Programming Notes

The range of the floating point magnitude $M$ that produces a non-zero integral result is, $\pm \mathrm{X}^{\prime} 4880000000000000^{\prime}<\mathrm{M} \geq \pm \mathrm{X}^{\prime} 4110000000000000^{\prime}$.

Double precision floating point magnitudes greater than $\pm \mathrm{X}^{\prime} 487$ F FFFF FFFF FFFF' cause overflow. The result is forced to $\mathrm{X}^{\prime} 7 \mathrm{FFFFFFF}$ ' if positive or to $\mathrm{X}^{\prime} 8000000 \mathbf{1}^{\prime}$ if negative. The V flag is set in the Condition Code along with either the G or L flag, depending on the sign of the result.

Double Precision floating point magnitudes less than $+X^{\prime} 4110000000000000$ ' cause underflow. The result is forced to zero and the Condition Code is set to zero.

In the event of overflow or underflow, the Arithmetic Fault Interrupt is not taken even if enabled in the current PSW.

## INSTRUCTION

Float Register Double Precision (FLDR)

| Assembler Notation | Op-Code | Format |
| :---: | :---: | :---: |
| FLDR $\quad$ R1, R2 | $3 F$ | RR |

## Operation

R1 specifies one of the double precision floating point registers. R2 specifies one of the general purpose registers. The integer value contained in the register specified by $R 2$ is converted to a floating point number and placed in the double precision floating point register specified by R1.

## Condition Code

| C | V | G | L |
| :--- | :--- | :--- | :--- |
| X | 0 | 0 | 0 |
| X | 0 | 0 | 1 |
| X | 0 | 1 | 0 |

Result is ZERO
Result is less than ZERO
Result is greater than ZERO

## Programming Notes

The full range of fixed point integer values may be converted to double precision floating point. The fixed point value $\mathrm{X}^{\prime} 7 \mathrm{FFF}$ FFFF', the largest positive integer, converts to a double precision floating point value of $\mathrm{X}^{\prime} 487 \mathrm{~F}$ FFFF FF00 $0000{ }^{\prime}$. The fixed point value $\mathrm{X}^{\prime} 80000000$, the most negative integer, converts to a double precision floating point value of $\mathrm{X}^{\prime} \mathrm{C} 880000000000000{ }^{\prime}$.

The result in R1 is normalized.

## CHAPTER 6 <br> STATUS SWITCHING AND INTERRUPTS

At any given time, the Processor may be in either the Stop mode or the Run mode. In the Stop mode, the normal execution of instructions is suspended. The Processor is under control of the operator who can, through the display console:

Examine any memory location
Change any memory location
Examine the contents of any general register
Examine and modify the current PSW
Execute instructions singly

The transition from the Stop mode to the Run mode requires operator intervention at the display console, or the occurrence of an interrupt (if enabled by the current PSW).

Once the Processor has been put in the Run mode, the current PSW controls the operation of the Processor. By changing the contents of the current PSW, a running program can:

Put the Processor in the Wait state
Enable or disable various interrupts

Switch between supervisor and protect modes
Vary the normal sequential execution of instructions

## PROGRAM STATUS WORD

The Program Status Word is a 64 bit double word. (See Figure 6-1.)


Figure 6-1. Program Status Word

Bits 0:15 of the PSW are not currently used, and must be zero. Bits 16:27 are reserved for status definition and interrupt masks. Bits 28:31 are reserved for the Condition Code. Bits 32:39 are not used, and must be zero. Bits 40:63 are reserved for the Location Counter. The status and interrupt bits are interpreted as follows:

| Bit 16 (W) | Wait state |
| :--- | :--- |
| Bit 17 (D) | Immediate interrupt/Auto Driver Channel enable |
| Bit 18 (M) | Machine malfunction interrupt enable |
| Bit 19 (A) | Arithmetic fault interrupt enable |
| Bit 20 (I) | Imrnediate interrupt/Auto Driver Channel enable |
| Bit 21 (RP) | Relocation/protection enable |
| Bit 22 (Q) | System queue service interrupt enable |
| Bit 23 (P) | Protect mode |
| Bits $24: 27$ (R) | Register set selection |

The current PSW is contained in a hardware register within the Processor. Status switching results when the current PSW, or at least the first half (Bits $0: 31$ ) of the current PSW, is replaced. The occurrence of an interrupt or the execution of a Status Switching instruction can cause the replacement of the current PSW.

## Wait State

When Bit 16 of the current PSW is set, the Processor is in the Wait state. In this state, program execution is halted. However, the Processor is still responsive to machine malfunction and immediate interrupts, if they are enabled. If the Processor is put in the Wait state with these interrupts disabled, only operator intervention from the Display console can force the Processor out of the Wait state.

## Protect Mode

When Bit-23 of the current PSW is set, the Processor is in the protect mode. A program running in this mode is not allowed to execute Privileged instructions. (Privileged instructions include all I/O instructions and most of the Status Switching instructions. See Appendix 1.) A privileged instruction is treated as an illegal instruction when the Processor is in the protect mode. If Bit-23 of the current PSW is reset, the Processor is in the Supervisor mode. Programs running in this mode may execute any legal instruction.

## Register Set Selection

Bits 24:27 of the current PSW control register set selection. These bits are interpreted as follows:

| $\underline{\text { Bit } 24}$ | Bit 25 | Bit 26 | Bit 27 |  |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | Register Set 0 |
| 0 | 0 | 0 | 1 | Register Set 1 |
| 0 | 0 | 1 | 0 | Register Set 2 |
| 0 | 0 | 1 | 1 | Register Set 3 |
| 0 | 1 | 0 | 0 | Register Set 4 |
| 0 | 1 | 0 | 1 | Register Set 5 |
| 0 | 1 | 1 | 0 | Register Set 6 |
| 1 | 1 | 1 | 1 | Register Set 15 |

When the processor is equipped with two register sets, Bits 24, 25, 26 of the current PSW have no effect on selection of register sets. Consequently, specifying an even numbered register set causes register set 0 to be selected whereas specifying odd numbered register set causes register set 15 to be selected.

When the processor is cquipped with eight register sets, Bit-24 of the current PSW has no effect on selection of register sets. Consequently, specifying a register set number between 7 and 14 causes one of the equipped sets to be selected instead.

## INTERRUPT SYSTEM

The interrupt system of the Processor provides rapid response to external and internal events that require service by special software routines. In the interrupt response procedure, the Processor preserves its current state and transfers control to the required interrupt handler. This software routine may optionally restore the previous state of the Processor upon completion of the service. (See Table 6-1 and Figure 6-2.)

Some interrupts are controlled by bits in the current Program Status Word, that is, they can be enabled or disabled by setting or resetting a bit in the PSW. Other interrupts are not controlled by PSW bits, and are always enabled. The following is a list of Processor interrupts and their controlling PSW bits, if any:

| Interrupt | PSW Bit |
| :--- | :---: |
| Immediate, Auto Driver Channel | $\mathbf{1 7}$ and 20 |
| Console | $\mathbf{1 7}$ and 20 |
| Machine Malfunction | 18 |
| Arithmetic Fault | 19 |
| System Queue Service | 22 |
| Protect Mode Violation | 23 |
| Relocation/Protection | 21 |
| Supervisor Call | none |
| Simulated | none |
| Illegal Instruction | none |

Interrupts occur at various times during processing. The immediate, console, and machine malfunction interrupts occur between the execution of instructions or after completion of an auto driver channel operation. The relocation/protection interrupt occurs after the execution of an instruction. The system queue service, arithmetic fault, supervisor call, and simulated interrupts occur during the execution of instructions. The illegal instruction and protect mode violation interrupts occur before the execution of the improper instruction.

The interrupt procedure is based on the concepts of old, current, and new Program Status Words. The current PSW, contained in a hardware register, defines the operating state of the Processor. When this state must be changed, the current PSW becomes the old PSW. The new PSW becomes the current PSW. The current PSW now contains the operating status and the Location Counter for the interrupt service routine.

With one exception (the machine malfunction interrupt), when the current PSW becomes the old PSW it is saved in a pair of registers specified by the register set selection field of the new PSW. The machine malfunction old PSW is stored in a reserved memory location. Again with one exception, when a new PSW becomes the current PSW, it is loaded from a reserved memory location. The exception is the immediate interrupt. On an immediate interrupt, the current status is forced to a predetermined value. The current Location Counter is loaded from the interrupt service pointer table.

The new Program Status Word for any interrupt should, if possible, disable interrupts of its own class.

TABLE 6-1. INTERRUPT SYSTEMS

| INTERRUPT | TYPE | CONTROLLEDBY PSW BIT (S) | CAN BE QUEUED | OLD PSW STORED IN | NEW PSW <br> LOADED FROM | NOTES |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ARITHMETIC FAULT | Internal | 19 | NO | REG. 14, 15 | $\mathrm{X}^{\prime} 48-4 \mathrm{~F}^{\prime}$ | 'C' FLAG SET IN NEW PSW IF FLOATING POINT ARITHMETIC FAULT |
| AUTO DRIVER CHANNEL | EXTERNAL | 17, 20 | YES | REG. 0, 1 | MICROPROGRAM (STATUS) <br> CHANNEL COMMAND BLOCK SUBROUTINE ADDRESS (LOC) | NEW PSW STATUS $=Y^{\prime} 000028 N X^{*}$ <br> (MACHINE MALFUNCTION AND HIGHER-LEVEL IMMEDIATE INTERRUPTS ENABLED) <br> N IS THE SELECTED REGISTER SET <br> $X$ IS THE CONDITION CODE ON TERMINATION <br> (REG2) $=$ INTERRUPTING DEVICE ADDRESS <br> (REG3) $=$ INTERRUPTING DEVICE STATUS <br> (REG 4) = ADDRESS OF CHANNEL COMMAND BLOCK |
| CONSOLE | EXTERNAL | 17,20 | NO | (SEE IMMEDIATE INTERRUPT) |  | NEW PSW STATUS $=Y^{\prime} 00002800^{\circ}$ |
| ILLEGAL instruction | INTERNAL | * | NO | REG. 14, 15 | X'30-37' | CANNOT BE DISABLED |
| immediate | External | 17,20 | YES | REG. 0, 1 | MICROPROGRAAN <br> STATUS INTERRUPT SERVICE POINTER TABLE (LOC) | NEW PSW STATUS = Y'000028NO' <br> (MACHINE MALFUNCTION AND HIGHER-LEVEL IMMEDIATE INTERRUPTS ENABLED) <br> WHERE N IS THE SELECTED REGISTER SET <br> (REG.2) = INTERRUPTING DEVICE ADDRESS <br> (REG.3) $=$ INTERRUPTING DEVICE STATUS |
| MACHINE MALFUNCTION | INTERNAL | 18 | YES** | $\mathrm{X}^{\prime} 20-27^{\prime}$ | X'38-3F' | CONDITION CODE SET TO INDICATE NATURE OF MALFUNCTION |
| MEMORY ACCESS CONTROLLER | INTERNAL | 21 | YES | REG. 14, 15 | X'90-97' | MAC STATUS REGISTER INDICATES NATURE OF INTERRUPT |
| PRIVILEGED INSTRUCTION | INTERNAL | 23 | NO | REG. 14, 15 | $\mathrm{x}^{\prime} 30-37{ }^{\prime}$ | TAKEN WHEN PRIVILEGED INSTRUCTION ATTEMPTED WHILE PROCESSOR IN PROTECT MODE |
| SIMULATED | INTERNAL | * | NO | (SEE IMMEDIATE OR AUTO DRIVER CHANNEL INTERRUPTS |  | TAKEN WHEN 'SINT' INSTRUCTION EXECUTED IN NON-PROTECT MODE (REG.4) = INTERRUPT SERV. POINTER |
| SUPERVISOR CALL | INTERNAL | * | NO | REG. 14, 15 | $x^{\prime} 98-9 B^{\prime}$ (STATUS) SVC POINTER TABLE (LOC) | TAKEN WHEN 'SVC' INSTRUCTION EXECUTED (REG. 13) = ADDRESS OF SVC PARAMETER BLOCK |
| SYSTEM QUEUE | INTERNAL | 22 | YES | REG. 14, 15 | $\chi^{\prime} 88.8 F^{\prime}$ | TAKEN WHEN ‘EPSR,' 'LPSW,' OR ‘LPSWR' INSTRUCTIONS EXECUTED IF SYSTEM QUEUE NOT EMPTY. (REG. 13) = ADDRESS OF SYSTEM QUEUE |

* This Interrupt is always enabled.
** Memory Parity Error only


Figure 6－2．Immediate Interrupt Systems Block Diagram

## Immediate Interrupt

The immediate interrupt is used for control of external devices. Through this mechanism, external devices can request and obtain Processor service. Interrupt requests from external devices are arranged on 4 priority levels. Level ZERO is the highest priority level. Level 3 is the lowest. Priority interrupts are controlled by Bits-17 and 20 of the current PSW. The interpretation of these bits is:
Bit-17 Bit-20

| 0 | 0 | All levels disabled |
| :--- | :--- | :--- |
| 0 | 1 | Higher levels enabled |
| 1 | 0 | All levels enabled |
| 1 | 1 | Current and higher levels enabled |

The current level is equal to the currently active register set. When interrupts on any levels are enabled, the Processor is responsive to interrupt requests on those levels. When interrupts on any levels are disabled, requests are queued until the Processor is able to recognize them.

The relationship between the interrupt priority and the currently active Register Set is summarized below:

| $\begin{aligned} & \text { PSW } \\ & \text { Bits } \end{aligned}$ |  | Current Register Set | External Interrupt Level Enabled |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 17 | 20 |  | Level 0 | Level 1 | Level 2 | Level 3 |
| 0 | 0 | X | NO | NO | NO | NO |
| 0 | 1 | 0 | NO | NO | NO | NO |
| 0 | 1 | 1 | YES | NO | NO | NO |
| 0 | 1 | 2 | YES | YES | NO | NO |
| 0 | 1 | 3 | YES | YES | YES | NO |
| 0 | 1 | 4 | YES | YES | YES | NO |
| 0 | 1 | 5 | YES | YES | YES | NO |
| 0 | 1 | 6 | YES | YES | YES | NO |
| 0 | 1 | F | YES | YES | YES | NO |
| 1 | 0 | X | YES | YES | YES | YES |
| 1 | 1 | 0 | YES | NO | NO | NO |
| 1 | 1 | 1 | YES | YES | NO | NO |
| 1 | 1 | 2 | YES | YES | YES | NO |
| 1 | 1 | 3 | YES | YES | YES | YES |
| 1 | 1 | 4 | YES | YES | YES | YES |
| 1 | 1 | 5 | YES | YES | YES | YES |
| 1 | 1 | 6 | YES | YES | YES | YES |
| 1 | 1 | F | YES | YES | YES | YES |

A unique new register set is associated with each interrupt level.
The register set number is the same as the interrupt level number. Thus, an interrupt on level ZERO causes register set ZERO to be used; on level ONE, register set ONE, etc. When the Processor recognizes a request from a device, it:

1. Saves the current PSW in registers zero and one of the new set. (Bits 0:31 are saved in register zero; bits 32:63 are saved in register one.)
2. Loads the status portion of the current PSW with a value of $Y^{\prime} 000028 \mathrm{X} 0^{\prime}$, where the " X " specifies the new register set; $0,1,2$, or 3 .
3. Acknowledges the request and obtains the device number and status from the device. The device number is placed in register two of the new set. The status is placed in register three.
4. Adds two times the device number to $\mathrm{X}^{\prime} 0000 \mathrm{D} 0^{\prime}$ (the start of the interrupt service pointer table), to obtain the address within the table that corresponds to the interrupting device. For the immediate interrupt, the value in the table must be even. The value in the table becomes the current location counter.

In setting up the registers for the immediate interrupt service routine, the Processor loads the device number and status into the least significant bits of registers two and three. The most significant bits in these registers are forced to ZERO. Note that the new PSW disables current and lower levels, and specifies the appropriate register set. The machine malfunction interrupt is enabled. Relocation and protection are disabled.

## Console Interrupt

The console interrupt is a special case of the immediate interrupt. It also is controlled by Bits 17 and 20 of the current PSW. If Bit- 17 or 20 is set, a console interrupt is generated by:

Depressing the Function key on the console

Depressing 0

The effect of the console interrupt is to cause an immediate interrupt, as described prveiously, from device $\mathrm{X}^{\prime} 001$ '. Register set 0 is always selected.

## Simulated Interrupt

The Simulate Interrupt instruction simulates an immediate interrupt. When this instruction is executed, the Processor goes through the immediate interrupt procedure as if a request for service had been received from an external device. The current PSW is saved, and a new PSW loaded just as for the immediate interrupt. The device is addressed, and the status returned in Register 3. The address from the interrupt service pointer table is placed in Register 4. The state of Bits-17 and 20 have no effect on this interrupt. It is always enabled. The new register set is specified by the least significant 4 bits of the register specified by the R1 field of the instruction.

## Machine Malfunction Interrupt

Bit-18 of the current PSW controls the machine malfunction interrupt. This interrupt occurs on a memory parity error, on the detection of primary power failure, and during the restart procedure after power has been restored. When a machine malfunction interrupt occurs, the current PSW is saved in memory location $\mathrm{X}^{\prime} 000020^{\prime}$. The new PSW from memory location $\mathrm{X}^{\prime} 000038^{\prime}$ becomes the current PSW. The Condition Code of the new PSW as stored in memory must contain zeros. After the interrupt is taken, the state of the Condition Code indicates the specific cause of the interrupt.

Condition Code states are:

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 |
|  | 0 | 0 | 1 |

Power Restore
Power failure
Memory malfunction (e.g. Parity Error)
Memory malfunction during Auto Driver Channel operation
Power failure during Auto Driver Channel operation

Power failure occurs when the primary power fail detector senses a low voltage, when the Initialize key (INI) of the Display console is depressed, or when the key operated POWER switch is turned to the OFF position. Following the PSW exchange, the software has approximately one millisecond to perform any necessary operations before the automatic shut down procedure takes over. During the automatic shut down procedure the Processor saves the current PSW at the memory location specified by the contents of location $\mathrm{X}^{\prime} 00084^{\prime}$; saves the 8 single-precision floating point registers, if equipped, in memory locations $X^{\prime} 00000$ ' through ' $0001 \mathrm{~F}^{\prime}$; and it saves all available sets of general registers, starting with register set 0 , at the location specified by the contents of memory location $X^{\prime} 00086^{\prime}$. If the processor is equipped with double precision floating point, the double precision floating point registers are stored immediately following the General Register Save area.

When power returns, the Processor restored the PSW and the general registers and floating point registers from their save areas. The contents of all other registers are undefined. If Bit 18 of the restored PSW is set, the Processor takes another machine malfunction interrupt, this time with no bits set in the Condition Code of the current PSW.

It is important here to note that during the power restore sequence, the Processor does distinguish the Initialize Key (INT) from power fail or power off. If, on power up, the Initialize Key is still depressed, the Halt mode is unconditionally entered regardless of the state of Bit-18 of the restored PSW. The operator has to hold the Initialize Key down for longer than half a second before the Halt mode is guaranteed.

During Write operations to memory with parity option, the Parity bit of each memory word is set to maintain odd parity. The Parity bit is recomputed on each memory read. If the computed bit is not equal to the bit read out of memory, the Processor takes a machine malfunction interrupt, setting the G flag to indicate the parity error.

If a machine malfunction interrupt condition arises during an auto driver channel operation, the PSW, current at the time the channel was activated, becomes the old machine malfunction PSW. Register 4 of the set, designated by the machine malfunction new PSW, contains the address of the Channel Command Block. The C flag of the current PSW is set along with either the L flag or the V flag to indicate either power failure or parity error.

## Arithmetic Fault Interrupt

Bit-19 of the current PSW controls the arithmetic fault interrupt. This interrupt, if enabled, can occur for any of the following reasons:

Fixed point division by zero
Fixed point quotient overflow
Floating point division by zero
Floating point overflow or underflow
When this interrupt occurs, the current PSW is saved in Registers 14 and 15 of the set designated by the arithmetic fault new PSW. The new PSW, from memory location X'000048', becomes the current PSW. All Condition Code bits in the new PSW as stored in memory must be zero. Before going to the interrupt service routine, the Processor sets the carry flag in the Condition Code if the interrupt is the result of a floating point operation. If the interrupt is the result of a fixed point operation, the carry flag is reset.

Any of the following conditions cause fixed point quotient overflow:
A halfword divide operation produces a result greater than 32,767 ( $\mathrm{X}^{\prime} 7 \mathrm{FFF}$ ').
A halfword divide operation produces a result less than $-32,768$ ( $\mathrm{X}^{\prime} 8000^{\prime}$ ).
A fullword divide operation produces a result greater than $2,147,483,647$ ( $\mathrm{X}^{\prime} 7$ FFF FFFF').
A fullword divide operation produces a result less than $-2,147,483,648\left(X^{\prime} 80000000\right.$ ) .

When a fixed point division by zero or a fixed point quotient overflow occurs, the operand registers remain unchanged.

Floating point overflow occurs when, in a floating point operation, the value of the exponent exceeds +63 . Floating point underflow occurs when, during the execution of a Floating Point instruction, the value of the exponent becomes less than -63 . Following floating point overflow, the result is forced to plus or minus $\mathrm{X}^{\prime} 7 \mathrm{FFF}$ FFFF'. Following a floating point underflow, the result is forced to true zero, X'0000 $0000^{\prime}$. After a floating point division by zero, the operand register remains unchanged.

After any arithmetic fault interrupt, the Location Counter of the old PSW contains the address of the instruction immediately following the one that caused the interrupt.

## Relocation/Protection Interrupt

Bit-21 of the current PSW controls the relocation/protection interrupt. If this bit is set, and the currently running program violates any of the relocation and protection conditions available in the relocation and protection module, the Processor saves the current PSW in Registers 14 and 15 of the set designated by the relncation/protection new PSW. The new PSW at memory location $\mathrm{X}^{\prime} 000090^{\prime}$ becomes the current PSW.

## System Queue Service Interrupt

The system queue is a circular list identical to that described for the list processing instructions. The queue may be set up at any convenient location in memory. While the maximum size of the system queue allows 65536 entries, in practice, the queue should be big enough to hold one entry for every external device controlled by a software program.

Memory location $X^{\prime} 000080^{\prime}$ contains the address of the system queue. In the course of executing any of the following instructions:

```
Load Program Status Word
Load Program Status Word Register
Exchange Program Status
```

the Processor tests Bit-22 of the new status being loaded. If this bit is set, the Processor checks the state of the system queue. If there is an entry in the queue, the just loaded PSW becomes the old PSW. It is saved in Registers 14 and 15 of the set designated by the system queue service interrupt new PSW. The address of the queue, taken from location $\mathrm{X}^{\prime} 000080^{\prime}$, is placed in Register 13 of that set. The new PSW from location $X^{\prime} 000088^{\prime}$ becomes the current PSW.

## Protect Mode Violation Interrupt

Bit-23 of the current PSW controls the execution of Privileged instructions. When this bit is set, the Processor is in the Protect mode. Programs running in the Protect mode are not allowed to execute Privileged instructions. Privileged instructions are:

```
All I/O instructions
Load Program Status Word
Load Program Status Word Register
Exchange Program Status Register
Simulate Interrupt
Simulate Channel Program
```

If a program running in the protect mode attempts to execute a Privileged instruction, the instruction is not executed. The Processor saves the current PSW in Registers 14 and 15 of the set designated by the illegal instruction new PSW. The illegal instruction new PSW at location $X^{\prime} 000030^{\prime}$ becomes the current PSW. The Location Counter of the old PSW contains the address of the Privileged instruction.

## Illegal Instruction Interrupt

The illegal instruction interrupt cannot be disabled. The interrupt occurs whenever the Processor fetches an instruction word containing an operation code that is not one of those permitted by the system. The Processor saves the current PSW in Registers 14 and 15 of the set designated by the illegal instruction new PSW. The illegal instruction new PSW from memory location X'000030' becomes the current PSW.

When the Processor encounters an illegal instruction, it makes no attempt to execute it. The Location Counter of the old PSW contains the address of the illegal instruction.

## Supervisor Call Interrupt

This interrupt occurs as the result of the execution of a Supervisor Call instruction. This instruction provides a means for user level programs to communicate with system programs. The supervisor call interrupt is always enabled. When the Processor executes a Supervisor Call instruction, it:

Saves the current PSW in Registers 14 and 15 of the set designated by the supervisor call interrupt new status.

Places the address of the supervisor call parameter block (address of the second operand) in Register 13 of the appropriate set.

Loads the current PSW status with the value contained at memory location $\mathrm{X}^{\prime} 000098^{\prime}$, supervisor call new PSW status.

Loads the current PSW Location Counter from one of the supervisor call new PSW Location Counter locations.

## STATUS SWITCHING INSTRUCTION FORMATS

The Status Switching instructions use the Kegister to Register (RR), and the Register and Indexed Storage (RX) instruction formats. In some cases, Load Program Status Word and Load Program Status Word Register, and the R1 field of the instruction has no significance and must be ZERO.

## STATUS SWITCHING INSTRUCTIONS

The Status Switching instructions provide for software control of the interrupt structure of the system. They also allow user level programs to communicate efficiently with control software. All Status Switching instructions, except the Supervisor Call instruction are privileged operations. Therefore, all interrupt handling routines must run in the Supervisor mode.

The instructions described in this section are:

| LPSW | Load Program Status Word |
| :--- | :--- |
| LPSWR | Load Program Status Word Register |
| EPSR | Exchange Program Status Register |
| SINT | Simulate Interrupt |
| SVC | Supervisor Call |

## INSTRUCTION

Load Program Status Word (LPSW)

Assembler Notation
LPSW
LPSW

Op-Code
C2
C2

Format
RX1, RX2
RX3

## Operation

The 64 bit second operand becomes the current Program Status Word.

## Condition Code

Determined by the new PSW (bits 28:31)

## Programming Note

The quantity to be loaded into the current Program Status Word must be located in memory on a double word boundary.

This instruction is a privileged operation.
The R1 field of this instruction must be zero.

This instruction may be used to change register sets. The new set becomes active for execution of the next instruction.

| Assembler Notation |  | Op-Code | Format |
| :---: | :---: | :---: | :---: |
|  | R2 | 18 | RR |

## Operation

The contents of the register specified by R2 replace Bits-0:31 of the current Program Status Word. The contents of the register specified by R2+1 replace Bits-32:63 of the current Program Status Word.

## Condition Code

Determined by the new PSW (Bits 28:31)

## Programming Notes

The R1 field of this instruction must be zero.
This instruction may be used to change register sets. The new set becomes active for execution of the next instruction.

This instruction is a privileged operation.
The R2 field of this instruction may not specify a register greater than 14.

## INSTRUCTION

- Exchange Program Status Register (EPSR)

| Assembler Notation |  | Op-Code | Format |
| :---: | :---: | :---: | :---: |
| EPSR | R1, R2 | 95 | RR |

## Operation

Bits $0: 31$ of the current Program Status Word replace the contents of the register specified by R1. The contents of the register specified by R2 replace Bits 0:31 of the current Program Status Word.

## Condition Code

Determined by the new PSW (Bits 28:31)

## Programming Notes

If R1 = R2, Bits $0: 31$ of the current PSW are copied into the register specified by R1, but otherwise remain unchanged.

This instruction may be used to change register sets. The new set becomes active for execution of the next instruction.

This instruction is a privileged operation.

## INSTRUCTION

Simulate Interrupt (SINT)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :---: |
| SINT | $\mathrm{I} 2(\mathrm{X} 2)$ | E 2 | RI1 |
| SINT | $\mathrm{R} 1, \mathrm{I} 2(\mathrm{X} 2)$ | E 2 | RII |

## Operation

The least significant 10 bits of the second operand are presented to the interrupt handler as a device number. The device number is used to index into the interrupt service pointer table, simulating an interrupt request from an external device. The result is either an immediate interrupt or an auto driver channel operation.

## Condition Code

Determined by the new PSW in case of immediate interrupt or determined by the way the auto driver channel operation terminates.

## Programming Notes

If the R1 field of this instruction is not specified or contains zero, an interrupt from level 0 is assumed and register set 0 is selected.

If the R1 field of the instruction is non-zero, the least significant 4 bits of the register specified by R1 designate the interrupt level and the new Register set.

This instruction is a privileged operation.
In the execution of this instruction, the Processor loads Registers $0: 3$ or $0: 4$ of the new set as for a real interrupt request.

During the execution of this instruction, the device is addressed and the status byte is returned in Register 3 of the new set.

In the event of instruction time-out, the V flag is set in the PSW, and register 3 of the new set contains $\mathrm{Y}^{\prime} 00000004^{\prime}$.

## INSTRUCTION

- Supervisor Call (SVC)


## Assembler Notation

SVC N, D2 (X2)
SVC N, A2(FX2,SX2)

# Op-Code 

E1
E1

Format
RX1, RX2
RX3

## Operation

The second operand (program address of the parameter block) replaces Bits 8:31 of Register 13 of the set designated by the supervisor call new PSW status. Bits $0: 7$ of this register are forced to ZERO. The current Program Status Word replaces the contents of Registers 14 and 15 of the appropriate set. The fullword quantity located at $\mathrm{X}^{\prime} 000098^{\prime}$ in memory replaces Bits $0: 31$ of the current Program Status Word. The four-bit N field is doubled and added to $\mathrm{X}^{\prime} 00009 \mathrm{C}^{\prime}$. The halfword quantity located at this address becomes the current Location Counter.

## Condition Code

Determined by the new PSW (Bits 28:31)

## Programming Notes

The second operand must be located on a fullword boundary.
This instruction provides means of switching from the Protect Mode to the Supervisor Mode. It is used by the user program running under an Operating System to initiate certain functions in the Supervisor program. The second operand address, is normally a pointer to the memory location of the parameters the Supervisor program needs to complete the function specified. The type of Supervisor call is specified in the R1 field of the instruction. Sixteen different calls are provided for. Return from the Supervisor is made by executing an LPSWR instruction specifying the stored "Old" PSW in Registers 14, 15 of the appropriate set (LPSWR R14).

## CHAPTER 7 <br> INPUT/OUTPUT OPERATIONS

## INTRODUCTION AND CONFIGURATION OF I/O SYSTEM

Input output (I/O) operations, as defined for the 32 bit series, provide a versatile means for the exchange of information between the Processor, memory, and external devices. Communication between the Processor and external devices is accomplished over the I/O Multiplexor Channel Bus (Byte or Halfword Modes). Data transfers over the Multiplexor Channel require Processor intervention, either programmed or automatic for each item transferred.

Direct data transfers between external devices and memory are accomplished over the EDMA Bus, (Byte, Halfword or Burst Mode) and proceed independently of the Processor so other program processing can proceed simultaneously. For more details refer to the following manuals:

1. EDMA Bus Universal Interface Instruction Manual, Publication Number 29-423
2. ESELCH Programming Manual, Publication Number 29-529
3. BSELCH Maintenance Manual, Publication Number 29-572.

Burst mode data transfers over the EDMA Bus are possible only with the help of the EDMA Bus Universal Interface 02-361 or the Buffered Selector Channel 02-456. Both devices can handle data transfer rates up to six Megabytes per second between Local Memory and custom designed I/O systems. In the burst mode, the originating device transmits the starting memory address and Burst Read or Burst Write command. This is followed by an arbitrary number of fullword data transmissions (up to six Megabytes/sec). Lower limit burst mode data transmission rate is $400 \mathrm{Kbytes} / \mathrm{sec}$ ( $10 \mathrm{microsec} / \mathrm{fullword)}$, transmitter dead and abort the transfer.

## DEVICE CONTROLLERS

The basic functions of all device controllers are:

1. To provide synchronization with the Processor and to provide device address recognition.
2. To transmit operational commands from the Processor to the device.
3. To translate device status into meaningful information for the Processor.
4. To request Processor attention when required.

In addition, controllers may generate parity, convert serial data to parallel, buffer incoming or outgoing data, or perform other device-dependent functions.

## Device Addressing

The system design allows as many as 1,023 external devices. Each device must have its own unique device number or address. Device numbers may range from $\mathrm{X}^{\prime} 001^{\prime}$ through $\mathrm{X}^{\prime} 3 \mathrm{FF}^{\prime}$. (Device number $\mathrm{X}^{\prime} 000^{\prime}$ is not used.) The minimum system provides for 255 device numbers. Larger systems may have either 511 or 1,023 .

## Processor/Controller Communication

Device controllers may be attached directly to the I/O Bus, or they may be attached to the I/O Bus indirectly through a Selector Channel. Communication between the Processor and controller is a bi-directional, request-response type of operation.

The Processor can initiate a communication, by sending the device address out onto the I/O Bus. When a controller recognizes the address, it returns a synchronization signal to the Processor, and remains ready to accept commands from the Processor. The Processor waits up to 35 microseconds for the synchronization signal. If no signal is received within this period, the Processor aborts the operation and notifies the controlling program. In this case, the status returned is $\mathrm{X}^{\prime} 04^{\prime}$, know as False Sync. The condition code in the PSW, is also set to $X^{\prime} 4^{\prime}(V$ flag $=1)$. Controller malfunction and software failure (incorrect device address) are the most common causes of this type of time-out.

A controller can initiate communication with the Processor by generating an attention signal. If the Processor is in the interruptable state as defined by bits 17 and 20 of PSW, it temporarily suspends the normal "fetch instruction, execute, fetch next instruction" operation at the end of the execute phase, and transmits an acknowledge signal over the I/O Bus. The controller requesting attention responds with a synchronization signal, and transmits its device number to the Processor.

## Device Priorities - External Interrupt Levels; Interrupt Queuing

The Model 8/32 architecture provides for four external interrupt levels. PSW bits $17 \& 20$ define the external interrupt enable status of the Processor. (See Chapter 6.).

When interrupt requests occur on more than one interrupt level, requests on the higher priority interrupt level are acknowledged first. Level 0 is the highest, level 3 is the lowest in priority.

Interrupt Queuing: Any device controller wanting to interrupt the Processor activates one of the four Attention lines sensed by the Processor and holds that line until the Processor acknowledges the interrupt. Requests for attention are asynchronous; therefore more than one request may be pending at any time on any interrupt level. The system resolves these conflicts according to device priority, determined by the physical placement of the device controller on the I/O Bus. When two or more device controllers on the same interrupt level request attention at the same time, the controller "nearest" to the Processor in the RACK0/TACK0 priority wiring paitern captures the Acknowledge signal from the Processor and gets serviced first. All other interrupting controllers further down the line in priority must wait for the next Acknowledge signal from the Processor.

For details on standard and modified RACK0/TACK0 priority wiring patterns, see the Model 8/32 Processors Installation Manuals, Publication Numbers 29-526 and 29-537.

## INTERRUPT SERVICE POINTER TABLE

Device requests for service may result in either an immediate interrupt or an Auto Driver Channel operation. The Processor chooses one of these options according to information contained in the Interrupt Service Pointer Table.

The Interrupt Service Pointer Table is an ordered list containing one entry for each possible device number in the system. The table starts at memory location $\mathrm{X}^{\prime} 0000 \mathrm{D} 0^{\prime}$ and contains a halfword entry for each device number in the system. For a minimum system, 255 device numbers, the table extends through memory location $\mathrm{X}^{\prime} 0002 \mathrm{CF}^{\prime}$; for a maximum system, the table extends through memory location $\mathrm{X}^{\prime} 0008 \mathrm{CF}^{\prime}$ ( 1023 device numbers). The software controlling I/O operations must set up the table.

When, having acknowledged a request for service, the Processor receives the device address, it adds two times the device address to $\mathrm{X}^{\prime} 000 \mathrm{D}^{\prime}{ }^{\prime}$. The result is the address, within the table, of the entry reserved for the device requesting attention.

If the entry in the table is even (Bit 15 equals 0 ), the Processor takes an immediate interrupt and transfers control to the software routine at the address contained in the table. If the entry in the table is odd (Bit 15 equals 1), the Processor transfers control to the Auto Driver Channel, without interrupting the currently running program.

At the time the Processor transfers control to the software routine, the old PSW (current at the time of the device request) has been saved in Registers 0 and 1 of the new register set. The device number is saved in Register 2 and the status in Register 3. The status portion of the current PSW has been forced to a value of $\mathrm{X}^{\prime} 000028 \mathrm{n} 0^{\prime}$, where n is the new register set number equal to the device interrupt level. Machine Malfunction Interrupts and higher level I/O interrupts are enabled and all other interrupts disabled. The entry in the Interrupt Service Pointer Table has become the new Location Counter.

In using the device number presented by the controller to vector into the Interrupt Service Pointer Table, the Processor masks off the high order bits of the address as received from the I/O Bus. In a system with only 255 device numbers, the address is masked to eight bits. In a system with 1,023 device numbers the address is masked to 10 bits. The action preserves system integrity in the event that a hardware malfunction results in a device address greater than the maximum allowed in the system. (See Table 6-1.)

## I/O INSTRUCTION FORMATS

The I/O instructions use the Register to Register (RR) and the Register and Indexed Storage (RX) instruction formats.

## I/O INSTRUCTIONS

Following most I/O instructions, the V flag in the Condition Code indicates an instruction time-out. This means that the operation was not completed, either because the device did not respond at all, or because it responded incorrectly.

In the Sense Status and Block I/O instructions, the V flag can also mean examine status. To distinguish between these two conditions, the program should test Bits 0:3 of the device status byte. If all of these bits are ZERO, device time-out has occurred.

The instructions described in this section are:

| SS | Sense Status |
| :--- | :--- |
| SSR | Sense Status Register |
| OC | Output Command |
| OCR | Output Command Register |
| RD | Read Data |
| RDR | Read Data Register |
| RH | Read Halfword |
| RHR | Read Halfword Register |
| RB | Read Block |


| RBR | Read Block Register |
| :--- | :--- |
| WD | Write Data |
| WDR | Write Data Register |
| WH | Write Halfword |
| WHR | Write Halfword Register |
| WB | Write Block |
| WBR | Write Block Register |
| AL | Autoload |
| SCP | Simulate Channel Program |

## INSTRUCTIONS

Output Command (OC)
Output Command Register (OCR)

Assembler Notation
Op-Code

DE
DE
9E

Format
RX1, RX2
RX3
RR

## Operation

Bits 22:31 of the register specified by R1 contain the 10 bit device address. The Processor addresses the device and transmits an eight-bit command byte from the second operand location to the device. Neither operand is changed.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 0 |

Operation successful
Instruction time--out (FALSE SYNC) or EXAMINE status

## Programming Notes

In the RR format, Bits $24: 31$ of the register specified by R2 contain the device command.
These instructions are privileged operations.

## INSTRUCTIONS

Sense Status (SS)
Sense Status Register (SSR)

| Assembler Notation |  | Op-Code |  |
| :---: | :--- | :---: | :--- |
|  |  | Format |  |
| SS | R1, D2 (X2) | DD | RX1, RX2 |
| SS | R1, A2 (FX2, SX2) | DD | RX3 |
| SSR | R1, R2 | 9D | RR |

## Operation

Bits 22:31 of the register specified by R1 contain the 10 bit device address. The device is addressed and the eight bit device status is placed in the second operand location. The Condition Code is set equal to the right most four bits of the device status byte. The first operand is unchanged.

## Condition Code

Bits 4:7 of the device status byte are copied into the Condition Code. See the appropriate device manual for a description of this status.

If the device is not in the system, condition code is set to 0100 .

## Programming Notes

In the RR format, the device status byte replaces Bits $24: 31$ of the register specified by R2. Bits 0:23 are forced to zero.

These instructions are privileged operations.

## NSTRUCTIONS

Read Data (RD)
Read Data Register (RDR)

| Assembler Notation |  |  | Op-Code |
| :---: | :--- | :---: | :--- |
|  |  |  | Format |
| RD | R1, D2 (X2) | DB | RX1, RX2 |
| RD | R1, A2 (FX2, SX2) | DB | RX3 |
| RDR | R1, R2 | $9 B$ | RR |

## Operation

Bits 22:31 of the register specified by R1 contain the 10 bit device address. The Processor addresses the device. The device responds by transmitting an eight-bit data byte. This byte is placed in the second operand location.

## Condition Code

| $\mathbf{C}$ | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 0 |

Operation successful
Instruction time--out (FALSE SYNC) or EXAMINE status

## Programming Notes

In the RR format, the eight bit data byte replaces Bits $24: 31$ of the register specified by R2. Bits $0: 23$ of the register are forced to zero.

These instructions are privileged operations.

## INSTRUCTIONS

Read Halfword (RH)
Read Halfword Register (RHR)

| Assembler Notation |  | Op-Code | Format |
| :---: | :--- | :---: | :--- |
|  |  |  |  |
| RH | R1, D2 (X2) | D9 | RX1, RX2 |
| RH | R1, A2 (FX2, SX2) | D9 | RX3 |
| RHR | R1, R2 | 99 | RR |

## Operation

Bits 22:31 of the register specified by R1 contain the 10 bit device address. The Processor addresses the device. If the device is halfword oriented, the Processor transmits 16 bits of data from the device to the second operand location. If the device is byte oriented, the Processor transmits two eight-bit bytes in successive operations.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | $\mathbf{1}$ | 0 | 0 |

Operation successful<br>Instruction time-out (FALSE SYNC) or EXAMINE status

## Programming Notes

In the RR format, the data received from a halfword device replaces Bits 16:31 of the register specified by R2. Bits $0: 15$ are forced to zero. The first byte of data from a byte device replaces Bits $16: 23$ of the register specified by R2. The second byte replaces Bits $24: 31$. Bits 0:15 are forced to ZERO.

If the device is byte-oriented, it must be capable of supplying both bytes without intervening status checks. Unlike the RB and RBR instructions, this instruction does not perform status checking between the two byte transfers.

In the RX format, the second operand must be located on a halfword boundary.

These instructions are privileged operations.

INSTRUCTION NO-3200

- Read Block (RB)

Assembler Notation

Op-Code
D7
D7

Format
RX1, RX 2
RX

## Operation

Bits 22:31 of the register specified by R1 contain the 10 bit device address. Bits 8:31 of the fullword located at the second operand address contain the starting address of the data buffer. Bits $8: 31$ of the fullword located at the second operand address plus four contain the ending address of the data buffer.

The Processor transmits eight bit data bytes from the device to consecutive locations in the specified buffer.

## Condition Code

Bits $4: 7$ of the device status byte are copied into the Condition Code. See the appropriate device manual for a description of this status.

If the device is not in the system, condition code is set to 0100 .

## Programming Notes

The starting address must be less than, or equal to, the ending address. If the starting address is greater than the ending address, no transfer takes place and the Processor forces the Condition Code to ZERO. If the addresses are equal, one byte of data is transmilted.

The Processor is in a non-interruptable state during the transfer.
This instruction is a privileged operation.
The second operand must be located on a fullword boundary.

- holds up Pr e


## INSTRUCTION

Read Block Register (RBR)

Assembler Notation

RBR R1,R2

## Op-Code

97

## Format

RR

## Operation

Bits 22:31 of the register specified by R1 contain the 10 bit device address. The register specified by R2 contains the starting address of the data buffer. The register specified by R2+1 contains the ending address of the data buffer.

The Processor transmits eight bit data bytes from the device to consecutive locations in the specified buffer.

## Condition Code

Bits 4:7 of the device status byte are copied into the Condition Code. See the appropriate device manual for a description of this status.

If the device is not in the system, condition code is set to 0100 .

## Programming Notes

The starting address must be less than, or equal to, the ending address. If the starting address is greater than the ending address, no transfer takes place and the Processor forces the Condition Code to ZERO. If the addresses are equal, one byte of data is transmitted.

The Processor is in a non-interruptable state during the transfer.

This instruction is a privileged operation.

## INSTRUCTIONS

Write Data (WD)
Write Data Register (WDR)

## Assembler Notation

| WD | R1, S2 (X2) |
| :--- | :--- |
| WD | R1, A2 (FX2, SX2) |
| WDR | R1, R2 |

## Op-Code

DA
DA
9A

## Format

RX1, RX2
RX3
RR

## Operation

Bits 22:31 of the register specified by R1 contain the 10 bit device address. The Processor addresses the device and transmits an eight bit data byte from the second operand location to the device. Neither operand is changed.

## Condition Code

| $\mathbf{C}$ | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 0 |

Operation successful
Instruction time-out (FALSE SYNC) or EXAMINE status

## Programming Notes

In the RR format, the eight bit data byte is contained in Bits 24:31 of the register specified by R2.

These instructions are privileged operations.

## INSTRUCTIONS

Write Halfword (WH)
Write Halfword Register (WHIR)

Assembler Notation
$\begin{array}{ll}\text { WH } & \text { R1, D2 (X2) } \\ \text { WH } & \text { R1, A2 (FX2,SX2) } \\ \text { WHR } & \text { R1, R2 }\end{array}$

Op-Code
D8
D8
98

Format

RX1, RX2
RX3
RR

## Operation

Bits 22:31 of the register specified by R1 contain the 10 bit device address. The Processor addresses the device. If the device is halfword oriented, the Processor transmits 16 bits of data from the second operand location to the device. If the device is byte oriented, the Processor transmits two eight bit data bytes in successive operations.

## Condition Code

| C | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |


| 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- |
| 0 | Operation successful |  |  |


| 0 | 1 | 0 | 0 |
| :--- | :--- | :--- | :--- |$\quad$ Instruction time-out (FALSE SYNC) or EXAMINE status

## Programming Notes

In the RR format, the data transmitted to a halfword device comes from Bits 16:31 of the register specified by R2. The first byte of data transmitted to a byte device comes from Bits 16:23 of the register specified by R2, the second byte, from Bits 24:31.

If the device is byte-oriented, it must be capable of accepting both bytes without intervening status checks. Unlike the WB and WBR instructions, this instruction does not perform status checking between the two byte transfers.

In the RX format, the second operand must be located on a halfword boundary.
These instructions are privileged operations.

## INSTRUCTION

Write Block (WB)

| Assembler Notation | Op-Code | Format |  |
| :---: | :--- | :---: | :---: |
|  |  |  |  |
| WB | R1, D2 (X2) | D6 | RX1, RX2 |
| WB | R1, A2 (FX2,SX2) | D6 | RX3 |

## Operation

Bits 22:31 of the register specified by R1 contain the 10 bit device address. Bits $8: 31$ of the fullword located at the second operand address contain the starting address of the data buffer. Bits 8:31 of the fullword located at the second operand address plus four contain the ending address or the data buffer.

The Processor transmits eight bit data bytes from consecutive locations in the specified buffer to the device.

## Condition Code

Bits 4:7 of the device status byte are copied into the Condition Code. See the appropriate device manual for a description of this status.

If the device is not in the system, the condition code is set to 0100 .

## Programming Notes

The starting address must be less than, or equal to, the ending address. If the starting address is greater than the ending address, no transfer takes place and the Processor forces the Condition Code to ZERO. If the addresses are equal, one byte of data is transmitted.

The Processor is in a non-interruptable state during the transfer.
This instruction is a privileged operation.
The second operand must be located on a fullword boundary.

## INSTRUCTION

Write Block Register (WBR)

| Assembler Notation |  | Op-Code | Format |
| :---: | :---: | :---: | :---: |
| WBR | R1, R2 | 96 | RR |

## Operation

Bits 22:31 of the register specified by R1 contain the 10 bit device address. The register specified by R2 contains the starting address of the data buffer. The register specified by R2+1 contains the ending address of the data buffer.

The Processor transmits eight bit data bytes from consecutive locations in the specified buffer to the device.

## Condition Code

Bits $4: 7$ of the device status byte are copied into the Condition Code. See the appropriate device manual for a description of this status.

If the device is not in the system, the condition code is set to 0100 .

## Programming Notes

The starting address must be less than, or equal to, the ending address. If the starting address is greater than the ending address, no transfer takes place and the Processor forces the Condition Code to ZERO. If the addresses are equal, one byte of data is transmitted.

The Processor is in a non-interruptable state during the transfer.
This instruction is a privileged operation.

## INSTRUCTION

Autoload (AL)

Assembler Notation

| AL | D 2 (X2) |
| :--- | :--- |
| AL | $\mathrm{A} 2(\mathrm{FX} 2, \mathrm{SX} 2)$ |

Op-Code
D5
D5

## Format

RX1, RX2
RX3

## Operation

The Autoload instruction loads memory with a block of data from a byte oriented input device. The data is read a byte at a time and stored in successive memory locations starting with location $X^{\prime} 000080^{\prime}$. If the status is bad, the operation is terminated with $V$, $G$ or $L$ flags set. The last byte is loaded into the memory location specified by the address of the second operand. Any blank or zero bytes that are input prior to the first non-zero byte are considered to be leader and are ignored. All other zero bytes are stored as data. The eight bit input device address is specified by memory location $\mathrm{X}^{\prime} 000078^{\prime}$. The device command code is specified by memory location $X^{\prime} 000079^{\prime}$.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| X | 1 | X | X |
| X | X | 1 | X |
| X | X | X | 1 |

Operation successful or aborted.
Examine status or time-out
End of medium
Device unavailable

## Programming Notes

This instruction may only be used with devices whose addresses are less than, or equal to, $X^{\prime} F^{\prime}$.

The R1 field of this instruction must be ZERO.
This instruction is a privileged operation.
The starting and ending addresses for this instruction are relocatable. Users should disable the Memory Access Controller before attempting to use this instruction.

If the second operand is less than $\mathrm{X}^{\prime} 80^{\prime}$ the operation is aborted.

Simulate Channel Program (SCP)

Assembler Notation

SCP R1, D2 (X2)
$\mathrm{SCP} \quad \mathrm{R} 1, \mathrm{~A} 2$ (FX2,SX2)

Op-Code

E3
E3

Format

RX1, RX2
RX3

## Operation

The second operand address is the address of a Channel Command Block (CCB). The buffer switch bit of the Channel Command Word (CCW) specifies the buffer to be used for the data transfer. If this bit is set, Buffer 1 is used. If it is reset, Buffer 0 is used. If the byte count field of the current buffer is positive, the V flag in the Condition Code is set, and the next sequential instruction is executed. If the byte count field is not positive, the following data transfer operation is performed.

If the Channel Command Word specifies read, a byte of data is moved from Bits 24:31 of the register specified by R1 to the appropriate buffer location. If the Channel Command Word specifies write, a byte of data is moved from the appropriate buffer location to Bits 24:31 of the register specified by R1. Bits 0:23 are forced to ZERO.

After a byte has been transferred, the count field of the appropriate buffer is incremented by one. If the count field is now positive, and if the last bit of the CCW is reset, the buffer switch bit of the CCW is complemented.

## Condition Code

| $\mathbf{C}$ | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |

Count field is now ZERO
Count field is now less than ZERO
Count field is now greater than ZERO
Count field was positive

## Programming Notes

The second operand must be located on a fullword boundary.
This instruction is a privileged operation.

## CONTROL OF I/O OPERATIONS

The design of the 32 bit series I/O structure allows data transfers in any of several ways. The choice of which I/O method to use depends on the particular application and on the characteristics of the external devices. The primary methods of data transfer between the Processor and external devices are:

One byte or one halfword to or from any of the general registers.
One byte or one halfword to or from memory.
A block of data to or from memory under direct Processor control.
A block of data to or from memory under control of a Selector Channel or EDMA Universal Interface.

Multiplexed blocks of data to or from memory under control of the auto driver channel.

INTERDATA standard device controllers expect a predetermined sequence of commands to effect data transfers. These commands address the device, put it in the correct mode, and cause data to be transferred. Because all I/O instructions are privileged operations, I/O control programs must run in the Supervisor mode, Bit 23 of the current PSW reset. I/O control programs should disable immediate interrupts, or enable only higher level interrupts, controlled by PSW Bits 17 and 20.

## STATUS MONITORING I/O

The simplest form of I/O programming is status monitoring I/O. In this mode of operation, only one device is handled at a time, and the Processor cannot overlap other operations with the data transfer. The sequence of operations in this type of programming is:

1. Address the device and set the proper mode (Output Command instruction).
2. Test the device status (Sense Status instruction).
3. Loop back to the Sense Status instruction until the status byte indicates that the device is ready (Conditional Branch instruction).
4. When the device is ready, transfer the data (Read or Write instruction).
5. If the transfer is not complete, branch back to the Sense Status instruction. If it is complete, terminate.

A variation on this type of programming makes use of the block I/O instructions. In this kind of programming, the program prepares the device and waits for it to become ready. It then executes a block I/O instruction. The Processor takes over control and completes the transfer, one byte at a time to or from memory. The Processor monitors device status during the transfer. Block transfers may be used only with byte oriented devices whose ready status is zero.

## INTERRUPT DRIVEN I/O

Interrupt driven I/O allows the Processor to take advantage of the disparity in speed between itself and the external devices being controlled. With status monitoring, the Processor spends much of its time waiting for the device. With interrupt driven programming, the Processor can use much of this time to perform other functions. This kind of programming establishes at least two levels of operation. On one level are the interrupt service programs. On the other levels are the interruptable programs that run with the immediate interrupt enabled.

Before starting interrupt driven operations, the Interrupt Service Pointer Table must be set up. This table starts at memory location $\mathrm{X}^{\prime} 0000 \mathrm{D} 0^{\prime}$. It must contain a halfword address entry for every possible device. The table is ordered according to device addresses in such a way that $\mathrm{X}^{\prime} 0000 \mathrm{D} 0$ ' plus two times the device address equals the memory address of the table entry reserved for that device. The value placed in the location reserved for a device is the address of the interrupt service routine for the device.

For example: if a console Teletype is connected at an address of $\mathrm{X}^{\prime} 02^{\prime}$ and the interrupt routine resides in memory at address $X^{\prime} 3000^{\prime}$, the set up involves: writing $X^{\prime} 3000^{\prime}$ at memory location $X^{\prime} \mathrm{D}^{\prime}:^{\prime}$. Note that $\mathrm{X}^{\prime} \mathrm{D}^{\prime}=\mathrm{X}^{\prime} \mathrm{D}^{\prime}+2$ times the Teletype address.

Although there may be gaps in device address assignments, the interrupt service pointer table should be completely filled. Entries for non-existent devices can point to an error recovery routine. (This precaution prevents system failure in the event of spurious interrupts caused by hardware malfunction or by improper use of the Simulate Interrupt instruction.)

The next step is to prepare the device for the transfer. This is done best with the immediate interrupt disabled. Once the table pointer has been set up, and the device prepared, the Processor can move on to an interruptable program.

When the device signals that it requires service, the Processor saves the current state, and transfers control to the location specified in the interrupt service pointer table. At this time, the current PSW has a status that indicates running state, machine malfunction interrupt enabled, higher level I/O interrupts enabled and all other interrupts disabled. Registers 0 and 1 of the new set contain the old PSW, indicating the status and location of the interrupted program. Register 2 of that set contains the device address. Register 3 contains the device status. The sequence of operation in this type of program is:

1. Set up the Interrupt Service Pointer Table to vector to error addresses for undefined devices.
2. Set up address of software interrupt handler routine at 2 times the device number plus $\mathrm{X}^{\prime} \mathrm{D}^{\prime}{ }^{\prime}$ ( $\mathrm{X}^{\prime} \mathrm{D} 0{ }^{\prime}$ is starting address of Service Pointer table).
3. Set up software interrupt handler routine.
4. Set up the device and enable device interrupts.
5. Enable interrupts in PSW

The interrupt handler routine should:

1. Check the device status in Register 3, and if satisfactory,
2. Make the transfer, and
3. Return to the interrupted program by reloading the old PSW from Registers 0 and 1 (LPSWR R0).

The interrupt service routine should not enable the immediate interrupt on its own level. To do so allows other interrupt requests to be acknowledged, and the contents of Registers $0: 4$ would be lost. If it is necessary to enable the immediate interrupt, the routine should save the register set, switch to a different register set, saving it if necessary, and then enable the immediate interrupt.

## SELECTOR CHANNEL I/O

The Selector Channel controls the transfer of data directly between high speed devices and memory. As many as 16 devices may be attached to the Selector Channel, only one of which may be operating at any one time. The advantage gained in using the Selector Channel is that other program processing may proceed simultaneously with the transfer of data between the external device and memory. This is possible because the Selector Channel accesses memory on a cycle stealing basis, which permits the Processor and the channel to share memory. In some cases, execution times of the program in progress may be affected, while in others, the effect is negligible. This depends upon the rate at which the Selector Channel and Processor compete for memory cycles.

The Selector Channel is linked to the Processor over the I/O Bus. It has its own unique device number which it recognizes when addressed by the Processor. Like other device controllers, it can request Processor attention through the immediate interrupt.

## Selector Channel Devices

The Selector Channel has a private bus similar to the Processor's I/O Bus. Controllers for the devices associated with the Selector Channel are attached to this bus. When the Selector Channel is idle, its private bus is connected directly to the I/O Bus. If this condition exists, the Processor can address, command, and accept interrupt requests from the devices attached to the Selector Channel. When the Selector Channel is busy, this connection is broken. All communication between the Processor and devices on the Selector Channel are cut off. Any attempt by the Processor to address devices on the channel results in instruction time-out.

## Selector Channel Operation

Two registers in the Selector Channel hold the current memory address and the final memory address. Before starting a Selector Channel operation, the control software, using Write instructions, places the address of the first byte of the data buffer in the current register and the address of the last byte in the final address register. During the data transfer, the channel increments the current address register by one for each byte transferred. When the current address equals the final address, the last byte has been transferred, and the channel terminates.

The Selector Channel accesses memory a halfword at a time. Therefore, the transfer must always involve an integer number of halfwords. The starting address of the data buffer must always be on an even byte (halfword) boundary. The ending address must always be on an odd byte boundary. The starting address must be less than the ending address.

Upon termination, the software can read back from the Selector Channel the address contained in the current address register. If this address is less than the final address specified for the transfer, and if the buffer limits were properly checked before the transfer, then this condition indicates a device malfunction or an unual condition within the device, for example, crossing a cylinder boundary on a disc.

The usual method of programming with the Selector Channel uses the immediate interrupt. The first step in the operation is to check the status of the Selector Channel. If it is not busy, the address of the termination interrupt service routine is placed in the location within the interrupt service pointer table reserved for the Selector Channel. Next the program should proceed as follows:

1. Give the Selector Channel a command to stop. This command initializes the Selector Channel's registers and assures the idle condition with the private bus connected to the I/O Bus.
2. Prepare the device for the transfer with whatever commands and information may be required.
3. Give the Selector Channel the starting and final addresses.
4. Give the Selector Channel the command to start.

With the Start command, the Selector Channel breaks the connection between its private bus and the Processor's I/O Bus, and provides a direct path to memory from the last device addressed over its bus. When the device becomes ready, the channel starts the transfer which proceeds to completion without further Processor intervention. Once the Start command has been given, the Processor can be directed to the execution of concurrent programs.

On termination, the channel signals the Processor that it requires service. The Processor subsequently takes an immediate interrupt, transferring control to the Selector Channel interrupt service routine. At this time, Registers 0:3 of the new set are set up as for any other immediate interrupt.

Note that if a power failure interrupts a SELCH transfer, the ending address in the SELCH is unpredictable.

## AUTO DRIVER CHANNEL

The Auto Driver Channel provides a means for multiplexing block data transfers between memory and low or medium speed I/O devices. The operation of the channel is similar in some respects to interrupt driven I/O. The channel is activated upon a service request from a device on the I/O Bus. Upon receipt of a device request, the Processor uses the device number to index into the Interrupt Service Pointer Table. If the value contained in the table is even, the Processor transfers control to the interrupt service routine. If the value is odd, it transfers control to the Auto Driver Channel.

To the Auto Driver Channel, the address in the Interrupt Service Pointer Table is the address plus one (making it odd) of a Channel Command Block (CCB). The Channel Command Block is basically a channel program consisting of a description of the operation to be performed, and a list of parameters associated with the operation. In addition to the functions of Read and Write, the channel can (a) translate characters, (b) test device status, (c) chain buffers, (d) calculate longitudinal and cyclic redundancy check values, and (e) transfer control to software routines to take care of unusual situations.

## CHANNEL COMMAND BLOCK

The Channel Command Block (CCB), as shown in Figure 7-1, consists of a Channel Command Word ( 16 bits ) that describes the function, count fields ( 16 bits each) for two buffers, final addresses ( 32 bits each) for two buffers, a check word ( 16 bits ) for the longitudinal or cyclic redundancy check, the address ( 32 bits ) of a translation table, and the address ( 16 bits ) of a software routine.


Just as there may be many interrupt service routines ready at any time to service device requests, there may be many channel command blocks in the system ready to handle data transfers as required. Each channel command block must start on a fullword boundary. The address plus one of the channel command block must be placed in the interrupt service pointer table location for the device involved in the transfer.

## Subroutine Address

When the channel transfers control to the software subroutine whose address is contained in the Channel Command Block, Registers 0:4 of the appropriate set have already been set up by the Processor to contain the old PSW, the device number, the device status, and the address of the Channel Command Block. The current PSW status specifies run state, machine malfunction interrupt enabled, higher level I/O interrupts enabled, and all other interrupts disabled.

The channel transfers control to the subroutine either unconditionally (controlled by a bit in the Channel Command Word), or because of bad device status, or because it has reached the limit of a buffer. It indicates its reason for transferring control by adjusting the Condition Code as follows.

| C | V | G | L |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 |

Unconditional transfer
Bad status
Buffer limit

The subroutine address in the CCB is a 16 bit address. Because of this, the subroutine at that address, or at least the first instruction of the subroutine, must reside in the first 64 KB of memory.

## Buffers

There is space in the CCB to describe two data buffer areas. The data areas may be located anywhere in memory. The limits of each data area are described by an address field and a count field. The address field contains the address of the last byte in the data area. This is a 24 bit address, right justified in the fullword provided. If the device being controlled is a halfword device, the final address must be odd. If the device is a byte device, the address may be either odd or even. The currently active buffer is selected by a bit in the Channel Command Word. When one buffer has been exausted, the channel may reverse the state of this bit and thus switch to the alternate buffer. Automatic buffer switching is only available for byte devices.

The count field, in most operations, contains a negative number whose absolute value is equal to one less than the number of bytes to be transferred. The one exception is the case of a single $b$ yte transfer, where the count field contains ZERO.

During data transfers, the channel adds the value contained in the count field to the final address to obtain the current address. It makes the transfer, referencing the current address, then increments the value in the count field by one for a byte device or by two for a halfword device. When the count field becomes positive, i. e., greater than zero, the channel sets the G flag in the Condition Code and transfers control to the specified software subroutine. If the count field is positive upon channel activation, the Channel makes no transfer and returns control to the processor with Condition Code $=0010(\mathrm{G}=1)$.

## Translation

The translation feature is used for special character recognition and is available only for byte devices. If this operation is specified, the fullword provided in the Channel Command Block must contain the 24 bit address, right justified, of a translation table. The table, which must start on a halfword boundary, can contain up to 256 halfword entries. During data transfers, the channel multiplies the data byte by two and adds this value to the translation table address. The result is the address within the translation table of the halfword corresponding to the data byte.

The channel references this location, and, if Bit 0 of the halfword is a one, it substitutes Bits $8: 15$ of the halfword for the data byte and proceeds with the operation. If Bit 0 of the halfword is a ZERO, the channel:

Does not increment the byte count for the appropriate buffer.
Puts the data byte, untranslated, in Bits 24:31 of Register 3, of the appropriate set.
Forces Bits 0:23 of Register 3 to ZERO.
Multiplies the value contained in the translation table by two, and transfers control to the software routine located at this address.

Upon transfer to the translation subroutine, Registers 0 and 1 contain the old PSW. Register 2 contains the device number. Register 3 contains the untranslated character. Register 4 contains the address of the Channel Command Block. The current PSW indicates run state, machine malfunction interrupt enabled, higher level I/O interrupts enabled and all other interrupts disabled. The Condition Code is zero.

## Check Word

If either longitudinal or cyclic redundancy checking is required, the check word in the Channel Command Block contains the accumulated value. The initial value for the check word is usually zero. (There are data dependent exceptions, e.g., where initial characters are not to be included in the check.) The longitudinal check is an Exclusive OR of the character with the check word. The cyclic check uses the formula for CRC 16:

$$
x^{16}+x^{15}+x^{2}+1
$$

If the Data Communication Option is equipped, the cyclic check may optionally use the formula for CRC SDLC:

$$
x^{16}+x^{12}+x^{5} \div 1
$$

On input, if both redundancy checking and translation are required, the character is translated first, then the cyclic redundancy check is done using the original character input rather than the translated character. On output, the character is translated first. Redundancy checking may be used only with byte devices.

## Channel Command Word

The Channel Command Word (CCW), as shown in Figure 7-2, consists of two parts. Bits 0:7 contain a status mask. Bits 8:15 describe the channel operation.


Figure 7-2. Channel Command Word

## Status Mask

On every channel operation involving a data transfer, the status mask is ANDed with the device status. This operation does not change the status mask. If the result is zero, the channel proceeds with the operation. If the result is non-zero, the channel sets the L flag in the Condition Code, and transfers control to the specified software subroutine.

## Execute Bit (E)

- If this bit is reset, the channel unconditionally transfers control to the specified subroutine, without taking any other action. The Condition Code is zero. If this bit is set, the channel continues with the operation as specified in the Channel Command Word.


## Fast Bit (F)

If this bit is set, the channel performs the I/O transfer in the fast mude. In the fast mode, buffer chaining, redundancy checking, and translation are not allowed. This bit must be set for halfword devices. If this bit is set, Buffer 0 is always used.

## Read/Write Bit (R/W)

This bit indicates the type of operation. If this bit is reset, a byte or a halfword is input from the device. If this bit is set, a byte or a halfword is output to the device.

## Translate Bit (T)

If this bit is set, and the fast bit reset, the channel translates the data byte.

## Redundancy Check Type Bits (RC)

These two encoded bits specify the type of redundancy check required. The following table contains the valid types of checks. These bits are ignored if the Fast bit (Bit 15) is set. CRC SDLC can be specified only if the Data Handling option is installed.

| Bit <br> 10 | Bit <br> 11 | Redundancy Check Type <br> 0 |
| ---: | :---: | :--- |
| 0 | 0 | LRC |
| 1 | 1 | BISYNC CRC |
| 1 | 1 | RESERVED - MUST NOT BE SPECIFIED |
|  |  | SDLC CRC - SHOULD ONLY BE SPECIFIFIED <br>  |
|  |  | IF THE DATA HANDLING OPTION IS |
| INSTALLED. |  |  |

Buffer Switch Bit (B)

When the fast bit is reset, this bit specifies which of the two buffers is to be used for the transfer. If this bit is reset, Buffer 0 is used. If it is set, Buffer 1 is used. The channel chains buffers when the count field becomes positive. It does this by complementing the buffer switch bit before transferring control to the specified software routine.

## Valid Channel Command Codes

The following is a list of valid codes for the Channel Command Word. Note that only the first three may be used with halfword devices.

## Channel Command Word 8:15

| Hexadecimal | Binary | Meaning |
| :---: | :---: | :---: |
| 00 | 00000000 | Transfer to subroutine |
| 81 | 10000001 | Read fast mode |
| 85 | 10000101 | Write, fast mode |
| 80 | 10000000 | LRC, Buffer 0, Read |
| 82 | 10000010 | LRC, Buffer 0, Read, translate |
| 84 | 10000100 | LRC, Buffer 0, Write |
| 86 | 10000110 | LRC, Buffer 0, Write, translate |
| 88 | 10001000 | LRC, Buffer 1, Read |
| 8A | 10001010 | LRC, Buffer 1, Read, translate |
| 8 C | 10001100 | LRC, Buffer 1, Write |
| 8 E | 10001110 | LRC, Buffer 1, Write, translate |
| 90 | 10010000 | CRC BISYNC, Buffer 0, Read |
| 92 | 10010010 | CRC BISYNC, Buffer 0, Read, translate |
| 94 | 10010100 | CRC BISYNC, Buffer 0, Write |
| 96 | 10010110 | CRC BISYNC, Buffer 0, Write, translate |
| 98 | 10011000 | CRC BISYNC, Buffer 1, Read |
| 9 A | 10011010 | CRC BISYNC, Buffer 1, Read, translate |
| 9 C | 10011100 | CRC BISYNC, Buffer 1, Write |
| 9 E | 10011110 | CRC BISYNC, Buffer 1, Write, translate |
| B0 | 10110000 | CRC SDLC, Buffer 0, Read |
| B2 | 10110010 | CRC SDLC, Buffer 0, Read, translate |
| B4 | 10110100 | CRC SDLC, Buffer 0, Write |
| B6 | 10110110 | CRC SDLC, Buffer 0, Write, translate |
| B8 | 10111000 | CRC SDLC, Buffer 1, Read |
| BA | 10111010 | CRC SDLC, Buffer 1, Read, translate |
| BC | 10111100 | CRC SDLC, Buffer 1, Write |
| BE | 10111110 | CRC SDLC, Buffer 1, Write, translate |

## General Auto Driver Channel Programming Procedure (See Figure 7-3.)

1. Set up Interrupt Service Pointer Table to vector to error routines for undefined devices.
2. Set up address of Channel Command Word +1 (odd) in table at 2 times Device number plus X'D0' (start of Interrupt Service Pointer Table)
3. Set up complete Channel Command Block.
4. Set up device and enable device interrupt.
5. Enable interrupts in PSW (Auto Driver Channel finishes operation).
6. Check for good termination of Auto Driver Channel operation.


Figure 7-3. Microcode Flowchart of Auto Driver Channel (Sheet 1)


Figure 7-3. Microcode Flowchart of Auto Driver Channel (Sheet 2)


Figure 7-3. Microcode Flowchart of Auto Driver Channel (Sheet 3)

## CHAPTER 8 <br> MEMORY MANAGEMENT

Memory Relocation and Protection is provided by the Memory Access Controller (MAC). The MAC is a device which monitors all memory accesses. Under program control, it can (a) translate the address of a memory access from a 20 -bit program address to a 20 -bit physical address, (b) prevent write access to a block of memory, (c) reject instruction execution from a block of memory or (d) detect an invalid memory access.

The throughput between the Processor and local memory or between the Selector Channel and local memory is not affected by the use of the MAC.

In an operating system environment, the operation of the MAC is completely transparent to most programs. It is very similar to a peripheral device in that only the operating system modules directly responsible for its operation need be aware of its existence.

## PROGRAM ADDRESS SPACE

The MAC allows an Operating System to provide support to user programs in such a way that the program can be coded as if some subset of available memory, starting at address 0 , were available to the program. The range of addresses thus referenced by the program is called the Program Address Space. At load time, the MAC can be used to map this program address space into the available physical memory addresses so that any program address, referenced during the program execution, is translated (relocated) to the correct physical address before memory is accessed. The MAC interprets the Program Address as follows


## RELOCATION

The relocation of program address to physical address is accomplished through the relocation/ protection bit (bit 21) of the Program Status Word and the 16 Segmentation Registers of the MAC. If the relocation/protection bit of the PSW is reset, the MAC provides no translation of the addresses. If the relocation/protection bit of the PSW is set, the MAC assumes that all memory accesses are program addresses which must be relocated to physical addresses. Before the relocation/protection bit of the PSW is set, the MAC Segmentation Registers must be loaded with the appropriate mapping of the program to physical address (see below). The MAC Segmentation Register describes the starting address and length of a block of physical memory allocated to the program address space. These blocks must start on a 256 byte boundary and may be up to 64 K bytes long.


When the relocation/protection bit of the PSW is set, the program address is relocated as follows:
Program address Bits $12: 15$ select one of the segmentation Registers. In the example above, segmentation Register 3 is selected.

Segmentation Register Bits 12:23 specify starting address of the block of memory. In the illustration above, X'742' means that the memory block starting address is X'74200'.

Program address Bits 16:31 contain the memory block displacement.
The block displacement is added to the memory block starting address to obtain physical memory address.

## PROTECTION

In addition to describing a block of physical addresses, each Segmentation Register can be used to limit the type of access to the described block of addresses. Five types of protection are provided by the MAC when the relocation/protection bit of the current PSW is set:
if the presence bit (Bit 27) is reset in the Segmentation Register selected by Bits 12:15 of the Program address (non-present address), or
if the write-protect bit (Bits 25:26 = 01 or 11) is set in the Segmentation Register selected by Bits 12:15 of the program address, and an attempt is made to store into the addressed memory (write protection violation), or
if write/interrupt protection bit (Bits 25:26 = 10) is set in the Segmentation Register selected by bits 12:15 of the program address and a store is made into the addressed memory (write/interrupt protection violation), or
if the execution-protection bit (Bit 24) is set in the Segmentation Register selected by Bits 12:15 of the program address and an instruction fetch is being attempted from the addressed memory (execute protection violation), or
if the value of Bits 16:23 of the program address is larger than the limit described in the Segmentation Register selected by Bits 12:15 of the program address (invalid address), then a Relocation/Protection Fault interrupt is generated. The MAC status register contains the reason for the interrupt (see below).


SEGMENTATION REGISTER

In the case of an execution protection violation, write protection violation or invalid address, if the interrupt generated by the MAC cannot be accepted immediately by the Processor, the controller continues to operate, but all Write operations are changed to read operations until the interrupt is cleared. In the case of write/interrupt protect violation, the store operation is allowed to complete and then an interrupt is generated. A MAC interrupt condition is cleared by any reference to the MAC interrupt status register, however, only a store instruction will clear the status register.

## EXAMPLE:

The effect of the MAC is best illustrated by an example of a program executing under operating system control.

Assume that the program consists of:
main program coded as if addresses 0 through 2 FFF are available and a program entry address of 100. $($ Program Address Space $=12 \mathrm{~K}$ )
a subroutine coded as if addresses F0000 through F1FFF are available. (Program Address Space $=8 \mathrm{~K}$ )
a data area which is initialized by some other program and which is contained at addresses A0000 through AFFFF. This area is to be write and execute protected. (Program Address Space $=64 \mathrm{~K}$ )

The operating system executes with the relocation/protection bit of the PSW reset so that no address relocation or protection is in effect.

Assume that the main program, subroutine and data area are loaded into physical memory starting at addresses 21000 , F000, 13000 respectively. Before passing control to the example program, the operating system:
sets the start address of Segmentation Registers 0, 10 and 15 to 21000 , 13000 and 0 F000 respectively.
resets the presence bit in the remaining Segmentation Registers.
sets the limits of Segmentation Registers 0, 10 and 15 to 47,255 and 31 blocks respectively. sets write and executes protection in Segmentation Register 10.


SEGMENTATION REGISTER FIELDS

SEGMENTATION REGISTER 0.


SEGMENTATION REGISTER 10:


SEGMENTATION REGISTER 15:


SEGMENTATION REGISTERS $1,2,3,4,5,6,7,8,9,11,12,13 \& 14$ :


The program can then be started by loading a PSW with relocation/protection bit of the status portion set and a location counter of 100. A relocation/protection fault interrupt occurs if:
an attempt is made to reference 30000. (Presence bit reset in selected Segmentation Register, i. e., Segmentation Register 3.)
an attempt is made to store into A0100. (Write protect set in selected Segmentation Register, i. e., Segmentation Register 10.)
an attempt is made to branch to A0000. (Execute protect set in selected Segmentation Register, i. e., Segmentation Register 10.)
an attempt is made to reference F3000. (Value of Bits 15:31 of program address (3000) is larger than the limit field of Segmentation Register 15 (32 256 byte blocks or 2000)).

An attempt to reference 100, F1200 or A0001 results in an access to 21100, 10200 or 13001 respectively.

## MAC REGISTERS

The MAC has 17 hardware registers referred to as Base Registers. There are 16 Segmentation Registers and 1 Interrupt Status Register. These registers are accessed through the assigned memory locations.

The 72 bytes starting at the first 256 byte boundary above the Interrupt Service Pointer Table, are dedicated to the MAC.

| MAX NUMBER OF DEVICE ADDRESSES | DEDICATED MAC LOCATIONS |
| :---: | :---: |
| 256 | $300-347$ |
| 512 | $500-547$ |
| 1024 | $900-947$ |

The MAC Registers are assigned to the dedicated locations as follows (for 256 maximum number of device addresses):


Values are loaded into the MAC registers by storing the values into the appropriate assigned memory locations. Any attempt to read the dedicated MAC locations returns the value in the corresponding memory location except for the location assigned to the MAC Status Register. In general, manipulation of MAC registers is performed with the relocation/protection of the PSW reset. To summarize the manipulation of the MAC registers:

The 68 bytes starting at the first 256 byte boundary above the Interrupt Service Pointer Table, are dedicated to the MAC.

The value of a MAC register is changed by storing into the appropriate dedicated MAC location.

The value of the MAC Status Register is read by loading from the appropriate dedicated MAC location.

All attempts to read (load) from dedicated MAC locations return the value in the corresponding memory location, except for the MAC status register location.

MAC registers are manipulated, with the relocation/protection bit of the PSW reset, as follows:
The Segmentation Registers are set up by storing data into the appropriate assigned memory locations.

The Segmentation Registers cannot be read. Any attempt to read the dedicated MAC locations assigned for the Segmentation Registers returns the value in the corresponding memory locations. This value may be different than the actual (hardware) Segmentation Register value. To read the data which has been loaded into the Segmentation Registers, it is necessary to read the assigned locations after the registers have been loaded (with MAC disabled) and before the MAC is enabled. Under these conditions the assigned memory locations will contain the same data as the Segmentation Registers.

The Interrupt Status Register is cleared by writing any data into its assigned memory location.

The Interrupt Status Register can be read by reading its assigned memory location. This also clears the Interrupt Status Register.

## Definition of MAC Register Fields

## Segmentation Register



Each Segmentation Register is 32 bits wide.

| Field | Bits | Meaning |
| :---: | :---: | :---: |
|  | 0-3 | Unused - must be zero |
| SLF | 4-11 | Segment Limit Field, contains one less than the number of 256 byte blocks in the segment described by this register. |
| SRF | 12-23 | Segment Relocation Field - indicates the starting address of the segment described by this register (Starting address $=$ SRF multiplied by $\mathrm{X}^{\prime} 100^{\prime}$ ). |
| E | 24 | Execute protect bit - if set, instruction fetch from segment causes relocation/protection fault. |
| WP | 25-26 | Write protection field - encoded as follows: |
|  |  | ```00 - no write protection 01 or 11 - Write protected - attempt to store into segment causes relocation/protection fault - store is not executed.``` |
|  |  | 10 - Write/Interrupt protect - attempt to store into segment causes relocation/protect fault - store is executed. |
| P | 27 | Presence bit - if not set, selection of this register causes relocation/protection fault. |
|  | 28-31 | Unused - must be zero. |

## Interrupt Status Register



| Field | Bits | Meaning |
| :--- | :--- | :--- |
| I | 27 | Invalid Address - value of bits 16:31 of program address <br> greater than the limit specified by SLF in the selected <br> Segmentation Register. |
| N | 28 | Non-present Address - present bit not set in selected <br> segmentation register. |
| WP | 29 | Write Protect Violation - attempt to store into write protected <br> segment. |
| WI | 30 | Write/interrupt protection violation - store into write/ <br> interrupt protected segment. |
| E | Execute Protect Violation - instruction fetch attempt from <br> execute protected segment. |  |

The Interrupt Status Register is set by the MAC during generation of a relocation/protection fault interrupt. The first reference, load or store, to the memory location assigned to the interrupt status register following the interrupt, clears the interrupt condition from the MAC. The Relocation and protection interrupt handler should execute with the relocation/protection bit of the PSW reset and should clear the Interrupt Status Register by storing any fullword into the assigned memory location before exiting.

## Initialization

Whenever the Initialize Switch (INI) on the display panel is depressed, or the processor is powered up, all segmentation, relocation, protection and MAC interrupts are disabled regardless of the state of bit 21 in the current PSW. The contents of the MAC segmentation registers must be restored by software after Power Fail.

The MAC remains disabled until a memory reference instruction is issued. At this time, the MAC is enabled or remains disabled depending on the condition of bit 21 of the current PSW.

## CHAPTER 9 WRITABLE CONTROL STORE INSTRUCTIONS

The writable control store option puts the power and speed of the Model $8 / 32$ micro processor into the hands of systems programmers for implementing high speed algorithms or specialized functions. This option is available in the Model 8/32 and may not be available with other 32 Bit Processors.

All the resources of the microprocessor become available to the user as an extension to the user level architecutre. The user is provided with 512 or 204832 -bit words of dynamically alterable high \} speed control store memory over and above the 1280 words of fixed read-only control store. Also there are user level instructions for writing to and reading from the control store and executing microprogrammed routines contained in the control store.

Figure 9-1 illustrates the organization of the Model 8/32 Microprocessor. In general, via the appropriate micro-instruction, data is gated from the Register Stacks by way of the A \& B source buses to the selected module (ALU or I/O) and a given operation specified for the I/O Module. Results appear in the selected destination register via the S bus. The register stacks are paralleled and each stack contains up to 16832 -bit registers. This includes up to 8 sets of 16 each user level general registers, 16 floating point registers, and 8 registers for exclusive use by the microprogram. The dual stack organization allows concurrent gating onto the two source buses (A\&B).


Figure 9-1. Model $\mathbf{8 / 3 2}$ Block Diagram

Many of the other internal registers are available for limited use by the microprogram.
Microinstructions in the Model 8/32 are divided into two basic types:

- Control Module Instructions. Branch, Execute, etc.
- Instructions for the other four modules.

ALU - Add, Subtract, Shift, Multiply, etc. I/O Module - Read, Write, etc.
Floating Point ALU - Add, Subtract, Multiply, etc.
Double Precision Floating Point ALU - Add, Subtract, Multiply, etc.
Figure 9-2 shows the basic micro-instruction formats. As can be seen, many concurrent operations are possible. For Branch and Execute instructions, the F field specifies the condition for branching to or executing the target micro-instruction. The control bits specify the type of memoryrelated action to be taken. Other bits determine if the next user instruction should be decoded and whether the instruction is a "Branch" or "Execute and Return" type of instruction.

For the ALU modules and the I/O module, there are also multiple fields defining several parallel operations. There are four basic instruction types: Register to Register with a transfer, Register to Register with memory control, Immediate, and Register write to the Control Store. Data may be retrieved from the fixed or the writable portion of the Control Store by use of the "I" bit in the microinstruction.

A large repertoire of micro-instructions is available to make most efficient use of the parallelism of the hardware. A complete list of micro-instructions is available in Appendix 8. Refer to the Model $8 / 32$ Microprogram Reference Manual, Publication No. 29-438, for details. Also refer to the Model $8 / 32$ WCS User's Guide, Publication Number 29-479, for usage of WCS under an operating system (e.g. OS/32-MT).

## NOTE

The Writable Control Store consists of RAM ICs. The microcode in the WCS is volatile and therefore must be restored after the power fail/restore sequence. This function is done by the Model 8/32 WCS Support Program, Program Number 03-102.

## WRITABLE CONTROL STORE INSTRUCTIONS

- The writable control store option provides the user with 512 or 2048 32-bit words of dynamically alterable, high-speed control store memory (WCS). User level instructions are added for writing blocks of data into the WCS, reading blocks of data from the WCS and executing micro-programmed routines contained in the WCS.

The WCS acts as an extension to the basic read-only control store memory. The basic control store represents control store addresses $\mathrm{X}^{\prime} 000^{\prime}$ through $\mathrm{X}^{\prime} 4 \mathrm{FF}$ ' and the WCS represents control
! store addresses $\mathrm{X}^{\prime} 800^{\prime}$ through $\mathrm{X}^{\prime} 9 \mathrm{FF}^{\prime}$ or $\mathrm{X}^{\prime} \mathrm{FFF}{ }^{\prime}$.

The instructions described in this section are:

| WDCS | Write Control Store |
| :--- | :--- |
| RDCS | Read Control Store |
| BDCS | Branch to Control Store |
| ECS | Enter Control Store |

ADDRESS LINK


REGISTER TO REGISTER TRANSFER


REGISTER TO REGISTER CONTROL


REGISTER TO REGISTER IMMEDIATE


REGISTER WRITE


| FIELD | MEMORY |
| :--- | :--- |
| A | Selects first operand register |
| B | Selects second operand register |
| S | Selects register to receive result |
| F | Specifies function of addressed module |
| E | Enables setting of Condition Code |
| C | If set, transfer is conditional |
| X | Execute |
| I | Second operand is address of data |
| D | Decode next user instruction |
| K | F field extension |
| MC | Main Memory Control |

Figure 9-2. Model 8/32 Micro Instruction Formats

## INSTRUCTION

Write Control Store (WDCS)

| Assembler Notation | Op-Code | Format |
| :---: | :---: | :---: |
| WDCS R2 | E80 | RR |

## Operation

The second operand address contained in the register specified by R2 is the starting location in main memory of the data to be transferred to WCS. The area of WCS to be loaded is specified by the low address contained in General Register 0 and the fullword count minus one contained in General Register 1. These registers must be set up by the user prior to executing the WDCS instruction.

The WDCS instruction is interruptable. When it is interrupted, the Location Counter field of PSW is not incremented so that after servicing the interrupt, the WDCS instruction can be resumed. Proper resumption of the instruction is assured because as each fullword is transferred to the WCS address specified by the contents of General Register 0 plus the count, the count in General Register 1 is decremented by one. The operation continues until the count decrements from zero to minus one.

## Condition Code

Unchanged

## Programming Notes

The R2 field may specify any register other than 0 or 1.
The second operand address in the register specified by R2 must be located on a fullword boundary.

This instruction is a privileged operation.

## INSTRUCTION

Read Control Store (RDCS)

## Assembler Notation

RDCS R2
$\frac{\text { Op-Code }}{\mathrm{E} 82} \quad \frac{\text { Format }}{\mathrm{RR}}$

## Operation

The second operand address contained in the register specified by R2 is the starting location in main memory that is to receive data from the WCS. The area from which this data is to be copied is specified by the low address contained in General Register 2 and the fullword count minus one in General Register 3. These registers must be set up by the user prior to executing the RDCS instruction.

The RDCS instruction is interruptable. When it is interrupted, the Location Counter field of the PSW is not incremented so that after servicing the interrupt, the RDCS instruction can be resumed. Proper resumption of the instruction is assured because as each fullword is transferred from WCS to main memory, the count in General Register 3 is decremented by one. The operation continues until the count decrements from zero to minus one.

## Condition Code

Unchanged

## Programming Notes

The R2 field may specify any register other than 2 or 3 .
The second operand address in the register specified by $R 2$ must be located on a fullword boundary.
This instruction is a privileged operation.

## INSTRUCTION

- Branch to Control Store (BDCS)

| Assembler Notation | Op-Code | Format |  |
| :---: | :---: | :---: | :---: |
|  |  | E5 | RX1, RX2 |
| BDCS | R1, D2(X2) | E5CS | R1, A(FX2, SX2) |

## Operation

An unconditional branch is taken to the Control Store address equal to the least significant 12 bits of the second operand address. The second operand address may specify any location within the writable portion of the control store, $\mathrm{X}^{\prime} 800$ through $\mathrm{X}^{\prime} \mathrm{FFF}^{\prime}$, or to any location within the readonly portion of the control store, $\mathrm{X}^{\prime} 000^{\prime}$ through $\mathrm{X}^{\prime} 4 \mathrm{FF}$ '. Unpredictable results can occur if a branch is taken to a non-present microprogram address.

## Condition Code

Depends on the microprogram entered into.

## Programming Notes

Micro level interrupts are not armed and the Location Count field of PSW is not incremented.

The second operand address is not tested for validity.
The user may assign any desired meaning to the R 1 field of the instruction.
This instruction is a privileged operation.

## INSTRUCTION

Enter Control Store (ECS)

Assembler Notation

ECS R1, A(X2)

Op-Code

E9

Format

RI1

## Operation

Control is given to the WCS location whose value is X'800' plus the contents of the R1 field. The affect is a branch to one of the first sixteen locations in WCS. These locations may contain branch microinstructions to sixteen different micro routines. By placing the appropriate number in the R1 field of the ECS instruction the user can call one of sixteen different functions.

## Condition Code

Depends on the microprogram entered into.

## Programming Notes

The Location Count field of PSW is not incremented and micro-level interrupts are not armed.

The user may assign any desired meaning to the X 2 field or the A field.

# CHAPTER 10 HIGH SPEED DATA HANDLING INSTRUCTIONS 

The Data Handling instructions are used to compute polynomial error check redundancy characters, as used by most data communications protocols. A high speed memory-to-memory move capability is also provided with this option. Communications protocols supported by this option include, but are not limited to, the following:

Binary Synchronous Communications (BISYNC or BSC) - IBM's widely accepted half-duplex protocol uses the CRC BISYNC error check polynomial ( $\mathrm{x}^{16}+\mathrm{x}^{15}+$ $\mathrm{x}^{2}+1$ ).

Synchronous Data Link Control (SDLC) - IBM's new full-duplex protocol uses the CRC SDLC error check polynomial ( $\mathrm{x}^{16}+\mathrm{x}^{12}+\mathrm{x}^{5}+1$ ).

Advanced Data Communications Control Procedure (ADCCP) - ANSI's proposed National Standard full-duplex protocol uses CRC SDLC.

High Level Data Link Control (HDLC) - The ISO's International Standard full-duplex protocol uses CRC SDLC.

DATA HANDLING INSTRUCTION FORMATS

The optional Data Handling instructions use the Register to Register (RR), and the Register and Indexed Storage (RX) formats.

DATA HANDLING INSTRUCTIONS

| PB | Process Byte |
| :--- | :--- |
| PBR | Process Byte Register |
| MPBSR | Move and Process Byte String Register |

## INSTRUCTION

Process Byte (PB)


Bits 24:31 of the register specified by R1 contain the data byte to be processed. Bits $8: 15$ of the register specified by $R 1$ contain a check code to indicate the type of processing. This byte is interpreted as follows:

| $\mathrm{X}^{\prime} 00^{\prime}$ | Cumulative check zero (CRC BISYNC) |
| :--- | :--- |
| $\mathrm{X}^{\prime} 01^{\prime}$ | Cumulative check one (CRC SDLC) |
| $\mathrm{X}^{\prime} 02^{\prime}$ | Cumulative check two (LRC) |

The second operand address points to a halfword residual checksum to be included in the cumulative check.

## Operation

If CRC BISYNC is specified, the data byte, and the old residual checksum participate in the Generation of a new residual checksum based on the evaluation of the polynomial $\left(x^{16}+x^{15}+x^{2}+1\right)$.

If CRC SDLC is specified, a similar operation is performed, using the polynomial $\left(x^{16}+x^{12}+x^{5}+1\right)$

In both of these cases, the new residual checksum replaces the old residual checksum at the second operand location.

If LRC is specified, the EXCLUSIVE OR of the data byte with the old residual checksum replaces the old residual checksum at the second operand location.

## Condition Code

Unchanged

## Programming Notes

Bits $0: 7$ and $16: 23$ of the register specified by R1 are ignored.
The register specified by R1 remains unchanged.
The second operand must be located on a halfword boundary.
Undefined check codes should not be used. If they are, the results are undefined.

## Example: PB

This example performs a Process Byte instruction and stores the residue into RESIDUE.

| Register 1 | contains $\mathrm{X}^{\prime} 0001007 \mathrm{~A}^{\prime}$ |
| ---: | :--- |
| where: | $01=$ CRC SDLC |
|  | $7 \mathrm{~A}=$ DATA BYTE |

RESIDUE contains $\mathrm{X}^{\prime}$ D053' = old residue

## Assembler Notation

PB R1,RESIDUE

## Comments

RESIDUE ON HALFWORD BOUNDARY

## Result of PB Instruction

| (R1) | $=$ unchanged by this instruction |
| :--- | :--- |
| (RESIDUE) | $=\mathrm{X}^{\prime} \mathrm{BC} 13^{\prime}=$ new residue |
| Condition Code | $=$ unchanged by this instruction |

## INSTRUCTION

## - Process Byte Register (PBR)

| Assembler Notation | Op-Code | Format |  |
| :---: | :---: | :---: | :---: |
| PBR | $\mathrm{R} 1, \mathrm{R} 2$ | 32 | $R R$ |

## Set Up

R1
R2

| 0 | 74 | $23+24$ |  |
| :---: | :---: | :---: | :---: |
| $x$ | CHECK CODE | X | DATA BYTE |
| 0 |  | RESIDUAL CHECKSUM |  |

Bits 24:31 of the register specified by R1 contain the data byte to be processed. Bits $8: 15$ of the register specified by $R 1$ contain a check code to indicate the type of processing. This byte is interpreted as follows:
$\mathrm{X}^{\prime} 00^{\prime} \quad$ Cumulative check zero (CRC BISYNC)
X'01' Cumulative check one (CRC SDLC)
X'02' Cumulative check two (LRC)
The second operand is a fullword contained in the register specified by R2. Bits 16:31 of the second operand contain the residual checksum to be included in the processing.

## Operation

If CRC BISYNC is specified, the data byte, and the old residual checksum participate in the generation of a new residual checksum based on the evaluation of the polynomial ( $x^{16}+x^{15}+x^{2}+1$ ).

IF CRC SDLC is specified, a similar operation is performed, using the polynomial $\left(x^{16}+x^{12}+x^{5}+1\right)$.

In both these cases, the new residual checksum replaces the contents of the Bits 16:31 of the register specified by R2.

If LRC is specified, the EXCLUSIVE OR of the data byte with the old residual checksum replaces the old residual checksum in the second operand.

## Condition Code

Unchanged

## Programming Notes

Bits 0:7 and 16:23 of the register specified by R1 are ignored. The register specified by R1 remains unchanged. Bits $0: 15$ of the register specified by R 2 are not used and must be zero.

Undefined check codes should not be used. If they are, the results are undefined.

## INSTRUCTION

Move and Process Byte String Register (MPBSR)

| Assembler Notation | Op-Code | Format |
| :---: | :---: | :---: | :---: | :---: |
| MPBSR R1, R2 | 30 | $R R$ |

## Set Up

| R1 | 7,8 |  | 1516 | 31 |
| :---: | :---: | :---: | :---: | :---: |
|  | DATA BYTES STRING ADDRESS |  |  |  |
| R1+1 | TRANSLATION TABLE ADDRESS |  |  |  |
| R $1+2$ | CONTROL CODE | CHECK CODE | COUNT |  |
| R1+3 | 0 |  | RESIDUAL CHECKSUM |  |
| R1+4 | LINK REGISTER FOR SUBROUTINE |  |  |  |
| R2 | DESTINATION BUFFER ADDRESS |  |  |  |

The register specified by R1 contains the address of the first byte in the string to be moved and processed.

The register specified by $R 1+1$ contains the address of the translation table.

Bits $0: 7$ of the register specified by R1+2 contain a control code to indicate both the type and the sequence of processing. This byte is defined as follows:

| $\mathrm{X}^{\prime} 00^{\prime}$ | Cumulative check using data byte, move data byte |
| :--- | :--- |
| $\mathrm{X}^{\prime} 08^{\prime}$ | Translate, cumulative check using data byte, move translated byte |
| $\mathrm{X}^{\prime} 0 \mathrm{~A}^{\prime}$ | Translate, cumulative check using translated byte, move translated byte |
| $\mathrm{X}^{\prime} 0 \mathrm{C}^{\prime}$ | Translate, move translated byte |

Bits 8:15 of the register specified by R1+2 contain a check code to indicate the type of cumulative check to be used in processing the data bytes. This byte is interpreted as follows:

```
X'00' Cumulative check zero (CRC BISYNC)
X'01' Cumulative check one (CRC SDLC)
X'02' Cumulative check two (LRC)
```

If cumulative check is not specified, this byte does not participate in the MPBSR instruction.
Bits 16:31 of the register specified by $\mathrm{R} 1+2$ contain a halfword count which defines the number of bytes to be processed. A count of X'0000' specifies a move of 1 character. A count of X'7FFF' specifies a move of 32,768 characters. These are the minimum and maximum count values respectively.

Bits 16:31 of the register specified by $\mathrm{R} 1+3$ contain the halfword residual value to be used in performing the cumulative check. If cumulative check is not specified, this register does not participate in the MPBSR instruction.

The register specified by $R 1+4$ is used as a link register in the translation process, if a special character subroutine is specified. If translate is not specified or if a special character subroutine is not specified, this register does not participate in the MPBSR instruction.

The register specified by R2 contains the address of the destination buffer.


Figure 10-1. Flow Chart of MPBSR Instruction


Figure 10-1. Flow Chart of MPBSR Instruction (Continued)

## - Operation (See Figure 10-1)

Successive bytes, starting with the first in the source string are:

1. Processed in accordance with the specified codes.
2. Moved to the destination buffer.

The operation stops when the byte count becomes negative. The source string is unchanged. (See Addresses and Count, below.) The processed bytes replace the contents of the destination buffer. Upon completion of the instruction, the location counter is incremented to point to the next instruction in sequence. If the byte count is negative at the start of the instruction, no moving or processing is done, the instruction terminates, and the location counter is incremented to point to the next instruction.

## Translation

The translation operation requires a 256 halfword table located in memory at the address contained in the register specified by $R 1+1$. The table is arranged in ascending order, with one entry for each of the 256 possible data bytes. The translation operation may result in cither a direct replacement, (in the destination buffer), of the data byte with another, or in a transfer to a special character subroutine.

If the most significant bit, bit zero, of the halfword entry corresponding to the data byte is a one, then bits $8: 15$ contain the replacement byte. This byte is moved to the proper location in the destination buffer. The table entry is unchanged.

If the most significant bit of the entry is a zero, then bits $1: 15$ contain the address, divided by two, of the special character subroutine. Before transferring to the subroutine, the link register, specified by $R 1+4$, is loaded wi th the address of the MPBSR instruction. The source address has not been incremented and points to the current bytc. The count has not been decremented. The destination address has not been incremented and points to the proper destination for this byte. This byte does not participate in the cumulative check.

If none of the halfwords in the translation table has its most significant bit set (i.e., no special character subroutines), the register specified by $R 1+4$ is not used by this instruction.

## Cumulative Check

The source byte used for the cumulative check may be the data byte or the translated byte as specified by the control code. The source byte is included in any one of three types of cumulative check operations as specified by the check code.

If CRC BISYNC is specified, the source byte, and the old residual checksum contained in Bits 16:31 of the register specificd by R1+3 participate in the generation of a new residual checksum using a cyclic redundancy checking algorithm based on the generated polynomial ( $x^{16}+x^{15}+x^{2}+1$ ).

If CRC SDLC is specified, a similar operation is performed, using the polynomial $\left(x^{16}+x^{12}+x^{5}+1\right)$.

In both of these cases, the new residual checksum replaces the contents of Bits 16:31 of the register specified by R1+3.

If LRC is specificd, the EXCLUSIVE OR of the source byte with the old residual checksum replaces the old residual checksum in Bits 16:31 of the register specified by R1+3.

## Byte Count

As each byte is moved, the source address and the destination address are incremented by one. The count is decremented by one. Upon completion of the instruction, the source and destination address registers contain the incremented addresses. The count register specified by R1+2 contains a negative one, X'FFFF FFFF'.

The count value is equal to the number of bytes in the source string minus one. A count of $X^{\prime} 0000^{\prime}$ causes one byte to be processed, a count of $\mathrm{X}^{\prime} 7 \mathrm{FFF}$ ' causes 32,768 bytes to be processed. These are the minimum and maximum count values respectively.

## Condition Code

| C | V | G | L |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 0 | I | 0 | 0 |

Successful completion
Count negative at start

## Addresses

There are no boundary restrictions on either the location of the source string or on the location of the destination buffer. Either may start and end on odd byte boundaries. If the memory access controller is present and enabled, memory references using these addresses are relocated.

The translation table must be located on a halfword boundary. The address of the translation table is relocated, if the memory access controller is enabled. Within the translation table, the address fo the special subroutine must point to a location within the first 64 KB of program space. This address is also subject to relocation by the memory access controller.

Source and destination buffers may overlap. No checking is performed. The addresses specified by the source (R1) and destination (R2) registers may be equal, specifying a move in place, but R1 must not be equal to R2. That is, the instruction MPBSR 3, 3 is invalid.

## Programming Notes

This instruction is interruptable. The point at which interrupts are recognized, and the periods of non-interruptability may vary in different implementations. Any of the following events may cause this instruction to be interrupted: machine malfunction, memory failure, memory access violation, external device attention. Before taking the interrupt, the processor finishes processing the current byte, increments the source and destination addresses, and decrements the count. The location counter is not incremented. This permits the move to resume, following the servicing of the interrupt. Interrupt routines may use this instruction, provided they do not destroy the contents of the registers.

Undefined control codes should not be used. If they are, the results are unpredictable.
Illegal instruction interrupt occurs if the Processor is not equipped with the communication Instructions option.

If R1 specifies register number 6 , then registers $6,7,8,9$ and 10 are used by this instruction. If R1 specifies register number 13 , then registers $13,14,15,0$ and 1 are used, in that order, by this instruction.

If $\mathrm{R} 1=\mathrm{R} 2$, the results are not defined.

This example moves and performs a CRC SDLC check on a byte string of data.

BUFIN $=256$ bytes buffer containing data $0: \mathrm{X}^{\prime} \mathrm{FF}^{\prime}$
Register 1 contains address of BUFIN
Register 2 contains address of TRANSTAB
Register 3 contains X'000100 FF'
where: 00 indicates check and move
01 indicates CRC SDLC
00 is not used
FF indicates 256 bytes to be used
Register 4 contains $X^{\prime} 0^{\prime}$ to begin
Register 5 not used in this example
Register 6 contains address of BUFOUT

## Assembler Notation

MPBSR REG1, REG6

## Comment

MOVE BUFIN TO BUFOUT
(REG1) $\quad=$ BUFIN +256
(REG2) $\quad=$ unchanged by this instruction
(REG3) $\quad=X^{\prime}$ FFFF FFFF'
(REG4) $\quad=$ Half Residue X'D841'
(REG6) $\quad=$ BUFOUT +256
Condition Code $=0000$ successful completion
BUFIN is unchanged
BUFOUT now contains 256 bytes $0-255$

# CHAPTER 11 <br> M71•102 HEXADECIMAL DISPLAY PANEL AND M71-101 BINARY DISPLAY PANEL PROGRAMMING SPECIFICATION 

## INTRODUCTION

The M71-102 Hexadecimal Display Panel and M71-101 Binary Display Panel provide a means to manually control the Processor, interrogate and display various Processor registers and machine status, set and display Processor memory locations, and may be programmed as an I/O device by the user. The Hexadecimal Display Panel and Binary Display Panel are identical in operation. For convenience of the operator the Hexadecimal Display is equipped with a Hexadecimal readout in addition to the standard Binary readout.

## CONFIGURATION

The Hexadecimal Display Panel provides the system operator with visual indications of the state of the Processor, as well as manual control over the system.

The Hexadecimal Display Panel, shown in Figure 11-1, is a RETMA standard 133 mm X 483 mm ( $5 \frac{1}{4}$ " $\mathrm{X} 19^{\prime \prime}$ ) panel which is plug removable from the Processor. It displays the current state of the Processor and provides all necessary manual control over the system. The following paragraphs describe the control and display elements of the Hexadecimal Display Panel.


Figure 11-1. Hexadecimal Display Pane!

## Display Registers and Indicators

Internal to the Hexadecimal Display Panel are five eight-bit byte Display Registers, D1 through D5, that hold data output from the Processor, and a 20-bit Switch Register that holds data input from The Hexadecimal Keyboard. Refer to Figure 11-2.


Figure 11-2. Display Registers and Indicators

Associated with each of Display Registers D1 through D4 are eight indicator lamps that provide a binary read-out and two optional hexadecimal read-out indicators. Associated with the least significant four bits of Display Register D5 are four indicator lamps for binary display and one optional hexadecimal read-out indicator.

The most significant four bits of Display Register D5 (Bits $0: 3$ ) control four of the five indicator lamps along the left edge of the Hexadecimal Display Panel. The fifth indicator lamp is controlled by logic internal to the Hexadecimal Display Panel. To the right of each of these five lamps is a. diagram that defines what is being displayed. In general, only one of the diagram lamps is on at a time. If none of the diagram lamps are on, a user program has written data to the Display Register D5.

As seen in Figure 11-2, the most significant 20-bits of the display show the contents of Display Registers D3 and D4 and the least significant four bits of Display Register D5 (Bits 4:7); or the contents of the 20-bit Switch Register. When the Switch Register is being displayed, the lamp next to the Switch Register diagram is turned ON. Any other diagram lamp that may have been ON, remains ON. When the Switch Register is no longer displayed, its diagram lamp goes out and the most significant 20-bits of the display again show the contents of Display Registers D3 and D4 and the least significant four bits of Display Register D5 (Bits 4:7).

The methods of displaying the Switch Register and the other diagrammed items are discussed later.

## Key Operated Security Lock

This is a three-position, OFF-ON-LOCK, key-operated locking switch, which controls the primary power to the system. This switch can also disable the Hexadecimal Display Panel, thereby preventing any accidental manual input to the system. The power indicator lamp (PWR) associated with the key lock is located in the lower right corner of the Hexadecimal Display Panel. The PWR lamp is ON when the key lock is in the ON or LOCK position. The relationship between the key lock switch positions, primary power, the Control keys, and the Ilexadecimal keys is:

| OFF | The primary power is OFF. |
| :--- | :--- |
| ON | The primary power is ON and the Control keys and Hexadecimal keys are <br> enabled. |
| LOCK | The primary power is ON and the Control keys and Hexadecimal keys are <br> disabled. |

## Control Keys

The momentary contact Control keys are only active when the key-operated locking switch is in the ON position.

INITIALIZE (INI)

DATA (DTA)

ADDRESS (ADD)

MEMORY READ (RD)

The Initialize (INI) key causes the system to be initialized. After the initialize operation, all device controllers on the system Multiplexor Bus are cleared and certain other functions in the Processor are reset.

The Data (DTA) key clears the Switch Register and connects it to the most significant 20 display indicators. The Switch Register diagram lamp is turned ON. Hexadecimal data may now be entered into the Switch Register from the Hexadecimal Keyboard. As each Hexadecimal key is depressed, the data shifts into the Switch Register from the right. If more than five hexadecimal digits are entered, data shifted out of the Switch Register is lost.

Depressing any non-hexadecimal key disconnects the Switch Register from the high order 20 display lamps and extinguishes the Switch Register diagram lamp.

The Address (ADD) key causes the Processor to halt and copy the contents of the Switch Register into the Location Counter field of the Program Status Word. The new value of the Location Counter is then output to Display Registers D1, D2, D3, and D4. The function diagram lamp is turned ON and a Hexadecimal 5 is output to the top four display lamps (Bits 4:7 of D5).

The Memory Read (RD) key causes the Processor to halt and read the halfword contents of the memory location presently pointed to by the Location Counter. (If the Memory Access Controller is enabled by the current PSW then the relocated value of the Location Counter is the effective address of the memory location.) The halfword data read is output to Display Registers D1 and D2. The Location Counter is incremented by two and output to Display Registers D3 and D4 and the least significant four bits of Display Registers D5 (a 20-bit value). The lamp next to the Memory Address/Memory Data diagram is turnedON.

EXAMINE REGISTER (REG)

EXAMINE FLOATINGPOINT REGISTER (FLT)

FUNCTION (FN)

SINGLE STEP (SGL)

RUN (RUN)

The Memory Write (WRT) key causes the Processor to halt and read in the least significant 16 bits of the 20 bit Switch Register. The halfword of data is written into the memory location presently pointed to by the Location Counter. (If the Memory Access Controller is enabled by the current PSW then the relocated value of the Location Counter is the effective address of the memory location.) The data written is then output to Display Registers D1 and D2. The Location Counter is incremented by two and output to Display Registers D3 and D4 and the least significant four bits of Display Registers D5. The lamp next to the MemoryAddress/ Memory Data diagram is turned ON.

The Examine Register (REG) key sets up the Hexadecimal Display Panel to interpret the next Hexadecimal key depressed as a General Register number. When the hexadecimal register number key is depressed, the Processor halts and the content of the selected General Register of the set specified by the current PSW is output to Display Registers D1, D2, D3 and D4. The General Register diagram lamp is turned ON and the number of the displayed register is output to the top four display lamps.

The Examine Floating-Point Register (FLT) key sets up the Hexadecimal Display Panel to interpret the next hexadecimal key depressed as the number of a Floating-Point Register. When the hexadecimal register number key is depressed, the Processor halts and the content of the selected Floating-Point Register is output to Display Registers D1, D2, D3, and D4. The Floating-Point Register diagram lamp is turned ON and the number of the displayed register is output to the top four display lamps. If an odd numbered register had been selected and the processor is not equipped with double precision option, the register number is forced to the next lower even value before being used. On Processors not equipped with floating-point, the result of this operation is undefined.

The Function (FN) key sets up the Hexadecimal Display Panel to interpret the next hexadecimal key depressed as the number of one of sixteen functions. When the hexadecimal key is depressed, the Processor halts to interpret the selected function. If the function is undefined, the Processor remains halted with no change to the display indicators. The defined functions are detailed later.

The Single Step (SGL) key causes the Processor to execute one user level instruction at current location counter, increment the LOC and then halt. The register that was selected (PSW, LOC, General Register, etc.) is displayed.

The Run (RUN) key causes the Processor to beg in program execution at the address pointed to by the Location Counter (LOC).

## Power Up

To power up the system, turn the key-operated security lock clockwise from the OFF position to the ON position. This action provides electrical power to the system and leaves all device controllers on the Multiplexor Bus in an initialized state.

## Power Down

To shut down power to the system:

1. Halt the Processor.
2. Turn the key-operated security lock to the OFF position.

This removes primary power from the system and forces a Primary Power Fail (PPF) interrupt to the Processor. When power is re-applied, the Processor displays the contents of the Location Counter (LOC) and then assumes the Halt mode. If the Processor had been running when power was turned OFF, the Run mode is assumed when power is re-applied.

## Address a Memory Location

To select an address:

1. Depress the Data (DTA) key. The Switch Register is cleared and displayed.
2. Enter the desired address from the Hexadecimal Keyboard.
3. Depress the Address (ADD) key. The Processor halts and copies the contents of the Switch Register into the Location Counter field of the PSW. The new value of the Location Counter is then displayed.

## Memory Read

To display the contents of memory locations:

1. Select the memory read start address as in Address a Memory Location.
2. Depress the Read (RD) key. The address read from, plus two, and the data read from memory are displayed.
3. Repeat from Step 2 to read successive memory locations. The Location Counter is automatically incremented by two each time RD is depressed.

## Memory Write

To write data from the Switch Register into memory:

1. Select the memory write start address as in Address a Memory Location.
2. Depress the Data (DTA) key. The Switch Register is cleared and displayed.
3. Enter the data to be written from the Hexadecimal Keyboard.
4. Depress the Write (WRT) key. The address written into, plus two, and the data written are displayed.
5. Repeat from Step 2 to write different data into successive locations or from Step 4 to write the same data into successive locations. The Location Counter is automatically incremented by two each time WRT is depressed.

## General Register Display

To examine the contents of a General Register:

1. Depress the Register (REG) key.
2. Depress the hexadecimal register number. The Processor halts and the contents of the selected General Register is displayed.

NOTE

> The General Register displayed is from the register set specified by the current Program Status Word.

## Floating-Point Register Display

To examine the contents of a Floating-Point Register:

1. Depress the Floating-Point Register (FLT) key.
2. Depress the hexadecimal register number. If the Processor is not equipped with floating-point the result of this operation is undefined. If the Processor is equipped with floating-point, the selected register number is forced even and the Floating-Point Register is displayed. The Processor is left in the Halt mode.

## Floating-Point Register Display (later versions of 8/32)

After initialize or after a Function 2 all manual references to floating register are single precision. After a Function 3 all references to floating registers are double precision, if the Double Floating Point Unit (DFU) is equipped.

Using even/odd concept
The even numbered register of an even/odd pair rcfers to the most significant 32 bits and the odd numbered register refers to the least significant 32 bits.

References to an odd numbered floating point register when in the single precision mode (FN 2) produce different results depending on whether or not the DFU is equipped. If DFU is absent, then the number is forced to the next lower even number and that single precision register is displayed. If DFU is present, then the LS 32 bits of the corresponding double register are displayed.

## Program Status Word Display and Modification

To examine the Status field (most significant half) of the current PSW:

1. Depress the Function (FN) key.
2. Depress Hexadecimal key 4. The Processor halts and the status field (most significant half) of PSW is displayed.

To examine the Location Counter field (least significant half) of the current PSW:

1. Depress the Function (FN) key.
2. Depress Hexadecimal key 5. The Processor halts and the Location Counter field (least significant half) of PSW is displayed.

To modify the least significant 16 bits (Bits 16-31) of the Status field:

1. Depress the Data (DATA) key.
2. Enter the data (to be written into bits 16-31 of the PSW) from the Hexadecimal keyboard.
3. Depress the Function (FN) key.
4. Depress Hexadecimal key 1. The Processor halts and copies the 16 bits of the Switch register in bits 16-31 of the PSW. The modified PSW is then displayed.

## Program Execution

To begin execution of a program:

1. Select the program start address as in Address a Memory Location.
2. Select the register to be displayed.
3. Depress the Run (RUN) key.

To execute a program in the Single-Step mode:

1. Select the program start address as in Address a Memory Location.
2. Select the register to be displayed.
3. Depress the Single-Step (SGL) key. One instruction is executed, the last selected register (PSW, LOC, General Register, etc.) is displayed and the Processor halts.
4. Repeat Step 3 to execute successive instructions. Return to Step 2 to display different registers.

## Program Termination

To manually halt the execution of a program, display any register or depress the Single-Step (SGL) key. In the latter case, the last selected register is displayed.

## Console Interrupt

To generate an interrupt from the Hexadecimal Display Panel:

1. Depress the Function (FN) key.
2. Depress Hexadecimal key 0. If enabled by the current PSW, an interrupt from device number 1 is simulated. If not enabled, the Processor enters the Run mode. Hexadecimal Display Panel interrupts are not queued.

The Hexadecimal Display Panel interrupt feature allows an operator to inform the running program that some operator service or function is needed. No acknowledgement of the interrupt is required of the running program.

## Switch Register

To examine the Switch Register at any time during execution of a program, depress any hexadecimal key. The Switch Register is displayed for as long as the key is depressed. No information enters the Switch Register. When the hexadecimal key is released, the top 20 display lamps return to their previous state.

The Switch Register can be modified without interrupting the Processor as follows:

1. Depress the Data (DTA) key. The Switch Register is cleared and displayed.
2. Enter the desired hexadecimal data.

## Power Fail

When the Processor detects a power failure, the micro-program senses the Hexadecimal Display Panel status. The present status of the display is stored in main memory at a dedicated area by the micro-program. The current Program Status Word, Location Counter and the programmable registers are then saved in dedicated main memory locations and the micro-program deactivates the System Clear (SCLR) relay.

On power up, after the system clear relay has re-activated, the Program Status Word, Location Counter, and programmable registers are restored from their main memory save locations. The status of the display prior to the power failure is retrieved and interrogated by the micro-program.

If the Hexadecimal Display Panel was in the Run mode, and the Initialize Key is not depressed, and if the Machine Malfunction Interrupt Enable bit of the PSW is set, a Machine Malfunction Interrupt is taken. If Machine Malfunction Interrupts are not enabled, the Processor enters the Run mode beginning at the instruction pointed to by the Location Counter.

If the Hexadecimal Display Panel was not in the Run mode, or if the Initialize Key is still depressed, the value of the Location Counter is output to the display registers, the WAIT lamp on the console is turned ON and the Halt mode is entercd.

Power failure and operation of the Initialize key are indistinguishable to the Micro-Program except as described above. Consequently, operation of the Initialize key should be considered carefully when the Machine Malfunction Interrupt is enabled. The Initialize Key causes all the activities associated with a power failure to occur. The System Clear relay deactivates, then, after some delay, it is re-activated. If, after these electro-mechanical delays, the Initialize Key is still being depressed, the Halt mode is entered. The total delay works out to be about a half a second.

Care should also be taken when using the Hexadecimal Display Panel as an input device (testing Switch Register bits) due to the volatility of the Switch Register in a power fail situation.

After a power up, the contents of the Switch Register are undefined. The display status byte is forced to $\mathrm{X}^{\prime} 40^{\prime}$ on power up or initialize.

## DATA FORMAT

A byte or a halfword can be transferred to or from the Display using a WD, WH, WDR, WHR, or RD, RII, RDR, RHR instruction. Refer to Figure 11-3.


Figure 11-3. Hexadecimal Display Panel Data Transfers

## PROGRAMMING INSTRUCTIONS

## Input/Output Programming

The Hexadecimal Display Panel is available to any running program as an I/O device with device address 01 . The status and command bytes for the Hexadecimal Display Panel are summarized in Table 11-1. The status byte indicates the mode of the Hexadecimal Display Panel and is of little interest to a running program as it always indicates Run mode or Hexadecimal Display Panel Interrupt (Function 0 ). The command byte selects Normal or Incremental mode, which pertains to data Transfers. The selection logic which determines the Switch Register byte or register display byte to transfer is reset every time the Hexadecimal Display Panel is addressed when in the Normal mode. When an Output Command Incremental mode is issued to the Hexadecimal Display Panel, the byte selection logic is initially reset. Subsequent Read or Write instructions transfer bytes as shown in Figure 11-3.

Block I/O with the Hexadecimal Display Panel is only feasible when the least significant four status bits are reset.

## NOTE

After an initialize sequence or after any manual Hexadecimal Display Panel operation that results in anything being displayed, the Display Device Controller is automatically placed in the Normal mode.

When programming the Hexadecimal Display Panel in the Incremental mode, the Output Command Incremental mode must be issued before each set of data transfers to guarantee that the byte selection logic is reset.

The most significant four bits of the Switch Register are only available to the micro-program. These four bits are transferred as Bits 5, 6, 7, and 0 of the status when the Hexadecimal Display Panel status is Address (i.e., Display Status = X011XXXX').

## Wait State

The running program can place the Processor into the Wait state by setting the Wait bit of the current PSW. The WAIT indicator on the lower right of the panel is turned ON to inform the operator of the Wait state. The Processor can leave the Wait state and resume execution in two ways:

1. An Interrupt can occur causing the Processor to jump to an interrupt service routine. When the routine restores the original PSW, the Wait state is re-established.
2. The operator can depress the RUN key which causes the Wait bit in the PSW and the WAIT lamp to be reset and execution to resume at the address specified by LOC.

## PROGRAMMING SEQUENCES

The Hexadecimal Display has a device address of $\mathrm{X}^{\prime} 01^{\prime}$.

This device can be used to output up to five bytes of data to the Console Panel Indicators. The following program sequence outputs four bytes of data starting from the memory location BUF:

| LIS | R1, 1 | (R1) = Display Address |
| :--- | :--- | :--- |
| LHI | R3, X'40' |  |
| OCR | R1, R3 | Display in Incremental Mode |
| WD | R1, BUF |  |
| WD | R1, BUF+1 |  |
| WD | R1, BUF+2 |  |
| WD | R1, BUF +3 |  |

At this time the Console Panel Indicators are ON as shown below:

| D5 | D 4 | D 3 | D 2 | D 1 |
| :---: | :---: | :---: | :---: | :---: |
|  | $(\mathrm{BUF}+3)$ | $(\mathrm{BUF}+2)$ | $(\mathrm{BUF}+1)$ | $(\mathrm{BUF})$ |

In order to light indicators D1 and D2, the Console can be in the normal mode and one halfword can be output. The following programming sequence can be used:

| LIS | R1,1 |  |
| :--- | :--- | :--- |
| LHI | R3, X'80' |  |
| OCR | R1,R3 |  |
| WH | R1, BUF |  |

The Console Panel Indicators will be ON as shown below:

| D5 | D4 | D3 | D2 | D1 |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | $(\mathrm{BUF}+1)$ | $(\mathrm{BUF})$ |

Note that when a halfword of data is output to the Console Panel, the most significant byte loads in indicator D1 and the least significant byte loads in D2

The Console Panel Switch Register can be read by using the read instructions as shown below:

| LIS | R1, 1 | (R1) $=$ Console Address |
| :--- | :--- | :--- |
| LHI | R3, ${ }^{\prime} 80^{\prime}$ | (R3) $=80=$ Normal Mode |
| OCR | R1, R3 |  |
| RHR | R1,R4 | Read 1 Halfword |
| EXBR | R4, R4 | Exchange Bytes |

At this time Register 4 has the 16 data switches.

## Programming Note:

If more than five bytes are output to the Display Panel, the data is lost after five bytes. The Console must then be initialized by giving an Output Command to it before outputting any data, if the data is to be displayed.

## TABLE 11-1 DISPLAY STATUS AND COMMAND

|  | STATUS |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |  |
| Run | X | 0 | 0 | 0 | X | X | X | X |  |
| Memory write | X | 0 | 0 | 1 | X | X | X | X |  |
| Memory read | X | 0 | 1 | 0 | X | X | X | X |  |
| Address | X | 0 | 1 | 1 | X | X | X | X | \} Single or Halt |
| Fixed Register | X | 1 | 0 | 0 | X | X | X | X | Single or Halt |
| Floating Register | X | 1 | 0 | 1 | X | X | X | X |  |
| Function | X | 1 | 0 | 0 | X | X | X | X | $J$ |



| Function 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | Console Interrupt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | PSW Select |
| 2 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | Set Single precision display mode |
| 3 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | Set Double precision display mode |
| 4 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | Display PSW |
| 5 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | Display LOC |
| 6 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 |  |
| 7 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 |  |
| 8 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 |  |
| 9 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 |  |
| A | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 |  |
| B | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 |  |
| C | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 |  |
| D | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 |  |
| E | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 |  |
| Function F | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 |  |
|  |  |  |  | OM | AN |  |  |  |  |
| Normal | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |
| Incremental | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |  |


|  | $\begin{array}{r} \text { MSD } \\ 0 \end{array}$ | $\longrightarrow$ | 2 | 3 | 4 | 5 | 6 | 7 | 9 | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { LSD } \\ 1 \end{gathered}$ |  | SRLS | BTBS | $\left\lvert\, \begin{array}{r} 5 \\ \text { MPBSR } \end{array}\right.$ | STH | ST ${ }^{4}$ | $\mathrm{STE}_{4}^{2}$ | $\mathrm{STD}_{4}^{3}$ | SRHLS | BXH | $\mathrm{STM}_{4}$ | TS |  |
|  | BALR | SLLS | BTFS |  | BAL | $\text { AM }{ }^{4}$ | AHM | STME $^{2}$ | SLHLS | BXLE | ${ }^{\text {LM }} 4$ | SVC $_{4}$ |  |
| 2 | BTCR | CHVR | BFBS | PBR ${ }^{5}$ | BTC |  | PB 5 | LME ${ }_{4}$ | STBR | * LPSW | STB | *SINT |  |
| 3 | BFCR |  | BFFS |  | BFC |  | $\mathrm{LRA}_{4}$ | LHL | LBR | THI | LB | ${ }^{*} \mathrm{SCP} 4$ | TI |
| 4 | NR |  | LIS | EXHR | NH | N ${ }^{4}$ | $\mathrm{ATL}_{4}$ | TBT | EXBR | NHI | CLB |  | NI |
| 5 | CLR |  | LCS |  | CLH | $\mathrm{CL}{ }^{4}$ | $\mathrm{ABL}_{4}$ | SBT | *EPSR | CLHI | *AL | *BDCS ${ }^{1}$ | CLI |
| 6 | OR |  | AIS |  | OH | 0 | $\mathrm{RTL}_{4}$ | RBT | *WBR | OHI | ${ }^{*}$ WB $_{4}$ | LA | Ol |
| 7 | XR |  | SIS |  | XH |  | $\mathrm{RBL}_{4}$ | CBT | *RBR | XHI | ${ }^{*} \mathrm{RB}_{4}$ | TLATE | XI |
| 8 | LR | *LPSWR | LER ${ }^{2}$ | LDR ${ }^{3}$ | LH | L 4 | LE $\begin{aligned} & 2 \\ & 4\end{aligned}$ | LD ${ }^{3}$ | *WHR | LHI | *WH | * ${ }^{*}$ R/WDCS ${ }^{1}$ | LI |
| 9 | CR |  | CER ${ }^{2}$ | CDR ${ }^{3}$ | CH | C ${ }^{4}$ | CE $\begin{aligned} & 2 \\ & 4\end{aligned}$ | CD $\begin{array}{r}3 \\ 4\end{array}$ | *RHR | CHI | *RH | ECS ${ }^{1}$ | Cl |
| A | AR |  | $A E R^{2}$ | $A D R^{3}$ | AH | A 4 | $\mathrm{AE}_{4}^{2}$ | AD $\begin{aligned} & 3 \\ & 4\end{aligned}$ | *WDR | AHI | *WD | RRL | Al |
| B | SR |  | SER ${ }^{2}$ | SDR ${ }^{3}$ | SH | S 4 | SE ${ }^{2}$ | SD $\begin{aligned} & 3 \\ & 4\end{aligned}$ | *RDR | SHI | *RD | RLL | SI |
| C | MHR | MR | MER ${ }^{2}$ | $M D R^{3}$ | MH | M 4 | ME ${ }_{4}^{2}$ | MD ${ }_{4}^{3}$ |  | SRHL |  | SRL |  |
| D | DHR | DR | DER ${ }^{2}$ | DDR ${ }^{3}$ | DH | D 4 | DE ${ }^{2}$ | DD ${ }_{4}^{3}$ | *SSR | SLHL | *SS | SLL |  |
| E |  |  | FXR ${ }^{2}$ | FXDR ${ }^{3}$ |  | CRC12 |  | STMD ${ }_{4}^{3}$ | *OCR | SRHA | *OC | SRA |  |
| F |  |  | $F L R{ }^{2}$ | FLDR ${ }^{3}$ |  | CRC16 |  | LMD ${ }^{3}$ |  | SLHA |  | SLA |  |

## NOTES

1. Writable Control Store (Optional) Instructions. Not supported on Model 7/32. RDCS $=$ E82, WDCS $=$ E80.
2. Single Precision Floating Point (Optional) Instructions.
3. Double Precision Floating Point (Optional) Instructions.
4. Second operand must be aligned on a fullword boundary.
5. Communication (Optional) Instructions. (Model 8/32C, 8/32D)

* Privileged Instructions


## APPENDIX 1 (Continued)

This manual describes all of the features (standard and optional) or all of the versions of Model $8 / 32$.
The following table shows the standard and optional features of the current versions of Model 8/32. Note that the optional features may be included with the initial system or may be added later. Certain optional features are required for certain software products. The corresponding software manuals list all such requirements

For further information, refer to INTERDATA Price List, Publication Number 38-094.

| Model | Standard Features | Optional Features |
| :---: | :---: | :---: |
| 8/32C | 83-025750 ns 32 KB <br> Core MemoryStandard 148 Instructions | M83-102 Hexidecimal Display Panel <br> M83-103 <br> High Speed Data Handling Option  <br> M83-107 Processor/Memory Parity Generation <br> and Checking Hardware <br> M83-108 Writable Control Store <br> Extended Regester Sets for 8/32 Processor <br> M83-110 High Performance Floating Point Option. <br> M83-111 Extended Memory Selector Channel <br> M73-105 <br> M49-035 System Chassis previewed for up to 8 <br> 381 mm (15") or 16 178 mm (7"') <br> controllers with power <br> Up to 1 MB of 750 ns core memory  |
| 8/32D | $83-030$ 750 ns 64 KB <br> Core Memory <br> Standard 148 Instructions | M83-102 Hexidecimal Display Panel <br> M83-103 High Speed Data Handling Option <br> M83-107 Processor/Memory Parity Generation and <br>  <br> Checking Hardware <br> M83-108 Writable Control Store <br> M83-110 <br> Extended Register Sets for 8/32 Processor  <br> M83-111 High Performance Floating Point Option <br> M73-105 <br> M49-035 <br>  Systeded Memory Selector Channel <br> 381 mm (15sis previewed for up to 8 <br> controllers with power 16 <br>  ci") mm (7") <br> Up to 1 MB or 750 ns core memory |

APPENDIX 2<br>INSTRUCTION SUMMARY - ALPHABETICAL WITH ATTRIBUTES

Attributes
A:
arithmetic fault interrupt can occur
C:
CM:
Condition Code in the PSW is set to reflect the result
D:
Fecond operand must be on double work boundary for consistent result
F:
Hecond operand must be on fullword boundary for consistent result
H: second operand must be on halfword boundary for consistent result
I: illegal instruction interrupt can be initiated
IA: immediate interrupt or Auto-Driver Channel can be initiated
P: protect mode violation can occur
RP: relocation/protection interrupt can occur

| INSTRUCTION | OP-CODE | MNEMONIC | ATTRIBUTES | PAGE NO. |
| :---: | :---: | :---: | :---: | :---: |
| Add | 5 A | A | C, F | 4-4 |
| Add Double Precision Floating Point | 7 A | AD | C, D, A, I | 5-29 |
| Add Floating Point | 6 A | AE | C, F, A, I | 5-14 |
| Add Floating Point Register | 2 A | AER | C, A, I | 5-14 |
| Add Halfword | 4A | AH | C, H | 4-5 |
| Add Halfword immediate | CA | AHI | C | 4-5 |
| Add Halfword to Memory | 61 | A HM | C, RP, H | 4-7 |
| Add Immediate | FA | AI | C | 4-4 |
| Add Immediate Short | 26 | AIS | C | 4-4 |
| Add Register | 0A | AR | C | 4-4 |
| Add Register Double Precision Floating Point | 3A | ADR | C, A, I | 5-29 |
| Add to Bottom of List | 65 | ABL | C, F, RP | 2-45 |
| Add to Memory | 51 | AM | C, F, RP | 4-6 |
| Add to Top of List | 64 | ATL | C, F, RP | 2-45 |
| AND | 54 | N | C, F | 2-21 |
| AND Halfword | 44 | NH | C, H | 2-22 |
| AND Halfword Immediate | C4 | NHI | C | 2-22 |
| AND Immediate | F4 | NI | C | 2-21 |
| AND Register | 04 | NR | C | 2-21 |
| Autoload | D5 | AL | C, P | 7-14 |
| Branch and Link | 41 | BAL | H | 3-5 |
| Branch and Link Register | 01 | BALR |  | 3-5 |
| Branch to Control Store | E5 | BDCS | CM, P, I | 9-6 |
| Branch on False Condition | 43 | BFC | H | 3-4 |
| Branch on False Condition Backward Short | 22 | BFBS |  | 3-4 |
| Branch on Flase Condition Forward Short | 23 | BFFS |  | 3-4 |
| Branch on False Condition Register | 03 | BFCR |  | 3-4 |
| Branch on Index High | C0 | BXH | H | 3-7/3-8 |
| Branch on Index Low or Equal | C1 | BXLE | H | 3-6 |
| Branch on True Condition | 42 | BTC | H | 3-3 |
| Branch on True Condition Backward Short | 20 | BTBS |  | 3-3 |
| Branch on True Condition Forward Short | 21 | BTFS |  | 3-3 |
| Branch on True Condition Register | 02 | BTCR |  | 3-3 |

## APPENDIX 2 (Continued)

| INSTRUCTION | OP-CODE | MNEMONIC | ATTRIBUTES | PAGE NO. |
| :---: | :---: | :---: | :---: | :---: |
| Compare | 59 | C | C, F | 4-10 |
| Compare Double Precision Floating Point | 79 | CD | C, D, I | 5-31 |
| Compare Floating Point | 69 | CE | C, F, I | 5-18 |
| Compare Floating Point Register | 29 | CER | C, I | 5-18 |
| Compare Halfword | 49 | CH | C, H | 4-11 |
| Compare Halfword Immediate | C9 | CHI | C | 4-11 |
| Compare Immediate | F9 | CI | C | 4-10 |
| Compare Logical | 55 | CL | C, F | 2-18 |
| Compare Logical Byte | D4 | CLB | C | 2-20 |
| Compare Logical Halfword | 45 | CLH | C, H | 2-19 |
| Compare Logical Halfword Immediate | C5 | CLHI | C | 2-19 |
| Compare Logical Immediate | F5 | CLI | C | 2-18 |
| Compare Logical Register | 05 | CLR | C | 2-18 |
| Compare Register | 09 | CR | C | 4-10 |
| Compare Register Double Precision Floating Point | 39 | CDR | C, I | 5-31 |
| Convert Halfword Value Register | 12 | CHVR | C | 4-22 |
| Complement Bit | 77 | CBT | C, RP | 2-38 |
| Cyclic Redundancy Check Modulo 12 | 5 E | CRC12 | H, RP | 2-40 |
| Cyclic Redundancy Check Modulo 16 | 5 F | CRC16 | $\mathrm{H}, \mathrm{RP}$ | 2-40 |
| Divide | 5D | D | F, A | 4-14 |
| Divide Double Precision Floating Point | 7 D | DD | C, D, A, I | 5-33 |
| Divide Floating Point | 6 D | DE | C, F, A, I | 5-21 |
| Divide Floating Point Register | 2D | DER | C, A, I | 5-21 |
| Divide Halfword | 4D | DH | H, A | 4-16 |
| Divide Halfword Register | 0D | DHR | A | 4-16 |
| Divide Register | 1D | DR | A | 4-14 |
| Divide Register Double Precision Floating Point | 3D | DDR | C, A, I | 5-33 |
| Enter Control Store | E9 | ECS | C, I | 9-7/9-8 |
| Exchange Byte Register | 94 | EXBR |  | 2-13 |
| Exchange Halfword Register | 34 | EXHR |  | 2-12 |
| Exchange Program Status Register | 95 | EPSR | C, P, IA | 6-14 |
| Exclusive OR | 57 | X | C, F | 2-25 |
| Exclusive OR Halfword | 47 | XH | C, H | 2-26 |
| Exclusive OR Halfword Immediate | C7 | XHI | C | 2-26 |
| Exclusive OR Immediate | F7 | XI | C | 2-25 |
| Exclusive OR Register | 07 | XR | C | 2-25 |
| Fix Register | 2 E | FXR | C, I | 5-23 |
| Fix Register Double Precision Floating Point | 3 E | FXDR | C, I | 5-34 |
| Float Register | 2 F | FLR | C, I | 5-24 |
| Float Register Double Precision | 3 F | FLDR | C, I | 5-35/5-36 |
| Load | 58 | L | C, F | 2-5 |
| Load Address | E6 | LA |  | 2-7 |
| Load Byte | D3 | LB |  | 2-11 |
| Load Byte Register | 93 | LBR |  | 2-11 |
| Load Complement Short | 25 | LCS | C | 2-5 |
| Load Double Precision Floating Point | 78 | LD | C, D, A, I | 5-25 |
| Load Floating Point | 68 | LE | C, F, A, I | 5-10 |
| Load Floating Point Multiple | 72 | LME | F, I | 5-11 |
| Load Floating Point Register | 28 | LER | C, A, I | 5-10 |
| Load Halfword | 48 | LH | C | 2-6 |

## APPENDIX 2 (Continued)

| INSTRUCTION | OP-CODE | MNEMONIC | ATTRIBUTES | PAGE NO. |
| :---: | :---: | :---: | :---: | :---: |
| Load Halfword Immediate | C8 | LHI | C | 2-6 |
| Load Halfword Logical | 73 | LHL | C | 2-9 |
| Load Immediate | F8 | LI | C | 2-5 |
| Load Immediate Short | 24 | LIS | C | 2-5 |
| Load Multiple | D1 | LM | F | 2-10 |
| Load Multiple Double Precision Floating Point | 7 F | LMD | D, I | 5-26 |
| Load Program Status Word | C2 | LPSW | C, D, P, IA | 6-12 |
| Load Program Status Word Register | 18 | LPSWR | C, P, IA | 6-13 |
| Load Real Address | 63 | LRA | C, F, I | 2-8 |
| Load Register | 08 | LR | C | 2-5 |
| Load Register Double Precision Floating Point | 38 | LDR | C, A, I | 5-25 |
| Move and Process Byte String Register | 30 | M PBSR | C, I | 10-5 |
| Multiply | 5 C | M | F | 4-12 |
| Multiply Double Precision Floating Point | 7 C | MD | C, D, A, I | 5-32 |
| Multiply Floating Point | 6 C | ME | C, F, A, I | 5-19 |
| Multiply Floating Point Register | 2 C | MER | C, A, I | 5-19 |
| Multiply Halfword | 4 C | MH | H | 4-13 |
| Multiply Halfword Register | 0 C | MHR |  | 4-13 |
| Multiply Register | 1 C | MR |  | 4-12 |
| Multiply Register Double Precision Floating Point | 3 C | MDR | C, A, I | 5-32 |
| OR | 56 | O | C, F | 2-23 |
| OR Halfword | 46 | OH | C, H | 2-24 |
| OR Halfword Immediate | C6 | OHI | C | 2-24 |
| OR Immediate | F6 | OI | C | 2-23 |
| OR Register | 06 | OR | C | 2-23 |
| Output Command | DE | OC | C, P, IA | 7-4 |
| Output Command Register | 9 E | OCR | C, P, IA | 7-4 |
| Process Byte | 62 | PB | H, I | 10-2 |
| Process Byte Register | 32 | PBR | I | 10-4 |
| Read Block | D7 | RB | C, F, P | 7-8 |
| Read Block Register | 97 | RBR | C, P | 7-9 |
| Read Control Store | E82 | RDCS | F, P, I | 9-5 |
| Read Data | DB | RD | C, P | 7-6 |
| Read Data Register | 9B | RDR | C, P | 7-6 |
| Read Halfword | D9 | RH | C, H, P | 7-7 |
| Read Halfword Register | 99 | RHR | C, P | 7-7 |
| Reset Bit | 76 | RBT | C, RP | 2-39 |
| Remove from Bottom of List | 67 | RBL | C, F, RP | 2-46 |
| Remove from Top of List | 66 | RTL | C, F, RP | 2-46 |
| Rotate Left Logical | EB | RLL | C | 2-33 |
| Rotate Right Logical | EA | RRL | C | 2-34 |
| Sense Status | DD | SS | C, P | 7-5 |
| Sense Status Register | 9D | SSR | C, P | 7-5 |
| Set Bit | 75 | SBT | C, RP | 2-37 |
| Shift Left Arithmetic | EF | SLA | C | 4-18 |
| Shift Left Halfword Arithmetic | CF | SLHA | C | 4-19 |

## APPENDIX 2 (Continued)

| INSTRUCTION | OP-CODE | MNEMONIC | ATTRIBUTES | PAGE NO. |
| :---: | :---: | :---: | :---: | :---: |
| Shift Left Halfword Logical | CD | SLHL | C | 2-31 |
| Shift Left Halfword Logical Short | 91 | SLHLS | C | 2-31 |
| Shift Left Logical | ED | SLL | C | 2-29 |
| Shift Left Logical Short | 11 | SLLS | C | 2-29 |
| Shift Right Arithmetic | EE | SRA | C | 4-20 |
| Shift Right Halfword Arithmetic | CE | SRHA | C | 4-21 |
| Shift Right Halfword Logical | CC | SRHL | C | 2-32 |
| Shift Right Halfword Logical Short | 90 | SRHLS | C | 2-32 |
| Shift Right Logical | EC | SRL | C | 2-30 |
| Shift Right Logical Short | 10 | SRLS | C | 2-30 |
| Simulate Channel Program | E3 | SCP | C, F, P | 7-15 |
| Simulate Interrupt | E2 | SINT | C, P, IA | 6-15 |
| Store | 50 | ST | F, RP | 2-14 |
| Store Byte | D2 | STB | RP | 2-16 |
| Store Byte Register | 92 | STBR |  | 2-16 |
| Store Double Precision Floating Point | 70 | STD | D, RP, I | 5-27 |
| Store Floating Point | 60 | STE | F, RP, I | 5-12 |
| Store Floating Point Multiple | 71 | STME | F, RP, I | 5-13 |
| Store Halfword | 40 | STH | H, RP | 2-15 |
| Store Multiple | D0 | STM | F, RP | 2-16 |
| Store Multiple Double Precision Floating Point | 7 E | STMD | D, RP, I | 5-28 |
| Subtract | 5B | S | C, F | 4-8 |
| Subtract Double Precision Floating Point | 7B | SD | C, D, A, I | 5-30 |
| Subtract Floating Point | 6 B | SE | C, F, A, I | 5-16 |
| Subtract Floating Point Register | 2B | SER | C, A, I | 5-16 |
| Subtract Halfword | 4B | SH | C, H | 4-9 |
| Subtract Halfword Immediate | CB | SHI | C | 4-9 |
| Subtract Immediate | FB | SI | C | 4-8 |
| Subtract Immediate Short | 27 | SIS | C | 4-8 |
| Subtract Register | 0B | SR | C | 4-8 |
| Subtract Register Double Precision Floating Point | 3B | SDR | C, A, I | 5-30 |
| Supervisor Call | E1 | SVC | C, F | 6-16 |
| Test Bit | 74 | TBT | C | 2-36 |
| Test Halfword Immediate | C3 | THI | C | 2-28 |
| Test Immediate | F3 | TI | C | 2-27 |
| Test and Set | E0 | TS | C, RP | 2-35 |
| Translate | E7 | TLATE | F | 2-42 |
| Write Block | D6 | WB | C, F, P | 7-12 |
| Write Block Register | 96 | WBR | C, P | 7-13 |
| Write Control Store | E80 | WDCS | F, P, I | 9-4 |
| Write Data | DA | WD | C, P | 7-10 |
| Write Data Register | 9A | WDR | C, P | 7-10 |
| Write Halfword | D8 | WH | C, H, P | 7-11 |
| Write Halfword Register | 98 | WHR | C, P | 7-11 |


| OP-CODE | MNEMONIC | INSTRUCTION | PAGE NO. |
| :---: | :---: | :---: | :---: |
| 01* | BALR | Branch and Link Register | 3-5 |
| 02* | BTCR | Branch on True Condition Register | 3-3 |
| 03* | BFCR | Branch on False Condition Register | 3-4 |
| 04 | NR | AND Register | 2-21 |
| 05 | CLR | Compare Logical Register | 2-18 |
| 06 | OR | OR Register | 2-23 |
| 07 | XR | Exclusive OR Register | 2-25 |
| 08 | LR | Load Register | 2-5 |
| 09 | CR | Compare Register | 4-10 |
| OA | AR | Add Register | 4-4 |
| OB | SR | Subtract Register | 4-8 |
| OC* | MHR | Multiply Halfword Register | 4-13 |
| OD* | DHR | Divide Haffword Register | 4-16 |
| 10 | SRLS | Shift Right Logical Short | 2-30 |
| 11 | SLLS | Shift Left Logical Short | 2-29 |
| 12 | CHVR | Convert to Halfword Value Register | 4-22 |
| 18 | LPSWR | Load Program Status Word Register | 6-13 |
| 1C* | MR | Multiply Register | 4-12 |
| 1D* | DR | Divide Register | 4-14 |
| 20* | BTBS | Branch on True Condition Backward Short | 3-3 |
| 21* | BTFS | Branch on True Condition Forward Short | 3-3 |
| 22* | BFBS | Branch on False Condition Backward Short | 3-4 |
| 23* | BFFS | Branch on False Condition Forward Short | 3-4 |
| 24 | LIS | Load Immediate Short | 2-5 |
| 25 | LCS | Load Complement Short | 2-5 |
| 26 | AIS | Add Immediate Short | 4-4 |
| 27 | SIS | Subtract Immediate Short | 4-8 |
| 28 | LER | Load | 2-5 |
| 29 | CER | Compare Floating Point | 5-18 |
| 2A | AER | Add Floating Point Register | 5-14 |
| 2B | SER | Subtract Floating Point Register | 5-16 |
| 2 C | MER | Multiply Floating Point Register | 5-19 |
| 2D | DER | Divide Floating Point Register | 5-21 |
| 2E | FXR | Fix Register | 5-23 |
| 2F | FLR | Float Register | 5.24 |
| 30 | MPBSR | Move \& Process Byte String Register | 10-5 |
| 32* | PBR | Process Byte Register | 10-4 |


| OP-CODE | MNEMONIC | INSTRUCTION | PAGE NO. |
| :---: | :---: | :---: | :---: |
| 34* | EXHR | Exchange Halfword Register | 2-12 |
| 38 | LDR | Load Register Double Precision Floating Point | 5-25 |
| 39 | CDR | Compare Register Double Precision Floating Point | 4-22 |
| 3A | ADR | Add Register Double Precision Floating Point | 5-29 |
| 3B | SDR | Subtract Register Double Precision Floating Point | 5-30 |
| 3 C | MDR | Multiply Register Double Precision Floating Point | 5-32 |
| 3D | DDR | Divide Register Double Precision Floating Point | 5-33 |
| 3E | FXDR | Fix Register Double Precision Floating Point | 5-34 |
| 3F | FLDR | Float Register Double Precision Floating Point | 5-35/5-36 |
| 40* | STH | Store Halfword | 2-15 |
| 41* | BAL | Branch and Link | 3-5 |
| 42* | BTC | Branch on True Condition | 3-3 |
| 43* | BFC | Branch on False Condition | 3-4 |
| 44 | NH | AND Halfword | 2-22 |
| 45 | CLH | Compare Logical Halfword | 2-19 |
| 46 | OH | OR Halfword | 2-24 |
| 47 | XH | Exclusive OR Halfword | $2-26$ |
| 48 | LH | Load Halfword | 2-6 |
| 49 | CH | Compare Halfword | 4-11 |
| 4A | AH | Add Halfword | 4-5 |
| 4B | SH | Subtract Halfword | 4-9 |
| 4C* | MH | Multiply Halfword | $4-13$ |
| 4D* | DH | Divide Halfword | 4-16 |
| 50* | ST | Store | 2-14 |
| 51 | AM | Add to Memory | 4.6 |
| 54 | $N$ | AND | 2-21 |
| 55 | CL | Compare Logical | 2-18 |
| 56 | 0 | OR | 2-23 |
| 57 | X | Exclusive OR | 2-25 |
| 58 |  |  | 2-5 |
| 59 | C | Compare | 4-10 |
| 5A | A | Add | 4-4 |
| 5B | S | Subtract | $4-8$ |
| 5C* | M | Multiply | 4-12 |
| 5D* | D | Divide | 4-14 |
| 5E* | CRC12 |  | 2-40 |
| 5F* | CRC16 | Cyclic Redundancy Check Modulo 16 | $2-40$ |
| 60* | STE | Store Floating Point | 5-12 |
| 61 | AHM | Add Halfword to Memory | 4-7 |
| 62* | PB | Process Byte | 10-2 |
| 63 | LRA | Load Read Address | 2-8 |
| 64 | ATL | Add to Top of List | 2-45 |
| 65 | ABL | Add to Bottom of List | 2-45 |
| 66 | RTL | Remove from Top of List | 2-46 |
| 67 | RBL | Remove from Bottom of List | 2-46 |



APPENDIX 3 (Continued)

| OP-CODE | MNEMONIC | INSTRUCTION | PAGE NO. |
| :---: | :---: | :---: | :---: |
| C6 | OHI | OR Halfword Immediate | 2-24 |
| C7 | XHI | Exclusive OR Halfword Immediate | $2-26$ |
| C8 | LHI | Load Halfword Immediate | 2-6 |
| C9 | CHI | Compare Halfword Immediate | 4-11 |
| CA | AHI | Add Halfword Immediate | $4-5$ |
| CB | SHI | Subtract Halfword Immediate | 4.9 |
| CC | SRHL | Shift Right Halfword Logical | 2-32 |
| CD | SLHL | Shift Left Halfword Logical | 2-31 |
| CE | SRHA | Shift Right Halfword Arithmetic | 4-21 |
| CF | SLHA | Shift Left Halfword Arithmetic | 4-19 |
| D0* | STM | Store Multiple | 2-16 |
| D1* | LM | Load Multiple | $2 \cdot 10$ |
| D2* | STB | Store Byte | 2-17 |
| D3* | LB | Load Byte | 2-11 |
| D4 | CLB | Compare Logical Byte | 2-20 |
| D5 | AL | Autoload | 7-14 |
| D6 | WB | Write Block | $7-12$ |
| D7 | RB | Read Block | 7-8 |
| D8 | WH | Write Halfword | 7-11 |
| D9 | RH | Read Halfword | 7.7 |
| DA | WD | Write Data | 7-10 |
| DB | RD | Read Data | 7-6 |
| DD | SS | Sense Status | 7-5 |
| DE | OC | Output Command | 7-4 |
| E0 | TS | Test and Set | 2-35 |
| E1 | SVC | Supervisor Call | 6-16 |
| E2 | SINT | Simulate Interrupt | 6-15 |
| E3 | SCP | Simulate Channel Program | 7.15 |
| E5 | BDCS | Branch to Control Store | 9-6 |
| E6* | LA | Load Address | 2.7 |
| E7* | tlate | Translate | 2-42 |
| E80* | WDCS | Write Control Store | 9-4 |
| E82* | RDCS | Read Control Store | 9-5 |
| E9 | ECS | Enter Control Store | 9-7/9-8 |
| EA | RRL | Rotate Right Logical | 2-34 |
| EB | RLL | Rotate Left Logical | 2-33 |
| EC | SRL | Shift Right Logical | 2-30 |
| ED | SLL | Shift Left Logical | 2-29 |


| OP-CODE | MNEMONIC | INSTRUCTION | PAGE NO. |
| :--- | :--- | :--- | :--- |
|  |  |  |  |
| EE | SRA | Shift Right Arithmetic <br> Shift Left Arithmetic | $4-20$ |
|  | SLA |  | $4-18$ |
| F3 | TI | Test Immediate |  |
| F4 | NI | AND Immediate | $2-27$ |
| F5 | CLI | Compare Logical Immediate | $2-21$ |
| F6 | OI | OR Immediate | $2-18$ |
| F7 | XI | Exclusive OR Immediate | $2-23$ |
| F8 | LI | Load Immediate | $2-25$ |
| F9 | CI | Compare Immediate | $2-5$ |
| FA | AI | Add Immediate | $4-10$ |
| FB | SI | Subtract Immediate | $4-4$ |

## APPENDIX 4

EXTENDED BRANCH MNEMONICS

| INSTRUCTION | OP CODE (M1) | MNEMONIC | OPERAND |
| :---: | :---: | :---: | :---: |
| Branch on Carry | 428 | BC | A (X2) |
| Branch on Carry Register | 028 | BCR | R2 |
| Branch on No Carry | 438 | BNC | A(X2) |
| Branch on No Carry Register | 038 | BNCR | R2 |
| Branch on Equal | 433 | BE | A (X2) |
| Branch on Equal Register | 033 | BER | R2 |
| Branch on Not Equal | 423 | BNE | A(X2) |
| Branch on Not Equal Register | 023 | BNER | R2 |
| Branch on Low | 428 | BL | A(X2) |
| Branch on Low Register | 028 | BLR | R2 |
| Branch on Not Low | 438 | BNL | A(X2) |
| Branch on Not Low Register | 038 | BNLR | R2 |
| Branch on Minus | 421 | BM | A (X2) |
| Branch on Minus Register | 021 | BMR | R2 |
| Branch on Not Minus | 431 | BNM | A (X2) |
| Branch on Not Minus Register | 031 | BNMAR | R2 |
| Branch on Plus | 422 | BP | A (X2) |
| Branch on Plus Register | 022 | BPR | R2 |
| Branch on Not Plus | 432 | BNP | A(X2) |
| Branch on Not Plus Register | 032 | BNPR | R2 |
| Branch on Overflow | 424 | $\mathrm{B} \cap$ | A(X2) |
| Branch on Overflow Register | 024 | BOR | R2 |
| Branch on Not Overflow | 434 | BNO | A(X2) |
| Branch on Not Overflow Register | 034 | BNOR | R2 |
| Branch Unconditional | 430 | B | A(X2) |
| Branch Unconditional Register | 030 | BR | R2 |
| Branch on Zero | 433 | BZ | A ( X 2 ) |
| Branch on Zero Register | 033 | BZR | R2 |
| Branch on Not Zero | 423 | BNZ | A(X2) |
| Branch on Not Zero Register | 023 | BNZR | R2 |
| No Operation | 420 | NOP |  |
| No Operation Register | 020 | NOPR |  |
| Branch on Carry Short | 208 | BCS | A (Backward Reference) |
|  | 218 | BCS | A (Forward Reference) |
| Branch on No Carry Short | 228 | BNCS | A (Backward Reference) |
|  | 238 | BNCS | A (Forward Reference) |
| Branch on Equal Short | 223 | BES | A (Backward Reference) |
|  | 233 | BES | A (Forward Reference) |
| Branch on Not Equal Short | 203 | BNES | A (Backward Reference) |
|  | 213 | BNES | A (Forward Reference) |


| INSTRUCTION | OP CODE (M1) | MNEMONIC | OPERANDS |
| :---: | :---: | :---: | :---: |
| Branch on Low Short | 208 | BLS | A (Backward Reference) |
|  | 218 | BLS | A (Forward Reference) |
| Branch on Not Low Short | 228 | BNLS | A (Backward Reference) |
|  | 238 | BNLS | A (Forward Reference) |
| Branch on Minus Short | 201 | BMS | A (Backward Reference) |
|  | 211 | BMS | A (Forward Reference) |
| Branch on Not Minus Short | 221 | BNMS | A (Backward Reference) |
|  | 231 | BNMS | A (Forward Reference) |
| Branch on Plus Short | 202 | BPS | A (Backward Reference) |
|  | 212 | BPS | A (Forward Reference) |
| Branch on Not Plus Short | 222 | BNPS | A (Backward Reference) |
|  | 232 | BNPS | A (Forward Reference) |
| Branch on Overflow Short | 204 | BOS | A (Backward Reference) |
|  | 214 | BOS | A (Forward Reference) |
| Branch on Not Overflow Short | 224 | BNOS | A (Backward Reference) |
|  | 234 | BNOS | A (Forward Reference) |
| Branch Unconditional Short | 220 | BS | A (Backward Reference) |
|  | 230 | BS | A (Forward Reference) |
| Branch on Zero Short | 223 | BZS | A (Backward Reference) |
|  | 233 | BZS | A (Forward Reference) |
| Branch on Not Zero Short | 203 | BNZS | A (Backward Reference) |
|  | 213 | BNZS | A (Forward Reference) |

1024

## APPENDIX 5

 ARITHMETIC REFERENCES
## TABLE OF POWERS OF TWO

|  |  |  | $\left(2^{n}\right)_{10}$ |  |  | $\left(2^{n}\right)_{16}$ | n | $2^{-n}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 1 |  |  | 1 | 0 | 1.0 |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 2 |  |  | 2 | 1 | 0.5 |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 4 |  |  | 4 | 2 | 0.25 |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 8 |  |  | 8 | 3 | 0.125 |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 16 |  |  | 10 | 4 | 0.062 | 5 |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 32 |  |  | 20 | 5 | 0.031 | 25 |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 64 |  |  | 40 | 6 | 0.015 | 625 |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 128 |  |  | 80 | 7 | 0.007 | 812 | 5 |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 256 |  |  | 100 | 8 | 0.003 | 906 | 25 |  |  |  |  |  |  |  |  |  |  |
|  |  |  | 512 |  |  | 200 | 9 | 0.001 | 953 | 125 |  |  |  |  |  |  |  |  |  |  |
|  |  | 1 | 024 |  |  | 400 | 10 | 0.000 | 976 | 562 | 5 |  |  |  |  |  |  |  |  |  |
|  |  | 2 | 048 |  |  | 800 | 11 | 0.000 | 488 | 281 | 25 |  |  |  |  |  |  |  |  |  |
|  |  | 4 | 096 |  |  | 1000 | 12 | 0.000 | 244 | 140 | 625 |  |  |  |  |  |  |  |  |  |
|  |  | 8 | 192 |  |  | 000 | 13 | 0.000 | 122 | 070 | 312 | 5 |  |  |  |  |  |  |  |  |
|  |  | 16 | 384 |  |  | 4000 | 14 | 0.000 | 061 | 035 | 156 | 25 |  |  |  |  |  |  |  |  |
|  |  | 32 | 768 |  |  | 8000 | 15 | 0.000 | 030 | 517 | 578 | 125 |  |  |  |  |  |  |  |  |
|  |  | 65 | 536 |  |  | 000 | 16 | 0.000 | 015 | 258 | 789 | 062 | 5 |  |  |  |  |  |  |  |
|  |  | 131 | 072 |  |  | 000 | 17 | 0.000 | 007 | 629 | 394 | 531 | 25 |  |  |  |  |  |  |  |
|  |  | 262 | 144 |  |  | 000 | 18 | 0.000 | 003 | 814 | 697 | 265 | 625 |  |  |  |  |  |  |  |
|  |  | 524 | 288 |  |  | 000 | 19 | 0.000 | 001 | 907 | 348 | 632 | 812 | 5 |  |  |  |  |  |  |
|  | 1 | 048 | 576 |  |  | 000 | 20 | 0.000 | 000 | 953 | 674 | 316 | 406 | 25 |  |  |  |  |  |  |
|  | 2 | 097 | 152 |  | 200 | 000 | 21 | 0.000 | 000 | 476 | 837 | 158 | 203 | 125 |  |  |  |  |  |  |
|  | 4 | 194 | 304 |  |  | 000 | 22 | 0.000 | 000 | 238 | 418 | 579 | 101 | 562 | 5 |  |  |  |  |  |
|  | 8 | 388 | 608 |  |  | 000 | 23 | 0.000 | 000 | 119 | 209 | 289 | 550 | 781 | 25 |  |  |  |  |  |
|  | 16 | 777 | 216 |  | 000 | 000 | 24 | 0.000 | 000 | 059 | 604 | 644 | 775 | 390 | 625 |  |  |  |  |  |
|  | 33 | 554 | 432 | 2 | 000 | 000 | 25 | 0.000 | 000 | 029 | 802 | 322 | 387 | 695 | 312 | 5 |  |  |  |  |
|  | 67 | 108 | 864 | 4 | 000 | 000 | 26 | 0.000 | 000 | 014 | 901 | 161 | 193 | 847 | 656 | 25 |  |  |  |  |
|  | 134 | 217 | 728 | 8 | 000 | 000 | 27 | 0.000 | 000 | 007 | 450 | 580 | 596 | 923 | 828 | 125 |  |  |  |  |
|  | 268 | 435 | 456 |  | 000 | 000 | 28 | 0.000 | 000 | 003 | 725 | 290 | 298 | 461 | 914 | 062 | 5 |  |  |  |
|  | 536 | 870 | 912 | 20 | 000 | 000 | 29 | 0.000 | 000 | 001 | 862 | 645 | 149 | 230 | 957 | 031 | 25 |  |  |  |
| 1 | 073 | 741 | 824 | 40 |  | 000 | 30 | 0.000 | 000 | 000 | 931 | 322 | 574 | 615 | 478 | 515 | 625 |  |  |  |
| 2 | 147 | 483 | 648 | 80 | 000 | 0000 | 31 | 0.000 | 000 | 000 | 465 | 661 | 287 | 307 | 739 | 257 | 812 | 5 |  |  |
| 4 | 294 | 967 | 296 | 100 | 000 | 000 | 32 | 0.000 | 000 | 000 | 232 | 830 | 643 | 653 | 869 | 628 | 906 | 25 |  |  |
| 8 | 589 | 934 | 592 | 200 |  | 000 | 33 | 0.000 | 000 | 000 | 116 | 415 | 321 | 826 | 934 | 814 | 453 | 125 |  |  |
| 17 | 179 | 869 | 184 | 400 |  | 000 | 34 | 0.000 | 000 | 000 | 058 | 207 | 660 | 913 | 467 | 407 | 226 | 562 | 5 |  |
| 34 | 359 | 738 | 368 | 800 |  | 0000 | 35 | 0.000 | 000 | 000 | 029 | 103 | 830 | 456 | 733 | 703 | 613 | 281 | 25 |  |
| 68 | 719 | 476 | 736 | 1000 | 000 | 0000 | 36 | 0.000 | 000 | 000 | 014 | 551 | 915 | 228 | 366 | 851 | 806 | 640 | 625 |  |
| 137 | 438 | 953 | 472 | 2000 | 000 | 0000 | 37 | 0.000 | 000 | 000 | 007 | 275 | 957 | 614 | 183 | 425 | 903 | 320 | 312 | 5 |
| 274 | 877 | 906 | 944 | 4000 | 000 | 0000 | 38 | 0.000 | 000 | 000 | 003 | 637 | 978 | 807 | 091 | 712 | 951 | 660 | 156 | 25 |
| 549 | 755 | 813 | 888 | 8000 |  | 0000 | 39 | 0.000 | 000 | 000 | 001 | 818 | 989 | 403 | 545 | 856 | 475 | 830 | 078 | 125 |
| 099 | 511 | 627 | 776 | 10000 | 000 | 0000 | 40 | 0.000 | 000 | 000 | 000 | 909 | 494 | 701 | 772 | 928 | 237 | 915 | 039 | 062 |

## TABLE OF POWERS OF SIXTEEN



Decimal Values

1023
HEXADICIMAL TO DECIMAL INTEGER CONVERSION TABLE

| BYTE |  |  |  | BYTE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| HEX | DEC | IIEX | DEC | HEX | DEC | HEX | DEC |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 4,096 | 1 | 256 | 1 | 16 | 1 | 1 |
| 2 | 8,192 | 2 | 512 | 2 | 32 | 2 | 2 |
| 3 | 12,288 | 3 | 768 | 3 | 48 | 3 | 3 |
| 4 | 16,384 | 4 | 1,024 | 4 | 64 | 4 | 4 |
| 5 | 20,480 | 5 | 1,280 | 5 | 80 | 5 | 5 |
| 6 | 24,576 | 6 | 1,536 | 6 | 96 | 6 | 6 |
| 7 | 28,672 | 7 | 1,792 | 7 | 112 | 7 | 7 |
| 8 | 32,768 | 8 | 2,048 | 8 | 128 | 8 | 8 |
| 9 | 36,864 | 9 | 2,304 | 9 | 144 | 9 | 9 |
| A | 40,960 | A | 2,560 | A | 160 | A | 10 |
| B | 45, 056 | B | 2,816 | B | 176 | B | 11 |
| C | 49,152 | C | 3,072 | C | 192 | C | 12 |
| D | 53,248 | D | 3,328 | D | 208 | D | 13 |
| E | 57,344 | E | 3,584 | E | 224 | E | 14 |
| F | 61,440 | F | 3,840 | F | 240 | F | 15 |

HEXADECIMAL ADDITION AND SUBTRACTION TABLE
Examples: $5+\mathrm{A}=\mathrm{F} ; 18-\mathrm{D}=\mathrm{B} ; \mathrm{A}+\mathrm{B}=15$

|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| I | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F | 10 | l |
| 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F | 10 | 11 | 2 |
| 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F | 10 | 11 | 12 | 3 |
| 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F | 10 | 11 | 12 | 13 | 4 |
| 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F | 10 | 11 | 12 | 13 | 14 | 5 |
| 6 | 7 | 8 | 9 | A | B | C | D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 6 |
| 7 | 8 | 9 | A | B | C | D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 7 |
| 8 | 9 | A | B | C | D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 8 |
| 9 | A | B | C | D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 9 |
| A | B | C | D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | A |
| B | C | D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1 A | B |
| C | D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1 A | 1 B | C |
| D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1 A | 1 B | 1 C | D |
| E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1 A | 1 B | 1 C | 1 D | E |
| F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1 A | 1 B | 1 C | 1 D | 1 E | F |
|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |  |

1021
HEXADECIMAL MULTIPLICATION AND DIVISION TABLE
Examples: $5 \mathrm{x} 6=1 \mathrm{E} ; 75 \div \mathrm{D}=9 ; 58 \div 8=\mathrm{B} ; 9 \mathrm{xC}=6 \mathrm{C}$

|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F | 1 |
| 2 | 2 | 4 | 6 | 8 | A | C | E | 10 | 12 | 14 | 16 | 18 | 1 A | 1 C | 1 E | 2 |
| 3 | 3 | 6 | 9 | C | F | 12 | 15 | 18 | 1B | 1 E | 21 | 24 | 27 | 2A | 2D | 3 |
| 4 | 4 | 8 | C | 10 | 14 | 18 | 1 C | 20 | 24 | 28 | 2 C | 30 | 34 | 38 | 3C | 4 |
| 5 | 5 | A | F | 14 | 19 | 1 E | 23 | 28 | 2D | 32 | 37 | 3 C | 41 | 46 | 4B | 5 |
| 6 | 6 | C | 12 | 18 | 1 E | 24 | 2A | 30 | 36 | 3 C | 42 | 48 | 4 E | 54 | 5A | 6 |
| 7 | 7 | E | 15 | 1C | 23 | 2A | 31 | 38 | 3 F | 46 | 4D | 54 | 5B | 62 | 69 | 7 |
| 8 | 8 | 10 | 18 | 20 | 28 | 30 | 38 | 40 | 48 | 50 | 58 | 60 | 68 | 70 | 78 | 8 |
| 9 | 9 | 12 | 1B | 24 | 2D | 36 | 3 F | 48 | 51 | 5 A | 63 | 6 C | 75 | 7 E | 87 | 9 |
| A | A | 14 | 1 E | 28 | 32 | 3 C | 46 | 50 | 5A | 64 | 6 E | 78 | 82 | 8 C | 96 | A |
| B | B | 16 | 21 | 2C | 37 | 42 | 4D | 58 | 63 | 6 E | 79 | 84 | 8 F | 9 A | A5 | B |
| C | C | 18 | 24 | 30 | 3 C | 48 | 54 | 60 | 6 C | 78 | 84 | 90 | 9C | A8 | B4 | C |
| D | D | 1A | 27 | 34 | 41 | 4 E | 5B | 68 | 75 | 82 | 8 F | 9 C | A9 | B6 | C3 | D |
| E | E | 1 C | 2A | 38 | 46 | 54 | 62 | 70 | 7E | 8 C | 9A | A8 | B6 | C4 | D2 | E |
| F | F | 1 E | 2D | 3C | 4B | 5A | 69 | 78 | 87 | 96 | A5 | B4 | C3 | D2 | E1 | F |
|  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |  |

## APPENDIX 5 (Continued)

TABLE OF MATHEMATICAL CONSTANTS

| CONSTANT | DECIMAL VALUE |  |  |  | HEXADECIMAL value | FLOATING POINT VALUE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\pi$ | 3.14159 | 26535 | 89793 | 23846 | $\begin{array}{rr} 3.243 F & 6 A 88 \\ 85 A 3 & 08 D 3 \end{array}$ | DOUBLE PRECISION |  |  |  |
|  |  |  |  |  |  | SINGLE PRECISION |  |  |  |
|  |  |  |  |  |  | 4132 | 43F6 | A888 | 5A31 |
|  |  |  | 83790 | 67154 |  |  | 7CC1 | B727 |  |
| $\pi-1$ | 0.31830 | 98861 |  |  | 0.517 C C1B7 | 4051 |  |  | 220B |
|  |  |  |  |  | 2722 0A95 |  |  |  |  |
| $\sqrt{ } \pi$ | 1.77245 | 38509 | 05516 | 02730 | 1.C5BF 891B | 411C | 5BF8 | 9184 | EF6B |
|  |  |  |  |  | 4EF6 AA7A |  |  |  |  |
| $\operatorname{Ln} \pi$ | 1.14472 | 98858 | 49400 | 17414 | 1.250D 048E | 4112 | B67A | E858 | 4CAA |
|  |  |  |  |  | 7A1B D0BD |  |  |  |  |
| $\sqrt{3}$ | 1.73205 | 08075 | 68877 | 29353 | 1.BB67 AE85 | 411B | 67AE | 8584 | CAA7 |
|  |  |  |  |  | 84CA A73B |  |  |  |  |
| e | 2.71828 | 18284 | 59045 | 23536 | 2.B7E1 5162 | 412B | 7E15 | 1628 | AED3 |
|  |  |  |  |  | 8AED 2A6B |  |  |  |  |
| $e^{-1}$ | 0.36787 | 94411 | 71442 | 32160 | 0.5E2D 58D8 | 405E | 2D58 | D8B3 | BCDF |
|  |  |  |  |  | B3BC DF1B |  |  |  |  |
| $\sqrt{\text { e }}$ | 1.64872 | 12707 | 00128 | 14683 | 1.A612 98E1 | 411A | 6129 | 8E1E | 069C |
|  |  |  |  |  | E069 BC97 |  |  |  |  |
| $\log _{10}{ }^{\text {e }}$ | 0.43429 | 44819 | 03251 | 82765 | 0.6F2D EC54 | 406F | 2DEC | 5A9B | 9439 |
|  |  |  |  |  | 9B94 38CB |  |  |  |  |
| $\log _{2} \mathrm{e}$ | 1.44269 | 50408 | 88963 | 40736 | 1.71547652 | 4117 | 1547 | 652B | 82FE |
|  |  |  |  |  | B82F E177 |  |  |  |  |
| $\gamma$ | 0.57721 | 56649 | 01532 | 86061 | 0.93 C 467 E 3 | 4093 | C467 | E37D | B0C8 |
|  |  |  |  |  | 7DB0 C7A5 |  |  |  |  |
| $\operatorname{Ln} \gamma$ | -0.54953 | 93129 | 81644 | 82234 | -0.8CAE 9BC1 | C08C | AE9B | C11F | 5 A 60 |
|  |  |  |  |  | 1F5A 5FF4 |  |  |  |  |
| $\sqrt{2}$ | 1.41421 | 35623 | 73095 | 04880 | 1.6A09 E667 | 4116 | A09E | 667 F | 3 BCD |
|  |  |  |  |  | F3BC C909 |  |  |  |  |
| Ln2 | 0.69314 | 71805 | 59945 | 30942 | $0 . \mathrm{B172}$ 17F7 | 40B 1 | 7217 | F7D1 | CF7A |
|  |  |  |  |  | D1CF 79AC |  |  |  |  |
| $\begin{gathered} \log _{10} 2 \\ -\sqrt{10} \end{gathered}$ | 0.30102 | 99956 | 63981 | 19521 | 0.4 D 10 4D42 | 404D | 104D | 427D | E7FC |
|  |  |  |  |  | 7DE7 FBCC |  |  |  |  |
|  | 3.16227 | 76601 | 68379 | 33199 | 3.298 B 075B | 4132 | 98B0 | 75B4 | B6A5 |
|  |  |  |  |  | 4B6A 5240 |  |  |  |  |
| Ln10 | 2.30258 | 50929 | 94045 | 68402 | 2.4 D 763776 | 4124 | D763 | 776A | AA2B |
|  |  |  |  |  | AAA2 BO5C |  |  |  |  |

Hexadecimal and Decimal Integer Conversion Table

| HALFWORD |  |  |  |  |  |  |  | HALFWORD |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BYTE |  |  |  | BYTE |  |  |  | BYTE |  |  |  | BYtE |  |  |  |
| BITS: 0123 |  | 4567 |  | 0123 |  | 4567 |  | 0123 |  | 4567 |  | 0123 |  | 4567 |  |
| Hex | Decimal | Hex | Decimal | Hex | Decimal | Hex | Decimal | Hex | Decimal | Hex | Decimal | Hex | Decimal | Hex | Decimal |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 268,435,456 | 1 | 16,777,216 | 1 | 1,048,576 | 1 | 65,536 | 1 | 4,096 | 1 | 256 | 1 | 16 | 1 | 1 |
| 2 | 536,870,912 | 2 | 33,554,432 | 2 | 2,097,152 | 2 | 131,072 | 2 | 8,192 | 2 | 512 | 2 | 32 | 2 | 2 |
| 3 | 105,306,368 | 3 | 50,331,648 | 3 | 3,145,728 | 3 | 196,608 | 3 | 12,288 | 3 | 768 | 3 | 48 | 3 | 3 |
| 4 | 1,073,741,824 | 4 | 67,108,864 | 4 | 4,194,304 | 4 | 262,144 | 4 | 16,384 | 4 | 1,024 | 4 | 64 | 4 | 4 |
| 5 | 1,342,177,280 | 5 | 83,886,080 | 5 | 5,242,880 | 5 | 327,680 | 5 | 20,480 | 5 | 1,280 | 5 | 80 | 5 | 5 |
| 6 | 1,610,612,736 | 6 | 100,663,296 | 6 | 6,291,456 | 6 | 393,216 | 6 | 24,576 | 6 | 1,536 | 6 | 96 | 6 | 6 |
| 7 | 1,879,048,192 | 7 | 117,440,512 | 7 | 7,340,032 | 7 | 458,752 | 7 | 28,672 | 7 | 1,792 | 7 | 112 | 7 | 7 |
| 8 | 2,147,483,648 | 8 | 134,217,728 | 8 | 8,388,608 | 8 | 524,288 | 8 | 32,768 | 8 | 2,048 | 8 | 128 | 8 | 8 |
| 9 | 2,415,919,104 | 9 | 150,994,944 | 9 | 9,437,184 | 9 | 589,824 | 9 | 36,864 | 9 | 2,304 | 9 | 144 | 9 | 9 |
| A | 2,684,354,560 | A | 167,772,160 | A | 10,485,760 | A | 655,360 | A | 40,960 | A | 2,560 | A | 160 | A | 10 |
| B | 2,952,790,016 | B | 184,549,376 | B | 11,534,336 | B | 720,896 | B | 45,056 | B | 2,816 | B | 176 | B | 11 |
| C | 3,221,225,472 | C | 201,326,592 | C | 12,582,912 | C | 786,432 | C | 49,152 | C | 3,072 | C | 192 | C | 12 |
| D | 3,489,660,928 | D | 218,103,808 | D | 13,631,488 | D | 851,968 | D | 53,248 | D | 3,328 | D | 208 | D | 13 |
| E | 3,758,096,384 | E | 234,881,024 | E | 14,680,064 | E | 917,504 | E | 57,344 | E | 3,584 | E | 224 | E | 14 |
| $F$ | 4,026,531,840 | F | 251,658,240 | F | 15,728,640 | F | 983,040 | F | 61,440 | F | 3,840 | F | 240 | F | 15 |
|  | 8 |  | 7 |  | 6 |  | 5 |  | 4 |  | 3 |  | 2 |  | 1 |

## TO CONVERT HEXADECIMAL TO DECIMAL

1. Locate the column of decimal numbers corresponding to the left-most digit or letter of the hexadecimal; select from this column and record the number that corresponds to the position of the hexadecimal digit or letter.
2. Repeat stop 1 for the next (second from the left) position.
3. Repeat step Ifor the units (third from the left) position.
4. Add the numbers selected from the table to form the decimal number.

| EXAMPLE |  |
| :--- | ---: |
| Conversion of <br> Hexadecimal Value | D34 |
| 1. D | 3328 |
| 2. 3 | 48 |
| 3. 4 | -4 |
| 4. Decimal | 3380 |

To convert integer numbers greater than the capacity of table, use the techniques below:

## HEXADECIMAL TO DECIMAL

Successive cumulative multiplication from left to right, adding units position.

Example: \begin{tabular}{rl}

$D 34_{16}=3380_{10} \quad D$ \& $=$| 13 |
| ---: |
| $\frac{\times 16}{208}$ |
| 3 | <br>

$=\frac{+3}{211}$ <br>
$\frac{\times 16}{3376}$ <br>
4 \& $=\frac{+4}{3380}$
\end{tabular}

1026
TO CONVERT DECIMAL TO HEXADECIMAL

1. (a) Select from the table the highest decimal number that is equal to or less than the number to be converted.
(b) Record the hexadecimal of the column containing the selected number.
(c) Subtract the selected decimal from the number to be converted.
2. Using the remainder from step 1(c) repeat all of step 1 to dovelop the second position of the hexadecimal (and a remainder).
3. Using the remainder from step 2 repeat all of step 1 to develop the units position of the hexadecimal.

| EXAMPLE <br> Conversion of <br> Decimal Value |  |
| :--- | ---: |
| 1. D | 3380 |
| 2. 3 | $\frac{-3328}{52}$ |
| 3. 4 | $-\frac{-48}{4}$ |
| 4. Hexadecimal | D34 |

4. Combine terms to form the hexadecimal number.

## DECIMAL TO HEXADECIMAL

Divide and collect the remainder in reverse order.
Example: $\quad{ }^{3380}{ }_{10}=X_{16}$


## APPENDIX 5 (Continued)

FRACTION CONVERSION TABLE

Hexadecimal and Decimal Fraction Conversion Table

| HALFWORD |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BYTE |  |  |  |  | BYTE |  |  |  |  |  |  |  |  |
| BITS | 0123 | 4567 |  |  | 0123 |  |  |  | 4567 |  |  |  |  |
| Hex | Decimal | Hex | Decimal |  | Hex | Decimal |  |  | Hex | Decimal Equivalent |  |  |  |
| . 0 | . 0000 | . 00 | . 0000 | 0000 | . 000 | . 0000 | 0000 | 0000 | . 0000 | . 0000 | 0000 | 0000 | 0000 |
| . 1 | . 0625 | . 01 | . 0039 | 0625 | . 001 | . 00002 | 4414 | 0625 | . 0001 | . 0000 | 1525 | 8789 | 0625 |
| . 2 | . 1250 | . 02 | . 0078 | 1250 | . 002 | . 0004 | 8828 | 1250 | . 0002 | . 0000 | 3051 | 7578 | 1250 |
| . 3 | . 1875 | . 03 | . 0117 | 1875 | . 003 | . 0007 | 3242 | 1875 | . 0003 | . 0000 | 4577 | 6367 | 1875 |
| . 4 | . 2500 | . 04 | . 0156 | 2500 | . 004 | . 0009 | 7656 | 2500 | . 0004 | . 0000 | 6103 | 5156 | 2500 |
| . 5 | . 3125 | . 05 | . 0195 | 3125 | . 005 | . 0012 | 2070 | 3125 | . 0005 | . 0000 | 7629 | 3945 | 3125 |
| . 6 | . 3750 | . 06 | . 0234 | 3750 | . 006 | . 0014 | 6484 | 3750 | . 0006 | . 0000 | 9155 | 2734 | 3750 |
| . 7 | . 4375 | . 07 | . 0273 | 4375 | . 007 | . 0017 | 0898 | 4375 | . 0007 | . 0001 | 0681 | 1523 | 4375 |
| . 8 | . 5000 | . 08 | . 0312 | 5000 | . 008 | . 0019 | 5312 | 5000 | . 0008 | . 0001 | 2207 | 0312 | 5000 |
| . 9 | . 5625 | . 09 | . 0351 | 5625 | . 009 | . 0021 | 9726 | 5625 | . 0009 | . 0001 | 3732 | 9101 | 5625 |
| . ${ }^{\text {A }}$ | . 6250 | . 0 A | . 0390 | 6250 | .00A | . 0024 | 4140 | 6250 | . 000 A | . 0001 | 5258 | 7890 | 6250 |
| . B | . 6875 | . 08 | . 0429 | 6875 | . 008 | . 0026 | 8554 | 6875 | . 0000 B | . 0001 | 6784 | 6679 | 6875 |
| . C | . 7500 | . 0 C | . 0468 | 7500 | . 000 C | . 0029 | 2968 | 7500 | . 0000 C | . 0001 | 8310 | 5468 | 7500 |
| . D | . 8125 | . 00 | . 0507 | 8125 | . 000 | . 0031 | 7382 | 8125 | . 0000 D | . 0001 | 9836 | 4257 | 8125 |
| . E | . 8750 | . 0 E | . 0546 | 8750 | . 000 E | . 0034 | 1796 | 8750 | . 0000 E | . 0002 | 1362 | 3046 | 8750 |
| . F | . 9375 | . 0 F | . 0585 | 9375 | . 00 F | . 0036 | 6210 | 9375 | . 000 F | . 0002 | 2888 | 1835 | 9375 |
| 1 |  | 2 |  |  | 3 |  |  |  | 4 |  |  |  |  |

## TO CONVERT. ABC HEXADECIMAL TO DECIMAL

Find . A in position 1 . 6250
Find .OB in position 2 . 04296875
Find. $O 0 C$ in position 3 . 002929687500
.ABC Hex is equal to . 670898437500

TO CONVERT . 13 DECIMAL TO HEXADECIMAL


To convert fractions beyond the capacity of table, use techniques below:

HEXADECIMAL FRACTION TO DECIMAL
Convert the hexadecimal fraction to its decimal equivalent using the same technique as for integer numbers. Divide the results by $16^{n}$ ( n is the number of fraction positions).
Example: $.8 A 7=.540771_{10}$
$8 A 7_{16}=2215_{10}$
$1 6 ^ { 3 } = 4 0 9 6 \quad 4 0 9 6 \longdiv { 2 2 1 5 . 0 0 0 0 0 0 }$

## DECIMAL FRACTION TO HEXADECIMAL

Collect integer parts of product in the order of calculation.
Example: $\quad .5408_{10}=.8 \mathrm{~A}_{16}$


APPENDIX 6
MODEL $8 / 32$ EXECUTION TIMES IN MICRO SECONDS

| INST. | $\begin{aligned} & \text { EXECUTION } \\ & \text { TIME } \end{aligned}$ | NOTES | COMMENTS |
| :---: | :---: | :---: | :---: |
| A | 1.26 | 1 |  |
| ABL | 4.77/10.45/10.75 |  | OVF/NORM/WRAP |
| AD | 3.53/3.93 | 5 | RX1, RX3/RX2 |
| ADR | 1.12 | 5 |  |
| AE | 1.82 | 5 |  |
| AER | 1.00 | 5 |  |
| AH | 1.26 | 1 |  |
| AHI | . 515 |  |  |
| A HM | 2.60 | 4 |  |
| AI | . 510 | 2 |  |
| AIS | . 415 |  |  |
| AL | $6.31+2.10+3.27 \mathrm{n}$ | 4 | $\begin{aligned} & \mathrm{L}=\text { LEADER BYTES } \\ & \mathrm{n}=\text { DATA BYTES } \end{aligned}$ |
| AM | 2.60 | 4 |  |
| AR | . 415 |  |  |
| ATL | $4.77 / 10.07 / 10.47$ | 4 | OVF/NORM/WRAP |
| BAL | 1.45 | 3 |  |
| BALR | 1.19 | 3 |  |
| BDCS | 1.80 User's U code | 4 |  |
| BFBS | . $415 / 1.45$ | 3 | No branch/branch |
| BFC | . $415 / 1.19$ | 3 | No branch/branch |
| BFCR | . $415 / .930$ | 3 | No branch/branch |
| BFFS | . $415 / 1.45$ | 3 | No branch/branch |
| BTBS | . $415 / 1.45$ | 3 | No branch/branch |
| BTC | . $415 / 1.19$ | 3 | No branch/branch |
| BTCR | . $415 / .930$ | 3 | No branch/branch |
| BTFS | . $415 / 1.45$ | 3 | No branch/branch |
| BXH | 3.54/4. 05 | 3 | No branch/branch |
| BXLE | 3.54/4.05 | 3 | No branch/branch |


| APPENDIX 6 (CONTINUED) |  |  |  |
| :---: | :---: | :---: | :---: |
| INST. | $\begin{aligned} & \text { EXECUTION } \\ & \text { TIME } \end{aligned}$ | NOTES | COMMENTS |
| C | $2.00 / 2.60$ |  | LIKE SIGNS/UNLIKE SIGNS |
| CBT | 4.66 | 4 |  |
| CD | 3.09/3. 49 | 5 | RX1, RX3/RX2 |
| CDR | 0.63 | 5 |  |
| CE | 1.47 | 5 |  |
| CER | 0.630 | 5 |  |
| CH | 2.00/2.60 |  | LIKE SIGNS/UNLIKE SIGNS |
| CHI | 1.43/2.02 |  | LIKE SIGNS/UNLIKE SIGNS |
| CHVR | 3.14/3.40 |  | NORM/OVF |
| CI | 1.43/2. 02 |  | LIKE SIGNS/UNLIKE SIGNS |
| CL | 1.26 | 1 |  |
| CLB | 2.77 | 4 |  |
| CLH | 1.26 | 1 |  |
| CLHI | . 515 |  |  |
| CLI | . 515 | 2 |  |
| CLR | . 415 |  |  |
| CR | 1.18/1.76 |  | LIKE SIGNS/UNLIKE SIGNS |
| CRC12 | 7.84/9.52/10.33 | * 4 | MIN/AVG/MAX |
| CRC16 | 8.84/10.09/12.16 | * 4 | MIN/AVG/MAX |
| D | 5.76 |  |  |
| DD | 9.20/9.65 | 5 | RX1, RX3/RX2 |
| DDR | 6.70 |  |  |
| DE | 4.47 | 5 |  |
| DER | 3.60 | 5 |  |
| DH | 8.21 | 5 |  |
| DHR | 8.21 | 5 |  |
| DR | 6.31 |  |  |
| ECS | $\begin{aligned} & \text { 1. } 51 \text { USER'S U } \\ & \text { CODE } \end{aligned}$ |  |  |
| EPSR | 2.89 |  |  |
| EXBR | 1.22 |  |  |
| EXHR | 1.74 |  |  |

APPENDIX 6
(CONTINUED)


| APPENDIX 6 (CONTINUED) |  |  |  |
| :---: | :---: | :---: | :---: |
| INST. | $\begin{aligned} & \text { EXECUTION } \\ & \text { TIME } \end{aligned}$ | NOTES | COMMENTS |
| MR | 2.70/4.26 |  | BEST/WORST |
| N | 1.26 | 1 |  |
| NH | 1.26 | 1 |  |
| NHI | . 515 |  |  |
| NI | . 515 | 2 |  |
| NR | . 415 |  |  |
| O | 1.26 | 1 |  |
| OC | 4.52 | 4 |  |
| OCR | 2.88 |  |  |
| OH | 1.26 | 1 |  |
| OHI | . 515 |  |  |
| OI | . 515 | 2 |  |
| OR | . 415 |  |  |
| PB | 8.34/8.34/8. 34 8.74/8.74/8.74 8.34/8.34/8. 34 | $\begin{aligned} & \text { RX1 } \\ & \text { RX2 } \\ & \text { RX3 } \end{aligned}$ | CRC 16/SDLC/LDC CRC 16/SDLC/LDC CRC 16/SDLC/LDC |
| PBR | 6.96/6.96/6.96 |  | CRC 16/SDLC/LDC |
| RB | $4.88+2.66 \mathrm{n}$ | 4 | n = NO. OF BYTES |
| RBL | 5.20/9.85/10.43 | 4 | OVF/NORM/WRAP |
| RBR | $3.90+3.25 n$ |  | $\mathrm{n}=$ NO. OF BYTES |
| RBT | 4.75 | 4 |  |
| RD | 4.11 | 4 |  |
| RDCS | $3.09+1.51 \mathrm{n}$ |  | $\mathrm{n}=$ NO. FULLWORDS |
| RDR | 1.70 |  |  |
| RH | 4.00/3.53 |  | BYTE/HALFWORD |
| RHR | 2.18/1.70 |  | BYTE/HALFWORD |
| RLL | . $675+.06 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF SHIFTS |


| APPENDIX 6 (CONTINUED) |  |  |  |
| :---: | :---: | :---: | :---: |
| INST. | $\begin{aligned} & \text { EXECUTION } \\ & \text { TIME } \end{aligned}$ | NOTES | COMMENTS |
| RRL | $6.75+.06 n$ |  | $\mathrm{n}=$ NO. OF SHIFTS |
| RTL | $5.22 / 12.05 / 12.32$ | 4 | OVF/NORM/WRAP |
| S | 1.26 | 1 |  |
| SBT | 4.66 | 4 |  |
| SCP | 6.10/9.88/10. 22 | 4 | CNT+/NORM/TERM TIMES SHOWN ARE FOR READ. FOR WRITE, ADD 0.13 |
| SD | 3.53/4.94 | 5 | RX1, RX2/RX3 |
| SDR | 1.12 | 5 |  |
| SE | 1.81 | 5 |  |
| SER | 1.00 | 5 |  |
| SH | 1.26 | 1 |  |
| SHI | . 515 |  |  |
| SI | . 510 | 2 |  |
| SINT | 7.19/8.14 | 3 | LEVEL0/LEVEL 1:3 |
| SIS | . 415 |  |  |
| SLA | . $675+.06 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF SHIFTS |
| SLHA | . $675+.06 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF SHIFTS |
| SLHL | . $675+.06 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF SHIFTS |
| SLHLS | $4.20+.06 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF SHIFTS |
| SLL | . $675+.06 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF SHIFTS |
| SLLS | . $420+.06 \mathrm{n}$ |  | $n=$ NO. OF SHIFTS |
| SR | . 415 |  |  |
| SRA | . $675+.06 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF SHIFTS |
| SRHA | .675+.06n |  | $\mathrm{n}=$ NO. OF SHIFTS |
| SRHL | . $675+.06 \mathrm{n}$ |  | $\mathrm{n}=$ NO。OF SHIFTS |
| SRHLS | . $420+.06 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF SHIFTS |
| SRL | . $675+.06 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF SHIFTS |
| SRLS | $.420+.6 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF SHIFTS |

APPENDIX 6
(CONTINUED)

| INST. | $\begin{aligned} & \text { EXECUTION } \\ & \text { TIME } \end{aligned}$ | NOTES | COMMENTS |
| :---: | :---: | :---: | :---: |
| SS | 4.10 | 4 |  |
| SSR | 1.72 |  |  |
| ST | 2.05 | 4 |  |
| STB | 2.63 | 4 |  |
| STBR | 1.30 |  |  |
| STD | 2.79/2.81 | 5 | RX1, RX3/RX2 |
| STE | 2.30/2.70 | 5 | RX1, RX3/RX2 |
| STH | 2.05 | 4 |  |
| STM | 3.42+.78n | 4 | $\mathrm{n}=$ NO. OF REGISTERS |
| STMD | $4.60+1.90 \mathrm{n}$ | 5 | $\mathrm{n}=$ NO. OF REGISTERS |
| STME | $3.65+.95 \mathrm{n}$ | 5 | $\mathrm{n}=$ NO. OF REGISTERS |
| SVC | 5.32 | 3 |  |
| TBT | 3.82 | 4 |  |
| THI | . 515 |  |  |
| TI | . 515 | 2 |  |
| TLATE | 2.52/3.16 | 3 | TRANSLATE/SPECIAL CHARACTER |
| TS | 2.82/3. 22 |  | BIT SET/BIT RESET |
| WB | $5.50+3.39 n$ | 4 | $\mathrm{n}=$ NO OF BYTES |
| WBR | $3.89+3.39 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF BYTES |
| WD | 4.10 | 4 |  |
| WDCS | $2.36+2.17 \mathrm{n}$ |  | $\mathrm{n}=$ NO. OF FULLWORDS |
| WDR | 1.82 |  |  |
| WH | 4.14/3.46 |  | BYTE/HALFWORD |
| WHR | 2.50/1.83 |  | BYTE/HALFWORD |
| X | 1.26 | 1 |  |
| XH | 1.26 | 1 |  |
| XHI | . 515 |  |  |
| XI | . 515 | 2 |  |
| XR | . 415 |  |  |

## -APPENDIX 6

(CONTINUED)

All execution times assume no DMA interference. Times given for I/O Instructions assume best case device response.

Due to an Instruction's position within the cache, execution times will vary.

NOTES

1. RX1-1.26/1.51/1.71-BEST/TYPICAL/WORST RX2-1.26/1.51/1.71-BEST/TYPICAL/WORST RX3-1.27/1.57/1.77-BEST/TYPICAL/WORST
2. R12-0.51/0.61/0.71-BEST/TYPICAL/WORST
3. On branching out of the cache, additional overhead is incurred on fetching the next Instruction. This overhead can range from 0 to 0.54 microseconds, depending on the format of the next instruction. Use 0.20 microseconds for the typical case. Subtract 0.54 microseconds if the next Instruction is in the cache.
4. Add 0.40 if RX2.
5. Execution times vary depending on the data in the operands in many cases and on the instruction's location in the cache, for memory referencing instructions. In all cases, the listed time for an instruction is the fastest execution time. The following factors can be used to adjust the execution time.
A. Normalize Result (add, subtract, multiply, divide, float load) - Add 100 ns per hexadecimal shift.
B. Equalize exponents (add, subtract) - Add 100 ns per hexadecimal shift, add 140 ns if B operand is greater than the A operand.
C. Data with alternate 1 's and 0 's (multiply only) can increase time by 700 ns for single precision and 1600 ns for double percision.
D. Position of an instruction in the cache (all memory referencing instructions) can increase execution time by 400 ns (maximum) if instruction read causes the cache to try to refill from memory, or if the stack is already being refilled from memory.

* Abortable Instruction


## AUTO DRIVER CHANNEL EXECUTION TIMES IN MICROSECONDS

FAST MODE

| FUNCTION |  |  |  | NORMAL |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| READ (BYTE) | 10.080 | 11.39 | 13.52 | 16.47 | 16.06 |
| READ (HALFWORD) | 10.080 | 11.39 | 13.52 | 15.22 | 15.81 |
| WRITE (BYTE) | 10.080 | 11.39 | 13.52 | 16.330 | 15.92 |
| WRITE (HALFWORD) | 10.080 | 11.39 | 13.52 | 16.23 | 15.91 |

NORMAL MODE

| FUNCTION |  | 会感 |  | NORMAL | BUFFER END | Y1 ¢ 8 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LRC, BU FF0, READ | 10.08 | 11.39 | 14.72 | 21.73 | 22.10 |  |
| LRC, BU FF0, READ, TLATE | 10.08 | 11.39 | 14.72 | 24.65/16.94 | 25.02 | 1 |
| LRC, BU FF0, WRITE | 10.08 | 11.39 | 14.72 | 20.59 | 20.96 |  |
| LRC, BU FF0,WRITE, TLATE | 10.08 | 11.39 | 14.72 | 23.49/16.710 | 23.86 | 1 |
| LRC, BU FF1, READ | 10.08 | 11.39 | 14.98 | 21.47 | 21.84 |  |
| LRC, BU FF1, READ, TLATE | 10.08 | 11.39 | 14.98 | 24.39/16.68 | 24.76 | 1 |
| LRC, BU FF1, WRITE | 10.08 | 11.39 | 14.98 | 20.33 | 20.70 |  |
| LRC, BU FF1, WRITE, TLA TE | 10.08 | 11.39 | 14.98 | 23.23/16.45 | 23.60 | 1 |
| CRC, BU FF0, READ | 10.08 | 11.39 | 14.72 | 26.77/28.41/30.05 | 26.99/28.63/30.27 | 2 |
| CRC, BU FF0, READ, TLATE | 10.08 | 11.39 | 14.72 | (16.94)29.67/31.31/32.95 | 29.89/31.53/33.17 | 3 |
| CRC, BU FF0, WRITE | 10.08 | 11.39 | 14.72 | 25.33/26.97/28.61 | 25.55/27.19/28.83 | 2 |
| CRC, BU FF0, WRITE, TLATE | 10.08 | 11.39 | 14.72 | (16.71) $28.23 / 29.87 / 31.51$ | 28.45/30.09/31.73 | 3 |
| CRC, BU FF1, READ, | 10.08 | 11.39 | 14.98 | 26.51/28.15/29.79 | 26.73/28.37/30.01 | 2 |
| CRC, BU FF1, READ, TLATE | 10.08 | 11.39 | 14.98 | (16.68)29.41/31.05/32.69 | 29.63/31.27/32.91 | 3 |
| CRC, BU FF1, WRITE | 10.08 | 11.39 | 14.98 | 25.07/26.71/28.35 | 25.29/26.93/28.57 | 2 |
| CRC, BU FF1, WRITE, TLATE | 10.08 | 11.39 | 14.98 | (16.45)27.97/29.61/31.25 | 28.19/29.83/31.47 | 3 |

NOTE 1: NORMAL/SPECIAL CHARACTER
NOTE 2: MIN/AVE/MAX ALWAYS USE MIN IF DATA COMMUNICATION OPTION EQUIPPED
NOTE 3: (SPECIAL CHARACTER) MIN/AVE/MAX ALWAYS USE MIN IF DATA COMMUNICATION OPTION EQUIPPED

| IMMEDIATE INTERRUPTS | $\mathbf{6 . 7 2}$ |
| :--- | :--- |
| MALF | 6.64 |
| MAC (DATA) | 5.60 |
| MAC (INSTR) | 5.34 |
| ILLEGAL INSTR | 5.34 |
| on LPSW, LPSWR, EPSR ADD | 2.38 IF QUEUE SERVICE ENABLED |
|  | THEN ADD |
|  | 3.420 IF QUEUE NOT EMPTY |

## APPENDIX 7

I/O REFERENCES

ASCII/HEX CONVERSION TABLE

| BITS |  |  |  | $b_{6}$ $b_{5}$ $b_{4}$ | $\begin{array}{lll}0 & \\ 0 & \\ & 0\end{array}$ | $\begin{array}{lll}0 & \\ & 0 & \\ & & 1\end{array}$ | $\begin{array}{lll}0 & \\ & 1 & \\ & & 0\end{array}$ | $\begin{array}{lll}0 & & \\ & 1 & \\ & & 1\end{array}$ | $\begin{array}{lll}1 & \\ 0 \\ & \\ & 0\end{array}$ | $\begin{array}{lll}1 & & \\ & 0 & \\ & & 1\end{array}$ | $\begin{array}{lll}1 & & \\ & 1 \\ & & 0\end{array}$ | $\begin{array}{llll}1 & & \\ & 1 & \\ & & \\ & & 1\end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} b_{3} \\ b \end{gathered}$ | $\mathrm{b}_{2}$ | $b_{1}$ $\downarrow$ | $\begin{gathered} b_{0} \\ \downarrow \end{gathered}$ | MSD | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 0 | 0 | 0 | 0 | 0 | NUL | DLE | SPACE | 0 | @ | P | ' | $p$ |
| 0 | 0 | 0 | 1 | 1 | SOH | DC1 | ! | 1 | A | Q | a | q |
| 0 | 0 | 1 | 0 | 2 | STX | DC2 | " | 2 | B | R | b | $r$ |
| 0 | 0 | 1 | 1 | 3 | ETX | DC3 | \# | 3 | C | S | c | $s$ |
| 0 | 1 | 0 | 0 | 4 | EOT | DC4 | \$ | 4 | D | T | d | t |
| 0 | 1 | 0 | 1 | 5 | ENO | NAK | \% | 5 | E | U | e | u |
| 0 | 1 | 1 | 0 | 6 | ACK | SYN | \& | 6 | F | V | $f$ | $v$ |
| 0 | 1 | 1 | 1 | 7 | BEL | ETB | , | 7 | G | W | $g$ | w |
| 1 | 0 | 0 | 0 | 8 | BS | CAN | 1 | 8 | H | X | h | x |
| 1 | 0 | 0 | 1 | 9 | HT | EM | 1 | 9 | 1 | $Y$ | i | $y$ |
| 1 | 0 | 1 | 0 | A | LF | SUB | * | : | $J$ | Z | 1 | z |
| 1 | 0 | 1 | 1 | B | VT | ESC | + | ; | K | [ | k | $\{$ |
| 1 | 1 | 0 | 0 | C | FF | FS | , | $<$ | L | 1 | 1 | 1 |
| 1 | 1 | 0 | 1 | D | CR | GS | - | $=$ | M | $]$ | m | \} |
| 1 | 1 | 1 | 0 | E | SO | RS | . | $>$ | N | $\widehat{ }$ | $n$ | $\sim$ |
| 1 | 1 | 1 | 1 | F | SI | US | 1 | ? | 0 | -- | - | DEL |


| NUL | Null | DLE | Data link escape |
| :--- | :--- | :--- | :--- |
| SOH | Start of heading | DC1-3 | Device control |
| STX | Start of text | DC4 | Device stop |
| ETX | End of text | NAK | Negative acknowledge |
| EOT | End of transmission | SYN | Synchronous idle |
| ENQ | Enquiry | ETB | End of transmission block |
| ACK | Acknowledge | CAN | Cancel |
| BEL | Audible signal | EM | End of medium |
| BS | Backspace | SUB | Start of special sequence |
| HT | Horizontal tabulation | ESC | Escape |
| LF | Line feed | FS | File separator |
| VT | Vertical tabulation | GS | Group separator |
| FF | Form feed | RS | Record separator |
| CR | Carrier return | US | Unit separator |
| SO | Shift out | SP | Space |
| SI | Shift in | DEL | Delete/Idle |

APPENDIX 7 (Continued)

ASCII CARD CODE CONVERSION TABLE

| GRAPHIC | $\begin{aligned} & \text { 7-BIT } \\ & \text { ASCII } \\ & \text { CODE } \end{aligned}$ | $\begin{aligned} & \text { CARD } \\ & \text { CODE } \end{aligned}$ | GRAPHIC | 7-BIT ASCII CODE | $\begin{aligned} & \text { CARD } \\ & \text { CODE } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SPACE | 20 | BLANK | @ | 40 | 8-4 |
| , | 21 | 11-8-2 | A | 41 | 12-1 |
| " | 22 | 8-7 | B | 42 | 12-2 |
| \# | 23 | 8--3 | C | 43 | 12-3 |
| \$ | 24 | 11-8-3 | D | 44 | 12-4 |
| \% | 25 | 0-8-4 | E | 45 | 12-5 |
| \& | 26 | 12 | F | 46 | 12-6 |
| 1 | 27 | 8-5 | G | 47 | 12-7 |
| ( | 28 | 12-8-5 | H | 48 | 12-8 |
| ) | 29 | 11-8--5 | I | 49 | 12-9 |
| * | 2A | 11-8-4 | J | 4A | 11-1 |
| + | 2B | 12-8-6 | K | 4B | 11-2 |
| , | 2 C | 0-8-3 | L | 4 C | 11-3 |
| - | 2D | 11 | M | 4D | 11-4 |
| - | 2E | 12-8-3 | N | 4 E | 11-5 |
| 1 | 2 F | 0-1 | O | 4 F | 11-6 |
| 0 | 30 | 0 | P | 50 | 11-7 |
| 1 | 31 | 1 | Q | 51 | 11-8 |
| 2 | 32 | 2 | R | 52 | 11-9 |
| 3 | 33 | 3 | S | 53 | 0-2 |
| 4 | 34 | 4 | T | 54 | 0-3 |
| 5 | 35 | 5 | U | 55 | 0-4 |
| 6 | 36 | 6 | V | 56 | 0-5 |
| 7 | 37 | 7 | W | 57 | 0-6 |
| 8 | 38 | 8 | X | 58 | 0-7 |
| 9 | 39 | 9 | Y | 59 | 0-8 |
| : | 3A | 8-2 | Z | 5A | 0-9 |
|  | 3B | 11-8-6 | [ | 5B | 12-8-2 |
| $<$ | 3 C | 12-8-4 | 1 | 5 C | 0-8-2 |
| $=$ | 3D | 8-6 | ] | 5D | 12-8-7 |
|  | 3 E | 0-8-6 | $\uparrow$ | 5 E | 11-8-7 |
| ? | 3 F | 0-8-7 | $\leftarrow$ | 5 F | 0-8-5 |

STANDARD－PREFERRED ADDRESS TABLE


AIC AMALGMPMT COMTROLLER QSA QLADSYNCHRONOLSADAPTER


## APPENDIX 8

## MODEL 8/32 MICRO INSTRUCTIONS

| FIXED POINT | Add | A |
| :---: | :---: | :---: |
| ARITHMETIC | Add and Transfer | AX |
| INSTRUCTIONS | Add Immediate | AI |
|  | Add and Increment | AINC |
|  | Add and Increment and Transfer | AINCX |
|  | Subtract | S |
|  | Subtract and Transfer | SX |
|  | Subtract Immediate | SI |
|  | Subtract and Decrement | SDEC |
|  | Subtract and Decrement and Transfer | SDECX |
|  | Multiply | M |
|  | Multiply and Transfer | MX |
|  | Multiply Immediate | MI |
|  | Divide | D |
|  | Divide and Transfer | DX |
|  | Divide Immediate | DI |
| LOGICAL | Load | L |
| INSTRUCTIONS | Load and Transfer | LX |
|  | Load Immediate | LI |
|  | Store | STR |
|  | And | N |
|  | And and Transfer | NX |
|  | And Immediate | NI |
|  | OR | O |
|  | OR and Transfer | OX |
|  | OR Immediate | OI |
|  | Exclusive OR | X |
|  | Exclusive OR and Transfer | XX |
|  | Exclusive OR Immediate | XI |
| BYTE HANDLING | Load Byte | LB |
| INSTRUCTIONS | Load Byte Register | LBR |
|  | Store Byte | STB |
|  | Store Byte Register | STBR |
|  | Exchange Byte | EXB |
| SHIFT ROTATE | Shift Left Logical | SLL |
| INSTRUCTIONS | Shift Left Logical and Transfer | SLLX |
|  | Shift Left Logical Immediate | SLLI |
|  | Shift Left Halfword Logical | SLHL |
|  | Shift Right Logical | SRL |
|  | Shift Right Logical and Transfer | SRLX |
|  | Shift Right Logical Immediate | SRLI |
|  | Shift Right Halfword Logical | SRHL |
|  | Shift Left Arithmetic | SLA |
|  | Shift Left Arithmetic and Transfer | SLAX |
|  | Shift Left Arithmetic Immediate | SLAI |
|  | Shift Left Halfword Arithmetic | SLHA |
|  | Shift Right Arithmetic | SRA |
|  | Shift Right Arithmetic and Transfer | SRAX |
|  | Shift Right Arithmetic Immediate | SRAI |
|  | Shift Right Halfword Arithmetic | SRHA |


| TYPE | INSITRUCTIONS | MNEMONIC |
| :---: | :---: | :---: |
|  | Rotate Left | RL |
|  | Rotate Left and Transfer | RLX |
|  | Rotate Left Immediate | RLI |
|  | Rotate Right | RR |
|  | Rotate Right and Transfer | RRX |
|  | Rotate Right Immediate | RRI |
| FLOATING POINT | Compare | CE |
| INSTRUCTIONS | Compare and Equalize | CEQ |
| (MODULE 3) | Compare and Equalize and Transfer | CEQX |
|  | Add | AE |
|  | Subtract | SE |
|  | Add Unnormalized | AU |
|  | Multiply | ME |
|  | Divide | DE |
| FLOATING POINT INSTRUCTIONS (MODULE 6 OR 4) | Read Condition Code | RCC |
|  | Load Double Precision | LD |
|  | Load Double Precision and Transfer | LDX |
|  | Load Double Precision Immediate | LDI |
|  | Load Double Unnormalized | LW |
|  | Load Double Unnormalized Immediate | LWI |
|  | Load Double Unnormalized and Transfer | LWX |
|  | Load Single Precision | LE |
| - | Load Single Precision Immediate | LEI |
|  | Load Single Precision and Transfer | LEX |
|  | Add Double Precision Register | ADR |
|  | Divide Double Precision Register | DDR |
|  | Subtract Double Precision Register | SDR |
|  | Multiply Double Precision Register | MDR |
|  | Compare Double Precision Register | CDR |
|  | Read Register Double Precision | RRD |
|  | Read Register Double Precision and Transfer | RRDX |
|  | Compare Single Precision | CER |
|  | Read Register Single Precision | RRE |
|  | Read Register Single Precision and Transfer | RREX |
|  | Add Single Precision Register | AER |
|  | Divide Single Precision Register | DER |
|  | Subtract Single Precision Register | SER |
|  | Multiply Single Precision Register | MER |
| BRANCH/EXECUTE | Branch and Link | BAL |
| AND LINK | Branch and Link and Arm Interrupts | BALA |
| INSTRUCTIONS | Branch and Link and Disarm Interrupts | BALD |
|  | Branch and Link on Zero | BALZ |
|  | Branch and Link on Not Zero | BALNZ |
|  | Branch and Link on Less | BALL |
|  | Branch and Link on Not Less | BALNL |
|  | Branch and Link on Greater | BALG |
|  | Branch and Link on Not Greater | BALNG |
|  | Branch and Link on Overflow | BALV |
|  | Branch and Link on No Overflow | BALNV |
|  | Branch and Link on Carry | BALC |
|  | Branch and Link on No Carry | BALNC |
|  | Branch and Link on True CC Match | BALT |
|  | Branch and Link on False CC Match | BALF |

APPENDIX 8 (Continued)

| Execute and Link | EXL |
| :--- | :--- |
| Execute and Link and Arm Interrupts | EXLA |
| Execute and Link and Disarm Interrupts | EXLD |
| Execute and Link on Zero | EXLZ |
| Execute and Link on Not Zero | EXLNZ |
| Execute and Link on Less | EXLL |
| Execute and Link on Not Less | EXLNL |
| Execute and Link on Greater | EXLG |
| Execute and Link on Not Greater | EXLNG |
| Execute and Link on Overflow | EXLV |
| Execute and Link on No Overflow | EXLNV |
| Execute and Link on Carry | EXLC |
| Execute and Link on True CC Match | EXLT |
| Execute and Link on No Carry | EXLNC |
| Execute and Link on False CC Match | EXLF |

INPUT/OUTPUT INSTRUCTIONS

Acknowledge Interrupt AK
Acknowledge Interrupt and Transfer AKX
Address and Sense Status SSA
Address and Sense Status and Transfer SSAX
Address and Sense Status Register SSRA
Sense Status SS
Sense Status and Transfer SSX
Sense Status Register SSR
Address and Output Command OCA
Address and Output Commands and Transfer OCAX
Address and Output Command Immediate OCAI
Address and Output Command Register OCRA
Output Command OC
Output Command and Transfer OCX
Output Command Immediate OCI
Output Command Register OCR
Address and Read Data RDA
Address and Read Data and Transfer RDAX
Address and Read Data Register RDRA
Read Data RD
Read Data and Transfer RDX
Read Data Register RDR
Address and Write Data WDA
Address and Write Data and Transfer WDAX
Address and Write Data Immediate WDAI
Address and Write Data Register WDRA
Write Data WD
Write Data and Transfer WDX
Write Data Immediate WDI
Write Data Register WDR
Address and Read Halfword RHA
Address and Read Halfword and Transfer RHAX
Read Halfword RH
Read Halfword and Transfer RHX
Address and Write Halfword WHA
Address and Write Halfword and Transfer WHAX
Write Halfword WH
Write Halfword and Transfer WHX

TYPE

CONTROL INSTRUCTIONS

INSTRUCTIONS
MNEMONIC

| Sense Machine Control Register | SMCR |
| :--- | :--- |
| Sense Machine Control Register and Transfer | SMCRX |
| Clear Machine Control Register | CMCR |
| Load the Wait Flip-Flop | LWFF |
| Pulse Output Lines | POUT |
| Branch and Disable Console Interrupt | BDC |
| Power Down | POW |

## INDEX

ARITHMETIC REFERENCES ..... A5-1
AUTO DRIVER CHANNEL ..... 7-19
AUTOLOAD ..... 7-14
BOOLEAN OPERATIONS ..... 2-2
BRANCHING ..... 3-1
BRANCH INSTRUCTION FORMATS ..... 1-10, 3-1
BRANCH INSTRUCTIONS ..... 3-2
Branch and Link ..... 3-5
Branch and Link Register ..... 3-5
Branch on False Condition ..... 3-4
Branch on False Condition Backward Short ..... 3-4
Branch on False Condition Forward Short ..... 3-4
Branch on False Condition Register ..... 3-4
Branch on Index High ..... 3-7/3-8
Branch on True Condition ..... 3-3
Branch on True Condition Backward Short ..... 3-3
Branch on True Condition Forward Short ..... 3-3
Branch on True Condition Register ..... 3-3
BUFFER ..... 7-21
CHANNEL COMMAND BLOCK ..... 7-20
CHANNEL COMMAND CODES ..... 7-23
CHANNEL COMMAND WORD ..... 7-22
Buffer Switch Bit (B) ..... 7-23
Check Type Bit (C) ..... 7-23
Cyclic Check Type Bit (S) ..... 7-23
Executive Bit (E) ..... 7-22
Fast Bit (F) ..... 7-22
Read/Write Bit (R/W) ..... 7-22
Status Mask ..... 7-22
Translate Bit (T) ..... 7-22
CHECK WORD ..... 7-21
CIRCULAR LIST ..... 2-3
CONDITION CODE ..... 1-5, 4-2, 5-8
CONSOLE INTERRUPT ..... 6-7, 11-7
CONTROL KEYS ..... 11-3
CONTROL OF I/O OPERATIONS ..... 7-16
CONVERSION FROM DECIMAL ..... 5-8
DATA ALIGNMENT ..... 1-9
DATA HANDLING INSTRUCTION FORMATS ..... 10-1
DATA HANDLING INSTRUCTIONS ..... 10-1
Move and Process Byte String Register ..... 10-5
Process Byte ..... 10-2
Process Byte Register ..... 10-4
DATA FORMATS ..... 1-8, 2-1, 4-1, 5-6
Fixed Point Data ..... 1-8
Floating Point Data ..... 1-8
Logical Data ..... 1-9
DECISION MAKING ..... 3-1
DEVICE ADDRESSING ..... 7-2
DEVICE CONTROLLERS ..... 7-1
DEVICE PRIORITIES ..... 7-2
DISPLAY REGISTERS AND INDICATORS ..... 11-2
DISPLAY STATUS AND COMMAND ..... 10-10

## INDEX (Continued)

EQUALIZATION ..... 5-5
EXPONENT OVERFLOW ..... 5-6
EXPONENT UNDERFLOW ..... 5-6
EXTENDED BRANCH MNEMONICS ..... A4-1
FIXED POINT ARITHMETIC ..... 4-1
FIXED POINT DATA WORDS FORMATS ..... 4-1
FIXED POINT INSTRUCTION FORMATS ..... 4-3
FIXED POINT INSTRUCTIONS ..... 4-3
Add ..... 4-4
Add Halfword ..... 4-5
Add Halfword Immediate ..... 4-5
Add Halfword to Memory ..... 4-7
Add Immediate ..... 4-4
Add Immediate Short ..... 4-4
Add Register ..... 4-4
Add to Memory .....  4-6
Compare ..... 4-10
Compare Halfword ..... 4-11
Compare Halfword Immediate ..... 4-11
Compare Immediate ..... 4-10
Compare Register ..... 4-10
Convert to Halfword Value Register ..... 4-22
Divide ..... 4-14
Divide Halfword ..... 4-16
Divide Halfword Register ..... 4-16
Divide Register ..... 4-14
Multiply ..... 4-12
Multiply Halfword ..... 4-13
Multiply Halfword Register ..... 4-13
Multiply Register ..... 4-12
Shift Left Arithmetic ..... 4-18
Shift Left Halfword Arithmetic ..... 4-19
Shift Right Arithmetic ..... 4-20
Shift Right Halfword Arithmetic ..... 4-21
Subtract ..... 4-8
Subtract Halfword ..... 4-9
Subtract Half word Immediate ..... 4-9
Subtract Immediate ..... 4-8
Subtract Immediate Short ..... 4-8
Subtract Register ..... 4-8
FLOATING/FIXED POINT RANGES ..... 5-4
FLOATING POINT INSTRUCTION FORMATS ..... 5-8
FLOATING POINT INSTRUCTIONS ..... 5-8
Add Double Precision Floating Point ..... 5-29
Add Floating Point ..... 5-14
Add Floating Point Register ..... 5-14
Add Register Double Precision Floating Point ..... 5-29
Compare Double Precision Floating Point ..... 5-31
Compare Floating Point ..... 5-18
Compare Floating Point Register ..... 5-18
Compare Register Double Precision Floating Point ..... 5-31
Divide Double Precision Floating Point ..... 5-33
Divide Floating Point ..... 5-21
Divide Floating Point Register ..... 5-21
Divide Register Double Precision Floating Point ..... 5-33
Fix Register ..... 5-23
Fix Register Double Precision ..... 5-34
Float Register ..... 5-24
Float Register Double Precision ..... 5-35/5-36
Load Double Precision Floating Point ..... 5-25

## INDEX (Continued)

Load Floating Point ..... 5-10
Load Floating Point Multiple ..... 5-1
Load Floating Point Register ..... 5-10
Load Multiple Double Precision Floating Point ..... 5-26
Load Register Double Precision Floating Point ..... 5-25
Multiply Double Precision Floating Point ..... 5-32
Multiply Floating Point ..... 5-19
Multiply Floating Point Register ..... 5-19
Multiply Register Double Precision Floating Point ..... 5-32
Store Double Precision Floating Point ..... 5-27
Store Floating Point ..... 5-12
Store Floating Point Multiple ..... 5-13
Store Multiple Double Precision Floating Point ..... 5-28
Subtract Double Precision Floating Point ..... 5-30
Subtract Floating Point ..... 5-16
Subtract Floating Point Register ..... 5-16
Subtract Register Double Precision Floating Point ..... 5-30
FLOATING POINT NUMBER ..... 5-3
FLOATING POINT NUMBER RANGE ..... 5-4
FLOATING POINT REGISTER ..... 1-7
FLOATING POINT REGISTER DISPLAY ..... 11-6
FLOATING POINT REGISTER DISPLAY (LATER VERSIONS OF 8/32) ..... 11-6
GENERAL REGISTER ..... 1-7
GENERAL REGISTER DISPLAY ..... 11-6
GUARD DIGIT AND ROUNDING ..... 5-7
HEXADECIMAL DISPLAY PANEL ..... 11-1
HEXADECIMAL DISPLAY PANEL DATA TRANSFERS ..... 11-8
INPUT/OUTPUT INSTRUCTION FORMATS ..... 7-3
INPUT/OUTPUT INSTRUCTIONS ..... 7-3
Autoload ..... 7-14
Output Command ..... 7-4
Output Command Register ..... $7-4$
Read Block ..... 7-8
Read Block Register ..... $7-9$
Read Data ..... 7-6
Read Data Register ..... $7-6$
Read Halfword ..... 7-7
Read Halfword Register ..... 7-7
Sense Status ..... 7-5
Sense Status Register ..... $7-5$
Simulate Channel Program ..... 7-15
Write Block ..... 7-12
Write Block Register ..... 7-13
Write Data ..... 7-10
Write Data Register ..... 7-10
Write Halfword ..... 7-11
Write Halfword Register ..... 7-11
INPUT/OUTPUT PROGRAMMING ..... 11-9
INPUT/OUTPUT OPERATIONS ..... 7-1
INPUT/OUTPUT REFERENCES ..... A7-1
INPUT/OUTPUT SYSTEM CONFIGURATION ..... 7-1
INSTRUCTION FORMATS ..... 1-9
Branch Instruction Formats ..... 1-10
Register and Immediate Storage One (RI1) Format ..... 1-16
Register and Immediate Storage Two (RI2) Format ..... 1-17
Register and Indexed Storage One (RX1) Format ..... 1-12
Register and Indexed Storage Two (RX2) Format ..... 1-13

## INDEX (Continued)

Register and Indexed Storage Three (RX3) Format ..... 1-15
Short Form (SF) Format ..... 1-10
INSTRUCTION SUMMARY - ALPHABETICAL WITH ATTRIBUTES ..... A2-1
INSTRUCTION SUMMARY - NUMERICAL ..... A3-1
INTERRUPT SERVICE POINTER TABLE ..... 7.2
INTERRUPT STATUS REGISTER ..... 8-6
INTERRUPT SYSTEM ..... 6-4
Arithmetic Fault Interrupt ..... 6-9
Console Interrupt ..... 6-7
Illegal Instruction Interrupt ..... 6-10
Immediate Interrupt ..... 6-6
Machine Malfunction Interrupt ..... 6-8
Protect Mode Violation Interrupt ..... 6-10
Relocation/Protection Interrupt ..... 6-9
Simulated Interrupt ..... 6-7
Supervisor Call Interrupt ..... 6-10
System Queue Service Interrupt ..... 6-10
INTERRUPT SYSTEM BLOCK DIAGRAM ..... 6-5
KEY OPERATED SECURITY LOCK ..... 11-3
LIST PROCESSING ..... 2-3
LOGICAL DATA ..... 2-1
LOGICAL INSTRUCTION FORMATS ..... 2-4
LOGICAL INSTRUCTIONS ..... 2-4
Add to Bottom of List ..... 2-45
Add to Top of List ..... 2-45
AND ..... 2-21
AND Halfword ..... 2-22
AND Halfword Immediate ..... 2-22
AND Immediate ..... 2-21
AND Register ..... 2-21
Compare Logical ..... 2-18
Compare Logical Byte ..... 2-19
Compare Logical Halfword ..... 2-19
Compare Logical Halfword Immediate ..... 2-19
Compare Logical Immediate ..... 2-18
Compare Logical Register ..... 2-18
Complement Bit ..... 2-38
Cyclic Redundancy Check Modulo 12 ..... 2-40
Cyclic Redundancy Check Modulo 16 ..... 2-40
Exchange Byte Register ..... 2-12
Exchange Halfword Register ..... 2-13
Exclusive OR ..... 2-25
Exclusive OR Halfword ..... 2-26
Exclusive OR Halfword Immediate ..... 2-26
Exclusive OR Immediate ..... 2-25
Exclusive OR Register ..... 2-25
Load ..... 2-5
Load Address ..... 2-7
Load Byte ..... 2-11
Load Byte Register ..... 2-11
Load Complement Short ..... 2-5
Load Halfword ..... 2-6
Load Halfword Immediate ..... 2-6
Load Halfword Logical ..... 2-9
Load Immediate ..... 2-5
Load Immediate Short ..... 2-5
Load Multiple ..... 2-10
Load Real Address ..... 2-8

## INDEX (Continued)

Load Register ..... 2-5
OR ..... 2-22
OR Halfword ..... 2-24
OR Halfword Immediate ..... 2-24
OR Immediate ..... 2-23
OR Register ..... 2-23
Remove from Bottom of List ..... 2-46
Remove from Top of List ..... 2-46
Reset Bit ..... 2-39
Rotate Left Logical ..... 2-33
Rotate Right Logical ..... 2-34
Set Bit ..... 2-37
Shift Left Halfword Logical ..... 2-31
Shift Left Halfword Logical Short ..... 2-31
Shift Left Logical ..... 2-29
Shift Left Logical Short ..... 2-29
Shift Right Halfword Logical ..... 2-32
Shift Right Halfword Logical Short ..... 2-32
Shift Right Logical ..... 2-30
Shift Right Logical Short ..... 2-30
Store ..... $2-14$
Store Byte ..... 2-17
Store Byte Register ..... 2-17
Store Halfword ..... 2-15
Store Multiple ..... 2-16
Test and Set ..... 2-35
Test Bit ..... 2-36
Test Halfword Immediate ..... 2-28
Test Immediate ..... 2-27
Translate ..... 2-42
MAC REGISTERS ..... 8-4
Definition of MAC Register Fields ..... 8-5
Interrupt Status Register ..... 8-6
Segmentation Register ..... 8-5
MEMORY READ ..... 11-5
MEMORY WRITE ..... 11-5
MICRO CODE FLOW CHART OF AUTO DRIVER CHANNEL ..... 7-24
MODEL 8/32 BLOCK DIAGRAM ..... 9-2
MODEL 8/32 EXECUTION TIMES IN MICROSECONDS ..... A6-1
MODEL 8/32 INSTRUCTION FORMATS ..... 9-3
MODEL 8/32 MICRO INSTRUCTIONS ..... A8-1
MODEL 8/32 PROCESSOR BLOCK DIAGRAM ..... 1-2
OP-CODE MAP ..... A1-1
OPERATING PROCEDURES ..... 11-5
Console Interrupt ..... 11-7
Floating Point Register Display ..... $11-6$
Floating Point Register Display (later versions of 8/32) ..... 11-6
General Register Display ..... 11-6
Memory Read ..... 11-5
Memory Write ..... 11-5
Power Down ..... 11-5
Power Fail ..... 11-7
Power Up ..... $11-5$
Program Execution ..... 11-7
Program Status Word Display and Modification ..... 11-6
Program Termination ..... 11-7
Switch Register ..... 11-7
OPERATIONS ..... 3-1, 4-1

## INDEX (Continued)

POWER DOWN ..... 11-5
POWER FAIL ..... $11-7$
POWER UP ..... 11-5
PROCESSING INSTRUCTIONS ..... 2-47
PROCESSOR ..... 1-1
PROCESSOR/CONTROLLER COMMUNICATION ..... 7-2
PROCESSOR INTERRUPTS ..... $1-7$
PROCESSOR OPERATIONS ..... 1-8
PROGRAM EXECUTION ..... 11-7
PROGRAMMING INSTRUCTIONS ..... 11-9
PROGRAMMING SEQUENCES ..... 11-9
PROGRAM STATUS WORD ..... 1-4, 6-1
Arithmetic Fault Interrupt Mask (A) ..... 1-5
Condition Code (CVGL) ..... 1-5
Immediate Interrupt/Auto Driver Channel Mask (I) ..... 1-4
Location Counter (LOC) ..... 1-5
Protect Mode (P) ..... 1-5
Register Set Select (R) ..... 1-5
Relocation Protection Interrupt Mask (R/P) ..... $1-5$
System Queue Service Interrupt Mask (Q) ..... $1-5$
Wait State (W) ..... 1-4
PROGRAM STATUS WORD DISPLAY AND MODIFICATION ..... 11-6
PROGRAM TERMINATION ..... 11-7
PROTECTION ..... 8-1
PROTECT MODE ..... 6-2
REGISTER SET NUMBERING ..... 1-6
REGISTER SET SELECTION ..... 6-2
RELOCATION ..... 8-1
RESERVED MEMORY LOCATION ..... 1-7
SEGMENTATION REGISTERS ..... $.8-5,8-6$
SELECTOR CHANNEL I/O ..... 7-18
Selector Channel Devices ..... 7-18
Selector Channel Programming ..... 7-19
Selector Channel Operation ..... 7-18
STATUS MONITORING I/O ..... 7-16
STATUS SWITCHING AND INTERRUPTS ..... 6-1
STATUS SWITCHING INSTRUCTION FORMATS ..... 6-11
STATUS SWITCHING INSTRUCTIONS ..... 6-11
Exchange Program Status Register ..... 6-14
Load Program Status Word ..... 6-12
Load Program Status Word Register ..... 6-13
Simulate Interrupt ..... 6-15
Supervisor Call ..... 6-16
SUBROUTINE ADDRESS ..... 7-20
SUBROUTINE LINKAGE .....  3-1
SWITCH REGISTER ..... 11-7
TRANSLATION ..... 2-2, 7-21
TRANSLATION TABLE ENTRY ..... 2-2
WAIT STATE ..... 1-4, 6-2
WRITABLE CONTROL STORE INSTRUCTIONS ..... 9-2
Branch to Control Store ..... 9.6
Enter Control Store ..... 9-7/9-8
Read Control Store ..... 9-5
Write Control Store ..... 9-4

Check the appropriate item.

Page No. $\qquad$ Drawing No. $\qquad$
$\square$ Addition Page No. $\qquad$ Drawing No. $\qquad$
$\square$ Other Page No. $\qquad$ Drawing No. $\qquad$
Explanation:

FOLD
FOLD


| BUSINESS REPLY MAIL |  |  |
| :---: | :---: | :---: |
| FIRSt CLASS | PERMIT NO. 22 | OCEANPORT, N.J. |

POSTAGE WILL BE PAID BY ADDRESSEE
PERMRMNEEMMER
Computer Systems Division
2 Crescent Place
Oceanport, NJ 07757

TECH PUBLICATIONS DEPT. MS 322A


