## SIGMA 7

 CENTRAL PROCESSORMODEL 8401 ASSEMBLY NO. 117307


## Publication <br> $D_{\text {ata }}$ Quick

PDQ NO. 72-056
PUBLICATION NO. 901060B-1
DATE November 1972

TO: ALL HOLDERS OF XEROX Sigma 7 Central Processor, Model 8401
SUBJECT: TEMPORARY CHANGES TO TECHNICAL MANUAL

The following changes to Technical Manual 901060 B __are necessary to reflect the latest technical information. The changes are released in this manner for purposes of expediency.
The next scheduled revision to the manual will incorporate these changes formally.
PURPOSE: To make corrections in the Environmental Requirements (temperature and humidity) and Primary Power Requirements in this technical manual.

INSTRUCTIONS: Make the following pen and ink changes:

1. Page 1-7, Table 1-3. General Specifications: Under the Specification column for Temperature (electronics), Operating, change to read... $60^{\circ} \mathrm{F}$ to $90^{\circ} \mathrm{F}$; under Characteristics column, immediately below Temperature (electronics), Operating, add the category Relative Humidity and in the Specification column for the Relative Humidity add $25 \%$ to $80 \%$.
2. Remove and destroy old title page, insert new title page.

Insert this PDQ instruction sheet between the cover and title page of the manual. Do not remove until this change has been incorporated in a released or re-issue of the technical manual.

# TECHNICAL MANUAL <br> SIGMA 7 CENTRAL PROCESSOR <br> MODEL 8401 ASSEMBLY NO. 117307 

Specifications, equipment descriptions, and procedures contained herein are subject to change without notice.

November 1972

This revision is a supplement to 901060B, dated March 1970

Prepared by
Field Engineering Publications

## Publication

PDQ NO. 71-016
Data Quck

TO: ALL HOLDERS OF XDS Sigma 7 Computer
SUBJECT: TEMPORARY CHANGES TO TECHNICAL MANUAL

The following changes to Technical Manual XDS 901060B are necessary to reflect the latest technical information. The changes are released in this manner for purposes of expediency. The next scheduled revision to the manual will incorporate these changes formally.

PURPOSE: The purpose of this PDQ is to correct the phase sequence charts per Technical Action Report No. 20890.

INSTRUCTIONS: Make the following changes to the manual with pen and ink.

1. Page 3-661, table 3-143: Add timing signal "T6L" to the Phase column of the table under PCP2.
2. Page 3-663, table 3-143: Add timing signal "T6L" to the Phase column in two places in the table: under PCP7 and PCP1.
3. Page 3-665, table 3-144: Add timing signal "T6L" to the Phase column of the table under PCP2.
4. Page 3-666, table 3-144: Add timing signal "T6L" to the Phase column of the table under PCP2.
5. Page 3-668, table 3-145: In the "Function Performed" column for phase PCP3, change Q15-Q31 $\rightarrow$ PO-P31 to read Q15-Q31 $\rightarrow$ P15-P31.

0
Page 2_of

## INSTRUCTIONS (Cont.)

6. Page 3-669, table 3-145:
a. In the "Signals Involved" column for phase PCP5, change:

$$
\begin{gathered}
\text { LB15-LB31 = P15-P31 NCMXQ NCMXC } \\
\text { to read }
\end{gathered}
$$

LB15-LB31 = P15-P31 NLMXQ NLMXC
b. Add timing signal "T6L" to the Phase column of the table under PCP2.
7. Page 3-670 and page 3-671, table 3-146: Add timing signal "T6L" (one place on each page) to the Phase column of the table under PCP2.
8. Page 3-674, table 3-147, and page 3-676, table 3-148: Add timing signal "T6L" (one place on each page) to the Phase column of the table under PCP2.
9. Page 3-679, table 3-149: Change the first entry in the "Function Performed" column from "Repeated until switch released" to "Repeated until P28 goes high".
10. Page 3-680, table 3-149: Add a horizontal line through the middle of the table to separate the PCP6 phases from the PCP7 phases.
11. Page 3-681, table 3-149: Add timing signal "T6L" to the Phase column of the table under PCP2.

Xerox Data Systems

Publication $D_{\text {ara }}$ aube

PDQ NO. 70-053
PUBLICATION NO. XDS 901060B
DATE 8 June 1970

TO: ALL HOLDERS OF XDS Sigma 7 Central Processor Mode 1 8401 Assembly 117307 SUBJECT: TEMPORARY CHANGES TO TECHNICAL MANUAL

The following changes to Technical Manual XDS 901060B__ are necessary to reflect the latest technical information. The changes are released in this manner for purposes of expediency. The next scheduled revision to the manual will incorporate these changes formally.

PURPOSE: The purpose of this PDQ is to update the text and illustrations that apply to the power monitor change affected by Field Modification Kit 8001, 8201, 8401 (drawing 159871).

INSTRUCTIONS: Make the following changes to the manual with pen and ink:

1. Page 3-128, paragraph 3-98. Change AT13 line driver (or module) to AT68 line driver (or module). Total of seven changes.
2. Page 3-129, figure 3-117. Change LINE DRIVER AT13 to LINE DRIVER AT68
3. Page 3-129, paragraph 3-103. Change AT13 modules to AT68 modules
4. Page 3-129, paragraph 3-105. Change AT13 line drivers to AT68 line drivers
5. Page 3-130, Figure 3-118:
a. Change AT13 (below J3) to AT68.
b. Add pin 44 to lower part of J3.
c. Add a connecting line between pin 44 of $J 3$ and pin 8 of P1. Label the connection "+ 60 V filtered".
6. Pages 3-140 and 3-142, paragraph 3-107. Change AT13 to AT68 (three places)

# TECHNICAL MANUAL SIGMA 7 CENTRAL PROCESSOR <br> MODEL 8401 ASSEMBLY NO. 117307 

Specifications, equipment descriptions, and procedures contained herein are subject to change without notice.

March 1970

This publication supersedes 901060A-1, . dated January 1967, revised April 1967

Prepared by
Field Engineering Publications

## LIST OF EFFECTIVE PAGES

Total number of pages is 826 , as follows:

| Page No. | Issue | Page No. | Issue |
| :---: | :---: | :---: | :---: |
| Title | Original |  |  |
| A.... | Original |  |  |
| i thru xx | Original |  |  |
| 1-1 thru 1-8. | Original |  |  |
| 2-1 thru 2-14. | Original |  |  |
| 3-1 thru 3-736. | Original |  |  |
| 4-1 thru 4-10.. | Original |  |  |
| A-1 thru A-36. | Original |  |  |

## FOREWORD

This B reissue supersedes XDS publication No. 901060A (preliminary) and contains the following information and changes:

1. Incorporation of the latest revision of all applicable engineering drawings
2. Incorporation, in section IV, of the information previously released in the form of Publications Data Quick (PDQ) 70-001. PDQ 70-001 relates to the replacement of miniature incandescent lamps that are mounted on the processor control panel
3. Deletion of sections $V$ through VIII
4. Addition of an appendix which includes a parts list

## tABle OF CONTENTS

Section Title Page
I GENERAL DESCRIPTION ..... 1-1
1-1 Introduction ..... 1-1
1-2 Physical Description ..... 1-1
1-3 Basic Computer System ..... 1-1
1-4 Optional Features. ..... 1-1
1-5 Cabinet Types ..... 1-1
1-6 Computer Configuration ..... 1-4
1-7 Functional Description. ..... 1-4
1-8 Basic Computer System. ..... 1-4
1-9 Optional Features ..... 1-4
1-10 Two Additional Real-Time Clocks ..... 1-4
1-11 Power Fail-Safe Feature ..... 1-4
1-12 Memory Protection ..... 1-6
1-13 Memory Map ..... 1-6
1-14 Private Memory Register Extension ..... 1-6
1-15 Floating Point Feature ..... 1-6
1-16 Decimal Arithmetic Feature ..... 1-6
1-17 External Interrupts ..... 1-6
1-18 Memory Expansion ..... 1-6
1-19 Memory Port Expansion ..... 1-6
1-20 Additional Eight Subchannels (IOP). ..... 1-6
1-21 Selector Input/Output Processor. ..... 1-6
1-22 System Supervisory Console ..... 1-7
1-23 Six Internal Interrupt Levels ..... 1-7
1-24 Specifications ..... 1-7
II OPERATION AND PROGRAMMING. ..... 2-1
2-1 Introduction. ..... 2-1
2-2 Operation ..... 2-1
2-3 Controls and Indicators ..... 2-1
2-4 Operating Procedures. ..... 2-1
2-5
Applying Power. ..... 2-1
Displaying Contents of Memory Location ..... 2-1
Selected Address. ..... 2-1
Instruction Address ..... 2-1
Changing Contents of a Memory Location. ..... 2-1
Selected Address. ..... 2-1
Instruction Address ..... 2-9
Changing the Current Program Status Doubleword ..... 2-9
Manual Branching. ..... 2-9
Stepping Through Program ..... 2-10
Single Clocking an Instruction ..... 2-10
Single Instruction Repetition ..... 2-10
Loading Program ..... 2-102-19Programming.2-11
Basic Instructions ..... 2-11
2-20 Computer Modes ..... 2-11

## TABLE OF CONTENTS (Cont.)

Section Title Page
III PRINCIPLES OF OPERATION ..... 3-1
3-1 Introduction ..... 3-1
3-2 General Principles ..... 3-1
3-3 Core Memory ..... 3-1
3-4 Three-Wire Core Selection ..... 3-23-5Introduction3-18
3-36 Circuit Description ..... 3-18
Typical T-Series Circuit ..... 3-19
Integrated Circuits ..... 3-19
3-38
Data Paths ..... 3-2
Memory Timing ..... 3-3
Interleaving ..... 3-4
Central Processing Unit ..... 3-4
Private Memory ..... 3-4
Arithmetic and Control Section ..... 3-4
Processor Control Panel ..... 3-8
Internal Interrupt Circuits ..... 3-8
Clock Generator ..... 3-8
Real-Time Clock ..... 3-9
Watchdog Timer ..... 3-9
Power Supplies ..... 3-10
Optional Features ..... 3-10
Decimal Arithmetic Unit ..... 3-10
Floating Point Arithmetic Feature ..... 3-10
External Interrupts ..... 3-10
Power Fail-Safe Feature ..... 3-10
Two Additional Real-Time Clocks ..... 3-11
Additional Private Memory Register Banks ..... 3-11
Memory Map ..... 3-11
Memory Protection Feature ..... 3-11
Basic Timing Characteristics ..... 3-13
Central Processor Operations ..... 3-13
Processor Control Panel Operations ..... 3-14
Interrupt Operation. ..... 3-14
Trap Operation ..... 3-15
Input/Output Channel ..... 3-15
Multiplexing Input/Output Processor ..... 3-15
IOP Priority ..... 3-17
Detailed Principles
3-31
3-31
CPU Information Transfer and Storage
CPU Information Transfer and Storage ..... 3-31
Control and Data Registers
3-31
3-31
B-Register. ..... 3-36
C-Register ..... 3-36
Condition Code Register ..... 3-43
CS-Register ..... 3-43
D-Register ..... 3-44
E-Register ..... 3-45
O-Register ..... 3-45
P -Register ..... 3-45

## TABLE OF CONTENTS (Cont.)

Section Title Page
Q-Register ..... 3-52
R-Register ..... 3-52
RP-Register ..... 3-55
Private Memory Registers ..... 3-55
Register Extension Chassis (REU) ..... 3-60
Sum Bus ..... 3-65
Adder. ..... 3-65
Adder Operation ..... 3-68
Generate Signal ..... 3-68
Propagate Signal ..... 3-72
Carry Signal ..... 3-72
Sum Bus Output. ..... 3-73
Addition ..... 3-74
Exclusive OR Operation ..... 3-74
AND and OR Operations ..... 3-74
Complementing ..... 3-77
Upward Alignment ..... 3-77
Register Gating ..... 3-77
Display Lamp Gating. ..... 3-82
Load Gating ..... 3-82
Fixed-Point Overflow ..... 3-82
Fixed-Point End Carry ..... 3-85
Basic Timing ..... 3-86
Clock Generator ..... 3-86
Clock-Enabling Function ..... 3-97
TIL Clock Generation ..... 3-97
TIL Post Enabling Function ..... 3-99
Trip Counter ..... 3-100
Timing Request Flip-Flops. ..... 3-101
Clock Enabling Logic Circuits ..... 3-101
Single Clock Generation ..... 3-103
Memory Map ..... 3-105
Map Register Organization ..... 3-105
Loading the Memory Map ..... 3-105
Program Control Code Organization ..... 3-107
Loading the Program Control Codes ..... 3-107
Using the Memory Map ..... 3-107
Memory Map Control Registers ..... 3-116
Program Control Registers ..... 3-116
Memory Protection ..... 3-120
Memory Protection Register Organization ..... 3-120
Loading the Write Locks ..... 3-120
Using the Write Locks ..... 3-123
Watchdog Timer ..... 3-123
Real-Time Clocks ..... 3-123
Power Fail-Safe ..... 3-128
General. ..... 3-128
Power Fail-Safe Interrupts ..... 3-128
Power Monitor Assembly ..... 3-128
Real-Time Clock Line Frequency ..... 3-128

## TABLE OF CONTENTS (Cont.)

Section Title Page
3-100 Input Requirements ..... 3-129
3-101 Three-Phase Input Detection ..... 3-129
3-102 Single-Phase Detection ..... 3-129
3-103 Internal Power Supply ..... 3-129
3-104 Parallel Operation ..... 3-1293-105
Output Signals ..... 3-129
3-106 Circuit Description ..... 3-129
Power Monitor Logic ..... 3-140
3-107
nterrupts ..... 3-142Interrupt Control3-142Interrupt Levels3-142
3-111 Interrupt Sequence ..... 3-142
3-1123-113Interrupt Circuits3-143
3-1143-1153-1163-117Power Fail-Safe Interrupts3-143
Count Pulse Interrupts ..... 3-144
Memory Parity Interrupt ..... 3-145
Counter-Equals-Zero Interrupts ..... 3-145
Input/Output Interrupt ..... 3-145
Control Panel Interrupt ..... 3-145
3-119 Priority Signals ..... 3-145
3-120 Priority Chain Signals ..... 3-146
3-121 Group Control ..... 3-146Memory Address Control3-146
Service Routine Sequence ..... 3-1473-124
Modify and Test Sequence ..... 3-1523-12
3-125 External Interrupts ..... 3-153
3-126 Write Direct Interrupt Operation ..... 3-153CPU Interrupt Sequence3-155
3-128 Traps ..... 3-156
3-129 Nonallowed Operation ..... 3-160
3-130 Nonexistent Instruction ..... 3-160
3-131 Nonexistent Memory Address ..... 3-160
3-132 Privileged Instruction in Slave Mode ..... 3-160
3-133 Memory Protection Violation ..... 3-160
3-134 Unimplemented Instructions ..... 3-161
3-135 Push-Down Stack Limits ..... 3-161
3-136 Fixed-Point Overflow ..... 3-161
3-137 Floating Point Arithmetic Fault Condition ..... 3-162
3-138 Decimal Arithmetic Fault ..... 3-162
3-139 Watchdog Timer Runout ..... 3-163
3-140 Call Instructions ..... 3-163
3-141 CPU Trap Sequence ..... 3-163
3-142 Trap Addressing ..... 3-164
3-143 Instruction Analysis ..... 3-164
3-144 Data Formats ..... 3-164
3-145 Instruction Formats ..... 3-164
3-146 Instruction Code ..... 3-164
3-147 Opcode Families ..... 3-164
3-148 Operation Code Decoding ..... 3-164
3-149 Function Code Logic ..... 3-179

## TABLE OF CONTENTS (Cont.)

Section Title ..... PageFamily Code Logic3-179
3-151 Logic Simplification ..... 3-182
3-152 Instruction Timing ..... 3-184
3-153 Phases ..... 3-184
3-154 Memory Request Timing ..... 3-184
3-155 Memory Addressing ..... 3-1983-156Core Memory
3-198
3-157
3-157 ..... 3-198
3-158 Memory Addressing With Mapping ..... 3-206
3-159 Private Memory ..... 3-2063-160
Instruction Description ..... 3-2083-161
3-161 Preparation Sequence ..... 3-208
3-162 General Preparation ..... 3-208
3-163 Indirect Addressing ..... 3-208
3-164 Indexing ..... 3-2103-1653-166Load Immediate (LI 22, 62)3-2103-167Load Byte (LB 72, F2)3-210
3-210Load Halfword (LH 52, D2)
3-168 Load Word (LW 32, B2) ..... 3-220
3-169 Load Doubleword (LD 12, 92) ..... 3-220
3-170 Load Complement Halfword (LCH 5A, DA) ..... 3-220
3-171 Load Absolute Halfword (LAH 5B, DB) ..... 3-220
3-172 Load Complement Word (LCW 3A, BA) ..... 3-220
3-173 Load Absolute Word (LAW 3B, BB) ..... 3-220
3-174 Load Complement Doubleword (LCD 1A, 9A) ..... 3-220
3-175 Load Absolute Doubleword (LAD 1B, 9B) ..... 3-235
3-176 Load Selective (LS 4A, CA) ..... 3-235
3-177 Load Multiple (LM 2A, AA) ..... 3-247
3-178 Load Conditions and Floating Control Immediate (LCFI 02, 82) ..... 3-247
3-179 Load Conditions and Floating Control (LCF 70, F0) ..... 3-247
3-180 Exchange Word (XW 46, C6) ..... 3-247
3-181 Store Byte (STB 75, F5) ..... 3-247
3-182 Store Halfword (STH 55, D5) ..... 3-247
3-183 Store Word (STW 35, B5) ..... 3-247
3-184 Store Doubleword (STD 15, 95) ..... 3-247
3-185 Store Selective (STS 47, C7) ..... 3-259
3-186 Store Multiple (STM 2B, AB) ..... 3-259
3-187 Store Conditions and Floating Control (STCF 74, F4) ..... 3-259
3-188 Analyze (ANLZ 44, C4) ..... 3-259
3-189 Interpret (INT 6B, EB) ..... 3-270
3-190 Add Immediate (AI 20) ..... 3-270
3-191 Add Halfword (AH 50, D0) ..... 3-270
3-192 Add Word (AW 30, B0) ..... 3-270
3-193 Add Doubleword (AD 10, 90) ..... 3-281
3-194 Subtract Halfword (SH 58, D8) ..... 3-281
3-195 Subtract Word (SW 38, B8) ..... 3-281
3-196 Subtract Doubleword (SD 18, 98) ..... 3-2813-197 Multiply Word (MW 37, B7), Multiple Immediate (MI 23), andMultiply Halfword (MH 57, D7)3-295

## TABLE OF CONTENTS (Cont.)

Section Title PageMultiplication by Bit-Pairs and Carry-Save Addition3-295
3-199 Description of Multiply Word and Multiply Immediate Instructions ..... 3-297
3-200 Description of Multiply Halfword Instruction ..... 3-307
3-201 Divide Word (DW 36, B6) and Divide Halfword (DH 56, D6) ..... 3-319
Nonrestoring Division ..... 3-320
3-202
Description of Divide Word Instruction ..... 3-328
3-204 Description of Divide Halfword Instruction ..... 3-338
3-205 Add Word to Memory (AWM 66, E6) ..... 3-345
3-206 Modify and Test Byte (MTB 73, F3) ..... 3-345
3-207 Modify and Test Halfword (MTH 53, D3) ..... 3-345
3-208 Modify and Test Word (MTW 33, B3) ..... 3-353
3-209 Compare Immediate (CI 21) ..... 3-353
3-210 Compare Byte (CB 71, F1) ..... 3-362
3-211 Compare Halfword (CH 51, D1) ..... 3-362
3-212 Compare Word (CW 31, B1) ..... 3-369
3-213 Compare Doubleword (CD 11, 91) ..... 3-369
3-214 Compare Selective (CS 45, C5) ..... 3-376
3-215 Compare With Limits in Registers (CLR 39, B9) ..... 3-376
3-216 Compare With Limits in Memory (CLM 19, 99) ..... 3-383
3-217 OR Word (OR 49, C9) ..... 3-383
3-218 Exclusive OR Word (EOR 48, C8) ..... 3-383
3-219 AND Word (AND 4B, CB) ..... 3-391
3-220 Shift (S 25, A5) ..... 3-391Shift Phase3-391
Shift Count ..... 3-396
Shift Floating (SF 24, A4) ..... 3-396
Short Format ..... 3-397
Long Format ..... 3-404
Short and Long Format ..... 3-404
Convert by Subtraction (CVS 28, A8) ..... 3-4153-22Convert by Addition (CVA 29, A9)3-4153-2293-230Move Byte String (MBS 61)3-419
Compare Byte String (CBS 60) ..... 3-424
3-23 Translate Byte String (TBS 41) ..... 3-424
3-232 Translate and Test Byte String (TTBS 40) ..... 3-445
3-23 Push Word (PSW 09, 89) ..... 3-461
3-23 Pull Word (PLW 08, 88) ..... 3-464
3-235 Push Multiple (PSM 0B, 8B) ..... 3-473
3-236 Pull Multiple (PLM 0A, 8A) ..... 3-479
3-23 Modify Stack Pointer (MSP 13, 93) ..... 3-487
3-238
3-239 Branch on Conditions Set (BCS 69, E9) ..... 3-498 ..... 3-502
3-240 Branch on Conditions Reset (BCR 68, E8) ..... 3-502
3-241 Branch on Incrementing Register (BIR 65, E5) ..... 3-502
3-242 Branch on Decrementing Register (BDR 64, E4) ..... 3-506
3-243 Branch and Link (BAL 6A, EA) ..... 3-506
3-24 Call 1 (CAL1, 04), Call 2 (CAL2, 05), Call 3 (CAL3, 06), Call 4 (CAL4, 07) ..... 3-506
3-24 Load Program Status Doubleword (LPSD OE, 8E) ..... 3-511
3-246 Exchange Program Status Doubleword (XPSD 0F, 8F) ..... 3-511
3-247 Load Register Pointer (LRP 2F, AF) ..... 3-516

## table of CONTENTS (Cont.)

Section Title Page

Title
PageMove to Memory Control (MCC 6F, EF)3-524
Wait (WAIT 2E, AE) ..... 3-527
Read Direct (RD 6C, EC) ..... 3-527
PH3 Internal Mode (B1619Z). ..... 3-545
PH3 External Mode (NB1619Z) ..... 3-545
Write Direct (WD 6D, ED) ..... 3-545
Internal Control Mode. ..... 3-553
Interrupt Control Mode ..... 3-553
Output Mode ..... 3-558
Start Input/Output (SIO 4C, CC) ..... 3-559
Halt Input/Output (HIO 4F, CF) ..... 3-565
Test Input/Output (TIO 4D, CD) ..... 3-571
Test Device (TDV 4E, CE) ..... 3-571
Acknowledge Input/Output (AIO 6E, EE) ..... 3-572
Floating Point Feature ..... 3-572
General ..... 3-572
Floating Point Formats ..... 3-572
Implementation of Floating Point Instructions ..... 3-573
Module Additions for Floating Point Option ..... 3-573
Floating Point Register Nomenclature ..... 3-573
Description of Floating Point Instructions ..... 3-576
Floating Add Short (FAS 3D, BD) ..... 3-576
Floating Add Long (FAL 1D, 9D) ..... 3-576
Floating Subtract Short (FSS 3C, BC). ..... 3-576
Floating Subtract Long (FSL 1C, 9C) ..... 3-576
Floating Multiply Short (FMS 3F, BF) ..... 3-576
Floating Multiply Long (FML 1F, 9F) ..... 3-576
Floating Divide Short (FDS 3E, BD) ..... 3-576
Floating Divide Long (FDL IE, 9E) ..... 3-576
Floating Point Condition Codes and Mode Control Bits ..... 3-576
Floating Point Concepts ..... 3-576
Shifting Floating Point Numbers ..... 3-576
General Normalization. ..... 3-576
Simple Normalization ..... 3-577
Truncation ..... 3-577
Overflow and Underflow ..... 3-578
Floating Point Addition and Subtraction (FAFLAS) ..... 3-578
General ..... 3-578
Floating Point Mode Control Bits ..... 3-579
Exponent Overflow ..... 3-579
Condition Code Settings ..... 3-579
Basic Steps in FAFLAS Implementing ..... 3-579
Detailed Steps in FAFLAS Implementation ..... 3-581
Floating Point Multiplication (FAFLM) ..... 3-597
General ..... 3-597
Floating Point Mode Control Bits ..... 3-597
Condition Code Settings ..... 3-597
Basic Steps in FAFLM Implementation ..... 3-597
Detailed Steps in FAFLM Implementation ..... 3-598
3-297

## table of contents (Cont.)

Section Title Page
3-298 General ..... 3-620
3-299 Floating Point Mode Control Bits ..... 3-620
3-300 Condition Code Settings ..... 3-620
3-301 Basic Steps in FAFLD Implementation. ..... 3-620
3-302 Detailed Steps in FAFLD Implementation ..... 3-622
3-303 Processor Control Panel. ..... 3-641
3-304 Common Output Signals ..... 3-641
3-305 POWER Switch ..... 3-641
3-306 CONTROL MODE Switch ..... 3-6413-307
CLOCK MODE Switch ..... 3-641
3-308 WATCHDOG TIMER Switch ..... 3-641
3-309 INTERLEAVE SELECT Switch ..... 3-648
3-310 PARITY ERROR MODE Switch ..... 3-648
3-311 AUDIO Switch. ..... 3-648
3-312 SENSE Switches ..... 3-648
3-313 REGISTER DISPLAY Switch ..... 3-648
3-314 REGISTER SELECT Switch ..... 3-648
3-315 I/O RESET Pushbutton ..... 3-6493-316
UNIT ADDRESS Thumbwheels ..... 3-6493-317
INTERRUPT Switch ..... 3-6503-318
3-318 SELECT ADDRESS Switches ..... 3-650
3-319 32 DATA Switches. ..... 3-650
3-320 PCP Phase Sequencing ..... 3-650
3-3213-650
3-322 Compute Switch to Idle ..... 3-651
3-323 DCSTOP ..... 3-652
3-324 POWER ON or POWER OFF Sequence ..... 3-652
3-325 RESET Function. ..... 3-652
3-326 COMPUTE STEP or RUN Function. ..... 3-652
3-327 INSERT Function ..... 3-656
3-328 DATA ENTER/CLEAR Function ..... 3-656
3-329 STORE INSTR ADDR/SELECT ADDR function ..... 3-656
3-330 DISPLAY INSTR ADDR/SELECT ADDR Function ..... 3-656
3-331 ..... 3-6563-332
CLEAR MEMORY Function ..... 3-6603-333
LOAD Function ..... 3-660
3-334 Indicators ..... 3-664
3-335 DISPLAY Indicators ..... 3-664
3-336 NORMAL MODE Indicator ..... 3-664
3-337 RUN Indicator ..... 3-664
3-338 WAIT Indicator ..... 3-664
3-339 PHASE Indicators ..... 3-684
3-340 MENORY FAULT Indicators ..... 3-684
3-341 Power Distribution. ..... 3-684
3-342 Glossary Tables ..... 3-684
IV INSTALLATION AND MAINTENANCE. ..... 4-1
4-1 Introduction ..... 4-1
4-2 Installation ..... 4-1

## TABLE OF CONTENTS (Cont.)

Section Title Page
Basic Cabinet Installation Requirements ..... 4-1
Floor Space ..... 4-1
Power. ..... 4-1
Cable Connections ..... 4-2
Main Unit Installation Requirements ..... 4-2
Central Processing Unit ..... 4-2
Optional Feature Installation Requirements ..... 4-2
Real-Time Clock ..... 4-2
Power Fail-Safe ..... 4-2
Memory Protection. ..... 4-2
Memory Map ..... 4-3
Private Memory Register Extension ..... 4-3
Floating Point ..... 4-5
Decimal Arithmetic ..... 4-5
External Interrupt Chassis ..... 4-5
Free-Standing Console ..... 4-5
Maintenance ..... 4-5
Special Tools and Test Equipment ..... 4-5
Preventive Maintenance. ..... 4-5
Diagnostic Testing ..... 4-6
CPU Diagnostic System (SENSE) ..... 4-6
CPU Diagnostic System (VERIFY) ..... 4-6
CPU Diagnostic System (PATTERN) ..... 4-6
CPU Diagnostic System (AUTO). ..... 4-6
CPU Diagnostic System (SUFFIX) ..... 4-6
CPU Diagnostic System (FLOAT) ..... 4-7
CPU Diagnostic System (MAP) ..... 4-7
Sigma 5 and 7 Real-Time Clock Test ..... 4-7
Sigma 5 and 7 Memory Protect Diagnostic ..... 4-7
Sigma 5 and 7 Power Fail-Safe Test ..... 4-7
Sigma 5 and 7 Interrupt Test ..... 4-7
Sigma 5 and 7 Systems Test Monitor (SEVA) ..... 4-7
Corrective Maintenance ..... 4-8
Power. ..... 4-8
Clocks ..... 4-8
Memory ..... 4-8
Instructions ..... 4-8
Replacement of Miniature Incandescent Lamps (DS1 through DS21 and DS29through DS98)4-10

## LIST OF ILLUSTRATIONS

Figure Title Page
1-1 Sigma 7 Computer System (Typical Configuration) ..... 1-2
1-2 Cabinet Types ..... 1-5
1-3 Sigma 7 Minimum System ..... 1-6
2-1 Processor Control Panel ..... 2-2
3-1 Sigma 7 System Elements ..... 3-1
3-2 Memory Connection ..... 3-2
3-3 Memory Organization ..... 3-3
3-4 $X$ and $Y$ Core Winding, Typical ..... 3-4
3-5 Interleaving Timing. ..... 3-5
3-6 Central Processing Unit, Functional Block Diagram ..... 3-6
3-7 Arithmetic and Control Unit Registers ..... 3-7
3-8 Control Flip-Flops and Setting Conditions ..... 3-7
3-9 Internal Interrupt System, Block Diagram ..... 3-8
3-10 Clock Generator, Simplified Block Diagram ..... 3-9
3-11 Real-Time Clock, Simplified Block Diagram ..... 3-10
3-12 Memory Map Organization ..... 3-12
3-13 Organization of Block Addresses in Memory Map Word ..... 3-12
3-14 Organization of Program Control Codes in Memory Word ..... 3-13
3-15 CL Clock Timing, Typical ..... 3-14
3-16 IOP Information Exchange ..... 3-16
3-17 IOP Functional Flow Chart for Input/Output ..... 3-17
3-18 IOP Priority Assignments. ..... 3-18
3-19 AT21 Cable Driver, Schematic Diagram ..... 3-20
3-20 AT21 Cable Driver, Logic Diagram ..... 3-21
3-21 Memory Element (XDS 304), Schematic Diagram ..... 3-22
3-22 Memory Element Operation, Timing Diagram ..... 3-23
3-23 Gate Structure for Inverter (XDS 305), Typical ..... 3-23
3-24 Inverter (XDS 305), Schematic Diagram ..... 3-24
3-25 Gate Structure for Buffer (XDS 306), Typical ..... 3-24
3-26 Buffer (XDS 306), Schematic Diagram ..... 3-25
3-27 Gate Structure for Flip-Flop (XDS 307), Typical ..... 3-25
3-28 Flip-Flop (XDS 307), Schematic Diagram ..... 3-26
3-29 Flip-Flop (XDS 307), Logic Diagram ..... 3-27
3-30 Discriminator (XDS 308), Schematic Diagram ..... 3-28
3-31 Use of Discriminator (XDS 308), Typical ..... 3-29
3-32 Discriminator (XDS 308) Gate Structure, Typical ..... 3-29
3-33 Flip-Flop (XDS 311), Schematic Diagram ..... 3-30
3-34 Flip-Flop (XDS 311) Gate Structure, Typical ..... 3-31
3-35 Arithmetic and Control Unit Data Transfer ..... 3-33
3-36 A-Register Inputs and Enabling Signals ..... 3-35
3-37 A-Register Extension Inputs and Enabling Signals ..... 3-36
3-38 B-Register Inputs and Enabling Signals ..... 3-37
3-39 B-Register Extension Inputs and Enabling Signals ..... 3-38
3-40 C-Register Bit 1, Simplified Logic Diagram ..... 3-39
3-41 Loading Cl From Sum Bus, Timing Diagram ..... 3-39
3-42 CXS Enabling Signal Generation ..... 3-40
3-43 C-Register Inputs and Enabling Signals ..... 3-41
3-44 C-Register Enabling Signal Generation ..... 3-42
3-45 Condition Code Register Inputs and Enabling Signals ..... 3-43
3-46 CS-Register Inputs and Enabling Signals ..... 3-44

## LIST OF ILLUSTRATIONS (Cont.)

Figure Title Page
3-47 D-Register Inputs and Enabling Signals. ..... 3-47
3-48 D-Register Extension Inputs and Enabling Signals ..... 3-49
3-49 E-Register Inputs and Enabling Signals ..... 3-49
3-50 O-Register Inputs and Enabling Signals ..... 3-50
3-51 P-Register Inputs and Enabling Signals ..... 3-51
3-52 $\quad \mathrm{P}$-Register Count Gating. ..... 3-52
3-53 Q-Register Inputs and Enabling Signals ..... 3-54
3-54 R-Register Inputs and Enabling Signals. ..... 3-54
3-55 RP-Register Inputs and Enabling Signals ..... 3-55
3-56 Word Distribution in Private Memory Bank ..... 3-55
3-57 Memory Element (XDS 304), Simplified Block Diagram ..... 3-56
3-58 FT25 Module, Page 0, Byte 0, Simplified Diagram ..... 3-57
3-59 Private Memory Data Organization ..... 3-59
3-60 Bit Addressing on FT25 Module ..... 3-59
3-61 Register Extension Chassis, Simplified Block Diagram. ..... 3-61
3-62 . Register Extension FT25 Module, Page 0, Byte 0, Simplified Diagram ..... 3-63
3-63 Sum Bus Inputs and Gating Signals ..... 3-66
3-64 Adder and Sum Bus Gating, Block Diagram ..... 3-67
3-65 Typical Adder and Sum Bus Gating, Logic Diagram ..... 3-71
3-66 Adder Logical Operation ..... 3-72
3-67 (A Plus D) Gated to S. ..... 3-74
3-68 (A Plus CS) Gated to $S$ ..... 3-75
3-69 (D Plus CS) Gated to $S$ ..... 3-75
3-70 ( $A \oplus D$ ) Gated to $S$ ..... 3-76
3-71 (A $\oplus C S$ ) Gated to $S$ ..... 3-76
3-72 ( $D \oplus C S$ ) Gated to $S$ ..... 3-77
3-73 (A OR D) Gated to $S$ ..... 3-78
3-74 (A AND D) Gated to S ..... 3-78
3-75 Two's Complement of A Gated to S ..... 3-79
3-76 Two's Complement of D Gated to S ..... 3-79
3-77 Upward Alignment, Functional Diagram ..... 3-80
3-78 A-Register Upward Alignment (Byte). ..... 3-80
3-79 A-Register Upward Alignment (Halfword). ..... 3-81
3-80 D-Register Upward Alignment (Byte). ..... 3-81
3-81 D-Register Upward Alignment (Halfword). ..... 3-82
3-82 Display Lamp Gating, Logic Diagram. ..... 3-83
3-83 Overflow into Condition Code Bit CC2, Simplified Logic Diagram ..... 3-85
3-84 K00H End Carry and Compare Flip-Flop, Logic Diagram ..... 3-87
3-85 Clock Generator, Simplified Diagram. ..... 3-89
3-86 Clock Generator Delay Line 1, Logic Diagram ..... 3-91
3-87 Clock Generator Delay Line 2, Logic Diagram ..... 3-92
3-88 Clock Generator Delay Line 3, Logic Diagram ..... 3-93
3-89 Clock Generator Delay Line 4, Logic Diagtam ..... 3-94
3-90 Original CL Clock Generation (T61), Timing Diagram ..... 3-95
3-91 TIL Clock Logic. ..... 3-96
3-92 Delay Line 1 Lockout Circuit. ..... 3-96
3-93 Delay Line Sensor Enabling Signal Generation ..... 3-97
3-94 CL, DCH, and CK Clock Signals Actual Timing ..... 3-98
3-95 Clock Enabling Function, Timing Diagram ..... 3-98
3-96 TIL Clock Generation, Timing Diagram ..... 3-99

## LIST OF ILLUSTRATIONS (Cont.)

Figure Title Page
3-97 TlL Post Enabling Timing Diagram. ..... 3-100
3-98 Trip Counter Functions, Timing Diagram. ..... 3-102
3-99 Delay Line 2 Recirculation Enabling Signal Generation ..... 3-103
3-100 Clock Enabling Logic ..... 3-104
3-101 Clock Enabling Gates ..... 3-105
3-102 Single Clock Mode, Timing Diagram. ..... 3-106
3-103 Memory Map Page Address Code Registers ..... 3-107
3-104 Memory Map Organization ..... 3-109
3-105 Memory Map Bit Addressing ..... 3-111
3-106 Memory Map Program Control Registers ..... 3-111
3-107 Program Control Register Organization. ..... 3-113
3-108 Loading One Word of Program Control Codes ..... 3-115
3-109 Memory Map Address Conversion. ..... 3-117
3-110 Map Register Output Gating ..... 3-118
3-111 Program Control Register Output Decoding ..... 3-119
3-112 Memory Protection Register Organization ..... 3-121
3-113 Memory Protection Register Output Decoding ..... 3-124
3-114 Watchdog Timer Counter, Logic Diagram ..... 3-125
3-115 Watchdog Timer Control Circuits, Logic Diagram ..... 3-126
3-116 Real-Time Clock, Simplified Diagram ..... 3-127
3-117 Power Fail-Safe Feature, Simplified Block Diagram ..... 3-129
3-118 Power Monitor, Functional Schematic Diagram ..... 3-130
3-i19 WT21 Reguiator, Schematic Diagram. ..... 3-132
3-120 WT22 Line Detector, Block Diagram ..... 3-133
3-121 WT22 Line Detector, Schematic Diagram ..... 3-135
3-122 Power Fail-Safe Waveforms ..... 3-137
3-123 Single-Phase Detection. ..... 3-138
3-124 Three-Phase Detection ..... 3-139
3-125 ION One-Shot Operation ..... 3-139
3-126 Real-Time Clock Operation ..... 3-140
3-127 Power Fail-Safe Logic Diagram ..... 3-141
3-128 Interrupt Memory Location Addressing ..... 3-149
3-129 Interrupt Timing Diagram (Counter 4 Count Pulse). ..... 3-151
3-130 Write Direct Sequence, Timing Diagram. ..... 3-154
3-131 P-Register Configuration in Trap Sequence Pass 2 ..... 3-164
3-132 Trap Memory Location and Addressing ..... 3-169
3-133 Data Word Formats ..... 3-170
3-134 Instruction Word Formats ..... 3-172
3-135 Instruction Mnemonics and Families ..... 3-177
3-136 Phase Control ..... 3-185
3-137 Memory Timing for Port C (Typical) ..... 3-187
3-138 AHCL and RESTM, Logic Diagram ..... 3-193
3-139 Address Release Request Signal (ARQ), Logic Diagram. ..... 3-194
3-140 Memory Request Timing, Logic Diagram ..... 3-195
3-141 Memory Request Phase Flip-Flops, Simplified Logic Diagram ..... 3-196
3-142 OPRQ Signal Gating, Simplified Logic Diagram ..... 3-197
3-143 RQ Signal Gating, Simplified Logic Diagram ..... 3-197
3-144 RQC Signal Gating, Simplified Logic Diagram ..... 3-198
3-145 Request From Port C During Load Word Instruction, Timing Diagram (Typical) ..... 3-199
3-146 Memory Request During Load Word Instruction With Crossover, Timing Diagram (Typical). ..... 3-201

## LIST OF ILLUSTRATIONS (Cont.)

Figure Title ..... Page
3-147 Load Word Instruction, Request From P-Register Followed by Request From Q-Register, Timing Diagram (Typical). ..... 3-203
3-148 Store Display Operation, Timing Diagram (Typical) ..... 3-204
3-149 LMXC and LMXQ Signals Gating, Logic Diagram ..... 3-205
3-150 Fast-Access Memory Map Output Distribution. ..... 3-206
3-151 Crossover, Logic Diagram ..... 3-207
3-152 Preparation Sequence, Flow Diagram ..... 3-213
3-153 Instruction Addressing, Integer Displacement ..... 3-268
3-154 Single-Bit Multiplication ..... 3-296
3-155 Bit-Pair Multiplication ..... 3-298
3-156 Carry-Save Addition. ..... 3-299
3-157 Carry-Save Addition in Multiplication ..... 3-300
3-158 Register Organization and Flow Chart for Multiply Word and Multiply Immediate Instructions ..... 3-301
3-159 Multiply Iteration Signal Routing ..... 3-304
3-160 High-Order Bit Logic ..... 3-305
3-161 BC1 Timing. ..... 3-306
3-162 Iteration Counting for Multiply Word and Multiply Immediate Instructions ..... 3-307
3-163 Multiply Word and Multiply Immediate Final Product Assimilation ..... 3-308
3-164 Multiply Halfword Register Organization and Flow Chart ..... 3-313
3-165 Multiply Halfword Iteration Counting. ..... 3-319
3-166 Multiply Halfword Final Product Assimilation. ..... 3-321
3-167 Restoring Division ..... 3-322
3-168 Restoring Division, Graphic Representation. ..... 3-322
3-169 Nonrestoring Division. ..... 3-323
3-170 Nonrestoring Division, Graphic Representation ..... 3-323
3-171 Nonrestoring Division with Two's Complement Addition ..... 3-324
3-172 Plus/Minus Case in Division ..... 3-324
3-173 Minus/Plus Case in Division. ..... 3-325
3-174 Minus/Minus Case in Division. ..... 3-326
3-175 Sigma 7 Division ..... 3-327
3-176 Divide Word Register Organization and Flow Chart. ..... 3-329
3-177 Divide Word and Divide Halfword Iteration Counting ..... 3-336
3-178 Overflow Detection. ..... 3-337
3-179 Divide Halfword Register Organization and Flow Chart ..... 3-339
3-180 Arithmetic Left Shift, Flow Diagram ..... 3-394
3-181 Arithmetic Right Shift, Flow Diagram ..... 3-395
3-182 Circular Left Shift, Flow Diagram ..... 3-395
3-183 Circular Right Shift, Flow Diagram ..... 3-396
3-184 Convert by Subtraction, Logic Sequence Diagram ..... 3-418
3-185 Doubleword-Stack Relationship for PSW Instruction ..... 3-461
3-186 Push Word, Logic Sequence Diagram. ..... 3-462
3-187 Doubleword-Stack Relationship for PLW Instruction. ..... 3-470
3-188 Pull Word, Logic Sequence Diagram. ..... 3-471
3-189 Push Multiple, Logic Sequence Diagram ..... 3-480
3-190 Pull Multiple, Logic Sequence Diagram. ..... 3-488
3-191 Modify Stack Pointer, Logic Sequence Diagram ..... 3-497
3-192 Exchange Program Status Doubleword, Logic Sequence Diagram ..... 3-517
3-193 Read Direct Internal Control Mode, Timing Diagram ..... 3-542
3-194 Read Direct External Mode, Timing Diagram ..... 3-543
3-195 Read/Write Direct Input/Output Lines DIO0-DIO31 ..... 3-543

## LIST OF ILLUSTRATIONS (Cont.)

Figure Title Page
3-196 Read/Write Direct Address Lines /DIO32/-/DIO47/ ..... 3-544
3-197 Read/Write Direct Control Lines /DIO48/-/DIO54/ ..... 3-544
3-198 Write Direct Function Decoding in Internal Control Mode ..... 3-552
3-199 Write Direct Interrupt Control Mode Action Decoding ..... 3-552
3-200 Write Direct Output Mode Decoding ..... 3-552
3-201 Write Direct Internal Mode, Timing Diagram ..... 3-553
3-202 Write Direct Interrupt Mode, Timing Diagram ..... 3-554
3-203 Write Direct Data Lines. ..... 3-555
3-204 Write Direct Address Lines ..... 3-556
3-205 Write Direct Interrupt Mode Function Decoding ..... 3-557
3-206 Write Direct External Mode, Timing Diagram ..... 3-559
3-207 Start Input/Output Information Stored in Location X'20' ..... 3-560
3-208 SIO, HIO, TIO, TDV, AIO, Logic Sequence Diagram ..... 3-562
3-209 SIO, R-Field Even But Not Zero, Simplified Timing Diagram ..... 3-564
3-210 SIO, R-Field Zero or R-Field Not Zero But Start Unsuccessful, Simplified Timing Diagram ..... 3-565
3-211 Short and Long Floating Point Formats ..... 3-573
3-212 Short and Long Floating Point Number Ranges ..... 3-574
3-213 Floating Point Register Extensions ..... 3-575
3-214 Shifting Floating Point Numbers ..... 3-577
3-215 Normalization of Floating Point Numbers ..... 3-578
3-216 Fraction Overflow and Adjustment ..... 3-579
3-217 Example of FAFLAS Implementation (Floating Add) ..... 3-582
3-218 FAFLAS Implementation, Block Diagram ..... 3-583
3-219 Example of FAFLM Implementation ..... 3-599
3-220 FAFLM Implementation, Block Diagram ..... 3-601
3-221 FAFLM Register Organization (Phase 10) ..... 3-617
3-222 Floating Point Multiply Iteration Signal Routing ..... 3-618
3-223 Example of FAFLD Implementation ..... 3-623
3-224 FAFLD Implementation, Block Diagram ..... 3-625
3-225 FAFLD Register Organization (Phase 11) ..... 3-640
3-226 Entering PCP Phases ..... 3-651
3-227 Power On or Power Off, Sequence Flow Diagram ..... 3-653
3-228 CPU RESET/CLEAR and SYS RESET/CLEAR, Sequence Flow Diagram ..... 3-656
3-229 PCP Sequence Beyond Wait State ..... 3-657
3-230 INSERT Function, Sequence Flow Diagram ..... 3-660
3-231 DATA ENTER/CLEAR, Sequence Flow Diagram ..... 3-664
3-232 STORE INSTR ADDR/SELECT ADDR, Sequence Flow Diagram ..... 3-667
3-233 DISPLAY INSTR ADDR/SELECT ADDR, Sequence Flow Diagram ..... 3-667
3-234 INSTR ADDR INCREMENT, Sequence Flow Diagram ..... 3-672
3-235 CLEARMEM Function, Sequence Flow Diagram ..... 3-672
3-236 LOAD, Sequence Flow Diagram ..... 3-677
3-237 NORMAL LOAD Indicator, Simplified Schematic Diagram ..... 3-683
3-238 Cable Designation Code. ..... 3-684
3-239 Cabinet and Frame Location Codes ..... 3-685
3-240 Male Connectors, Prong Shapes and Uses ..... 3-685
3-241 PT15 Power Supply, and PT14 Power Supply, Main Power Distribution Box, and Power Junction Box(Typical Installation)3-686
3-242 PT16 Power Supply, PT17 Power Supply (Typical Installation) ..... 3-687
3-243 System Power Distribution, Typical ..... 3-689
3-244 System Power Configuration, Typical ..... 3-690

## LIST OF ILLUSTRATIONS (Cont.)

Figure Title ..... Page
3-245 System Ac Interconnections, Typical ..... 3-691
3-246 Peripheral Station Power Control, Functional Diagram, Typical ..... 3-695
3-247 Marginal Voltage Indicator Interconnections, Typical ..... 3-698
4-1 Address Selector Module ST14 ..... 4-3
4-2 Switch Comparator LT26. ..... 4-4
4-3 Plug-In Lamp Assembly Installation ..... 4-10
A-1 CPU Cabinet No. 1 ..... A-3
A-2 CPU Cabinet No. 2 (Typical) ..... A-13
A-3 Assembly, Processor Control Panel ..... A-19
A-4 Memory Cabinet. ..... A-29

## LIST OF TABLES

Table Title Page
1-1 Main Units ..... 1-1
1-2 Optional Features ..... 1-3
1-3 General Specifications ..... 1-7
1-4 Power Supply Input Power Specifications ..... 1-8
1-5 Fuses ..... 1-8
1-6 Lamps. ..... 1-8
2-1 Controls and Indicators, PCP Programmer's Section. ..... 2-3
2-2 Controls and Indicators, PCP Maintenance Section. ..... 2-7
2-3 Basic Instructions ..... 2-11
2-4 Basic Instruction Codes, Cross-Reference ..... 2-14
3-1 Program Control Code Functions ..... 3-13
3-2 CL Clock Pulse Intervals. ..... 3-14
3-3 E-Register Count Logic ..... 3-50
3-4 P-Register Count Logic ..... 3-53
3-5 R-Register Count Logic ..... 3-54
3-6 REU Interface Signals ..... 3-65
3-7 Sum Bus Output Gating. ..... 3-68
3-8 Sum Bus Gating Function ..... 3-69
3-9 Display Lamp Gating, Logic ..... 3-84
3-10 Trip Counter Progression ..... 3-101
3-11 Clock Time Intervals ..... 3-101
3-12 Program Control Code Functions ..... 3-120
3-13 Memory Protection Functions ..... 3-120
3-14 FAILD Signal Generation in Memory Protection ..... 3-123
3-15 Significant States of Interrupt Circuit. ..... 3-143
3-16 Function of Codes for WD Interrupt Control Mode ..... 3-155
3-17 Signals Enabled by Codes for WD Interrupt Control Mode, and Resulting Changes of State ..... 3-156
3-18 Interrupt Sequence ..... 3-157
3-19 Trap Sequence ..... 3-165
3-20 Operation Code List ..... 3-173
3-21 Family Code Logic. ..... 3-180
3-22 CPU/Memory Interface Signals ..... 3-186
3-23 Memory Request Timing and Control Signals ..... 3-188
3-24 Instruction Decoding for PREOPRQ/1, PREOPRQ/2, PRERQ, PREFADO, PREDO, and PREIM ..... 3-190
3-25 Preparation Sequence (No Indexing, No Indirect Addressing). ..... 3-209
3-26 Preparation Sequence (Indirect Addressing, No Indexing) ..... 3-211
3-27 Preparation Sequence (Indexing, No Indirect Addressing) ..... 3-214
3-28 Load Immediate, Phase Sequence ..... 3-215
3-29 Load Byte, Phase Sequence ..... 3-216
3-30 Load Halfword, Phase Sequence ..... 3-218
3-31 Load Word, Phase Sequence. ..... 3-221
3-32 Load Doubleword, Phase Sequence ..... 3-223
3-33 Load Complement Halfword, Phase Sequence ..... 3-226
3-34 Load Absciute Halfword, Phase Sequence ..... 3-228
3-35 Load Complement Word, Phase Sequence ..... 3-230
3-36 Load Absolute Word, Phase Sequence. ..... 3-232
3-37 Load Complement Doubleword, Phase Sequence ..... 3-236
3-38 Load Absolute Doubleword, Phase Sequence ..... 3-239
3-39 Load Selective Operation Example with Even and Odd Numbered R-Field Address. ..... 3-243
3-40 Load Selective, Phase Sequence ..... 3-244

## LIST OF TABLES (Cont.)

Table Title Page
3-41 Load Multiple, Phase Sequence ..... 3-248
3-42 Load Conditions and Floating Control Immediate, Phase Sequence ..... 3-250
3-43 Load Conditions and Floating Control, Phase Sequence ..... 3-251
3-44 Exchange Word, Phase Sequence ..... 3-253
3-45 Store Byte, Phase Sequence ..... 3-255
3-46 Store Halfword, Phase Sequence ..... 3-256
3-47 Store Word, Phase Sequence ..... 3-258
3-48 Store Doubleword, Phase Sequence ..... 3-260
3-49 Store Selective Operation Example with Even and Odd Numbered R-Field Address ..... 3-262
3-50 Store Selective, Phase Sequence ..... 3-263
3-51 Store Multiple, Phase Sequence ..... 3-265
3-52 Store Conditions and Floating Control, Phase Sequence ..... 3-267
3-53 Condition Code Settings ..... 3-268
3-54 Analyze Table for Opcode Groups ..... 3-269
3-55 Analyze, Phase Sequence ..... 3-271
3-56 Interpret, Phase Sequence ..... 3-274
3-57 Add Immediate, Phase Sequence ..... 3-276
3-58 Add Halfword, Phase Sequence ..... 3-278
3-59 Add Word, Phase Sequence ..... 3-282
3-60 Add Doubleword, Phase Sequence ..... 3-284
3-61 Subtract Halfword, Phase Sequence ..... 3-288
3-62 Subtract Word, Phase Sequence ..... 3-290
3-63 Subtract Doubleword, Phase Sequence ..... 3-292
3-64 Instruction MW, MI, and MH Condition Codes ..... 3-295
3-65 Bit-Pair Multiplier Logic ..... 3-297
3-66 Multiplication Sign Logic ..... 3-299
3-67 Multiply Sign Manipulation ..... 3-299
3-68 Bit-Pair Multiplier Logic ..... 3-303
3-69 Multiplier Control Flip-Flop Logic ..... 3-303
3-70 Multiply Word, Multiply Immediate, Phase Sequence ..... 3-309
3-71 Multiply Halfword, Phase Sequence ..... 3-315
3-72 Instruction DW and DH Condition Codes ..... 3-320
3-73 Quotient Logic ..... 3-326
3-74 Divide Word, Phase Sequence ..... 3-330
3-75 Divide Halfword, Divide Word $(R=31)$, Phase Sequence ..... 3-340
3-76 Add Word to Memory, Phase Sequence ..... 3-346
3-77 Modify and Test Byte, Phase Sequence ..... 3-348
3-78 Modify and Test Halfword, Phase Sequence ..... 3-354
3-79 Modify and Test Word, Phase Sequence ..... 3-359
3-80 Compare Immediate, Phase Sequence ..... 3-363
3-81 Compare Byte, Phase Sequence ..... 3-366
3-82 Compare Halfword, Phase Sequence ..... 3-370
3-83 Compare Word, Phase Sequence ..... 3-373
3-84 Compare Doubleword, Phase Sequence ..... 3-377
3-85 Compare Selective, Phase Sequence ..... 3-380
3-86 Compare With Limits in Register, Phase Sequence ..... 3-384
3-87 Compare With Limits in Memory, Phase Sequence ..... 3-387
3-88 OR Word, Phase Sequence ..... 3-390
3-89 Exclusive OR Word, Phase Sequence ..... 3-392
3-90 AND Word, Phase Sequence ..... 3-393

## LIST OF TABLES (Cont.)

Table Title Page
3-91 Shift Determination ..... 3-394
3-92 Left Shift Count Sequence Example ..... 3-396
3-93 Right Shift Count Example ..... 3-397
3-94 Shift, Phase Sequence ..... 3-398
3-95
Left Shift Count Less Than 14 ..... 3-404
3-96Left Shift Count Exceeding 143-405
3-97 Right Shift Count Less Than 14 ..... 3-405
3-98 Right Shift Count Exceeding 14 ..... 3-406
3-99 Shift Floating, Phase Sequence ..... 3-407
3-100 Convert by Addition, Phase Sequence ..... 3-416
3-101 Convert by Subtraction, Phase Sequence ..... 3-420
3-102 Move Byte String, Phase Sequence ..... 3-425
3-103 Compare Byte String, Phase Sequence ..... 3-4343-104
Translate Byte String, Phase Sequence ..... 3-446
3-105 Translate and Test Byte String, Phase Sequence ..... 3-453
106
106 3-106 Push Word, Phase Sequence ..... 3-465
3-107 Pull Word, Phase Sequence ..... 3-474
3-108 Push Multiple, Phase Sequence ..... 3-482
3-109 Pull Multiple, Phase Sequence ..... 3-491
3-110 Modify Stack Pointer, Phase Sequence ..... 3-499
3-111 Execute, Phase Sequence ..... 3-503
3-112 Branch on Conditions Set, Phase Sequence ..... 3-504
3-113 Branch on Conditions Reset, Phase Sequence ..... 3-505
3-114 Branch on Incrementing Register, Phase Sequence ..... 3-507
3-115 Branch on Decrementing Register, Phase Sequence ..... 3-508
3-116 Branch and Link, Phase Sequence ..... 3-510
3-117 Call 1, Call 2, Call 3, Call 4, Phase Sequence ..... 3-512
3-118 Load Program Status Doubleword, Phase Sequence ..... 3-513
3-119 Exchange Program Status Doubleword, Phase Sequence ..... 3-519
3-120 Load Register Pointer, Phase Sequence ..... 3-525
3-121 Bit Position Functions ..... 3-526
3-122 Move to Memory Controi, Phase Sequence ..... 3-528
3-123 Wait, Phase Sequence ..... 3-537
3-124 Read Direct Internal Control Mode, Phase Sequence ..... 3-538
3-125 Read Direct External Mode, Phase Sequence ..... 3-540
3-126 Write Direct Internal Control Mode, Phase Sequence ..... 3-546
3-127 Write Direct Interrupt Control Mode, Phase Sequence ..... 3-548
3-128 Write Direct Output Mode, Phase Sequence ..... 3-550
3-129 Status Bits for Input/Output Instructions ..... 3-561
3-130 Start Input/Output, Phase Sequence ..... 3-566
3-131 Condition Codes for Floating Point Addition and Subtraction ..... 3-580
3-132 Floating Add, Floating Subtract (FAFLAS), Phase Sequence ..... 3-585
3-133 Condition Codes for Floating Point Multiplication ..... 3-598
3-134 Floating Multiply (FAFLM), Phase Sequence ..... 3-603
3-135 Condition Codes for Floating Point Division ..... 3-621
3-136 Floating Divide (FAFLD), Phase Sequence ..... 3-627
3-137 PCP Control Switches ..... 3-642
3-138 PCP Indicators ..... 3-646
3-139 Switch Settings for Signals (KAS/1, KAS/2, and NKAS/B ..... 3-647
3-140 REGISTER SELECT Switch Logic ..... 3-649

## LIST OF TABLES (Cont.)

Table Title ..... Page
3-141 RESET Function, Phase Sequence ..... 3-654
3-142 STEP, RUN Function, Phase Sequence ..... 3-658
3-143 INSERT Function, Phase Seqeunce ..... 3-661
3-144 DATA ENTER/CLEAR, Phase Sequence ..... 3-665
3-145 STORE INSTR ADDR/SELECT ADDR, Phase Sequence ..... 3-668
3-146 DISPLAY INSTR ADDR/SELECT ADDR, Phase Sequence ..... 3-670
3-147 INSTR ADDR INCREMENT, Phase Sequence ..... 3-673
3-148 CLEARMEM Function, Phase Sequence ..... 3-675
3-149 LOAD Function, Phase Sequence ..... 3-678
3-150 Bootstrap Program ..... 3-682
3-151 Peripheral Equipment and Power Supply Installation Drawings ..... 3-698
3-152 Types of Power Cables ..... 3-699
3-153 Symbols Used in Glossaries, Equations, and Phase Sequence Charts ..... 3-700
3-154 Glossary of CPU Signals ..... 3-701
3-155 Glossary of Interrupt Signals ..... 3-727
4-1 Reference Documents for Sigma 7 Installation ..... 4-1
4-2 Space Requirements for Sigma 7 Cabinets ..... 4-2
4-3 Sigma 7 Cable Connections ..... 4-24-4
LT26 Switch Settings - Register Extension Address ..... 4-4
Special Tools and Test Equipment ..... 4-5
A-1 Sigma 7 Central Processing Unit Model 8401, Replaceable Parts ..... A-2
A-2 Frame No. 1, CPU Cabinet No. 1, Replaceable Parts ..... A-4
A-3 Wired Board Assembly (A, B, C), Replaceable Parts ..... A-5
Wired Board Assembly (D, E, F), Replaceable Parts ..... A-6
Wired Board Assembly (G, H, J), Replaceable Parts ..... A-7
Frame No. 2, CPU Cabinet No. 1, Replaceable Parts ..... A-8
A- Wired Board Assembly (K, L, M), Replaceable Parts ..... A-9
A-8 Wired Board Assembly (N, P, Q), Replaceable Parts ..... A-10
A-9 Wired Board Assembly ( $\mathrm{R}, \mathrm{S}, \mathrm{T}$ ), Replaceable Parts ..... A-11
A-10 Frame No. 1, CPU Cabinet No. 2, Replaceable Parts ..... A-12
A-11 Wired Board Assembly (U, V, W), Replaceable Parts ..... A-14
A-12 Wired Board Assembly (Y), Replaceable Parts ..... A-15
A-13 Processor Control Panel Assembly, Replaceable Parts ..... A-16
A-14 Floating Point Arithmetic Assembly, Replaceable Parts ..... A-22
A-15 Decimal Arithmetic Assembly, Replaceable Parts ..... A-23
A-16 Memory Map Assembly, Replaceable Parts ..... A-24
A-17 Real Time Clock Assembly, Replaceable Parts ..... A-24
A-18 Power Fail-Safe Assembly, Replaceable Parts ..... A-24
A-19 Additional Register Banks Assembly, Replaceable Parts ..... A-24
A-20 Register Extension Unit Assembly and Register Extension Unit Interface, Replaceable Parts ..... A-25
A-21 Memory Protect Assembly, Replaceable Parts ..... A-25
A-22 Priority Interrupt Assembly, Replaceable Parts ..... A-26
A-23 Basic Memory, 4096 Words, Assembly, Replaceable Parts ..... A-27
A-24 Memory Increment, 4096 Words, Replaceable Parts ..... A-30
A-25 Three-Way Access Memory (Port A), Replaceable Parts ..... A-30
A-26 Six-Way Access Memory, Replaceable Parts ..... A-31
A-27 Multiplexor I/O Processor, Replaceable Parts ..... A-32
A-28 Additional IOP/DC Expansion (Up to 8 Channels), Replaceable Parts ..... A-33
A-29 Basic Cabinet Hardware, Replaceable Parts ..... A-33
A-30 Manufacturer's Code Index ..... A-34

## LIST OF RELATED PUBLICATIONS

| Publication Title | Publication No. |
| :---: | :---: |
| XDS T-Series, Integrated Circuit Logic Niodules, Description and Specifications | 645103 |
| Sigma 7 CPU Diagnostic System (Sense), Diagnostic Program Manual | 900824 |
| Sigma 5 and 7 CPU Diagnostic Program (Verify), Diagnostic Program Manual | 900870 |
| Sigma 7 CPU Diagnostic-Auto, Diagnostic Program Nianual | 900872 |
| Sigma 7 CPU Diagnostic System (Pattern), Diagnostic Program Manual | 900891 |
| Sigma 7 CPU Diagnostic (Suffix), Diagnostic Program Nianual | 900893 |
| Sigma 5 and 7 CPU Diagnostic-Float, Diagnostic Program Manual | 900898 |
| Sigma 7 CPU Diagnostic System (Decimal), Diagnostic Program Manual | 900908 |
| Sigma 7 MAP Diagnostic Program, Diagnostic Program Manual | 900920 |
| Sigma 7 Computer Reference Nianuai | 900950 |
| Sigma 5 and 7 Systems Test Monitor, Diagnostic Program Manual | 901076 |
| Sigma 5 and 7 Interrupt Test, Diagnostic Program Manual | 901134 |
| Sigma 5 and 7 Power Fail-Safe Test, Diagnostic Program Manual | 901135 |
| Sigma 5 and 7 Real-Time Clock Test, Diagnostic Program Manual | 901136 |
| Sigma 5 and 7 CPU Diagnostic Program (Memory Protect), Diagnostic Program Manual | 901516 |
| Sigma 5 and 7 Core Memory, Technical Manual | 901586 |
| imal Arithmetic Unit Model 8419, Technical Manual | 901587 |

## SECTION I

GENERAL DESCRIPTION

## 1-1 INTRODUCTION

This manual contains information necessary to install, operate, and maintain the Sigma 7 Computer System manufactured by Xerox Data Systems, El Segundo, California. Section I provides a general physical and functional description. Subsequent sections contain information on operation and programming, complete principles of operation, maintenance instructions, and tabular parts lists of printed circuit modules.

The List of Related Publications in the front matter of this manual references technical manuals and programming manuals describing equipment and programs associated with the Sigma 7 computer system.

The Sigma 7 computer is a high-speed, general-purpose digital computer for use in business, scientific, process control, hybrid, and systems applications. The computer functions efficiently in real-time, time-sharing, and multiusage computing environments.

Figure 1-1 shows a maximum Sigma 7 computer system configuration without peripheral input/output equipment.

## 1-2 PHYSICAL DESCRIPTION

## 1-3 BASIC COMPUTER SYSTEM

The basic computer system contains a central processing unit (CPIJ) contained in two cabinets, an expandable memory contained in one to four cabinets, and an input/ output processor (IOP). The CPU, IOP, and memory are comprised of printed circuit modules inserted into chassis each of which may contain up to 32 modules. Pins at the rear of the modules are plugged into sockets mounted on
a rear wiring board that contains all wire connections. Module sizes are identical except for the core diode modules in the memory units. These modules cccupy the vertical space normally filled by two standard modules and requires a double-sized chassis.
Table 1-1 lists the main units in a basic Sigma 7 computer system.

## 1-4 OPTIONAL FEATURES

Optional features that may be added to the computer are listed in table 1-2. Many of these features are additional modules that are plugged into the CPU; others are added to accessory cabinets or memory cabinets as needed. The following optional equipment is added by plugging additional modules into the chassis in CPU cabinets 1 and 2: power fail-safe, memory protection, memory map, floating point, two additional real-time clocks (two real-time clocks are part of the basic computer), three additional high-speed register banks used as private memory registers, and six internal interrupt levels. The main part of the optional decimal arithmetic feature is contained in three separate chassis located in CPU cabinet No. 2, and some of the decimal modules are in CPU cabinet No. 1. Three private memory register banks, in addition to the one bank contained in the basic omputer, may be included in the CPU logic modules in CPU cabinet No. 1; the remaining additional register banks are obtained by adding separate chassis to the memory cabinets. Each external interrupt chassis provides control and mounting space for up to eight interrupt modules and contains two interrupt levels per module.

## 1-5 CABINET TYPES

Two types of cabinets are used in Sigma 7 computers. The memory cabinets may contain two hinged frames and a fixed

Table 1-1. Main Units

| Model No. | Nameplate Nomenclature <br> or <br> Assembly Drawing Title | Common Name | Assembly <br> Drawing No. | Location <br> (See figure 1-1) |
| :---: | :---: | :---: | :---: | :---: |
| 8401 | XDS Sigma 7 |  |  |  |
| 8451 | Basic 4K $\times 33$ Bit | Central Processing Unit (CPU) | 117307 | CPU cabinets Nos. 1 and 2 |
| 8471 | Input/Output Processor <br> (IOP) | Multiplexing Input/Output <br> Processor (MIOP) | 117610 | CPU cabinet No. 2. |



Table 1-2. Optional Features

| Model No. | Nameplate Nomenclature <br> or <br> Assembly Drawing Title | Common Name | Assembly <br> Drawing No. | Location <br> (See figure 1-1) |
| :---: | :--- | :--- | :--- | :--- |
| 8411 | Real-Time Clock | Two Additional Real-Time <br> Clocks <br> Power Fail-Safe | 117616 | CPU cabinet No. 2 |

(Continued)

Table 1-2. Optional Features (Cont.)

| Model No. | Nameplate Nomenclature <br> or <br> Assembly Drawing Title | Common Name | Assembly <br> Drawing No. | Location <br> (See figure 1-1) |
| :---: | :--- | :--- | :--- | :--- |
| 8482 | Secondary Selector IOP | Additional Selector Channel | 133997 | CPU cabinet No. 2, <br> accessory cabinet No. 1 or <br> No. 2 |
| 8485 | Selector Input/Output <br> Processor | Selector Input/Output <br> Processor | 117620 | Memory or accessory <br> cabinet |
| 8491 | Controller, CFE-3 <br> 8492 | Multi-Add Unit, CFE-3 | CFE-3 | CFE-3 |
| 8495 | Free-Standing Console | Free-Standing Console | 139237 | Accessory cabinet |

frame; the CPU, accessory, and I/O cabinets may contain two hinged frames. Power supplies are mounted on the side of the frames. In the CPU, I/O, and accessory cabinets, power supplies are also mounted in the rear of the cabinet. Examples of the two types of cabinets are shown in figure 1-2.

## 1-6 COMPUTER CONFIGURATION

A maximum computer system is comprised of the cabinets shown in figure 1-1. The two CPU cabinets, a memory cabinet, and an I/O cabinet are always included. Accessory cabinets, additional memory, and I/O cabinets are included as needed.

## 1-7 FUNCTIONAL DESCRIPTION

## 1-8 BASIC COMPUTER SYSTEM

For purposes of description, a minimum computer system is defined as a CPU, a 4 K memory, an IOP, a device controller, and a device, as shown in figure 1-3. The computer is comprised of a CPU, a 4 K memory, and an IOP.

Although the CPU physically consists of rows of modules, certain basic functional elements can be identified. These are arithmetic and control logic and associated registers, two real-time clocks, a watchdog timer, seven internal interrupt levels, a clock generator, a $1.024-\mathrm{MHz}$ clock oscillator, and a 16-register bank of private memory. The functions of the CPU are to address core memory, to fetch and store information, to perform arithmetic and logical operations, to sequence and control instruction execution, and to control the exchange of information between core memory and other elements of the system.

The memory contains magnetic core storage; addressing, port priority, and control logic, a timing signal generator, and drive, predrive, inhibit, and sensing circuits. The memory stores 32 -bit words and generates and checks parity for each word. Partial words may be stored in the form of

8-bit bytes and 16-bit halfwords. All memory is directly addressable by both the CPU and the IOP.

The IOP contains input and output data storage registera and buffers, fast-access memory registers for command manipulation, a timing signal generator, and control logic.

The function of the multiplexing IOP is to control and sequence simultaneously input and output operations for eight (expandable to 32 ) peripheral devices, allowing the CPU to concentrate on program execution. The active devices timeshare the hardware in the IOP. For each device connected to the IOP, a storage unit (subchannel) is included in the IOP. Any input/output events that require CPU intervention are brought to the attention of the CPU by means of the interrupt system. Device controller and other devices are described in other technical manuals.

## 1-9 OPTIONAL FEATURES

## 1-10 Two Additional Real-Time Clocks

This feature adds interrupt capability for two real-time clocks in addition to the two already in the CPU. When this feature is installed, the CPU has four independent realtime clocks, and each is controlled separately by programming. The clocks can be used as either elapsed-time counters or as real-pulse accumulators. The real-time clock frequency is selectable by ineans of a switch module in CPU cabinet No. 2. The optional frequencies of operation are $8 \mathrm{kHz}, 2 \mathrm{kHz}, 500 \mathrm{~Hz}, 60 \mathrm{~Hz}$, and an external frequency supplied by the user.

## 1-11 Power Fail-Safe Feature

The power fail-safe feature detects an imminent failure of primary power and, with the help of programming, brings the system to an orderly halt while power is still at a sufficient level to permit reliable operation. After a shutdown, this feature automatically senses that power has returned to


Figure l-3. Sigma 7 Minimum System
a normal level and causes the machine to resume computation under program control at the point of prior interruption. The contents of all volatile registers are saved in nonvolatile magnetic core memory before shutdown occurs. The register contents are restored as part of the start-up routine.

## 1-12 Memory Protection

The memory protection feature allows concurrent running of both real-time (foreground) and background programs. A foreground program is protected against destruction by an unchecked background program. The memory protection feature allows protected areas of memory to be written in only under specified conditions.

## 1-13 Memory Map

The memory map provides the means for automatic relocation of programs and controls the problems of memory fragmentation. Regardless of the addresses used by the operating program, the memory map permits the program to reside anywhere in memory, including in noncontiguous areas. Access to these areas for reading or writing can be programcontrolled.

## 1-14 Private Memory Register Extension

The private memory register extension provides additional private memory registers in blocks of 16 registers each. Up to 31 private memory register blocks may be added, making a total of 32 banks in the computer.

## 1-15 Floating Point Feature

The floating point feature enables floating point arithmetic to be performed, using an 8-bit exponent and a 24- or 56bit fraction. Normalized or unnormalized modes of addifion and subtraction may be selected by the program.

## 1-16 Decimal Arithmetic Feature

The decimal arithmetic feature performs arithmetic and logical operations on binary-coded decimal data, adding decimal add, subtract, multiply, divide, compare, shift,
load, store, pack, and unpack logical operations and a comprehensive edit-byte instruction to the CPU functions.

## 1-17 External Interrupts

The maximum external interrupt system provides 224 interrupt levels in addition to those already existing internally in the CPU. Each level can be individually armed or enabled under program control. External interrupts are added to the computer with a maximum of 16 per chassis. Priorities are established at the time of installation.

## 1-18 Memory Expansion

Memory size can be expanded in increments of 4096 words to a maximum of 131,072 words.

## 1-19 Memory Port Expansion

Each memory bank may have from two to six entry ports, each of which may be connected to a memory bus containing data, address lines, and control signal lines. Each memory bus provides access to memory for one CPU, IOP, or other unit. The basic computer system includes two ports for each memory bank; an optional third port may be added for three-way access, and, if the third port is included, an optional port expander of four ports may be used to provide a total of six entry ports. Since each CPU or IOP has its own bus to any memory bank, a computer system with more than one memory bank can have more than one memory access occurring simultaneously.

## 1-20 Additional Eight Subchannels (IOP)

To increase the number of devices connected to one IOP, additional subchannels may be added in increments of eight up to a maximum of 32 subchannels for 32 devices.

## 1-21 Selector Input/Output Processor

The selector IOP provides control, sequencing, and data transmission for up to 32 high-speed peripheral devices operating one at a time. These devices may have data rates that would exceed the bandwidth of the multiplexing IOP or would use up such a large percentage of the bandwidth that it would be impractical to run any other device concurrently.

An optional selector channel identical to the first selector IOP may be added when a second high-speed data path is required. This optional additional channel may share the same memory with the first selector channel.

## 1-22 System Supervisory Console

The system supervisory free-standing console is a separate operator's control and display unit, featuring hexadecimal entry and display. Total system status is constantly presented for monitoring of system performance. A display of the rate of instruction execution is included.

## 1-23 Six Internal Interrupt Levels

Seven internal interrupt levels are included in the standard computer. The following internal interrupts are optional: two power interrupts (power fail-safe), two counter interrupts, and two counter zero interrupts.

## 1-24 SPECIFICATIONS

The general specifications for the Sigma 7 computer are given in table 1-3.

The input power specifications for the power supplies used in the computer are given in table 1-4. Power supply PT14 receives $60-\mathrm{Hz}$ power from the main power source and supplies 60 Vdc to the PT 15 power supply. The $120 \mathrm{~V}, 2000-\mathrm{Hz}$ output of the PT15 power supply is used as an input to the PT16, PT17, and PT18 power supplies. Since the PT14 and PT15 power supplies are always in series, the input and output power specifications are given as if the two were one power supply. The power output in watts from the PT16, PT17, and PT18 power supplies is determined by the power requirements of the computer. Power requirements for peripheral devices are given in the technical manuals for those devices.

The fuses and circuit breakers for the computer are contained in the power supplies and in the processor control panel and are listed in table 1-5.

The indicator lamps are located on the processor control panel and are listed in table 1-6 with reference designators and ratings.

Table 1-3. General Specifications

| Characteristic | Specification |
| :---: | :---: |
| Temperature (electronics) |  |
| Nonoperating | $-40^{\circ} \mathrm{C}$ to $60^{\circ} \mathrm{C}\left(-40^{\circ} \mathrm{F}\right.$ to $\left.140^{\circ} \mathrm{F}\right)$ |
| Operating | $5^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}\left(41^{\circ} \mathrm{F}\right.$ to $\left.122^{\circ} \mathrm{F}\right)$ |
| Altitude |  |
| Nonoperating | 20,000 ft max |
| Operating | $10,000 \mathrm{ft}$ max |
| Memory cycle |  |
| Without interleaving | 850 ns |
| With interleaving | 635 ns effective time |
| Logic signal levels | ONE, +4V; ZERO, OV |
| Word length | 32 bits plus parity bit |
| Data format | 8-bit byte, 16-bit halfword, fixed and floating point word, fixed and floating point doubleword |
| Coding | Binary |

Table 1-4. Power Supply Input Power Specifications

| Power Supply | Power Input |
| :---: | :---: |
| PT14, PT15 | 1.66 times VA output (2000 Hz) |
| PT17 (2400 Hz input) | $150+1.36$ times dc output in watts (table 1-5) |

Table 1-5. Fuses

| Name | Type | Reference Designator | Rating | Location | Circuit Protected |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Circuit breaker | PAM 666 | CB1 | 24 Vdc | Power Supply PT14 | Main power |
| Fuse | 3AG | Fl | $125 \mathrm{~V}, 8 \mathrm{~A}$ | Power Supply PT16 | $\begin{aligned} & 120 \mathrm{~V}, \\ & 2000 \mathrm{~Hz} \text { input } \end{aligned}$ |
| Fuse | 3AG | F2 | 125V, 8A | Power Supply PT16 | $\begin{aligned} & 120 \mathrm{~V} \\ & 2000 \mathrm{~Hz} \text { input } \end{aligned}$ |
| Fuse | 3AG | F3 | 250V, 10A | Power Supply PT16 | $\begin{aligned} & 120 \mathrm{~V} \\ & 2000 \mathrm{~Hz} \text { input } \end{aligned}$ |
| Fuse | 3AB | Fl | 250V, 15A | Power Supply PT17 | Input circuit |
| Fuse | 3AG | Fl | 250V, 4.0A | Power Supply PT18 | 120 Vac input |
| Fuse | 3AG | F2 | 32V, 7.5A | Power Supply PT18 | +25V |
| Fuse | 3AG | F3 | 250V, 1.5A | Power Supply PT18 | -25V |
| Fuse | 3AG | F4 | 32V, 10.0A | Power Supply PT18 | $+8 \mathrm{~V}$ |
| Fuse | 3AG | F5 | 250V, 1.5A | Power Supply PT18 | $+50 \mathrm{~V}$ |

Table 1-6. Lamps

| Type | Reference Designator | Rating | Quantity |
| :---: | :---: | :---: | :---: |
| Miniature incandescent | DS1 - DS21, | $5 \mathrm{~V}, 53 \mathrm{~mA}$ | 91 |
| Miniature incandescent | DS29-DS98 |  |  |
|  |  |  |  |

## SECTION II

OPERATION AND PROGRAMMING

## 2-1 INTRODUCTION

This section contains operating instructions and programming description. Sigma 7 operating instructions describe the purpose and function of the processor control panel (PCP), its control switches and displays. The paragraphs describing programming include instruction and data formats and computer modes. Descriptions of individual instructions can be found in the Sigma 7 Computer Reference Manual, publication No. 900950, and in the operation code descriptions in section III of this manual.

## 2-2 OPERATION

The following paragraphs describe the operating procedures required during computer maintenance. All operations are carried out from the PCP.

## 2-3 CONTROLS AND INDICATORS

The PCP is divided into two parts: a maintenance section on the upper half of the panel and an operator's or programmer's section on the lower half of the panel. The various control switches, indicators, and displays on the PCP are shown in figure 2-1. Table 2-1 lists the switches and indicators found on the programmer's section of the PCP with their reference designator and a brief functional description. A similar list of the switches and indicators on the the maintenance section of the PCP is given in table 2-2.

## 2-4 OPERATING PROCEDURES

The following paragraphs describe step-by-step manual procedures for the various operations from the processor control panel.

## 2-5 Applying Power

Both ac and dc power are applied to the CPU and to all units connected to it when the POWER switch is pressed. The POWER switch is lighted when ac power is applied to the system.

## 2-6 Displaying Contents of Memory Location

2-7 SELECTED ADDRESS. To display the contents of any core memory location or private memory register, perform the following steps.
a. Set the COMPUTE switch to IDLE. The PHASE display indicates that the CPU is in phase PCP2.
b. Place the address of the memory location (or of the register in the current private memory register bank) into the SELECT ADDRESS switches.
c. Place the DISPLAY switch in the momentary SELECT ADDR position.
d. Observe the binary contents of the selected address in the DISPLAY indicators.
e. Release the DISPLAY switch. The DISPLAY indicators still contain the contents of the selected location. The current instruction must be returned to the DISPLAY indicators by setting the DISPLAY switch to the momentary INSTR ADDR position, if the program is to be resumed by setting the COMPUTE switch to RUN or STEP.

The contents of the POINTER field must be changed to point to the desired register bank, to observe the contents of a private memory register in a register bank other than the one currently displayed by the POINTER field of PSW2. This operation is described in paragraph 2-12.

2-8 INSTRUCTION ADDRESS. To display the contents of the memory location indicated by the INSTRUCTION ADDRESS indicators, perform the following steps:
a. Set the COMPUTE switch to IDLE. The PHASE indicators show that the CPU is in phase PCP2.
b. Place the DISPLAY switch in the momentary INSTR ADDR position.
c. Observe the DISPLAY indicators, which now display the contents of the instruction address location.
d. If successive memory locations are to be displayed, perform steps $a, b$, and $c$ and momentarily set the INSTR ADDR switch to the INCREMENT position. The display indicates the contents of the INSTRUCTION ADDRESS indicator, which have been incremented by one. Continue setting the INSTR ADDR switch to INCREMENT to successive memory locations to be displayed.

The memory map is in effect if the memory map option is included and if the MAP MODE indicator is lighted. Memory protection, if included, is inhibited in these PCP operations.

## 2-9 Changing Contents of a Memory Location

2-10 SELECTED ADDRESS. To store data into selected memory locations, in core memory or in private memory, perform the following steps.
a. Set the COMPUTE switch to IDLE. The PHASE display indicates that the CPU is in phase PCP2.

SCIENTIFIC DRTR 5YSTEMS


Table 2-1. Controls and Indicators, PCP Programmer's Section

(Continued)

Table 2-1. Controls and Indicators, PCP Programmer's Section (Cont.)

| Control or Indicator | Function |
| :--- | :--- |
|  | c. PARITY ERROR MODE switch is set to CONT (continue) |
| d. CLOCK MODE switch is set to CONT (continuous) |  |
| e. All CPU, memory, and DC logic power margins are normal |  |

Table 2-1. Controls and Indicators, PCP Programmer's Section (Cont.)

| Control or Indicator | Function |
| :---: | :---: |
| INSTRUCTION ADDRESS Indicators | Seventeen indicators, part of PSW1, represent current contents of Q-register in CPU. Address displayed in this field is address of next instruction |
| DISPLAY Indicators | Thirty-two indicators are used to display contents of memory word when used with INSTR ADDR, STORE and DISPLAY (INSTR ADDR and SELECT ADDR) and DATA switches. DISPLAY indicators normally represent current contents of internal CPU sum bus. When moving COMPUTE switch from IDLE to RUN or STEP, the first instruction executed is the one displayed in the DISPLAY indicators |
| DATA Switches | Thirty-two DATA switches are used to change contents of program status doubleword when used with INSERT switch and to alter value of DISPLAY indicators when used with DATA CLEAR/ENTER switch. Each DATA switch is inactive in center position and is latching in both upper (1) and lower (0) positions. In center position, DATA switch represents no change. In upper or lower position, each switcí, represents 1 or 0 , respectively |
| INSERT Switch | Used manually to make changes in program status doubleword. Switch is inactive in center position and is momentary in upper (PSW2) and lower (PSW1) positions. When switch is moved to either PSW1 or PSW2, corresponding portion of program status doubleword is altered according to current state of DATA switches |
| STORE Switch | Used to change contents of either general register or memory location. Switch is inactive in center position and is momentary in INSTR ADDR and SELECT ADDR positions. When switch is moved to INSTR ADDR, current value of DISPLAY indicators is stored in location shown by INSTRUCTION ADDRESS indicators. When switch is moved to SELECT ADDR, current value of DISPLAY indicators is stored in location shown by SELECT ADDRESS switches |
| DATA Switch | Single DATA switch is used to change state of DISPLAY indicators. Switch is not active in center position and is momentary in CLEAR and ENTER positions. When switch is moved to CLEAR, all DISPLAY indicators are turned off. When switch is moved to ENTER, DISPLAY indicators are altered according to state of 32 DATA switches |
| INSTR ADDR Switch | INSTR ADDR (instruction address) switch is inactive in center position. Upper position (HOLD) is latching, and lower position (INCREMENT) is momentary. When switch is placed in HOLD, normal process of incrementing instruction address portion of program status doubleword with each instruction is inhibited. If COMPUTE switch is placed in RUN while INSTR ADDR switch is at HOLD, instruction in location displayed by INSTRUCTION ADDRESS indicators is executed repeatedly and INSTRUCTION ADDRESS indicators remain unchanged. However, if the instruction contains a branch or is a Load or Exchange Doubleword instruction, the specified instruction is executed. If COMPUTE switch is moved to STEP while INSTR ADDR switch is at HOLD, the instruction is executed every time the COMPUTE switch is moved to STEP, and INSTRUCTION ADDRESS indicators remain unchanged. The following operations are performed each time INSTR ADDR switch is moved from center position to INCREMENT: <br> a. Current value of INSTRUCTION ADDRESS indicators is counted up by one <br> b. Contents of virtual address displayed by INSTRUCTION ADDRESS indicators (subject to current memory map, if MAP mode indicator is lighted) are shown in DISPLAY indicators |
| DISPLAY Switch | Displays contents of either general register or memory location. Switch is inactive in center position and is momentary in both INSTR ADDR and SELECT |

(Continued)

Table 2-1. Controls and Indicators, PCP Programmer's Section (Cont.)

| Control or Indicator | Function |
| :--- | :--- |
| COMPUTE Switch | ADDR positions. When switch is moved to INSTR ADDR or SELECT ADDR, <br> contents of location shown by indicators or switches, respectively, appear in <br> DISPLAY indicators |
| Controls execution of instructions. Center position (IDLE) and upper position <br> (RUN) are both latching. Lower position (STEP) is momentary, When COMPUTE |  |
| switch is at IDLE, all other control panel switches are operative and interrupts |  |
| are disabled. When COMPUTE switch is moved from IDLE to RUN, RUN indi- |  |
| cator lights, and CPU begins to execute instructions as follows: |  |
| a. Current setting of DISPLAY indicators is taken as next instruction to be |  |
| Switch ADDRESS |  |
| executed regardless of contents of location shown by current value of INSTRUC- |  |
| TION ADDRESS indicators |  |
| b. Value in INSTRUCTION ADDRESS indicators is counted up by one |  |
| c. Instruction execution continues with instruction in location shown by |  |

Table 2-2. Controls and Indicators, PCP Maintenance Section

| Control or Indicator | Function |
| :---: | :---: |
| CONTROL MODE Switch | CONTROL MODE switch is a three-position key lock. When switch is in LOCAL, all confrols and indicators on PCP are operative, and most controls on free-standing console are inoperative. However, indicators on the free-standing console (if attached) continue to display the same information as indicators in programmer's portion of PCP。 POWER and INTERRUPT switches on free-standing console are operative when CONTROL MODE switch is in LOCAL <br> When switch is in REMOTE, all controls on free-standing console are operative, and all indicators on PCP maintenance section are operative. The WATCHDOG TIMER, INTERLEAVE SELECT, PARITY ERROR MODE, and AUDIO switches on the maintenance section are operative. All indicators on programmer's portion of PCP continue to display the same information as those on free-standing console. However, most of the switches on programmer's section are inoperative, The POWER switch is operative <br> When CONTROL MODE switch is in LOCK, all controls on free-standing console (except POWER, INTERRUPT and SENSE) are inoperative. Most controls on programmer's section of PCP are inoperative, although all indicators on both free-standing console and PCP continue to indicate various computer conditions. With CONTROL MODE switch in LOCK, the following switches on the PCP remain operative: POWER, INTERRUPT, AUDIO and all SENSE switches. The following switches are interlocked to the following states regardless of their actual settings when CONTROL MODE switch is in LOCK: <br> a. COMPUTE switch to RUN <br> b. WATCHDOG TIMER switch to NORMAL. <br> c. INTERLEAVE SELECT switch to NORMAL <br> d. PARITY ERROR MODE switch to CONT <br> e。 CLOCK MODE switch to CONT |
| MEMORY FAULT Indicators | Since the system is limited to no more than eight memory banks, each MEMORY FAULT indicator corresponds to a specific memory bank. Whenever a memory parity error occurs in a memory bank, the appropriate indicator lights and remains lighted until the indicator is reset. MEMORY FAULT indicators can be turned off by pressing CPU RESET/CLEAR or SYS RESET/CLEAR switches or by Read Direct instruction coded to read MEMORY FAULT indicators |
| ALARM Switch and Indicator | Indicator is used to attract operator's attention to some urgent operating condition and is turned on and off under program control by executing properly coded Write Direct instruction. When ALARM indicator is lighted and AUDIO switch is ON, a $1-\mathrm{kHz}$ signal is sent to PCP speaker. Speaker is disconnected when AUDIO switch is not set to ON. AUDIO switch does not affect state of ALARM indicator. ALARM indicator is turned off whenever CPU RESET/CLEAR or SYS RESET/CLEAR switches are pressed |
| PREPARATION <br> PHASES Indicators | Three indicators display in binary notation one of four CPU phases during preparation portion of instruction cycle |
| PCP PHASES <br> Indicators | Three PCP indicators display CPU phases during processor control panel operations. These phases, ranging from PCP1 to PCP7, are displayed in binary notation |

Table 2-2. Controls and Indicators, PCP Maintenance Section (Cont.)

| Control or Indicator | Function |
| :---: | :---: |
| EXECUTION PHASES <br> Indicators | Four EXECUTION indicators display CPU phases during execution portion of instruction cycle. These phases, ranging from PHI to PH 15 , are displayed in binary notation |
| INT/TRAP PHASES Indicators | Two indicators display four interrupt/trap phases during interrupt or trap operation |
| WATCHDOG TIMER Switch | When WATCHDOG TIMER switch is in OVERRIDE, watchdog timer is inoperative. When switch is in NORMAL, watchdog timer is operative. CPU can be interrupted at end of each instruction and at certain points during execution of some instructions. An interval of not more than $40 \mu \mathrm{~s}$ may occur between any two interruptible points. Watchdog timer is reset at each interruptible point and counts at a rate of $1-\mathrm{MHz}$ between interruptible points. If count in watchdog timer reaches $40 \mu \mathrm{~s}, \mathrm{CPU}$ traps to location $\mathrm{X}^{\prime} 46^{\prime}$ |
| INTERLEAVE SELECT <br> Switch | When switch is in NORMAL, interleaving between memory banks can be in effect according to the memory internal switches. When switch is at DIAGNOSTIC, memory addresses may not be interleaved between memory banks |
| PARITY ERROR MODE Switch | Controls action of CPU if a memory error occurs when the CPU is accessing, If switch is at CONT (continue) when parity error occurs, appropriate MEMORY FAULT indicator lights, and an interrupt signal is transmitted to memory parity interrupt level. If switch is at HALT when a parity error occurs, appropriate MEMORY FAULT indicator lights and CPU halts operation. Memory bank in which error has occurred is not available until its MEMORY FAULT indicator is reset or the PARITY ERROR MODE switch is set to CONT. In order to proceed, COMPUTE switch must be set to IDLE, CPU RESET or SYS RESET switches must be pressed, and COMPUTE switch then set to STEP or to RUN |
| SENSE Switches | Switches are used, under program control, to set the condition code portion of program status doubleword. When Read Direct or Write Direct instruction is executed in internal control mode, condition code is set according to state of four SENSE switches. SENSE switches are always operative and are normally used in this manner during diagnostic or other test routines |
| CLOCK MODE Switch | Controls internal CPU clock. When switch is at CONT (continue), clock operates at normal speed. When switch is in inactive (center) position, CPU clocks are not generated. Under these circumstances a single clock is generated each time CLOCK MODE switch is moved to SINGLE STEP position. As clock is stepped manually, PHASE indicators reflect CPU phase |
| REGISTER DISPLAY <br> Switch | Normally, REGISTER DISPLAY switch is not at ON. When switch is at ON, contents of register selected by REGISTER SELECT switch are displayed in DISPLAY indicators if the CLOCK MODE switch is in the center position |
| REGISTER SELECT <br> Switch | Used to display contents of selected internal registers. When CLOCK MODE switch is in center position, register selected by REGISTER SELECT switch may be shown in DISPLAY indicators by moving REGISTER DISPLAY switch to ON position. When REGISTER DISPLAY switch is returned to inactive position, DISPLAY indicators return to state previous to display of selected register |

b. Place the address of the memory location into which the data is to be stored in the SELECT ADDRESS switches.
c. If the entire contents of the memory word are to be changed, set the single DATA ENTER/CLEAR switch to CLEAR. This resets the DISPLAY indicators.
d. If the DISPLAY indicators have been cleared, set the DATA switches to one wherever a one is to be stored in the memory word. If only a part of the memory word is to be changed, set the DISPLAY switch to SELECT ADDR. The selected memory word appears in the DISPLAY indicators. Set the DATA switches to the center position wherever a bit is to remain unchanged. Where a one is to be changed to a zero, set the corresponding DATA switch to 0 ; where a zero is to be changed to a one, set the corresponding DATA switch to 1 .
e. Set the single DATA switch to ENTER and then release. The DISPLAY indicators contain the information to be stored.
f. Set the STORE switch momentarily to the SELECT ADDR position and release. The data in the DISPLAY indicators are stored in the selected memory location. The current instruction must be returned to the DISPLAY indicators by momentarily setting the DISPLAY switch to INSTR ADDR before program resumption by setting the COMPUTE switch to RUN or STEP.

2-11 INSTRUCTION ADDRESS. To store new data in the contents of the current instruction address, perform the following steps:
a. Set the COMPUTE switch to IDLE. The PHASE display indicates that the CPU is in phase PCP2.
b. Set the single DATA switch to CLEAR. This resets the display indicators.
c. Place the binary information to be sfored in the instruction address into the DATA switches.
d. Set the single DATA switch to ENTER and then release. The DISPLAY indicators then contain the same information as the DATA switches.
e. Set the STORE switch momentarily to the INSTR ADDR position and release. The data in the DISPLAY indicators are stored in the memory location indicated by the INSTRUCTION ADDRESS indicators. If the program is resumed by setting the COMPUTE switch to RUN or STEP, the new instruction set in the DISPLAY indicators is executed as the current instruction, followed by the instructions in successive memory locations.

If the memriy map option is included and the MAP MODE indicator is lighted, the memory map is in effect as the data is stored. Memory protection, if included, is inhibited in this PCP operation. To store data into a private memory
register bank other than the one currently displayed by the POINTER field of PSW2, the contents of the POINTER field must be changed to point to the desired register bank. This operation is described in the next paragraph.

## 2-12 Changing the Current Program Status Doubleword

Changing any data in the current program status doubleword (PSD) requires that PSW1 and PSW2 be treated separately and that the following steps be performed:
a. Set the COMPUTE switch to IDLE.
b. Enter the desired information into the 32 DATA switches in the bit positions of PSW1 or PSW2 being changed. In bit positions where no changes are made, the corresponding DATA switches must be in the center (no change) position. Be sure to set DATA switches to 0 where zeros are desired.
c. Set the INSERT switch to PSW1 or to PSW2, depending on the portion of the PSD that is being changed.
d. Release the INSERT switch. The new information is entered in the appropriate word of the program status doubleword.

## 2-13 Manual Branching

Perform the following steps to cause the CPU to branch to any instruction in memory, regardless of the instruction that is currently being executed.
a. Set the COMPUTE switch to IDLE.
b. Enter the address of the instruction to which the CPU is to branch in the 17 least significant DATA switches which correspond to the INSTRUCTION ADDRESS field of PSWI. Set the DATA switches to 0 where zeros are desired.
c. Set the INSERT switch to PSWI and release. The INSTRUCTION ADDRESS indicators display the address set in the DATA switches. The DISPLAY indicators display the instruction ready for execution when the CPU went into the idle state.
d. Set the DISPLAY switch to INST ADDR and release. The contents of the location in INSTRUCTION ADDRESS indicators appear in the DISPLAY indicators. The INSTRUCTION ADDRESS indicators continue to display the address set in the DATA switches. The instruction read from the location set in the data switches is the next instruction executed by the CPU.
e. If the COMPUTE switch is set to RUN, the CPU executes the instruction in the address in the INSTRUCTION ADDRESS indicators, then continues from the point in memory, executing instructions in successive memory locations.

## 2-14 Stepping Through a Program

It is often necessary when debugging programs or when maintaining the equipment to sequence slowly through the program one instruction at a time and to observe the results of each instruction after it has been executed. This is done by performing the following steps:
a. Set the COMPUTE switch to IDLE, and use the manual branching procedure to branch to the part of the program from which stepping is required. See paragraph 2-13.
b. Set the COMPUTE switch to STEP. The instruction in the branch location is executed. When the switch is released, the following instruction is displayed in the DISPLAY and the INSTRUCTION ADDRESS indicators.
c. The results of the executed instruction can be seen by displaying the contents of the memory location or private memory register affected by the instruction. See paragraph 2-7.
d. Repeat steps $b$ and $c$ to continue the program sequence step by step.

## 2-15 Single Clocking an Instruction

During maintenance operations, it is often necessary to sequence through individual instructions from one clock period to the next, observing the results in the CPU internal registers after each clock pulse. This technique can often be used to pinpoint a malfunctioning logic gate or an active circuit element without observing the action on an oscilioscope. However, this operation is not usually of value until after the malfunctioning instruction has been located. To singleclock instructions, perform the following steps:
a. Branch to the malfunctioning instruction, using the manual branching procedure in paragraph 2-13 or store an identical instruction in memory (paragraph 2-10) and branch to this location.
b. Set the CLOCK MODE switch to the center position. (This inhibits all clock pulses.) Set the COMPUTE switch to RUN or STEP.
c. Set the CLOCK MODE switch to SINGLE STEP. This causes the CPU to go to phase PCP3. PCP4 and PCP5 enter with further single clocking, then phase PREI of the instruction.
d. Observe the contents of the affected internal registers by setting the REGISTER SELECT switch to the proper register position and by setting the REGISTER DISPLAY switch to ON.
e. After all affected internal registers have been observed and if no malfunction is seen, repeat steps $c$ and d .

In most single-clock operations, the INSTR ADDR switch can be placed in the HOLD position if the single-clock operation is to be repeated more than once.

## 2-16 Single Instruction Repetition

Single clocking a malfunctioning instruction (paragraph 2-15) may pinpoint the area of the malfunction, but the observer may be unable to determine what is causing the faulty condition. In some cases, an error may consistently occur while the CLOCK MODE switch is in the CONT (continuous) position, but may never occur when the switch is in the SINGLE STEP position. This could be caused by a slow gate or by a slow active circuit element. In such a case, the operator should repeatedly run the single malfunctioning instruction using the oscilloscope to observe all signals that could be the cause of the error condition.

To run a single instruction repeatedly, perform the following steps:
a. Branch to the malfunctioning instruction. (See paragraph 2-13.)
b. Set the INSTR ADDR switch to HOLD. This prevents the instruction address field of PSW1 from changing after each instruction execution.
c. Set the COMPUTE switch to RUN and observe all pertinent signals on the oscilloscope as the instruction is repeatedly executed.

Certain instiuctions (for example, multiply and divide instructions which change an operand each time the instruction is executed) cannot be repeated in this manner without destroying data meaningful to the observer. For this type of instruction, it may be necessary to enter a small fouror five-word instruction program loop to establish initial conditions each time the instruction is observed.

## 2-17 Loading Program

After the input device has been loaded with the program tape or cards and has been properly prepared to read, the following steps should be completed to load the program into memory:
a. Set the COMPUTE switch to IDLE.
b. Press the SYS RESET/CLEAR switch.
c. Set the UNIT ADDRESS switches to the address of the desired input peripheral device.
d. Press the LOAD switch.
e. Set the COMPUTE switch to RUN. The CPU reads the program from the input device and stores it in memory.

## 2-18 PROGRAMMING

## 2-19 BASIC INSTRUCTIONS

Table 2-3 lists all of the basic operation codes, options included. Operation codes and corresponding mnemonics are given in table 2-4. This table also indicates optional, privileged, or nonexistent instructions. For detailed operation of each instruction see the Sigma 7 Reference Manual, XDS publication No. 900950 , or refer to the operation code descriptions in section III of this manual.

## 2-20 COMPUTER MODES

The Sigma 7 computer operates in either the master mode or the slave mode. The mode of operation is determined by the slave mode bit in program status doubleword 1. When this bit is set, the computer is in the slave mode. When the bit is reset, the program is in the master mode. The mode control bit can be changed when the computer is in the master mode and when a RESET signal is generated. The bit can also be changed when a trap or interrupt takes the program to an interrupt or trap location that contains a Load or Exchange Program Status Doubleword instruction. Therefore, a slave program cannot directly change the computer from slave to master mode.

In the master mode, any legal Sigma 7 instruction may be executed. In the slave mode, privileged instructions are prohibited. The following are privileged instructions:
a. Load Program Status Doubleword
b. Exchange Program Status Doubleword
c. Load Register Pointer
d. Move to Memory Control
e. Wait
f. Read Direct
g. Write Direct
h. Start Input/Output
i. Halt Input/Output
¡. Test Input/Output
k. Test Device
I. Acknowledge Input/Output Interrupt

An executive program, which is stored in memory and operates in the master mode, controls and supports the operation of other programs in the master or slave mode. Control returns to the executive program if any attempt is made by a program to execute a privileged instruction while the computer is in the slave mode. However, the slave program can gain direct access to certain executive program operations without the use of the executive program by means of Call instructions. The operations available through the Call instructions are established by the executive program.

Table 2-3. Basic Instructions

| Mnemonic | Code | Instruction Name |
| :--- | :--- | :--- |
| LOAD-STORE |  |  |
| LI |  |  |
| LB | 22 | Load Immediate |
| LH | 72 | Load Byte |
| LW | 52 | Load Halfword |
| LD | 32 | Load Word |
| LCH | 12 | Load Doubleword |
| LAH | $5 A$ | Load Complement Halfword |
| LCW | $5 B$ | Load Absolute Halfword |
| LAW | $3 A$ | Load Complement Word |
| LCD | $3 B$ | Load Absolute Word |
| LAD | $1 A$ | Load Complement Doubleword |
| LS | $1 B$ | Load Absolute Doubleword |
| LM | $4 A$ | Load Selective |
| LCFI | $2 A$ | Load Multiple |
|  | 02 | Load Conditions and Floating |
| LCF |  | Control Immediate |
| XW | 70 | Load Conditions and Floating Control |
| STB | 46 | Exchange Word |
| STH | 75 | Store Byte |
| STW | 55 | Store Halfword |
| STD | 35 | Store Word |
|  | 15 | Store Doubleword |

Table 2-3. Basic Instructions (Cont.)

| Mnemonic | Code | Instruction Name |
| :---: | :---: | :---: |
| LOAD-STORE (Cont.) |  |  |
| STS | 47 | Store Selective |
| STM | 2B | Store Multiple |
| STCF | 74 | Store Conditions and Floating Control |
| ANALYZE-INTERPRET |  |  |
| ANLZ | 44 | Analyze |
| INT | 6 B | Interpret |
| LOGICAL |  |  |
| OR | 49 | OR Word |
| EOR | 48 | Exclusive OR Word |
| AND | 4B | AND Word |
| CONVERSION |  |  |
| CVA | 29 | Convert by Addition |
| CVS | 28 | Convert by Subtraction |
| FLOATING POINT ARITHMETIC |  |  |
| FAS | 3 D | Floating Add Short |
| FAL | 1D | Floating Add Long |
| FSS | $3 C$ | Floating Subtract Short |
| FSL | 1 C | Floating Subtract Long |
| FMS | 3 F | Floating Multiply Short |
| FML | 1F | Floating Multiply Long |
| FDS | 3E | Floating Divide Short |
| FDL | 1 E | Floating Divide Long |
| DECIMAL |  |  |
| DL | 7E | Decimal Load |
| DST | 7F | Decimal Store |
| DA | 79 | Decimal Add |
| DS | 78 | Decimal Subtract |
| DM | 7 B | Decimal Multiply |
| DD | 7A | Decimal Divide |
| DC | 7 D | Decimal Compare |
| DSA | 7 C | Decimal Shift Arithmetic |
| PACK | 76 | Pack Decimal Digits |
| UNPK | 77 | Unpack Decimal Digits |
| FIXED-POINT ARITHMETIC |  |  |
| AI | 20 | Add Immediate |
| AH | 50 | Add Halfword |
| AW | 30 | Add Word |
| AD | 10 | Add Doubleword |
| SH | 58 | Subtract Halfword |
| SW | 38 | Subtract Word |
| SD | 18 | Subtract Doubleword |
| MI | 23 | Multiply Immediate |

[^0]Table 2-3. Basic Instructions (Cont.)

| Mnemonic | Code | Instruction Name |
| :---: | :---: | :---: |
| FIXED-POINT ARITHMETIC (Cont.) |  |  |
| MH | 57 | Multiply Halfword |
| MW | 37 | Multiply Word |
| DH | 56 | Divide Halfword |
| DW | 36 | Divide Word |
| AWM | 66 | Add Word to Memory |
| MTB | 73 | Modify and Test Byte |
| MTH | 53 | Modify and Test Halfword |
| MTW | 33 | Modify and Test Word |
| COMPARISON |  |  |
| Cl | 21 | Compare Immediate |
| CB | 71 | Compare Byte |
| CH | 51 | Compare Halfword |
| CW | 31 | Compare Word |
| CD | 11 | Compare Doubleword |
| CS | 45 | Compare Selective |
| CLR | 39 | Compare with Limits in Register |
| CLM | 19 | Compare with Limits in Memory |
| SHIFT |  |  |
| S | 25 | Shift |
| SF | 24 | Shift Floating |
| BYTE STRING |  |  |
| MBS | 61 | Move Byte String |
| CBS | 60 | Compare Byte String |
| TBS | 41 | Translate Byte String |
| TTBS | 40 | Translate and Test Byte String |
| EBS | 63 | Edit Byte String |
| PUSH-DOWN |  |  |
| PSW | 09 | Push Word |
| PLW | 60 | Pull Word |
| PSM | OB | Push Multiple |
| PLM | 0A | Pull Multiple |
| MSP | 13 | Modify Stack Pointer |
| EXECUTE-BRANCH |  |  |
| EXU | 67 | Execute |
| BCS | 69 | Branch on Conditions Set |
| BCR | 68 | Branch on Conditions Reset |
| BIR | 65 | Branch on Incrementing Register |
| BDR | 64 | Branch on Decrementing Register |
| BAL | 6A | Branch and Link |
| CALL |  |  |
| CALI | 04 | Call 1 |
| CAL2 | 05 | Call 2 |

(Continued)

Table 2-3. Basic Instructions (Cont.)

| Mnemonic | Code | Instruction Name |
| :--- | :--- | :--- |
| CALL (Cont.) |  |  |
| CAL3 | 06 | Call 3 |
| CAL4 | 07 | Call 4 |
|  |  |  |
| CONTROL |  |  |
| LSPD |  |  |
| XPSD | 0 E | Load Program Status Doubleword |
| LRP | $0 F$ | Exchange Program Status Doubleword |
| MMC | 2 F | Load Register Pointer |
| WAIT | 6 F | Move to Memory Control |
| RD | 2 E | Wait |
| WD | 6 C | Read Direct |
|  | 6 D | Write Direct |
| INPUT/OUTPUT |  |  |
|  |  |  |
| SIO | 4 C |  |
| HIO | 4 F | Start Input/Output |
| TIO | Halt Input/Output |  |
| TDV | Test Input/Output |  |
| AIO | Test Device |  |
|  |  | AEknowledge Input/Output |

Table 2-4. Basic Instruction Codes, Cross-Reference

| LEAST <br> SIGNIFICANT CHARACTER | MOST SIGNIFICANT CHARACTER |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 0 | * | AD | Al | AW | TTBS | AH | CBS | LCF |
| 1 | * | $C D$ | Cl | CW | TBS | CH | MBS | CB |
| 2 | LCFI | LD | LI | LW | * | LH | * | LB |
| 3 | * | MSP | MI | MTW | * | MTH | EBS ${ }^{\dagger}$ | MTB |
| 4 | CALI | * | SF | * | ANLZ | * | BDR | STCF |
| 5 | CAL2 | STD | S | STW | CS | STH | BIR | STB |
| 6 | CAL3 | * | * | DW | XW | DH | AWM | PACK ${ }^{\dagger}$ |
| 7 | CAL4 | * | * | MW | STS | MH | EXU | UNPK ${ }^{\dagger}$ |
| 8 | PLW | SD | CVS | SW | EOR | SH | BCR | DS ${ }^{\dagger}$ |
| 9 | PSW | CLM | CVA | CLR | OR | * | BCS | DA ${ }^{\dagger}$ |
| A | PLM | LCD | LM | LCW | LS | LCH | BAL | DA ${ }^{\dagger}$ |
| B | PSM | LAD | STM | LAW | AND | LAH | INT | DD ${ }^{\dagger}$ |
| C | ** | FSL ${ }^{\dagger}$ | ** | FSS $^{\dagger}$ | SIO** | * | RD** | DM ${ }^{\dagger}$ |
| D | ** | FAL ${ }^{\dagger}$ | ** | FAS ${ }^{\dagger}$ | TIO** | * | WD** | DSA ${ }^{\dagger}$ |
| E | LPSD** | $\mathrm{FDL}^{\dagger}$ | WAIT** | FDS ${ }^{\dagger}$ | TDV** | * | $\mathrm{AlO}^{* *}$ | $D C^{\dagger}$ |
| F | XPSD** | FML ${ }^{\dagger}$ | $L R P^{* *}$ | FMS ${ }^{\dagger}$ | $\mathrm{HIO}^{* *}$ | - | MMC** | DST ${ }^{\dagger}$ |
| *Nonexistent instruction <br> ${ }^{\dagger}$ Optional instruction <br> *Privileged instruction |  |  |  |  |  |  |  |  |

## SECTION III

 PRINCIPLES OF OPERATION
## 3-1 INTRODUCTION

This section describes the principles of operation of the Sigma 7 computer system on a general information, or block diagram, level and on a detailed information, or circuit diagram, level. The general principles describe the overall operation of the computer equipment, beginning with the main functions and proceeding logically through the subfunctions. The detailed principles describe the operation of each physical or functional unit of the equipment in terms of logic elements.

## 3-2 GENERAL PRINCIPLES

The computer system is organized around one or more central processing units, magnetic core memories, and input/ output processors, device controllers, and devices such as card readers and punches, magnetic tape units, and printers. Two types of input/output processors are available: a multiplexing input/output processor, which allows up to 32 peripheral devices to operate simultaneously, and a selector input/output processor, which allows one device at a time to operate at a high-speed transfer rate. The major system elements are shown in figure 3-1. Each of the illustrated system elements performs asynchronously with respect to the other elements.

## 3-3 CORE MEMORY

The core memory consists of from one to eight memory banks, each containing from 4 K to 16 K of memory. Thus,
a maximum memory system may contain 128 K of memory storage. Memory banks are connected in parallel to the central processing unit as shown in figure 3-2.

Each memory bank in the system contains three ports, designated A, B, and C. A port is a section of memory logic that controls entry priorities during memory access. Each port may be connected to a memory bus. A controlling central processing unit must be connected to port $C$ to provide auxiliary signals not present on the other ports. Port A and Port B may be connected to an input/output processor or to another CPU. Port A has the highest priority and port C , the lowest priority.

Either port A or port B may be replaced by a three- to sixport expansion unit, which expands one port to four ports. The three available ports on one memory bank are thereby increased to six. The four ports on the port expansion unit, designated ports 1, 2, 3, and 4, are assigned priorities in numerical order, port 1 having the highest priority and port 4 the lowest.

The memory is organized in banks as shown in figure 3-3.

A memory bank contains from one to four memory stacks plugged into one memory frame; hence, a memory bank may contain $4 \mathrm{~K}, 8 \mathrm{~K}, 12 \mathrm{~K}$, or 16 K words.


Figure 3-1. Sigma 7 System Elements


Figure 3-2. Memory Connection

## 3-4 Three-Wire Core Selection

The Sigma 7 combines the three-dimensional coincidentcurrent selection method with the two-dimensional linear selection method and is commonly known as the 2-1/2D system. The system has a coincident-current read cycle and a linear-select write cycle. Three wires are threaded through each core: an $X$ wire (word wire), a $Y$ wire, and a sense wire. No inhibit winding is necessary.

On each bit plane there are 128 X wires. Each X wire also threads all other bit planes on a core module. A bit plane contains 16 Y wires, which are separate for each bit plane. Each Y wire doubles back through a second row of cores to provide 32 Y wires in all. Typical X and Y wiring for two cores in each of two bit planes on a memory module is shown in figure 3-4. A sense wire threads through all of the cores on one bit plane.

When writing ones, half current is passed through one word wire, and half current is passed through the proper Y wire to select one out of 4096 cores. The addition of the two half-currents at the intersection forces the core to the logical one state. To write zeros, the Y current is inhibited on the bit planes where zero bits are desired. This is similar
to the linear-select method because the digit current is added to, rather than subtracted from, the word current.

When reading data, half current is passed through the appropriate $X$ wire, and half current is passed through the same $Y$ wire on all bit planes. All cores in the selected word location are forced to zero, and the sense wires detect current from the bit planes that contained ones in the selected location.

As shown in figure 3-4, each $Y$ wire on a bit plane passes through two rows of cores; hence, there are two core intersections for each combination of $X$ and $Y$ wires. For a given direction of current, the currents add in the core at one intersection and cancel in the other. Therefore, core selection is determined by current direction as well as by wire location.

## 3-5 Data Paths

Interchange of data between the CPU and memory takes place on the bidirectional 32-bit memory bus. Data entering memory from the CPU is gated onto the memory bus from the sum bus in the CPU and is placed in the memory data $(M)$ register. Outputs from the $M$-register flip-flops control current flow in the Y wires, causing ones or zeros to


Figure 3-3. Memory Organization
appear in the corresponding core locations. During read operation, outputs from the sense amplifiers cause ones or zeros to be placed in the M -register flip-flops. This information is transmitted on the memory bus to the C-register in the CPU. A similar memory bus connects the memory with the IOP, and data is transferred in both directions between the $M$-register in memory and a data register in the IOP, also designated the M -register.

## 3-6 Memory Timing

Two delay lines are used in a memory bank to control the timing; one controls the read cycle and the other controls the write cycle. The delay lines have taps at each $20-\mathrm{ns}$
interval. Both a read and a write cycle are required for each memory access. When a read cycle is used to read data from memory, it must be followed by a write cycle to restore the data to the same location. When a write cycle is used to enter data, it must be preceded by a read cycle to clear the location to zero.

Three types of memory access are used: read-restore, write full, and write partial. The latter is used when data is being entered only into 1, 2, or 3 bytes of the memory word. The timing is slightly different for each type of access.

The read cycle is the same in all three memory accesses. As a result of a memory request, a pulse is started down the read-delay line, Outputs from the delay line taps are used


901060A. 303

Figure 3-4. $X$ and $Y$ Core Winding, Typical
to control the timing signals to energize the $X$ and $Y$ drive lines, to set latches enabling data to enter the $M$-register, and to control the operations strobing data into the $M$ register. In the write-full operation, the read data is not gated into the $M$-register and is lost. In the write-partial operation, the read data is placed in the $M_{1}$-register, and parity is checked, but the data is not gated out of memory. Parity is also checked in the read-restore operation.

The write cycle is the same for read-restore and write-full operations. An output from the read-delay lines starts a pulse down the write-delay line. Outputs from the writedelay lines are used to send current through the $X$ and $Y$ drive lines in the opposite direction from that in read operation and to inhibit current in the Y lines on the bit planes where zeros are to be stored. Odd parity is generated in write-full operation by setting the parity flip-flop if the $M$-register contains an even number of ones.

Write partial timing is the same as for read-restore and write full except that energizing the drive lines is delayed long enough to set byte indicators that steer the information into the desired byte locations.

## 3-7 Interleaving

Memory speed can be increased by interleaving or overlapping the second cycle of one access with the first cycle of the following access as shown for a read-restore cycle in figure 3-5. This can be done only if successive words are stored in different memory banks, because both the read and write cycles of one access must be completed before another access is started when addressing twice in one memory bank.

As an example of interleaving, consider two 4 K memory banks and a program that stores data in a series of sequential memory locations. The first word is stored in one 4 K bank, the second word is stored in the same location in the second 4 K bank, the third word is stored in the first 4 K bank, and so forth. In larger memories with various bank sizes, the process is more complicated, but two successive words are never stored in the same memory bank.

## 3-8 CENTRAL PROCESSING UNIT

The basic central processing unit (CPU) consists of eight elements: private memory, arithmetic, control and address unit, processor control panel, internal interrupts, real-time clock, watchdog timer, clock-generation circuits, and power supplies (see figure 3-6).

## 3-9 Private Memory

The private memory is a bank of 16 integrated circuit flipflop registers containing 32 bits each. These registers which are loaded and unloaded through the arithmetic and control unit of the central processing unit are not available to the input/output units. The private memory registers may be used as accumulators, temporary storage, or to contain information such as data addresses, counts, points, and so forth. Any or all of private memory registers 1 through 7 may be used as index registers.

## 3-10 Arithmetic and Control Section

The registers in the arithmetic and control unit with data flow paths are shown in block diagram form in figure 3-7. The paths that are used at any one time are determined by the instruction being executed.

## CYCLE 1

CYCLE 2 WITHOUT INTERLEAVING
1


901060A. 304

Figure 3-5. Interleaving Timing

The functions of the individual registers are as follows:
a. C-Register. Receives data and instructions from private and core memory. The instruction operation code is placed in the O-register for decoding, and the private memory address from the R-field of the instruction is placed in the R-register. All C-register information used in the adder or placed on the sum bus which is a 32-bit data path with multiple sources goes through the D-register. Data may be modified in the adder and returned to the C-register via this sum bus. Addresses from the address field in the Cregister are placed on the core memory address lines if the address is greater than 15 , or on the private memory address lines if the address is 15 or less.
b. O-Register. Receives operation code from the operation field in the C -register.
c. R-Register. Receives private memory address from R-field in C-register and places the address on private memory address lines. In some instructions, the R-register contains the number used to modify the memory contents.
d. D-Register. Receives all C-register information except addresses. During manual entry of data, the Dregister receives information from the control panel DATA switches. The D-register receives condition codes from CC flip-flops and places data on the sum bus for memory storage and control panel display. It places the index register address on private memory address lines and supplies register pointer, RP, with a code indicating the private memory currently in use.
e. A-Register. Serves as one of the adder inputs. It receives direct inputs from private memory and receives
inputs from the sum bus so that A-register information may be modified in the adder and returned to the A-register. The A-register places information on the sum bus for memory storage and for control panel display.
f. B-Register, Used for temporary storage and as an intermediate register in certain operations.
g. CS-Register. Stores the carry in some adder operations. This register is also used for complementing and for other arithmetic functions.
h. RP-Register. Receives the most significant five bits of the private memory address from the D-register. These bits indicate the private memory block being used. The RP-register places these bits on the private memory address lines.
i. Q-Register. Holds the address of the next instruction and is displayed in the INSTRUCTION ADDRESS indicators on the control panel. The Q-register receives the address from the P-register, and sends the address to the $P$-register to be increased by one for the next instruction access. The $Q$-register also supplies the address to the private memory and to the core memory address lines.
i. P-Register. Holds the current instruction address, obtained from the Q-register, the sum bus, or the control panel INSTRUCTION ADDRESS switches. It puts information on the sum bus for storage or display, and supplies the address to core memory address lines. The P-register adds one to the address received from the $Q$-register.
The control flip-flops in the arithmetic and control unir are shown in figure 3-8. These flip-flops, together with the


Figure 3-6. Central Processing Unit, Functional Block Diagram

Q-register and RP-register, are part of the program status doubleword and are displayed as such on the control panel. The outputs of the flip-flops are used throughout the computer logic to control modes and operations.

The control flip-flops, their functions and setting conditions, are as follows:
a. Flip-Flops CC1 Through CC4. Condition code flipflops which indicate the nature of the results of an instruction. These flip-flops are set by various conditions at the end of an instruction, or may also be set by the control panel SENSE switches or the INSERT switch. When the INSERT switch is used, the information enters the CC flipflops by way of $S 0$ through $S 4$ of the sum bus. The trap
condition code flip-flops and signals from the decimal unit may also set CC1 through CC4.
b. Flip-Flops FS, FZ, and FN. Flip-flops used for control purposes in floating point instructions.
c. Flip-Flop MASTERF. When set, puts the computer in the slave mode. This flip-flop is set by bit 8 of the sum bus when a load or exchange program status doubleword instruction is being executed.
d. Flip-Flop MAPF. When set, puts the memory map in effect. It is set by bit 9 of the sum bus when a load or exchange program status doubleword instruction is being executed.


901060A. 307

Figure 3-7. Arithmetic and Control Unit Registers


Figure 3-8. Control Flip-Flops and Setting Conditions
e. Flip-Flop DM. When set, puts the decimal arithmetic trap in effect; it is set by bit 10 of the sum bus when a load or exchange program status doubleword is being executed.
f. Flip-Flop AM. When set, puts the arithmetic overflow trap in effect. Flip-flop AM is set by bit 11 of the sum bus when a load or exchange program status doubleword is being executed.
g. Flip-Flops WK0 and WK1. Write key bits used with the optional memory protection unit. These flip-flops are loaded from bits 2 and 3 of the D -register during load and exchange program status doubleword instructions.
h. Flip-Flops C1, II, and EI. Counter interrupt, input/output interrupt, and external interrupt group inhibit flip-flops. These are set by bits 5, 6, and 7, respectively, of the D -register during load and exchange program status doubleword instructions and are also set during a write direct instruction according to the configuration of the instruction.

## 3-11 Processor Control Panel

The processor control panel (PCP, figure 2-1) indicates the states of selected registers in the central processing unit and provides switch-controlled signals for manual computer operation. The upper section is specifically for maintenance purposes; the lower section is for the computer operator.

## 3-12 Internal Interrupt Circuits

The 16 internal interrupts in the central processing unit are classified as override, counter, and input/oufput as shown
in figure 3-9. The override interrupts always have the highest priority. The counter zero interrupts are activated when the corresponding counter in core memory reaches a count of zero. These interrupts may be inhibited as a group. The input/output interrupt levels receive signals from the input/output system or from the control panel. The interrupts, in order of their priority, take the program to the memory location which may contain a subroutine for processing the interrupt. Two levels of interrupt are contained on one interrupt module.

## 3-13 Clock Generator

The CPU clock generator produces an irregular clock signal. The time intervals of this signal are determined by the number of logic levels through which the computer control signals must pass before another clock is needed. Three types of clocks are generated: a CL clock for trailing-edge triggering of ac flip-flops in the computer system, a general register CK clock to gate information into the general registers, and a dc hold DCH clock to latch data in the Cregister.

A simplified block diagram of the clock generator is presented in figure 3-10. A clock pulse starts a pulse down delay line 4. This pulse is transmitted into delay line 1, and then into delay line 2 or 3 , depending on the length of the clock interval required. Signals are tapped off at various points on the three delay lines. To obtain time intervals longer than from the combined delay lines, the pulse is recirculated through delay line 2 from one to three times. Since a clock pulse cannot enter delay line 1 without a previous clock pulse, delay line 4 is used to produce


Figure 3-9. Internal Interrupt System, Block Diagram


Figure 3-10. Clock Generator, Simplified Block Diagram
a clock pulse when the control panel CPU RESET pushbutton is pressed at the start of the operation. Delay line 4 also produces a clock pulse after the clock logic has been disabled for a period of time, and a clock enable signal is received.

A $2-\mathrm{MHz}$ clock oscillator is included in the CPU in addition to the delay line clock circuits. The actual frequency is $2.048-\mathrm{MHz}$, and is crystal-controlled. This frequency is then down-counted by a flip-flop counter to make the following frequencies available:
2.048 MHz - used in the interrupt system

1. 024 MHz - used to provide clock for single-clock mode. Also available for use by all units in computer system

| 512 kHz | - unused |
| :--- | :--- |
| 256 kHz | - unused |
| 128 kHz | - unused |
| 64 kHz | - unused |
| 32 kHz | - unused |
| 16 kHz | - unused |
| 8 kHz | - input to time base selector |

4 kHz - unused
2 kHz - input to time base selector
1 kHz - input to time base selector. Also used to drive PCP speaker

500 Hz - input to time base selector

## 3-14 Real-Time Clock

The real-time clock basically consists of an oscillator and a time base selector as shown in figure 3-11. Two of the outputs from the time base selector are connected to the internal interrupt circuits as counter 3 and counter 4 count pulses. (See paragraph 3-12.) The desired frequencies may be selected by means of switches on the time base selector module. Two additional outputs from the time base selector are part of optional equipment and are used as counter 1 and counter 2 count pulses in the internal interrupt circuits.

## 3-15 Watchdog Timer

The watchdog timer ensures that the program periodically reaches interruptible points in instruction execution. The timer is a six-bit counter triggered by a $1.024-\mathrm{MHz}$ clock signal. The counter starts at the end of every instruction or at interruptible points in long instructions, and sends a trap signal to the trap circuits if a count of 40 is reached.


901060B. 311

Figure 3-11. Real-Time Clock, Simplified Block Diagram

This indicates an elapsed time of approximately $40 \mu s$ before another interruptible point or end of instruction is detected. Programs trapped by the watchdog timer usually cannot be continued.

## 3-16 Power Supplies

Power for the basic CPU is furnished by two PT14 ac-dc converters, two PT15 dc-ac inverters, four PT16 logic power supplies, and one PT 18 auxiliary power supply. An output from one of the PT15 converters supplies $120 \mathrm{~V}, 2000 \mathrm{~Hz}$ power for the core memory power supply (PT17).

## 3-17 OPTIONAL FEATURES

## 3-18 Decimal Arithmetic Unit

This unit contains the logic circuits to perform arithmetic and logic operations on four-bit binary-coded decimal data. Decimal instructions that may be executed are Add, Subtract, Multiply, Divide, Compare, Shift, Load, Store, Pack, Unpack, and comprehensive Edit. One eight-bit byte in memory contains two decimal digits. Decimal fields are variable in length, the longest being 31 digits plus sign.

## 3-19 Floating Point Arithmetic Feature

This feature extends the $\mathrm{A}-, \mathrm{B}-, \mathrm{C}-, \mathrm{D}-$, and CS -registers and the sum bus from 32 to 57 or 58 bits so that floating point arithmetic may be performed.

## 3-20 External Interrupts

Fourteen groups of external interrupts are available for recognizing and processing selected special conditions that exist in external equipment. All external interrupt signals are wired into the interrupt chassis according to the requirements of the individual system. The groups of external
interrupts can be connected in any priority sequence, determined by the manner in which it is connected to the rest of the interrupt system. Each group of external interrupts contains a maximum of 16 levels. The priority assignment of interrupts within these 16 levels is fixed, the level assigned the lowest memory address having the highest priority.

The individual interrupt modules, each containing the logic for two interrupt levels, are identical to the interrupt modules used in the internal interrupt system described in paragraph 3-12. The external interrupts operate in the same manner as the internal interrupts except for the source of the interrupt signal.

## 3-21 Power Fail-Safe Feature

The power fail-safe feature enables the computer to retain programs and processed or partially processed data when the primary power source fails. When a power failure occurs, the power fail-safe circuits notify the computer by an interrupt. Sufficient energy is stored in the Sigma 7 power supply system to maintain de power for the duration of a short power failure subroutine. Such a subroutine usually stores in core memory all pertinent volatile data held in flip-flops in the CPU. On reapplication of primary power, a second interrupt causes the computer to enter a power-on recovery subroutine that restores the computer to the state existing prior to the lapse of power.

The primary power source is monitored by a power monitor assembly located in the power distribution panel. When the power drops below a preset threshold, a power-off signal is generated and a power-on signal is generated when the line voltage goes above the preset level. Both of these signals, connected to the internal interrupt system, are part of the override group described in paragraph 3-12. The power-on and power-off signals have the highest priority in the override group and in the entire interrupt system.

## 3-22 Two Additional Real-Time Clocks

The optional two additional real-time clocks are identical to the two real-time clocks included with the standard computer system. Two additional interrupt modules must be added to the internal interrupt chassis to receive the counter 1 and counter 2 pulses described in paragraphs 3-12 and 3-14. The four counter interrupts are part of the override group in the internal interrupt system.

## 3-23 Additional Private Memory Register Banks

Up to 31 additional private memory register banks may be added to the CPU. Each bank is identical to the private memory bank included with the standard computer system and described in paragraph 3-9. One of a possible 32 private memory register banks is selected by a code in the program status doubleword and this code is placed in the RPregister.

## 3-24 Memory Map

When the computer is in the memory map mode (MM-bit in the program status doubleword true), all memory references used by the program (direct, indirect, or indexed) are referenced as program addresses. The memory map divides the program addresses into a series of 256 512-word blocks called memory map pages. The nine low-order bits of the program address select a word within a 512-word page of addresses. The eight high-order bits select one of 256 pages. The addresses of these pages appear in the CPU registers, but do not necessarily represent the same physical locations in core memory.

Associated with each page of addresses is an eight-bit map register. The 256 map registers are designated page 0 through 255 as shown in figure 3-12. These registers are integrated-circuit, fast-access memory registers identical to those used for the CPU private memory.

The program places in each map page register an eight-bit code representing the eight high-order bits of the address of an actual core memory location. When memory is addressed in the map mode and when indexing has been completed, the nine low-order bits of the address field in the $\mathrm{C}-$, $\mathrm{P}-$, or Q -register are presented to the nine low-order memory address lines. The eight high-order bits of the program address go into the map logic to select the outputs of the map register associated with the addressed page. The map register outputs replace the high-order bits of the program address and are presented to the high-order address lines to select an actual 512-word block of memory locations.

Using the memory map registers, the programmer may locate 512-word blocks of information in any desired positions in memory, either in a selected set of sequential locations or distributed throughout memory. Since the map is used during reading as well as during writing, the program address is altered by the map registers to read the information
out of the block of memory locations into which it was written,

The program used to load the map register contents into memory must organize the codes in a byte string as shown in figure 3-13. This series of codes in memory, the memory map control image, may reside in any set of sequential memory locations. A control image for the entire set of 256 map registers may be contained in 64 words in memory.

The map control image is transferred from memory to the map registers one word at a time by a Move to Memory Control instruction. Each memory word is transferred into four successive map registers.

Not all memory locations may be addressed at all times in the map mode. Program addresses in the range 0 through $F$ are not used to address core memory. The four low-order bits of the program address used as a private memory register address are the source or destination of the instruction operand.

In the master mode, the CPU has access to all memory locations. In the slave mode, however, memory access is controlled by a set of 256 program control registers that are part of the memory map option. A two-bit program control register is assigned to each page of program addresses as shown in figure 3-12. These registers are referenced as access control code registers in the Sigma 7 Reference Manual. The program control codes are interpreted by the CPU as shown in table 3-1.

The program control bits are stored in integrated-circuit fast-access memory registers like those used for the memory map codes. The program must first store in memory a series of two-bit codes, 16 codes to a memory word as shown in figure 3-14. This string of codes in memory is known as the program control image. The image is transferred to the program control registers by a Move to Memory Control instruction which reads a word at a time from memory and places the codes in a succession of locations in the fastaccess memory registers.

In the slave mode, when a program address is received by the CPU, the logic first checks the program control registers to see the type of access that may be made into the page of program addresses.

## Note

The memory map controls access into program addresses, not into actual core memory locations.

## 3-25 Memory Protection Feature

Access to core memory locations may be program-controlled by using a set of write lock registers identical to those used for the control codes. A two-bit write lock code is assigned


Figure 3-12. Memory Map Organization


Figure 3-13. Organization of Block Addresses in Memory Map Word

Table 3-1. Program Control Code Functions

| PCBO | PCBI | Function |
| :---: | :---: | :--- |
| 0 | 0 | Permits program to write into, read from, or take instructions from this page <br> of program addresses |
| 0 | 1 | Prevents writing into this page of program addresses, but permits reading or <br> taking instructions from this page |
| 1 | 0 | Prevents writing into or taking instructions from this page of program ad- <br> dresses, but permits reading from the page |
| 1 | 1 | Prevents any access to this page of program addresses by the slave program |



Figure 3-14. Organization of Program Control Codes in Memory Word
to each 512-word block of core memory addresses. The write lock codes with 16 codes to a memory word are first written into memory as a lock control image. The lock control image is transferred to the write lock registers by a Move to Memory Control instruction. When memory access is required, the write lock codes are compared with two write key bits in the program status doubleword to determine if the memory bank addressed may be used for reading or writing.

> Note
> The memory protection feature protects actual core memory addresses, not program addresses.

## 3-26 BASIC TIMING CHARACTERISTICS

Timing signals for instruction execution are taken from the clocks generated from delay line 1 or 3 and from two sets of timing sources: phase control flip-flops and clock-gating flip-flops. The phase control flip-flops determine the phase of the instruction being performed; that is, PREI through PRE4 are for preparation phases and PH 1 through PH 15 , for execution phases. Only one phase flip-flop is set at a time.

Every instruction must use preparation phases PRE1 and PRE2 to clear registers and to prepare for operand access. Phases PRE3 and PRE4 are used for operations that require special preparation sequences such as indirect addressing.

When preparation is complete, flip-flops PHI through PH15 are set in numerical order unless a branch signal is given during one phase to skip one or more phases at the next transition or to return to an earlier phase. Generally, only a few of the available phases are used, and the instruction may end at any point in the sequence.

The transition between phases is marked by a CL clock signal. Although the clock signal always comes from the same source, the time interval between clock pulses varies according to the time required to generate the signals needed before the next clock pulse. The time inverval is defined by one of the clock gating flip-flops, TIL, T4L, T8L, or T10L, or by a clock-gating signal, T6L, which is true whenever none of the clock-gating flip-flops is set. The time intervals are given in table 3-2. Gating the clock signals from the delay lines in the clock generator is shown in figure 3-10. A timing diagram of a typical sequence of CL clock pulses is given in figure 3-15.

## 3-27 CENTRAL PROCESSOR OPERATIONS

Computer operations are controlled by instructions, which are first loaded into memory and then read out of memory by the arithmetic and control units.

Reference addresses in the instruction word can be interpreted in three ways: the reference address refers to an actual location in memory, the location specified in the reference address contains the address of the instruction to
be executed (indirect addressing), or the contents of the index register must be added to the reference address before memory access (indexing). Indirect addressing and indexing may be performed on the same instruction; that is, memory is first indirectly addressed and then the contents of the index register are added to the address read from memory.

Table 3-2. CL Clock Pulse Intervals

| Gating Signal | Time Interval (ns) |
| :---: | :---: |
| TIL | 150 |
| T4L | 280 |
| T6L | 320 |
| T8L | 380 |
| T10L | 440 |

An immediate instruction contains in the reference address field a number to be operated on, rather than an address. If bit position 0 of an immediate instruction word contains a one, indicating indirect addressing, the operation is illegal, and the program branches to a trap memory location which may contain a subroutine to carry out the necessary remedial steps.

In all computer operations, words are read from memory a full 32-bit word at a time; however, writing may be done on a byte basis, using four signal lines to indicate which of four bytes are to be written.

## 3-28 PROCESSOR CONTROL PANEL OPERATIONS

When control switches are operated on the processor control panel, a phase sequence is entered similar to the phases used in central processor operations. The CPU contains a set of phase flip-flops designated PCP1 through PCP7 for use of the processor control panel. The flip-flops are set and
reset by ac clock signals from the CPU delay lines, usually using the T6L clock-gating signal.

Operating the RESET switch places the control panel logic in PCP2. When operating other switches, the other phases follow in numerical order, and the computer functions are performed according to the sefting of the switches. PCPI follows PCP7, except during a LOAD operation, and the operation waits in PCP2 until the COMPUTE switch is placed in RUN or STEP. The PCP then goes through the sequence to PCP5, and the next clock sets the first preparation phase flip-flop to start normal computer operation.

## 3-29 INTERRUPT OPERATION

This system permits the interruption of the normal sequence of events in the CPU by a signal generated either internal or external to the CPU. Each interrupt has an assigned priority and can be individually armed and enabled by the program. An active interrupt causes the program to branch to a memory address assigned to the interrupt, and the instruction in that address is executed. The interrupt location may contain a single instruction or may take the program to a subroutine. Normal operation can usually be resumed from the point of interruption.

Interrupt operations are controlled by phase flip-flops INTRAP1 and INTRAP2. The flip-flops are clocked by CPU ac clock signals; however, actual control of the phases is in the interrupt circuits which are clocked by a 2.048 MHz clock from the CPU. The synchronization of the clocks is accomplished by disabling the CPU clock until a clock is received from the interrupt chassis. During the interrupt phases, the next instruction address is stored, and the interrupt address associated with the interrupt in progress is received by the CPU for memory access.

Flip-flops in the interrupt circuits, which indicate whether the interrupt is armed, disarmed, enabled, wating, or active, determine whether or not an interrupt is admitted. Priority is established by cabling between these circuits,


Figure 3-15. CL Clock Timing, Typical
because only the highest priority interrupt may advance from the waiting to the active state.

## 3-30 TRAP OPERATION

The trap system is used basically for error detection. A trap indication results from a condition such as a nonexistent instruction, addressing a nonexistent memory location, watchdog timer runout, or an instruction calling for decimal or floating point operation when the option is not included in the system. The detection of a trap condition causes the immediate execution of a trap instruction in a unique location in memory. Trap operation is also used to simulate instructions not included in the system logic; that is, a Call instruction causes the program to trap to a specific location from which a branch is made to a subroutine to carry out the desired operation.

Trap operations are controlled by the two phase flip-flops used in interrupt operation: INTRAPI and INTRAP2. A trap operation has priority over any interrupt except when a power on or power off interrupt has been detected and the INTRAP phases are entered in the first cycle following the end phase of the instruction in process. Trap phases are clocked by T6L and T10L clocks and are not affected by the 2.048 MHz clock in the interrupt circuits. During the trap phases, the next instruction is stored and the trap address associated with the trap signal received is presented to memory for access. The program then branches to the memory address stored in the trap location.

## 3-31 INPUT/OUTPUT CHANNEL

An input/output channel is composed of a multiplexing input/output processor or a selector input/output processor and of one or more device controllers, each connected to one or more peripheral input/output devices such as card readers and punches, magnetic tape units, and printers. Operation of the device controllers and devices is covered in other technical manuals. Therefore, it is not explained in detail in this section.

The input/output processor controls all data transfers between the computer memory and the peripheral devices. After receiving an instruction from the CPU to start operation, the IOP executes input/output commands in much the same manner as the CPU executes instructions. Input/ output is performed simultaneously with central processing operations, since the IOP operates independently.

## 3-32 Multiplexing Input/Output Processor

The multiplexing input/output processor (MIOP) contains an address register, a data register, fast access memory registers, adding circuits, and delay lines for generating timing pulses. Interface signal exchange is via cable receivers and cable drivers, and a logical one is represented by +2 volts and a logical zero is represented by 0 volts.

Information exchange between the IOP and the CPU takes place on three function lines, three IOP address lines, and two condition code lines. The function lines carry a threebit code which indicates one of five input/output instructions being executed. The IOP address is a three-bit code designating one of eight possible IOP's being addressed. The IOP addresses, in the range 0 through 7 , are set by manual switches in the individual IOP units. Information exchange between the IOP and other units is shown in figure 3-16. However, timing, control, and interrupt signals are not shown on the diagram.

Each IOP is connected to one memory port and uses a single memory bus. Memory addresses are placed on the 17 address lines for memory access. Commands, responses, and data are carried on 32 memory data lines as shown in figure 3-16.

The eight data lines between the IOP and the device controller carry data in both directions and also carry the eight order bits from the input/output commands. Interrupts are generated in the device controller and are acknowledged by the IOP.

A general flow chart of the IOP functions during an input/ output operation is shown in figure 3-17. The functions in the instruction execution block are carried out in cooperation with the CPU. Except for the Halt instruction, the functions under command execution proceed without help from the CPU. Commands are first stored in memory by the CPU.

After a Start Input/Output instruction is indicated on the function lines, and an IOP recognizes its address on the IOP address lines, all communication between the IOP and the CPU takes place by way of locations $X^{\prime} 20^{\prime}$ and $X^{\prime} 21^{\prime}$ in memory. The IOP reads the first command address and the device controller (or device and device controller) address from location $X^{\prime} 20^{\prime}$. Information on the device status is then placed in locations $X^{\prime} 20^{\prime}$ and $X^{\prime} 21^{\prime}$ by the IOP for use by the computer. During command execution, the IOP acts independently and transfers a series of bytes between the device and successive locations in core memory until the number of bytes sepcified in the command doubleword is transferred. One word at a time is transferred between the IOP and memory on the 32 data lines. Transfer between the IOP and the device controller is a byte at a time on the eight data lines.

The IOP contains a fast-access memory register for each device controller. Each command goes into the register associated with the device controller specified in the input/ output instruction. In the command word there is an eightbit order field directing the peripheral unit to read, write, read backward, and so forth. These order bits are transferred directly to the device on the eight data lines without entering the memory register.


Figure 3-16. IOP Information Exchange


901060A. 313

Figure 3-17. IOP Functional Flow Chart for Input/Output

After input/output has started, the computer communicates with the IOP only to halt the operation, to test the status of data transmission or of the device, or to acknowledge an interrupt. Halt, Test, and Interrupt Acknowledge instructions are available for these communications. During execution of these instructions, the instruction code is placed on the function lines to the IOP. After an IOP address or an interrupt has been recognized, the remainder of the communication between the CPU and the IOP takes place via memory locations $X^{\prime} 20^{\prime}$ and $X^{\prime} 21^{\prime}$ as in the Start instruction. The type of information carried on the condition code, data, and status lines varies according to the instruction being executed.

Two types of chaining are used to permit the IOP to take more than one command from memory with only one instruction from the CPU.
a. Command Chaining. Stipulated by setting a command chain flag bit in the command doubleword in memory. When the command has been executed, the IOP, instead of terminating the service, steps up a command counter by one and reads the next command from the next memory location. This process continues until the IOP receives a command with a zero in the command chain flag bit. The command chain function permits the IOP to read a chain of commands
from core memory and to execute these commands until the chain is completed without communicating with the CPU.
b. Data Chaining. Setting a data chain flag bit in the command doubleword permits scatter-reading and gatherwriting. Scatter-reading is placing information from one physical record in a device into one or more noncontiguous memory locations. Gather-writing is taking information from one or more noncontiguous memory locations and writing it into one physical record in a device, such as a magnetic tape unit or a card punch. When a data chain flag bit is detected, the IOP reads a command from the next memory location as in command chaining; however, the order bits in the command are not passed on to the device controller. Thus, the operation required in the previous order is continued without starting a new record. Data chaining stops when a zero is detected in the data chain flag bit in a command word.

## 3-33 IOP Priority

Two types of priority are established in the system with regard to the IOP: interrupt priority and memory access priority.

Each IOP is recognized in the order of its assigned priority, if more than one IOP sends an interrupt request to the CPU
while an interrupt is being processed. The priority is determined by the cable connection as shown in figure 3-18. IOP 0 has the highest priority and IOP 4 has the lowest priority. All of the IOP's share a single interrupt request line to the CPU.

If more than one IOP requests memory access from the same memory bank at the same time, the priority is determined by the memory port to which the IOP is connected. Since memory port $A$ has a higher priority than port $B$, and the four port expander outputs have priority corresponding to their numerical order, the IOP units have memory access priority in the following order: IOP 4, IOP 3, IOP 2, IOP 1, and IOP 0 .

## 3-34 DETAILED PRINCIPLES

## 3-35 INTRODUCTION

This subsection describes the operation of each functional unit of equipment, primarily in terms of logic
elements (flip-flops, gates, registers) rather than in terms of circuit components (capacitors, resistors, transistors). Also included are functional, logic, timing, and simplified schematic diagrams.

## 3-36 Circuit Description

Diode-transistor logic is used for all Sigma 7 T-Series module logical functions. Integrated circuit flip-flops, inverters, and buffer amplifiers are combined with discrete electronic components such as diodes, transistors, and resistors to form logic element modules, flip-flop and register modules, and special circuit modules. The logic element modules contain AND, OR, NAND, and NOR gates. The outputs are logically amplified or amplified and inverted. The flip-flop modules are used for storage, counting, and shifting. The special circuits, such as cable drivers and receivers, oneshots, and lamp drivers, are used primarily for communication with other equipment or display devices.


Figure 3-18. IOP Priority Assignments

The clock pulse that is applied to the T-Series flip-flops is a standard 4 -volt logic signal that is shaped and synchronized to provide proper system operation.

Standard supply voltages for the logic circuitry are $+4,+8$, and -8 volts. Voltage tolerances must be within $\pm 10$ percent. The logic levels are +3.6 volts for a minimum logical 1 and +0.05 volts for a maximum logical 0 (nominal 0 volts for a zero and nominal +4 volts for a one). Typical noise margins are 1.1 volts for both one and zero rejections. The typical propagation delay time is 40 ns for flip-flops and 18 ns for buffered AND/OR or NAND/NOR gate circuits. Propagation time is defined as the time between a 50 percent change of input level and a 50 percent change in output level.

3-37 TYPICAL T-SERIES CIRCUIT. The AT21 cable driver schematic diagram in figure 3-19 shows a typical combination of an integrated circuit with diodes and resistors on a logic module. The module contains 14 cable driver circuits, only one of which is shown in the figure.

A logic diagram of the AT21 cable driver is shown in figure $3-20$. Diodes CR1 and CR2 make up one AND gate; diodes CR3 and CR4 make up a second AND gate; diodes CR5 and CR6 form an OR gate whose output is amplified by the integrated circuit buffer (XDS 306) A4 through A7. Emitter follower Q1 transmits an uninverted signal to the cable connected to P2.

As shown in figures 3-19 and 3-20, circuits 2 through 7 contain only one AND gate. In the remaining circuits, the outputs of two AND gates are joined in an OR gate.

The integrated circuit chip (XDS 306) consists of four buffer circuits, as shown in the schematic diagram of A4 through A7 (figure 3-19). The circuits are designated -1 through -4. As shown in figure 3-19, all of the buffer circuits are used on the AT21 module except A6-1 and A6-2.

3-38 INTEGRATED CIRCUITS. Six integrated circuits are used as the active logic elements in the Sigma 7 modules. The logic output of each circuit may be considered like a semiconductor switch at ground. A conducting output (transistor on) propagates a zero; an open output (transistor off) propagates a one. The $+4,+8$, and -8 supply voltages are standard for the integrated logic circuits.

The following integrated circuits are used in Sigma 7:
a. Memory Element (XDS 304). Contains eight storage bits in one integrated circuit element. A schematic diagram of the memory element is shown in figure 3-21. Each bit in the memory element consists of a flip-flop with the collectors of the two transistors, Q1 and Q2, connected to the source voltage. The control line is connected to transistor Q3 which supplies power to the decoding and writing circuits. When the control line is false, these circuits are deprived of power, and the data output line is the collector of a cutoff transistor, Q4. The three address lines are
decoded so that only one of the eight flip-flops in the memory element is subjected to a write line input. Also, only that bit controls the data output line. The registerwrite input must be true in order for a data input signal to set the selected flip-flop. A timing diagram of memory element operation is shown in figure 3-22.
b. Inverter (XDS 305). Contains four inverter circuits in one package. The inverters drive and are driven by diode-resistor AND/OR gates. The nominal threshold is +2.0 volts. Each inverter circuit presents the logical inversion of the input signal at the output. The typical gate structure for the inverter is shown in figure 3-23, and a schematic diagram of one inverter is shown in figure 3-24.

- c. Buffer (XDS 306). The XDS 306 buffer contains four buffer circuits in one package. The buffers drive and are driven by diode-resistor AND/OR gates. The nominal threshold is 2.0 volts. The typical gate structure for the buffer is shown in figure 3-25. Each buffer circuit presents the logical equivalent of the input signal at the output. A schematic diagram of one buffer circuit is shown in figure 3-26.
d. Flip-Flop (XDS 307). Contains one flip-flop circuit in one package. The flip-flop drives and is driven by dioderesistor AND-OR gates. The nominal threshold is 2.0 volts. The typical gate structure is shown in figure 3-27. A schematic diagram of the flip-flop is shown in figure 3-28, and a logic diagram is shown in figure 3-29. The flip-flop is set or reset on the trailing edge of the clock pulse. The flip-flop sets, if both set and reset inputs are true. The dc set and dc reset inputs act independently of the others. When the dc set input becomes one, the set output becomes one and remains one after the de set input becomes zero. When the dc reset input becomes one, the reset output becomes one and remains one after the dc reset input becomes zero. When the de set and dc reset inputs are one simultaneously, the state of the flip-flop is indeterminate.
e. Discriminator (XDS 308). Contains two discriminator circuits in one integrated circuit package. A schematic diagram of the discriminator is shown in figure 3-30. If the input signal is greater than the reference voltage, the discriminator generates a logical 1 at the output. If the input signal is less than the reference voltage, the discriminator generates a logical 0 at the output. The discriminator is driven by an emitter follower circuit of the type shown in figure 3-31, and drives diode-resistor AND/ OR gates of the type shown in figure 3-32. The voltage discrimination level for each circuit is set externally. Input signals must range from -2.0 to 4.4 volts with a voltage discrimination level between -1.5 and +1.5 volts.
f. Flip-Flop (XDS 311). Contains two flip-flop circuits in one package. A schematic diagram of the flipflop is shown in figure 3-33. The flip-flop changes state at the trailing edge of the clock pulse. If both the set and reset inputs are true, the flip-flop sets. The dc set and dc reset inputs act independently of the others.


Figure 3-19. AT2 1 Cable Driver, Schematic Diagram


Figure 3-20. AT21 Cable Driver, Logic Diagram


Figure 3-21. Memory Element (XDS 304), Schematic Diagram


Figure 3-22. Memory Element Operation, Timing Diagram


Figure 3-23. Gate Structure for Inverter (XDS 305), Typical


Figure 3-24. Inverter (XDS 305), Schematic Diagram


Figure 3-25. Gate Structure for Buffer (XDS 306), Typical


Figure 3-26. Buffer (XDS 306), Schematic Diagram


Figure 3-27. Gate Structure for Flip-Flop (XDS 307), Typical





Figure 3-31. Use of Discriminator (XDS 308), Typical


Figure 3-32. Discriminator (XDS 308) Gate Structure, Typical


Figure 3-33. Flip-Flop (XDS 311), Schematic Diagram

When the dc set input becomes one, the set output becomes one and remains one after the de set input becomes zero. When the dc reset input becomes one, the reset output becomes one and remains one after the dc reset input becomes zero. When the dc set and dc reset inputs are one simultaneously, the state of the flip-flop is indeterminate. The logical function is independent of the delay control input, which provides an output signal delay of 80 to 200 ns after the fall of the input clock pulse. This flip-flop is functional only if the delay control input is grounded. If the input is left open, the flip-flop (XDS 311) functions exactly like the flip-flop (XDS 307). The flip-flop drives and is driven by diode-resistor AND/OR gates of the type shown in figure 3-34.


Figure 3-34. Flip-Flop (XDS 311) Gate Structure, Typical

## 3-39 CPU INFORMATION TRANSFER AND STORAGE

## 3-40 Control and Data Registers

Information transfer and storage in the CPU is performed by 12 registers, designated $A, B, C, C C, C S, D, E, O, P$, $Q, R$, and RP. Temporary storage is provided by a set of private memory registers, and all data except address information leaves the CPU via the sum bus. An adder is used in conjunction with the A-, D-, and CS-registers for calculation purposes. Figure 3-35 shows the data transfer between the registers, the sum bus, and the adder.

This description includes a diagram of each register that shows inputs to the register and the enabling signal for each input. The byte inputs are not shown separately except for the C -register diagram. For example, the transfer of the sum
bus to the $B$-register is shown as $S 0-S 31$ into $B 0-B 31$. The enabling signal is given as $B X S-0$ through $B X S-3$. The actual enabling signals are: $B X S-0$ for byte $0, B X S-1$ for byte 1, BXS -2 for byte 2, and BXS-3 for byte 3 .

The generation of the enabling signals is shown in the set of logic diagrams that follow each register diagram. In most cases, the origin of an enabling signal is an instruction family and an instruction phase. The interpretation of the instruction family mnemonics and of other signals found in the logic diagrams is contained in the glossary of terms in th is manual. Register data transfers are given detailed explanation in discussions of the individual instructions.

Enabling terms for data transfer must be connected to the reset sides of the flip-flops so that when the input is a zero, a one previously in the flip-flop may be cleared. When the set and reset sides of a flip-flop in a CPU register are made true at the same time, the set side overrides the reset side, and the flip-flop sets.

3-41. A-REGISTER. The A-register is used for the following purposes:
a. Providing an accumulator for arithmetic calculations
b. Providing an intermediate register during storage of private memory information in core memory
c. Accepting $R$-register information when the R-field in an instruction is used as an operand during Modify and Test Word, Modify and Test Halfword, and Modify and Test Byte instructions
d. Shifting words right and left during shift instructions
e. Shifting private memory words right for byie and halfword instructions
f. Shifting private memory words left for indexing during doubleword operation
g. Receiving E-register information during exponent operation
h. Storing count from the E-register during byte string operations
i. Receiving count information from the E-register when storing the control image for the memory map and memory protection
i. Forming words for storage in core memory location X'20' for communication with the IOP

The A-register consists of 32 register flip-flops when the floating point option is not included. The floating point option adds 25 additional flip-flops. The flip-flops have both set and reset inputs.

Inputs to the A-register, with the enabling signals for each input, are shown in figure 3-36. The inputs to the $A-$ register floating point extension, with enabling signals, are shown in figure 3-37.


Figure 3-35. Arithmetic and Control Unit


Figure 3-36. A-Register Inputs and Enabling Signals


Figure 3-37. A-Register Extension Inputs and Enabling Signals

3-42 B-REGISTER. The B-register is used as follows:
a. To operate in conjunction with the D-register and the sum bus for arithmetic calculations
b. To indicate shift left and right for shift instructions
c. To save byte address for the P-register during byte string instructions
d. To contain the upper half of doubleword during doubleword instructions
e. To store address during interrupt operation
f. To store exponents

The standard B -register consists of 32 register flip-flops. With the floating point option, 25 additional flip-flops are added. The flip-flops have both set and reset inputs.

Inputs to the $B$-register, with the enabling signals for each input, are shown in figure 3-38. The inputs to the Bregister floating point extension are shown in figure 3-39.

3-43 C-REGISTER. The C-register serves as an instruction register and is used in calculations in conjunction with the A-, D-, and CS-registers. All core memory information enters the CPU via the C-register, and part of the private memory information also uses this path. Inputs for calculation purposes are received from the sum bus. Opcodes and private memory addresses are sent from the C -register to the O - and


NOTE: TERMS INSIDE BRACKETS ARE ENABLING SIGNALS

Figure 3-38. B-Register Inputs and Enabling Signals


NOTE: TERMS INSIDE BRACKETS ARE ENABLING SIGNALS

Figure 3-39. B-Register Extension Inputs and Enabling Signals

R-registers, respectively. Core memory addresses go directly from the C-register to the memory address lines. Ali other outputs from the C-register are taken to the Dregister. In doubleword operations, the C-register holds the 32 high-order bits of the effective doubleword.

The C-register is unique among the CPU registers in that its storage circuits are made of buffered latches instead of flip-flops. In the logic equations, these buffered latches are referenced as buffer flip-flops, designated by symbol FB.

The operation of a buffered latch, using bit one of the Cregister as an example, is illustrated in figure 3-40. Other bits are the same, except that with bytes 1, 2, and 3 the dash number after the HOLDC term and the number after the slash in the enabling terms is 1,2 , or 3 instead of 0.

When the C-register is loaded from private memory, the sum bus, or the memory bus, one of the three lower inputs to the OR gate (see figure 3-40) goes true, and buffer output Cl is driven true. The Cl output is fed back to the input of an AND gate containing holding term HOLDC-0. As long as HOLDC-0 is true, Cl contains a logical $1_{\text {; }}$ even after the qualifying signal has dropped. A zero is placed in Cl when a false output from one of the inverters causes $\mathrm{HOLDC}-0$ to go false.

A timing diagram for loading Cl from the sum bus is shown in figure 3-41. The generation of enabling signals CXS $/ 0$
through $C X S / 6$ is shown in figure 3-42. A low $N(S / C X S)$ signal is generated at the output of an AND gate whenever a combination of instruction logic and phasing indicates that a transfer from the sum bus to the C -register is to be performed. When ac clock signal occurs, CXSE goes true and is latched by feedback because CXS is false. After a $45-$ ns delay, CXSE/D rises, causing CXS to go true. Signal CXS is latched by feedback to the AND gate which contains DCH, true in its inactive state. Forty-five nanoseconds later, time delay output CXS/D causes CXS $/ 0$ to rise, and a one is gated into Cl by S 1 and $\mathrm{CXS} / 0$.

When a given time interval has elapsed after the occurrence of the ac clock, a pulse traveling down the clock generator delay line causes DCH to go false for 40 ns. The CXS latch is then released. Dropping CXS allows HOLDC-0 to go true, and the bit in Cl is latched until a subsequent signal drives HOLDC-0 false. Because of circuit delays between HOLDC-0 and CXS $/ 0$, CXS $/ 0$ remains true for a short time after HOLDC-0 rises. The overlap ensures that the latch will hold while the signals are changing.

Figure 4-43 shows all possible inputs to the C-register and the enabling signal for each input. Signal $C X / 1$ clears the C-register; CXRR transfers data from private memory; CXMB transfers data from the memory bus; and CXS transfers data from the sum bus. Signal CXCL32 moves data into bits 47 through 71 during floating point operation. Figure 3-44 is a logic diagram showing the generation of the enabling signals.


Figure 3-40. C-Register Bit 1, Simplified Logic Diagram


Figure 3-41. Loading Cl from Sum Bus, Timing Diagram


Figure 3-42. CXS Enabling Signal Generation



Figure 3-44. C-Register Enabling Signal Generation

Bits 46 through 71 of the C-register are included only when the CPU contains the floating point option.

3-44 CONDITION CODE REGISTER. The condition code register contains a four-bit code that indicates the nature of the results of an instruction. The significance of the condition code bits depends on the instruction just executed. The condition code register is also used as a control register during execution of Load Multiple, Store Nultiple, Edit Byte String, Push Multiple, and Pull Multiple instructions. The outputs of the condition code register are fed to the Dregister for storage in memory as part of the program status
doubleword. The CC-register is part of the program status doubleword. The condition code register consists of four flip-flops. Common inputs to all four flip-flops, with the enabling signal for each input, are shown in figure 3-45.

3-45 CS-REGISTER. The carry save (CS) register is used for the following purposes:
a. To save the carry bits in multiplication
b. To help form the two's complement of the data in the A - or D-register


Figure 3-45. Condition Code Register Inputs and Enabling Signals
c. To extend the sign of the R-field in the instruction when this field is used as a number

Only one bit (CS31) in the CS-register has a reset term. The reset sides of all the other flip-flops are connected to an ac-clock signal. These flip-flops reset at the first clock pulse after the setting term for the flip-flop has dropped.

The standard CS-register consists of 34 flip-flops, CSO through CS33. For the floating point option, 25 more flipflops, CS47 through CS71, are added. The inputs to the register are generate terms from the adder, designated $G$, and ones. Outputs are taken to the adder and to the sum bus. A block diagram of the CS-register with inputs is shown in figure 3-46.

3-46 D-REGISTER. The D-register is used for the following purposes:
a. To enter information from the data keys on the processor control panel
b. To receive data from the decimal arithmetic option
c. To receive direct input from external equipment by way of the read/write direct data lines
d. To form the program status doubleword for storage in memory
e. To place the index register address and private memory page address on the private memory address lines
f. To display the contents of the memory fault flipflops in the MEMORY FAULT indicators on the processor control panel
g. To align bytes and halfwords downward from the C-register for storage in memory
h. To perform arithmetic calculations
i. To provide intermediate storage during transfer from core memory into private memory


NOTE: TERMS INSIDE BRACKETS AND PARENTHESES ARE ENABLING SIGNALS

Figure 3-46. CS-Register Inputs and Enabling Signals
i. To store full words in core memory
k. To load into memory the complement of the word in the $C$-register

1. To extend the sign bit
m . To hold the 32 low-order bits of the effective doubleword in doubleword operation

The D-register consists of 33 register flip-flops, D0 through D31 and D71, when the floating point option is not included; 25 register flip-flops, D46-D70, are added for floating point operation. Flip-flop D71 is used in multiplication in the standard computer. The inputs to the D-register and to the D-register extension, with the enabling signals for each input, are shown in figures $3-47$ and $3-48$. The fourbyte enabling signals are given under one bracket for a specified transfer instead of showing individual byte transfer. For example, $C$ is gated into $D$ with $\mathrm{DXC} / 10$ through DXC/13. Byte 0 is gated with $\mathrm{DXC} / 10$, byte 1 with DXC/11, byte 2 with DXC/12, and byte 3 with DXC/ 13 . Other byte-enabling signals are similarly gated.

3-47 E-REGISTER. The E-register is used for the following purposes:
a. To hold the exponent in floating point operation
b. To check for a nonzero product in multiplication
c. To act as a counter in byte operation and in floating point shift instructions, and to place the control image in memory during memory map and memory protection operations

## d. To store the condition code in stack instructions

The E-register consists of eight counter flip-flops. Data enters the register via the B -register, the condition code register, and the sum bus. Outputs from the E-register are applied to the A-register. Internal E-register count logic adds or subtracts one from the contents of the register or subtracts four from the contents.

Figure 3-49 shows inputs to the E-register, with enabling signals. Count logic is not shown in this figure, but the complete count logic is given in table 3-3.

3-48 O-REGISTER. The O-register is an operation code register. Decoding to determine the instruction to be executed is done from this register. The operation code is taken from bits 1 through 7 of the C -register which contain the operation field of the instruction.

The O-register is made up of seven flip-flops. The inputs to the O -register and the enabling signals are shown in figure 3-50.

3-49 P-REGISTER. The P-register is used as a storage register for core memory addresses and as a counter. During
address storage, the count logic increases or decreases the contents of the P -register in increments of one in order to address the next memory location in sequence or to address the previous memory location. The P -register is part of the program status doubleword; however, the INSTRUCTION ADDRESS indicators in the program status doubleword on the processor control panel are lighted by the outputs of the Q-register that contain the same information.

The P-register consists of 19 counter flip-flops. Addresses are placed in the register by way of the sum bus, the Qregister, the interrupt address flip-flops, the trap address flip-flops, and the SELECT ADDRESS switches on the processor control panel. Address information goes out of the P-register to the core memory by direct input, via the LB lines, to the Q-register and to the processor control panel INSTRUCTION ADDRESS indicators via the sum bus.

Information input to the P -register and the enabling signals are shown in figure 3-51. The count logic for the P-register is not shown in this figure, but is discussed separately.

The counting function of the P -register is used for the following purposes:
a. To add or subtract increments to or from the entire P -register contents for address sequencing
b. To count shifts in shift instructions
c. To count iterations in multiply and divide instructions
d. To count words when storing the memory map or memory protection control image in memory

The P-register count-control logic operates on five separate sections of the register as shown in figure 3-52. The enabling signals are the plus-count P -register signals, PCTP1 through PCTP5, for adding increments to all five sections; and the minus-count $P$-register signals, MCTPI, MCTP2, and MCTP5 for subtracting increments from the corresponding sections.

The outputs of the P-register flip-flops and the plus-count signals PCTP1 through PCTP5 are used to add one to the contents of the $P$-register for address sequencing. Signal PCTP1 is generated for this purpose from the ENDE signal during the end phase of each instruction or from the following processor control panel switch inputs to the NPCTP1 logic:

KFILL (LOAD switch)
KINCREMENT (INCREMENT position of INSTR ADDR switch)

CLEARMEM (CPU RESET/CLEAR switch and SYSTEM RESET/CLEAR switch, pressed simultaneously)
$8 t-\varepsilon / \angle\rangle-\varepsilon$




Figure 3-48. D-Register Extension Inputs and Enabling Signals


NOTE: TERMS IN BRACKETS ARE ENABLING SIGNALS

Figure 3-49. E-Register Inputs and Enabling Signals

Table 3-3. E-Register Count Logic

| Count Enabling Signal | Flip-Flop | Set Logic | Reset Logic | Count |
| :---: | :---: | :---: | :---: | :---: |
| PCTE 1 | E4 <br> E5 <br> E6 <br> E7 | NE4 E5 E6 E7 <br> NE5 E6 E7 <br> NE6 E7 ES4 <br> NE7 ES4 | E5 E6 E7 <br> E6 E7 <br> E7 ES4 <br> ES4 | Counts up by ones. $E S 4=1$ during PCTE 1 |
| MCTE 1 | E4 <br> E5 <br> E6 <br> E7 | NE4 NE5 (NE6 NE7 + NES4) <br> NE5 (NE6 NE7 + NES4) <br> NE6 NE7 ES4 <br> NE7 ES4 | NE5 (NE6 NE7 + NES4) <br> NE6 NE7 + NES4 <br> NE7 ES4 <br> ES4 | If ES4 $=1$, counts down by ones. If ES4 $=0$, counts down by fours |
| PCTE2 | EO <br> El <br> E2 <br> E3 | NEO E1 E2 E3 <br> NE1 E2 E3 <br> NE2 E3 <br> NE3 | E1 E2 E3 <br> E2 E3 <br> E3 <br> PCTE2 | Counts up by ones |
| MCTE2 | E0 <br> E1 <br> E2 <br> E3 | NEO NE1 NE2 NE3 <br> NE1 NE2 NE3 <br> NE2 NE3 <br> NE3 | NEI NE2 NE3 <br> NE2 NE3 <br> NE3 <br> MCTE2 | Counts down by ones |



Figure 3-50. O-Register Inputs and Enabling Signals


NOTE: TERMS INSIDE BRACKETS AND IN PARENTHESES ARE ENABLING SIGNALS

Figure 3-51. P-Register Inputs and Enabling Signals


NOTE: ARROWS INDICATE COMMON ENABLING SIGNALS

Figure 3-52. P-Register Count Gating

The count begins in a two-bit counter, P30 and P31. When these flip-flops contain ones, PCTP2/1 is true, and P26 through P29 act as a four-bit counter until all of these flipflops contain ones. This causes P2629W to go true. Signal PCTP3 is then generated, and P23 through P25 count up by ones. Signal P2329W is now true, and PCTP4 counts up the section consisting of P19 through P21. At the end of this count, P1929W is true, and P15 through P18 are allowed to count to all ones. When the P -register is full of ones, the count is $13 \mathrm{i}, 072$ which includes ail locations in a maximum 128K memory.

The set and reset logic for each bit in the P -register during count operations is shown in table 3-4. Signal PA33 is true during byte string, decimal, translate, and move-to-memory control instructions. Signal FASHFX is true during shift instructions.

3-50 Q-REGISTER. The Q-register stores the next instruction address in order to release the $P$-register for other functions. In some cases, the $Q$-register outputs are applied directly to the core memory address iines for memory access. The Q-register information is transferred to the P -register when the $P$-register is ready to supply the address. When the computer is being set to the initial conditions by the CPU RESET switch, a hexadecimal 25 is placed directly in the Q-register.

Lamp drivers are connected to the Q-register flip-flops for display in the INSTRUCTION ADDRESS indicators in the program status doubleword on the processor control panel. The information in the $Q$-register, the same as that in the P -register, is part of the program status doubleword. A block diagram of the $Q$-register and the enabling signals is shown in figure 3-53.

3-51 R-REGISTER. The R-register stores the address of a private memory register. The register addresses, ranging from 0 to 15, address the 16 registers in one register bank. The address is received from the C-register, bits 8 through 11, which contains the R-field of the instruction word. Outputs from the R-register go to the private memory address lines.

The R-register acts as a counter when it is necessary to address sequential private memory registers. Signal PCTR (plus count the R-register) adds one to the contents of the R-register, and signal MCTR (minus count the R-register) subtracts one from the contents of the R-register. Table $3-5$ contains set and reset logic for each $\mathbb{R}$-register filipflop when counting up and down.

Figure 3-54 is a diagram of the R -register inputs and enabling signals. The count logic for the R-register is not shown.

Table 3-4. P-Register Count Logic

| Count Enabling Signal | Flip-Flop | Set Logic | Reset Logic | Count |
| :---: | :---: | :---: | :---: | :---: |
| PCTP1 | $\begin{aligned} & \text { P30 } \\ & \text { P31 } \\ & \text { P32 } \\ & \text { P33 } \end{aligned}$ | NP30 P31 (P32 P33 + NPA33) <br> NP31 (P32 P33 + NPA33) <br> NP32 P33 PA33 <br> NP33 PA33 | $\begin{aligned} & \text { P31 (P32 P33 + NPA33) } \\ & \text { (P32 P33 + NPA33) } \\ & \text { P33 PA33 } \\ & \text { PA33 } \end{aligned}$ | NPA true, P30 and P31 count up by ones; P32 and P33 remain unchanged. PA33 true. Four bits count up by ones |
| MCTP1 | $\begin{aligned} & \text { P30 } \\ & \text { P31 } \\ & \text { P32 } \\ & \text { P33 } \end{aligned}$ | NP31 NP30 N(FASHFX NP30 NP31) <br> NP31 N(FASHFX NP30 NP31) <br> PA33 NP33 NP32 <br> PA33 NP33 | NP31 N(FASHFX NP30 NP31) <br> N(FASHFX NP30 NP31) PA33 NP33 PA33 | FASHFX true. P30 and P31 count down by ones to zero, then remain unchanged. P32 and P33 cannot set or reset. PA33 true. P30 and P31 count down by ones; P32 and P33 count down by ones |
| PCTP2 | $\begin{aligned} & \text { P26 } \\ & \text { P27 } \\ & \text { P28 } \\ & \text { P29 } \end{aligned}$ | NP26 P27 P28 P29 <br> NP27 P28 P29 <br> NP28 P29 <br> NP29 | $\begin{aligned} & \text { P27 P28 P29 } \\ & \text { P28 P29 } \\ & \text { P29 } \\ & \text { PCTP2 } \end{aligned}$ | Counts up by ones |
| MCTP2 | $\begin{aligned} & \text { P26 } \\ & \text { P27 } \\ & \text { P28 } \\ & \text { P29 } \end{aligned}$ | NP26 NP27 NP28 NP29 <br> NP27 NP28 NP29 <br> NP28 NP29 <br> NP29 | NP27 NP28 NP29 <br> NP28 NP29 <br> NP29 <br> MCTP2 | Counts down by ones |
| PCTP3 | P23 <br> P24 P25 | NP23 P24 P25 <br> NP24 P25 <br> NP25 | $\begin{aligned} & \text { P24 P25 } \\ & \text { P25 } \\ & \text { PCTP3 } \end{aligned}$ | Counts up by ones |
| PCTP4 | $\begin{aligned} & \text { P19 } \\ & \text { P20 } \\ & \text { P21 } \\ & \text { P22 } \end{aligned}$ | NP19 P20 (P21 P22 + NPA22) <br> NP20 (P21 P22 + NPA22) <br> NP21 P22 PA22 <br> NP22 PA22 | $\begin{aligned} & \text { P20 (P21 P22 + NPA22) } \\ & \text { (P21 P22 + NPA22) } \\ & \text { P22 PA22 } \\ & \text { PA22 } \end{aligned}$ | NPA22 true. P21 and P22 remain unchanged; P19 and P20 count up by ones. PA22 true. Four bits count up by ones |
| PCTP5 | P15 <br> P16 <br> P17 <br> P18 | NP15 P16 P17 P18 NP16 P17 P18 NP17 P18 NP18 | P16 P17 P18 <br> P17 P18 <br> P18 <br> PCTP5 | Counts up by ones |
| MCTP5 | P15 <br> P16 <br> P17 <br> P18 | NP16 NP15 <br> NP16 <br> NP17 NP18 <br> NP18 | NP16 <br> MCTP5 <br> NP18 <br> MCTP5 | Counts 0000 down to 1111 |



Figure 3-53. Q-Register Inputs and Enabling Signals
Table 3-5. R-Register Count Logic

| Count Enabling Signal | Flip-Flop | Set Logic | Reset Logic |
| :---: | :---: | :---: | :---: |
| PCTR | R28 | NR28 R29 R30 R31 | R29 R30 R31 |
|  | R29 | NR29 R30 R31 | R30 R31 |
|  | R30 | NR30 R31 | R31 |
|  | R31 | NR31 | PCTR |
| MCTR | R28 | NR28 NR29 NR30 NR31 | NR29 NR30 NR31 |
|  | R29 | NR29 NR30 NR3I | NR30 NR31 |
|  | R30 | NR30 NR31 | NR31 |
|  | R31 | NR31 | MCTR |



Figure 3-54. R-Register Inputs and Enabling Signals

3-52 RP-REGISTER. The register pointer (RP) register is part of the program status doubleword and is used to store the address of a private memory extension register bank. This register is used when one or more additional private memory banks are included in the system to augment the 16 basic private memory registers in the standard computer. When the D-register contains PSW2 of the program status doubleword during PSD instructions, the register pointer is loaded from the D-register. During the Load Register Pointer instruction, the register pointer address is taken from memory and is stored in the RP-register through the D-register.

The RP-register consists of five flip-flops with inputs from the D-register and outputs to the private memory address lines. Figure 3-55 is a block diagram of the register and the enabling signal.


Figure 3-55. RP-Register Inputs and Enabling Signals

3-53 PRIVATE MEMORY REGISTERS. The private memory registers are located on a set of FT25 fast-access memory modules. The registers are installed in banks of 16, numbered register 0 through $F$ in hexadecimal notation. Each register contains a 32-bit word.

A maximum of 32 private memory banks may be installed in the computer. Each bank is assigned a page number, 0 through 31, and is addressed by the RP-register with codes from 00000 to 11111 . Page 0 is included in the standard computer; pages 1 through 31 are optional. Pages 0 through 3 are installed in frame 2 of computer unit 1. Additional pages are installed in the register extension chassis in frame 2 of unit 2.

Each private memory bank consists of four FT25 fast-access memory modules. The distribution of the words among the four modules is shown in block diagram form in figure 3-56. Each module contains one byte of any given word.

One FT25 module conains 16 eight-bit integrated circuit memory elements (XDS 304). A simplified diagram of a single memory element is shown in figure 3-57. The control, address, and VCC inputs are applied to all flip-flops in the element, although it is not shown in the diagram.

Each bit of the element is individually addressed by the address lines on pins 2, 3, and 4. The three-bit code selects one of eight flip-flops. The control line also contains address information. When the control line is false, the states of all bits in the memory element remain unchanged, regardless of the state of the read/write line. When the control line is true, bits of the element may change state if the read/write line is true; the output of each bit may be read when that bit is addressed regardless of the state of the read/write line.


Figure 3-56. Word Distribution in Private Memory Bank


Figure 3-57. Memory Element (XDS 304), Simplified Block Diagram

The arrangement of bits in the memory elements on one FT25 fast-access memory module is shown in figure 3-58. The module shown contains byte 0 of the standard private memory bank, designated page 0 . Each of the 16 memory elements contains eight corresponding bits in eight registers. The data, address, and write clock signals are interpreted as follows:
 (bit selection)


Input and output data signals for the four modules in a memory bank are shown in figure 3-59. The address lines in the four modules are identical.

Individual bits in each memory element on the FT25 modules are selected by address lines LR28 through LR31. As indicated in figure 3-58, a memory element contains a corresponding bit for each of eight registers. Dividing the memory elements into two sets of eight (figure 3-58), the three least significant bits (LR29, LR30, and LR31) select one of eight registers in each set (see figure 3-60). Address line NLR28 gates information into the memory elements containing registers 0 through 7, and LR28 gates information into the elements containing registers 8 through $F$. The gating signal is connected to the control line input of every memory element. The total effect of the LR28 through LR31 address lines is to select one of 16 registers for input or output of data. Gating signals RP23 through RP27 which designate the private memory page are taken from the RP-register. Since each memory bank is equivalent to one page, the four FT25 modules in one bank receive the same code from the RP-register and are enabled at one time.



Figure 3-59. Private Memory Data Organization


Figure 3-60. Bit Addressing on FT25 Module

The RP lines for the module in figure 3-58 contain NRP23 through NPR27 which select page 00000.

Address signals LR28 through LR31 are generated, in general, from either the R-register or the D-register. The Rregister contains the number of the private memory register to be addressed and is used when no crossover occurs. The equation is as follows:

$$
\text { LR28-LR31 }=\text { R28-R31 (LRXR NLRXLB) }+\ldots
$$

Crossover occurs when a core memory location with an address of less than 16 is addressed. During crossover, LR28 through LR30 are taken from the D-register, when transferring from the C-register to the core memory address lines with the equation

$$
\text { LR28-LR30 }=(\text { D28-D30 LMXC }+\ldots) \text { LRXLB }
$$

or are taken from the LB lines, when transferring from the Q -register or the P -register with the equation

$$
\text { LR28-LR31 }=(\text { LB28-LB31 NLMXC }+\ldots) \text { LRXLB }
$$

In cases of doubleword operation or multiple-word operation, LR31 is generated from other sources either to select an odd numbered register or to implement the function $\mathrm{R}+1$, as explained in the discussion on individual instructions. During the indexing operation, the private memory address is taken from bits 12 through 14 (the index field) of the Dregister.

$$
\text { LR29-LR30 }=\text { DI2-DI4 LRXD }+\ldots
$$

The equation for the register-write byte signals is as follows:

$$
\begin{aligned}
\text { RWB0-RWB3 }=\quad & {[R W+M B X S} \\
& \left.+N\left(N R V^{\prime} B 0\right)-N(\text { NRWB3 })\right] \text { NRWDIS }
\end{aligned}
$$

Where RW is a register-write enabling signal, MBXS gates the sum bus onto the core memory bus; NRWB0-NRWB3 are byte 0 through 3 gating terms generated from instruction and phase logic; and RWDIS is a private memory write-disabling signal. Signal MBXS is used when crossover occurs because of a core memory address less than 16. The CK clock signal, gated with the write byte signals, is the private memory clock which comes true 20 ns before the ac clock signal.

Data signals are gated from the sum bus into the private memory as follows:
RW0-RW31 = S0-S31 RWXS

3-54 REGISTER EXTENSION CHASSIS (REU). A register extension chassis contains up to 16 FT25 fast-access memory modules and adds from one to four banks of additional private memory to the central processor. Since one bank of private memory requires four FT25 modules, these modules in the register extension chassis must be added in multiples
of four. Up to seven register extension chassis may be added to the computer, making a maximum of 32 private memory banks, including the four banks in the CPU.

Additional modules in the REU provide cable drivers and receivers, terminators, chassis-selection switches and switch comparators, and logic circuits for selection and conversion of addresses and data signals. Figure 3-61 is a simplified logic diagram of the REU.

Address, data, and control signals are transmitted from the CPU on cables and are applied to cable receivers in the register extension unit. These bidirectional data cables also have cable driver inputs from the REU. Clock signals are taken from the ac clock circuits, CL1-CL12, in the CPU. The nomenclature, functions, and decoding of the interface signals between the CPU and the REU are given in table 3-6.

Each register extension chassis is assigned an address from 001 through 111 by manually setting switches S3-2, S3-1, and S2-2 on an LT26 switch comparator module in the desired configuration, with $52-2$ as the least significant bit. The outputs of these switches are designated SWIO for S3-2, SWI1 for S3-1, and SWI2 for S2-2. A MATCH signal is generated in the selected REU by comparing the switch signals with the chassis-selection bits in the address as follows:

$$
\begin{aligned}
\text { MATCH }= & \text { N(SWIO NREU0 + NSWIO REU0 } \\
& + \text { SWI1 NREU1 + NSWI1 REU1 } \\
& + \text { SWI2 NREU2 + NSWI2 REU2) }
\end{aligned}
$$

This MATCH signal is applied to an AND gate containing another input, NREUZ, to indicate that page 0 is not being addressed, and the AND gate output, register extension unit select (REUSEL), is connected to all of the FT25 modules in the selected REU.

Address lines LR26 and LR27, designated PAG0 and PAG1 in the REU, are decoded to select one of four blocks or pages in the selected REU. Figure 3-62 is a simplified logic diagram of page 0 of the selected REU, a typical connection. The data, address, and clock signals are interpreted as follows:

(bit selection)


Within each register extension unit, the pages are numbered individually 0 through 3.


Figure 3-61. Register Extension Chassis, Simplified Block Diagram


Table 3-6. REU Interface Signals

| Input Cable | Function | Cable Receiver Output | Address Decoding |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { /LR23/ } \\ & \text { /LR24/ } \\ & \text { /LR25/ } \end{aligned}$ | Address <br> Address <br> Address | REUO <br> REUI <br> REU2 | Seven chassis (in addition to one 4-module set in CPU) |
| $\begin{aligned} & \text { /LR26/ } \\ & \text { /LR27/ } \end{aligned}$ | Address <br> Address | PAGO <br> PAGI | Four 16-register backs in a chassis |
| /LR28/ | Address | WDA0 or WDB0 | Two sets of 8 memory elements on an FT25 |
| $\begin{aligned} & \text { /LR29/ } \\ & \text { /LR30/ } \\ & \text { /LR31/ } \end{aligned}$ | Address <br> Address <br> Address | WDAl or WDB1 WDA2 or WDB2 WDA3 or WDB3 | Eight flip-flops in a memory element |
| /RRWO/- <br> /RRW31/ | Data | Cable receiver output: WRO-WR31 <br> Cable driver input: FD0-FD31 RDB0-RDB3 |  |
| /RWBO1//RWB3/ | Write byte | WRB0-WRB3 |  |

Read byte signals RDB0 through RDB3 are generated when the switch settings match the chassis-selecting address lines and when the write byte signals are low as shown in figure $3-61$. The SWOI term is added to save power by turning off circuits in the unselected REU's.

Data is gated from the sum bus into the private memories in the CPU and in the REU as follows:
RW0-RW31 = S0-S31 RWXS/1-RWXS/3
(CPU private memory)

$$
/ \text { RRW0/-/RRW31/ = S0-S31 RRWXS/I-RRWXS/3 }
$$

(cables to REU)

The arrangement of bits in the memory elements on one FT25 fast-access memory module is shown in figure 3-62.

3-55 SUM BUS. The sum bus is a set of 32 wires ( 57 wires when extended) for floating point operation which carries all output information, except address signals, from the arithmetic and control section of the CPU. The sum bus is also used for the transfer of certain types of data between registers in the CPU.

Information is gated onto the sum bus from the A-, the B-, the CS- and D-register, and from the adder. Since the
sum bus bits are not stored in flip-flops, the terms are true only while the gating terms are true. Figure 3-63 shows the sum bus inputs and gating signals.

Outputs from the sum bus are sent to processor control panel indicators, decimal arithmetic chassis, core memory, private memory, and to external equipment via the direct input/output data lines. Gating signals for these outputs are shown in fable 3-7.

## 3-56 Adder

The adder performs the basic arithmetic and logical functions of the computer and is one of the outputs to the sum bus. The sum bus circuitry also gates other signals onto the sum bus. Figure 3-64 illustrates the adder and sum bus gating. For discussion purposes, both the adder circuitry and the sum bus gating circuitry are called sum bus gating. The sum bus gating performs four functions, as shown in the figure:
a. Adder Operation. Logical and arithmetic operations performed on the contents of the A-, D-, and CSregister contents
b. Register Gating. Direct gating of the A-, B-, CS-, $D-$, and $P$-registers to the sum bus
c. Display Lamp Gating. Gating of the sum bus outputs to the PCP DISPLAY lamps


Figure 3-63. Sum Bus Inputs and Gating Signals


Figure 3-64. Adder and Sum Bus Gating, Block Diagram
d. Load Gating. Gating of manually entered data (PCP LOAD switch entry) to the sum bus

Table 3-8 lists the functions that the sum bus gating performs, the controlling signals for each function, and the prior conditions for the performance of the function. The control signals listed in the table are generated by the operation code control logic circuits and are described in the operation code descriptions in this section.

In a computer without the floating point option, there are 32 individual adder and sum bus gating combinations, one for each of the 32 sum bus outputs, S0 through S31, similar to the circuit in figure 3-65. A computer with the floating point option utilizes 25 additional adder and sum bus circuits to perform the floating point operation. In the following paragraphs, discussion of the four sum bus gating functions is with reference to figure 3-65.

3-57 ADDER OPERATION. Parallel addition is used in the adder, that is, all bits in one register are added at the same time to the corresponding bits in another register. Figure 3-66 shows the logical operation of each of the 32 individual adder stages in the sum bus gating. Adder stage N sums the N th bit of the $\mathrm{A}-, \mathrm{CS}-$, and D -registers for all arithmetic and logical functions listed in table 3-8. The arithmetic and logical functions are divided into five groups: straight addition, exclusive OR addition, AND and OR functions, complementing, and upward alignment.

Each adder stage is a full adder which generates a sum signal (SN), a propagate signal (PRN), and a generate signal (GN). Signals PRN and GN are developed in place of a carry. They control certain logical operations and are used in developing carry signals for higher order adders. One carry signal, KN, decoded from the previous (lower order) GN and PRN signals, may be received by each adder stage; a carry is added to the Nth-bit sum of the A-, CS-, and $D$-registers. To accelerate adder operation, propagate, generate, and carry signals from lower order adders are gated together to produce carry signals to individual adders. Thus, a carry to an adder may be immediately detected rather than waiting until it is propagated over a long chain. Carry gating is discussed later in this section.

3-58 Generate Signal. The generate signal is used to develop carry signals for higher order adders and is routed to the higher order carry gating. Generate signal GN from adder $N$ is generally true whenever two of the three bits in bit positions AN, CSN, and DN are ones, regardless of the carry from the lower orders. In figure 3-66, for example, signal $G N$ is true whenever signals $A N$ and $D N$ are true (the CS-register has been previously cleared). For every adder function:

$$
\begin{aligned}
\text { GN }= & A N \text { DN + AN CSN NDN GX } \\
& + \text { NAN CSN DN GX }
\end{aligned}
$$

where:

The highest order adder stage is adder 0 , the lowest order is adder 31. Adder $N$ designates any adder ( 0 through 31 ); adder $\mathrm{N}+1$ is the adder one order below adder N .

GN $\quad=$ generate signal from adder $N$
AN, DN, CSN = Nth bit of applicable register GX $\quad=$ enabling signal for portion of generate gating

Table 3-7. Sum Bus Output Gating

| Signal Name | Logic Element | Destination | Equations |
| :---: | :---: | :---: | :---: |
| RW | Buifer | Private memory | $\begin{aligned} & \text { RW0-RW31 }=(\text { S0-S31 }) \text { RWXS } \\ & / \text { RRW0 } /-/ \text { RRW31/ }=(\text { SO-S31) RRWXS } \end{aligned}$ |
| $\begin{aligned} & S X / L \\ & (X=0-31,56-71) \end{aligned}$ | Lamp driver | Processor control panel indicators | $\begin{aligned} S 16 / L-S 31 / L= & (S 16-S 21) \\ & \mathrm{NKSHI}+(S 56-S 71) \\ & \mathrm{KSHI} \end{aligned}$ <br> where KSHI specifies high-order bits 56-71 |
| /MB/ | Cable driver | Core memory | $/ \mathrm{MBO} /-\mathrm{MB31} /=(S 0-S 31) \mathrm{MBXS}$ |
| /DU/ | Cable driver | Decimol arithmetic chassis | $\begin{aligned} & \text { /DU0/-,OU7/ }=\text { DUN/1-DU7/1 }+\ldots \\ & \text { DU0/1-DU0/4 }=(\text { S24-S31) DUXS }+ \end{aligned}$ |
| /DIO/ | Cable driver | External equipment via direct output | $/$ DIOO/-/DIO31/ $=(S 0-S 31)$ DIOXS |

Table 3-8. Sum Bus Gating Functions

| FUNCTION <br> Arithmetic and Logical Functions | CONTROL SIGNALS |  |  |  |  |  |  |  |  |  |  | $\begin{gathered} \text { PRIOR } \\ \text { CONDITIONS } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SXA | SXB | SXCS | SXD | GX | PRX | SXK | SXPR | SXP | SXUAB | SXUAH |  |
| (A plus D) $\rightarrow$ S | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | $\mathrm{O}^{\prime} \mathrm{s} \longrightarrow \mathrm{CS}$ |
| (A plus CS ) $\rightarrow$ S | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 's $\longrightarrow \mathrm{D}$ |
| (D plus CS) $\rightarrow$ S | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | $0^{\prime} \mathrm{s} \longrightarrow \mathrm{A}$ |
| $(A \oplus D) \longrightarrow S$ | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | $\mathrm{O}^{\prime} \mathrm{s} \longrightarrow \mathrm{CS}$ |
| $(A \oplus C S) \rightarrow S$ | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 's $\longrightarrow \mathrm{D}$ |
| $(D \oplus C S) \rightarrow S$ | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | $\mathrm{O}^{\prime} \longrightarrow \longrightarrow \mathrm{A}$ |
| $(A$ or $D) \longrightarrow S$ | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | $\mathrm{O}^{\prime} \longrightarrow \longrightarrow \mathrm{CS}$ |
| $(A$ and $D) \longrightarrow S$ | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | $1 ' s \longrightarrow C S$ |
| $(-A) \longrightarrow S$ | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | $\begin{aligned} & 1 \text { 's } \longrightarrow C S \\ & 0 ' s \longrightarrow D \\ & N G X \Longrightarrow 1 \rightarrow K 31 \end{aligned}$ |
| $(-D) \longrightarrow S$ | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | $\begin{aligned} & 1 \text { 's } \longrightarrow \mathrm{CS} \\ & 0 ' s \longrightarrow \mathrm{~A} \\ & \mathrm{NGX} \longrightarrow 1 \rightarrow \mathrm{~K} 31 \end{aligned}$ |
| $\begin{aligned} & \begin{array}{l} \text { A upward } \\ \text { aligned } \\ \text { (byte): } \end{array} \\ & \text { A24-A31 } \longrightarrow \\ & \text { S16-S23 } \\ & \text { A24-A31 } \\ & \text { S8-S15 } \\ & \text { A24-A31 } \longrightarrow \\ & \text { S0-S7 } \\ & \text { A24-A31 } \\ & \text { S24-S31 } \end{aligned}$ | $\begin{array}{r} 1 \\ \text { (A24 } \\ \text { to } \\ \text { A31 } \\ \text { only) } \end{array}$ | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | $\begin{aligned} & 0^{\prime} \mathrm{s} \longrightarrow \mathrm{D} \\ & \mathrm{O}^{\prime} \mathrm{s} \longrightarrow \mathrm{CS} \end{aligned}$ |
| A upward aligned (halfword): $\xrightarrow{\text { A } 16-A 31} \begin{aligned} & \text { S0-S } 15 \\ & \text { A16-A31 } \\ & \text { S16-S31 } \end{aligned} \longrightarrow$ | $\begin{array}{r} 1 \\ \text { (A16 } \\ \text { to } \\ \text { A31 } \\ \text { only) } \end{array}$ | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |  |
| D upward aligned (byte): $\begin{aligned} & \text { D24-D31 } \\ & \text { S16-S23 } \\ & \text { D24-D31 } \\ & \text { S8-S15 } \end{aligned} \longrightarrow$ | 0 | 0 | 0 | $\begin{array}{\|c} 1 \\ \text { (D24 } \\ \text { to } \\ \text { D31 } \\ \text { only) } \end{array}$ | 1 | 0 | 0 | 0 | 0 | 1 | 0 | $\begin{aligned} & 0 ' s \longrightarrow A \\ & C S \\ & \\ & \\ & \\ & \end{aligned}$ |

Table 3-8. Sum Bus Gating Functions (Cont.)

| FUNCTIONS <br> Arithmetic and Logical Functions | CONTROL SIGNALS |  |  |  |  |  |  |  |  |  |  | PRIOR CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | SXA | SXB | SXCS | SXD | GX | PRX | SXK | SXPR | SXP | SXUAB | SXUAH |  |
| $\begin{aligned} & \text { D24-D31 } \\ & \text { S0-S7 } \\ & \text { D24-D31 } \longrightarrow \\ & \text { S24-S31 } \end{aligned}$ | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | $\begin{aligned} & 0^{\prime} \mathrm{s} \longrightarrow \mathrm{~A} \\ & \mathrm{I}^{\prime} \mathrm{s} \longrightarrow \mathrm{CS} \end{aligned}$ |
| D upward <br> aligned <br> (halfword): $\begin{gathered} \text { D16-D31 } \\ \text { S0-S15 } \\ \text { D16-D31 } \\ \text { S16-S31 } \end{gathered}$ | 0 | 0 | 0 | $\begin{gathered} 1 \\ \text { (D16 } \\ \text { to } \\ \text { D31 } \\ \text { only) } \end{gathered}$ | 1 | 0 | 0 | 0 | 0 | 0 | 1 |  |
| Register Gating Functions |  |  |  |  |  |  |  |  |  |  |  |  |
| $A \longrightarrow S$ | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |
| $B \longrightarrow S$ | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |
| $\mathrm{CS} \longrightarrow S$ | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |
| $D \longrightarrow S$ | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |
|  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |  |
| Notes |  |  |  |  |  |  |  |  |  |  |  |  |

SXA, SXB, SXCS, SXD, SXP

GX, PRX

SXK, SXPD

SXUAB, SXUAH
$\oplus$
-
$A \longrightarrow B$
$\Rightarrow$

Gating signal for transfer of applicable register to sum bus

Enabling signal for portion of generate and propagate gating, respectively

Gating signal for transfer of acryy and propagate signals, respectively, to sum bus

Gating signal for upward alignment of byte and upward alignment of halfword to sum bus

Exclusive OR

Negation (two's complement)

A-register transferred to $B$-register

Implies


Figure 3-65. Typical Adder and Sum Bus Gating, Logic Diagram


Figure 3-66. Adder Logical Operation

3-59 Propagate Signal. The propagate signal PRN is used in developing the sum bus output for adder $\mathrm{N}, \mathrm{SN}$; it is also used to develop carry signals for higher order adders and is routed to higher order carry gating. Propagate signal PRN from adder $N$ is generally true whenever one or three bits in flip-flops AN, CSN, and DN are ones, regardless of the carry from the lower orders. In figure 3-66, signal PRN is true whenever either signal AN or DN is true (exclusive OR operation; CS-register has been cleared). For every adder function:

$$
\begin{aligned}
\text { PRN }= & \text { AN NCSN NDN + NAN NCSN DN } \\
& + \text { NAN CSN NDN PRX + AN CSN DN }
\end{aligned}
$$

where:

> PRN $=$ propagate signa! from $N$-adder
> PRX $=$ enabling signal for portion propagate gating

3-60 Carry Signal. Carry signal KN to adder N is added to signals $\mathrm{AN}, \mathrm{CSN}$, and DN . Signal KN is true when there is a generate signal from the next lower order adder,
$G(N+1)$; a generate signal from adder $N+1$ always results in a carry to adder $N$ whenever lower order additions are performed. For example:


There is also a carry to adder N whenever adder $\mathrm{N}+1$ produces a propagate signal and there is a carry signal to adder $\mathrm{N}+\mathrm{I}$, as in the following example:


The partial equation for a carry to adder $N$ is:

$$
K N=G(N+1)+P R(N+1) \quad K(N+1)+\ldots
$$

In some additions, a chain of carries is produced by an addition in one of the least significant orders. For example:


The chain of carries is started at the extreme right of the addition. The final carry takes a relatively long time to reach the most significant digit (MSD); if a carry for the MSD could be detected before it is transmitted by the previous order (that is, before going through the chain), addition would be faster. This is accomplished by gating in the adder. Carry gating for any adder $N$ is composed of AND-gated inputs of preceding (lower order) propagate, generate, and carry terms. The carry for adder $N$ is enabled whenever there are digits in the lower orders that produce the proper PR, G, and K terms which are digits that result in a carry to adder $N$. The carry to adder $N$ is then immediately detected and is sent to the adder. The carry gating equations that describe these configurations follow.

## K NUMBER


$\begin{array}{lllllllllllllll}16 & 17 & 18 & 19 & 20 & 21 & 22 & 23 & 24 & 25 & 26 & 27 & 28 & 29 & 30\end{array} 1$


Equations for carry (KN) for bit $N$ :

1. $K N=G(N+1)+P R(N+1) K(N+1)$
2. $K N=G(N+1)+P R(N+1) G(N+2)$
$+\operatorname{PR}(N+1) \operatorname{PR}(N+2) K(N+2)$
3. $K N=G(N+1)+P R(N+1) G(N+2)$
$+\operatorname{PR}(N+1) \operatorname{PR}(N+2) G(N+3)$
$+\operatorname{PR}(N+1) \operatorname{PR}(N+2) \operatorname{PR}(N+3) K(N+3)$
4. $K 3=K 19=[G(N+1)-(N+4)]$
$+\operatorname{PR}[(N+1)-(N+4)] G[(N+5)-(N-8)]$
$+\operatorname{PR}[(N+1)-(N+4)] \operatorname{PR}[(N+5)-(N-8)]$
$G[(N+9)-(N+12)]+P R[(N+1)-(N+4)]$
$\operatorname{PR}[(N+5)-(N+8)] \operatorname{PR}[(N+9)-(N+12)]$
$K(N+12)$

$$
\begin{aligned}
K 7= & K 23=G[(N+1)-(N+4)] \\
& +P R[(N+1)-(N+4)] G[(N+5)-(N-8)] \\
& +P R[(N+1)-(N-4)] P R[(N+5)-(N-8)] \\
& K(N+8)
\end{aligned}
$$

$$
K 11=K 27=G[(N+1)-(N+4)]
$$

$$
+P R[(N+1)-(N+4)] K(N+4)
$$

$$
\mathrm{K} 15=\mathrm{G} 1619 \text { + PR1619 G2023 }
$$

+ PR1619 PR2023 G2427
+ PR1619 PR2023 PR2427 G2831

$$
+ \text { PR1631 K31 + I(PH6 FAST) }
$$

$$
\mathrm{K} 31=(\mathrm{K} 00 \mathrm{H}+\mathrm{NFASHFL})(\mathrm{BO} \mathrm{CS} 32
$$

+ PR32 G33 + NGX)


## Note

A logic term in the form $A B 1115$ means that logic signals $A B 11$ through $A B 15$ are true simultaneously. That is, $A B 1115=$ $A B 11$ AB12 AB13 AB14 AB15

There are four sets of conditions that result in a carry to adder 20, for example:

Bit 20212223 Carry
Bit 20212223


The remainder of the right-hand side of the partial equation

$$
K N=G(N+1)+P R(N+1) \quad K(N+1)+\ldots
$$

is composed of propagate and generate terms from the preceding adders. (See preceding paragraphs for an explanation of the equation.)

3-61 Sum Bus Output. Sum bus output SN for any adder $N$ in the sum bus gating is always false if there are,
simultaneously, a carry to the adder and a propagate signal from the adder.

| 0 | 1 | Carry |
| :---: | :---: | :---: |
| 1 | 1 |  |
| 10 | 0 |  |
| PRN | G |  |

Either of these alone, however, produces a true output for SN . The equation for the adder N portion of the sum bus output is:

$$
S N=N(K N \text { PRN } S X K)(K N S X K+P R N S X P R+\ldots)
$$

where:

$$
\begin{aligned}
& \text { SXK = enabling term for carry gating } \\
& \text { SXPR =e enabling term for propagate gating } \\
& \text { SN }=\text { sum bus output for bit } N
\end{aligned}
$$

Figure 3-66 includes a truth table for an individual adder that illustrates a sample addition.

3-62 Addition. The adder adds the contents of two of the three registers together in a straight binary addition. The remaining register is cleared before the addition takes place. The sum output of each adder stage goes directly to the sum bus.

Figures 3-67 through 3-69 illustrate the three additive functions and list the simplified logic equations for each function. Only the last byte of each register is shown. Applicable control signals are defined in table 3-8.

3-63 Exclusive OR Operation. The adder adds the contents of two of the three registers together in an exclusive OR operation, that is, there is a true output for SN when there is a one in the Nth bit position of one, but not both registers. Since the propagate signal is developed according to the same rules as an exclusive OR addition, it alone is used as a signal to the sum bus gating; a propagate signal produces a true sum bus output. Carry and generate signals do not enter into the gating logic. The third register is cleared before the operation takes place.

Figures 3-70 through 3-72 illustrate the three exclusive OR operations and list the simplified logic equations of each. Only the last byte of each register is shown. Applicable control signals are defined in table 3-8.

3-64 AND and OR Operations. The AND operation is performed by filling the CS-register with ones and by adding the contents of the $A-$ and $D$-registers. The propagate signals, developed when there is a one in bit position AN and a one in bit position DN, are the only enabling signals to the sum bus gating used in this operation. A true propagate signal produces a true sum bus output.


Figure 3-67. (A Plus D) Gated to $S$


A $\quad G N=A N C S N$
PRN = AN NCSN + NAN CSN
$K N=G(N+1)+P R(N+1) K(N+1)+\cdots$
$S N=N(K N P R N)(K N+P R N+\cdots)$

10010110 G
01100001 PR
11101100 K
$\begin{cases}10 & 0 \\ 10: 1 & 1 \\ \mathrm{~T}_{24} \mathrm{~T}_{25} \mathrm{~T}_{26} \mathrm{~T}_{27} \mathrm{~T}_{28} \mathrm{~T}_{29} \mathrm{I}_{30} \mathrm{~T}_{31} & \mathrm{~S}\end{cases}$

Figure 3-68. (A Plus CS) Gated to $S$


Figure 3-69. (D Plus CS) Gated to $S$

## XDS 901060



Figure 3-70. (A $\oplus \mathrm{D})$ Gated to S


Figure 3-71. (A $\oplus C S$ ) Gated to $S$


Figure 3-72. ( $\mathrm{D} \oplus \mathrm{CS}$ ) Gated to S

The OR operation is not strictly an adder function since the two registers involved are simply gated to the sum bus at the same time. The adder acts as a two-input OR gate. The CS-register is cleared before the operation takes place.

Figures 3-73 and 3-74 illustrate the OR and AND operations, respectively, and list the simplified logic equations for each. Only the last byte of each register is shown. Applicable control signals are contained in table 3-8.

3-65. Complementing. This function is used to form the two's complement of the contents of either the A- or the D-register and to gate the result to the sum bus. The two's complement of any binary number is defined as $2^{x}-N$, where $x$ is the number of digits in a register. The two's complement of a binary number can be calculated by changing all the ones in the number to zeros and all of the zeros to ones and by adding one to the result. The adder performs two's complementing in this manner. The CS-register is filled with ones, and the register containing the number to be complemented is added to the contents of the CSregister; this addition effectively changes all zeros to ones and ones to zeros in the number. Since the carry for bit 31 is set initially to one, one is added to the result at the same time that the two registers are added.

Figures 3-75 and 3-76 illustrate the two complementing operations and list the simplified logic equations for each function. Only the last byte of each register is shown. Applicable control signals are defined in table 3-8.

## 3-66 Upward Alignment. This function is used to:

a. Transfer the last byte (bits 24 through 31 ) in the A- or D-register to all byte positions on the sum bus (bits S0 through S7, S8 through S15, S16 through S23, and S24 through S31). Figure 3-77 illustrates this operation.
b. Transfer the last halfword (bits 16 through 31 ) in the A- or D-registers to the two halfword positions on the sum bus (bits S0 through S15 and S16 through S31). Figure 3-77 shows this operation.

To perform the upward alignment, the CS-register is filled with ones, and the register not containing the byte or halfword to be transferred is cleared. The registers are then added and the choice of halfword or byte alignment is made by control signals $S X U A H$ or $S X U A B$, respectively.

Figures 3-78 through 3-81 illustrate upward alignment for bytes and halfwords and list the simplified logic equations for each. Applicable control signals are shown in table 3-8.

3-67 REGISTER GATING. The register gating portion of the sum bus gating transfers the contents of different registers onto the sum bus with application of the proper control signal. The register gating functions are listed in table 3-8. Registers $A, B, C S$, and $D$ are gated so that bits 0 through 31 go to sum bus outputs $S 0$ through S31, respectively. Register $P$ is gated so that bits 15 through 31 go to sum bus outputs S 15 through S31, respectively; bit 32 goes to bit S0, and bit 33 goes to S 1 .


Figure 3-73. (A OR D) Gated to $S$


Figure 3-74. (A AND D) Gated to $S$



00000000 G
01001011 PR
00000111 K


NOTE:
(-A) FUNCTION COMPUTES THE TWO'S COMPLEMENT OF A. IN GENERAL, TWO'S COMPLEMENT OF A NUMBER, $N$, IS $2^{\times}-N$, WHERE $X$ IS NUMBER OF DIGITS CONTAINED IN A REGISTER. THE COMPLEMENT OF 10110100 , THEN IS:

100000000
$-10110100$
01001100

Figure 3-75. Two's Complement of A Gated to S

$G N=0$
PRN = NDN
$K N-\operatorname{PR}(N+1) K(N+1)$ EXCEPT $K 31=1$
NGX $=>1 \rightarrow K 31$
$S N=N(K N$ PRN $)(K N+P R N)$ $=$ NPRN KN + PRN NKN

NOTE :
SEE FIGURE 3-75. THE TWO'S COMPLEMENT OF 11001010IS:

| 100000000 |
| ---: |
| -11001010 |
| 00110110 |

Figure 3-76. Two's Complement of D Gated to S


Figure 3-77. Upward Alignment, Functional Diagram


Figure 3-78. A-Register Upward Alignment (Byte)

$$
\begin{aligned}
& 10110101111010101100010101101110
\end{aligned}
$$

$$
\begin{aligned}
& 00000000000000000000000000000000 \\
& 10110101111010101100010101101110 \text { GN } \\
& 00000000000000000000000000000000 \text { PRN } \\
& 01101011110101011000101011011100 \mathrm{KN} \\
& G N=A N \\
& \text { PRN }=0 \\
& \begin{array}{|c|c|c|c|}
\hline 1100010101101110 & 1100010101101110 \\
S N
\end{array} \\
& K N=G(N+1) \\
& \left.\begin{array}{rl}
S N= & K N^{\prime} S X U A H \\
& + \text { AN SXA }
\end{array}\right] \text { WHERE } N^{\prime}=N+15 \text { IF } N=0 \text { TO } 15
\end{aligned}
$$

Figure 3-79. A-Register Upward Alignment (Halfword)


Figure 3-80. D-Register Upward Alignment (Byte)


Figure 3-81. D-Register Upward Alignment (Halfword)

Sum bus outputs S2 through S14 have no output for $P$ to $S$. The equation for the register gating portion of the sum bus output is:

$$
\begin{aligned}
S N= & A N S X A+B N S X B+C S N S X C S \\
& +D N S X D+P N^{\prime} S X P+\ldots
\end{aligned}
$$

Where:

$$
\begin{aligned}
N & =0-31 \\
N^{\prime} & =15-31 \text { when } N=15-31 \\
& =32 \text { when } N=0 \\
& =33 \text { when } N=1
\end{aligned}
$$

3-68 DISPLAY LAMP GATING. Display lamp gating is not strictly a part of sum bus gating but is related to it. The display gating enables the sum bus outputs to be displayed on the PCP display lamps, if the REGISTER DISPLAY switch is ON, the CLOCK MODE switch is not set to CONT, and the REGISTER SELECT switch is set to the appropriate position. The REGISTER SELECT switch generates control signals which select the register to be gated to the sum bus for later gating to the DISPLAY lamps. Figure

3-82 illustrates the display lamp gating, and table 3-9 lists the possible displays and the logic equations for the gating.

3-69 LOAD GATING. The load gating portion of the sum bus gating enables decoded data from the UNIT ADDRESS switches that has been entered by the LOAD switch to be gated to the sum bus. The entire loading process and switch functions are described in the discussion of the PCP in this section (paragraphs 3-303 through 3-340).

3-70 FIXED-POINT OVERFLOW. Fixed-point overflow occurs when the sum of an addition is greater than $2^{32}-1$; that is, when the sum is greater than the largest number that can be held in a 32-bit register. The buffered gate PROBEOVER (figure 3-83) determines those instructions in which an arithmetic overflow can occur. The equation for the buffered gate PROBEOVER is:

$$
\text { PROBEOVER }=P H 5(F A S 3+F A S 12+F A S 19+F A S 26)
$$

The instructions during which PROBEOVER is true are:
Load Complement Doubleword
Load Complement Word

Load Absolute Doubleword
Load Absolute Word
Add Immediate
Add Word
Add Halfword
Add Doubleword
Subtract Word
Subtract Doubleword
Subtract Halfword
Addition of magnitudes with unlike signs can never cause an overflow. The addition of magnitudes with like signs causes an overflow when the sign bit of the sum is different from the sign of the magnitudes being added. The buffered
gate OVER (figure 3-83) detects an overflow condition in the adder by the following logic:

```
OVER : NFAS1O (DO NKO NPRO)
    + NFASIO (NAO NDO KO NPRO)
```

Although PROBEOVER is true during Load Absolute Word and Load Absolute Halfword instructions, OVER cannot come true during these two instructions because the term NFAS10 inhibits the OVER gate.

The gate term (NAO NDO KO NPRO) in the above equation applies to the addition of two positive numbers in the Aand the $D$-registers. If $K 0$ is true, the sign of the sum of the two positive numbers is negative, causing OVER to be true. The gate term (DO NKO NPRO) in the above equation applies to the addition of two negative numbers in the Aand the D-registers.


Figure 3-82. Display Lamp Gating, Logic Diagram

Table 3-9. Display Lamp Gating, Logic

| $\begin{aligned} & \text { REGISTER } \\ & \text { SELECT } \\ & \text { POSITION } \end{aligned}$ | CONTROL SIGNALS |  |  |  |  |  |  | REGISTER DISPLA YED |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | KSHI | KSXE | SXA | SXB | sxcs | SXD | SXP |  |
| ${ }^{\text {a }}$ L | 0 | 0 | 1 | 0 | 0 | 0 | 0 | A0-A31 on lamps 0-31 |
| $\mathrm{A}_{\mathrm{H}}$ | 1 | 0 | 1 | 0 | 0 | 0 | 0 | A47-A71 on lamps 7-31 |
| $B_{L}$ | 0 | 0 | 0 | 1 | 0 | 0 | 0 | B0-831 on lamps 0-31 |
| ${ }^{\text {B }} \mathrm{H}$ | 1 | 0 | 0 | 1 | 0 | 0 | 0 | B47-871 on lamps 7-31 |
| $\mathrm{CS}_{\mathrm{L}}$ | 0 | 0 | 0 | 0 | 1 | 0 | 0 | CS0-C531 on lamps 0-31 |
| $\mathrm{CS}_{\mathrm{H}} \mathrm{E}$ | 1 | 1 | 0 | 0 | 1 | 0 | 0 | CS47 not observed CS48-CS71 on lamps 8-71 E0-E7 on lamps 0-7 |
| $\mathrm{D}_{\mathrm{L}}$ | 0 | 0 | 0 | 0 | 0 | 1 | 0 | D0-D31 on lamps 0-31 |
| $\mathrm{D}_{\mathrm{H}}$ | 1 | 0 | 0 | 0 | 0 | 1 | 0 | D47-D71 on lamps 7-31 |
| P | 0 | 0 | 0 | 0 | 0 | 0 | 1 | P15-P31 on lamps 15-31 P32 on lamp 0, P33 on lamp 1 |
| $S_{L}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | S0-S31 on lamps 0-31 |
| Notes <br> KSHI =: REGISTER DISPLAY switch ON. CLOCK MODE switch not in COUNT. REGISTER SELECT switch in $A_{H^{\prime}}{ }^{B_{H^{\prime}}} C S_{H^{\prime}} E, D_{H^{\prime}}$ or $S_{H}$ <br> KSXE KSHI. REGISTER SELECT switch in CSL <br> SXA, SXB, SXCS, SXD, SXP = Gating signals for transfer of applicable register to sum bus Logic Equations |  |  |  |  |  |  |  |  |


9010608. 3520

Figure 3-83. Overflow into Condition Code Bit CC2, Simplified Logic Diagram

If DO is true and NPRO is true, then either CSO or AO, but not both, must contain a one. If $K 0$ is not true, the sign of the sum of the two negative numbers being added is positive, causing OVER to be true.

In all instructions in which a fixed-point overflow can occur, condition code bit CC2 is set to a one if overflow occurs.

```
S/CC2 = OVER PROBEOVER + ...
```

Condition code bit CC2 is set if an overflow should occur during a Load Absolute Word instruction (FAS10). This happens only if the effective word contained a one in bit position 0 and zeros in bit positions 1 through 31 (negative zero). Carry K 0 can never be true (overflow can never occur) in a Load Absolute Halfword instruction.

An overflow occurs during a fixed-point left shift instruction when bit 0 and bit 1 of the A-register are not of the same binary magnitude.

$$
S / C C 2=S F T L 1 \text { NP25 (NA0 A1 }+A 0 \text { NA1 })
$$

Overflow can occur as the result of certain conditions during a divide instruction. Since overflow by divide is not strictly an adder function, it is treated separately in the Divide instructions (paragraph 3-201).

3-71 FIXED-POINT END CARRY. The buffered gate K00 checks for an end carry condition during all additions onto the sum bus. An end carry is meaningful only in those operations in which bit 0 of both the addend and the augend are considered to be magnitude bits rather than sign bits. End carry generation is independent and exclusive of overflow generation. For example, if the overflow has
significance in a specific instruction, the end carry, if generated, has no significance. Conversely, if the end carry has significance in a specific instruction, the overflow, if generated, is ignored.

In many instructions, both overflow and end carry are recorded in CC2 and CCl, respectively, after the instruction has been completed.

In both Add Doubleword and Subtract Doubleword instructions, the end carry out of the low order sum is transferred to flip-flop K00H. See figure 3-84. Flip-flop K0OH forces a one into CS31 for the addition of the high order sum, which, in effect, adds the end carry from the low order sum to the high order sum. In an Add Word or a Subtract Word instruction, an end carry is recorded in condition code bit CCl . This end carry has meaning only if the program is dealing with multiple precision fixed-point numbers.

The following five examples describe conditions in which combinations of overflow and end carry can occur.

Example 1. No overflow, no end carry

## Sign

Bit

| 0 | 0 | 1 | 1 | 0 | 0 | . | . | . | 0 | Augend |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 0 | 0 | 1 | 0 | . | . | . | 0 | Addend |
| 0 | 1 | 1 | 1 | 1 | 0 | . | . |  | 0 | Sum |

Example 2. Overflow, no end carry

> Sign

Bit

| 0 | 1 | 0 | 0 | 0 | 0 | . | . | . | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 0 | 0 | 1 | 0 | . | . | . | 0 |
| 1 | 0 | 0 | 0 | 1 | 0 | . | . | . | 0 |

Augend
Addend
Sum
Example 3. No overflow, end carry

> Sign

Bit

| 1 | 0 | 1 | 0 | 0 | 0 | . | . | . | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 1 | 1 | 1 | 0 | 0 | . | . | . | 0 |
| 1 | 0 | 0 | 1 | 0 | 0 | . | . | . | 0 |

Augend
Addend

Sum
Example 4. No overflow, end carry
Sign
Bit

| 0 | 1 | 0 | 1 | 0 | 0 | . | . | . | 0 | Augend |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 1 | 0 | 0 | 0 | 0 | . | . | . | 0 | Addend |
| 0 | 0 | 0 | 1 | 0 | 0 | . | . | . | 0 | Sum |

Example 5. Overflow, end carry

$$
\begin{gathered}
\text { Sign } \\
\mathrm{Bit}
\end{gathered}
$$

| 1 | 0 | 1 | 1 | 0 | 0 | . | . | . | 0 | Augend |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 1 | 0 | 0 | 0 | 0 | . | . | . | 0 | Addend |
| 0 | 1 | 1 | 1 | 0 | 0 | . | . | . | 0 | Sum |

The buffered gate K00 detects an end carry by the following logic (see figure 3-84):

$$
\begin{aligned}
\mathrm{K} 00= & A 0 \text { D0 + A0 CS0 ND0 + NA0 CS0 D0 GX } \\
& + \text { PR0 G1 + PR0 PR1 G2 + PR0 PR1 PR2 G3 } \\
& + \text { PR0003 G0407 + PR0003 PR0407 G0811 } \\
& + \text { PR0003 PR0407 PR0811 G1215 } \\
& + \text { PR0015 K15 }
\end{aligned}
$$

After an end carry has been generated, it is stored in K 00 H as a one or zero depending on the state of SOOX:

$$
\begin{aligned}
& S / \mathrm{KOOH}=\mathrm{SOO} \\
& \mathrm{R} / \mathrm{K} 00 \mathrm{H}= \\
& S 00=\text { KOO SOOX + NKOO NSOOX } \\
& \mathrm{N}[\text { FASHFL }(\mathrm{PH} 14 / 1+\mathrm{PHI}+\mathrm{PHII})] \\
& \text { SOOX }=\text { FASII [SOOXN + (A0 } \oplus D 0)] \\
& + \text { SOOXN (A0 D0 + NAO NDO) } \\
& \text { SOOXN = FAS1 PH2 + FAS22 PH5 }
\end{aligned}
$$

NKOOH sets a one into CS31, before the addition of the high-order half of the doubleword instructions.

$$
\begin{aligned}
S / C S 31 & =(S / B W Z / 1) \text { NK00H NOLB } \\
(S / \text { BWZ/1) } & =(\text { FAS16 }+ \text { FAS22 }) \text { PH3 NOL9 }
\end{aligned}
$$

During Compare Doubleword, Compare with Limits in Memory, and Compare with Limits in Register instructions, KOOH is used to generate an end carry from the low-order sum to the high-order sum. During all compare instructions KOOH is also used to detect the equal, less-than and greater-than conditions of the words compared. Compare instructions are discussed in detail in paragraphs 3-209 to 3-216.

## 3-72 Basic Timing

3-73 CLOCK GENERATOR. The clock generator in the central processor consists of four delay lines with associated gates and amplifiers to tap off pulses oi the desired rime intervals. Three basic clock signals are produced:
a. A CL clock signal for trailing edge triggering of flip-flops throughout the CPU. This signal, when distributed, is referenced in the following discussion as CL clocks CL/1 through $\mathrm{CL} / 12$.

b. A private memory clock signal to gate information into the private memory registers. This signal, when distributed, is referenced as CK clocks CK/1 through CK/12.
c. A negative-going dc-hold signal to place data in the C-register buffer flip-flops, which are latching circuits and do not use an ac clock signal. This signal is referenced as the DCH clock signal.

All clock pulses are 40 ns wide.
Figure 3-85 is a simplified block diagram of the clock generator in which only the basic timing functions are shown. Gating, latching, pulse shaping, enabling, and other clock control functions are shown in detail later in this manual.

All clock signals except the first originate with a CL clock input to delay line 1. Taps are taken from this 300 ns delay line according to the time interval needed between one clock pulse and the next. These taps are controlled by flipflops TIL, T4L, T8L, and T10L and signal T6L, and are selected according to the number of logical operations to be performed before another clock signal is needed.

A TIL clock request gives rise to an odd and an even CL clock signal every time a pulse travels down delay line 1 (except the first time when only an odd pulse is produced). Since the TIL delay line outputs are fed directly to the clock drivers, no DCH or clock signals are generated.

The T4L output from delay line 1 and the T6L, T8L, and T10L outputs, when not preceded by a TIL timing request, are fed into delay line 3 , which times and shapes the three basic output clock signals. The positive-going CK clock signal is tapped off at the 20 ns point on delay line 3, and the CL clock signal is tapped off at 40 ns and is fed to delay line 4. A negative-going DCH signal appears at the 90 ns tap. The total delay times of these clock signals include a delay of approximately 40 ns at the inputs to the delay lines and in the clock-gating and amplifying circuits.

When a T6L, T8L, or T 10 L clock request follows a TIL clock signal, the time interval is longer than the normal T6L, T8L, and T10L clock intervals. A TIL post enable signal from a latch set by TIL disables the normal taps. When the even CL clock signal is generated from TIL, a pulse enters delay line 2. The T6L, T8L, and T10L taps are taken from delay line 2 and are gated into delay line 3. The CK, DCH, and CL clock signals are then tapped from delay line 3.

Timing intervals, longer than those from combining delay lines, can be obtained by recirculating the timing pulse through delay line 2 under the control of a two-bit trip counter which counts the number of times the pulse has recirculated.

Outputs, in addition to the three basic clock signals, are taken at timing points on delay lines 1 and 2 and are sent to various parts of the computer logic circuitry. Outputs
from timing points on delay line 2 are gated by the trip counter to obtain specific extended time intervals.

All CL clock signals, except the TIL clock signals, are tapped from delay line 4. A clock enable signal is used to gate the pulses into delay line 4. Thus, the input to delay line 4 is disabled, when it is necessary to stop the clock pulse circulation temporarily because a memory access has not been completed. In this case, the DCH and CK clock pulses occur, and the CL clock pulse is held in a latch circuit at the input to delay line 4 until the clock enabling signal comes true.

Delay line 4 is used to generate the first clock signal at the start of computer operation, using a signal from the control panel as the first input to the delay line.

Logic diagrams of delay lines 1 through 4 are shown in figures $3-86$ through 3-89. Figure $3-90$ shows a timing diagram of the generation of the first two CL clock signals after the CPU RESET switch on the control panel is set. The timing is drawn on the assumption that the T6L clock request flip-flop is set, and the clock enable signal CE is true.

When the CPU RESET switch is set, reset clock signal RESETCL goes up and remains for an indeterminate period of time (figure 3-89). Signal CLEXTE goes true, and a 40 ns output, CLEXT, is generated from delay line 4. Clock driver outputs $\mathrm{CL} / 1$ through $\mathrm{CL} / 12$ are driven true as a result of CLEXT, and the first CL clock signal is distributed to the CPU. Signal RESETCL drives the TIL odd enable signal TILOE and the TIL even enable signal TILEE false and drives the DLI enable signal DLIE true (see figures $3-91$ and 3-92).

As a result of the delay line 1 input, delay line 1 pulse expansion signal DLIPE is brought up (see figure 3-90) and 40 ns later delay line 1 pulse cutoff signal DLIPC goes down. These two signals continue the input to delay line 1 and then terminate it after 40 ns which shapes the signal as it originaliy traveis down the delay line. Delay line $i$, delay 1 , signal DLI/D1 is available at 30 ns , and the inverted delay 2 signal NDL1/D2 is true at 50 ns . Delay line 1 sensor enable signal DLSEI follows DLSE1/S at 110 ns (figure 3-93), and this signal, with NTIL post enable signal NTILPE and T6L, gate the output of a delay line sensor at 170 ns to provide the T6L clock generate signal CLT6LG.

The delay line 3 input, with its pulse expansion and pulse cutoff signals, is shown in figure 3-88. A low DL3PC signal releases the TIL post enable latch TILPE if this latch is set, as shown in the following equation:

```
TILPE = TILPE DL3PC NRESETCL + TIL
```

At 20 ns , signal CKT2NL is taken from a delay line sensor to develop the private memory clock signal outputs CK/1 through $\mathrm{CK} / 12$. Forty nanoseconds down delay line 3 , a

note: delay line taps are in nanoseconds


Figure 3-86. Clock Generator Delay Line 1, Logic Diagram


Figure 3-87. Clock Generator Delay Line 2, Logic Diagram


Figure 3-88. Clock Generator Delay Line 3, Logic Diagram


Figure 3-89. Clock Generator Delay Line 4, Logic Diagram


Figure 3-90. Original CL Clock Generation (TLI), Timing Diagram


Figure 3-91. TIL Clock Logic


Figure 3-92. Delay Line 1 Lockout Circuit


901060 B .3408

Figure 3-93. Delay Line Sensor Enabling Signal Generation

CLT2NL signal is sensed and applied to the input circuitry to delay line 4. A CLEXT signal at the output of delay line 4 produces the second set of CL clock signals. Signal DCH which appears 90 ns down delay line 3 is fed to the C-register latching circuits. A timing diagram of the CL , DCH, and CK clock signals as actually seen on an oscilloscope is shown in figure 3-94.

3-74 Clock-Enabling Function. The timing diagram in figure $3-95$ shows how the CL clock signal is temporarily disabled when clock enabling signal CE goes false and then goes true again. The assumption is made that the T8L timing flip-flop has been turned on by a prior clock pulse and that timing flip-flop T4L is turned on by the T8L clock pulse. In this example, signal CE is dropped during the interval between the clock signals. The diagram shows that the CK and DCH clock signals occur as usual, but that the CL clock signals are delayed until CE rises again.

Signal CLEXTE is latched by its own feedback and by NDL1/D2 which remains true as long as no clock pulse goes down delay line 1 . The input to delay line 4 is held false by the negative signal at the CE input to the S/DL4 AND gate. As soon as CE goes true, the AND gate is enabled, a pulse starts down delay line 4, CLEXT goes true, and a CL clock signal is produced.

3-75 IIL Clock Generation. The timing diagram in figure 3-96 shows the generation of two T1L clock signals every time that a pulse travels down delay line 1. In the diagram, the previous clock signal is generated from a T6L clock request. Delay line 1 enable signal DLIE has been latched on during the previous clock cycle (see figure 3-92); therefore, S/DLl goes true and a pulse starts down delay line 1. On the falling edge of the T6L clock signal, flip-flop T6L is reset, and flip-flop TIL is set. The TIL signal drives the TIL odd enable signal TILOE true. Since TILEE is


Figure 3-94. CL, DCH, and CK Clock Signals Actual Timing
false, an even TIL clock signal is not gated from the delay line during this first trip.

About 300 ns after the previous clock pulse (including circuit delays), a clock signal is gated from the 250 ns tap by TILOE and DLSEI. The DLSEI signal has been latched on since the pulse passed the 110 ns tap, driving DLSEI/S true (see figure 3-93). The odd clock signal CLTILO drives the TIL even enable signal TILEE true, which enables a gate that passes an even clock signal on the next trip of a pulse down the delay line.

The CLTILO signal goes to the CL clock drivers through the OR gate shown in figure 3-89. The clock pulse is applied to the input of delay line 1 through another gating circuit. The total delay time of the circuits external to the delay line is about 50 ns . An even clock pulse is tapped at 100 ns , giving a total time interval of about 150 ns between the odd clock signal and the following even


Figure 3-95. Clock Enabling Function, Timing Diagram
clock signal. This even clock pulse is locked out of the delay line 1 input because DLIE has been driven false by DLI/DI and TILOE, as shown in figure 3-92.

There are normally at least 16 clock pulses after TIL is set. Figure $3-96$ is an abbreviated example that shows TIL reset at the fall of the first even clock pulse. Two more TIL clock signals occur after the fall of TIL which is explained in the following paragraph.

Down the delay line and 150 ns from the even tap, an odd clock pulse is sensed. Signal DLIE has risen by this time, and the pulse is allowed to reenter delay line 1. When the second even pulse is gated, CLTILE and NTIL drive TILOE false (see figure 3-91). Further odd pulses are now disabled. When CLTILE drops, TILEE can no longer remain true, and the even pulses are terminated. The last TIL clock signal is always an even one.

A TIL post enable signal, T1LPE, is set by TIL to allow the next clock pulse following the last TIL clock to be tapped from delay line 2 (see figure 3-87).

3-76 TIL Post Enabling Function. A TIL clock request is always followed by a T6L, T8L, or T10L clock request. These clock signals, when preceded by a T1L request, are taken from delay line 2 instead of from delay line 1 because the last TIL clock signal always comes from an earlier portion of delay line 1. If the next T6L clock signal were taken from the normal point on delay line 1, it would not be a true T6L time interval. Therefore, the signal must be propagated from delay line 1 into delay line 2 for an additional period of time to get a normal T6L delay. A TIL post enable signal, TILPE, is driven true by TIL and is latched until the DL3 pulse cutoff signal, DL3PC, from delay line 3 at the end of the following clock cycle goes false (see figure 3-97).
The timing diagram in figure 3-97 shows a T6L clock signal generated from delay line 2 with TILPE true and from delay line 1 with TILPE false.
The last even TIL pulse is gated into delay line 2 as shown in figure 3-87:

```
S/DL2 = CLTILE NTIL TILPE + ...
```



Figure 3-96. TIL Clock Generation, Timing Diagram

At the 200 ns tap, CLT6LG/1 is sensed and is gated into delay line 3 as shown in figure 3-88:

$$
S / D L 3=C L T 6 L G / 1 \text { T6L TILPE }+\ldots
$$

The CL, CK, and DCH clock signals are then tapped from delay line 3 as in normal clock generation.

Signal TILPE drops at the end of the first T6L cycle (figure 3-97). The second T6L pulse is gated from delay line 1 by NTILPE. The T6L tap, CLT6LG, is applied to the delay line 3 input gates, and the three basic clock signals are obtained as usual.

3-77 Trip Counter. Time signals are required from delay line 2 for length intervals beyond the last clock. For example, if clock enable signal CE goes false, it is necessary to have some means of determining whether a signal such as an address from memory has been received within a certain interval of time. If the signal is not received, appropriate action must be taken to generate a clock, to note that an error has occurred, and to continue from this point with the error condition. For this reason, it may be necessary to get timing pulses at intervals greater than those provided by delay lines 1 or 2 . This is done by repeatedly circulating a pulse through delay line 2. A trip counter is used


Figure 3-97. TIL Post Enabling Timing Diagram
to count the number of trips that the pulse makes through delay line 2.

The trip counter, shown in figure 3-87, consists of four flipflops, DL2TC1A, DL2TC1B, DL2TC2A, and DL2TC2B. Each of the two flip-flop combinations in the trip counter is placed in the $0-0$ state when signal DLI/DI is tapped from delay line 1. In the absence of a clock signal, the count progresses as the clock pulse circulates through the delay line as shown in table 3-10.

Table 3-10. Trip Counter Progression

| DL2TC1A <br> DL2TC1B | DL2TC2A <br> DL2TC2B | State |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 1 | 3 |
| 1 | 0 | 2 |
| 0 | 0 | 0 |

The use of the trip counter is shown in figure 3-98. The top waveforms show the input to delay line 1, followed by delay line sensor enable 1 (DLSE1) at the 110 ns tap and delay line sensor enable 2 (DLSE2) at 230 ns . At 300 ns , the pulse enters delay line 2, and delay line sensor enable 3 (DLSE3) rises at the 40 ns tap on delay line 2. The logic of these sensor enabling signals is shown in figure 3-93.
The delay line 2 recirculation enabling signal, DL2RE, rises and is latched when the delay line 2 input occurs (see figure 3-99). Each time the pulse reaches a tap labelled DL2TCCA or DL2TCCB (delay line 2 trip counter clocks), the two halves of the trip counter are advanced to their following states. The timing point signals shown in figure $3-98$ are gated by the trip counter outputs. The CL clock signal, which is disabled by a false CE signal during the delay line 2 recirculation, causes the sensor enabling signals to go false.
3-78 Timing Request Flip-Flops. The TIL, T4L, T8L, and T10L clock request flip-flops are set by instruction and phase logic so that the time interval between one clock signal and the next is adequate to allow the necessary operations to be performed. Clock request signal T6L, which is not a flipflop, is true when no other timing request is set:

## T6L : NTIL NT4L NT8L NT10L

The time intervals obtained by the clock request are shown in table 3-11.

Table 3-11. Clock Time Intervals

| Clock Request | Time Interval (ns) |
| :---: | :---: |
| TIL | 150 |
| T4L | 280 |
| (Continued) |  |

Table 3-11. Clock Time Intervals (Cont.)

| Clock Request | Time Interval (ns) |
| :---: | :---: |
| T6L | 320 |
| T8L | 380 |
| T10L | 440 |

The time required when private memory is addressed is dependent, in part, on the location of the private memory register bank being addressed. Because of the physical distance the signals must travel, more time is required to address private memory extension register banks in frame 2 of CPU cabinet No. 2 than to address one of the first four pages of private memory registers in CPU cabinet No. 1. Signals T4RL and T6RL are used when the private memory extension registers might be addressed. Signal T4RL requests a T4L clock signal if the CPU private memory is addressed and a T10L clock signal if the register extension is addressed. Signal T6RL requests a T6L clock signal for the CPU registers and a T10L clock signal for the register extension.

In either case, the T10L request flip-flop is set if either RP23, RP24, or RP25 in the register pointer register contains a one, which indicates a register designation higher than four, If RP23 through RP25 contains zeros, only RP26 and RP27 select the private memory register bank one of banks 0 through 3 in the CPU. The T4RL and T6RL signals are gated with the outputs of flip-flops RP23 through RP25 to select a T10L clock signal. A T4L clock is selected when these flip-flops contain zeros.
3-79 CLOCK ENABLING LOGIC CIRCUITS. As explained in paragraph 3-74, a CLEXT signal for clock generation is obtained from delay line 4 only if clock enable signal CE is true. When it is necessary to delay the clock, CE is held false until a CL clock signal is desired.

A logic diagram of the clock enabling signal is shown in figure $3-100$. To illustrate the various functions of the clock-enabling gates, figure 3-101 shows the equation for CE divided into sections. The function of each section is described separately.

If all other gates are true, gate 1 allows a CL clock to be generated at the proper time in a memory access. Any one of the terms listed in figure 3-101 produces a clock. Beginning at the top, AHCL (address here clock) is a timing signal that goes true when the memory acknowledges an address. Signal AR comes from an address release signal from memory. Signal NARQ is the reverse of signal $A R Q$ which indicates that after a memory request, an address release signal must be received from memory before another clock signal is generated. Signal NRIP means that no memory request is in progress, and signal MAA indicates that no memory request is pending. Signals NMAA and NMR indicate that a memory request is pending, but that a memory request signal has not been sent to the memory.


Figure 3-98. Trip Counter Functions, Timing Diagram


Figure 3-99. Delay Line 2 Recirculation Enabling Signal Generation

Gate 2 of the clock enabling signal coordinates the CL clock with the data request and data release signals between memory and the CPU. Signal NDRQ is the reverse of signal $D R Q$ which indicates that if a memory request is out, the clock must be delayed until a data release signal has been received from memory. Signals MAA and NRIP indicate that no memory request is in progress and no memory request is pending. Signal MFF means that one memory request has been sent to memory, and an early data release signal has come back. Signal DRL is the output of a flipflop set when data release signal $D R$ is received from memory and is latched if a second memory request is not pending.

$$
S / D R L=D R+(D R L \text { NMGG NMEE })
$$

If all the other gates are true, any one of the signals on gate 2 drives $C E$ high.

Gate 3 provides a means of disabling signal CE if crossover is taking place, if the watchdog timer has been activated, or if a memory parity error signal has been received when the PARITY ERROR MODE switch is in the HALT position.

Gate 4 is used to synchronize the CL clock signal with the 2.048 MHz clock signal used in the interrupt circuits. This gate is also used to synchronize the CL clock signal with the 1.024 MHz clock signal when the CLOCK MODE switch is in the SINGLE STEP position. Gates 5 and 6 are used in the single clock mode.

3-80 Single Clock Generation. When the CLOCK MODE switch is moved from the CONT to the center position, KSC goes true and signal CE is disabled by NKSC and SC2 at gate 5 (figure 3-101). Setting the switch to the SINGLE STEP position drives KC true, and KSC remains true. On the trailing edge of the following 1.024 MHz clock signal, flip-flop SC1 is set. Flip-flop SC2 sets on the next 1.024 MHz clock signal, and the output of gate 5 goes true, generating a CL clock signal. Assuming that the AND gate inputs to SCEN are all false, the clock signal drives SCD true, and this signal is latched by feedback as long as the switch is kept in the SINGLE STEP position. While the latch is set, CE is disabled by gate 6, and no CL clock
signals may be generated. Releasing the switch resets SCl and SC2, and CE is disabled by gate 5 until the switch is set in the SINGLE STEP position again. Releasing the switch also drops the latch holding SCD true. A timing diagram of this operation is shown in figure 3-102.

Gate 4 and the SCEN signal on gate 6 are used to synchronize the CL clock signal with the 2.048 MHz clock signal used in the interrupt system. Signal SCEN is false when the following conditions are true:
a. Phase 6 of Load Program Status Doubleword instruction with R30 true
b. Interrupt operation with INTRAP1 set and INTRAP2 reset. This is the first phase of interrupt operation
c. Phase 3 of Modify and Test Word, Halfword, or Byte instruction with INTRAPF set

When the CLOCK MODE switch is in the SINGLE STEP position and signal SCEN is false, a CL clock signal is generated through gate 5, but SCD may not go true. The SCD latch may no longer disable signal $C E$; however, the $C L$ clock signal produced by the SINGLE STEP position of the CLOCK MODE switch moves the instruction to the following phase, and signal CE is disabled by a low signal on the NCEINT line. In the case of conditions a and $c$ above, a GARF signal is generated at the next IMC clock signal:

| S/GARF $=$ | AIB |
| ---: | :--- |
| C/GARF $=$ | IMC |
| S/AIB $=$ | LEVACT NAIB NGARF |
| LEVACT $=$ | (FAPSD PH7 NO7 R30) |
|  | + (FAS7 PH4 INTRAPF) |

Note
The term IMC in the interrupt system is actually 2.048 MHz .


Figure 3-100. Clock Enabling Logic


Figure 3-101. Clock Enabling Gates

When GARF is true, NGARF is false, and one input to the ARE gate is enabled. At the leading edge of the $1 M C$ clock signal, ARE goes true, and signal CE is enabled, which produces a CL clock signal in synchronization with the $1 M C$ clock signal.

During interrupt operation, NCEINT is driven low by INTRAP2, INTRAP1, and NTRAP. Signal NAIEB immediately goes false.

$$
\begin{aligned}
\text { S/AIEB } & =\text { AIEA NAIEB } \\
\text { S/AIEA } & =\text { NAIEA SAIEA } \\
\text { SAIEA } & =\text { INTRAPI INTRAP2 NEWDM }
\end{aligned}
$$

This enables CE when the $1 M C$ signal goes true, as explained in the previous paragraph.

## 3-81 Memory Map

The function of the memory map as an addressing feature and the use of the memory map registers for memory addressing and access control are described in the general principles. This section describes the type of registers, the logic used to load the registers, and the gating logic for the register outputs during memory access.

3-82 MAP REGISTER ORGANIZATION. The registers that store memory map information are made up of FT25 fastaccess memory modules and are identical to the private memory registers. The page address code registers may be represented as shown in figure 3-103. Each FT25 module contains 16 eight-bit registers; 16 modules are used to hold the required 256 registers.

The actual organization of the codes in the integrated circuit memory elements (XDS 304) on an FT25 module is shown
in figure 3-104, using the first FT25 module as an example. A description of the flip-flops in a memory element and their logical characteristics are given in the circuit description. Each memory element on an FT25 module contains a corresponding bit in each of eight page address code registers. The elements on the left-hand side of figure 3-104 contain the codes for pages $0-7$ and those on the right-hand side for pages $8-\mathrm{F}$. The other 15 FT 25 modules are arranged in a similar manner. The last module contains codes for pages 239 through 247 on the left side and for pages 248 through 256 on the right side.

3-83 LOADING THE MEMORY MAP. A Move to Memory Control instruction with a one in bit 12 transfers the page address codes in core memory, known as the memory map control image, from memory to the memory map registers. The data is first placed in the C-register, then is transferred a byte at a time to D24-D31. From the D-register, each byte is gated onto the memory map data lines, MAPW15 through MAPW22, with the equation:
MAPW15-MAPW22 = D24-D31 MAPWXD

The eight write data lines on each module are connected to the MAPW lines as follows:

$$
\mathrm{W} / \mathrm{MPO} / 15-\mathrm{W} / \mathrm{MPO} / 22=\mathrm{MAPW} 15-\mathrm{N}_{1} A P W 22
$$

for the first FT25 module, MPO. Other modules are designated MP1 through MP15.

The individual bits in the memory element are selected by address signals generated from the LM lines with the following equations for the first FT25 module:

$$
\begin{aligned}
& L / M P O / 3=L M 20 \\
& L / M P 0 / 4=L M 21 \\
& L / M P O / 5=L M 22
\end{aligned}
$$



Figure 3-102. Single Clock Mode, Timing Diagram


Figure 3-103. Memory Map Page Address Code Registers

The modules are selected by decoding address lines LM15 through LM18, which are inputs to the AND gates in figure 3-104. The two halves of the module are selected by address line LM19, as shown in figure 3-105. The write clock signal is generated from a map write signal and a private memory clock signal with the equation for the first FT25 module:

## K/MPO MAPW CK

Clost signals for the other modules are K/MP1 through Y/IAP 15 .

3-24 PPOGRAM CONTROL CODE ORGANIZATION. Four FT25 fast-access memory modules are used to store the 256 t wo-bit program control codes (called access control corles or access protection codes in the reference manual) associated with the page address codes. The functions of the program control codes are described under General Principles. The registers are represented in figure 3-106.

The actual organization of the codes in the integrated circuit memory elements (XDS 304) on an FT25 module is shown in figure 3-107, and uses the first FT25 module as an example. Memory elements on the left half of the diagram contain the codes for pages 0 through 1 F ; those on the
right half contain the codes for pages 20 through $3 F$, for a total of 128 bits, or 64 codes, on one module. Because of the limited space, only the first, second, and last bits in each memory element are shown.

3-85 LOADING THE PROGRAM CONTROL CODES. The codes are entered a byte at a time from the D-register (figure $3-108$ ). When one word has been transferred, the eight elements on the left side are half full. The second word fills the left side, and the third word is loaded into the top half of the elements on the right side. After the fourth word, the second FT25 module is selected and the loading continues as described.

A Move to Memory Control instruction with a one in bit 13 transfers the program control codes in core memory, known as the program control image (also referred to in the reference manual as the access protection control image) from memory to the program control registers. The data is first placed in the C-register, then is transferred a byte at a time to D24 through D31. From the D-register, each byte is inverted and is gated onto the program control data lines with the equation for the first FT25 module, PBO:

$$
\begin{aligned}
\text { MAPW15-MAPW22 }= & \text { D24-D31 } \\
& \text { MAPWXD } \\
\text { W/PB0/15-W/PB0/22 }= & \text { NMAPW15- } \\
& \text { NMAPW22 }
\end{aligned}
$$

Other modules are designated PB1 through PB3.

The individual bits in the memory elements are selected by address signals generated from the LM lines with the equations for the first FT25 module:

$$
\begin{aligned}
& \mathrm{L} / \mathrm{PBO} / 3=\mathrm{LM} 18 \\
& \mathrm{~L} / \mathrm{PBO} / 4=\mathrm{LM} 19 \\
& \mathrm{~L} / \mathrm{PBO} / 5=\mathrm{LM} 20
\end{aligned}
$$

The modules are selected by decoding address lines LM15 and LM16 which are inputs to the AND gates in figure 3-108. The two halves of the module are selected by address line LM17, as shown in figure 3-107. The write clock signal is generated from a program control bit write signal and a private memory clock signal with the equation for the first FT25 module:

$$
K / P B O=P C B W C K
$$

Clock signals for the other modules are $\mathrm{K} / \mathrm{PB} 1$ through K/PB3.

3-86 USING THE MEMORY MAP. Paragraphs 3-87 and 3-88 present a detailed description of the control registers used for the memory map.
$011-\varepsilon / 601-\varepsilon$


|  | LM19 | LM20 LM21 LM22 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SELECTS | 0 | $\begin{array}{lcc} 0 & 0 & 0 \\ \text { THROUGH } \end{array}$ |  |  | BITS |
| PAGES |  |  |  |  | 0 THROUGH 7 IN |
| 0 THROUGH 7 | 0 | 1 | 1 | 1 | LEFT-HAND SET |
| SELECTS | 1 | 0 | 0 | 0 | BITS |
| PAGES |  |  | OU |  | 0 THROUGH 7 IN |
| 8 THROUGH F | 1 | 1 | 1 | 1 | RIGHT-HAND SET |

Figure 3-105. Memory Map Bit Addressing


Figure 3-106. Memory Map Program Control Registers
$\downarrow \rightarrow-\varepsilon / \varepsilon I L-\varepsilon$



Figure 3-108. Loading One Word of Program Control Codes

3-87 Memory Map Control Registers. The virtual address of an instruction or operand is divided between the LM and the LB lines. The LB lines, LB23 through LB31, go directly to the memory address cable drivers. The LM lines, LM15 through LM22, which are select groups of 512 memory locations known as pages, are connected to the memory map registers. A page of virtual addresses may be located anywhere in memory, depending on the code stored in the map register for that page.

Figure 3-109 shows a typical virtual address on the LM and the LB lines. The most significant eight bits of the address, which specify the page, contain a two, and map register 2 is selected by the address lines (figure 3-105). The outputs of map register 2, which in this case contain a four, are gated onto the most significant eight bits of the LB address lines to memory. Thus, page 2 on the input lines to the memory map is converted to page 4 for actual addressing.

When reading the map register outputs, the modules, module halves, and bits in the memory elements are selected by the LM address lines in the same manner as when storing data. In this case, the register write clock signal need not be true. As long as the control line is true, the outputs of the memory elements connected to that control line may be sensed. Since one control line selects the elements on onehalf a module, those eight bits are read at one time on the lines designated MAP 15/1 through MAP22/1 or MAP 15/2 through MAP22/2 (figure 3-104). The signals ending in $/ 1$ are taken from the first eight modules, and the signals ending in $/ 2$ are taken from the second eight modules (figure 3-110). The outputs of unselected memory elements remain high; therefore, several outputs may be connected and applied to the same AND gate. If the selected flipflop contains a one, the outputs of all of the memory elements are true, and the LB line at the AND gate output senses a one. If the selected flip-flop contains a zero, all of the eight lines connected to that flip-flop output are brought low, one input to the AND gate becomes false, and a zero is sensed at the AND gate output. Signal MAP is true when bit 9 in program status doubleword 1 is true, which indicates that the memory map is operative.

Figure 3-110 shows how eight bits at a time are read in parallel from corresponding flip-flops in eight selected memory elements containing one page address code. Only one register on one module is selected at any one time.

3-88 Program Control Registers. The program control registers are used to prevent the slave program from performing certain operations on the associated page of virtual addresses.

To read the program contro! register outputs, address !ines LM15 through LM20 select eight memory elements on a module of map registers and the upper or lower half of each memory element (see figure 3-104). These address lines also select a module of program control registers, a control line for half the module, and one bit in each of the eight memory elements (see figure 3-107). A one on the control line
allows outputs PCB15 through PCB22 for the half module to be sensed. Address lines LM21 and LM22 select the page code within the map memory elements. Those lines are also decoded to select one of four two-bit codes in the half module of program control codes, as shown in figure 3-111. The outputs of all the decoding circuits NPCBO and NPCB1 contain the complement of the code stored with the selected virtual page address. The complement is used because the codes were inverted when they were stored in the program control registers.

Signals NPCB0 and NPCB1 are interpreted during write operation as shown in table 3-12. A trap condition is produced if the slave program attempts to perform a forbidden operation. Signal PROTECTD (protect data) or PROTECTI (protect instruction) is generated from the program control bits, and the trap flip-flop is set with the equations:

```
S/TRAP = NRESET S/TRACC4/1
S/TRACC4/1 = (PROTECTD NPROTECTDIS NTRAP
                                    + PROTECTI ENDE NFUEXU
                                    NTRAP) NRESET
PROTECTD = PROTD DRQ
PROTD = NPCP5 NPCP6 FAILD 
                                    PCB NPCP5 NPCP6 NLMXQ
                                    MR
                            + . . .
FAILD = MR [WRITE (NPCBO PCB + NPCBI
    N(FAIO EXU) PCB NLMXQ + . . )]
    + . . .
PROTECTI = PROTI DRQ
PROTI =(MR NPCB0 PCB NPCP5 NPCP6
    + . . .)
PCB = NMASTER MAP
```

If both NPCBO and NPCBI are false, no trap condition is produced; reading, writing, and instruction access may be performed.

If NPCBO is false and NPCBI is true, only writing is prohibited. A one in NPCBI and a WRITE signal generate FAILD, which causes PROTECTD to go true, setting the trap flip-flop at the next clock signal. The NLMXQ term on the FAILD AND gate is for mechanization convenience. The NPCP5 and NPCP6 terms disable the PROTD gate during processor control panel phases when the memory is being cleared. The N(FAIO EXU) term is included because other logic aborts an instruction when the slave program attempts an input/output operation.

If NPCBO is true and NPCP1 is false, reading operands is permitted while reading instructions and writing are forbidden. Signal FAILD is generated from NPCPO and WRITE which causes a trap condition through the PROTECTD logic when attempting to write into memory.


Figure 3-109. Memory Map Address Conversion


FT25 MODULES AND MODULE LOCATIONS

Figure 3-110. Map Register Output Gating


Figure 3-111. Program Control Register Output Decoding

Signal PROTECTI is generated from NPCB0, PCB, and MR, so that a trap occurs when the next instruction is read from memory. Reading data occurs before ENDE is true, and is therefore allowed.

If both NPCBO and NPCBI are true, all memory access is prohibited. Writing is inhibited by FAILD, as described above. Reading is disqualified by the gate containing NPCB0 and NPCB1, which produces PROTECTD. If LMXQ is true, indicating that instruction access is being performed, PROTECTI is generated instead of PROTECTD. The difference is one of timing, since PROTECTD sets the trap flipflop at the next clock, and PROTECTI waits until ENDE is true.

Table 3-12. Program Control Code Functions

| NPCBO | NPCB 1 | Read | Write | Instruction Address |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Yes | Yes | Yes |
| 0 | 1 | Yes | No | Yes |
| 1 | 0 | Yes | No | No |
| 1 | 1 | No | No | No |

## 3-89 Memory Protection

The memory protection feature, which operates independently of the memory map, prevents alteration of specified areas of actual addresses in memory. The program is subjected to memory protection in both master and slave modes. If the CPU is in the slave mode using the memory map, the program control codes are examined when the virtual addresses are converted into actual addresses. The memory protection feature is then used to determine if the program is allowed to alter the contents of the core memory location corresponding to the final actual address.

The memory protection registers contain a two-bit write lock code for each 512-word page of core memory addresses. Two flip-flops designated the write key are set by bits 3 and 4 of program status doubleword 2. The write locks and write key are interpreted as shown in table 3-13. If an instruction attempts to write into a protected memory page, the trap flip-flop is set, and a trap sequence is entered.

Table 3-13. Memory Protection Functions

| Write Lock | Write Key | Protection |
| :---: | :---: | :---: |
| 00 | $\times \times$ | Write access permitted independent of key value |
| $\times \times$ | 00 | Write access permitted independent of lock value |
| 01 through 11 | 01 through 11 | Write access permitted only if lock value matches key value |

3-90 MEMORY PROTECTION REGISTER ORGANIZATION. The 256 memory protection codes are located on four FT25 fast-access memory modules. The registers may be represented as shown in figure 3-106.

The actual organization of the write locks in the integrated circuit memory elements (XDS 304) on an FT25 module is shown in figure 3-112, using the first FT25 module as an example. The write lock bits are placed in the memory elements in the same manner as the codes in the memory map program control registers. The memory elements on the left half of the diagram contain the write locks for pages 0 through 1F; those on the right half contain the write locks for pages 20 through 3 F, for a total of 128 bits or 64 write locks on one module. Only the first, second, and last bits in each memory element are shown in the figure.

3-91 LOADING THE WRITE LOCKS. A Move to Memory Control instruction with a one in bit 14 transfers the write locks in core memory, referenced in the reference manual as the memory lock control image from core memory to the memory protection registers. The data is first placed in the C-register, then transferred a byte at a time to D24 through D31. From the D-register, each byte is inverted and gated onto the lock data lines with the equations:
MAPW15-MAPW22 = D24-D31 MAPWXD
W/LK0/15-W/LK0/22 - NMAPW15 - NMAPW22
where MAPWXD is true during a Move to Memory Control instruction. The second equation applies only to the first FT25 module. Other modules are designated LKI through LK3 instead of LKO.

The individual bits in the memory elements are selected by address signals generated from the LB lines with the equations for the first FT25 module:

$$
\begin{aligned}
& \mathrm{L} / \mathrm{LKO} / 3=\mathrm{LB} 18 \\
& \mathrm{~L} / \mathrm{LKO} / 4=\mathrm{LB} 19 \\
& \mathrm{~L} / \mathrm{LKO} / 5=\mathrm{LB} 20
\end{aligned}
$$

The modules are selected by the decoding address lines LB15 and LB16 which are inputs to the AND gates in figure 3-112. The two halves of the module are selected by address line LB17, as shown in figure 3-112. Use of the LB lines instead of the LM lines ensures that any mapping function takes place before the memory protection feature takes effect.

The write clock signal is generated from write lock signal LOCKW and a private memory clock signal with the equation for the first FT25 module:

$$
\text { K/LKO }=\text { LOCKW CK }
$$

Clock signals for the other three modules are K/LKI through K/LK3.
ZZL-६/LZI-६


3-92 USING THE WRITE LOCKS. To read the memory protection register outputs, address lines LB15 through LB20, select a module of write lock registers, a control line for half the module, and one bit in each of the eight memory elements (see figure 3-112). A one on the control line allows sensing of outputs LOCK15 through LOCK22. Address lines LB21 and LB22 are decoded to select one of four two-bit codes in the half module of write locks, as shown in figure 3-113. The outputs of the decoding circuit, NLOCK0 and NLOCK1, contain the complement of the write lock stored with the selected actual page address. The complement is used because the codes were inverted when they were stored in the memory protection registers.

A mismatch of a write lock and the write key generates a FAILD signal, as shown in table 3-14. The logic equation for the FAILD signal is as follows:

```
FAILD = LOCKO NLOCKI WKO CMPKEYS
    + NLOCKO LOCK1 WKI
    CMPKEYS
    + WRITE (NLOCKO NWKO
    CMPKEYS + NLOCKI NWKI
    CMPKEYS + ...)
    CMPKEYS = WRITE NINTRAPF (WKO + WK1)
```

From the FAILD signal, a PROTECTD signal is produced, the trap flip-flop is set, and a trap sequence is entered.

Table 3-14. FAILD Signal Generation in Memory Protection

| Write Lock | Write Key |
| :---: | :---: |
| 01 | $1 \times$ |
| 10 | $\times 1$ |
| $1 \times 1$ | $0 \times 0$ |

## 3-93 Watchdog Timer

The watchdog timer is a six-bit flip-flop binary counter, triggered by the $1-\mathrm{MHz}$ clock signal. The counter is set at interruptible points in the program and counts to 40 , which allows $40 \mu$ s before runout. If the timer runs out before another interruptible point is reached, a trap sequence is entered.

A logic diagram of the watchdog timer counter is shown in figure 3-114. The control circuits and trap-setting logic are shown in figure 3-115. The counter is started by loading it with ones at the following times:
a. When the counter contains 1010XX
b. At the first clock pulse after the interrupt enable flip-flop IEN has been set
c. At the first clock pulse after the END signal goes true during the last execution phase of an instruction
d. At phase 4 of a Move to Memory Control instruction
e. While the WATCHDOG TIMER switch is set at the OVERRIDE position
f. At phase 6 of byte operation instructions
g. While the CLOCK MODE switch is not in the CONT position
h. While the COMPUTE switch is not in the RUN position
i. At processor control panel phases 2 through 6
i. At phase 6 of Decimal Add and Decimal Compare instructions

Any one of these conditions drives WDTRAC true, and flipflops WCT1 through WCT6 are set.

When the watchdog timer has counted to 40 without being restarted, flip-flop WDTA is set by WCT1, NWCT2, WCT3, and NWCT4. A one at the set output of WDTA causes WDTRAC to be set which restarts the counter and causes WDTLATCH to go true. Feedback from WDTLATCH holds this signal true until STRAP and TRAP are true.

When WDTLATCH goes true, STRAP is latched true, and the trap flip-flop is set. As soon as STRAP and TRAP are true, WDTLATCH drops, and is followed by STRAP. A trap sequence is then entered to take the program to location X'46'.

Any one of the conditions stated in the above-mentioned steps restarts the counter without causing a trap. Signal WDTR goes true, setting flip-flop WDTRAC, but WDTLATCH stays low because WDTA has not been set. In the case of KWDTR, KSC, and NRRUN/B, the set input to flip-flop WDTRAC is held true as long as the switch is in the position indicated, and the counter is not allowed to step.

## 3-94 Real-Time Clocks

The real-time clock signals are obtained from an ST29 Time Base Selector, which, in turn, receives its clock pulses from a CT16 Medium Frequency Oscillator. A simplified diagram of these circuits is shown in figure 3-116. Outputs from the time base selector are applied to the interrupt circuits on the LTl6 Priority Interrupt modules in the CPU.
A $2-\mathrm{MHz}$ sine wave from the oscillator, shown in figure 3-116, goes through a frequency divider consisting of seven flip-flops, each of which divides the frequency by two. The $16-\mathrm{kHz}$ signal at the output of the oscillator module is connected to the time base selector, where the frequency is again divided by a series of five flip-flops.


Figure 3-113. Memory Protection Register Output Decoding


Fizure 3-114. Watchdog Timer Counter, Logic Diagram



Figure 3-116. Real-Time Clock, Simplified Diagram

The $8-k H z, 4-k H z, 2-k H z, 1-k H z$, and $500-k H z$ square wave outputs of these flip-flops are available as internal time bases, to be used as inputs to the real-time clock flipflops CPUL1 through CPUL4. The clock frequencies may be selected by jumpers from the frequency divider outputs to the clock pulse flip-flop inputs.

Time bases from sources outside the CPU may be used by connecting external frequencies to the amplifiers shown on the oscillator module in figure 3-116. The amplifier outputs may be connected by jumpers to the desired clock pulse flip-flops on the time base selector. The line frequency of 50 or 60 Hz may also be used by connecting the clock pulse flip-flop inputs to a $50 / 60-\mathrm{Hz}$ source elsewhere in the computer.

The outputs of flip-flops CPUL3 and CPUL4 are taken to the priority interrupt modules used to process the standard counter 3 count-pulse and counter 4 count-pulse interrupts. The outputs of flip-flops CPULI and CPUL2 are used only if the optional counter 1 count-pulse and counter 2 countpulse interrupt levels are included in the CPU. The events that occur after a count-pulse signal enters the interrupt circuits are described in the section on interrupts (beginning with paragraph 3-108).

## 3-95 Power Fail-Safe

3-96 GENERAL. The Sigma 7 optional power fail-safe feature monitors the primary power sources and provides automatic shutdown in cases of partial or complete power failure where power drops below given limits. If power returns to an acceptable level, normal operation automatically resumes. During power fail-safe shutdown, information in certain volatile flip-flop registers is stored in core memory to prevent critical program data loss. When power is restored, the information in core memory is returned to the volatile flip-flop registers so that the program can resume at or near the interrupted point. Core memory serves as the storage device during power fail-safe operation because the cores are nonvolatile and retain information without the presence of power.

The power fail-safe feature is composed of two major components: the power fail-safe interrupts, which initiate the save and recovery programs, and the power monitor assembly, which monitors the primary power source.

3-97 POWER FAIL-SAFE INTERRUPTS. When a power failure occurs, the power fail-safe feature notifies the CPU by means of a power-off interrupt. Sufficient energy is stored in the Sigma 7 power supply system to maintain dc power for the duration of a short power failure subroutine. When primary power resumes, a power-on interrupt causes the CPU to enter a recovery subroutine that restores the CPU to the state existing prior to the lapse of power.

The interrupt memory locations are $X^{\prime} 50$ ' for the power-on interrupt and $X^{\prime} 51$ ' for the power-off interrupt. The poweron interrupt is the highest priority interrupt in the system;
power-off interrupt has second highest priority. Both of these interrupt levels are always enabled; neither can be disarmed, disabled, inhibited, or triggered under program control.

3-98 POWER MONITOR ASSEMBLY. Figure 3-117 is a simplified block diagram of the power monitor assembly, which is a standard equipment item in Sigma 7, consisting of three standard modules: the WT21 regulator and independent power supply, the WT22 line detector, and the ATI3 line driver.

The WT21 regulator is used to supply regulated dc voltages to the WT22 line detector and the AT13 line driver.

The WT22 line detector performs the function of detecting a power failure and indirectly providing the necessary signals to the CPU for a start-up or shutdown sequence.

The AT13 line driver is basically a cable driver which is used to drive the output signals of the WT22 module.

Although the primary power sources are optional, depending on user requirements, the primary power source shown in the simplified block diagram is single phase 120 Vac.

The application of primary power to the Sigma 7 system power supplies provides the power fail-safe feature with the voltage necessary to power the WT21, WT22, and AT13 modules. These standard dc voltages are provided by the internal power supply in the WT21 regulator. The power failsafe feature receives 120 Vac and 60 Vdc power when primary power is applied. The 120 Vac power is transmitted to the WT21 regulator, which in turn is converted to regulated $+4 \mathrm{Vdc},+8 \mathrm{Vdc}$, and -8 Vdc . The regulated dc voltages are transmitted to the WT22 and AT13 module.

The $60-\mathrm{Vdc}$ power output from the PTI4 power supply is monitored directly to the WT22 line detector, which senses this input and the other dc voltages to determine if they are within acceptable limits.

The requirements for a start-up or shutdown sequence are governed by the WT22 line detector, which contains the basic sensing circuits within the power fail-safe feature. Detection of one or more out-of-tolerance voltages by the WT22 line detector generates the necessary logic signals to the AT13 line driver for a fail-safe shutdown. A subsequent return of voltages that are within tolerance generates the necessary logic signals to the ATI3 line driver for a fail-safe start-up.

3-99 Real-Time Clock Line Frequency. The real-time clock circuit on the WT22 module generates a stable clock frequency synchronized to the line frequency. This realtime clock is not an integral part of the power fail-safe feature and is located on the WT22 module primarily for purposes of convenience.


901060A. 31100

Figure 3-117. Power Fail-Safe Feature, Simplified Block Diagram

3-100 Input Requirements. The input power source varies according to user requirements. For information on the various power sources, refer to the section on Power Distribution (paragraph 3-341).

3-101 Three-Phase Input Detection. When three-phase operation is used, one phase is used to supply power to the power monitor. The presence of three phases is detected by sensing the presence of a three-phase rectified but unfiltered $60-\mathrm{Vdc}$ signal supplied by the PT14 power supply.

3-102 Single-Phase Detection. Single-phase detection is provided for by a simple rewiring in the power monitor. When rewired, this standard $110-$ Vac line is the only external input to the power monitor assembly.

3-103 Internal Power Supply. The power monitor has its own internal power supply capable of delivering power to the WT21, WT22, and AT13 modules. This supply comes into operation when external power is applied. When power is shut off, this internal supply outlasts the dc supplies in the computer, thereby keeping logic signals in their appropriate states as power decays and the power-off subroutine is executed.

3-104 Parallel Operation. The power monitor is capable of paralleling its output with the output of other power
monitors. This is necessary, since several power monitors may be used to monitor individual lines and power supplies in a system. Therefore, if more than one power monitor is used in a given installation, the equivalent logic outputs of the power monitors are OR-gated.

3-105 Output Signals. There are five output signals from the ATI 3 line drivers: $S T$, the master reset signal; ION, which initiates the start-up sequence; IOFF, which initiates the shutdown sequence; IONEN, the ION enable signal, which performs an AND function for the output of the power monitor assembly; and RTC, the real-time clock signal, which is a clock synchronized to the line frequency, but which is not used directly in the power fail-safe feature.

3-106 Circuit Description. Figure 3-118 is a functional schematic of the power monitor assembly. Input power to the internal power supply on the WT21 regulator is shown to be single phase $110 / 120 \mathrm{Vac}$ from pins 1 and 2 of the P1 connector. This input power is transmitted to transformer T1, which is in the internal power supply of the WT21 regulator package. Diodes CR1 through CR4 comprise a fullwave bridge rectifier and provide the dc inputs to the +8 Vdc and the +4 Vdc regulator drivers. Diodes CR5 and CR6 act as a full wave rectifier providing ac input to the -8 Vdc regulator circuit.

a. WT21 Regulator. The WT21 (see figure 3-119 for the schematic) is the voltage regulator-driver used to supply regulated dc to the WT22 power monitor. The WT21 contains $a+8 \mathrm{Vdc}$ regulator-driver, +4 Vdc regulator-driver, and -8 Vdc regulator. The +8 -volt and +4 -volt drivers are used with external pass transistors. The -8 -volt regulator contains the pass transistor located on the module. The -8-volt regulator contains a rectifier circuit to allow operation from ac inputs at pins 14 and 18 . The +8 and +4 -volt regulator-drivers require dc input voltages. Two additional bridge rectifying circuits are located on the WT21 to provide 24 Vdc and 50 Vdc .

Filter capacitors for input filtering to the series regulators are not located on the module; however, provisions are made for external connections. Surge resistors are located on the WT21 to prevent damage to the external rectifiers that supply current to the $+8-V d c$ and $+4-\mathrm{Vdc}$ regulators.

R1 through R4 are the surge protection resistors. CR1 through CR4 and CR5 through CR8 rectify the ac input voltages, which are then used to operate the power monitor with 24 Vdc and 50 Vdc .

Transistors Q2 and Q1 are the sense and drive transistors used in the $+8-\mathrm{Vdc}$ regulator. The input of the regulator is pin 17 (V2). Pin $27(\mathrm{~V} 1)$ is brought out to connect to an external filter capacitor. Voltage adjustment is accomplished by controlling the current in Q2. This current is determined by the emitter voltage (reference voltage) and the sampled base voltage as adjusted by R8. The Q1 emitter output drives the external pass transistor.

Transistors Q3 and Q4 are the drive and sense transistors for the +4 -volt regulator. Collector voltages to Q3 are derived from the +8 -volt supply. Drive voltage to Q3 also comes from the +8 volts, therefore providing preregulation for the +4 -volt regulator. Q3 drives a power transistor external to the WT21. The base of Q4 is connected to the +4 -volt output. Current is controlled by changing the reference voltage, R12, at the emitter of Q4.

The -8-volt regulator, including pass transistor Q5, is located on the WT21. CR9 and CR10 provide a negative supply voltage when ac is applied to pins 18 and 14. Pin 20 is the common and external capacitor connection. R17 provides voltage control of the output.
b. WT22 Line Detector. Figure 3-120 is a block diagram of the WT22; figure 3-121 is the WT22 schematic; and figure 3-122 shows the WT22 waveforms. Basic timing and input power for the WT22 are as follows:

| Delay time D | adjustable from 5 to 20 ms |
| :--- | :--- |
| ION time A | $300 \mathrm{~ms} \pm 10 \%$ |
| Power failure <br> detection time | $<3 \mathrm{~ms}$ |


| Input power | $+8 \mathrm{Vdc} \propto 40 \mathrm{~mA}$ |
| :--- | :--- |
|  | $+4 \mathrm{Vdc} @ 30 \mathrm{~mA}$ |
|  | $+60 \mathrm{Vdc} @ 50 \mathrm{~mA}$ for $3 \varnothing$ |
|  | detection |
|  | $+22 \mathrm{Vdc} @ 10 \mathrm{~mA}$ for $1 \varnothing$ |
|  | detection |

The WT22 is the line detector module that provides all output signals for the power monitor. This is the basic unit within the power fail-safe feature. The principal function of the WT22 is to detect a power failure and provide the necessary reset and interrupt signals for the CPU. These signals provide start-up and shutdown sequences when power comes on and goes off.

When power is first turned on (figure 3-121) the 307 flipflop is dc set by V 1 ( +8 Vdc ), charging C 8 , causing ST to go high. VD, the ION threshold voltage, is also applied and charges C4 through R13. The voltage across C4 is determined by the magnitude of VD through R13, as well as the time constant R13-C4. This time constant determines the time after power has been turned on that the threshold sensing circuit triggers the ION pulse. As shown in figure 3-122, the occurrence of ION is time A, or the time necessary for all dc power supplies in the computer to stabilize. The ION pulse resets the $307 \mathrm{flip-flop}$, and ST falls to zero. If ST is zero, the reset of the 307 flip-flop is high and prevents C4 from charging by holding the NOR gate on.

When the line detection circuit indicates power failing, it generates the IOFF signal. At the same time, the IOFF signal is delayed by the period $D$ which is the maximum time that dc power supplies remain within regulation after a power failure (figure 3-122). IOFF is applied to the clock input of the $307 \mathrm{flip-flop}$, and since the set is held high, the flip-flop sets when IOFF returns to zero at the conclusion of period D. IOFF pulses continue to be generated as long as power is below the acceptable threshold level.

As shown in figure 3-122, IOFF pulses and NST prevent C4 from charging in case of a short power interrupt. As long as IOFF produces a pulse, C4 discharges, preventing an ION pulse until C4 charges up again. During this time ST is held high by IOFF, setting the 307 flip-flop continuously.

ST goes false when ION goes true, and there are no IOFF pulses present. This means that any time an IOFF pulse occurs, the entire start-up sequence takes place. When power returns, the line detection circuit generates IOFF pulses whenever the line voltage drops below threshold. Threshold oscillation is prevented by a preset hysteresis. IOFF and ION, as determined by their respective threshold settings, may be set 10 volts apart; for example, IOFF is present at 80 -volts line and ION occurs at 90 -volts line. ST goes high when the line drops below 80 volts and remains high until the line raises above 90 volts.


NOTE: REFERENCE XDS DWG: 132374-1B

Figure 3-119. WT21 Regulator, Schematic Diagram


CONNECTIONS:
1 PH = 22V UNREG TO 13 AND 45; CONN 5 TO 39 ; 1 AND 11 NO CONN
3 PH = INPUT TO 1; CONN 11 TO 45; 13 AND 39 NO CONN

Figure 3-120. WT22 Line Detector, Block Diagram



Figure 3-122. Power Fail-Safe Waveforms

In addition to the ST, ION and IOFF signals, the WT22 generates a real-time clock pulse (RTC) synchronized to the line frequency. By selecting the 1F or 2F term on the module, this pulse is at the line frequency or twice the line frequency.

The WT22 is supplied with power by the internal power supply in the power monitor. A schematic of this power supply and its relationship to all the modules in the power monitor assembly is shown in figure 3-118.
The line detection circuit is that part of the WT22 module which detects an ac line failure. The detection scheme is slightly different for single-phase and three-phase operation; however, both phases are detected by the WT22.

Single phase operation is shown in figure 3-123. Cl cannot charge to level $V_{p}$ if an ac signal is present at $E_{i n}$, the single-phase input. $\mathrm{E}_{\mathrm{in}}$ is generated by an unfiltered dc signal that is clamped to provide a steep rise at the zero crossing. This rise time determines the minimum response time of the IOFF pulse. Cl must charge to $V_{p}$, and $V_{p}$ is determined by setting potentiometer R2. The time constant of $R 3 C 1$ is longer than $T 1$ as the voitage charges to $V_{p}$. In addition, the base voltage, $V_{D}$, is derived from an unregulated source so it decreases with the line voltage, causing $V_{p}$ to be at a lower point ( $V_{p}=n V_{B B}$ where $n$ is 0.7 and $V_{p}$ is the firing point of the unijunction transistor Q2). If power drops out completely, Q2 fires at less than one-quarter of a cycle, as set by R2.


Figure 3-123. Single-Phase Detection

If power goes down slowly below threshold, Q2 fires at a worst-case condition of one-half cycle caused by the decrease in $V_{B B}$; however, this is only if power drops slowly below threshold and is not a worst-case condition. This happens because the power supplies take longer to come out of regulation.

For three-phase operation, the threshold is set below the crest of the multiphase signal, as shown in figure 3-124. This unfiltered signal supplies the VBB source voltage in three-phase operation. If any phase falls below threshold the unijunction transistor triggers. Since the voltage is now sampled at six times the line frequency, response time is faster than in single-phase operation. The additional transistor across Cl is not used and is therefore disconnected in three-phase operation by selecting the proper input connections to the WT22 module.

For single-phase operation, pin 39 is connected to pin 5, and 22 Vdc is applied to pins 13 and 45 . For three-phase
operation, $60-\mathrm{v}$ de unfiltered three-phase is applied to pin 1 , and pin 11 is connected to pin 45.

The ION one-shot is used to generate the ION pulse. This occurs when there are no IOFF pulses, and the $307 \mathrm{flip-}$ flop is in the reset state with ST low if the line is above the ION threshold. The one-shot shown in figure 3-125 consists of a unijunction transistor threshold circuit, an inverter, and a two-input OR gate. If pulses are applied to $D$, the emitter voltages never reach $V_{p}$ on $Q 6$; likewise, if $R$ is positive $Q 5$ conducts and $C 4$ never charges. This provides the inhibit function of the one-shot. C4 only charges if power is on and no IOFF pulses are present. This is the start-up routine. W̌'hen Qó fires, it produces a pulse across R15 that is used to generate ION.

The real-time clock puts out pulses at the line frequency or twice the line frequency, as shown in figure 3-126. $Q 7$ derives its interbase voltage $V_{B B}$ from a clamped,


Figure 3-124. Three-Phase Detection


Figure 3-125. ION One-Shot Operation


Figure 3-126. Real-Time Clock Operation
high-voltage, unfiltered, dc source. R20C7 is set to be longer than one cycle. As $C 7$ is charged, $V_{B B}$ is sudden!y reduced, and $Q 7$ fires when $V_{p}=n V_{B B}$ and produces a pulse at $B 1$. If single frequency pulses are required, $Q 7$ must not fire every half cycle. C7 is prevented from charging by diverting the current through R20 through CRI every other cycle.

3-107 Power Monitor Logic. There are five power monitor logic signals put out by the AT13 logic module. The signals and their cable pins are as follows:

| Signal | Cable Pin |
| :--- | :---: |
| ST | 04 |
| RTC | 07 |
| IONEN | 08 |
| ION | 09 |
| IOFF | 10 |

The ION and IOFF signals are input to the LT16 interrupt module as shown in figure 3-127.
a. Start-up Routine. The following steps outline the logic signals that make up the power monitor assembly start-up routine.

1. ST is the master reset signal that is true when power on/off transitions are occurring. When power is applied, this signal comes true as soon as possible (determined by the internal power supply). ST remains high initially as the power supplies in the computer stabilize. This time is determined by ION occurring.
2. ION occurs only if the line voltage is above a preset level, the ION threshold. ION is generated approximately 300 ms after power is turned on. When ION occurs, ST falls to 0 . ION should outlast ST by more than $2 \mu \mathrm{~s}$ but less than $100 \mu \mathrm{~s}$.


Figure 3-127. Power tail-Safe, Logic Diagram
3. IONEN is a true signal as long as a power monitor is operating. This signal is necessary only when using more than one power monitor per system. It is available on an AT13 cable driver-receiver where the receivers and drivers are externally connected. This signal from a driver of one power monitor connects to the receiver of another, cascading the signals. IONEN becomes an AND function which is only true if all power monitors are operative.

As shown in figure 3-117, the IONEN switch S1, is left open if only one power monitor is used in a system. If more than one is used, the IONEN switches are closed on all power monitors except the last switch in the cable scheme which is the IONEN switch closest to the cable terminator. It is always left open. With SI open, the IONEN signal remains high as long as primary power is applied to the power monitor. IONEN is AND-gated with ION to produce the PON signal for the LT16 interrupt module so that the power-on interrupt subroutine can be initiated.
b. Real-Time Clock (RTC). A clock pulse that is ¡itter-free and synchronized to the line frequency is one of the outputs. This output is arranged so that the interconnecting cables do not parallel one RTC signal with other RTC signals. One of the isolated receiver-drivers on the AT13 is used for this purpose. This precaution is necessary since these RTC signals may be on different phases of the line.
c. Shutdown Routine. The following steps outline the logic signals that make up the power monitor assembly shutdown routine.

1. IOFF is a signal that sets an interrupt channel indicating to the CPU that the line voltage is below a preset threshold. This interrupt initiates a shutdown subroutine that stores all volatile data into core storage before the master reset signal ST causes a cessation of memory operations. The IOFF pulse should be greater than $2 \mu \mathrm{~s}$, but less than 20 ms . The delay between a power failure and the IOFF pulse going true should be minimized (less than 2 mis for single phase, less than 1 ms for thinee phase).
2. ST goes true, after a delay time, when power fails. This delay time is determined by the amount of time it takes for the external dc supplies in the computer to fall below their specified tolerances. This delay time or the time between IOFF occurring and ST going true should be adjusted to the maximum possible duration to allow sufficient time to store data before shutting down the memory input. The delay is adjustable between 5 to 20 ms .

## 3-108 Interrupts

The interrupi sysiem provides a maximum of 237 inierrupi levels, of which 13 originate inside the CPU, and 224 are external, originiating in equipment outside the CPU. The 13 internal interrupt levels include seven standard features: two count-pulse interrupts, a memory parity interrupt, two counter-equals-zero interrupts, an input/output interrupt, and a control panel interrupt. Six optional features
are also available: the power-on interrupt, the power-off interrupt, two additional count-pulse interrupts, and two additional counter-equals-zero interrupts. The 224 external interrupts are divided into 14 groups of 16 interrupt levels each. Chassis wiring in the CPU divides the internal interrupts into the override group, the counter-equals-zero group, and the input/output group. The override group has priority over other interrupts. As described in the Sigma 7 Computer Reference Manual in the Interrupt System section, the priority sequence of all other groups is optional. Also see the reference manual for a detailed description of each group of interrupts.

3-109 INTERRUPT CONTROL. Interrupt operations are controlled by logic and by programming. Each of the 237 interrupt levels is assigned a unique memory location to which the CPU branches when the interrupt level is acknowledged. The contents of the memory location are transferred to the CPU. The interrupt location must contain one of the following instructions: Modify and Test Byte (MTB), Modify and Test Halfword (MTH), Modify and Test Word (MTW), or Exchange Program Status Doubleword (XPSD). The MTB, MTH, and MTW instructions are single instruction interrupts. The XPSD instruction transfers control of the CPU to a service routine stored in memory. The service routine must end with a Load Program Status Doubleword instruction (LPSD).

3-110 INTERRUPT LEVELS. Each of the 237 interrupt levels includes an interrupt circuit consisting of three flip-flops. The state of the interrupt circuit indicates the status of the interrupt level. An armed circuit is transferred to the waiting state when an event or condition associated with the circuit is detected. For example, the event or condition may be a power failure, a programmed count sequence, or a control panel operation. If a circuit in the waiting state is enabled, it causes an interrupt operation to begin when that interrupt level has priority. Any number of interrupt circuits may be in the waiting and enabled state, but only one may be in the active state at any one time. Priority is established by a combination of signals generated by interrupt circuits and by system cabling.

3-111 INTERRUPT SEQUENCE. Any interrupt except the power-on and power-off interrupts may be individually armed, disarmed, enabled, or disabled by a Write Direct instruction. An armed interrupt level accepts and remembers an input interrupt signal, and remains in the waiting state until enabled. A disarmed interrupt cannot enter the waiting state; that is, it cannot accept an input interrupt signal and is effectively removed from the system. A disabled interrupt may go into the waiting state when the event connected with that interrupt occurs, but interrupt operation cannot begin uniil the interrupi is enabled.

All interrupts except the override interrupts may be inhibited by groups by means of three flip-flops whose outputs are used in the program status doubleword. If counter inhibit flipflop CIF which represents bit 37 in the program status doubleword is set, the counter-equals-zero interrupts are inhibited.

If input/output inhibit flip-flop II, representing bit 38 , is set, the input/output and control panel interrupts are inhibited. If external interrupt inhibit flip-flop EI, representing bit 39, is set, all of the external interrupts are inhibited. An inhibited interrupt may accept an input and go into the waiting state, but that input may not begin operation until the flip-flop representing its respective program status doubleword bit is reset.

Any interrupt except the power-on and power-off interrupts may be triggered by means of a Write Direct instruction which is described later in this section. When a Write Direct instruction triggers an armed interrupt, the specified interrupt level goes into the waiting state as if its associated event or condition has been detected. The triggering function allows the use of diagnostic programs to test the interrupt system.

3-112 INTERRUPT CIRCUITS. The state of each interrupt level is controlled by an interrupt circuit that generates signals to control the priority of each level. Each interrupt consists of three flip-flops: ISn, IPn, INn, ( $\mathrm{n}=0,1$, 2, . . 15). These flip-flops are clocked at a 2.048 MHz rate by signals GCLK1 and GCLK2, which are generated from signal 1MC-2, the output of an amplifier whose input is 2 MHz signal 2 MC . Other interrupt circuit flip-flops are also clocked at 2.048 MHz , by signal $1 \mathrm{MC}-1$, which is developed from signal $2 M C$. The five significant states of an interrupt circuit and the condition established for the level are summarized in table 3-15.

3-113 Power Fail-Safe Interrupts. Interrupt levels 0 and 1 are the power-on and power-off interrupts which are controlled by optional equipment. These circuits have the highest priority level and are always enabled because the input to INn flip-flops are hard wired.

$$
\begin{aligned}
& \mathrm{S} / \mathrm{IN} 0=\cdots \\
& \text { R/IN0 }=\text { GND } \\
& \mathrm{S} / \mathrm{IN} 1=\cdots \\
& \text { R/INI }=\text { GND }
\end{aligned}
$$

The circuits are placed in the armed state by a reset signal and are normally in the armed and enabled state.

```
S/IPO = CPUREST2 +...
R/ISO = CPUREST2 RESET + ...
S/IPI = CPUREST2 RESET + ...
R/IS1 = CPUREST2 RESET + ...
```

When power fails, signal IOFF is true, and interrupt level 1 is placed in the waiting and enabled state.

$$
S / I S 1=I P 1 \text { POFF }
$$

An interrupt sequence takes place, during which the interrupt level is placed in the active state.

Table 3-15. Significant States of Interrupt Circuit

| FLIP-FLOPS |  |  | STATE |
| :---: | :---: | :---: | :---: |
| ISn* | IPn* | $\mathrm{INn}^{+}$ |  |
| 0 | 0 | X | Disarmed. Circuit removed from interrupt system. Interrupt signal neither accepted nor remembered. Change of state only by program intervention |
| 0 | 1 | X | Armed. Can accept and remember interrupt signal. Advances to waiting state when interrupt signal is recognized |
| 1 | 1 | 0 | Waiting and disabled. Cannot advance to active state. Requires program intervention to be enabled |
| 1 | 1 | 1 | Waiting and enabled. Can advance to active state if interrupt circuit has highest priority |
| 1 | 0 | 1 | Active or waiting. The highest priority circuit in this state becomes active when accepted as an interrupt by the CPU. Other circuits in this state wait for acceptance in priority sequence |
| $\text { * } n=0,1,2, \ldots 15$ <br> ${ }^{\dagger}$ Power fail-safe interrupt circuits ( 0 and 1 ) are always enabled, so that state of flip-flops is XX1 at all times (INn set) |  |  |  |


| R/IPI | $=$ REIPI IEO $+\ldots$ |
| ---: | :--- |
| REIPI | $=$ INI IPI ISI NISINO NISNIPO |
| NISINO | $=$ NISO + NINO |
| NISNIPO | $=$ N $(I S O$ NIPO $)=$ NISO + IPO |
| IEO | $=$ AIEB ENOVRD |
| ENOVRD | $=$ NENFNL OVRQ |
| OVRQ | $=$ ROI $+\ldots$ |
| ROI | $=$ REIPI $+\ldots$ |

Signals NISINO and NISNIPO are priority signals that prevent a change of state if the higher priority 0 level is waiting and enabled, or is active. Signal ENOVRD initiates the interrupt sequence. Signal AIEB is a timing signal generated during an interrupt sequence.

After the XPSD instruction in the interrupt location has been executed, the associated service routine is followed, and the interrupt circuit returns to the armed state.

```
R/ISI = NISNIPO NIPI IBO + ...
IBO = AIB CHAO
S/IPI = ISI NISNIPO IBO
```

$\operatorname{IBO}=\mathrm{AIB}$ CHAO
$S / I P 1=$ ISI NISNIPO IBO

Signal CHAO is a timing signal generated during the interrupt sequence. Signal AIB is generated from signal LEVACT which is an interrupt exit signal in the service routine:

```
S/AIB = LEVACT N(...)
```

When power is applied, signal PON is true, and interrupt circuit 0 goes through a similar sequence of operations.

```
S/IPO = ISO IBO + CPUREST2
R/IPO = RO IEO + ...
    RO = INO IPO ISO
S/ISO = IPO PON
R/ISO = NIPO IBO + CPUREST2
```

Because interrupt level 0 has the highest priority of all interrupts, no priority signals such as NISNIPO or NISIN0 are required. Signal ENOVRD is enabled by signal RO, as explained above.

3-114 Count Pulse Interrupts. Interrupt levels 2 through 5 are count pulse interrupts, two of which are standard and two of which are optional. The interrupt circuit feature that distinguishes its function is the input that enables the change of state from armed to waiting ( 01 X to 11X). For the count pulse interrupts, the signals are CPULI through CPUL4.

```
S/IS2 = IP2 CPULI + ...
S/IS3 = IP3 CPUL2 + ...
S/IS4 = IP4 CPUL3 + ...
S/IS5 = IP5 CPUL4 + ...
```

These signals are generated by real-time counter flip-flops, which are direct reset after the transfer from the armed state (01X) to the waiting state (IIX).

$$
\begin{aligned}
& \text { E/CPUL1 }=\mathrm{IS} 2 \\
& \mathrm{E} / \text { CPUL2 }=\mathrm{IS} 3 \\
& \mathrm{E} / \text { CPUL3 }=I S 4 \\
& \mathrm{E} / \text { CPUL4 }=\mathrm{IS5}
\end{aligned}
$$

The inputs to interrupt circuit 2 are typical of interrupt circuits 2 through 15.

```
S/IN2 = DATAl6 AEENLE
R/IN2 = DATA16 ADBDB1 + REN
S/IP2 = IS2 NISNIPI ARMOVD + DATAI6
    AEADBI
    NISNIP1 = NIS1 NISNIPO + IPI NISNIPO
    ARMOVD = IBO LEVARM
    FAPSD PH7 N07 R30 R31 + ...
R/IP2 = R2 IEO + DATAI6 DARM1
```

```
    R2 = IS2 IP2 IN2 NISINI
    NISINI = NISI NISINO NISNIPO + NINI
        NISINO NISNIPO
S/IS2 = IP2 CPUL1 + DATAI6 IP2 TRIGI
R/IS2 = NIP2 NISNIPI IBO + DATA DARMI
```

Signals associated with DATA 16 are controlled by a Write Direct (WD) instruction; therefore, the circuit can be enabled (placed in state XX1) only during a WD instruction. The circuit is also initially placed in the armed state ( 010 or 011 ) by a WD instruction.

Signals NISNIP1, NISNIPO, NISIN0, and NISINI are priority signals that prevent changes of state when higher priority circuits are active, or are waiting and enabled. Such signals are generated at all levels which makes it possible for only one interrupt circuit to transfer to the active state (101) at any time. More than one interrupt circuit can be in the active state if a higher priority interrupt circuit goes active during a subroutine for a lower priority interrupt circuit. Several interrupt circuits may be in the waiting and enabled state (11I) at one time; however, only the circuit having the highest priority can be transferred to the active state ( 111 to 101).

Signals IEO, IBO, and ARMOVD are generated during the interrupt sequence for the override interrupts. Corresponding signals for the counter-equals-zero interrupts are IEI, IB1, and ARMCNTR; and IE2, IB2, and ARMIO are corresponding signals for the input/output interrupts.

The normal sequence of operations for an interrupt circuit begins when the circuit is armed (placed in state OIX). When the interrupt input signal is true, the circuit is placed in the waiting state ( 11 X ).

```
S/IS2 = IP2 CPULI + ...
```

When the circuit is enabled and waiting and has highest priority, it initiates an interrupi sequence and is iransferred to the active state (101).

```
R/IP2 = R2 IEO + ...
```

The instruction stored in the associated memory location is executed while the interrupt circuit is in the active state. After all operations associated with the interrupt have been completed, the interrupt circuit leaves the active state ( 101 to 011 or 001 ). The circuit cannot be disabled by an interrupt sequence.

```
S/IP2 = IS2 NISNIPI ARMOVD + ...
R/IS2 = NIP2 NISNIPI IBO
    ARNIOVD = IBO LEVARM
```

Signal IBO is always true at the end of the interrupt sequence and causes a transfer from state 101 to state $0 \times 1$. If signal LEVARM is true at the end of the active state, the transfer is from state 101 to 011 ; if LEVARM is false, the transfer is from state 101 to 001.

3-115 Memory Parity Interrupt. Interrupt circuit 6 is transferred from the armed state to the waiting state ( $01 X$ to IIX) if PEI is true which indicates a core memory parity error has occurred while the CPU was accessing core memory.

$$
S / I S 6=I P 6 \text { PEI }+\ldots
$$

3-116 Counter-Equals-Zero Interrupts. Interrupt circuits $8,9,10$, and 11 are controlled by interrupt circuits 2,3 , 4 , and 5 , respectively.

| S/IS8 | $=1 P 8$ SR8 $+\ldots$ |
| :---: | :---: |
| SR8 | $=1 J 8 \mathrm{OF}$ |
| S/IJ8 | $=\mathrm{R} 2 \mathrm{IE} 0$ |
| R2 | $=~ I P 2 ~ I S 2 ~ I N 2 ~ N I S I N 1 ~$ |
| IE0 | = AIEB ENOVRD |
| S/AIEB | = AIEA NAIEB |
| S/AIEA | = NAIEA SAIEA |
| SAIEA | $=$ INTRAP1 INTRAP2 NEWDM NAIEB |
| S/OF | $=1 B O$ CNTZREQ |
| CNTZREQ | $=$ FAS7 PH4 INTRAPF A0031Z |
| S/IS9 | $=$ IP9 SR9 + |
| SR9 | $=1 J 9 \mathrm{OF}$ |
| S/IJ9 | $=$ SIJ9 IE0 |
| S/IJ9 | $=$ NR2 R23 |
| R23 | $=$ REIP3 + . |
| REIP3 | $\begin{aligned} = & \text { IP3 IN3 IS3 NISIN1 NISIN2 } \\ & \text { NISNIP2 } \end{aligned}$ |
| S/IS10 | $=1 P 10$ SR10 + . |
| SR 10 | $=1.10 \mathrm{OF}$ |
| S/IJ 10 | $=\mathrm{R} 4 \mathrm{IE} 0$ |
| R4 | $=$ IP4 IS4 IN4 NISIN3 |
| S/IS 11 | $=$ IPII SR11 + |
| SR11 | = IJll OF |
| S/IJll | = SIJll IE0 |
| SIJll | $=$ NR4 R45 |
| R45 | $=$ REIP5 + |
| REIP5 | $=$ IP5 IN5 IS5 NISIN3 NISIN4 NISNIP4 |

When one of the count pulse interrupt circuits is in the active state ( 101 ), and the count has been reduced to zero (A0031Z), one of the counter-equals-zero interrupt circuits is placed in the waiting state ( 01 X to 11 X ).

3-117 Input/Output Interrupt. Interrupt circuit 12 is placed in the waiting state (11X) by an IOP interrupt
request signal.

$$
\mathrm{S} / \mathrm{IS} 12=\mathrm{IP} 12 \mathrm{IR}+\ldots
$$

3-118 Control Panel Interrupt. Interrupt circuit 13 is placed in the waiting state (11X) by control pane! switch signal KINTRP interlocked with a flip-flop.

```
S/ISI3 \(=\) IPI3 SRI3 \(+\ldots\)
    SR13 \(=\) KINTRP NCNLK
S/CNLK = ISI3
R/CNLK \(=\) NKINTRP \(/ B+\ldots\)
```

3-119 PRIORITY SIGNALS. Signals generated by interrupt circuits are interconnected in order to control priority of interrupt levels. Interrupt levels 0 through 7 have the highest priority. Counter-equals-zero interrupts, input/output interrupts, and external interrupts in groups of 16 may be connected in any priority sequence at the option of the user.

The priority signals permit only one interrupt circuit in the waiting and enabled state (111) to be transferred to the active or waiting state (101) on a particular interrupt clock. However, more than one interrupt circuit may be in the active or waiting state at a given time; for example, if a high-priority interrupt circuit is transferred to the active or waiting state while a low-priority interrupt circuit is active, the high-priority circuit overrides the lowpriority circuit. While the high-priority circuit is active, the low-priority circuit which was previously active is dormant until the high-priority circuit has completed its operation. The low-priority circuit, having remained in the active or waiting state (101), then resumes operation.

Priority signals are associated with each interrupt circuit. Typical signals for even-numbered circuits are:

$$
\begin{aligned}
\text { R10 } & =\text { IN10 IP10 IS10 NISIN9 } \\
\text { NISIN9 } & =\text { NIS9 NISIN8 NISNIP8 }+\ldots \\
\text { NISNIP8 } & =\text { NIS8 }+ \text { IP8 }
\end{aligned}
$$

Thus, R10 can be true only if interrupt circuit 10 is waiting and enabled and if no high priority interrupt in that group is waiting or active. Signal NISIN10 is true only if circuit 10 is not active, and not waiting and enabled: NISNIP 10 is true only if circuit 10 is not active.

Typical signals for odd-numbered circuits are:

| REIPI1 $=$ | IN1I IP11 IS11 NISIN10 NISNIP10 |
| ---: | :--- |
|  | NISIN9 |
| NISIN10 - | NIS $10+$ NIN10 |
| NISNIP10 - | NIS $10+$ IP10 |

Thus, REIP 11 can be true only if interrupt circuit 11 is waiting and enabled and if no higher priority interrupt in that group is waiting or active. Signal NISIN10 can be
true only if interrupt circuit 10 is not active, and not waiting and enabled and if no higher priority interrupt in that group is waiting or active.

Signals NISIN9 and NISNIP9 are controlled by all interrupt circuits from 0 through 9. Similar signals are generated at all levels of interrupts.

3-120 Priority Chain Signals. An interrupt sequence is initiated after signal INT9 is true, enabling flip-flop INT to be set. Signal INT9 is controlled by inputs from all interrupt circuits, including external interrupts.

| /INT09/ $=$ | TNIREQ |
| ---: | :--- |
| TNIREQ $=$ | ENOVRD OVRQ |
|  | + ENCNTR CNRQ |
|  | + ENIO IORQ + LINREQ NEWDM |

Signal ENOVRD is true if any of the first eight interrupt circuits is waiting and enabled.

| ENOVRD | $=$ OVRQ NENFNL |
| ---: | :--- |
| OVRQ | $=$ R01 + R23 + R45 + R67 |
| R01 | $=$ IPO IS0 INO (typical) |

More than one interrupt circuit may be waiting and enabled; however, only one can generate a trùe Rx signal or REIPy signal.

Signal ENCNTR is true if any of interrupt circuits 8 through 11 is waiting and enabled (R89 + R1011), provided that the group is not inhibited by the program status doubleword (NCIF), and that no higher priority group is waiting and enabled.

```
ENCNTR = NCIF NHRQBZI NENFNL CNRQ
    HRQBZI = /RQYI/
    CNRQ = R89 + R1011
```

Signal RQYI goes outside the CPU to provide for the option of external interrupts with higher priority than the counter-equals-zero interrupt group or the input/output interrupt group.

Signal ENIO is true if any of the interrupt circuits 12 through 15 is waiting and enabled ( $\mathrm{R} 1213+\mathrm{R} 1415$ ), provided that the group is not inhibited by the program status doubleword (NII), and that no higher priority group is waiting and enabled.

$$
\begin{aligned}
\mathrm{ENIO} & =\text { NII NENFNL IORQ } \\
\mathrm{IORQ} & =\text { Ri} i \mathbf{i} 3+R i 4 i 5
\end{aligned}
$$

Signal LINREQ is generated in external equipment when an external interrupt is waiting and enabled, and starts an interrupt sequence if no Write Direct instruction in the interrupt mode (0001) is active. The NEWDM term is
required because /DATm/ lines are shared between the trigger arm, enable data on output during a Write Direct instruction, and the memory address data on input during interrupt operations.

| INT09 | $=$ TNIREQ |
| ---: | :--- |
| TNIREQ | $=$ LINREQ NEWDM $+\ldots$ |
| LINREQ | $=/$ DATA25/NEI |
| EWDM | $=$ B1619ONE WD |

3-121 Group Control. Priority signals generated by the interrupt circuits also control signals which cause changes of state in the interrupt circuits during an interrupt sequence. These signals permit only one group of interrupts to be controlled at any time. The family of IEx signals causes a change of state from waiting and enabled (111) to active (101).

```
IEO = AIEB ENOVRD NEWDM
IEI = AIEB ENCNTR ENEXSTR
IE2 = AIEB ENIO ENEXSTR
```

The family of IBx signals remove an interrupt circuit from the active state.

| IB0 $=$ | AIB CHA0 |
| ---: | :--- |
| IB1 $=$ | AIB CHAI |
| CHA0 $=$ | CHA0 RCCHA0 NCPURESET |
|  | + IEO IMC |
| RCCHAO $=$ | RCCHA NISNIP7 |
| CHAI $=$ | CHAI RCCHAI NCPURESET + IEI |
| RCCHA1 $=$ | RCCHA NISNIP 11 |
| CHA2 $=$ | CHA2 RCCHA2 NCPURESET + IE2 |
| RCCHA2 $=$ | RCCHA NISNIP15 |
| RCCHA $=$ | GARF + . . |
| S/GARF $=$ | AIB |

The family of ARMx signals causes a change of state from active to armed ( 011 ).
ARMOVD $=$ IBO LEVARM
ARMCTR $=$ IB1 LEVARM
ARMIO $=$ IB2 LEVARM

Signals AIB and LEVARM are generated during an interrupt sequence. If the LEVARM signal is false, the interrupt circuit is left in the disarmed state ( 001 ) after transfer from the active state.

3-122 Memory Address Control. Signals INT00 through INT08 retain a code which addresses the memory location associated with an interrupt level. This code, which is transferred to the P -register during the interrupt sequence,
is established by priority signals generated in the interrupt circuits.

Signals INTO, INT1, and INT3 are false for any internal interrupt level; signals INT2 and INT4 are true for any internal interrupt level.

```
INT2 = TNIO2 = ENOVRD OVRQ + ENCNTR
    CNRQ + ENIO IORQ + ...
INT4 = TNIO4 = ENOVRD OVRQ + ENCNTR
    CNRQ + ENIO IORQ + ...
```

Signals INT00 through INT08 hold the code 00101 XXXX for any internal interrupt level. Signals INT05 through INT08 hold a code that is dependent upon the internal interrupt level enabled.

```
INT05 = TNI05 = ENCNTR CNRQ + ENIO
        IORQ + ...
INT06 = TNI06 = OVLN6 ENOVRD + ENIO
        IORQ + ...
    OVLN6 = R45 + R67
INT07 = TNIO7 = OVLN7 ENOVRD
    + CNLN7 ENCNTR
    + IOLN7 ENIO + ...
    OVLN7 = R23 + R67
    CNLN7 = R1011
    IOLN7 = R1415
INT08 = OVLN8 ENOVRD + CNLN8 ENCNTR
        + IOLN8 ENIO + . . .
        OVLN8 = R1357
        CNLN8 = R911
        IOLN8 = R1315
```

Although more than one circuit may be waiting and enabled for a time, only one of the Rx signals associated with the internal interrupt circuits can be true at any time. The last four bits of the code held by signals INT00 through INT08 are any of 0000 through 1111, depending upon the interrupt circuit controlling the interrupt. Therefore, the address code for an internal interrupt is any value between 001010000 and 001011111 (hexadecimal 050 through 05F;.

The logic diagram in figure 3-128 shows how a specific interrupt level generates address data to a specific memory location. The counter 1 zero interrupt is used for this example.

When flip-flop outputs IN8, IP8, and IS8 are true, R8 is gated on. When R8 is true, the term NR89 goes false. NR89 which is one of the input terms to the CNRQ bufferinverter causes CNRQ output to go true. CNRQ generates counter group service request signal which is fed into the TNI buffer gates. These buffers are the interrupt service
routine address lines to the CPU, and because both CNRQ and the enable counter group signal ENCNTR are true, the input to the TNI buffers in this example has a binary equivalent of 0101 1000. This is equivalent to $X^{\prime} 58$ ', the memory location to be addressed.

The TNI buffer gating is input to the /INTOO/ through /INT09/ cable drivers that drive the data into the CPU. Cable receivers INT0 to INT9 receive the data. The terms INT0 through INT8 are gated with the term PXINT and are clocked into P-register flip-flops P23 through P31.

Signal INT9 generates interrupt request INT. When the request is received and acknowledged by the CPU, signal IE1 is generated, flip-flop IP8 is reset, and the interrupt sequence in the CPU is started. A detailed sequence chart is given later in this section.

3-123 SERVICE ROUTINE SEQUENCE. Figure 3-129 is a timing diagram for an interrupt operation which transfers control to a stored service routine.

When an interrupt circuit is waiting and enabled, INT is set by the interrupt service request signal, INT9.

$$
\text { S/INT }=\text { INT9 }
$$

The three interrupt flip-flops are then set during a program instruction.

$$
\begin{aligned}
\text { S/INTRAPF }= & (\text { S/INTRAPF }) \text { NRESET } \\
(\mathrm{S} / \text { INTRAPF })= & \text { INT }(\text { S/INTRAPF/I) } \\
& (\text { IEN }+ \text { ENDE })+\ldots \\
(\text { S/INTRAPFI })= & \text { NINTRAPF NINTEN KRUN/B } \\
& \text { INT }
\end{aligned}
$$

Flip-flop IEN is set during phase 1, 2, 8, 9 or 10 of an instruction, depending on the type of instruction.

$$
\begin{array}{ll}
\text { S/INTRAP1 } & =(S / I N T R A P F) \text { NRESET } \\
\text { S/INTRAP2 } & =\text { INTRAPI NRESET }
\end{array}
$$

Signal CEINT is generated and INTRAP2 is reset.

| CEINT | $=$ |
| ---: | :--- |
|  | INTRAP1 INTRAP2 |
|  | NTRAP $+\ldots$ |
| R/INTRAP2 $=$ | INTRAP2 |

The CPU clock is inhibited until signal ARE is true, and signal PXINT is true enabling transfer of address data to the P -register.

| CLEN | $=$ NCEINT + CEINT ARE $+\ldots$ |
| ---: | :--- |
| ARE | $=$ IMC AIEB $+\ldots$ |
| S/AIEB | $=$ AIEA NAIEB |
| S/AIEA | $=$ SAIEA NAIEA |
| SAIEA | $=$ INTRAP1 INTRAP2 NEWDM NAIEB |
| PXINT | $=$ INTRAP1 NINTRAP2 NTRAP |




Figure 3-129. Interrupt Timing Diagram (Counter 4 Count Pulse)

Signal CLEN is a clock enable signal.
Signal ARE is controlled by the $2-\mathrm{MHz}$ clock through signal IMC-1 and prevents changes of state in the interrupt circuit by inhibiting gated clock signal GCLK.

```
GCLK1,2 = IMC NAIEA
```

While signal AIEB is true, a true IEO, IE1, or IE2 signal causes the interrupt circuit to transfer from waiting and enabled (111) to active (101).

| R/IPn | $=$ Rn IEx $+\ldots$ (typical) |
| ---: | :--- |
| IE0 | $=$ AIEB ENOVRD NEWDM |
| IE1 | $=$ AIEB ENCNTR ENEXSTR |
| IE2 | $=$ AIEB ENIO ENEXSTR |

Signal DATA26 is generated to enable the change of state in the external circuit, if the interrupt logic is servicing an external interrupt.

$$
\text { DAT26 }=\text { AIEB } 1 M C+\ldots
$$

Signal DAT26 becomes signal DATA26 in the external interrupt circuits. This signal is used to enable the change of state of the external interrupts from waiting and enabled to active, as explained in paragraph 3-125, External Interrupts.

After signal ARE is true, a CPU clock is generated which resets INTRAP1, sets INTRAP2, and drops CEINT.

```
R/INTRAP1 = INTRAP2 + ...
S/INTRAP2 = INTRAPI NRESET
```

At this time, the XPSD instruction in the assigned memory location is extracted from memory and is executed. The service routine addressed by the XPSD instruction may be interrupted. A service routine that is not interrupted is terminated by an LPSD instruction which generates CEINT during phase 7 and causes signal LEVACT to be true.

```
CEINT = FAPSD PH7 N07 R30 + ...
LEVACT = FAPSD PH7 N07 R30 + ...
```

The CPU clock is inhibited until signal ARE is true.

$$
\begin{aligned}
C E & =N C E I N T+C E I N T A R E+\ldots N(\ldots) \\
\text { ARE } & =\operatorname{IMC} \operatorname{AIEB}(\ldots)
\end{aligned}
$$

When the interrupt service routine ends, the interrupt circuit that initiated the operation is transferred from the active state (101) to either the disarmed state (001) or the armed state ( 011 ). Bit position 10 of the LPSD instruction must contain a one which causes R30 to be set, and enables LEVACT to be true for any change of state.

$$
\begin{aligned}
\mathrm{R} / \mathrm{ISn} & =\mathrm{NIPn} \text { NISNIPy IBO }+\ldots \text { (typical) } \\
\mathrm{IBO} & =\mathrm{AIBCHAO}
\end{aligned}
$$

If bit position 11 of the LPSD instruction contains a one, R31 is set, LEVARM is true, and the change of state is from active to armed ( 101 to 011 ).

```
S/IPn = ISn NISNIPy ARMOVD + ...
    (typical)
    ARMOVD = IBO LEVARM
    LEVARM = FAPSD PH7 O7 R30 R31
```

If bit position 11 of the LPSD instruction contains a zero, R3I is not set, and the change of state is from active to disarmed (101 to 001).

If the interrupt logic is servicing an external interrupt, signals DAT27 and DAT28 are generated to enable changes of state in the external circuit.

$$
\begin{aligned}
\text { DAT27 } & =\text { AIB } 1 M C+\ldots \\
\text { DAT28 } & =\text { LEVARM NEWDM }+\ldots
\end{aligned}
$$

These signals become signals DATA27 and DATA28 in the external interrupt circuits. Signal DATA27 enables removal of an external interrupt from the waiting or active state, and signal DATA28 is used to place the interrupt in the armed state. This logic is explained in paragraph 3-125.

3-124 MODIFY AND TEST SEQUENCE. The sequence of operations for an interrupt that transfers control to a Modify and Test instruction is similar to the sequence that transfers control to an XPSD instruction and the associated service routine. When the interrupt circuit is waiting and enabled and has priority, INT is set, and the interrupt operations follow the end phase of the instruction or the interruptible point in an instruction as determined by flip-flop IEN. After INTRAP, INTRAP1, and INTRAP2 are set, the CPU clock is inhibited, the interrupt circuit is placed in the active state, and the contents of the memory location are extracted and executed, as described for the service routine sequence (paragraph 3-123).

During a modify and test sequence of a counter interrupt, count-equals-zero A0031Z is sampled, and a count-equalszero interrupt circuit may be placed in the waiting state (11X) if the effective location of the Modify and Test instruction contains all zeros when A 0031 Z indicates that the modified word in the effective location equals zero.

| S/IS8 | $=$ IP8 SR8 $+\ldots$ (typical) |
| ---: | :--- |
| SR8 | $=$ IJ8 OF |
| S/IJ8 | $=$ R2 IE0 |
| R2 | $=$IP2 IS2 IN2 NISIN1 (count <br> pulse interrupt) |
| S/OF | IB0 CNTZREQ |
| CNTZREQ | $=$ FAS7 PH4 INTRAPF A0031Z |

The interrupt circuit is always transferred from the active state (101) to the armed state (011) because LEVARM is always true.

```
R/ISn = NIPn NISNIPy IBO + . . (typical)
    IBO = AIB CHAO
    AIB = LEVACTN (...)
    LEVACT = FAS7 PH4 INTRAPF + ...
S/IPn = ISn NISNIPy ARMOVD + ...
    ARMOVD = IBO LEVARM
    LEVARM = FAS7 PH4 INTRAPF + ...
```

After the Modify and Test instruction has been extracted from memory, it inhibits and enables the CPU clock by controlling CEINT

```
CEINT
FAS7 PH4 INTRAPF + ....
```

and terminates the sequence by resetting INTRAPF.

$$
\text { R/INTRAP }=\text { FAS7 PH4 INTRAPF }+\ldots
$$

The modify and test sequence is controlled by the Modify and Test Word instruction. The address of the next instruction in sequence is stored during PREP phases; therefore, a modify and test sequence is a single-instruction interrupt.

3-125 EXTERNAL INTERRUPTS. External interrupts control an interrupt circuit containing three flip-flops. The priority of an external interrupt group depends upon the cable connection with the CPU. The priority of the individual interrupts within a group is established in the same way as in the internal interrupt circuits.

When an external interrupt is waiting and enabled and has priority, it generates a true INT9 signal, and causes INT to be set, like an internal interrupt. The true INT9 signal is generated by a DAT25 signal when no WD instruction in the interrupt mode is active where /DAT25/ is the interrupt signal from the external interrupt chassis.

```
S/INT = INT9 = /INT09/
    INT9 = LINREQ NEWDM + . . 
    /INT09/ = TNIREQ
    TNIREQ = LINREQ NEWDM
    LINREQ = LINREQ NEWDM
    LINREQ = /DAT25/
    EWDM = NB16, NB17, NB18, B19 DIOWD
```

The interrupt address is transmitted from the external to the internal interrupt circuits over lines /DAT 16/ through /DAT24/.

| INTO |  | $\underset{(\text { internal) }}{/ \mathrm{INTOO}}=\mathrm{TNIOO}=$ | LINOO NEWDM |
| :---: | :---: | :---: | :---: |
| INT8 | $=$ | /INT08/ = TNI08 = | LIN08 NEWDM |
| LIN00 | $\cdots$ | /DAT16/ (external) |  |
| : |  | : |  |
| LIN08 | $=$ | /DAT24/ |  |

The change of state of an external interrupt circuit from waiting and enabled (111) to active (101) is controlled by DAT26, originating in the internal interrupt circuits, when ENEXSTR is an interrupt enable signal generated in the internal circuits.

```
R/IPn = REIPn EIE (external)
    EIE = DATA26 ENEXSTR LINREQ
    DATA26 = /DAT26/ (from internal circuits)
```

Signal DAT27 from the internal interrupt circuits controls removing an external interrupt from the active state.

```
R/ISn = EIB (...) (external)
    EIB : DATA27 ENEXSTR (external)
    DATA27 = /DAT27/ (from internal circuits)
```

Signal DAT28 from the internal interrupt circuits controls placing the interrupt in the armed state on removal from the active state.

```
S/IPn = ISn LEVARM (...) (external)
    LEVARM = ENEXSTR DATA28 EIB (external)
    DATA28 = /DAT28/ (from internal circuits)
```

All external interrupts are inhibited if flip-flop EI, part of the program status doubleword, is set.

| /ERQY/ | $=$ PCRQBZE (external interrupt request) |
| ---: | :--- |
| PCRQBZE $=$ | DATA29 LINREQ NEWDM |
|  | ECHA $+\ldots$ |
| DATA29 $=$ | /DAT29/ (from internal circuits) |
| /DAT29/ | $=$ NEWDM NEI $+\ldots$ (internal) |

3-126 WRITE DIRECT INTERRUPT OPERATION. A Write Direct (WD) instruction can control the interrupt operation in two ways. When operating in the internal mode, it can control the states of flip-flops CIF, EI, and II, which can inhibit the priority chain signals. A WD enables signals DAT16 through DAT31, which select individual interrupt circuits, when operating in the interrupt mode. These inputs have the following general form, $y=x+14$ for $x$ = 2, 3 . . 15.

```
S/INx -- DATAy AEENLEI + ...
R/INx = DATAy ADBDBI + REN + ...
```

```
S/IPx = DATAy AEADBI + ...
R/IPx = DATAy DARMI + ...
S/ISx = DATAy TRIGI IPx + ...
R/ISx = DATAy DARMI + ...
    DATAy = /DIOy/ = Sy DIOXS
    DIOXS = OLD OU6 SW3 NRZ (Write Direct)
```

These signals change the state of interrupt circuits when a WD instruction in the interrupt control mode, bits 16 through 19, presents a code, bits 21 through 23, addressed to any group, bits 28 through 31 . The details of this operation are explained in the following paragraphs.

When a WD instruction in the interrupt control mode is executed, signal EWDM is true.

$$
\begin{aligned}
\text { EWDM }= & \text { B1619ONE WD } \\
W D= & / D I O 50 /=\text { DIO50X1 }=\text { OLD } \\
& \text { OU6 SW3 }
\end{aligned}
$$

During phase 3 of the WD instruction, /DIO48/is true and CNA is set.

| S/CNA | $=$ NCNA NCNB SCNA |
| ---: | :--- |
| SCNA | $=$ FS EWDM |
| FS | $=$ /DIO48/ |
| /DIO48/ | $=$ DIO48X1 = FARWD SW4 |

Flip-flop CNB is set on the next $1-\mathrm{MHz}$ clock following the setting of flip-flop CNA, and flip-flop CNA is reset
by signal CNB:

```
S/CNB = CNA NCNB
R/CNA = CNB + ...
```

A function strobe acknowledge signal is generated in the interrupt circuits and is sent to the CPU on line /DIO49/.

$$
\begin{aligned}
& \text { FSA }=\text { NCNA CNB } \\
& \text { /DIO49/ }=\text { FSA }
\end{aligned}
$$

These signals are generated in the internal interrupt circuits for use during both internal and external interrupt operation. Figure 3-130 is a timing diagram of these signals.

Changes of state in the interrupt circuits may take place only when signal CNA is true. In the internal interrupt circuits, this is ensured by enabling the group 0 signal with CNA:

$$
\begin{aligned}
\text { GRP0 }= & \text { CNA NADDR12 NADDR13 } \\
& \text { NADDR14 NADDR15 }
\end{aligned}
$$

where ADDR12 through ADDR15 represent the group code in B 28 through B31. The external interrupt operation is controlled by using signal CNA to generate function line enable signal ENFNL.

```
ENFNL = CNA IMC + ...
FNLOO - FNLO2 = (ADDR05 - ADDR07) ENFNL
```

The function lines to the external interrupt circuits can be active only when signal CNA is true.


Figure 3-130. Write Direct Sequence, Timing Diagram

The next phase of the Write Direct instruction is entered, when the CPU receives signal FSA from the interrupt circuits.

The internal interrupts are selected when the Write Direct instruction selects group 0 by zeros in bits 28 through 31 of the instruction word. Signals DAT16 through DAT29, generated from the contents of the private memory register by way of the DIO lines, select interrupt circuits 2 through 15. The first two internal interrupt circuits are the power fail-safe interrupts and are not controlled by a Write Direct instruction.

An external interrupt group has been chosen if any interrupt group other than group 0 is selected, and signals DAT16 through DAT31 determine which of the 16 interrupts in the group are to be controlled.

The code stored in bits 21 through 23 of the instruction word causes changes of state in the interrupt circuits as shown in table 3-16. Signals generated from this code in the B -register are as follows:

$$
\begin{aligned}
\text { ADDR05-ADDR07 } & =/ \mathrm{DIO} 37 /-/ D I O 39 / \\
& =\text { B21-B23 }
\end{aligned}
$$

For the external interrupts, signals ADDR05 through ADDR07 become signals FNL00 through FNL02, which are used for function decoding. The control signals generated from the code are DARM1, AEADBI, AEENLE1, ADBDB1, REN, and TRIG1. A logic diagram of these signals is shown in the interrupt control mode part of the Write Direct instruction description. The signals are used to change the states of the IS, IP, and IN flip-flops as previously described in this discussion. The changes of state resulting from these signals are summarized in table 3-17.

3-127 CPU INTERRUPT SEQUENCE. An interrupt can occur during the ENDE or IEN phase of an instruction. Since most instructions have a short execution time, most interrupts occur before or after an instruction execution of ENDE time. However, during multiple operand instructions, iterative sequences have a longer execution period because the control and intermediate results of these instructions reside in registers and memory. Since it may be necessary to interrupt during multiple operand instructions, the interrupt enable flip-flop, IEN, is set between instruction iterations.

When IEN is set, an interrupt can be accepted on any clock. If an interrupt request is received and acknowledged, INT is set, and the term (S/INTRAPF) initiates the interrupt sequence. The CLEAR signal is generated during ENDE time or when (S/INTRAPF) is true. Flip-flop INTRAPI, the interrupt phase flip-flop, is set during ENDE or IEN in preparation for Pass 1 and Pass 2 of the INTRAP1 phasing.

If IEN is true and ENDE is false, $B R Q$ is set. $B R Q$ is a repeater flip-flop which causes the contents of $Q$ to transfer to $P$. BRQ insures that the address stored by the XPSD instruction points at the right instruction in the
iteration chain for processing after the interrupt is completed.

Table 3-16. Function of Codes for WD Interrupt Control Mode

| CODE |  |  | OPERATION |
| :---: | :---: | :---: | :---: |
| B21 | B22 | 323 |  |
| 0 | 0 | 0 | Undefined |
| 0 | 0 | 1 | Disarm all levels selected by a one; all levels selected by a zero are not affected |
| 0 | 1 | 0 | Arm and enable all levels selected by a one; all levels selected by a zero are not affected |
| 0 | 1 | 1 | Arm and disable all levels selected by a one; all levels selected by a zero are not affected |
| 1 | 0 | 0 | Enable all levels selected by a one; all levels selected by a zero are not affected |
| 1 | 0 | 1 | Disable all levels selected by a one; all levels selected by a zero are not affected |
| 1 | 1 | 0 | Enable all levels selected by a one and disable all levels selected by a zero |
| 1 | 1 | 1 | Trigger all levels selected by a one. All such levels that are currently armed advance to the waiting state. Those levels currently disarmed are not altered, and all levels selected by a zero are not affected |

Three interrupt phases are interposed between the interrupt acknowledgment at ENDE or IEN and preparation phase 1 of the following Program Status Doubleword instruction. These three phases are referenced in the following paragraphs as Pass 1, Pass 2 and Pass 3, where Pass $1=$ INTRAP1 NINTRAP2, Pass $2=$ INTRAP1 INTRAP2, and Pass $3=$ NINTRAP1 INTRAP2.
a. Pass 1. During Pass 1, the address of the interrupted instruction is transferred from the P -register to the S-bus. From the S-bus, the interrupted instruction address is clocked into the A-register. The D-register is cleared of ones and is filled with zeros. The CS-register is filled with ones. Further action on the interrupted instruction address occurs during Pass 3.

The address in the $P$-register is transferred to $Q$ at the Pass 1 clock, and, if $B R Q$ is true, the contents of the $Q$-register
are clocked into $P$. If $B R Q$ is not true, the contents of the P -register are not disturbed at the Pass 1 clock. Thus, during Pass 2, the $P$-register contains the address of the next instruction if the interrupt was acknowledged at ENDE time, or contains the address of the current instruction if the interrupt was acknowledged at IEN time.

Table 3-17. Signals Enabled by Codes for WD Interrupt Control Mode, and Resulting Changes of State

| CODE | TRUE CONTROL SIGNALS | CHANGE OF STATE (ISn, IPn, INn) |  |
| :---: | :---: | :---: | :---: |
|  |  | DATy $=1$ | DAT $y=0$ |
| 001 | DARM | $X X X \rightarrow 00 x$ | No change |
| 010 | AEENLE, ADBDB, AEADB, DARM | $X X X \rightarrow 011$ | No change |
| 011 | ADBDB, AEADB, DARM | $X X X \rightarrow 010$ | No change |
| 100 | AEENLE, ADBDB | $X X X \rightarrow X X I$ | No change |
| 101 | ADBDB | $X X X \rightarrow X X 0$ | No change |
| 110 | AEENLE, REN | $X X X \rightarrow X X 1$ | $\mathrm{XXX} \rightarrow \mathrm{XXO}$ |
| 111 | TRIG (if IPn) | $\mathrm{X} 1 \mathrm{X} \rightarrow 11 \mathrm{x}$ | No change |
|  | (if NIPn) | $\mathrm{XOX} \rightarrow \mathrm{XOX}$ |  |

If the memory map feature is used in the system, the map disconnect flip-flop, MAPDIS, is set during INTRAP1 Pass 1 to inhibit mapping for the ensuing phases of the interrupt sequence. MAPDIS prevents any modification of the interrupt address if MAP is true.

At the end of Pass I, DRQ and INTRAP2 are set. DRQ is a repeater flip-flop that indicates the next clock will not occur until the data release signal, DR, has been received by the CPU from memory, if a memory request, $M R Q$, has been generated.

The term that generates the T 10 L clock $(\mathrm{S} / \mathrm{T} 10 \mathrm{~L} / 1)$ is always true during Pass 1. Therefore, T1OL measures the period for Pass 2.
b. Pass 2. The Pass 2 phase of the sequence sets the highest priority waiting interrupt to the active state, and the interrupt address is transferred to the P -register by the term PXINT. The contents of INTO-INT08 are clocked into P23-P31. Bits P15-P22 of the P-register are simultaneously filled with zeros.

The contents of P15-P31 are put on the LM-LB lines, and the memory request, $M R Q$, is generated during this pass. Signal CEINT is a clock enable interlock signal that causes the next clock to be synchronized with the 1 MHz interrupt
clock. CEINT further insures that the address on the interrupt lines has settled before the next T6L clock is generated. Both INTRAP1 and INTRAP2 are reset and Pass 2 is clocked. During this pass, INTRAP2 is again set so that it goes true for the Pass 3 phase that follows.
c. Pass 3. During Pass 3, the A-register contains the next instruction address of the interrupted instruction. This was accomplished during Pass 1 by SXP and AXS. Since the next instruction address of the interrupted instruction is currently in the A-register, it is necessary to decrease the contents of $A$ by a count of one. This is necessary because when the interrupted instruction address is returned to the $P$-register after the interrupt, it is increased by a count of one. Therefore, the contents of registers A, D, and CS are added for the decrement of one. The A-register contains the interrupted instruction address, the CS-register contains all ones and the D-register contains all zeros.
G0-G31 = A0-A31 CS0-CS31 ND0-ND31

Data from the memory bus lines, MB, is loaded into the Cregister by the data release signal, $D R$, at any time during INTRAP2. At the next clock, the contents of the C-register are transferred to the $\mathrm{O}-\mathrm{R}$-, and D -registers. Flip-flop SWl is also set because INTRAPEND is generated.

At the next clock, flip-flop MAPDIS is reset if bit 10 of the Exchange Program Status Doubleword is set which indicates map mode. Flip-flop SW1 is set in this phase, which enables the setting of flip-flop PREI at the following clocks. The XPSD instruction is then executed.

The interrupt phase sequence chart is shown in table 3-18. See table 3-153 for an explanation of phase sequence chart symbology.

If HALT is true at this point in the sequence, PCPI is set.

## 3-128 Traps

Trap is basically an automatic error detection system. If a call instruction, nonallowed operation, unimplemented instruction, fault condition, or watchdog timer runout is detected, a trap results. The CPU detection of a trap condition causes the immediate execution of the Trap instruction in a unique location in memory. Trap can also be used to simulate optional instructions that have not been physically implemented. The simulation is accomplished by the use of call instructions.

When a trap condition occurs, the CPU sets the trap state flip-flop, INTRAPF. Depending on the type of trap, the instruction currently being executed by the CPU may or may not be carried to completion. In any event, the instruction is terminated with a trap sequence. In this sequence, the instruction address portion of the Program Status Doubleword (PSD), which has already been incremented by one, is decremented by one, and the instruction in the location associated with the trap is executed.

Table 3-18. Interrupt Sequence


Table 3-18. Interrupt Sequence (Cont.)

| Phase | Function Performed | Signals Involved |  |  | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
| T6L (Cont. | SCEN <br> Reset flip-flop HALT <br> Set INTRAP2 | SCEN <br> R/HALT <br> S/INTRAP2 | $=$ $=$ $=$ | N(INTRAP1 NINTRAP2 NTRAP) <br> INTRAPI + . . . <br> INTRAPI NRESET | SCEN goes false and inhibits single clock during following clock period |
| PASS 2 | Interrupt address $\longrightarrow$ P-register | PXINT |  | INTRAP1 INTRAP2 NTRAP | $\left\lvert\, \begin{aligned} & \text { INT0-8 } \longrightarrow \text { P23-P31 } \\ & 0 \longrightarrow \text { P15-P22 } \\ & 0 \longrightarrow \text { P32-P33 } \end{aligned}\right.$ |
| IN- <br> TRAPI <br> IN- <br> TRAP2 | Disable signal LMXC | LMXC | $=$ | LMXC NAR N(INTRAPI INTRAP2) | Disable C $\longrightarrow$ LM and LB address lines |
|  | Disable AHCL | AHCL <br> (INTRAPI <br> INTRAP) | $=$ $=$ | AHCL N(INTRAPI INTRAP) INTRAPI INTRAP2 | Address here clock |
|  | $P \longrightarrow S \rightarrow$ A | $S X P$ |  | INTRAPI NSDIS + . . | Current instruction address |
|  |  | AXS |  | INTRAPI + . . |  |
|  | Generate memory request | MRQ |  | INTRAPI INTRAP2 + ... |  |
| TIOL | Generate CEINT | CEINT |  | INTRAPI INTRAP2 NTRAP +... | Synchronizes next CPU clock with $1-\mathrm{MHz}$ interrupt clock |
| PASS 3 <br> inv- <br> TRAP2 <br> NIN- <br> TRAPI | $A-1 \longrightarrow S \rightarrow B$ | SXADD | $=$ INTRAP2 NINTRAPI NSDIS |  | Decrements next instruction address of interrupted instruction |
|  |  | BXS |  | INTRAP2 + |  |
|  | P15-P31 $\longrightarrow$ Q15-Q31 | QXP |  | INTRAP2 + | Interrupt address |
|  | MB0-MB31 $\longrightarrow \mathrm{C} 0-\mathrm{C} 31$ | CXMB | $=$ | DGC | Read Program Status Doubleword instruction trom interrupt address |
|  | $\mathrm{CO} \rightarrow-\mathrm{IA}$ | OXC |  | ORXC + OXC | Instruction word $\dagger$ O-, |
|  | $\begin{aligned} & \mathrm{Cl}-\mathrm{C} 7-\mathrm{O}-\mathrm{O} 7 \\ & \mathrm{C} 8-\mathrm{Cl}, \mathrm{R} 28-\mathrm{R} 31 \end{aligned}$ | ORXC | $=$ | NINTRAP1 INTRAP2 | R -, and D-registers |
|  | $\mathrm{CO}-\mathrm{C} 31 \rightarrow$ D0-D31 | DXC |  | INTRAP2 + . |  |
| (Continued) |  |  |  |  | Mnemonic: Interrupt Sequence |

Table 3-18. Interrupt Sequence (Cont.)


An interrupt acknowledgement cannot occur until the execution of the instruction in the trap location is completed. The instruction in the trap location must be an Exchange Program Status Doubleword (XPSD) instruction; if the execution of any other instruction in a trap location is attempted as the result of a trap activation, the results of the instruction are unpredictable.

The XPSD instruction in a trap location is accessed without using the memory map, regardless of whether or not the memory map is in effect when the trap condition occurs. No memory protection violation or privileged instruction violation can occur as a result of either accessing or executing an XPSD instruction in a trap location.

3-129 NONALLOWED OPERATION. The occurrence of one of the nonallowed operations or an interrupt system fault always causes the computer to abort the instruction being executed at the time that the nonallowed operation is detected and to execute immediately the instruction in trap location $X^{\prime} 40^{\prime}$.

3-130 NONEXISTENT INSTRUCTION. Any instruction that is neither standard nor optional is defined as nonexistent. This includes immediate addressing instructions that are indirectly addressed. If a nonexistent instruction is detected, the computer traps to location $X^{\prime} 40$ ' at the time the nonexistent instruction is detected. For this case, the operation of the XPSD instruction in trap location $X^{\prime} 40^{\prime}$ with respect to the condition code and instruction address portions of the PSD is as follows:
a. Store current PSD. Condition code stored existed at the end of instruction executed immediately before the nonexistent instruction.
b. Load new PSD. Current PSD is replaced by contents of the doubleword location following doubleword location in which current PSD was stored.
c. Modify new PSD.

1. Set CC 1 to 1. $\mathrm{CC} 2, \mathrm{CC} 3$, and CC 4 remain set at values loaded from memory.
2. If bit position 9 of XPSD contains a one, the instruction address loaded from memory is incremented by eight. If bit position 9 of XPSD contains a zero, instruction address remains at the value loaded from memory.

3-131 NONEXISTENT MEMORY ADDRESS. Any memory access to a nonexistent memory address causes a trap to location $X^{\prime} 40$ ' at the time of the request for memory service. A nonexistent memory address condition is detected by memory on the basis of the actual address presented. If the CPU is currently using the memory map, the virtual address has already been modified by the memory map to generate an actual, but nonexistent, address. The
operation of the XPSD in trap location X'40' for this case is as follows:
a. Store current PSD.
b. Load new PSD.
c. Modify the new PSD.

1. Set CC2 to 1. CC1, CC3, and CC4 remain set at values loaded from memory.
2. If bit position 9 of XPSD contains a one, the instruction address loaded from memory is incremented by four. If bit position 9 of XPSD contains a zero, the instruction address remains at the value loaded from memory.

3-132 PRIVILEGED INSTRUCTION IN SLAVE MODE. An attempt to perform a privileged instruction while the CPU is in the slave mode causes a trap to location $X^{\prime} 40^{\prime}$ at the time of instruction decoding. In this case, the operation of the XPSD in trap location $X^{\prime} 40^{\prime}$ is as follows:
a. Store current PSD.
b. Load new PSD.
c. Modify the new PSD.

1. Set CC 3 to 1. $\mathrm{CC1}, \mathrm{CC} 2$, and CC 4 remain at values loaded from memory.
2. If bit position 9 of XPSD contains a one, the instruction address loaded from memory is incremented by two. If bit position 9 of XPSD contains a zero, the instruction address remains at values loaded from memory.

The operation codes $X^{\prime} 0 C^{\prime}, X^{\prime} O D^{\prime}, X^{\prime} 2 C^{\prime}, X^{\prime} 2 D^{\prime}$ and their indirectly addressed forms $X^{\prime} 8 C^{\prime}, X^{\prime} 8 D^{\prime}, X^{\prime} A C ', X^{\prime} A D^{\prime}$ are both nonexistent and privileged. If one of these operation codes is used while the CPU is in the slave state, both CC1 and CC3 are set to ones after the new PSD has been loaded and, if bit position 9 of XPSD contains a one, the instruction address loaded from memory is incremented by 10 .

3-133 MEMORY PROTECTION VIOLATION. A memory protection violation can occur either because of a memory map access control bit violation by a slave program using the memory map or because of a memory write lock violation by either a slave or a master mode program. When either memory protection violation occurs, the CPU aborts execution of the current instruction without changing protected memory and traps to location X' 40 '. In this case, the operation of the XPSD in trap location $X^{\prime} 40^{\prime}$ is as follows:
a. Store current PSD.
b. Load new PSD.
c. Modify the new PSD.

1. Set CC 4 to 1. $\mathrm{CC} 1, \mathrm{CC} 2$, and CC 3 remain at values loaded from memory.
2. If bit position 9 of XPSD contains a one, the instruction address loaded from memory is incremented by one. If bit position 9 of XPSD contains a zero, the instruction address remains at the value loaded from memory.

An attempt to access a memory location that is both protected and nonexistent causes both CC2 and CC4 to be set to ones after the new PSD has been loaded and, if bit position 9 of XPSD contains a one, the instruction address loaded from memory is incremented by five.

3-134 UNIMPLEMENTED INSTRUCTIONS. There are two optional instruction groups for the system: the decimal option and the floating point option. The computer traps to location $\mathrm{X}^{\prime} 4 \mathrm{I}^{\prime}$, if an attempt is made to execute a directly or indirectly addressed instruction in either of these groups when the required option is not implemented. An indirectly addressed Edit Byte String (EBS) instruction is always treated as a nonexistent instruction rather than as an unimplemented instruction. The Move to Memory Control (MMC) instruction is always considered implemented even if the memory map or memory protection options are not implemented. The operation of the XPSD in trap location $X^{\prime} 41^{\prime}$ is as follows:
a. Store current PSD. The condition code stored is that which existed at the end of the instruction immediately before the unimplemented instruction.
b. Load new PSD. The condition code and instruction address portions of the PSD remain at the values loaded from memory.

3-135 PUSH-DOWN STACK LIMITS. Push-down stack overflow or underflow can occur during execution of any of the following instructions:

Push Word
Pull Word
Push Multiple
Pull Multiple
Modify Stack Pointer
During the execution of any stack-manipulating instruction, the stack is either pushed with words added to the stack or is pulled with words removed from the stack. In either case, the space and the word count fields of the stack pointer doubleword are tested before moving any words. If execution of the instruction would cause the space count to become either less than zero or greater than $2^{15}-1$, the instruction is aborted with memory and registers unchanged. If bit 32 (TS) of the stack pointer doubleword is zero, the CPU traps to location $X^{\prime} 42^{\prime}$. If execution of the instruction would cause the word count to become either less than
zero or greater than $2^{15}-1$, the instruction is aborted with memory and registers unchanged; then, if bit 48 (TW) of the stack pointer doubleword is zero, the CPU traps to location X'42'. If trapping does occur, the condition code remains at the value it had immediately before the instruction that caused the trap. When trapping is inhibited, either CCl or CC3 is set to one, or both CCl and CC3 are set to one, to indicate the reason for aborting the instruction. The stack pointer doubleword, memory, and registers are modified only if the instruction is successfully executed. The execution of the XPSD in trap location $X^{\prime} 42^{\prime}$ is as follows:
a. Store current PSD. The condition code stored is that which existed immediately before execution of the aborted push-down instruction.
b. Load new PSD. The condition code and instruction address portions of PSD remain at values loaded from memory.

## 3-136 FIXED-POINT OVERFLOW. Fixed-point overflow

 can occur for any of the following instructions:Load Complement Word
Load Absolute Word
Load Complement Doubleword
Load Absolute Doubleword
Add Immediate
Add Halfword
Add Word
Add Doubleword
Subtract Halfword
Subtract Doubleword
Divide Halfword
Divide Word
Add Word to Memory
Modify and Test Halfword
Modify and Test Word
Except for the Divide Halfword (DH) and Divide Word (DW) instructions, the instruction execution is allowed to proceed to completion; CC2 is set to one. CC3 and CC4 represent the actual result ( $0,-$, or + ) after overflow.

If the fixed-point arithmetic trap mask, bit 11 of PSD, is a one, the CPU traps to location $X^{\prime} 43^{\prime}$ instead of executing the next instruction in sequence.

For DW and DH, the instruction execution is aborted without changing any registers, and CC 2 is set to one. CCl , CC3, and CC4 remain unchanged from their values at the end of the instruction immediately before the DW or DH. If the fixed-point arithmetic trap mask is a one, the CPU
traps to location X'43' instead of executing the next instruction in sequence as follows:
a. Store current PSD. If the instruction causing the trap was an instruction other than DW or DH, the stored condition code is interpreted as follows:

| CC1 | CC2 | CC3 | $\frac{C C 4}{}$ | Meaning <br> - | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: |

$C C 1$ remains unchanged for the LCW, LAW, LCD, and LAD instructions.

If the instruction causing the trap was DW or DH, the stored condition code is interpreted as follows:

$$
\begin{array}{ccccc}
C C 1 & \frac{C C 2}{} \quad \frac{C C 4}{} \quad \begin{array}{l}
\text { Meaning } \\
- \\
-
\end{array}-\quad \text { Overflow }
\end{array}
$$

b. Load new PSD. The condition code and instruction address portions of the PSD remain at the value loaded from memory.

3-137 FLOATING POINT ARITHMETIC FAULT CONDITION. Floating point fault detection is performed after the operation called by the instruction code is performed, but before any results are actually loaded into the general registers. Thus, the floating point operation that causes an arithmetic fault is not carried to completion in the sense that the original contents of the general registers remain unchanged. Instead, the computer traps to location $X^{\prime} 44$ ' with the current condition code indicating the reason for the trap. A characteristic overflow or an attempt to divide by zero always results in a trap condition. A significance check or a characteristic underflow results in a trap condition only if the floating point mode controls (FS, FZ, and FN) in the program status doubleword are set to the appropriate state.

If a floating point instruction causes a trap, the execution of XPSD in trap location $X^{\prime} 444^{\prime}$ is as follows:
a. Store current PSD. If division is attempted with a zero divider or if characteristic overflow occurs, stored condition code is interpreted as follows:

$$
\frac{C C 1}{0} \quad \frac{C C 2}{1} \quad \frac{C C 3}{0} \quad \frac{C C 4}{0} \quad \text { Divide by zero }
$$

| CC1 | $\underline{C C 2}$ | $\underline{C C 3}$ | $\underline{C C 4}$ | Meaning <br> 0 |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 1 | Characteristic overflow, <br> negative result |  |
| 0 | 1 | 1 | 0 | Characteristic overflow, <br> positive result |

b. If none of the above conditions occurs, but characteristic underflow occurs with the floating zero (FZ) mode bit set to one, the stored condition is interpreted as follows:

$$
\begin{array}{ccccc}
\text { CC1 } & \text { CC2 } & \text { CC3 } & \frac{C C 4}{1} &
\end{array} \begin{gathered}
\text { Meaning } \\
1
\end{gathered} 1 \begin{array}{lllll}
\text { Characteristic underflow, } \\
1 & 1 & 1 & 0 & 1
\end{array} \begin{aligned}
& \text { Characteristic underflow, } \\
& \text { negative result } \\
& \text { positive result }
\end{aligned}
$$

c. The stored condition code is interpreted in the following manner, if none of the above conditions occur, but an addition or subtraction results in either a zero result (with $\mathrm{FS}=1$ and $\mathrm{FN}=0$ ), or a postnormalization shift of more than two hexadecimal places (with FS $=1$ and $F N=0$ ).

$$
\begin{array}{ccccc}
\frac{C C 1}{1} & \frac{C C 2}{} & \frac{C C 3}{} & \frac{C C 4}{} & \begin{array}{l}
\text { Meaning } \\
1
\end{array} 0
\end{array}
$$

d. Load the new PSD. The condition code and instruction address portions of the PSD remain at the values loaded from memory.

3-138 DECIMAL ARITHMETIC FAULT. When either of two decimal fault conditions occur, the normal sequencing of instruction execution is halted. $\mathrm{CC1}$ and CC 2 are set according to the reason for the fault condition; and CC 3 , CC4, memory, and the decimal accumulator remain unchanged by the instruction. If the decimal arithmetic trap mask, bit position 10 of the PSD, is a zero, the instruction execution sequence continues with the next instruction in the sequence of the time of fault detection; however, if the decimal arithmetic trap mask bit is a one, the computer traps to location $X^{\prime} 45^{\prime}$ at the time of fault detection. The execution of XPSD in trap location $X^{\prime} 45^{\prime}$ is as follows:
a. Store the current PSD. The stored condition code is interpreted as follows:

| $\frac{C C 1}{0}$ | $\frac{C C 2}{1}$ | $\frac{C C 3}{}$ | $\frac{C C 4}{}$ |  |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | - | - | Mll digits legal and overflow |
| 1 | 0 | - | Illegal digit detected |  |

b. Load the new PSD. The condition code and instruction address portions of the PSD remain at the values loaded from memory.

3-139 WATCHDOG TIMER RUNOUT. The instruction watchdog timer ensures that the CPU must periodically reach interruptible points of operation in the execution of instructions. An interruptible point is a time during the execution of a program when an interrupt request, if present, is acknowledged. Interruptible points occur at the end of every instruction, ENDE time, and during the execution of some instructions, IEN time. The watchdog timer measures elapsed time from the last interruptible point. If the maximum allowable time has been reached before the next time that an interrupt could be recognized, the current instruction is aborted, and the watchdog timer runout trap is activated. Except for a nonexistent address used with Read Direct or Write Direct instructions, programs trapped because of watchdog timer runout cannot, in general, be continued. In this case, execution of the XPSD in trap location X'46' is as follows:
a. Store current PSD. Stored condition code is, in general, meaningless.
b. Load new PSD. Condition code and instruction address portions of the PSD remain at the values loaded from memory.

3-140 CALL INSTRUCTIONS. The four call instructions, CAL1, CAL2, CAL3, and CAL4, cause the computer to trap to location X'48' for CAL1, X'49' for CAL2, X'4A' for CAL3, or $X^{\prime} 4 B^{\prime}$ for CAL4. Execution of the XPSD in the appropriate trap location is as follows:
a. Store current PSD. The stored condition code is that which existed at the end of the instruction immediately before the call instruction.
b. Load new PSD.
c. Modify new PSD.

1. The R-field of the call instruction is logically OR-gated with the condition code value loaded from memory, and the result is loaded into the condition code.
2. If bit 9 of XPSD conrains a one, the R-field of the call instruction is added to the instruction address loaded from memory.
3. If bit 9 of XPSD contains a zero, the instruction address remains at the value loaded from memory.

3-141 CPU TRAP SEQUENCE. A trap can occur during the phases noted in the S/TRAP or S/TRACC logic or during the ENDE phase of an instruction. The trap flip-flop remains true until phase 7 of the XPSD instruction sequence. This allows an XPSD to be executed in the slave mode although the XPSD is a privileged instruction.

If a trap condition is detected by the CPU, the term (S/INTRAPF) is one of the terms that initiates the sequence during ENDE. (S/TRAPF) sets INTRAPI, the trap phase flipflop.

Flip-flop $B R Q$ is set if the return address of the instruction following the trap is in the Q-register. This condition exists when both ENDE and PREl are false and (S/INTRAPF) is true. BRQ insures that the address stored by the XPSD instruction points at the correct next instruction address in the program sequence after the trap is processed. The CLEAR signal is generated during ENDE time or when (S/INTRAPF) is true.

Three trap phases are interposed between the trap acknowledgment at ENDE or IEN and preparation phase 1 of the following program status doubleword instruction. These three phases are referenced in the following paragraphs as Pass 1, Pass 2, and Pass 3, where Pass $1=$ INTRAP1 NINTRAP2, Pass $2=$ INTRAP1 INTRAP2, and Pass $3=$ NINTRAP1 INTRAP2.
a. Pass 1. If the return address of the instruction aborted by the trap is in the Q-register during this period, $B R Q$ is true. If $B R Q$ is true, the contents of the $Q-$ register are clocked into the $P$-register. During the Pass 1 phasing of the trap sequence, the aborted instruction address is transferred from the P -register to the S -bus. From the S -bus, the aborted instruction address is clocked into the A-register. The D-register is cleared of ones and is filled with zeros. The CS-register is filled with ones. MAPDIS is set during this pass to prevent modification of the trap address, and the contents of the $P$-register are transferred to $Q$.

The set logic for the $D R Q$ flip-flop (S/DRQ) is true during this pass so that the DRQ flip-flop output S/DRQ is true at the next clock time. $D R Q$ is a repeater flip-flop to indicate that the next clock does not occur until the CPU receives a data release signal from memory if $M R Q$ is true. Since MRQ is true during Pass 2, $D R Q$ is also true during Pass 2. DRQ is reset on the first clock after T10L time. INTRAP2 is also set at the end of Pass 1.
$B R Q$ is reset at TIOL time by the T1OL clock. The term that generates the T 10 L clock $(\mathrm{S} / \mathrm{T} 10 \mathrm{~L} / 1)$ is always true during Pass 1. Therefore, TlOL measures the period for Pass 2.
b. Pass 2. The Pass 2 phase of the sequence clocks the trap address into the P -register. PXINT must be false at this time so that PXTR can be true. The trap address in flip-flops TR28 through TR31 is clocked into the P-register flip-flops P28 through P31. At the same time, zeros are clocked into P15 through P24, P26, P27, P32, and P33. A one is clocked into P25 to establish the most significant digit (MSD) of the trap address. The MSD in all cases is $X^{\prime} 4$ ' since trap addresses run from $X^{\prime} 40^{\prime}$ through $X^{\prime} 4 B^{\prime}$.

The P -register flip-flop configuration is then as shown in figure 3-131.

The contents of P15-P31 are put on the LM-LB lines. The memory request, $M R Q$, is generated during this pass. INTRAP1 is reset during this pass and goes false at the next clock time.


Figure 3-131. P-Register Configuration in Trap Sequence Pass 2
c. Pass 3. During Pass 3, the A-register contains the next instruction address of the aborted instruction. This is accomplished during Pass 1 by SXP and AXS. Since the next instruction address of the aborted instruction is currently in the A-register, it is necessary to decrease the contents of A by a count of one if the CPU operation is to continue after the trap sequence. This is necessary because when the aborted instruction address is returned to the $P_{-}$ register after the trap, it is increased by a count of one. Therefore, the contents of registers A, D, and CS are added together for the decrement of one. The A-register contains the aborted instruction address, the CS-register contains all ones, and the D-register contains all zeros.

The addition is performed in the adder. When the addition is completed, the sum is placed on the S-bus. From the Sbus, the daia is iransferred io the B -register for storage.

Data from the memory bus lines, MB, is loaded into the Cregister by the data release signal $D R$ at any time during INTRAP2. At the next clock, the contents of the C-register are transferred to registers $O, R$, and $D$, and PREI is set.

Table 3-19 details the logic sequence for the trap system.

3-142 TRAP ADDRESSING. Trap addressing is performed by the trap address flip-flops TR28-TR31 and by the logic term PXTR, as shown in figure 3-132. In all cases where a trap condition exists, P-register flip-flop P25 is set and represents the MSD of the trap address. The MSD is always $X^{\prime} 4^{\prime}$. The LSD of the trap address is determined by the trap address flip-flops TR28 through TR31. In figure 3-132, the memory location of the trap is shown as $\mathrm{X}^{\prime} 41$ ' which results from an unimplemented instruction. The term FANIMP (PREI NANLZ) initiates the trap in this example.

## 3-143 INSTRUCTION ANALYSIS

3-144 Data Formats
The 32-bit Sigma computer word has various data formats for the various instructions. The basic data formats are illustrated in figure 3-133. Signed negative numbers are represented in two's complement form. Decimal numbers are represented in sign-magnitude form. All fixed-point arithmetic operations are performed on integer operands.

## 3-145 Instruction Formats

The normal instruction format is illustrated in figure 3-134. A second instruction format, providing for immediate operands, is illustrated in the same figure.

3-146 Instruction Code
The seven bit operation code (opcode) field of the instruction word format provides for up to 128 instructions; however, not all of the available opcodes are used in the computer. Table 3-20 lists the available instructions, their hexadecimal opcodes for both direct and indirect addressing, and their names.

## 3-147 Opcode Families

Many opcodes have identical sequences that are performed during execution of the instruction. For logic purposes, these similar opcodes are grouped into families. Opcodes which are unique or which contain unique execution sequences are assigned function names. The opcodes and the families to which they are assigned are illustrated in figure 3-135.

## 3-148 Operation Code Decoding

Instructions are read into the $C$-register during the final phase of the previous instruction. As the CPU sequences into the first preparation state (PRE1) for the instruction in the C -register, the contents of the C -register are gated into the D-register. Bits Cl through C 7 which represent the basic operation code of the instruction are also gated into the O -register and remain in the O -register until the instruction has been completed. Bit 0 of the operation code determines if the instruction is indirectly addressed, is gated into flip-flop IA and does not go into the O register.

Bits O1, O2, and O3 are gated to form all possible combinations of the upper hexadecimal digit of the basic operation code. Since only three of the operation code bits are used, the upper hexadecimal digit can range only from 0 through 7. The lower four bits of the operation code in the O -register are gated to form all possible combinations of the lower hexadecimal digit of the operation code.

Table 3-19. Trap Sequence


Table 3-19. Trap Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| ENDE or phase noted in $S / T R-$ AP logic (Cont.) | Set TRAP <br> Set INTRAPF <br> Set INTRAPI <br> Set BRQ <br> Set flip-flop $D R Q$ under conditions specified <br> Generate CLEAR signal | S/TRAP <br> R/TRAP <br> S/INTRAPF <br> S/INTRAPI <br> $S / B R Q$ <br> S/DRQ <br> CLEAR |  | Memory protection violation. Trap to memory location $X^{\prime} 40^{\prime}$. Set CC4 <br> Unimplemented instruction. Trap to memory location X'41' <br> Push-down stack limit. Trap to memory location X'42' <br> Fixed-point overflow. Trap to memory location X'43' <br> Floating point fault. Trap to memory location $X^{\prime} 44^{\prime}$ <br> Decimal unit fault. Trap to memory location X'45' <br> Watchdog timer runout. Trap to memory location X'46' <br> Trap to memory location $X^{\prime} 48^{\prime}, X^{\prime} 49^{\prime}, X^{\prime} 4 A^{\prime}$, or $X^{\prime} 4 B^{\prime}$ <br> $B R Q$ is set if trap is to point at current instruction rather than next instruction <br> If nonexistent address or not end phase |
| $\begin{aligned} & \text { IN- } \\ & \text { TRAPI } \\ & \text { IN- } \\ & \text { TRAP2 } \end{aligned}$ | $\begin{aligned} & Q \rightarrow P \text { if } B R Q=1 \\ & P \longrightarrow S \\ & S \longrightarrow A \end{aligned}$ | $\begin{aligned} & \text { PXQ } \\ & \text { SXP } \\ & \text { AXS } \end{aligned}$ | $\begin{aligned} & =\text { BRQ } \\ & =\text { INTRAPI NSDIS } \\ & =\text { INTRAPI } \end{aligned}$ | Current instruction address <br> Next instruction address |
| (Continued) |  |  |  | Mnemonic: Trap Sequence |

Table 3-19. Trap Sequence (Cont.)


Table 3-19. Trap Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| Pass 3 <br> IN- <br> TRAP2 <br> NIN- <br> TRAPI | $\begin{aligned} & \mathrm{P} 15-\mathrm{P} 31 \longrightarrow \mathrm{Q} 15-\mathrm{Q} 31 \\ & \mathrm{MB} 0-\mathrm{MB} 31 \longrightarrow \mathrm{C} 1 \end{aligned}$ $\begin{aligned} & \mathrm{C} 0 \xrightarrow{\longrightarrow} \mathrm{IA} \\ & \mathrm{C} 1-\mathrm{C} 7 \rightarrow \mathrm{O} 1-\mathrm{O} 7 \\ & \mathrm{C} 8-\mathrm{C} 11 \rightarrow \mathrm{R} 28-\mathrm{R} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31 \end{aligned}$ <br> Set flip-flop SW2 | Note <br> The trap flip-flop remains true until phase 7 of the XPSD sequence. This allows an XPSD to be executed in slave mode although XPSD is a privileged instruction. <br> SXADD $\quad=$ INTRAP2 NINTRAPI NSDIS <br> BXS $\quad=$ INTRAP2 $+\ldots$ <br> QXP $\quad=$ INTRAP2 $+\ldots$ <br> CXMB $=\mathrm{DGC}$ <br> OXC $=$ ORXC + OXC <br> ORXC $\quad=$ NINTRAPI INTRAP2 <br> DXC $\quad=\quad$ INTRAP2 $+\ldots$ <br> S/SW2 $\quad=$ INTRAPEND $+\ldots$ <br> INTRAPEND $=$ INTRAPF NINTRAPI NPREP <br> NEXU | Decrements next instruction address of trapped instruction <br> Trap address <br> Read program status doubleword instruction from trap address <br> Instruction word $\mathrm{O}-$, R-, and D-registers |
| $\begin{aligned} & \text { IN- } \\ & \text { TRAPF } \\ & \text { SW2 } \end{aligned}$ | Reset flip-flop MAPDIS <br> Set flip-flop SWI | R/MAPDIS $=$ FAPSD NSW1 SW2 R30 <br> $S / S W 1$ $=$ INTRAPEND SW $2+\ldots$ | $\begin{aligned} & \mathrm{R} 30 \Longrightarrow \text { bit } 10 \text { of } \mathrm{XPSD} \\ & \text { instruction }=1 . \text { Speci- } \\ & \text { fies map mode } \end{aligned}$ |
| $\begin{aligned} & \text { IN- } \\ & \text { TRAPF } \\ & \text { SWI } \end{aligned}$ | Set flip-flop PREI | S/PREI $\quad=$ INTRAPEND SWI $+\ldots$ | Preparation phase of XPSD instruction |
|  |  |  | Mnemonic:Trap  <br>  Sequence |



Figure 3-132. Trap Memory Location and Addressing

## A. BYTE

| BYTE 0 | BYTE 1 | BYTE 2 | BYTE 3 |
| :---: | :---: | :---: | :---: |

B. HALFWORD

C. FIXED-POINT WORD

D. 20-BIT FIELD

E. FIXED-POINT DOUBLEWORD


Figure 3-133. Data Word Formats (Sheet 1 of 2)

## F. FLOATING POINT WORD


G. FLOATING POINT DOUBLEWORD

H. BYTE STRING

I. ZONED DECIMAL NUMBER

J. PACKED DECIMAL NUMBER

| DIGIT | DIGIT | DIGIT | DIGIT | DIGIT | DIGIT | DIGIT | DIGIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | BB |  | BB |  | BB |  |  |

NOTE: BB MUST BE A BYTE BOUNDARY. FIRST BIT AFTER BYTE BOUNDARY IS BIT 0, 8, 16, OR 24

Figure 3-133. Data Word Formats (Sheet 2 of 2)

NOTES :

| A OPERATION | R OR L | X | ADDRESS |
| :---: | :---: | :---: | :---: |

IA

OPERATION
R

L
$X \quad$ THREE-BIT FIELD THAT DESIGNATES ANY OF REGISTERS 1 THROUGH 7 OF THE

ADDRESS
INDIRECT ADDRESSING IS PERFORMED IF THIS BIT POSITION CONTAINS A ONE AND IS NOT PERFORMED IF THIS BIT POSITION CONTAINS A ZERO SEVEN-bit FIELD that designates the operation to be performed FOUR-BIT FIELD THAT DESIGNATES ANY OF THE 16 REGISTERS OF THE CURRENT REGISTER PAGE AS AN OPERAND SOURCE OR DESTINATION IN DECIMAL OPERATIONS, THIS FIELD INDICATES THE LENGTH, IN BYTES, OF THE DECIMAL OPERAND. L = 1 DESIGNATES A 1-DIGIT SIGNED DECIMAL NUMBER; $L=2$ DESIGNATES A 3-DIGIT SIGNED DECIMAL NUMBER. IN GENERAL, $L=n$ DESIGNATES A $2 n-1$ DIGIT SIGNED DECIMAL NUMBER. L --0 DESIGNATES 16 BYTES OR A 31-DIGIT SIGNED DECIMAL NUMBER CURRENT REGISTER PAGE AS AN INDEX REGISTER. $X$ - 0 DESIGNATES NO INDEXING; THEREFORE, REGISTER 0 CANNOT BE USED AS AN INDEX REGISTER

SEVENTEEN-BIT FIELD THAT CONTAINS THE INITIAL VIRTUAL ADDRESS OF THE INSTRUCTION OPERAND. THE ADDRESS FIELD ALLOWS ANY WORD, DOUBLEWORD, LEFT HALFWORD, OR LEFTMOST BYTE WITHIN A WORD IN MEMORY TO BE DIRECTLY ADDRESSED
A. NORMAL INSTRUCTION


NOTES :
0
INDIRECT ADDRESSING CANNOT BE USED WITH THIS TYPE OF INSTRUCTION. IF INDIRECT ADDRESSING IS USED, THE COMPUTER TRAPS TO LOCATION X'64' AT THE TIME OF OPERATION CODE DECODING

OPERATION SEVEN-BIT FIELD THAT DESIGNATES THE OPERATION TO BE PERFORMED BETWEEN THE IMMEDIATE OPERAND AND THE DESIGNATED REGISTER
R FOUR-BIT FIELD THAT DESIGNATES ANY OF THE 16 REGISTERS OF THE CURRENT REGISTER PAGE
VALUE IMMEDIATE OPERAND 20 BITS IN LENGTH (19 MAGNITUDE BITS PLUS SIGN BIT WITH NEGATIVE NUMBERS IN TWO'S COMPLEMENT FORM). THE SIGN BIT (BIT POSITION 12) OF THE VALUE IS EXTENDED 12 BIT POSITIONS TO THE LEFT TO PROVIDE A 32-BIT OPERAND

DISPLACEMENT A 20-BIT FIELD THAT CONTAINS A SIGNED 19-BIT QUANTITY USED AS DISPLACEMENT VALUE TO FORM AN EFFECTIVE BYTE ADDRESS IN BYTE STRING INSTRUCTIONS
B. IMMEDIATE OPERAND INSTRUCTION

Figure 3-134. Instruction Word Formats

Table 3-20. Operation Code List

| Mnemonic | Opcode* | Name |
| :---: | :---: | :---: |
| AD | 10,90 | Add Doubleword |
| $A H$ | 50, D0 | Add Halfword |
| AI | 20 | Add Immediate |
| AIO | 6E, EE | Acknowledge I/O Interrupt (privileged) |
| AND | 4B, CB | AND Word |
| ANLZ | 44, C4 | Analyze |
| AW | 30, B0 | Add Word |
| AWM | 66, E6 | Add Word to Memory |
| BAL | 6A, EA | Branch and Link |
| BCR | 68, E8 | Branch on Conditions Reset |
| BCS | 69, E9 | Branch on Conditions Set |
| BDR | 64, E4 | Branch on Decrementing Register |
| BIR | 65, E5 | Branch on Incrementing Register |
| CALI | 04, 84 | Call 1 |
| CAL2 | 05, 85 | Call 2 |
| CAL3 | 06, 86 | Call 3 |
| CAL4 | 07, 87 | Call 4 |
| CB | 71, F1 | Compare Byte |
| CBS | 60 | Compare Byte String |
| $C D$ | 11, 91 | Compare Doubleword |
| CH | 51, D1 | Compare Halfword |
| Cl | 21 | Compare Immediate |
| CLM | 19,99 | Compare with Limits in Memory |
| CLR | 39, B9 | Compare with Limits in Register |
| CS | 45, C5 | Compare Selective |
| CVA | 29, A9 | Convert by Addition |
| CVS | 28, A8 | Convert by Subtraction |
| CW | 31, B1 | Compare Word |
| DA | 79, F9 | Decimal Add (optional) |
| DC | 7D, FD | Decimal Compare (optional) |
| DD | 7A, FA | Decimal Divide (optional) |
| DH | 56, D6 | Divide Halfword |
| DL | 7E, FE | Decimal Load (optional) |
| DM | 7B, FB | Decimal Multiply (optional) |
| DS | 78, F8 | Decimal Subtract (optional) |
| DSA | 7C, FC | Decimal Shift Arithmetic (optional) |
| *First opcode specifies direct addressing; second specifies indirect addressing |  |  |

(Continued)

Table 3-20. Operation Code List (Cont.)

| Mnemonic | Opcode* | Name |
| :---: | :---: | :---: |
| DST | 7F, FF | Decimal Store (optional) |
| DW | 36, B6 | Divide Word |
| EBS | 63 | Edit Byte String (optional) |
| EOR | 48, C8 | Exclusive OR Word |
| EXU | 67, E7 | Execute |
| FAL | 1D, 9D | Floating Add Long (optional) |
| FAS | 3D, BD | Floating Add Short (optional) |
| FDL | 1E, 9E | Floating Divide Long (optional) |
| FDS | 3E, BE | Floating Divide Short (optional) |
| FML | 1F, 9F | Floating Multiply Long (optional) |
| FMS | $3 \mathrm{~F}, \mathrm{BF}$ | Floating Multiply Short (optional) |
| FSL | 1C, 9C | Floating Subtract Long (optional) |
| FSS | 3C, BC | Floating Subtract Short (optional) |
| HIO | 4F, CF | Halt I/O (privileged) |
| INT | 6 B , EB | Interpret |
| LAD | 1B, 9B | Load Absolute Doubleword |
| LAH | 5B, DB | Load Absolute Halfword |
| LAW | 3B, BB | Load Absolute Word |
| LB | 72, F2 | Load Byte |
| LCD | 1A, 9A | Load Complement Doubleword |
| LCF | 70, F0 | Load Conditions and Floating Control |
| LCFI | 02 | Load Conditions and Floating Control Immediate |
| LCH | 5A, DA | Load Complement Halfword |
| LCW | 3A, BA | Load Complement Word |
| LD | 12, 92 | Load Doubleword |
| LH | 52, D2 | Load Halfword |
| LI | 22 | Load Immediate |
| LM | 2A, AA | Load Multiple |
| LPSD | OE, 8E | Load Program Status Doubleword (privileged) |
| LRP | 2F, AF | Load Register Pointer (privileged) |
| LS | 4A, CA | Load Selective |
| LW | 32, B2 | Load Word |
| MBS | 61 | Move Byte String |
| MH | 57: D7 | Multiply Halfword |
| MI | 23 | Multiply Immediate |
| MMC | 6F, EF | Move to Memory Control (privileged) |

[^1](Continued)

Table 3-20. Operation Code List (Cont.)

| Mnemonic | Opcode* | Name |
| :---: | :---: | :---: |
| MSP | 13,93 | Modify Stack Pointer |
| MTB | 73, F3 | Modify and Test Byte |
| MTH | 53, D3 | Modify and Test Halfword |
| MTW | 33, B3 | Modify and Test Word |
| MW | 37, B7 | Multiply Word |
| OR | 49, C9 | OR Word |
| PACK | 76, F6 | Pack Decimal Digits (optional) |
| PLM | 0A, 8A | Pull Multiple |
| PLW | 08, 88 | Pull Word |
| PSM | $0 \mathrm{~B}, 8 \mathrm{~B}$ | Push Multiple |
| PSW | 09, 89 | Push Word |
| RD | 6C, EC | Read Direct (privileged) |
| S | 25, A5 | Shift |
| SD | 18, 98 | Subtract Doubleword |
| SF | 24, A4 | Shift Floating |
| SH | 58, D8 | Subtract Halfword |
| SIO | 4C, CC | Start I/O (privileged) |
| STB | 75, F5 | Store Byte |
| STCF | 74, F4 | Store Conditions and Floating Controls |
| STD | 15,95 | Store Doubleword |
| STH | 55, D5 | Store Halfword |
| STM | $2 \mathrm{~B}, \mathrm{AB}$ | Store Multiple |
| STS | 47, C7 | Store Selective |
| STW | 35, B5 | Store Word |
| SW | 38, B8 | Subtract Word |
| TBS | 41 | Translate Byte String |
| TDV | 4E, CE | Test Device (privileged) |
| TIO | 4D, CD | Test I/O (privileged) |
| TTBS | 40 | Translate and Test Byte String |
| UNPK | 77, F7 | Unpack Decimal Digits (optional) |
| WAIT | 2E, AE | Wait (privileged) |
| WD | 6D, ED | Write Direct (privileged) |
| XPSD | OF, 8F | Exchange Program Status Doubleword (privileged) |
| XW | 46, C6 | Exchange Word |

[^2]


| OUO | NO1 NO2 NO3 |
| :---: | :---: |
| OU1 | NO1 NO2 O3 |
| OU2 | NO1 O2 NO3 |
| OU3 | $\mathrm{NO} 1 \mathrm{O}_{2} \mathrm{O} 3$ |
| OU4 | O 1 NO 2 NO 3 |
| OU5 | O 1 NO 2 O 3 |
| OU6 | O1 O2 NO3 |
| OU7 | $\mathrm{O} 1 \mathrm{O}_{2} \mathrm{O} 3$ |
| OLO | NO4 NO5 NO6 NO7 |
| OLI | NO4 NO5 NO6 NO7 |
| OL2 | NO4 NO5 O6 NO7 |
| OL3 | NO4 NO5 O6 O7 |
| OL4 | NO4 O5 NO6 NO7 |
| OL5 | NO4 O5 NO6 O7 |
| OL6 | NO4 O5 O6 NO7 |
| OL7 | NO4 O5 O6 O7 |
| OL8 | O4 NO5 NO6 NO7 |
| OL9 | O4 NO5 NO6 O7 |
| OLA | O4 NO5 O6 NO7 |
| OLB | O4 NO5 O6 O7 |
| OLC | O4 O5 NO6 NO7 |
| OLD | O4 O5 NO6 07 |
| OLE | O4 O5 O6 NO7 |
| OLF | O4 O5 O6 O7 |

Certain combinations of the upper and lower hexadecimaily decoded digits of the O -register are gated to form function codes. The decoded gates are designated as FUXX, where $X X$ describes the function by its mnemonic. Only the following functions or instructions are logically represented.

```
FUAD = OUl OLO
FUANLZ = OU4 OL4
FUAWM = OU6 OL6
```

FUBAL $=$ OU6 OLA
FUCB $=$ OU7 OL1
FUCI $=$ OU2 OL1
FUCLR $=$ OU3 OL9
FUCS $=$ OU4 OL5
FUCVS $=$ FACV NO7
FUEOR $=$ OU4 OL8
FUEXU $=$ OU6 OU7
FULAD $=$ OU1 OLB
FULCD $=$ OU1 OLA
FULD $=$ OU1 OL2
FUINT $=$ OU6 OLB
FULRP $=$ OU2 OLF
FULS $=$ OU4 OLA
FUXW $=$ OU4 OL6
FUMC $=$ OU6 OLF
FUMTB $=$ OU7 OL3
FUMTH $=$ OU5 OL3
FUSTH $=O U 3 ~ O L 3 ~ O L 5 ~$

3-150 Family Code Logic

Families of instructions are made up of combinations of the function codes and O -register bits to form gates that describe instruction groups having common usage. These gates are designated as FAXX, where $X X$ describes the family group. For example, FAIM represents the family of instructions that can be executed in the immediate mode. Table 3-21 describes most families of instructions. Most families that are qualified by terms other than the function codes or O-register bits are omitted; for example, FATR $=$ FABOX NO2 NPHA.

Table 3-21. Family Code Logic

| Families of Instructions |  | Hexadecimal Opcodes | Instruction |
| :---: | :---: | :---: | :---: |
| FABC | $=$ OU6 O4 NO5 NO6 | 68/69 | $B C R, B C S$ |
| FABOX | $=$ OU6 OL3 |  | EBS |
|  | + O1 NO3 NO4 NO5 NO6 | 40/41, 60/61 | TBS, CBS, MBS |
| FABR | $=$ OU6 NO4 O5 NO6 | 64/65 | BIR, BDR |
| FACAL | $=$ OU0 NO4 O5 | $04 \longrightarrow 07$ | $\mathrm{CALI} \longrightarrow \mathrm{CAL4}$ |
| FACV | $=\mathrm{OU} 2 \mathrm{O} 4 \mathrm{NO} 5 \mathrm{NO} 6$ | 28/29 | CVA, CVS |
| FADE | $\begin{aligned} = & \text { OU7 OU4 } \\ & + \text { OU7 NO4 O5 O6 } \end{aligned}$ | $\begin{aligned} & 78 \longrightarrow 7 F \\ & 76 / 77 \end{aligned}$ |  |
| FADIV | $=$ OU5 OL6 | 56 | DH |
|  | + OU3 OL6 | 36 | DW |
| FADW | $\begin{aligned} = & \text { OUI } \\ & + \text { OUO O4 } \end{aligned}$ | $\begin{aligned} & 10 \rightarrow 1 F \\ & 08 \rightarrow 0 F \end{aligned}$ | Doubleword functions PSW, PLM, PSM, LPSD, XPSD |
| FAFL | $=\mathrm{NO} 1 \mathrm{O} 3 \mathrm{O} 4 \mathrm{O} 5$ | $\begin{aligned} & 1 C \longrightarrow 1 F \\ & 3 C \longrightarrow 3 F \end{aligned}$ | Floating point |
| FAFLD | $=$ NO1 O3 OLE | 1E/3E | Floating divide |
| FAFLM | $=$ NO1 O3 OLF | 1F/3F | Floating multiply |
| FAFRR | $=\mathrm{OU} 2 \mathrm{OL} 3$ | 23 | MI |
|  | + OU2 OL5 | 25 | S |
|  | + OUI OL5 | 15 | STD |
| FAFRR/1 | $=$ OU3 NO4 O5 O6 | 36/37 | DW, MW |
|  | + OU4 OL7 | 47 | SS |
|  | + OUI OLF | 1F | FML |
| FAILL | $\begin{aligned} = & \text { OU5 O4 O5 } \\ & + \text { NO1 O3 OL4 } \end{aligned}$ | $5 \mathrm{C} \longrightarrow 5 \mathrm{~F}$ | Illegal operations causing traps |
|  | + OU0 NO4 NO5 NO6 | 00/01 |  |
|  | + NO2 NO3 OL3 | 03/43 |  |
|  | $+\mathrm{O} 1 \mathrm{NO} 3 \mathrm{OL} 2$ | 42/62 |  |
|  | + OU5 O4 NO6 O7 | 59/5D |  |
|  | + OU5 O5 NO6 NO7 | 54/5C |  |
|  | + OUl NO4 O5 O6 | 16/17 |  |
|  | + NO1 NO3 O4 O5 O6 | 0C/0D, 2C/2D |  |
|  | $+ \text { OU2 NO4 O5 O6 }$ | 26/27 |  |
| FAIM | $=\mathrm{NO} 3 \mathrm{NO} 4 \mathrm{NO} 5$ | $\begin{aligned} & 00 \longrightarrow 03, \\ & 20 \longrightarrow 23 \end{aligned}$ | Immediate mode |
| FAIO | $=\mathrm{OU4}$ O4 O5 | $4 \mathrm{C} \longrightarrow 4 \mathrm{~F}$ | I/O |
|  | + OU6 OLE | 6E | AlO |
| FAMDSF | $\begin{aligned} = & \text { FAMUL }+ \text { FADIV }+ \text { FASH } \\ & + \text { FAFL }+ \text { SDIS } \end{aligned}$ |  |  |

Table 3-21. Family Code Logic (Cont.)

| Families of Instructions | Hexadecima! Opcodes | Instruction |
| :---: | :---: | :---: |
| FAMDSF/D $=$ FADIV + FAFLD |  |  |
| $\begin{aligned} \text { FAMUL }= & \text { OU5 OL7 } \\ & + \text { OU3 OL7 } 7 \\ & + \text { OU2 OL3 }\end{aligned}$ | 57 | MH |
|  | 37 | MW |
|  | 23 | SF |
| $\begin{aligned} \text { FANIMP }= & \text { NO1 O3 O4 O5 NFPOPTION } \\ & + \text { OU7 O4 NDEOPTION } \\ & + \text { OU7 NO4 O5 O6 NDEOPTION } \\ & + \text { FUEBS NIA NDEOPTION } \end{aligned}$ |  | Nonimplemented instructions |
| FAPRIV $=$ NO3 O4 O5 |  | Privileged instructions |
| FAPSD $=$ OU0 O4 O5 O6 | OE/OF | LPSD, XPSD |
| FARWD $=$ OU6 O4 O5 O6 | 6C/6D | RD, WD |
| FASI $=$ NO1 O3 OL9 | 19/39 | CLM, CLR |
| FAS2 $=$ OU1 OL8 | 18 | SD |
| + OUl OLI | 11 | $C D$ |
| FAS3 $=$ OU1 NO5 NO6 NO7 | 10/18 | $A D, S D$ |
| FAS6 $=$ OU4 NO4 O5 O7 | 45/47 | CS, STS |
| + OU4 OLA | 0A | PLM |
| FAS7 $=$ O2 O3 OL3 | 33/73 | MTW, MTB |
| + O1 O3 Ol3 | 53/73 | MTH, MTB |
| FAS8 $=$ OU3 OL3 | 33 |  |
| + OU6 OL6 | 66 |  |
| FAS9 = OU4 OL6 | 46 | XW |
| + OU4 O4 NO5 NO6 | 48/49 | EOR, OR |
| + OU4 O4 NO5 O7 | 49/4B | OR, AND |
| FAS10 $=$ OU3 OLB | 3B | LAW |
| OU5 OLB | 5B | LAH |
| $\text { FAS11 }=\text { NO1 O2 OLI }$ | 21/31 | CI, CW |
| + O1 O3 OLI | 51/71 | $\mathrm{CH}, \mathrm{CB}$ |
| FAS12 $=$ NO1 O2 OL0 | 20/30 |  |
| + OU3 NO5 NO6 NO7 | 30/38 | AW, SW |
| + OU5 NO5 NO6 NO7 | 50/58 | $A H, S H$ |
| FAS13 $=\mathrm{O} 1 \mathrm{O} 3 \mathrm{OL} 3$ | 53/73 | MTH, MTB |
| FAS14 $=$ OU4 OL7 | 47 | STS |
| + OUI OL5 | 15 | STD |
| FAS15 $=$ OU4 OL5 | 45 | CS |
| + OU4 OLA | 4A | LS |

(Continued)

Table 3-21. Family Code Logic (Cont.)

| Families of Instructions |  | Hexadecimal Opcodes | Instruction |
| :---: | :---: | :---: | :---: |
| FASI6 | $\begin{aligned} = & \text { OU1 O4 NO5 O6 } \\ & + \text { OU1 NO5 O6 NO7 } \end{aligned}$ | $\begin{aligned} & 1 A / 1 B \\ & 12 / 1 A \end{aligned}$ | LCD, LAD <br> LD, LCD |
| FAS17 | $\begin{aligned} = & \text { OU0 OL2 } \\ & + \text { OU7 OL0 } \end{aligned}$ |  |  |
| FAS18 | $\begin{aligned} = & \text { OU7 NO4 O5 NO6 } \\ & + \text { O2 O3 OL5 } \\ & + \text { O1 O3 OL5 } \end{aligned}$ | $\begin{aligned} & 74 / 75 \\ & 35 / 75 \\ & 55 / 75 \end{aligned}$ | STCF, STB <br> STW, STB <br> STH, STB |
| FAS19 | $=$ OUl O4 NO5 O6 | 1A/1B | LCD, LAD |
| FAS21 | $\begin{aligned} = & \text { FAS } 10 \\ & + \text { FAS23 } \end{aligned}$ |  |  |
| FAS22 | $\begin{aligned} = & \text { OU1 NO5 NO6 } \\ & + \text { NO1 O3 OL9 } \end{aligned}$ | $\begin{array}{ll} 10 / 11, & 18 / 19 \\ 19 / 39 \end{array}$ | $A D, C D, S D, C L M$ CLM, CLR |
| FAS23 | $\begin{aligned} = & \text { OU5 NO5 O6 NO7 } \\ & + \text { O1 O3 OL2 } \\ & + \text { NO1 O2 OL2 } \\ & + \text { OU3 NO5 O6 NO7 } \end{aligned}$ | $\begin{aligned} & 52 / 5 \mathrm{~A} \\ & 52 / 72 \\ & 22 / 32 \\ & 32 / 3 \mathrm{~A} \end{aligned}$ | LH, LCW <br> LH, LB <br> LI, LW <br> LW, LCW |
| FAS24 | $\begin{aligned} = & \text { OU6 OL6 } \\ & + \text { O2 O3 OL3 } \\ & + \text { O1 O3 OL3 } \end{aligned}$ | 66 <br> 33/73 <br> 53/73 | AWM MTW, MTB MTH, MTB |
| FAS26 | $=$ OU3 O4 NO5 NO6 | 3A/3B | LCW, LAW |
| FASH | $=$ OU2 NO4 O5 NO6 | 24/25 | SF, S |
| FASHFL | $=$ FASH NO7 | 24 | SF |
| FASHFX | $=$ FASH O7 | 25 | S |
| FAST/I | $\begin{aligned} = & \text { OU0 O4 NO5 } \\ & + \text { OU1 OL3 } \\ & + \text { OU2 OLA } \\ & + \text { OU2 OLB } \end{aligned}$ | $\begin{aligned} & 08 \longrightarrow 0 B \\ & 13 \\ & 2 A \\ & 2 B \end{aligned}$ | PLW, PSW, PLM, PSM MSP <br> L.M <br> STM |
| FAW | $\begin{aligned} = & \mathrm{OU} 3 \\ & +\mathrm{NO} 3 \mathrm{NO} \mathrm{O} 5 \\ & +\mathrm{O} 1 \mathrm{NO} 3 \mathrm{O} 4 \\ & +\mathrm{O} 2 \mathrm{NO} \mathrm{O} 4 \end{aligned}$ | $\begin{aligned} & 30 \rightarrow 3 \mathrm{~F} \\ & 04 \longrightarrow 07,24 \longrightarrow 27, \\ & 44 \rightarrow 47,64 \longrightarrow 67 \\ & 48 \rightarrow 4 \mathrm{~F}, 68 \rightarrow 6 \mathrm{~F} \\ & 28 \rightarrow 2 \mathrm{~F}, 68 \longrightarrow 6 \mathrm{~F} \end{aligned}$ |  |

3-151 Logic Simplification
The logic equations used in this section are a simplified form of the complete logic equations and are not representative of the actual logic mechanization. For example, the logic to set flip-flop D16 for a Load Halfword instruction may be shown as the following:

```
S/D16 = C16 DXC + CO DXCR16 + ...
DX = DXC/5
```

R/D16 = DX
C/D16 = CL-32P19
$D X C=D X C / 5$ P32
$\mathrm{DXC} / 5=\mathrm{OU} 5(\mathrm{NO} 4 \mathrm{NO} 5) \mathrm{PHI}+\ldots$

The actual logic equation to set flip-flop D16 as contained in the automated logic equations is as follows:

Line No.

| 1161320 | $\begin{aligned} \text { S/D16 }= & { }^{*}+. C 16 . D X C / 12 \\ & +. C 17 . D X C L 1-2 . N C 16 . D X N C / 12 \end{aligned}$ |
| :---: | :---: |
| 1161330 | +.DIO16.DXDIO-2 |
|  | $\begin{aligned} & \text { +.KS16.DXK-4 } \\ & \text { +.D16.KNC16.DXK-5 } \end{aligned}$ |
| 1161340 | $\begin{aligned} & +. C 0 . D X C R 16-2 \\ & +. \text { NC0 .DXNCR16-2 } \end{aligned}$ |
| 1161350 | R/D16 $=$ DX-2 |
| 1161360 | C/D16 = CL-32P19 |

The particular instruction using this equation requires bit C0 or C16 to be clocked into flip-flop D16 as determined by flip-flop P32. The above logic equation, therefore, is simplified as follows.

$$
\begin{aligned}
& \text { S/D16 }=C 16 \text { DXC/12 }+ \text { C0 DXCR16- } 2+\ldots \\
& \text { R/D16 }=\text { DX-2 } \\
& \text { C/D16 }=\text { CL-32P19 }
\end{aligned}
$$

The logic equation for term DXC/12 as contained in the automated logic equations is as follows:

Line No.
3908200 DXC/12 = I.NDXC/7.NDXCM .NDXC/D
Since signal DXC/12 is the output of an inverter, one of the input terms to the inverter must be false to make the output of the inverter true. The logic for the first term for signal $D X C / 12$ is as follows:

Line No.

$$
\begin{aligned}
3907690 \text { NDXC } / 7= & \mathrm{B} \cdot \mathrm{NDXC} / 2 \cdot \mathrm{NDXC} / 6 \\
& . \text { NDXC/4.NDXC/3 }
\end{aligned}
$$

If one of the terms in the AND gate for signal NDXC/7 is false, signal NDXC/7 is false, thereby making DXC/12 true. The logic for term NDXC/2 is as follows:

## Line No.

3907190 NDXC/2 = I *.DXC/5 .P32
The instruction being discussed uses flip-flop P32 to indicate which half of the data word is used. The logic for signal NDXC/2 contains P32 true; therefore, only term DXC/5 is required to make signal NDXC/2 low. The logic for signal DXC/5 is as follows:

Line No.
$3907401 \mathrm{DXC} / 5=\mathrm{B} *+. \mathrm{OU5}$.(.NO4 .NO5) . PH
$3907402+$.OU5 . (.NO5 .O6 .O7) .PH1

Line No.
$3907404=+. \mathrm{OU} 5 .(. \mathrm{NO} 4 . \mathrm{O} 5 . \mathrm{O} 6) . \mathrm{PH}$
The particular instruction being discussed has an opcode of 52. Therefore, signal $D X C / 5$ is true because expression OU5 (NO4 NO5) PH1 is true. With signal DXC/5 true and signal P32 true, signal NDXC/2 is low making signal NDXC/7 low. With signal NDXC/7 low, signal DXC/12 is high, thereby setting flip-flop D16 at the PHI clock if bit C 16 is a one. Eliminating the buffers and inverters contained in the actual logic mechanization, flip-flop D16 sets if bit C16 is a one, signal DXC/5 is true, and flip-flop P32 is set.

The reset term DX must also be true to reset flip-flop D16 if bit Cl 6 is not a one. The logic for term DX-2, as contained in the automated logic equations, is as follows:

Line No.
3902200 DX-2 $=1 . N D X$
The logic for term NDX is as follows:
Line No.


Term NDXC/ 2 is low. The output of the buffer is low, and signal NDX is low; therefore, signal DX-2 is high and flipflop D16 is reset, if the set input is not true. The simplified logic equation for signal DX on the reset input to flip-flop D15 is indicated as:

$$
D X=D X C / 5
$$

The complete simplified logic equation for flip-flop D16 for a Load Halfword instruction with flip-flop P32 true is as follows:

$$
\begin{aligned}
\text { S/D16 } & =\text { C16 DXC }+\ldots \\
\text { R/D16 } & =\text { DX } \\
C / D 16 & =\text { CL-32P19 } \\
\text { DXC } & =\text { DXC/5 P32 } \\
\text { DXC/5 } & =\text { OU5 (NO4 NO5) PHI }+\ldots \\
\text { DX } & =\text { DXC/5 }
\end{aligned}
$$

## 3-152 INSTRUCTION TIMING

## 3-153 Phases

All operations required for an instruction are performed during two types of phase sequences: a preparation sequence consisting of from one to four phases, PRE1 through PRE4, and an execution phase sequence consisting of from 1 to 15 phases, PHI through PHI 5 . The timing of each phase is determined by the instruction being performed and by the family to which the instruction belongs. The timing for the next phase is set at the clock of the phase sequence being performed. Figure 3-136 shows the sequence of phases and the signals that enable the progression or branching from one phase to another. The processor control panel, interrupt, and trap phases are discussed in the paragraphs on these operations.

## 3-154 Memory Request Timing

The CPU-memory interface signals are subject to time delays because of the internal delays of active circuits (cable drivers and receivers), back board wiring, distributed capacitances, loading conditions, cable length, and other factors. Typically, single direction delays in the CPU-memory interface signals can range from 50 to 80 nanoseconds. Cable length and loading characteristics contribute the major portion of interface signal delay. The interface signals that control communication between the CPU and the memory are listed in table 3-22.

The interface signal timing characteristics described in this section are typical and do not necessarily describe the actual timing of any particular Sigma 7 system because of the number of variables that can exist from one system to another. Since the operation between the CPU and the memory is asynchronous, the logic must take into account all possible worst cases. As a result, the clock enable signals are dependent upon certain prior conditions resulting from the CPU-memory signal interchange. A discussion of propagation delay may be found in XDS T-Series, Integrated Circuit Logic Modules, Description and Specifications, publication No. 645103.

Figure 3-137 describes the timing characteristics of memory port C (the CPU is always attached to memory port C) for a read-restore, a full write, and a partial write operation.

The major interface signals and the basic logic control terms with a brief description of each are listed in rable 3-23. Logic diagrams of signals AHCL and RESTM, ARQ,/MQC/, MAA through MGG, OPRQ, RQ and RQC are shown in figures 3-138 through 3-144, respectively. Instruction decoding tor some of the preparation sequence control signals is shown in table 3-24.

In addition to the delays because of cable length and other factors previously described, other types of delays must be
considered when addressing memory. These delays are the result of one or more of the following conditions:
a. The memory map is in effect
b. Crossover exists
c. An instruction is indexed
d. An instruction is indirectly addressed

Each of these conditions require some action that is not normally performed when the condition is nonexistent; therefore, time must be allowed to carry out the required action. In most cases, the extra delay time is accounted for by the memory request delay line (MRDL) in the CPU and its associated circuitry. See figure 3-140.

A delay occurs in the CPU when a memory read or write cycle has not been completed when the next clock should normally occur. This condition can occur when interleaving is either nonexistent or not in effect, or when two locations in the same memory bank are sequentially adaressed. This delay is inserted by keeping the CPU in its current phase by withholding the clock enable signal (CE) until the memory cycle (including restoration of the data) has been completed.

Because of the possible delays described above, the time required to perform an instruction can vary. Four examples of memory access timing are shown in figures 3-145 through $3-148$. These timing diagrams illustrate the functions of the several interface terms, and show the total operation time conditions that inject delays into the execution. The diagrams are presented to show the interaction of the major control terms that accomplish a successful memory access under the prescribed conditions.

If memory banks are not interleaved, or if two successive memory requests are made from the same memory bank, the second memory access is forced to wait until after the data restoration cycle of the first access has been accomplished. This noninterleaved condition requires an additional execution delay time of approximately 390 to 400 nanoseconds for each access to memory.

An indexed instruction also injects a delay into the execution time of the instruction. This delay is caused by the extra time required to fetch the index register, to add its contents to the virtual operand address, and to place the sum into the $P$-register where it is then placed onto the LB lines. (See figure 3-147.)
An indirectly addressed instruction requires two extra preparation phases to fetch the operand from the indirectly addressed word location.
When the operand address in the reference field of the instruction is $\mathrm{X}^{\prime} 0000 \mathrm{~F}$ ' or less, a crossover situation exists in which the private memory address lines (LR) receive their address from the core memory address lines (LB). See figure 3-146.


Figure 3-136. Phase Control

Table 3-22. CPU/Memory Interface Signals

| Port C | $\mathrm{M} \rightarrow \mathrm{CPU}$ | $\mathrm{CPU} \longrightarrow \mathrm{M}$ | Function |
| :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { MCOO/ } \\ \text { to } \\ \text { MC31 } \end{gathered}$ | X | $x$ | 32 data lines, two way |
| $\begin{gathered} / \mathrm{LC} 15 / \\ \text { to } \\ / \mathrm{LC} 31 / \end{gathered}$ |  | X | 17 address lines |
| MWOC/ to /MW3C/ |  | X | 4 write byte lines |
| /MR/ |  | $x$ | Memory reset |
| /ORSP/ |  | x | Override slow port |
| /ORIL/ |  | $x$ | Override interleave |
| /HOF/ |  | $x$ | Halt on fault |
| /ABOC/ |  | $x$ | Abort (change write to read) |
| /MQC/ |  | $x$ | Memory request |
| AHC/ | $x$ |  | Address here signal |
| /ARC/ | X |  | Address release signal |
| /DRC/ | $x$ |  | Data release signal |
| /PEC/ | $x$ |  | Parity error signal |
| /POKC/ | X |  | Parity OK |
| /EDRC/ | X |  | Early data release signal |
| /SRAC/ | X |  | Second request allowed signal |
| /DGC/ | $x$ |  | Data gate signal |
| - | $x$ |  | Parity OK signal |
| $\begin{aligned} & \text { MFLO/ } \\ & \text { to } \\ & \text { /MFL7/ } \end{aligned}$ | X |  | Memory fault light signals |
| /MNN/ | $x$ |  | Margins not normal |
| /MFR/ |  | $x$ | Memory fault reset |
| /ST/ | $x$ |  | Start |



Figure 3-137. Memory Timing for Port C (Typical)

Table 3-23. Memory Request Timing and Control Signals

| Signal | Definition |
| :---: | :---: |
| /ABOC/ | An interface signal sent to memory when writing into memory is denied because of memory map or memory protection lockout. This signal is generated in the buffer amplifier PROTECTD in the CPU. For detailed logic, refer to the discussions of memory map and memory protection contained in this section |
| /AHC/ | Address here - a signal generated in memory port $C$ after the memory address has been verified and accepted. This signal becomes AH in the CPU after the cable receiver (figure 3-138) |
| AHCL | Address here clock - a signal generated in the CPU to enable the clock (figure 3-139) |
| /ARC/ | Address release signal from memory port C informing the CPU that the address has been accepted, and that a memory cycle has started for the CPU. This signal becomes AR in the CPU after the cable receiver |
| ARQ | A flip-flop in the CPU which, if true, indicates that the next CL clock cannot occur until the address release signal (AR) has been received from memory if a memory request is pending (figure 3-139) |
| $\begin{aligned} & \text { (ATE } \\ & \text { NAR) } \end{aligned}$ | A signal generated in the CPU designating that the address time has elapsed but that the address release signal has not arrived from memory (figure 3-140) |
| BRQ | A memory request flip-flop in the CPU that is set true whenever an interrupt or a trap occurs |
| /DGC/ | Data gate signal from memory port C. Gates the MB (memory bus) lines into the CPU C-register |
| /DRC/ | Data release signal from memory port $C$ denoting that the data lines contain the requested memory data. Becomes signal DR in the CPU after the cable receiver |
| DRQ | A flip-flop in the CPU indicating, when true, that the next CL clock cannot occur until the data release signal (DR) has been received from memory if a memory request is pending |
| /EDRC/ | Early data release signal from memory port C. Becomes signal EDR in the CPU after the cable receiver. This signal, when true; unlatches the C-register iust before the new data from memory is placed in the C-register by signal DGC |
| / $\mathrm{HOF} /$ | A signal generated from the PCP when parity error mode switch is in HALT (KHOP). When this signal is true, the memory halts and remains busy at the end of the cycle in which a parity error has occurred |
| MAA through MGG | Buffer latches MAA, MBB, MCC, MDD, MEE, MFF, and MGG represent memory request states (see figure 3-141) |
| MAA | When signal MAA is true, no memory request is pending |
| MiBB | When signal MBB is tive, one memory request has been made, but the address release signal (AR) has not been received from memory |
| MCC | When signal MCC is true, one memory request has been made, and data release signal DR has not been received from memory |

Table 3-23. Memory Request Timing and Control Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| MDD | When signal MDD is true, a second memory request has been made before the $D R Q$ clock for the first memory request |
| MEE | When signal MEE is true, the first memory request has been completed but a second request is pending |
| MFF | When signal MFF is true, one memory request is pending but DRQ CL has not occurred |
| MGG | When signal MGG is true, the last memory request has been completed |
| /MFLO/ through /MFL7/ | Memory fault light signals from memory to PCP memory fault lights. When true, these signals indicate in which memory bank a parity error has occurred |
| /MNN/ | Margins not normal signal from the memory logic power supply. True when the memory voltages are not within specified limits |
| MR | Memory request signal generated in the CPU. Becomes interface signal MQC to memory port $C$ after cable driver (figure 3-140) |
| /MR/ | A signal generated from the PCP when the CPU reset switch is pressed (KCPURESET) |
| MRD | When true, this signal injects a pulse into the memory request delay line MRDL (figure 3-140) |
| MRDL | Memory request delay line in the CPU (figure 3-140). Delays setting of memory request signal MR depending upon such conditions as crossover, map in effect, indirect addressing, and indexing |
| MRQ | A signal generated in the CPU requesting a memory cycle with the memory address specified by the P -register |
| MRQ/1 | A signal similar to $M R Q$ with the address specified by the $Q$-register. A memory request is initiated with either $M R Q$ or $M R Q / 1(M R Q+M R Q / 1)$ |
| NPREFLL | A signal generated in the CPU that is always true except during floating long instructions |
| OPRQ | A latch set true in PRE1 by either signal PREOPRQ/1 or PREOPRQ/2, and held true during the preparation phases (figure 3-142). I dicates that an operand is required |
| /ORIL/ | A signal generated from the PCP when the INTERLEAVE SELECT switch is in DIAGNOSTIC. When this signal is true, the interleaving feature is not in effect |
| /PEC/ | Parity error signal generated in memory port $C$ when a parity error is detected during a read or partial write cycle |
| /POKC/ | Parity OK signal generated in memory port C. True when no parity error is detected during a read or partial write cycle |
| PREDO | A signal generated in the CPU that is true for doubleword instructions |

Table 3－23．Memory Request Timing and Control Signals（Cont．）

| Signal | Definition |
| :---: | :---: |
| PREFADO | A signal generated in the CPU that is true for doubleword instructions |
| PREIM | A buffered gate true for all immediate operand type of instructions（table 3－24） |
| $\begin{aligned} & \text { PREOPRQ/1 } \\ & \text { and } \\ & \text { PREOPRQ/2 } \end{aligned}$ | Buffered gates that are decoded from the C－register during preparation state PRE to set OPRQ latch（table 3－24） |
| PRERQ | A gate true for those instructions in which flip－flop $R Q$ must be set during the preparation phases PRE1，PRE2，or PRE4（table 3－24）．Indicates that the next in－ struction may be accessed early |
| RIDL | This signal，when true，denotes that a memory request is current in the memory request delay line（MRDL）（figure 3－140） |
| RIP | This signal，when true，denotes that a memory request is in progress（see figure 3－140） |
| RQ | A memory request flip－flop in the CPU normally set at the beginning of the last operand request of most instructions．If $R Q$ is true when the address release signal（AR）associated with that operand request is received，another memory re－ quest is initiated with the $Q$－register specifying the address．Since the $Q$－register contains the address of the next instruction，signal RQ true causes the next in－ struction to be fetched and placed in the C－register（see figure 3－143） |
| RQC | RQC is a buffered gate in the CPU that initiates a memory request in either preparation states PREI or PRE4 when the memory address must be specified from the contents of the C－register（see figure 3－144） |
| ／SRAC／ | Second request allowed signal generated in memory port C．Becomes signal SRA in the CPU after the cable receiver．This signal is true before the memory data has been strobed and specifies that a second memory request can be made |
| SRAF | Second memory request latch set by SRA and reset by AR or RESETM |
| ／ST／ | This signal，when true，inhibits drive currents in the memory and resets the con－ trol flip－flops．Signal ST is true when power is first applied and remains true until memory voltoges are stabilized．This signal also sets the CPU to initial conditions．When power fails，ST goes true when power falls below a preset level |

Table 3－24．Instruction Decoding for PREOPRQ／1，PREOPRQ／2，PRERQ，PREFADO，
PREDO，and PREIM

| $\begin{aligned} & - \\ & 0 \\ & 0 \\ & \alpha \\ & 0 \\ & 0 \\ & \underset{\alpha}{\alpha} \end{aligned}$ |  | $\begin{aligned} & \text { O} \\ & \text { 区 } \\ & \text { 山 } \\ & \text { ( } \end{aligned}$ | $\begin{aligned} & \mathrm{O} \\ & \stackrel{\rightharpoonup}{4} \\ & \stackrel{4}{山} \\ & \stackrel{\rightharpoonup}{\alpha} \end{aligned}$ |  | $\begin{aligned} & \sum_{u}^{\underset{\sim}{w}} \\ & \end{aligned}$ | Code | Mnemonic | Instruction |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} x \\ x \\ x \\ x \end{gathered}$ |  | $\begin{gathered} x \\ \times \\ x \end{gathered}$ | $\begin{gathered} x \\ \times \\ \times \end{gathered}$ | $\times$ | 02 <br> 10 <br> 11 <br> 12 <br> 13 | LCFI <br> AD <br> CD <br> LD <br> MSP | Load Conditions and Floating Control Immediate <br> Add Doubleword <br> Compare Doubleword <br> Load Doubleword <br> Modify Stack Pointer |

Table 3－24．Instruction Decoding for PREOPRQ／1，PREOPRQ／2，PRERQ，PREFADO， PREDO，and PREIM（Cont．）

| - 0 o 0 0 足 |  | o 区 区 区 | O 希 山 믈 | $\begin{aligned} & \text { O} \\ & \underset{\sim}{\sim} \\ & \stackrel{\sim}{\alpha} \end{aligned}$ | $\underset{\substack{\underset{\sim}{\sim}}}{\substack{\underset{\sim}{2}}}$ | Code | Mnemonic | Instruction |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\times$ |  |  | $\times$ | $\times$ |  | 18 | SD | Subtract Doubleword |
| $\times$ |  |  | $\times$ | $\times$ |  | 19 | CLM | Compare Limits in Memory |
| $\times$ |  |  | $\times$ | $\times$ |  | 1 A | LCD | Load Complement Doubleword |
| $\times$ |  |  | $\times$ | $\times$ |  | 1B | LAD | Load Absolute Doubleword |
| $\times$ |  |  |  |  |  | 1 C | FSL | Floating Subtract Long |
| $\times$ |  |  |  |  |  | 1D | FAL | Floating Add Long |
| $\times$ |  |  |  |  |  | 1E | FDL | Floating Divide Long |
| $\times$ |  |  |  |  |  | 1F | FML | Floating Multiply Long |
|  |  |  |  |  | $\times$ | 20 | AI | Add Immediate |
|  |  |  |  |  | $\times$ | 22 | LI | Load Immediate |
|  |  | $\times$ |  |  |  | 2 F | LRP | Load Register Pointer |
|  | $\times$ | $\times$ |  |  |  | 30 | AW | Add Word |
| $\times$ | x | $\times$ |  |  |  | 31 | CW | Compare Word |
| $\times$ | x | $\times$ |  |  |  | 32 | LW | Load Word |
| $\times$ |  |  |  |  |  | 33 | MTW | Modify and Test Word |
| $\times$ |  |  |  |  |  | 36 | DW | Divide Word |
| $\times$ |  |  |  |  |  | 37 | MW | Multiply Word |
| $\times$ |  | $\times$ |  |  |  | 38 | SW | Subtract Word |
| $\times$ |  | $\times$ |  |  |  | 39 | CLR | Compare with Limits in Register |
| $\times$ |  | $\times$ |  |  |  | 3 A | LCW | Load Complement Word |
| $\times$ |  | $\times$ |  |  |  | 3B | LAW | Load Absolute Word |
| $\times$ |  |  |  |  |  | $3 C$ | FSS | Floating Subtract Short |
| $\times$ |  |  |  |  |  | 3 D | FAS | Floating Add Short |
| $\times$ |  |  |  |  |  | 3 E | FDS | Floating Divide Short |
| $\times$ |  |  |  |  |  | 3F | FMS | Floating Multiply Short |
|  | x |  |  |  |  | 40 | TTBS | Translate and Test Byte String |

[^3]Table 3-24. Instruction Decoding for PREOPRQ/1, PREOPRQ/2, PRERQ, PREFADO, PREDO, and PREIM (Cont.)




Figure 3-139. Address Release Request Signal (ARQ), Logic Diagram




Figure 3-142. OPRQ Signal Gating, Simplified Logic Diagram


Figure 3-143. RQ Signal Gating, Simplified Logic Diagram


901060B. 3627

Figure 3-144. RQC Signal Gating, Simplified Logic Diagram

## 3-155 MEMORY ADDRESSING

## 3-156 Core Memory

Core memory is addressed by the address placed on the LB lines, LB15 through LB31. The LB lines receive memory addresses directly or indirectly from either the Q-register, the C -register, or the P -register. If the memory map is present and in effect (flip-flop MAP true), the eight most significant LB lines (LB15-LB22) receive their page addresses from the appropriate memory map register. Whether the LB address lines take their data from the $\mathrm{C}-, \mathrm{Q}$-, or P -registers depends on the status of the terms $\angle M X C$ and $L M X Q$. See figure 3-149.

3-157 MEMORY ADDRESSING WITHOUT MAPPING.
When the memory map option is either not present or not in effect (NMAP), the core memory address lines are affected in the following manner when $L M X Q$ is true.

$$
\text { Q15-Q22 } \rightarrow \text { LM15-LM22 } \rightarrow \text { LB15-LB22 }
$$

When the memory map option is either not present or not in effect (NMAP), the core memory address lines are affected in the following manner when LMXC is true.

$$
\begin{aligned}
& \mathrm{C} 15-\mathrm{C} 22 \rightarrow \text { LM15-LM22 } \rightarrow \text { LB15-LB22 } \\
& \mathrm{C} 23-\mathrm{C} 30 \rightarrow \text { LB23-LB30 } \\
& \text { If }(\mathrm{LMXC} \text { C0 NAG C31), } \rightarrow \text { LB31 } \\
& \text { If }(L M X C \text { AG PREDO), } \rightarrow \text { LB31 } \\
& \text { If }(L M X C \text { NPREFLL CO C31), } \longrightarrow \text { LB31 }
\end{aligned}
$$

$$
\begin{aligned}
& \text { If }(\text { LMXC NC0 PREFADO), } \longrightarrow \text { LB31 } \\
& \text { If (PRE3 NIA), } \longrightarrow \text { LB31 } \\
& \text { If }(\text { LB31 } 1), 1 \longrightarrow \text { LB31 }
\end{aligned}
$$

The low order address bit (LB31) is handled in a manner different from the high order bits (LB15-LB30). The LB31 address line represents the difference between an even numbered address and the next higher odd numbered address. For doubleword operations or for multiple word operations where successive odd even numbered locations are addressed, the flip-flop LB31/1 is toggled to provide the successive even odd numbered operand locations.

A memory request $M R Q$ is initiated, and flip-flop $A R Q$ is set inhibiting transmission of another clock until address release signal $A R$ is received. Flip-flop $R Q$ is set indicating that another memory request can be generated as soon as the operand is received with the address specified in the Qregister. Flip-flop PHI is set, and clock T4R1 is enabled which indicates the first of the execution phases of the instruction.

If the memory map option is not present, or is not in effect (NMAP), the core memory address lines are affected in the following manner when neither LMXQ nor LMXC is true (NLMXQ NLMXC):

P15-P22 $\rightarrow$ LM15-LM22 $\rightarrow$ LB15-LB22

P23-P31 $\longrightarrow$ LB23-LB31


Figure 3-145. Request from Port C During Load Word Instruction, Timing Diagram (Typical)



Figure 3-147. Load Word Instruction, Request from P-Register Followed by Request from $Q$-Register, Timing Diagram (Typical)


Figure 3-148. Store Display Operation, Timing Diagram (Typical)


Figure 3-149. LMXC and LMXQ Signals Gating, Logic Diagram

3-158 MEMORY ADDRESSING WITH MAPPING. If the memory map option (MAP) is present and in effect, the eight high order LB lines do not accept the address from the LM lines as is the case when mapping is not in effect. Instead, the eight high order LM lines address a map register, and the information (page address) located in this addressed map register is placed on the LB lines, LB15-LB22. When the map mode is in effect, the eight high order LB lines are affected in the following manner.

```
MAP15/1 MAP15/2-MAP22/1 MAP22/2 \longrightarrow
LB15-LB22
```

Mapping does not affect the manner in which the LM lines, LM15-LM22, and the LB lines, LB23-LB31, are addressed.

The fast-access map addressing registers that address each LB line, LB15-LB22, are divided in two groups for each LB line, MAPn/l and MAPn/2, where n - 15 through 22. Either one or the other can be addressed at any time; both cannot be addressed simultaneously. Since the paralleled output of an unaddressed fast-access memory is always true, MAPn/1 is true when MAPn/2 is addressed, and MAPn/2 is true when MAPn/1 is addressed. Figure 3-150 shows how LB15 receives its data from the memory map high-speed memory elements. LB16 through LB22 operate in a similar manner. Refer to the memory map detailed theory of operation in this section.

## 3-159 Private Memory

The private memory registers are addressed on lines LR23 through LR31 which go to cable drivers /LR23/ through /LR3I/ and then through cables to the private memory fastaccess registers. Address lines /LR23/ through /LR27/ receive their inputs directly from the register pointer (RP) register. These lines address one of 32 possible private memory banks. Address lines LR29 through LR31 address
one of 16 registers within the private memory bank currently selected by the register pointer.

The individual private memory registers 0 through $F$ of the current private memory bank are addressed under the following conditions:
a. Before reading the contents of the register designated by the R-field (bits 8 through 11) of the instruction word. This address is taken from the $R$-register when signal LRXR is true, and when crossover does not exist. When signal LRXR is true and signal LRXLB is false, the LR lines are addressed in the following manner.

$$
\begin{aligned}
& R P 23-R P 27 \rightarrow / L R 23 /-/ L R 27 / \\
& R 28-R 31 \longrightarrow L R 28-L R 31 \rightarrow / L R 28 /-/ L R 31 /
\end{aligned}
$$

b. Before reading the contents of one of the index registers (1 through 7) during the preparation phases of an indexed instruction, halfword, or byte addressed instructions. This address is taken from the D-register (D12 through D14). When signal LRXD is true, the LR lines are addressed in the following manner.

c. When a crossover condition exists while addressing either an operand or an instruction (NLMXC). Crossover occurs when the address on the LB lines is $X^{\prime} 0000 F^{\prime}$ or less (figure 3-151). When crossover occurs, the address on core memory address lines LB28-LB31 is transferred to private memory address lines LR28-LR31. The LR lines are addressed


901060B. 3608

Figure 3-150. Fast-Access Memory Map Output Distribution


Figure 3-151. Crossover, Logic Diagram
in the following manner, when the term (LRXLB NLMXC) is true.

$$
\begin{aligned}
& \text { RP23-RP27 } \rightarrow \text { LR23/-/LR27/ } \\
& \text { LB28-LB31 } \rightarrow \text { LR28-LR31 } \longrightarrow / \text { LR28/-/LR31/ }
\end{aligned}
$$

d. When a crossover condition exists while addressing an operand. The $L R$ lines are addressed in the following manner when signal LMXC is true and signal LRXLB is true.

$$
\begin{aligned}
& \text { RP23-RP27 } \rightarrow / L R 23 /-/ L R 27 / \\
& \text { D28-D31 } \rightarrow \text { LR28-LR31 } \rightarrow / L R 28 /-/ L R 31 /
\end{aligned}
$$

When an address for core memory is taken from the contents of the C-register, and the address causes crossover from core memory to private memory, the private memory address is
taken from the D-register which contains the same information as the C -register.

Flip-flop LR31/2 forces a one into the least significant private memory register line LR31 for doubleword and for some multioperand instructions to provide the successive odd even, even odd register addresses required for these instructions. Input logic for flip-flop LR31/2 is described under each appropriate instruction.

When PCP switches CPU-RESET-CLEAR and SYS-RESETCLEAR are pressed simultaneously, the general storage memory is cleared to zeros. During this memory clear operation, crossover cannot occur with an address less than $\mathrm{X}^{\prime} 0000 \mathrm{~F}^{\prime}$; therefore, memory locations $X^{\prime} 00000$ 'through $X^{\prime} 0000 F^{\prime}$ are cleared to zeros. The private memory registers are not affected. See figure 3-151 for the gating for CRO.

## 3-160 INSTRUCTION DESCRIPTION

## 3-161 Preparation Sequence

3-162 GENERAL PREPARATION. Nearly all instructions require the same preparation sequence. Sequence for those instructions requiring special preparation sequences is discussed in the applicable instruction description. General preparation sequences are covered in the following paragraphs.

During the last execution phase of an instruction, the next instruction address contained in the $Q$-register is gated into memory on memory address lines LB and LM (modified by MAP, if indicated). The instruction word contained in that memory address is loaded into the C-register.

From the C-register, the opcode (bits Cl through C7) is gated into bit positions 1 through 7 of the opcode register ( O -register). The R-field (bits C8 through $\mathrm{Cl1}$ ) is gated into bit positions R28 through R31 of the R-register; and, during the time when signal ENDE is true, the entire word, bits C0 through C31, of the C-register is gated into the Dregister. The address of the desired operand, bits C15 through C31, is placed in the memory address lines LM15 through LM23 and LB24 through LB31 by signal LMXC. When the clock occurs, phase flip-flop PREI is set, clock T6L is enabled, and the address contained in the P-register (program register) is increased by one count.

When the PREI clock occurs, the content of the P -register is transferred into the $Q$-register. The $Q$-register then contains the address of the next instruction. During phase PREI, signal RQC is generated for the instructions that require an operand during the preparation phase. Signal RQC generates memory request/MQC/ for data from the memory address placed on the $L B$ and $L M$ lines from the $C$-register. Registers A, B, and E are cleared; flip-flop ARQ is set which indicates that there is a memory address request that has not received response and that another clock is not be to transmitted until address-release signal AR is received from memory. Phase flip-flop PRE2 is set, and clock T4RL is enabled.

During phase PRE2, the contents of the A-, D-, and CS(carry save) registers are added, and the result is placed on the sum bus. Since the A-register was cleared during phase PRE1, and the CS-register is not used during phase PRE2, both contain all zeros. Therefore, the data transferred to the sum bus is the contents of the $D$-register. If addressrelease signal AR has been received from memory, a PRE2 clock occurs, and bits S 15 through S 31 from the sum bus (address of the operand) are gated into the $P$-register. Kegisters $A$ and $\bar{D}$ are cleared, and filip-fiop $\bar{D} \bar{Q}$ is set. This inhibits transmission of another clock until data-release signal DR is received from memory if there is a memory request out. Phase 1 (PHI) flip-flop, the first of the execution phases, is set and clock T4RL is enabled. The execution phase of the instruction begins with phase PHI.

A sequence chart of the general preparation phases is shown in table 3-25.

3-163 INDIRECT ADDRESSING. Any Sigma instruction, except immediate and byte string instructions, can be indirectly addressed. The indirect addressing operation is limited to one level and is indicated by a one in bit position zero in the instruction word. Indirect addressing does not proceed to further levels regardless of the contents of bit position zero of the word addressed by the instruction address field.

Indirect addressing is performed during the preparation phases of the instruction. In indirect addressing, the 17-bit word address field of the instruction, referenced as the program address, is used to obtain a second word from memory. The 17bit address field of the second word, referenced as the indirect program address, replaces the initial word address field and is used as the address to obtain the operand from memory. Because indirect addressing is the same for all instructions, the logical operation is being presented in the following paragraphs and will not be repeated in the individual instruction discussions.

During the execution phases of an instruction, the next instruction is read from memory and is gated into the Cregister as described under general preparation phases. If bit C0 is a one, indicating indirect addressing, indirect address flip-flop IA is set at the following clock. The program address, bits C15 through C31, is gated onto the memory address lines by signal LMXC. The preparation phase one (PREI) flip-flop is set at the clock pulse, and clock T6L is enabled.

Signal RQC is generated during phase PREI and causes a memory request with the address as specified by the $C$ register. When the PREI clock occurs, flip-flop ARQ is set. This inhibits transmission of another clock until address release signal AR is received from memory. Phase PRE2 flipflop is set, and T4RL is enabled. When address release signal AR is received from memory, clock T4RL is allowed to occur. At clock T4RL, flip-flop DRQ is set. This innibits transmission of another clock until a data release signal is received from memory. Repeater flip-flop AG is set, indicating the first pass through PRE2 for indirect addressing. Phase PRE3 is generated, and clock T4RL is enabled.

When data release signal DGC is received from memory, gating signal CXMB is generated and the $C$-register is enabled. As soon as the data is available on the $M B$ lines from memory, signal CXMB gates the data into the C register. Data release signal DR from memory enables clock PRE3 to occur. When the clock occurs, data from the Cregister is transferred into the D-register, and bits Ci 5 through C31 are loaded onto the LM and LB memory address lines by signal LMXC to obtain the operand from memory. Indirect address flip-flop IA is reset, repeater flip-flop AG is held set, phase PRE4 flip-flop is set, and clock T4RL is enabled.

Table 3-25. Preparation Sequence (No Indexing, No Indirect Addressing)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| ENDE <br> (Last <br> phase <br> of pre- <br> vious <br> in- <br> struc- <br> tion 1 | $\begin{aligned} & \mathrm{C} 1-\mathrm{C} 7 \rightarrow \mathrm{O} 1-\mathrm{O} 7 \\ & \mathrm{C} 8-\mathrm{Cl} 1 \rightarrow \mathrm{R} 28-\mathrm{R} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & \mathrm{C} 15-\mathrm{C} 31 \rightarrow \text { LM15-LB31 } \end{aligned}$ <br> Set phase PRE1 flip-flop <br> Enable clock T6L for next phase <br> Add one to address in P-register | OXC <br> ORXC <br> DXC <br> LMXC <br> S/PREI <br> T6L <br> PCTPI | $\begin{aligned} = & \text { ENDE } \\ = & \text { ENDE }+\ldots \\ = & \text { ENDE }+\ldots \\ = & \text { OXC }(\ldots)+\ldots \text { (latched) } \\ = & \text { ENDE (NHALT + FUEXU) } \\ & \text { (S/INTRAPF) }+\ldots \\ = & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \\ = & \text { ENDE }+\ldots \end{aligned}$ | Opcode $\longrightarrow$ O-register <br> R-field $\longrightarrow$ R-register <br> Program address for required operand <br> Set at clock following ENDE <br> Address of next instruction |
| PRE1 | $P \rightarrow Q$ <br> Clear A-, B-, and E-registers <br> Memory request for operand from address specified in C-register <br> Set flip-flop ARQ <br> Set Phase PRE2 flip-flop <br> Enable clock T4RL for next phase | QXP <br> NAX/1 <br> NBX/1 <br> NEX/1 <br> RQC <br> (S/ARQ) <br> S/PRE2 <br> T4RL | $\begin{aligned} = & \text { PREI NANLZ }+\ldots \\ = & \text { PRE } 1+\ldots \\ = & \text { PRE } 1 \text { NINTRAPF + } \ldots \\ = & \text { PRE } 1+\ldots \\ = & \text { PREI NINDX PREOPRQ } \\ & \text { NANLZ }+\ldots \\ = & \text { RQC }+\ldots \\ = & \text { NPREIM PREI N(S/INTRAPF) } \\ = & \text { PREP }+\ldots \end{aligned}$ | Address of next instruction <br> Generates /MQC/ for transmission to memory <br> Set at T6L. Inhibits another clock until AR received from memory |
|  | $D \longrightarrow S$ $s \rightarrow p$ <br> Reset $A$ - and $D$-registers <br> Set flip-flop DRQ <br> Set phase 1 flip-flop <br> Enable clock T4RL <br> Execution phase of instruction | SXADD <br> PXS <br> NAX/1 <br> NDX/1 <br> S/DRQ <br> S/PHI/l <br> T4RL | PRE2 NIA + . . . <br> PRE2 NIA + . . . <br> PRE2 NIA + . . . <br> PRE2 NIA + . . . <br> PRE2 NIA OPRQ N(PREDO IX + NFABRANCH) <br> NPREDO PRE2 NIA + . . . <br> PREP + . . . | Contents of A-, D-, and CS-registers added and placed on sum bus. Aand CS-registers contain zeros <br> Clear A- and D-registers <br> Set at T4RL. Inhibits another clock until data release signal received |

Signal RQC is generated during PRE4 and causes memory request/MQC/ for the data word stored in the location specified on the LB and LM memory address lines. When the clock occurs, flip-flop $A R Q$ is set to inhibit another clock until the address release signal is received. Repeater flip-flop AG is held set, indicating that a second pass through PRE2 has not yet been performed. Phase PRE2 flipflop is set, and clock T4RL is enabled.

During the second PRE2, the contents of the A-, D-, and CS- (carry save) registers are added, and the result is placed on the sum bus. The A-register was cleared during phase PRE3 and contains all zeros. The CS-register has not been set and also contains all zeros. The data transferred to the sum bus is, therefore, the contents of the D-register. If the address release signal has been received from memory, a T4RL clock is enabled, and bits S 15 through S 31 from the sum bus are gated into the P -register. The P -register then contains the address of the present operand and the Qregister contains the address of the next instruction. Registers $A$ and D are cleared, and flip-flop DRQ is set inhibiting transmission of another clock until a data release signal is received. Phase PHI flip-flop is set, the first of the execution phases for the instruction, and clock T4RL is enabled. The logic for the PRE2 sequence is described in the PRE2 discussion under the general preparation sequence.

A sequence chart of the preparation sequence when indirect addressing is specified is shown in table 3-26.

3-164 INDEXING. The three-bit X-field of a normal instruction format allows any one of the registers, 1 through 7 in private memory, to be used as an index register.
The indexing technique provides for operation on bytes, halfwords, words, and doublewords. Indexing for byte operations, halfwords, and doublewords will be discussed under the applicable instructions. Indexing for word operations (FAW) is discussed in the following paragraphs. See figure 3-152 which illustrates all possible preparation phase sequences.
As described under indirect addressing, during a previous instruction, the next instruction in the sequence is read from memory into the C-register, and the appropriate bits are gated into the O -, and R -registers. The entire word is gated into the $D$-register. If bit $C 0$ of the instruction is a one, indirect addressing is performed prior to any indexing. When the clock occurs after occurrence of signal ENDE, flip-flop PRE1 is set, and clock T6L is enabled.

During PRE1, bits D12 through D14 (X-field of the instruction) are gated onto the private memory address lines LR29 through LR31. The address contained on the LR lines selects one of seven registers in private memory for use as an index register. A one in bits $\mathrm{Cl} 2, \mathrm{Cl3}$, or Cl 4 causes signal INDX to be generated. The PRII clock gares rhe address contained in the $P$-register into the Q -register, resets registers $B$ and $E$, and clocks the word on the RR lines from private memory into the A-register. Index flip-flop IX is set by signal INDX. Phase PRE2 flip-flop is set, and clock T4RL is enabled.

During PRE2, the index data contained in the A-register, and the address contained in the D-register are added and are placed on the sum bus. Clock T4RL clocks the modified program address contained on the sum bus into the P -register. Index flip-flop IX is reset, and registers $A$ and $D$ are cleared. When the modified program address is in the P -register, the address is immediately gated onto the LM and LB lines to obtain the operand from memory. A memory request $M R Q$ is initiated, and flip-flop $A R Q$ is set which inhibits transmission of another clock until address release signal AR is received. Flip-flop RQ is set indicating that another memory request can be generated as soon as the operand is received with the address as specified in the $Q$-register. Flipflop PHI is set, and clock T4R1 is enabled which indicates the first of the execution phases of the instruction.

Table 3-27 is a sequence chart of the preparation phases when indexing is specified.

## 3-165 Load Immediate (LI 22, 62)

This instruction extends the sign bit of a 20 -bit operand 12 positions to the left, then loads the new 32-bit word into the private memory register specified by the R-field. The operand, including the sign bit contained in bit 12, occupies bit positions 12 through 31 . At the end of the instruction, the word loaded in the private memory register is tested for a positive, a negative, or a zero value. The results of this test are stored in flip-flops CC3 and CC4. A sequence chart of the Load Immediate instruction is given in table 3-28.
3-166 Load Byte (LB 72, F2)

The Load Byte instruction is used to transfer a byte from core memory into a private memory register specified by the $R$ field. Initially, the four bytes of the referenced word are transferred from core memory into the C -register. From here, the appropriate byte determined by the states of flip-flops P32 and P33 is clocked into D24-D31. At the end of the instruction, the byte is tested for a zero condition. Results of the test uie stored in flip-flop CC3. A sequence chari of the Load Byte instruction is given in table 3-29.

## 3-167 Load Halfword (LH 52, D2)

The Load Halfword instruction is used to transfer a halfword from core memory into a private memory register specified by the R-field. Initially, both halves of the word, which are specified by the reference address, are transferred from core memory into the C-register. The appropriate halfword determined by the state of flip-flop P32 is then clocked into D16-D31. The sign bit of the halfword (MBO if NP32, MB16 if P32) is extended into D0-D15. Next, the contents of the D -register are ioaded into the private memory register specified by the R-field. At the end of the instruction, the word loaded in the private memory register is tested for a positive, a negative, or a zero value. Results of this test are stored in flip-flops CC3 and CC4. A sequence chart of the Load Halfword instruction is given in table 3-30.

Table 3-26. Preparation Sequence (Indirect Addressing, No Indexing)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| ENDE <br> (Last <br> phase <br> of pre- <br> vious <br> in- <br> struc- <br> tion) | $\left\{\begin{array}{l} \mathrm{Cl}-\mathrm{C} 7 \rightarrow \mathrm{O} 1-\mathrm{O} 7 \\ \mathrm{C} 8-\mathrm{C} 11 \rightarrow \mathrm{R} 28-\mathrm{R} 31 \\ \mathrm{C} 15-\mathrm{C} 31 \longrightarrow \text { LM15-LB31 } \\ \mathrm{C} 0-\mathrm{C} 31 \rightarrow \text { D0-D31 } \end{array}\right.$ <br> Set Indirect Address flip-flop, IA Set Phase PREI flip-flop Enable clock T6L | OXC <br> ORXC <br> LMXC <br> DXC <br> S/IA <br> S/PRE 1 <br> T6L | ENDE + . . . <br> = ENDE + . . . <br> MCC OXC + . . (latched) <br> ENDE + . . <br> CO OXC + . . . <br> ENDE NHALT N(S/INTRAPF) <br> NTIL NT4L NT8L NTIOL NRESET | Opcode $\rightarrow$ O-register <br> $R$-field $\rightarrow$ R-register <br> Program address to obtain second word from memory |
| $\begin{array}{\|l} \hline \text { PREI } \\ \text { T6L } \end{array}$ | Memory request for next word from address specified in C-register <br> Set flip-flop ARQ <br> Set Phase PRE2 flip-flop <br> Enable clock T4RL | RQC <br> $S / A R Q$ <br> S/PRE2 <br> T4RL | $\begin{aligned} & \text { CO PRE } 1+\ldots \\ - & \text { RQC }+\ldots \\ = & \text { NPREIM PREI N(S/INTRAPF) } \\ & +\ldots \\ = & \text { PREP }+\ldots \end{aligned}$ | Set at T6L. Inhibits another clock until AR signal received |
| PRE2 <br> T4RL <br> AR <br> Re- <br> ceived | Set flip-flop DRQ <br> Set flip-flop AG <br> Set Phase PRE3 flip-flop Enable clock T4RL | S/DRQ <br> S/AG <br> S/PRE3 <br> T4RL | ```IA PRE2 + . . . = PRE2 IA NIX OPRQ NANLZ + . . . = PRE2 IA N(S/INTRAPF) + ... - PREP + . . .``` | After signal AR received, inhibits another clock until data received <br> Indicates first pass through phase PRE2 |
| $\begin{aligned} & \text { PRE3 } \\ & \text { T4RL } \end{aligned}$ | $\mathrm{MBO}-\mathrm{MB3} \longrightarrow \mathrm{CO}-\mathrm{C} 31$ $\mathrm{C} 0-\mathrm{C} 31 \rightarrow \text { D0-D31 }$ <br> Reset indirect address flip-flop IA <br> Set repeater flip-flop AG $\mathrm{C} 15-\mathrm{C} 31 \longrightarrow \mathrm{LM} 15-\mathrm{LB} 31$ <br> Set PRE4 flip-flop | CXMB <br> DXC <br> R/IA <br> S/AG <br> LMXC <br> S/PRE4 | $\begin{aligned} & =\text { DGC } \\ & =\text { IA PRE3 }+\ldots \\ & =\text { PRE3 }+\ldots \\ & =\text { PRE3 AG }+\ldots \\ & - \text { (PRE3 IA }+\ldots) \text { NAR } \\ & =\text { PRE3 AG N(S/INTRAPF) } \end{aligned}$ | Second memory word gated into C -register when data release signal received <br> Indicates 2nd pass through PRE2 has not been made. Program address to obtain operand from memory |

Table 3-26. Preparation Sequence (Indirect Addressing, No Indexing) (Cont.)



Figure 3-152. Preparation Sequence, Flow Diagram

Table 3-27. Preparation Sequence (Indexing, No Indirect Addressing)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| ENDE <br> (Last phase of previous in-structions) | $\begin{aligned} & \mathrm{Cl}-\mathrm{C} 7 \longrightarrow \mathrm{Ol}-\mathrm{O} 7 \\ & \mathrm{C} 8-\mathrm{C} 11 \longrightarrow \mathrm{R} 28-\mathrm{R} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \mathrm{D} 0-\mathrm{D} 31 \end{aligned}$ <br> Set flip-flop LRXD <br> Add one to.address in P -register <br> Set phase PREI flip-flop <br> Enable clock T6L for next phase | OXC <br> ORXC <br> DXC <br> (S/LRXD) <br> PCTPI <br> S/PRE 1 <br> T6L | ```ENDE + . . . ENDE + ... ENDE + . . . OXC + ... = ENDE + ... - ENDE NHALT N(S/INTRAPF) = NTIL NT4L NT8L NTIOL NRESET``` | Opcode $\longrightarrow$ O-register <br> R-field $\longrightarrow$ R-register <br> X-field onto private memory address lines for PREI |
| $\begin{aligned} & \text { PREI } \\ & \text { TKL } \end{aligned}$ | Generate index signal INDX $P \xrightarrow{ } \text { Q }$ <br> Clear B- and E-registers <br> Clear A-register $\text { RRO-RR31 } \leftrightarrows \text { A0-A31 }$ <br> Set index flip-flop IX <br> Set phase PRE2 flip-flop <br> Enable clock T4RL | INDX <br> QXP <br> NBX/I <br> NEX/1 <br> NAX/1 <br> AXRR <br> S/IX <br> S/PRE2 <br> T4RL | $\begin{aligned} = & (C 12+C 13+C 14)(C 3+C 4 \\ & +C 5) \\ = & \text { PREI NANLZ }+\ldots \\ = & \text { PREI NINTRAPF + } \ldots \\ = & \text { PRE } 1+\ldots \\ = & \text { PRE } 1+\ldots \\ = & \text { FAW INDX PRE } 1+\ldots \\ = & \text { INDX PREI } \\ = & \text { NPREIM PREI N(S/INTRAPF }) \\ = & \text { PREP + } \ldots \end{aligned}$ | Select index register <br> Address of next instruction <br> Word from selected index register read into A-register |
| $\begin{aligned} & \text { PRE2 } \\ & \text { T4RL } \end{aligned}$ | $A+D+C S \longrightarrow$ Sum bus $\mathrm{S} 15-\mathrm{S} 31 \rightarrow \mathrm{P} 15-\mathrm{P} 31$ <br> Index flip-flop reset <br> Clear $A$--, and D-register <br> P15-P31 $\longrightarrow$ LM15-LB31 <br> Generate memory request $M R Q$ <br> Set flip-flop RQ <br> Set flip-flop $A R Q$ <br> Set phase 1 flip-flop <br> Enable clock T4RL | SXADD <br> PXS <br> R/IX <br> NAX/I <br> NDX/1 <br> (NLMXC <br> NLMXQ) <br> MRQ <br> $S / R Q$ <br> S/ARQ <br> S/PHI <br> T4RL | $\begin{aligned} = & \text { PRE2 NIA }+\ldots \\ = & \text { PRE2 NIA }+\ldots \\ = & \text { PRE2 NIA }+\ldots \\ = & \text { PRE2 NIA }+\ldots \\ = & \text { PRE2 NIA }+\ldots \\ = & \text { PRE2 NIA NRIP } \\ = & \text { PRE2 NIA IX OPRQ NANLZ } \\ & +\ldots \\ = & \text { (PRE2 NIA) IX PRERQ + } \ldots \\ = & \text { PRE2 NIA IX + . . . } \\ = & \text { NPREDO PRE2 NIA } \\ = & \text { PREP + . . } \end{aligned}$ | Modified program address transferred to sum bus <br> Modified program address gated into P-register <br> New program address gated onto address lines <br> Generate memory request for operand <br> Memory address from Q-register <br> Inhibits transmission of another clock until address release signal received |

Table 3-28. Load Immediate, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (P) Next instruction address <br> (DO-D11) Value of bit 12 of the instruction word <br> (D12-D31) Value field of instruction word <br> (R) R-field |  | Sign extended 12 positions to the left |
| PHI <br> T4RL | Set flip-flop DRQ <br> Set flip-flop PH5 <br> Enable signal (S/T10L) | S/DRQ $\because$ FAS23 PHI $+\ldots$ <br> R/DRQ $\ldots$ <br> S/PH5 $=$ BRPH5 NCLEAR + . . <br> BRPH5 FAS23 PHI $+\ldots$ <br> R/PH5 $\because$ <br> $(S / T 10 L)$ $\because$ | Inhibits clock until data release signal received from memory <br> Advance to PH5 <br> Select clock T10L in PH5 |
| PH5 <br> TIOL | $\begin{aligned} & \mathrm{DO}-\mathrm{D} 31 \longrightarrow \text { ADDER } \longrightarrow \text { SO-S31 } \\ & \text { SO-S31 } \longrightarrow \text { RW0-RW31 } \\ & \text { SO-S31 } \longrightarrow \mathrm{AO}-\mathrm{A} 31 \end{aligned}$ <br> Set flip-flop TESTA <br> Enable signal ENDE <br> Set flip-flop PRE1 for next instruction |  | Sign-extended value field gated into sum bus <br> Data from sum bus gated into scratchpad memory <br> Data gated from sum bus into A-register <br> Prepare to test result after the next clock |
| Next clock | Test word in A-register and, accordingly, code condition-code flipflops CC3 and CC4: <br> If word is positive ( NA 0 ), set flipflop CC3 and reset flip-flop CC4 <br> If word is negative ( A 0 ), set flipflop CC4 and reset flip-flop CC3 <br> If word contains all zeros, reset flip-flops CC3 and CC4 |  |  |
|  |  |  | Mnemonic: LI22 |

Table 3-29. Load Byte, Phase Sequence


Table 3-29. Load Byte, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\left\|\begin{array}{l} \mathrm{PH} 5 \\ \mathrm{~T} 10 \mathrm{~L} \\ \text { (Cont.) } \end{array}\right\|$ | $\text { SO-S31 } \longrightarrow \text { RW0-RW31 }$ $\mathrm{SO}-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> Set flip-flop TESTA <br> Enable signal ENDE <br> Set flip-flop PREI for the next instruction |  | Load data from sum bus into private memory register specified by the Rfield <br> Load data from sum bus into A-register |
| Next clock | Test word in A-register and, accordingly, code condition-code flipflop CC3 <br> If word is not zero (NA0031Z), set flip-flop CC3 <br> If word is zero ( A 0031 Z ), reset flipflop CC3 | $\begin{aligned} \text { S/CC3 }= & \text { NA0 NA0031Z TESTA }(\ldots) \\ & +\ldots \\ \text { NA0031Z }= & \text { A-register does not contain } \\ & \text { all zeros } \\ \text { R/CC3 }= & \text { TESTA }+\ldots \end{aligned}$ |  |

Table 3-30. Load Halfword, Phase Sequence

\begin{tabular}{|c|c|c|c|c|}
\hline Phase \& Function Performed \& \& Signals Involved \& Comments \\
\hline PREP \& \begin{tabular}{l}
At the end of PREP: \\
(O) Opcode \\
(Q) Next instruction address \\
(R) R-field \\
(P) Effective word address \\
(P32) Halfword select bit
\end{tabular} \& \& \& \\
\hline \begin{tabular}{l}
PHI \\
T4RL
\end{tabular} \& \begin{tabular}{l}
\[
\begin{aligned}
\& \text { Q15-Q31 P15-P31 } \\
\& \text { MB0-MB31 } \rightarrow \text { C0-C31 } \\
\& \text { If NP32 } \\
\& \text { C0-C15 } \longrightarrow \text { D16-D31 } \\
\& \text { MB0 } \rightarrow \text { D0-D11 } \\
\& \text { MB0 } \not \text { D12-D15 } \\
\& \text { If P32 } \\
\& \text { C16-C31 } \rightarrow \text { D16-D31 } \\
\& \text { MB16 } \rightarrow \text { D0-D11 } \\
\& \text { MB16 } \rightarrow \text { D12-D15 }
\end{aligned}
\] \\
Set flip-flop DRQ \\
Set flip-flop PH5 \\
Enable signal (S/T10L)
\end{tabular} \& PXQ
CXMB

DXCR16
DXC/5
C0C16C12
C0C16
DXC/2
COC16C12
$C 0 C 16$
S/DRQ
$R / D R Q$
S/PH5
BRPH5
R/PH5

$(S / T 10 L)$ \&  \& | Load next instruction address into the P -register |
| :--- |
| Operand gated into the C-register from memory bus when data gate signal received from memory |
| Load most significant half of operand word into the D-register |
| Extend sign bit of most significant halfword in the $D$-register |
| Load least significant half of operand word into the D-register |
| Extend sign bit of least significant half of operand word into the D-register |
| Inhibits clock until data release signal received from memory |
| Advance to PH5 |
| Select clock in PH5 | <br>

\hline $$
\begin{aligned}
& \text { PH5 } \\
& \text { T10L }
\end{aligned}
$$ \& \[

$$
\begin{aligned}
& \text { DO-D31 } \longrightarrow \text { ADDER } \longrightarrow \text { SO-S31 } \\
& \text { SO-S31 } \longrightarrow \text { RWO-RW31 }
\end{aligned}
$$

\] \& | SXADD |
| :--- |
| RWXS/0 - |
| RWXS/ $/ 3$ |
| RW | \& \[

$$
\begin{aligned}
& =\text { FAS21 PH5 }+\ldots \\
& =\text { RW } \\
& =\text { FAS21 PH5 }+\ldots
\end{aligned}
$$

\] \& | Data from D-register gated onto sum bus |
| :--- |
| Load data from sum bus into private memory register specified by the $R$ field | <br>

\hline \multicolumn{4}{|c|}{(Continued)} \& Mnemonic: LH (52, D2) <br>
\hline
\end{tabular}

Table 3-30. Load Halfword, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH5 <br> T10L <br> (Cont. | $\mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> Set flip-flop TESTA <br> Enable signal ENDE <br> Set flip-flop PREI for the next instruction | AXS <br> S/TESTA <br> R/TESTA <br> ENDE <br> S/PRE 1 <br> R/PRE 1 | $\begin{aligned} = & \text { FAS21 PH5 }+\ldots \\ = & \text { FAS21 PH5 }+\ldots \\ = & \ldots \\ = & \text { FAS21 PH5 + } \ldots \\ = & \text { ENDE } N(S / \text { INTRAPF }) \\ & (\text { NHALT }+ \text { FUEXU }+\ldots \end{aligned}$ | Load data from sum bus into A-register |
| Next clock | Test word in A-register and, accordingly, code condition-code flipflops CC3 and CC4 <br> If word is positive (NA0), set flipflop CC3 and reset flip-flop CC4 <br> If word is negative (A0), set flipflop CC4 and reset flip-flop CC3 <br> If word contains all zeros, reset flip-flops CC3 and CC4 | $\begin{aligned} & \text { S/CC3 } \\ & \text { NA0031Z } \\ & R / C C 3 \\ & S / C C 4 \\ & R / C C 4 \end{aligned}$ | NAO NA003IZ TESTA (. . .) + . . <br> A-register does not contain all zeros <br> $=$ TESTA $+\ldots$ <br> - A0 TESTA NTESTA/1 + . . <br> :- TESTA + . . |  |
|  |  |  |  | Mnemonic: LH (52, 02$)$ |

## 3-168 Load Word (LW 32, B2)

The Load Word instruction is used to read a word from a referenced core memory address, and to load this word into a private memory register specified by the R-field. At the end of the instruction, the word is tested for a positive, a negative, or a zero value. Results of this test are stored in flip-flops CC3 and CC4. A sequence chart of the Load Word instruction is given in table 3-31.

## 3-169 Load Doubleword (LD 12, 92)

The Load Doubleword instruction is used to transfer two words from consecutive locations in core memory into two consecutive private memory registers specified by the Rfield. The low order word is loaded first, followed by the high order word. The sequence of word transfer is from core memory via the C -register to the D -register, then via the sum bus to the private memory register. A sequence chart of the Load Doubleword instruction is given in table 3-32.

## 3-170 Load Complement Halfword (LCH 5A, DA)

The Load Complement Halfword instruction is used to transfer the two's complement of a halfword from core memory into a private memory register specified by the R-field. Initially, both halves of the word, specified by the reference address, are transferred from core memory into the C-register. The one's complement of the appropriate halfword determined by the state of flip-flop P32 is clocked into D16D31. The complement of the sign bit of the appropriate halfword (NMB0 if NP32, NMB16 if P32) is extended into D0-D15. Next, a one is added to the contents of the Dregister in the adder, and the new sum placed on the sum bus. The two's complement formed from the appropriate halfword is loaded into the private memory register. At the end of the instruction, the new word (a complemented halfword with extended sign) is tested for a positive, a negative, or a zero value. Results of this test are stored in flip-flops CC3 and CC4.

Table 3-33 is a sequence chart of the Load Complement Halfword instruction.

## 3-171 Load Absolute Halfword (LAH 5B, DB)

During the Load Absolute Halfword instruction, a halfword is read from core memory. The sign bit is extended, and the new 32-bit word is tested. If it is positive, the new word is loaded into a private memory register specified by the R-field. If it is negative, the two's complement of the new word is loaded into the specified private memory register. Initially, both halves of the word specified by the reference address are transferifed from core memory into the C-register. The halfword specified by P32 is clocked into D16-D31, and its sign is extended into DO-D15. Next, depending on whether the new word is positive or negative, the CSregister is either reset or set in preparation for the adder operation. The adder places on the sum bus either the two's complement of the contents of the D-register (CS-register
set) or the contents of the D-register unaltered (CS-register reset). From the sum bus, the result is loaded into the private memory register specified by the R-field. At the end of the instruction, the word that is loaded in the private memory register is tested for zero. The result is stored in flip-flop CC3.

A sequence chart of the Load Absolute Halfword instruction is given in table 3-34.

## 3-172 Load Complement Word (LCW 3A, BA)

The Load Complement Word instruction is used to transfer the two's complement of a word from core memory into a private memory register specified by the R-field. First, the word obtained from a reference address in core memory is transferred to the C-register. The one's complement of the word is then clocked into the D-register. A one is added to the contents of the D-register in the adder, and the new sum placed on the sum bus. The two's complement formed is loaded into the private memory register, and the complemented word is first tested for overflow at the end of the instruction. Flip-flop CC2 is set, if overflow occurs and the trap mask is present. Next, the complemented word is tested for a positive, a negative, or a zero value. Results of the second test are stored in flip-flops CC3 and CC4.

A sequence chart of the Load Complement Word instruction is given in table 3-35.

## 3-173 Load Absolute Word (LAW 3B, BB)

During the Load Absolute Word instruction, a word is read from a reference address in core memory, and is tested. If it is positive, the word is loaded into a private memory register specified by the R-field. If it is negative, the word is first two's complemented and then is loaded into the specified private memory register. Initially, the word is read from the referenced core memory location and is clocked, via the C-register, into the D-register. Then, depending on the value of the sign bit D0, all flip-flops of the CSregister are either set (negative sign) or reset (positive sign). In addition, if D0 is true, the term K31 is also driven true. During the next operation, the contents of the D-register are either two's complemented (CS-register set) in the adder or are maintained in their original form (CS-register reset) and are placed on the sum bus. The absolute value of the original word is loaded into the private memory register. At the end of the instruction, the word now contained in the private memory register is tested for overflow. Flip-flop CC2 is set if overflow occurs and the trap mask is present. Next, the word is tested for a zero value. Results of this test are stored in flip-flop CC3.
A sequence chart of the Load Absolute Word instruction is given in table 3-36.

## 3-174 Load Complement Doubleword (LCD 1A, 9A)

During the Load Complement Doubleword instruction, two words are read from consecutive locations in core memory.

Table 3-31. Load Word, Phase Sequence


Table 3-31. Load Word, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| Next clock (Cont.) | If word is positive (NA0), set flipflop CC3 and reset flip-flop CC4 <br> If word is negative (A0), set flipflop CC4 and reset flip-flop CC3 <br> If word contains all zeros, reset flip-flops CC3 and CC4 |  |  |

Mnemonic: LW (32, B2,

Table 3-32. Load Doubleword, Phase Sequence

\begin{tabular}{|c|c|c|c|c|}
\hline Phase \& Function Performed \& \& Signals Involved \& Comments \\
\hline PREP \& \begin{tabular}{l}
At the end of PREP: \\
(O) Opcode \\
(Q) Next instruction address \\
(R) R-field \\
(P) Effective doubleword address \\
(LB31) Logical one \\
Two memory requests pending, one for each word of the doubleword
\end{tabular} \& \& \& Selects 32 low order bits of doubleword to be loaded \\
\hline \[
\begin{array}{|l|}
\mathrm{PHI} \\
\mathrm{~T} 4 \mathrm{RL}
\end{array}
\] \& \begin{tabular}{l}
MBO-MB3I \(\longrightarrow\) C0-C31
C0-C31 \(\longrightarrow\) D0-D31
Enable signal \((S / L R 31 / 2)\) \\
Set flip-flop RQ \\
Set flip-flop DRQ \\
Enable signal (S/T8L) \\
Set flip-flop PH3
\end{tabular} \& CXMB
DXC/6
(S/LR31/2)

S/RQ
R/RQ
$S / D R Q$
PREDO
R/DRQ
(S/T8L)
FULD
$S / P H 3$
$B R P H 3$

$R / P H 3$ \& | DG |
| :--- |
| NO1 O3 NO4 NO5 NO7 PHI + . . |
| OUI NO5 NO7 PHI + .. |
| OUl NO5 NO7 PHI +.. |
| CLEAR + DRQ |
| PREDO PHI +... |
| OUl NO5 NO7 + . . . |
| FULD PHI + . . . |
| OUI OL2 + . . . |
| BRPH3 NCLEAR + . . . |
| FULD PHI + . . | \& | Low order word gated into the C-register from memory bus when data gate signal received from memory |
| :--- |
| Clock low order word into the D-register |
| Force a one into address line LR31 for selection of lodd numbered fast memory register |
| Generate memory request for next instruction |
| Inhibits clock until data release signal received from memory |
| Select clock in PH3 |
| Advance to PH 3 | <br>

\hline $$
\begin{aligned}
& \mathrm{PH} 3 \\
& \mathrm{TBL}
\end{aligned}
$$ \& \[

$$
\begin{aligned}
& \text { Q15-Q31 } \rightarrow \text { P15-P3! } \\
& \text { D0-D31 } \longrightarrow \text { S0-S31 } \\
& \text { S0-S31 } \longrightarrow \text { RW0-RW31 }[R+1]
\end{aligned}
$$

\] \& | PXQ |
| :--- |
| PREDO SXD |
| FULD |
| RWXS/0RWXS/3 |
| RW | \& | PREDO PH3 + . . . |
| :--- |
| OUl NO5 NO7 + . |
| FULD PH3 + . . . |
| OUl OL2 + ... |
| RW |
| FULD PH3 + . . . | \& | Load next instruction address into the P -register |
| :--- |
| Place low order word onto the sum bus |
| Load low order word in odd numbered private memory register | <br>

\hline \multicolumn{4}{|c|}{(Continued)} \& Mnemonic: LD (12, 92) <br>
\hline
\end{tabular}

Table 3-32. Load Doubleword, Phase Sequence (Cont.)


Table 3-32. Load Doubleword, Phase Sequence (Cont.)


Table 3-33. Load Complement Halfword, Phase Sequence


Table 3-33. Load Complement Halfword, Phase Sequence (Cont.)


XDS 901060

Table 3-34. Load Absolute Halfword, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (Q) Next instruction address <br> (R) $R$-field <br> (P) Effective word address <br> (P32) Halfword select bit <br> (A) All zeros |  |  |  |
| $\begin{aligned} & \mathrm{PHI} \\ & \mathrm{~T} 4 \mathrm{RL} \end{aligned}$ |  | PXQ CXMB DXCR16 DXC/5 $C 0 C 16 C 12$ $C 0 C 16$ $D X C / 2$ $C 0 C 16 C 12$ $C 0 C 16$ $(S / T 4 L)$ |  | Load next instruction address into the P -register <br> Operand gated into the C-register from memory bus when data gate signal received from memory <br> Load most significant half of operand word into the D-register <br> Extend sign bit of most significant halfword in the D-register <br> Load least significant half of operand word into the D-register <br> Extend sign bit of least significant halfword in the D-register <br> Select clock in PH2 |
| $\begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 4 \mathrm{~L} \end{aligned}$ | If data word is negative (D0) <br> Enable signal ( $\mathrm{S} / \mathrm{NGX}$ ) <br> Force ones into the CS-register <br> Set flip-flop $D R Q$ <br> Set flip-flop PH5 <br> Enable signal ( $\mathrm{S} / \mathrm{T} 10 \mathrm{~L}$ ) | (S/NGX) CSX/9, CSX/10 S/DRQ R/DRQ S/PH5 BRPH5 R/PH5 (S/TIOL) | $\begin{aligned} - & \text { FAS10 PH2 D0 + . . } \\ & (S / \text { NGX })+\ldots \\ = & \text { FAS10 PH2 }+\ldots \\ & \ldots \\ = & \text { BRPH5 NCLEAR }+\ldots \\ - & \text { FAS10 PH2 }+\ldots \\ = & \ldots \\ = & \text { FASIO PH2 }+\ldots \end{aligned}$ | Prepare to place two's complement of word stored in D-register onto the sum bus during PH5 <br> Inhibits clock until data release signal received from memory <br> Advance to PH5 |
| (Continued) |  |  |  | Mnemonic: LAH (5B, DB) |

Table 3-34. Load Absolute Halfword, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{aligned} & \text { PH5 } \\ & \mathrm{TIOL} \end{aligned}\right.$ | If word stored in D-register is negative (NGX) <br> Enable signal K31 <br> If word stored in D-register is positive <br> SO-S31 $\longrightarrow$ RWO-RW31 <br> $\mathrm{SO}-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> Set flip-flop TESTA <br> Enable signal ENDE <br> Set flip-flop PREI for the next instruction | K31 <br> SXPR/10-13 <br> SXADD <br> SXPR/10-13 <br> SXADD <br> RWXS/0- <br> RWXS/3 <br> RW <br> AXS <br> S/TESTA <br> R/TESTA <br> ENDE <br> S/PRE 1 <br> R/PRE 1 | $\begin{aligned} & =\text { NGX }+\ldots \\ & =\text { SXADD }+\ldots \\ & =\text { FAS2 } 1 \text { PH } 5+\ldots \end{aligned}$ $\begin{aligned} & \text { SXADD }+\ldots \\ = & \text { FAS21 PH5 }+\ldots \end{aligned}$ <br> : RW <br> - FAS21 PH5 + ... <br> - FAS21 PH5 + . . <br> - FAS21 PH5 + ... <br> - FAS21 PH5 + ... <br> ENDE N(S/INTRAPF) <br> (NHALT + FUEXU) + . . . | Used for changing one's complement number to two's complement <br> Place two's complement of word stored in the Dregister onto the sum bus <br> Place word contained in D-register onto the sum bus <br> Load data from sum bus into private memory register specified by R-field <br> Load data from sum bus into A-register |
| $\mathrm{Ne} \times \dagger$ clock | Test word in A-register and code condition-code flip-flop CC3 <br> If word is not zero, set flip-flop CC3. <br> If word is zero, reset flip-flop CC3 | $\begin{aligned} & \text { S/CC3 } \\ & \text { NA0031Z } \\ & \text { R/CC3 } \end{aligned}$ | NA0 NA003IZ TESTA $(. . .)+\ldots$ <br> $=$ A-register does not contain all zeros <br> TESTA , |  |
|  |  |  |  | Mnemonic: LAH (5B, DB) |

Table 3-35. Load Complement Word, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (Q) Next instruction address <br> (R) R-field <br> (P) Effective word address |  |  |  |
| $\begin{array}{\|l} \mathrm{PHI} \\ \mathrm{~T} 4 \mathrm{RL} \end{array}$ | $\begin{aligned} & \text { Q15-Q31 } \longrightarrow \text { P15-P31 } \\ & \text { MB0-MB31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ & \mathrm{NCO}-\mathrm{NC} 31 \longrightarrow \mathrm{DO}-\mathrm{D} 31 \end{aligned}$ <br> Set flip-flop CS31 <br> Set flip-flop DRQ <br> Set flip-flop PH5 <br> Enable signal ( $\mathrm{S} / \mathrm{T} 10 \mathrm{~L}$ ) | PXQ CXMB DXNC/1 S/CS31 CSXI/31 $R / C S 31$ $S / D R Q$ $R / D R Q$ $S / P H 5$ $B R P H 5$ $R / P H 5$ (S/TIOL) | $\begin{aligned} = & \text { PRERQ PHI }+\ldots \\ = & \text { DG } \\ = & \mathrm{NO} 1 \mathrm{O} 3 \mathrm{O} 4 \mathrm{NO} 5 \mathrm{NO} 7 \\ & \mathrm{PHI}+\ldots \\ = & \mathrm{CSXI} / 31 \\ = & \mathrm{DXNC} / 1+\ldots \\ = & (\text { R/CS3I }) \\ = & \text { FAS23 PHI }+\ldots \\ = & \ldots \\ = & \text { BRPH5 NCLEAR }+\ldots \\ = & \text { FAS23 PHI }+\ldots \\ = & \ldots \\ = & \text { FAS23 PHI }+\ldots \end{aligned}$ | Load next instruction address into the P -register <br> Operand gated into the C-register from memory bus when data gate signal received from memory <br> Load one's complement of data in C-register into the $D$-register <br> Force a one into CS31 in preparation for two's complementing of data in PH5 <br> Inhibits clock until data release signal received from memory <br> Advance to PH5 <br> Select clock in PH5 |
| $\begin{aligned} & \mathrm{PH5} \\ & \mathrm{~T} 10 \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \text { D0-D31 + CS3! } \longrightarrow \text { ADDER } \rightarrow \text { SO-S31 } \\ & \text { SO-S31 } \longrightarrow \text { RW0-RW31 } \\ & \text { SO-S31 } \longrightarrow \text { A0-A31 } \\ & \text { Set flip-flop TESTA } \\ & \text { Enable signal ENDE } \\ & \text { Set flip-flop PREI for the next } \\ & \text { instruction } \end{aligned}$ | SXADD <br> RWXS/0- <br> RWXS/3 <br> RW <br> AXS <br> S/TESTA <br> R/TESTA <br> ENDE <br> S/PRE I <br> R/PRE 1 | $\begin{aligned} & =\text { FAS21 PH5 }+\ldots \\ & =\text { RW } \\ & =\text { FAS21 PH5 }+\ldots \\ & =\text { FAS21 PH5 }+\ldots \\ & =\text { FAS21 PH5 + . . } \\ & =\ldots \\ & =\text { FAS21 PH5 + . . } \\ & =\text { ENDE N(S/INTRAPF) } \\ & =(\text { NHALT }+ \text { FUEXU }+\ldots \\ & =\ldots \end{aligned}$ | Gate two's complement of data onto the sum bus <br> Load data from sum bus into private memory register specified by the Rfield <br> Load data from sum bus into A-register |
| (Continued) |  |  |  | Mnemonic: LCW (3A, BA) |

Table 3-35. Load Complement Word, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH5 <br> T10L <br> (Cont.) | If overflow, set condition-code flipflop CC2 <br> If overflow and bit 11 of the PSW is a one (trap mask), enable signal TROVER | $\begin{aligned} & \text { S/CC2 } \\ & \text { OVER } \\ & \text { PROBEOVER } \\ & \text { R/CC2 } \\ & \\ & \text { TROVER } \\ & \text { AM } \end{aligned}$ | OVER PROBEOVER + . . . <br> DO NKO NPRO NFASIO + . . <br> FAS26 PH5 + . . . <br> - PROBEOVER + . . . <br> OVER AM PROBEOVER + . . . <br> Function of b:t 11 of the PSW | During an LCW instruction fixed-point overflow occurs if the original data word in the C-register was $X^{\prime} 80000000{ }^{\prime}$, since the two's complement of this number is also $X^{\prime} 30000000^{\prime}$ <br> Trap to location X'43' |
| Test <br> clock | Test word in A-register and code condition-code flip-flops CC3 and CC4 <br> If word is positive, set flip-flop CC3 and reset flip-flop CC4 <br> If word is negative, set flip-flop CC4 and reset flip-flop CC3 <br> If word is zero, reset flip-flops CC3 and CC4 | S/CC3 NAO NA003IZ TESTA <br>  $(\ldots)+\ldots$ <br> NA0031Z $\quad \because$ A-register does not contain <br> all zeros  <br> R/CC3 $\because$ TESTA $+\ldots$ <br> S/CC4 $=$ A0 TESTA NTESTA $/ 1+\ldots$ <br> R/CC4 $=$ TESTA $+\ldots$ |  |  |
|  |  |  |  | Mnemonic: LCW (3A, BA) |

Table 3-36. Load Absolute Word, Phase Sequence

| P.hase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (Q) Next instruction address <br> (R) $\quad$-field <br> (P) Effective word address <br> (A) All zeros |  |  |  |
| PHI <br> T4RL | $\begin{aligned} & \text { Q15-Q31 } \rightarrow P 15-P 31 \\ & \text { MB0-MB31 } \longrightarrow \text { C0-C31 } \\ & C 0-C 31 \longrightarrow D 0-D 31 \end{aligned}$ <br> Set flip-flop PH2 <br> Enable signal ( $\mathrm{S} / \mathrm{T} 4 \mathrm{~L} / 2$ ) | PXQ <br> CXMB <br> DXC/6 <br> S/PH2 <br> R/PH2 <br> (S/T4L/2) | $\begin{aligned} = & \text { PRERQ PHI }+\ldots \\ = & \text { DG } \\ = & \text { NOI O3 OLB PHI }+. \\ = & \text { PHI NBR N(FNANLZ) } \\ & \text { NANLZ) }+\ldots \\ = & \ldots \\ = & \text { FASIO PHI }+\ldots . \end{aligned}$ | Load next instruction address into the P -register <br> Operand gated into the C-register from memory bus when data gate signal received from memory <br> Operand clocked into the D-register <br> Advance to PH2 <br> Select clock T4L in PH2 |
| $\begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 4 \mathrm{~L} \end{aligned}$ | If data word is negative (D0) Enable signal (S/NGX) <br> Set flip-flop DRQ <br> Set flip-flop PH5 <br> Enable signal (S/T10L) | (S/NGX) <br> CSX1/9, <br> CSXI/10 <br> S/DRQ <br> R/DRQ <br> S/PH5 <br> BRPH5 <br> R/PH5 <br> (S/T10L) | $\begin{aligned} & =\text { FASIO DO PH2 }+\ldots \\ & =(S / N G X)+\ldots \\ & =\text { FAS10 PH2 }+\ldots \\ & =\ldots \\ & =\text { BRPH5 NCLEAR }+\ldots \\ & =\text { FASIO PH2 }+\ldots \\ & =\ldots \\ & =\text { FASIO PH2 }+\ldots \end{aligned}$ | Prepare to place two's complement of word stored in D-register onto the sum bus during PH5 <br> Inhibits clock until data release signal received from memory <br> Advance to PH5 <br> Select clock in PH5 |
| $\begin{array}{\|l\|l} \text { PH5 } \\ \text { T10L } \end{array}$ | If word stored in D-register is negative (NGX) <br> Enable signal K31 | K31 <br> SXPR/10- <br> SXPR/ 13 <br> SXADD | $\begin{aligned} & =\text { NGX + ... } \\ & - \text { SXADD + .. } \\ & =\text { FAS21 PH5 }+. \end{aligned}$ | Used for changing one's complement number to two's complement <br> Place two's complement of word contained in the D-register onto the sum bus |
| (Continued) |  |  |  | Mnemonic: LAW (3B, BB) |

Table 3-36. Load Absolute Word, Phase Sequence (Cont.)


Table 3-36. Load Absolute Word, Phase Sequence (Cont.)


The two words are taken together as a 64-bit unit and two's complemented. The complemented doubleword is loaded into two consecutive private memory registers specified by the R-field. The 32 low order bits occupy the odd private memory location. If the address specified by the R-field is odd, only the 32 high order bits of the doubleword are stored.

The low order word is read from core memory into the Cregister. The contents of the C-register is one's complemented and is clocked into the D-register. In the adder, one is added to the contents of the D-register. The two's complement of the low order word formed is loaded via the sum bus into the odd private memory register specified by the R-field. The complemented low order word is also tested for zero and for end carry conditions, and the results are stored in flip-flops BWZ and CS3I, respectively.

The high order word is then read from core memory into the C-register. Again the one's complement of the C-register is clocked into the D-register and is placed in the adder. Bit CS31, if true, is added to the contents of the D-registers. The entire sum is placed on the sum bus and is loaded into the even numbered private memory register. In addition, this new high order word is clocked into the A-register, and bit A31 is merged with the contents of flip-flop BWZ. This information is used for zero-testing the complemented doubleword. At the end of the instruction the complemented doubleword is tested for overflow. Flip-flop CC2 is set, if overflow occurs and the trap mask is present. The complemented doubleword is tested for positive, negative, and zero conditions. Results of this test are stored in flip-flops CC3 and CC4.
A sequence chart of the Load Complement Doubleword instruction is given in table 3-37.

## 3-175 Load Absolute Doubleword (LAD 1B, 9B)

The Load Absolute Doubleword instruction is used to transfer the absolute value of a doubleword from two consecutive word locations in core memory to two consecutive fast memory registers specified by the R-field. Initially, the low order word is read from core memory and is gated, via the C-register, into the D-register. The two's complement of the low order word is clocked via the adder and sum bus into the A-register, while the D-register retains the original low order word. If end carry is detected in the two's complement of the low order word, it is stored in flip-flop K 00 H (reset condition). The high order word is read from core memory into the C-register, and is tested for a positive or a negative value. If it is positive, the low order word is transferred from the $D$-register into the odd private memory register. If it is negative, the two's complement of the low order word is transferred from the A-register into the odd private memory register. Also, if the value is positive, the high order word is clocked into the D-register; if negative, the one's complement of the high order word is gated into the D-register. The two's complement of the low order word is also tested for zero conditions, and the result is stored in flip-flop BWZ (reset condition).

In the adder, the contents of the D-register is combined with the end carry, if any, and the new sum is loaded via the sum bus into the even numbered fast memory register. The absolute value of the doubleword is tested for overflow condition. If overflow occurs and the trap mask is present, it is stored in flip-flop CC2. Next, the absolute value of the doubleword is tested for a positive, a negative, and a zero condition. Results of this test are stored in flip-flops CC3 and CC4.

A sequence chart of the Load Absolute Doubleword instruction is given in table 3-38.

## 3-176 Load Selective (LS 4A, CA)

The LS instruction causes storing of selected bits from the word contained in the effective memory location, as determined by a 32-bit mask in private memory, into the private memory register addressed in the $R$-field of the instruction word.

If the private memory register addressed in the R-field is an even numbered register, the 32-bit mask contained in the odd numbered private memory register is compared with the data word from core memory. Wherever a one is contained in the mask, the corresponding bit of the core memory data word is stored in the even numbered private memory register. Wherever a zero exists in the mask, the corresponding bit in the private memory register is left unchanged.

If the private memory register addressed in the R-field is an odd numbered register (the same register containing the mask), a logical AND operation is performed with the mask and the data word from core memory. The result is stored in the odd numbered private memory register.
The core memory operand is loaded into the D-register, and, at the same time, the contents of the odd numbered private memory register are loaded into the A-register. Address line LR31 has been set previously to address the odd numbered register. A logical AND operation is performed in the adder between the mask in the A-register and the data word in the $D$-register. The result is loaded into the $B$-register. Next an Exclusive OR operation is performed between the mask in the A-register and the ones in the CS-register to obtain the complement of the mask. The result is stored in the D-register. Flip-flop LR31 is reset, and the data from the private memory register selected by the R-field of the instruction, whether even or odd, is clocked into the Aregister. A logical AND operation is performed on the data in the A-register, the complement of the mask in the Dregister, and the ones in the CS-register. The adder output is merged on the sum bus with the output of the B-register, and the result is stored in the private memory register addressed by the R-field of the instruction. The data on the sum bus is tested for all zeros and for the state of bit 0 , and the condition-code flip-flops are set accordingly.
Table 3-39 is an example of the Load Selective operation for both an even and an odd numbered private memory register. A sequence chart for the instruction is given in table 3-40.

- Table 3-37. Load Complement Doubleword, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (Q) Next instruction address <br> (R) R-field <br> (P) Effective doubleword address <br> (LB31) Logical one <br> Two memory requests pending, one for each word of the doubleword |  |  | Selects 32 low order bits of doubleword to be loaded |
| PHI <br> T4RL | $\text { MB0-MB31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ $\text { NC0-NC31 } \rightarrow \text { D0-D31 }$ $1 \rightarrow \text { LR3 } 1$ $1 \rightarrow \operatorname{cs3} 1$ <br> Set flip-flop RQ <br> Set flip-flop $D R Q$ <br> Set flip-flop PH2 <br> Enable signal (S/T10L) | CXMB <br> DXNC/10- <br> DXNC/13 <br> DXNC/1 <br> (S/LR31/2) <br> CSXI/31 <br> DXNC/I <br> $S / R Q$ <br> R/RQ <br> S/DRQ <br> PREDO <br> R/DRQ <br> S/PH2 <br> R/PH2 <br> (S/T10L) <br> FULCD |  | Low order word gated into the C-register from memory bus when data gate signal received from memory <br> Clock one's complement of low order word into the D-register <br> Force a one into address line LR31 for selection of odd numbered fast memory register <br> Preset adder for two's complement of low order word $\rightarrow$ S in PH 2 <br> Generate memory request for next instruction <br> Inhibits clock until data release signal received from memory <br> Advance to PH 2 <br> Select clock in PH 2 |
| $\begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 10 \mathrm{~L} \end{aligned}$ |  | $\begin{aligned} & \text { SXPR } / 10- \\ & \text { SXPR } / 13 \\ & \text { SXADD } \end{aligned}$ | $\begin{aligned} & =\text { SXADD } \\ & =\text { FAS16 PH2 }+. \end{aligned}$ | Place two's complemeni of low order word onto the sum bus |
| (Continued) |  |  |  | Mnemonic: LCD (1A, 9A) |
|  |  |  |  |  |

Table 3-37. Load Complement Doubleword, Phase Sequence (Cont.)


Table 3-37. Load Complement Doubleword, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH5 } \\ & \mathrm{T} 10 \mathrm{~L} \end{aligned}$ | $\text { SO-S31 } \longrightarrow \text { RW0-RW31 }$ $\mathrm{S} 0-\mathrm{S} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> $B W Z \xrightarrow{\longrightarrow}$ A31 <br> Set flip-flop TESTA <br> Enable signal ENDE <br> Set flip-flop PREI for the next instruction <br> If overflow, set condition-code flipflop CC2 <br> if overfiow, and bit il of the PSW is a one (trap mask), enable signal TROVER | SXPR/10-13 SXADD RWXS/0- RWXS $/ 3$ RW AXS S/A31 A3IXI S/TESTA R/TESTA ENDE S/PRE1 R/PREI S/CC2 OVER PROBEOVER R/CC2 TROVER AM | ```SXADD + ... FAS19 PH5 + . . . - RW FAS16 PH5 + . . . = FASI6 PH5 + ... = A31XI +... = FASI6 BWZ + ... = FASI6 PH5 + ... = ... = FASI6 PH5 + . .  - ENDE N(S/INTRAPF) (NHALT + FUEXU) + ... = ... - OVER PROBEOVER + ... DO NKO NPRO NFAS10 + . . . ` FASI9 PH5 + ... = PROBEOVER + ... = OVER AMM PROBEOVER = Function of bit 11 of the PSW``` | Place high order word together with carry from low order word onto the sum bus <br> High order word gated into even numbered private memory register specified by the R-field <br> Load high order word from sum bus into the Aregister <br> Store not-all-zeros condition of low order word in flip-flop A31 <br> During an LCD instruction fixed-point overflow occurs if the original doubleword was X'8000000000000000', since the two's complement of this number is also $X^{\prime} 8000000000000000^{\prime}$ <br> Trap to iocation $\mathrm{X}^{\prime} 43^{i}$ |
| Next clock | Test word in A-register and code condition-code flip-flops CC3 and CC4 <br> If word is positive, set flip-flop CC3 and reset flip-flop CC4 <br> If word is negative, set flip-flop CC4 and reset flip-flop CC3 <br> If word is zero, reset flip-flops CC3 and CC4 | $\begin{aligned} & \text { S/CC3 } \\ & \text { NA0031Z } \\ & \text { R/CC3 } \\ & \text { S/CC4 } \\ & \text { R/CC4 } \end{aligned}$ | $=$ NAO NA0031Z TESTA <br> (. . .) + . . <br> = A-register does not contain all zeros <br> - TESTA <br> . AO TESTA NTESTA/1 + . . . <br> - TESTA |  |
|  |  |  |  | Mnemonic: LCD (1A, 9A) |

Table 3-38. Load Absolute Doubleword, Phase Sequence


Table 3-38. Load Absolute Doubleword Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH2 <br> T6L <br> (Cont.) | Reset flip-flop K00H if end carry is detected in complement of low order word $\text { MBO-MB31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ $1 \nmid \text { LR3 } 1$ <br> Set flip-flop PH3 <br> Enable signal ( $\mathrm{S} / \mathrm{TBL}$ ) | $\begin{gathered} \mathrm{S} / \mathrm{KOOH} \\ \mathrm{SOO} \\ \mathrm{KOO} \\ \mathrm{R} / \mathrm{KOOH} \\ \mathrm{CXMB} \\ \\ \\ \\ \\ \text { (S/LR31/2) } \\ \text { FULAD } \\ \mathrm{S} / \mathrm{PH} 3 \\ \mathrm{R} / \mathrm{PH} 3 \\ \text { (S/T8L) } \end{gathered}$ | $\begin{aligned} & =\text { S00 + . . } \\ & =\text { Function of NK00 } \\ & =\text { End carry present } \\ & =\ldots \\ & =\text { DG } \\ & =\text { FULAD PH2 + . . } \\ & =\text { OU1 OLB } \\ & =\text { PH2 NBR (...) + ... } \\ & =\ldots \\ & =\text { FULAD PH2 }+\ldots \end{aligned}$ | Store carry from low order word <br> High order word gated into the C-register from memory bus when data gate signal received from memory <br> Selects odd numbered private memory register <br> Advance to PH 3 <br> Select clock in PH3 |
| $\begin{array}{\|l\|l} \text { PH3 } \\ \text { T8L } \end{array}$ | $\begin{aligned} & \text { If NC0 } \\ & \text { D0-D31 } \longrightarrow \text { S0-S31 } \end{aligned}$ <br> If CO <br> $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ $\text { S0-S31 } \longrightarrow R W 0-R W 31 \quad[R+1]$ <br> Set flip-flop BWZ if two's complement of low order word does not contain all zeros <br> If NC0 $\mathrm{C} 0-\mathrm{C} 31 \longrightarrow \text { D0-D31 }$ <br> If CO <br> NCO-NC31 $\rightarrow$ DO-D31 | $\begin{gathered} \text { SXD/10- } \\ \text { SXD/13 } \\ \text { SXD } \\ \\ \text { SXA/10- } \\ \text { SXA/13 } \\ \text { SXA } \\ \\ \text { RWXS/0- } \\ \text { RWXS/3 } \\ \text { RW } \\ \\ \text { S/BWZ } \\ \text { R/BWZ } \\ \text { DXC/10- } \\ \text { DXC/13 } \\ \text { DXC/6 } \\ \text { DXNC/10- } \\ \text { DXNC/13 } \\ \text { DXNC } \end{gathered}$ | $\begin{aligned} & =\text { SXD }+\ldots \\ & =\text { FULAD NC0 PH3 + . . } \\ & =\text { SXA } \\ & =\text { FULAD C0 PH3 + ... } \\ & = \\ & =\text { RW } \\ & =\text { FULAD PH3 + . . } \\ & =\text { CLEAR } \\ & =\text { DXC/6 } \\ & = \\ & = \\ & = \\ & = \\ & = \\ & = \\ & = \end{aligned}$ | If operand is positive, place low order word onto the sum bus <br> If operand is negative, place two's complement of low order word onto the sum bus <br> Load absolute value of low order word into the odd numbered private memory register specified by the R-field <br> If operand is positive, clock high order word into the D-register <br> If operand is negative, clock one's complement of high order word into the D-register |
|  |  |  | ued) | Mnemonic: LAD (1B, 9B) |

Table 3-38. Load Absolute Doubleword, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH3 <br> T8L <br> (Cont. | If CO and flip-flop K 00 H was reset in PH2, set flip-flop CS31 <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Enable signal $M R Q / 1$ <br> Set flip-flop PH5 <br> Enable signal (S/T10L) | S/CS31 CSXI/8 PXQ PREDO MRQ/1 S/PH5 BRPH5 (S/T10L) | $\begin{aligned} = & \text { CSXI } / 8+\ldots \\ = & \text { FULAD NKOOH C0 PH3 } \\ & +\ldots \\ = & \text { PREDO PH3 + . . } \\ = & \text { OU1 O4 NO5 + . . } \\ = & \text { FULAD PH3 + . . } \\ = & \text { BRPH5 NCLEAR + . . } \\ = & \text { FAS16 PH3 + . . } \\ = & \text { FAS19 PH3 + . . } \end{aligned}$ | Store end carry from low order word in flip-flop CS31 <br> Redundant $Q \longrightarrow P$ is for mechanization convenience <br> Generate memory request for next instruction <br> Advance to PH5 <br> Select clock in PH5 |
| $\begin{aligned} & \text { PH5 } \\ & \text { T10L } \end{aligned}$ | BWZ $\longrightarrow$ A31 <br> Set flip-flop TESTA <br> Enable signal ENDE <br> Set flip-flop PREI for the next instruction <br> If overflow, set condition-code flip-flop CC2 | SXPR/10-13 SXADD RWXS/0- RWXS/3 RW AXS S/A31 A31XI S/TESTA R/TESTA ENDE S/PRE1 R/PRE1 S/CC2 OVER PROBEOVER R/CC2 | ```= SXADD + ... = FASI9 PH5 + ... = RW FASI6 PH5 + ... = FASI6 PH5 + ... - A31XI + ... = FASI6 BWZ + ... FASI6 PH5 + . . . FAS16 PH5 + ... ENDE N(S/INTRAPF) (NHALT + FUEXU) + ... OVER PROBEOVER + . . . DO NKO NPRO NFASIO + . . . FAS19 PH5 + . . . PROBEOVER``` | Place absolute value of high order word, together with carry from low order word, onto the sum bus <br> High order word gated into even numbered private memory register specified by the R-field <br> Load high order word from sum bus into the Aregister <br> Store not-all-zeros condition of low order word in flip-flop A31 <br> During a LAW instruction fixed-point overflow occurs if the original value of the doubleword was X'8000000000000000' |
|  |  |  |  | Mnemonic: LAD (1B, 9B) |

Table 3-38. Load Absolute Doubleword, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved |  |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{PH} \mathrm{~S} \\ & \mathrm{~T} 10 \mathrm{~L} \\ & \text { (Cont.) } \end{aligned}$ | If overflow and bit 11 of the PSW is a one (trap mask), enable signal TROVER, and set flip-flops TRAP, TR30, and TR31 |  | Trap to location $X^{\prime} 43{ }^{\prime}$ |
| Next clock | Test word in A-register and set flip-flops CC3 and CC4 <br> If word is positive, set flip-flop CC3; if word is negative, set flip-flop CC4; if word is zero, reset flip-flops CC3 and CC4 | $\begin{array}{\|lrl} \text { S/CC3 } & & \text { NA0 NA0031Z TESTA } \\ & (\ldots)+\ldots \\ \text { NA003IZ }= & \text { A-register does not contain } \\ & \text { all zeros } \\ \text { R/CC3 }= & \text { TESTA } \\ \text { S/CC4 }= & \text { A0 TESTA NTESTA } / 1+\ldots \\ \text { R/CC4 }= & \text { TESTA } \end{array}$ |  |
|  |  |  | Mnemonic: LAD (1B, 9B) |

Table 3-39. Load Selective Operation Example with Even and Odd Numbered R-Field Address
A. R-Field Even Address

Contents of registers:

R (odd) (mask)
Effective word R (even)
PH2 A.D $\longrightarrow S$
Mask (A-register)
Effective word (D)
Result in B
$\mathrm{PH} 4 \quad \mathrm{~A} \oplus \mathrm{CS} \longrightarrow \mathrm{S}$
Mask (A-register)
CS-register
Result in D-register (NRodd)

PH5 A.D $\longrightarrow$ S
$R$ (even) (A-register)
D-register (NRodd)
Result on sum bus
Sum bus
B-register
Merge

00101100111010101110100011011101 01010001110110010111101011010011 01100111001110100010101100110111

## $S \rightarrow B$

00101100111010101110100011011101
01010001110110010111101011010011 00000000110010000110100011010001

$$
s \rightarrow C \not C \rightarrow D
$$

00101100111010101110100011011101
11111111111111111111111111111111
11010011000101010001011100100010

$$
B \longrightarrow S
$$

| 01100111001110100010101100110111 | $673 A 2 B 37$ |
| :--- | :--- |
| $\underline{11010011000101010001011100100010}$ | $\underline{\text { D3151722 }}$ |
| 01000011000100000000001100100010 | 43100322 |
| 01000011000100000000001100100010 |  |
| $\underline{00000000110010000110100011010001}$ | $\underline{43100322}$ |
| 0100001111011000011010111110011 | $\underline{\text { 43D83BFF3 }}$ |

Operation: Wherever a one is contained in the mask, the corresponding bit of the effective word is stored in the even numbered private memory register. When a zero exists in the mask, the corresponding bit in the private memory register is left unchanged.
B. R-Field Odd Address

Contents of registers:
$R$ (odd) (mask)
Effective word
PH2 A.D $\longrightarrow S$
Mask (A-register)
Effective word (D)
Result in B-register
$\mathrm{PH} 4 \quad \mathrm{~A} \oplus \mathrm{CS} \longrightarrow \mathrm{S}$
Mask (A-register)
CS-register
Result in D-register
PH5 A.D $\longrightarrow S$
R (odd) A-register
D-register (NRodd)
Result on sum bus
Sum bus
B-register Result of merge

00101100111010101110100011011101
2CEAE8DD 51D97AD3

## $S \rightarrow B$

00101100111010101110100011011101
2CEAE8DD
51D97AD3
00C868D1
01010001001010010111101011010011
00000000110010000110100011010001

## $\mathrm{S} \rightarrow \mathrm{C} \rightarrow \mathrm{D}$

| 00101100111010101110100011011101 | 2CEAE8DD |
| :--- | :--- |
| 1111111111111111111111111111111 | FFFFFFFF |
| 11010011000101010001011100100010 | D3151722 |

## $B \longrightarrow S$

| 00101100111010101110100011011101 | 2CEAE8DD |
| :--- | :--- |
| $\underline{11010011000101010001011100100010}$ | $\underline{\text { D3151722 }}$ |
| 00000000000000000000000000000000 | 0000000 |

00000000
00 C 868 D 1
00 C 868 D 1

Operation: A logical AND operation is performed with the mask and the effective word. The result is stored back in the odd numbered private memory register.

Table 3-40. Load Selective, Phase Sequence


Table 3-40. Load Selective, Phase Sequence (Cont.)


Table 3-40. Load Selective, Phase Sequence (Cont.)


Mnemonic: LS (4A, CA)

3-177 Load Multiple (LM 2A, AA)
During the Load Multiple instruction, a sequential set of words is read from core memory and is loaded into a sequential set of private memory registers specified by the Rfield. The number of words to be loaded (word count) is first stored in flip-flops CC1-CC4 and then is clocked into flip-flops E4-E7. An initial count of 0000 is interpreted as a word count of 16 .

The instruction is executed in a sequence of iterations. During each iteration, a word is transferred from core memory, via the $C$ - and $D$-registers, and sum bus into the private memory register. The $P$ - and $R$-registers are incremented by one, and the E-register is decremented by one. Iterations stop when the word count in the E-register reaches one.

A sequence chart of the Load Multiple instruction is given in table 3-41.

## 3-178 Load Conditions and Floating Control Immediate (LCFI 02, 82)

This instruction is used to load the condition codes and floating control bits obtained during the previous instruction into CPU registers reserved for this purpose. The condition codes occupy bit positions 24 through 27 of the instruction word, and are loaded into flip-flops CC1-CC4 if bit position 10 of the instruction word is a one. The floating control bits occupy bit positions 29 through 31 of the instruction word, and are loaded into flip-flops FS, FZ, and FNF if bit position 11 of the instruction word is a one.

A sequence chart of the Load Conditions and Floating Control Immediate instruction is given in table 3-42.

3-179 Load Conditions and Floating Control (LCF 70, F0)
The Load Conditions and Floating Control instruction is used to load the condition codes and floating control bits, obtained from a specific byte in core memory, into CPU registers reserved for this purpose. The condition codes occupy bit positions 0 through 3 of the effective byte, and are loaded into flip-flops CC1-CC4 if bit position 10 of the instruction word is a one. The floating control bits occupy bit positions 5 through 7 of the effective byte, and are loaded into flip-flops FS, FZ, and FNF if bit position 11 of the instruction word is a one.

A sequence chart of the Load Conditions and Floating Control instruction is given in table 3-43.

## 3-180 Exchange Word (XW 46, C6)

The Exchange Word instruction is used to exchange a word in core memory with a word in a private memory register specified by the R-field. The original core memory word is held temporarily in the $D$-register and then is loaded into the private memory register. The original private memory word is held temporarily in the A-register and then is stored
in core memory. At the end of the instruction, the new word contained in the private memory register is tested for zero, positive, and negative conditions. The results of this test are stored in flip-flops CC1-CC4.

A sequence chart of the Exchange Word instruction is given in table 3-44.

3-181 Store Byte (STB 75, F5)
The Store Byte instruction is used to transfer one byte from a fast memory register specified by the R-field into a core memory location specified by the effective address.

The byte to be stored is obtained from bits 24-31 of the affected fast memory register and is clocked into A24-A31. It is transferred to the appropriate byte on the sum bus ( SO S7, S8-S15, S16-S23, or S24-S31) as specified by P32 and P33 and is stored at the effective byte address in core memory.

A sequence chart of the Store Byte instruction is given in table 3-45.

3-182 Store Halfword (STH 55, D5)
The Store Halfword instruction is used to transfer one halfword from a fast memory register specified by the R-field into a core memory location specified by the effective address.

The halfword to be stored is obtained from bits 16-31 of the affected fast memory register and is clocked into A16-A31. It is transferred to the appropriate halfword on the sum bus (S0-S15 or S16-S31) as specified by P32 and is stored at the effective halfword address in core memory.

A sequence chart of the Store Halfword instruction is given in table 3-46.

3-183 Store Word (STW 35, B5)
The Store Word instruction is used to transfer one word from a private memory register specified by the R-field, via the A-register and sum bus, into the effective core memory location.

A sequence chart of the Store Word instruction is given in table 3-47.

## 3-184 Store Doubleword (STD 15, 95)

The Store Doubleword instruction is used to transfer a doubleword from two consecutive private memory registers into two consecutive core memory locations. The R-field and the effective address point to the even numbered private memory register and to the even numbered core memory locations, respectively. Initially, bits LR31 and LB31 are driven true, causing the low order word to be transferred first. The low order word is obtained from the odd private memory register and is stored in the odd core memory location.

Table 3-41. Load Multiple, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (Q) Next instruction address <br> (P) Effective address of first word <br> (R) Address of first general register <br> (CC) Word count |  |  |  |
| $\begin{aligned} & \mathrm{PHI} \\ & \mathrm{~T} 4 \mathrm{RL} \end{aligned}$ | $\mathrm{CCl}-\mathrm{CC} 4 \longrightarrow \mathrm{E} 4-\mathrm{E} 7$ <br> Enable signal BRPH3 <br> Set flip-flop PHA <br> Enable signal $M R Q$ <br> Enable signal (S/DRQ) <br> Set flip-flop IEN <br> Enable signal T6L | EXCC <br> BRPH3 <br> S/PHA <br> R/PHA <br> MRQ <br> (S/DRQ) <br> S/IEN <br> R/IEN <br> T6L | $=$ FAST PHI O4 NO5 O6 <br> $=$ FAST PHI OLA O2 + ... <br> $=$ FAST PH1 O2 + ... <br> $=$ CLEAR <br> $\therefore$ FAST PHI NO2 NO7 + . <br> $=$ FAST EXU + ... <br> $=$ FAST PHI O4 NO5 O6 + . <br> $\therefore$ (R/IEN) <br> $=$ NTIL NT4L NT8L NTIOL NRESET | Load word count into the E-register <br> Advance to PH3A <br> Request first data word from memory <br> Inhibits clock until data release signal received from memory <br> Allows interrupt to be accepted at any clock pulse <br> Select clock in PH3A |
| $\left\lvert\, \begin{aligned} & \text { PH3A } \\ & \text { T6L } \end{aligned}\right.$ | MBO-MB31 $\longrightarrow \mathrm{C} 0-\mathrm{C} 31$ $\mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31$ <br> If word count does not equal 1 $P+1 \rightarrow P$ <br> Enable signal $M R Q$ <br> Reset flip-flop IEN <br> Enable signal BRPH5 <br> Enable signal T6L | CXMB <br> DXC/6 <br> PCTP1 <br> ( $\mathrm{E}=1$ ) <br> MRQ <br> R/IEN <br> BRPH5 <br> T6L | $\begin{aligned} = & \text { DGC } \\ = & \text { FASTA PH3 }+\ldots \\ = & \text { FASTA PH3A OLA N(E=1) } \\ & +\ldots \\ = & \text { Word count equals } 1 \\ = & \text { FASTA PH3 OLA N(E }=1) \\ & +\ldots \\ = & \text { FASTA PH3 }+\ldots \\ = & \text { FASTA PH3 OLA }+\ldots \\ = & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \end{aligned}$ | First word loaded into the C-register from memory bus when data gate signal received from memory <br> Clock first word into the D-register <br> Increment P -register to obtain the next word address <br> Request next data word from memory <br> Prevents interrupt from being accepted <br> Advance to PH5A <br> Select clock in PH5A |
|  |  |  | inved) | Mnemonic: LM (2A, AA) |

Table 3-41. Load Multiple, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH5A } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \text { D0-D31 } \longrightarrow \text { S0-S31 } \\ & \text { SO-S31 } \longrightarrow \text { RW0-RW31 } \end{aligned}$ $M B 0-M B 31 \longrightarrow C 0-C 31$ | SXD <br> RWXS/0- <br> RWXS/3 <br> RW <br> CXMB | $\begin{aligned} & =\text { FASTA PH5 NSDIS }+\ldots \\ & =\text { RW } \\ & \therefore \text { FASTA PH5 }+\ldots \\ & =\text { DGC } \end{aligned}$ | Transfer first data word from the D-register via the sum bus into the private memory register specified by the R-field <br> Next word loaded into the C-register from memory bus when data gate signal received from memory |
|  | $\mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31$ | DXC/6 | $=\text { FASTA PH5 + }$ | Load next data word into the $D$-register |
|  | $R+1 \nrightarrow R$ | PCTR | $=$ FASTA PH5 + | Increment private memory register address in preparation for the next iteration |
|  | $\mathrm{E}-1 \longrightarrow \mathrm{E}$ | MCTEI | $=\text { FASTA PH5 }+\ldots$ | Decrement the word count by one after each iteration |
|  | If count in E-register does not equal 1, enable signal BRPH5 <br> If count in E-register does not equal 1 or 2 | BRPH5 | FASTA PH5 OLA $N(E=1)$ + . . . | Sustain PH5A until word count is reduced to one <br> Memory request is one clock ahead of the word |
|  | Enable signal $M R Q$ | $M R Q$ | $=$ FASTA PH5 $\mathrm{N}(\mathrm{E}=1$ or 2$)$ OLA + . . . | count, and anticipates a reduction in the word count at the end of this |
|  | $P+1 \longrightarrow P$ | PCTPI | $\begin{aligned} = & \text { FASTA PH5 } N(E=1 \text { or } 2) \\ & \text { OLA }+\ldots . \end{aligned}$ | phase |
|  | If count in E-register equals 1 |  |  |  |
|  | Enable signal $M R Q / 1$ | $M R Q / 1$ | $\text { - FASTA PH5 }\left(E^{-1}\right) \mathrm{O} 2 \text { NO7 }$ + . . . | Generate memory request for next instruction, with the address as specified by the Q -register |
|  | Q15-Q31 $\rightarrow$ P15-P31 | $P X Q$ | : MRQ/1 + | Load next instruction address into the P -register |
|  | Enable signal BRPHI3 | BRPHI3 | $\therefore$ FASTA PH2 O2 (E 1) + . | Advance to PHI 3 A |
|  | Enable signal T6L | TGL | - NTIL NT4L NT8L NTIOL NRESET | Select clock in PHI3A |
| $\left\lvert\, \begin{aligned} & \mathrm{PH} 13 \mathrm{~A} \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}\right.$ | Enable signal ENDE <br> Set flip-flop PREI for the next instruction | ENDE <br> S/PREI | FASTA PHI3 + . . <br> ENDE NHALT N(S/INTRAPF) + . . . |  |
|  |  |  |  | Mnemonic: LM (2A, AA) |

Table 3-42. Load Conditions and Floating Control Immediate, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP:(O) Opcode  <br> (D) Opcode <br> (R30) D10 <br> (R31) D11 |  |  |  |
| $\left\lvert\, \begin{aligned} & \mathrm{PHI} \\ & \mathrm{~T} 4 \mathrm{RL} \end{aligned}\right.$ | Enable signals CSXI/9 and CSXI/10 <br> Set flip-flop DRQ <br> Set flip-flop PH2 <br> Reset flip-flop NT8L | $\begin{aligned} & \text { CSXI/9 } \\ & \text { CSXI/10 } \\ & \quad(\mathrm{S} / \mathrm{NPRX}) \\ & \mathrm{S} / \mathrm{DRQ} \\ & \mathrm{R} / \mathrm{DRQ} \\ & \mathrm{~S} / \mathrm{PH} 2 \\ & \\ & \mathrm{R} / \mathrm{PH} 2 \\ & \mathrm{R} / \mathrm{NT8L} \\ & \mathrm{~S} / \mathrm{NT} \text { TL } \\ & (\mathrm{S} / \mathrm{T} 8 \mathrm{~L}) \end{aligned}$ | $\begin{aligned} = & (S / \text { NPRX })+\ldots \\ = & (S / N P R X)+\ldots \\ = & \text { FASI7 PHI }+\ldots \\ = & \text { FASI7PHI }+\ldots \\ = & \ldots \\ = & \text { PHI NBR N(FNANLZ } \\ & \text { NANLZ })+\ldots \\ = & \ldots \\ = & \ldots \\ = & \text { N(S/T8L) } \\ = & \text { FASI7 PHI }+\ldots \end{aligned}$ | Force ones into the CSregister, in preparation for $D \longrightarrow S$ in PH 2 <br> Inhibits transmission of another clock until data received <br> Advance to phase 2 <br> Select clock T8L in PH2 |
| $\begin{array}{\|l\|l} \hline \mathrm{PH} 2 \\ \mathrm{~T} 8 \mathrm{~L} \end{array}$ | D24-D31 $\longrightarrow$ ADDER $\longrightarrow$ SO-S7 <br> If R3I <br> $S 5 \rightarrow F S$ <br> $S 6 \xrightarrow{\rightarrow} \mathrm{FZ}$ <br> S7 $\rightarrow$ FNF <br> If R30 $\mathrm{SO}-\mathrm{S} 3 \nrightarrow \mathrm{CCl}-\mathrm{CC} 4$ <br> Enable signal ENDE <br> Set flip-flop PRE 1 <br> Enable signal T6L | SXUAB $\mathrm{PH} 2 / 1$ <br> S/FS <br> FSZNXS <br> R/FS <br> S/FZ <br> R/FZ <br> S/FNF <br> R/FNF <br> $\mathrm{S} / \mathrm{CCl}-\mathrm{CC} 4$ <br> ccsX <br> R/CCl-CC4 <br> ENDE <br> S/PRE 1 <br> R/PRE <br> T6L |  | R31 is derived from bit 11 of the instruction word which specifies floating mode control <br> R30 is derived from bit 10 of the instruction word which specifies condition code setting |
|  |  |  |  | Mnemonic: LCFI (02) |

Table 3-43. Load Conditions and Floating Control, Phase Sequence


Table 3-43. Load Conditions and Floating Control, Phase Sequence (Cont.)


Table 3-44. Exchange Word, Phase Sequence


Table 3-44. Exchange Word Phase Sequence (Cont.)


Mnemonic: XW (46, C6)

XDS 901060

Table 3-45. Store Byte, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (Q) Next instruction address <br> (P15-P31) Effective word address <br> (P32, P33) Byte address <br> (A) Byte to be stored |  |  |  |
| $\begin{array}{\|l\|} \hline \mathrm{PHI} \\ \mathrm{~T} 4 \mathrm{RL} \end{array}$ | ```\(\mathrm{A} 24-\mathrm{A} 31 \longrightarrow \mathrm{ADDER} \longrightarrow \mathrm{SO}-\mathrm{S} 7\) A24-A31 \(\longrightarrow\) ADDER \(\longrightarrow\) S8-Si5 \(\mathrm{A} 24-\mathrm{A} 31 \longrightarrow\) ADDER \(\longrightarrow\) S16-S23 \(\mathrm{A} 24-\mathrm{A} 31 \longrightarrow\) ADDER \(\longrightarrow\) S24-S31 If NP32 NP33 \[ \text { S0-S7 } \longrightarrow \mathrm{MB0} 0-\mathrm{MB7} \]``` <br> If NP32 P33 $\text { S8-S15 } \longrightarrow \mathrm{MB8}-\mathrm{MBI} 5$ <br> If P32 NP33 $\mathrm{S} 16-\mathrm{S} 23 \longrightarrow \mathrm{MB} 16-\mathrm{MB} 23$ <br> If P32 P33 $\mathrm{S} 24-\mathrm{S} 31 \longrightarrow \mathrm{MB} 24-\mathrm{MB} 31$ <br> Enable signal $M R Q / 1$ $\text { Q15-Q31 } \rightarrow \text { P15-P31 }$ <br> Enable signal (S/DRQ) <br> Enable signal T6L | SXUAB <br> SXUAB <br> SXUAB <br> SXUAB <br> MBXS/0 <br> MWB <br> $M B X S / 1$ <br> MBXS/2 <br> MBXS/3 <br> MRQ/ 1 <br> PXQ <br> (S/DRQ) <br> T6L | + . . . $\begin{aligned} \because & \text { NP32 NP33 MWB (. .) }+\ldots \\ & \text { OU7 NO4 O5 NO6 PHI } \\ & +\ldots \\ = & \text { NP32 P33 MWB }(\ldots)+\ldots \\ = & \text { P32 NP33 MWB }(\ldots)+\ldots \\ = & \text { P32 P33 MWB }(\ldots)+\ldots \\ = & \text { FAS18 PH1 }+\ldots \end{aligned}$ $=M R Q / 1+\ldots$ <br> $=$ FASI8 PHI + ... <br> $=$ NTIL NT4L NT8L NTIOL NRESET | Transfer byte from Aregister via adder to each byte of the sum bus <br> Store byte to the byte location specified by flipflops P32 and P33 <br> Generate memory request for next instruction with address as specified by the Q-register <br> Load next instruction address into the P -register <br> Select clock in PH2 |
| $\begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | Enable signal ENDE <br> Set flip-flop PREI for the next instruction | ENDE <br> S/PREI | $=$ FASI8 PH2 $+\ldots$ <br> ENDE NHALT N(S/INTRAPF) <br> (NHALT + FUEXU) + ... |  |
|  |  |  |  | Mnemonic: STB (75, F5) |

Table 3-46. Store Halfword, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (Q) Next instruction address <br> (P15-P31) Effective word address <br> (P32) Halfword address <br> (A) Contents of general register specified by R-field, including halfword to be stored |  |  |  |
| $\begin{aligned} & \mathrm{PHI} \\ & \mathrm{~T} 4 \mathrm{RL} \end{aligned}$ | $\left\{\begin{array}{l}\text { A16-A31 } \longrightarrow \text { ADDER } \longrightarrow \text { S0-S15 } \\ \text { A16-A31 } \longrightarrow \text { ADDER } \longrightarrow \text { S16-S31 } \\ \text { If NP32 } \\ \text { S0-S15 MB0-MB15 } \\ \text { If P32 } \\ \text { S16-S31 MB16-MB31 } \\ \text { Enable signal /MRQ/1 } \\ \text { Enable signal }(S / D R Q) \\ \text { Q15-Q31 } \rightarrow \text { P15-P31 } \\ \text { Set flip-flop CS15 } \\ \text { Enable signal }(S / \text { T8L })\end{array}\right.$ | SXUAH FUSTH SXUAH | $\begin{aligned} & =\text { FUSTH PHI NSDIS }+\ldots \\ & =\text { OU5 OL5 } \\ & =\text { NP32 MWH }(\ldots)+\ldots \\ & =\text { FUSTH PHI }+\ldots \\ & =\text { P32 MWH }(\ldots)+\ldots \\ & =\text { FASI8 PHI }+\ldots \\ & =\text { FASI8 PHI }+\ldots \\ & =/ M R Q / I \\ & =\text { FUSTH PHI }+\ldots \\ & =\text { FUSTH PHI }+\ldots \end{aligned}$ | Store halfword in the halfword location specified by flip-flop P32 <br> Generate memory request for next instruction as specified by Qregister <br> Inhibits clock until data release signal received from core memory <br> Load next instruction address into the P -register <br> Used in PH2 to generate carry bit K00 if high order halfword contains the extended sign of the low order halfword <br> Select clock in PH2 |
| $\begin{array}{\|l\|} \hline \text { PH2 } \\ \text { T8L } \end{array}$ | Test for end carry K00 <br> Set flip-flop CC2 under one of the following conditions <br> If A16 and NK00 | K00 CS15 <br> S/CC2 <br> A16 | $=\operatorname{CSI} 5$ (A0-A15 are all ones) <br> - Was set in PHI <br> $=$ FUSTH PH2 A16 NKOO + . <br> - Indicates that halfword stored is negative | Setting of CC2 indicates that high order halfword contains data and not the extended sign of the low order word |
| (Continued) |  |  |  | Mnemonic: §TH (55, D5) |

Table 3-46. Store Halfword, Phase Sequence (Cont.)


Table 3-47. Store Word, Phase Sequence


Mnemonic: STW (35, B5)

Bits LR31 and LB31 are driven false, and the contents of the even private memory register are stored in the even core memory location.

A sequence chart of the Store Doubleword instruction is given in table 3-48.

## 3-185 Store Selective (STS 47, C7)

The Store Selective instruction is used to alter or to write over selected bits of a core memory word. If the R-field is even, the even numbered private memory register contains the operand, and the odd numbered private memory register contains a 32-bit mask. When ones appear in the mask, the corresponding bits of the operand are stored in the effective core memory word. When zeros appear in the mask, the corresponding bits of the core memory word remain unchanged.

Initially, the complement of the mask is clocked in the Aregister, and the effective word is clocked in the D-register. Then, the contents of the A-register are AND-gated with the contents of the D-register, and the result stored in the B-register. This result is the Exclusive OR between the mask and the core memory word.

Next, the mask is placed in the A-register; the operand is placed in the D-register. The two are AND-gated in the adder, and are merged on the sum bus with the contents of the B -register. Finally, the contents of the sum bus are stored in the effective core memory location.

If the R-field is odd, the contents of the private memory register are OR-gated with the contents of the effective core memory word. The new word is stored in the effective core memory location.
An example of the Store Selective instruction is shown in table 3-49. A sequence chart of the instruction is given in table 3-50.

## 3-186 Store Multiple (STM 2B, AB)

During the Store Multiple instruction, a group of words is obtained from a sequential set of private memory registers specified by the R-field and is stored in a sequential set of core memory locations. The number of words to be stored (word count) is first stored in flip-flops CCI-CC4 and then is clocked into flip-flops E4-E7. An initial count of 0000 is interpreted as a word count of 16 .

The instruction is executed in a sequence of iterations. During each iteration, a word is transferred from a fast memory register, via the A-register and sum bus, into the effective core memory location. The P - and E-registers are incremented by one, and the E-register is decremented by one. Iterations stop when the word count in the E-register reaches one.

A sequence chart of the Store Multiple instruction is given in table 3-51.

## 3-187 Store Conditions and Floating Control (STCF 74, F4)

This instruction is used to store the current condition codes and floating control bits of the program status doubleword in byte 0 of the effective core memory location.

A sequence chart of the Store Conditions and Floating Control instruction is given in table 3-52.

## 3-188 Analyze (ANLZ 44, C4)

The ANLZ instruction causes a word to be read from the effective core memory address. The operand read into the $C$ register is treated as an instruction, and either the reference address is modified by indexing or indirect addressing is performed, as required, by the instruction being analyzed. If the operation code (opcode) portion of the word specifies an immediate addressing type, the condition code register is set to indicate the addressing type, and the execution proceeds to the next instruction. If the opcode portion of the instruction being analyzed is a non-immediate addressing type, the condition code register is set to indicate the type of addressing.

The effective address of the analyzed instruction is computed and is aligned as an integer displacement value (as illustrated in figure 3-153). The displacement value is then loaded into the private memory register indicated in the Rfield of the ANLZ instruction word.

The preparation sequence for an ANLZ instruction is the same as the general preparation sequence. Since the ANLZ flip-flop has not been set, normal indexing and indirect addressing are performed as required.

The instruction word being analyzed is loaded into the Dregister, and its opcode is clocked into the O-register. Signal LMXC is inhibited so that the reference address of the new instruction is not placed on the core memory address lines. A normal preparation sequence is entered to compute the effective address of the instruction being analyzed. Condition code flip-flops are set to indicate whether the instruction is in the immediate, the byte, the halfword, or the word class (see table 3-53). The instructions for each class are shown in table 3-54.

If the instruction is not an immediate type, the effective address in the P -register is gated onto bits 15 through 31 of the sum bus, and the byte or the halfword addressing bits in flipflops P32 and P33 are gated into SO and S1. The contents of the sum bus are clocked into the A-register.

If the instruction is of the byte addressing type, the Aregister contents are shifted left two bit positions, and the byte selection bits in SO and S1 are shifted into A30 and A31. The A-register contents are shifted left one bit position, and the halfword selection bit in SO is shifted into A31, if the instruction is of the halfword addressing type.

Table 3-48. Store Doubleword, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (Q) Next instruction address <br> (P15-P30) Effective doubleword address <br> (P31) False <br> (LB31) True <br> (A) Low order word to be stored |  |  | Selects odd memory location |
| PHI <br> T4RL |  | SXA <br> MBXS/0MBXS $/ 3$ <br> MW <br> MRQ <br> FUSTD <br> AXRR <br> (S/DRQ) <br> BRPH4 <br> T6L | $\begin{aligned} = & \text { NOI O3 OL5 PHI NSDIS } \\ & +\ldots \\ = & \text { MW }(\ldots)+\ldots \\ = & \text { NO1 O3 OL5 PHI }+\ldots \\ = & \text { FUSTD PHI }+\ldots \\ = & \text { OUI OL5 } \\ = & \text { FUSTD PHI }+\ldots \\ = & \text { O3 OL5 PHI + .... } \\ = & \text { FUSTD PHI + ... } \\ = & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \end{aligned}$ | Store low order word in odd memory location <br> Generate memory request for writing high order word <br> Transfer high order word from even location in fast memory register to the Aregister <br> Inhibits clock until data release signal received from core memory <br> Advance to PH4 <br> Select clock in PH4 |
| $\left\lvert\, \begin{aligned} & \text { PH4 } \\ & \text { T6L } \end{aligned}\right.$ | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \text { S0-S31 } \\ & \text { S0-S31 } \longrightarrow \text { MB0-MB31 } \end{aligned}$ <br> Enable signal $M R Q / 1$ <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Enable signal (S/DRQ) | SXA <br> $M B X S / 0-$ <br> $M B X S / 3$ <br> $M W$ <br> $M R Q / 1$ <br>  <br>  <br> $P X Q$ <br>  <br> $(S / D R Q)$ | ```= FUSTD PH4 NSDIS + ... = MW (...) + ... * FASI4 PH4 + ... = FUSTD PH4 + ... \MRQ/1 + ... == FUSTD PH4 + ...``` | Store high order word in even memory location <br> Generate memory request for next instruction, as specified by the Qregister <br> Load next instruction address into the P -register <br> Inhibits clock until data release signal received from core memory |
|  |  |  |  | Mnemonic: STD (15, 95) |

Table 3-48. Store Doubleword, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH4 <br> T6L <br> (Cont.) | Enable signal T6L | T6L | $=$ NTIL NT4L NT8L NTIOL NRESET | Select clock in PH5 |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | Enable signal ENDE <br> Set flip-flop PRE1 for the next instruction | ENDE <br> S/PREI | $\begin{aligned} = & \text { FASI } 4 \text { PH5 }+\ldots \\ = & \text { ENDE NHALT N(S/INTRAPF) } \\ & +\ldots \end{aligned}$ |  |
|  |  |  |  | Mnemonic: STD (15,95) |

Table 3-49. Store Selective Operation Example with Even and Odd Numbered R-Field Address
A. R-Field Even Address

Contents of registers:

R (odd) (mask)
$R$ (even)
Effective word
$\mathrm{PHI} \quad \mathrm{A} \oplus \mathrm{CS} \rightarrow \mathrm{S}$
$R$ (odd) A-register
CS-register (NPRX)
NR (odd) A-register
$\mathrm{PH} 2 \quad \mathrm{~A} . \mathrm{D} \rightarrow \mathrm{S}$
Effective word (D-reg.)
NR (odd) from A-register
Result in B-register
PH4 A.D $\longrightarrow$ S
$R$ (even) D-register
$R$ (odd) A-register
Result on sum bus
Sum bus
B-register
Result of merge on sumbus

00101100111010101110100011011101
01100111001110100010101100110111 01010001110110010111101011010011

## $S \rightarrow A$

| 00101100111010101110100011011101 | 2CEAE8DD |
| :--- | :--- |
| 1111111111111111111111111111111 | FFFFFFFF |
| 11010011000101010001011100100010 |  |

$11010011000101010001011100100010 \quad \overline{\text { D3151722 }}$

$$
S \nrightarrow B
$$

$\begin{array}{ll}01010001110110010111101011010011 & \text { 5ID97AD3 } \\ \frac{11010011000101010001011100100010}{01010001000100010001001000000010} & \frac{\text { D3151722 }}{51111202}\end{array}$

$$
s \rightarrow s
$$

| 01100111001110100010101100110111 | 673A2B37 |
| :--- | :--- |
| 00101100111010101110100011011101 | $\frac{\text { 2CEAE8DD }}{242 A 2815}$ |
| 00100100001010100010100000010101 | $242 A 2815$ |
| 00100100001010100010100000010101 | $\frac{51111202}{753 B 3 A 17}$ |

Operation: Wherever a one is contained in the mask, the corresponding bit of the even numbered private memory register is stored in the core memory word. The corresponding bit in the core memory word is left unchanged, when a zero exists in the mask.
B. R-Field Odd Address

Contents of registers:

R (odd) (mask)
Effective word
$\mathrm{PHI} \mathrm{A}+\mathrm{CS} \rightarrow \mathrm{S}$
$R$ (odd) (mask) A-reg.
CS-register (NPRX)
NR (odd) A-register
PH2 A.D $\rightarrow S$
Effective word (D-reg.)
NR (odd) A-register
Result in B-register
PH4 A.D $\rightarrow$ S
R (odd) D-register
R (odd) A-register
Result on sum bus
Sum bus
$B$-register
Result of merge on sumbus

00101100111010101110100011011101
2CEAE8DD 01010001110110010111101011010011

$$
S \nrightarrow A
$$

| 00101100111010101110100011011101 | 2CEAE8DD |
| :--- | :--- |
| iiiiiiiiiiiiiiiiiiiiiiiiiiiiiii | FFFFFFFF |
| 11010011000101010001011100100010 | D3151722 |

$$
S \nrightarrow B
$$

$$
\begin{array}{ll}
01010001110110010111101011010011 & \text { 51D97AD3 } \\
11010011000101010001011100100010 & \frac{\text { D3151722 }}{51111202} \\
\hline 01010001000100010001001000000010 &
\end{array}
$$

## $B \longrightarrow S$

| 00101100111010101110100011011101 | 2CEAE8DD |
| :--- | :--- |
| 00101100111010101110100011011101 | 2CEAE8DD |
| 00101100111010101110100011011101 | 2CEAE8DD |
| 00101100111010101110100011011101 | 2CEAEE8DD |
| 01010001000100010001001000000010 | 51111202 |
| 0111110111111011111101011011111 | 7DFBFADF |

Operation: An inclusive OR operation is performed with the word from the odd numbered private memory register and the core memory word. The result is stored in the core memory word location.

Table 3-50. Store Selective, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (P) Effective word address <br> (Q) Next instruction address <br> (A) Contents of odd fast memory register (mask) <br> (CS) All ones |  |  |  |
| PHI <br> T4RL |  | SXPR <br> FUSTS <br> AXS <br> CXMB <br> DXC/10- <br> DXC/13 <br> DXC/6 <br> $\quad$ FAS6 <br> CSXI <br> $\quad$ (S/NPRX) <br> (S/CXRR) <br> (S/TIOL) | $\begin{aligned} & \text { FUSTS PHI NSDIS }+\ldots \\ & \text { OU4 OL7 } \\ & \text { FUSTS PHI }+\ldots \\ & \text { DGC } \\ = & \text { DXC } / 6+\ldots \\ = & \text { FAS6 PHI + ... } \\ = & \text { OU4 NO4 O5 O7 + ... } \\ = & (\mathrm{S} / \mathrm{NPRX})+\ldots \\ = & \text { FAS6 PHI + ... } \\ = & \mathrm{OU} 4 \mathrm{NO} 4 \mathrm{O} 5 \mathrm{O} 7 \mathrm{PHI} \\ & +\ldots \\ = & (\mathrm{S} / \mathrm{CXRR})+\ldots \end{aligned}$ | Load complement of mask in A-register <br> Load effective word into the D-register <br> Used for logical operation in PH2 <br> Preset for $R R \longrightarrow C$ in PH2 <br> Select clock in PH2 |
| $\begin{aligned} & \text { PH2 } \\ & \text { T10L } \end{aligned}$ | Set flip-flop LR31/2 <br> Enable signal T4RL | SXPR <br> NPRX <br> BXS <br> CXRR <br> S/LR31/2 <br> T4RL | $\begin{aligned} & =\text { NPRX } / 1 \text { NSDIS }+\ldots \\ & =\text { Set at PHI clock } \\ & =\text { FAS6 PH2 + } \ldots \\ & =\text { Set at PHI clock } \\ & =\text { FUSTS PH2 + ... } \\ & =\text { FUSTS PH2 }+\ldots \end{aligned}$ | Complement of mask AND gated with effective core memory word, and loaded in B-register via sum bus <br> Transfer word from fast memory register (even numbered word if R-field is even) to the C-register <br> Select odd fast memory register in PH3 <br> Select clock in PH3 |
| $\begin{aligned} & \text { PH3 } \\ & \text { T4RL } \end{aligned}$ | RR0-RR31 $\rightarrow$ A0-A31 | AXRR <br> LR3I | FUSTS PH3 + . . . <br> = Was set in PH2 | Transfer mask from the odd numbered fast memory register into the A register |

Mnemonic: STS (47, C7)

XDS 901060

Table 3-50. Store Selective, Phase Sequence (Cont.)


Table 3-51. Store Multiple, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (P) Storage address of first word <br> (Q) Next instruction address <br> (R) First word address in private memory register <br> (CCl-CC4) Word count |  |  |  |
| PHI <br> T4RI. | $\mathrm{CCl}-\mathrm{CC} 4 \rightarrow \mathrm{E} 4-\mathrm{E} 7$ <br> Set flip-flop PHA <br> Enable signal BRPHI <br> Enable signal T6L <br> Set flip-flop IEN | $\begin{aligned} & \text { EXCC } \\ & \text { FAST } \\ & \text { S/PHA } \\ & \text { BRPHI } \\ & \text { T6L } \\ & \\ & \text { S/IEN } \end{aligned}$ | $\begin{aligned} = & \text { FAST PHI O4 NO5 O6 } \\ = & \text { OU2 OLB NPHA }+\ldots \\ = & \text { FAST PH1 O2 }+\ldots \\ = & \text { FAST PH1 OLB O2 }+\ldots \\ = & \text { NTIL NT4L NT8L NT10L } \\ & \text { NRESET } \\ = & \text { FAST PH1 O4 NO5 O6 } \\ & +\ldots \end{aligned}$ | Transfer word count into the E-register <br> Advance to PHIA <br> Select clock in PHIA <br> Allows interrupt to be accepted at any clock pulse |
| $\begin{aligned} & \mathrm{PHIA} \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | $\text { RRO-RR31 } \rightarrow \text { A0-A31 }$ $R+1 \nrightarrow R$ <br> Enable signal MRQ <br> Enable signal (S/DRQ) <br> Reset flip-flop IEN <br> Enable signal (S/T8L) | AXRR <br> FASTA PCTR <br> MRQ <br> (S/DRQ) <br> EXU <br> R/IEN <br> (S/T8L) | $\begin{aligned} = & \text { FASTA PHI O4 NO5 O7 } \\ & +\ldots \\ = & \text { OU2 OLB PHA }+\ldots \\ = & \text { FASTA PHI O7 }+\ldots \\ = & \text { FASTA PHI }+\ldots \\ = & \text { FASTA EXU }+\ldots \\ = & \text { Was set during PREP phases } \\ = & \text { FASTA PHI }+\ldots \\ = & \text { FASTA PHI }+\ldots \end{aligned}$ | Transfer first word from fast memory register into the A-register <br> Increment fast memory address by one <br> Generate memory request for writing first word <br> Inhibits clock until data release signal received from core memory <br> Prevents interrupt from being accepted <br> Select clock in PH2A |
| $\begin{aligned} & \mathrm{PH} 2 \mathrm{~A} \\ & \mathrm{~T} 8 \mathrm{~L} \end{aligned}$ | $\begin{aligned} & A 0-A 31 \longrightarrow S 0-S 31 \\ & S 0-S 31 \longrightarrow M B 0-M B 31 \end{aligned}$ <br> If word count does not equal one $[\mathrm{N}(\mathrm{E}-1)]$ $\text { RR0-RR31 } \rightarrow \text { A0-A31 }$ | SXA <br> MBXS/0MBXS/3 <br> MW <br> AXRR | $\begin{aligned} = & \text { FASTA PH2 NSDIS }+\ldots \\ = & \text { MW }(\ldots)+\ldots \\ = & \text { FASTA PH2 }+\ldots \\ = & \text { FASTA PH2 N(E 1) NOL9 } \\ & +\ldots \end{aligned}$ | Store word in core memory <br> Transfer next word from fast memory register into the A-register |
|  |  |  |  | Mnemonic: STM (2B, AB) |

Table 3-51. Store Multiple, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\left\|\begin{array}{l} \mathrm{PH} 2 \mathrm{~A} \\ \mathrm{~T} 8 \mathrm{~L} \\ \text { (Cont.) } \end{array}\right\|$ | Enable signal $M R Q$ <br> Enable signal (S/DRQ) $P+1 \not P$ <br> Enable signal BRPH2 $R+1 \nsim R$ <br> $E-1 \longrightarrow E$ <br> If word count equals one Enable signal MRQ/1 <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Enable signal BRPHI3 <br> Enable signal (S/T8L) | MRQ <br> (S/DRQ) <br> CPTPI <br> BRPH2 <br> PCTR <br> MCTE 1 <br> MRQ/ 1 <br> PXQ <br> BRPHI3 <br> (S/T8L) |  | Generate memory request for next word to be stored <br> Inhibits clock until data release signal received from core memory <br> Increment P -register by one <br> Sustain PH2 until word count is reduced to one <br> Increment fast memory address by one <br> Decrement word count by one <br> Generate memory request for next instruction as specified by the Qregister <br> Load next instruction address into the P-register <br> Advance to PHI3A <br> Select clock in PHI3A |
| $\left\lvert\, \begin{aligned} & \mathrm{PHI} 3 \mathrm{~A} \\ & \mathrm{~T} 8 \mathrm{~L} \end{aligned}\right.$ | Enable signal ENDE <br> Set flip-flop PREI for the next instruction | ENDE S/PRE 1 | $\begin{aligned} = & \text { FASTA PHI } 3+\ldots \\ = & \text { ENDE NHALT } \\ & N(S / \text { INTRAPF })+\ldots \end{aligned}$ |  |

Mnemonic: STM (2B, AB)

Table 3-52. Store Conditions and Floating Control, Phase Sequence

| Phase | Function Performed | Signals Involved |  | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (Q) Next instruction address <br> (P15-P31) Effective address <br> (P32, P33) Zeros <br> (D24) CCl <br> (D25) CC2 <br> (D26) CC3 <br> (D27) CC4 <br> (D29) Floating significance (FS) <br> (D30) Floating zero (FZ) <br> (D31) Floating normalize (FN) |  |  |  |
| PHI T4RL | $\begin{aligned} & \text { D24-D31 } \longrightarrow \text { ADDER } \longrightarrow \text { S0-S7 } \\ & \text { SO-S7 } \longrightarrow \mathrm{MBO}-\mathrm{MB7} \end{aligned}$ <br> Enable signal $M R Q / 1$ <br> Enable signal (S/DRQ) <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Enable signal T6L | SXUAB <br> MBXS $/ 0$ <br> MWB <br> NP32, NP33 <br> MRQ/ 1 <br> (S/DRQ) <br> PXQ <br> T6L |  | Transfer byte from Dregister via adder to the high order byte of sum bus <br> Store byte in core memory location specified by the P -register. Byte contains condition codes and floating control bits <br> Generate memory request for next instruction, as specified by the Qregister <br> Inhibits transmission of another clock until data release signal is received from core memory <br> Load next instruction address into the P -register <br> Select clock in PH2 |
| $\begin{aligned} & \text { PH2 } \\ & \text { T6L } \end{aligned}$ | Enable signal ENDE <br> Set flip-flop PREI for the next instruction | ENDE S/PREI | FASI8 PH2 + . . . <br> ENDE NHALT <br> N(S/INTRAPF) + . . . |  |
|  |  |  |  | Mnemonic: $\operatorname{STCF}(74, \mathrm{~F} 4)$ |

BYTE ADDRESSING

| 0000000000000 | 19-BIT BYTE DISPLACEMENT |
| :---: | :---: |

HALFWORD ADDRESSING

| 00000000000000 | 18-BIT HALFWORD DISPLACEMENT |
| :---: | :---: |
|  |  |

WORD ADDRESSING


DOUBLEWORD ADDRESSING

| 0000000000000000 | 16-BIT DOUBLEWORD DISPLACEMENT |
| :---: | :---: |
| $T_{2} T_{3} T_{4} T_{5}{ }_{0} T_{1} 1_{8} T_{9} T_{10} T_{11} T_{12} T_{13} T_{14}$ |  |

Figure 3-153. Instruction Addressing, Integer Displacement

Table 3-53. Condition Code Settings

| CONDITION CODE FLIP-FLOPS |  |  |  | TYPE OF ADDRESSING* |
| :---: | :---: | :---: | :---: | :---: |
| CCl | CC2 | CC3 | CC4 |  |
| 0 | 0 | 0 | 0 | Byte (0) |
| 0 | 0 | 0 | 1 | Immediate Byte (1) |
| 0 | 1 | 0 | 0 | Halfword (4) |
| 1 | 0 | 0 | 0 | Word (8) |
| 1 | 0 | 0 | 1 | Immediate Word (9) |
| 1 | 1 | 0 | 0 | Doubleword (12) |

*Circled numbers indicate instruction groups listed in table 3-54

Table 3-54. Analyze Table for Opcode Groups

| X | $00+x$ | $20+X$ | $40+X$ | $60+x$ |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 00 \\ & 01 \\ & 02 \\ & 03 \end{aligned}$ | $\overline{\text { LCFI }}$ | AI <br> CI <br> LI <br> MI | TTBS <br> TBS <br> (1) $\qquad$ | $\begin{aligned} & \text { CBS } \\ & \text { MBS } \\ & \hline \text { EBS } \end{aligned}$ |
| $\begin{aligned} & 04 \\ & 05 \\ & 06 \\ & 07 \end{aligned}$ | CALI <br> CAL2 <br> CAL3 <br> CAL4 | $\begin{aligned} & \text { SF } \\ & \mathrm{S} \\ & \hline \\ & \hline \end{aligned}$ | ANLZ <br> CS <br> XW <br> STS | BDR <br> BIR <br> AWM <br> EXU |
| $\begin{aligned} & 08 \\ & 09 \\ & 0 A \\ & 0 B \end{aligned}$ | PLW <br> PSW <br> PLM <br> PSM | CVS <br> CVA <br> LM <br> (8) <br> STM | EOR <br> OR <br> LS <br> AND | $\begin{aligned} & \text { BCR } \\ & \text { BCS } \\ & \text { BAL } \\ & \text { INT } \end{aligned}$ |
| $\begin{aligned} & O C \\ & O D \\ & O E \\ & O F \end{aligned}$ | $\begin{aligned} & \bar{Z} \\ & \begin{array}{l} \text { LPSD } \\ \text { XPSD } \end{array} \end{aligned}$ | $\qquad$ <br> WAIT <br> LRP | SIO <br> TIO <br> TDV <br> HIO | RD <br> WD <br> AlO <br> MMC |
| $\begin{aligned} & 10 \\ & 11 \\ & 12 \\ & 13 \end{aligned}$ | AD <br> CD <br> LD <br> MSP | AW <br> CW <br> LW <br> MTW | AH <br> CH <br> LH <br> MTH | $\begin{aligned} & \text { LCF } \\ & \text { CB } \\ & \text { LB } \\ & \text { MTB } \end{aligned}$ |
| $\begin{aligned} & 14 \\ & 15 \\ & 16 \\ & 17 \end{aligned}$ | $\overline{\text { STD }}$ | STW <br> DW <br> MW | $\begin{aligned} & \overline{S T H} \\ & \mathrm{DH} \\ & \mathrm{MH} \end{aligned}$ | $\begin{aligned} & \text { STCF } \\ & \text { STB } \\ & \text { PACK } \\ & \text { UNPK } \end{aligned}$ |
| $\begin{aligned} & 18 \\ & 19 \\ & 1 \mathrm{~A} \\ & 1 \mathrm{~B} \end{aligned}$ | SD <br> CLM <br> LCD <br> LAD | SW <br> CLR <br> LCW <br> LAW | $\begin{aligned} & \frac{S H}{L C H} \\ & \text { LAH } \end{aligned}$ | DS <br> DA <br> DD <br> DM |
| $\begin{aligned} & 1 \mathrm{C} \\ & 1 \mathrm{D} \\ & 1 \mathrm{E} \\ & 1 \mathrm{~F} \end{aligned}$ | FSL <br> FAL <br> FDL <br> FML | FSS <br> FAS <br> FDS <br> FMS |  | $\begin{aligned} & \text { DSA } \\ & \text { DC } \\ & \text { DL } \\ & \text { DST } \end{aligned}$ |
| Note <br> Circled numbers indicate type of addressing on table 3-53 |  |  |  |  |

If the instruction is of the doubleword type, the A-register contents are shifted one bit position to the left and then two bit positions to the right. This is an effective shift of one bit position to the right. The result of these shifts is shown in figure 3-153. The modified word is stored in the addressed private memory register.

A sequence chart of the Analyze instruction is given in table 3-55.

## 3-189 Interpret (INT 6B, EB)

INT instruction causes bits zero through three of the core memory effective word to be loaded into the condition code flip-flops. Bits 4 through 15 are loaded into bit positions 20 through 31 of the private memory register addressed in the R-field of the instruction word, and bits 16 through 31 of the effective word are loaded into bit positions 16 through 31 of the odd numbered private memory register. Zeros are loaded into the remaining bit positions.

If the private memory register addressed in the R-field is an odd numbered register, bits 16 through 31 of the core memory effective word are loaded into bit positions 16 through 31 of the odd numbered register. Zeros are loaded into bit positions 0 through 15 of the private memory register.

Bits 4 through 15 of the core memory word are loaded into bit positions 20 through 31 of the D-register, and bits 0 through 19 are forced to 0 . The result is stored in the private memory register specified in the R-field of the instruction. The entire memory word is then clocked into the $D$ register, and the odd numbered private memory register is cleared which may or may not be the register addressed above. Bits 0 through 3 of the operand in the D-register are transferred to condition code flip-flops CCl through CC4. Bits 16 through 31 of the core memory word are loaded into the odd numbered private memory register by setting the private memory write byte signals for bytes 2 and 3.

A sequence chart of the Interpret instruction is given in table 3-56.

## 3-190 Add Immediate (AI 20)

Add Immediate is an immediate addressing type instruction in which bits 12 through 31 of the instruction word are treated as a 20-bit two's complement integer.

The Al instruction causes the sign bit of the integer (bit 12) to be extended 12 bit positions to the left which forms a 32 -bit addend. This addend is added to the 32-bit word contained in the private memory register addressed in the R-field of the instruction word. The sum is stored in the addressed private memory register.

The sign in the D-register is extended into bits 0 through 11 during the preparation phases. The contents of the addressed private memory register are loaded into the

A-register. This value is gated into the adder with the contents of the D-register. The sum on the sum bus is stored in the selected private memory register, and the contents of the sum bus are also clocked into the A-register to allow the setting of appropriate condition code flip-flops.

The instruction traps to location $X^{\prime} 43$ ', if condition code flip-flop CC2 is set and if the trap mask flip-flop in the PSD contains a one. The instruction traps in the preparation phases, if indirect addressing is attempted (see paragraph 3-141 for trap sequencing).

Table 3-57 is a sequence chart of the Add Immediate instruction.

## 3-191 Add Halfword (AH 50, D0)

The AH instruction selects the desired halfword from the effective core memory location and extends the sign bit 16 bit positions to the left. The resulting 32-bit addend is then added to the data word contained in the private memory register addressed in the R-field. The sum is stored in the private memory register.

During the preparation phases, the least significant bit (LSB) of the index register contents is moved into flip-flop P32 to select the desired halfword in the memory location. The indexing data is read into the A-register. The contents are shifted one bit position to the right. The operand address in the D-register and the indexing data in the A-register are added. This modified program address is transferred to the P -register. The selected halfword from memory is loaded into the $D$-register, and the value from the selected private memory register is clocked into the A-register. These two values are gated into the adder. The sum is transferred to the selected private memory register and to the A-register. The contents of the adder and the A-register are tested for condition code and trap information. The program traps to location $X^{\prime} 43$ ' after loading the results into private memory, if overflow has occurred and the fixed-point arithmetic trap mask bit in the PSD is set.

Table 3-58 is a sequence chart of the Add Halfword instruction.

## 3-192 Add Word (AW 30, B0)

The AW instruction causes the data word from the reference address location in core memory to be added to the data word from the private memory register addressed in the Rfield of the instruction word. The sum is stored in the addressed private memory register.

The operand from core memory is transferred to the Dregister, and the value in the addressed private memory register is transferred to the A-register. These two values are gated into the adder, and the sum is loaded into the selected private memory register. The sum is also stored in the A-register. The adder and the A-register contents are tested for condition code and overflow information.

Table 3-55. Analyze, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{aligned} & \text { PHI } \\ & \text { T4RL } \end{aligned}\right.$ | $\begin{aligned} & \mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & \mathrm{Cl}-\mathrm{C} 7 \rightarrow \mathrm{O} 1-\mathrm{O} 7 \end{aligned}$ <br> Inhibit generation of signal LMXC <br> Set flip-flop ANLZ <br> Set flip-flop PREI <br> Inhibit setting of flip-flop PH2 <br> Enable clock T8L | DXC <br> OXC <br> LMXC <br> S/ANLZ <br> S/PREI <br> S/PH2 <br> BRPH2 <br> NBR <br> S/T8L | $\begin{aligned} = & \text { FUANLZ NANLZ PHI }+\ldots \\ = & \text { FUANLZ NANLZ PHI }+\ldots \\ = & \text { NAR (NPH1 + NFUANLZ } \\ & + \text { SW2 })+\ldots \\ = & \text { FUANLZ PHI } \\ = & \text { FUANLZ NANLZ PHI } \\ & \text { N(S/INTRAPF) }+\ldots \\ = & \text { BRPH2 NCLEAR + PHI NBR } \\ = & \text { PHI NBR } \\ = & \text { NFUANLZ }+ \text { ANLZ (. . .) } \\ = & \text { FUANLZ PHI NANLZ + ... } \end{aligned}$ | Instruction to be analyzed <br> Opcode of instruction to be analyzed <br> To ensure that reference address of new instruction is not read onto LM and LB address lines <br> To perform preparation sequence for new instruction |
| $\begin{array}{\|l\|} \text { PRE } \\ \hline \text { TBL } \end{array}$ | Normal preparation sequence except as follows: <br> Inhibit signal QXP <br> Inhibit memory requests except for indirect addressing <br> Set flip-flop SW2 <br> Set condition code flip-flops to indicate opcode class <br> If flip-flop is not set, generate signal ANLZ/1 | $\begin{aligned} & \text { QXP } \\ & \mathrm{S} / \mathrm{RQ} \\ & \mathrm{PRERQ} \\ & \mathrm{RQC} \\ & \mathrm{~S} / \mathrm{SW} 2 \\ & \mathrm{~S} / \mathrm{CCl} \\ & \mathrm{~S} / \mathrm{CC} 2 \\ & \mathrm{~S} / \mathrm{CC} 4 \\ & \mathrm{ANLZ} / 1 \end{aligned}$ | ```:= PREI NANLZ + ... PRERQ PREI NIA NINDXX =- NOL3 NANLZ + ... - PREI NINDX PREOPRQ/2 NANLZ + . . . = ANLZ PREI + ... = FADW (ANLZ PREI) + ANLZ PRE1 FAIM (NO1 NO3) (NO4 NO5) + (ANLZ PREI) FAW + ... = OU5 (ANLZ PRE1) + FADW ANLZ PREI + ... = FAIM ANLZ PREI + ... = ANLZ NCC4``` | To compute effective address <br> Prohibit clocking operand address into Q-register <br> Allowed for indirect addressing <br> To control address gating term LMXC <br> Immediate word type, doubleword type, and word type <br> Doubleword and halfword class <br> Immediate class |
| END PREP T4RL | Generate signal (S/PHI/I) <br> Set flip-flop PHI <br> Force ANLZ opcode into O-register Enable T4RL | $\begin{aligned} & (\mathrm{S} / \mathrm{PHI} / 1) \\ & \\ & \mathrm{S} / \mathrm{PHI} \\ & \mathrm{OX} / \mathrm{I} \\ & \mathrm{~T} 4 \mathrm{RL} \end{aligned}$ | $\begin{aligned} = & \text { NPREDO (PRE2 NIA) } \\ & + \text { PREDO NIX (PRE2 NIA) } \\ & + \text { PRE3 NIA } \\ = & (S / P H I / 1) \text { NCLEAR }+\ldots \\ = & (S / P H I / 1) \text { ANLZ }+\ldots \\ & \text { PREP }+\ldots . \end{aligned}$ |  |
|  |  |  | ued) | Mnemonic: $\begin{aligned} & \text { ANLZ } \\ & (44, C 4) \end{aligned}$ |

Table 3-55. Analyze, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PHI <br> (Cont.) <br> T4RL | If signal ANLZ/1 is true, gate P15-P31 $\longrightarrow$ S15-S31 <br> If a byte addressing class, gate signals <br> P32 and P33 into S0 and S1 <br> Clock S0-S31 $\longrightarrow$ A0-A31 <br> Clear D-register <br> Generate memory request for next instruction <br> Q15-Q31 $\rightarrow$ P15-P31 <br> P15-P31 $\longrightarrow$ LM15-LB31 <br> Set flip-flop PH2 <br> Enable clock T6L |  | Address gated onto sum bus if not immediate addressing <br> Byte addressing bits <br> Byte or halfword addressing bit <br> If not immediate addressing <br> Address of next instruction |
| $\left\lvert\, \begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}\right.$ | If signal ANLZ/1 is true, A0-A31 $\longrightarrow$ SO-S31 $\mathrm{S} 1-\mathrm{S} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 30$ $S C \xrightarrow{\rightarrow} A 31$ <br> Set flip-flop PH3 <br> Enable clock T6L | SXA $=$ $($ NCC1 +CC2) PH2 ANLZ/1 <br>  $+\ldots$ <br> AXSLI $=$ $($ NCCI + CC2) PH2 ANLX $/ 1$ <br>  $+\ldots$ <br> A3IEN $/ 2=$ SO ALCYC <br> ALCYC $=$ NFAMDSF <br> S/PH3 $=$ PH2 NBR N(FNANLZ <br>  NANLZ $+\ldots$ <br> T6L $=$ NTILNT4L NT8L NTIOL <br>  NRESET | Byte, halfword, or double word <br> Cyclic left shift into Aregister |
| $\left\lvert\, \begin{aligned} & \text { PH3 } \\ & \text { T6L } \end{aligned}\right.$ | If a byte class instruction, $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow$ S0-S31 $\begin{aligned} & \mathrm{S} 1-\mathrm{S} 31 \rightarrow \mathrm{~A} 1 \mathrm{~A}-\mathrm{A} 30 \\ & \mathrm{~S} 0 \rightarrow \mathrm{~A} 31 \end{aligned}$ <br> If doubleword class, A0-A31 $\longrightarrow \text { PRO-PR31 }$ $\text { PRO-PR29 } \nrightarrow \text { A2-A31 }$ <br> Set flip-flop DRQ | SXA $=$ NCC1 NCC2 PH3 ANLZ/1 <br>  $+\ldots$ <br> AXSLI $=$ NCC1 NCC2 PH3 ANLZ/1 <br>  $+\ldots$ <br> AXPRR2 $=$  <br> $=$  <br>  $+\ldots$ <br> SCI CC2 PH3 ANLZ/1  <br>   <br> SRR $=$ PH3 ANLZ $+\ldots$ | Cyclic left shift into Aregister. Byte address now in bits 30 and 31 <br> Doubleword class shifted two bit places to the right ( 16 bit displacement value) <br> Inhibits transmission of another clock until signal received |
| (Continued) |  |  | Mnemonic: ANLZ $(44, C 4)$ |

Table 3-55. Analyze, Phase Sequence (Cont.)


Table 3-56. Interpret, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (P) Effective word address <br> (Q) Next instruction address <br> (R) R-field |  |  |  |
| $\begin{aligned} & \text { PHI } \\ & \text { T4RL } \end{aligned}$ | $\mathrm{MBO}-\mathrm{MB31} \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ $\mathrm{C} 4-\mathrm{Cl} 5 \xrightarrow{\longrightarrow} 20-\mathrm{D} 31$ <br> Enable signal (S/T8L) <br> Zeros $\rightarrow$ D0-D19 | $\begin{aligned} & \text { CXMB } \\ & \\ & \text { DXCR16/2 } \\ & \text { DXC/9 } \\ & \text { FUINT } \\ & \text { (S/T8L) } \\ & \text { DX } \end{aligned}$ | $\begin{aligned} & =\text { DG } \\ & =\mathrm{DXC} / 9+\ldots \\ & =\text { FUINT PHI } \\ & =\text { OU6 OLB } \\ & =\text { FUINT EXU NEDNE }+ \\ & =\text { DXC } / 9 \end{aligned}$ | Operand gated from core memory into the C-register when data gate signal received from core memory <br> Bits 4 through 15 are loaded into the even private memory register during PH2 <br> Select clock in PH2 |
| $\begin{array}{\|l\|l} \mathrm{PH} 2 \\ \mathrm{~T} 8 \mathrm{~L} \end{array}$ | $\begin{aligned} & \text { D0-D31 } \longrightarrow \text { S0-S31 } \\ & \text { S0-S31 } \longrightarrow \text { RW0-RW31 } \end{aligned}$ $C 0-C 31 \rightarrow D 0-D 31$ <br> Enable signal $M R Q / 1$ <br> Q15-Q31 $\nrightarrow$ P15-P31 <br> Enable signal (S/LR31/2) <br> Enable signal (S/T8L) | SXD <br> RWXS/0- <br> RWXS/3 <br> RW <br> DXC/6 <br> $M R Q / 1$ <br> PXQ <br> (S/LR31/2) <br> (S/T8L) | $\begin{aligned} & =\text { FUINT } 07 \text { PH2 }+\ldots \\ & =\text { RW }+\ldots \\ & =\text { FUINTPH2 }+\ldots \\ & =\text { FUINT PH2 }+\ldots \\ & =\text { FUINTPH2 }+\ldots \\ & =\text { MRQ } 1+\ldots \\ & =\text { FUINT PH } 2+\ldots \\ & =\text { FUINT EXU NENDE }+ \end{aligned}$ | Load bits 4 through 15 in the even numbered private memory register <br> Clock operand into the D-register <br> Generate memory request for next instruction, as specified by the Q-register <br> Load next instruction address into the P -register <br> Used in PH3 for selecting odd numbered private memory register <br> Select clock in PH3 |
| $\begin{aligned} & \mathrm{PH} 3 \\ & \mathrm{~T} 8 \mathrm{~L} \end{aligned}$ | SO-S31 $\longrightarrow$ RWO-RW31 $[\mathrm{R}+1]$ | $\begin{gathered} \text { RWXS/0- } \\ \text { RWXS/3 } \\ \text { RW } \end{gathered}$ | $\begin{aligned} & =\mathrm{RW}+\ldots \\ & =\text { FUINT PH3 + ... } \end{aligned}$ | S0-S31 presently contain all zeros, causing the odd numbered private memory register to be cleared. During PH4, data is written intobits 16 through 31 of the odd numbered private memory register, leaving bits 0 through 15 clear |
| (Continued) |  |  |  | Mnemonic: INT <br>  $(6 \mathrm{~B}, \mathrm{~EB})$ |

Table 3-56. Interpret, Phase Sequence (Cont.)


Table 3-57. Add Immediate, Phase Sequence


Table 3-57. Add Immediate, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH5 <br> T10L <br> (Cont.) | Set flip-flop TESTA <br> Enable signal ENDE <br> Set flip-flop PREI for the next instruction |  | $B R Q$ causes the return address to reflect the address of the instruction being executed at the time of the trap |
| Next clock | Test word in A-register, and set flip-flops CC3 and CC4 <br> If word is positive, set flip-flop CC3; if word is negative, set flipflop CC4; if word is zero, reset flip-flops CC3 and CC4 | S/CC3 $=$ NA0 NA0031Z TESTA <br>  $(\ldots)+\ldots$ <br> NA0031Z $=$ A-register does not contain <br>  all zeros <br> R/CC3 $=:$ TESTA <br> S/CC4 $=$ A0 TESTA NTESTA $/ 1+\ldots$ <br> R/CC4 $==$ TESTA |  |
|  |  |  | Mnemonic: Al (20) |

Table 3-58. Add Halfword, Phase Sequence


Table 3-58. Add Halfword, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH5 } \\ & \text { T10L } \end{aligned}$ | $\mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> If end carry, set flip-flop CCl <br> If overflow, set flip-flop CC2 <br> If overflow, and bit 11 of the PSW is a one (trap mask), enable signal TROVER, and set flip-flops TRAP, TR30, TR31, and BRQ <br> Set flip-flop TESTA <br> Enable signal ENDE <br> Set flip-flop PREI for the next instruction |  | Add halfword (D-register) to augend (A-register) and place result on sum bus <br> Store result in private memory register <br> Store result in A-register. Used during next phase for testing result |
|  |  | (Continued) | Mnemonic: AH (50, D0) |

Table 3-58. Add Halfword, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| Next clock | Test word in A-register, and set flip-flops CC3 and CC4 <br> If word is positive, set flip-flop CC3; if word is negative, set flip-flop CC4; if word is zero, reset flip-flops CC3 and CC4 | $\begin{aligned} \text { S/CC3 }= & \text { NA0 NA0031Z TESTA } \\ & (\ldots)+\ldots \\ \text { NA0031Z }= & \text { A-register does not contain } \\ & \text { all zeros } \\ \text { R/CC3 }= & \text { TESTA } \\ \text { S/CC4 }= & \text { A0 TESTA NTESTA } 1+\ldots \\ \text { R/CC4 }= & \text { TESTA } \end{aligned}$ |  |

Mnemonic: AH (50, D0)

The program traps to location $X^{\prime} 43^{\prime}$ after loading the results into private memory, if overflow has occurred, and the fixedpoint arithmetic trap mask bit of the PSD is set.

A sequence chart of the Add Word instruction is given in table 3-59.

3-193 Add Doubleword (AD 10, 90)
Instruction AD causes the effective doubleword from core memory to be added to the contents of an even and an odd numbered private memory register. The low order 32 bits of the sum are stored in the odd numbered private memory register, and the 32 high order bits are stored in the even numbered private memory register.

The one's complement of low order half of the core memory doubleword is loaded into the D-register. The low order half of the doubleword in the selected private memory registers is loaded into the A-register. Flip-flop CS31 is set to form the two's complement of the word in the D-register. The A-, D-, and CS-register outputs are gated into the adder, and the addition is an effective subtraction of the core memory word from the private memory word. The result is loaded into the odd numbered private memory register, and into the A-register to be tested for a zero condition. The one's complement of the high order half of the core memory doubleword is loaded into the D-register, and the high order half of the private memory doubleword is loaded into the A-register. The A-, the D-, and the CS-register outputs are gated into the adder, and the addition completes the effective subtraction mentioned above. The result is transferred to the even numbered private memory register.

A sequence chart of the Add Doubleword instruction is given in table 3-60.

## 3-194 Subtract Halfword (SH 58, D8)

The SH instruction causes a word to be read from a referenced memory address. The instruction selects the desired halfword and extends the sign bit 16 bit positions to the left. The two's complement is obtained; the resulting 32-bit word is added to the data word contained in the addressed private memory register. The sum is stored in the private memory register.

The index value is read into the A-register, and is shifted one bit position to the right, during the preparation phases. The halfword select bit in the least significant position is clocked into flip-flop P32. The operand address in the Dregister and the indexing data in the A-register are placed in the adder, and the modified program address is clocked into the P -register.

During the execution phases, the one's complement of the most or the least significant halfword, depending on the state of flip-flop P32, is clocked into the D-register. Flipflop CS31 is set to form the two's complement. The data word in the selected private memory register is loaded into the A-register. These values are added in the adder which
results in algebraically subtracting the core memory data word from the data word in private memory. The result is transferred to the selected private memory register, and to the A-register to test for a non-zero value and for condition code information. The program traps to location X'43' after loading the contents of the sum bus into private memory, if the sign bit changes, which indicates fixed-point overflow, and if the fixed-point arithmetic trap mask bit in the PSD is set.

A sequence chart of the Subtract Halfword instruction is given in table 3-61.

## 3-195 Subtract Word (SW 38, B8)

The SW instruction causes a word to be read from a referenced memory address. The two's complement of the word is obtained and is added to the data word contained in the addressed private memory register. The sum is stored in the private memory register.

The one's complement of the word in memory is clocked into the D-register. Flip-flop CS31 is set to form the two's complement in the adder. The data word from the selected private memory register is loaded into the A-register. The outputs of the A- and D-registers are gated into the adder where the addition performed results in the effective algebraic subtraction of the core memory word from the word in private memory. The result is transferred to the selected private memory register, and to the A-register to be tested for overflow and condition code information. The program traps to location $X^{\prime} 43^{\prime}$ after loading the result into the private memory register, if the sign bit changes, which indicares fixedpoint overflow, and the fixed-point arithmetic trap mask bit in the PSD is set.

Table 3-62 is a sequence chart of the Subtract Word instruction.

## 3-196 Subtract Doubleword (SD 18, 98)

The SD instruction causes two data words to be read from successive core memory locations. The two's complement of the 64-bit data word is obtained and is added to the contents of an even and an odd numbered private memory register. The low order 32-bits of the sum are then stored in the memory register, and also in the A-register where they are tested for overflow and condition code information. If fixedpoint overflow occurs, and if the fixed-point arithmetic trap mask bit in the PSD is set, the program traps to location $X^{\prime} 43^{\prime}$ after loading the result into the private memory registers.

A sequence chart of the Subtract Doubleword is given in table 3-63.

The low order half of the addend from core memory is loaded into the D-register, and the low order half of the augend from the odd numbered private memory register is loaded into the A-register. The two values are gated into the adder, and the sum is loaded into the odd numbered private memory register, and into the A-register to be tested for a nonzero condition.

Table 3-59. Add Word, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | At the end of PREP: <br> (O) Opcode <br> (P) Effective address <br> (Q) Next instruction address <br> (R) R-field |  |  |  |
| PHI <br> T4RL | $\text { MBO-MB31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ $C 0-C 31 \rightarrow D 0-D 31$ $R R 0-R R 31 \longrightarrow A 0-A 31$ <br> Enable signal (S/DRQ) <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Enable signal BRPH5 <br> Enable signal (S/T10L) | CXMB <br> DXC/10- <br> DXC/ 13 DXC/6 <br> AXRR-0, <br> AXRR-1, <br> AXRR/12, <br> AXRR/13 <br> AXRR <br> FAS12 <br> (S/DRQ) <br> PXQ <br> PRERQ <br> BRPH5 <br> (S/T10L) | $\begin{aligned} & =\text { DG } \\ & =\mathrm{DXC} / 6+\ldots \\ & =\mathrm{OU} 3 \mathrm{NO} 4 \mathrm{NO} 5 \mathrm{PHI}+\ldots \\ & =\text { AXRR }+\ldots \\ & =\text { FASI2 PHI + . . } \\ & =\text { OU3 NO5 NO6 NO7 + } \\ & =\text { FASI2 PHI + .. } \\ & =\text { PRERQ PHI + ... } \\ & =\text { OU3 NO5 }(\ldots)+\ldots \\ & =\text { FASI2 PHI }+\ldots \\ & =\text { FASI2 PHI }+\ldots \end{aligned}$ | Addend gated from core memory into the Cregister when data gate signal received from core memory. <br> Clock addend into the D-register <br> Transfer augend from fast memory register into the A-register <br> Inhibits transmission of another clock until data release signal received from core memory <br> Load next instruction address into the P -register <br> Advance to PH5 <br> Select clock in PH5 |
| $\begin{aligned} & \text { PH5 } \\ & \text { T10L } \end{aligned}$ | $\text { SO-S31 } \longrightarrow \text { RWO-RW31 }$ $\mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{AO}-\mathrm{A} 31$ <br> Set flip-flop TESTA | SXPR/10- SXPR/13 SXADD RWXS/10- RWXS/13 RW AXS S/TESTA R/TESTA | $\begin{aligned} & =\text { SXADD }+\ldots \\ & =\text { FAS12 PH5 NSDIS } \\ & =\text { RW }+\ldots \\ & =\text { FAS12 PH5 + . . } \\ & =\text { FAS12 PH5 }+\ldots \\ & =\text { FASI2 PH5 + . . } \\ & =\ldots \end{aligned}$ | Add addend ( $D$-register) to augend (A-register) and place result on sum bus <br> Store result in fast memory register <br> Store result in A-register. Used during next phase to test result |
| (Continued) |  |  |  | Mnemonic: AW (30, B0) |

Table 3-59. Add Word Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH5 <br> T10L <br> (Cont.) | Enable signal ENDE <br> Set flip-flop PRE1 for the next instruction <br> If end carry, set flip-flop CCl <br> If overflow, set flip-flop CC2 <br> If overflow and bit 11 of the PSW is a one (trap mask), enable signal TROVER and set flip-flops TRAP, TR30, TR31, and BRQ |  | Trap to location $X^{\prime} 43^{\prime}$ |
| Next clock | Test word in A-register, and set flip-flops CC3 and CC4 <br> If word is positive, set flip-flop CC3; if word is negative, set flip-flop CC4; if word is zero, reset flip-flops CC3 and CC4 | S/CC3 $=$ NA0 NA003IZ TESTA <br>  $(\ldots)+.\ldots$ <br> NA0031Z $=$ A-register does not contain <br>  all zeros <br> R/CC3 $=$ TESTA <br> S/CC4 $=$ AO TESTA NTESTA $/ 1+\ldots$ <br> R/CC4 $=$ TESTA |  |
|  |  |  | Mnemonic: AW (30, B0) |

Table 3-60. Add Doubleword Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | Same as general preparation sequence except <br> Force a one on LB31 address line to select odd numbered core memory word location <br> During PRE2, force a zero on LB3I address line to select even numbered core memory word by inhibiting flipflop P31 from setting <br> Generate a memory request for second half of doubleword <br> Force a one on LR31 address line to select odd numbered private memory register | LB31 <br> S/P31 <br> MRQ <br> S/LR31/2 | $\begin{aligned} = & \text { PREFADO LMXC NC0 } \\ = & \text { S31 PXS NP3IZ } \\ = & \text { PRE2 NIA PREDO NANLZ } \\ = & (\text { (S/PHI/1) } \\ & (\text { FAS3 N04 N05 N06) } \end{aligned}$ |  |
| PHI <br> T4RL | $\begin{aligned} & \mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & \mathrm{RRO} 0-\mathrm{RR} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 31 \end{aligned}$ <br> Set flip-flop DRQ <br> Force a one on LR31 address line | DXC <br> AXRR <br> S/DRQ <br> S/LR31/2 | $\begin{aligned} & =(\text { N01 03) (N04 N05 N07) } \\ & \text { PHI } \\ & =\text { FAS22 PHI } \\ & =\text { PREDO PHI } \\ & =\text { OUI (N05 N07) PHI } \end{aligned}$ | Low order half of doubleword from core memory <br> Low order half of doubleword from private memory <br> Inhibits transmission of another clock until signal received from memory <br> Selects odd numbered private memory register |
| PREP | At the end of PREP: <br> (O) Opcode <br> (P) Effective address <br> (P31) Reset <br> LB31 = 1 during PREI <br> LB31 - 0 during PRE2 <br> (Q) Next instruction address <br> (R) R-field <br> (LR31) Set | $\begin{array}{\|l} \text { LB̄3i } \\ \text { S/P31 } \\ \text { P3IZ } \end{array}$ | - PREFADO LMXC NCO + <br> -: S31 PXS NP3IZ <br> $\therefore$ PRE2 NIA FADW | Memory request for low order word was made in PREI, for high order word in PRE2 by inhibiting setting of P31 <br> Selects $\mathrm{R}+1$ in PHI |
| $\begin{array}{\|l\|} \text { PHI } \\ \text { T4RL } \end{array}$ | MBO-MB31 $\longrightarrow \mathrm{CO}-\mathrm{C} 31$ | CXMB | = DG | Low order half of addend doubleword gated into the C-register from core memory when data gate signal received from core memory |
|  |  |  |  | Mnemonic: AD (10, 90) |

Table 3-60. Add Doubleword, Phase Sequence (Cont.)


Table 3-60. Add Doubleword, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\left\|\begin{array}{l} \mathrm{PH} 2 \\ \text { (Cont.) } \end{array}\right\|$ | $\mathrm{C} 0-\mathrm{C} 31 \rightarrow \text { D0-D31 }$ <br> Enable signal T6RL | DXC/10- $=$ DXC $/ 6+\ldots$ <br> DXC $/ 13$ $=$ FUAD PH2 $+\ldots$ <br> DXC $/ 6$ $=$ OU1 OL0 <br> FUAD $=$ FAS3 PH2 $+\ldots$ <br> TRRL  | Clock high order half of addend doubleword into the $D$-register <br> Select clock in PH3 |
| PH3 <br> T6RL | Test contents of A-register. If nonzero, set flip-flop BWZ $\begin{equation*} \text { RRO-RR31 } \longrightarrow \text { A0-A31 } \tag{R} \end{equation*}$ <br> If flip-flop KOOH was reset in PH 2 , set flip-flop CS31 <br> Enable signal (S/DRQ) <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Enable signal BRPH5 <br> Enable signa! ( $\mathrm{S} / \mathrm{T} 10 \mathrm{~L}$ ) |  | Store nonzero condition in flip-flop BWZ <br> Transfer high order half of augend doubleword from the even fast memory register to the Aregister <br> Store end carry from low order addition in flipflop CS31 <br> Inhibits transmission of another clock until data release signal received from core memory <br> Load next instruction address into the P -register <br> Advance to PH5 <br> Select clock in PH5 |
| $\begin{aligned} & \text { PH5 } \\ & \text { TIOL } \end{aligned}$ | $\mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{RW} 0-\mathrm{RW} 31 \quad[\mathrm{R}]$ $\mathrm{S} 0-\mathrm{S} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> If $\mathrm{BW} Z, \quad 1 \longrightarrow \mathrm{~A} 31$ |  | Add high order half of addend doubleword to high order half of augend doubleword; incorporate end carry if any, and place result on sum bus <br> Store result in even fast memory register <br> Used for testing result during next clock |

Mnemonic: $A D(10,90)$
(Continued)

Table 3-60. Add Doubleword, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH5 <br> T10L <br> (Cont.) | Set flip-flop TESTA <br> Enable signal ENDE <br> Set flip-flop PRE 1 for the nexi instruction <br> If end carry, set flip-flop CCl <br> If overflow, set flip-flop CC2 <br> If overflow and bit 11 of the PSW is a one (trap mask), enable signal TROVER and set flip-flops TRAP, TR30, and TR31 |  | Trap to location $\mathrm{X}^{\prime} 43^{\prime}$ |
| Next clock | Test word in A-register, and accordingly, set flip-flops CC3 and CC4 <br> If word is positive (indicates that doubleword sum in private memory register is positive), set flip-flop CC3; if word is negative (indicates that doubleword sum in private memory register is negative), set flipflop CC4; if word is zero (indicates that doubleword sum in private memory register is zero), reset flip-flops CC3 and CC4 | S/CC3 NA0 NA003IZ TESTA <br> $(\ldots)$. <br> NA0031Z A-register does not contain <br> all zeros <br> R/CC3 TESTA <br> S/CC4 AO TESTA NTESTA/1 + . . <br> R/CC4 TESTA |  |
|  |  |  | Mnemonic: AD (10, 90) |

Table 3-61. Subtract Halfword, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PRE } 1 \\ & \text { T6L } \end{aligned}$ | D12-D14 $\longrightarrow$ LR29-LR31 | LRXD | - ENDE | Selects index register containing halfword select bit |
|  | Generate signal INDX | INDX | $\begin{aligned} & (\mathrm{Cl} 2+\mathrm{Cl} 3+\mathrm{Cl} 4)(\mathrm{C} 3+\mathrm{C} 4 \\ & +\mathrm{C} 5) \end{aligned}$ |  |
|  | P15-P31 $\rightarrow$ Q15-Q31 | QXP | - PREI NANLZ + . . |  |
|  | RR14-RR30 $\rightarrow$ A15-A31 | AXRRRI | - OU5 INDX PREI | Index data gated into Aregister shifted one bit right |
|  | RR31 $\longrightarrow$ P32 | S/P32 | - RR31 AXRRR1 | Halfword select bit |
|  | Set flip-flop IX | S/IX | - INDX PREI |  |
|  | Set flip-flop PRE2 | S/PRE2 | * NPREIM PREI N(S/INTRAPF) |  |
|  | Enable T4RL | T4RL | - PREP + |  |
| $\begin{aligned} & \text { PRE2 } \\ & \text { T4RL } \end{aligned}$ | $\begin{aligned} & \mathrm{A} 15-\mathrm{A} 31+\mathrm{D} 15-\mathrm{D} 31 \longrightarrow \\ & \mathrm{~S} 15-\mathrm{S} 31 \end{aligned}$ | SXADD | - PRE2 NIA + | Modified program address |
|  | S15-S31-PP15-P31 | PXS | - PRE2 NIA + . |  |
|  | P15-P31 $\longrightarrow$ LM15-LB31 | (NLMXC NLMXQ) | - PRE2 NIA NRIP + . | Address of operand from core memory |
|  | R28-R31 $\longrightarrow$ LR28-LR31 | (LRXR NLRXLB) | - NENDE | Address of operand from private memory |
|  | Generate memory request for next instruction | $S / R Q$ | - PRE2 NIA IX PRERQ + . |  |
|  | Set flip-flop PHI | $\mathrm{S} / \mathrm{PH} \mathrm{l}$ | - NPREDO PRE2 NIA + . |  |
|  | Enable T4RL | T4RL | - PREP + . |  |
|  | Reset IX flip-flop |  | PRE2 NIA |  |
| $\begin{array}{\|l\|} \text { PHI } \\ \text { T4RL } \end{array}$ | Q15-Q31 $\rightarrow$ P15-P31 | PXQ | - PRERQ PHI + . . | Address of next instruction <br> Most significant halfword Extend sign <br> Least significant halfword Extend sign <br> D-register contains inverse of selected halfword with inverted sign intended 16 places to the left |
|  | If NP32 is true, $\mathrm{NCO}-\mathrm{NCl} 5 \rightarrow$ D15-D31 and NMBO $\rightarrow$ D0-D15 | $\begin{aligned} & \text { DXNCR16-2 } \\ & \text { C0C16C12 } \end{aligned}$ | OU5 (04 N05 N07) PHI NP32 NMB0 NP32 CXMB/4 |  |
|  | If P32 is true, NC16-NC31 $\rightarrow$ D16-D31 and NMB16 $\rightarrow$ D0-D15 | $\begin{aligned} & \text { DXNC } \\ & \mathrm{COCl} 16 \mathrm{Cl} \end{aligned}$ | OU5 (04 N05 N07) PHI P32 NMB16 P32 CXMB/4 |  |
|  |  |  |  |  |
|  | Force a one into flip-flop CS31 | $s / C s 31$ | $\begin{aligned} & \text { CSXI :- OU5 (04 N05 N07) } \\ & \text { PHI } \end{aligned}$ | To obtain two's complement |
|  | RRO-RR31 $\rightarrow$ A0-A31 | AXRR | - FASI2 PHI + . . | Addend from private memory |
|  |  |  |  | Mnemonic: SH (58, D8) |

Table 3-61. Subtract Halfword, Phase Sequence (Cont.)


Table 3-62. Subtract Word, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | Same as general preparation sequence except that during PREI a memory request is generated for the next instruction | S/RQ | NIA PREI NINDX PRERQ |  |
| $\begin{array}{\|l\|} \hline \mathrm{PHI} \\ \mathrm{~T} 4 \mathrm{RL} \end{array}$ | Q15-Q31 $\longrightarrow$ P15-P31 | PXQ | PRERQ PHI + | Address of next instruction |
|  | $\mathrm{NCO}-\mathrm{NCl5}+\rightarrow$ D0-D15 | DXNC/1 | (N01 03) (04 N05 N07) PH1 | One's complement of data word from core memory |
|  | Force a one into flip-flop CS31 | S/CS31 | DXNC/I | To obtain two's complement |
|  | RRO-RR31 $\rightarrow$ A0-A31 | AXRR | FASI2 PHI + . . | Data word from private memory |
|  | Set flip-flop DRQ | S/DRQ | $=$ FASI2 PHI + | Inhibits transmission of another clock until data signal received from memory for next instruction |
|  | Set flip-flop PH5 | S/PH5 | - BRPH5 - FAS12 PHI +. |  |
|  | Enable clock T10L | S/T10L | $=\mathrm{FASI} 2 \mathrm{PHI}+$. |  |
| PH5 <br> T10L | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31+\mathrm{CS} 31 \longrightarrow \\ & \mathrm{SO}-\mathrm{S} 31 \end{aligned}$ | SXADD | - FAS12 PH5 + | Algebraic subtraction of data word from core memory from data word from private memory |
|  | $\text { SO-S31 } \longrightarrow \text { RWO-RW31 }$ <br> Generate write byte signals RWB0-RWB3 | RWXS | - FASI2 PH5 + |  |
|  |  | RWB0-RWB3 | RW FAS12 PH5 + | Result of subtraction stored in private memory register |
|  | $\mathrm{SO}-\mathrm{S31} \longrightarrow \mathrm{~A} 0-\mathrm{A} 31$ | AXS | - FASI2 PH5 + | For condition code and overflow tests |
|  | Generate signal ENDE | ENDE | - FASI2 PH5 + . . |  |
|  | Set flip-flop TESTA | S/TESTA | \% FASI2 PH5 + . . . |  |
|  | If word in $A$ is all zeros, reset flipflops CC3 and CC4; if word is negative (A0), set flip-flop CC4 and reset flip-flop CC3; if word is positive (NA0), set flip-flop CC3 and reset flip-flop CC4 <br> If fixed-point overflow occurs, set flip-flop CC2; if a carry exists from bit position zero, set flip-flop CC1 | S/CC3 | - NTESTA/I TESTA NA0 + . . . NA0031Z |  |
|  |  | R/CC3 | $-\quad \text { TESTA + }$ |  |
|  |  | S/CC4 | $=$ NTESTA/1 TESTA A0 $+\ldots$ |  |
|  |  | R/CC4 | $=$ TESTA + . . |  |
|  |  | S/CC2 | - PROBEOVER OVER + . . . |  |
|  |  | $\mathrm{R} / \mathrm{CC} 2$ | - PROBEOVER + . . . |  |
|  |  | $\mathrm{S} / \mathrm{CCl}$ | - FASI2 PH5 K00 + . . |  |
|  |  | $\mathrm{R} / \mathrm{CCl}$ | $\because$ FASI2 PH5 + . . |  |
|  |  |  |  | Mnemonic: SW (38, B8) |

Table 3-62. Subtract Word, Phase Sequence (Cont.)


XDS 901060

Table 3-63. Subtract Doubleword, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | Same as general preparation sequence except <br> Force a one onto LB31 address lines <br> Force a one onto LR31 address line <br> During PRE2, force a zero onto LB31 address line by inhibiting flip-flop P31 from setting <br> Generate a memory request for high order half of doubleword | $\begin{aligned} & \text { LB31 } \\ & \text { S/LR31/2 } \\ & \text { NP31Z } \\ & \text { P31Z } \end{aligned}$ <br> MRQ | $\begin{aligned} = & \text { PREFADO LMXC NC0 }+\ldots \\ = & (\mathrm{S} / \mathrm{PHI} / 1) \text { OUI NO4 NO5 } \\ & \mathrm{NO} 6+\ldots \\ = & \text { NPRE2 + IA + NFADW } \\ = & \text { PRE2 NIA FADW } \\ = & \text { PRE2 NIA PREDO NANLZ } \\ & +\ldots \end{aligned}$ | Selects address for low order half of doubleword <br> Selects low order half of doubleword from private memory <br> Selects even numbered core memory location for high order half of doubleword |
| $\begin{aligned} & \mathrm{PHI} \\ & \mathrm{~T} 4 \mathrm{RL} \end{aligned}$ | $\begin{aligned} & \mathrm{NCO}-\mathrm{NC} 31 \rightarrow \text { D0-D31 } \\ & \text { RR0-RR31 } \rightarrow \text { A0-A31 } \end{aligned}$ <br> Set flip-flop DRQ <br> Force a one onto LR3I address line <br> Generate memory request for next instruction <br> Force a one into flip-flop CS31 <br> Set flip-flop PH2 <br> Enable clock T10L | DXNC AXRR S/DRQ S/LR31/2 S/RQ $S / C S 31 / 1$ $S / P H 2$ $S / T 10 L$ | $\begin{aligned} & =\text { FAS2 PHI }+\ldots \\ & =\text { FAS22 PHI }+\ldots \\ & =\text { PREDO PHI }+\ldots \\ & =\text { OUI (NO5 NO7) PHI }+\ldots \\ & =\text { OUI (NO5 NO7) PHI }+\ldots \\ & - \text { DXNC } \\ & =\text { PHI NBR N(FNANLZ } \\ & \text { NANLZ) }+\ldots \\ & =\text { FAS3 PHI + . . } \end{aligned}$ | Complement of low order half of data word <br> Low order half of data word from private memory <br> Inhibits transmission of another clock until data signal received <br> Odd numbered private memory register to store low order half of sum <br> To form two's complement of memory word |
| PH2 | $\begin{aligned} & \text { A0-A31 + D0-D31 +CS31 } \\ & \text { S0-S31 } \end{aligned}$ <br> If end carry occurs, reset flip-flop KOOH $\text { SO-S31 } \longrightarrow \text { RW0-RW31 }$ <br> Generate write byte signals RWBO-RWB3 $\begin{aligned} & S 0-S 31-A 0-A 31 \\ & M B O-M B 31-C 0-C 31 \end{aligned}$ | $\begin{aligned} & \text { SXPR } \\ & \text { S/K00H } \\ & \text { RWXS } \\ & \text { RWBO-RWB3 } \\ & \text { AXS } \\ & \text { CXMB } \end{aligned}$ | $\begin{aligned} & =\text { SXADD }=\text { FAS22 PH2 }+\ldots \\ & =\text { NK00 }+\ldots \\ & =\text { FAS3 PH2 }+\ldots \\ & =\text { RW }=\text { FAS3 PH2 }+\ldots \\ & =\text { FAS22 PH2 }+\ldots \\ & =\text { DGC } \end{aligned}$ | Addition of low order half of doubleword <br> Sum of low order addition stored in odd numbered private memory register <br> For zern testing <br> High order half of doubleword from core memory |
| (Continued) $\quad$ Mnemonic: SD (18,98) |  |  |  |  |

Table 3-63. Subtract Doubleword, Phase Sequence (Cont.)


Table 3-63. Subtract Doubleword, Phase Sequence (Cont.)


The high order half of the addend is then loaded into the D-register, and the high order half of the augend from the even numbered private memory register is clocked into the A-register. These two values are gated into the adder, and the sum is clocked into the even numbered private memory register, and into the A-register to be tested for condition code and trap information. The program traps to location X'43' after loading the result into private memory if fixedpoint overflow occurs, and if the fixed-point arithmetic trap mask bit in the PSD is set.

## 3-197 Multiply Word (MW 37, B7), Multiply Immediate (MI 23), and Multiply Halfword (MH 57, D7)

Instructions MW, MI, and MH are similar in implementation and result and are discussed as a group. Specific differences are noted in the discussion.

Instruction MW multiplies the contents of an odd numbered private memory register by the effective word from core memory. If the R-field of the instruction word is an even value, the 32 lower order bits of the product are stored in the odd numbered private memory register, and the 32 high order bits of the product are stored in the even numbered private memory register. If the $R$-field is an odd value, only the 32 lower order bits of the product are stored in the odd numbered private memory register.

Instruction MI extends the sign of the value field (bit position 12) of the instruction word 12 bit positions to the left. The resulting 32 -bit value is then multiplied by the contents of an odd numbered private memory register in the same manner as instruction MW.

Instruction MH multiplies the contents of bit positions 16 through 31 of an even or odd numbered private memory register by the effective halfword from core memory. The 32bit product is stored back in the odd numbered register if the R-field of the instruction word is odd. If the R-field is even, the 32 -bit product is stored in the odd numbered private memory register; the even numbered register retains the original multiplier.

Instructions MW and MI utilize condition code bits 2 through 4. Instruction MH uses only the third and fourth
bits of the condition code. Table 3-64 lists the condition codes for the three instructions.

3-198 MULTIPLICATION BY BIT-PAIRS AND CARRY-SAVE ADDITION. The Sigma 7 computer uses bit-pair multiplication and carry-save addition for implementation of instructions MW, MI, and MH. A review of single-bit multiplication may help in understanding bit-pair multiplication techniques.

Single-bit multiplication by repeated addition is illustrated in figure 3-154. In this example, four-bit registers are used for both the multiplicand (the number to be multiplied) and the multiplier. An eight-bit register is used to hold the product. (The number of bits in the product is never greater than the total of the number of multiplicand bits, and multiplier bits.) Sign bits are not used in this example.
The multiplier is examined one bit at a time, starting with the least significant digit (LSD). If the bit examined is a zero, all zeros are added to the partial product in the product register. If the bit examined is a one, the multiplicand or the appropriate multiple of the multiplicand (two times the multiplicand, four times the multiplicand, and so forth) is added to the partial product. After each examination and addition, the multiplicand is shifted left one bit position. Alternately, the partial product is shifted one bit position to the right. The previous example and the Sigma 7 computer use the latter type of shift. One iteration is required for each bit of the multiplier.
Bit-pair multiplication reduces the number of iterations required by examining two bits of the multiplier at one time and by performing one addition or one subtraction for that bit pair.
There are four permutations of two bits; 00, 01, 10, and 11 . Multiplying by the first three types of bit pairs is done by normal shift and add operations: Multiplying by bit pair 00 is done by adding zeros to the partial product; multiplying by bit pairs 01 and 10 is done by adding the multiplicand, or two times the multiplicand, respectively, to the partial product. Multiplying by bit pair 11 is a special case.
Multiplication by 3 cannot be represented by a factor of 2 ; simply shifting the multiplicand and adding is not possible in this case. To multiply by this bit pair, one times the multiplicand is subtracted from the partial product during

Table 3-64. Instruction MW, MI, and MH Condition Codes

| Description | CC1 | CC2 | CC3 | CC4 | Meaning |
| :---: | :---: | :---: | :---: | :---: | :--- |
| Instructions MW, MI, MH | - | - | 0 | 0 | Result is zero |
|  | - | - | 0 | 1 | Result is negative |
|  | - | - | 1 | 0 | Result is positive <br> Result can be held in odd numbered private <br> memory register only |
| Instructions MW, MI only | - | 0 | - | - | Result cannot be held in odd numbered pri- <br> vate memory register only |



Figure 3-154. Single-Bit Multiplication
one iteration, and four times the multiplicand is added to the partial product during the next iteration. Adding four times the multiplicand is accomplished by adding a one to the next bit pair at the time that the bit pair is under examination. The next bit pair becomes a 01 (if it was 00), a 10 (if it was 01), an 11 (if it was 10), or a 00 with a one to be added to the next bit pair (if it was 11). Any one, or carry, to the next higher bit pair is saved until that bit pair comes under examination. Table 3-65 lists bit pair combinations and multiplications.

Table 3-65. Bit-Pair Multiplier Logic

| Bit Pair | Carry From <br> Lower Order <br> Bit Pair | Bit Pair <br> Becomes | Carry to <br> Higher <br> Order <br> Bit Pair | Multiplicand <br> Multiplied <br> By |
| :--- | :---: | :---: | :---: | :---: |
| 00 | 0 | 00 | 0 | 0 |
| 01 | 0 | 01 | 0 | 1 |
| 10 | 0 | 10 | 0 | 2 |
| 11 | 0 | 11 | 1 | -1 |
| 00 | 1 | 01 | 0 | 1 |
| 01 | 1 | 10 | 0 | 2 |
| 10 | 1 | 11 | 1 | -1 |
| 11 | 1 | 00 | 1 | 0 |

An example of multiplication by bit pairs is shown in figure 3-155. Sign bits are not used in this example. After each partial product is found, the product register is shifted two places to the right, since the multiplicand has been multiplied by two bit positions.

One addition to the partial sum occurs during each iteration in a multiply operation. The Sigma 7 computer uses carrysave addition to eliminate the need (and time required) for propagating carries as each partial product is formed. Carry propagation is needed only after the last iteration with this technique. Carry-save addition resolves three quantities to be added into the two quantities, sums and carries. An example of carry-save addition is shown in figure 3-156.

The sum for any bit position is a one when one or three of the three bits in a column is a one. The carry from any bit position is a one when two of the three bits are ones. The carry from any bit position is shifted one bit position to the left to provide a normal carry to the next higher order. Figure 3-157 shows how carry-save addition is used in the previous multiplication example. Quantity A (A-register) is the sums portion of the previous partial product. Quantity $D$ ( $D$-register) is the number produced when the bit pair is examined ( $0,1,2$, or -1 times the multiplicand), and quantity CS (Carry-Save register) is the carries portion of the previous partial product. Register nomenclature and organization in this example are similar to the Sigma 7 computer multiply process. Sign bits are not used. The three
quantities at the beginning of each iteration are resolved to two quantities at the end, which represent the partial sum for that iteration. The final two quantities are added by conventional methods to assimilate the complete product.

## 3-199 DESCRIPTION OF MULTIPLY WORD AND MULTIPLY

 IMMEDIATE INSTRUCTIONS. Instructions Multiply Word (MW) and Multiply Immediate (MI) FAMULNH are almost identical in implementation. Figure 3-158 shows the register arrangement during the two instructions. The C-register holds the complete or the inverted multiplicand from core memory. (During instruction MI, the sign bit of the value field of the instruction word, bit position 12, is extended to bit positions 0 through 11 to make up a 32 -bit multiplicand.) The multiplicand is inverted if the multiplier is negative to ensure a correct product. The D-register holds the multiple of the multiplicand to be added to the partial product. The contents of the D-register, under control of the $B$ control ( BCON ) logic, vary with each iteration. BCON logic, in turn, is controlled by the bit pair under examination in bit position 30 and 31 of the $B$-register and the contents of flipflop BC31, the carry from the previous bit pair. The A-and CS-registers taken together contain the partial product for each iteration. The A-register holds the sums, and the CSregister holds the carries. The B -register initially holds the multiplier from private memory. With each iteration, the contents of the B-register are shifted two places to the right; the two least significant bits are lost; and a new bit pair comes under examination in B30 and B31. The four most significant bit positions in the $B$-register, 0 through 3, receive four sum bits of the partial product for each iteration. The sums portion of the partial product is constantly expanding into the higher order bit positions of the B-register which are vacated as the multiplier is shifted out. At the end of the iterations (MITEX: multiply iteration exit), the A- and $B$-registers contain the 64 bits of the sums portion of the final product, and the CS-register holds the final product carries. The sums and carries are added to produce the 64bit product. The 32 high order bits are placed in the even numbered private memory register, and the 32 lower order bits are placed in the odd numbered private memory register.The following paragraphs describe the phases of instructions MW and MI. Figure 3-158 and the sequence chart (table $3-70$ ) supplement the discussion.
During the phase preceding PRE2 NIA, a one is forced onto private memory address line LR31 to obtain the multiplier contained in the odd numbered private memory register. During PRE2, the multiplier is clocked into the A-register. If the multiplier is negative, flip-flop RN (register negative) is set. One's are forced into the CS-register by signal CSXI in PRE2 in preparation for a possible multiplier sign adjustment in PHI. The remainder of the preparation sequence is the same as the general preparation sequence.

At the time of the PHI clock, the multiplicand from core memory has been read into the C -register. If instruction Ml is being performed, the sign-padded multiplicand is clocked into the D-register by signal DXC/4, and flip-flop CSX is set for use in PH 2 . Sign manipulation of the operand is started in PH 1 .


Figure 3-155. Bit-Pair Multiplication


Figure 3-156. Carry-Save Addition
This is necessary to ensure that the multiplier is always positive; multiplying by a negative, as shown in table 3-66, would produce an incorrect result.

Table 3-66. Multiplication Sign Logic

| Multiplication | Result | Validity |
| :--- | :---: | :--- |
| $(+5) \times(+4)$ | $(0101) \times(0100)=00010100$ | Correct |
| $(+5) \times(-4)$ | $(0101) \times(1100)=00111100$ | Incorrect |
| $(-5) \times(+4)$ | $(1011) \times(0100)=11101100$ | Correct |
| $(-5) \times(-4)$ | $(1011) \times(1100)=10000100$ | Incorrect |

If the multiplier is positive, the A -register is gated to the sum bus by signal SXA during PHI. At the time of the PHI clock, the multiplicand (sum bus) is clocked into the Bregister by signal BXS. The multiplier remains in its original form, positive or negative.

If the multiplier is negative, it is inverted by an exclusive OR operation with the CS-register (all ones). The inverted (one's complemented) multiplier is gated to the sum bus from the adder by signal SXPR. At the PHI clock, the inverted multiplier is clocked into the B-register by signal BXS, and the BC31 (carry into B31) flip-flop is set. The contents of the B-register and flip-flop BC31 make up the two's complement of the multiplier. The multiplier sign has changed,
therefore the multiplicand sign must also change. This is accomplished in PH9 by combining the D-register (temporary multiplicand storage) with the CS-register (all ones) in an exclusive OR operation. The result is gated to the sum bus by signal SXPR and is clocked into the C-register at the time of the PH9 clock by signal CXS. Signal CCWCM denotes that $C$ contains one's complement and was previously enabled in PRE2. The contents of the C-register and signal CCWCM constitute the two's complement of the multiplicand. Table 3-67 shows the sign manipulation for all possible multiply cases.

Other operations occurring at the PHI clock include clearing the $A$-register, clearing the $P$-register, resetting flip-flop CC2, and enabling clock T4L for PH2.

At the PH 2 clock, the multiplicand in the C-register is clocked into the D-register if instruction MW is being performed. If instruction MI is being performed, the signpadded multiplicand in the D-register is gated to the sum bus by signal SXD, is transferred to the C-register by signal CXS, and is transferred to the D-register by signal DXC/6. The multiplicand is now in the $C$ - and $D$-registers. If the multiplier is negative (flip-flop RN is set), the D contents is inverted and clocked into the C-register in PH9 for sign manipulation, as discussed in previous paragraphs.

Coincident with sign manipulation in PH 2 through PH 9 , BCON logic is set up and performed. Signal BCON is high during the time that the multiplier bit pairs are examined and is an enable signal to the examination logic. BCON logic in PH2 through PH9 is described below.


The absolute value of the multiplier is contained in the Bregister in PH 2 . The first bit pair of the multiplier, $\mathrm{B} 30-$ B31 (multiplier 21, 20 ), and flip-flop BC31 are examined at this time. Flip-flop BC31 saves the carry to the next bit pair (multiply by -1 case). If the multiplier was originally negative, BC31 is set at this time. B30, B31, and $B C 31$ control the same functions as shown in table 3-65.

Table 3-67. Multiply Sign Manipulation

| Original <br> Multiplicand <br> Sign | Original <br> Multiplier <br> Sign | RN | Sign of <br> Multiplicand <br> in C-register <br> (PH9) | CCWCM <br> f(RN) | Sign of <br> Multiplier in <br> B-register <br> (PH1) | BC31 <br> $f(R N)$ | Sign of <br> Product <br> (PH11) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| + | + | 0 | + | 0 | + | 0 | + |
| - | - | 1 | - | 1 | + | 1 | - |
| - | + | 0 | - | 0 | + | 0 | - |
| - | - | 1 | + | 1 | + | 1 | + |

```
MULTIPLICAND }\begin{array}{llllllll}{\mp@subsup{2}{}{5}}&{\mp@subsup{2}{}{4}}&{\mp@subsup{2}{}{3}}&{\mp@subsup{2}{}{2}}&{2}&{2}&{2}
(REGISTER C)
```



```
    25
multiplier
(REGISTER B)
    \begin{array} { | l | l | l | l | l | l | } { \hline 0 } & { 1 } & { 1 } & { 1 } & { 0 } & { 1 } \\ { \hline } \end{array}
```




Figure 3-158. Register Organization and Flow Chart for Multiply Word and Multiply Immediate Instructions

The multiplicand is multiplied by either $0,1,2$, or ( -1 ) and the resulting quantity is transferred to the D-register. Multiplier control flip-flops DXCM, DXCLIM, and DXNCM control the multiplication and transfer and are, in turn, controlled by B30, B31, and BC31. Setup of the multiplier control flip-flops occurs one clock before the transfer into the D-register; bit pair $21,2^{0}$, therefore, controls the transfer to the D-register in PH9. Table 3-68 shows the multiplier logic. Note that BC31 may be set for the next bit pair examination.



(bit pair 10, carry)
NB31 BC31)

(bit pair 01, carry)
B31 BC31)


At the same time that the multiplier control flip-flops are set up, the B-register shifts two bit positions to the right, bringing the second multiplier bit pair $\left(2^{3}, 2^{2}\right)$ into B30 and B31. Zeros are clocked into BO and B1. At the end of PH2, the multiplier control flip-flops have been set up by the first bit pair, and the next bit pair is in position for examination.

At the PH9 clock, the following operations occur simultaneously:
a. The contents of the C-register are clocked into the D-register as a function of the multiplier control flipflop set by multiplier bit pair $2^{1}, 2^{0}$ in PH 2 . If no multiplier control flip-flops are set, zeros are clocked into the D-register. If multiplier control flip-flop DXCM is set, the contents of CO through C31 are clocked into D0 through D31, respectively. If the multiplicand of the $C$-register
is the one's complement of the original multiplicand (flipflop CCWCM set), flip-flop DCWCM (D contains one's complement) is set. If multiplier control flip-flop DXCLIM is set, the contents of C0 through C31 are clocked into D71 and D0 through D30, respectively. A one is forced into D31 to maintain the one's complement condition, and flip-flop DCWCM is set. The contents of C0 through C31 are inverted and clocked into DO through D31, respectively, if multiplier control flip-flop DXNCM is set. If flip-flop CCWCM is set, the multiplicand is in its original form, and flip-flop DCWCM is not set. The one's complement is in the D-register and flip-flop DCWCM is set, if the C-register does not hold the one's complement. The various transfers are shown in table 3-69.
b. The multiplier control flip-flops are set up again by bit pair $2^{3}, 2^{2}$ of the multiplier.
c. The B -register shifts two bit positions to the right by signal $B X B R 2$, bringing bit pair 25, 24 of the multiplier into B3O, B3I. Zeros are clocked into BO and B1.

```
BXBR2 = FAMDSFF/M PH9 + . . .
```

d. Flip-flop MIT (multiply iterations) is set. Signal MIT controls the number of multiply iterations.
e. Clock T10 is enabled for PH10.


The D-register now contains the first partial sum. The Aregister contains all ones (cleared in PHI ), and the CSregister all zeros.

There are 16 clocks in PH 10 for the 16 multiply iterations. At each clock, the following events occur:
a. The D-register is combined with the A- and CSregisters in the adder to produce the partial product for that iteration. Figure 3-159 shows the addition process and signal routing. The sums portion of the product is clocked into A0 through A31 and the first four bit positions of the B -register, BO through B 3 . Depending upon the number of iterations previously performed, B4 through B31 contain 0 to 27 lower-order bits of the partial product; however, these do not enter into the addition. Because of their position in the product, these bits remain constant as higherorder bits of the multiplier are examined, and the partial product is shifted. The carries portion of the partial product is clocked into the CS-register, bit positions 0 through 33. Generally, the sum for any bit position in the sums register (A-register) is set by a propagate signal from the adder, defined by $P R_{n}=A_{n} N C S_{n} N D_{n}+N A_{n} N C S_{n} D_{n}$

Table 3-68. Bit-Pair Multiplier Logic

| B30 | B31 | BC31 | S/BC31 | S/DXCM | S/DXNCM | S/DXCLIM | Transfer |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 into D |
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | $C$ into $D$ |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | $2 \times C$ into $D$ |
| 1 | 1 | 0 | 1 | 0 | 1 | 0 | NC into D |
| 0 | 0 | 1 | 0 | 1 | 0 | 0 | $C$ into $D$ |
| 0 | 1 | 1 | 0 | 0 | 0 | 1 | $2 \times C$ into $D$ |
| 1 | 0 | 1 | 1 | 0 | 1 | 0 | $N C$ into $D$ |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 into D |

Table 3-69. Multiplier Control Flip-Flop Logic

| CCWCM | Multiplier Control Flip-Flop Set | Transfer | DCWCM |
| :---: | :--- | :--- | :--- |
| 0 | None | Zeros into D71, D0-D31 | 0 |
| 0 | DXCM | C0-C31 into D0-D31 | 0 |
| 0 | DXCLIM | C0 into D71, C1-C31 | 0 |
| 0 | DXNCM | NC0-NC31 into D0-D31 | 1 |
| 1 | None | Zeros into D71, D0-D31 | 0 |
| 1 | DXCM | C0-C31 into D0-D31 | 1 |
| 1 | DXCLIM | C0 into D71, C1-C31 | 1 |
|  |  | into D0-D30, one into |  |
|  | DXNCM | NC0-NC31 into D0-D31 | 0 |

$+N A_{n} C S_{n} N D_{n}+A_{n} C S_{n} D_{n}$. $P R_{n}$ is true when one or three bits of the three to be added are ones. The propagate signals are shifted two bit positions to the right in prepreparation for the next addition. The carry to any bit position is generally set by generate signals from the adder, defined by $G_{n}=A_{n} D_{n}+A_{n} C S_{n} N D_{n}+N A_{n} C S_{n} D_{n}$. $G_{n}$ is true whenever two of the three bits added are ones. A true $G_{n}$ signal for any bit position provides a carry signal to the next higher order; the generate signals are shiffed right only one bit position for this reason (two right shifts in preparation for the next addition minus one left shift for a carry to the next higher order). A new set of sums and carries is generated with each iteration. The only bits changing in the addition are the 36 higher order sum bits (A0-A31, B0-B3) and the 33 carry bits (CS1-CS33).
b. The extreme higher order and lower order bits of the partial product are formed by special logic. Figure $3-160$ shows the possible configurations of the high order bits to be added in an iteration (CSO is always a 0), together with the resulting sums and carries. A0 of the sum is used only for sign-padding the partial product and is a one when there is a one in A0 or D71 or both. Al would normally be the sign bit in a straight addition, but it is a sum
bit in carry-save addition, since CSI may hold a carry after the addition. Flip-flops A2 through A31 are set two orders to the left by the propagate signal. Flip-flop B3 is set by signal BIS, equivalent to a propagate signal from bit position 33 and true when there is a total of one or three ones in $B 1, B C 1$, and CS33. Flip-flop $B C 1$ is set by signal DCWCM and contains a one if the one's complement of the multiplicand was put in the D-register at the previous iteration. By adding a one to B3 of the partial product one clock after the addition of the A-, D-, and CS-registers, the $D$-register is paid the 1 needed to make a 2 's complement. The partial product has been shifted so that the order of $B 3$ is the same that would have received the one, if it had been initially added to the D-register. Figure 3-161 illustrates the timing for this operation. Flip-flop B2 is set by the propagate signal, PR32, for bit position 32; this is the same as the normal propagate signal except that only the CS- and B-registers are combined. There is no CS32 or CS33. B2 is not set, however, when there are both a PR32 signal and a generate signal from the thirty-third bit position. G33 amounts to a carry from bit position 33. The carry from bit position 33, if not resolved by setting flipflop B2, is stored in CS33. Flip-flops CS1 through CS32 are set by $G 0$ through $G 31$, respectively.


Figure 3-159. Multiply Iteration Signal Routing

PRO
= AO NCSO NDO + NAO NCSO DO + NAO CSO NDO + AO CSO DO
$\begin{aligned} \text { PR31 }= & \text { A31 NCS31 ND31 + NA31 NCS31 D31 } \\ & + \text { NA31 CS31 ND31 + A31 CS31 D31 }\end{aligned}$

PR32

|  | CSO NDO + AO CSO D0 |
| :--- | :---: |
| $\cdot$ | $\cdot$ |
| $\cdot$ | $\cdot$ |
| $\cdot$ | $\cdot$ |
| PR31 $=$ | A31 NCS31 ND31 + NA31 NCS31 D31 |
|  | + NA31 CS31 ND31 + A31 CS31 D31 |
| PR32 $=$ | BO NCS32 + NB0 CS32 |

```
G0 = A0 D0 + A0 CS30 NDO + NA0 CSO D0
. .
G31 = A31 D31 + A31 CS31 ND31 + NA31
    CS31 D31
G33 = B1 BCl + B1 NBC1 CS33 + NB1 BCl CS33
S/BCI = DCWCM CSXGRI = DCWCM MIT
```



Figure 3-160. High-Order Bit Logic

```
S/A0 = (A0 + D7I)MIT + ...
S/A1 = (A0 + D71)N(A0 D71) MIT + ...
S/A2 - PRO MIT + ...
S/A31 = PR29 MIT + ...
S/BO = PR30 MIT + ...
S/B1 = PR31 MIT + ...
S/B2 = BOS MIT
S/B3 = BIS MIT
BOS = (PR32 NG33 + NPR32 G33) MIT
B1S = B1 NBC1 NCS33 + NB1 BCl NCS33
    +NB1 NBCl CS33 + B1 BCl CS33
```

$\begin{array}{ll}S / C S 1 & = \\ \cdot & \text { GOMIT }+\ldots \\ \cdot & \cdot \\ \cdot & \cdot \\ S / C S 32 & = \\ S / C S 33 & = \\ & \text { G31 MIT }+\ldots \\ & \text { BO CS32 }+ \text { PR32 G33) MIT }+\ldots\end{array}$
$\begin{array}{ll}S / C S 1= & \text { GOMIT }+\ldots \\ \cdot & \cdot \\ \cdot & \cdot \\ \cdot & \cdot \\ S / C S 32 & = \\ S / C S 33 & =(B O \text { CS32 }+ \text { PR32 G33 }) \text { MIT }+\ldots\end{array}$
c. The contents of the C-register are clocked into the D-register as a function of the multiplier control flip-flops that were set during the previous clock.
d. The next bit-pair of the multiplier is examined, and the multiplier control flip-flops are set.
e. The B-register shifts two bit positions to the right by signal $B \times B R 2$, bringing a new bit-pair into $B 30$ and $B 31$.
F. The contents of B2 and B3 are clocked into bit positions 2 and 3, respectively, of the register. If E2 and E3

PHASE 10


Figure 3-161. BCI Timing
contain 0 's at the end of 16 iterations, the product bits $2^{27}$ through $2^{0}$ are 0 's, since all of these bits have been shifted in and out of E2 and E3 during the iterative process.

```
S/E2 = B2 (FAMUL MIT) + ...
S/E3 = B3 (FAMUL MIT) + ...
```

g. The number of the iteration is counted. The iteration counter is made up of flip-flops P15 through P18 (cleared in PHI by signal PX) and flip-flop MP19. These five flip-flops form a five-bit binary up-counter that counts iterations during instructions MW, MI, MH, and floating point instructions. Figure 3-162 shows the counting configurations and the signals enabled by the counter for instructions MW and MI. The counter is used only through the 14th clock for the two instructions. At the first clock of PHIO , signal PCTP5 (plus count control for P15 through P19) goes true as flip-flop MP19 is set. Flip-flop MP19 takes the place of P19 in the iteration counting and is set at every even clock except the last (clock 16). At the 14th clock, flip-flop MULC is set. A true MULC signal sets flip-flop MITEX at clock 15; MITEX resets flip-flop MIT at clock 16. At clock 14, also, flip-flop TIL is reset to initiate the end of TIL (TIL timing lasts through PH10) and memory request flip-flop $M R Q / M$ is set, requesting the next instruction. At clock 15, the $P$-register is cleared (signal $P X$ ), and the address of the next instruction is transferred from Q15
through Q31 to P15 through P31 by signal PXQ. Clock 15 is the last transfer of the C-register contents to the Dregister under control of the multiplier control flip-flops. Other functions at clock 15 include clearing the D-register (signal DX/1) and resetting flip-flop MIT to signify the end of the multiply iterations. The last carry-save addition of the A-, D-, and CS-registers occurs during clock 16; the product of the multiplication is contained in A0 through A31 and BO through B31 (sums) and CSI through CS33 and BCI (carries). If the R-field of the instruction word is even, clock TIOL is enabled. If the R-field is odd, clock T6L is enabled. PHIl is set.

During PHII, the final product of the multiplication is assimilated from the results of the last iteration in PHIO (see figure 3-163). The most significant word of the product, bits $2^{63}$ through 232 , is obtained by adding the contents of the A-register to the contents of the CS-register. Any carry from bits $2^{31}$ through $2^{0}$ of the product, designated K3I, is also added to the sum. The sum, S0 through S31, is clocked into the A-register by signal AXS and, if $R$ is even, it is clocked into the even private memory register by signal RW.

The least significant word of the product, bits $2^{31}$ through $2^{0}$, is obtained by adding the contents of BO and BI to the contents of flip-flops CS32, CS33, and BCl. Flip-flop BCI may contain a one if the one's complement was put into the

| $\begin{gathered} \text { CLOCK } \\ (\text { PH10 }) \end{gathered}$ | P15 | P16 | P17 | P18 | MP 19 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | 0 | 0 | c |  |
| 2 |  |  |  |  | 1 | PCTP5 |
| 3 |  |  |  | 1 | 0 |  |
| 4 |  |  |  | 1 | 1 |  |
| 5 |  |  | 1 | 0 | 0 |  |
| 6 |  |  | 1 | 0 | 1 |  |
| 7 |  |  | 1 | 1 | 0 |  |
| 8 |  |  | 1 | 1 | 1 |  |
| 9 |  | 1 | 0 | 0 | 0 |  |
| 10 |  | 1 | 0 | 0 | 1 |  |
| 11 |  | 1 | 0 | 1 | 0 |  |
| 12 |  | 1 | ก | 1 | 1 |  |
| 13 |  | 1 | 1 | 0 | 0 |  |
| 14 |  | 1 | 1 | 0 | 1 | S/MULC |
| 15 |  | NOT | APP | LICA | ABLE | S/MITEX |
| 16 |  | NOT | APP | LICA | ABLE | $0 \rightarrow$ D, |

Figure 3-162. Iteration Counting for Multiply Word and Multiply Immediate Instructions

D-register at the fifteenth iteration of PHIO. CS32 and CS33 contain the remaining carries to be added. The sum of $\mathrm{BO}, \mathrm{B1}$, and CS32, CS33, and $\mathrm{BC1}$ is clocked back into bit positions BO and Bl of the B -register by signal BXB . The remainder of the bits in the $B$-register remain unchanged.

If either bit positions 2 or 3 of the E-register contain a one at the beginning of $\mathrm{PHI1}$, the product $2^{27}$ through $2^{0}$ is nonzero. During PH 11 , any ones in the product bits 231 through $2^{28}$ cause one or more ones to be clocked into EO through E3. If E0 through E3 contain all zeros at PH15, product bits $2^{31}$ through $2^{0}$ are all zeros.

At the PHIl clock, a one is forced on private memory address line LR31 to select the odd numbered private memory register for storage of the least significant word of the product, bits $2^{31}$ through $2^{0}$, in PH 15 . A one is forced into CS31 to enable K00 in PH 15 for magnitude testing. Flipflop DRQ is set which inhibits transmission of another clock until the memory data release signal is received. PH 15 is enabled by setting flip-flop PH15. Flip-flop T8L is set for PHI5 clock.

During PHI 5 , the least significant word of the product, bits $2^{31}$ through $2^{0}$, is gated to the sum bus by signal SXB. At the PH15 clock, the least significant word of the product is read into the odd numbered private memory register by signal

RW at the PH15 clock. If the E-register contents are not equal to zero, the least significant word of the product is not zero. A one is forced into A31 in this case. Flip-flop CC3 is set if there is a one in A1 through A31 and if A0 is a zero which indicates a positive product. Flip-flop CC4 is set if AO is a one, indicating a negative product. Flipflop CC2 is set if the $2^{31}(\mathrm{BO})$ bit of the product is a zero and if bits $2^{63}$ through $2^{32}$ are nonzero, or if the $2^{31}$ bit is a one and bits $2^{63}$ through $2^{32}$ are not all ones. ( K 00 goes true if bits $2^{63}$ through $2^{32}$ are all ones and if CS31 contains a one.) A one was forced into CS3l in PHIl for this test. Signal ENDE is generated.

A sequence chart for Multiply Immediate and Multiply Word is given in table 3-70.

## 3-200 DESCRIPTION OF MULTIPLY HALFWORD INSTRUC-

 TION. Instruction Multiply Halfword (MH), FAMULH, is very similar to instructions MW and MI. However, there are eight iterations rather than 16 in MH , and there are 32 product bits. Figure 3-164 shows the register arrangement during instruction MH . The C -register holds the complete or inverted halfword multiplicand from core memory in bit positions 0 through 15. The multiplicand is inverted if the multiplier is negative. Bit positions 16 through 31 contain all zeros if the multiplicand is not inverted or all ones if the multiplicand is inverted.FINAL PRODUCT SUMS


Figure 3-163. Multiply Word and Multiply Immediate Final Product Assimilation

Table 3-70. Multiply Word, Multiply Immediate, Phase Sequence


Table 3-70. Multiply Word, Multiply Immediate, Phase Sequence (Cont.)


Table 3-70. Multiply Word, Multiply Immediate, Phase Sequence (Cont.)


Table 3-70. Multiply Word, Miultiply Immediate, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{array}{\|l} \mathrm{PH} 10 \\ \mathrm{TILL} \\ \text { (Cont. } \end{array}$ | Clear the D-register <br> Reset flip-flop MIT <br> Enable clock T10L if $R$ is even <br> Stop sustaining PH10 <br> Set flip-flop PH 11 | DX/I $=$ MIT $+\ldots$ <br> R/MIT $=$ . <br> $S / T 10 L=$ FAMULNH MITEX NR3I <br>  $+\ldots$ <br> BRPH $10=$ MIT NMITEX $+\ldots$ <br> $S / P H 11=$ PH 10 N $($ MIT NMITEX $)+\ldots$ |  |
| PHII <br> T6L <br> or <br> T10L | Timing: T6L if $R$ is odd, T10L if $R$ is even $\begin{aligned} & A+C S+K 31 \longrightarrow S 0-S 31 \\ & S 0-S 31 \rightarrow A 0-A 31 \\ & S 0-S 31 \longrightarrow R W 0-R W 31 \text { if } R \text { is even } \\ & B+C S 32, C S 33, B C 1 \longrightarrow B 0-B 7 \end{aligned}$ <br> Merge the contents of $B O$ through B3 into the contents of EO-E3- <br> Force a one into CS31 to enable KOO in PHI 5 for magnitude test <br> Force a one on private memory address line LR31 <br> Set flip-flop DRQ <br> Set flip-flop PH 15 <br> Enable clock T8L |  | Retained for PH 15 testing <br> Store product bits $2^{63}$ $2^{32}$ <br> B8-B31 remain unchanged <br> For check of nonzero product in bits $231-20$ in PH15 <br> To select the odd numbered private memory register for storage of bits $2^{31}-2^{0}$ of the product |
| PH15 | $\begin{aligned} & \mathrm{BO}-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{RW} 0-\mathrm{RW} 31 \end{aligned}$ <br> Set flip-flop TESTA <br> Force a one into A31 if the contents of $E$ are not equal to zero <br> Set CC2, CC3, CC4 as applicable <br> Enable ENDE |  | Store product bits $2^{31}$ _ $2^{0}$ <br> If $E \neq 0$, the product bits $2^{31}-2^{0} \neq 0$ |
|  |  |  | $\begin{aligned} \text { Mnemonic: } & \text { MW (37, B7) } \\ & M I(23,17)\end{aligned}$ |



Figure 3-164. Multiply Halfword Register Organization and Flow Chart

In either case, this portion of the multiplicand (shaded area) produces zeros in the lower order bits of the product; the lower order bits are then discarded. The effect obtained is the same as by using a 16-bit multiplicand. As with instructions MW and MI, the D-register holds the multiple of the multiplicand, which has been transferred under control of the BCON logic. The iteration process is also the same. The A-register holds the sums, and the CS-register holds the carries. The B -register is shifted as before and initially holds the multiplier in bit positions 16 through 31. Bit positions 0 through 15 hold the other halfword from the private memory register. These bits do not take part in the multiplication. At the end of eight iterations, the A-register contains the 32 sum bits of the final product, and the CSregister holds the final carries. The sums and carries are added to produce the 32 -bit product which is placed in the odd numbered private memory register.

The following paragraphs describe the phases of instruction MH . Figure 3-164 and table 3-71 supplement the discussion.

The preparation sequence is the same as the general preparation sequence, with the following exceptions: During PRE2, the contents of the even numbered private memory register are clocked into the A-register by signal AXRR. The multiplier consists of bit positions 16 through 31; bit positions 0 through 15 are clocked into the A-register, but are not used in the multiplication. The sign of the multiplier, contained in bit position 16, is stored in flip-flop RN. Ones are clocked into the CS-register by signal CSXI in preparation for a possible multiplier sign adjustment.
During the preparation phase of the instruction, the word containing the effective halfword is read into the Cregister from core memory. At the time of the PH 1 clock, the effective halfword is clocked by signal DXC/5 into bit positions 16 through 31 of the D-register from either the least significant halfword or the most significant halfword location in the C-register. Choice of halfword location is dependent upon the state of P32. Also dependent upon P32, signal C0C16 goes true if C0 (P32 true) or C16 (P32 false) is true. If COC16 is true, ones are clocked into bit positions 0 through 15 of the D-register (temporary multiplicand storage) to sign-pad the negative halfword multiplicand.

Sign manipulation identical to instructions MW and MI takes place in PHI . If the multiplier is positive, the multiplier is gated to the sum bus by signal SXA and is clocked into the B-register by signal BXS. The multiplicand is not inverted in the following phases. If the multiplier is negative, it is inverted by an exclusive OR operation with the CS -register (all ones). The inverted multiplier is clocked into the B-register, and flip-flop BC31 is set. The contents of the $\overline{\mathrm{B}}$-register and BC 3 i make up the two's complement of the original multiplier. The multiplier is inverted in PH9 to complete the sign manipulation. Other operations during PHI include clearing the $\mathrm{A}-$ register by signal $A X / 1$, clearing the $P$-register by signal $P X$, and enabling clock T8L for PH2. Flip-flops CXS and NPRX are also set at this time in preparation for PH2.

During PH2, the halfword multiplicand in D16 through D31 is upward aligned into bit positions 0 through 15 of the Cregister by signals $S X U A H / 1$ and CXS. Zeros are present in bit positions 16 through 31 of the C -register. The C -register contents are transferred to the D-register at the PH2 clock by signal $D X C / 6$. The D-register now contains the multiplicand in bit positions 0 through 15, followed by zeros in bit positions 16 through 31 .

The remainder of PH 2 is identical to instructions MW and MI. Ones are clocked into the CS-register by signal CSXI, and if the multiplier is negative, the CXS flip-flop is set for inversion of the multiplicand in PH9. The first bit-pair of the multiplier is examined, and the multiplier control flipflops are set. The B-register shifts two bit positions to the right, bringing the next bit-pair into B30, B31. Zeros are clocked into BO and B1. PH9 is enabled.

PH9 of instruction MH is the same as instructions MW and MI. In summary:
a. The contents of the C-register are clocked into the D-register as a function of the multiplier control flip-flops set by bit-pair $2^{1}, 2^{0}$ in PH 2 .
b. Bit-pair $2^{3}, 2^{2}$ is examined. The multiplier control flip-flops are set again.
c. The B -register shifts two bit positions to the right, bringing bit-pair $2^{5}, 2^{4}$ of the multiplier into B 30 and B 31 . Zeros are clocked into BO and B1.
d. Flip-flop MIT is set.

The D-register now contains the first partial product, the Aregister contains all zeros, and the CS-register contains all zeros.

PH1O is identical to instructions MW and MI except that eight iterations are performed, and iteration counting is modified. Eight iterations are involved, since only eight bitpairs in the multiplier are examined. At each of the eight clocks in PHIO, the following operations occur:
a. The D-register is combined with the A- and CSregisters in the adder to produce the partial product for the iteration.
b. The C-register is clocked into the D-register as a function of the multiplier control flip-flops set during the previous clock.
c. The next bit-pair of the multiplier is examined, and the multiplier conirol flip-flops are set.
d. The B-register shifts two bit positions to the right, bringing a new bit-pairinto B30 and B31. The last bit-pair examined is bit-pair $2^{16}, 2^{15}$.
e. The number of the iteration is counted. The iteration counting scheme is identical to instructions MW and

Table 3-71. Multiply Hal fword, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PREP | Same as general preparation sequence except for PRE2 NIA |  |  |
| PRE2 NIA | $R R 0-R R 31 \rightarrow A 0-A 31$ <br> Set flip-flop RN if halfword multiplier negative <br> Force ones into CS0-CS31 | AXRR $=$ FAMDSF PRE2 NIA $+\ldots$ <br> S/RN $=$ RR16 FAMULH PRE2 NIA <br>  $+\ldots$ <br> CSXI $=$ PRE2 NIA FAMUL $+\ldots$ | Multiplier is in RR16RR31 <br> Store multiplier sign <br> To produce one's complement of multiplier in PH 1 if RN |
| PHI | $\mathrm{MBO}-\mathrm{MB3I} \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ $\begin{aligned} & \mathrm{C} 0-\mathrm{Cl} 6 \rightarrow \text { D0-D15 } \\ & \mathrm{C} 0-\mathrm{Cl} 16 \rightarrow \text { D16-D31 if NP32 } \\ & \mathrm{Cl} 16-\mathrm{C} 31 \rightarrow \text { D16-D31 if P32 } \\ & \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \text { if A positive } \\ & \mathrm{A} 0-\mathrm{A} 31 \oplus \mathrm{CS} 0-\mathrm{CS} 31 \longrightarrow \text { S0-S31 } \end{aligned}$ <br> if A negative <br> Set flip-flop BC31 $S 0-S 31 \nrightarrow B 0-B 31$ <br> Clear A-register <br> Clear P -register <br> Set flip-flop CXS <br> Force a one into NPRX <br> Enable clock T8L | Preparation control <br> SXA $\quad=$ FAMUL PHI NRN $+\ldots$ <br> SXPR $\quad=\quad$ FAMUL PHI RN + ... <br> S/BC31 $=$ FAMUL PHI RN + ... <br> BXS $\quad=$ FAMDSF $\mathrm{PHI}+\ldots$ <br> $\mathrm{AX} / 1 \quad=$ FAMDSF $\mathrm{PH} 1+\ldots$ <br> PX $\quad=$ FAMUL PHI $+\ldots$ <br> $S / C X S \quad=$ FAMULH PHI + ... <br> S/NPRX $\quad=$ FAMULH PHI + ... <br> S/T8L $\quad$ - FAMULH PHI + . . | Multiplicand $\rightarrow$ Cregister <br> Sign pad <br> Downward aligned halfword multiplicand $\rightarrow$ C-register <br> Absolute value of multiplier transferred to the B -register and BC31 <br> For PH2 upward alignment of halfword <br> For PH2 upward alignment of halfword |
| $\begin{array}{\|l\|l} \mathrm{PH} 2 \\ \mathrm{~T} 8 \mathrm{~L} \end{array}$ | $\begin{aligned} & \mathrm{D} 0-\mathrm{D} 31 \oplus \mathrm{CSO}-\mathrm{CS} 31 \longrightarrow \mathrm{KO}-\mathrm{K} 31 \\ & \mathrm{~K} 15-\mathrm{K} 30 \longrightarrow \mathrm{C} 0-\mathrm{S} 15 \\ & \mathrm{SO} \mathrm{~S} 31 \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \mathrm{D}-\mathrm{D} 31 \end{aligned}$ <br> Force ones into CSO-CS31 for PH9 if multiplier is negative <br> Set flip-flop CXS for PH9 if multiplier is negative $\mathrm{B} 0-\mathrm{B} 29 \xrightarrow{\rightarrow} \mathrm{~B} 2-\mathrm{B} 31$ <br> Enable BCON | SXUAH/1 $=$ FAMULH PH2 $+\ldots$ <br> CXS $=$ Previously set in PH1 <br> DXC/6 - FAMUL PH2 $+\ldots$ <br> CSX1 $=$ FAMUL PH2 RN $+\ldots$ <br> S/CXS $=$ FAMUL PH2 RN $+\ldots$ <br> BXBR2 $=$ FAMUL PH2 $+\ldots$ <br> BCON $=$ BXBR2 FAMDSF $/ M+\ldots$ | Zeros on S16-S31 <br> For PH9 multiplicand sign adjustment <br> For PH9 multiplicand sign adjustment <br> Examine multiplier bitpair $2^{1}, 2^{0}$. Set multiplier control flip-flops to this bit-pair |
| (Continued) |  |  | Mnemonic: $\mathrm{MH}(57, \mathrm{D} 7)$ |

Table 3-71. Multiply Halfword, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH2 <br> T8L <br> (Cont. | Set up flip-flops DXCM, DXNCM, DXCLIM, BC31 as functions of B30, $B 31$, and $B C 31$ <br> Set flip-flop PH9 | BRPH9 | $=$ FAMUL PH2 + . | Shift multiplier to bring next pair into B30, B31 |
| $\left\lvert\, \begin{aligned} & \text { PH9 } \\ & \mathrm{T} 6 \mathrm{~L} \end{aligned}\right.$ | $\begin{aligned} & \text { D0-D31 } \oplus \mathrm{CSO}-\mathrm{CS} 31 \longrightarrow \text { S0-S31 } \\ & \text { S0-S31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \end{aligned}$ <br> $\mathrm{NCO}-\mathrm{NC} 31 \rightarrow$ D0-D31 <br> Zeros transferred to D71-D30 if none of the above <br> Force a one into flip-flop DCWCM if one's complement is transferred to D $\mathrm{B} 0-\mathrm{B} 29 \rightarrow \mathrm{~B} 2-\mathrm{B} 31$ <br> Sustain BCON <br> Set up flip-flops DXCM, DXNCM, DXCLIM, B31 as functions of B30, B31, BC31 <br> Set flip-flop MIT <br> Enable clock TIL if not a single clocking | SXPR <br> CXS <br> DXCM <br> DXNCM <br> DXCLIM <br> S/DCWCM <br> BXBR2 <br> BCON <br> S/MIT <br> S/TIL | $\begin{aligned} = & \text { FAMDSF/M PH9 }+\ldots \\ = & \text { Previously set in PH2 } \\ = & \text { Previously set in PH2 } \\ = & \text { Previously set in PH2 } \\ = & \text { Previously set in PH2 } \\ = & C C W C M(D X C M+\text { DXCLIM) } \\ & + \text { NCCWCM DXNCM } \\ = & \text { FAMDSF/M PH9 + . . } \\ = & \text { FAMDSF/M BXBR2 + . . } \\ = & \text { FAMDSF/M PH9 NCLEAR } \\ & +\cdots \\ = & F A M D S F / M \text { PH9 NKSC } \\ & \text { N(S/FLMC/1 P18) + . . } \end{aligned}$ | Final multiplicand sign adjustment in case of negative multiplier. C already contains multiplicand if multiplier is positive <br> First transfer of multiplicand under control of bitpair $2^{1}, 2^{0}$. <br> Records one's complement condition so that a one can be added later to make up two's complement <br> Examine multiplier bitpair $2^{3}, 2^{2}$. Set multiplier control flip-flops to this bit-pair. Shift multiplier to bring next bit-pair into B30, B31 |
| $\begin{aligned} & \text { PH10 } \\ & \text { TIL } \end{aligned}$ | Eight clocks. During the first 6 clocks, the following events occur: <br> $\mathrm{A} \oplus \mathrm{D} \oplus \mathrm{CS} \longrightarrow$ PRO-PR31 <br> $\mathrm{PR} 0-\mathrm{PR} 31 \longrightarrow \mathrm{~A} 2-\mathrm{A} 31, \mathrm{~B} 0, \mathrm{~B} 1$ <br> $A D+A C S+D C S \longrightarrow G 0-G 31$ <br> G0-G31 $\rightarrow$ CSI-CS32 <br> Contents of C are transferred to D under control of the multiplier control flip-flops DXCM, DXNCM, DXCLIM, set during previous clock | AXPRR2 <br> CSXGRI | $\begin{aligned} & =M I T+. \\ & =M I T \end{aligned}$ | Sums of the partial products <br> Carries of the partial products |
|  |  |  |  | Mnemonic: MH (57, D7) |

Table 3-71. Multiply Halfword, Phase Sequence (Cont.)


Table 3-71. Multiply Halfword, Phase Sequence (Cont.)


MI except that terminal signals are detected at clocks six through eight rather than through 16. Figure 3-165 shows the counting configurations and the signals enabled for instruction MH. At clock 6, flip-flop MULC is set. A true MULC signal sets flip-flop MITEX at clock 7; MITEX resets flip-flop MIT at clock 8 . At the sixth clock, also, flip-flop TIL is reset to initiate the end of TIL (TIL timing lasts through PH10), and memory request flip-flop MRQ/M is set to request the next instruction. At clock 7 , the $P$ register is cleared (signal $P X$ ), and the address of the next instruction is clocked into the P -register by signal PXQ. The seventh clock is the last transfer of the C-register contents to the D-register under control of the multiplier control flip-flops. At the eighth clock, the D-register is cleared by signal DX/1 and flip-flop MIT is reset. This signifies the end of the multiply iterations. The last addition of the A-, D-, and CS-registers occurs at clock 8; the product of the multiplication is now contained in A0 through A31, B0 through 31 (sums), CS1 through CS33, and BCl (carries). The product bits in B4 through B31 are irrelevent; the final product is contained in A0 through A31 after the final addition of the sums and carries. PHIl is set by MITEX.

During PHII, the final product of the multiplication is assimilated from the results of the lastiteration in PHIO . This is done by adding the contents of the A-register to the contents of CS1 through CS31 and K31 (carry from the lowerorder bits). The addition is shown in figure 3-166. The sum, S0 through S31, is clocked back into the A-register, which now contains the complete product of the halfword multiplication. K31 is produced by the addition of BO and BI to CS32, CS33, and BCl at the PHIl clock. Flip-flop BCl contains a one if the one's complement was put into the $D$ register on the seventh iteration of PH 10 . The sum of BO and $\mathrm{BI}, \mathrm{CS} 32$ and CS33, and BCI for this last addition is zero. Zeros are clocked into $B 0$ and $B 1$ by signal $B X B$.

The quantity in B 2 through B 19 is also zero; the contents of $B 20$ through B31 are meaningless.

At the PHIl 1 clock, a one is forced on private memory address line LR31 to select the odd numbered private memory register for storage of the product. Flip-flop DRQ is set, inhibiting transmission of another clock until the memory data release signal is received. PH 13 is enabled by setting flip-flop PHI5. Flip-flop T8L is set for PHI5.

During PHI5, the product in the A-register is gated to the sum bus by signal SXA. At the PH15 clock, the product is read into the odd numbered private memory register. Flipflop CC3 is set if bits $2^{31}$ through $2^{0}$ of the product are nonzero and if the $2^{31}$ bit is not a one. Flip-flop CC4 is set if the $2^{31}$ bit is a one. Signal ENDE is generated.
A sequence chart for Multiply Halfword is given in table 3-71.

## 3-201 Divide Word (DW 36, B6) and Divide Halfword (DH 56, D6)

Instructions DW and DH are similar in implementation and result. Both instructions are discussed together; however, specific differences between instruction DW and DH are noted.

Instruction DW divides the contents of an even and an odd numbered private memory register by the effective word from core memory if the R-field of the instruction word is an even value. The resulting 32-bit quotient is stored in the odd numbered private memory register, and a 32 -bit remainder is stored in the even numbered private memory register. If the R-field of the instruction word is an odd value, the contents of the odd numbered private memory register are divided by the effective word from core memory, and the 32 -bit quotient is loaded back into the odd numbered


Figure 3-165. Multiply Halfword Iteration Counting
private memory register. The remainder is lost in this case. When the R-field is odd, the result of the instruction is the same as if instruction DH had been performed.

Instruction DH divides the contents of the even or the odd numbered private memory register by the effective halfword from core memory, and loads the quotient back into the same private memory register. The remainder is lost.

Instructions DW and DH use condition code bits 2 through 4. Fixed-point overflow may occur in instruction DW if the quotient cannot be represented correctly in 32 bits, or the overflow may occur in instruction DH if division is by $-2^{31}$, -1 , or 0 . The condition codes shown in table 3-72 apply to the two instructions.

Table 3-72. Instruction DW and DH Condition Codes

| CC1 | CC2 | CC3 | CC4 | Meaning |
| :---: | :---: | :---: | :---: | :--- |
| - | 0 | 0 | 0 | Quotient zero, <br> no overflow |
| - | 0 | 0 | 1 | Quotient negative, <br> no overflow <br> - |
| - | 0 | 1 | 0 | Quotient positive, <br> no overflow |
| - | 1 | - | - | Fixed-point <br> overflow |

3-202 NONRESTORING DIVISION. The Sigma 7 computer uses the method of nonrestoring division for instructions DW and DH. A review of division techniques may help in understanding nonrestoring methods.

Restoring division is the most basic type of division. Long division is an example of restoring type. Subtractions are repeated to obtain a quotient. An example of restoring binary division is shown in figure 3-167. Sign bits are not used in this example.

Multiples of the divisor (hereafter called denominator) are subtracted from the dividend (hereafter called numerator) or partial dividend (hereafter called residue). The first subtraction in this example is $\left(1011_{2} \times 2^{5}\right)$ or 1011000002 . Successive subtractions involve the demoninator times $2^{4}, 2^{3}$, and so forth, for as many times as necessary. Each subtraction yields either a one or a zero in the quotient, depending upon whether the residue is positive or negative. A negative residue signifies that the denominator multiple is larger than the previous residue and could not be contained in it. The previous positive residue, therefore, is restored. A 0 is put in the quotieni for that order, and the next lower order multiple is subtracted. Figure 3-168 is a representation of restoring division using the same numbers as in figure 3-167. At no time may the residue be negative. The zero point (residue $=0$ ) is always approached from the positiveside. The total of all multiples subtracted and the remainder (the last residue) equals the numerator.

Nonrestoring division is similar to restoring division in that repeated subtractions of multiples of the denominator are used; however, it differs from the nonrestoring type because the residue may be negative. Figure 3-169 is an example of nonrestoring binary division, using the same numerator and denominator as before. Sign bits are not used. Successive subtractions of multiples of the denominator are performed as before. However, if the residue is negative, the previous positive residue is not restored. A negative residue signifies that a zero should be placed in the quotient for that order and that the next denominator multiple should be added to, rather than subtracted from, the residue. Every time the residue goes positive, a one is added to the appropriate order of the quotient and the next denominator multiple is subtracted. Every time the residue goes negative, a zero is added to the appropriate order of the quotient, and the next denominator multiple is added. The result is exactly the same as restoring division. The numerator is equal to the total of all of the multiples subtracted, minus the total of all the multiples added, plus the remainder. The zero point (residue $=0$ ) is approached from both sides. Figure 3-170 illustrates how this type of division works.

Nonrestoring division using complementing techniques for subtractions is used in Sigma 7. The denominator multiple to be subtracted can then be added to the residue. Figure 3-171 shows a division of the previous numbers, using sign bits (MSD) and two's complementing. The division process in this example is the same as before. Each time a one appears in the sign bit of the residue, a zero is added to the appropriate order of the quotient, and the next denominator multiple is added (remaining in uncomplemented form). Each time that a zero appears in the sign bit of the residue, a one is added to the appropriate order of the quotient, and the next denominator multiple is subtracted (two's complement form is added). The end carry bit is a one each time that a positive residue is reached. Normally, in two's complement additions, this end carry is discarded. In Sigma 7 division, the end carry, designated $K 00$, is used to signify that a positive partial dividend has been obtained. Nonrestoring division, complementing, and the end carry are used in all division cases. There are four different divisions in regard to sign - a positive divided by a positive $\left(\frac{+}{+}\right)$, a positive divided by a negative ( $\left(\frac{+}{-}\right)$, a negative divided by a negative ( $-\overline{-}$ ), and a negative divided by a positive ( $(-)$. In Sigma 7 division, special logic is used to produce the correct quotient in the $\left(\frac{ \pm}{-}\right),\left(\frac{-}{+}\right)$, and $(\stackrel{y}{=}$ cases.
Figure 3-171 is an example of the $\left(\frac{+}{+}\right)$ case. Each time that the end carry is a one, a one is placed in the quotient for that order. Each time that there is no end carry, a zero is placed in the quotient. The final quotient is in the correct form with proper sign and magnitude.
Figure 3-172 shows the case of $(\stackrel{+}{-})$. If a one is put in the quotient for every end carry, the result is the two's complement of the correct quotient as shown, with the opposite sign of the correct quotient. To produce the correct quotient, therefore, a one is put in the quotient when there is no end carry.


Figure 3-166. Multiply Halfword Final Product Assimilation


Figure 3-167. Restoring Division


Figure 3-168. Restoring Division, Graphic Representation


Figure 3-169. Nonrestoring Division


Figure 3-170. Nonrestoring Division, Graphic Representation


Figure 3-171. Nomestoring Division with Two's Complement Addition


Figure 3-172. Plus/Minus Case in Division

A zero is put in the quotient every time that there is an end carry. Adding a one to this quantity produces the correct result.

Figure 3-173 shows the case of $\left(\frac{-}{\dagger}\right)$ which includes two subcases. If a zero residue is produced in iterations, the answer is correct as it stands. If, at the end of the division process, the residue has never been nonzero, the correct quotient is found by adding one to the quantity produced by the division. This difference in methods results from zero being a positive number; the nonrestoring division process becomes nonsymmetrical at the zero point. Eoth subcases produce a quotient bit of one when the end carry is one and produce a quotient bit of zero when the end carry is zero. The process used in both subcases is shown in the figure.

Figure $3-174$ shows the (三) case. The subcase of the nonzero remainder and the subcase of a zero remainder are shown. In both cases, putting a one in the quotient when there is an end carry results in a quantity with an incorrect sign. A one is put in the quotient, therefore, when there is no end carry. A zero is used when there is an end carry. In the nonzero residue case, the result is the correct quotient. A one must be added to the quantity produced to obtain the correct remainder, in the zero residue case. All division cases and accompanying logic for producing the correct quotient are shown in table 3-73.
An eight-bit numerator divided by a four-bit denominator is shown in figure 3-175. Register nomenclature and division methods are similar to Sigma 7 division. The eight-bit numerator is held in the A - and the B -registers. The fourbit denominator is contained in the C -register.


901060A. 3674

Figure 3-173. Minus/Plus Case in Division


Figure 3-174. Minus/Minus Case in Division

Table 3-73. Quotient Logic

| CASE |  | QUOTIENT BIT |  | FORM AT END OF DIVISICN |
| :---: | :---: | :---: | :---: | :---: |
|  |  | 1 | 0 |  |
| Plus/Plus <br> Plus/Minus |  | K00 | NK00 | Correct; no changes necessary |
|  |  | NK00 | K00 | One less than correct quotient; add +1 to form correct quotient |
| Minus/Plus | Zero residue | K00 | NK00 | Correct; no changes necessary |
|  | Nonzero residue | K00 | NKOO | One less than couriect quuatient; add +1 to form correct quotient |
| Minus/Minus | Zero residue | NK00 | K00 | One less than correct quotient; add +1 to form correct quotient |
|  | Nonzero residue | NK00 | K00 | Correct; no changes necessary |



Figure 3-175. Sigma 7 Division

The signs of the numerator and the denominator are held in flip-flops RN and MWN, respectively. The size of the numerator and the demoninator are selected in such a way that the quotient may be held in a four-bit register ( $\left|\frac{N}{d}\right|<2^{3}$ ) The numerator is shifted one bit position to the right to bring the $2^{3}$ bit of the numerator (the maximum bit position of the quotient) over the $2^{0}$ denominator bit before the first iteration.

Either the true denominator $(C)$ or the inverted denominator (NC) may be transferred to the D-register. If NC is transferred, a one is forced into flip-flop CS31 to make up the two's complement of the true denominator. The transfer to the $D$-register is always made so that the $D$-register holds the opposite sign to the numerator (or residue) in the Aand $B$-registers. As each denominator multiple is added to the numerator or residue, one quotient bit is produced. During each iteration, the residue from the addition is shifted one bit position to the left so that the next addition produces the quotient bit for the next lower order. Quotient bits are produced according to the method of the case; each quotient bit is transferred to the least significant bit position of the B -register. After the last iteration, the residue is transferred directly to the A-register; and the quotient is adjusted (see table 3-73).

## 3-203 DESCRIPTION OF DIVIDE WORD INSTRUCTION.

Figure 3-176 shows the register arrangement during instruction Divide Word (DW), FADIVW. Division is similar to the example in figure 3-175. The numerator from the even and odd numbered private memory registers is contained in flip-flop RN (numerator sign), the A-register (numerator bits $2^{62}$ through $2^{31}$ ), and the $B$-register bit positions 0 through 30 (numerator bits $2^{30}$ through $2^{0}$ ). The Cregister holds the true denominator from core memory. Flip-flop MWN holds the sign of the denominator. Either the true denominator or the inverted denominator may be transferred from the C -register to the D -register. The registers are aligned so that the $2^{31}$ bit is the first quotient bit produced. After each iteration except the last, the residue is shifted one place to the left and is transferred back to the A-register. At the same time, the $B$-register is shifted one place to the left; the contents of BO are transferred to A31. Quotient bits are clocked into B31. During the iterations, the quotient fills up more of the B-register as the $A$ - and $B$-registers shift left, and the quotient bits are fed into B31 (the residue becomes smaller). After the 32nd iteration, the B-register holds the 32-bit quotient and the A-register holds the last residue. The quotient is corrected, if necessary, and the remainder is restored from the residue. The quotient is clocked into the odd numbered private memory register, and the remainder is clocked into the even numbered private memory register.

A fixed-point overflow condition exists, if the absolute value of the numerator is relatively large compared with the absolute value of the denominator, and the quotient is larger or equal to $2^{31}$ (too large to be contained in a 32 bit register if a sign bit is to be present. This condition
is detected after the first division iteration and results in a trap to memory location 67.

During PRE1, a one is forced on private memory address line LR31 to obtain the least significant word of the numerator in the odd numbered private memory register. During PRE2, the odd numbered private memory register is clocked into the A-register. The remainder of the preparation sequence is the same as the general preparation sequence.

The following paragraphs describe the phases of instruction DW. Figure 3-176 and the sequence chart, table 3-74, supplement the discussion.

During PHI , the A-register contents are gated to the sum bus by signal SXA. At the PHI clock, the sum bus output is clocked into the B-register by signal BXS. Flip-flop BWZ ( $B$ was zero) is set if bit positions 1 through 31 of the $A-$ register contain zeros. Signal BWZ is used in PHIl for the overflow test. At the PHI clock, the even numbered private memory register contents are transferred to the Aregister. The $A$-register now contains the most significant word of the numerator and the B-register contains the least significant word. Flip-flop RN is set if RRO is true. The denominator from core memory has been read into the C register at this time; if the denominator is negative, flipflop MWN (memory was negative) is set. Flip-flop CC2 is reset; the P -register is cleared by signal PX; and interruptibility is started by setting flip-flop IEN (interrupt enable).

During PH2, the contents of the A-register (most significant word of the numerator) and the B-register (least significant woid of the numerator) are shifted one bit position to the left by signals $A X S L 1$ and BXBLI, respectively. The sign bit of the numerator is still retained in flip-flop RN. BO is clocked into A31. Flip-flop BO is not set. The numerator magnitude is held in A0 through A31 (numerator bits 262 through 231 , respectively) and B0 through B31 (numerator bits 230 through 20 , respectively). The numerator is scaled in this fashion so that the first quotient bit produced is the $2^{3!}$ bit (the numerator $2^{3!}$ bit is in the same relalive position as the denominator $2^{0}$ bit).

At the PH2 clock, the first transfer of the denominator from the C - to the D-register occurs at the PH2 clock. The denominator in the $D$-register must be of the opposite sign to the numerator to accomplish the first nonrestoring division iteration. Comparison of the numerator and the denominator signs is made by comparing flip-flops RN (numerator sign) and MWN (denominator sign). If only one of the flip-flops contains a one, the numerator and denominator signs are unlike, and the contents of register $C$ are clocked into register $D$ by signal $D X C / 6$. If both the flip-flops contain ones or if both contain zeros, the signs of the numerator and denominator are the same. The contents of $C$ are inverted and clocked into the D-register by signal DXNC/1, and a one is forced into CS31 in the case of like signs. The inverted denominator in the D-register and the one in CS31 make up the two's complement of the denominator.


Table 3-74. Divide Word, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PREP | Same as general preparation sequence except that a one is forced onto LR31 address line and PRE2 NIA is as follows | $\begin{aligned} S / L R 31 / 2= & (\text { PRE } 1 \text { NIA }+ \text { PRE3 IX } \\ & + \text { PRE4) FAFRR } / 1+\ldots . \end{aligned}$ | Selects odd numbered private memory register |
| $\begin{aligned} & \text { PRE2 } \\ & \text { NIA } \end{aligned}$ | RRO-RR31 $\longrightarrow$ A0-A31 | AXRR $\quad=$ FAMDSF PRE2 NIA + . . | LSW of numerator $\left(2^{31}-2^{0} \text { bits }\right) \longrightarrow A$ |
| $\begin{array}{\|l\|} \mathrm{PHH} \\ \mathrm{~T} 4 \mathrm{~L} \end{array}$ | $\begin{aligned} & A 0-A 31 \rightarrow S 0-S 31 \\ & S 0-S 31 \rightarrow B 0-\text { B31 } \end{aligned}$ <br> Force a one into flip-flop BWZ if the magnitude of the number in the A-register was zero $\text { RRO-RR31 } \longrightarrow \text { A0-A31 }$ <br> Set flip-flop RN if numerator negative $M B 0-M B 31 \longrightarrow C 0-C 31$ <br> Set flip-flop MWN if denominator negative <br> Reset flip-flop CC2 <br> Clear P -register <br> Set flip-flop IEN to start interruptibility |  | LSW of numerator $\rightarrow B$ <br> MSW of numerator $\left(2^{63}-2^{32} \text { bits }\right) \longrightarrow A$ <br> Stores numerator sign <br> Denominator $\rightarrow C$ <br> Stores denominator sign |
| PH2 | $\begin{aligned} & A 0-A 31 \longrightarrow P R 0-P R 31 \\ & S 1-S 31 \rightarrow A 0-A 31 \\ & B 0 \rightarrow A 31 \\ & \mathrm{BI}-\mathrm{B} 31 \rightarrow \mathrm{~B} 1 \rightarrow \mathrm{~B} 30 \\ & (0 \rightarrow \mathrm{~B} 31) \\ & \mathrm{NCO}-\mathrm{NC} 31 \rightarrow \mathrm{C} 1 \rightarrow-\mathrm{C} 31 \end{aligned}$ | SXPR $=$ FADIVW PH $2+\ldots$ <br> AXSLI $=$ FADIVW PH $2+\ldots$ <br> BXBLI $=$ FADIV PH $2+\ldots$ <br> BXBLI $=$ FADIV PH $2+\ldots$ <br>   <br> DXNC $/ 1$ $=$ <br>  $+\ldots$ | $(D, C S=0)$ <br> Align numerator so that 231 bit is over denominator $2^{0}$ bit. First iteration yields quotient bit $2^{31}$ <br> First transfer of denominator to $D$ made so that D holds opposite polarity to the numerotor |
|  |  |  | Mnemonic: DW (36, B6) |

Table 3-74. Divide Word, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH2 (Cont.) | Force a one into CS31 <br> or $\mathrm{C} 0-\mathrm{C} 31 \rightarrow$ D0-D31 <br> Plus - count iteration counter <br> Set flip-flop PHII | $\begin{gathered} \text { S/CS31 } \\ \text { or } \\ \text { DXC/6 } \\ \text { PCTPI } \\ \text { BRPHI } 1 \end{gathered}$ | $\begin{aligned} & =\text { DXNC } / 1+\ldots \\ & =\text { FADIV PH2 }(M W N \oplus R N) \\ & =\text { FADIV PH2 }+\ldots \\ & =\text { FADIV PH2 }+\ldots \end{aligned}$ | For two's complement |
| $\begin{array}{\|l\|l\|} \text { PHI } \\ \text { T6L } \end{array}$ | 32 clocks if overflow does not occur, 3 clocks if overflow does occur. During the first 30 clocks (no overflow), the following events occur: <br> Enable signal DIT $A+D+C S 31 \longrightarrow S 0-S 31$ <br> $\mathrm{SI}-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 31$ $\mathrm{BO} \nrightarrow \mathrm{~A} 31$ $B 1-B 31 \rightarrow B 0-B 31$ <br> Force a one into B31 $\text { NCO-NC31 } \nrightarrow \text { D0-D31 }$ <br> Force a one into CS31 $C 0-C 31 \rightarrow D 0-D 31$ <br> Set flip-flop SW3 if zero residue numerator is negative and zero residue is reached <br> Count iterations, using P26-P31 <br> Sustain PHIl until DITEX $=1$ <br> On the 31st clock: <br> Other events listed above <br> Enable DITEX | DIT <br> SXADD <br> AXSLI <br> S/A31 <br> A31EN/2 <br> BXBLI <br> S/B31 <br> DXNC/D <br> S/Cs31 <br> DXC/D <br> S/SW3 <br> PCTPI <br> BRPHII | $\begin{aligned} = & \text { FAMDSF } / D \text { PHII }+\ldots \\ = & \text { DIT }+\ldots \\ = & \text { DIT N(FADIV P26) }+\ldots \\ = & \text { A3IEN } / 2 \text { AXSLI } \\ = & \text { BO FAMDSF } \\ = & \text { DIT }+\ldots \\ = & (\text { MWN } \oplus K 00) \text { FADIV PHII } \\ = & \text { FADIV PHII (MWN } \oplus K 00) \\ & +\ldots \\ = & \text { DXNC/D }+\ldots \\ = & \text { FADIV PHII N(MWN } \oplus K 00) \\ = & \text { FADIV PHII RN A003IZ } \\ & +\ldots \\ = & \text { DIT NDITEX + . . . } \\ = & \text { DIT NDITEX + . . } \\ = & \text { FADIV P26 + CC2 + . . } \end{aligned}$ | Most significant part of residue <br> Residue ${ }^{x} \longrightarrow A$, $B$ <br> First quotient bit <br> Polarity of denominator clocked into D and CS31 must be opposite to the residue clocked into A, B <br> Initiate end of iterations |
|  |  |  | nued) | Mnemonic: DW (36, B6) |

Table 3-74. Divide Word, Phase Sequence (Cont.)


Table 3-74. Divide Word, Phase Sequence (Cont.)


Table 3-74. Divide Word, Phase Sequence (Cont.)


Other operations occurring at the PH2 clock include enabling signal PCTPI (plus count P-register) for PHII iteration counting and enabling PHII.

PHIl is the iteration phase of instruction DW. There is one iteration in PHIl for each clock, making a total of 32 iterations. Signal DIT (divide iterations) is set at the beginning of the phase and remains true as long as the iterations are to continue. Signal DITEX (divide iterations exit) goes true at the 32nd clock if there is no fixed-point overflow, or at the third clock if there is fixed-point overflow, and signals the end of the divide iterations.

During the first clock of PHIl, the first addition of the division process occurs. The contents of the A-register (bits $2^{62}$ through $2^{31}$ of the numerator) are summed with the contents of the D-register (true or inverted form of the denominator) and CS31 (contains a one if denominator was inverted in PH 2 ). The sum is the first residue (partial dividend). At the first clock of PHIl , the following division operations occur.
a. The residue is shifted one place to the left by signal AXSLI and is transferred back into the A-register.
b. The contents of B0 are transferred to A31.
c. The B-register is shifted one bit position to the left by signal BXBLI.
d. The first quotient bit is put into B31. The bit is a one if $K 00$ is true and the denominator is positive or if K00 is false and the denominator is negative (see table 3-72).
e. The denominator or the inverted denominator is transferred from the $C$-register to the $D$-register. The transfer is made so that the contents of the $D$-register will be of opposite polarity to the residue in the A-register and will enable the next addition in the nonrestoring process to occur. The true denominator will be transferred by signal DXC/D if the residue is negative and the true denominator is positive, or if the residue is positive and the true denominator is negative. The inverted denominator will be transferred by signal DXNC/D if both the residue and true denominator have like signs. A one is clocked into CS31 in the latter case to make up the two's complement of the denominator when the nexi addition takes place.
f. Iteration counting begins. Flip-flops P26 through P31 make up a six-bit binary iteration up-counter for instruction DW and DH. The count is increased by one (in $\mathrm{PH} 2)$ so that PH 13 will be enabled on clock 32 of PHIl rather than on clock 33 (P26 sets flip-flop PH13). Figure 3-177 shows the counting configurations and the signals enabled for instruction DW.

When the counter indicates 31 iterations, signal DITEX goes true, enabling signal $M R Q / 1$ to request the next instruction. At the next clock (32nd), the P-register is
cleared (signal PX). Signal BRPHIl goes false as DITEX goes true (31st clock). At clock 32, PH13 and clock T10L are enabled, and flip-flop IEN is reset.

During successive clocks of PHI1, another addition takes place, and the operations in steps a through $f$, with the exception of residue transfer on the last iteration and overflow condition, are repeated.

On the last iteration (32nd), signal AXSLI goes false, and signal AXS is enabled. The residue, represented by sum bus outputs S0 through S31, is not shifted before transfer to the A-register; it is transferred directly to the A-register. The residue remains intact ir this case to accomplish PH 13 remainder restoration.

Fixed-point overflow is detected, if present at the second clock of PHIl . Fixed-point overflow occurs if the quotient cannot be contained in a 32 -bit register. (See figure 3-178) If the magnitude of the quotient is greater than or equal to $2^{31}$, at least one $2^{31}$ multiple of the denominator is contained in the numerator. The quotient will be at least 33 bits long (sign bit plus 32 magnitude bits). If the magnitude of the quotient is less than $2^{31}$, the $2^{31}$ multiple of the denominator extends over the zero-point line to make the 231 magnitude bit of the quotient equal to zero. Extension to the opposite side is also true in the case of a negative numerator. After the first iteration, therefore, a residue sign opposite to the numerator sign signifies that there is no overflow and that the next denominator multiple to be added must be of the same sign as the numerator. Unlike denominator multiple and numerator signs after the first iteration indicate that the zero-point was not crossed. Divide overflow is therefore defined by flip-flop RN condition and the contents of DO. The last DIVOVER = RN NDO + NRN DO + D0 A0031 BWZ term defines the case of a zero residue after the first iteration (figure 3-178, second example).

Condition code 2 is set at the second clock of PHIl if signal DIVOVER is true. CC2 enables DITEX, which enables the other control functions (MRQ/1, PX, NBRPHI1, R/IEN). Flip-flops PH13 and T10L are not set. CC2 also causes a trap to memory location $X^{\prime} 43^{\prime}(67)$ if the fixed-point arithmetic mask (AM) is a one. PHI2 is entered if overflow is detected, and signal ENDE is enabled.

Flip-flop SW3 is set if the division involves a negative numerator, and a zero residue is reached after any iteration. If a zero residue is reached in this case, succeeding residues are negative and approach, but do not attain, a zero residue (see figures 3-173 and 3-174). SW3 indicates that the correct remainder of all zeros is to be restored after the division process is completed.

PHI3 is the remainder restoration phase of the instruction. The last residue produced in the iteration process is not necessarily the true remainder of the division. During this phase, the true remainder is restored from the last residue, and the sign of the remainder is adjusted to agree with the
sign of the quotient. There are four remainder cases at the start of the phase.
a. If the last residue is the same sign as the quotient, and flip-flop SW3 is not set, a zero residue was never present during the iterations, and the last residue is the true remainder. The last residue in the A-register is gated to the sum bus by signal SXA.
b. If the last residue is the same sign as the quotient, and flip-flop SW3 is set, the remainder should be all zeros (see figures 3-173 and 3-174). Nothing is gated to the sum bus. The sum bus outputs, S 0 through S 31 , represent a zero remainder.
c. If the last residue is of an opposite sign to the quotient, and if the residue is equal to zero, the residue is the true remainder. Nothing is gated to the sum bus. The sum bus outputs represent a remainder of zero.
d. If the last residue is of an opposite sign to the quotient, and the residue is not equal to zero, it must be converted to a remainder that has the same sign as the quotient. This is done by restoring the next to the last residue, which has the same sign as the quotient. The last bit of the quotient, in this case, must have the absolute value of zero, so that restoring the next to last residue does not alter the quotient. Any further division of the next to the last residue by the same denominator would result in exactly the same quotient as division of the last residue. The last residue in the A-register is added to the denominator multiple in the D-register (already of opposite sign to the last residue) and CS31 (containing a zero or one, depending on the
previous $C$ to $D$ transfer). The true remainder result is gated to the sum bus by signal SXADD. The sum bus outputs, SO through S31, represent the 32 -bit remainder. The remainder is clocked into the even numbered private memory register for storage and into the A-register for PHI 4 testing.
PH14 is the quotient adjustment setup phase of instruction DW. As discussed in paragraph 3-202, certain division cases other than the plus/plus case produce a quantity that is one less than the correct quotient. These cases are detected in this phase, and the one is added in PHI5. The B-register, containing the unadjusted quotient, is gated to the sum bus by signal SXB. At the PH14 clock, the sum bus outputs are clocked into the A-register by signal AXS. At the same time, a one is clocked into CS31 if the plus/minus, minus/ plus with nonzero residue, or minus/minus with zero residue case is being performed. The D-register is cleared by signal DX/1 at the PH14 clock. Flip-flop DRQ is set, inhibiting transmission of another clock until the data signal is received from memory. A one is forced on private memory address line LR31 to select the odd numbered register. T1OL is enabled for PHI5.



Figure 3-177. Divide Word and Divide Halfword Iteration Counting


Figure 3-178. Overflow Detection

During PH 15 , the uncorrected quotient in the A-register is added to CS31 to produce the correct quotient. The sum is gated to the sum bus by signal SXADD and into the odd numbered private memory register by signat RW. Signal AXS also clocks the sum into the A-register at this time. Flip-flop TESTA is set. If A0 is zero and A0 through A31 is nonzero, flip-flop CC3 is set to denote a positive quotient. If AO is a one, flip-flop CC4 is set, to denote a negative quotient. Signal ENDE is generated.

## 3-204 DESCRIPTION OF DIVIDE HALFWORD INSTRUC-

IION. Figure 3-179 shows the register arrangement during instruction Divide Halfword (DH), FADIVH. The 32-bit numerator from the even or odd numbered private memory register is initially contained in flip-flop RN (numerator sign) and bit positions 2 through 30 of the B -register. The A-register bit positions contain sign padding. The $\mathrm{C}-$ register holds the halfword denominator from core memory in bit positions 16 through 31 . Bit positions 0 through 15 contain sign padding for the denominator. Flip-flop MWN contains the denominator sign. The nonrestoring division process is the same as instruction DW. After the 32nd iteration, the B-register holds the 32-bit quotient, and the Aregister holds the last residue. The quotient is corrected if necessary and the true remainder is restored from the residue. The quotient is clocked into the even or odd numbered private memory register. The remainder is discarded. Implementation of instruction DW with an odd value R-field is identical to implementation of instruction DH.

The following paragraphs describe the phases of instruction DH. Figure 3-179 and the sequence chart in table 3-75 supplement the discussion. During PRE2, the numerator in the even or odd numbered private memory register is clocked into the A-register. Flip-flop $R N$ is set if the numerator is negative. The remainder of the preparation sequence is the same as the general preparation sequence.

During PHI , the A -register contents are gated to the sum bus by signal SXA. The sum bus outputs are clocked into the B -register by signal BXS at the PHI clock. Flip-flop BWZ is set if bit positions 1 through 31 of the A-register contain zeros. The word containing the halfword denominator from core memory has been read into the C-register at this time. If the effective halfword is negative, bit 0 or bit 16 of the memory word (zero if P32 is false, 16 if P32 is true) enables signal COC 16, which sets flip-flop MWN. At the PHI clock, the halfword denominator in the C-register is downward aligned into the D-register. The halfword denominator is clocked into bit positions 16 through 31 of the D-register. If COC 16 is true, ones are clocked into bit positions 0 through 15 of the D-register to sign-pad the denominator.

Other functions that occur at the PHI clock include resetting flip-flop CC2, clearing the P-register (signal PX), starting interruptibility by setting flip-flop IEN, and clearing the A-register (signal AX/1). Flip-flop CXS is set only if instruction DH is being implemented (not instruction DW, R31).

The downward-aligned, sign-padded denominator in the Dregister is gated to the sum bus by signal SXD, during PH2. The sum bus outputs are clocked into the C-register by CXS at this clock. (If instruction DW, R31 is being performed, these two operations are not done, since the C-register already contains the 32-bit denominator.) The remainder of PH2 is identical to instruction DW, except for sign-padding of the numerator. If the numerator is negative, ones are put into bit positions 0 through 31 of the CS-register. When the $A-, D-$, and $C S$-registers are added on the first iteration of PHIl , the ones in CSO through CS31 effectively sign-pad the numerator.

The remainder of the operations in PH 2 is identical to instruction DH. In summation:
a. The first denominator multiple is transferred from the $C$-register to the $D$-register so that the $D$-register contains a quantity of an opposite sign to the numerator (NC is transferred to $D$ by signal DXNC/1; C is transferred to $D$ by signal $D X C / 6$ ). If the $C$ contents are inverted and are transferred to the D-register, a one is forced into CS31 if the numerator is positive, or into A31 if the numerator is negative (a one is already in CS31 in this case). The inverted contents of the C -register and the one make up the two's complement of the denominator. For every other $C$ to $D$ transfer (PHI), a one is put into CS31.
b. The B-register is shifted one bit position to the left so that the numerator 231 bit is in the same relative position as the denominator 20 bit. The first quotient bit, therefore, will be the $2^{31}$ bit. A zero is clocked into B31.
c. PCTPI for PHII iteration counting is enabled. The PHIl flip-flop is set.

PHIl is identical to instruction DW. The following operations occur for each iteration:
a. Signal DIT goes true, or remains true.
b. Addition of the A-, D-, and CS-registers occurs (after the first iteration, addition is of the A- and Dregisters and CS31). The residue is shifted one bit position to the left by signal AXSLI and is transferred back to the A-register.
c. The B-register is simultaneously shifted one bit position to the left by signal BXBLI. BO is clocked into A31.
d. The first quotient bit is put into B31.
e. The denominator or inverted denominator is transferred from the C-register to the D-register so that the Dregister contains a quantity of opposite polarity to the residue. A one is clocked into CS31 if the inverted denominator is transferred.


Table 3-75. Divide Halfword, Divide Word $(R=31)$, Phase Sequence


Table 3-75. Divide Halfword, Divide Word ( $R$ : 31), Phase Sequence (Cont.)


Table 3-75. Divide Halfword, Divide Word $(R=31)$, Phase Sequence (Cont.)


Mnemonic: DH (56, D6)

Table 3-75. Divide Halfword, Divide Word ( R • 31), Phase Sequence (Cont.)


Table 3-75. Divide Halfword, Divide Word ( $R=31$ ), Phase Sequence (Cont.)

f. Iteration counting begins. Thirty-two iterations are counted, as described in the section on instruction DW, beginning in paragraph 3-203.
g. SW3 is set if the residue goes to zero after any of the 32 iterations.
h. Overflow is detected after the first iteration. Overflow can occur only if the denominator is zero or if the numerator is $-2^{31}$ and the denominator is $-2^{0}$. Overflow causes a trap to memory location $X^{\prime} 43^{\prime}$ (67). Signal ENDE is generated in PHI2.

PH13 is identical to instruction DW except that clock T6L is used instead of T1OL and that signal RW is not enabled (the remainder is not stored in private memory). The remainder is restored from the last residue as before and is gated to the sum bus and into the A-register (for PH 14 use).

PH14 is the quotient adjustment setup phase, as in instruction DW. The 32-bit quotient is gated from the B-register to the sum bus and is clocked into the A-register. If the quotient needs correction, a one is forced into CS31. Flipflops DRQ and T10L are set as before. A one is not forced on private memory address line LR31/2 in this instruction.

PH15 completes the halfword division. The A-register, containing the unadjusted quotient, is added to CS31. The result is gated to the sum bus and is clocked into the even or odd numbered private memory register for storage. The condition codes are set as in instruction DW.

A sequence chart for the Divide Halfword Instruction is given in table 3-75.

3-205 Add Word to Memory (AWM 66, E6)

The AWM instruction causes a data word to be read from an effective core memory location. The contents of a private memory register addressed in the R-field of the instruction word is added to the data word, and the result is stored back in the effective core memory location. If fixed-point overflow occurs and if the fixed-point arithmetic trap mask (bit 11 of PSD) is a one, the computer traps to location X'43' (67) after loading the sum into the private memory registers. The data word from core memory is loaded into the D-register, and the data word from the selected private memory register is loaded into the A-register. The outputs of the $A$ - and $D$-registers are gated into the adder, and the sum is written into the effective core memory location. The sum is also clocked into the A-register to be tested for condition code information.

If fixed-point overflow occurs, and the fixed-point arithmetic trap mask bit in the PSD is set, the program traps to location X'43' after the sum is stored in core memory. A sequence chart of the Add Word to Memory instruction is given in table 3-76.

## 3-206 Modify and Test Byte (MTB 73, F3)

The MTB instruction causes a data word to be read from the effective core memory address and loads the selected byte into the D-register. The desired word is determined by the byte address which is stored in the private memory register that is addressed in the $X$-field of the instruction word. If the R-field of the instruction word is nonzero, the high order bit (bit position 8 of the $R$-field) is extended to the left to form a byte. This byte is added to the byte contained in the D-register, and the sum is stored back in the effective byte location. The condition code is set according to the value of the resultant byte. The three bits of the R-field plus a sign bit allow modification of a byte by any number from -8 through +7 .

If the R-field of the instruction word is zero, the effective byte is tested for a zero or nonzero value. The result sets the condition code, but the effective byte is not affected.

During the preparation sequence, the index value is shifted two bit positions to the right into the A-register, and the byte selection bits in the two least significant bit positions of the index value are loaded into flip-flops P32 and P33 for byte addressing. The index value is added to the effective address in the D-register, and the operand is read from core memory into the C -register. In the first execution phase, the selected byte is loaded from the C-register into bit positions 24 through 31 of the D-register. The value in the R-field of the instruction word is clocked into flip-flops A28 through A31, and flip-flops CS0 through CS27 are set or are cleared according to the state of R28. The remaining flip-flops in the A- and CS-registers are cleared. The contents of the $A-, D-$, and CS-registers are gated into the adder, and the sum is placed in the A-register. The relevant portion of the sum, in bit positions 24 through 31 of the A-register, is upward aligned into all byte positions of the sum bus, and the sum byte, with byte addressing using the outputs of P32 and P33, is written into the selected byte location in the memory word. Flip-flop CCl is set if an end carry occurs from the byte addition.

Another execution phase is entered, if the instruction is part of an interrupt subroutine. The modified byte in the A-register is checked for a zero or nonzero condition. If the modified byte is all zeros, a counter-equals-zero interrupt is generated, and the appropriate interrupt subroutine is performed. If the modified byte is not all zeros, a priority interrupt exit signal is generated, and flip-flop INTRAPF is reset. The address of the next instruction, which had been stored in the B-register during the interrupt sequence, is gated onto the sum bus and is clocked into the P -register. This address selects the next instruction. A sequence chart for the Modify and Test Byte instruction is given in table 3-77.

## 3-207 Modify and Test Halfword (MTH 53, D3)

The MTH instruction causes a data word to be read from the effective core memory address and loads the selected halfword into the D-register. The desired halfword is determined by the halfword address stored in the private memory

Table 3-76. Add Word to Memory, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PHI | $\begin{aligned} & C 0-C 31 \rightarrow D 0-D 31 \\ & R R 0-R R 31 \rightarrow A 0-A 31 \end{aligned}$ <br> Generate memory request to write into core memory <br> Set flip-flop DRQ <br> Set flip-flop PH2 <br> Enable clock T10L | DXC <br> AXRR <br> MRQ <br> S/DRQ <br> S/PH2 <br> S/TIOL | $\begin{aligned} & =\text { FAS8 PHI }+\ldots \\ & =\text { FUAWM PHI }+\ldots \\ & =\text { FAS8 PHI NRZ }+\ldots \\ & =\text { FAS8 PHI }+\ldots \\ & =\text { NBR PHI N(FNANLZ } \\ & \text { NANLZ) }+\ldots \\ & =\text { FAS24 PHI }+\ldots \end{aligned}$ | Data word from core memory <br> Data word from private memory <br> To write result of addition into core memory <br> Inhibits transmission of another clock until signal received data lines have been strobed |
| PH2 | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31 \\ & +\mathrm{CSO}-\mathrm{CS31} \longrightarrow \mathrm{SO}-\mathrm{S} 31 \end{aligned}$ <br> Generate memory write signal MW <br> Generate write byte signals MBXS/0-MBXS/3 $\mathrm{S} 0-\mathrm{S} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> If an end carry occurs, set flipflop CCl ; otherwise, reset it <br> If fixed-point overflow occurs, set flip-flop CC2; otherwise, reset it <br> Generate memory request for next instruction $\text { Q15-Q31 } \leftrightarrows \text { P15-P31 }$ | SXADD MBO-MB31 MW MBXS/0- MBXS/3 AXS S/CC1 $R / C C 1$ $S / C C 2$ OVER $R / C C 2$ $M R Q / 1$ $P X Q$ |  | Addition of data word from core memory and data word from private memory. $\mathrm{CS}=0$ <br> Sum stored in effective core memory location <br> To be tested for condition code information |
|  |  |  | ued) | Mnemonic: AWM (66, E6) |

Table 3-76. Add Word to Memory, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH2 <br> (Cont.) | P15-P31 $\longrightarrow$ LM15-LB31 <br> Set flip-flop DRQ <br> Set flip-flop PH4 <br> Enable clock T6L | $\begin{aligned} & \text { (NLMXC NLMXQ) } \\ & \text { S/DRQ }= \text { FAS24 PH2 }+\ldots \\ & \\ & \text { S/PH4 }= \text { BRPH4 = FAS8 PH2 NKSC } \\ &+\ldots \\ & \text { T6L }= \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \end{aligned}$ | Inhibits transmission of another clock until data signal received |
| $\begin{array}{\|l\|} \mathrm{PH} 4 \\ \mathrm{~T} 6 \mathrm{~L} \end{array}$ | Set flip-flop TESTA <br> Generate signal ENDE <br> Set flip-flop PREI <br> Enable clock T6L <br> If data word in A-register is all zeros, reset flip-flops CC3 and CC4; if word is negative (A0), set flip-flop CC4 and reset CC3; if word is positive (NA0), set flip-flop CC3 and reset flip-flop CC4 <br> If fixed-point overflow occurs and fixed-point arithmetic trap mask is a one, trap to location X'43' (67) |  |  |

Table 3-77. Modify and Test Byte, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PREI <br> T6L | D12-D14 $\longrightarrow$ LR29-LR31 <br> Generate INDX signal <br> P15-P31 $\rightarrow$ Q15-Q31 <br> RR13-RR29 $\longrightarrow$ A15-A31 <br> Reset A0-A14 <br> RR30 $\rightarrow$ P32 <br> RR31 $\leftrightarrows$ P33 <br> Set flip-flop IX <br> Set flip-flop PRE2 <br> Enable T4RL | LRXD $=$ ENDE <br> INDX $=$ $(\mathrm{Cl} 2+\mathrm{Cl} 3+\mathrm{Cl} 4)$ <br>  $(\mathrm{C} 3+\mathrm{C} 4+\mathrm{C} 5)$ <br> QXP $=$ PRE1 NANLZ $+\ldots$ <br> AXRRR2 $=$ OU7 INDX PRE $1+\ldots$ <br> AX $=$ AXRRR2 <br> S/P32 $=$ RR30 AXRRR2 <br> S/P33 $=$ RR31 AXRRR2 <br> S/IX INDX PRE1 <br> S/PRE2 NPREIM PRE1 N(S/INTRAPF) <br> T4RL $=$ | Index data from private memory index register <br> Byte address <br> Byte address selection |
| $\begin{array}{\|l\|} \hline \text { PRE2 } \\ \text { T4RL } \end{array}$ | $\begin{aligned} & \text { A0-A31 + D0-D31 + CS0-CS31 } \\ & \text { S15-S31 } \\ & \text { P15-P31 } \rightarrow \text { P15-P31 } \\ & \text { LM15-LB31 } \end{aligned}$ <br> Generate memory request for operand <br> Set flip-flop ARQ <br> Reset flip-flop IX <br> Set flip-flop PHI <br> Enable clock T4RL | SXPR $=$ SXADD $=$ PRE2 NIA $+\ldots$ <br> PXS $=$ PRE2 NIA $+\ldots$ <br> (NLMXC $=$ PRE2 NIA NRIP <br> NLMXQ $)$  <br> MRQ PRE2 NIA IX OPRQ NANLZ <br> OPRQ $=$ PRE1 TP140 PREOPRQ $/ 2$ <br>  latched <br> PREOPRQ/2 $=$ C3 NC4 NC5 $+\ldots$ <br> S/ARQ $=$ PRE2 NIA IX $+\ldots$ <br> R/IX $=$ <br> S/PH1 PRE2 NIA $+\ldots$ <br> T4RL NPREDO PRE2 NIA $+\ldots$ | Modified program address <br> Inhibits transmission of another clock until data release signal received |
|  |  | (Continued) | Mnemonic: MTB (73, F3) |

Table 3-77. Modify and Test Byte, Phase Sequence (Cont.)


Table 3-77. Modify and Test Byte, Phase Sequence (Cont.)


Table 3-77. Modify and Test Byte, Phase Sequence (Cont.)


Table 3-77. Modify and Test Byte, Phase Sequence (Cont.)

register and addressed in the X -field of the instruction word. If the R-field of the instruction word is nonzero, the high order bit (bit position 8 of the $R$-field) is extended to the left to form a halfword. This halfword is added to the halfword contained in the D-register, and the sum is stored in the effective halfword location. The condition code register is set according to the value of the resultant halfword. The three bits of the R-field plus a sign bit allows modification of a halfword by any number from -8 to +7 .

If the R-field of the instruction word is zero, the effective halfword is tested for being a zero or nonzero value. The condition code is set as a result of this test, but the effective halfword is not affected.

During the preparation sequence, the index value is shifted one bit position to the right into the A-register, and the halfword selection bit in the least significant bit position of the index value is loaded into flip-flop P32 for halfword addressing. The index value is added to the effective address in the D-register, and the operand is read from core memory into the C-register. When the data is on the memory bus, the selected halfword is loaded into flip-flops D15 through D31. The value in the R-field of the instruction word is clocked into flip-flops A28 through A31, and flipflops CS0 through CS27 are set or are cleared according to the state of flip-flop R28. The remaining flip-flops in the A- and CS-registers are cleared. The contents of the A-, $D-$, and CS-registers are gated into the adder, and the sum is placed in the A-register. Flip-flop CCl is set if an end carry occurs in this operation. If fixed-point overflow occurs, flip-flop CC2 is set. The relevant portion of the sum, in bit positions 15 through 31 of the A-register, is upward aligned into both halfword positions of the sum bus, and with halfword addressing, using the output of flip-flop P32, the sum byte is written into the selected byte location in the memory word.

If the MTH instruction is not being performed in an interrupt sequence, execution ends and the program goes to the preparation sequence for the next instruction. Condition code flip-flops are set. If overflow has occurred and if the fixedpoint arithmetic trap mask bit in the PSD is set, the program traps to location $X^{\prime} 43^{\prime}$ after the result is stored in the effective halfword location.

If the instruction is part of an interrupt subroutine, another execution phase is entered. The modified halfword in the A-register is checked for a zero or nonzero condition. If the modified halfword is all zeros, a counter-equals-zero interrupt is generated, and the appropriate interrupt subroutine is performed. If the modified halfword is not all zeros, a priority interrupt exit signal is generated, and flip-flop INTRAPF is reset. The address of the next instruction, which had been stored in the B-register during the interrupt sequence, is gated onto the sum bus and is clocked into the P -register. This address selects the next instruction. A sequence chart of the Modify and Test Halfword is given in table 3-78.

## 3-208 Modify and Test Word (MTW 33, B3)

The MTW instruction causes a data word to be read from the effective core memory address. If the R-field of the instruction word is nonzero, the high order bit (bit position 8 of the R-field) is extended 28 bit positions to the left to form a 32-bit word. This word is added to the data word from core memory, and the sum is stored back in the effective core memory location. The three bits of the R-field plus a sign bit allow modification of a word by any number from -8 to +7 .

If the R-field of the instruction word is zero, the effective word is tested for being zero, negative, or positive. As a result, the condition code is set but the effective word is not affected.

The core memory operand is loaded into the D-register, and the value in the $R$-field of the instruction word is clocked into flip-flops A28 through A31. Flip-flops CS0 through CS27 are set or are cleared according to the state of flipflop R28. This extends the R-field 28 bit positions to the left as the contents of the A-, D-, and CS-registers are gated into the adder. The sum is clocked into the Aregister for testing and onto the core memory data lines for writing into memory. If an end carry occurs, flip-flop CCl is set; if overflow occurs, flip-flop CC2 is set.

If the MTW instruction is not being performed in an interrupt sequence, execution ends and the program goes to the preparation sequence for the next instruction. The program traps to location X'43' after the result is stored in the effective location, if overflow has occurred and if the fixed-point arithmetic trap mask bit in the PSD is set.

If the MTW instruction is part of an interrupt subroutine, a check of the A-register is made for a zero or nonzero condition. If the modified word is all zeros, a counter-equalszero interrupt is generated, and the program branches to the appropriate subroutine. If the modified word is not all zeros, a priority interrupt exit signal is generated, and flipflop INTRAPF is reset. A sequence chart of the Modify and Test Word instruction is given in table 3-79.

## 3-209 Compare Immediate (CI 21)

The Compare Immediate instruction extends the sign of the value field (bit 12) of the instruction word 12 bit positions to the left. It also compares the 32 -bit result with the contents of register $R$ and sets the condition code according to the results of the comparison.

The Cl instruction sequences through the preparation phases in which the contents of the selected private memory register are transferred to the A-register. The CS-register is set to ones, and the D-register is cleared to zeros. The one's complement of the private memory word is taken by performing an exclusive-OR operation on the word in the A-register and on the ones in the CS-register.

Table 3-78. Modify and Test Halfword, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{aligned} & \text { PRE } \\ & \text { T6L } \end{aligned}\right.$ | $\text { D12-D14 }- \text { LR29-LR31 }$ <br> Generate signal INDX <br> P15-P31 $\longrightarrow$ Q15-Q31 <br> RR14-RR30 $\rightarrow$ A15-A31 <br> RR31 $\rightarrow$ P32 <br> Set flip-flop IX <br> Set flip-flop PRE2 <br> Enable T4RL | LRXD <br> INDX <br> QXP <br> AXRRRI <br> S/P32 <br> S/IX <br> S/PRE2 <br> T4RL | $\begin{aligned} = & \text { ENDE } \\ = & (C 12+C 13+C 14) \\ & (C 3+C 4+C 5) \\ = & \text { PREI NANLZ }+\ldots \\ = & \text { OU5 INDX PRE1 }+\ldots \\ = & \text { RR31 AXRRR1 }+\ldots \\ = & \text { INDX PREI } \\ = & \text { NPREIM PREI N(S/INTRAPF }) \\ = & \text { PREP }+\ldots \end{aligned}$ | Selects index register containing halfword address <br> Next instruction address <br> Index data shifted right one bit position <br> Halfword select bit |
| $\begin{array}{\|l} \text { PRE2 } \\ \text { T4RL } \end{array}$ | $A 15-A 31+D 15-D 31+C S 15-$ <br> CS31 $\longrightarrow$ S15-S31 <br> $\mathrm{S} 15-\mathrm{S} 31 \longrightarrow \mathrm{P} 15-\mathrm{P} 31$ <br> P15-P3I $\longrightarrow$ LM15-LB31 <br> Generate memory request <br> Set flip-flop ARQ <br> Reset flip-flop IX <br> Set flip-flop PHI <br> Enable clock T4RL | SXPR <br> PXS <br> (NLMXC <br> NLMXQ) <br> MRQ <br> S/ARQ <br> R/IX <br> S/PHI <br> T4RL | $\begin{aligned} = & \text { SXADD }=\text { PRE2 NIA }+\ldots \\ = & \text { PRE2 NIA }+\ldots \\ = & \text { PRE2 NIIA NRIP }+\ldots \\ = & \text { PRE2 NIA IX OPRQ NANLZ } \\ & +\ldots \\ = & \text { PRE2 NIA IX + } \ldots \\ = & \text { PRE2 NIA } \\ = & \text { NPRED0 PRE2 NIA }+\ldots \\ = & \text { PREP }+\ldots \end{aligned}$ | Add indexing data and operand address <br> Address $\longrightarrow$ memory address lines <br> Memory request for operand <br> Inhibits transmission of another clock until address release signal received |
| $\left\lvert\, \begin{aligned} & \mathrm{PHI} \\ & \mathrm{~T} 4 \mathrm{RL} \end{aligned}\right.$ | If P32 is a zero, clock bit MBO into flip-flops D0 through D15 <br> If P32 is a one, clock bit Míló into flip-flops D0 through D15 | $\mathrm{COC16Cl} 12$ <br> COC16/1 <br> COClóCl2 <br> $\mathrm{COCl} 16 / 1$ | $\begin{aligned} & =\text { MBO NP32 CXMB }+\ldots \\ & =\text { MB0 NP32 CXMB }+\ldots \\ & =\text { M'B16́ P32 CXMB }+\ldots \\ & =\text { MB16 P32 CXMB }+\ldots \end{aligned}$ | Sign bit extended <br> Sign bit extended |
|  |  |  | ued) | Mnemonic: MTH (53, D3) |

XDS 901060

Table 3-78. Modify and Test Halfword, Phase Sequence (Cont.)


Table 3-78. Modify and Test Halfword, Phase Sequence (Cont.)


Table 3-78. Modify and Test Halfword, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH4 <br> T6L <br> IN- <br> TRAPF | If part of interrupt subroutine <br> If modified halfword in A-register is all zeros, generate counter-equals-zero interrupt signal CNTZREQ <br> If modified halfword in A-register is not all zeros, generate interrupt exit signal LEVACT <br> Generate interrupt arming signal LEVARM <br> Gate address of next instruction from $B$-register onto sum bus <br> Clock address from sum bus into P -register <br> Generate memory request for instruction if part of interrupt sequence <br> Set flip-flop DRQ <br> Set flip-flop PH5 <br> Enable clock T6L <br> Reset flip-flop INTRAPF | CNTZREQ <br> LEVACT <br> LEVARM <br> SXB <br> PXS <br> MRQ <br> $S / D R Q$ <br> S/PH5 <br> T6L <br> R/INTRAPF | $\begin{aligned} & =\text { FAS7 PH4 INTRAPF } \\ & \text { A003IZ } \\ & = \\ & =\text { FAS7 PH4 INTRAPF + . . } \\ & =\text { FAS7 PH4 INTRAPF + . . } \\ & =\text { FAS7 PH4 INTRAPF + ... } \\ & =\text { FAS7 PH4 INTRAPF + ... } \\ & =\text { FAS7 PH4 INTRAPF + ... } \\ & =\text { PH4 NBR + . . } \\ & =\text { NTIL NT4L NT8L NT10L } \\ & =\text { FASESET PH4 INTRAPF + . . } \end{aligned}$ | Counter-equals-zero interrupt $\mathrm{A} 0031 \mathrm{Z} \Rightarrow$ contents of A-register - 0 . Go to appropriate subroutine <br> Address stored in Bregister during interrupt subroutine <br> Inhibits transmission of another clock until data signal received |
| PH4 <br> TGL <br> NIN- <br> TRAPF | Set flip-flop PREI <br> Enable clock T6L <br> Generate signal ENDE <br> Set flip-flop TESTA | S/PRE 1 <br> T6L <br> ENDE <br> S/TESTA | ```= ENDE (NHALT + FUEXU) N(S/INTRAPF) = NTIL NT4L NT8L NTIOL NRESET = FAS24 PH4 NINTRAPF +. = FAS24 PH4 NINTRAPF +.``` | Go to PRE1 of next instruction if not interrupt sequence <br> If instruction is not in an interrupt sequence <br> To test condition code flip-flops |
|  |  |  | ued) | Mnemonic: MTH (53, D3) |

Table 3-78. Modify and Test Halfword, Phase Sequence (Cont.)


Mnemonic: MTH (53, D3)

Table 3-79. Modify and Test Word, Phase Sequence


Table 3-79. Modify and Test Word, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH2 <br> T10L <br> (Cont.) | $\begin{aligned} & \text { Q15-Q31 } \rightarrow \text { P15-P31 } \\ & \text { P15-P31 } \longrightarrow \text { LM15-LB31 } \end{aligned}$ <br> Set flip-flop PH4 <br> Enable clock T6L |  | Address of next instruction |
| $\begin{aligned} & \text { PH4 } \\ & \text { T6L } \\ & \text { IN- } \\ & \text { TRAPF } \end{aligned}$ | If not part of interrupt subroutine <br> Generate signal ENDE <br> Set flip-flop TESTA <br> Set flip-flop PREI <br> Enable clock T6L <br> If data word in A-register is positive (NA0), set flip-flop CC3 and reset CC4; if data word is negative (A0), set flip-flop CC4 and reset flip-flop CC3 <br> If part of interrupt subroutine <br> If overflow occurred (flip-flop CC2 set) and fixed-point arithmetic trap mask (bit 11 of PSD) is a one, trap to location $X^{\prime} 43^{\prime}$ (67) |  | To test for condition code settings |

Table 3-79. Modify and Test Word, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH4 <br> T6L <br> IN- <br> TRAPF <br> (Cont.) | If modified word in A-register is all zeros, generate count zero interrupt CNTZREQ <br> If modified word in A-register is not all zeros, generate interrupt exit signal LEVACT <br> Generate interrupt arming signal LEVARM <br> Reset flip-flop INTRAPF $\mathrm{B} 15-\mathrm{B} 31 \longrightarrow \mathrm{~S} 15-\mathrm{S} 31$ <br> S15-S31 $\nrightarrow$ P15-P31 <br> $\mathrm{P} 15-\mathrm{P} 31 \longrightarrow$ LM15-LB31 <br> Generate memory request for next instruction if part of interrupt sequence <br> Set flip-flop DRQ <br> Set flip-flop PH5 <br> Enable clock T6L |  | Address of next instruction stored in B-register during interrupt subroutine <br> INTRAPF $\Longrightarrow$ interrupt sequence <br> Inhibits transmission of another clock until data signal received |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | Generate signal ENDE <br> Set flip-flop PREI <br> Enable clock T6L | ENDE $=$ FAS24 PH5 $+\ldots$ <br> S/PRE1 $=$ ENDE (NHALT + FUEXU) <br>  N(S/INTRAPF) <br> T6L $=$ NTIL NT4L NT8L NTIOL <br>  NRESET | To begin preparation for next instruction |
|  |  |  | Mnemonic: MTW (33, B3) |

This complement is transferred to the B -register. The immediate value in bits 12 through 31 of the C-register is transferred to the D-register, and the value of Cl 2 is transferred to flip-flops D0 through D11 to extend the sign. The individual bits in the $A$ - and D-registers are compared with an AND operation, and the result is placed in the A-register. If the A-register contains zeros, indicating that no bits of the private memory word and the sign-extended immediate value were coincident, flip-flop CC2 is reset. Otherwise, CC2 is set.

The contents of the B-register are transferred to the Aregister, and a one is set into flip-flop CS31 to obtain the two's complement of the private memory word. The contents of the A-and D-registers are added, subtracting the private memory word from the immediate value. The sum is placed in the A-register.

An end carry out of bit position 0 is stored in flip-flop K00H, This flip-flop and the contents of the A-register are examined in the first preparation phase of the following instruction, or in the first phase of interrupt, trap, or control panel operation. Flip-flop CC4 is set if a nonzero value in the A -register and a one in KOOH indicate that the private memory word is less than the immediate value. A zero in K 00 H and a nonzero value in the A-register cause flip-flop CC3 to be set. This indicates that the private memory word is greater than the immediate value. A sequence chart of the Compare Immediate instruction is given in table 3-80.

## 3-210 Compare Byte (CB 71, F1)

The CB instruction compares the contents of bit positions 24 through 31 of register $R$ with the effective byte. Both bytes are treated as positive magnitudes. The condition code is set according to the results of the comparison.

Because the Compare Byte instruction addresses a byte, it becomes an indexed instruction if the $X$-field does not equal zero. Indexing is described under preparation phases. A memory request for the effective byte is made during indexing, and flip-flop RQ is set to request the next instruction as soon as the operand is received.

Signal AXRR2 is true in the preparation sequence, and causes a downward alignment of the index register two bit positions into the A-register. At this same clock, bits 30 and 31 of the index register are transferred to P32 and P33, respectively. The configuration placed into P32 and P33 determines which core memory byte is to be clocked into the D-register.

| S/A15 | $=$ RR13 AXRRR2 |
| :--- | :--- |
| $\vdots$ | $\vdots$ |
| S/A31 | $=$ RR29 AXRRR2 |
| AXRRR2 | $=$ OU7 INDX PRE1 |
| S/P32 | $=$ RR30 AXRRR2 |
| S/P33 | $=$ RR31 AXRRR2 |

Byte 3 (bits 24 through 31) of the addressed private memory register is gated to A24 through A31. Zeros are clocked into A0 through A23, the CS-register is filled with ones and the D-register is cleared to zeros.

In PH2 an AND operation is performed on the contents of the A - and D -registers (the original contents of the private memory register word and the effective operand). The result of this operation is taken from the sum bus and is placed into the A-register at the clock that ends PH2.

The selected byte from the core memory word is loaded into bits 24 through 31 of the D-register. The one's complement of the private memory byte is taken by performing an exclusive OR operation on the byte in bits 24 through 31 of the A-register and the ones in the CS-register. This complement is transferred to the B-register. The individual bits in the bytes which are in the least significant byte positions in the A- and D-registers are compared with an AND operation, and the result is placed in the A-register. If the Aregister contains zeros, indicating that no bits of the private memory byte and the effective byte are coincident, flip-flop CC2 is reset. Otherwise, CC2 is set.

The contents of the B-register are transferred to the Aregister, and a one is set into flip-flop CS31 to obtain the two's complement of the private memory byte. The contents of the A- and D-registers are added, subtracting the private memory byte from the effective byte, and the sum is placed in the A-register. A carry into 500 is stored in flip-flop K 00 H . This flip-flop and the contents of the A-register are examined in the first preparation phase of the following instruction, or in the first phase of interrupt, trap, or control panel operation, if one of these occurs next. Flip-flop CC4 is set if a nonzero value in the A-register and a one in K 00 H indicate that the private memory byte is less than the private memory word. A zero in K 00 H and a nonzero value in the A-register cause flip-flop CC3 to be set. This indicates that the private memory byte is greater than the effective byte. A sequence chart of the Compare Byte instruction is given in rable 3-81.

## 3-211 Compare Halfword (CH 51, DI)

The Compare Halfword instruction extends the sign of the effective halfword 16 bit positions to the left and then compares the 32-bit result with the contents of the addressed private memory register. Both words are treated as signed magnitudes. The condition code is set according to the results of the comparison.

The instruction sequences through the preparation states. Because the instruction addresses a halfword, it effectively becomes an indexed instruction if the $X$-field does not equal zero. Indexing is described under the preparation sequence. During indexing, flip-flop MRQ is set to request the effective halfword, and flip-flop $R Q$ is set to request the next instruction as soon as the operand is received.

Table 3-80. Compare Immediate, Phase Sequence


Table 3-80. Compare Immediate, Phase Sequence (Cont.)


Table 3-80. Compare Immediate, Phase Sequence (Cont.)


Table 3-81. Compare Byte, Phase Sequence

\begin{tabular}{|c|c|c|c|c|}
\hline Phase \& Function Performed \& \& Signals Involved \& Comments \\
\hline PRE2 \& \begin{tabular}{l}
\[
\begin{aligned}
\& R R 24-R R 31 \rightarrow A 24-A 31 \\
\& 1 ' s \rightarrow \text { CS0-CS31 } \\
\& 0 ' s \rightarrow \text { D0-D31 }
\end{aligned}
\] \\
Enable T4RL \\
Set PHI
\end{tabular} \& \begin{tabular}{l}
AXRR/3 \\
CSXI \\
DX/I \\
S/T4RL \\
S/PHI
\end{tabular} \& \[
\begin{aligned}
\& =\text { PRE2 NIA FUCB }+\ldots \\
\& =\text { PRE2 NIA FASII }+\ldots \\
\& =\text { PRE2 NIA } \\
\& =\text { PREP }+\ldots \\
\& =\text { NPRED0 (PRE2 NIA) }+\ldots
\end{aligned}
\] \& \begin{tabular}{l}
Private memory byte 3 into A-register \\
Set all ones into CSregister \\
Reset \(D\) to zeros
\end{tabular} \\
\hline \begin{tabular}{l}
PHI \\
T4RL
\end{tabular} \& \begin{tabular}{l}
Enable T4L clock \\
Set PH2
\end{tabular} \& \begin{tabular}{l}
CXMB \\
DXCR24 \\
DXCR16/1 \\
DXCR8 \\
DXC/ 1 \\
DXCBP \\
SXPR \\
BXS \\
CSXI \\
S/NPRX \\
S/T4L \\
S/PH2
\end{tabular} \& \[
\begin{aligned}
\& =\text { DGC } \\
\& =\text { NP32 NP33 DXCBP }+\ldots \\
\& =\text { NP32 P33 DXCBP }+\ldots \\
\& =\text { P32 NP33 DXCBP }+\ldots \\
\& =\text { P32 P33 DXCBP }+\ldots \\
\& =\text { OU7 NO4 NO5 PHI }+ \\
\& =(\text { FAS11 PHI })+\ldots \\
\& =\text { FASII PHI }+\ldots \\
\& =\text { SNNPRX }+\ldots \\
\& =F A S I I P H I+\ldots \\
\& =F A S I I P H I+\ldots \\
\& =P H 1 N B R N(F N A N L Z ~
\end{aligned}
\] \& \begin{tabular}{l}
Effective byte into Cregister depending on configuration of P32 and P33 \\
Exclusive OR action places one's complement of \(A\) onto sum bus \\
One's complement of private memory into \(B\) register for adding in PH4 \\
Prepare for AND action in PH2
\end{tabular} \\
\hline PH2

T4L \& \begin{tabular}{l}
$$
\text { A0-A31 D0-D31 } \longrightarrow \text { S0-S31 }
$$
$$
\mathrm{SO} 0-\mathrm{S} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 31
$$ <br>
Enable T4L clock

 \& 

SXPR <br>
AXS <br>
S/T4L

\end{tabular} \& \[

$$
\begin{aligned}
& =\text { NPRX NSDIS }+\ldots \\
& =\text { FAS11 PH2 }+\ldots \\
& =\text { FAS11 PH2 }+\ldots
\end{aligned}
$$

\] \& | Compare coincident |
| :--- |
| 1-bits in private memory byte and effective byte |
| Put results into $A$ | <br>

\hline \& \& \& ued) \& Mnemonic: CB (71, F1) <br>
\hline
\end{tabular}

Table 3-81. Compare Byte, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 4 \mathrm{~L} \\ & \text { (Cont.) } \end{aligned}\right.$ | Set PH3 | $\begin{aligned} \mathrm{S} / \mathrm{PH} 3= & \mathrm{PH} 2 \mathrm{NBR} \text { N(FNANLZ } \\ & \text { NANLZ })+\ldots \end{aligned}$ |  |
| PH3 | $\left\{\begin{array}{l} 0 \xrightarrow{H} \mathrm{CC} 2 \\ \text { If } \mathrm{A} 0-\mathrm{A} 31 \neq 0,1 \longrightarrow \mathrm{CC} 2 \\ \mathrm{BO}-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ \mathrm{SO-S31} \longrightarrow \mathrm{~A} 0-\mathrm{A} 31 \\ 1 \rightarrow \mathrm{CS31} \end{array}\right.$ <br> Set $D R Q$ for next instruction <br> Enable T6L clock <br> Set PH4 |  | If no bits of private memory byte and effective byte are coincident, reset CC2; otherwise, set CC2 <br> One's complement of private memory word <br> For two's complement <br> Inhibits clock until data release received from memory |
| $\begin{aligned} & \mathrm{PH} 4 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | Generate ENDE $\begin{aligned} & A 0-A 31+D 0-D 31+C S 31 \longrightarrow \\ & S 0-S 31 \\ & S 0-S 31 \longrightarrow A 0-A 31 \\ & \text { If D0-D31 } \geq A 0-A 31,1 \longrightarrow \mathrm{~K} 00 \mathrm{H} \end{aligned}$ <br> Set flip-flop KOOH if $\mathrm{SOO}=1$ <br> Set flip-flop TESTA <br> Set flip-flop TESTA/I <br> Enable T6L clock <br> Set flip-flop PREI |  | Subtract effective byte from private memory byte <br> Difference into $A$ $\begin{aligned} & S 00 X=1 \text { if } A 0 \neq D 0 \\ & N S 00 X N=1 \end{aligned}$ <br> To test for condition codes |

Mnemonic: CB (71, F1)

Table 3-81. Compare Byte, Phase Sequence (Cont.)


Mnemonic: CB $(71, \mathrm{FI})$

Signal AXRR1 is true causing a one-bit downward alignment of the index register into the A-register at the clock ending PRE1. At this same clock, bit 31 of the index register is transferred to P32. The status of P32 will later determine which core memory halfword is to be clocked into the Dregister.

At the clock pulse ending PRE2, the halfword in private memory is clocked into the A-register. The CS-register is filled with ones and the D-register is reset to zeros.

If halfword 0 were addressed, RQ would have been set at the end of PREI, because the Compare Halfword instruction would not have been indexed. Flip-flop NPRX is reset at the end of PRE2 for the exclusive OR operation in the first execution phase.

The one's complement of the private memory halfword is taken by performing an exclusive OR operation on the halfword in the A-register and the ones in the CS-register, and this complement is transferred to the B-register. The selected halfword in the C-register is transferred to bits 16 through 31 in the D-register, and the sign bit is extended to bits 0 through 15 of the D -register. The individual bits in the A- and D-registers are compared with an AND operation, and the result is placed in the A-register. Flip-flop CC2 is reset if the A-register contains zeros, indicating that no bits of the private memory halfword and the signextended halfword are coincident. Otherwise CC2 is set.

The contents of the B-register are transferred to the Aregister, and a one is set into flip-flop CS31 to obtain the two's complement of the private memory halfword. The contents of the A-and D-registers are added, subtracting the private memory halfword from the effective halfword, and the result is placed in the A-register. An end carry from bit 0 is stored in flip-flop K00H. This flip-flop and the contents of the A-register are examined in the first preparation phase of the following instruction, or, at times, in the first phase of interrupt, trap, or control panel operation. Flip-flop CC4 is set if a nonzero value in the Aregister and a one in KOOH indicate that the private memory halfword is less than the effective halfword. A zero in K 00 H and a nonzero value in the A-register cause flipflop CC3 to be set, indicating that the private memory halfword is greater than the effective halfword. A sequence chart of the Compare Halfword instruction is given in table 3-82.

## 3-212 Compare Word (CW 31, B1)

The Compare Word instruction compares the contents of the register specified by the R-field with the contents of the effective word. Both words are treated as signed quantities. The condition code is set according to the results of the comparison.

The CW instruction sequences through the preparation states. If the instruction is not indirectly addressed, a memory request is generated for the next instruction. The
address of the next instruction is taken from the address contained in the Q-register:

## $S / R Q=$ NIA PREI NINDX (NANLZ PRERQ)

The contents of the addressed private memory register are transferred to the A-register, ones are placed into the CSregister, and the D-register is cleared to zeros. The one's complement of the private memory word is taken by performing an exclusive-OR operation on the word in the Aregister and the ones in the CS-register, and this complement is transferred to the B-register. The effective word in the C-register is transferred to the $D$-register. The individual bits in the A-and D-registers are compared with an AND operation, and the result is placed in the A-register. If the A-register contains zeros, indicating that no bits of the private memory word and the effective word were coincident, flip-flop CC2 is reset. Otherwise, CC2 is set.

The contents of the B-register are transferred to the Aregister, and a one is set into flip-flop CS31 to obtain the two's complement of the private memory word. The contents of the A-and D-registers are added, subtracting the private memory word from the effective word. The sum is placed in the A-register. The presence or absence of an end carry, depending on the sign, is stored in flip-flop KOOH . This flip-flop and the contents of the A-register are examined in the first preparation phase of the following instruction or in the first phase of interrupt, trap, or control panel operation. Flip-flop CC4 is set if a nonzero value in the A-register and a one in K 00 H indicate that the private memory word is less than the effective word. A zero in K 00 H and a nonzero value in the A-register cause flipflop CC3 to be set, indicating that the private memory word is greater than the effective word. A sequence chart of the Compare Word instruction is given in table 3-83.

## 3-213 Compare Doubleword (CD 11, 91)

The Compare Doubleword instruction compares the effective doubleword with the contents of register $R$ and $R+1$. Both doublewords are treated as signed magnitudes. The condition code bits CC3 and CC4 are set according to the results of the comparison.

During PRE1, the address of the low order half of the doubleword in memory is gated onto the core memory lines from the C-register by forcing a one onto address line LB31 to select the odd numbered memory location.
The low order half of the data doubleword is read into the C-register during PRE2, and a memory request is generated for the high order half of the memory doubleword. Since the high order half of the doubleword is in an even numbered location, a zero is forced onto address line LB31 by inhibiting flip-flop P31 from setting regardless of the state of S31. At the clock ending PRE2, flip-flop LR31/2 is set to force a one onto private memory address line LR31 to obtain the low order half of the private memory register doubleword. The remainder of the preparation sequence is the same as the general preparation sequence.

Table 3-82. Compare Halfword, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PRE2 | $\begin{aligned} & \text { RRO-RR31 } \rightarrow \text { A0-A31 } \\ & 1 ' s \rightarrow C S 0-C S 31 \\ & 0 ' s \rightarrow D 0-D 31 \end{aligned}$ <br> Enable T4RL clock Set PHI | AXRR <br> CSXI <br> DX <br> S/T4RL <br> S/PHI | $\begin{aligned} = & \text { PRE2 NIA FASI1 NFUCB } \\ & +\ldots \\ = & \text { FAS11 PRE2 NIA }+\ldots \\ = & \text { PRE2 NIA }+\ldots \\ = & \text { PREP }+\ldots \\ = & \text { PRE2 NIA NPREDO }+\ldots \end{aligned}$ | Private memory halfword into A-register <br> Set ones into CS-register <br> Clear D-register to zeros |
| PHI \|T4RL | If NP32, $\mathrm{C} 0-\mathrm{Cl} 5 \rightarrow$ D16-D31 <br> $\mathrm{C} 0 \rightarrow$ D0-D15 <br> If P32, C16-C31 $\longrightarrow$ D16-D31 <br> $\mathrm{Cl} 6 \rightarrow$ D0-D15 <br> $\mathrm{A} 0-\mathrm{A} 31 \oplus \mathrm{CSO}-\mathrm{CS31} \longrightarrow \mathrm{SO}-\mathrm{S31}$ <br> $\mathrm{SO}-\mathrm{S} 31 \rightarrow \mathrm{BO}-\mathrm{B} 31$ <br> $1 \mathrm{~s} \rightarrow \mathrm{CSO}-\mathrm{CS} 31$ <br> Enable T4L clock <br> Set PH2 | DXCR16 <br> DXC/5 <br> DXC/12 <br> COCl 6 <br> SXPR <br> BXS <br> CSXI <br> NPRX <br> S/T4L <br> S/PH2 | $\begin{aligned} & =\text { NP32 DXC } / 5 \\ & =\text { OU5 NO4 NO5 PHI }+\ldots \\ & =\mathrm{DXC} / 7=\mathrm{DXC} / 2=\mathrm{DXC} / 5 \\ & =\text { CXRR (RR0 NP32 }+ \text { RR16 P32) } \\ & =\text { FASIIPHI }+\ldots \\ & =\text { FASII PHI }+\ldots \\ & =\text { S/NPRX }+\ldots \\ & =\text { FASII PHI }+\ldots \\ & =\text { FAS11 PHI }+\ldots \\ & =\text { PHI NBR N(FNANLZ } \\ & \text { NANLZ) }+\ldots \end{aligned}$ | Effective halfword into Cregister, depending on state of P32 <br> Extend sign left <br> Exclusive OR action places one's complement of A onto sum bus. One's complement of private memory halfword into Bregister for addition <br> Prepare for AND action in PH 2 |
| PH2 | $A 0-A 31 \wedge D 0-D 31 \longrightarrow S 0-S 31$ $50-531 \longrightarrow A 0-A 31$ <br> Enable T4L clock <br> Set PH 3 | SXPR <br> AXS <br> S/T4L <br> S/PH3 | $\begin{aligned} = & \text { NPRX } \\ = & \text { FASII PH2 }+\ldots \\ = & \text { FAS11 PH2 }+\ldots \\ = & \text { PHZ } 2 \text { NBR } N(\text { FNAANLZ } \\ & \text { NANLZ })+\ldots \end{aligned}$ | Compare coincident 1-bits in private memory halfword and effective halfword. Put results into $A$ |
|  |  |  | ved) | Mnemonic: $\mathrm{CH}(51, \mathrm{DI})$ |

Table 3-82. Compare Halfword, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH3 } \\ & \text { T4L } \end{aligned}$ | $\begin{aligned} & 0 \rightarrow \mathrm{CC} 2 \\ & \text { If } \mathrm{A} 0-\mathrm{A} 31=0,1 \longrightarrow \mathrm{CC} 2 \\ & \mathrm{BO}-\mathrm{B} 31 \longrightarrow \text { SO-S31 } \\ & \mathrm{SO-S31} \longrightarrow \mathrm{~A} 0-\mathrm{A} 31 \\ & 1 \rightarrow \mathrm{CS} 31 \end{aligned}$ <br> Set DRQ for next instruction <br> Enable T6L clock <br> Set PH4 | R/CC2 <br> S/CC2 <br> SXB <br> AXS <br> CSX1/8 <br> S/DRQ <br> T6L <br> S/PH4 | $\begin{aligned} & =\text { FAS11 PH3 }+\ldots \\ & =\text { FAS11 PH3 NA0031Z }+\ldots \\ & =\text { FAS11PH3 }+\ldots \\ & =\text { FAS11PH3 }+\ldots \\ & =\text { FAS11PH3 }+\ldots \\ & =\text { FAS11PH3 }+\ldots \\ & =\text { NT1L NT4L NT8L NT10L } \\ & \text { NRESET } \\ & =\text { FAS11PH3 }+\ldots \end{aligned}$ | If no 1-bits of private memory halfword and effective halfword are coincident, reset CC2; otherwise, set CC2 <br> One's complement of private memory halfword $\rightarrow B$ <br> Inhibits clock until data release received from memory |
| PH4 <br> T6L | Generate ENDE $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31+\mathrm{CS} 31 \longrightarrow \\ & \mathrm{S0}-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{~A} 1-\mathrm{A} 31 \end{aligned}$ <br> Set flip-flop KOOH <br> Set flip-flop KOOH if $\mathrm{SOO}=1$ <br> Set TESTA <br> Set TESTA/I <br> Enable T6L clock <br> Set PREI | ENDE <br> SXADD <br> AXS <br> SXK <br> $\mathrm{S} / \mathrm{KOOH}$ <br> 500 <br> S00X <br> S/TESTA <br> S/TESTA/I <br> T6L <br> S/PRE 1 |  | Subtract private memory halfword from effective halfword <br> Difference into A $\begin{aligned} & S O O X=1 \text { if AO } \neq D 0 \\ & \text { NSOOXN }=1 \end{aligned}$ |
| (Continued) |  |  |  | Mnemonic: $\mathrm{CH}(51, \mathrm{DI})$ |

Table 3-82. Compare Halfword, Phase Sequence (Cont.)


Table 3-83. Compare Word, Phase Sequence


Table 3-83. Compare Word, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH3 <br> (Cont) T6L | $\begin{aligned} & \text { If } \mathrm{A} 0-\mathrm{A} 31 \neq 0,1 \not \mathrm{CC} 2 \\ & \mathrm{BO} 0-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \end{aligned}$ $\mathrm{SO}-\mathrm{S} 31 \xrightarrow{\longrightarrow} \mathrm{~A} 0-\mathrm{A} 31$ $1 \nrightarrow \operatorname{cs} 31$ $0 \rightarrow C S O-C S 30$ <br> Set DRQ <br> Set PH4 | $\begin{array}{ll} S / C C 2 & =\text { FAS11 PH3 NA0031Z }+\ldots \\ \text { SXB } & =\text { FAS11 PH3 }+\ldots \\ \text { AXS } & =\text { FAS11 PH3 }+\ldots \\ \text { CSX1/8 } & =\text { FAS11 PH3 }+\ldots \\ \text { R/CS0-CS30 } & =\ldots \\ \text { S/DRQ } & =\text { FAS11 PH3 }+\ldots \\ \text { S/PH4 } & =F A S 11 \mathrm{PH} 3+\ldots \end{array}$ | One's complement of private memory register contents <br> For two's complement <br> Inhibits another clock until data release received from memory |
| PH4 | Generate ENDE $\xrightarrow{\text { A0-A31 }+ \text { D0-S31 }}$ $\mathrm{S} 0-\mathrm{S} 31 \xrightarrow{\longrightarrow} \mathrm{~A} 0-\mathrm{A} 31$ $\begin{aligned} & \text { If D0-D31 } \geq \mathrm{A} 0-\mathrm{A} 31 \text {, } \\ & 1 \rightarrow \mathrm{~K} 00 \mathrm{H} \end{aligned}$ <br> Set TESTA <br> Set TESTA/l <br> Set PREI <br> Enable T6L clock |  | Add effective word and two's complement of private memory word <br> Difference into Aregister $\begin{aligned} & S 00 X=1 \text { if AO } \neq D 0 \\ & N S O O X N=1 \end{aligned}$ <br> To test A-register for condition codes |
| PREI <br> next in- <br> struc- <br> tion | Set flip-flop CC3 if K00H $=0$ | $\begin{aligned} \text { S/CC3 }= & \text { TESTA } / 1 \text { NK00H NA003IZ } \\ & +\ldots \\ \text { R/CC3 }= & \text { TESTA }+\ldots \end{aligned}$ | Private memory word > effective word |

Mnemonic: CW $(31, B 1)$
(Continued)

Table 3-83. Compare Word, Phase Sequence (Cont.)


The low order word of the effective memory doubleword is read into the C -register, and into the one's complement as it is transferred into the D-register. A one is forced into flip-flop CS31 to obtain the two's complement during addition. The low order word of the private memory doubleword is loaded into the A-register. The A- and D-registers contents are gated into the adder, which subtracts the effective word from the private memory word. The sum is transferred to the A-register, and flip-flop K 00 H is set if an end carry occurs. Flip-flop CS31 is set to reflect the carry if signal K 00 H is true. The high order word of the effective memory doubleword is read into the C -register, and into the one's complement as it is transferred into the D-register. Flip-flop BWZ is set if the A-register does not contain all zeros, this indicates a nonzero difference between the low order words. The contents of the A- and D-registers are again gated into the adder, subtracting the high order effective word from the high order private memory word. The result is placed in the A-register. Flip-flop KOOH is set if no end carry results from bit 0 . The A-register and flip-flop K 00 H are examined in the first phase of the instruction or interrupt, trap, or control sequence that follows. Flip-flop CC3 is set if a nonzero value in the A-register and a zero in flip-flop KOOH indicate that the private memory doubleword was greater than the effective doubleword. Flip-flop CC4 is set if a one in flip-flop K 00 H and a nonzero value in the A-register indicate that the private memory doubleword was less than the effective doubleword. A sequence chart of the Compare Doubleword instruction is given in table 3-84.

## 3-214 Compare Selective (CS 45, C5)

The Compare Selective instruction compares the contents of register $R$ with the effective word in only those bit positions selected by a one in corresponding bit positions of the mask in register $R+1$. The contents of register $R$ and the effective word are ignored in those bit positions designated by a zero in corresponding bit positions of register $\mathrm{R}+1$. The selected contents of register $R$ and the effective word are ireared as positive magnitudes, and the condition codes CC3 and CC4 are set according to the results of the comparison. If the R-field of the instruction is an odd value, Compare Selective compares the contents of the register with the logical product (AND) of the effective word and the contents of register R. A sequence chart of the Compare Selective instruction is given in table 3-85.

The normal preparation sequence for the CS instruction is described under the preparation sequence. During PRE2, the odd numbered private memory register is addressed by setting LR31/2. In the execution phases, the effective word in the C -register is clocked into the $\bar{D}$-register. The mask is read from private memory register $R+1$ into the $A-$ register. With ones in the CS-register, and NPRX true, an AND operation is performed in the adder between the Aand D-registers to extract ones from the effective word wherever a one appears in the corresponding bit of the mask. The result is placed in the $B$-register.

The contents of private memory register $R$ are loaded into the $D$-register by way of the $C$-register. An AND operation is again performed between the A- and D-registers. This extracts ones from the private memory word wherever a one appears in the corresponding bit of the mask. The result is placed in the A-register.

The contents of the B-register, representing the extracted bits from the effective word, are one's complemented by way of the C-register and are placed in the D-register. Flipflop CS31 is set to form the two's complement. The contents of the $A$ - and $D$-registers are gated into the adder, subtracting the selected bits of the effective word from the selected bits of the private memory word. The result is placed in the A-register. Flip-flop K 00 H is set if no end carry results out of bit 0 .

The A-register and flip-flop K 0 OH are examined in the first phase of the instruction or interrupt, trap, or control panel operation that follows. Flip-flop CC3 is set if a nonzero value in the A-register and a zero in flip-flop K 00 H indicate that the private memory word bit combination was greater than the effective word bit combination. Flip-flop CC 4 is set if a one in flip-flop K 00 H and a nonzero value in the A-register indicate that the private memory bit combination was less than the effective word bit combination.

## 3-215 Compare With Limits in Registers (CLR 39, B9)

The Compare with Limits in Registers instruction compares the contents of the effective word with the contents of both private memory registers $R+1$ and $R$, in that order. Al! three words are treated as signed magnitides. The condition codes are set according to the results of the comparison, $\mathrm{CC1}$ and CC 2 representing the results of the comparison of register $\mathrm{R}+1$ and the effective word. CC3 and CC4 represent the results of the comparison of register $R$ and the effective word.

The normal preparation sequence for the instruction is described under preparation sequence. in PRE2, the leasi significant LR line is set true to address the odd numbered private memory register, $R+1$.
S/LR3I/2 = FUCLR PRE2 NIA

The low order effective word is read from memory and one's complemented by way of the C-register into the D-register. Flip-flop CS31 is set to form the two's complement in the adder. The contents of private memory register $R+1$ are loaded into the A-register. The A- and D-register contents are gated into the adder, subtracting the effective word from the private memory word. Flip-flop K 00 H and the A register are examined to determine which value was larger. If the private memory word is greater than the effective word, flip-flop CC3 is set; otherwise, flip-flop CC4 is set.
The contents of private memory register $R$ are gated into the A-register, and the effective word is subtracted from this value by again gating the $A$ - and $D$-register values into the adder with CS31 set for the two's complement.

Table 3-84. Compare Doubleword, Phase Sequence


Table 3-84. Compare Doubleword, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH2 <br> T6L <br> (Cont.) | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31+\mathrm{CS} 31 \longrightarrow \\ & \mathrm{SO}-\mathrm{S} 31 \end{aligned}$ <br> Set flip-flop KOOH if SOO = 1 $\text { MBO-MB31 } \longrightarrow \mathrm{CO}-\mathrm{C} 31$ $\text { NC0-NC31 } \neq \text { D0-D31 }$ <br> Set flip-flop PH3 | $\begin{aligned} & \text { SXPR } \\ & \text { AXS } \\ & \text { S/K00H } \\ & \text { R/KOOH } \\ & \text { SOO } \\ & \text { SOOX } \\ & \text { CXMB } \\ & \text { DXNC } \\ & \text { S/PH3 } \end{aligned}$ | $\begin{aligned} = & S X A D D=F A S 22 P H 2+\ldots \\ = & \text { FAS22 PH2 }+\ldots \\ = & S 00 \\ = & \ldots \\ = & \text { K00 S00X }+ \text { NK00 NS00X } \\ & \text { N }(\ldots) \\ = & \text { SOOXN }+\ldots \\ = & \text { DGC } \\ = & \text { FAS2 PH2 }+\ldots \\ = & \text { PH2 NBR N(FNANLZ } \\ & \text { NANLZ) }+\ldots \end{aligned}$ | Subtract low order effective word from low order private memory word <br> Transfer to A-register $\text { SOOXN }=0 \text { in } P H 2$ $500 x=0$ <br> $\mathrm{SOO} \Longrightarrow$ no end carry out of bit position 0 <br> One's of high order memory word complement into D-register |
| $\begin{aligned} & \mathrm{PH} 3 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | Enable T6L <br> If $A \neq 0$, set flip-flop $B W Z$ <br> $\mathrm{NKOOH} \rightarrow \mathrm{CS3I}$ <br> $R R O-R R 31 \longrightarrow A 0-A 31$ <br> $Q \longrightarrow P$ <br> Set flip-flop DRQ for next instruction <br> Set flip-flop PH5 | T6L S/BWZ $(S / B W Z / 1)$ CSXI/8 AXRR PXQ S/DRQ S/PH5 BRPH5 | $\begin{aligned} & =\text { NT1L NT4L NT8L NTI0L } \\ & \text { NRESET } \\ & =\text { NA0031Z }(S / B W Z / 1) \\ & =\text { FAS22 NOL9 PH3 }+\ldots \\ & =\text { NK00H }(S / B W Z / 1) \\ & =\text { FAS22 PH3 }+\ldots \\ & = \\ & = \\ & = \\ & \text { PREDO PHS22 PH3 }+\ldots \\ & = \\ & \text { BRPH5 }+\ldots \\ & = \\ & \text { FAS22 PH3 }+\ldots \end{aligned}$ | $B W Z=0 \Rightarrow$ low order words equal <br> End carry out of bit position 0 <br> High order private memory word <br> Next instruction address |
| PH5 | Enable T6L | T6L | $=$ NTIL NT4L NT8L NTIOL NRESET |  |
| (Continued) |  |  |  | Mnemonic: CD (11,91) |

Table 3-84. Compare Doubleword, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH5 <br> T6L <br> (Cont.) | Generate ENDE $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31+\mathrm{CS} 31 \longrightarrow \\ & \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31-\mathrm{A} 0-\mathrm{A} 31 \end{aligned}$ <br> Set flip-flop KOOH if SOO = 1 <br> If $B W Z$, merge $1 \rightarrow A 31$ <br> Set flip-flop TESTA <br> Set flip-flop TESTA/1 | ENDE <br> SXADD <br> AXS <br> $\mathrm{S} / \mathrm{KOOH}$ <br> S00 <br> s00X <br> S00XN <br> A31X1 <br> (S/TESTA) <br> S/TESTA/1 | $\begin{aligned} = & \text { FAS22 PH5 }+\ldots \\ = & \text { FAS22 PH5 }+\ldots \\ = & \text { FAS22 PH5 }+\ldots \\ = & \text { S00 } \\ = & \text { K00 NS00X + NK00 S00X } \\ & \mathrm{N}(\ldots) \\ = & \text { SO0XN (A0 D0 + NA0 ND0) } \\ & \mathrm{N}(\ldots) \\ = & \text { FAS22 PH5 + . . . } \\ = & \text { FAS22 BWZ }+\ldots \\ = & \text { FAS22 PH5 + . . . } \\ = & (S / T E S T A) \text { NO4 NO6 O7 } \\ & +\ldots \end{aligned}$ | Difference high order halves of doublewords <br> Place in A-register <br> To indicate difference between low order words $\neq 0$ <br> For condition code test |
| PREI <br> (next in-struction) | Set flip-flop CC3 if $\mathrm{KOOH}=0$ <br> Set flip-flop CC4 if $\mathrm{KOOH}=1$ | s/CC3 <br> R/CC3 <br> S/CC4 <br> R/CC4 | $\begin{aligned} = & \text { TESTA/1 NKOOH NA003IZ } \\ & +\ldots \\ = & \text { TESTA } \\ = & \text { TESTA } / 1 \text { K00H NA0031Z } \\ & +\ldots \\ = & \text { TESTA } \end{aligned}$ | Private memory doubleword > effective doubleword <br> Private memory doubleword < effective doubleword |
|  |  |  |  | Mnemonic: CD (11, 91) |

Table 3-85. Compare Selective, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| ENDP | S/LR31/2 | S/LR31/2 $\quad=$ PRE2 NIA FUCS + . | Merge a one onto address to select mask |
| $\begin{aligned} & \text { PHI } \\ & \text { T4RL } \end{aligned}$ | $\begin{aligned} & C 0-C 31 \rightarrow D 0-D 31 \\ & R R 0-R R 31 \rightarrow A 0-A 31 \\ & 1 \rightarrow N P R X \\ & 1+s \rightarrow C S 0-C S 31 \end{aligned}$ <br> Set flip-flop CXRR <br> Enable T10L clock <br> Set PH2 |  | Effective word to Dregister <br> Mask from private memory register $\mathrm{R}+1$ <br> To prepare for AND operation in PH2 <br> For transfer of contents of selected private memory register to C -register |
| PH2 <br> T10L | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{BO}-\mathrm{B} 31 \\ & \text { RRO-RR31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ & \mathrm{CO}-\mathrm{C} 31 \longrightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & \mathrm{~S} / \mathrm{NPRX} \\ & \mathrm{I} \text { 's } \longrightarrow \mathrm{CSO}-\mathrm{CS} 31 \\ & \text { Set T4L clock } \\ & \text { Set PH3 } \end{aligned}$ | $\begin{array}{ll} \text { SXPR } & =\text { NPRX }+\ldots \\ \text { BXS } & =\text { FAS6 PH2 }+\ldots \\ \text { CXRR set in PHI } & \\ \text { DXC/6 } & =\text { (FUCS PH2) }+\ldots \\ \text { S/NPRX } & =\text { FUCS PH2 }+\ldots \\ \text { CSXI } & \text { S/NPRX }+\ldots \\ \text { S/T4L } & =F U C S ~ P H 2+\ldots \\ S / P H 3 & =P H 2 \text { NBR N(FNANLZ } \\ & \text { NANLZ })+\ldots \end{array}$ | Ones extracted from effective word under control of mask <br> Contents of selected private memory register <br> Transfer to D-register <br> For AND operation |
| $\begin{aligned} & \mathrm{PH} 3 \\ & \mathrm{~T} 4 \mathrm{~L} \end{aligned}$ | $A 0-A 31 \wedge D 0-D 31 \longrightarrow S 0-531$ $\mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 31$ | $\begin{aligned} \text { SXPR } & =\text { NPRX }+\ldots \\ \text { AXS } & =F U C S P H 3+\ldots \end{aligned}$ | Ones extracted from private memory register under control of mask <br> Transfer to A-register |
|  |  | (Continued) | Mnemonic: CS (45, C5) |

Table 3-85. Compare Selective, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH3 <br> T4L <br> (Cont.) | Set CXS <br> Set PH4 | $\begin{aligned} \mathrm{S} / \mathrm{CXS} & =\mathrm{FUCS} \mathrm{PH} 3+\ldots \\ \mathrm{S} / \mathrm{PH} 4 & =\mathrm{PH} 3 \mathrm{NBR}+\ldots \end{aligned}$ | For transfer of sum bus contents to C-register |
| $\begin{array}{\|l\|l\|} \hline \text { PH4 } \\ \text { T6L } \end{array}$ | $\mathrm{B} 0-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ $\mathrm{SO}-\mathrm{S} 31 \xrightarrow{-} \mathrm{C} 0-\mathrm{C} 31$ $\mathrm{NCO}-\mathrm{NC} 31 \rightarrow \text { D0-D31 }$ $1 \rightarrow \operatorname{CS31}$ <br> Set MRQ/1 and DRQ for next instruction <br> Enable T6L <br> Set PH5 |  | Ones extracted from effective word to C -register via sum bus <br> One's complement of extracted bits of effective word into D-register <br> For two's complement |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | Enable T6L <br> Enable ENDE $\begin{aligned} & \text { A0-A31 + D0-D31 + CS31 } \\ & \text { S0-S31 } \\ & \text { S0-S31 }-A 0-A 31 \end{aligned}$ <br> Set flip-flop KOOH if SOO = 1 <br> Set test for $A$ |  | Difference selected bits of effective word and register $R$ and transfer to A-register <br> FAS11 $=0$ <br> S00X $:=0$ <br> SOO $\Rightarrow$ no end carry out of bit position 0 |
|  |  | (Continued) | Mnemonic: CS (45, C5) |

Table 3-85. Compare Selective, Phase Sequence (Cont.)


The contents of flip-flops CC3 and CC4 are transferred to $\mathrm{CC1}$ and CC2. In the first phase of the instruction, or interrupt, trap, or control panel operation that follows, flipflops CC3 and CC4 are set by checking the A-register and the state of flip-flop K00H. Flip-flop CC3 is set if the word from private memory register $R$ is greater than the effective word; otherwise, flip-flop CC4 is set. A sequence chart of the Compare with Limits in Register instruction is given in table 3-86.

## 3-216 Compare With Limits in Memory (CLM 19, 99)

The Compare with Limits in Memory instruction compares the contents of register R with the effective memory doubleword. First the low order effective doubleword is compared, and the high order effective word is then compared. All three words are treated as signed magnitudes. The condition codes are set according to the results of the comparison.

The normal preparation sequence for the CLM instruction is described under the preparation sequence. During the preparation sequence, a one is forced onto the least significant memory address line LB31 to address the low order effective word.

```
LB31/2 = LMXC NCO PREFADO + ...
```

The low order effective word is read from memory and one's complemented into the $D$-register by way of the $C$-register. Flip-flop CS31 is set to form the two's complement in the adder. The contents of the selected private memory register are loaded into the A-register. The A- and D-register contents are gated into the adder, subtracting the low order effective word from the private memory word. Flip-flop K 00 H and the A-register are examined to determine which value is larger. Flip-flop CC3 is set if the private memory word is greater than the effective word; otherwise, flipflop CC4 is set.

The contents of the selected private memory register are again loaded into the A-register. The high order effective word is read from memory and one's complemented into the D-register by way of the C-register. Flip-flop CS31 is again set to form the two's complement in the adder. The contents of flip-flops CC3 and CC4 are transferred to flipflops CCl and CC2. The A- and D-register outputs are gated into the adder, subtracting the high order effective word from the private memory word. In the first phase of the next operation, whether instruction, interrupt, trap, or control panel operation, flip-flop K 00 H and the A-register are examined to determine which value is larger. Flipflop CC3 is set, if K 00 H contains a zero, indicating that the private memory word was greater than the effective word; otherwise, flip-flop CC4 is set.

A sequence chart of the Compare with Limits in Memory instruction is given in table 3-87.

## 3-217 OR Word (OR 49, C9)

The OR Word instruction merges the individual bits of the contents of the private memory register $R$ and the effective word. The result, which contains 1-bits in those bit positions where ones appear in either R or EW, is transferred to private memory register $R$.

The OR Word instruction can be indirectly addressed, or indexed, or both. The normal preparation sequence, as well as the sequencing for all modes and conditions of the OR instruction, is described under the preparation sequence.

At PHI clock, EW in the C-register is transferred to $D$, and the private memory word is clocked into the A-register.

Both signals SXA and SXD come true during PH3. This allows the sum bus to follow the contents of both the $A$ register and the D-register, effecting a merge or OR operation. The contents of the sum bus are placed on the RW lines to be stored back into private memory register R. The contents of the sum bus are also transferred to the A-register in PH3 to be tested by CC3 and CC4. Flip-flop TESTA is set at the PH3 clock pulse.

Condition code bits CC3 and CC4 are not affected until the clock at the end of the phase following PH3 of the OR instruction. This normally is at the end of PREI, although it could also be at the end of the first phase of an interrupt or trap operation or at the clock of phase PCP1 of a control panel operation.

A sequence chart of the OR Word instruction is given in table 3-88.

## 3-218 Exclusive OR Word (EOR 48, C8)

The EOR instruction performs a logical addition on the contents of private memory register $R$ and the effective word. The result contains one-bits in those bit positions where ones appear in either R or EW, and zeros in those bit positions where either ones or zeros appear in both R and EW. The result is transferred to private memory register $R$.

The EOR instruction can be indexed, indirectly addressed, or both. The normal preparation sequence, as well as the sequencing for all modes and conditions of the EOR instruction, is described under the preparation sequence.

The effective word in the C-register is transferred to D at the PHI clock, and the private memory word R is clocked into the A-register.
During PH3, the signal SXPR is true, allowing the sum bus to follow the propagate signals. The contents of the sum bus, which contain the exclusive-OR information, are then placed onto the RW lines. The contents of the sum bus are also transferred in PH3 to the A-register to be tested by CC3 and CC4. Flip-flop TESTA is set at the PH3 clock pulse.

Table 3-86. Compare With Limits in Register, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| ENDP | Set LR31 | S/LR31/2 | $=$ FUCLR PRE2 NIA $+\ldots$ | Addresses R + 1 |
| PHI <br> T4RL | $\mathrm{NC} 0-\mathrm{NC} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31$ <br> Set flip-flop CS31 $R R 0-R R 31 \longrightarrow A 0-A 31$ <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Set PH2 | DXNC/1 <br> S/CS31 <br> AXRR <br> PXQ <br> S/PH2 | $\begin{aligned} = & \text { FASI PHI }+\ldots \\ = & C S X I / 31=D X N C / 1+\ldots \\ = & \text { FAS22 PHI }+\ldots \\ = & \text { PRERQ PHI }+\ldots \\ = & \text { PHI NBR N(FNANLZ } \\ & \text { NANLZ) }+\ldots \end{aligned}$ | One's complement of effective word into Dregister <br> For two's complement. Contents of private memory register $R+1 \text { into A-register }$ |
| $\left\lvert\, \begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}\right.$ | Enable T6L $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31+\mathrm{CS} 31 \longrightarrow \\ & \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{P} 0-\mathrm{A} 31 \end{aligned}$ <br> Set flip-flop KOOH if SOO = 1 <br> Set A test <br> Enable T4L <br> Set PH3 | T6L <br> SXADD <br> AXS <br> $\mathrm{S} / \mathrm{KOOH}$ <br> S00 <br> s00X <br> S00XN <br> S/TESTA <br> S/TESTA/I <br> S/T4L <br> S/PH3 | $\begin{aligned} = & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \\ = & \text { FAS22 PH2 }+\ldots \\ = & \text { FAS22 PH2 }+\ldots \\ = & \text { S00 } \\ = & (\text { SO0X K00 }=\text { NS00X NK00) } \\ & \text { NFASHFL } \\ = & (\text { AO DO }+ \text { NA0 ND0) S00XN } \\ = & \text { FASI PH2 }+\ldots \\ = & \text { FASI PH2 }+\ldots \\ = & (S / T E S T A) \text { FASI + . . . } \\ = & \text { FASI PH2 }+\ldots \\ = & \text { PH2 NBR N(FNANLZ } \\ & \text { NANLZ) }+\ldots \end{aligned}$ | Private memory register $R+1$ - effective word <br> Difference into Aregister $\begin{aligned} & S 00 X N=1 \\ & S 00 X=1, \text { if } A 0=D 0 \end{aligned}$ $\mathrm{SOO} \Longrightarrow \text { no end carry }$ from bit position 0 , if signs are alike; carry if signs are unlike |
| (Continued) |  |  |  | Mnemonic: $\operatorname{CLR}(39, \mathrm{B9})$ |

Table 3-86. Compare With Limits in Register, Phase Sequence (Cont.)


Table 3-86. Compare With Limits in Register, Phase Sequence (Cont.)


Table 3-87. Compare With Limits in Memory, Phase Sequence


Mnemonic: $\operatorname{CLM}(39,99)$

Table 3-87. Compare With Limits in Memory, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{aligned} & \mathrm{PH} 2 \\ & \text { (Cont.) } \end{aligned}\right.$ | Set PH3 | S/PH3 | $=$ PH2 NBR N(FNANLZ NANLZ) + . . . |  |
| $\left\lvert\, \begin{aligned} & \text { PH3 } \\ & \mathrm{T} 4 \mathrm{~L} \end{aligned}\right.$ | Set condition codes CC3, CC4 <br> Set flip-flop CC3 if $\mathrm{KOOH}=0$ <br> Set flip-flop CC4 if $\mathrm{K} 00 \mathrm{H}=1$ <br> RRO-RR31 $\longrightarrow$ A0-A31 <br> Set CS31 <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Set DRQ for next instruction <br> Set PH5 | S/CC3 R/CC3 S/CC4 R/CC4 AXRR S/CS31 CSXI/8 PXQ S/DRQ S/PH5 BRPH5 | $\begin{aligned} & =\text { TESTA/I NA003IZ NK00H } \\ & =\text { TESTA } \\ & =\text { TESTA } / 1 \text { NA0031Z K00H } \\ & =\text { TESTA } \\ & =\text { FAS22 PH3 }+\ldots \\ & =\text { CSXI } / 31=\text { CSXI } / 8+\ldots \\ & =\text { FASI PH3 }+\ldots \\ & =\text { PREDO PH3 }+\ldots \\ & =\text { FAS22 PH3 }+\ldots \\ & =\text { PH3 BRPH5 }+\ldots \\ & - \text { FAS22 PH3 }+\ldots \end{aligned}$ | Private memory word A-register <br> Private memory word A-register <br> For two's complement of effective word <br> Inhibits clock until data release received from memory |
| $\left\lvert\, \begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}\right.$ | $\begin{aligned} & \text { Enable T6L } \\ & \text { A0-A31 + D0-D31 + CS31 } \\ & \text { S0-S31 } \\ & \text { S0-S31 A0-A31 } \\ & \text { Set flip-flop K00H if S00 } 1 \\ & \text { Set A test } \\ & 0 \xrightarrow[C C l]{C H} \end{aligned}$ | T6L <br> SXADD <br> AXS <br> SOOXN <br> S/TESTA <br> S/TESTA/I <br> $\mathrm{R} / \mathrm{CCl}$ | $\begin{aligned} = & \text { NTIL NT4L NT8L NT10L } \\ & \text { NRESET } \\ = & \text { FAS22 PH5 }+\ldots \\ = & \text { FAS22 PH5 }+\ldots \\ = & \text { FAS22 PH5 }+\ldots \\ = & \text { FAS22 PH5 }+\ldots \\ = & (S / T E S T A) \text { FAS1 }+\ldots \\ = & \text { FAS1 PH5 } \end{aligned}$ | Private memory word, high order effective word <br> Difference into Aregister |
|  |  |  | ued) | Mnemonic: $\operatorname{CLM}(39,99)$ |

Table 3-87. Compare With Limits in Memory, Phase Sequence (Cont.)


Table 3-88. OR Word, Phase Sequence


Mnemonic: OR (49, C9)

Condition code bits CC3 and CC4 are not affected until the clock at the end of the phase following PH3 of the EOR instruction. This normally is at the end of PREI, although it could also be at the end of the first phase of an interrupt or a trap operation or at the clock of phase PCP1 of a control panel operation. If $A 0=0$ and $A 1-31 \neq 0$, set CC3; if AO $=1$, set CC4.

A sequence chart of the Exclusive OR Word instruction is given in table 3-89.

## 3-219 AND Word (AND 4B, CB)

The AND Word instruction performs a logical multiplication of the individual bits of the contents of private memory register $R$ and the effective word. The result, which contains one-bits in bit positions where both $R$ and EW contain ones and zero-bits in all other bit positions, is transferred to private memory register $R$.

The AND instruction can be indirectly addressed, or indexed, or both. The normal preparation sequence, as well as the sequencing for all modes and conditions of the AND instruction, is described under the preparation sequence.

At the PHl clock, the EW in the C-register is transferred to $D$, and the private memory word $R$ is clocked into the A-register. The CS-register is filled with ones at the PHI clock and NPRX is set to prepare for the AND operation in PH2.

During PH3, SXPR is enabled. This allows PRO through PR31 to be true wherever the corresponding bits of the A-, D-, and CS-registers are ones. The data in PRO through PR31 is transferred to the sum bus, and the sum bus contents are placed on the RW lines to be stored in private memory register $R$. The contents of the sum bus are also transferred in PH3 to the A-register to be tested by CC3 and CC4. Flipflop TESTA is set at the PH3 clock pulse.

Condition code bits CC3 and CC4 are not affected until the clock at the end of the phase following PH3 of the AND instruction. This normally is at the end of PREI, although it could also be at the end of the first phase of an interrupt or trap operation or at the clock of phase PCPI of a control panel operation. If $A 0=0$ and $A 1-A 31 \neq 0$, set $C C 3$; if $\mathrm{AO}=1, \operatorname{set} \mathrm{CC} 4$.

A sequence chart of the AND Word instruction is given in table 3-90.

## $3-220$ Shift (S 25, A5)

The shift instruction shifts the contents of the private memory register selected by the R-field of the instruction or shifts register $R$ and register $R+1$. This type of shift is determined as follows: If neither indirect addressing nor indexing is called for in the S -instruction, bit positions 21 through 31 of the reference address field determine the type, direction, and amount of the shift. If indirect addressing is
indicated in the instruction (where bit 0 is a one), bits 15 through 31 of the instruction word are used to fetch the indirect word. Bits 21 through 31 of the indirect word determine the type, the direction, and the amount of shift. If only indexing is indicated in the instruction word, bits 21 through 23 of the instruction word determine the type of shift. The direction and amount of shift are determined by the sum of bits 25 through 31 of the instruction and bits 25 through 31 of the index register. If both indirect addressing and indexing are indicated, bits 15 through 31 of the reference address are used as the address to fetch the new word. Bits 21 through 23 of the indirect word are used to determine the type of shift. The direction and the amount of the shift are determined by bits 25 through 31 of the indirect word plus bits 25 through 31 of the index register.

Bits 21 through 23 of the effective address determine the type of shift as listed in table 3-91.

Bit positions 25 through 31 of the effective address contain a shift count that determines the direction and the amount of the shift. The shift count is treated as a seven-bit signed binary integer with bit 25 as the sign bit. A one in bit 25 indicates a right shift with the count given in two's complement form. A zero in bit 25 indicates a left shift. The value of the count can be within the range -64 to +63 .

Overflow occurs on a left shift whenever the value of the sign bit changes. At the completion of the shift operation, the condition code register is set to indicate the results of the shift; the result is then stored in the private memory registers.

The preparation sequence is the same as the general preparation sequence except that data is loaded from the odd numbered private memory register into the A-register in case the instruction calls for a double-register shift. This data is loaded into the B -register in the first execution phase, and then is cleared if the instruction calls for a single-register shift.

3-221 SHIFT PHASE. In the shift phase, the data in the A-register or in the $A$ - and $B$-registers is shifted as follows:
a. Left shift. In a single-register arithmetic left shift or a single-register logical left shift, the data in the Aregister is shifted left the number of bit positions indicated by the count, and zeros are placed in the vacated bit positions on the right. The bits shifted past $A 0$ are lost. In a single-register circular left shift, the bits shifted past position A0 are clocked into position A31. In a doubleregister arithmetic left shift or a double-register logical left shift, the contents of the A- and B-registers are shifted left the number of bit positions indicated by the count. Zeros are placed in the vacated bit positions on the right in the $B$-register. Bits shifted past bit 0 in the $B$-register are copied into bit 31 of the A-register. Bits shifted past bit 0 of the A-register are lost. In a double-register circular left shift, bits shifted past A0 are clocked into B31.

Table 3-89. Exclusive OR Word, Phase Sequence


Table 3-90. AND Word, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | $\begin{aligned} & \text { MBO-MB31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ & \text { Set } \mathrm{RQ} \end{aligned}$ | CXMB <br> $S / R Q$ | $\begin{aligned} & =/ D G C / \\ & =\text { PREI NIA NINDX PRERQ } \end{aligned}$ | EW into C-register |
| PHI <br> T4RL | $\begin{aligned} & \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & \text { RR0-RR31 } 10-\mathrm{A} 31 \end{aligned}$ <br> Set NPRX $1 ' s \not C \text { CSO-CS3 }$ <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Set DRQ <br> Set T8L <br> Go to PH3 | DXC/6 <br> AXRR <br> S/NPRX <br> CSXI <br> PXQ <br> S/DRQ <br> S/T8L <br> BRPH3 | $\begin{aligned} & =\text { FAS9 PHI }+\ldots \\ & =\text { FAS9 PHI }+\ldots \\ & =\text { OU4 }(\mathrm{O} 4 \mathrm{NO} 5 \mathrm{O} 6)+\ldots \\ & =(\mathrm{S} / \mathrm{NPRX})+\ldots \\ & =\text { PH1 PRERQ }+\ldots \\ & =\text { FAS9 PHI }+\ldots \\ & =\text { FAS9 PHI }+\ldots \\ & =\text { FAS9 PHI O4 }+\ldots \end{aligned}$ | EW into D-register <br> $R$ into A-register |
| $\begin{aligned} & \text { PH3 } \\ & \text { T8L } \end{aligned}$ | End $\begin{aligned} & \text { PRO-PR31 } \longrightarrow \text { S0-S31 } \\ & \text { SO-S31 } \longrightarrow \text { RW0-RW31 } \\ & \text { SO-S31 } \longrightarrow \mathrm{A} 0-\mathrm{A} 31 \end{aligned}$ <br> Set test for $A$ | ENDE <br> SXPR <br> RW <br> AXS <br> S/TESTA | $\begin{aligned} & =\text { FAS9 PH3 }+\ldots \\ & =\text { NPRX }+\ldots \\ & =\text { FAS9 PH3 }+\ldots \\ & =\text { FAS9 PH3 }+\ldots \\ & =\text { FAS9 PH3 }+\ldots \end{aligned}$ | Final phase <br> Store AND result into $R$ AND result into A for test |
| PREI <br> (next <br> in- <br> struc- <br> tion) | Test contents of $A$ register <br> If A0 $=0$ and $\mathrm{A} 1-\mathrm{A} 31>0$, set CC3 <br> If $A O=1$, set CC4 | R/CC3 <br> R/CC4 <br> S/CC3 <br> S/CC4 | $\begin{aligned} = & \text { TESTA } \\ = & \text { TESTA } \\ = & \text { NTESTA } / 1 \text { TESTA NA0 } \\ & \text { NA003IZ } \\ = & \text { NTESTA/1 TESTA A0 } \end{aligned}$ |  |
|  |  |  |  | Mnemonic: AND (4B, CB) |

Table 3-91. Shift Determination

| Bit Positions |  |  | Type of Shift |
| :--- | :--- | :--- | :--- |
| 21 | 22 | 23 |  |
| 0 | 0 | 0 | Single register logical |
| 0 | 0 | 1 | Double register logical |
| 0 | 1 | 0 | Single register circular (cyclic) |
| 0 | 1 | 1 | Double register circular (cyclic) |
| 1 | 0 | 0 | Single register arithmetic |
| 1 | 0 | 1 | Double register arithmetic |
| 1 | 1 | 0 | Not used |
| 1 | 1 | 1 | Not used |

b. Right shift. In a single-register arithmetic right shift, the contents of the A-register are shifted right the number of bit positions indicated by the count. The sign bit contained in bit 0 is copied into the vacated bit positions. Bits shifted past A31 are lost. A single-register
circular right shift is the same except that bits shifted past A31 are clocked into A0. In a single-register logical right shift, bits shifted past A31 are lost, and zeros are placed in the vacated bit positions. In a double-register arithmetic right shift, the sign bit is copied into the vacated bit positions in the A-register, bits shifted past A31 are clocked into BO, and bits shifted past B31 are lost. A doubleregister circular right shift is the same except that bits shifted past B31 are clocked into flip-flop A0. A double-register logical right shift is the same as a double-register arithmetic right shift except that zeros are clocked into the vacated bit positions in the A-register. During a right shift, the Aregister is shifted right two bits at a time throughout the shift phase. At the end of the phase, if the shift count is odd, the A-register is shifted right one more bit position.

During a left shift operation, the bits are shifted one bit position at a time until flip-flops P30 and P31 contain zeros. From that point, the A-register is shifted left four bits at a time. Diagrams of single and double-register arithmetic left shift, arithmetic right shift, circular left shift, and circular right shift are shown in figures 3-180 through 3-183.

## A. SINGLE REGISTER ARITHMETIC LEFT SHIFT


B. DOUBLE REGISTER ARITHMETIC LEFT SHIFT


NOTE: LIGHT SOLID TRANSFER LINES INDICATE 4-BIT LEFT SHIFT WHEN NP30 NP3I. DASHED TRANSFER LINES INDICATE 1-BIT LEFT SHIFT WHEN P30 + P3I

Figure 3-180. Arithmetic Left Shift, Flow Diagram


Figure 3-181. Arithmetic Right Shift, Flow Diagram


Figure 3-182. Circular Left Shift, Flow Diagram

## A. SINGLE REGISTER CIRCULAR RIGHT SHIFT



## B. DOUBLE REGISTER CIRCULAR RIGHT SHIFT



901060A. 3637

Figure 3-183. Circular Right Shift, Flow Diagram

3-222. SHIFT COUNT. In left shift operation, the P-register counts down by ones until P30 and P31 contain zeros and then counts down by fours, as shown in table 3-92. In a right shift, flip-flops P30 and P31 are not used in the count, but flip-flops P26 through P29 are counted up by one every other clock time until they all contain ones. Up-counting is used because the count is in the two-complement form. When flip-flops P26 through P29 contain ones, flip-flops P15 through P18 are counted down in one clock time from all zeros to all ones. At this time, flip-flop P31 is checked to determine if the shift is odd and a one-bit right shift should take place. The P -register count during a right shift count of 17 is shown in table 3-93.
After the shift is finished, the modified data in the Aregister or in the A - and B -registers is loaded into the selected private memory register for a single-register shift, or inio registers $R$ and $R+1$ for à double-register shifft.
A sequence chart of the Shift instruction is given in table 3-94.

## 3-223 Shift Floating (SF 24, A4)

If either indirect addressing or indexing is called for in the instruction word, the address is computed as described under
the shift instruction. Bit position 23 of the address determines the type of shift. If bit 23 is a zero, the contents of the addressed private memory register are treated as a short format floating point number. If bit 23 is a one, the contents of the even or odd numbered private memory registers are treated as a long format floating point number.

Table 3-92. Left Shift Count Sequence Example

| P25 | P26 | P27 | P28 | P29 | P30 | P31 | Decimal Count |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | 1 | 0 | 0 | 1 | +25 |
| 0 | 0 | 1 | 1 | 0 | 0 | 0 | +24 |
| 0 | 0 | 1 | 0 | 1 | 0 | 0 | +20 |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | +16 |
| 0 | 0 | 0 | 1 | 1 | 0 | 0 | +12 |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | +8 |
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | +4 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  |  |  |  |  |  |  |

Table 3-93. Right Shift Count Example

| SHPC | P25 | P26 | P27 | P28 | P29 | P30 | P31 | Shift Action |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | Shift 2 |
| 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | Shift 2 |
| 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | Shift 2 |
| 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | Shift 2 |
| 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | Shift 2 |
| 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | Shift 2 |
| 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | Shift 2 |
| 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Shift 2 |
| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Shift 1 |
|  |  |  | P15 | P16 | P17 | P18 |  |  |
|  |  |  | 0 | 0 | 0 | 0 |  |  |
|  |  |  | 1 | 1 | 1 | 1 |  |  |

The shift count, contained in bit positions 25 through 31 of the instruction word, determines the amount and direction of the shift. The shift count is treated as a 7-bit signed binary integer, with bit position 25 as the sign bit. Negative numbers are in two's complement form. The absolute value of the shift count determines the number of hexadecimal bit positions that the floating point number is to be shifted. If the shift count is positive, the floating point number is shifted to the left; if the count is negative, the number is shifted to the right.

The SF instruction loads the floating point number from the register specified by the $R$-field of the instruction word, if it is in the short format or from registers $R$ and $R+1$, if the instruction is in the long format, and loads into the Aregister if the number is in the short format, or the A- and $B$-registers, if it is in the long format. If the number is negative, it is changed to a two's complement. A record of the original sign is retained. The floating point number is then separated into a characteristic and a fraction.

A positive shift count (NP25) produces the following leftshift operations:
a. If the fraction field is all zeros, the entire floating point number is set to all zeros (true zero) and flip-flop CCl is set.
b. If the fraction is normalized (less than one and equal to or greater than $1 / 16$ ), flip-flop CCl is set.
c. If the fraction is not normalized, the fraction field is shifted four bit positions to the left, and the characteristic field is decreased by one. Vacated bit positions at the right are filled with zeros.
d. If the characteristic field underflows (that is, if it is all ones as the result of being down counted), flip-flop CC2 is set. If the characteristic field does not underflow, the shift process continues until the fraction is normalized, until underflow occurs, until the shift count is reached, or until 14 shifts have taken place.
e. At the completion of the left-shift operation, the floating point result is stored back in the private memory registers. If the number was originally negative, the two's complement of the result is stored in private memory.

A negative shift count produces the following right-shift operations:
a. The fraction field is shifted two digit positions to the right, and the characteristic field is increased by one. Vacated bit positions on the left are filled with zeros.
b. Flip-flop CC2 is set if the characteristic field overflows (that is, if it becomes all zeros from being counted up). If the characteristic field does not overflow, the shift process continues until the characteristic field overflows or until the shift count is reached.
c. If the resultant fraction field is all zeros, the entire floating point number is set to all zeros (true zero).
d. Upon completion of the right-shift operation, the floating point result is loaded back into the private memory registers. If the number was originally negative, the two's complement of the result is loaded into private memory.

The preparation sequence for an SF instruction is the same as the general preparation sequence except that, if the instruction is not indirectly addressed, the sign bit of the data word from private memory is stored in flip-flop RN. If bit C23 is a one, indicating a long floating point format, a one is forced on private memory address line LR31 to select the odd numbered private memory register.

If the odd numbered private memory register was addressed, the contents of the private memory register are clocked into the A-register. If a one was not forced on the LR31 address line, the contents of the private memory register addressed in the R-field of the instruction word are read into the Aregister.

3-224 SHORT FORMAT. The data word, if positive, or the two's complement of the data word, if negative, is loaded into the A - and E -registers with the fraction in bits 8 through 31 of the A-register and the characteristic in the E-register. The shift count is loaded into flip-flops P25 through P31. If flip-flop P25 contains a zero, indicating a left shift, the data in the A-register is shifted four bit positions to the left at each clock time. While the shift count in bits 25 through 31 of the P -register is counted down by ones, the characteristic in the E-register is counted down by ones, and the limit count in P15 through P18 is counted up by ones.

Table 3-94. Shift, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | Same as general preparation sequence except <br> During PRE1, force a one on private memory address line LR31 <br> At PRE2 clock, RRO-RR31 $\rightarrow$ A0-A31 | R/NLR31/2 <br> AXRR | $\begin{aligned} = & \text { PRE1 NIA + PRE3 IA OU2 } \\ & \text { OL5 + . . } \\ = & \text { FAMDSF PRE2 NIA }+\ldots . \end{aligned}$ | Select odd numbered private memory register <br> Data from odd numbered private memory register |
| $\left\lvert\, \begin{aligned} & \text { PHI } \\ & \text { T4RL } \end{aligned}\right.$ | If bit C23 is a one, A0-A31 $\longrightarrow \text { S0-S31 }$ $\mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{BO}-\mathrm{B} 31$ $\text { RRO-RR31 } \longrightarrow \text { A0-A31 }$ <br> Reset flip-flops CC1 and CC2 <br> Set interrupt enable flip-flop. IEN <br> If P25 is a one, set flip-flop BWZ <br> Force zeros into P15 through P22 <br> If P30 is a one, set flip-flop SHPC <br> Set flip-flop PH9 <br> Enable clock T6L | SXA <br> BXS <br> BX <br> AXRR <br> $\mathrm{R} / \mathrm{CCl}$ <br> R/CC2 <br> S/IEN <br> S/BWZ <br> PX/2 <br> S/SHPC <br> S/PH9 <br> T6L | $\begin{aligned} &= \text { FASHFX C23 PHI }+\ldots \\ &= \text { FAMDSF PHI }+\ldots \\ &= \text { BXS } \\ &= \text { FASHFX PHI }+\ldots \\ &= \text { FASH PHI }+\ldots \\ &= \text { FAMDSF NFAMULH PHI } \\ &+\ldots \\ &= \text { FAMDSF NFAMUL PHI } \\ &+\ldots \\ &= \text { FASH PHI P25 + . . . } \\ &= \text { FASH PHI }+\ldots \\ &= \text { FASHFX PHI P30 }+\ldots \\ &= \text { BRPH9 = FASHFX PHI + . . } \\ &= \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \end{aligned}$ | Data from even numbered private memory register <br> Allows instruction to be interrupted |
| PH9 | Single register shift <br> Set flip-flop CC2 if overflow <br> if F 25 is a zero (NBWZ), generate signal SFTL <br> If bits P30 or P31 are ones, generate signal SFTLI | S/CC2 <br> SFTL <br> SFTLI | $\begin{aligned} = & \text { FASHFX SFTL4 } \\ & \text { N(A0004Z }+ \text { A0004W) } \\ & + \text { SFTLI A0 NBWZ } \\ = & \text { FASH PHI NBWWZ ; } \ldots \\ = & \text { FASHFX (NFASHFX }+ \text { P30 } \\ & + \text { P3I) SFTL }+\ldots . \end{aligned}$ | Indicates left shifit <br> Shift one bit left until bits P30 and P31 are zeros |
|  |  |  | ved) | Mnemonic: S (25, A5) |

Table 3-94. Shift, Phase Sequence (Cont.)


Table 3-94. Shift, Phase Sequence (Cont.)


Table 3-94. Shift, Phase Sequence (Cont.)


Table 3-94. Shift, Phase Sequence (Cont.)


Table 3-94. Shift, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH9 <br> T6L <br> (Cont, | Generate memory request for next instruction <br> Q15-Q31 $\rightarrow$ P15-P31 $\mathrm{P} 15-\mathrm{P} 31 \longrightarrow \mathrm{LM} 15-\mathrm{LB31}$ <br> Set flip-flop PH14 <br> Force a one on address line LR31 <br> Enable clock T10L |  | Address of next instruction <br> Selects odd numbered private memory register |
| $\left\lvert\, \begin{aligned} & \mathrm{PHI} 4 \\ & \mathrm{TIOL} \end{aligned}\right.$ | (Double register only) $\begin{aligned} & \mathrm{BO}-\mathrm{B} 31 \longrightarrow \text { SO-S31 } \\ & \text { SO-S31 } \longrightarrow \text { RWO-RW31 } \end{aligned}$ <br> Generate write byte signals RWB0-RWB3 <br> Set flip-flop DRQ <br> Set PHI5 <br> Enable clock TIOL | SXB $=$ FASHFX PHI $4+\ldots$ <br> RWXS $=$ FASHFX PH14 $+\ldots$ <br> RWBO-RWB3 $=$ RWXS <br> S/DRQ $=$ FAMDSF PH14 $+\ldots$ <br> S/PH15 $=$ PHI4 NBR $+\ldots$ <br> S/T10L $=$ FAMDSF PHI $4+\ldots$ | Store modified data in Bregister in odd numbered private memory register <br> Inhibits transmission of another clock until data signal received |
| $\underbrace{\mathrm{PHI} 5}$ | $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow S 0-\mathrm{S} 31$ $\text { SO-S31 } \longrightarrow \text { RWO-RW31 }$ <br> Generate write byte signals RWBO-RWB3 <br> Generate signal ENDE <br> Set flip-flop PREI <br> Enable T6L | SXPR $=$ SXADD $=$ FASH PHI5 <br>  NRTZ $+\ldots$ <br> RWXS $=$ FAMDSF PHI5 $+\ldots$ <br> RWB0-RWB3 $=$ RWXS <br>   <br> ENDE $=$ FAMDSF PHI5 $+\ldots$ <br> S/PRE1 $=$ ENDE (NHALT + FUEXU) <br>  N(S/INTRAPF) $+\ldots$ <br> T6L $=$ NTIL NT4L NT8L NTIOL <br>  NRESET | Modified contents of Aregister <br> Modified contents of Aregister stored in addressed private memory register |
|  |  |  | Mnemonic: S (25, A5) |

Zeros are placed in the vacated bit positions at the least significant end of the A-register. Shifting stops when one of the following events takes place:
a. Zeros in P25 through P31 indicate that the shift count has been reached.
b. Zeros in bits 8 through 11 of the A-register indicate that the number has been normalized.
c. Ones in P15 through P17 of the limit counter indicate that 14 shifts have taken place, and that the number is shifted 56 bit positions.
d. A one in bit 0 of the E-register indicates characteristic underflow.

If flip-flop P25 contains a one, indicating a right shift, the data in the A-register is shifted two bit positions to the right at each clock time, and zeros are copied into the vacated bit positions at the most significant end of the A-register. The shift count in flip-flops P25 through P31, the limit count in flip-flops P15 through P18, and the characteristic in the E-register are counted up by one at every other clock time. Shifting is stopped by the same events as in left shift except that normalizing does not apply in the right shift, and a one in bit 0 of the E-register indicates characteristic overflow instead of underflow.

3-225 LONG FORMAT. The data words, if positive, or the two's complement of the data words, if negative, are loaded into the $\mathrm{A}-\mathrm{B}, \mathrm{B}-$, and E -registers with the most significant part of the fraction in bits 8 through 11 of the A-register, the remainder of the fraction in the B-register, and the characteristic in the E-register. The shift count is loaded into flip-flops P25 through P31, as in the short format operation. Shifting and counting takes place in the same manner as in short format operation, except that during left shift the data in flip-flops B0 through B3 is shifted into flip-flops A28 through A31, and during right shift, the data in flip-flops A30 and A31 is shifted into flip-flops BO and B1. Vacated positions in the $A$-register are filled with zeros during right shift, and vacated positions in the B-register are filled with zeros during left shift.
$3-226$ SHORT AND LONG FORMAT. When shifting is complete, the shifted data or the two's complement of the shifted data, if originally negative, is loaded into the selected private memory register if it is in short format or into registers $R$ and $R+1$ if it is in long format.

Examples of left and right shift counts less than 14 and exceeding 14 are shown in tables 3-95 through 3-98.

A sequence chart of the Shift Floating instruction is given in table 3-99.

Table 3-95. Left Shift Count Less Than 14

| P15 | P16 | P17 | P18 | Decimal Count | P26 | P27 | P28 | P29 | P30 | P31 | Decimal Count |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | $+0$ | 0 | 0 | 1 | 1 | 0 | 0 | +12 |
| 0 | 0 | 0 | 1 | + 1 | 0 | 0 | 1 | 0 | 1 | 1 | +11 |
| 0 | 0 | 1 | 0 | $+2$ | 0 | 0 | 1 | 0 | 1 | 0 | +10 |
| 0 | 0 | $!$ | $!$ | $+3$ | 0 | 0 | 1 | 0 | 0 | $!$ | + ¢ |
| 0 | 1 | 0 | 0 | + 4 | 0 | 0 | 1 | 0 | 0 | 0 | + 8 |
| 0 | 1 | 0 | 1 | $+5$ | 0 | 0 | 0 | 1 | 1 | 1 | $+7$ |
| 0 | 1 | 1 | 0 | $+6$ | 0 | 0 | 0 | 1 | 1 | 0 | $+6$ |
| 0 | 1 | 1 | 1 | $+7$ | 0 | 0 | 0 | 1 | 0 | 1 | + 5 |
| 1 | 0 | 0 | 0 | + 8 | 0 | 0 | 0 | 1 | 0 | 0 | $+4$ |
| 1 | 0 | 0 | 1 | $+9$ | 0 | 0 | 0 | 0 | 1 | 1 | 3 |
| 1 | 0 | 1 | 0 | +10 | 0 | 0 | 0 | 0 | 1 | 0 | + 2 |
| 1 | 0 | 1 | 1 | +11 | 0 | 0 | 0 | 0 | 0 | 1 | +1 |
| 1 | 1 | 0 | 0 | +12 | 0 | 0 | 0 | 0 | 0 | 0 | $+0$ |

Table 3-96. Left Shift Count Exceeding 14

| P15 | P16 | P17 | P18 | Decimal Count | P26 | P27 | P28 | P29 | P30 | P31 | Decimal Count |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | + 0 | 0 | 1 | 0 | 0 | 0 | 0 | +16 |
| 0 | 0 | 0 | 1 | +1 | 0 | 0 | 1 | 1 | 1 | 1 | $+15$ |
| 0 | 0 | 1 | 0 | + 2 | 0 | 0 | 1 | 1 | 1 | 0 | +14 |
| 0 | 0 | 1 | 1 | + 3 | 0 | 0 | 1 | 1 | 0 | 1 | +13 |
| 0 | 1 | 0 | 0 | + 4 | 0 | 0 | 1 | 1 | 0 | 0 | +12 |
| 0 | 1 | 0 | 1 | $+5$ | 0 | 0 | 1 | 0 | 1 | 1 | +11 |
| 0 | 1 | 1 | 0 | + 6 | 0 | 0 | 1 | 0 | 1 | 0 | +10 |
| 0 | 1 | 1 | 1 | + 7 | 0 | 0 | 1 | 0 | 0 | 1 | +9 |
| 1 | 0 | 0 | 0 | + 8 | 0 | 0 | 1 | 0 | 0 | 0 | $+8$ |
| 1 | 0 | 0 | 1 | + 9 | 0 | 0 | 0 | 1 | 1 | 1 | $+7$ |
| 1 | 0 | 1 | 0 | +10 | 0 | 0 | 0 | 1 | 1 | 0 | $+6$ |
| 1 | 0 | 1 | 1 | +11 | 0 | 0 | 0 | 1 | 0 | 1 | $+5$ |
| 1 | 1 | 0 | 0 | +12 | 0 | 0 | 0 | 1 | 0 | 0 | + 4 |
| 1 | 1 | 0 | 1 | +13 | 0 | 0 | 0 | 0 | 1 | 1 | + 3 |
| 1 | 1 | 1 | 1 | +14 | 0 | 0 | 0 | 0 | 1 | 0 | $+2$ |

Table 3-97. Right Shift Count Less Than 14

| P15 | P16 | P17 | P18 | Decimal Count | P25 | P26 | P27 | P28 | P29 | P30 | P31 | Decimal Count | SHPC |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | +0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | -11 | 1 |
| 0 | 0 | 0 | 1 | +1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | -10 | 0 |
| 0 | 0 | 0 | 1 | +1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | -10 | 1 |
| 0 | 0 | 1 | 0 | +2 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | -9 | 0 |
| 0 | 0 | 1 | 0 | +2 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | -9 | 1 |
| 0 | 0 | 1 | 1 | +3 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | -8 | 1 |
| 0 | 0 | 1 | 1 | +3 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | -8 | 0 |
| 0 | 1 | 0 | 0 | +4 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | -7 | 1 |
| 0 | 1 | 0 | 0 | +4 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | -7 | 0 |
| 0 | 1 | 0 | 1 | +5 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | -6 | 1 |
| 0 | 1 | 0 | 1 | +5 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | -6 | 0 |
| 0 | 1 | 1 | 0 | +6 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | -5 | 1 |
| 0 | 1 | 1 | 0 | +6 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | -5 | 0 |
| 0 | 1 | 1 | 1 | +7 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | -4 | 1 |
| 0 | 1 | 1 | 1 | +7 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | -4 | 0 |
| 1 | 0 | 0 | 0 | +8 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | -3 | 1 |
| 1 | 0 | 0 | 0 | +8 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | -3 | 1 |
| 1 | 0 | 0 | 1 | +9 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | -2 | -2 |
| 1 | 0 | 0 | 1 | +9 | 10 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | -1 |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | -1 | 1 |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | -1 | 0 | 0 | 1 |

Table 3-98. Right Shift Count Exceeding 14

| P15 | P16 | P17 | P18 | Decimal Count | P25 | P26 | P27 | P28 | P29 | P30 | P31 | Decimal Count | SHPC |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |  | 1 | 1 | 1 | 0 | 0 | 0 | 1 | -15 | 1 |
| 0 | 0 | 0 | 1 | +1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | -14 | 0 |
| 0 | 0 | 0 | 1 | +1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | -14 | 1 |
| 0 | 0 | 1 | 0 | + 2 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | -13 | 0 |
| 0 | 0 | 1 | 0 | + 2 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | -13 | 1 |
| 0 | 0 | 1 | 1 | + 3 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | -12 | 0 |
| 0 | 0 | 1 | 1 | + 3 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | -12 | 1 |
| 0 | 1 | 0 | 0 | + 4 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | -11 | 0 |
| 0 | 1 | 0 | 0 | + 4 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | -11 | 1 |
| 0 | 1 | 0 | 1 | + 5 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | -10 | 0 |
| 0 | 1 | 0 | 1 | + 5 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | -10 | 1 |
| 0 | 1 | 1 | 0 | $+6$ | 1 | 1 | 1 | 0 | 1 | 1 | 1 | - 9 | 0 |
| 0 | 1 | 1 | 0 | $+6$ | 1 | 1 | 1 | 0 | 1 | 1 | 1 | -9 | 1 |
| 0 | 1 | 1 | 1 | + 7 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | - 8 | 0 |
| 0 | 1 | 1 | 1 | $+7$ | 1 | 1 | 1 | 1 | 0 | 0 | 0 | - 8 | 1 |
| 1 | 0 | 0 | 0 | + 8 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | - 7 | 0 |
| 1 | 0 | 0 | 0 | $+8$ | 1 | 1 | 1 | 1 | 0 | 0 | 1 | - 7 | 1 |
| 1 | 0 | 0 | 1 | +9 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | - 6 | 0 |
| 1 | 0 | 0 | 1 | $+9$ | 1 | 1 | 1 | 1 | 0 | I | 0 | -6 | 1 |
| 1 | 0 | 1 | 0 | +10 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | - 5 | 0 |
| 1 | 0 | 1 | 0 | +10 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | - 5 | 1 |
| 1 | 0 | 1 | 1 | $+11$ | 1 | 1 | 1 | 1 | 1 | 0 | 0 | - 4 | 0 |
| 1 | 0 | 1 | 1 | $+11$ | 1 | 1 | 1 | 1 | 1 | 0 | 0 | - 4 | 1 |
| 1 | 1 | 0 | 0 | +12 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | - 3 | 0 |
| 1 | 1 | 0 | 0 | +12 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | - 3 | 1 |
| 1 | 1 | 0 | 1 | +13 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | - 2 | 0 |
| 1 | 1 | 0 | 1 | +13 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | - 2 | 1 |
| 1 | 1 | 1 | 0 | +14 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | - 1 | 0 |

Table 3-99. Shift Floating, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | Same as general preparation sequence in tables 3-24 through 3-26 except: <br> If the instruction is not indirectly addressed, during PRE2 the sign bit of the data word is stored in flipflop RN <br> If bit C23 is a one, force a one on address line LR31 to select odd numbered private memory register | S/RN <br> R/NLR31/2 | $\begin{aligned} = & \text { RRO RNXRRO }+\ldots \\ = & \text { LR31/2 = FASHFL PRE2 NIA } \\ & C 23+\ldots . \end{aligned}$ | Stores sign bit of floating point number. $\mathrm{RN} \Rightarrow$ negative number |
| PHI | $R R 0-R R 31 \longrightarrow A 0-A 31$ <br> Reset condition code flip-flops $\mathrm{CC1}$ and CC2 <br> Set interrupt enable flip-flop IEN <br> If bit P25 is a one, set flip-flop BWZ <br> Clear flip-flops P15 through P22 <br> If flip-flop RN is set, set flipflop NGX <br> Force ones into CS-register is signal ( $\mathrm{S} / \mathrm{NGX}$ ) is generated <br> Reset flip-flop K 00 H | AXRR <br> $\mathrm{R} / \mathrm{CCl}$ <br> R/CC2 <br> S/IEN <br> S/BWZ <br> PX/2 <br> S/NGX <br> $\operatorname{CSX1}$ <br> $\mathrm{R} / \mathrm{KOOH}$ | $\begin{aligned} = & \text { FASHFL PHI }+\ldots \\ = & \text { FASH PHI }+\ldots \\ = & \text { FAMDSF NFAMULH PHI } \\ & +\ldots \\ = & \text { FAMDSF NFAMULH PHI } \\ & +\ldots \\ = & \text { FASH PHI P25 + } \ldots \\ = & \text { FASH PHI }+\ldots \\ = & \text { FASHFL PHI RN }+\ldots \\ = & (S / \text { NGX) }+\ldots \\ = & \text { NKOO }(\text { FASHFL PHI })+\ldots \end{aligned}$ | Number to be shifted (from register $R+1$ if long format) <br> Allow interrupts <br> Negative shift count <br> Clears limit counter <br> Negative number <br> For two's complement operation <br> Generates signal K31 for two's complement operation |
| $\left\lvert\, \begin{aligned} & \mathrm{PHI} \\ & \mathrm{~T} 4 \mathrm{RL} \end{aligned}\right.$ | If NC23, set flip-flop PH3 If C23, set flip-flop PH2 | $\mathrm{S} / \mathrm{PH} 3$ S/PH2 | $\begin{aligned} = & \text { BRPH3 }=\text { FASHFL PHI NC23 } \\ & +\ldots \\ = & \text { PHI NBR N(FNANLZ } \\ & \text { NANLZ) }+\ldots . \end{aligned}$ | For short format <br> For long format |
|  |  |  |  | Mnemonic: SF (24, A4) |

Table 3-99. Shift Floating, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{PHI}$ <br> T4RL <br> (Cont. | If NC23, enable clock T6L <br> If C23, enable T6RL | T6L <br> T6RL | ```= NT1L NT4L NT8L NT10L NRESET = FASHFL PHI C23 + ...``` | For short format <br> For long format |
| $\begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 6 \mathrm{RL} \end{aligned}$ | (Long format only) <br> If NGX is true, $\mathrm{A} 0-\mathrm{A} 31 \oplus$ <br> CSO-CS31 plus $\mathrm{K} 31 \longrightarrow$ SO-S31 <br> CSO-CS31 plus $\mathrm{K} 31 \longrightarrow$ - $0-\mathrm{S} 31$ <br> If GX is true, $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow$ S0-S31 $\mathrm{SO}-\mathrm{S} 31 \rightarrow \mathrm{BO}-\mathrm{B} 31$ <br> If end carry occurs, reset KOOH ; otherwise, set KOOH <br> If NGX is true, hold NGX set <br> RRO-RR31 $\longrightarrow$ A0-A31 <br> Set flip-flop PH3 <br> Enable clock T6L | K31 <br> SXK <br> BXS <br> $\mathrm{S} / \mathrm{KOOH}$ <br> $\mathrm{R} / \mathrm{KOOH}$ <br> S/NGX <br> AXRR <br> S/PH3 <br> T6L | $\begin{aligned} = & \text { NGX (NKOOH + NFASHFL) } \\ & +\ldots \\ = & \text { SXADD }+ \text { FASHFL PH2 }+\ldots \\ = & \text { FASHFL PH2 }+\ldots \\ = & \text { SO0 = NK00 N(FASHFL PHI) } \\ & +\ldots \\ = & \ldots \\ = & \text { FASHFL PH2 RN }+\ldots \\ = & \text { FASHFL PH2 }+\ldots \\ = & \text { PH2 NBR N(FNANLZ } \\ & \text { ANLZ) }+\ldots \\ = & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \end{aligned}$ | Exclusive OR operation performed to obtain one's complement. K31 added to obtain two's complement <br> Inverted end carry <br> Inverted end carry <br> To hold ones in CSregister for negation of remainder of word <br> From even numbered private memory register |
| $\left\lvert\, \begin{aligned} & \text { PH3 } \\ & \text { T6L } \end{aligned}\right.$ | (Short and long format) <br> If $N G X$ is true, $A 0-A 31 \oplus$ <br> CSO-CS31 plus K31 if an end carry exists from PH2 <br> If signal GX is true, A0-A31 $\longrightarrow$ S0-S31 | SXK SXK | $\begin{aligned} = & \text { SXADD }=\text { FASHFL PH3 }+\ldots \\ = & \text { SXADD }=\text { FASHFL PH3 } \\ & +\ldots \end{aligned}$ | Obtain two's complement for short format operation. Continue obtaining two's complement if long formá |
|  |  |  | ued) | Mnemonic: SF (24, A4) |

Table 3-99. Shift Floating, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH3 <br> T6L <br> (Cont.) | $\mathrm{SO}-\mathrm{S} 7 \rightarrow \mathrm{EO}-\mathrm{E} 7$ $\mathrm{S} 8-531 \rightarrow \mathrm{~A} 8-\mathrm{A} 31$ <br> Set flip-flop PH9 <br> Enable clock T6L | EXS <br> AXS/3 <br> S/PH9 <br> T6L | $\begin{aligned} = & \text { FASHFL PH3 }+\ldots \\ = & \text { FASHFL PH3 }+\ldots \\ = & \text { BRPH9 }=\text { FASHFL PH3 }+\ldots \\ = & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \end{aligned}$ | Characteristic read into E-register <br> Fraction read into Aregister |
| $\left\lvert\, \begin{aligned} & \text { PH9 } \\ & \text { T6L } \end{aligned}\right.$ | (Short and long format) <br> If NC23 NP25, A0-A31 $\longrightarrow$ <br> S0-S31 $\mathrm{S} 4-\mathrm{S} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 27$ <br> P26-P31 minus one, P15-P17 plus one, E0-E7 minus one | SXA <br> AXSL4 <br> SFTL4 <br> SFTL <br> MCTP 1 | $\begin{aligned} & =\text { FASH PH9 }+\ldots \\ & =\text { SFTL4 }+\ldots \\ & =\text { SFTL NSFTLI NSHEX }+\ldots \\ & =\text { PH9 NBWZ }+\ldots \\ & =\text { SFTL NSHEX }+\ldots \end{aligned}$ | Short format left shift <br> Left shift four bit positions <br> Zeros $\xrightarrow{\rightarrow}$ vacated positions <br> Shift count decreased by one, limit count increased by one, and characteristic decreased by one. Limit counter limits shifts to 14. Signal SHEX is generated if 14 shifts take place and shift count is not reached |
|  | P26-P31 minus one, P15-P17 plus one, E0-E7 minus one | MCTP2 <br> PCTP5 <br> MCTE 1 <br> MCTE2 | $\begin{aligned} = & \text { MCTP1 NP30 NP31 } \\ = & \text { FASHFL SFTL4 }+\ldots \\ = & \text { SFTL4 FASHFL }+\ldots \\ = & \text { MCTE1 NE4 NE5 (NE6 NE7 } \\ & + \text { NES4) } \end{aligned}$ |  |
|  | Hold flip-flop PH9 set | S/PH9 | $\begin{aligned} = & \text { BRPH9 }=\text { FASH PH9 NSHEX } \\ & +\ldots \end{aligned}$ |  |
|  | If a one is detected in A8 through All, generate signal SHEX <br> If a one is detected in flip-flop EO, generate signal SHEX | SHEX <br> SHEX | $\begin{aligned} = & \text { NA0811Z NP25 FASHFL } \\ & +\ldots \\ = & \text { FASH PH9 E0 }+\ldots . \end{aligned}$ | Indicates number is normalized <br> Indicates characteristic underflow |
|  |  |  |  | Mnemonic: SF (24, A4) |

Table 3-99. Shift Floating, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH9 <br> T6L <br> (Cont.) | If bits P25 through P3I are all zeros or P15 through P17 are all ones, generate signal SHEX $\begin{aligned} & \text { If C23 NP25, } \\ & \text { A0-A31 } \text { S0-S31 } \end{aligned}$ | $\begin{aligned} & \text { SHEX } \\ & \\ & \text { S/A28 } \\ & \vdots \\ & \text { S/A31 } \\ & \text { A28EN/1 } \\ & \vdots \\ & \text { A31EN/1 } \\ & \text { SXA } \end{aligned}$ | $\begin{aligned} = & \text { FASH PH9 }(\text { P2629Z NP25 } \\ & \text { NP30 NP31 }+ \text { P15 P16 P17) } \\ & +\ldots \\ = & \text { A28EN } / 1 \text { AXSL4 }+\ldots \\ = & \text { A31EN } / 1 \text { AXSL4 }+\ldots \\ = & \text { B0 FASH C23 }+\ldots \\ = & \text { B3 FASH C23 }+\ldots \\ = & \text { FASH PH9 }+\ldots . \end{aligned}$ | Indicates count has been reached or register is all zeros <br> Long format left shift |
|  | $\mathrm{S} 4-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 27$ | AXSL4 | $=$ SFTL4 $+\ldots$ | Shift left four bit positions |
|  | $\mathrm{B} 0-\mathrm{B} 3 \longrightarrow \mathrm{~A} 28-\mathrm{A} 31$ $\mathrm{B} 4-\mathrm{B} 27 \rightarrow \mathrm{BO}-\mathrm{B} 27$ <br> If NC23 P25 | BXBL4 | $=S F T L 4+\ldots$ | Zeros $\rightarrow$ vacated bit positions in B-register |
|  | $\begin{aligned} & A 0-A 31 \longrightarrow P R O-P R 31 \\ & \text { PR0-PR29 } \rightarrow A 2-A 31 \end{aligned}$ | AXPRR2 <br> SFTR2 <br> SFTR | $\begin{aligned} & =\text { SFTR2 }+\ldots \\ & =\text { SFTR NSHEX }+\ldots \\ & =\text { FASH PH9 BWZ }+\ldots \end{aligned}$ | Short format right shift. Shift right two bit positions. Zeros $\xrightarrow{\longrightarrow}$ vacated bit positions |
|  | $\begin{aligned} & \mathrm{PR} 30, \mathrm{PR} 31 \rightarrow \mathrm{BO}, \mathrm{BI} \\ & \mathrm{BO}-\mathrm{B} 29 \rightarrow \mathrm{~B} 2-\mathrm{B} 31 \end{aligned}$ | BXBR2 | $=\text { SFTR2 }+\ldots$ |  |
|  | Toggle flip-flop SHPC | S/SHPC | $=\text { SFTR2 NSHPC }$ | Enable counting up shift count and characteristic every other clock time |
|  |  | R/SHPC | $=\cdot$ |  |
|  | $(\text { P25-P31) }+1 \xrightarrow{\longrightarrow} \text { P25-P31 }$ | PCTPI <br> PCTP2 | $\begin{aligned} & =\text { SHPC FASHFL }+\ldots \\ & =\text { NPA33 P30 P31 }+\ldots \end{aligned}$ | Add one to two's complement of shift count |
|  |  | PCTP3 | $=$ PCTP2 P2629W |  |
|  | $(\mathrm{P} 15-\mathrm{P} 10)+1+\mathrm{f}=\mathrm{P} 5-\mathrm{P} 18$ | PCTPS | $=\text { FASHFL SHPC + . . }$ | Add one to limit counter |
|  |  | PCTEI | $=$ FASHFL SHPC $+\ldots$ | Add one to characteristic |
|  |  |  |  | Mnemonic: SF (24, A4) |

Table 3-99. Shift Floating, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH9 T6L (Cont.) | Hold flip-flop PH9 set until shift exit signal SHEX <br> Generate signal SHEX <br> Reset flip-flop IEN <br> If NC23, generate memory request for next instruction <br> Q15-Q31 $\rightarrow$ P15-P31 <br> P15-P31 $\longrightarrow$ LM15-LM31 <br> Set flip-flop PHI4 if short format <br> Set flip-flop PHIO if long format <br> Enable clock T6L <br> Set flip-flop CXS | PCTE2 <br> S/PH9 <br> R/IEN <br> $M R Q / 1$ <br> PXQ <br> S/PHI4 <br> S/PH10 <br> T6L <br> S/CXS | $\begin{aligned} = & \text { PCTE1 E4 E5 E6 E7 (NF } \\ & \text { E0F + NE2) } \\ = & \text { BRPH9 = FASH PH9 NSHEX } \\ & +\ldots \\ = & \text { SHEX + . . } \\ = & \text { SHEX (NFASHFL NC23) } \\ & +\ldots \\ = & \text { MRQ } / 1+\ldots \\ = & \text { SHEX FASHFL NC23 + . . . } \\ = & \text { PH9 NBR + . . } \\ = & \text { NTIL NT4L NT8L NT10L } \\ & \text { NRESET } \\ = & \text { SHEX FASHFL C23 + . . } \end{aligned}$ | See short format left shift. $\mathrm{EO} \Longrightarrow$ characteristic overflow <br> Disable interruptibility <br> Short format <br> Address of next instruction <br> Address $\longrightarrow$ core memory address lines <br> Branch to phase 14 <br> Go to phase 10 <br> For use in phase 10 |
| $\begin{aligned} & \text { PH10 } \\ & \text { T6L } \end{aligned}$ | (Long format only) $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{CO}-\mathrm{C} 31 \end{aligned}$ <br> If NA0031Z, reset flip-flop RTZ <br> Set flip-flop PHII <br> Enable clock T6L | SXA <br> CXS <br> R/RTZ <br> S/PHII <br> T6L | $\begin{aligned} = & \text { FAMDSF PHIO }+\ldots \\ = & \text { SHEX FASHFL C23 }+\ldots \\ = & \text { FASHFL NA0031Z }+\ldots \\ = & \text { PHIO NBR }+\ldots \\ = & \text { NTIL NT4L NT8L NT10L } \\ & \text { NRESET } \end{aligned}$ | NA0031Z $\Rightarrow$ Aregister not all zeros |
| $\begin{aligned} & \text { PHII } \\ & \text { T6L } \end{aligned}$ | (Long format only) $\begin{aligned} & \mathrm{BO}-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 31 \end{aligned}$ | SXB <br> AXS | $\begin{aligned} & =\text { FASHFL PHII }+\ldots \\ & =\text { FASHFL PHII }+\ldots \end{aligned}$ |  |
|  |  |  | ued) | Mnemonic: SF (24, A4) |

Table 3-99. Shift Floating, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PHII <br> T6L <br> (Cont. | If original operand negative, set flip-flop NGX <br> Reset flip-flop K00H to generate signal K31 <br> Force a one onto private memory address line LR31 <br> Set flip-flop PH12 <br> Enable clock T10L | S/NGX <br> $\mathrm{R} / \mathrm{KOOH}$ <br> R/NLR31/2 <br> S/PHI2 <br> S/TIOL | $\begin{aligned} = & \text { FASHFL RN PHII }+\ldots \\ = & . \\ = & \text { LR31/2 }=\text { FASHFL PHII } \\ & +\ldots \\ = & \text { PHII NBR }+\ldots \\ = & \text { FASH PHII }+\ldots \end{aligned}$ | For two's complement operation <br> To select odd numbered private memory register |
| $\begin{aligned} & \mathrm{PH} 12 \\ & \mathrm{~T} 10 \mathrm{~L} \end{aligned}$ | (Long format only) <br> If GX is true, $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow$ S0-S31 <br> If NGX is true, A0-A31 $\oplus$ CSO-CS31 $\longrightarrow$ S0-S31 <br> If NGX is true and NKOOH is true from PHIl, A0-A31 $\oplus$ CSO-CS31 plus K31 $\longrightarrow$ S0-S31 <br> Set K 00 H unless an end carry occurs during the two's complement operation $\text { SO-S31 } \longrightarrow \text { RW0-RW31 }$ <br> Generate write byte signals RWB0-RWB3 <br> If NA0031Z, reset flip-flop RTZ <br> $\mathrm{E} 0-\mathrm{E} 7 \boldsymbol{\prime} \boldsymbol{\prime}=\mathrm{A} 0-\mathrm{A}^{7}$ $C 0-C 31 \rightarrow D 0-D 31$ | SXK <br> SXK <br> K3I <br> $\mathrm{S} / \mathrm{KOOH}$ <br> RWXS <br> RWB0-RWB3 <br> R/RTZ <br> S/AO, AI <br> AOEN/I <br> AIEN/I <br> AXE <br> DXC | $\begin{aligned} = & \text { FASHFL PHI } 2+\ldots \\ = & \text { SXADD }=\text { FASHFL PHI2 } \\ & +\ldots \\ = & \text { N(K00H FASHFL) NGX } \\ & +\ldots \\ = & \text { S00 } \\ = & \text { FASHFL PH12 }+\ldots \\ = & \text { RWXS } \\ = & \text { FASHFL NA0031Z + . . } \\ = & \text { AOEN/1, AIEN } / 1 \text { AXE } \\ = & \text { EO NFAMDSF } \\ = & \text { EI NFAFL } \\ = & \text { FASHFL PH12 + . } \\ = & \text { FASHFL PH12 }+\ldots \end{aligned}$ | $G X \Rightarrow$ positive sign <br> Forms one's complement <br> Forms two's complement <br> Store lower half of floating point word in odd numbered private memory register <br> Modified characterisite <br> Modified fraction. Bits D0 through D7 are zeros |
|  |  |  | ued) | Mnemonic: SF $(24, ~ A 4)$ |

Table 3-99. Shift Floating, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH12 <br> TIOL (Cont.) | Generate memory request for next instruction <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Set flip-flop DRQ <br> Set flip-flop PH15 <br> Enable clock T10L | $M R Q / 1$ <br> PXQ <br> S/DRQ <br> S/PH15 <br> S/T10L | $\begin{aligned} = & \text { FASHFL PHI2 }+\ldots \\ = & \text { MRQ } / 1+\ldots \\ = & \text { FASH PHI } 2+\ldots \\ = & \text { BRPHI5 = FASHFL PHI2 } \\ & +\ldots \\ = & \text { FASH PHI2 }+\ldots . \end{aligned}$ | Address of next instruction <br> Inhibits transmission of another clock until data signal received |
| $\left\lvert\, \begin{aligned} & \mathrm{PH} 14 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}\right.$ | (Short format only) $\mathrm{E} 0-\mathrm{E} 7 \rightarrow \mathrm{AO}-\mathrm{A} 7$ <br> If NA0031Z, reset flip-flop RTZ <br> If original operand was negative, set flip-flop NGX <br> Reset flip-flop K00H to generate K31 <br> Set flip-flop DRQ <br> Set flip-flop PH15 <br> Enable clock T10L | AXE <br> R/RTZ <br> S/NGX <br> $\mathrm{R} / \mathrm{K} 00 \mathrm{H}$ <br> $S / D R Q$ <br> S/PH15 <br> S/TIOL | $\begin{aligned} & =\text { FASHFL PHI } 4+\ldots \\ & =\text { FASHFL NA003IZ }+\ldots \\ & =\text { FASHFL PHI4 RN }+\ldots \\ & =\ldots \\ & =\text { FAMDSF PH14 + . . } \\ & =\text { PHI4 NBR }+\ldots \\ & =\text { FAMDSF PHI4 }+\ldots \end{aligned}$ | Characteristic clocked into A-register <br> Force one's into CSregister for two's complement <br> Inhibits transmission of another clock until data signal received |
| $\left\lvert\, \begin{aligned} & \mathrm{PH} \mathrm{H} 5 \\ & \mathrm{~T} 10 \mathrm{~L} \end{aligned}\right.$ | (Short and long format) <br> If original operand was positive <br> A0-A31 $\longrightarrow$ SO-S31 (if short) <br> $\mathrm{AO}-\mathrm{A} 31+\mathrm{DO}-\mathrm{D} 31 \longrightarrow$ S0-S31 <br> (if long) <br> If original operand was negative <br> A0-A31 $\dagger$ CS0-CS31 plus <br> $\mathrm{K} 31 \rightarrow$ S0-S31 | SXK <br> SXK | $\begin{aligned} = & \text { SXADD }=\text { FASH PH15 NRTZ } \\ & +\ldots \\ = & \text { SXADD = FASH PHI5 NRTZ } \\ & +\ldots . \end{aligned}$ | 8-bit characteristic and 4-bit fraction. Modified 32-bit floating point word <br> Two's complement for short format |
|  |  |  |  | Mnemonic: SF (24, A4) |

Table 3-99. Shift Floating, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PHI5 <br> T10L <br> (Cont.) | A0-A31 $\oplus$ CS0-CS31 $\oplus$ D0-D31 plus $\mathrm{K} 31 \longrightarrow$ S0-S31 if long format and an end carry exists <br> A0-A31 $\oplus$ D0-D31 $\oplus$ CS0-CS31 <br> $\longrightarrow$ SO-S31 $\text { SO-S31 } \longrightarrow \text { RW0-RW31 }$ <br> Generate write byte signals RWBO-RWB3 $\mathrm{S} 0-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> Force a one into A31 if NRTZ <br> Set flip-flop TESTA <br> Generate signal ENDE <br> Set flip-flop PREI <br> Enable clock T6L <br> If result of shift is zero or fraction was normalized, set flip-flop CCl <br> If characteristic under or overflow occurs, set flip-flop CC2 | RWXS <br> RWBO-RWB3 <br> AXS <br> A31X1 <br> S/TESTA <br> ENDE <br> S/PREI <br> T6L <br> $\mathrm{S} / \mathrm{CCl}$ <br> S/CC2 | $\begin{aligned} = & \text { FAMDSF PHI5 }+\ldots \\ = & \text { RWXS } \\ = & \text { FASHFL PHI5 + } \ldots \\ = & \text { FASHFL PHI5 NRTZ }+\ldots \\ = & \text { FAMDSF NFAHSFX PHI5 } \\ & +\ldots \\ = & \text { FAMDSF PHI5 + . . . } \\ = & \text { ENDE (NHALT + FUEXU) } \\ & \text { N(S/INTRAPF) } \\ = & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \\ = & \text { FASHFL PHI5 NBWZ RTZ } \\ & + \text { FASHFL SHEX NA08IIZ } \\ & +\ldots \\ = & \text { FASHFL PHI5 NRTZ EO } \\ & +\ldots \end{aligned}$ | One's complement plus carry from PHI 2 for long format <br> One's complement for long format without carry <br> Store floating point word in addressed private memory register <br> To set condition code flip-flops <br> Result of shift $\neq 0$ <br> For condition code testing |
| PREI <br> next instruc tion | If the sign bit is positive, set flipflop CC3; if the sign bit is negative, flip-flop CC4 is set | S/CC3 S/CC4 | $\begin{aligned} = & \text { TESTA NTESTA } / 1 \text { NAO } \\ & \text { NA0031Z }+\ldots \\ = & \text { NTESTA } / 1 \text { TESTA AO }+\ldots . \end{aligned}$ |  |
|  |  |  |  | Mnemonic: SF (24, A4) |

3-227 Convert by Addition (CVA 29, A9)
The CVA instruction converts positive binary-coded decimal ( $B C D$ ) integers to their positive binary equivalents or converts positive binary fractions to their positive $B C D$ equivalents. The value in $R+1$ is the number converted, and the converted binary equivalent is stored into private memory register $R$. The effective address is the first address of a 32 -word table that contains descending conversion values. Since all values are positive, bit 0 of each word is the most significant magnitude bit.

Conversion is carried out during PH3 of the CVA instruction by adding those values of the conversion table that correspond to the one-bits of the word to be converted. The Bregister contains the number to be converted and $B$ shifts end-around left each iteration of PH 3 . As each one-bitin $B$ is detected, the corresponding table word value is read from memory and added to the A-register.

During the preparation sequence of the CVA instruction, the $D$ - and E-registers are cleared to zeros, and LR31 is set for the transfer of $R+1$ to the $A$-register in PHI. During all execution phases, the DRQ flip-flop is set. In PH2 the contents of the private memory register $R+1$ are transferred to the A-register from the RR lines.

The number to be converted is placed on the sum bus and is then clocked into the B-register. The A-and C-registers are cleared to zeros and CCl is reset. The CPU enters into PH 3 and remains in PH3 for 34 iterations which are counted by the E-register. When the E-register reaches a count of 33 , the CPU sequences from PH 3 to PH 4 . During each iteration of PH 3 except the last two, MRQ is enabled whenever the most significant bit (MSB) in the B-register is a one. This requests the appropriate conversion word to be read from memory so that it can be added to the A-register when the one-bit in B has been shifted to bit position 30.

After the conversion value has been transferred from $C$ into the $D$-register, the contents of $A$ and $D$ are added. The sum is placed on the sum bus, and, if B30 is a one, it is transferred to A . CCl will set if the sum bus generates an end carry during PH2. The SW1 signal is true during each PH3 iteration except the first. The P-register counts up by one each PH3 when SW1 is true. The B-register, which contains the value being converted during the PH3 iteration, shifts one bit position to the left in each iteration. At the clock of the final PH3 iteration ( $\mathrm{E}=33$ ), MRQ/1 is enabled to request the next instruction.

During PH4 the converted number in the A-register is placed on the sum bus and at the next clock pulse is transferred to the RW lines to be stored in private memory R. In PH5 the A test flip-flop TESTA is set, and ENDE is enabled.

Condition code bits CC3 and CC4 are not affected until the clock at the end of the phase following PH5 of the CVA instruction. This is normally at the end of PREI of
the next instruction, although it could also be during the first phase of an interrupt or trap operation or during phase PCP1 of a control panel operation.

A sequence chart of the Convert by Addition instruction is given in table 3-100.

The number to be converted is placed on the sum bus and is clocked into the B -register. The A - and C -registers are cleared to zeros, and CCl is reset. The CPU enters into PH 3 and remains in PH3 for 34 iterations counted by the E-register. When the E-register reaches a count of 33 , the CPU sequences from PH 3 to PH 4 .

3-228 Convert by Subtraction (CVS 28, A8)
The Convert by Subtraction instruction is normally used to convert positive binary integers to their positive $B C D$ equivalents or positive $B C D$ fractions to their positive binary equivalents. The R-field of the instruction points to the number to be converted. The effective address is the first address of a 32 -word table that contains descending conversion values. Since all values are positive, bit 0 of each word is the most significant magnitude bit.

Conversion is carried out by successive subtractions of the table values from the number to be converted. If the result of the subtraction is a positive difference, a one-bit is placed in the least significant bit position of the $B$-register, the $B$-register contents are shifted one binary place to the left, and the difference is placed in the A-register for the succeeding subtraction. If the result of the subtraction is a negative difference, a zero bit is placed into the low order bit of the $B$-register, and the $B$-register contents are shifted one binary place to the left. The contents of $A$ are unchanged.

The conversion phase lasts for 33 iterations to generate a 32-bit conversion (the first operation does not generate a bit into the B-register). Figure 3-184 is a flow chart describing the Convert by Subtraction instruction operation.

The normal preparation sequence is described under preparation sequence. In the execution sequence, the number to be converted is taken from the RR lines and is transferred to the A-register. The B-register is cleared to zeros, and a one is clocked into E7. The first operand request is made by MRQ, and PH3 is set.

During a CVS instruction, the CPU remains in PH3 for 33 iterations counted by the E-register. When the E-count reaches 33 (E2 E7), the CPU sequences to PH4. MRQ is enabled during each iteration except the last. At the final PH 3 sequence, $\mathrm{MRQ} / 1$ is enabled. Also during each iteration, the P -register counts up by one to address the next operand of the conversion table.

During each iteration of PH3, the new memory table word in the C-register is one's complemented, and is clocked into the D-register. CS31 is set. The contents of the

Table 3-100. Convert by Addition, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PREP | $\begin{aligned} & 0 ' \mathrm{~s} \nrightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & 0 ' \mathrm{~s} \longrightarrow \mathrm{E} 0-\mathrm{E} 7 \end{aligned}$ <br> Set LR31/2 | DX <br> EX/I S/LR31/2 | $\begin{aligned} = & \text { ENDE }+\ldots \\ = & \text { PREI }+\ldots \\ = & \text { FACV O7 (PRE2 NIA) } \\ & +\ldots \end{aligned}$ | To address R + 1 |
| $\begin{array}{\|l\|l} \mathrm{PHI} \\ \mathrm{~T} 4 \mathrm{RL} \end{array}$ | $\begin{aligned} & \text { RRO-RR3I } \rightarrow \mathrm{A} 0-\mathrm{A} 31 \\ & 0^{\prime} \mathrm{s} \rightarrow \mathrm{~B} 0-\mathrm{B} 31 \end{aligned}$ <br> Go to PH2 | AXRR $B X / I$ S/PH2 | $\begin{aligned} & =\text { FACV PHI }+\ldots \\ & =\text { FACV PHI }+\ldots \\ & =\text { PHI NBR }+\ldots \end{aligned}$ | Number to be converted $\longrightarrow$ A-register |
| $\begin{array}{\|l\|l} \text { PH2 } \\ \text { T6L } \end{array}$ | Enable T6L <br> $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ <br> $\mathrm{SO} 0-\mathrm{S} 31 \rightarrow \mathrm{BO}-\mathrm{B} 31$ <br> 0 's $\rightarrow$ A0-A31 <br> Reset CCI <br> Set CX/1 <br> Set T10L <br> Go to PH3 | T6L <br> SXA <br> BXS <br> AX/1 <br> $\mathrm{R} / \mathrm{CCl}$ <br> S/CX/1 <br> S/TIOL <br> S/PH3 | $\begin{aligned} = & \text { NTIL NT4L NT8L NT10L } \\ & \text { NRESET } \\ = & \text { FACV PH2 }+\ldots \\ = & \text { FACV PH } 2+\ldots \\ = & \text { FACV PH } 2+\ldots \\ = & \text { FACV PH } 2+\ldots \\ = & \text { FACV PH } 2+\ldots \\ = & \text { FACV PH2 }+\ldots \\ = & \text { PH2 NBR (FNANLZ NANLZ) } \\ & +\ldots \end{aligned}$ | Number to be converted into B-register <br> Clear C-register |
| PH3 <br> TIOL | Set SWI <br> Shift B0-B31 left one place $E+1 \rightarrow E$ <br> If $B O=1$, enable $M R Q$ <br> Set flip-flop DRQ $\mathrm{C} 0-\mathrm{C} 31 \longrightarrow \mathrm{D} 0-\mathrm{D} 31$ | S/SWI <br> BXBLI <br> S/B31 <br> B3IEN <br> PCTE <br> PCTE2 <br> MRQ <br> S/DRO <br> DXC/I | $\begin{aligned} & =\text { FACV PH3 }+\ldots \\ & =\text { FACV PH3 }+\ldots \\ & =\text { B3IEN BXBLI } \\ & =\text { BO NFAMDSF } \\ & =\text { FACV PH3 }+\ldots \\ & =\text { PCTE1 E4-E7 } \\ & =\text { FACV PH3 NE2 BO }+\ldots \\ & =\text { FACV BRPH3 }+\ldots \\ & =\text { FACV PH3 O7 }+\ldots \end{aligned}$ | End-around shift <br> Request conversion value, but not in last two iterations |
| (Continued) |  |  |  | Mnemonic: CVA (29, A9) |

Table 3-100. Convert by Addition, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & A 0-A 31+D 0-D 31 \\ & +C S 0-C S 31 \longrightarrow \text { S0-S31 } \\ & \text { If } B 0=1, S 0-S 31 \rightarrow A 0-A 31 \\ & \text { If } B 30=1, K 00=1 \text {; set } C C 1 \\ & P+1 \rightarrow P \end{aligned}$ <br> If $\mathrm{E} \neq 33$, remain in PH 3 If $\mathrm{E}=33$, go to PH 4 <br> Enable MRQ/1 <br> Set TIOL | $\begin{aligned} \text { SXADD } & =\text { FACV PH3 }+\ldots \\ \text { AXS } & =\text { FACV PH3 O7 B30 }+\ldots \\ S / C C 1 & =\text { FACV PH3 O7 K00 }+\ldots \\ \text { PCTP1 } & =\text { FACV PH3 SW1 N(E2 E7) }+ \\ \text { PCTP2 } & =\text { PCTP } 1 \\ \text { BRPH3 } & =\text { FACV PH3 N(E2 E7 })+\ldots \\ S / P H 4 ~ & =\text { PH3 NBR }+\ldots \\ M R Q / 1 & =\text { FACV PH3 E2 E7 } \\ S / T 10 L ~ & =\text { FACV PH3 }+\ldots \end{aligned}$ | CS always zero <br> Sum is greater than $2^{32}-1$ |
| $\begin{aligned} & \mathrm{PH} 4 \\ & \mathrm{TIOL} \end{aligned}$ | $\begin{aligned} & A 0-A 31 \longrightarrow \text { SO-S31 } \\ & \text { S0-S31 } \longrightarrow \text { RW0-RW31 } \end{aligned}$ <br> Set flip-flop DRQ for next instruction <br> Set T8L <br> Go to PH5 | $\begin{aligned} \text { SXA } & =\text { FACV PH4 }+\ldots \\ \text { RW } & =\text { FACV PH } 4+\ldots \\ \text { S/DRQ } & =\text { FACV PH } 4+\ldots \\ \text { S/T8L } & =\text { FACVPH } 4+\ldots \\ \text { S/PH5 } & =\text { PH5 NBR }+\ldots \end{aligned}$ | Converted number to $R$ |
| $\begin{aligned} & \text { PH5 } \\ & \text { T8L } \end{aligned}$ | Set test for $A$ Enable ENDE | $\begin{aligned} & \mathrm{S} / \text { TESTA }=\text { FACV PH5 }+\ldots \\ & \mathrm{ENDE}=\mathrm{FACV} \text { PH5 }+\ldots \end{aligned}$ |  |
| PREI <br> (next in-struction) | Test contents of $A$ | $\begin{aligned} \text { R/CC3 }= & \text { TESTA }+\ldots \\ \text { R/CC4 }= & \text { TESTA }+\ldots \\ \text { S/CC3 }= & \text { NTESTA/1 TESTA NA0 } \\ & \text { NA003IZ }+\ldots \\ \text { S/CC4 }= & \text { NTESTA/ } 1 \text { TESTA A0 }+\ldots \end{aligned}$ | If $\mathrm{A} 0 \neq 1$, and $\mathrm{Al}-\mathrm{A} 31<0$ If $A 0=1$ |
|  |  |  | Mnemonic: CVA (29, A9) |



Figure 3-184. Convert by Subtraction, Logic Sequence Diagram

A- and D-registers are gated into the adder, and the sum is placed on the sum bus. If the sum is positive, a one is inserted into the low order bit of B . B is shifted one position to the left, and the contents of the sum bus are gated back into the $A$-register. If the sum is negative, a one is not inserted into the low order bit of $B$. B is shifted one position to the left, and the contents of the A-register are left unchanged.

In PH4 the remainder (if a remainder exists) in A is placed on the sum bus and is then transferred to the RW lines to be written into private memory register R. LR31 flip-flop is set to address $R+1$ in PH5.

In PH5 the converted word in the B-register is placed on the sum bus and is clocked into the A-register for testing purposes. The converted word on the sum bus is also placed on the RW lines and is written into private memory register $R+1$. The test for A flip-flop is set.

Condition code bits CC3 and CC4 are not affected until the clock at the end of the phase following PH5 of the CVS instruction. This is normally at the end of PREI of the next instruction, although it could also be during the first phase of an interrupt or a trap operation or during phase PCP1 of a control panel operation.

A sequence chart of the Convert by Subtraction instruction is given in table 3-101.

## 3-229 Move Byte String (MBS 61)

The MBS instruction is an immediate type instruction with a displacement value contained in bit positions 12 through 31. If the address in the R-field of the instruction word is an even numbered address, the contents of the even numbered private memory register are clocked into the A-register. This data word contains a source address in bit positions 13 through 31. The displacement number is added to this source address as the address where the data readout will begin.

A one is forced on the private memory address lines to select the odd numbered private memory register. The data word in the register contains a destination address in bit positions 13 through 31 and a byte count in bit positions 0 through 7.

The MBS instruction copies the contents of a byte string beginning with the modified source address into byte string locations beginning with the destination address. The number of bytes to be transferred are determined by the count; the bytes to be transferred are determined by the byte address in flip-flops P32 and P33. Each time a byte is transferred, the count is decreased by one. The byte source address and the byte destination address are increased by one.

If the MBS instruction is indirectly addressed, the instruction is treated as a nonexistent instruction. The computer
aborts execution of the instruction at the time of opcode decoding and traps to location $X^{\prime} 40^{\prime}$.

The MBS instruction word is clocked into the D-register at the clock following signal ENDE. The opcode portion is clocked into the O-register for decoding; the R-field is clocked into the R-register; and the address contained in the P -register is increased by one. If bit C 0 is a one, indicating indirect addressing, signal FAILL is generated, causing the computer to trap to location X ' 40 '.

During PRE1, signal PROTECTDIS is generated to inhibit trapping if an attempt is made to read out from or store into a protected area of core memory. At the PREI clock the A-, B-and E-registers are cleared, and the address of the next instruction contained in the P -register is clocked into the Q-register. Flip-flop PH 1 is set to begin execution of the instruction. Flip-flop EXU is set, indicating the execution phases of the instruction, and clock T4RL is enabled.

During PHI , the address contained in flip-flops R28 through R31 is gated onto the $L R$ lines to select the private memory register. At the PHI clock, the contents of the addressed private memory register are clocked into the A-register. The displacement value contained in bits 12 through 31 of the $C$-register is clocked into the D-register, and the sign bit (bit 12) is extended 12 bit positions to the left to form a 32 -bit data word. A one is forced onto private memory address line LR31 to select the odd numbered private memory register. Flip-flop $D R Q$ is set, but the clock transmission is not affected because a memory request has not been initiated. At the PH1 clock, flip-flop PH2 is set, and clock T6RL is enabled.

During PH 2 , the source address contained in the A-register and the displacement contained in the D-register are gated into the adder, and an addition operation is performed. The result is gated onto the sum bus and is clocked into the B register at the PH2 clock. When the data from the odd numbered private memory register is available, clock PH2 clocks the data into the A-register. The data word from the odd numbered register contains the count in bit positions 0 through 7 and the destination address in bit positions 13 through 31. Bit positions 30 and 31 contain the byte selection data. A one is forced on private memory address line LR31 to select the odd numbered private memory register for use during PH3. Flip-flop DRQ is set, but clock transmission is not inhibited since a memory request has not been generated. The instruction sequences to PH3, and clock T1OL is enabled.

The 32-bit displacement value contained in the D-register is gated onto the sum bus during PH 3 and is then gated onto private memory data lines RW0 through RW31. Write-byte signals RWB0 through RWB3 are generated, and the data word is stored in the odd numbered private memory register. At the PH3 clock, the D-register is cleared, and flip-flop $D R Q$ is set. Since no memory request has been generated, transmission of the clock is not inhibited by flip-flop DRQ.

Table 3-101. Convert by Subtraction, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| ENDP | $\begin{aligned} & \mathrm{O}^{\prime} \mathrm{s} \rightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & \mathrm{O}^{\prime} \mathrm{s} \rightarrow \mathrm{E} 0-\mathrm{E} 7 \end{aligned}$ | $\begin{array}{ll} \mathrm{DX} & =\text { ENDE }+\ldots \\ \mathrm{EX} / 1 & =\text { PRE } 1+\ldots \end{array}$ |  |
| $\begin{aligned} & \mathrm{PHI} \\ & \mathrm{~T} 4 \mathrm{RL} \end{aligned}$ | $\begin{aligned} & R R 0-R R 31 \rightarrow A 0-A 31 \\ & 0 ' s \rightarrow B \\ & 1 \rightarrow E 7 \end{aligned}$ <br> Enable $M R Q$ <br> Set flip-flop DRQ <br> Set T10L <br> Go to PH3 | $\begin{array}{ll} \text { AXRR } & =\text { FACV PHI }+\ldots \\ \mathrm{BX} / 1 & =\text { FUCS PHI }+\ldots \\ \mathrm{EX} 7 X 1 & =\text { FUCS PHI }+\ldots \\ \mathrm{MRQ} & =\text { FUCVS PHI }+\ldots \\ \text { S/DRQ } & =\text { FACV BRPH } 3+\ldots \\ S / T 1 O L & =\text { FUCS PHI }+\ldots \\ \mathrm{S} / \mathrm{PH} 3 & =\text { PHI BRPH } 3+\ldots \\ B R P H 3 & =F U C V S P H 1+\ldots \end{array}$ | Number to be converted into A-register <br> Clear B-register <br> Set one count into $E$ <br> Requests first operand conversion value <br> Inhibits clock until data release received from memory |
| PH3 <br> T10L | $\begin{aligned} & \mathrm{NC0-NC31} \mathrm{\rightarrow D0-D31} \\ & 1 \rightarrow \mathrm{CS} 31 \\ & \mathrm{~A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31+\mathrm{CS} 1 \rightarrow \\ & \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{SO}-\mathrm{S} 31 \rightarrow \mathrm{~A} 1 \rightarrow \mathrm{~A} 31 \\ & \text { If } \mathrm{K} 00,1 \rightarrow \mathrm{~B} 31 \end{aligned}$ <br> Shift B left $P+1 \not P$ $E+1 \nmid E$ <br> Set T10L <br> Enable MRQ/1 | $\begin{aligned} \text { NDXNC }= & \text { FUCVS PH3 }+\ldots \\ \text { CXI/8 }= & \text { FUCVS PH3 }+\ldots \\ \text { SXADD }= & \text { FACV PH3 }+\ldots \\ \text { AXS }= & \text { FACV PH3 K00 N(E }+1) \\ & +\ldots \\ \text { B3IXI }= & \text { FUCVS PH3 N(E = 1) K00 } \\ & +\ldots \\ \text { BXBLI }= & \text { FACV PH3 }+\ldots \\ \text { PCTP1 }= & \text { FUCVS PH3 N(E2 E7) }+\ldots \\ \text { PCTP2 }= & \text { PCTPI } \\ \text { PCTE1 }= & \text { FACV PH3 }+\ldots \\ \text { PCTE2 }= & \text { PCTEI E4 E5 E6 E7 }+\ldots \\ \text { S/TIOL }= & \text { FACV PH3 }+\ldots \\ \text { MRQ/I }= & \text { FACV PH3 (E2 E7) }+\ldots \end{aligned}$ | One's complement of EW into D-register <br> For two's complement <br> Private memory word (R)-(EW) 2 -effective word <br> Difference into A if not negative <br> But not if first time in PH3 <br> Increase memory address by one <br> Add one to the E-register <br> Request next instruction, final iteration |
| (Continued) |  |  | Mnemonic: CVS (28, A8) |

Table 3-101. Convert by Subtraction, Phase Sequence (Cont.)


Flip-flop PH5 is set at the PH3 clock, and clock T8L is enabled.

The byte address is contained in bits 30 and 31 of both the source address and the destination address. During PH5, both the source address contained in the B-register and the destination address contained in the A-register are circular right shifted two bit positions. The operation places the desired core memory addresses in bit positions 15 through 31 and the byte selection bits in bit positions 0 and 1. If flipflop PHA is not set, flip-flop PH6 is set, and clock T8L is enabled. Flip-flop DRQ is set, but clock transmission is not inhibited since a memory request has not been generated.

The modified source address and byte selection bits contained in the B-register are gated onto the sum bus. At the PH6 clock, the source address is clocked from the sum bus into the P -register, and byte selection bits S0 and S1 are clocked into flip-flops P32 and P33. The source address is gated from the $P$-register onto core memory address lines LM15 through LB31.

Word mode flip-flop SWI is set if the byte selection bits in the source address (BO BI) and the destination address (AO Al ) are all zeros and if the count in the E-register is four or larger, which indicates that there is to be a transfer of at least one word (four bytes).

If signal SW1 is generated, which indicates a word mode, and if the R-field is not all zeros, a memory request is generated for the first word from the address contained on the $L M$ and the LB lines. Flip-flop DRQ is set. This inhibits transmission of another clock until the data release signal is received. Word mode flip-flop SW1 is reset at the PH6 clock if the set input is not true; the instruction sequences to PH 7 ; and clock T6L is enabled.

The first word is gated into the C-register when it is available from core memory. If signal SWI is true, indicating a full word, bits C0 through C31 are clocked into flip-flops DO through D3?. If signal NSW' is trive, flip-flops P32 and P33 are read to determine the byte selections. If both flip-flop P32 and flip-flop P33 are zeros, signal DXCR24 is generated, which gates bits C0 through C7 into flip-flops D24 through D31. If flip-flop P32 is a zero and P33 is a one, signal DXCR16/1 is generated, gating bits C8 through C15 into flip-flops D24 through D31. Signal DXCR8 is generated, causing bits C16 through C23 to be clocked into flip-flop D24 through D31 if flip-flop P32 is a one and P33 is a zero. Bits C24 through C31 are clocked into flipflops D24 through D31 if flip-flops P32 and P33 are both ones.

A word transfer is indicated, if signal Swi is true, and the contents of the P -register are increased by one count. If signal NSW1 is true, indicating a byte transfer, a one is added to P33 to increase the byte address by one. When the byte address has been counted to three, a one is added to the source address in the $P$-register.

If the memory map and the memory protection options are installed and if the modified source address points to a protected area of core memory, flip-flop SW2 is set, indicating that a memory protection violation has occurred. Flip-flop PH8 is set, and clock T4L is enabled.

Since the first word or byte to be transferred is now in the D-register, the modified source address and byte selection contained in flip-flops P15 through P33 are gated onto the sum bus. Bits P32 and P33 are gated onto bit positions S0 and S1. At the PH8 clock, the contents of the sum bus are clocked into the B-register. Flip-flop DRQ is set, but clock transmission is not inhibited since a memory request has not been generated. The instruction sequences to PHIO , and clock T4L is enabled.

The destination address stored in the A-register is gated onto the sum bus and is then clocked into the P -register. The address is gated onto the LM and the LB address lines to select the memory location for storage of the first word or byte. The byte selection bits contained in bit locations 0 and 1 are clocked into flip-flops P32 and P33. At the PH9 clock, the A-register is cleared. If signal NSW2 is true, indicating that the source address did not point to a protected area of memory, a memory request is generated to store the word or byte in the location pointed by the destination address. Flip-flop NPRX is set for use during PHIO if a byte transfer is indicated by SWI. Signal NPRX forces ones into the CS-register at the PH9 clock. Flip-flop PH10 is set, and clock T6L is enabled.

During PH 10 , storage of the first word or byte is performed. A word mode is indicated if signal SWI is true, and the contents of the D-register are gated onto the sum bus and then onto data lines MB0 through MB31. Write-byte signals MW0 through MW3 are generated; WRITE signal is gen erated; and the first word is stored in the core memory location pointed by the destination address.

A byte selection is indicated if signal NSW1 is true, and the byte previously clocked into flip-flops D24 through D31 is gated onto the sum bus by means of the adder. Bits D24 through D31 are gated into positions S0 through S7, S8 through $\mathrm{S} 15, \mathrm{~S} 16$ through S 23 , and S 24 through S 31 . The byte selected by flip-flops P32 and P33 is gated onto the applicable MBO through MB31 data lines. The appropriate write-byte signal is generated; WRITE signal is generated; and the byte is stored in the byte location pointed by the destination address.

After a word has been stored in core memory, the byte count in the E-register is decreased by four, and the destination address in the P -register is increased by one. If a byte has been stored in core memory, the byte count in the E-register is decreased by one, and the byte address in flip-flops P32 and P33 is increased by one for the next byte. The destination address is not increased until byte 3 has been transferred.

If the destination address points to a protected area of memory, signal PROTECTD is generated. The word or byte is not stored, and the destination address is not counted up. As the trap function is disabled by signal PROTECTDIS, flip-flop SW2 is set to indicate an attempted memory protection violation. The instruction sequences to PH 13 , and clock T6L is enabled.

After the destination address and byte selection bits have been modified, they are gated onto the sum bus. Bits P15 through P31 are gated onto S15 through S31 and P32 and P33 are gated onto SO and S1. The modified destination address and byte address are clocked into the A-register of the PHI 3 clock. If a memory protection violation has not occurred and the byte count has not been counted down to zero, the instruction branches back to PH 6 and the operation is repeated until either flip-flop SW2 is set, indicating a memory violation, or the byte count is zero.

During the shift of the destination address, the count contained in bits 0 through 7 is clocked into flip-flops E0 through E7. If the byte count is not all zeros, the word mode flip-flop SWI is set. As the memory protection trapping function is disabled, flip-flop SW2 is reset to allow an indication when a memory protection violation occurs. The instruction branches to PH6A if the byte count in bit positions $A 0$ through $A 7$ is all zeros, or if an interrupt has occurred, flip-flop PHA is set. If SW2 is set, which indicates a memory protection violation, an interrupt occurs or the byte count is counted down to zero. Flip-flop PHA is set; the instruction branches to PH6A; and clock T8L is enabled.

The modified destination address contained in the A-register is gated onto the sum bus and is shifted left one bit position. Bit A0 is clocked into flip-flop A31. At the same PH6A clock, the source address contained in the $B$-register is shifted one bit position to the left, with bit BO clocked into flip-flop B31. A one is forced onto private memory address line LR31 to select the odd numbered private memory register. This register contains the displacement value that was stored in it during PH3. Signal CXRR is generated to gate the data word into the C-register when it is available on the RR lines. The instruction sequences to PH7, and clock T4RL is enabled.

During PH7A, the destination address contained in the Aregister is gated onto the sum bus and is shifted one bit position to the left into the A-register. Bit AO is clocked into flip-flop A31. The destination address and the byte address are then contained in flip-flops A13 through A31. The modified byte count contained in the E-register is clocked into flip-flops A0 through A7. A one is forced on private memory address line LR31/2 to select the odd numbered private memory register. When the data is available from private memory, signal CXRR gates it into the C -register. The instruction sequences to PH8A, and clock T8L is enabled.

During PH8A, the modified destination address and the byte count contained in the A-Register are gated onto the sum bus and then onto private memory data lines RWO through RW31. Write-byte signals RWB0 through RWB3 are gener ated, and the data word is stored in the odd numbered private memory register. Flip-flop PH9 is set, and clock T8L is enabled.

During PH9, the modified source address contained in the B-register is gated onto the sum bus and is shifted one bit position to the left and is clocked into the A-register. Bit SO is clocked into flip-flop A31. The source address and the byte selection address are contained in flip-flops A13 through A31 at the PH9 clock, and the displacement value contained in the C -register is inverted and is clocked into the $D$-register.

A one is forced into flip-flop CS31, if signals EZ and NSW2 are true, indicating that the byte count was counted down to zero and a memory protection violation did not occur. The remainder of the CS-register is cleared. A memory request is generated for the next instruction. When memory request $M R Q / 1$ is generated, the address of the next instruction is clocked from the $Q$-register into the $P$-register and is gated into the LM and the LB core memory address lines. Flip-flop PHIO is set for the next phase, and clock T6L is enabled.

During PH10, the one's complement of the displacement value contained in the $D$-register, the source address contained in the A-register, and the contents of the CS-register are gated into the adder. An addition operation is performed the result of which is the source address minus the displacement value. The result is gated onto the sum bus and is clocked into the A-register. The D-register is cleared at the PHIO clock. Flip-flop DRQ is set which inhibits transmission of another clock until the data is received from memory.

One's are forced into flip-flops CSO through CS29 (-4) if the transfer operations were in the word mode (SWI), and if a memory protection violation occurred (SW2). Interrupt enable flip-flop IEN is set which allows interrupts to occur. Flip-flop PHIl is set, and clock T10L is enabled.

If bit R31 is not a one, but if there are ones in R28, R29, or R30, the source address contained in the A-register and the contents of the $D$ - and CS-registers are gated into the adder, and an addition operation is performed. The Dregister contains all zeros because it was cleared at the PH10 clock. The CS-register contains a -4 if the transfer operation was a word mode and a memory protection violation occurred. Adding this value to the source address causes the source address to point to the address of the last byte transferred before the violation occurred.

The result of the addition operation is gated onto the sum bus and then onto private memory data lines RWO through

RW31. Write-byte signals RWBO through RWB3 are generated, and the source address is stored in the even numbered private memory register. If the transfer operation was completed and the count in the E-register was al! zeros, signal ENDE is generated. Flip-flop PRE1 is set, and clock T6L is enabled.

Signal ENDE is not generated if a memory protection violation occurred (SW2 is true). Signal (S/TRACC4/1) is generated, and the trap flip-flop is set which causes entrance into the trap sequence.

A sequence chart of the Move Byte String instruction is given in table 3-102.

## 3-230 Compare Byte String (CBS 60)

The CBS instruction compares the contents of the source byte string with the contents of the destination byte string, byte by corresponding byte, beginning with the first byte of each string. The comparison continues until the specified number of bytes has been compared or until an inequality is found.

When the CBS instruction terminates, flip-flops CC3 and CC4 are set to indicate the result of the last comparison. Flip-flop CC4 is set if the source byte string is less than the destination byte string. Flip-flop CC3 is set, if the source byte string is greater than the destination byte string. If the CBS instruction terminates because of inequality, the byte count is one greater than the number of bytes remaining to be compared. The source address and the destination address indicate the locations of the unequal bytes.

If the CBS instruction is indirectly addressed, it is treated as a nonexistent instruction, and the computer aborts execution of the instruction at the time of opcode decoding and traps to location $X^{\prime} 40$ '.

The preparation phase and phases PHI through PH 3 are the same as the sequences given for the Move Byte Stining instruction except that, during PH3, condition code flip-flops CC3 and CC4 are reset.

Phases PH5 through PH9 are the same as PH5 through PH9 of the Move Byte String instruction except that word mode flip-flop SW1 is not set during PH6 and, during PH9, signal (S/NGX) is generated instead of signal NPRX. Signal (S/NGX) forces ones into the CS-register and forces a one into K3l for the two's complement operation to be performed during PHIO. During PH10, the source byte contained in the $D$-register, the ones in the CS-register, and the one in K31 are gated into the adder, and a two's complement opeiation is performed. The resulit is gated onio the sum bus and, at the PH 10 clock, is clocked into the A-register.

When the byte from the destination address location is available on the $M B$ data lines, signal $C X M B$ gates the data into the C -register. At the PHIO clock, the selected
byte is downward aligned into flip-flops D24 through D31. Flip-flop SW2 is set if a memory protection violation occurs. The instruction sequences to PHIl , and clock T6L is enabled.

During PHII , the two's complement of the source byte contained in the A-register and the destination byte contained in the D-register are gated into the adder, and an addition operation is performed. The result is gated onto the sum bus and is clocked into the A-register at the PHIl clock. The instruction sequences to PH 12 , and clock T8L is enabled.

If the source byte is larger than the destination byte, flipflop A0 is a one, and flip-flop CC3 is set. If the source byte is smaller than the destination byte, flip-flop A0 is zero, but the $A$-register does not contain all zeros, and flip-flop CC4 is set. If the two bytes are equal, the contents of the A-register are all zeros and flip-flops CC3 and CC 4 remain reset. If the contents of the A-register are all zeros, indicating the bytes were equal, the byte count in the E -register is decreased by one and the byte address in flip-flops P32 and P33 is increased by one. Flip-flop PHI3 is set, and clock T6L is enabled. If the bytes do not compare, the count in the E-register and the byte address in the P -register remain unchanged.

Operation during phases PHI 3 through PHIIA is the same as the operation described for the Move Byte String instruction, except that if, during PHI 3 , the bytes compared and the E -register are not all zeros, flip-flop PHA is not set. The sequence repeats from PH 6 through PHI 3 until unequal bytes occur (NA0031Z) or the count in the E-register is counted down to zeros. Flip-flop PHA is then set, and the operation proceeds as described in the Move Byte String description.

During PHIIA, signal ENDE is generated if flip-flops CC3 or CC4 have been set or if the E-register has been counted down to all zeros. If a trap does not occur, flip-flop PREI is set and clock T6L is enabled.

Signal ENDE is generated if the transfer operation is completed and the count in the E-register is all zeros. Flipflop PREI is set, and clock T6L is enabled.

If a memory protection violation occurred (SW2 is true), signal ENDE is not generated. Signal (S/TRACC4/1) is generated, and the trap flip-flop is set which causes entrance into the trap sequence.

A sequence chart of the Compare Byte String instruction is given in table 3-103.

## 3-231 Translate Byte String (TBS 41)

The TBS instruction replaces each byte of the destination byte string with a source byte located in a translation table. The destination byte string begins with the byte locations pointed by the destination address in an odd numbered private memory register.

Table 3-102. Move Byte String, Phase Sequence


Table 3-102. Move Byte String, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH2 <br> T6RL (Cont. | $\begin{aligned} & S 0-S 31 \rightarrow B 0-B 31 \\ & \text { RRO-RR31 } \rightarrow \text { A0-A31 } \end{aligned}$ <br> Force a one on private memory address line LR31 <br> Set flip-flop PH3 <br> Enable clock T1OL <br> Set flip-flop DRQ | BXS <br> AXRR <br> R/NLR31/2 <br> $\mathrm{S} / \mathrm{PH} 3$ <br> S/TIOL <br> S/DRQ | $\begin{aligned} = & \mathrm{FABO} \mathrm{PH} 2+\ldots \\ = & \mathrm{FABO} / 2 \mathrm{PH} 2+\ldots \\ = & \mathrm{LR} 31 / 2=\mathrm{FABO} \mathrm{PH} 2 \\ & +\ldots \\ = & \text { PH2 } \mathrm{NBR}+\ldots \\ = & \mathrm{FABO} \mathrm{PH} 2+\ldots \\ = & \mathrm{FABO} / 1 \mathrm{EXU}+\ldots . \end{aligned}$ | Store modified source address in B-register <br> Word from odd numbered private memory register (contains count and destination address) <br> For use in PH3 <br> No function. Does not inhibit transmission of clock |
| $\begin{aligned} & \mathrm{PH} 3 \\ & \mathrm{TIOL} \end{aligned}$ | $\left\{\begin{array}{l} \text { R28-R30 } \longrightarrow \text { LR28-LR30 } \\ \text { LR31/2 } \longrightarrow \text { LR31 } \\ \text { D0-D31 } \longrightarrow \text { S0-S31 } \\ \text { S0-S31 } \longrightarrow \text { RW0-RW31 } \end{array}\right.$ <br> Generate write-byte signals RWBO-RWB3 <br> Disable memory protection <br> Clear D-register <br> Set flip-flop PH5 <br> Enable clock T8L <br> Set flip-flop DRQ | LRXR <br> SXD <br> RWXS <br> RWB0-RWB3 <br> PROTECTDIS <br> DX/1 <br> S/PH5 <br> R/NT8L <br> $S / D R Q$ | $\begin{aligned} & =\text { LRXD }+ \text { LRXR } \\ & =\mathrm{FAB0} / 2 \mathrm{PH} 3+\ldots \\ & =\mathrm{FABO} \mathrm{PH} 3+\ldots \\ & =\mathrm{RW}=\mathrm{FABO} \mathrm{PH} 2+\ldots \\ & =\text { FABOX }+\ldots \\ & =\text { FABS PH3 }+\ldots \\ & =\text { BRPH5 }=\mathrm{FABO} / 1 \mathrm{PH} 3+\ldots \\ & =\text { FABO/1 PH3 }+\ldots \\ & =\text { FAB0/1 EXU }+\ldots \end{aligned}$ | Address of odd numbered private memory register <br> Displacement gated onto sum bus <br> Store 32-bit displacement value in odd numbered private memory register <br> No function. Does not inhibit transmission of clock |
| $\begin{aligned} & \text { PH5 } \\ & \text { T8L } \end{aligned}$ | Circular shift $B$-register right two bit positions with $\mathrm{B} 30 \longrightarrow \mathrm{BO}$ and B31 $\longrightarrow$ B1 <br> Circular shift A-register right two bit positions through adder with A30 $\longrightarrow \mathrm{A} 0$ and $\mathrm{A} 31 \longrightarrow \mathrm{Al}$ | BXBR2 <br> S/BO <br> $S / B 1$ <br> AXPRR2 <br> S/AO <br> S/AI | $\begin{aligned} & =\text { FABS PH5 }+\ldots \\ & =\text { B30 BXBR2 }+\ldots \\ & =\text { B31 BXBR2 }+\ldots \\ & =\text { FABS PH5 }+\ldots \\ & =\text { A30 ARCYC AXPRR2 }+\ldots \\ & =\text { A31 ARCYC AXPRR2 }+\ldots \end{aligned}$ | Modified source address shifted right to place byte address bits in positions BO and BI and address in bit positions 15 through 31 <br> Destination address circular shifted right to place byte address bits in positions AO and $A 1$ |
| (Continued) |  |  |  | Mnemonic: MBS (61) |

Table 3-102. Move Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ $\mathrm{SO} 0-\mathrm{S} 7 \rightarrow \mathrm{E} 0-\mathrm{E} 7$ <br> If the count is not all zeros and if there is no interrupt occurring, set word mode flip-flop SW1 <br> Reset flip-flop SW2 to use for memory protection violation <br> Set flip-flop PHA if count is all zeros or INT is true <br> If PHA is true, branch to PH 6 A ; otherwise, sequence to PH 6 <br> Enable clock T8L <br> If flip-flop PHA is not set, set flip-flop $D R Q$ | ARCYC $=$ ALCYC NANLZ <br> ALCYC $=$ NFAMDSF $+\ldots$ <br> SXA $=$ FABO $/ 2$ PH5 $+\ldots$ <br> EXS $=$ FABO $/ 2$ PH5 $+\ldots$ <br> S/SWI $=$ FABS PH5 NA0007Z NINT <br>  $+\ldots$ <br> R/SW2 $=$ FABS PH5 $+\ldots$ <br> S/PHA $=$ FABS PH5 A0007Z <br>  + FABS PH5 INT $+\ldots$ <br> S/PH6 $=$ PH5 NBR $+\ldots$ <br> R/NT8L $=$ T8L $=$ FAB0 PH5 $+\ldots$ <br> S/DRQ $=$ FAB0 $/ 1$ EXU $+\ldots$ | Count clocked into E. register <br> No function. Does not inhibit transmission of clock |
| $\begin{aligned} & \text { PH6 } \\ & \text { T8L } \end{aligned}$ | $\begin{aligned} & \mathrm{BO-B31} \longrightarrow \mathrm{SO-S31} \\ & \mathrm{SO} \longrightarrow \mathrm{P} 32 \mathrm{~S} 2 \rightarrow \mathrm{P} 15-\mathrm{P} 31 \end{aligned}$ <br> If the R-field is not all zeros and byte 0 has been selected both in the source and destination addresses and the count in the E-register is 4 or more, set word mode flip-flop SW1; otherwise, reset it | $\begin{aligned} \text { SXB } & =\text { FABS PH6 }+\ldots \\ S / \text { P32 }= & \text { SO PXS } / 1+\ldots \\ S / P 33= & S 1 \text { PXS } / 1+\ldots \\ \text { PXS } / 1= & \text { FABO/2 PH6 }+\ldots \\ & \\ \text { S/SW1 }= & (\text { FABS 07) PH6 (NBO NB1 } \\ & \text { NAO NA1) NRZ NE05Z } \\ & +\ldots \\ \text { R/SW1 }= & \text { FABS PH6 }+\ldots \end{aligned}$ | Modified source address gated onto sum bus <br> Byte address clocked into flip-flop P32 and P33 <br> Modified source address clocked into P -register <br> Modified source address gated onto core memory address lines |
|  |  |  | Mnemonic: MBS (61) |

Table 3-102. Move Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved |  | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PH6 <br> T8L <br> (Cont. | If signal SW1 is generated, indicating a word mode, or the R-field is not all zeros and byte 0 has been selected, generate a memory request <br> Set flip-flop DRQ <br> Set flip-flop PH7 <br> Enable clock T6L | $M R Q$ <br> S/DRQ <br> S/PH7 <br> T6L | ```= FABS PH6 SWI + FABS PH6 NRZ NBO NBI + ... = FABO/1 EXU + ... = PH6 NBR + ... = NTIL NT4L NT8L NLIOL NRESET``` | Generate memory request for first data word <br> If $M R Q$ is generated, inhibits transmission of another clock until data release signal is received |
| $\begin{aligned} & \text { PH7 } \\ & \text { T6L } \end{aligned}$ | $\text { MBO-MB31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ <br> If SW1 is true, C0-C31 $\rightarrow$ D0-D31 | CXMB <br> DXC/6 <br> DXC/10, DX <br> DXC/12 <br> DXC/13 <br> DXC/7 <br> DXC/ 1 <br> DXCR8 <br> DXCR16/1 <br> DXCR24 <br> DXCBP <br> PCTPI <br> PCTPI <br> PA33 <br> S/SW2 <br> S/PH8 | $\begin{aligned} & =\text { DGC } \\ & =\text { FABS PH7 SWI }+\ldots \\ & =\text { DXC } / 6+\ldots \\ & =\text { DXC } / 7+\ldots \\ & =\text { DXC } / 7+\text { DXC } / 1+\ldots \\ & =\text { DXC/6 }+\ldots \\ & =\text { DXCBP P32 P33 } \\ & =\text { DXCBP P32 NP33 } \\ & =\text { DXCBP NP32 P33 } \\ & =\text { DXCBP NP32 NP33 } \\ & =\text { FABS PH7 NSWI }+\ldots \\ & =\text { FABS PH7 SWI }+\ldots \\ & =\text { FABS PH7 NRZ }+\ldots \\ & =\text { FABS PH7 NRZ }+\ldots \\ & =\text { FABO/2 PH7 PROTECTD } \\ & \\ & +\ldots \end{aligned}$ | First data word gated into C-register |
| (Continued) |  |  |  | Mnemonic: MBS (61) |

Table 3-102. Move Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH7 <br> T6L <br> (Cont.) <br> PH8 <br> T4L | Enable clock T4L <br> $\mathrm{SO}-\mathrm{S} 31 \nrightarrow \mathrm{BO}-\mathrm{B} 31$ <br> Set flip-flop PH9 <br> Enable clock T4L <br> Set flip-flop DRQ | $\begin{aligned} S / T 4 \mathrm{~L} & =\mathrm{FABO} / 1 \mathrm{PH} 7+\ldots \\ \mathrm{SXP} & =\mathrm{FABS} \text { PH8 }+\ldots \\ \mathrm{BXS} & =\mathrm{FABS} \text { PH8 }+\ldots \\ S / P H 9 & =\text { PH8 NBR }+\ldots \\ S / T 4 \mathrm{~L} & =\mathrm{FABO} / 1 \mathrm{PH} 8+\ldots \\ S / D R Q & =\mathrm{FABO} / 1 \mathrm{EXU}+\ldots \end{aligned}$ | Modified source address and byte selection bits gated onto sum bus <br> Modified source address stored in B-register to allow destination address into $P$-register <br> No function. Does not inhibit transmission of next clock |
| $\begin{aligned} & \text { PH9 } \\ & \text { T4L } \end{aligned}$ | $\begin{aligned} & \text { A0-A31 } \\ & \text { S15-S31 S0-S31 } \\ & \text { P15-P31 P15-P31 } \end{aligned}$ <br> Clear A-register <br> If signal NSW2 is true, generate memory request to store first word or byte <br> If signal NSW1 is true, set flip-flop NPRX to use for upward alignment <br> Set flip-flop PH1O <br> Enable clock T6L <br> Set flip-flop DRQ | $\begin{array}{ll} \text { SXA } & =\text { FAB0/1 PH9 }+\ldots \\ \text { PXS } / 1= & \text { FAB0/1 PH9 }+\ldots \\ \text { AX/1 } & =\text { FABS PH9 }+\ldots \\ \text { MRQ } & =\text { FABS PH9 NSW2 }+\ldots \\ \text { S/NPRX } & =\text { FABS } 07 \text { NSW1 PH9 }+\ldots \\ \text { S/PH10 } & =\text { PH9 NBR } \\ \text { T6L } & =\text { NTIL NT4L NT8L NTIOL NRESET } \\ \text { S/DRQ } & =\text { FAB0/1 EXU } \end{array}$ | Destination address clocked into P -register <br> Destination address gated onto core memory address lines <br> If $M R Q$ is generated, inhibits transmission of next clock until signal is received that data lines have been strobed; otherwise, no function |
| $\begin{aligned} & \text { PH10 } \\ & \text { T6L } \end{aligned}$ | If signal SW 1 is true, D0-D31 $\longrightarrow$ S0-S31 | SXD = FABS 07 PHIO SWI $+\ldots$ | Word mode |
|  |  | (Continued) | Mnemonic: MBS (61) |

Table 3-102. Move Byte String, Phase Sequence (Cont.)


Table 3-102. Move Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH13 T6L (Cont.) | $\mathrm{S} 0-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> If signal SW2 is true, INT is true, or the E-register contains all zeros flip-flop PHA is set <br> Branch to PH6. If PHA is not set, phases PH6 through PHI3 are repeated until flip-flop PHA is se $\dagger$ <br> Enable clock T8L | $\begin{aligned} \text { AXS }= & \text { FABS PHI3 }+\ldots \\ \text { S/PHA }= & \text { FABS PH13 }(\text { SW } 2+\mathrm{INT} \\ & + \text { NA003IZ }+ \text { EZ })+\ldots \\ \text { S/PH6 }= & \text { BRPH6 }=\text { FABS PHI3 }+\ldots \\ \text { R/NT8L }= & \text { T8L }=\text { FABS PHI3 }+\ldots \end{aligned}$ | Modified destination address stored in A-register |
| PH6A <br> T8L | $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ <br> Circular left shift one digit position with $\mathrm{Sl}-\mathrm{S} 31 \rightarrow$ $\mathrm{AO}-\mathrm{A} 30, \mathrm{SO} \longrightarrow \mathrm{A} 31$ <br> Circular left shift one digit position with $\mathrm{BI}-\mathrm{B} 31 \rightarrow$ $\mathrm{BO}-\mathrm{B} 30, \mathrm{BO} \nrightarrow \mathrm{B} 31$ <br> Force a one onto private memory address line LR31 to select odd numbered private memory register <br> Generate signal (S/CXRR) <br> Set flip-flop PH7 <br> Enable clock TIOL | $\begin{array}{ll} \text { SXA } & =\text { FABSA PH6 }+\ldots \\ \text { AXSLI } & =\text { FABSA PH6 }+\ldots \\ \text { A3IEN } / 2 & =\text { SO ALCYC } \\ \text { BXBIL } & =\text { FABSA PH6 } \\ \text { B3IEN/1 } & =\text { B0 NFAMDSF } \\ \text { R/NLR31/2 } & =\text { LR3I/2 }=\text { FABSA PH6 }+\ldots \\ (S / C X R R) & =\text { FABSA PH6 }+\ldots \\ \text { S/PH7 } & =\text { PH6 } 6 \text { NBR } \\ \text { S/T1OL } & =(S / C X R R)+\ldots \end{array}$ | Destination address shifted left once to place byte address from P32 into A31 <br> Source address shifted left once to place byte address from BO into B31 <br> For use in PH7A |
| $\begin{aligned} & \text { PH7A } \\ & \text { T10 } \end{aligned}$ | $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31$ <br> Circular shift left one digit position with S1-S31 $\rightarrow$ $\mathrm{A} 0-\mathrm{A} 30, \mathrm{SO} \longrightarrow \mathrm{~A} 31$ $\mathrm{E} 0-\mathrm{E} 7 \longrightarrow \mathrm{~A} 0-\mathrm{A} 7$ $\text { RR0-RR31 } \rightarrow \text { C0-C31 }$ | $\begin{array}{ll} \text { SXA } & =\text { FABSA PH7 }+\ldots \\ \text { AXSL1 } & =\text { FABSA PH7 }+\ldots \\ \text { A3IEN } / 1 & =\text { SO ALCYC } \\ \text { AXE } & =\text { FABS PH7 }+\ldots \\ \text { AOEN } / 1 & =\text { EO NFAMDSF } \end{array}$ CXRR preset in PH6 | Destination address shifted left one bit position to place address in bit positions 13 through 31 with byte address in bits 30 and 31 <br> Modified byte count clocked into flip-flops A0-A7 <br> Displacement bits read back into $C$-register. Stored in private memory register during PH3 |
| (Continued) |  |  | Mnemonic: MBS (61) |

Table 3-102. Move Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{aligned} & \text { PH7A } \\ & \text { TIOL } \\ & \text { (Cont.) } \end{aligned}\right.$ | Force a one on LR3I private memory address line to select odd numbered private memory register <br> Set flip-flop PH8 <br> Enable clock T8L | $\begin{aligned} \text { R/NLR3I } / 2= & \text { LR31/2 }=\text { FABSA PH7 } \\ & +\ldots \\ \text { S/PH8 }= & \text { PH7 NBR }+\ldots \\ \text { R/NT8L }= & \text { T8L }=\text { FABSA PH7 }+\ldots \end{aligned}$ |  |
| $\begin{array}{\|l\|l} \text { PH8A } \\ \text { T8L } \end{array}$ | $\begin{aligned} & A 0-A 31 \longrightarrow S 0-S 31 \\ & S 0-S 31 \longrightarrow \text { RW0-RW31 } \end{aligned}$ <br> Generate write-byte signals RWB0-RWB3 <br> Set flip-flop PH9 <br> Enable clock T8L | $\begin{array}{ll} \text { SXA } & =\text { FABOA/2 PH8 }+\ldots \\ \text { RWXS } & =\text { FAB0A } / 2 \text { PH8 }+\ldots \\ \text { RWB0-RWB3 } & =\text { RWXS } \\ \text { S/PH9 } & =\text { PH8 NBR }+\ldots \\ \text { R/NT8L } & =\text { T8L }=\text { FAB0A/2 PH8 } \end{array}$ | Modified destination address and count <br> Destination address and count stored in odd numbered private memory register |
| PH9A <br> T8L | $\mathrm{BO}-\mathrm{B} 31 \longrightarrow \text { S0-S31 }$ <br> Shift left one bit position into A-register with $\mathrm{SI}-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 30$ $\mathrm{SO} \nrightarrow \mathrm{~A} 31$ <br> $\mathrm{NCO}-\mathrm{NC31} \rightarrow$ D0-D31 <br> $1 \rightarrow$ CS31 under conditions specified <br> Generate a memory request for the next instruction <br> Q15-Q31 $\rightarrow$ P15-P31 <br> P15-P31 $\longrightarrow$ LM15-LB31 <br> Set flip-flop PH10 <br> Enable clock T6L |  | Source address <br> Source address shifted left one bit position to place address into bit positions 13 through 31 with byte address in bits 30 and 31 <br> Displacement value inverted into $D$-register to obtain one's complement <br> For two's complement SWI $\Rightarrow$ word mode NSW2 $\Rightarrow$ no memory protection violation <br> Address of next instruction |
|  |  | (Continued) | Mnemonic: MBS (61) |

Table 3-102. Move Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{array}{\|l\|l} \text { PHIOA } \\ \text { T6L } \end{array}$ | A0-A31 + D0-D31 + <br> $\mathrm{CSO}-\mathrm{CS} 31 \rightarrow$ SO-S31 $S 0-S 31 \rightarrow A 0-A 31$ <br> Clear D-register <br> If signals SW1 and SW2 are true, indicating a word transfer and a memory protection violation, ones are forced into flip-flops CSO-CS29 <br> Set flip-flop DRO <br> Set flip-flop IEN <br> Set flip-flop PHII <br> Enable clock T10L |  | Subtraction of displacement value from source address <br> Result $\rightarrow$ A-register <br> Places -4 in CS-register <br> Inhibits transmission of another clock until data release signal is received <br> Enable interrupt |
| $\begin{aligned} & \text { PHIIA } \\ & \text { T10L } \end{aligned}$ | R28-R31 $\longrightarrow$ LR28-LR31 <br> If R31 is not a one, but the R-register is not all zeros $\mathrm{A} 0-\mathrm{A} 31+\mathrm{CSO}-\mathrm{CS} 29 \longrightarrow$ S0-S31 $\text { SO-S31 } \longrightarrow \text { RW0-RW31 }$ <br> Generate write-byte signals RWB0-RWB3 <br> Generate signal ENDE <br> If signal SW2 is true, indicating a memory protection violation, generate signal (S/TRACC4/1) and set TRAP flip-flop <br> If flip-flop INTRAPF is not set, set flip-flop PREI <br> Enable clock T6L | Always occurs unless signal LRXD is true | Address of private memory register <br> Four subtracted from address to correct for increase due to 4-byte transfer. Dregister contains zeros <br> Store source address in even numbered private memory register |
|  |  |  | Mnemonic: MBS (61) |

Table 3-103. Compare Byte String, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PREI | P15-P31 $\rightarrow$ Q15-Q31 <br> Reset A-, B-, and E-registers <br> Generate signal PROTECTDIS <br> $\mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31$ <br> Set flip-flop PHI <br> Enable clock T4RL <br> If bit $C 0$ is a 1 , generate signal FAILL and set flip-flop TRAP <br> Generate signal EXU |  | Disables trapping feature of memory protection |
| PHI <br> T4RL | $\begin{aligned} & \mathrm{Cl} 2-\mathrm{C} 31 \rightarrow \text { D12-D31 } \\ & \mathrm{Cl} 2 \rightarrow \text { D0-D11 } \\ & \text { R28-R31 } \longrightarrow \text { LR28-LR31 } \end{aligned}$ <br> If R28-R31 are not all zeros, clock RRO-RR31 $\rightarrow$ A0-A31 <br> Force a one onto private memory address line LR31 to address odd numbered private memory register <br> Set flip-flop PH2 <br> Enable clock T6RL <br> Set flip-flop $D R Q$ | $\begin{array}{ll} \text { DXC/4 } & =\text { FABS PHI }+\ldots \\ \text { S/LRXR } & =0 X C+\ldots \\ \text { AXRR } & =\text { FABS PHI NRZ }+\ldots \\ \text { R/NLR3I/2 } & =\text { LR3I/2 }=\text { FABS PHI }+\ldots \\ \text { S/PH2 } & =\text { PHI NBR }+\ldots \\ \text { T6RL } & =\text { FABO/1 PHI }+\ldots \\ \text { S/DRQ } & =\text { FABO/1 EXU } \end{array}$ | Displacement value clocked into D-register <br> Sign bit extended to form 32-bit word <br> Contents of register $R$ (contains source address) <br> No function. Does not inhibit transmission of clock |
| PH2 <br> T6RL | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{DO}-\mathrm{D} 31 \rightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \rightarrow \mathrm{BO}-\mathrm{B} 31 \end{aligned}$ | $\begin{array}{ll} \text { SXADD } & =\text { FABO/2 PH2 }+\ldots \\ \text { BXS } & =\text { FABO PH2 }+\ldots \end{array}$ | Adds displacement value to source address <br> Store modified source address in B-register |
| (Continued) |  |  | Mnemonic: CBS (60) |

Table 3-103. Compare Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH2 <br> T6RL (Cont.) | $\text { RR0-RR31 } \rightarrow \text { A0-A31 }$ <br> Force a one on private memory address line LR31 <br> Set flip-flop PH3 <br> Enable clock T10L <br> Set flip-flop DRG | $\begin{array}{ll} \text { AXRR } & =\text { FABO/2 PH } 2+\ldots \\ \text { R/NLR31/2 } & =\text { LR31/2 }=\text { FABO PH2 }+\ldots \\ \text { S/PH3 } & =\text { PH2 NBR }+\ldots \\ \text { S/T10L } & =\text { FABO PH } 2+\ldots \\ \text { S/DRQ } & =\text { FABO } 1 \text { EXU }+\ldots \end{array}$ | Word from odd numbered private memory register (contains count and destination address) <br> For use in PH3 <br> No function. Does not inhibit transmission of clock |
| PH3 <br> T10L | R28-R30 $\longrightarrow$ LR28-LR30 <br> LR31/2 LR31 <br> DO-D31 $\longrightarrow$ SO-S31 <br> SO-S31 $\longrightarrow$ RW0-RW31 <br> Generate write-byte signals RWB0-RWB3 <br> Reset flip-flops CC3 and CC4 <br> Clear D-register <br> Disable memory protection <br> Set flip-flop PH5 <br> Enable clock T8L <br> Set flip-flop DRQ | $\begin{array}{ll} \text { S/LRXR } & =\text { LRXD }+ \text { LRXR } \\ & =\text { FAB0/2 PH3 }+\ldots \\ \text { SXD } & =\text { FABO PH3 }+\ldots \\ \text { RWXS } & \\ \text { RWB0-RWB3 } & =\text { RW }=\text { FABO PH2 }+\ldots \\ \text { R/CC3 } & =\text { FABS PH3 NO7 }+\ldots \\ \text { R/CC4 } & =\text { FABO } / 1 \text { PH3 NO7 }+\ldots \\ \text { DX/1 } & =\text { FABS PH3 }+\ldots \\ \text { PROTECTDIS } & =\text { FABOX }+\ldots \\ \text { S/PH5 } & =\text { BRPH5 }=\text { FAB0/1 PH3 }+\ldots \\ \text { R/NT8L } & =\text { T8L }=\text { FAB0/1 PH3 }+\ldots \\ \text { S/DRQ } & =\text { FAB0/1 EXU }+\ldots \end{array}$ | Address of odd numbered private memory register <br> Displacement gated onto sum bus <br> Store 32-bit displacement value in odd numbered private memory register <br> No function. Does not inhibit transmission of clock |
| $\begin{aligned} & \text { PH5 } \\ & \text { T8L } \end{aligned}$ | Circular shift B-register right two bit positions with $\mathrm{B} 30 \leadsto \mathrm{BO} \text { and } \mathrm{B} 31 \leadsto \mathrm{~B} 1$ <br> Circular shift A-register right two bit positions through adder with $\mathrm{A} 30 \longrightarrow \mathrm{~A} 0$ and $\mathrm{A} 31 \longrightarrow \mathrm{Al}$ | $\begin{array}{ll} \text { BXBR2 } & =\text { FABS PH5 }+\ldots \\ \text { S/B0 } & =\text { B30 BXBR2 }+\ldots \\ \text { S/B1 } & =\text { B31 BXBR2 }+\ldots \\ \text { AXPRR2 } & =\text { FABS PH5 }+\ldots \\ \text { S/A0 } & =\text { A30 ARCYC AXPRR2 }+\ldots \end{array}$ | Modified source address shifted right to place byte address bits in positions BO and Bl and address in B15 through B31 <br> Destination address circular shifted right to place byte address in positions A0 and AI |
| (Continued) |  |  | Mnemonic: CBS (60) |

Table 3-103. Compare Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH5 T8L (Cont.) | $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ $\mathrm{S} 0-\mathrm{S} 7 \rightarrow \mathrm{E} 0-\mathrm{E} 7$ <br> Reset flip-flop SW2 to use for memory protection violation <br> Set flip-flop PHA if count is all 0 's or if signal INT is true <br> If PHA is true, branch to PH6A; otherwise, sequence to PH 6 <br> Enable clock T8L <br> If flip-flop PHA is not set, set flip-flop DRQ | $\begin{aligned} \text { S/A1 } & =\text { A31 ARCYC AXPRR2 }+\ldots \\ \text { ARCYC }= & \text { ALCYC NANLZ } \\ \text { ALCYC }= & \text { NFAMDSF }+\ldots \\ \text { SXA }= & \text { FAB0 } / 2 \mathrm{PH} 5+\ldots \\ \text { EXS } & \text { FAB0 } / 2 \mathrm{PH} 5+\ldots \\ \text { R/SW2 }= & \text { FABS PH5 }+\ldots \\ \text { S/PHA }= & \text { FABS PH5 A0007Z } \\ & + \text { FABS PH5 INT }+\ldots \\ \text { S/PH6 }= & \text { PH5 NBR }+\ldots \\ \text { R/NT8L }= & \text { FAB0 PH5 }+\ldots \\ \text { S/DRQ }= & \text { FAB0/1 EXU }+\ldots \end{aligned}$ | Count clocked into Eregister <br> No function. Does not inhibit transmission of clock |
| $\begin{aligned} & \text { PH6 } \\ & \text { T } 1 \text { L } \end{aligned}$ | $\begin{aligned} & \mathrm{B} 0-\mathrm{B} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{SO} \rightarrow \mathrm{P} 32 \mathrm{~S} 1 \rightarrow \mathrm{P} 33 \\ & \mathrm{~S} 15-\mathrm{S} 31 \longrightarrow \mathrm{P} 15-\mathrm{P} 31 \\ & \mathrm{P} 15-\mathrm{P} 31 \longrightarrow \text { LM15-LB31 } \end{aligned}$ <br> Generate memory request for first byte <br> Set flip-flop DRQ <br> Set flip-flop PH7 <br> Enable clock T6L | $\begin{array}{ll} \text { SXB } & =\text { FABS PH6 }+\ldots \\ \text { S/P32 } & =\text { SO PXS } / 1+\ldots \\ \text { S/P33 } & =\text { SI PXS/1 }+\ldots \\ \text { PXS } & =\text { FAB0/2 PH6 }+\ldots \\ \text { MRQ } & =\text { FABS PH6 N07 }+\ldots \\ \text { S/DRQ }= & \text { FAB0/1 EXU }+\ldots \\ & \\ \text { S/PH7 }= & \text { PH6 NBR }+\ldots \\ \text { T6L } & = \\ & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \end{array}$ | Modified source address gated onto sum bus <br> Byte address clocked into flip-flops P32 and P33 <br> Modified source address clocked into P-register <br> Modified source address gated onto core memory address lines <br> Memory request for first byte <br> Inhibits transmission of another clock until data release signal is received |
| (Continued) |  |  | Mnemonic: CBS (60) |

Table 3-103. Compare Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH7 } \\ & \text { T6L } \end{aligned}$ | $\text { MBO-MB31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ <br> Byte selected by bits P32 and P33 are clocked into flipflop D24-D31 <br> Add one to byte selection bits for selection of next byte <br> If source address pointed to an address located in protected memory, set flip-flop SW2 <br> Set flip-flop PH8 <br> Enable clock T4L <br> Set flip-flop DRQ | $\begin{aligned} \text { CXMB } & =\text { DGC } \\ \text { DXCBP } & =\text { FABS PH7 NSWI }+\ldots \\ \text { PCTP1 } & =\text { FABS PH7 NRZ }+\ldots \\ \text { PA33 } & =\text { FABS PH7 NRZ }+\ldots \\ \text { S/SW2 } & =\text { FAB0/2 PH7 PROTECTD }+\ldots \\ S / P H 8 & =\text { PH7 NBR }+\ldots \\ S / T 4 L & =F A B 0 / 1 \text { PH7 }+\ldots \\ S / D R Q ~ & =\text { FAB0/1 EXU }+\ldots \end{aligned}$ | First data word gated into C-register <br> See equations in PH7 of Move Byte String <br> No function. Does not inhibit transmission of next clock |
| PH T4L | $\begin{aligned} & \mathrm{P} 15-\mathrm{P} 31 \longrightarrow \mathrm{~S} \longrightarrow \mathrm{~S} 15-\mathrm{S} 31, \\ & \mathrm{P} 32 \longrightarrow \mathrm{~S} 33 \\ & \mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{~B} 0-\mathrm{B} 31 \end{aligned}$ <br> Set flip-flop PH9 <br> Enable clock T4L <br> Set flip-flop DRQ | $\begin{aligned} S X P & =\mathrm{FABS} \mathrm{PH} 8+\ldots \\ B X S & =\mathrm{FABS} \mathrm{PH} 8+\ldots \\ S / P H 9 & =\text { PH8 NBR }+\ldots \\ S / T 4 L & =\mathrm{FABO} / 1 \mathrm{PH} 8+\ldots \\ S / D R Q & =\mathrm{FABO} / 1 \mathrm{EXU}+\ldots \end{aligned}$ | Modified source address and byte selection bits gated onto sum bus <br> Modified source address stored in B -register to allow destination address in P register <br> No function. Does not inhibit transmission of next clock |
| $\begin{aligned} & \text { PH9 } \\ & \text { T4L } \end{aligned}$ | $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ <br> S15-S31 P15-P31 <br> P15-P31 $\longrightarrow$ LM15-LB31 <br> Clear A-register | $\begin{aligned} & \mathrm{SXA}=\mathrm{FABO} / 1 \mathrm{PH} 9+\ldots \\ & \mathrm{PXS} / 1=\mathrm{FABO} / 1 \mathrm{PH} 9+\ldots \\ & \mathrm{AX} / 1=\text { FABS PH9 }+\ldots \end{aligned}$ | Address of destination byte clocked into P -register <br> Address of destination byte gated onto core memory address lines |
|  |  | (Continued) | Mnemonic: CBS (60) |

Table 3-103. Compare Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH9 <br> T4L <br> (Cont.) | Generate memory request for byte located in destination address location <br> Generate signal (S/NGX) <br> Force ones into CS-register <br> Force a one into K31 <br> Set flip-flop PHIO <br> Enable clock T6L <br> Set flip-flop DRQ | $\begin{aligned} M R Q= & \text { FABS PH9 NSW2 }+\ldots \\ (S / N G X)= & \text { FABS PH9 NO7 }+\ldots \\ C S X 1 / 1= & (S / N G X)+\ldots \\ K 31 & =(S / N G X)+\ldots \\ S / P H 10= & \text { PH9 NBR }+\ldots \\ T 6 L & \\ & \text { NTIL NT4L NT8L NT10L } \\ & \text { NRESET } \\ S / D R Q= & \text { FABO/I EXU }+\ldots \end{aligned}$ | For 2's complement in PHIO <br> Inhibits transmission of another clock until data release signal is received |
| PHIO <br> T6L | Gate source destination byte from D-register into adder with ones in CS-register and one in K31 for two's complement operation <br> Gate two's complement of source byte onto sum bus <br> Clock contents of sum bus into flip-flops A0-A31 <br> When byte from destination address is available, $\mathrm{MBO}-\mathrm{MB31} \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ <br> Destination byte selected by bits P32 and P33 clocked into flip-flops D24-D31 <br> If address of destination byte pointed to a protected area of memory, set flip-flop SW2 <br> Set flip-flop PHII <br> Enable clock T6L |  | Generate two's complement of source byte for subtraction from destination byte during PHII <br> Destination byte gated into C-register, and then selected byte clocked into flip-flops D24-D31 <br> See equations in PH7 of Move Byte String |

Table 3-103. Compare Byte String, Phase Sequence (Cont.)


Table 3-103. Compare Byte String, Phase Sequence (Cont.)


Table 3-103. Compare Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH7A } \\ & \text { T10L } \\ & \text { (Cont.) } \end{aligned}$ | $\text { RRO-RR31 } \longrightarrow \mathrm{CO}-\mathrm{C} 31$ <br> Force a one on OR31 private memory address line to select odd numbered private memory register <br> Set flip-flop PH8 <br> Enable clock T8L $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31$ $\text { S0-S31 } \longrightarrow \text { RW0-RW31 }$ <br> Generate write-byte signals RWB0-RWB3 <br> Set flip-flop PH9 <br> Enable clock T8L | $\begin{array}{ll} \text { CXRR preset in PH6A } \\ \text { R/NLR31/2 } & =\text { LR31/2 }: \text { FABSA PH7 }+\ldots \\ & =\text { PH7 NBR }+\ldots \\ \text { S/PH8 } & =\text { T8L }=: \text { FABSA PH7 }+\ldots \\ \text { R/NT8L } & \\ \text { SXA } & =\text { FAB0A/2 PH8 }+\ldots \\ \text { RWXS } & =\text { RWXS } \\ \text { RWB0-RWB3 } & =\text { PH8 }+\ldots \\ \text { S/PH9 } & =\text { PH8 NBR }+\ldots \\ \text { R/NT8L } & =\text { T8L }=\text { FAB0A/2 PH8 } \end{array}$ | Displacement bits read back into C-register. Stored in private memory register during PH3 <br> Modified destination address and count <br> Destination address and count stored in odd numbered private memory register |
| PH9A <br> T8L | $\text { BO-B31 } \longrightarrow \text { S0-S31 }$ <br> Shift left one bit position into A-register with Sl -S31 $\ldots$ $\mathrm{A} 0-\mathrm{A} 30 \mathrm{SO} \longrightarrow \mathrm{A} 31$ <br> $\mathrm{NCO}-\mathrm{NC} 31 \rightarrow$ DO-D31 <br> $1 \longrightarrow$ CS31 under specified conditions <br> Generate a memory request for next instruction <br> Q15-Q31 $\rightarrow$ P15-P31 |  | Source address <br> Source address shifted left one bit position to place address into bit positions 13 through 31 with byte address in bits 30 and 31 <br> Displacement value inverted into D-register to obtain one's complement <br> For two's complement. NSW2 $\Rightarrow$ no memory protection violation CC3 $\Rightarrow$ source byte $>$ destination byte CC4 $\Rightarrow$ source byte < destination byte <br> Address of next instruction |
| (Continued) |  |  | Mnemonic: CBS (60) |

Table 3-103. Compare Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | $\text { P15-P31 } \longrightarrow \text { LM15-LB31 }$ <br> Set flip-flop PH10 <br> Enable clock T6L | $\begin{aligned} \text { S/PHIO } & =\text { PH9 NBR }+\ldots \\ \text { T6L } & = \\ & \\ & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \end{aligned}$ |  |
| PH10A <br> T6L | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31+ \\ & \mathrm{CS} 0-\mathrm{CS} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 31 \end{aligned}$ <br> Clear D-register <br> Set flip-flop DRQ <br> Set flip-flop IEN <br> Set flip-flop PHII <br> Enable clock T10L |  | Subtraction of displacement value from source address $\text { Result } \xrightarrow{\longrightarrow} \text { A-register }$ <br> Inhibits transmission of another clock until data release signal is received |
| PHIIA T10L | $\text { R28-R31 } \longrightarrow \text { LR28-LR31 }$ <br> If R31 is not a one, but the R-register is not all zeros, $\mathrm{A} 0-\mathrm{A} 31+\mathrm{CSO}-\mathrm{CS31} \longrightarrow$ S0-S31 $\text { S0-S31 } \longrightarrow \text { RW0-RW31 }$ <br> Generate write byte signals RWB0-RWB3 <br> Generate signal ENDE <br> If signal SW2 is true, indicating a memory protection violation, generate signal ( $5 /$ TRACC4/1) and set TRP flip-flop <br> If flip-flop INTRAPF is not set, set flip-flop PREI <br> Enable clock T6L | Always occurs unless signal LRXD is true <br> RWB0-RWB3 $=$ RWXS <br> ENDE $\quad=$ FABSA PHII N07 CC3 <br> + FAB0A/1 PHIl N07 CC4 <br> + FABOA PHII EZ <br> $(S / T R A C C 4 / 1)=$ FABOA PHII SW2 NTRAP + ... <br> $S /$ TRAP $\quad=(S / T R A C C 4 / 1)+\ldots$ <br> S/PREI = ENDE (NHALT + FUEXU) N(S/INTRAPF) <br> T6L $\quad=$ NTIL NT4L NT8L NTIOL NRESET | Address of private memory register <br> Source address gated onto sum bus <br> Store source address in even numbered private memory register <br> If CC3 or CC4 has been set or E-register contains zeros |
|  |  |  | Mnemonic: CBS (60) |

The translation table consists of up to 256 consecutive byte locations. The first byte location of the table is pointed by the displacement in the TBS instruction word plus the source address contained in the even numbered private memory register.

A source byte is the byte in the location pointed to by the 19 low order bits of the sum of the following:
a. The displacement in bit positions 12 through 31 of the TBS instruction word
b. The current contents of bit positions 13 through 31 of the even numbered private memory register
c. The numeric value of the current destination byte

If the TBS instruction is indirectly addressed, it is treated as a nonexistent instruction, and the computer traps to location $X^{\prime} 40^{\prime}$ at the time of opcode decoding.

The TBS instruction word is clocked into the D-register at the clock following the generation of signal ENDE. The opcode portion is clocked into the O-register for decoding, the R-field is clocked into the R-register, and the address contained in the P -register is increased by one. Indirect addressing is indicated if bit C 0 is a one. Signal FAILL is generated, which causes the computer to trap to location X'40'.

During PREI, signal PROTECTDIS is generated to inhibit trapping if an attempt is made to read out from or store into a protected area of core memory. At the PREI clock, the A-, B-, and E-registers are cleared, and the address of the next instruction contained in the $P$-register is clocked into the $Q$-register. Flip-flop PRE2 is set, and clock T4RL is enabled.

At the PRE2 clock, flip-flop NLR31/2 is reset, thereby forcing a one on the LR31 address line. Signal (S/PH1/1) is generated, and flip-flops PHI and EXU are set. Clock T4RL is enabled.

The displacement value contained in bits C12 through C31 is clocked into the D-register at the PHI clock. Flip-flops D0 through D11 are cleared. When the data word from the odd numbered private memory register is available on the RR lines, it is read into the A-register at the PHI clock. Flip-flop PH2 is set, and clock T6RL is enabled.

The destination address and the count are gated from the A-register onto the sum bus during PH2. The count is read from bits S0 through S7 into the E-register at the PH2 clock, and the entire word, bits S0 through S31, is clocked into the $B$-register. When the data word from the even numbered private memory register is available on the RR lines, it is read into the A-register at the PH2 clock. A one is forced on LR31 address line to select odd numbered private memory register. If the R-field of the instruction word is all zeros, ones are forced into flip-flops CS0 through CS7.

Flip-flop DRQ is set, but transmission of the next clock is not inhibited, because a memory request has not been generated. The instruction sequences to PH 3 , and clock T 10 L is enabled.

During PH3, the source address contained in the A-register, the displacement value contained in the D-register, and the contents of the CS-register (all zeros if the R-field is nonzero) are gated into the adder. An addition operation is performed, and the result is gated onto the sum bus. If the R-field is all zeros, the result of the addition places the displacement value in bit positions 12 through 31 and the ones in bit positions 0 through 7. If the $R$-field is nonzero, the displacement value is added to the source address, and the result is gated onto the sum bus.

The modified source address is gated from the sum bus onto private memory data lines RW0 through RW31. Write-byte signals RWBO through RWB3 are generated, and the source address is stored in the odd numbered private memory register.

The address contained in the $B$-register has the destination byte address in bits 30 and 31 and the destination word address in bit positions 13 through 29. At the PH3 clock, the contents of the B-register are circular shifted two bit positions to the right to place the destination address in bit positions 15 through 31 and the byte address in bit positions 0 and 1. First pass flip-flop SW1 is set, indicating the first pass through the translation sequence. Protect fail flip-flop SW2 is reset. Because the memory protection trapping feature is disabled, flip-flop SW2 is used to indicate a memory protection violation. Flip-flop DRQ is set, but clock transmission is not inhibited because a memory request has not been generated. The instruction branches to PH5, and clock T8L is enabled.

If first pass flip-flop SW1 is set during PH5, the destination address is gated from the B-register onto the sum bus and is then clocked into the P -register at the PH5 clock. S15 through S31 are clocked into flip-flops P15 through P31 and byte address bits SO and SI are clocked into flip-flops P32 and P33, respectively. First pass flip-flop SW1 is then reset.

A memory request is generated for the first byte from the destination address that is contained in the P -register if the first pass flip-flop SW1 is set, or for the next byte if the first pass is not set. If the address is in a protected area of memory and if signal PROTECTD is received, protect fail flip-flop SW2 is set, flip-flop PHA is set, and the instruction sequences to PH9A without performing any additional transfers.

If a memory protection violation did not occur (NSW2 + NPROTECTD), a one is added to the byte address in bits P32 and P33 to select the next byte. A one is forced on private memory address line LR31 to select the odd numbered private memory register where the source address is stored. Clock T8L is enabled, and the instruction sequences to PH6.

If this is not the first pass through PH5 (that is, if the instruc tion has proceeded through PH10 and has returned to PH 5 ), the byte read in from the source address during PH 10 is gated into the adder and is upward aligned into bit positions 0 through 7,8 through 15,16 through 23 , and 24 through 31 on the sum bus. The byte selected by bits P32 and P33 is gated onto the appropriate MB data lines. Signal MWB is generated, and the byte is stored in the addressed core memory destination address location. A one is added to the byte address in bit positions P32 and P33 to select the next byte. A one is forced onto private memory address line LR31 to select the odd numbered private memory register. A memory request is generated for the next byte; clock T8L is enabled; and the instruction sequences to PH6. When the count in the E-register finally becomes all zeros, flip-flop PHA is set, and the instruction branches to PH9A.

When the word pointed by the destination address is available on the MB data lines, signal CXMB gates the word into the C-register. At the PH6 clock, the byte selected by bits P32 and P33 is clocked into flip-flops D24 through D31. The destination address is gated from the P -register into the sum bus, and byte address bits P32 and P33 are gated into positions S0 and S1. At the PH6 clock, the entire destination address is clocked into the B-register. When the modified source address is on the RR lines from the odd numbered private memory register, signal AXRR is generated which clocks the address into the A-register at the PH6 clock. The instruction sequences to PH 7 , and clock T6L is enabled.

The modified source address contained in the A-register and the selected byte contained in the D-register from the destination address are gated into the adder during PH 7 and an addition operation is performed. The result is gated onto the sum bus and is clocked from the sum bus into the A-register at the PH7 clock. The D-register is cleared, clock T4L is enabled, and the instruction sequences to PH 8 .

The modified source address is gated from the A-register into the adder during PH 8 and is circular shifted two digit positions to the right. Bit A30 is clocked into flip-flop A0, and bit A31 is clocked into flip-flop A1. This places the source address in bit positions A15 through A31 and the byte selection bits in position AO and AI. Clock T4L is enabled, and the instruction sequences to PH 9.

During PH9 the modified source address is gated from the A-register onto the sum bus and is then clocked into the P -register. The byte address bits SO and Sl are clocked into flip-flops P32 and P33. A memory request is generated for the byte pointed to by the source address. The source address is gated onto the LM and LB address lines to core memory. The byte count in the E-register is decreased by one count. Clock T6L is enabled, and the instruction sequences to PHIO .

When the data word is available on the $M B$ lines from the source address, signal CXMB is generated to gate the word into the C-register. The byte selected by bits P32 and P33 is clocked intoflip-flops D24 through D31 at the PH10 clock.

The destination address contained in the B-register is gated onto the sum bus and, at the PH 10 clock, is clocked into the P -register. Byte selection bits S0 and S1 are clocked into flip-flops P32 and P33, respectively.

If a memory protection violation occurred during the source addressing, flip-flop SW2 is set and no further transfers are made. If flip-flop SW2 is not set, a memory request is generated to store the first byte in the location pointed to by the destination address. The A-register is cleared at the PH10 clock, thereby clearing the source address used for the byte. Flip-flop NPRX is set, forcing ones into the CSregister for use during the byte upward alignment in PH5. Flip-flop PH5 is set to return the instruction to PH5, and clock T8L is enabled.

Sequences PH5 through PH10 and back to PH 5 are repeated until all of the destination bytes have been replaced with bytes from the translation table (that is, E-register contains all zeros). A memory protection violation (that is, PROTECTD is received or flip-flop SW2 is set) or an interrupt occurs. Flip-flop PHA is set, clock T8L is enabled, and the instruction branches to PH9A.

During PH9A, the destination address is gated from the P register onto the sum bus. Bits P 32 and P 33 are gated onto bit positions S 0 and S 1 . The contents of the sum bus are then circular shifted one bit position to the left and are clocked into the A-register which places byte address bit S0 in flip-flop A31. A memory request is generated for the next instruction. When memory request $M R Q / 1$ is generated, the address of the next instruction is clocked from the Qregister into the $P$-register and is then gated onto the LM and $L B$ address lines.

If a memory protection violation occurs, one is added to the count in the E-register to leave the count pointing to the last byte transferred. Clock T6L is enabled, and the instruction sequences to PHIOA . During PHIOA, the destination address contained in the A-register is gated onto the sum bus, is circular shifted one bit position to the left and is clocked back into the A-register. The destination address is then contained in bit positions A13 through A29, and the byte selection bits are contained in A30 and A31. At the same clock, the count from the E-register is clocked into flip-flops A0 through A7. The modified destination address and byte count are then ready for storing in private memory. A one is forced on address line LR31 to select the odd numbered private memory register. Flip-flop DRQ is set which inhibits transmission of another clock until the data release signal is received. Interrupt enable flip-flop IEN is set, clock T8L is enabled, and the instruction proceeds to $\mathrm{PHIl} A$.

The modified destination address and byte count from the A-register are gated onto the sum bus during PHIIA and then onto the data lines RW0 through RW31. Write-byte signals RWB0 through RWB3 are generated, and the data word is stored in the odd numbered private memory register.

If flip-flop SW2 is set, which indicates a memory protection violation, signal (S/TRACC4/1) is generated. Flip-flop TRAP is set, which branches the instruction into the trap sequence. If flip-flop SW2 is not set and if the byte count in the E-register is all zeros, signal ENDE is generated, flip-flop PREI is set for the next instruction, and clock T6L is enabled.

A sequence chart of the Translate Byte String instruction is given in table 3-104.

## 3-232 Translate and Test Byte String (TTBS 40)

The TTBS instruction compares a mask contained in bit positions 0 through 7 of the private memory register addressed in the R-field with source bytes contained in a byte translation table. The destination byte string begins with the byte location pointed by the destination address in an odd numbered private memory register. The destination byte string is examined (without being changed) until a source byte is found that contains a one in any location comparing with the mask. When a comparison is found, the mask is replaced with the logical AND result of the source byte and the mask. Condition code flip-flop CC4 is set to a one.

If the instruction terminates because of a comparison match, the byte count is one greater than the number of bytes remaining to be compared, and the destination address indicates the location of the destination byte that caused the termination. If no comparison match is found, after the number of bytes that were indicated in the count have been compared, the instruction terminates with condition code flip-flop CC4 reset to zero. In no case is the source byte string changed.

If the TTBS instruction is indirectly addressed, it is treated as a nonexistent instruction. The computer aborts execution of the instruction at the time of opcode decoding and traps to location $X^{\prime} 40$ '.

Operation during the preparation phases and PHI through PH9 is the same as the operation for these phrases described in the Translate Byte String instruction.

If the R-field of the instruction word is all zeros, ones are forced into flip-flops CS0 through CS7 during PH2. This byte is added to the word which contains the displacement value and forms a mask for later use.

The word from the location pointed by the source address is gated into the C -register during PHIO . At this clock, the byte selected by bits P32 and P33 is clocked into flip-flops D24 through D31. The destination address is gated from the B -register onto the sum bus. The destination address, bits S 15 through S 31 , is clocked into the P -register of the PH1O clock, and the byte selection bits SO and S1 are clocked into flip-flops P32 and P33. The A-register is cleared, thereby clearing the source address and mask. If
a memory protection violation occurs (signal PROTECTD received), flip-flop SW2 is set and no further translation of bytes is performed. Flip-flop NPRX is set at the PH1O clock. This forces one's into the CS-register for use during upward alignment in PHII. Signal (S/CXS) is generated for use during PHIl. Since the source address and mask were cleared from the A-register, a one is forced on the LR31 address line to read them back from the odd numbered private memory register. Flip-flop PHIl is set for the next phase, and clock T10L is enabled.

The source byte contained in bits D24 through D31 is gated into the adder during PHIl and is upward aligned into bit positions 0 through 7 of the sum bus. The byte is then gated from the sum bus into bit positions 0 through 7 of the $C$ register and is clocked into flip-flops D0 through D7 of the PH11 clock. Since the mask was cleared from the A-register during PH10, the data word containing the mask is read out of the private memory register and is clocked into the Aregister at the PH1l clock. Flip-flop NPRX is set to force ones into the CS-register for use during the logical AND operation in PHI2. Clock T4RL is enabled, and the instruction sequences to PH 12 .

The mask contained in the A-register and the source byte contained in the D -register are gated into the adder during PH12, and a logical AND operation is performed. This result is gated onto the sum bus and is clocked into the Aregister at the PH12 clock. If no ones are compared in the mask and the source byte, the result in the A-register is all zeros. If any ones are compared, the result in the A-register is the byte formed as the result of the logical AND. Clock T8L is enabled, and the instruction sequences to PHI 3 .

Flip-flop CC4 is set if any ones are contained in the Aregister which indicates a comparison. No further byte comparisons are made. If a comparison has been found, and bits R28 through R31 are not all zeros, and if bit R31 is a zero, the byte stored in the A-register is gated onto the sum bus and then onto data lines RW0 through RW7. Writebyte signal RWBO is generated, and the byte is stored in the even numbered private memory register in place of the mask.

Clock T8L is enabled, and the instruction branches to PH5. Phases PH5 through PH13 are repeated until a byte comparison is made (that is, flip-flop CC4 is set), the total number of bytes have been compared (signal EZ is true), a memory violation occurs (flip-flop SW2 is set), or an interrupt occurs (INT is true). Flip-flop PHA is then set and the instruction branches to PH9A.

Operation during PH9A through PHIIA is the same as the operation for Translate Byte instruction, except that during PHIlA flip-flop CC4 is reset if the count in the E-register is all zeros, and that signal ENDE is generated if flip-flop CC4 is set or if the count in the E-register is all zeros.

A sequence chart of the Translate and Test Byte String instruction is given in table 3-105.

Table 3-104. Trans!ate Byte String, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{array}{\|l} \text { PRE } 1 \\ \text { T6L } \end{array}$ | Generate signal PROTECTDIS <br> Clear $A-, B-$, and $E$-registers $\text { P15-P31 } \longrightarrow \text { Q15-Q31 }$ <br> Set flip-flop PRE2 <br> Enable clock T4RL | $\begin{array}{\|ll} \text { PROTECTDIS }= & \text { FABO }+\ldots \\ \text { AX } & =\text { PREI }+\ldots \\ \text { BX } & =\text { PREI NINTRAPF }+\ldots \\ \text { EX } & =\text { PREI }+\ldots \\ \text { QXP } & =\text { PREI NANLZ }+\ldots \\ \text { S/PRE2 }= & \text { NPREIM PREI N(SNTRAPF }) \\ & +\ldots \\ \text { T4RL } & = \\ & \text { PREP }+\ldots \end{array}$ | Disables trapping function for memory protection <br> Next instruction address |
| PRE2 <br> T4RL | Force a one on LR3I <br> Set flip-flop EXU <br> Set flip-flop PHI <br> Enable clock T4RL | $\begin{aligned} & \mathrm{R} / \mathrm{NLR31} / 2= \text { LR31/2 }=\text { FATR (PRE2 NIA) } \\ &+\ldots \\ & \mathrm{S} / \mathrm{EXU}=(\mathrm{S} / \mathrm{PH} / / 1) \mathrm{NCLEAR}+\ldots \\ & \mathrm{S} / \mathrm{PHI}=(\mathrm{S} / \mathrm{PHI} / 1) \mathrm{NCLEAR} \mathrm{NBR} \\ &+\cdots \\ &(\mathrm{S} / \mathrm{PHI} / 1)= \text { NPREDO PRE2 NIA }+\ldots \\ & \mathrm{T} 4 R L= \\ &= \text { PREP }+\ldots \end{aligned}$ | Selects odd numbered private memory register |
| PHI <br> T4RL | $\begin{aligned} & C 12-C 31 \xrightarrow{\longrightarrow} \text { D12-D31, } \\ & 0 \xrightarrow{\longrightarrow} 0-D 11 \\ & R R 0-R R 31 \longrightarrow A 0-A 31 \end{aligned}$ <br> Set flip-flop PH2 <br> Enable clock T6RL | DXC/3 $=$ FATR PHI $+\ldots$ <br> AXRR $=$ FATR PHI $+\ldots$ <br> S/PH2 $=$ PHI NBR $+\ldots$ <br> TGRL $=$ FABO/ $1 \mathrm{PHI}+\ldots$ | Displacement value <br> Destination address and count |
| $\begin{array}{\|l\|l} \text { PH2 } \\ \text { T6RL } \end{array}$ | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{SO}-\mathrm{S} 7 \longrightarrow \mathrm{E} 0-\mathrm{E} 7 \\ & \mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{BO}-\mathrm{B} 31 \end{aligned}$ | SXA $=$ FATR PH2 $+\ldots$ <br> EXS $=$ FATR PH $2+\ldots$ <br> BXS $=$ FABO PH $2+\ldots$ | Byte count <br> Destination address |
|  |  | (Continued) | Mnemonic: TBS (41) |

Table 3-104. Translate Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH2 <br> T6RL (Cont.) | $\text { RR0-RR31 } \rightarrow \text { A0-A31 }$ <br> Force a one on LR31 address line <br> Set flip-flop DRQ <br> Set flip-flop PH3 <br> Enable clock T1OL | $\begin{aligned} \text { AXRR }= & \text { FATR PH2 NRZ }+\ldots \\ \text { R/NLR31/2 }= & \text { LR31/2 }=\text { FABO PH2 } \\ & +\ldots \\ \text { S/DRQ }= & \text { FABO } / 1 \mathrm{EXU}+\ldots \\ \mathrm{S} / \mathrm{PH} 3= & \mathrm{PH} 2 \mathrm{NBR}+\ldots \\ \mathrm{R} / \mathrm{NTIOL}= & \mathrm{T} 10 \mathrm{~L}=\text { FAB0 PH } 2+\ldots \end{aligned}$ | Source address <br> Selects odd numbered private memory register <br> No function. Memory request has not been made |
| $\begin{aligned} & \text { PH3 } \\ & \text { T10L } \end{aligned}$ | $\begin{aligned} & \text { A0-A31 + D0-D31 + } \\ & \text { CS0-CS31 } \longrightarrow \text { S0-S31 } \\ & \text { S0-S31 } \longrightarrow \text { RW0-RW31 } \end{aligned}$ <br> Generate write-byte signals RWB0-RWB3 <br> Circular shift $B$-register right two bit positions <br> If first translation, set flipflop SW1 <br> Disable memory protection <br> Set flip-flop $D R Q$ <br> Set flip-flop PH5 <br> Enable clock T8L | $\begin{aligned} \text { SXADD } & =\text { FATR PH3 }+\ldots \\ \text { RWXS } & =\text { FABO PH3 }+\ldots \\ \text { RWB0-RWB3 }= & \text { RWXS } \\ = & \text { FATR PH3 }+\ldots \\ \text { BXBR2 } & \\ \text { S/SWI } & \text { FATR PH3 }+\ldots \\ \text { PROTECTDIS }= & \text { FABOX }+\ldots \\ \text { S/DRQ }= & \text { FAB0/1 EXU }+\ldots \\ \text { S/PH5 }= & \text { BRPH5 }=\text { FAB0/1 PH3 } \\ & +\ldots \\ \text { R/NT8L }= & \text { T8L }=\text { FAB0/1 PH3 }+\ldots \end{aligned}$ | Source address plus displacement value <br> Modified address <br> $\longrightarrow$ R-register <br> Store modified source address in odd numbered private memory register <br> Places destination address in bit positions 15 through 31 and byte selection bits in positions 0 and 1 <br> First pass <br> No function. Memory request has not been made |
| $\begin{aligned} & \text { PH5 } \\ & \text { T8L } \end{aligned}$ | If first pass (SWI set), BO-B31 $\longrightarrow$ SO-S31 <br> S15-S31 $\rightarrow$ P15-P31 <br> $\mathrm{SO} \nrightarrow \mathrm{P} 32, \mathrm{SI} \not \mathrm{P} 33$ <br> Reset flip-flop SW1 <br> Generate memory request for byte | SXB $=$ FATR5 SW $1+\ldots$ <br> PXS $/ 1$ $=$ FATR5 SW $1+\ldots$ <br> PXS $/ 1$ $=$ FATR5 SW $1+\ldots$ <br> R/SW 1 $=$ FATR PH5 $+\ldots$ <br> MRQ $=$ FATR5 NFATRFINISH $+\ldots$ | Destination address <br> Byte selection bits |
| (Continued) |  |  | Mnemonic: TBS (41) |

Table 3-104. Translate Byte String, Phase Sequence (Cont.)


Table 3-104. Translate Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH6 <br> T8L | $\begin{aligned} & \text { MBO-MB31 C0-C31 } \\ & \text { Byte selected by P32 and } \\ & \text { P33 } \longrightarrow \text { D24-D31 } \\ & \text { P15-P31 S15-S31, } \\ & \text { P32 S1 } \\ & \text { S0-S31 P33 } \longrightarrow \text { B0-B31 } \\ & \text { RR0-RR31 } \longrightarrow \text { A0-A31 } \end{aligned}$ <br> Set flip-flop PH7 <br> Enable clock T6L <br> Set flip-flop DRQ | CXMB $=$ DGC <br> DXCBP $=$ FATR PH6 $+\ldots$ <br> SXP $=$ FATR PH6 $+\ldots$ <br> BXS $=$ FATR PH6 $+\ldots$ <br> AXRR $=$ FATR PH6 $+\ldots$ <br> S/PH7 $=$ PH6 NBR $+\ldots$ <br> T6L $=$ NTIL NT4L NT8L NTIOL <br>  NRESET <br> S/DRQ $=$ FABO/I EXU $+\ldots$ | Word from destination address <br> Byte from destination address downward aligned into Dregister. See equations in PH7 of Move Byte String <br> Destination address stored in B-register <br> Modified source address clocked into A-register from private memory <br> No function. No memory request made |
| $\begin{aligned} & \mathrm{PH} 7 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \xrightarrow{A 0-A 31+D 0-D 31} \mathrm{SO-S31} \\ & S 0-S 31 \rightarrow A 0-A 31 \end{aligned}$ <br> Clear D-register <br> Set flip-flop PH8 <br> Enable clock T4L <br> Set flip-flop DRQ | $\begin{array}{ll} \text { SXADD } & =\text { FATR PH7 }+\ldots \\ \text { AXS } & =\text { FATR PH7 }+\ldots \\ \text { DX/1 } & =\text { FATR PH7 }+\ldots \\ \text { S/PH8 } & =\text { PH7 NBR }+\ldots \\ \text { R/NT4L } & =\text { S/T4L }=\text { FAB0/1 PH7 }+\ldots \\ \text { S/DRQ } & =\text { FABO/1 EXU }+\ldots \end{array}$ | Source address and byte added <br> Result $\rightarrow$ A-register <br> No function |
| $\begin{array}{\|l\|l\|} \text { PH8 } \\ \text { T4L } \end{array}$ | $\text { A0-A31 } \longrightarrow P R 0-P R 31$ <br> Circular shift right two digit places with $\mathrm{A} 30 \longrightarrow \mathrm{~A} 0$, and $\mathrm{A} 31 \longrightarrow \mathrm{Al}$ | $\begin{aligned} \text { AXPRR2 } & =\text { FATR PH8 }+\ldots \\ \text { AOEN } / 2 & =\text { A30 ARCYC } \\ \text { AlEN } / 2 & =\text { A31 ARCYC } \\ \text { ARCYC } & =\text { ALCYC }=\text { NFAMDSF } \end{aligned}$ | Address shifted into bit positions 15 through 31 and byte selection bits into positions 0 and 1 |
|  |  | (Continued) | Mnemonic: TBS (41) |

Table 3-104. Translate Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH8 <br> T4L <br> (Cont.) | Set flip-flop PH9 <br> Enable clock T4L <br> Set flip-flop DRQ | $\begin{aligned} & \mathrm{S} / \mathrm{PH} 9=\mathrm{PH} 8 \mathrm{NBR}+\ldots \\ & \mathrm{R} / \text { NT4L }=\mathrm{S} / \mathrm{T} 4 \mathrm{~L}=\mathrm{FABO} / 1 \mathrm{PH} 8+\ldots \\ & \text { S/DRQ }=\mathrm{FABO} / 1 \mathrm{EXU}+\ldots \end{aligned}$ | No function |
| $\begin{aligned} & \text { PH9 } \\ & \text { T4L } \end{aligned}$ | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 15-\mathrm{S} 31 \rightarrow \mathrm{P} 15-\mathrm{P} 31, \\ & \mathrm{~S} 0 \rightarrow \mathrm{P} 32, \mathrm{~S} 1 \rightarrow \mathrm{P} 33 \end{aligned}$ <br> Generate a memory request for byte from source address <br> Set flip-flop DRQ <br> Subtract one from byte count in E-register <br> Set flip-flop PHIO <br> Enable clock T6L | $\begin{aligned} \text { SXA } & =\text { FAB0/1 PH9 }+\ldots \\ \text { PXS/1 } & =\text { FATR PH9 }+\ldots \\ M R Q & =\text { FATR PH9 }+\ldots \\ \text { S/DRQ } & =\text { FABO/1 EXU }+\ldots \\ \text { MCTE1 } & =\text { FATR PH9 }+\ldots \\ \text { ES4 } & =\text { NFABS NSWI } \\ S / P H I O ~ & =\text { PH9 NBR }+\ldots \\ \text { TKL } & =\text { NTIL NT4L NT8L NTIOL } \end{aligned}$ | Source address clocked into P -register. Byte selection bits clocked into flip-flops P32, P33 <br> Inhibits transmission of another clock until data signal is received |
| $\begin{aligned} & \text { PH10 } \\ & \text { T6L } \end{aligned}$ | $\mathrm{MBO}-\mathrm{MB31} \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ <br> Byte selected by bits P32 and P33, C $\rightarrow$ D24-D31 <br> $\mathrm{BO}-231 \longrightarrow$ SO-S31 <br> S15-S31 $\rightarrow$ P15-P31, <br> $\mathrm{SO} \rightarrow \mathrm{P} 32, \mathrm{SI} \rightarrow \mathrm{P} 33$ <br> Clear A-register <br> If memory protection violation occurs, set flip-flop SW2 <br> Memory request generated to store first byte <br> Set flip-flop NRPX | $\begin{aligned} \text { CXMB } & =\text { DGC } \\ \text { DXCBP } & =\text { FATR PHIO }+\ldots \\ \text { SXB } & =\text { FATR PHIO }+\ldots \\ \text { PXS } / 1= & \text { FATR PHIO }+\ldots \\ \text { AX/1 }= & \text { FATR PHIO }+\ldots \\ S / S W 2= & \text { FABO PH10 PROTECTD }+\ldots \\ \text { MRQ }= & \text { FATR } 07 \text { PHIO NPROTECTD } \\ & \text { NSW } 2+\ldots \\ S / N R P X= & \text { FATR PH10 }+\ldots \end{aligned}$ | Data word from modified source address <br> See equations in PH 7 of Move Byte String <br> Destination address <br> Destination address clocked into $P$-register. Byte selection bits clocked into flip-flops P32, P33 |
|  |  | (Continued) | Mnemonic: TBS (41) |

Table 3-104. Translate Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Force ones into flip-flops CSO-CS31 <br> Branch to PH5 <br> Enable clock T8L <br> Set flip-flop DRQ | $\begin{aligned} \text { CSXI } & =\text { NPRX } \\ \text { S/PH5 } & =\text { BRPH5 }=\text { FATR } 07 \text { PH } 10+\ldots \\ \text { R/NT8L } & =\text { T8L }=\text { FATR } 07 \mathrm{PH} 10+\ldots \\ \text { S/DRQ } & =\text { FAB0 } / 1 \text { EXU }+\ldots \end{aligned}$ | For use during upward byte alignment in PH5 <br> Cycle repeated until flipflop PHA is finally set during PH5 <br> Inhibits transmission of another clock until signal is received that data lines have been strobed |
| $\begin{aligned} & \text { PH9A } \\ & \text { T } 8 \mathrm{~L} \end{aligned}$ | (Entered from PH5 when flipflop PHA is set) $\xrightarrow{\mathrm{P} 15-\mathrm{P} 31 \longrightarrow \mathrm{~S} 32-\mathrm{S} 31,} \mathrm{~S} 1$ <br> Circular shift one bit position to the left with $\mathrm{SO} \rightarrow$ A31, $\mathrm{S} 1-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 30$ <br> Generate memory request for next instruction <br> Q15-Q31 $\rightarrow$ P15-P31 <br> P15-P31 $\longrightarrow$ LM15-LB31 <br> If flip-flop SW2 is set, add one to count in E-register <br> Set flip-flop PH10 <br> Enable clock T6L | $\begin{aligned} S X P= & \text { FATRA PH9 }+\ldots \\ \text { AXSLI }= & \text { FABOA PH9 }+\ldots \\ M R Q / 1= & \text { FAB0A/1 PH9 }+\ldots \\ \text { PXQ }= & \text { MRQ/1 }+\ldots \\ \text { PCTE1 }= & \text { FATRA PH9 SW2 }+\ldots \\ S / P H 10= & \text { PH9 NBR }+\ldots \\ \text { T6L }= & \text { NT1L NT4L NT8L NT10L } \\ & \text { NRESET } \end{aligned}$ | Destination address and byte selection bits <br> Places address in bit positions 14 through 30 and byte selection bits in 0 and 31 <br> Address of next instruction <br> Count points to last byte transferred |
| PHIOA <br> T6L | $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ <br> Circular shift one bit position to the left with $\mathrm{SO} \longrightarrow \mathrm{A} 31$, $\mathrm{S} 1-\mathrm{S} 31 \longrightarrow \mathrm{~A} 1-\mathrm{A} 30$ $\mathrm{E} 0-\mathrm{E} 7 \longrightarrow \mathrm{~A} 0-\mathrm{A} 7$ | $\begin{aligned} & \text { SXA }=\text { FATRA PHIO }+\ldots \\ & \text { AXSLI }=\text { FATRA PH } 10+\ldots \\ & \text { AXE }=\text { FATRA PH10 }+\ldots \end{aligned}$ | Destination address and byte selection bits <br> Places address in bit positions 13 through 29 and byte selection bits in positions 30 and 31 <br> Modified byte count clocked into A-register |
|  |  | (Continued) | Mnemonic: TBS (41) |

Table 3-104. Translate Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Set flip-flop IEN <br> Set flip-flop DRQ <br> Force a one on address line LR31 <br> Set flip-flop PHII <br> Enable clock T8L |  | Enables interrupt to be acknowledged <br> Inhibits transmission of another clock until signal is received from memory <br> Select odd numbered private memory register |
| PHIlA T\&L | $\begin{aligned} & \text { A0-A31 } \longrightarrow \text { S0-S31 } \\ & \text { S0-S31 } \longrightarrow \text { RW0-RW31 } \end{aligned}$ <br> Generate write-byte signals RWB0-RWB3 <br> If flip-flop SW2 is true, generate signal (S/TRACC4/1) and set TRAP flip-flop <br> If SW2 is not set and byte count in E-register is all zeros, generate signal ENDE <br> Set flip-flop PREI <br> Enable clock T6L | $\begin{aligned} \text { SXA }= & \text { FATRA PHII }+\ldots \\ \text { RWXS }= & \text { FATRA PHII }+\ldots \\ \text { RWB0-RWB3 }= & \text { RWXS } \\ & \cdot \\ (S / T R A C C 4 / 1)= & \text { FABOA PHII SW2 NTRAP } \\ & +\ldots \\ \text { S/TRAP }= & (S / \text { TRACC4/1) }+\ldots \\ \text { ENDE }= & \text { FABOA PHII EZ }+\ldots \\ \text { S/PREI }= & \text { ENDE (NHALT + FUEXU) } \\ & \text { N(S/INTRAPF) } \\ \text { T6L }= & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \end{aligned}$ | Modified destination address and byte count <br> Store modified destination address and byte count in odd numbered private memory register <br> Trap because of attempted memory protection violation <br> For next instruction |
|  |  |  | Mnemonic: TBS (41) |

Table 3-105. Translate and Test Byte String, Phase Sequence

| Phase | Function Performed | Signals Involved <br> T6L | Generate signal PROTECTDIS | PROTECTDIS $=$ FABO $+\ldots$ |
| :--- | :--- | :--- | :--- | :--- |
| Clear A-, B-, and E-registers | AX | Comments |  |  |

Table 3-105. Translate and Test Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH2 <br> T6RL (Cont.) | Force a one on LR31 address line <br> Set flip-flop DRQ <br> Set flip-flop PH3 <br> Enable clock T10L | $\begin{array}{ll} \mathrm{R} / \text { NLR3I } / 2 & =\mathrm{LR} 31 / 2=\mathrm{FABO} \mathrm{PH} 2+\ldots \\ \mathrm{S} / \mathrm{DRQ} & =\mathrm{FABO} / 1 \mathrm{EXU}+\ldots \\ \mathrm{S} / \mathrm{PH} 3 & =\mathrm{PH} 2 \mathrm{NBR}+\ldots \\ \mathrm{R} / \text { NTIOL } & =\text { FABO PH2 }+\ldots \end{array}$ | Selects odd numbered private memory register <br> No function. Memory request has not been made |
| $\begin{aligned} & \text { PH3 } \\ & \text { T10L } \end{aligned}$ | $\begin{aligned} & \begin{array}{l} \text { A0-A31 + D0-D31 } \\ + \text { CS0-CS31 } \end{array} \text { S0-S31 } \\ & \text { S0-S31 } \longrightarrow \text { RW0-RW31 } \end{aligned}$ <br> Generate write-byte signals RWB0-RWB3 <br> Circular shift B-register left two bit positions <br> If first translation of byte, set flip-flop SW 1 <br> Set flip-flop DRQ <br> Reset flip-flop CC4 <br> Set flip-flop PH5 <br> Enable clock T8L | $\begin{array}{ll} \text { SXADD } & =\text { FATR PH3 }+\ldots \\ \text { RWXS } & =\text { FABO PH3 }+\ldots \\ \text { RWB0-RWB3 } & =\text { RWXS } \\ & =\text { FATR PH3 }+\ldots \\ \text { BXBR2 } & =\text { FATR PH3 }+\ldots \\ \text { S/SW1 } & =\text { FAB0 } / 1 \text { EXU }+\ldots \\ \text { S/DRQ } & =\text { FAB0 } / 1 \text { PH3 NO7 }+\ldots \\ \text { R/CC4 } & =\text { BRPH5 }=\text { FAB0/1 PH3 }+\ldots \\ \text { S/PH5 } & =\text { T8L }=\text { FAB0/1 PH3 }+\ldots \\ \text { R/NT8L } & \end{array}$ | Source address plus displacement value plus mask if RZ <br> Store modified source address and mask in odd numbered private memory register <br> Places destination address in bit positions 15 through 31 and byte selection bits in positions 0 and 1 <br> No function. Memory request has not been made |
| $\begin{aligned} & \text { PH5 } \\ & \text { T8L } \end{aligned}$ | If first pass (SW1 set), $\mathrm{BO}-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ <br> S15-S31 $\rightarrow$ P15-P31, <br> $\mathrm{SO} \rightarrow \mathrm{P} 32, \mathrm{SI} \rightarrow \mathrm{P} 33$ <br> Reset flip-flop SWI <br> Generate memory request for byte <br> If address was in a protected area of memory, set flip-flop SW2 | SXB $=$ FATR5 SWI $+\ldots$ <br> PXS $/ 1$ $=$ FATR5 SWI $+\ldots$ <br> R/SWI $=$ FATR PH5 $+\ldots$ <br> MRQ $=$ FATTR5 NFATRFIN!SH $+\ldots$ <br> S/SW2 $=$ FATR PH5 PROTECTD $+\ldots$ | Destination address and byte selection bits |
|  |  | (Continued) | Mnemonic: TTBS (40) |

Table 3-105. Translate and Test Byte String, Phase Sequence (Cont.)


Table 3-105. Translate and Test Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH6 } \\ & \text { T8L } \end{aligned}$ | $\begin{aligned} & \text { MB0-MB31 C0-C31 } \\ & \text { Byte selected by P32 and } \\ & \text { P33 } \longrightarrow \text { D24-D31 } \\ & \text { P15-P31 S15-S31, } \\ & \text { P32 S1 } \\ & \text { S0-S31 P33 } \longrightarrow \text { B0-B31 } \\ & \text { RR0-RR31 } \longrightarrow \text { A0-A31 } \end{aligned}$ <br> Set flip-flop PH7 <br> Set flip-flpp DRQ <br> Enable clock T6L | $\begin{aligned} & \text { CXMB }=\text { DGC } \\ & \text { DXCBP }=\text { FATR PH6 }+\ldots \\ &=\text { FATR PH6 }+\ldots \\ & \text { SXP } \\ & \text { BXS } \\ & \\ & \text { AXATR PH6 }+\ldots \\ & \text { S/PH7 }=\text { FATR PH6 }+\ldots \\ & \text { S/DRQ }=\text { FABO/I EXU }+\ldots \\ & \text { T6L }=\begin{array}{l} \text { NTIL NT4L NT8L NTIOL } \end{array} \\ & \text { NRESET } \end{aligned}$ | Word from destination address <br> Byte from destination address downward aligned into Dregister. See equations in PH7 of Move Byte String <br> Destination address stored in B-register <br> Modified source address clocked into A-register from private memory <br> No function. No memory request made |
| $\begin{aligned} & \text { PH7 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \rightarrow \mathrm{~A} 1 \rightarrow \mathrm{~A} 31 \end{aligned}$ <br> Clear D-register <br> Set flip-flop DRQ <br> Set flip-flop PH8 <br> Enable clock T4L | $\begin{aligned} \text { SXADD } & =\text { FATR PH7 }+\ldots \\ \text { AXS } & =\text { FATR PH7 }+\ldots \\ \text { DX/1 } & =\text { FATR PH7 }+\ldots \\ \text { S/DRQ } & =\text { FAB0/1 EXU }+\ldots \\ \text { S/PH8 } & =\text { PH7 NBR }+\ldots \\ \text { R/NT4L } & =\text { S/T4L }=\text { FAB0 } / \text { PH7 } \end{aligned}$ | Source address and byte added <br> Result $\rightarrow$ A-register <br> No function. No memory request made |
| $\begin{aligned} & \text { PH8 } \\ & \text { T4L } \end{aligned}$ | $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{PR} 0-\mathrm{PR} 31$ <br> Circular shift right two digit places with A30 $\nrightarrow \mathrm{A} 0$, and $\mathrm{A} 31 \longrightarrow \mathrm{Al}$ | $\begin{aligned} & \text { AXPRR2 }=\text { FATR PH8 }+\ldots \\ & \text { AOEN } / 2=\text { A30 ARCYC } \\ & \text { AIEN } / 2=\text { A31 ARCYC } \end{aligned}$ | Address shifted into bit positions 15 through 31 and byte selection bits into positions 0 and 1 |
|  |  | (Continued) | Mnemonic: TTBS (40) |

Table 3-105. Translate and Test Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Set flip-flop DRQ <br> Set flip-flop PH9 <br> Enable clock T4L | $\begin{aligned} \text { ARCYC } & =\mathrm{ALCYC}=\mathrm{NFAMDSF} \\ \text { S/DRQ } & =\mathrm{FABO} / 1 \mathrm{EXU}+\ldots \\ \mathrm{S} / \mathrm{PH} 9 & =\mathrm{PH} 8 \mathrm{NBR}+\ldots \\ \text { R/NT4L } & =\mathrm{S} / \mathrm{T} 4 \mathrm{~L}=\mathrm{FAB0} / 1 \mathrm{PH} 8+\ldots \end{aligned}$ | No function. No memory request made |
| $\begin{aligned} & \text { PH9 } \\ & \text { T4L } \end{aligned}$ | $\begin{aligned} & \text { A0-A31 S0-S31 } \\ & \text { S15-S31 P15-P31, } \\ & \text { S0 P32, S1 } \longrightarrow \text { P33 } \end{aligned}$ <br> Generate memory request for byte from source address <br> Set flip-flop DRQ <br> Subtract one from count in E-register <br> Set flip-flop PH 10 <br> Enable clock T6L | $\begin{array}{ll} \text { SXA } & =\text { FAB0/1 PH9 }+\ldots \\ \text { PXS/1 } & =\text { FATR PH9 }+\ldots \\ \text { MRQ } & =\text { FATR PH9 }+\ldots \\ \text { S/DRQ } & =\text { FAB0/1 EXU }+\ldots \\ \text { MTCE1 }= & \text { FATR PH9 }+\ldots \\ \text { S/PH10 }= & \text { PH9 NBR }+\ldots \\ \text { T6L } & = \\ & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \end{array}$ | Source address clocked into P -register. Byte selection bits clocked into flip-flops P32, P33 <br> Inhibits transmission of another clock until data signal received |
| $\begin{aligned} & \text { PHIO } \\ & \text { T6L } \end{aligned}$ | $\text { MBO-MB31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ <br> Byte selected by bits P32 and P33, $C \leftrightarrows$ D24-D31 $\text { B30-B31 } \longrightarrow \text { S0-S31 }$ <br> S15-S31 $\longrightarrow$ P15-P31, $\mathrm{SO} \nrightarrow \mathrm{P} 32, \mathrm{~S} 1 \longrightarrow \mathrm{P} 33$ <br> Clear A-register <br> If memory protection violation occurs, set flip-flop SW2 <br> Set flip-flop NPRX | $\begin{array}{ll} \text { CXMB } & =\text { DGC } \\ \text { DXCBP } & =\text { FATR PH } 10+\ldots \\ \text { SXB } & =\text { FATR PH } 10+\ldots \\ \text { PXS } / 1 & =\text { FATR PH } 10+\ldots \\ \text { AX/1 } & =\text { FATR PH10 }+\ldots \\ \text { S/SW2 } & =\text { FABO PH10 PROTECTD }+\ldots \\ \text { S NPRX } & =\text { FATR PH } 10+\ldots \end{array}$ | Data word from modified source address <br> See equations in PH7 of Move Byte String <br> Destination address <br> Destination address clocked into P-register. Byte selection bits clocked into flip-flops P32, P33 |
| (Continued) |  |  | Mnemonic: TTBS (40) |

Table 3-105. Translate and Test Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PHIO T6L (Cont.) | Force ones into flip-flops CSO-CS31 <br> Force a one onto address line LR31 <br> Generate signal (S/CXS) <br> Set flip-flop DRQ <br> Set flip-flop PHII <br> Enable clock T10L | $\begin{aligned} \text { CSXI }= & \text { NPRX } \\ \text { R/NLR31 } / 2= & \text { LR3I } / 2=0 \cup 4 \text { OLO NPHA } \\ & \text { PHIO }+\ldots \\ (S / C X S)= & O U 40 L 0 \mathrm{NPHA} \mathrm{PHIO}+\ldots \\ S / D R Q= & \text { FABO/1 EXU }+\ldots \\ S / P H I I= & \text { PHIO NBR }+\ldots \\ \text { R/NTIOL }= & \text { TIOL }=0 U 4 \text { OLO NPHA PHIO } \end{aligned}$ | For upward alignment during PHII <br> Selects odd numbered private memory register to obtain mask <br> No function. No memory request made |
| $\begin{aligned} & \text { PHII } \\ & \text { T10L } \end{aligned}$ | $\begin{aligned} & \mathrm{D} 24-\mathrm{D} 31 \longrightarrow \mathrm{~K} 23-\mathrm{K} 30 \\ & \mathrm{~K} 23-\mathrm{K} 30 \longrightarrow \mathrm{~S} 0-\mathrm{S} 7 \\ & \mathrm{~S} 0-\mathrm{S} 7 \longrightarrow \mathrm{C} 0-\mathrm{C} 7 \\ & \mathrm{C} 0-\mathrm{C} 7 \longrightarrow \mathrm{D} \longrightarrow \mathrm{D} 7 \\ & \mathrm{RR} 0-\mathrm{RR} 31 \longrightarrow \mathrm{~A} 3-\mathrm{A} 31 \end{aligned}$ <br> Set flip-flop NPRX <br> Force ones into flip-flops CS0-CS31 <br> Set flip-flop DRQ <br> Set flip-flop PHI2 <br> Enable clock T4RL | SXUAB $=$ FATR PHII $+\ldots$ <br> CXS $=$ (generated during PHIO) <br> DXC $=$ FATR PHII $+\ldots$ <br> AXRR $=$ FATR PHII $+\ldots$ <br> S/NPRX $=$ FATR PHII $+\ldots$ <br> CSXI $=$ NPRX $+\ldots$ <br> S/DRQ $=$ FABO/I EXU $+\ldots$ <br> S/PHI2 $=$ PHII NBR $+\ldots$ <br> T4RL $=$ FATR PHII $+\ldots$ | Source byte <br> See equations in PH 10 of Move Byte String <br> Source byte upward aligned into C-register and clocked into D-register <br> Source address and mask <br> For AND operation during PHI2 <br> No function. No memory request made |
| PHI2 <br> T4RL | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31+ \\ & \mathrm{CSO}-\mathrm{CS} 31 \longrightarrow \mathrm{SO-S31} \end{aligned} \mathrm{SO-S31} \mathrm{\rightarrow A0-A31} \mathrm{C}$ <br> Set flip-flop DRQ | $\begin{array}{ll} \text { SXPR } & =\text { NPRX NSDIS }+\ldots \\ \text { AXS } & =\text { FATR PH } 12+\ldots \\ \text { S/DRQ } & =\text { FABO/1 EXU }+\ldots \end{array}$ | Logical AND operation between mask and source byte <br> Result $\rightarrow$ A-register <br> No function. No memory request made |
|  |  | (Continued) | Mnemonic: TTBS (40) |

Table 3-105. Translate and Test Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { PHI2 } \\ \text { T4RL } \\ \text { (Cont.) } \end{gathered}$ | Set flip-flop PH13 <br> Enable clock T8L | $\begin{aligned} \mathrm{S} / \mathrm{PH} 13 & =\text { PHI2 NBR }+\ldots \\ \text { R/NT8L } & =\text { T8L }=\text { FATR PH12 } \end{aligned}$ |  |
| $\begin{aligned} & \text { PHI3 } \\ & \text { T8L } \end{aligned}$ | If any ones are compared, ones are contained in Aregister and flip-flop CC4 is set <br> If a comparison has been found and bits R28 through R30 are not all zeros, and R31 is a zero $\mathrm{AO}-\mathrm{A} 31 \longrightarrow$ S0-S31 $\text { SO-S7 } \longrightarrow \text { RW0-RW7 }$ <br> Set flip-flop PH5 <br> Set flip-flop $D R Q$ <br> Enable clock T8L <br> Phases PH5 through PH13 are repeated until flip-flop PHA is set, and the instruction then branches to PH9A | $\begin{aligned} \text { S/CC4 }= & \text { FATR NSW2 NA007Z PHI3 } \\ & +\ldots \\ \text { SXA }= & \text { FATR NSW2 NA0007Z NRZ } \\ & \text { NR31 PH13 }+\ldots \\ \text { RWXS } / 0= & \text { RWB0 } \\ \text { RWB0 }= & \text { FATR NSW2 NA0007Z PHI3 } \\ & \text { NRZ NR31 }+\ldots \\ \text { S/PH5 }= & \text { BRPH5 }=\text { FATR PH13 }+\ldots \\ \text { S/DRQ }= & \text { FAB0 } / 1 \text { EXU }+\ldots \\ \text { R/NT8L }= & \text { T8L }=\text { FAB0/1 PHI3 }+\ldots \end{aligned}$ | Store new byte in even numbered private memory register in place of mask <br> No function. No memory request made |
| $\begin{aligned} & \text { PH9A } \\ & \text { T8L } \end{aligned}$ | $\begin{aligned} & \begin{array}{l} \text { P15-P31 } \\ \text { P32 S15-S31, } \\ \text { S0, P33 } \end{array} \end{aligned}$ <br> Circular shift left one bit position with $\mathrm{SO} \rightarrow$ A31, $\mathrm{Sl}-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 30$ <br> Generate memory request for next instruction <br> Q15-Q31 $\rightarrow$ P15-P31 $\text { P15-P31 } \longrightarrow \text { LM15-LB31 }$ <br> If flip-flop SW2 is set, add one to count in E-register | $\begin{array}{ll} S X P & =\text { FATRA PH9 }+\ldots \\ \text { AXSLI } & =\text { FABOA PH9 }+\ldots \\ M R Q / 1 & =\text { FABOA/1 PH9 }+\ldots \\ P X Q ~ & =\text { MRQ } / 1+\ldots \\ \text { PCTE1 } & =\text { FATRA PH9 SW2 }+\ldots \end{array}$ | Destination address and byte selection bits <br> Place address in bit positions 14 through 30 and byte selection bits in positions 0 and 31 <br> Address of next instruction <br> Count points to last byte compared |
|  |  | (Continued) | Mnemonic: TTBS (40) |

Table 3-105. Translate and Test Byte String, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH9A <br> T8L <br> (Cont. | Set flip-flop PHIO Enable Clock T6L | $\begin{array}{ll} \hline \text { S/PH10 }= & \text { PH9 NBR }+\ldots \\ \text { T6L }= & \text { NTIL NT4L NT8L NT10L } \\ & \text { NRESET } \end{array}$ |  |
| $\begin{aligned} & \text { PH 10A } \\ & \text { T6L } \end{aligned}$ | $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ <br> Circular shift left one bit position with $\mathrm{SO} \xrightarrow{\longrightarrow}$ A31, $\mathrm{S} 1-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 30$ $\mathrm{E} 0-\mathrm{E} 7 \leftrightarrows \mathrm{~A} 0-\mathrm{A} 7$ <br> Set flip-flop IEN <br> Set flip-flop DRQ <br> Force a one on address line LR31 <br> Set flip-flop PHII <br> Enable clock T8L | SXA $=$ FATRA PH10 $+\ldots$ <br> AXSLI $=$ FATRA PH $10+\ldots$ <br> AXE $=$ FATRA PH $10+\ldots$ <br> S/IEN $=$ FATRA PH $10+\ldots$ <br> S/DRQ $=$ FATRA PH $10+\ldots$ <br> R/NLR31/2 $=$ LR31/2 $=$ FATRA PH $10+\ldots$ <br> S/PHII $=$ PH 10 NBR $+\ldots$ <br> R/NT8L $=$ T8L $=$ FATRA PH $10+\ldots$ | Destination address and byte selection bits <br> Places address in bit positions 13 through 29 and byte selection bits in positions 30 and 31 <br> Modified byte count clocked into A-register <br> Enables interrupt to be acknowledged <br> Inhibits transmission of another clock until signal is received from memory <br> Select odd number private memory register |
| $\mathrm{PH} 11 \mathrm{~A}$ <br> T8L | $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ <br> SO-S3I $\longrightarrow$ RW0-RW31 <br> Generate write-byte signals RWB0-RWB3 <br> If E-register is all zeros, reset flip-flop CC4 <br> If flip-flop SW2 is true, generate signal ( $\mathrm{S} / \mathrm{TRACC} 4 / 1$ ) and set flipflop TRAP <br> If byte count in E-register is all zeros or a byte comparison was made (CC4 set), generate signal ENDE <br> Enable clock T6L |  | Modified destination address and byte count <br> Stored modified destination address and byte count in odd numbered private memory register <br> Trap because of attempted memory protection violation <br> For next instruction |
|  |  |  | Mneumonic: TTBS (40) |

## 3-233 Push Word (PSW, 09, 89)

The PSW instruction pushes the contents of register $R$ into the location that is one greater than the location addressed by the current TSA defined by the stack pointer doubleword. Figure 3-185 describes the purposes and the geometry of the push-down stack as they relate to the PSW instruction.

The effective doubleword addresses ( 70 C in the example in figure 3-185) in the PSW instruction addresses TSA which, in turn, addresses the last word (1503) that was pushed into the stack. A one is added to this address, and the contents of the R-register are pushed into location TSA +1 (1504) by the PSW instruction. The count word, CW (the least significant half of the effective doubleword), contains two counts - a space count that defines the number of spaces remaining in the stack and a word count that defines the number of words currently in the stack. The sum of these two counts is equal to the length of the stack.

Words are pushed into the stack in numerically ascending order and are pulled from the stack in numerically descending order. At the end of the PSW instruction described in
figure 3-185, location 1504 will contain the contents of register $R$, the top of stack address in 70 C will be 1504 , and the space and word counts in the count word 70D will be $1 B$ and 05 , respectively.

The preparation sequence for the PSW instruction is the same as the general preparation sequence given under the Preparation Sequence. The execution sequence for the Push Word instruction is described in figure 3-186.

In PH1 the A-register is set to equal X'00000001'. The contents of the A-register are two's complemented and are transferred to the $B$-register in $\mathrm{PH} 2, \mathrm{BO}-\mathrm{BI} 5$, which are reset to zeros, are the only exception. $B$ equals $X^{\prime} 0000 F F F F F^{\prime}$. In PH3 the A-register is halfword aligned upward, and $A$ equals $X^{\prime} 00010000^{\prime}$. The contents of $A$ and $B$ are merged (OR-gated) in PH4, and the result is placed into $A$. The A-register now contains X'0001FFFF'. MRQ is enabled to read the contents of the count word. In PH5 carry bit K15 is forced true, and the A-register is again two's complemented, which effectively reverses the two halves of the Aregister. A now equals X'FFFF0001'. A0-A15 contains a one's decrement value, and A16-A31 contains a one's increment value.


Figure 3-185. Doubleword-Stack Relationship for PSW Instruction


Figure 3-186. Push Word, Logic Sequence Diagram (Sheet 1 of 2)


In PH6 the count word is in D. The contents of A and D are added, which effectively adds one to the word count and subtracts one from the space count. The result, which is the modified count word, is transferred to the B-register and is held there until it is used in PHIIA. Carry bit K15 is inhibited during this addition. This prevents any carry from the word count from affecting the space count addition.

SW1 is set if the space count underflows. SW2 is set if the word count overflows. Space count underflow and word count overflow can occur simultaneously only if the stack contains 32,768 words. Space count underflow and word count overflow are detected by comparing bit 0 of the original space count in $D$ with the result in sum bus bit 0 and by comparing bit 16 of the original word count in D with the result in sum bus bit 16. If bit 0 of the count word TS (trap on space underflow) is a zero, a trap occurs because of a space count underflow. If bit 16 of the count word TW (trap on word overflow) is a zero, á trap occurs because of a word count overflow. Flip-flop SWI is not set if a trap occurs because of a space count underflow since D0 must be a one to set SW1 or a zero to cause a trap. Flip-flop SW2 is not set if a trap occurs because of a word count overflow, since D16 must be a zero to cause a trap or a one to set SW2.

If bi: 0 of the count word TS (trap on space underflow) is a one and if the space count underflowed, the CPU aborts the PSW instruction by branching to PH14A. If bit 16 of the count word TW (trap on word overflow) is a one and if the word count overflowed, the CPU aborts the PSW instruction by branching to PHI4A. If no underflow/overflow occurs, the instruction sequences from PH 6 to PH 7 . A memory request is made to read TSA in PH7.

Starting with PH7 and ending with PH12A, four pieces of data (two addresses and two words) are entered and are saved in the various registers. The following list wili aid in keeping track of the data, where: ATSA is the address of TSA; TSA is the address of the current stack word; SW is the contents of the current stack word; and CW is the contents of the count word.

| PHASE | ATSA | $\underline{T S A}$ | $\underline{S W}$ | CW |
| :--- | :---: | :---: | :---: | :---: |
| PH7 | $P$ |  |  | $S$ |
| PH8 | $P$ | $C \rightarrow D$ |  | $B$ |
| PH9 | $P \rightarrow C$ | $D$ |  | $B$ |
| PHIA | $C \rightarrow D$ | $D+1 \rightarrow P$ | $R R \rightarrow A$ | $B$ |
| PH2A | $D$ | $P$ | $A \rightarrow M B$ | $B$ |
| PH8A | $D$ | $P \rightarrow C$ |  | $B$ |


| PHASE | ATSA | TSA | SW | CW |
| :--- | :---: | :---: | :---: | :---: |
| PH9A | $D \nrightarrow P$ | $C \rightarrow-D$ | $B$ |  |
| PHIOA | $P$ | $(T S A+1) \rightarrow M B$ | $B$ |  |
| PHIIA | $P+1$ |  | $B \rightarrow M B, B \nrightarrow A$ |  |
| PHI2A |  |  | $A$ |  |
| PH14A |  |  | $D \rightarrow A$ |  |

A one is added to TSA in PHIA, and the result is placed in the $P$-register. The contents of register $R$ are clocked into $A$, and a memory request is made to write into the top of stock location (TSA+1).

In PHIOA the new top of the stack address, which has been transferred to $D$, is written into the TSA location. The modified space and word count is transferred from $B$ to the $M B$ lines in PHIIA and is written into the count word location.

In PH 12 A the condition codes are set. CCl is set if the space count underflowed in PH6; CC3 is set if the word count overflowed in PH6; CC2 is set if the modified space count is currently equal to zero; and CC4 is set if the modified word count is equal to zero.

A sequence chart of the Push Word instruction is given in table 3-106.

## 3-234 Pull Word (PLW 08, 88)

The Pull Word instruction loads the private memory register specified by the R-field of the instruction with the contents of the word whose address currently represents the top of the push-down stack defined by the stack pointer doubleword located at the effective doubleword address of the instruction. Figure 3-187 describes the purposes of the effective doubleword and the geometry of the push-down stack as they related to the PLW instruction.

The effective doubleword address (70C in the example in figure 3-187) in the PLW instruction addresses TSA (top of stack address) which, in turn, addresses the last word (1503) that was pushed into the stack. This is the word that is pulled out of the stack and is placed into register R by the PLW instruction. The count word CW the least significant half of the effective doubleword) contains two counts, a space count that defines the number of spaces remaining in the stack, and a word count that defines the number of words currently in the stack.

Table 3-106. Push Word, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | $1 \nsim D R Q$ | $\begin{aligned} S / D R Q= & \text { FAST EXU }+ \text { FASTA EXU } \\ & +\ldots \end{aligned}$ | DRQ is set for all execution phases |
| $\begin{aligned} & \mathrm{PHI} \\ & \text { T4RL } \end{aligned}$ | $\begin{aligned} & 1 \nsim \mathrm{~A} 31 \\ & 1 \not \mathrm{NGX} \\ & 1 \text { 's } \nrightarrow \mathrm{CSO}-\mathrm{CS} 31 \end{aligned}$ | $\begin{array}{ll} \text { A31X1 } & =\text { FAST PH1 NO6 }+\ldots \\ (S / N G X) & =\text { FAST PH1 NO2 }+\ldots \\ \text { CSX1 } & =(S / N G X) \end{array}$ | Set one in A-register <br> Prepare for negation |
| $\begin{aligned} & \text { PH2 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & 1 \longrightarrow \mathrm{G} 1619 \\ & 1 \longrightarrow \mathrm{~K} 15 \\ & -(\mathrm{A} 16-\mathrm{A} 31) \longrightarrow \mathrm{SO} \mathrm{~S} 15 \\ & 0 \mathrm{~S} 16-\mathrm{S} 31 \\ & \mathrm{SO}-\mathrm{S} 15 \rightarrow \mathrm{~B} 0-\mathrm{B} 31 \\ & 1 \longrightarrow \mathrm{NPRX} \\ & 1 \longrightarrow \mathrm{~K} 31 \end{aligned}$ | $\begin{array}{ll} \text { G1619 } & =\text { FAST PH2 }+\ldots \\ \text { K15 } & =\text { G1619/1 } \\ \text { SXADD } / 1 & =\text { NGX NFAMDSF }+\ldots \\ \text { BXS } & =\text { FAST PH2 }+\ldots \\ \text { CSX1 } & =(S / N P R X) \\ \text { K31 } & =\text { NGX } \end{array}$ | Causes zeros in B0-B15 <br> Two's complement <br> Results in $B=0000$ FFFF <br> Prepare for upward alignment |
| $\begin{aligned} & \mathrm{PH} 3 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{A} 16-\mathrm{A} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 15 \\ & \mathrm{SO}-\mathrm{S} 15 \rightarrow \mathrm{~A} 0-\mathrm{A} 15 \\ & \mathrm{O}_{\mathrm{S}} \rightarrow \mathrm{D} 0-\mathrm{D} 31 \end{aligned}$ | $\begin{aligned} \text { SXUAH } & =\text { FAST PH3 }+\ldots \\ \text { AXS } / 2 & =\text { FAST PH3 }+\ldots \\ \text { DX } / 1 & =\text { FAST PH3 }+\ldots \end{aligned}$ | Upward align halfword. Results in $A=00010000$ |
| $\begin{aligned} & \text { PH4 } 4 \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \mathrm{B} 0-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{~A} 0-\mathrm{A} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{C} 0-\mathrm{A} 31 \end{aligned}$ <br> Enable memory request $1 \nrightarrow L B 31 / 1$ | $\begin{array}{ll} \text { SXB } & =\text { FAST PH } 4+\ldots \\ \text { SXA } & =\text { FAST PH } 4+\ldots \\ \text { AXS } & =\text { FAST PH } 4+\ldots \\ \text { MRQ } & =\text { FAST PH4 }+\ldots \\ (S / L B 31 / 1) & =\text { FAST PH } 4+\ldots \\ \text { R/LB31/1 } & =\cdots \end{array}$ | Increment-decrement values. This OR function results in $A=0001$ FFFF . Combines positive and negative halves of modifier. Positive in A0-Al5. Negative in Al6A31 <br> To read space and word count <br> Address low order half of stack pointer doubleword |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 1 \rightarrow \mathrm{D} 31 \\ & (-\mathrm{A} 0-\mathrm{A} 31) \longrightarrow \mathrm{S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \rightarrow \mathrm{~A} 1 \rightarrow \mathrm{~A} 31 \end{aligned}$ | $\begin{array}{ll} \text { DXC } / 6 & =\text { FAST PH5 }+\ldots \\ \text { AXS } & =\text { FAST PH5 O7 }+\ldots \\ \text { G1619 } & =\text { FAST PH5 }+\ldots \end{array}$ | Read space and word count <br> Negate A-register. Reverses two halves of A-register |
|  |  | (Continued) | Mnemonic: PSW $(09,89)$ |

Table 3-106. Push Word, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH5 <br> T6L <br> (Cont. | Reset flip-flop NTIOL | $\begin{array}{ll} \text { K15 } & =\text { G1619 } \\ (\mathrm{S} / \mathrm{T} 10 \mathrm{~L}) & =\text { FAST PH5 }+\ldots \end{array}$ |  |
| $\begin{aligned} & \text { PH6 } \\ & \text { T10L } \end{aligned}$ | $A 0-A 31+D 0-D 31 \longrightarrow \text { S0-S31 }$ <br> Force $0 \longrightarrow \mathrm{~K} 15$ <br> $\mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{BO}-\mathrm{B3} 1$ <br> D16 NSI6 $\Rightarrow 1 \rightarrow$ SW2, or <br> DO NSO $\Rightarrow 1 \rightarrow$ SWI <br> Trap, or <br> Go to PHI4A <br> $1 \rightarrow \mathrm{PHA}$ <br> $1 \rightarrow$ CXS |  | Add one to word count, subtract one from space count. Modifier is in A-register <br> Prevent carry from word field to space field <br> Update count word to $B$-register <br> Word count overflow <br> Space count underflow <br> If trap flag = 1, trap with condition code unchanged <br> If trap flag $=0$, go to phase 14A to abort instruction <br> Bit 16 or bit 0 has changed because of an underflow or overflow |
| $\begin{aligned} & \text { PH7 } \\ & \text { T } \& \mathrm{~L} \end{aligned}$ | $0 ' \mathrm{~s} \longrightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> Enable memory request | $\begin{aligned} \mathrm{AX} / 1 & =\text { FAST PH } 7+\ldots \\ M R Q & =\text { FAST PH } 7+\ldots \end{aligned}$ | To read top-of-stack address |
| $\begin{aligned} & \text { PH8 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \text { MB0-MB31 C0-C31 } \\ & \mathrm{C} 0-\mathrm{C} 31 \rightarrow \text { D0-D31 } \\ & 1 \rightarrow \mathrm{CXS} \end{aligned}$ | $\begin{aligned} \text { CXMB } & =\text { DGC } \\ \text { DXC } / 6 & =\text { FAST PH8 }+\ldots \\ \text { S/CXS } & =\text { FAST PH8 NOL } 3+\ldots \\ S / T 8 L & =(S / C X S)+\ldots \end{aligned}$ | Read top-of-stack address D-register via Cregister <br> Preset for PH9 |
|  |  |  | Mnemonic: PSW $(09,89)$ |

Table 3-106. Push Word, Phase Sequence (Cont.)


Table 3-106. Push Word, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH9A <br> T6L | $\begin{aligned} & \mathrm{D} 0-\mathrm{D} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 16-\mathrm{S} 31 \longrightarrow \mathrm{P} 16-\mathrm{P} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \mathrm{D} 0-\mathrm{D} 31 \end{aligned}$ <br> Enable memory request | SXD $=$ FASTA PH9 $+\ldots$ <br> PXS $=$ FASTA PH9 $+\ldots$ <br> DXC $/ 6$ $=$ FASTA PH9 $+\ldots$ <br> MRQ $=$ FASTA PH9 $+\ldots$ | Effective address P-register <br> Top-of-stack address $\rightarrow$ D-register <br> To write top-of-stack address |
| PHIOA <br> T6L | $\begin{aligned} & \text { D0-D31 }+\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \text { S0-S31 } \\ & \text { S0-S31 } \longrightarrow \mathrm{MBO}-\mathrm{MB31} \\ & 1 \longrightarrow \mathrm{LB31/1} \end{aligned}$ <br> Enable memory request | $\begin{array}{ll} \text { SXADD } & =\text { FASTA PHIO }+\ldots \\ \text { MW } & =\text { FASTA PH } 10+\ldots \\ (S / L B 31 / 1) & =\text { FASTA PH } 10+\ldots \\ M R Q & =\text { FASTA PH } 10+\ldots \end{array}$ | $A=0 ' s, \text { top-of-stack }$ <br> address $\longrightarrow$ core memory in effective word location <br> To address low order half of stack pointer doubleword <br> To write count word |
| PHIIA <br> T6L | $\begin{aligned} & \mathrm{BO} 0-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{MBO}-\mathrm{MB31} \\ & \mathrm{SO-S31} \longrightarrow \mathrm{C} 0-\mathrm{A} 31 \end{aligned}$ <br> Enable memory request | $\begin{array}{ll} \text { SXB } & =\text { FASTA PHII }+\ldots \\ \text { MW } & =\text { FASTA PHII }+\ldots \\ \text { AXS } & =\text { FASTA PHII }+\ldots \\ M R Q / I & =\text { FASTA PHII }+\ldots \end{array}$ | Write updated count word in effective address +1 <br> Updated count word to Aregister for check in PHI2A <br> To read next instruction |
| $\mathrm{PH} 12 \mathrm{~A}$ T6́L | If $\mathrm{SWI}=1,1 \rightarrow \mathrm{CCl}$ <br> If $\mathrm{SW} 2=1,1 \not \mathrm{CC} 3$ <br> If $(\mathrm{Al}-\mathrm{Al} 5=0), 1 \longrightarrow \mathrm{CC} 2$ <br> If $(A 17-A 31=0), 1 \not C C 4$ <br> End <br> Reset PHA | S/CC1 $=$ FASTA PH12 SW1 $+\ldots$ <br> S/CC3 $=$ FASTA PH12 SW2 $+\ldots$ <br> S/CC2 $=$ FASTA PH12 AOII5Z $+\ldots$ <br> S/CC4 $=$ FASTA PH12 Al73IZ $+\ldots$ <br> $(R / C C)$ $=$ FASTA PHI2 $+\ldots$ <br> ENDE $=$ FASTA PH12 $+\ldots$ <br> R/PHA $=$ CLEAR $=$ ENDE | Space count underflow <br> Word count overflow <br> Space count zero <br> Word count zero |
| PHI4A <br> T\&L | Entered from PH6 if trap has occurred |  |  |
| (Continued) |  |  | Mnemonic: PWS (09, 89) |

Table 3-106. Push Word, Phase Sequence (Cont.)



Figure 3-187. Doubleword-Stack Relationship for PLW Instruction

The sum of these two counts is equal to the length of the stack. Words are pushed into the stack in numerically descending order, and are pulled from the stack in numerically descending order. At the end of the PLW instruction described in figure 3-187, register $R$ contains the contents of word location 1503; the top of stack address in 70 C is 1502 ; and space and word counts in the count word 70D are 1D and 03, respectively.

The preparation sequence for the PLW instruction is the same as the general preparation sequence given under the Preparation Sequence. The execution sequence for the Pull Word instruction is described in figure 3-188.

In PHI the A-register is set to equal X'00000001'. In PH2 the contents of the A -register are two's complemented and are transferred to the B -register. B equals X'0000FFFF'. In PH3 the $A$-regisier is half-word upward aiigned, and $A$ equals $X^{\prime} 00010000$ '. The contents of $A$ and $B$ are merged ( $O R$-gated) in PH4, and the result is placed in A. The Aregister now contains $X^{\prime} 0001 F F F F$ ', which represents the increment/decrement values to be added to the contents of the count word in PH6.

The count word is read into $D$ at the PH5 clock and in PH6 the contents of $A$ and $D$ are added, effectively adding one to the space count and subtracting one from the word count. The result, which is the modified count word, is transferred to the B-register and is held there for later use. Carry bit $K 15$ is inhibited during this addition to prevent any carry from the word count from affecting the space count addition.

SWI is set if the space count overflows. If the word count underflows, SW2 is set. Space count overflow and word count underflow can occur simultaneously only if the stack contains 32,768 words. Space count overflow and word count underflow are detected by comparing bit 0 of the original space count in $D$ with the result in sum bus bit 0 , and by comparing bit 16 of the original word count in D with the result in sum bus bit 16 .

If bit 0 of the count word TS (trap on space overflow) is a zero, a trap occurs because of a space count overflow. If bit 16 of the count word TW (trap on word underflow) is a zero, a trap occurs because of a word count underflow. If a trap occurs because of a space count overflow, flip-flop SWI is not set, since D0 must be a one to set SWI or a zero to cause a trap. If a trap occurs because of a word count


Figure 3-188. Pull Word, Logic Sequence Diagram (Sheet 1 of 2 )


Figure 3-188. Pull Word, Logic Sequence Diagram (Sheet 2 of 2)
underflow, flip-flop SW2 is not set, since D16 must be a zero to cause a trap or a one to set SW2.

If bit 0 of the count word TS (trap on space overflow) is a one and the space count overflowed, the CPU aborts the PLW instruction by branching to PH14A. If bit 16 of the count word TW (trap on word underflow) is a one and the word count underflowed, the CPU aborts the PLW instruction by branching to PHI4A. If no underflow/overflow occurs the instruction sequences from PH6 to PH7.

In PH7 a memory request is made to read TSA. Starting with PH7 and ending with PH12A, four pieces of data (two addresses and two words) are entered and are saved in the various registers. The following sequence list will aid in keeping track of the data, where: ATSA is the address of TSA; TSA is the address of the current stack word; SW is the contents of the current stack word; and CW is the contents of the count word.

| PHASE | ATSA | TSA | SW | CW |
| :---: | :---: | :---: | :---: | :---: |
| PH7 | P |  |  | $S \rightarrow B$ |
| PH8 | P | $C \rightarrow 0$ |  | B |
| PH9 | $\mathrm{P} \rightarrow \mathrm{C}$ | D |  | B |
| PHIA | $C \rightarrow$ D | $D \rightarrow P$ |  | B |
| PH3A | $D \nrightarrow-A$ | P | $C \rightarrow D$ | B |
| PH4A | A | $\mathrm{P} \rightarrow \mathrm{C}$ | D | B |
| PH5A | A | $C \rightarrow D$ | D $\neq$ RW | B |
| PH6A | $A \rightarrow P$ | D | . | B |
| PH7A | P | D |  | B |
| PHIOA | P | $(T S A-1) \rightarrow M B$ |  | B |
| PHIIA | P+1 |  |  | $\begin{aligned} & B \rightarrow M B, \\ & B \rightarrow A \end{aligned}$ |
| PH12A |  |  |  | A |

> PH14A
$D \rightarrow A$

During PH7A the CS-register contains all ones $(-1)$ and is added to the TSA, effectively subtracting one from the TSA. The modified TSA is written into the TSA location in PHIOA. The modified count word, which has been held in the Bregister, is written into the count word location in PHIlA. The count word is also clocked into the A-register for testing in PH12A.

In PH12A the condition code flip-flops are set. Flip-flop CC1 is set if the space count overflowed in PH6; flip-flop CC3 is set if the word count underflowed in PH6. Flipflop CC2 is set if the modified space count is currently equal to zero; and flip-flop CC4 is set if the modified word count is equal to zero.

A sequence chart of the Pull Word instruction is given in table 3-107.

3-235 Push Multiple (PSM OB, 8B)

Before the PSM instruction is executed, the condition code must contain a value equal to the number of words to be pushed into the pushdown stack. Since the condition code consists of four flip-flops, CC1-CC4, no more than 16 words can be pushed into a stack during the execution of any one PSM instruction regardless of the stack length. If the condition code is equal to zero, 16 words will be pushed into the stack.

During the execution of the PSM instruction, the value of the condition code is transferred to the E-register, and a one is added to the contents of TSA to become the address of the first word to be pushed into the stack. Words are pushed into the stack in ascending order. For example, if CC equals three, and the top of stack address is 1517, the stack words will be pushed from private memory into the stack in the following order:

R to (1518)
$R+1$ to (1519)

$$
R+2 \text { to (151A) }
$$

As each word is pushed into the stack, the contents of E are counted down. The words to be pushed have been loaded into the stack when $E$ reaches a count of one. The contents of TSA are modified by adding the value of the condition code to the current TSA and by restoring it to memory. The value of the condition code is added to the word count and subtracted from the space count. The result is stored to the count word in memory.

Table 3-107. Pull Word, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | $1 \rightarrow D R Q$ | $\begin{aligned} S / D R Q= & \text { FAST EXU + FASTA EXU } \\ & +\ldots \end{aligned}$ | $D R Q$ is set for all execution phases |
| $\mathrm{PHI}$ <br> T4RL | $\begin{aligned} & 1 \rightarrow \mathrm{~A} 31 \\ & 1 \rightarrow \mathrm{NGX} \\ & 1 \text { 's } \rightarrow \mathrm{CS} 0-\mathrm{CS} 31 \end{aligned}$ | $\begin{array}{ll} \text { A31XI/1 } & =\text { FAST PHI NO6 }+\ldots \\ (S / N G X) & =\text { FAST PHI NO2 }+\ldots \\ \text { CSXI } & =(S / N G X) \end{array}$ | Set one in A-register <br> Prepare for negation |
| PH2 <br> T6L | $\begin{aligned} & 1 \longrightarrow \mathrm{G} 1619 / 1 \\ & 1 \longrightarrow \mathrm{~K} 15 \\ & -(\mathrm{Al} 6-\mathrm{A} 31) \longrightarrow \mathrm{S} 16-\mathrm{S} 31 \\ & 0 ' \mathrm{~s} \longrightarrow \mathrm{~S} 0-\mathrm{S} 15 \\ & \mathrm{SO}-\mathrm{S} 31 \rightarrow \mathrm{~B} 0-\mathrm{B} 31 \\ & 1 \rightarrow \mathrm{NPRX} \\ & 1 \mathrm{CSO} \mathrm{CS} 31 \\ & 1 \longrightarrow \mathrm{~K} 31 \end{aligned}$ | $\begin{array}{ll} \text { G1619/1 } & =\text { FAST PH2 }+\ldots \\ \text { K15 } & =\text { G1619/1 } \\ \text { SXADD/1 } & =\text { NGX NFAMDSF }+\ldots \\ \text { BXS } & =\text { FAST PH2 }+\ldots \\ (S / \text { NPRX }) & =\text { FAST PH2 }+\ldots \\ \text { CSX1 } & =(S / \text { NPRX }) \\ \text { K31 } & =\text { NGX } \end{array}$ | Causes zeros in $\mathrm{BO}-\mathrm{Bl} 5$ <br> Two's complement <br> Results in $\mathrm{B}=0000 \mathrm{FFFF}$ <br> Prepare for upward alignment |
| $\begin{aligned} & \text { PH3 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \mathrm{A} 16-\mathrm{A} 31 \rightarrow \mathrm{~S} 0-\mathrm{S} 15 \\ & \mathrm{~S} 0-\mathrm{S} 15 \rightarrow \mathrm{~A} 0-\mathrm{A} 15 \\ & 0 ' \mathrm{~S} \rightarrow \mathrm{D} 0-\mathrm{D} 31 \end{aligned}$ | $\begin{aligned} \text { SXUAH } & =\text { FAST PH3 }+\ldots \\ \text { AXS } / 2 & =\text { FAST PH3 }+\ldots \\ \text { DX/1 } & =\text { FAST PH } 3+\ldots \end{aligned}$ | Upward align halfword Results in $A=00010000$ |
| PH4 <br> T6L | $\mathrm{BO} 0-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ <br> $A 0-A 31 \longrightarrow S 0-S 31$ $\mathrm{S} 0-\mathrm{S} 31 \rightarrow \mathrm{~A} 1 \rightarrow \mathrm{~A} 31$ <br> Enable memory request $1 \rightarrow L B 31 / 1$ | $\begin{array}{ll} \text { SXB } & =\text { FAST PH! } 4+\ldots \\ \text { SXA } & =\text { FAST PH } 4+\ldots \\ \text { AXS } & =\text { FAST PH } 4+\ldots \\ \text { MRQ } & =\text { FAST PH } 4+\ldots \\ (S / L B 31 / 1) & =\text { FAST PH4 }+\ldots \\ \text { R/LB31/1 }= & \end{array}$ | Increment-decrement values $\rightarrow$ A-register. This OR function results in $A=0001$ FFFF. Combines positive and negative halves of modifier. Positive in A0-A15, negative in Al6A31 <br> To read space and word count <br> Address low order half of stack pointer doubleword |
|  |  | (Continued) | Mnemonic: PLW (08, 88) |

Table 3-107. Pull Word, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | $\mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31$ <br> Reset flip-flop NTIOL | $\begin{aligned} & \mathrm{DXC} / 6=\text { FAST PH5 }+\ldots \\ & (\mathrm{S} / \mathrm{T} 10 \mathrm{~L} / 1)=\text { FAST PH5 } \end{aligned}$ | Read space and word count |
| $\begin{aligned} & \mathrm{PH6} \\ & \mathrm{~T} 10 \mathrm{~L} \end{aligned}$ | $\mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31$ <br> Force $0 \longrightarrow \mathrm{Kl} 5$ <br> $\mathrm{S} 0-\mathrm{S} 31 \rightarrow \mathrm{BO}-\mathrm{B} 31$ <br> D16 NS16 $\Rightarrow 1 \rightarrow$ SW2, or <br> DO NSO $\Rightarrow 1 \rightarrow$ SW1 <br> Trap if overflow or underflow <br> Go to PHI4A <br> $1 \longrightarrow$ PHA <br> $1 \rightarrow$ CXS |  | Add one to space count; subtract one from word count. Modifier is in Aregister <br> Inhibit carry to prevent carry from word count from affecting space count <br> Updated count word to B-register <br> Word underflow <br> Space overflow <br> If trap flag $=0$, trap with condition code unchanged <br> If trap flag $=1$, go to phase 14A to abort instruction <br> Bit 16 or bit 0 has changed because of an underflow or overflow |
| $\begin{gathered} \text { PH7 } \\ \text { T } 8 \mathrm{~L} \end{gathered}$ | $0^{\prime} \mathrm{s} \longrightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> Enable memory request | $\begin{aligned} \mathrm{AX} / 1 & =\text { FAST PH } 7+\ldots \\ \mathrm{MRQ} & =\text { FAST PH } 7+\ldots \end{aligned}$ | To read top-of-stack address |
| $\begin{aligned} & \text { PH8 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \mathrm{MBO}-\mathrm{MB31} \longrightarrow \mathrm{CO}-\mathrm{C} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & 1 \rightarrow \mathrm{CXS} \end{aligned}$ | $\begin{array}{ll} \text { CXMB } & =\text { DGC } \\ \text { DXC/6 } & =\text { FAST PH8 }+\ldots \\ \text { S/CXS } & =\text { FAST PH8 NOL3 }+\ldots \\ \text { S/T8L } & =(S / C X S)+\ldots \end{array}$ | Read top-of-stack address <br> $\longrightarrow$ C-register <br> $\rightarrow$ D-register <br> Preset for PH9 |
| (Continued) |  |  | Mnemonic: PLW (08, 88) |

Table 3-107. Pull Word, Phase Sequence (Cont.)


Table 3-107. Pull Word, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH5A } \\ & \text { T8L } \\ & \text { (Cont.) } \end{aligned}$ | SO-S31 $\longrightarrow$ RW0-RW31 | $\begin{array}{ll} \text { RW } & =\text { FASTA PH5 }+\ldots \\ \text { S/T8L } & =\text { FASTA PH5 }+\ldots \end{array}$ | Store data word in private memory register |
| PH6A <br> T6L |  | $\begin{array}{ll} \text { SXA } & =\text { FASTA PH6 }+\ldots \\ \text { PXS } & =\text { FASTA PH } 6+\ldots \\ \text { CSXI } & =\text { FASTA PH } 6+\ldots \\ \text { AX/1 } & =\text { FASTA PH } 6+\ldots \\ \text { S } / C X S ~ & =\text { FASTA PH6 OL8 }+\ldots \end{array}$ | Effective address $\qquad$ P-register <br> To subtract one from top-of-stack address <br> For subtraction in nextphase |
| PH7A T6L | $\begin{aligned} & (D 0-D 31)-1 \longrightarrow \text { SO-S31 } \\ & \mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{C} 1 \longrightarrow \mathrm{C} 31 \\ & \mathrm{CO}-\mathrm{C} 31 \longrightarrow \mathrm{D} 0-\mathrm{D} 31 \end{aligned}$ <br> Enable memory request <br> Go to PHIOA | $\begin{array}{ll} \text { SXADD } & =\text { FASTA PH7 } \\ \text { CSX set in PH6A } \\ \text { DXC/6 } & =\text { FASTA PH7 } \\ \text { MRQ } & =\text { FASTA PH7 }+\ldots \\ \text { BRPH10 } & =\text { FASTA PH7 }+\ldots \end{array}$ | Subtract one from top-ofstack address. Transfer to D-register <br> To write new top-of-stack address |
| PHIOA <br> T6L | $\begin{aligned} & D 0-D 31+A 0-A 31 \longrightarrow S 0-S 31 \\ & \text { S0-S31 MB0-MB31 } \\ & 1 \longrightarrow L B 31 / 1 \end{aligned}$ <br> Enable memory request | $\begin{array}{ll} \text { SXADD } & =\text { FASTA PH10 }+\ldots \\ M W & =\text { FASTA PH } 10+\ldots \\ (S / \text { LB31/1) } & =\text { FASTA PH } 10+\ldots \\ M R Q & =\text { FASTA PH } 10+\ldots \end{array}$ | Top-of-stack address minus one $\longrightarrow$ effective memory location <br> To address low order half of stack pointer doubleword <br> To write new count word |
| PHIIA T6L | $\begin{aligned} & \mathrm{BO}-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{MBO}-\mathrm{MB31} \\ & \mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{C} 0-\mathrm{A} 31 \end{aligned}$ <br> Enable memory reques $\dagger$ | SXB $=$ FASTA PHII $+\ldots$ <br> MW $=$ FASTA PHII $+\ldots$ <br> AXS $=$ FASTA PHII $+\ldots$ <br> $M R Q / 1$ $=$ FASTA PHII $+\ldots$ | Write updated count word in effective address plus one <br> Updated count word to Aregister to check in PH12A <br> To read next instruction |
|  |  |  | Mnemonic: PLW (08, 88) |

Table 3-107. Pull Word, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH12A T6L | $\begin{aligned} & S W 1=1 \Rightarrow 1 \rightarrow C C 1 \\ & S W 2=1 \Rightarrow 1 \rightarrow C C 3 \\ & \text { If }(A 1-A 15=0), 1 \rightarrow C C 2 \\ & \text { If }(A 17-A 31=0), 1 \rightarrow C C 4 \end{aligned}$ <br> End | $\begin{aligned} & S / C C 1=\text { FASTA PH12 SW1 }+\ldots \\ & S / C C 3=\text { FASTA PH12 SW } 2+\ldots \\ & S / C C 2=\text { FASTA PH12 A0115Z }+\ldots \\ & S / C C 4=\text { FASTA PHI2 Al73IZ }+\ldots \\ & (R / C C)=\text { FASTA PH12 }+\ldots \\ & \text { ENDE }=\text { FASTA PH12 }+\ldots \end{aligned}$ | Indicates space count overflow <br> Indicates word count underflow <br> Space count $=0$ <br> Word count $=0$ |
| PHI4A <br> T\&L | Entered from PH6 if trap has occurred $\text { D0-D31 } \longrightarrow \text { S0-S31 }$ $\text { S0-S31 } \rightarrow \text { A0-A31 }$ <br> Enable memory request <br> Go to PHI2A | $\begin{aligned} \text { SXD } & =\text { FASTA PHI } 4+\ldots \\ \text { AXS } & =\text { FASTA PHI } 4+\ldots \\ M R Q / 1 & =\text { FASTA PH14 }+\ldots \\ \text { BRPHI2 } & =\text { FASTA PH14 }+\ldots \end{aligned}$ | Word and space count $\rightarrow$ A-register to check for zero <br> To read next instruction |

Mnemonic: PLW $(08,88)$

The preparation sequence for the PSM instruction is the same as the general preparation sequence described in the paragraphs entitled Preparation Sequence. The execution sequence for the Push Multiple instruction is described in figure 3-189.

In PH 1 the contents of condition code bits $\mathrm{CCl}-\mathrm{CC} 4$ are transferred to E4-E7 and to D28-D31. A one is set into D27 if the value of CC1-CC4 is zero. Flip-flop NGX is set, and the CS-register is set to ones to prepare for the negation of D in PH2.

The D-register is two's complemented in PH2, and the result is transferred to $\mathrm{B} 16-\mathrm{B} 31$. B16-B31 now contains the word count increment value, and B0-B15 is cleared to zeros.

D16-D31 is upward aligned into A0-A15 in PH3. A0-A16 contains the space count decrement value. In PH4 the contents of $A$ and $B$ are merged (OR-gated), and the result, which is both the space count decrement value and the word count increment value, is transferred to $A$. The count word is read into D in PH5, and in PH6 the count word and the increment/decrement values are added. The modified count word is then transferred into the B-register and is held until PHIlA. During the addition in PH6, carry bit K15 is inhibited to prevent any carry from the word count from affecting the space count addition.

If the space count underflows, SWI is set; if the word count overflows, SW2 is set. Space count underflow and word count overflow can occur simultaneously only if the stack contains 32,768 words. Space count underflow and word count overflow are detected by comparing bit 0 of the original space count in $D$ with the result in sum bus bit 0 , and by comparing bit 16 of the original word count in $D$ with the result in sum bus bit 16 .

If bit 0 of the count word TS (trap on space underflow) is a zero, a trap occurs because of a space count underflow. If bit 16 of the count word TW (trap on word overflow) is a zero, a trap occurs because of a word count overflow. If a trap occurs because of a space count underflow, flip-flop SW1 is not set, since DO must be a one to set SW1 or a zero to cause a trap. If a trap occurs because of a word count overflow, flip-flop SW2 is not set, since D16 must be a zero to cause a trap or a one to set SW2.

It bit 0 of the count word TS (trap on space underflow) is a one and if the space count underflowed, the CPU aborts the PSM instruction by branching to PH14A. If bit 16 of the count word TW (trap on word overflow) is a one and if the word count overflowed, the CPU aborts the PSM instruction by branching to PH14A. If no underflow/overflow occurs, the instruction sequences from PH 6 to PH 7 . In PH 7 a memory request is made to read TSA.

The contents of TSA are read into the D-register during PH8. At PH9 clock one is set into CSI, and in PHIA this one is added to TSA and is transferred to the P-register. The address in the P -register is the address of the first word to be pushed into the stack. A memory request is enabled in PHIA to write the first stack word in PH2A.

The CPU remains in PH2A until the E-register has counted down to one. The R-and P-registers are counted up by one at each iteration of PH2A. When the contents of the E-register have counted down to one, the P-register contains the address of the last word pushed into the stack. This address becomes the new top-of-stack address. The contents of $P$ are transferred to $C$ in PH8A and to D in PH9A. The new modified TSA is written into memory in PHIOA. The modified count word, which has been saved in the Bregister, is written into memory in PHIIA. The modified count word is also transferred to the A-register in PHIIA and is tested in PH12A.

In PH12A the condition bits are set. Flip-flop CCl is set if the space count underflowed in PH6. Flip-flop CC3 is set if the word count underflowed in PH6; flip-flop CC2 is set if the modified space count is currently equal to zero; and flip-flop CC4 is set if the modified word count is zero.

A sequence chart of the Push Multiple instruction is given in table 3-108.

3-236 Pull Multiple (PLM 0A, 8A)
Before the PLM instruction is executed, the condition code must contain a value equal to the number of words to be pulled from the pushdown stack. Since the condition code consists of four flip-flops, CCl-CC4, not more than 16 words can be pulled from a stack during the execution of any one PLM instruction regardless of the stack length. If the condition code is equal to zero, 16 words are pulled from the stack.

During the execution of the PLM instruction, the value of the condition code less one is subtracted from the top of stack address so that the stack words are loaded into private memory in ascending order. For example, if CC is equal to 3 , and the top of stack address is 1517, the stack words will be loaded into private memory in the following order:
(1515) to $R$
(1516) to $R+1$
(1517) to $R+2$


Figure 3-189. Push Multiple, Logic Sequence Diagram (Sheet 1 of 2)


Figure 3-189. Push Multiple, Logic Sequence Diagram (Sheet 2 of 2 )

Table 3-108. Push Multiple, Phase Sequence

| Phase | Function Performed | Signals Involved |  | Comments |
| :---: | :---: | :---: | :---: | :---: |
|  | $1 \rightarrow$ DRQ | $S / D R Q$ | $\begin{aligned} = & \text { FAST EXU + FASTA EXU } \\ & +\ldots \end{aligned}$ | DRQ is set for all execution phases |
| $\begin{aligned} & \mathrm{PHI} \\ & \mathrm{~T} 4 \mathrm{RL} \end{aligned}$ | $\begin{aligned} & \mathrm{CCl}-\mathrm{CC} 4 \rightarrow \mathrm{E} 4-\mathrm{E} 7 \\ & \mathrm{CCl}-\mathrm{CC} 4 \rightarrow \mathrm{D} 28-\mathrm{D} 31 \\ & 1 \rightarrow \mathrm{IEN} \\ & 1 \rightarrow \mathrm{NGX} \\ & 1 \mathrm{~s} \rightarrow \mathrm{CS} 0-\mathrm{CS} 31 \end{aligned}$ | EXCC <br> DXCC <br> S/IEN <br> (S/NGX) <br> CSXI | $\begin{aligned} & =\text { FAST PHI }(\mathrm{O} 4 \mathrm{NO} 5 \mathrm{O} 6)+\ldots \\ & =\text { FAST PHI }(\mathrm{O} 4 \mathrm{NO} 5 \mathrm{O} 6)+\ldots \\ & =\text { FAST PHI }(\mathrm{O} 4 \mathrm{NO} 5 \mathrm{O} 6)+\ldots \\ & =\text { FAST PHI NO2 }+\ldots \\ & =(\mathrm{SNGX})+\ldots \end{aligned}$ | Number of words $\rightarrow$ E-register and D-register <br> Allow interrupts <br> Prepare for negation |
| PH2 T6L | $\begin{aligned} & 1 \longrightarrow \mathrm{G1619/1} \\ & 1 \longrightarrow \mathrm{~K} 15 \\ & -(\mathrm{D} 16-\mathrm{D} 31) \longrightarrow \mathrm{S} 16-\mathrm{S} 31 \\ & 0 \text { 's } \longrightarrow \mathrm{S} 0-\mathrm{S} 15 \\ & \mathrm{SO}-\mathrm{S} 31 \rightarrow \mathrm{~B} 1 \longrightarrow-\mathrm{B} 31 \\ & 1 \longrightarrow \mathrm{NPRX} \\ & 1+\mathrm{CSO}-\mathrm{CS} 31 \\ & 1 \longrightarrow \mathrm{~K} 31 \end{aligned}$ | G1619/1 <br> K15 <br> SXADD/1 <br> BXS <br> (S/NPRX) <br> CSXI | $\begin{aligned} & =\text { FAST PH2 }+\ldots \\ & =\text { G1619/1 } \\ & =\text { NGX NFAMDSF }+\ldots \\ & =\text { FAST PH2 }+\ldots \\ & =\text { FAST PH2 }+\ldots \\ & =(S N P R X)+\ldots \end{aligned}$ | Causes zeros in $\mathrm{BO}-\mathrm{Bl} 5$ <br> Negated word count $\nrightarrow \mathrm{B} 16-\mathrm{B} 31$ <br> (Word count increment value) <br> Prepare for upward alignment |
| $\begin{aligned} & \text { PH3 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \text { D16-D31 S0-S15 } \\ & \text { S0-S15 } \longrightarrow \text { A0-A15 } \\ & 0 ' s \rightarrow \text { D0-D31 } \end{aligned}$ | SXUAH <br> AXS $/ 2$ <br> DX/I | $\begin{aligned} & =\text { FAST PH3 }+\ldots \\ & =\text { FAST PH3 }+\ldots \\ & =\text { FAST PH3 }+\ldots \end{aligned}$ | Upward align negated count $\rightarrow \mathrm{A} 0-\mathrm{Al} 5$ <br> Clear D-register |
| $\begin{aligned} & \mathrm{PH} 4 \\ & \text { TSL } \end{aligned}$ | $\mathrm{BO}-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ <br> $\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31$ <br> Set flip-flop NGX <br> $\mathrm{SO}-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 31$ | SXB <br> SXA <br> (S/NGX) <br> AXS | $\begin{aligned} & =\text { FAST PH } 4+\ldots \\ & =\text { FAST PH } 4+\ldots \\ & =\text { FAST PH } 4 \\ & =\text { FAST PH } 4+\ldots \end{aligned}$ | Effectively $O R$-gates $A$ and $B$ into $A$. A contains increment and decrement values <br> Prepare to negate A-register contents |
|  |  |  | Continued) | Mnemonic: PSM ( $0 \mathrm{~B}, 8 \mathrm{~B}$ ) |

Table 3-108. Push Multiple, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH4 <br> T6L (Cont.) | Enable memory request $1 \longrightarrow L B 31 / 1$ | $\begin{array}{ll} \text { MRQ } & =\text { FAST PH } 4+\ldots \\ (S / L B 31 / 1) & =\text { FAST PH } 4+\ldots \end{array}$ | To read count word <br> Address low order half of stack pointer doubleword |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | $\left\{\begin{array}{l} \mathrm{MBO}-\mathrm{MB31} \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ \mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 1 \rightarrow-\mathrm{D} 31 \\ -(\mathrm{A} 0-\mathrm{A} 31) \longrightarrow \mathrm{S} 0-\mathrm{S} 31 \\ \mathrm{~S} 0-\mathrm{S} 31 \rightarrow \mathrm{~A} 1 \rightarrow-\mathrm{A} 31 \\ 1 \longrightarrow \mathrm{G} 1619 / 1 \\ 1 \longrightarrow \mathrm{~K} 15 \end{array}\right.$ | $\begin{array}{ll} \text { CXMB } & =\text { DGC } \\ \text { DXC } / 6 & =\text { FAST PH5 }+\ldots \\ \text { AXS } & =\text { FAST PH5 O7 }+\ldots \\ \text { G1619/1 } & =\text { FAST PH5 }+\ldots \\ \text { K15 } & =\text { G1619 }+\ldots \\ \text { S/T10L } & =\text { FAST PH5 }+\ldots \end{array}$ | Read count word from effective address plus one <br> Negate A-register |
| $\begin{aligned} & \text { PH6 } \\ & \text { T10L } \end{aligned}$ | $\begin{aligned} & \text { A0-A31 + D0-D31 S0-S31 } \\ & \text { Force } 0 \longrightarrow \text { K15 } \\ & \text { S0-S31 B0-B31 } \\ & \text { D16 NS16 } \Rightarrow 1 \rightarrow \text { SW2 } \\ & \text { D0-NSO } \Rightarrow 1 \rightarrow \text { SW1 } \\ & \text { Trap, or } \\ & \text { Go to PH14A } \\ & 1 \rightarrow \text { PHA } \\ & 1 \rightarrow \text { CXS } \end{aligned}$ |  | Subtract decrement value from space count; add increment value to word count <br> Updated count word to B-register <br> Word count overflow <br> Space count underflow <br> If trap flag $=0$, trap with condition code unchanged <br> If trap flag $=1$, go to PH14A to abort instruction <br> Bit 16 or bit 0 has changed because of an underflow or overflow <br> Preset for PH7 |
| (Continued) $\quad$ Mnemonic: PSM (0B, 8B) |  |  |  |

Table 3-108. Push Multiple, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH7 } \\ & \text { T\&L } \end{aligned}$ | $\begin{aligned} & \mathrm{AO}-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{C} 1 \rightarrow \mathrm{C} 31 \\ & \mathrm{C} 16-\mathrm{C} 31 \rightarrow \mathrm{D} 16-\mathrm{D} 31 \\ & 0^{\prime} \mathrm{S} \rightarrow \mathrm{~A} \rightarrow-\mathrm{A} 31 \end{aligned}$ <br> Enable memory request | $\begin{aligned} & \text { SXA }=\text { FAST PH7 }+\ldots \\ & \text { DXS } / 2=\text { FAST PH7 }+\ldots \\ & \text { AX } / 1=\text { FAST PH7 }+\ldots \\ & M R Q=F A S T P H 7+\ldots \end{aligned}$ | Decrement and increment values $\rightarrow$ D-register <br> Clear A-register <br> To read top-of-stack address |
| $\begin{aligned} & \text { PH8 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \mathrm{MBO}-\mathrm{MB31} \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & 1 \longrightarrow \mathrm{CXS} \end{aligned}$ | $\begin{aligned} \text { CXMB } & =\text { DGC } \\ \text { DXC/6 } & =\text { FAST PH8 }+\ldots \\ S / C X S ~ & =\text { FAST PH8 NOL3 }+\ldots \\ S / T 8 L & =(S / C X S)+\ldots \end{aligned}$ | Read top-of-stack address from effective memory location <br> Preset for PH9 |
| $\begin{aligned} & \text { PH9 } \\ & \text { T } \varepsilon \text { L } \end{aligned}$ | $\begin{aligned} & \mathrm{P} 16-\mathrm{P} 31 \longrightarrow \mathrm{~S} 16-\mathrm{S} 31 \\ & \mathrm{~S} 16-\mathrm{S} 31 \longrightarrow \mathrm{C} 16-\mathrm{C} 31 \\ & 1 \rightarrow \mathrm{CS} 31 \end{aligned}$ <br> Go to PHIA | $\begin{aligned} & \text { SXP }=\text { FAST PH9 }+\ldots \\ & \text { CSXI/8 }=\text { FAST PH9 NOL8 NOL3 }+\ldots \\ & S / P H A=\text { FAST PH9 }+\ldots \\ & \text { BRPHI }=\text { FAST PH9 NOL } 3+\ldots \end{aligned}$ | Effective address $\qquad$ C-register <br> CXS set true in PH8 <br> To add one to top-of-stack address |
| PHIA <br> T6L | $\begin{aligned} & C 0-C 31 \rightarrow D 0-D 31 \\ & \begin{array}{l} \text { A0-A31 + D0-D31 + CSO-CS31 } \\ \text { S16-S31 S31 } \\ R R 0-R R 31 \rightarrow P 16-P 31 \\ R+1 \rightarrow R \end{array} \\ & 0 \rightarrow I O-A 31 \\ & \hline \text { IEN } \end{aligned}$ | $\begin{aligned} \text { DXC } / 6 & =\text { FASTA PHI }+\ldots \\ \text { FASTA } & =\text { FAST PHA }+\ldots \\ \text { SXADD } & =\text { FAST PHI }+\ldots \\ \text { PXS } & =\text { FASTA PHI NO2 }+\ldots \\ \text { AXRR } & =\text { FASTA PHI (O4 NO5 O7) }+\ldots \\ \text { PCTR } & =\text { FASTA PHI O7 }+\ldots \\ \text { S/T8L } & =\text { FASTA PHI }+\ldots \end{aligned}$ | Effective address $\longrightarrow$ D-register <br> Top-of-stack address plus <br> $1 \rightarrow P$-register <br> First data word from private memory $\rightarrow$ A-register <br> Increment R-register for next data word |
| (Continued) |  |  | Mnemonic: PSM ( $08,8 \mathrm{~B}$ ) |

Table 3-108. Push Multiple, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PHIA } \\ & \text { T6L } \\ & \text { (Cont.) } \end{aligned}$ | Enable memory request | $\begin{aligned} & \text { R/IEN }=\text { FASTA PHI }+\ldots \\ & M R Q=\text { FASTA PHI }+\ldots \end{aligned}$ | Disallow interrupts <br> To write first data word |
| $\begin{aligned} & \text { PH2A } \\ & \text { T } \varepsilon \mathrm{L} \end{aligned}$ | $\mathrm{E}=1 \Rightarrow 0^{\prime} \mathrm{s} \rightarrow \mathrm{A} 0-\mathrm{A} 31$, and $1 \rightarrow$ CXS, and Go to PH8 |  | Write first data word into core memory <br> Increment R-register <br> Decrement word count in E-register <br> Request next data word <br> Increment $P$-register <br> Data word from private memory $\rightarrow$ A-register <br> If word count $\neq 1$ <br> If word count $=1$ |
| PH8A <br> T $\delta$ L | $\begin{aligned} & \mathrm{P} 16-\mathrm{P} 31 \longrightarrow \mathrm{~S} 16-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{C} 1 \longrightarrow-\mathrm{C} 31 \end{aligned}$ | SXP $=$ FASTA PH8 $+\ldots$ | Fina! top-of-stack address <br> CXS set true in PH2A |
| PH9A <br> T6L | $\begin{aligned} & \mathrm{D} 0-\mathrm{D} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 16-\mathrm{S} 31 \longrightarrow \mathrm{P} 16-\mathrm{P} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \mathrm{D} 1 \end{aligned}$ <br> Enable memory request | $\begin{aligned} \text { SXD } & =\text { FASTA PH9 }+\ldots \\ \text { PXS } & =\text { FASTA PH9 }+\ldots \\ \text { DXC } / 6 & =\text { FASTA PH9 }+\ldots \\ \text { MRQ } & =\text { FASTA PH9 }+\ldots \end{aligned}$ | Effective address P-register <br> Final top-of-stack address $\longrightarrow \text { D-register }$ <br> To write final top-of-stack address in core memory |
| (Continued) |  |  | Mnemonic: PSM ( $0 \mathrm{~B}, 8 \mathrm{~B}$ ) |

Table 3-108. Push Multiple, Phase Sequence (Cont.)


The value of the condition code is also transferred to the E-register, which counts the number of words to be pulled from the stack.

The preparation sequence for the PLM instruction is the same as the general preparation sequence given under the Preparation Sequence. The execution sequence for the Pull Multiple instruction is described in figure 3-190. In PHI the contents of the condition code bits, $\mathrm{CCl}-\mathrm{CC} 4$, are transferred to E4-E7 and to D28-D31. If the value of CC1CC4 is zero, a one is set into D27. Flip-flop NGX is set and the CS-register is set to ones to prepare for the negation of D in PH 2 .

The D-register is two's complemented in PH2, and the result is transferred to B16-B31. B16-B31 now contain the word count decrement value, and B0-B15 are cleared to zeros.

In PH3, D16-D31 is upward aligned into A0-A15. A0-A16 contains the space count increment value. In PH4 the contents of $A$ and $B$ are merged ( $O R$-gated), and the result, which is both the space count increment value and the word count decrement value, is transferred to $A$. The count word is read into D in PH5. In PH6 the count word and the increment/decrement values are added. The modified count word is then transferred into the B-register and is held there until PH11A. During the addition in PH5, carry bit K15 is inhibited to prevent any carry from the word count from affecting the space count addition.

SW1 is set if the space count overflows; SW2 is set if the word count underflows. Space count overflow and word count underflow can occur simultaneously only if the stack contains 32,768 words. Space count overflow and word count underflow are detected by comparing bit 0 of the original space count in $D$ with the result in sum bus bit 0 and by comparing bit 16 of the original word count in D with the result in sum bus bit 16 .

If bit 0 of the count word TS (trap on space overflow) is a zero, a trap occurs because of a space count overflow. If bit 16 of the count word TW (trap on word underflow) is a zero, a trap occurs because of a word count underflow. If a trap occurs because of a space count overflow, flip-flop SW1 is not set, since D0 must be a one to set SW1 or a zero to cause a trap. If a trap occurs because of a word count underflow, flip-flop SW2 is not set, since D16 must be a zero to cause a trap or a one to set SW2.

If bit 0 of the count word TS (trap on space overflow) is a one and if the space count overflowed, the CPU aborts the PLM instruction by branching to PHI4A. If bit 16 of the count word TW (trap on word underflow) is a one and if the word count underflowed, the CPU aborts the PLM instruction by branching to $\mathrm{PHI4A}$. If no underflow/overflow occurs, the instruction sequences from PH6 to PH7. In PH7 a memory request is made to read TSA.

The contents of TSA are read into the D-register during PH8. In PH9, a one is placed in CS31 to add one to the top-ofstack address in PHIA. The value in Al6 is loaded into CSO-CS15 to extend the sign of the word count decrement value. In PHIA the two's complement of the original contents of the condition codes, less one, is added to TSA. The result is clocked into the P -register. This address in P is the address of the first word to be pulled from the stack. A memory request is made in PHIA to read the first stack word.

The first stack word is read into the D-register in PH3A. If the value in $E$ does not equal one, the $P$-register counts up by one, and the CPU requests the next word from the memory stack as it sequences to PH5A.

The CPU remains in PH5, sequentially reading the stack words until the count in E equals one. During each iteration of PH5A, the E-register counts down by one, and the R - and P -registers count up by one. When the E count reaches one, however, the $P$-register does not count, and the CPU sequences to PH6A. The top-of-stack address in the A-register is transferred to the P -register in PH6A. Signal $M R Q$ is enabled to read the unmodified top-of-stack address from memory. The condition code is again transferred to D28 through D31.

The contents of the D-register are negated and are transferred to the A-register in PH7A. The top-of-stack address is read into the D-register and PHIOA is entered. The decrement value in the $D$-register is added to the top-ofstack address in the A-register, and the modified top-ofstack address is written into the top-of-stack address location in core memory.

In PHIlA the modified count word in the B-register is written into the count word location in memory. The count word is also transferred to the A-register for testing in PH12A.

In PH12A the condition code flip-flops are set. Flip-flop CCl is set if the space count overflowed in PH6; flip-flop CC3 is set if the word count underflowed in PH6. Flip-flop CC2 is set if the modified space count is currently equal to zero; flip-flop CC4 is set if the modified word count is zero.

A sequence chart of the Pull Multiple instruction is given in table 3-109.

## 3-237 Modify Stack Pointer (MSP 13, 93)

The MSP instruction modifies the stack pointer doubleword by the contents of register $R$, bits R16-R31. If bit 16 of $R$ is a zero, the modifier value is a positive number; if bit 16 of $R$ is a one, the modifier value is a negative number. If the modifier value in $R$ is a positive number, the stack pointer doubleword is affected in the following manner: the modifier value increases numerically the TSA and the


Figure 3-190. Pull Multiple, Logic Sequence Diagram (Sheet 1 of 3 )


Figure 3-190. Pull Multiple, Logic Sequence Diagram (Sheet 2 of 3)

$901060 \mathrm{~A} .30^{\circ} 3$
Figure 3-190. Pull Multiple, Logic Sequence Diagram (Sheet 3 of 3)
word count, but decreases the space count. If the modifier value in $R$ is a negative number, the stack pointer doubleword is affected in the following manner: the modifier value decreases numerically the TSA and the word count, but increases the space count. No words are pushed into or pulled from the push-down stack during the execution of an MSP instruction.

The preparation sequence for the MSP instruction is the same as the general preparation sequence described under the Preparation Sequence. The execution sequence for the MSP instruction is described in figure 3-191.

In PHI the least significant half of register $R, R 16-R 31$, is clocked into the A-register, A16-A31. In PH2 the Aregister is two's complemented and is trarisferred to B. Carry K15 is forced true during the two's complement action, which effectively places zeros in B0-B15.

In PH3 the least significant half of $\mathrm{A}, \mathrm{Alo}-\mathrm{A} 31$, is upward aligned into the most significant half of $A, A 0-A 15$, and A16-A31 is cleared to zeros. In PH4 the $A$ - and $B$-registers are merged (OR-gated), and the result is placed in A. In PH5 the A-register is again two's complemented. The Aregister now contains the increment and decrement values that are used to modify the stack pointer doubleword. If the $R$ modifier value is a positive number, A0-A15 contain the decrement value, and A16-A31 contain the increment value. Conversely, if the $R$ modifier value is a negative number, A0-Al5 contain the increment value, and A16A31 contain the decrement value.

In PH5 the count word is read into the D-register, and, in PH6, the modifier value in $A$ is added to the count word in D. The modified count word is transferred to the $B$-register and is saved until PHIlA. If either the space count or the word count overflows or underflows, the CPU either traps (if the corresponding trap flag, bit 0 or bit 16 of the count word, is a zero) or aborts the MSP instruction by branching to PHI4A (if the corresponding trap flag, bit 0 or bit 16 of the count word, is a one).

During the addition in PH6 carry bit K15 is inhibited to prevent any carry from the word count from affecting the space count addition. SWI is set if the space count either overflows or underflows. SW2 is set if the word count either overflows or underflows. Space count underflow or overflow is detected by comparing the original contents of bit 0 of the original count word in $D$ with the modified contents of bit 0 of the sum bus. If they are different, an underflow or overflow has occurred. Word count underflow or overflow is detected by comparing the contents of bit 16 of the original word count in D with the modified contents of bit 16 of the sum bus. If they are different, an underflow or an overflow has occurred.

If bit 0 of the count word TS (trap on space underflow or overflow) is a zero, a trap occurs because of a space count underflow or overflow. If bit 16 of the count word TW (trap on word underflow or overflow) is a zero, a trap occurs because of a word count underflow or overflow.

Table 3-109. Pull Multiple, Phase Sequence


Table 3-109. Pull Multiple, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH4 <br> T6L <br> (Cont.) | Enable memory request $1 \rightarrow L B 31 / 1$ | $\begin{aligned} & \text { NRQ }=\text { FAST PH } 4+\ldots \\ & (S / \text { LB31/1) }=\text { FAST PH } 4+\ldots \end{aligned}$ | To read count word <br> Address low order half of space count doubleword from core memory |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \mathrm{MB} 0-\mathrm{MB31} \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31 \end{aligned}$ | $\begin{array}{ll} \text { CXMB } & =\text { DGC } \\ \text { DXC } / 6 & =\text { FAST PH5 }+\ldots \\ (S / T 10 L / 1) & =\text { FAST PH5 }+\ldots \end{array}$ | Read count word |
| PH6 <br> TIOL | $\text { A0-A31+D0-D31 } \longrightarrow \text { S0-S31 }$ <br> Force $0 \longrightarrow \mathrm{Kl} 5$ <br> $\mathrm{S} 0-\mathrm{S} 31 \rightarrow \mathrm{~B} 0-\mathrm{B} 31$ <br> D16 NS16 $\Rightarrow 1 \rightarrow$ SW2 <br> DO-NSO $\Rightarrow 1 \rightarrow$ SWI <br> Trap, or <br> Go to PHI4A <br> $1 \rightarrow \mathrm{PHA}$ |  | Add increment value to space count; subtract decrement value from word count <br> Updated count word to B-register <br> Word count underflow <br> Space count overflow <br> If trap flag $=0$, trap with condition code unchanged <br> If trap flag $=1$, go to phase 14A to abort instruction <br> Bit 16 or bit 0 has changed because of an underflow or overflow <br> Preset for PH7 |
| PH7 | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{C} 1 \longrightarrow \mathrm{C} 31 \\ & \mathrm{Cl} 6-\mathrm{C} 31 \rightarrow \mathrm{D} 16-\mathrm{D} 31 \end{aligned}$ | $\begin{array}{ll} \text { SXA } & =\text { FAST PH } 7+\ldots \\ \text { DXC } / 2 & =\text { FAST PH } 7+\ldots \end{array}$ | Increment and decrement values $\rightarrow$ D-register <br> Sign in D16 |
|  |  | ( ${ }^{\text {d }}$ | Mnemonic: PLM (0A, 8A) |

Table 3-109. Pull Multiple, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved |  | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH7 } \\ & \text { T8L } \\ & \text { (Cont.) } \end{aligned}$ | $0 \text { 's } \nrightarrow \mathrm{A} 0-\mathrm{A} 31$ <br> Enable memory request | $A X / 1$ <br> MRQ | $\begin{aligned} & =\text { FAST PH } 7+\ldots \\ & =\text { FAST PH7 }+\ldots \end{aligned}$ | To read top-of-stack address |
| $\begin{aligned} & \text { PH8 } \\ & \text { T6L } \end{aligned}$ | $\left\{\begin{array}{l} \mathrm{MBO}-\mathrm{MB31} \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \mathrm{D} 1 \longrightarrow \mathrm{D} 31 \\ \mathrm{D} 0-\mathrm{D} 31 \longrightarrow \mathrm{SO-S31} \\ \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{~A} 1 \longrightarrow-\mathrm{A} 31 \\ 1 \longrightarrow \mathrm{CXS} \end{array}\right.$ | CXMB <br> DXC/6 <br> SXD <br> AXS <br> S/CXS <br> S/T8L | $\begin{aligned} = & \text { DGC } \\ = & \text { FAST PH8 }+\ldots \\ = & \text { FAST PH8 }+\ldots \\ = & \text { FAST PH8 }(\mathrm{OLA}+\mathrm{OL} 3) \\ & +\ldots \\ = & \text { FAST PH8 NOL3 }+\ldots \\ = & (S / C X S)+\ldots \end{aligned}$ | Read top-of-stack address into D-register via C-register <br> Word count decrement value <br> Preset for PH9 |
| $\begin{aligned} & \text { PH9 } \\ & \text { T8L } \end{aligned}$ | $\left\{\begin{array}{l} \mathrm{Pl} 6-\mathrm{P} 31 \longrightarrow \mathrm{~S} 16-\mathrm{S} 31 \\ \mathrm{~S} 16-\mathrm{S} 31 \longrightarrow \mathrm{Cl}-\mathrm{C} 31 \\ 1 \longrightarrow \mathrm{CS} 31 \\ \mathrm{Al} 6 \rightarrow \mathrm{CS} 0-\mathrm{CS} 15 \\ 1 \longrightarrow \mathrm{PHA} \\ \text { Go to PHIA } \end{array}\right.$ | SXP <br> CSXI/8 <br> CSXI/3 <br> S/PHA <br> BRPHI | $\begin{aligned} & =\text { FAST PH9 }+\ldots \\ & =\text { FAST PH9 NOL8 NOL3 }+ \\ & =\text { FAST PH9 Al } 6+\ldots \\ & =\text { FAST PH9 }+\ldots \\ & =\text { FAST PH9 NOL3 }+\ldots \end{aligned}$ | Effective address $\longrightarrow$ C-register <br> CXS set true in PH8 <br> For two's complement <br> For sign extension in word count decrement value |
| PHIA <br> T6L | $\left\{\begin{array}{l} C 0-C 31 \rightarrow \text { D0-D31 } \\ \xrightarrow{\text { A0-A31+D0-D31+CSO-CS31 }} \text { S0-S31 } \\ \text { S16-S31 } \mathrm{C} \text { P16-P31 } \end{array}\right.$ <br> Enable memory request <br> Set flip-flop T8L | DXC/6 <br> FAST <br> SXADD <br> PXS <br> MRQ <br> S/T8L | $\begin{aligned} & =\text { FASTA PHI }+\ldots \\ & =\text { FAST PHA }+\ldots \\ & =\text { FASTA PHI }+\ldots \\ & =\text { FASTA PHI NO2 }+\ldots \\ & =\text { FASTA PHI }+\ldots \\ & =\text { FASTA PHI }+\ldots \end{aligned}$ | Effective address $\longrightarrow$ D-register <br> Top-of-stack address minus decrement value $\rightarrow \mathrm{P}$ register. $P$-register now contains address of first word to be pulled <br> To read first data word from core memory |
|  |  |  | (Continued) | Mnemonic: PLM (0A, 8A) |

Table 3-109. Pull Multiple, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH1A } \\ & \text { T6L } \\ & \text { (Cont.) } \end{aligned}$ | $0 \longrightarrow \mathrm{IEN}$ <br> Go to PH3A | $\begin{aligned} \mathrm{R} / \mathrm{IEN}= & \text { FASTA PHI }+\ldots \\ \text { BRPH } 3= & \text { FASTA PHI (O4 NO5 NO7) } \\ & +\ldots \end{aligned}$ | Disable interrupt |
| $\begin{aligned} & \text { PH3A } \\ & \text { T8L } \end{aligned}$ | $\begin{aligned} & \mathrm{MB0}-\mathrm{MB31} \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & \mathrm{D} 0-\mathrm{D} 31 \longrightarrow \mathrm{~S} 1 \longrightarrow \mathrm{~S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{~A} 1 \longrightarrow \mathrm{~A} 31 \\ & \mathrm{P}+1 \longrightarrow \mathrm{P} \end{aligned}$ <br> Enable memory request <br> Go to PH5A | $\begin{aligned} \text { CXMB } & =\text { DGC } \\ \text { DXC } / 6 & =\text { FASTA PH3 }+\ldots \\ \text { SXD } & =\text { FASTA PH3 }+\ldots \\ \text { AXS } & =\text { FASTA PH3 }+\ldots \\ \text { PCTP1 } & =\text { FASTA PH3 N(E=1) OLA }+\ldots \\ \text { MRQ } & =\text { FASTA PH3 N(E=1) OLA }+\ldots \\ \text { S/T8L } & =\text { FASTA PH3 }+\ldots \\ \text { BRPH5 } & =\text { FASTA PH3 CLA }+\ldots \end{aligned}$ | Read data word. Place in D-register <br> Effective address $\rightarrow$ A-register <br> Increment P -register <br> Request for next data word |
| $\begin{aligned} & \text { PH5A } \\ & \text { T8L } \end{aligned}$ | $\begin{aligned} & \mathrm{MB} 0-\mathrm{MB31} \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \text { D0-D31 } \\ & \mathrm{D} 0-\mathrm{D} 31 \longrightarrow \text { S0-S31 } \\ & \text { S0-S31 } \longrightarrow \text { RW0-RW31 } \\ & \mathrm{R}+1 \longrightarrow \mathrm{R} \\ & \mathrm{E}-1 \longrightarrow \mathrm{E} \\ & \mathrm{E}=1 \text { or } 2 \Rightarrow \mathrm{P}+1 \longrightarrow \mathrm{P} \end{aligned}$ <br> If $\mathrm{E} \neq \mathrm{l}$, remain in PH5A <br> Enable memory request <br> If $\mathrm{E}=1$, go to PH 6 A | $\begin{aligned} \mathrm{CXMB}= & \text { DGC } \\ \mathrm{DXC} / 6= & \text { FASTA PH5 }+\ldots \\ \mathrm{SXD}= & \text { FASTA PH5 }+\ldots \\ \mathrm{RW}= & \text { FASTA PH5 }+\ldots \\ \text { PCTR }= & \text { FASTA PH5 }+\ldots \\ \text { MCTEI }= & \text { FASTA PH5 }+\ldots \\ \text { PCTPI }= & \text { FASTA PH5 } \mathrm{N}(\mathrm{E}=1 \text { or } 2) \mathrm{OLA} \\ & +\ldots \\ \mathrm{BRPH} 5= & \text { FASTA PH5 } \mathrm{N}(\mathrm{E}=1) \mathrm{OLA}+\ldots \\ \mathrm{MRQ}= & \text { FASTA PH5 } \mathrm{N}(\mathrm{E}=1 \text { or } 2) \mathrm{OLA} \\ & +\ldots \\ \mathrm{S} / \mathrm{PH} 6= & \text { PH5 NBR }+\ldots \\ \mathrm{S} / \mathrm{T} 8 \mathrm{C}= & \text { FASTA PH5 }+\ldots \end{aligned}$ | Read next data word from memory <br> Load previous data word $\qquad$ private memory register $R$ <br> Increment R-register <br> Decrement word count <br> Increment $P$-register <br> To read next data word |
| (Continued) |  |  | Mnemonic: PLM (0A, 8A) |

Table 3-109. Pull Multiple, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH6A T8L | $\begin{aligned} & \mathrm{CCl}-\mathrm{CC} 4 \rightarrow \mathrm{D} 28-\mathrm{D} 31 \\ & \mathrm{CC}=0 \Rightarrow 1 \rightarrow \mathrm{D} 27 \\ & 1 \rightarrow \mathrm{NGX} \\ & \mathrm{~A} 0-\mathrm{A} 31 \longrightarrow \mathrm{~S} 1 \longrightarrow \mathrm{~S} 31 \\ & \mathrm{~S} 16-\mathrm{S} 31 \rightarrow \mathrm{P} 16-\mathrm{P} 31 \\ & 1 \mathrm{~s} \rightarrow \mathrm{CS} 0-\mathrm{CS} 31 \\ & 0 \mathrm{~s} \rightarrow \mathrm{~A} 0-\mathrm{A} 31 \end{aligned}$ <br> Enable memory request | DXCC $=$ FASTA PH6 OLA NO2 <br>  $+\ldots$ <br> D27XI $=$ FASTA PH6 OLA CCZ <br>  $+\ldots$ <br> S/NGX $=$ FASTA PH6 OLA NO2 <br>  $+\ldots$ <br> SXA $=$ FASTA PH $6+\ldots$ <br> PXS $=$ FASTA PH6 $+\ldots$ <br> CSXI $=$ FASTA PH6 $+\ldots$ <br> AX $/ 1=$ FASTA PH6 $+\ldots$ <br> MRQ $=$ FASTA PH 6 OLA $+\ldots$ <br> S/T8L $=$ FASTA PH $6+\ldots$ | Word count back into D-register <br> Zero word count $\Rightarrow$ Pull 16 words <br> Prepare for negation <br> Effective address to P-register <br> Prepare for negation <br> To read top-of-stack address |
| PH7A <br> T8L | $\begin{aligned} & -(\mathrm{D} 0-\mathrm{D} 31) \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{~A} 1 \longrightarrow-\mathrm{A} 31 \\ & \mathrm{MB} 0-\mathrm{MB} 31 \longrightarrow \mathrm{C} 1 \longrightarrow-\mathrm{C} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \mathrm{D} 1 \longrightarrow \mathrm{D} 31 \end{aligned}$ <br> Enable memory request <br> Go to PHIOA | $\begin{array}{ll} \text { SXADD } & =\text { FASTA PH7 }+\ldots \\ \text { AXS } & =\text { FASTA PH7 OLA }+\ldots \\ \text { CXMB } & =\text { DGC } \\ \text { DXC/6 } & =\text { FASTA PH7 }+\ldots \\ \text { MRQ } & =\text { FASTA PH7 }+\ldots \\ \text { BRPHIO } & =\text { FASTA PH7 }+\ldots \end{array}$ | Negate word count in Dregister. Transfer to Aregister <br> Read top-of-stack address <br> To write new top-of-stack address |
| PHIOA T6L | $\begin{aligned} & D 0-D 31+A 0-A 31 \longrightarrow S 0-S 31 \\ & S 0-S 31 \longrightarrow M B 0-M B 31 \\ & 1 \longrightarrow L B 31 / 1 \end{aligned}$ <br> Set memory request | $\begin{array}{ll} \text { SXADD } & =\text { FASTA PH } 10+\ldots \\ M W & =\text { FASTA PH } 10+\ldots \\ (S / L B 31 / 1) & =\text { FASTA PH } 10+\ldots \\ M R Q & =\text { FASTA PH } 10+\ldots \end{array}$ | Update and write top-ofstack address into core memory <br> Address low order half of stack pointer doubleword <br> To write new count word |
| PHIIA T6L | B0-B31 $\longrightarrow$ S0-S31 | SXB $\quad=$ FASTA PHII $+\ldots$ | Write updated count word in effective location plus one |
|  |  | (Continued) | Mnemonic: PLM (0A, 8A) |

Table 3-109. Pull Multiple, Phase Sequence (Cont.)



Figure 3-191. Modify Stack Pointer, Logic Sequence Diagram (Sheet 1 of 2)


Figure 3-191. Modify Stack Pointer, Logic Sequence Diagram (Sheet 2 of 2)

If a trap occurs because of a space count underflow or overflow, flip-flop SWI cannot be set, since DO must be a one to set SWI or a zero to cause a trap. If a trap occurs because of a word count underflow or overflow, flip-flop SW2 will not be set because D16 must be a zero to cause a trap or a one to set SW2. If bit 0 of the count word TS (trap on space underflow or overflow) is a one and if the space count underflowed or overflowed, the CPU aborts the MSP instruction by branching to PHI4A. If bit 16 of the count word TW (trap on word underflow or overflow) is a one and if the word count underflowed or overflowed, the CPU aborts the MSP instruction by branching to PHI 4 A . If no space count or word count underflow or overflow occurs, the instruction sequences from PH 6 to PH 7 . In PH 7 a memory request is made to read TSA.

The contents of TSA are read into the D-register during PH8. In PHIOA the contents of D (which contains TSA) and the contents of $A$ (which contains the positive or negative modifier value) are added. The result, which is the modified TSA, is written into the top-of-stack address in memory.

During PHIIA the contents of $B$ (which contains the modified count word) are written into memory. The modified
count word is also transferred into the A-register in PHIIA for testing in PHI2A.

The condition code bits are set in PHI2A. CCl is set if the space count underflowed or overflowed in PH6; CC3 is set if the word count underflowed or overflowed in PH6; CC2 is set if the modified space count is currently equal to zero; and CC4 is set if the modified word count is currently equal to zero.

A sequence chart of the Modify Stack Pointer instruction is given in table 3-110.
3-238 Execute (EXU 67, F7)

The reference address field of the EXU instruction points to the address of an operand. This operand is taken to be the next instruction to be executed by the CPU following the EXU instruction. If the subject instruction is not a branch (or another EXU), the next instruction to be executed is the instruction that normally would follow the initial EXU instruction. If the subject instruction is located in a memory area under memory protection, the memory protection feature is disabled for that instruction access only.

XDS 901060

Table 3-110. Modify Stack Pointer, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | $1 \rightarrow$ DRQ | $\begin{aligned} \text { S/DRQ }= & \text { FAST EXU }+ \text { FASTA EXU } \\ & +\ldots \end{aligned}$ | DRQ is set for all execution phases |
| $\begin{aligned} & \text { PHI } \\ & \text { T4RL } \end{aligned}$ | $\begin{aligned} & \text { RR16-RR31 } \rightarrow \text { A16-A31 } \\ & 1 \rightarrow \text { NGX } \\ & 1 ' s \rightarrow \text { CS0-CS31 } \end{aligned}$ | $\begin{aligned} \text { AXRR } / 2 & =\text { FAST PHI OL3 }+\ldots \\ (S / \text { NGX }) & =\text { FAST PHI NO2 }+\ldots \\ \text { CSXI/20 } & =(\mathrm{S} / \text { NGX })+\ldots \end{aligned}$ | Modify value to A |
| $\begin{aligned} & \text { PH2 } \\ & \text { T6L } \end{aligned}$ | $-(\mathrm{A} 0-\mathrm{A} 31) \rightarrow \mathrm{B} 16-\mathrm{B} 31$ $\begin{aligned} & 1 \nrightarrow \text { NPRX } \\ & 1 \text { 's } \not C 0-C S 31 \end{aligned}$ | $\begin{array}{ll} \text { BXS } & =\text { FAST PH2 }+\ldots \\ \text { G1619/1 } & =\text { FAST PH2 }+\ldots \\ \text { K15 } & =\text { G1619 } \\ \text { S/NPRX } & =\text { FAST PH2 }+\ldots \\ \text { CSX1/20 } & =(S / N P R X)+\ldots \end{array}$ | Zeros to $\mathrm{B0} 0 \mathrm{~B} 15$ |
| $\begin{aligned} & \text { PH3 } \\ & \text { T6L } \end{aligned}$ | Upward align halfword, $\begin{aligned} & \mathrm{S} 0-\mathrm{S} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 31 \\ & 0 ' \mathrm{~s} \rightarrow \mathrm{D} 0-\mathrm{D} 31 \end{aligned}$ | $\begin{array}{ll} \text { SXUAH } & =\text { FAST PH3 }+\ldots \\ \text { AXS } / 2 & =\text { FAST PH3 }+\ldots \\ \text { DX } / 1 & =\text { FAST PH3 }+\ldots \end{array}$ | Results in A16-A31 $\rightarrow$ A0-Al5, and 0 's $\rightarrow$ A16-A31 |
| $\begin{aligned} & \text { PH4 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \mathrm{B0} 0-\mathrm{B} 31 \text { or } \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \rightarrow \mathrm{NGX} \\ & 1 \rightarrow \mathrm{LB} 31 / 1 \end{aligned}$ <br> Enable memory request | $\begin{array}{ll} \text { SXB } & =\text { FAST PH } 4+\ldots \\ \text { SXA } & =\text { FAST PH } 4+\ldots \\ (S / N G X) & =\text { FAST PH } 4+\ldots \\ (S / L B 31 / 1) & =\text { FAST PH } 4+\ldots \\ M R Q & =\text { FAST PH } 4+\ldots \end{array}$ | Combine positive and negative halves of modifier in A <br> To read count word |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & \substack{-(\mathrm{A} 0-\mathrm{A} 31) \rightarrow \mathrm{A}) \\ \rightarrow \mathrm{A} 31} \\ & 1 \longrightarrow \mathrm{~S} 31 \\ & \rightarrow \mathrm{G} 1619 / 1 \end{aligned}$ | $\begin{array}{ll} \text { DXC } / 6 & =\text { FAST PH5 }+\ldots \\ \text { AXS } & =\text { FAST PH5 O7 }+\ldots \\ \text { G1619/1 } & =\text { FAST PH5 }+\ldots \\ \text { K15 } & =\text { G1619 } \\ (S / T 10 L) & =\text { FAST PH5 }+\ldots \end{array}$ | Read count word <br> Negate A-register |
|  |  | (Continued) | Mnemonic: MSP (13, 93) |

Table 3-110. Modify Stack Pointer, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH6 <br> T10L | $\text { A0-A31+D0-D31 } \longrightarrow \text { S0-S31 }$ <br> Force $0 \longrightarrow \mathrm{~K} 15$ $\mathrm{S} 0-\mathrm{S} 31 \rightarrow \mathrm{~B} 0-\mathrm{B} 31$ <br> D16 NS16 $\Rightarrow 1 \rightarrow$ SW2, or <br> DO NSO $\Rightarrow 1 \rightarrow$ SW1 <br> Trap, or <br> Go to PHI4A $1 \rightarrow \mathrm{PHA}$ <br> $1 \rightarrow C X S$ |  | Add/subtract to space count; subtract/add to word count <br> Modified count word to B-register <br> Word underflow or overflow <br> Space underflow or overflow <br> If trap flag $=0$ <br> If trap flag $=1$ <br> Bit 16 or bit 0 has changed because of an underflow or overflow |
| $\begin{aligned} & \mathrm{PH} 7 \\ & \mathrm{~T} 8 \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{AO}-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{C} 1 \longrightarrow \mathrm{C} 31 \\ & \mathrm{C} 16-\mathrm{C} 31 \rightarrow \mathrm{D} 16-\mathrm{D} 31 \\ & 0 ' \mathrm{~s} \rightarrow \mathrm{~A} 0-\mathrm{A} 31 \end{aligned}$ <br> Enable memory request | $\begin{array}{ll} \text { SXA } & =\text { FAST PH7 }+\ldots \\ \text { DXC } / 2= & \text { FAST PH7 }+\ldots \\ \text { AX/1 } & =\text { FAST PH } 7+\ldots \\ & \cdot \\ \text { MRQ } & =\text { FAST PH } 7+\ldots \end{array}$ | CXS set true in PH6 <br> To read TSA |
| $\begin{aligned} & \text { PH8 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \mathrm{C} 0-\mathrm{C} 31 \rightarrow \text { D0-D31 } \\ & \text { D0-D31 } \\ & \mathrm{A} 0-\mathrm{A} 31 \end{aligned} \mathrm{SO-S31} \mathrm{\rightarrow} \mathrm{~S}$ | $\begin{aligned} \text { DXC } / 6 & =\text { FAST PH8 }+\ldots \\ \text { SXD } & =\text { FAST PH8 }+\ldots \\ \text { AXS } & =\text { FAST PH8 (OLA }+ \text { OL3 }) \end{aligned}$ | Read TSA <br> Increment/decrement values to A-register |
| $\begin{aligned} & \text { PH9 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \begin{array}{l} \mathrm{P} 16-\mathrm{P} 31 \longrightarrow \mathrm{~S} 16-\mathrm{S} 31 \longrightarrow \\ \mathrm{C} 16-\mathrm{C} 31 \end{array} \\ & 1 \rightarrow \mathrm{PHA} \end{aligned}$ <br> $\mathrm{Al} 6 \rightarrow \mathrm{CSO}-\mathrm{CS} 15$ <br> Enable memory request | $\begin{array}{ll} \text { SXP } & =\text { FAST PH9 }+\ldots \\ \text { S/PHA } & =\text { FAST PH9 }+\ldots \\ \text { CSXI/3 } & =\text { FAST PH9 AI } 6+\ldots \\ \text { MRQ } & =\text { FAST PH9 OL3 }+\ldots \end{array}$ | Hold TSA address in C <br> For sign extension To write TSA |
|  |  | (Continued) | Mnemonic: MSP ( 13,93 ) |

Table 3-110. Modify Stack Pointer, Phase Sequence (Cont.)


The EXU instruction can be indexed, indirectly addressed, or both. The normal preparation sequence, as well as the sequencing for all modes and conditions of the EXU instruction, is described under Preparation Sequence.

The operand (the next instruction to be executed) is loaded into the D-register at PHI clock. DRQ is set, and the CPU sequences to PH 2 .

During PH2 of the EXU instruction, ENDE is enabled, which causes the normal action of transferring C0-C31 to D0-D31, $\mathrm{C} 0-\mathrm{C} 7$ to $\mathrm{Ol}-\mathrm{O} 7$, and $\mathrm{C} 8-\mathrm{C} 11$ to R28-R31. The normal action of permitting the $P$-register to increase its count by one is suppressed; thus, P contains an address one greater than the address of the EXU instruction. The $P+1$ count and the memory protection trap are disabled.

A sequence chart of the Execute instruction is given in table 3-111.

## 3-239 Branch on Conditions Set (BCS 69, E9)

The Branch on Conditions Set instruction forms the logical product of the R-field of the instruction word and the current condition code. If the logical product is nonzero, the branch condition is satisfied and the program proceeds with the instruction pointed to by the effective address of the instruction. If the logical product is zero, the branch condition is unsatisfied, and the instruction execution proceeds with the next instruction in sequence.

The execution sequence for the BCS instruction begins with PH 3 . During the preparation sequence the contents of the reference address are read into the D-register. In PH3 the D-register holds the next instruction to be performed if a branch is to be executed. Whether or not a branch is to be made depends on the result of the comparison of bits R28R31 with bits $\mathrm{CCl}-\mathrm{CC} 4$. The BCS instruction ends at PH 3 if one bit of R28-R31 and the corresponding bit of the condition code compares.

A trap occurs if the CPU is denied access to the branch address because of a nonexistent memoryaddress or because of a memory protection violation. In this case, the trap occurs, and the return address must be taken from the $Q$-register. Flip-flop $B R Q$ is set to ensure that the return address is taken from $Q$ during the trap operation.

If no bits of the R-field compare with the corresponding bits of the condition code, the CPU sequences to PH4. $M R Q / 1$ is enabled in PH3 if no branch condition exists and the address of the next instruction is taken from the $Q$ register and is transferred into the P -register.

Phase PH5 is the final phase of the BCS instruction if no branch occurred. If the R-field of the BCS instruction contains all zeros, the term (R.CC) cannot come true and the BCS instruction acts as a no-operation type of instruction.

A sequence chart of the Branch on Conditions Set instruction is given in table 3-112.

3-240 Branch on Conditions Reset (BCR 68, E8)
The Branch on Conditions Reset instruction forms the logical product of the R-field of the instruction word and the current condition code. If the logical product is zero, the branch condition is satisfied, and the instruction proceeds with the instruction pointed to by the effective address of the instruction. If the logical product is nonzero, the branch condition is unsatisfied, and instruction execution proceeds with the next instruction in the sequence.

The preparation sequence for the $B C R$ instruction is the same as that described under Preparation Sequence, except that the instruction branches from PRE2 to PH3 for the first execution phase. During the preparation sequence, the contents of the reference address are read into the Dregister. In PH3, the D-register holds the next instruction to be performed if a branch is to be made. Whether or not a branch is to be made depends on the result of the comparison of bits R28 through R31 with bits CC1 through CC4. The logical product of each pair of corresponding bits is taken in the two registers. If all of the results are zero, signal ENDE is generated and the instruction in the Dregister is executed. This is, in effect, a branch operation.

A trap occurs if the CPU is denied access to the branch address either because of a nonexistent memory address or because of a memory protection violation. In case of a trap, the return address must be taken from the $Q$-register. Flip-flop $B R Q$ is set to ensure that, during the trap operation, the return address is taken from the $Q$-register.

If the logical product of any two corresponding bits is a one, the instruction goes to PH 4 to access the next instruction in sequence. Signal $M R Q / 1$ is enabled in $P H 3$ if no branch condition exists, and the address of the next instruction is taken from the $Q$-register and is transferred to the P -register. If no branch has occurred, PH 5 is the final phase of the instruction.

If the R-field of the instruction contains all zeros, the instruction acts as an unconditional branch instruction.

A sequence chart of the Branch on Conditions Reset instruction is given in table 3-113.

## 3-241 Branch on Incrementing Register (BIR 65, E5)

The BIR instruction counts up the private memory register $R$ by one. If $R$ is negative after the $R$-register has been counted up, the contents of the reference address location are taken as the next instruction. If $R$ is not negative after the $R$-register has been counted up, the next instruction is taken from the location whose address is one greater than the address of the BIR instruction address.

The preparation sequence for the BIR instruction is the same as that described under Preparation Sequence, except that the CPU branches from PRE2 to PH2 for the first execution phase. Also during PRE2, the CS-register is set to equal a one to prepare for the incrementing action in PH 2 .

Table 3-111. Execute, Phase Sequence


Table 3-112. Branch on Conditions Set, Phase Sequence


Table 3-113. Branch on Conditions Reset, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PRE2 | Go to PH3 and enable T4RL | BRPH3 $=$ FABC $($ PRE2 NIA $) / 1$ <br>  $+\ldots$ <br> FABC $=$ OU6 O4 NO5 NO6 <br> T4RL $=$ N FABC $($ PRE2 NIA $) / 1$ <br>  $+\ldots$ |  |
| PH3 <br> T4RL | Enable ENDE if branch <br> If trap and branch, set $B R Q$ <br> If branch only, go to PRE1 <br> If no branch, $1 \longrightarrow M R Q / 1$ <br> Suppress protect fail |  | Return address is in Qregister |
| $\begin{gathered} \text { PH4 } \\ \text { T6L } \end{gathered}$ | $\begin{aligned} & 1 \not P D R Q \\ & Q \not P \end{aligned}$ | $\begin{array}{ll} S / D R Q & =F A B C P H 4+\ldots \\ P X Q & =M R Q / 1+\ldots \end{array}$ | If no branch, next instruction address is in Q-register |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | End of no branch | ENDE $\quad=\mathrm{FABC}$ PH5 $+\ldots$ |  |
|  |  |  | Mnemonic: $\operatorname{BCR}(68, \mathrm{E} 8)$ |

In PH 2 the A-register, which contains the contents of private memory register $R$, is added to the contents of the CSregister which contains +1 . The result, ( $R$ ) + 1, is clocked back into the $A$-register. The $D$-register contains zeros during this addition and does not pick up the contents of the branch instruction until the PH 3 clock.

In PH3 the contents of A are stored back in register R unless the branch location is either nonexistent or memory protected. If the contents of the A-register are negative, PH3 is the final phase of the BIR instruction, and the data clocked from the $C$-register into $D$ at the next clock pulse is the next instruction to be executed.

If the contents of the A-register are not negative, or are equal to zero, ENDE cannot come true during PH3, and the branch does not occur. $\mathrm{MRQ} / 1$ is enabled in PH 3 , and the CPU sequences to PH4. In PH4, DRQ is set, and the CPU goes to PH5 for the end of the BDR sequence.

A sequence chart of the Branch on Incrementing Register instruction is given in table 3-114.

## 3-242 Branch on Decrementing Register (BDR 64, E4)

The BDR instruction counts down the private memory register $R$ by one. If, after the R-register has been counted down, $R$ is positive, but not zero, the contents of the reference address location are taken as the next instruction. If, after the R -register has been counted down, R is negative or is equal to zero, the next instruction is taken from the location whose address is one greater than the address of the BDR instruction address.

The preparation sequence for the $B D R$ instruction is the same as that described under Preparation Sequence, except that the CPU branches from PRE2 to PH2 for the first execution phase. Also during PRE2, the CS-register is set to all ones to prepare for the decrementing action in PH2.

In PH2 the A-register which contains the contents of private memory register R is added to the contents of the CS-register, which contains -1 . The result, $(R)-1$, is clocked back into the A-register. The D-register contains zeros during this addition and does not pick up the contents of the branch instruction until the PH3 clock.

In PH3 the contents of A are stored back into register R unless the branch location is either nonexistent or memory protected. If the contents of the A-register are positive, but are not equal to zero, PH3 is the final phase of the BDR instruction, and the data clocked from the C-register into $D$ at the next clock pulse is the next instruction to be execuled.

If the contents of the A-register are negative, ENDE cannot come true during PH 3 and the branch does not occur. MRQ/1 is enabled in PH3, and the CPU sequences to PH 4 . In PH 4 , DRQ is set, and the CPU goes to PH5 for the end of the BDR execution sequence.

A sequence chart of the Branch on Decrementing Register instruction is given in table 3-115.

## 3-243 Branch and Link (BAL 6A, EA)

The BAL instruction loads the address of the BAL instruction plus one into register $R$ and transfers the effective address into the $P$-register. The next instruction to be executed after BAL is the instruction located in the effective address of the BAL instruction.

The preparation sequence for the BAL instruction is the same as that described under Preparation Sequence.

In PH1 the effective address of the BAL instruction is transferred into the $P$-register from $Q$, and the current instruction address plus one is transferred from the Q -register into P. The CPU sequences from PHI to PH 2 .

In PH2 the current instruction address in the P -register is transferred to register $R$. The $Q$-register, which contains the effective address, is clocked into $P$. This is the address to which the CPU unconditionally branches. The current instruction address plus one is also transferred from $P$ to $Q$, since a trap occurs if the branch location in the $P$-register is either nonexistent or memory protected. $M R Q / 1$ is enabled in PH2 to read the next instruction.

PH3 is the final phase of the instruction. Flip-flop BRQ is set in the event of a trap. This indicates that the return address is in the $Q$-register.

A sequence chart of the Branch and Link instruction is given in table 3-116.

## 3-244 Call 1 (CALI, 04), Call 2 (CAL2, 05), Call 3 (CAL3, 06), Call 4 (CAL4, 07)

The Call instructions initiate programmed trap operations. The instructions CALI, CAL2, CAL3, and CAL4 trap to locations $48,49,4 A$, and $4 B$, respectively. Normally, each of these trap locations contains an exchange program status doubleword instruction.

All Call instructions can be indirectly addressed, indexed, or both. The normal preparation sequence, as well as the sequencing for all modes and all conditions, is described under Preparation Sequence.

In PHI the contents of the R-register (R-field of the Call instruction word) are transferred to flip-flops TRACCITRACC4. These flip-flops hold this data until it is used during the XPSD instruction following the trap sequence. The flip-flops TR28, TR30, and TR31 are set in different configurations, depending on whether the instruction is CALI, CAL2, CAL3, CAL4. The flip-flops TR28, TR30, and TR31 are used during the trap sequence to determine the trap address $48,49,4 \mathrm{~A}$, or 4 B . Flip-flop TRAP is set c.t the PHI clock.

Table 3-114. Branch on Incrementing Register, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PRE2 | RR0-RR31 $\rightarrow$ A0-A31 <br> $1 \rightarrow$ CS31 <br> Go to PH2 | AXRR $=$ FABR $($ PRE2 NIA $) / 1$ <br>  $+\ldots$ <br> CSX1/8 $=$ FABR $($ PRE2 NIA $) / 1$ <br>  $+\ldots$ <br> BRPH2 $=$ FABR $($ PRE2 NIA $) / 1$ <br>  $+\ldots$ <br> T4RL $=$  <br>  $=$ FABR (PRE2 NIA) $/ 1$ <br>  $+\ldots$ | Read register $\text { CS-register }=+1$ |
| PH2 | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{CSO}-\mathrm{CS} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \rightarrow \mathrm{~A} 1 \rightarrow \mathrm{~A} 31 \\ & 1 \rightarrow \mathrm{DRQ} \\ & 1 \longrightarrow \mathrm{~T} 10 \mathrm{~L} \end{aligned}$ | SXADD $=$ FABR PH2 $+\ldots$ <br> AXS $=$ FABR PH2 $+\ldots$ <br> S/DRQ $=F A B R P H 2+\ldots$ <br> S/T10L $=F A B R P H 2+\ldots$ | $\begin{aligned} & \mathrm{A}+1 \underset{\text { this time })}{ } \mathrm{A}(\mathrm{D}=0 \text { at } \end{aligned}$ |
| PH3 | $\underset{\substack{\text { A0-A31 } \\ \text { RW0-RW31 }}}{ } \text { SO-S31 }$ <br> Branch if $A$ is negative <br> $\mathrm{C} 0-\mathrm{C} 31 \rightarrow$ D0-D31 <br> $1 \rightarrow B R Q$ <br> $1 \longrightarrow M R Q / 1$ <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Suppress Protect Fail |  | $\text { Disable } A \longrightarrow R W \text { if trap }$ <br> Next instruction to Dregister |
| PH4 | $1 \rightarrow$ DRQ | S/DRQ $\quad=$ FABR PH4 $+\ldots$ |  |
| PH5 | End of no branch | ENDE $\quad=$ FABR PH5 + $\ldots$ |  |
|  |  |  | Mnemonic: BIR (65, E5) |

Table 3-115. Branch on Decrementing Register, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PRE2 | $\begin{aligned} & \text { RRO-RR31 } \nrightarrow \text { A0-A31 } \\ & 1 \text { 's } \not C \text { CSO-CS31 } \end{aligned}$ <br> Go to PH2 |  | Read register <br> CS-register $=-1$ |
| PH2 | $\begin{aligned} & \begin{array}{l} \mathrm{A} 0-\mathrm{A} 31+\mathrm{CS} 0-\mathrm{CS} 31 \longrightarrow \mathrm{C} 1 \longrightarrow \mathrm{~A} 0-\mathrm{A} 31 \\ \mathrm{~S} 0-\mathrm{S} 31 \end{array} \\ & \mathrm{~S} 0-\mathrm{S} 31 \rightarrow \mathrm{DRQ} \\ & 1 \rightarrow \mathrm{~T} 10 \mathrm{~L} \end{aligned}$ | SXADD $=$ FABR PH2 $+\ldots$ <br> AXS $=$ FABR PH $2+\ldots$ <br> S/DRQ $=F A B R P H 2+\ldots$ <br> $S / T 10 L$ $=F A B R P H 2+\ldots$ | $A-1 \rightarrow A(D=0$ at this time) |
| PH3 | $\underset{\text { A0-A31 }}{\text { RW0-RW31 }} \longrightarrow \text { SO-S31 } \longrightarrow$ <br> Branch if A is positive but not zero $\mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31$ <br> $i-B R Q$ <br> $1 \rightarrow M R Q / 1$ <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Suppress Protect Fail |  | $\text { Disable } A \longrightarrow \text { RW if trap }$ <br> Next instruction to $D$ register |
|  |  | (Continued) | Mnemonic: BDR (64, E4) |

Table 3-115. Branch on Decrementing Register, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :--- | :--- | :--- | :--- |
| PH4 | $1 \rightarrow$ DRQ | S/DRQ $=\mathrm{FABR} \mathrm{PH} 4+\ldots$ |  |
| PH5 | End of no branch |  |  |

Table 3-116. Branch and Link, Phase Sequence


In PH2 of a Call instruction, the flip-flops INTRAPF, INTRAPI, $C X / 1$, and BRQ are set. The term ENDE does not come true during the final phase of a Call instruction. The address of the next instruction is in the $Q$-register as the Call instruction sequences to the trap phase sequence.

Trap sequencing is discussed under Trap Operation. For details of the XPSD instruction, see the instruction description.

A sequence chart of the Call instructions is given in table 3-117.

3-245 Load Program Status Doubleword (LPSD 0E, 8E)
The LPSD instruction loads the effective doubleword (EW and EW +1 ) in memory into the program status doubleword; EW is loaded into PSW1, and EW +1 is loaded into PSW2. If bit position 8 of the LPSD instruction is a one, bits 23 through 27 of EW +1 are loaded into the register pointer RP23 through RP27. If bit position 8 is not a one, the register pointer is not changed.

During the execution of the LPSD instruction, the highest priority interrupt level that is currently active is affected by the status of bit positions 10 and 11 of the LPSD instruction.

The LPSD instruction can be indirectly addressed, but not indexed. The normal preparation sequence, as well as the sequencing for the indirect addressing mode of this instruction, is described under Preparation Sequence.

If the CPU is in the slave mode and if the privileged LPSD instruction is not being executed as the result of a trap or an interrupt (INTRAPF false), the LPSD aborts and the CPU traps to location 40 at the end of preparation state PRE2.

A memory request is made for EW and then for EW +1. The effective word EW in the C-register is transferred to D.

The effective word EW in D is transferred to the sum bus, and the contents of the sum bus are transferred to the Aregister. All bits of PSWI except the P-register are loaded from the sum bus. The following flip-flops are unconditionally reset: MAPDIS, CI, II, EI, and CIF. INTRAPF is reset if the watchdog timer has not run down. The effective word plus one is transferred from the C-register into $D$.

The effective word in the A-register is transferred to the sum bus, and the 16 least significant bits of the sum bus are clocked into the P -register. The significant bits of $E W+1$ (PSW2) in the D-register are clocked into the current program status word 2 as the D -register is cleared to zeros. If R28 is true, the register pointer is changed; otherwise, it is not affected. If R30 is true, the highest priority interrupt level currently active is cleared. If R30 and R31 are both true, this interrupt level is cleared but is armed.

If R30 is true because the highest priority interrupt currently active is to be disabled, the CPU clock enable signal CE must be synchronized with the interrupt clock.

The effective word EW in the A-register is added to the Dregister (which now contains zeros), and the result on the sum bus is clocked into the P -register.

A sequence chart of the Load Program Status Doubleword instruction is given in table 3-118.

3-246 Exchange Program Status Doubleword (XPSD OF, 8F)
The XPSD instruction stores the current PSD into the memory doubleword location specified by the contents of the instruction reference address field, and loads the contents of the successive doubleword in memory into the current PSD. Four memory words are involved in this operation (two doublewords), and they are referred to as EW, EW +1 , EW +2 and EW +3 , where EW represents the effective word addressed by the reference address field. The current PSD is stored into EW and EW +1 , and the contents of EW + 2 and EW +3 are loaded into the current PSD.

Because the XPSD instruction is privileged, an attempt to execute this instruction in the slave mode causes a trap to location 40. However, if the CPU is in the slave mode and an interrupt or trap occurs for any reason, the XPSD instruction that immediately follows the interrupt or trap sequence is allowed.

An XPSD instruction can be executed as the result of any of the following conditions:
a. During the course of a program or subroutine in the master mode but not as the result of an interrupt or trap (NINTRAPF NTRAP).
b. Immediately following an interrupt sequence (INTRAPF NTRAP).
c. A trap to location 40 as the result of a nonexistent instruction, a nonexistent memory address, an attempt to execute a privileged instruction in the slave mode, or as the result of a memory protection violation (INTRAPF TRAP TRACC1 + TRACC2 + TRACC3 + TRACC4 = 1).
d. A trap to location 40 as the result of an interrupt system fault, or a trap to trap locations 41 through 46 [INTRAPF TRAP [(TRACCl + TRACC2 + TRACC3 $+\operatorname{TRACC4}=0)$ ]
e. A trap resulting from any Call instruction [INTRAPF TRAP (TRACC1 + TRACC2 + TRACC3 + TRACC4 $=1$ )].

Depending upon previous conditions, special actions described in the following paragraph are taken during the execution of the XPSD instruction.

Table 3-117. Call 1, Call 2, Call 3, Call 4, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{array}{\|l} \mathrm{PHI} \\ \mathrm{~T} 4 \mathrm{RL} \end{array}$ | R28-R31 $\rightarrow$ TRACCI-TRACC4 <br> Set TR28 <br> If CAL3 or CAL4, set TR30 <br> If CAL2 or CAL4, set TR31 <br> Set TRAP <br> Set PH2 |  | Hold R-field for use later during XPSD <br> TR28, TR30, TR31 are used for trap address into P -register during trap phase |
| $\begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | T6L <br> Set INTRAPF <br> Set INTRAPI <br> Set $B R Q$ <br> Clear |  | (INTRAPI CX/1) true for the first phase of trap sequence |
|  |  |  | Mnemonic: CALI-2-3-4, 04, 05, 06, 07 |

Table 3-118. Load Program Status Doubleword, Phase Sequence


Table 3-118. Load Program Status Doubleword, Phase Sequence (Cont.)


Table 3-118. Load Program Status Doubleword, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH7 <br> T6L <br> (Cont.) | Synchronize clock <br> Reset flip-flop INTRAPF $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 15-\mathrm{S} 31 \longrightarrow \mathrm{P} 15-\mathrm{P} 31 \end{aligned}$ <br> Reset TRAP $0^{\prime} \mathrm{s} \rightarrow \text { D0-D31 }$ <br> Go to PH8 | $\text { CEINT }=\text { FAPSD NO7 PH7 R30 }+\ldots$ $\begin{array}{ll} \text { R/INTRAPF } & =\text { FAPSD PH7 }+\ldots \\ \text { SXA } & =\text { FAPSD PH7 }+\ldots \\ \text { PXS } & =\text { FAPSD PH } 7+\ldots \\ \text { R/TRAP } & =\text { FAPSD PH } 7+\ldots \\ \text { DX/1 } & =\text { FAPSD PH7 }+\ldots \\ \text { S/PH8 } & =\text { PH7 NBR }+\ldots \end{array}$ | Synchronizes next clock with interrupt $1-\mathrm{MHz}$ clock by disabling clock enable signal CE until 1 MHz clock occurs (see Basic Timing) <br> Next instruction address into $P$ and again in PH8 |
| $\begin{array}{\|l\|} \text { PH8 } \\ \text { T6L } \end{array}$ | Enable T6L $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 15-\mathrm{S} 31 \rightarrow \mathrm{P} 15-\mathrm{P} 31 \end{aligned}$ <br> Request next instruction <br> Go to PH9 |  | Effectively, A to sum bus, since $D$ is cleared Next instruction address to $P$ |
| $\left\lvert\, \begin{aligned} & \text { PH9 } \\ & \text { T6L } \end{aligned}\right.$ | Enable T6L $0 \text { 's } \nrightarrow \text { TRACCI-TRACC4 }$ <br> Set data release request <br> Go to PHIO | $\begin{aligned} \text { T6L }= & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \\ \text { R/TRACC }= & \text { FAPSD PH9 }+\ldots \\ \text { S/DRQ }= & \text { FAPSD NPH7 NPH8 EXU }+\ldots \\ \text { S/PHI0 }= & \text { PH9 NBR }+\ldots \end{aligned}$ |  |
| PHIO <br> T6L | Enable T6L <br> End of LPSD <br> Set data release request | T6L $=$ NTIL NT4L NT8L NTIOL <br>  NRESET <br> ENDE $=$ FAPSD PHI0 $+\ldots$ <br> S/DRQ $=$ FAPSD NPH7 NPH8 NRESET <br>  $+\ldots$ |  |

Instruction bits 8, 9, and 10 (which are loaded into R28, R29, and R30 as the instruction is read from memory) have special meanings and affect the execution of the instruction in the following ways:

Instruction Bits

| 8 | 9 | 10 |
| :---: | :---: | :---: |
| $(R 28$ | R29 | $R 30)$ |

$\times \quad \times \quad$ If the memory map is in $\operatorname{effect}$ (bit 9 of the current $\operatorname{PSD}=1$ ), it remains enabled
$\times \quad \times \quad 0$

If the memory map is in effect (bit 9 of the current PSD $=1$ ), it is disabled for the duration of the XPSD instruction execution
$0 \times \quad \times \quad$ The XPSD instruction does not change the contents of the register pointer (RP-register) of the current PSD
$1 \times \quad \mathrm{x}$ The XPSD instruction loads the contents of bits 23 through 27 of EW +3 into the RP-register of the current PSD
$x \quad 1 \quad \times \quad$ If the trap has occurred to trap location X' $^{\prime} 40^{\prime}$, merge the contents of TRACCITRACC4 into the condition code bits $\mathrm{CCl}-\mathrm{CC} 4$ and into the next instruction address. If the trap occurred because of the execution of a Call instruction, add the contents of the R-field of the Call instruction to the next instruction address. (The R-field of the Call instruction is placed in TRACCl through TRACC4 during the execution of the Call instruction.)

The XPSD instruction can be indirectly addressed but not indexed. The normal preparation sequence, as well as the sequencing for the indirect addressing mode of this instruction, is described under Preparation Sequence. The XPSD aborts and the CPU traps to location $X^{\prime} 40^{\prime}$ at the end of preparation state PRE2 if the CPU is in the slave mode and the privileged XPSD instruction is not being executed as the result of a trap or an interrupt (INTRAPF false).

| S/TRAP | = FAPRIV (PREI NANLZ) NMASTER |
| :---: | :---: |
| (S/INTRAPF) | $=$ TRAP NINTRAPF |
| S/PHI | $=(\mathrm{S} / \mathrm{PHI} / 1) \mathrm{NCLEAR}$ |
| CLEAR | $=(S /$ INTRAPF $)$ |
| S/INTRAPI | $=$ NRESET (S/INTRAPF) |
| S/CX/1 | $=(S / I N T R A P F)$ |

A flow chart of the instruction is shown in figure 3-192. The current PSWI (except for the contents of the P -register) is transferred to the D-register, and if R31 is not true, the memory map is disabled. If INTRAPF is not true, the operand address in the $P$-register is transferred to $Q$, and the next instruction address in the $Q$-register is transferred to P. If INTRAPF is true, the contents of the $\mathbf{P}$ - and $\mathrm{Q}-$ registers are not exchanged, and $M R Q$ is enabled.

If the instruction is not part of an interrupt or a trap sequence, the next instruction address in the P -register is placed on the sum bus and is then clocked into the B-register. At the same time, the address of EW is returned to the P -register where it had been temporarily stored in the Q-register during PHI.

The sum bus performs an OR function on the contents of $D$ (which contains the current PSWI) and B (which contains the next instruction address). The next instruction address was placed into $B$ during an interrupt or trap sequence, and the result is written into memory at the operand address location. The current PSW2 is gated into the D-register, a second memory write cycle is requested, $D R Q$ is set, $P$ is counted up by one, and the CPU sequences to PH4.

The PSW2 in D is written into memory at the effective word location plus one. The P -register is counted up by one. The effective word plus two from memory, which has been read into the $C$-register, is clocked into $D$ and the $P$-register counts up by one. The contents of the D-register are placed on the sum bus, and the sum bus is read into PSWI and into the A-register. If flip-flop TRAP is true, TRACCI-TRACC4 are gated into $\mathrm{CCl}-\mathrm{CC} 4$. Since $50-53$ are also gajed to CCl-CC4, TRACCI-TRACC4 are effectively merged into $\mathrm{CCl}-\mathrm{CC} 4$.

The contents of $A(E W+2)$ are placed on the sum bus, and the 16 least significant bits of the sum bus are clocked into the $P$-register. The $D$-register (which has picked up $[E W+3]$ ) is clocked into PSW2. The D-register is reset to zeros unless TRAP is true, in which case the contents of TRACCI-TRACC4 are clocked into D28 through D31, provided that R29 is also true. If R29 is not true, the CPU requests the next instruction from memory and sequences to PH9; otherwise, it goes to PH8.

If R29 is false, the contents of the A-and D-registers are added, and the result on the sum bus is transferred to the $P$-register. This operation, in effect, adds the state of the TRACCI-TRACC4 flip-flops to the next instruction address before the request is made for the next instruction.

A sequence chart of the Exchange Program Status Doubleword instruction is given in table 3-119.

## 3-247 Load Register Pointer (LRP 2F, AF)

The LRP instruction loads bits 23 through 27 of the effective word into the RP-register, RP23 through RP27. The RP register is part of the current program status doubleword. No other portion of the PSDW is affected.


Figure 3-192. Exchange Program Status Doubleword, Logic Sequence Diagram (Sheet 1 of 2)


Figure 3-192. Exchange Program Status Doubleword, Logic Sequence Diagram (Sheet 2 of 2)

Table 3-119. Exchange Program Status Doubleword, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PHI <br> T4RL | $\text { PSWI } \rightarrow \text { D0-D11 }$ <br> $\mathrm{CCl}-\mathrm{CC} 4 \rightarrow$ D0-D3 <br> FS $\rightarrow$ D5 <br> $F Z \rightarrow D 6$ <br> FNF $\rightarrow$ D7 <br> NMASTERF $\rightarrow$ D8 <br> MAPF $\longrightarrow$ D9 <br> DM $\rightarrow$ DIO <br> $\mathrm{AM} \rightarrow \mathrm{Dll}$ <br> $0 \rightarrow$ MAPDIS <br> If R30 $=1,1 \rightarrow$ MAPDIS <br> If INTRAPF $=1$, set memory reques $\dagger$ and go to PH3 <br> If INTRAPF $=0$, exchange $P$ and $Q$ and go to PH2 |  | $\mathrm{O}^{\prime} \mathrm{s} \longrightarrow$ D12-D31 <br> Condition code <br> Floating significance bit <br> Floating zero bit <br> Floating normalize bit <br> Master-slave bit <br> Map control bit <br> Decimal mask bit <br> Arithmetic mask bit <br> NR30 $\Rightarrow$ MP bit $=0$ <br> Part of interrupt or trap sequence <br> Next instruction address <br> Operand address <br> If not part of interrupt or trap sequence |
| PH2 | Enable T6L <br> P15-P31 $\longrightarrow$ S15-S31 <br> $\mathrm{SO}-\mathrm{S} 31 \rightarrow \mathrm{BO}-\mathrm{B3} 1$ <br> Q15-Q31 $\rightarrow$ P15-P31 <br> P15-P31 $\longrightarrow$ Q15-Q31 <br> Write memory reques $\dagger$ | $\begin{aligned} \text { T6L } & =\text { NTIL NT4L NT8L NT10L NRESET } \\ \text { SXP } & =\text { FAPSD PH2 }+\ldots \\ \text { BXS } & =\text { FAPSD PH2 }+\ldots \\ \text { PXQ } & =\text { FAPSD PH2 }+\ldots \\ \text { QXP } & =\text { FAPSD PH2 }+\ldots \\ \text { MRQ } & =\text { FAPSD PH2 }+\ldots \end{aligned}$ | Next instruction address into B <br> Address of EW into $P$ <br> Next instruction address |
|  |  | (Continued) | Mnemonic: XPSD ( $0 \mathrm{~F}, \mathrm{8F}$ ) |

Table 3-119. Exchange Program Status Doubleword, Phase Sequence (Cont.)


Table 3-119. Exchange Program Status Doubleword, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH4 T6L (Cont. | Read memory reques $\dagger$ <br> Set data request $P+1 \longrightarrow P$ | MRQ $=$ FAPSD PH $4+\ldots$ <br> S/DRQ $=$ FAPSD NPH 7 NPH 8 EXU $+\ldots$ <br> PCTP1 $=$ FAPSD PH $4+\ldots$ | Address of EW + 2 into P |
| $\left\lvert\, \begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}\right.$ | Enable T6L $\begin{aligned} & \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & \mathrm{P}+1 \longrightarrow \mathrm{P} \end{aligned}$ <br> Read memory reques $\dagger$ <br> Set data request | T6L $=$ <br>  NTIL NT4L NT8L NTIOL <br>  NRESET <br> DXC $/ 6=$ FAPSD PH5 $+\ldots$ <br> PCTPI $=$ FAPSD PH $5+\ldots$ <br> MRQ $=$ <br> SAPSD PH $5+\ldots$  <br>   | $\mathrm{EW}+2 \rightarrow \mathrm{D}$ <br> Address of EW+3 into $P$ |
| $\left\lvert\, \begin{array}{l\|l\|} \text { PH6 } \end{array}\right.$ |  | T6L $=$ NTIL NT4L NT8L NTIOL <br>  NRESET <br> DXC/6 $=$ FAPSD PH6 <br> SXD $=$ FAPSD PH6 <br> CCXS $=$ PSWIXS <br> PSWIXS $=$ FAPSD PH6 N(S/INTRAPF $)+\ldots$ <br> S/CCI-CC4 $=(S 0-S 3)$ CCXS $+\ldots$ <br> S/FS $=$ S5 FSZNXS $+\ldots$ <br> S/FZ $=$ S6 FSZNXS $+\ldots$ <br> S/FNF S7 FSZNXS <br> FSZNXS $=$ PSWIXS <br> S/MASTERF $=$ S8 PSWIXS <br> S/MAPF $=$ S9 PSWIXS <br> S/DM - SIO PSWIXS <br> S/AM $=$ S1I PSWIXS <br> AXS $\because$ FAPSD PH6 $+\ldots$ <br> R/MAPDIS $\because$ FAPSD PH6 $+\ldots$ | $\mathrm{EW}+3 \longrightarrow \mathrm{D}$ $\mathrm{EW}+2 \not \longrightarrow \mathrm{PSWI}$ <br> Condition code <br> Floating significance bit <br> Floating zero bit <br> Floating normalize bit <br> Master-slave bit <br> Map control bit <br> Decimal mask bit <br> Arithmetic mask bit <br> $\mathrm{EW}+2$ |
|  |  | (Continued) | Mnemonic: XPSD ( $0 \mathrm{~F}, \mathrm{8F}$ ) |

Table 3-119. Exchange Program Status Doubleword, Phase Sequence (Cont.)


Table 3-119. Exchange Program Status Doubleword, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH8 <br> T6L <br> (Cont.) | $\mathrm{A} 0-\mathrm{A} 31+\mathrm{D} 0-\mathrm{D} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31$ $\mathrm{S} 15-\mathrm{S} 31 \nrightarrow \mathrm{P} 15-\mathrm{P} 31$ <br> Request next instruction <br> Go to PH9 | SXADD $=$ FAPSD PH $8+\ldots$ <br> PXS $=$ FAPSD PH $8+\ldots$ <br> MRQ $=$ FAPSD PH $8+\ldots$ <br> S/PH9 $=$ PH $8 \mathrm{NBR}+\ldots$ | Adds states of trace flipflops to next instruction address. Transfer to $P$ |
| $\left\lvert\, \begin{aligned} & \text { PH9 } \\ & \text { T6L } \end{aligned}\right.$ | Enable T6L $0 \text { 's } \nrightarrow \text { TRACCI-TRACC4 }$ <br> Go to PHIO | $\begin{aligned} \text { T6L } & =\text { NTIL NT4L NT8L } \\ & \text { NTIOL NRESET } \\ \text { R/TRACC1-TRACC4 }= & \text { FAPSD PH9 }+\ldots \\ \text { S/DRQ }= & \text { FAPSD NPH7 NPH8 } \\ & \text { EXU }+\ldots \end{aligned}$ |  |
| PH10 <br> T6L | Enable T6L <br> End of execution | T6L $=$ NTIL NT4L NT8L <br>  NTIOL NRESET <br> ENDE $=$ FAPSD PH $10+\ldots$ <br> S/DRQ $=$ FAPSD NPH7 NPH8 <br>  EXU $+\ldots$ |  |

The LRP instruction can be indexed, indirectly addressed, or both. The normal preparation sequence, as well as the sequencing for all modes and conditions of the LRP instruction, is described under Preparation Sequence.

At the PHI clock pulse, the effective word in the C-register is transferred to $D$.

At the PH 2 clock pulse, bit positions 23 through 27 of the D-register are transferred to RP23 through RP27. MRQ/I is enabled to start the memory request for the next instruction, and DRQ is set.

A sequence chart of the Load Register Pointer instruction is given in table 3-120.

The $\mathrm{P}+1$ count and the memory protection trap are disabled.

## 3-248 Move to Memory Control (MMC 6F, EF)

MMC loads a string of one or more words into one of the three banks of high speed memory registers. Bit positions 12 through 14 of the MMC instruction word are not used as an index register address; instead, they are used to specify which bank of high speed memory registers is to be loaded, as indicated in table 3-121.

The instruction produces an undefined result if bit positions 12 through 14 contain either all zeros or more than a single one. Bit positions 15 through 31 (reference address field) are ignored insofar as the operation of the instruction is concerned, and the results of the instruction are the same whether or not the instruction is indirectly addressed.

The R-field of the instruction word designates an even-odd pair of private memory registers that are used to control the loading of the specified bank of high speed memory registers. Bit positions 15 through 31 of the even numbered private memory register contain the address of the first word of the data to be loaded into the specified bank of high speed registers. Bit positions 0 through 7 of the odd numbered private memory register contain a count of the number of words to be loaded. If bits 0 through 7 are initially all zeros, a word count of 256 is implied.

Bit positions 15 through 22 ( 15 through 20 for load program control registers or load write lock registers) of the odd numbered private memory register indicate the particular fast access memory module half and bits to be written into.

During PREI, the address of the next instruction contained in the $P$-register is clocked into the $Q$-register, and the $A-, B-$, and $E-r e g i s t e r s$ are cleared.

Since there must be a one in bit position D12, D13, or D14 to specify the bank of high speed memory registers to be loaded, signal INDX is generated, flip-flop IX is set, and the bit is gated onto the LR address lines as though the instruction had been indexed. The data contained in the
addressed index register is clocked into the A-register at the PRE1 clock. Flip-flop PRE2 is set, and clock T4RL is enabled.

During PRE2, the contents of the D-register and the contents of the A-register are gated into the adder, and an addition operation is performed. The result is gated onto the sum bus and is clocked into flip-flops P15 through P31 at the PRE2 clock. This address is not used by the MMC instruction and is cleared during PH 2 . The A- and Dregisters are cleared, and flip-flop IX is reset. If bit D12 is a one, indicating a load map function, flip-flop SW1 is set; if bit D13 is a one, indicating a load program control function, flip-flop SW2 is set; if bit D14 is a one, indicating a load write lock function, flip-flop SW3 is set.

Flip-flop SW4 is set. If the instruction is indirectly addressed, flip-flop SW4 inhibits changing SW1, SW2, or SW3 during the second PRE2 from the new information contained in the D-register. Signal ( $\mathrm{S} / \mathrm{PHI} / 1$ ) is generated, flip-flops PHI and EXU are set, and clock T4RL is enabled.

The even numbered private memory register contains an image address in bit positions 15 through 31. This address points to the core memory location containing the first word to be read out. At the PHI clock the contents of the even numbered private memory register are clocked into the Aregister. Flip-flops P32 and P33 are cleared to select byte 0 as the first byte to be stored.

A one is forced on address line LR31 to select the odd numbered private memory register. Flip-flop PH2 is set, and clock T4RL is enabled. The data word containing the image address is gated from the A-register onto the sum bus. At the PH 2 clock, the address contained in S 15 through S 31 is clocked into flip-flops P15 through P31 and is immediately gated onto the LM and LB address lines to read the first word from memory. A memory request is generated for the first word, and flip-flop ARQ is set. Setting of flip-flop ARQ inhibits transmission of another clock until the address release signa! is received.

When the data from the odd numbered private memory register is available on the RR lines, it is clocked into the Aregister at the PH2 clock. The data word from the odd numbered register contains the word count and control start address. The instruction sequences to PH3, and clock T4RL is enabled.

During PH3, the data from the A-register is gated onto the sum bus. The word count contained in bit positions S0 through S7 is clocked into flip-flops EO through D7, and the control start address contained in bit positions 515 through S 22 (or S 20 ) is clocked into flip-flops P 15 through P22 (or P20). Flip-flop DRQ is set, inhibiting transmission of another clock until the data release signal is received. When the first word is available from core memory, signal CXMB is generated and gates the data into the $C$-register. At the PH3 clock, the image address from the even numbered private memory register is clocked back into the

Table 3-120. Load Register Pointer, Phase Sequence


Table 3-121. Bit Position Functions

| BIT POSITIONS |  |  | FUNCTION |
| :---: | :---: | :---: | :---: |
| 12 | 13 | 14 |  |
| 1 | 0 | 0 | Load memory map registers |
| 0 | 1 | 0 | Load program control registers |
| 0 | 0 | 1 | Load write lock registers |

A-register. The instruction sequences to PH4, and clock T6L is enabled.

Phase PH4 is repeated four times. During the first pass through PH4, flip-flops P32 and P33 are both zeros. Signal DXCR24 is generated and, at the PH4 clock, bits C0 through C7 are downward aligned into flip-flops D24 through D31. A one is added to bit P33 to select the next byte. During the second pass through PH4, signal DXCR16 is generated, and bits C8 through C15 are downward aligned into flip-flops D24 through D31. Flip-flops P32 and P33 are cleared, and a one is added to P32. During the third pass through PH 4 , signal DXCR8 is generated, and bits C 16 through C23 are downward aligned into flip-flops D24 through D31. A one is then added to bit P33, making P32 and P33 both true. During the fourth pass through PH4, signal DXC is generated, and bits C24 through C31 are clocked into flip-flops D24 through D31. Flip-flops P32 and P33 are then reset to zero for the next word.

The address contained in the P -register is gated onto the LM and LB lines. If flip-flop SWI is true, indicating load memory map registers, an address is contained only on address lines LM15 through LM22. The address contained on LM15 through LM19 is gated onto map address lines L/MP0/1 through L/MP $15 / 1$ and L/MP0/2 through L/MP15/2. These bits select the fast-access memory module in which the page addresses are to be stored and the alternate halves of the module as determined by bit position LM19. The bits contained on address lines LM20 through LM22 are gated onto map address lines L/MPO/3, L/MPO/4, L/MPO/5 through L/MP15/3, L/MP $15 / 4, \mathrm{~L} / \mathrm{MP} 15 / 5$. These bits select the bit positions to be written into. Signal MAPWXD is generated, gating the byte from bit positions D24 through D31 onto data lines MAPW15 through MAPW22. A one is then added to bits $\mathrm{P} 20-22$ to select the next bit position to be written into. During the second, third, and fourth passes through PH4, signals MMCW and MAPW are generated. During the second pass, byte 0 is stored in the selected map register, and during passes 3 and 4, bytes 1 and 2 are stored in their addressed register locations. After a byte has been stored in bit position 7 (that is, P20, P21, P22), a one is added to P19 to select the alternate half of the module to store the next four bytes.

If flip-flop SW2 is true, indicating load program control registers, an address is contained on only address lines LM15 through LM20. The address contained on LMI5
through LMI7 is gated onto program control address lines $\mathrm{L} / \mathrm{PBO} / 1$ through $\mathrm{L} / \mathrm{P} B 0 / 2$ and $\mathrm{L} / \mathrm{P} B 0 / 2$ through $\mathrm{L} / \mathrm{PB} 3 / 2$. These bits select the module in which the access codes are to be stored and the alternate halves of the module as determined by bit position LM17. The bits contained on address lines LM18 through LM20 are gated onto program control address lines $\mathrm{L} / \mathrm{PB} 0 / 3, \mathrm{~L} / \mathrm{PB} 0 / 4, \mathrm{~L} / \mathrm{B} 0 / 5$ through $\mathrm{L} / \mathrm{PB} 3 / 3, \mathrm{~L} / \mathrm{PB} 3 / 4$, and $\mathrm{L} / \mathrm{P} 3 / 5$. These bits select the bit positions to be written into. Signal MAPWXD is generated, gating the byte from bit positions D24 through D31 onto data lines MAPW15 through MAPW22. The inverse of this data is gated onto data lines W/PBO/15 through W/PBO/22, $W / P B 1 / 15$ through $W / P B 1 / 22, W / P B 2 / 15$ through $W / P B 2 / 22$, and $W / P B 3 / 15$ through $W / P B 3 / 22$. A one is then added to bit position P20 to select the next bit position to be written into. During the second, third, and fourth passes through PH4, signals MMCW, PCBW and clocks K/PBO through $K / P B 3$ are generated. During the second pass, the one's complement of byte 0 is stored in the addressed PB-register and, during passes 3 and 4, the one's complement of bytes 1 and 2 are stored in their addressed register locations. After a byte has been stored in bit position 7 (that is, P18, P19, P20), a one is added to P17 to select the alternate half of the module to store the next four bytes.

If flip-flop SW3 is true, indicating load write lock registers, an address is contained only on address lines LMI5 through LM20. The address contained on LM15 through LMI7 is gated onto address lines LB15 through LB17 and from LB15 through LB17 onto write lock address lines L/LK0/1 through $\mathrm{L} / \mathrm{LK} 3 / 1$ and $\mathrm{L} / \mathrm{LK} 0 / 2$ through $\mathrm{L} / \mathrm{LK} 3 / 2$. These bits select the module in which the write locks are to be stored and the alternate halves of the module as determined by bit position LB17. The bit contained on address lines LM18 through LM20 are gated onto address lines LB18 through LB20 and then onto write lock register address lines L/LK0/3, L/LK0/4, L/LK0/5 through L/LK3/3, L/LK3/4, and L/LK3/5. These bits select the bitpositions to be written into. Signal MAPWXD is generated, gating the byte from bit positions D24 through D31 onto data lines MAPW15 through MAPW22. The inverse of this data is gated onto data lines W/LK0/15 through L/LK0/22 and L/LK3/15 through L/LK3/22. Aone is then added to bit position P20 to select the next bit position to be written into. During the second, third, and fourth passes through PH4, signals MMCW, LOCKW and clocks K/LKO through K/LK3 are generated. During the second pass, the one's complement of byte 0 is stored in the addressed LK-register and, during passes 3 and 4 , the one's complement of bytes 1 and 2 is stored in their addressed register locations. After a byte has been stored in bit position 7 (that is, P18, P19, P20) a one is added to P17 to select the alternate half of the module to store the next four bytes. When flip-flops P32 and P33 are both ones, indicating that three bytes have been stored, flip-flop PH5 is set, clock T8L is enabled, and flip-flop SW4 is reset.

During PH5 the last byte is gated onto data lines MAPW15 through MAPW22, signal MMCW is generated, and the appropriate write signal is determined by flip-flop SW1, SW2,
or SW3. The fourth byte is then stored in the addressed register. The address contained in the P -register is gated onto the sum bus and, at the PH5 clock, is stored in the B-register. The D-register is cleared for the next word. A one is subtracted from the count in the E-register, indicating that a complete word has been loaded. A one is forced into flipflop CS31 for use during PH6. The instruction sequences to PH6, and clock T6L is enabled.

During PH6, the image address contained in the A-register and the one contained in flip-flop CS31 are gated into the adder, and an addition operation is performed to select the next word. The result is gated onto the sum bus and, at the PH6 clock, bits S15 through S31 are clocked into flipflops P15 through P31. The address is then gated onto the LM and LB lines to address the next word. The modified image address is also clocked back into the A-register. A memory request is generated for the next word. Flip-flop ARQ is set, inhibiting transmission of another clock until an address release signal is received. If the E-register has not been counted down to zero and if an interrupt request occurs, set flip-flop SW4 to inhibit branching during PH7. The instruction sequences to PH7, and clock T6L is enabled.

The modified control start address stored in the B-register during PH5 is gated onto the sum bus and, at the PH7 clock, is clocked into flip-flops P15 through P17. Flip-flop DRQ is set, inhibiting transmission of another clock until the data signal is received from memory. If flip-flop SW4 is not set, and if the E-register is not all zeros, the instruction branches to PH4. Phases PH4 through PH7 are then repeated until flip-flop SW4 is set or until the count in the E -register reaches zero, indicating that all the words have been loaded. Flip-flop PH8 is then set, and clock T8L is enabled. When the next data word is available from core memory, signal CXMB is generated, gating the word into the C -register.

The image address contained in the A-register is gated onto the sum bus and from the sum bus onto data lines RW0 through RW31. Write-byte signals RWB0 through RWB3 are generated, and the modified image address is stored in the even numbered private memory register. If flip-flop SW1 is true, a one is added to bits P19 through P22. A one is added to bits P17 through P20 if either flip-flop SW2 or SW3 is true. The control start address then points to the next module and the bit to be loaded. Flip-flop IEN is set to allow any interrupt requests to be recognized. Flip-flop MAPDIS is reset to reinstate the mapping function. The instruction sequences to PH9, and clock T6L is enabled.

The modified control start address is gated from the P register onto the sum bus and, at the PH9 clock, is clocked into flip-flops B15 through B31. The modified count in bit positions E0 through E7 is clocked into flip-flops A0 through A7. A memory request is generated for the next instruction. Memory request $M R Q / 1$ gates the address of the next instruction for the Q -register into the P -register, and it is immediately gated onto the LM and LB address lines. Flipflop DRQ is set, inhibiting transmission of another clock
until the data release signal is received from memory. A one is forced on address line LR31 to select the odd numbered private memory register. Flip-flop PHIO is set, and clock T8L is enabled.

The modified word count contained in bit positions $A 0$ through A7 is gated onto bit positions S0 through S7 of the sum bus. The control start address contained in bit positions B15 through B31 is gated onto bit positions S15 through S31 of the sum bus. The entire word is then gated from the sum bus onto data lines RW0 through RW31. Write-byte signals RWBO through RWB3 are generated, and the data word is stored in the odd numbered private memory register. If flip-flop SW4 is not set, signal ENDE is generated, flipflop PRE1 is set, and clock T6L is enabled for the next instruction.

A sequence chart of the Move to Memory Control instruction is shown in table 3-122.

## 3-249 Wait (WAIT 2E, AE)

The WAIT instruction halts the sequential operation of the CPU until the computer operator manually moves the COMPUTE switch on the Processor Control Panel from RUN to IDLE and then back to RUN. The CPU then proceeds to execute the instruction that sequentially follows the WAIT instruction.

Input/output operations can be performed while the CPU is halted. If an interrupt is activated while the CPU is halted, the interrupt subroutine is carried out and, at the end of the subroutine, executes the instruction following the WAIT. It then continues its normal execution sequence.

The preparation sequence for the WAIT instruction is the same as that described under Preparation Sequence.

During PH1, MRQ/1 is enabled to read the next instruction following the WAIT, the contents of the $Q$-register are transferred to the P -register, and flip-flop HALT is set. The next instruction is clocked into the D-register at PH2 clock, and signal ENDE is enabled. The CPU cannot sequence to PREI since HALT is true. Instead, it sequences to PCPI, and then to PCP2. After the COMPUTE switch has been set to IDLE and then back to RUN, flip-flop HALT resets, and the CPU sequences to phases PCP3, PCP4, PCP5, and then to PREI to execute the instruction following the WAIT.

A sequence chart of the WAIT instruction is given in table 3-123.
3-250 Read Direct (RD 6C, EC)
The Read Direct instruction can be executed in either one of two modes: the internal control mode (table 3-124) or the external mode (table 3-125). When the RD instruction is executed in the internal control mode, the condition code bits CC1-CC4 are set to the status of the control panel sense switches KSSI-KSS4.

Table 3-122. Move to Memory Control, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PREI <br> T6L | P15-P31 $\rightarrow$ Q15-Q31 <br> Clear $\mathrm{A}-, \mathrm{B}-$, and E -registers <br> D12-D14 $\longrightarrow$ LR29-LR31 <br> Generate signal INDX <br> Set flip-flop IX <br> RRO-RR31 $\rightarrow$ A0-A31 <br> Disable RW lines <br> Set flip-flop PRE2 <br> Enable clock T4RL | $\begin{array}{ll} \text { QXP } & =\text { PREI NANLZ }+\ldots \\ \text { AX } / 1 & =\text { PREI }+\ldots \\ B X / 1 & =\text { PREI NINTRAPF }+\ldots \\ \text { EX/1 } & =\text { PREI }+\ldots \\ \text { LRXD } & =\text { OXC } \\ \text { INDX } & =(C 12+C 13+C 14)(C 3+C 4+C 5) \\ \text { S/IX } & =\text { INDX PRE1 } \\ \text { AXRR } & =\text { FAW INDX PREI }+\ldots \\ \text { RWDIS } & =\text { PREI } \\ \text { S/PRE2 } & =\text { NPREIM PREI N(S/INTRAPF) } \\ \text { T4RL } & =\text { PREP + } \ldots \end{array}$ | Next instruction address <br> No function <br> No function. Mechanization convenience <br> No function. Mechanization convenience <br> No function. Mechanization convenience |
| $\begin{aligned} & \text { PRE2 } \\ & \text { T4RL } \end{aligned}$ | $\mathrm{DO} 0-\mathrm{D} 31+\mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-531$ $\mathrm{S} 15-\mathrm{S} 31 \nrightarrow \mathrm{P} 15-\mathrm{P} 31$ <br> Reset flip-flop IX <br> Clear A- and D-regisiers <br> If bit DI2 is a one, set flip-flop SWI <br> If bit DI3 is a one, set flip-flop SW2 <br> If bit D14 is a one, set flip-flop SW3 <br> Set flip-flop SW4 | $\begin{aligned} \text { SXADD }= & \text { PRE2 NIA NSDIS }+\ldots \\ \text { PXS }= & \text { PRE2 NIA }+\ldots \\ \text { R/IX }= & \text { PRE2 NIA } \\ \text { AX/i = } & \text { PRE2 NIA }+\ldots \\ \text { DX/1 = } & \text { PRE2 NIA }+\ldots \\ S / S W 1= & \text { FUMMC NSW4 NANLZ PRE2 D12 } \\ & +\ldots \\ S / S W 2= & \text { FUMMC NSW4 NANLZ PRE2 D13 } \\ & +\ldots \\ S / S W 3= & \text { FUMMC NSW4 NANLZ PRE2 D14 } \\ & +\ldots \\ S / S W 4= & \text { FUMMC PRE2 }+\ldots \end{aligned}$ | No function. Mechanization convenience <br> No function. Mechanization convenience <br> No function. Mechanization convenience <br> Indicates load map function <br> Indicates load program control registers <br> Indicates load write lock register <br> Inhibits changing of flipflops SW1, SW2 or SW3 if instriuction is indirectly addressed |
| (Continued) |  |  | Mnemonic: MMC (6F, EF) |

Table 3-122. Move to Memory Control, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Set flip-flop PHI <br> Enable clock T4RL <br> Set flip-flop EXU | $\begin{array}{ll} \mathrm{S} / \mathrm{PH} 1 & =(\mathrm{S} / \mathrm{PHI} / 1) \text { NCLEAR NBR } \\ (\mathrm{S} / \mathrm{PH} 1 / 1) & =\text { NPRED0 (PRE2 NIA) }+\ldots \\ \text { T4RL } & =\text { PREP }+\ldots \\ \mathrm{S} / \text { EXU } & (\mathrm{S} / \mathrm{PH} 1 / 1) \text { NCLEAR } \end{array}$ |  |
| $\begin{array}{\|l\|} \mathrm{PHI} \\ \mathrm{~T} 4 \mathrm{RL} \end{array}$ | $\text { RR0-RR31 } \nrightarrow A 0-A 31$ <br> Force a one onto address line LR31 <br> Clear P32 and P33 <br> Set flip-flop PH2 <br> Enable clock T4RL | $\begin{array}{ll} \text { AXRR } & =\text { FUMMC PH2 }+\ldots \\ \text { R/NLR31/2 } & =\text { LR31/2 }=\text { FUMMC PHI }+\ldots \\ \text { PX/1 } & =\text { FUMMC PH1 }+\ldots \\ \text { S/PH2 } & =\text { PH1 NBR }+\ldots \\ \text { T4RL } & =\text { FUMMC PHI }+\ldots \end{array}$ | Even numbered private memory register. Contains image address. Points to memory location containing first word to be read out <br> Clear P32 and P33 for byte 0 |
| $\begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 4 \mathrm{RL} \end{aligned}$ | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{~S} 15-\mathrm{S} 31 \longrightarrow \mathrm{P} 15-\mathrm{P} 31 \\ & \mathrm{P} 15-\mathrm{P} 31 \longrightarrow \mathrm{LM15-LB31} \end{aligned}$ <br> Generate memory request <br> Set flip-flop ARQ $\text { RRO-RR31 } \rightarrow \text { A0-A31 }$ <br> Set flip-flop PH3 <br> Enable clock T4RL | $\begin{aligned} \text { SXA } & =\text { FUMMC PH2 }+\ldots \\ \text { PXS } & =\text { FUMMC PH2 }+\ldots \\ \text { MRQ } & =\text { FUMMC PH } 2+\ldots \\ \text { S/ARQ } & =\text { FUMMC PH2 }+\ldots \\ \text { AXRR } & =\text { FUMMC PH2 }+\ldots \\ \text { S/PH3 } & =\text { PH2 NBR }+\ldots \\ \text { T4RL } & =\text { FUMMC PH2 }+\ldots \end{aligned}$ | Image address for first word from core memory <br> Address for first word <br> Memory request for first word <br> Inhibits transmission of another clock until address release signal is received <br> Data from odd numbered private memory register. Contains count and control start addresses |
|  |  |  | Mnemonic: MMC (6F, EF) |

Table 3-122. Move to Memory Control, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{array}{\|l} \text { PH3 } \\ \text { T4RL } \end{array}$ | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{SO-S31} \\ & \mathrm{SO} 0-\mathrm{S} 7 \longrightarrow \mathrm{E} 0-\mathrm{E} 7 \\ & \mathrm{~S} 15-\mathrm{S} 31 \longrightarrow \mathrm{P} 15-\mathrm{P} 31 \\ & \mathrm{MB} 0-\mathrm{MB} 31 \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ & \mathrm{RR} 0-\mathrm{RR} 31 \longrightarrow \mathrm{~A} 3-\mathrm{A} 31 \end{aligned}$ <br> Set flip-flop $D R Q$ <br> Set flip-flop PH4 <br> Enable clock T6L | $\begin{aligned} \text { SXA } & =\text { FUMMC PH3 }+\ldots \\ \text { EXS } & =\text { FUMMC PH3 NPREI }+\ldots \\ \text { PXS } & =\text { FUMMC PH3 }+\ldots \\ \text { CXMB } & =\text { DGC } \\ \text { AXRR } & =\text { FUMMC PH3 }+\ldots \\ \text { S/DRQ } & =\text { FUMMC PH3 }+\ldots \\ \text { S/PH4 } & =\text { PH3 NBR }+\ldots \\ \text { T6L } & = \\ & \text { NTIL NT4L NT8L NTIOL } \\ & \end{aligned}$ | Word count stored in E-register <br> Control start address clocked into P -register <br> First data word <br> Image address clocked back into A-register from even numbered private memory register <br> Inhibits transmission of another clock until data signal is received |
| $\begin{array}{\|l\|} \mathrm{PH} 4 \\ \mathrm{~T} 6 \mathrm{~L} \end{array}$ | If bits P32 and P33 are 0 's, generate signal DXCR24 and clock C0-C7 $\rightarrow \text { D24-D31 }$ <br> Reset flip-flop SW4 <br> If NP32 and NP33, generate signal DXCR16 and clock $\mathrm{C} 8-\mathrm{Cl} 5+$ D24-D31 <br> If P32 and NP33, generate signal DXCR8 and clock $\mathrm{Cl} 6-\mathrm{C} 23 \longrightarrow$ D24-D31 <br> If P32 and P33, generate signal DXC and clock C24-C31 $\rightarrow$ D24-D31 <br> If flip-flop SW1 is true, gate address P15-P22 $\longrightarrow$ LM15-LM22 <br> LM15-LM19 $\longrightarrow$ L/MPO/IL/AMP $15 / 1$ and $L / M P O / 2-L / M P 15 / 2$ | $\begin{aligned} \text { DXCR24 } & =\text { NP32 NP33 DXCBP }+\ldots \\ \text { R/SW4 } & =\text { FUMMC PH4 } \\ \text { DXCR16 } & =\text { NP32 P33 DXCBP }+\ldots \\ \text { DXCR̄̄ } & =\text { P32 NP33 DXCBP }+\ldots \\ \text { DXC } & =\text { P32 P33 DXCBP }+\ldots \\ \text { DXCBP } & =\text { FUMMC PH4 }+\ldots \end{aligned}$ | True first pass through PH4. Downward align byte 0 <br> Reset during first pass <br> True second pass through PH4. Downward align byte 1 <br> True third pass through PH4. Downward align byte 2 <br> True fourth pass through PH4. Transfer byte 3 <br> LM15 through LM18 select module in which page addresses are to be stored. LMI9 selectsalternate halves of module |
| (Continued) |  |  | Mnemonic: MMC (6F, EF) |

Table 3-122. Move to Memory Control, Phase Sequence (Cont.)


Table 3-122. Move to Memory Control, Phase Sequence (Cont.)


Table 3-122. Move to Memory Control, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH4 <br> T6L <br> (Cont.) | Add a one to P17-P20 <br> Repeat PH4 until P32 and P33 are both ones <br> During passes 2, 3, and 4, generate signal MMCW and clock bytes 0,1 , and 2 into write lock registers <br> Reset flip-flop SW4 <br> When flip-flops P32 and P33 are both ones, set flip-flop PH5 <br> Enable clock T8L | PCTP $4 / 1=$ FUMMC NSW4 NANLZ PH4 <br> PCTP5 $=$ P19 P20 NPA22 PCTP4 <br> S/PH4 $=$ BRPH4 $=$ FUMMC PH4 (NP32 <br>  + NP33) $+\ldots$ <br> MMCW $=$ FUMMC PH4 (P32 + P33) <br> LOCKW $=$ MMCW SW3 <br> K/LK0-K/LK2 $=$ LOCKW CK $-24 U 04$ <br> R/SW4 $=$ FUMMC PH4 $+\ldots$ <br> S/PH5 $=$ PH4 NBR + ... <br> R/NT8L $=$ S/T8L = FUMMC PH4 | $P A 22=0$ <br> Clock bytes into selected bits of write lock registers <br> Reset during first pass through PH4 |
| $\left\lvert\, \begin{aligned} & \text { PH5 } \\ & \mathrm{T} \varepsilon \mathrm{~L} \end{aligned}\right.$ | P15-P31 $\longrightarrow$ S15-S31 $\mathrm{S} 15-\mathrm{S} 31 \not \mathrm{~B} 15-\mathrm{B} 31$ <br> D24-D31 $\longrightarrow$ MAPW15- <br> MAPW22 <br> Generate signal MMCW <br> Store byte 3 into register as determined by SW1, SW2, or SW3 <br> Reset flip-flop MAPDIS <br> Clear D-register <br> Force a one into flip-flop CS31 <br> Subtract one from count in E-register <br> Set flip-flop PH6 <br> Enable clock T6L | SXP $=$ FUMMC PH5 $+\ldots$ <br> EXS $=$ FUMMC PH5 $+\ldots$ <br> MAPWXD $=$ FUMMC EXU <br> MMCW $=$ FUMMC PH5 <br>   <br> R/MAPDIS $=$ FUMMC PH5 $+\ldots$ <br> DX/1 $=$ FUMMC PH5 $+\ldots$ <br> CSX1/8 $=$ FUMMC PH5 $+\ldots$ <br> MCTE $=$ <br>  FUMMC PH5 $+\ldots$ <br> S/PH6 $=$ PH5 NBR $+\ldots$ <br> T6L $=$ <br>  NTIL NT4L NT8L NTIOL | Store control start address <br> Last byte stored in addressed register <br> For use during PH 6 Indicates one word loaded |
|  |  | (Continued) | Mnemonic: MMC (6F, EF) |

Table 3-122. Move to Memory Control, Phase Sequence (Cont)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH6 } \\ & \text { T6L } \end{aligned}$ | $\mathrm{A} 0-\mathrm{A} 31+\mathrm{CS} 0-\mathrm{CS} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31$ <br> $\mathrm{S} 15-\mathrm{S} 31 \longrightarrow \mathrm{P} 15-\mathrm{P} 31$ <br> S15-P31 $\longrightarrow$ LM15-LB31 <br> $\mathrm{SO}-\mathrm{S} 31 \longrightarrow \mathrm{~A} 0-\mathrm{A} 31$ <br> Generate a memory request for next word <br> Set flip-flop ARQ <br> If the E-register has not been counted down to zero and an interrupt occurs set flip-flop SW4 <br> Set flip-flop PH7 <br> Enable clock T6L | $\begin{aligned} \text { SXADD } & =\text { FUMMC PH6 }+\ldots \\ \text { PXS } & =\text { FUMMC PH6 }+\ldots \\ \text { AXS } & =\text { FUMMC PH6 }+\ldots \\ \text { MRQ } & =\text { FUMMC PH6 NEZ }+\ldots \\ \text { S/ARQ } & =\text { FUMMC PH6 }+\ldots \\ \text { S/SW4 } & =\text { FUMMC NEZ PH6 INT }+\ldots \\ \text { S/PH7 } & =\text { PH6 NBR }+\ldots \\ \text { T6L } & =\text { NTIL NT4L NT8L NTIOL NRESET } \end{aligned}$ | Add one to image address to select next word <br> Address of next word from image address <br> Image address clocked back into A-register <br> Inhibits transmission of another clock until address release signal is received <br> Inhibits branching to PH 4 during PH7 |
| $\begin{aligned} & \text { PH7 } \\ & \text { T6L } \end{aligned}$ | $\begin{aligned} & \mathrm{BO}-\mathrm{B} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{~S} 15-\mathrm{S} 31 \longrightarrow \mathrm{P} 15-\mathrm{P} 31 \end{aligned}$ <br> If flip-flop SW4 is not set, and the count in the E-register is not all zeros, branch to PH 4 <br> Disable MAP <br> Repeat phases PH 4 through PH 7 until an interrupt occurs (that is, flip-flop SW4 is set), or the count in the Eregister reaches zero, indicating that all the words have been loaded. Flipflop PH8 is then set <br> Enable clock T8L | $\begin{aligned} \text { SXB }= & \text { FUMMC PH7 }+\ldots \\ \text { PXS }= & \text { FUMMC PH7 }+\ldots \\ \text { S/PH4 }= & \text { BRPH4 }=\text { FUMMC PH7 NSW4 } \\ & \text { NANLZ NEZ }+\ldots \\ \text { S/MAPDIS }= & \text { FUMMC BRPH4 } \\ \text { S/PH8 }= & \text { PH7 NBR }+\ldots \\ \text { R/T8L }= & \text { S/T8L = FUMMC PH7 }+\ldots \end{aligned}$ | Control start addressing information |
|  |  |  | Mnemonic: $M M C$ (6F, EF) |

Table 3-122. Move to Memory Control, Phase Sequence (Cont.)

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{PH} 7$ <br> T6L <br> (Cont.) | Set flip-flop $D R Q$ $\mathrm{MB} 0-\mathrm{MB31} \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ | $S / D R Q$ <br> CXMB | $=\text { FUMMC PH7 }+\ldots$ $=D G C$ | Inhibits transmission of another clock until data release signal is received for memory request generated during PH6 <br> When data release signal is received, next word is gated into C -register |
| $\left\lvert\, \begin{aligned} & \text { PH8 } \\ & \text { T\&L } \end{aligned}\right.$ | $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \text { S0-S31 } \\ & \text { S0-S31 } \longrightarrow \text { RW0-RW31 } \end{aligned}$ <br> Generate write-byte signals RWB0-RWB3 <br> Add a one to P 19 through P 22 if SW1 is true or to P17 through P20 if SW2 or SW3 is true <br> Set flip-flop IEN <br> Set flip-flop PH9 <br> Enable clock T6L | SXA <br> RWXS <br> RWB0-RWB3 <br> RW <br> PA22 <br> PCTP4/1 <br> S/IEN <br> S/PH9 <br> T6L | $\begin{aligned} & =\text { FUMMC PH8 }+\ldots \\ & =\text { FUMMC PH8 }+\ldots \\ & =\text { FUMMC PH8 }+\ldots \\ & =\text { FUMMC PH8 }+\ldots \\ & =\text { N(FUMMC PH8 NSWI) } \\ & =\text { FUMMC PH8 } \\ & =\text { FUMMC PH8 }+\ldots \\ & =\text { PH8 NBR }+\ldots \\ & =\text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \end{aligned}$ | Image address <br> Stores modified image address in even numbered private memory register <br> Control start address points to next module and bit to be loaded <br> Enable interrupt |
| $\left\lvert\, \begin{array}{l\|l\|} \text { PH9 } \\ \text { T6L } \end{array}\right.$ | $\begin{aligned} & \mathrm{P} 15-\mathrm{P} 31 \longrightarrow \mathrm{~S} 15-\mathrm{S} 31 \\ & \mathrm{~S} 15-\mathrm{S} 31 \longrightarrow \mathrm{~B} 15-\mathrm{B} 31 \end{aligned}$ <br> Set flip-flop IEN <br> Force a one on address line LR31/2 $\mathrm{E} 0-\mathrm{E} 7 \rightarrow \mathrm{~A} 0-\mathrm{A} 7$ <br> Generate memory request for next instruction | $\begin{aligned} & \text { SXP } \\ & \text { BXS } \\ & \text { S/IEN } \\ & \text { R/NLR31/2 } \\ & \text { AXE } \\ & \text { MRQ/1 } \end{aligned}$ | $\begin{aligned} & =\text { FUMMC PH9 }+\ldots \\ & =\text { FUMMC PH9 }+\ldots \\ & =\text { FUMMC PH9 }+\ldots \\ & =\text { LR3I } / 2=\text { FUMMC PH9 }+ \\ & =\text { FUMMC PH9 }+\ldots \\ & =\text { FUMMC PH9 }+\ldots \end{aligned}$ | Modified control start address stored in Bregister <br> Allows interrupt to be recognized <br> Count stored in A-register |
| (Continued) |  |  |  | Mnemonic: MMC (6F, EF) |

Table 3-122. Move to Memory Control, Phase Sequence (Cont.)


Table 3-123. Wait, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PHI <br> T4RL | Q15-Q31 $\rightarrow$ P15-P31 <br> Enable memory request $1 \rightarrow \text { HALT }$ | $\left\lvert\, \begin{array}{ll} \text { PXQ } & =\text { MRQ } / 1+\ldots \\ \quad M R Q / 1 & =\text { FUWAIT PHI }+\ldots \\ \text { S/DRQ } & =\text { FUWAIT PHI }+\ldots \\ \text { S/HALT } & =\text { FUWAIT PHI }+\ldots \end{array}\right.$ | To read next instruction |
| $\left\lvert\, \begin{aligned} & \text { PH2 } \\ & \text { T6L } \end{aligned}\right.$ | End of Wait $\mathrm{C} 0-\mathrm{C} 31 \rightarrow \text { D0-D31 }$ <br> Suppress PREI <br> Go to PCP 1 | ENDE $=$ FUWAIT PH $2+\ldots$ <br> DXC $=$ ENDE $+\ldots$ <br> S/PRE1 $=$ ENDE (NHALT + FUEXU $)$ <br>  N(S/INTRAPF) $+\ldots$ <br> S/PCPI $=$ $(S / P C P 1)$ NPCP3 $+\ldots$ <br> $(S / P C P 1)=$ ENDE HALT/1 N(S/INTRAPF) <br>  NFUEXU | Next instruction to Dregister |
| PCP 1 | Go to PCP2 | $\begin{aligned} S / P C P 2 & =(S / P C P 2) \text { NPCP3 } \\ (S / P C P 2) & =P C P 1 \text { NCLEAR } \end{aligned}$ |  |
| PCP2 | Halt in PCP2 until COMPUTE switch is set to IDLE and then back to RUN | $\begin{aligned} \mathrm{S} / \mathrm{PCP3} 3 & (\mathrm{~S} / \mathrm{PCP} 3) \mathrm{NPCP} 3 \\ (\mathrm{~S} / \mathrm{PCP} 3)= & \text { PCP2 NHALT NCLEAR } \\ & \text { KAS } / 1 \mathrm{KAS} / 2 \\ \mathrm{R} / \text { HALT }= & \text { PCP2 NKAS } / \mathrm{B}+\ldots \end{aligned}$ |  |
| PCP3 | Go to PCP4 | S/PCP4 $=$ PCP3 (NPCP7 NENDE) |  |
| PCP4 | Go to PCP5 | S/PCP5 $=$ PCP4 (NPCP7 NENDE) |  |
| PCP5 | Go to PRE1 | $\begin{aligned} \text { S/PRE }= & \text { ENDE (NHALT }+ \text { FUEXU }) \\ & \text { N(S/INTRAPF) }+\ldots \\ \text { ENDE }= & \text { PCP5 NKIDLE }+\ldots \end{aligned}$ |  |
|  |  |  | Mnemonic: WAIT ( $2 \mathrm{E}, \mathrm{AE}$ ) |

Table 3-124. Read Direct Internal Control Mode, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PHI } \\ & \text { T4RL } \end{aligned}$ | Enable memory request for nex $\dagger$ instruction $\text { Q15-Q31 } \rightarrow \text { P15-P31 }$ <br> Go to PH2 | $\begin{aligned} M R Q / 1 & =\text { FARWD PH1 }+\ldots \\ P X Q & =M R Q / 1+\ldots \\ S / P H 2 & =P H 1 \text { NBR N }(\ldots)+\ldots \end{aligned}$ | Next instruction address |
| PH2 T6L | Enable T6L <br> Go to PH3 | T6L $=$ NTIL NT4L NT8L NTIOL NRESET <br> S/PH3 $=$ PH2 NBR N(..) $+\ldots$ |  |
| $\left\lvert\, \begin{aligned} & \text { PH3 } \\ & \text { T6L } \end{aligned}\right.$ | Enable T6L <br> $1 \rightarrow$ SWI <br> Sense switches $\rightarrow \mathrm{CCl}-\mathrm{CC} 4$ <br> If NRZ B27, MFLO-MFL7 $\rightarrow$ <br> D24-D31 <br> If NRZ B27, 0's $\rightarrow$ MFLO-MFL7 <br> Go to PH4 |  | Differentiates between two PH3 intervals <br> Memory fault indicators <br> Reset memory fault indicators |
| $\begin{aligned} & \mathrm{PH} 4 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | Enable T6L <br> End $R D$ instruction if $D R Q=1$ | $\begin{array}{ll} \text { T6L } & =\text { NTIL NT4L NT8L NTIOL NRESET } \\ \text { ENDE } & =\text { FARWD PHA } D R Q+\ldots \\ \text { S/DRQ } & =\text { FARWD PH4 BT619Z }+\ldots \end{array}$ |  |
|  |  | (Continued) | Mnemonic: RD (6C, EC) |

Table 3-124. Read Direct Internal Control Mode, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH4 <br> T6L <br> (Cont.) | $\begin{aligned} & \begin{array}{l} \text { If R28-R31 } \neq 0, \text { DO-D31 } \\ \text { S0-S31 } \end{array} \\ & \text { S0-S31 } \longrightarrow \text { RW0-RW31 } \end{aligned}$ | $\begin{aligned} & \text { SXD }=\text { OU6 OLC PH4 NRZ }+\ldots \\ & \text { RW }= \text { OU6 OLC PH4 NRZ }+\ldots \\ & \text { BRPH4 }=\text { FARWD PH4 NDRQ }+\ldots \end{aligned}$ | Status of memory fault indications into private memory |
|  |  |  | Mnemonic: RD (6C, EC) |

Table 3-125. Read Direct External Mode, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| PHI <br> T4RL | Enable memory request for next instruction $\begin{aligned} & \text { Q15-Q31 } \nrightarrow \text { P15-P31 } \\ & \text { P15-P31 S15-S31 } \\ & \text { S0-S31 } \rightarrow \text { B0-B31 } \end{aligned}$ <br> Set SW3 <br> Go to PH2 | $M R Q / 1$ $P X Q$ $S X P$ $B X S$ $S / S W 3$ $S / P H 2$ | $\begin{aligned} & =\text { FARWD PHI }+\ldots \\ & =\mathrm{MRQ} / I+\ldots \\ & =\text { FADIO PHI }+\ldots \\ & =\text { FADIO PHI }+\ldots \\ & =\text { FADIO PHI }+\ldots \\ & =\text { PHI NBR N }(\ldots)+\ldots \end{aligned}$ | Address of next instruction to $P$ <br> Effective address to $B$ <br> For use in PH2 |
| PH2 | Enable T6L $\mathrm{B} 16-\mathrm{B} 31 \longrightarrow \text { DIO32-DIO47 }$ <br> Go to PH3 | T6L <br> DIOXB <br> S/PH3 | $\begin{aligned} = & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \\ = & \text { FARWD SW3 }+\ldots \\ = & \text { PH2 NBR N }(\ldots)+\ldots \end{aligned}$ | Device address to direct input/output address lines |
| $\begin{array}{\|l\|} \mathrm{PH} 3 \\ \mathrm{~T} 6 \mathrm{~L} \end{array}$ | Enable T6L <br> Set SW4 <br> Repeat PH3 until SWI $=1$ <br> Set SW1 when device response received <br> DIO0-DIO31 $\rightarrow$ D0-D31 <br> Set CC3-CC4 from devire | T6L <br> S/SW4 <br> R/SW4 <br> BRPH3 <br> S/PH3 <br> S/PH4 <br> S/SWI <br> R/SWI <br> DXDIO <br> S/D0-D31 <br> $\mathrm{S} / \mathrm{CC} 3$ <br> S/CC4 | $\begin{aligned} = & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \\ = & \text { FARWD PH3 NSWI }+\ldots \\ = & \text { FADIO SWI }+\ldots \\ = & \text { FARWD PH3 NSWI + } \ldots \\ = & \text { BRPH3 + ... } \\ = & \text { PH3 NBR + ... } \\ = & \text { FARWD PH3 DIO49 NSWI } \\ & +\ldots \\ = & \text { FADIO SWI + ... } \\ = & \text { FARWD SW1 NB1619Z + ... } \\ = & \text { (DIO0-DIO31) DXDIO } \\ = & \text { FARWD SW1 NBI619Z DIO51 } \\ & +\ldots \\ = & \text { FARWD SW1 NB1619Z DIO52 } \end{aligned}$ | SWl $\Rightarrow$ device response received <br> DIO49 => device response <br> Input data from device <br> Condition code information from device |
| (Continued) |  |  |  | Mnemonic: RD (6C, EC) |

Table 3-125. Read Direct External Mode, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\left\|\begin{array}{l} \text { PH3 } \\ \text { T6L } \\ \text { (Cont.) } \end{array}\right\|$ | Strobe data | $\mid \text { DIO48 }=\text { DIO48XI }$ <br> DIO48X1 = FADIO SW1 SW4 IARWD $+\ldots$ | Strobe signal to device |
| $\begin{aligned} & \text { PH4 } \\ & \text { T6L } \end{aligned}$ | Enable T6L <br> Remain in PH4 until device response signal drops and sets data request $\text { D0-D31 } \longrightarrow \text { S0-S31 }$ $\text { S0-S31 } \longrightarrow \text { RW0-RW31 }$ <br> End of RD instruction sequence |  | Final PH4 sequence <br> Read input data into private memory register unless address is zero |
|  |  |  | Mnemonic: RD (6C, EC) |

If the R-field of the RD instruction is not zero, the states of the memory fault indicators, MFLO-MFL7, are fransferred to the addressed private memory register $R$, bit positions 24 through 31 . Bit positions 0 through 23 of the private memory register are cleared to zeros, and the memory fault indicators are reset.

When the RD instruction is executed in the external mode, an external device is addressed. The RD instruction then waits until the device responds with input data to the CPU and then loads the data into the addressed private memory register.

Timing for the RD instruction internal control mode is shown in figure 3-193; timing for the RD instruction external mode is shown in figure 3-194.

Fifty-five separate input/output lines associated with the read direct instruction are available. The 32 data lines DIO0 through DIO31 are bidirectional lines used as input lines for the read direct instruction. The input data is accepted from the data lines by the D-register. (See figure 3-195.) The 16 address lines, /DIO32/through /DIO47/, are used to address the input device. (See figure 3-196.)

There are 7 direct input control lines, /DIO48/through /DIO54/. (See figure 3-197.) /DIO48/is a strobe signal to the addressed device. /DIO49/is a response signal from the device. Signal /DIO50/ is false for read-direct operation. Signals /DIO51/ and /DIO52/are input lines from the device and can be used for miscellaneous purposes, for example, for temperature out of limits in some applications, or for A/D off scale readings. The status of lines /DIO51/ and /DIO52 / is transferred into condition code bits CC3 and CC4. Line/DIO53/is used for the resetting of all inputs when the I/O RESET or SYS RESET switch-indicators are pressed or when power is first applied to the computer system. A $1-\mathrm{MHz}$ signal to all devices associated with the read-direct operations is provided on line/DIO54/.
The RD instruction can be indirectly addressed, indexed, or both. The normal preparation sequence, as well as the sequencing for all modes and conditions of the RD instruction, is described under Preparation Sequence.
The effective address in $P$ is transferred to the sum bus and is clocked into the B -register. The next instruction address in $Q$ is clocked into $P$; SW3 and $P H 2$ are set. The address of the device is taken from the B-register ( $\mathrm{B} 16-\mathrm{B} 31$ ) and is placed on the input/outout address lines.


Figure 3-193. Read Direct Internal Control Mode, Timing Diagram


Figure 3-194. Read Direct External Mode, Timing Diagram


Figure 3-195. Read/Write Direct Input/Output Lines DIO0-DIO31


Figure 3-196. Read/Write Direct Address Lines/DIO32/-/DIO47/




Figure 3-197. Read/Write Direct Control Lines/DIO48/-/DIO54/

The PH3 sequence of the RD instruction operates differently in the internal control mode (B1619Z) and in the external mode (NB1619Z). Each mode will be discussed separately in the following paragraphs.

3-251 PH3 INTERNAL MODE (B1619Z). The CPU leaves PH 2 and enters PH 3 for two clock periods. SWI differentiates between the two PH3 intervals by setting at the end of the first PH 3 interval and resetting at the end of the second PH3 interval. The sense switches are strobed into CCl through CC4 when SWI is high. If the R-field of the RD instruction word is not zero (NRZ), and if B27 is a one, the memory fault indicators are strobed into D24 through D31, and the memory fault indicators are reset.

3-252 PH3 EXTERNAL MODE (NB1619Z). The CPU leaves PH 2 and enters PH 3 to wait for the device response signal /DIO49/. Flip-flop SW4 is set after the first PH3 sequence. When SW4 is true, the strobe signal /DIO48/ is sent to the device. The CPU is forced to remain in PH3 by the signal BRPH3 until the device responds with the signal /DIO49/. When /DIO49/is received, SWI is set, and the CPU prepares to sequence to PH 4 . CC3 and CC4 are set if signals /DIO51/ and /DIO52/are received from the input device. Flip-flop SW 1 true marks the final PH3 sequence. At the clock of this final sequence in PH 3 , the input data from the device is read into the D-register. The CPU remains in PH4 until the device response signal /DIO49/drops. During PH4, if the R-field of the RD instruction was not zero (NRZ), the contents of $D$ are placed on the sum bus and are then clocked into the addressed private memory register. When the device response signal drops, data release flipflop $D R Q$ is set, marking the final PH 4 sequence.

A sequence chart of the Read Direct Internal Control Mode is shown in table 3-124. The External Mode Phase Sequence is shown in table 3-125.
3-253 Write Direct (WD 6D, ED)
Fifty-five separate input/output lines are associated with the write direct instruction. The 32 data lines, /DIO0/ through /DIO31/, are bidirectional lines used for data output during the write direct instruction. The output data is placed on the data lines from the sum bus.

Sixteen address lines, /DIO32/through /DIO47/, are used to address the output device. There are seven control lines, /DIO48/through /DIO54/. Line/DIO48/carries a strobe that informs the addressed device that data is present on the data lines. Line /DIO49/ carries a response signal from the addressed device. The signal on line/DIO50/is always true during write direct operations. Lines /DIO51/and /DIO52/ are input lines from the device that can be used for miscellaneous purposes. The status of the signals on these lines is transferred to condition code flip-flops CC3 and CC4. Line /DIO53/ is used to reset all output functions when the I/O RESET or SYS RESET switch-indicators are pressed or when power is first applied to the computer system. A $1-\mathrm{MHz}$ signal to all devices associated with the write directoperations is provided on line/DIO54/.

The WD instruction can be executed in one of three modes: internal control (table 3-126), interrupt control (table 3127), or output (table $3-12 \varepsilon$ ). The mode of execution is determined by the contents of bit positions 16 through 19 of the effective word. If these four bits contain a hexadecimal zero, the internal control mode is specified; if they contain a hexadecimal one, the interrupt control mode is specified; if they contain any hexadecimal number 2 through F , the output mode is specified. These three modes of WD execution are described in the following paragraphs.

When the WD instruction is executed in the internal control mode ( B 1619 Z ), bits 25 through 31 of the effective word determine the functions to be performed. (See figure 3-198.) The contents of the effective word are transferred to the $B$-register during the execution of the instruction and remain in the $B$-register until the end of the instruction; thus, the signal B1619Z represents the internal control mode of operation. Bits 25 through 31 of the B-register represent the function to be executed.

The interrupt inhibits can be set (if $\mathrm{B} 27=1$ ) or reset (if B27 $=0$ ) either individually or in any combination if a 1 bit is placed in bits 29, 30, or 31 . Bit 29 addresses the counter interrupt inhibit flip-flop Cl ; bit 30 addresses the input/output interrupt inhibit flip-flop II, and bit 31 addresses the priority interrupt inhibit flip-flop EI. A 1 bit in bit positions 25 and 31 sets the ALARM indicator on the processor control panel, and a 1 bit in bit position 25 anda 0 bit in bit position 31 resets the ALARM indicator. The AUDIC ALARM can be toggled by the flip-flop MUSIC if bit positions 25 and 30 both contain a one. Whenever the ALARM indicator is set and the CPU is in the RUN state (KRUN/B), the $P C P$ speaker emits a $1-\mathrm{kHz}$ signal to the panel speaker.

When the WD instruction is executed in the interrupt control mode (B1619ONE), bits 21 through 23 of the effective word (which is transferred to the B-register) determine the interrupt action code, and bits 28 through 31 address the interrupt group 0 through $F$. (See figure 3-199.)

The individual interrupt levels of the addressed interrupt group are addressed by 1 bits contained in bit positions 16 through 31 of the private memory register addressed by the R-field of the WD instruction word. In all code conditions except code 4 above, zeros in the addressed private memory register do not affect the current status of the associated interrupt levels.

The WD instruction operates in the output mode if bits 16 through 19 of the effective word represent a hexadecimal 2 through $F$ as shown in figure 3-200. Bits 20 through 31 of the effective word represent the address of the output device (such as a digital to analog converter or digital display) to which the output data is to be transferred. The output data is represented by the contents of the private memory register addressed by the $R$-field of the WD instruction word.
The write direct instruction in any of the three modes of operation can be indexed, indirectly addressed, or both.

Table 3-126. Write Direct Internal Control Mode, Phase Sequence

| Phase | Function Performed |  | Signals Involved | Comments |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PHI } \\ & \text { T4RL } \end{aligned}$ | Enable memory request for next instruction $\text { P16-P31 } \longrightarrow \text { S16-S31 }$ $\mathrm{S} 16-\mathrm{S} 31 \longrightarrow \mathrm{~B} 16-\mathrm{B} 31$ $0 ' s \nrightarrow B 0-B 31$ $1 \rightarrow \text { SW3 }$ <br> Go to PH2 | MRQ/ 1 <br> SXP <br> FADIO <br> $B X S$ <br> S/SW3 <br> S/PH2 | $\begin{aligned} & =\text { FARWD PHI }+\ldots \\ & =\text { FADIO PHI }+\ldots \\ & =\text { FARWD }+ \text { FAIO }+\ldots \\ & =\text { FADIO } \mathrm{PHI}+\ldots \\ & =\text { FADIO PHI }+\ldots \\ & =\text { PHI NBR N(...) }+\ldots \end{aligned}$ | Contains mode of operation (zeros in the case of internal mode) and function to be performed |
| $\begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ |  | T6L <br> DIO50XI <br> WDINTL <br> S/ALARM <br> ALARM/L <br> R/ALARM <br> S/MUSIC <br> R/MUSIC <br> WDINTL <br> AUDIO <br> INHXWD <br> S/CIF <br> R/CIF | $\begin{aligned} = & \text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \\ = & \text { OU6 OLD SW3 }+\ldots \\ = & \text { OU6 OLD PH2 B1619Z } \\ & +\ldots \\ = & \text { WDINTL B25 B3I } \\ = & \text { ALARM } \\ = & \text { WDINTL B25 + RESET } \\ = & \text { WDINTL B25 B30 NMUSIC } \\ = & \text { WDINTL B25 B30 } \\ = & \text { OU6 OLD PH2 B1619Z } \\ = & \text { MUSIC NALARM } \\ & +(A L A R M ~ K R U N / B) ~ 1 K C ~ \\ = & \text { OU6 OLD PH2 B1619Z B26 } \\ = & \text { INHXWD B27 B29 + ... } \\ = & \text { INHXWD B29 + ... } \end{aligned}$ | Alarm light on PCP <br> Inhibit counter interrupts <br> Allow counter interrupts |
| (Continued) |  |  |  | Mnemonic: WD (6D, ED) |

Table 3-126. Write Direct Internal Control Mode, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH2 <br> T6L <br> (Cont. | $\begin{aligned} & \text { If }(\text { INHXWD B27 B30) }=1 \text {, } \\ & \mathrm{I} \xrightarrow{\text { II }} \end{aligned}$ <br> If (INHXWD NB27 B30) $=1$, $0 \longrightarrow$ II <br> If (INHXWD B27 B31) $=1$, $1 \rightarrow E I$ <br> If (INHXWD NB27 B31) $=1$, $0 \longrightarrow \mathrm{EI}$ <br> Go to PH3 | S/II $=$ INHXWD B27 B30 $+\ldots$ <br> R/II $=$ INHXWD B30 $+\ldots$ <br> S/EI $=$ INHXWD B27 B31 $+\ldots$ <br> R/EI $=$ INHXWD B31 $+\ldots$ <br> S/PH3 $=$ PH2 NBR $+\ldots$ | Inhibit I/O interrupts <br> Allow I/O interrupts <br> Inhibit external interrupts <br> Allow external interrupts |
| PH3 | Enable T6L <br> If $\mathrm{SW} 1=0$, remain in PH 3 <br> $1 \longrightarrow /$ DIO50/ <br> $1 \rightarrow$ SWI <br> Read sense switches into condition codes <br> If SW1 = 1, go to PH4 |  | Identifies write direct |
| $\begin{aligned} & \text { PH4 } \\ & \text { T6L } \end{aligned}$ | Enable T6L <br> If $\mathrm{DRQ}=0$, remain in PH 4 and set data request | $\begin{aligned} \text { T6L } & =\text { NTIL NT4L NT8L NTIOL } \\ & \text { NRESET } \\ \text { BRPH4 }= & \text { FARWD PH4 NDRQ }+\ldots \\ \text { S/DRQ }= & \text { FARWD PH4 B1619Z }+\ldots \\ \text { R/SW3 }= & \text { CLEAR }+\ldots \\ \text { CLEAR }= & \text { ENDE }+\ldots \\ \text { ENDE }= & \text { FARWD PH4 DRQ }+\ldots \end{aligned}$ |  |
|  |  |  | Mnemonic: WD (6D, ED) |

Table 3-127. Write Direct Interrupt Control Mode, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\mathrm{PH} 1$ <br> T4RL | Enable memory request for next instruction $\text { P16-P31 }- \text { S16-S31 }$ <br> $\mathrm{S} 16-\mathrm{S} 31 \rightarrow \mathrm{~B} 16-\mathrm{B} 31$ <br> $\mathrm{O}^{\prime} \mathrm{s} \longrightarrow \mathrm{BO}-\mathrm{Bl} 5$ <br> R28-R31 $\longrightarrow$ LR28-LR31 <br> RRO-RR31 $\nrightarrow$ A0-A31 $1 \nrightarrow S W_{3}$ <br> Go to PH2 | $\begin{aligned} & \text { MRQ/I }=\text { FARWD PHI }+\ldots \\ & \text { SXP }=\text { FADIO PHI }+\ldots \\ & \text { BXS }=\text { FADIO PHI }+\ldots \\ & \text { Normal action } \\ & \text { AX/I }=\text { FARWD PHI + } \ldots \\ & S / S W 3=\text { FADIO PHI }+\ldots \\ & S / P H 2=\text { PHI NBR }+\ldots \end{aligned}$ | Contains mode (one in the case of interrupt) function and group address <br> Interrupt selection bits |
| $\left\lvert\, \begin{aligned} & \text { PH2 } \\ & \text { T6L } \end{aligned}\right.$ | Enable T6L $\text { B16-B31 } \longrightarrow / \mathrm{DIO} 32 /-/ \mathrm{DIO} 47 /$ $\text { If } R \neq 0, A 0-A 31 \longrightarrow S 0-S 31$ $\mathrm{S} 16-\mathrm{S} 31 \longrightarrow / \mathrm{DIO} 00 /-/ \mathrm{DIO} 15 /$ <br> Go to PH3 | $\begin{aligned} \text { T6L } & =\text { NTIL NT4L NT8L NTIOL NRESET } \\ \text { DIOXB } & =\text { FARWD SW } 3+\ldots \\ \text { SXA } & =\text { OU6 OLD SW3 NRZ }+\ldots \\ \text { DIOXS } & =\text { OU6 OLD SW3 NRZ }+\ldots \\ \text { S/PH3 } & =\text { PH2 NBR }+\ldots \end{aligned}$ | Mode function and group address to address lines <br> Selection bits to data lines. Bits 16-31 are used |
| $\left\lvert\, \begin{aligned} & \text { PH3 } \\ & \text { T6L } \end{aligned}\right.$ | Enable T6L $\begin{aligned} & \text { If } \mathrm{SW} 1=0 \text {, remain in } \mathrm{PH} 3 \\ & 1 \rightarrow \text { SW } 4 \end{aligned}$ | $\begin{aligned} \text { T6L } & =\text { NTIL NT4L NT8L NTIOL NRESET } \\ \text { BRPH3 } & =\text { (FARWD PH3) NSWI }+\ldots \\ \text { S/SW4 } & =\text { (FARWD PH3) NSWI }+\ldots \\ \text { R/SW4 } & =\text { FADIO SWI }+\ldots \\ \text { S/SW1 } & =\text { FARWD PH3 DIO49 } \\ \text { /DIO48/ } & =\text { DIO48XI } \\ \text { DIO48XI } & =\text { FARWD SW4 }+\ldots \\ W D & =/ \text { DIO50/ } \end{aligned}$ | DIO49 $\Rightarrow$ response from interrupt chassis |
|  |  | (Continued) | Mnemonic: WD (6D, ED) |

Table 3-127. Write Direct Interrupt Control Mode, Phase Sequence (Cont.)


Table 3-128. Write Direct Output Mode, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PHI <br> T4RL | Enable memory request for next instruction $\text { P16-P31 } \longrightarrow \text { S16-S31 }$ $\mathrm{S} 16-\mathrm{S} 31 \rightarrow \mathrm{~B} 16-\mathrm{B} 31$ $0 \text { 's } \rightarrow \mathrm{B} 0-\mathrm{Bl} 5$ $\text { R28-R31 } \longrightarrow \text { LR28-LR31 }$ $\text { RR0-RR31 } \longrightarrow \text { A0-A31 }$ $1 \rightarrow \text { SW3 }$ <br> Go to PH2 |  | Address of output device <br> Output data <br> Register into $A$ |
| $\left\lvert\, \begin{aligned} & \text { PH2 } \\ & \text { T6L } \end{aligned}\right.$ | Enable T6L $\mathrm{Bl} 6-\mathrm{B} 31 \longrightarrow / \mathrm{DIO} 32 /-/ \mathrm{DIO} 47 /$ <br> If $R \neq 0, A 0-A 31 \longrightarrow S 0-S 31$ $\mathrm{SO}-\mathrm{S31} \longrightarrow / \mathrm{DIO} 00 /-/ \mathrm{DIO} 31 /$ <br> Go to PH3 | T6L $=$NTIL NT4L NT8L NTIOL <br>  <br> NRESET <br> DIOXB $=$ FARWD SW3 $+\ldots$ <br> SXA $=$ OU6 OLD SW3 NRZ $+\ldots$ <br> DIOXS $=$ OU6 OLD SW3 NRZ $+\ldots$ <br> SPH3 $=$ PH2 NBR $+\ldots$ | Device address to DIO address lines <br> Data into DIO data lines |
| $\begin{array}{\|l\|l} \mathrm{PH} 3 \\ \mathrm{~T} 6 \mathrm{~L} \end{array}$ | Enable T6L <br> If SW1 $=0$, remain in PH 3 $1 \nrightarrow \text { SW } 4$ | T6L $=$NTIL NT4L NT8L NTIOL <br>  <br> NRESET <br> BRPH3 $=($ FARWD PH3 $) \mathrm{NSWI}+\ldots$ <br> S/SW4 $=($ FARWD PH3 $) \mathrm{NSWI}+\ldots$ <br> /DIO48/ $=$ DIO48XI <br> DIO48X1 $=$ FARWD SW4 $+\ldots$ <br> /DIO50/ $=$ DIO50X1 <br> DIO50XI $=$ OU6 OLD SW3 $+\ldots$ <br> WD $=/ D I O 50 /$ | Strobe to device |
|  |  | (Continued) | Mnemonic: WD (6D, ED) |

Table 3-12 . Write Direct Output Mode, Phase Sequence (Cont.)


$1617181920 \longrightarrow 24252627293031$

| 0 | 1 | 1 | $X$ | $C$ | $I$ | $E$ | SET INTERRUPT INHIBITS |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 1 | 0 | $X$ | $C$ | $I$ | $E$ | RESET INTERRUPT INHIBITS |
| 1 | 0 | 0 | $X$ | 0 | 0 | 1 | SET ALARM INDICATOR |
| 1 | 0 | 0 | $X$ | 0 | 0 | 0 | RESET ALARM INDICATOR |
| 1 | 0 | 0 | $X$ | 0 | 1 | 0 | TOGGLE AUDIO ALARM |

Figure 3-198. Write Direct Function Decoding in Internal Control Mode


Figure 3-199. Write Direct Interrupt Control Mode Action Decoding


Figure 3-200. Write Direct Output Mode Decoding

The normal preparation sequence, as well as the sequencing for all modes and conditions of the WD instruction, is described under Preparation Sequence.

3-254 INTERNAL CONTROL MODE. Timing for the WD instruction, internal control mode, is shown in figure 3-201. During PH1, the memory request for the next instruction is enabled. The contents of the P -register are transferred to the sum bus and are then clocked into B16 through B31. During the remaining sequences of the WD instruction execution the B-register contains the mode (B1619Z) and the function to be performed. Flip-flop SW3 is set at the PHI clock. The following flip-flops are set or are reset according to the contents of B25 through B31: ALARM, MUSIC, CIF, II, and EI.

The CPU sequences through two PH3 states. Flip-flop SW1 is true during the second PH 3 sequence and, at the next clock, the condition codes read the PCP sense switches.

The CPU sequences from PH3 to PH4 for two clock times. DRQ is set, and SW3 is reset.

A sequence chart of the Write Direct internal control mode is shown in table 3-126.

3-255 INTERRUPT CONTROL MODE. Timing for the WD instruction execution, interrupt control mode, is shown in
figure 3-202. During PH 1 the memory request for the next instruction is enabled, the contents of the $P$-register are transferred to the sum bus and are then clocked into the Bregister, B 16 through B 31 . During the remaining part of the execution, the $B$-register contains the mode (B16190NE), the function code in B21 through B23, and the interrupt group address in B28 through B31. Flip-flop SW3 is set.

The selection bits in the addressed private memory register are clocked into the A-register, and the contents of B16 through B31 are placed on DIO address lines /DIO31/ through /DIO47/.If the R-field of the WD instruction word did not address register 0 , the contents of $A$ are transferred to the sum bus, and sum bus bits S0 through S31 are placed on the DIO data lines /DIO00/through /DIO31/. Only bits 15 through 31 contain the selection bits. Flip-flop SW4 is set.

The write directoutput lines, /DIO00/through /DIO31/and WD address lines, /DIO32/through/DIO47/, are shown in figures 3-203 and 3-204, respectively. Figure 3-205 is a logic diagram showing the interrupt group and function decoding for the WD instruction in the interrupt control mode. The CPU sequences to PH 3 and remains in PH3 until SW1 is set. SWl does not set until response signal DIO49 is received from the interrupt circuits. /DIO49/ is delayed for a minimum of 3 but not more than 4 microseconds, and is timed by flip-flops CNA and CNB in the interrupt chassis, which are clocked by the $1-\mathrm{MHz}$ clock.


Figure 3-201. Write Direct Internal Mode, Timing Diagram


Figure 3-202. Write Direct Interrupt Mode, Timing Diagram



Figure 3-204. Write Direct Address Lines


Figure 3-205. Write Direct Interrupt Mode Function Decoding

Signal /DIO49/ is generated in the internal interrupt chassis for both internal and external interrupts.

The internal interrupts levels are enabled, disabled, armed, disarmed, or triggered when CNA is true, since the addressed interrupt group gate can be true only when CNA is true. For example:

$$
\begin{aligned}
G R P 0= & \text { NADDR12 NADDR13 NADDR14 } \\
& \text { NADDR15 CNA }
\end{aligned}
$$

The addressed group gate in the external interrupt chassis is selected by the group code from the CPU and switch settings for each chassis:

$$
\begin{array}{rll}
\text { GRPSEL }= & \text { N(GPADR0 } & \text { NSWTH0 } \\
& + \text { GPADR1 } & \text { NSWTH1 } \\
& + \text { GPADR2 } & \text { NSWTH2 } \\
& + \text { GPADR3 } & \text { NSWTH3 } \\
& + \text { NGPADR0 } & \text { SWTH0 } \\
& + \text { NGPADR1 } & \text { SWTHI } \\
& + \text { NGPADR2 } & \text { SWTH2 } \\
& + \text { NGPADR3 } & \text { SWTH3 })
\end{array}
$$

The individual interrupt levels within a group are selected by signals DATA16 through DATA31, which are generated from the selection bits on the CPU data lines. The equations for the internal interrupt circuits are as follows:

```
S/IN2 = AEENLEI DATAI6 + ...
R/IN2 = ADBDBI DATA16 + REN
    \vdots
S/IN15 = AEENLEI DATA29 + ...
R/IN15 := ADBDBI DATA29 + REN
S/SP2 =- AEADB1 DATA16 + ...
R/IP2 = DARM DATAI6 + ...
    \vdots
S/IP15 = AEADBI DATA29 + ...
R/IP15 = DARM DATA29 + ...
S/IS2 - TRIGI IP2 DATA16 + ...
R/IS2 = DARM DATA16 + ...
S/IS15 = TRIG1 IP15 DATA29 + ...
R/IS15 = DARM DATA29 + ...
```

The first two interrupt levels of the basic interrupts (power on, power off) are never addressed by the WD instruction. The data lines, DATA16 through DATA31, are offset by two when addressing group 0 interrupts compared to all other interrupt groups. For example:

|  | Basic <br> Interrupt <br> Group | External <br> Interrupt <br> Group |
| :---: | :---: | :---: |
| DATA16 | 2 | 0 |
| DATA17 | 3 | 1 |
| DATA18 | 4 | 2 |
| . | $\cdot$ | $\cdot$ |
| . | $\cdot$ | . |
| DATA28 | 14 | 12 |
| DATA29 | 15 | 13 |
| DATA30 |  | 14 |
| DATA31 |  | 15 |

When/DIO49/ comes true, SWl is set and the CPU sequences to PH4. The CPU remains in PH4 until /DIO49/drops.

The number of PH 3 and PH 4 iterations for any WD instruction execution depends on the time relationship of the T6L clock and the $1-\mathrm{MHz}$ clock as the instruction sequences out of PH2 into PH3.

A sequence chart of the Write Direct interrupt control mode is given in table 3-127.

3-256 OUTPUT MODE. Timing for the WD instruction, output mode, is shown in figure 3-206. During PHI the memory request for the next instruction is enabled, the contents of the P -register are transferred to the sum bus and are clocked into B16 through B31. During the remaining sequences of the WD instruction, the B-register contains the address of the output device. SW3 is set at the PHI clock.

The output data in the addressed private memory register is transferred from the RR lines to the A-register. The device address in $B$ is placed on the direct output address lines, /DIO32/through /DIO47/. If the R-field of the W'D instruction word was not zero, the output data is taken from the A-register, is placed onto the sum bus, and then is transferred to the output data lines, /DIO00/ through /DIO31/.


Figure 3-206. Write Direct External Mode, Timing Diagram

During PH3 the strobe signal /DIO48/is sent to the output device. The CPU remains in PH3 until the response signal from the device /DIO49/ is received. When /DIO49/goes true, SWI is set and, at the next clock condition, codes CC3 and CC4 are set according to the states of the device signals /DIO51/ and /DIO52/.

In PH4 the CPU waits for the device response signal /DIO49/ to fall. Flip-flop DRQ is set, and ENDE comes true to mark the final phase of the instruction.

A sequence chart of the Write Direct output mode is given in table 3-128.

## 3-257 Start Input/Output (SIO 4C, CC)

Before the SIO instruction is executed, private memory register RO must contain, in bit positions 16 through 31, the first command address for the IOP operation. This address is placed into the A-register together with the IOP, controller and device addresses and the status (zero, odd or even) of the $R$-field of the instruction word. This data in the A-register is stored into memory location $X^{\prime} 20^{\prime}$ as shown in figure 3-207.

After the CPU stores this data into location $X^{\prime} 20^{\prime}$, the IOP reads this same data. If the IOP, controller or device address is nonexistent, CCl is set and the SIO instruction execution is aborted. If these addresses are valid, the IOP performs the following operations:
a. If the R-field of the SIO instruction word is zero, the IOP attempts to start the addressed device. If the start is successful, CC2 is reset; if the start is not successful, CC2 is set.
b. If the R-field of the SIO instruction word is even, but is not zero, the IOP stores the current status and byte count of the IOP operation into memory location $X^{\prime} 20^{\prime}$, and stores the current command address into location $X^{\prime} 21$ '.
c. If the R-field of the SIO instruction word is odd, the IOP stores the status and byte count of the current IOP operation into memory location $X^{\prime} 21$ '.
If the contents of the R-field of the SIO instruction word are even but not zero, the CPU reads the contents of core memory location X'21' (current command address) into private memory register $R$, and reads the contents of $X^{\prime} 20^{\prime}$ (status and byte count) into private memory register $\mathrm{R}+1$.

A-REGISTER TO X'20'


CONTROLLER AND DEVICE ADDRESS

Figure 3-207. Start Input/Output Information Stored in Location $X^{\prime} 20^{\prime}$

If the contents of the R-field of the SIO instruction word are odd, the CPU reads the contents of $X^{\prime} 21^{\prime}$ (status and byte count) into private memory register $R$. The meaning of each of the various status bits for all input/output instructions (SIO, HIO, TIO, TDV, AIO) is given in table 3-129.

The preparation sequence for the SIO instruction is the same as the general preparation sequence described under the Preparation Sequence.

All conditions of the SIO instruction execution are described by the logic sequence diagram, figure 3-208. This diagram also describes the execution of all other input/output instructions (HIO, TIO, TDV, AIO). Figure 3-209 is a simplified timing diagram that applies to an SIO instruction when the R-field of the instruction word is even but is not zero. Figure 3-210 shows the timing for the same instruction when the R-field of the instruction word is zero, or when the R-field is not zero, but the IOP made an unsuccessful start.

In PHI the contents of the P -register (which contains the first command address) are transferred to the sum bus and are then clocked into the least significant halves of both the A-and B-registers. The indicator flip-flop SWI is reset, the data flip-flop SW3 is reset, and ones are clocked into the CS-register for the upward alignment of $A$ to the sum bus during PH2. The memory map is disabled, since locations $X^{\prime} 20^{\prime}$ and $X^{\prime} 21^{\prime}$ must always be actual addresses.
At PHI clock flip-flop NLRXR is set to force zeros onto the LR lines during PH2. During PH2 of an SIO instruction, the function code lines, FNC0 through FNC2, are gated to represent the type of input/output instruction, where:

| $\frac{\text { FNC0 }}{1}$ | $\frac{\text { FNC1 }}{1}$ | $\frac{F N C 2}{1}$ |  |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | Represents TIO (4D) |
| 0 | 1 | 0 | Represents TDV (4E) |
| 0 | 1 | 1 | Represents HIO (4F) |
| 1 | 1 | 0 | Represents AIO (6E) |

The LR lines are forced to an address of zero by NLRXR true. The 17 least significant bits of register R0 are read and are clocked into A16 through A31, but only if the instruction is an SIO. Bits A24 through A31 are realigned and are transferred to S0 through S7 and are clocked back into A0 through A7. A9 is set if the R-field of the instrucfion word is not zero. Á is set if the $\mathbb{R}$-fieid is an even number but is not zero. For all I/O instructions except $\mathrm{AIO}, \mathrm{MRQ}$ is enabled in PH 2 . The address release request flip-flop $A R Q$ is set and the $P$-register is set to an address of $20{ }_{16}$

In PH3 the strobe flip-flop SW4, the address release request flip-flop $A R Q$, and the data request flip-flop $D R Q$ are set. Phase 3 repeats until the proceed signal PR is received from the IOP. The indicator flip-flop SWl sets at the next clock after the proceed signal is received. The contents of the A-register are read into memory location 2016 in PH3, and condition codes CC1 and CC2 are set or reset according to the IOP signals COND1 and COND2.

At this point in PH3, two conditions can exist that sequence the CPU to PH8 to read the next instruction: CONDI true

Table 3-129. Status Bits for Input/Output Instructions



Figure 3-208. SIO, HIO, TIO, TDV, AIO, Logic Sequence Diagram (Sheet 1 of 2)


Figure 3-208. SIO, HIO, TIO, TDV, AIO, Logic Sequence Diagram (Sheet 2 of 2 )



901060A. 3684

Figure 3-210. SIO, R-Field Zero or R-Field Not Zero But Start Unsuccessful, Simplified Timing Diagram
(nonexistent IOP address), or the R-field of the instruction word was zero. In either case, the contents of memory locations $X^{\prime} 20^{\prime}$ and $X^{\prime} 21^{\prime}$ are not read into private memory. The memory map is enabled; $D R Q$ is set; and the next instruction address in $Q$ is transferred to the $P$-register.

If the R-field in the instruction word is not zero, flip-flop LB31/1 is set in order to address memory location $21{ }_{16}$ in PH4.

$$
\mathrm{S} / \mathrm{LB} 31 / 1=\mathrm{FAIO} \mathrm{PH} 3 \mathrm{NBR}
$$

If the instruction is an AIO with the R-field zero and the CONDl signal from the IOP true, the memory map is enabled, the next instruction address in $Q$ is transferred to $P$, and the CPU branches to PH6.

In PH5, the contents of the P-register are placed on the memory address lines. P equals $20_{16}$ if the $R$-field of the instruction word is even, and $A R Q$ is set; if the R-field of the instruction word is odd, the contents of $P$ are the next instruction address. At PH5 clock, the contents of location 2116 are transferred from the $C$-register into $D$.

In PH6, if the instruction is an AIO or if the R-field of the instruction word is even, $M R Q / 1$ is enabled to request the next instruction from memory. The data request flip-flop DRQ is set, and the next instruction address in the Qregister is clocked into $P$. The memory map is enabled, and flip-flop LR31/2 is set to address $\mathrm{R}+1$.

In PH7, if the instruction is not an AIO, the contents of memory location 20 are gated into the C -register and are then clocked into D. This data in D is not stored into register RO, however, until PH8. If the instruction is an SIO, HIO, TIO, or TDV, the 16 high order bits of $C$ are transferred to the 16 low order bits of D. D0 through D15 extend the status of $C 0$. The contents of $D$ are transferred to the sum bus, are placed onto the RW lines, and are then transferred to register $\mathrm{R}+1$.

In PH8, if the R-field of the instruction word is even, but is not zero, and if CCl is not true, the contents of the sum bus (the original contents of memory location 20 16 ) are transferred to register $R$.

A sequence chart of the Start Input/Output instruction is given in table 3-130.

## 3-258 Halt Input/Output (HIO 4F, CF)

The HIO instruction causes the addressed device to halt immediately its current operation. If the $R$-field of the HIO instruction is zero, condition codes CCl and CC 2 are affected, but no data is transferred into private memory registers. If the R-field of the HIO instruction is an even value but is not zero, condition codes CC1 and CC2 are affected, private memory register $R$ is loaded with the current command address, and register $R+1$ is loaded with the current status and the byte count of the IOP operation being halted. If the R-field of the HIO instruction word is an odd

Table 3-130. Start Input/Output, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PHI <br> T4RL | $\begin{aligned} & \mathrm{P} 16-\mathrm{P} 31 \longrightarrow \mathrm{~S} 16-\mathrm{S} 31 \\ & \mathrm{~S} 16-\mathrm{S} 31 \longrightarrow \mathrm{~A} 16-\mathrm{A} 31 \\ & \mathrm{~S} 16-\mathrm{S} 31 \rightarrow \mathrm{~B} 16-\mathrm{B} 31 \\ & 1 \mathrm{~s} \rightarrow \mathrm{CS} 0-\mathrm{CS} 31 \\ & 1 \rightarrow \mathrm{SW} 3 \\ & 1 \rightarrow \mathrm{SW} 1 \end{aligned}$ Disable MAP $\text { Prepare for 0's } \longrightarrow \text { LR in } \mathrm{PH} 2$ Select T6RL for PH2 <br> Go to PH2 | $\begin{array}{ll} \text { SXP } & =\text { FAIO PHI }+\ldots \\ \text { AXS } & =\text { FAIO PHI }+\ldots \\ \text { BXS } & =\text { FAIO PHI }+\ldots \\ \text { S/NPRX } & =\text { FAIO PHI }+\ldots \\ \text { CSXI } & =(S / \text { NPRX }) \\ \text { S/SW3 } & =\text { FAIO PHI }+\ldots \\ \text { R/SWI } & =\text { FAIO PHI }+\ldots \text { CLEAR }+\ldots \\ \text { S/MAPDIS } & =\text { FAIO PHI }+\ldots \\ \text { S } / \text { NLRXR } & =\text { FAIO PHI }+\ldots \\ \text { TGRL } & =\text { FAIO PHI }+\ldots \\ \text { S/PH2 } & =\text { PHI NBR }+\ldots \end{array}$ | I/O address <br> Ones into CS-register for upward alignment in PH2 <br> Data flip-flop <br> Indicator flip-flop <br> Since locations $X^{\prime} 20^{\prime}$ and $X^{\prime} 21$ ' must be actual addresses |
| $\left\lvert\, \begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} \text { TRL } \end{aligned}\right.$ | Enable T6L $\begin{aligned} & \mathrm{A} 24-\mathrm{A} 31 \longrightarrow \mathrm{~K} \longrightarrow \mathrm{~K} 23-\mathrm{K} 30 \\ & \mathrm{~K} 23-\mathrm{K} 30 \longrightarrow \mathrm{~S} 0-\mathrm{S} 7 \\ & \mathrm{~K} 23-\mathrm{K} 30 \longrightarrow \mathrm{~S}-\mathrm{S} 15 \\ & \mathrm{~K} 23-\mathrm{K} 30 \longrightarrow \mathrm{~S} 16-\mathrm{S} 23 \\ & \mathrm{~K} 23-\mathrm{K} 30 \longrightarrow \mathrm{~S} 24-\mathrm{S} 31 \end{aligned}$ <br> $\mathrm{O}^{\prime} \mathrm{s} \longrightarrow$ LR lines <br> RR16-RR31 $\rightarrow$ Al6-A31, if SIO <br> If $R \neq 0,1 \rightarrow A 9$ <br> If $R \neq 0$, but even, $!\rightarrow \Delta 8$ $20_{16} \rightarrow \mathrm{P} 16-\mathrm{P} 31$ |  | Upward align byte <br> Address private memory register D because NLRXR is true <br> Command address SIO only <br> Memory address 2016 |
|  |  | (Continued) | Mnemonic: SIO (4C, CC) |

Table 3-130. Start Input/Output, Phase Sequence (Cont.)


Table 3-130. Start Input/Output, Phase Sequence (Cont.)

| Thase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH3 <br> T6L <br> (Cont. | Enable MAP <br> Set data release request <br> Go to PH8 <br> Set condition codes <br> If $(\mathrm{AIO}, \mathrm{R}=0, \mathrm{CONDI}=1)$, <br> Enable MAP <br> Go to PH6, if AIO <br> Strobe IOP via CNST line <br> If no branch to PH6 or PH8, $1 \rightarrow L \text { B31/1 }$ <br> Go to PH4 |  | CONDI $\Rightarrow$ nonexistent IOP address |
| $\begin{aligned} & \mathrm{PH} 4 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | Enable T6L ${ }^{21_{16}} L \mathrm{LB} \text { ines }$ <br> Enable memory request <br> Set data release request <br> If R31 $=1$, <br> Q16-Q31 $\rightarrow$ P16-P31 <br> Go to PH5 | $\begin{array}{ll} \text { T6L } & =\begin{array}{l} \text { NTIL NT4L. NT8L NTIOL } \\ \\ \text { NRESET } \end{array} \\ \text { MRQ } & =\text { FAIO PH4 }+\ldots \\ \text { S/DRQ } & =\text { FAIO PH } 4+\ldots \\ \text { PXQ } & =\text { FAIO PH4 R3I }+\ldots \\ \text { S/PH5 } & =\text { PH4 NBR }+\ldots \end{array}$ | To read iocation $\mathrm{X}^{\prime 2} \mathrm{I}^{\circ}$ P26 set by PX20 in PH2. LB31 set in PH3 <br> If R-field was odd |
|  |  | (Continued) | Mnemonic: SIO (4C, CC) |

Table 3-130. Start Input/Output, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | Enable T6L <br> $\mathrm{C} 0-\mathrm{C} 31 \rightarrow$ D0-D31 <br> If R31 = 1, <br> Set address release reques $\dagger$ | $\begin{aligned} \text { T6L }= & \text { NTIL NT4L NT8L NT1OL } \\ & \text { NRESET } \\ \text { DXC } / 6= & \text { FAIO PH5 }+\ldots \\ \text { S/ARQ }= & \text { FAIO PH5 NR31 }+\ldots \end{aligned}$ | Contents of location X'21' |
| PH6 | Enable T6L <br> If AlO , or R31 $=1$ <br> Enable memory request <br> Set data release reques $\dagger$ <br> Q15-Q31 $\rightarrow$ P15-P31 <br> Enable MAP $\begin{aligned} & 1 \nleftarrow \mathrm{LR31} / 2 \\ & 1 \rightarrow \mathrm{~T} 1 \mathrm{~L} \end{aligned}$ <br> Go to PH7 | $\begin{array}{ll} \text { T6L } & =\begin{array}{l} \text { NTIL NT4L NT8L NTIOL } \\ \\ \text { NRESET } \end{array} \\ \text { MRQ/1 } & =\text { FAIO PH6 }(\text { NR31 }+\mathrm{O} 2)+\ldots \\ \text { S/DRQ } & =\text { FAIO PH6 }(\text { NR31 }+\mathrm{O} 2)+\ldots \\ \text { PXQ } & =\text { MRQ/1 }+\ldots \\ \text { R/MAPDIS } & =\text { FAIO PH6 }+\ldots \\ \text { S/LR3I/2 } & =\text { FAIO PH6 }+\ldots \\ \text { S/T8L } & =\text { FAIO PH6 }+\ldots \\ \text { S/PH7 } & =\text { PH6 NBR }+\ldots \end{array}$ | For next instruction <br> Next instruction address |
| $\begin{array}{\|l} \text { PH7 } \\ \text { T8L } \end{array}$ | If $\mathrm{AIO}, \mathrm{CO}-\mathrm{C} 31 \rightarrow$ D0-D31 <br> If not $\mathrm{AlO}, \mathrm{CO}-\mathrm{Cl5} \rightarrow$ D16-D31 $\mathrm{C} 0 \longrightarrow \text { D0-D15 }$ $\text { D0-D31 } \rightarrow \text { S0-S31 }$ $\text { S0-S31 } \longrightarrow \text { RW0-RW31 }$ <br> Set data request <br> Set T8L <br> Go to PH8 | $\begin{array}{ll} \text { DXC/6 } & =\text { OU6 OLE PH7 }+\ldots \\ \text { DXCR16 } & =\text { FAIO } / 1 \mathrm{PH} 7+\ldots \\ \text { SXD } & =\text { FAIO } / 1 \mathrm{PH} 7+\ldots \\ \text { RW } & =\text { FAIO } / 1 \mathrm{PH} 7+\ldots \\ \text { S/DRQ } & =\text { FAIO PH7 }+\ldots \\ (S / T 8 L) & =\text { FAIO PH7 }+\ldots \\ \text { S/PH8 } & =\text { PH7 NBR }+\ldots \end{array}$ | Contents of location ${ }^{20}{ }_{16}$ <br> Transfer contents of location X'21' to odd numbered private memory register |
|  |  | (Continued) | Mnemonic: SIO (4C, CC) |

Table 3-130. Start Input/ Output, Phase Sequence (Cont.)

value, condition codes CCl and CC 2 are affected, and register $R$ is loaded with the current status and the byte count of the IOP operation is halted. Register $R+1$ is not affected.

Condition codes CCl and CC 2 have the following meaning after the HIO instruction has been executed:

| $C C 1$ | $\underline{C C 2}$ |  |
| :--- | :--- | :--- |
| 0 | - | I/O address recognized |
| 1 | - | I/O address not recognized |
| - | 0 | Device not operating at time of the halt |
| - | 1 | Device operating at time of the halt |

The preparation sequence for the HIC instruction is the same as the general preparation sequence described under Preparation Sequence.

All conditions of the HIO instruction execution are described by the Logic Sequence Diagram, figure 3-208, and by the SIO execution sequence logic. An H lO instruction is identical to an SIO instruction in its execution except that register RO is not used, and therefore the contents of register RO are inhibited from entering the A-register in PH 2 by the equation

## $\mathrm{AXRR} / 2=\mathrm{OU4} \mathrm{OLC} \mathrm{PH} 2$

which applies only to an SIO instruction.

The meaning of the status bits in register $\mathrm{R}+1$ after the HIO instruction has been executed is described in table 3-129.

3-259 Test lnput/Output (TIO 4D, CD)
The TIO instruction interrogates the addressed IOP, controller, and device for its current status without affecting these units in any way. No input/output operations are initiated or are terminated by this instruction.

If the R-field of the TIO instruction is zero, condition codes $\mathrm{CC1}$ and CC2 are affected but no data is transferred into private memory registers. If the R-field of the TIO instruction is an even value but is not zero, condition codes CCl and CC2 are affected, private memory register $R$ is loaded with the current command address, and register $R+1$ is loaded with the current status and the remaining byte count of the IOP operation. If the R-field of the TIO instruction word is an odd value, condition codes $\mathrm{CC1}$ and CC 2 are affected, and register $R$ is loaded with the current status and the remaining byte count of the IOP operation; register $R+1$ is not affected. The meaning of the various status bits for the TIO instruction is given in table 3-129.

Condition codes CCl and CC2 have the following meanings after the TIO instruction has been executed:

| CCl | CC 2 |  |
| :---: | :---: | :---: |
| 0 | - | I/O address recognized |
| 1 | - | I/O address not recognized |
| - | 0 | Successful SIO is currently possible |
| - | 1 | Successful SIO is not currently possible |

The preparation sequence for the TIO instruction is the same as the general preparation sequence described under Preparation Sequence.
All conditions of the TIO instruction execution are described by the Logic Sequence Diagram, figure 3-208, and by the SIO execution sequence logic described in table 3-130. A TIO instruction is identical to an SIO instruction in its execution except that register RO is not used. Therefore, the contents of register R0 are inhibited from entering the Aregister in PH 2 by the equation which applies only to an SIO instruction.

## 3-260 Test Device (TDV 4E, CE)

The TDV instruction obtains information about the addressed device other than that obtainable by means of a TIO instruction. The operation of the selected IOP, controller, and device are not affected. No operations are initiated or are terminated by this instruction. Responses to TDV provide the program with information giving details on the condition of the selected device, the number of bytes remaining to be transmitted in the current operation, and the present point at which the IOP is operating in a command list.

If the R-field of the TDV instruction is zero, the condition code flip-flop CCl is affected but no private memory registers are affected. If the R-field of the instruction word is even, but not zero, the condition code flip-flop CCl is affected, register $R$ is loaded with the current command address, and register $R+1$ is loaded with the current status and the remaining byte count of the IOP operation. If the Rfield of the instruction word is odd, condition code flipflop CCl is set, and the device status and the remaining byte count are loaded into register $R$.

After the TDV instruction has been executed, condition code flip-flop CCI has the following meaning:

| $\frac{\mathrm{CCl}}{}$ |  |
| :---: | :--- |
| 0 | I/O address recognized |
| 1 | I/O address not recognized |

The preparation sequence for the TDV instruction is the same as the general preparation sequence described under Preparation Sequence.
All conditions of the TDV instruction execution are described by the logic sequence diagram, figure 3-208 and by the SIO
execution sequence logic described in table 3-130. A TDV instruction is identical to an SIO instruction in its execution except that register RO is not used. Therefore, the contents of register R0 are inhibited from entering the A-register in PH 2 by the equation

$$
\mathrm{AXRR} / 2=\mathrm{OU} 4 \mathrm{OLC} \mathrm{PH} 2
$$

which applies only to an SIO instruction.

## 3-261 Acknowledge Input/Output (AIO 6E, EE)

The AIO instruction is used to acknowledge an I/O interrupt and to identify the source and the reason for the interrupt. Bits 21 through 23 of the effective program address of the AIO instruction word (the IOP address portion of the I/O selection code field) specify the type of interrupt being acknowledged. For the standard I/O system interrupt acknowledgement, these bits should be coded 000 . Other codings are reserved for use with special I/O systems.

If the R-field of the AIO instruction word is zero, only condition code flip-flops CCl and CC 2 are affected. CC1 and $C C 2$ are affected if the R-field of the AIO instruction word is not zero. Register $R$ is loaded with status identification bits and with the address of the interrupting I/O unit. The status bits for acknowledging an I/O interrupt are described in table 3-129.

After the TDV instruction has been executed, condition code flip-flops CCl and CC2 have the following meanings:

| CC1 | CC2 |  |
| :---: | :---: | :--- |
| 0 | - | I/O interrupt recognition |
| 1 | - | NoI/O interrupt is present |
| - | 0 | Normal interrupt |
| - | 1 | Unusual condition interrupt |

The preparation sequence for the AIO instruction is the same as the general preparation sequence described under Preparation Sequence.

All conditions of the AIO instruction execution are described by the logic sequence diagram, figure 3-208, and by the SIO execution sequence logic described in table $3-130$. The execution of an AlO instruction is similar to the execution of an SIO instruction except that register RO is not used. Therefore, the contents of register RO are inhibited from entering the A-register in PH2 by the equation

$$
\mathrm{AXRR} / 2=\mathrm{OU} 4 \mathrm{OLC} \mathrm{PH} 2
$$

which applies only to an SIO instruction.

## 3-262 FLOATING POINT FEATURE

## 3-263 General

Implemented floating point instructions can be used to add, subtract, multiply, and divide floating point numbers. Floating point instructions are implemented by the addition of the floating point option to the Sigma 7 computer system. If the floating point option is not implemented in the computer and if execution of a floating point instruction is attempted, the computer will abort execution of the instruction and will trap to location $X^{\prime} 41^{\prime}(65)$, the unimplemented instruction trap location.

The following floating point instructions are included in the floating point option:

| Instruction | Mnemonic | Basic Family |
| :---: | :---: | :---: |
| Floating Add Short | FAS | FAFLAS |
| Floating Add Long | FAL | FAFLAS |
| Floating Subtract Short | FSS | FAFLAS |
| Floating Subtract Long | FSL | FAFLAS |
| Floating Multiply Short | FMS | FAFLM |
| Floating Multiply Long | FML | FAFLM |
| Floating Divide Short | FDS | FAFLD |
| Floating Divide Long | FDL | FAFLD |

## 3-264 Floating Point Formats

There are short and long floating point number formats possible with the Sigma 7 computer. Both are shown in figure $3-211$. The short format is made up of a sign bit (bit 0 ), a biased base -16 exponent (bits 1 through 7), and a 24-bit fraction (bits 8 through 31).

The long format floating point number adds 32 bits of lower significance to the fraction. The short format floating point number can be contained in a single word of memory or in one general register; the long format floating point number occupies a doubleword memory location or an even-odd pair of general registers.


901060A. 31400

Figure 3-211. Short and Long Floating Point Formats

The range of numbers that can be expressed in both the short and the long floating point formats and the register for sample floating point numbers are shown in figure 3-212. The floating point number contained in a register is expressed by the equation

$$
\text { Floating point number }=F \times 16^{E}
$$

The fraction of the floating point number, $F$, is contained in bit position 0 (sign) and in bit positions 8 through 31 (short format) or 8 through 63 (long format). The binary point is before bit position 8. The fraction is in true form if the sign bit is zero (positive floating point number). It is in two's complement form if the sign bit is a one (negative floating point number).

Bit positions 1 through 7 contain a quantity that is 64 more than the exponent, $E$, of the floating point number. This is the biased exponent (excess 64). Subtracting 64 from this quantity produces the actual or unbiased exponent of the floating point number. If the floating point number is positive (sign bit zero), the exponent is in true form; if the floating point number is negative (sign bit one), the exponent is in one's complement form. The term inverted exponent refers to the one's complemented (negated) form; the term uninverted exponent refers to the true form of the exponent of a floating point number.

Biasing the exponent by 64 and inverting the biased exponent of a negative number enables processing of floating point numbers with fixed-point instructions, making possible, for example, the performance of a Compare instruction.

The range of Sigma 7 floating point numbers is from approximately $+16^{63}$ to approximately $-16^{63}$ for both short and long formats. (The most positive and most negative long format floating point numbers are slightly more positive or negative than the short format because of the extra bits of
significance of the fraction.) There are several types of floating point numbers which equal zero. A number with a zero fraction and a zero-biased exponent (shown in figure 3-212), for example, is a true zero. A number with a fraction of zero and a nonzero, biased exponent is an abnormal zero and may or may not be treated as a true zero.

## 3-265 Implementation of Floating Point Instructions

## 3-266 MODULE ADDITIONS FOR FLOATING POINT

 OPTION. Forty-eight modules are added to the Sigma 7 system to implement the floating point arithmetic instructions. In addition to providing floating point logic circuits, these modules contain the circuitry required to extend five of the CPU registers by 25 bit positions. The CPU registers and their floating point extensions are shown in figure 3-213. The $S$-bus extension is also shown.
## 3-267 FLOATING POINT REGISTER NOMENCLATURE.

 In the discussion of floating point instructions, the following nomenclature will be used:a. The letters $A, B, C, C S$, and $D$ refer to bit positions 0 (MSB) through 31 of the respective register ( 32 bits). The letter $S$ refers to bit positions 0 through 31 of the sum bus.
b. The designations $A^{\prime}, B^{\prime}, C^{\prime}, C S^{\prime}$, and $D^{\prime}$ refer to bit positions 47 (MSB) through 71 of the respective register ( 25 bits). The designation $S$ refers to bit positions 47 through 71 of the sum bus.
c. The designations $A^{\prime \prime}, B^{\prime \prime}, C^{\prime \prime}, C S^{\prime \prime}$, and $D^{\prime \prime}$ refer to bit positions 47 (MSB) through 31 ( 57 bits) of the respective registers; $S^{\prime \prime}$ refers to bit positions 47 through 31 of the sum bus.


Figure 3-213. Floating Point Register Extensions

3-268 Description of Floating Point Instructions
3-269 FLOATING ADD SHORT (FAS 3D, BD). Instruction FAS adds the effective word from core memory and the contents of an odd or even numbered private memory register. If no floating point arithmetic faultoccurs, the sum is stored back in the same odd or even numbered private memory register as a short format floating point number.
3-270 FLOATING ADD LONG (FAL 1D, 9D). Instruction FAL adds the effective doubleword from core memory and the contents of an odd and even numbered private memory register. If no floating point arithmetic fault occurs, the sum is stored back in the same two registers as a long for mat floating point number. The R-field of the instruction word must be an even value for a correct result.
3-271 FLOATING SUBTRACT SHORT (FSS 3C, BC). Instruction FSS is identical to instruction FAS except that the effective word from core memory is subtracted from the contents of the private memory register.
3-272 FLOATING SUBTRACT LONG(FSL 1C,9C). Instruction FSL is identical to instruction FAL except that the effective doubleword from core memory is subtracted from the contents of the odd and even numbered private memory registers.
3-273 FLOATING MULTIPLY SHORT (FMS 3F, BF). Instruction FMS multiplies the effective word from core memory by the contents of an odd or even numbered private memory register, after effective prenormalization of both operands. The product is postnormalized. If the R-field of the instruction word is an even value and if there is no fault condition, the product is loaded into the odd and even numbered private memory registers as a long format floating point number. If the R-field is an odd value and there is no fault condition, the product is loaded into the odd numbered private memory register as a truncated short format floating point number.
3-274 FLOATING MULTIPLY LONG (FML 1F, 9F). Instruction FML multiplies the effective doubleword from core memory by the contents of the odd and even numbered private memory registers after prenormalization of both operands. The product is postnormalized and, if no floating point arithmetic fault occurs, the product is truncated to a long format floating point number and is loaded into the odd and even numbered private memory registers. The $R$-field of the instruction word must be an even value for correct results.
3-275 FLOATING DIVIDE SHORT (FDS 3E, BE). Instruction FDS divides the contents of an odd or even numbered private memory register by the effective word from core memory after prenormalization of both operands. If no floating point arithmetic fault occurs, the quotient is loaded back into the odd or even numbered private memory register as a short format floating point number.

3-276 FLOATING DIVIDE LONG (FDL IE, 9E). Instruction FDL divides the contents of the odd and even numbered private memory registers by the effective doubleword from
core memory after prenormalization of both operands. If no floating point arithmetic fault occurs, the quotient is loaded back into the same two registers as a long format floating point number. The R-field of the instruction word must be even for the correct result.

## 3-277 FLOATING POINT CONDITION CODES AND MODE CONTROL BITS. Three mode control bits, FS

 (floating significance), FN (floating normalize), and FZ (floating zero), in the program status doubleword, are used to qualify floating point operations. The floating mode control bits and condition code settings are described under the discussion of the individual floating point operation codes.
## 3-278 Floating Point Concepts

3-279 SHIFTING FLOATING POINT NUMBERS. Shifting floating point numbers is accomplished by adjusting both the fraction and the exponent of the floating point number. Changing the exponent by one changes the size of the number by a factor of $16\left(2^{4}\right)$. The minimum shift in the fraction of a floating point number, consequently, is four bit positions (one hexadecimal place, shortened to one hex). A right shift of one hex necessitates adding one to the exponent in addition to shifting the fraction; a left shift of one hex necessitates subtracting one from the exponent. Each successive shift of one changes the exponent by one bit. A right shift is usually used during overflow adjustment and is used to equalize exponents of two numbers. A left shift is usually used during normalization procedures. Examples of floating point shifts are shown in figure 3-214.

In the following discussion of floating point operation codes, shifting will always refer, unless otherwise noted, to shifting the fraction of the floating point number one hexadecimal place (four bit positions) and changing the exponent by one bit (one power of 16 ).

3-280 GENERAL NORMALIZATION. A floating point number is normalized if the absolute value of the fraction is less than one but is equal to or is greater than $1 / 16$. The fraction of a positive floating point number must have a one somewhere in the four most significant bits for the number to be normalized. The fraction of a negative floating point number is in two's complement form. A negative floating point number, therefore, must have a zero somewhere in the four most significant bits or have all ones in the four most significant bits and all zeros in the remaining digits. The following lists all possible cases.

| Normalized Positive Floating Point Numbers |  | Normalized Negative Floating Point Numbers |  |
| :---: | :---: | :---: | :---: |
| $0 \mid x \times x \times x \times x$ | $0001 \times x \rightarrow x$ | $1 \mid x \times x \times x \times x$ | 111100-0 |
|  |  |  | $1110 x x-x$ |
| $0 \mid x \times x \times x \times x$ | $0010 x x \rightarrow x$ | $1 \mid$ xxxxxx | $1101 \times x \rightarrow x$ |
| $0 \mid x \times x \times x \times x$ | $1111 \times x \rightarrow x$ | 1\|xxx ${ }^{\text {a }} \times \times \times x$ | 0000xx $\rightarrow$ x |



Figure 3-214. Shifting Floating Point Numbers

The negative floating point number $1 \times x \times x \times x \times 0000 \longrightarrow 0$ is illegal, since the absolute value of the fraction is greater than the number of bit positions allocated for the fraction. This number is always changed to an equal number whose exponent is one greater than the original and whose fraction is $1 / 16$ of the original.

$$
\begin{aligned}
1|0000010| 0 \longrightarrow 0 & =-1 \times 16^{61} \\
1|0000001| 11110 \longrightarrow 0 & =-1 / 16 \times 16^{62} \\
-1 \times 16^{61} & =-1 / 16 \times 16^{62}
\end{aligned}
$$

Normalization of floating point numbers in implementation of floating point instructions may occur before the arithmetic operation takes place (prenormalization) or after the arithmetic operation (postnormalization). Normalization is usually performed on absolute numbers. Both prenormalization and postnormalization are accomplished by left shifting operations. Left shifting continues until the absolute value of the fraction is greater than or is equal to $1 / 16$. Normalization is illustrated in figure 3-215.

3-281 SIMPLE NORMALIZATION. Valid floating point numbers in the Sigma 7 memory are numbers whose fractions are in the range $1 / 16 \leq|N|<1$. In the hardware, however, the computer tolerates another range of floating point numbers while arithmetic operations are performed. Floating point number, valid in the execution of an instruction, may be in the ranges $+1 / 16 \leq N<1$ and $-1 \leq N<-1 / 16$. Numbers in these ranges are called simple nörmalized numbers.

3-282 TRUNCATION. A floating point number may be truncated when it is necessary to discard some of the least significant bits of the number. Multiplication of two long format floating point numbers, for example, produces a fraction product of 112 bits, of which it is convenient to retain only 56.

Truncation takes the place of rounding off a number and is accomplished simply by discarding the unwanted bits. The error in the truncated number may range from 0 (when 0.00100000 is truncated to 0.0010 , for example) to almost one bit of the lowest order in the truncated number (when 0.00101111 is truncated to 0.0010 ). Since it is more

NUMBER TO BE
NORMALIZED
(SHORT FORMAT)

$$
\begin{aligned}
& +\left(\frac{1}{2^{15}}\right) \times 16^{1}
\end{aligned}
$$

FIRST SHIFT


SECOND SHIFT


## THIRD SHIFT, NORMALIZED NUMBER



FRACTION $=\frac{1}{8}\left(>\frac{1}{16}\right)$

Figure 3-215. Normalization of Floating Point Numbers
accurate to truncate absolute values than negative numbers, negative numbers are always put in the absolute form in the Sigma 7 operations where truncation may occur.

3-283 OVERFLOW AND UNDERFLOW. There are two types of overflow in floating point operations: fraction (mantissa) and exponent (characteristic). When fraction overflow occurs, the fault is easily corrected by shifting the absolute value of the floating point number one hex to the right. There may be some error in the adjustment process because of truncation. Fraction overflow is illustrated in figure 3-216.

When exponent overflow occurs during any floating point instruction, a trap to memory location $X^{\prime} 44^{\prime}$ (68) always occurs.

Underflow occurs if the final result of an addition, subtraction, multiplication, or division cannot be postnormalized because the result is smaller than the smallest possible
quantity which can be represented in the computer. Underflow may cause a trap to location X'44' (68); it may cause a setting of the result to true zero; or it may be ignored, depending on the floating point mode control bits.

## 3-284 Floating Point Addition and Subtraction (FAFLAS)

3-285 GENERAL. The implementation of addition and subtraction of floating point numbers is nearly identical since, for example, subtracting $(A)$ from $(B)$ is identical to adding ( $-A$ ) to ( $B$ ). Operations with short and long format numbers are also very similar; there are only differences in the number of digits to be operated upon. Because of the similarities between operations and format, all FAFLAS operation codes (FAS, FAL, FSS, FSL) are discussed as a group, with differences between them noted in the discussion. The floating point number which is operated upon is called the augend whether it is the actual augend (addition) or the minuend (subtraction), and the floating point number which is added or is subtracted is called the addend (whether


Figure 3-216. Fraction Overflow and Adjustment
it is the addend or subtrahend). The result of the operation is always called the sum.

3-286 FLOATING POINT MODE CONTROL BITS. The three floating point mode control bits, FN, FZ, and FS, determine the operation of floating point addition and subtraction. The three are interrelated and the setting of one bit may affect the other two.

If mode control bit FN, floating normalize, equals zero, the results of the addition or subtraction are postnormalized. If underflow occurs, result is zero, or if more than two postnormalization shifts ( 4 bit positions each) are required, the settings for FZ and FS determine the resultant action. If FN $=1$, postnormalization of the result is inhibited, and the settings of FZ and FS have no effect on the instruction operation.
$F Z$, floating zero, is effective only when $\mathrm{FN}=0$. If FN $=0$ and $F Z=0$, underflow causes the results to be setequal to true zero. The one exception to this is if FS $=1$ and a trap occurs. In this case, the underflow generated in the process of postnormalization is ignored. If $\mathrm{FN}=0$ and FZ $=1$, underflow causes the result to trap to location $X^{\prime} 44^{\prime}$ (68).

FS, floating significance, is valid only when $\mathrm{FN}=0$. If $\mathrm{FN}=0$ and $\mathrm{FS}=1$, and if more than two postnormalizing
shifts are required or if the result is zero, the computer traps to location $\mathrm{X}^{\prime} 44^{\prime}$ (68). If $\mathrm{FN}=0$ and $\mathrm{FS}=0$, the significance trap is inhibited. If the result of an addition or subtraction is zero, the result is set equal to true zero, and no trap occurs. No trap occurs if more than two postnormalizing shifts are required and underflow does not occur.

3-287 EXPONENT OVERFLOW. If exponent overflow occurs, the computer always traps to location $X^{\prime} 44^{\prime}(68)$.

3-288 CONDITICN CODE SETTINGS. The condition code settings and their meanings for floating point addition and subtraction are shown in table 3-131.

3-289 BASIC STEPS IN FAFLAS IMPLEMENTING. To add or to subtract two floating point numbers in Sigma 7, the following basic steps are performed:
a. Transfer of operands ( PHI and PH 3 ): The augend (from private memory) and the addend (from core memory) are transferred to the arithmetic unit registers.
b. Exponent differencing ( PH 2 and PH 3 ): The uninverted biased addend exponent is subtracted from the uninverted biased augend exponent.
c. Equalization of exponents (PH4 through PH8): The exponent difference is examined.

Table 3-131. Condition Codes for Floating Point Addition and Subtraction


1. If the difference is zero, the exponents of the augend and the addend are the same and the two floating point numbers can be added or subtracted.
2. If the difference is not zero, the exponents of the augend and the addend are different, and the smaller floating point number must be adjusted (shifted right) so that its exponent equals the exponent of the other. When the exponents of both floating point numbers are equal or when the fraction of the smaller number is found to be zero, the numbers are ready for addition or subtraction.
d. Addition (PH9): The augend and addend fractions are added. The exponent of the floating point number that was not adjusted (originally the larger number) is unbiased by subtracting 64 from it.
e. Overflow detection and postnormalization (PHI2): The sum of the fractions is changed to its absolute value and examined.
3. If fraction overflow has occurred, the absolute value of the sum is shifted one hex to the right to correct the overflow condition.
4. If fraction overflow has not occurred, if the sum is not simple normalized, and if $\mathrm{FN}=0$, the absolute value of the sum is shifted one hex to the left for the first try at normalization.
5. The sum is left unchanged, if fraction overflow has not occurred, and if the sum is simple normalized or if normalization is to be inhibited (FN - 1).
f. Postnormalization (PH13): The adjusted sum is examined.
6. The result is ready for storage if the sum is normalized or if it is not normalized and $\mathrm{FN}=1$, or if the sum is zero. Sixty-four is added to the exponent to bias it once again.
7. If the sum is not normalized, if $\mathrm{FN}=0$, and if the result is not zero, the sum is shifted left one hex at a time until it is normalized. Step 1 above is then performed.
g. Storage (PH13 and PH15): The biased exponent and the fraction result are assimilated and are stored in memory in proper form if there is no trap condition.

An example of FAFLAS implementation is shown in figure 3-217. The lettered steps correspond to the basic steps discussed.

## 3-290 DETAILED STEPS IN FAFLAS IMPLEMENTATION.

Figure 3-218 shows the FAFLAS phases and the operations performed for each phase. The following discussion is supplemented by table 3-132 and by figure 3-218.

The preparation sequence is the same as the general preparation sequence.
a. PHI. At the PHI clock, the most significant word (MSW) of the augend is transferred to the A-register from the even numbered private memory register by signal AXRR. The MSW of the addend has already been transferred to the C -register from core memory during the preparation phases. Flip-flop RN is set at the PH1 clock if the augend is negative; flip-flop MWN is set if the addend is negative. Flipflop CXCL32 is set for use in PH2. Flip-flops CCl and CC2 are reset for underflow and overflow tests in PH 15 , and flip-flop IEN is set to start interruptibility. Ones are forced into flip-flops CS0 through CS7 by signal CSX1/5 to invert the augend exponent to its true form if the augend is negative.

```
R/CCl = FAFL PHI + ...
R/CC2 - FAMDSF PHI NFAMULH + ...
```

b. PH2. At the PH2 clock, the fraction part of the augend MSW (or the complete fraction if FAS or FSS is being performed) is transferred by signal AXAL32 from flipflops A0 and A8 through A31 to A47 and A48 through A71, respectively. The fraction part of the addend MSW is transferred to the $C$-register extension ( $\mathrm{C}^{\prime}$ ) in the same manner by signal CXCL32. The augend and addend exponents are set up in PH2 for exponent differencing. The uninverted (absolute) augend exponent either is present in flip-flops Al through A7 or is found by combining bits Al through A7 with bits CSO through CS7 (all ones) in an exclusive OR operation. The uninverted augend exponent is gated to the sum bus during PH 2 and, at the PH 2 clock, is transferred from the sum bus to two locations: flip -flops A 0 through A 7 and BO through B 7 by signals $A X S / 1$ and $B X S$, respectively. Flip-flops $B O$ through $B 7$ retain the uninverted exponent for later use.

The uninverted addend exponent must be subtracted in exponent differencing. The inverted addend exponent is therefore transferred to flip-flops D0 through D7 (signals DXC/6 or DXNC). A one is forced into flip-flop CS7 by signal CS7X1 in preparation for exponent differencing. (The contents of flip-flops A0 through A7, D0 through D7, and CS7 are later added to find the difference of exponents.)

Ones are forced on core memory address line LB31 and on private memory line LR31 for possible use in PH3 (with FAL or FSL). If FAL or FSL are being implemented, signal MRQ (memory request) is enabled and flip-flop DRQ (data release) is set to transfer the least significant word (1SW) of the augend to the C-register at the PH3 clock. Clock T6RL is enabled for PH3 if FAL is being performed. If FAS or FSS is being implemented, flip-flop $\mathrm{CX} / 1$ is set at the PH 2 clock to force all zeros into the C -register in PH 3 .
c. PH3. During PH3, the uninverted exponent augend (in flip-flops A0 through A7) and the two's complemented addend exponent (in flip-flops D0 through D7 and CS7) are added, and the result gated to the sum bus. At the PH3 clock, the sum bus outputs on S0 through S7 are transferred to flip-flops EO through E7 by signal EXS. Flip-flops EO through E7 now hold the difference of exponents, which may be zero, positive, or negative. E0 is the sign bit of the difference. If $E 0$ is a zero, the difference is positive or zero and is in true form. If EO is a one, the difference is negative and in two's complemented form.

If FAL or FSL is being implemented, the ISW of the augend is clocked into flip-flops A0 through A31 from the odd numbered private memory register by signal AXRR. The 1 SW of the addend is clocked into C0 through C31. If FAS or FSS is in effect, zeros are clocked into flip-flops A0 through A31 (no gating term is present) and are forced into C0 through C31 (signal CX/1 is set in PH 2 ).
d. PH4 through PH8. Phases 4 through 8 are the phases in which the exponents of the augend and the addend are compared and are equalized, if necessary.

| A. TRANSFER OF OPERANDS: | $\begin{aligned} & (F N: 0) \\ & 0 \left\lvert\, \begin{array}{llllll\|lllllllllll} 1 & 0 & 0 & 0 & 1 & 1 & 1 & 0 & 0 & 0 & 0^{1} & 0 & 0 & 0 & 0 & 0 & 1 \end{array} 0\right. \\ & \hline \end{aligned}$ |
| :---: | :---: |
| B. EXPONENT DIFFERENCING: | $\begin{aligned} & \begin{array}{l} \text { SIGN BIT } \\ 0 \end{array} 1 \\ & 1 \end{aligned} 0$ |
| C. EQUALIZATION OF EXPONENTS: <br> EXAMINE EXPONENT DIFFERENCE <br> ADJUST SMALLER FLOATING POINT NUMBER <br> EXAMINE EXPONENT DIFFERENCE |  |
| D. ADDITION: <br> UNBIAS EQUALIZED EXPONENT |  |
| E. OVERFLOW DETECTION AND POSTNORMALIZATION: <br> change to absolute value AND EXAMINE <br> FIRST POSTNORMALIZATION TRY <br> F. POSTNORMALIZATION: <br> BIAS EXPONENT |  |
| G. STORAGE: <br> CHANGE TO PROPER FORM AND STORE | $1 \left\lvert\, \begin{array}{lllllll\|llllllllll} 0 & 1 & 1 & 1 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \end{array} 0\right.$ $\begin{aligned} & \text { RESULT } \\ & -\left(2^{-1} \times 16^{\cdot 7}\right. \end{aligned}$ |

Figure 3-217. Example of FAFLAS Implementation (Floating Add)


Table 3-132. Floating Add, Floating Subtract(FAFLAS), Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PREP | Same as general preparation sequence |  |  |
| $\mathrm{PH}]$ <br> T4RL | $\text { RRO-RR31 } \rightarrow \text { A0-A31 }$ <br> Set flip-flop RN if augend negative <br> MBO-MB31 $\rightarrow$ CO-C31 <br> Set flip-flop MWN if addend negative <br> Set flip-flop CXCL 32 <br> Reset flip-flops CC1 and CC2 <br> Force ones into CSO-CS7 <br> Set flip-flop IEN <br> Enable clock T6L | AXRR $=$ RNRXRRO/2 PHI $+\ldots$ <br>  $=$ FAFL PHI $+\ldots$ <br> S/RN $=$ RRO RNRXRRO $+\ldots$ <br>  $\because$ RRO PHI FAFL $+\ldots$ <br> Preparation control  <br> S/MWN $=$ $C 0 C 16$ FAMDSF PHI $+\ldots$ <br>  $=$ MBO NP32 CXMB $+\ldots$ <br> S/CXCL32 $=$ FAFL PHI $+\ldots$ <br> R/CCI $=$ FAFL PHI $+\ldots$ <br> R/CC2 $=$ FAMDSF PHI NFAMULH $+\ldots$ <br> CSXI/5 $=$ FAFL PHI $+\ldots$ <br> S/IEN $=$ FAMDSF NFAMUL PHI $+\ldots$ <br> T6L $=$ NTIL NT4L NT8L NTIOL NRESET | MSW of augend $\rightarrow \mathrm{A}$ <br> Stores augend sign <br> MSW of addend $\rightarrow C$ <br> Stores addend sign <br> For PH2 use <br> For PH15 use <br> To invert the augend exponent if augend negative <br> Starts interruptibility |
| $\begin{array}{\|l\|} \mathrm{PH} 2 \\ \mathrm{~T} 6 \mathrm{~L} \end{array}$ | $\begin{aligned} & \begin{array}{l} \mathrm{A} 0, \mathrm{~A} 8-\mathrm{A} 31 \longrightarrow \mathrm{~A} 47, \mathrm{~A} 48-\mathrm{A} 71 \\ \mathrm{C} 0, \mathrm{C} 8-\mathrm{C} 31 \longrightarrow \mathrm{C} 47, \mathrm{C} 48-\mathrm{C} 71 \end{array} \\ & \begin{array}{l} \mathrm{A} 0-\mathrm{A} 7+\mathrm{CS0}-\mathrm{CS} 7 \longrightarrow \text { or } \\ \text { augend negative } \end{array} \\ & \begin{array}{l} \mathrm{A} 0-\mathrm{A} 7 \longrightarrow \mathrm{~S} 7 \text { if } \\ \text { tive } \end{array} \\ & \text { S0-S7 }\left\{\begin{array}{l} \longrightarrow \mathrm{S} 7 \text { if augend posi- } \\ \begin{array}{l} \text { C0-C7 } \\ \text { negative } \end{array} \text { B0-A7 } \end{array}\right. \\ & \text { D0-D7 if addend } \end{aligned}$ <br> or <br> NC0-NC7 $\rightarrow$ D0-D7 if addend positive | $\begin{aligned} \text { AXAL32 } & =\text { FAFL PH2 } \\ \text { CXCL32 } & =\text { Set in PHI } \\ \text { SXPR } & =\text { FAFL PH2 RN }+\ldots \\ \text { SXA } & =\text { FAFL PH2 NRN }+\ldots \\ \text { AXS/1 } & =\text { FAFL PH2 }+\ldots \\ & =\text { FAFL PH2 N(FAFLM NO2) } \\ \text { DXC/6 } & =\text { FAFL PH2 NMWN }+\ldots \end{aligned}$ <br> DXNC : FAFL PH2 NMWN + ... | MSW of augend $\rightarrow A^{\prime}$ <br> MSW of addend $\longrightarrow \mathrm{C}^{\prime}$ <br> Uninverted augend exponent <br> Inverted addend exponent |
|  |  |  | Mnemonic: FAS (3D, BD), FAL (1D, 9D), FSS (3C, $\mathrm{BC})$, FSL ( $1 \mathrm{C}, 9 \mathrm{C}$ ) |

Table 3-132. Floating Add, Floating Subtract (FAFLAS), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH2 <br> T6L <br> (Cont. ) | Force a one into CS7 <br> Force a one onto LB31 address line <br> Force a one onto LR31 address line Enable $M R Q$ if $F A L$ or $F S L$ <br> Set flip-flop DRQ if FAL or FSL <br> Set flip-flop $C X /$ if FAS or FSS <br> Enable clock T6RL if FAL or FSL | $\begin{array}{ll} \text { CS7X1 } & =\text { FAFL PH2 NFAFLM } \\ \text { S/LB31/1 } & =\text { FAFL PH2 }+\ldots \\ \text { R/NLR31/2 } & =\text { LR31/2 }=\text { FAFL PH2 }+\ldots \\ \text { MRQ } & =\text { FAFL PH2 NO2 }+\ldots \\ \text { S/DRQ } & =\text { FAFL PH2 NO2 }+\ldots \\ \text { S/CX/1 } & =\text { FAFL PH2 O2 }+\ldots \\ \text { T6RL } & =\text { FAFL PH2 NO2 }+\ldots \end{array}$ | For two's complement subtraction (PH3) <br> Selects LSW of addend <br> Selects LSW of augend <br> Inhibits transmission of another clock until data release signal is received <br> To clear C0-C31 in PH3 |
| PH3 <br> T6L <br> if short <br> T6RL <br> if long | Enable clock T6L | SXK $/ 1=$ FAFL PH3 $+\ldots$ <br> SXPR $/ 1=$ FAFL PH3 $+\ldots$ <br> EXS $=$ FAFL PH3 $+\ldots$ <br> AXRR $=$ FAFL PH3 N(FAFLM ASN) NO2 <br>  $+\ldots$ <br> See PH2  <br> AX/1 $=$  <br> AXS $/ 4=$  <br> T6L $=$ FAFL PH3 N(FAFLM ASN $)+\ldots$ <br>  $=$ | Unbiased exponent difference $\rightarrow$ E0-E7 <br> LSW of augend $\rightarrow$ A <br> LSW of addend $\rightarrow \mathrm{C}$ <br> A47-A71 remains the same |
| $\begin{aligned} & \text { PH4 } \\ & \text { T6L } \end{aligned}$ | Case 1: E0-E7 $=0$ <br> C47-C71 $\rightarrow$ D47-D71 <br> if FAS or FAL <br> $\left.\begin{array}{ll}\text { NC47-NC71 } \longrightarrow \text { D47-D71 } \\ \text { Force } 1 \text { into CS31 }\end{array}\right\} \begin{aligned} & \text { if FSS } \\ & \text { if FSS } \\ & \text { or FSL }\end{aligned}$ <br> Set flip-flop T8L <br> Enable PH9 | $\begin{array}{ll} \text { DXC/6 } & =\text { FAFLAS PH4 EZ O7 }+\ldots \\ \text { DXNC/1 } & =\text { FAFLAS PH4 EZ NO7 }+\ldots \\ \text { DXNC/1 } & =\text { Same } \\ \text { R/NT8L } & =\text { T8L }=\text { FAFLAS PH4 EZ }+\ldots \\ \text { BRPHG } & - \text { FAFLAS PH4 : E2 }+\ldots \end{array}$ | For two's complement |
|  |  | (Continued) | Mnemonic: FAS (3D, BD), FAL (1D, 9D), FSS (3C, BC), FSL (1C, 9C) |

Table 3-132. Floating Add, Floating Subtract (FAFLAS), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH4 <br> T6L <br> (Cont.) | Case 2: E0-E7 > 0 $\mathrm{C} 47-\mathrm{C} 31 \rightarrow \text { D47-D31 }$ <br> Set flip-flop CXS <br> Case 3: E0-E7 < 0 <br> $\mathrm{D} 1-\mathrm{D} 7 \rightarrow \mathrm{~B} 1-\mathrm{B} 7$ <br> Clear D-register <br> Increment E-register by one <br> $\left.\begin{array}{l}\text { Set flip-flop NGX } \\ \text { Set flip-flop FPR }\end{array}\right\} \begin{aligned} & \text { if } \\ & \text { augend } \\ & \text { negative }\end{aligned}$ <br> Set clock T8L <br> Enable PH7 | $\begin{aligned} & \text { DXC/6 }=\text { FAFLAS PH4 NEO NEZ }+\ldots \\ & \text { S/CXS }=\text { FAFLAS PH4 NEO NEZ }+\ldots \\ & \text { BXND }=\text { FAFLAS PH4 EO } \\ & \text { DX/1 }=\text { FAFLAS PH4 }+\ldots \\ & \text { PCTE1 }=\text { FAFLAS PH4 E0 }+\ldots \\ & \text { S/NGX }=\text { FAFLAS PH4 EO RN }+\ldots \\ & \text { S/FPR }=\text { FAFLAS PH4EO RN }+\ldots \\ & \text { R/NT8L }=\text { T8L }=\text { FAFLAS PH4E0 }+\ldots \\ & \text { BRPH7 }=\text { FAFLAS PH4 E0 }+\ldots \end{aligned}$ | For PH5 use <br> Augend exponent B1-B7 <br> To record PH7 shift <br> For PH7 use <br> Result must be reversed |
| PH5 | (Entered from PH4, case 2) <br> A47-A31 $\longrightarrow$ S47-S31 $\mathrm{S} 47-\mathrm{S} 31 \longrightarrow \mathrm{C} 47-\mathrm{C} 31$ <br> Clear A-register <br> Set flip-flop NGX if addend negative <br> Decrement E-register by one <br> Set FPR if absolute value of the addend is opposite to form required for addition or subtraction <br> Set clock T8L | $\begin{aligned} \text { SXA }= & \text { FAFL PH5 }+\ldots \\ \text { CXS }= & \text { Set in PH4 } \\ \text { AX/1 }= & \text { FAFLAS PH5 }+\ldots \\ S / N G X= & \text { FAFLAS PH5 MWN }+\ldots \\ \text { MCTE }= & \text { FAFLAS PH5 }+\ldots \\ S / F P R= & \text { FAFLAS PH5 }(\text { MWN O7 } \\ & + \text { NMWN NO7 }+\ldots \\ \text { R/NT8L }= & \text { T8L }- \text { FAFLAS PH5 }+\ldots \end{aligned}$ | Augend fraction $\qquad$ S47-S31 <br> To record PH6 shift <br> Result must be reversed |
| PH6 TEL | (Entered from PH5) $\begin{aligned} & \mid \text { D47-D31 } \longrightarrow \text { S47-S31 } \\ & \text { S47-S31 } \times 1 / 16 \rightarrow \text { A51-A31 } \end{aligned}$ | $\begin{aligned} & \text { SXADD }=\text { FAFLAS PH6 }+\ldots \\ & \text { AXSR4 }=\text { FAFLAS PH6 }+\ldots \end{aligned}$ | Shift addend to the right one hex |
|  |  | (Continued) | Mnemonic: FAS (3D, BD), FAL (ID, 9D), FSS (3C, $B C), F S L(1 C, 9 C)$ |

Table 3-132. Floating Add, Floating Subtract (FAFLAS), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH6 } \\ & \text { T8L } \\ & \text { (Cont.) } \end{aligned}$ | $\left.\begin{array}{l}\text { NC47-NC71 } \rightarrow \text { D47-D71 } \\ \text { Force one into CS31 }\end{array}\right\} \begin{aligned} & \text { if } \\ & \text { FPR }\end{aligned}$ <br> Decrement E-register by one <br> If E0-E7 is zero, enable PH 9 and set flip-flop T8L <br> or <br> If E0-E7 is not zero, enable PH8 | $\begin{aligned} & \text { DXC/6 }=\text { FAFLAS PH6 NFPR }+\ldots \\ & \text { DXNC/1 }=\text { FAFLAS PH6 FPR }+\ldots \\ & \text { DXNC/1 }=\text { Same } \\ & \text { MCTE1 }=\text { FAFLAS PH6 }+\ldots \\ & \text { BRPH9 }=\text { FAFLAS PH6 EZ }+\ldots \\ & \text { R/NT8L }=\text { T8L }=\text { FAFLAS PH8 EZ }+\ldots \\ & \text { BRPH8 }=\text { FAFLAS PH6 NEZ }+\ldots \end{aligned}$ | Augend $D^{\prime \prime}$, sign reversed if sign of addend was reversed <br> For two's complement <br> To record next shift |
| $\left\lvert\, \begin{aligned} & \mathrm{PH} 7 \\ & \mathrm{~T} 8 \mathrm{~L} \end{aligned}\right.$ | (Entered from PH4, case 3) $\begin{aligned} & \|\mathrm{A} 47-\mathrm{A} 31\| \longrightarrow \mathrm{S} 47-\mathrm{S} 31 \\ & \mathrm{~S} 47-\mathrm{S} 31 \times 1 / 16 \rightarrow \mathrm{~A} 51-\mathrm{A} 31 \end{aligned}$ <br> Increment E-register by one <br> C47-C31 $\rightarrow$ D47-D31 if performing addition with NFPR or subtraction with FPR <br> or <br> NC47-NC31 $\rightarrow$ D47-D31 if not the above <br> If E0-E7 is zero, enable PH9 and set flip flop TBL | $\begin{aligned} & \text { SXADD }=\text { FAFLAS PH7 }+\ldots \\ & \text { AXSR4 }=\text { FAFLAS PH7 }+\ldots \\ & \text { PCTEI }=\text { FAFLAS PH7 }+\ldots \\ & \text { DXC/ } 6=\text { FAFLAS PH7 }(\mathrm{O} 7 \oplus \text { FPR })+\ldots \\ & \text { DXNC/I }=\text { FAFLAS PH7 N }(\mathrm{O} 7 \oplus \text { FPR })+\ldots \\ & \text { BRPH9 }=\text { FAFLAS PH7 EZ }+\ldots \\ & \text { R/NT8L }=\text { T8L }=\text { FAFLAS PH7 EZ }+\ldots \end{aligned}$ | Shift absolute value of augend one hex to the right <br> Change addend in same sense as augend was changed |
| $\begin{aligned} & \text { PH8 } \\ & \text { T6L } \end{aligned}$ | (Entered from PH 6 or PH 7 ) <br> 0-8 clocks if FAS or FSS <br> 0-15 clocks if FAL or FSL <br> A47-A71 $\longrightarrow$ S47-S71 if FAS or FSS <br> A47-A31 $\longrightarrow$ S47-S31 if FAL or FSL | $\begin{aligned} & \text { SXA } / 3=\text { FAFLAS PH8 O2 }+\ldots \\ & \text { SXA }=\text { FAFLAS PH8 NO2 }+\ldots \end{aligned}$ | Zeros to S0-S31 |
|  |  | (Continued) | Mnemonic: FAS (3D, BD), FAL (1D, 9D), FSS (3C, BC). FSL (1C, 9C) |

Table 3-132. Floating Add, Floating Subtract (FAFLAS), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH8 T6L (Cont.) | $\mathrm{S} 47-\mathrm{S} 31 \times 1 / 16 \rightarrow \mathrm{~A} 47-\mathrm{A} 31$ <br> Increment E-register by one if E is negative <br> or <br> Decrement E-register by one if E is positive <br> Retain state of CS31 for PH9 <br> Sustain PH8 if E0-E7 is nonzero and if A47-A31 is nonzero <br> or <br> Advance to PH9 if not above and set flip-flop T8L | $\begin{aligned} \text { AXSR4 } & =\text { FAFLAS PH8 }+\ldots \\ \text { PCTE } 1 & =\text { FAFLAS PH8E0 }+\ldots \\ \text { MCTE1 } & =\text { FAFLAS PH8 NEZ } \\ \text { R/CS31 } & =\text { N(FAFLAS PH8) }+\ldots \\ \text { BRPH8 } & =\text { FAFLAS PH8 NEZ NA473IZ }+\ldots \\ \text { R/NT8L } & =\text { T8L }=\text { FAFLAS PH8 EZ }+\ldots \end{aligned}$ | Shift augend or addend right one hex. A0-A3 is guard digit for FAS and FSS <br> Count towards zero <br> Remains set for two's complement |
| $\left\lvert\, \begin{gathered} \text { PH9 } \\ \text { T8L } \\ \text { or } \\ \text { T6L } \end{gathered}\right.$ | (Entered from PH4 case 1, PH6, PH7, or PH8) $\begin{aligned} & \text { A47-A31 + D47-D31 } \\ & + \text { CS31 } \longrightarrow \text { S47-S31 } \end{aligned}$ $\mathrm{S} 47-\mathrm{S} 31 \rightarrow \mathrm{~A} 47-\mathrm{A} 31$ <br> Set flip-flop FMOF if fraction overflow exists $(\mathrm{Bl}-\mathrm{B7})-64{ }_{10} \rightarrow \mathrm{EO}-\mathrm{E} 7$ <br> Clear B-register <br> Clear D-register <br> Set flip-flop NGX <br> Enable MRQ/1 | ```SXADD = FAFLAS PH9 + ... AXS = FAFLAS PH9 NFMOF (ASN + FNF) S/FMOF = FAFLAS PH9 (A47 D47 NK47 + NA47 ND47 K47) EXB = FAFLAS PH9 + ... BX/1 = FAFLAS PH9 + ... DX/1 = FAFLAS PH9 + ... S/NGX = FAFLAS PH9 + ... MRQ/1 = FAFLAS PH9 + ...``` | Fraction sum $\longrightarrow$ A47- <br> A31 (Inverted if FPR). <br> Does not include case 1 <br> Unbiased exponent of sum $\rightarrow E 0-E 7$ <br> Memory request for next instruction |
|  |  | (Continued) | Mnemonic: FAS (3D, BD), FAL (1D, 9D), FSS (3C, $B C)$, $F S L(1 C, 9 C)$ |

Table 3-132. Floating Add, Floating Subtract (FAFLAS), Phase Sequence (Cont.)


Table 3-132. Floating Add, Floating Subtract (FAFLAS), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PH12 } \\ & \text { T8L } \\ & \text { (Cont.) } \end{aligned}$ | Clear D-register <br> Set flip-flop NGX <br> Set flip-flop G0003/1 if FAS or FSS <br> Set flip-flop T10L if FAL or FSL <br> Force a one onto LR31 address line | $\begin{array}{ll} \text { DX/1 } & =\text { FAFL PH12 }+\ldots \\ \text { S/NGX } & =\text { FAFL PH12 }+\ldots \\ (S / G 0003 / 1) & =\text { FAFL PH12 NFPRD } \\ \text { S/T10L } & =\text { FPRD PH12 }+\ldots \\ \text { FPRD } & =\text { FAFL NO2 }+\ldots \\ \text { R/NLR31 } / 2 & =\text { LR31/2 } 2 \text { FAFL PH12 }+\ldots \end{array}$ | For PHI 3 use Causes K71 in PHI3 |
| PHI3 <br> T6L <br> or <br> TIOL | 1-6 clocks if FAS or FSS <br> 1-13 clocks if FAL or FSL <br> Case 1: NFPRR - Result Not Ready for Storage <br> $\mathrm{A} 47-\mathrm{A} 31 \longrightarrow$ S47-S31 <br> Sustain PHI3 <br> Set flip-flop TIOL if FAL or FSL and more than two postnormalizing shifts are required <br> Force a one on LR31 address line <br> Set flip-flop NGX <br> S47-S31 $\times 1 / 16 \rightarrow$ A51-A31 Increment E0-E7 by one $\left\{\begin{array}{l}\text { If } \\ \text { A47 } \\ \text { is a } \\ \text { one }\end{array}\right.$ <br>  $\mathrm{B} 31 \rightarrow \mathrm{~B} 30$ |  | Absolute value of sum equals + case 1. \|Sum| $\times 1 / 16 \longrightarrow A^{\prime \prime}$. Result now ready for storage <br> 0-5 clocks if FAS or FSS, $0-12$ clocks if FAL or FSL. After last clock result is ready for storage |

Table 3-132. Floating Add, Floating (FAFLAS), Phase Sequence (Cont.)


Table 3-132. Floating Add, Floating (FAFLAS), Phase Sequence (Cont.)


There are three possible quantities that flip-flops E0 through E7 may contain at the beginning of PH4: all zeros, a positive number, or a negative number. If E0 through E7 are all zeros, signal $E Z$ goes true. If a positive number is present, NEZ is true and EO goes false. A negative quantity is defined by a one in E0. If flip-flops E0 through E7 are zeros, the augend and addend exponents are equal, the augend and addend are set up for addition or subtraction, and a branch to PH9 occurs. If flip-flops E0 through E7 are positive, the augend exponent is larger than the addend exponent. The augend and addend are interchanged, and the addend is shifted to the right until the addend exponent equals the augend exponent (flip-flops E0 through E7 = 0). The shifting and the examination process occurs in PH 5 , PH6, and possibly in PH8. PH8 is used if the original exponent difference was greater than one. If flip-flops E0 through E7 are negative, the addend exponent is larger than the augend exponent. The augend is shifted to the right until the augend exponent equals the addend exponent. The shifting and the examination process occurs in PH 7 and possibly is PH8.

EZ = NE0 NE1 NE2 NE3 NE4 NE5 NE6 NE7

1. PH4, flip-flops E0 through E7 $=0$. If the augend and the addend exponents are equal, PH 4 is used to set up the addend for the addition or the subtraction of the two floating point numbers. If FAS or FAL is being performed, the complete fraction of the addend in bits C47 through C31 is transferred to flip-flops D47 through D31 at the PH4 clock (signal DXC/6). Bits C0 through C31 contain zeros if FAS is being implemented. If FSS or FSL is being performed, the inverted added fraction is transferred to flipflops D47 through D31, and a one for the two's complement is forced into flip-flop CS31 by signal DXNC/1. PH9 and clock T8L are enabled.

## 2. PH4, flip-flops E0 through E7>0. If the aug-

 end exponent is greater than the addend expenent, PH4 is used to set up the registers for the interchange of the addend and the augend. The complete fraction of the addend in bits C47 through C31 is transferred to flip-flops D47 through D31 at the PH4 clock by signal DXC/6. The addend fraction is held temporarily in $\mathrm{D}^{\prime \prime}$ register until it can be transferred to the A-register in PH6. Flip-flop CXS is set for use in PH5.3. PH4, flip-flops E0 through E7 $>0$. If the addend exponent is larger than the augend exponent, PH 4 is used to set up the augend for right-shifting in PH7 and PH8. The inverted addend exponent is in flip flops D0 through D7. The absolute value of the addend exponent is taken by transferring bits ND0 through ND7 to flip-flops B1 through B7. (Flip-flops B1 through B7 always hold the absolute value of the larger of the original exponents.) The D-register is
cleared at the PH4 clock by signal DX/1. The E-register contents are incremented by one to record the right shift which occurs in PH7 (E-register is counting toward zero). PH 7 and T 8 L are enabled.

If the augend is negative, flip-flops NGX and FPR are set. NGX is used in the right shift during PH7. Signal FPR signifies that the floating point polarity of the result of the addition or the subtraction should be reversed. If the augend is negative, it is changed to positive before the addition for shifting purposes. The addend is also inverted to retain the same relationship to the augend. The result of the addition is therefore the inverse of the proper result.
e. PH5. PH5 is entered only if the E-register contained a positive number in PH 4 (the augend was greater than the addend). PH5 is used to transfer the augend fraction to the $C^{\prime \prime}$-register. The augend fraction in flip-flops A47 through A31 is gated to the sum bus by signal SXA and is transferred at the PH5 clock to the C"-register by signal CXS. The $A^{\prime \prime}$-register is cleared by signal $A X / 1$. The $E-$ register contents are decremented by one to record the first right shift of the addend in PH6. (The E-register is counting toward zero.) Flip-flop NGX is se' for use in PH6 if the addend is negative. The absolute value of the addend must be taken for shifting purposes. Flip-flop FPR is consequently set if the absolute value of the addend is opposite to the form required for addition or subtraction (if an addition is being performed with a negative addend or if a subtraction is being performed with a positive addend). Clock T8L is enabled for PH6.
f. PH6. PH6 is entered only from PH5 (the augend was greater than the addend in PH4). PH6 is used to complete the interchange of augend and addend and to perform the first shift of the addend. The absolute value of the addend is gated to the sum bus by signal SXADD. (NGX was set in PH5 if addend was negative.) The sum bus outputs are shifted one hex to the right and are transferred to the $A$ "register at the PH6 clock. The E-register contents are decremented one count to record a possible PH8 shift.

The augend was put into $\mathrm{C} "$-register in PH5. If flip-flop FPR has been set, the sign of the addend is opposite to what it should be, and likewise, the augend sign must be reversed. The augend is transferred to the D "-register by signal $\mathrm{DXC} / 6$ at the PH6 clock if signal FPR is false. The inverted augend is transferred to the $\mathrm{D}^{\prime \prime}$-register, and a one is forced into flip-flop CS31 for the two's complement by signal DXNC/1 if FPR is true. If the E-register contains a zero at the PH6 clock, PH9 and T8L are enabled. If flip-flops E0 through E7 are not aii zeros, more shifiting of the addend must be done, and PH8 is enabled.
g. PH7. PH7 is entered only if the E-register contained a negative number in PH 4 (the addend was greater
than the augend). PH7 is used to perform the first shift of the augend. The absolute value of the augend is gated to the sum bus from the $A "$-register by signal SXADD. (NGX was set in PH5 if the addend was negative.) The sum bus outputs are shifted one hex to the right and are transferred back to the A"-register at the PH6 clock. The E-register contents are incremented by one count.

Since the absolute value of the augend has been taken, the sign of the addend must also be reversed either if FPR is true and an addition is being performed or if FPR is false and a subtraction is being performed. Either the addend or the inverted addend is transferred to the $D$ "-register at the PH6 clock (signals DXC/6 and DXNC/1, respectively). A one is forced into flip-flop CS31 if the inverted addend is transferred to complete the two's complemented addend. If the E-register contains a zero at the PH7 clock, PH9 and T8L are enabled. If flip-flops E0 through E7 are not all zeros, more shifting of the augend must be done, and PH8 is entered.
h. PH8. PH8 is entered from either PH6 (the augend was greater than the addend) or PH 7 (the addend was greater than the augend). If PH8 is entered, it signifies that the difference of augend and addend exponents was greater than one and that more shifting is required before the addition can take place. If FAS or FSS is being performed, the augend or the addend in flip-flops A47 through A71 is gated to sum bus outputs $S 47$ through S 71 by signal $\mathrm{SXA} / 3$. If FAL or FSL is in effect, flip-flops A47 through A31 are gated to S47 through S 31 by signal SXA. The sum bus outputs are shifted one hex to the right and are transferred back into the Aregister at the PH8 clock. If FAS or FSS is being implemented, only bits A47 through A31 are significant. The bits in flip-flop A0 through A3 are the guard digits which may be retained in the final answer if postnormalization is needed. The count in the E-register is counted toward zero by incrementing the contents by one (if the contents are negative) or by decrementing the contents by one (if the contents are positive). Flip-flop CS31 remains set for complement for an inverted operand in the D-register. This must be held until the addition or subtraction takes place; repeater flip-flop CS31 is therefore not reset.

If the E-register is nonzero at the PH8 clock, PH8 is sustained and another shift is performed. If the E-register contains zero at any PH8 clock, the addend and augend exponents are equal and the addition or the subtraction can be performed. PH9 and clock T8L are enabled in this case. PH9 may also be enabled if a zero fraction in flip-flops A47 through A31 is detected. PH9 is enabled in this case but clock T8L is not, since carry propagation time in the addition is not required.
i. PH9 is the addition phase of FAFLAS, entered from $\mathrm{PH} 4, \mathrm{PH} 6, \mathrm{PH} 7$, or PH 8 . At this point in the
implementation, the exponents of the augend and the addend are equalized and the addition or subtraction can take place. The augend and the addend in the A-and D-registers (not necessarily in that order) and bit CS31 are added and the fraction result (sum) gated to the sum bus by signal SXADD. At the PH9 clock, the result on S47 through S31 is transferred from the sum bus outputs to flip-flops A47 through A31. If signal FPR is true at this time, the result obtained in the addition process has the opposite polarity of the correct result. The result will be inverted in a later phase.

Fraction (mantissa) overflow may occur with the addition. When two positive or two negative numbers are added and their absolute sum is greater than or is equal to one, the usual overflow that occurs is a carry into the sign bit position. Maximum overflow into bit position 46 exists when the sum of the addition is -2 . Overflow is corrected in all cases by a right shift of one hex. Flip-flop FMOF (floating point mantissa overflow) is set if overflow exists, but not if the overflow is caused by a sum of -1 . Overflow is corrected in PH 12 if FMOF is set, or in PHI 3 if caused by a sum of -1 .

Flip-flops B1 through B7 contain the biased uninverted exponent of the sum (put in the register in PH2 or PH4). Sixtyfour is subtracted from this by inverting the content of flipflop B1 and by transferring B1 through B7 to E0 through E7. The result is the unbiased exponent of the sum. Bit El is now used as the sign bit of the exponent and the seven exponent bits may represent a positive or negative number, depending upon the state of bit E1. If bits El through E7 are a negative number (bit $\mathrm{El}=1$ ), it is in two's complement form.

The $B$ - and $D$-registers are cleared by signals $B X / 1$ and $D X / 1$, respectively, at the PH9 clock. Flip-flop NGX is set for PH12 use. Memory request signal MRQ/1 is enabled to request the next instructions; interruptibility is stopped by resetting flip-flops IEN; and PH12 and T8L are enabled.
i. PH 12 . PH 12 is used for overflow adjustments and first posinormalization attempts. The absolute value of the fraction result is gated to the sum bus by signal SXADD (if the result is negative) or by signal SXA (if the result is positive). Fraction overflow causes the state of bit position 47 of the result to be reversed. A negative result is detected either when there has been no overflow and the sign bit is true or when there has been overflow and the sign bit is false. A positive result is detected when the opposite conditions are true. The state of flip-flop FPR is reversed if the result generated in PH9 was negative, since the taking of the absolute value has changed the result from negative to positive.

There are three possible sets of conditions at the beginning of PH12: overflow, no overflow with postnormalization not necessary, and no overflow with postnormalization necessary.

When overflow has occurred, the absolute value of the result must be shifted one hex to the right. If FMOF is true, the sum bus outputs $S 47$ through S 27 are shifted this amount to the right and are transferred back into the A-register at the PH12 clock. The unbiased exponent in the E-register is incremented by one as the fraction result is shifted. A special case of overflow occurs if FMOF is true and if flip-flops A47 through A31 contain all zeros. This is the case when the addition or the subtraction has yielded -2 . A one is forced into flip-flop A50 as the number is shifted in this case.

If overflow has not occurred and the result is simple normalized, or if the result is not simple normalized and postnormalization is to be inhibited (mode control bit $\mathrm{FN}=1$ ), the absolute value of the result is transferred to the $A$ "-register at the PHI2 clock by signal AXS.

If overflow has not occurred, and if the result is not simple normalized (postnormalization is to be performed), the sum bus outputs S51 through S31 are shifted one hex to the left and are transferred into flip-flops A47 through A27 at the PHI2 clock. The unbiased exponent in the E-register is decremented by one count as the shift is made. This is the first try at postnormalization; if other shifts are required, they are performed in $\mathrm{PHI3}$. Also at the PH12 clock, a one is forced into flip-flop BC31. Flip-flops BC31, B31, and B30 form the postnormalization counter. When the first postnormalization attempt is made ( PHI 2 or PHI 3 ), flipflop BC31 is set. The B-register was cleared in PH9; it shifts left one bit position ( $\mathrm{B} 30<-1 \mathrm{~B} 31-1-\mathrm{BC} 31$ ) for each postnormalization attempt. If flip-flop B31 contains a one and if postnormalization is still in progress or if flip-flop B30 contains a one when the result is ready for storage, more than two postnormalization shifts have taken place.

If overflow has not been detected and if flip-flops A47 through A31 contain all zeros, the result is equal to zero. Flip-flop RTZ is set in this case for use in following phases. The $D$-register is cleared by signal $D X / 1$, and flip-flop NGX is set for PHI3 use. If FAS or FSS is being performed, flip-flop G0003/1 is set for PH13 use. If FAL or FSL is being performed, clock T1OL is enabled. A one is forced on private memory address line LR31 for transfer of the LSW of the result into the odd numbered private memory register in PHI3.
k. PH13. PH 13 is the postnormalization phase of FAFLAS. The result at this time is either ready for storage or not ready for storage. The result is not ready for storage if, at the beginning of PHI3 or after adjustment, bit A47 is true or if there is a nonzero result that must be postnormalized. The result is ready for storage if bit A47 is not true, and there is a zero result, if the result is postnormalized, or if postnormalization is to be inhibited.

If the result is not ready for storage (NFPRR true), it is gated to the sum bus by signal SXA during PHI3. PHI3 is sustained as long as signal NFPRR is true. At the first PHI3 clock, clock T10L is enabled if FAL or FSL is in effect and if more than two postnormalization shifts are required. A one is again forced on private memory address line LR31, and flip-flop NGX is set.

One of two courses is then followed:

1. If bit A47 is true, it signifies that the absolute value of the sum is +1 . This can happen if the result in PH9 was $-1 / 16$ and $\mathrm{FN}=1$, or if the result in PH9 was -1 . The result must be shifted to the right to correct the overflow. The S-bus outputs are shifted one hex to the right and the shifted result is transferred into the A"-register at the PHI3 clock. The exponent in the E-register is increased by one. The result is now ready for storage.
2. If bit A47 is false, the result is nonzero, and if the result is not yet normalized and is to be, five postnormalization tries are made if FAS or FSS is in effect or twelve tries are made if FAL or FSL is being performed. The first clock is T1OL; all others are T6L. The result on the sum bus is shifted one hex to the left and clocked into the $A^{\prime \prime}$-register. The E-register is decreased by one count to adjust the exponent. A one is forced into flip-flop BC3l and the contents of the B-register and bit BC 31 are shifted one bit position to the left for postnormalization counting logic. Since the result is nonzero, no more than four additional clocks normalize the result if FAS or FSS is in effect, and no more than eleven additional clocks normalize the result if FAL or FSL is being implemented. This step is repeated for each clock until the result is normalized.

Underflow or exponent overflow is detected during PH13. If the exponent of the result in the E-register is decremented so often by postnormalization shifts that it becomes negative, underflow has occurred and signal FEUF goes true. The underflow indication is killed if more than two postnormalizing shifts are required, $F Z=0$, and $F S=1$ (trap on significance but not an underflow). A one is merged into flip-flop El to accomplish this. Exponent overflow is detected when the exponent is changed so that the quantity it holds exceeds +63 or is less than -63 . Signal FEOF goes true with exponent overflow. If an overflow condition exists, adding 64 to bias the exponent would result in a biased exponent exceeding +127 or a negative exponent, neither of which is possible.

```
FEUF = EO NEI FAFL NRTZ
```

EIXI = FAFLAS FPPN FS NFZ EO B31

```
S/El = EIXI + ...
FEOF = NEO EI FAFL NRTZ
```

When the result is ready for storage, one of three actions is taken

1. The result is negated, and a one is added for the two's complement if FPR is true. The one for two's complementing is provided by signal K31 (if FAL or FSL is in effect) or signal K71 (if FAS or FSS is being performed). The negated result is gated to the sum bus by signal SXADD.
2. The result remains unaltered if signal $F P R$ is false; it is gated to the sum bus by signal SXA.
3. Zeros are gated to the sum bus if the result is zero or if there was exponent underflow with $\mathrm{FZ}=0$.

If FAL or FSL is being performed, and if there is no trap condition (signal RWDIS is false), sum bus outputs S0 through S31, LSW of the result, are transferred to the odd numbered private memory register at the PH 13 clock by signal RW. Sum bus outputs S48 through S71 are transferred to flip-flops A8 through A31 at the clock by signal AXSR32. The exponent result in flip-flops E1 through E7 is biased by adding 64, and is clocked into flip-flops A1 through A7. Bias is achieved by reversing the state flip-flop of E1. Ones are clocked into flip-flops CS0 through CS7 to invert the exponent if the final result is negative. The A-register now holds a zero in flip-flop A0, the uninverted exponent in flip-flops Al through A7, and the most significant part of the fraction result in flip-flops A8 through A31.

Flip-flops DRQ, T8L, and PH15 are set at the PH13 clock. Flip-flop DRQ inhibits transmission of another clock until a data release signal is received from memory. If FAS or FSS are being performed and if the result is zero, flip-flop RTZ is set for PH15 use.

If trap conditions exist, flip-flops TRAP and TR29 are set to provide a trap to memory location $X^{\prime} 44^{\prime}$ (68). Trap conditions are the following:

1. Exponent overflow. If the result is not equal to zero, exponent overflow causes an unconditional trap.
2. Underflow. Underflow causes a trap if the floating zero mode control bit, FN , is a one, if the result is not zero, and if signal FEUF is true.
3. Insignificant result. If $\mathrm{FN}=0$ (result is to be postnormalized), and $F S=1$, a trap results if more than two postnormalizing shifts are required or if the result is zero.
I. PH15. PH 15 is used to store the MSW of the result and to set the condition codes. If the result is not equal to zero, the MSW of the result is summed with the CS-register in an exclusive OR operation (bits CSO through CS7 are all
ones if the result is negative and invert the exponent in this case). If the result is equal to zero and if there is no trap condition, zeros are on sum bus outputs S0 through S31. The sum bus outputs, S0 through S31, are transferred to the even numbered private memory register if no trap condition exists. Signal RWDIS disables the transfer if a trap exists. The sum bus outputs are also transferred to flip-flops A0 through A31 for condition code use. A one is merged into flip-flop A31 by signal A31X1 if the result was not equal to zero. This action is necessary because a portion of the result has already been stored (PH13), and the most significant part may be zero.

Flip-flop TESTA is set to enable condition code bits 3 and 4. Condition code 1 is set if underflow has occurred or if there is an insignificant result with $\mathrm{FN}=0$. Condition code 2 is set if there is underflow with FZ $=0$ (inhibited if FS $=1$ and significance trap exists). Condition code 3 is set if the result is positive and nonzero; condition code 4 is set if the result is negative. Signal ENDE is generated. Flip-flop PRE1 is set to begin the preparation sequence for the next instruction. Clock T6L is enabled.

## 3-291 Floating Point Multiplication (FAFLM)

3-292 GENERAL. The implementation of FML is identical to the implementation of FMS with the exception of the number of fractional digits to be operated upon. The two instructions will be discussed together and differences between them will be noted in the discussion.

3-293 FLOATING POINT MODE CONTROL BITS. Mode control bit FZ, floating zero, determines the operation of floating point multiplication. Mode control bits FN and FS are not in effect.

If mode control bit FZ $=0$, underflow or a zero result causes the result to be set equal to true zero. If $F Z=1$, underflow causes the computer to trap to memory location X'44' (68). The contents of the general registers remain unchanged if the trap occurs.

If exponent overflow occurs, the computer always traps to location X'44' (68).

3-294 CONDITION CODE SETTINGS. The condition code settings and their meanings for floating point multiplication are shown in table 3-133.

3-295 BASIC STEPS IN FAFLM IMPLEMENTATION. To multiply two floating point numbers in Sigma 7, the following basic steps are performed:
a. Transfer of operands ( PH 1 and PH 3 ). The multiplier (from private memory) and the multiplicand (from core memory) are transferred to the arithmetic unit registers.
b. Exponent summing (PH2 and PH3). The uninverted biased multiplicand exponent is added to the uninverted

Table 3-133. Condition Codes for Floating Point Multiplication

| $\mathrm{COI}$ |  |  |  | IF NO TRAP TO location X'44' OCCURS | IF TRAP TO LOCATION X'44' OCCURS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 2 | 3 |  |  |  |
| 0 | 0 | 0 |  | $A \times 0$ <br> Result negative |  |
| 0 | 0 | 0 |  |  |  |
|  | 0 |  |  | Result positive and nonzero | - Impossitle |
| 0 | 1 | 0 |  |  |  |
| 0 | 1 | 0 |  |  | Overflow, result negative |
| 0 | 1 |  |  | Overflow, result |  |
|  |  | 0 |  |  |  |
|  |  |  |  |  |  |  |
|  | 0 | 0 |  |  |  |
|  | 0 | 1 |  |  |  |
| 1 | 1 | 0 |  |  |  |
|  | 1 |  |  | Underflow, result negative, FZ = 1 |  |
| 1 | 1 |  |  | Underflow, result positive and nonzero,$F Z=1$ |  |

biased multiplier exponent. Also, -128 is subtracted from the exponent sum to remove the bias (since the exponent sum is biased by twice the normal amount after the addition of the two biased numbers). The unbiased exponent sum of the two floating point numbers represents the exponent of the product. This product exponent may be corrected as prenormalizing shifts are performed on the fractions of the two operands, or as postnormalizing shifts are performed on the product.
c. Prenormalization (PH3-PH7). Before the two floating point numbers are multiplied, both are simple normalized. After the exponents are added (step b), the multiplier and the multiplicand are examined. The following conditions are possible.

1. The multiplier and the multiplicand are both simple normalized. In this case, the multiplication may be performed without adjustment of either operand.
2. The multiplier is simple normalized but the multiplicand is not. The multiplicand is shifted to the left one hex at a time untit it is simple normalized and is ready for multiplication. With each shift, the exponent sum is decremented by one to compensate for the shift.
3. The multiplicand is simple normalized but the multiplier is not. The multiplier is shifted to the left one
hex at a time until it is simple normalized and is ready for multiplication. With each shift, the exponent sum is decremented by one.
4. Neither the multiplicand nor the multiplier are simple normalized. The multiplier is shifted to the right until it is simple normalized, and is followed by the simple normalization of the multiplicand. The exponent sum is decremented by an amount equal to the total number of multiplicand and multiplier shifts. Prenormalization of the multiplier is done only to record the number of insignificant digits in the multiplier. The prenormalized multiplier is discarded before the multiplication. When the multiplication is effected, the original multiplier is used; the insignificant digits of the original multiplier are ignored in the multiplication.
5. The multiplier or multiplicand or both are equal to zero. The multiplication is not performed and the product is set equal to zero.
d. Multiplication (PHIO). After prenormalization of both operands, the fractions of the prenormalized floating point multiplicand and the significant bits of the original multiplier are multiplied. Multiplication methods are almost identical to the bit-pair methods used for fixed-point numbers (MW, MI, and MH opcodes).
e. Postnormalization (PH13). The product is examined.
6. If the product is normalized or is zero, and if there is no overflow, the product is ready for storage; 64 is added to the exponent to bias it once again.
7. If the product is not normalized, it is shifted to the left one hex to perform the postnormalization (since both operands were prenormalized, only one postnormalization shift is required). Step 1 is then performed.
8. If there is overflow in the product, it is shifted right one hex to correct the overflow condition. Step 1 is then performed.
f. Storage ( PHI 3 and PH 15 ). The biased exponent and the fraction result of the product are assimilated and are stored in memory in proper form, if there is no trap condition.

An example of FAFLM is shown in figure 3-219. The lettered steps correspond to the basic steps discussed.

## 3-296 DETAILED STEPS IN FAFLM IMPLEMENTATION.

 Figure 3-220 shows the FAFLM phases and the operations performed for each phase. The following discussion is supplemented by table 3-134 and by figure 3-220.If FML is being performed, a one is forced on private memory address line LR31 during the phase preceding PRE2 NIA. The least significant word of the multiplier (LSW) is transferred from the odd numbered private memory register to the A-register during PRE2 NIA.

| A. TRANSFER OF OPERANDS: | $\left.\begin{array}{llllllllllllllllll} 0 & 1 & 0 & 0 & 0 & 1 & 0 & 1 & 0 & 0 & 0 & 0^{\prime} & 0 & 0 & 0 & 0^{\prime} & 0 & 0 \end{array} 0 \quad 1 \quad \begin{array}{l} \text { MULTIPLIER } \\ \left(+2^{-12} \times 16^{5},\right. \end{array}\right)$ |
| :---: | :---: |
| B. EXPONENT SUMMING: | $\begin{aligned} & \begin{array}{rrrllllllll} \text { EXPONENT SIGN BIT } & & \\ 1 & 0 & 0 & 0 & 1 & 0 & 1 & - & 69 & \\ 0 & 1 & 1 & 1 & 0 & 0 & 1 \\ 1 & + & + & 57 & \\ 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ \hline \end{array} \\ & \hline 1 \end{aligned} 1$ |
| C. PRENORMALIZATION OF OPERANDS: <br> EXAMINE MULTIPLIER fRACTION AND MULTIPLICAND FRACTION <br> SIMPLE NORMALIZE \|MULTIPLIER| AND RECORD NUMBER OF HEXADECIMAL SHIFTS REQUIRED; ADJUST EXPONENT PRODUCT <br> SIMPLE NORMALIZE MULTIPLICAND AND ADJUST EXPONENT PRODUCT |  |
| D. MULTIPLICATION OF FRACTIONS: <br> CHANGE MULTIPLICAND TO SAME SIGN AS ORIGINAL MULTIPLIER <br> MULTIPLY BY ORIGINAL MULTIPLIER. NOTE NUMBER OF SHIFTS IN STEP C AND MULTIPLY ONLY BY THE SIGNIFICANT DIGITS IN THE MULTIPLIER |  |
| E. OVERFLOW DETECTION AND POSTNORMALIZATION: <br> examine \|product| <br> POSTNORMALIZE; <br> ADJUST EXPONENT PRODUCT <br> BIAS EXPONENT |  |
| F. STORAGE: <br> ASSIMILATE FRACTION AND EXPONENT CHANGE TO PROPER FORM, AND STORE | $\begin{aligned} & 0\|0111001\| 0010_{1}^{\prime} 00000^{\prime} 0000 \\ & 1\|1000110\| 1110^{\prime} 00000^{\prime} 0000 \end{aligned}$ <br> \|PRODUCT| <br> PRODUCT $\begin{aligned} & \left(-2^{-3} \times 16^{-7}\right) \\ & \left(-2^{-23} \times 16^{-2}\right. \end{aligned}$ |

Figure 3-219. Example of FAFLM Implementation


Table 3-134. Floating Multiply (FAFLM), Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PREP <br> Phase Preceding PRE2, NIA | Same as general preparation except for <br> Force one onto LR31 address line if FML | $\begin{aligned} \text { R/NLR31/2 }= & \text { (PRE1 NIA }+ \text { PRE3 IX } \\ & + \text { PRE4) OUI OUF }+\ldots \end{aligned}$ | To select odd numbered private memory register |
| $\begin{aligned} & \text { PRE2 } \\ & \text { NIA } \\ & \text { T4RL } \end{aligned}$ | RR0-RR31 $\longrightarrow$ A0-A31 | AXRR $=$ FAMDSF PRE2 NIA + .. | LSW of multiplier (FML) or complete multiplier (FMS) |
| $\begin{aligned} & \mathrm{PHI} \\ & \text { T4RL } \end{aligned}$ | $\begin{aligned} & A 0-A 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \rightarrow \mathrm{~B} 1 \rightarrow \mathrm{~B} 31 \\ & \mathrm{RRO}-\mathrm{RR} 31 \rightarrow \mathrm{~A} 0-\mathrm{A} 31 \end{aligned}$ <br> Set flip-flop RN if multiplier negative $\text { MBO-MB31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ <br> Set flip-flop MWN if multiplicand negative <br> Set flip-flop CXCL32 <br> Reset flip-flop CCl <br> Reset flip-flop CC2 <br> Force all ones into CS0-CS7 <br> Set flip-flop IEN | $\begin{aligned} \text { SXA } & =\text { FAFL PHI }+\ldots \\ \text { BXS } & =\text { FAMDSF PHI }+\ldots \\ \text { AXRR } & =\text { RNXRRO } / 2 \text { PHI }+\ldots \\ & =\text { FAFL PHI }+\ldots \\ \text { S/RN } & =\text { RRO RNRXRRO }+\ldots \\ & =\text { RRO PHI FAFL }+\ldots \end{aligned}$ <br> Preparation control $\mathrm{S} / \mathrm{MWN}=\mathrm{COCl} 6 \mathrm{FAMDSF}$ $S / C X C L 32=F A F L P H 1+\ldots$ $\mathrm{R} / \mathrm{CCI} \quad=\mathrm{FAFL} \mathrm{PHI}+\ldots$ $\text { R/CC2 }=\text { FAMDSF NFAMULH }$ $\text { CSXI/5 }=\text { FAFL PHI }+\ldots$ <br> S/IEN $\quad=$ FAMDSF NFAMUL $+\ldots$ | Redundant if FMS; MSW of multiplier if FML <br> Stores multiplier sign <br> MSW of multiplicand <br> Stores multiplicand sign <br> For PH2 use <br> To invert multiplier exponent if multiplier negative <br> Start interruptibility |
| $\begin{aligned} & \mathrm{PH} 2 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \mathrm{A} 0, \mathrm{~A} 8-\mathrm{A} 31 \longrightarrow \mathrm{~A} 47, \mathrm{~A} 48-\mathrm{A} 71 \\ & \mathrm{C} 0, \mathrm{C} 8-\mathrm{C} 31 \longrightarrow \mathrm{C} 47, \mathrm{C} 48-\mathrm{C} 71 \end{aligned}$ <br> $\mathrm{A} 0-\mathrm{A} 31+\mathrm{CSO}-\mathrm{CS} 7 \longrightarrow$ <br> S0-S31 if multiplier negative <br> or <br> A0-A31 $\longrightarrow$ S0-S31 if multiplier positive $\mathrm{SO} 0-\mathrm{S7} \longrightarrow \mathrm{~A} 0-\mathrm{A} 7$ | $\begin{aligned} \text { AXAL32 } & =\text { FAFL PH2 } \\ \text { CXCL32 } & =\text { set in PH1 } \\ \text { SXPR } & =\text { FAFL PH2 RN }+\ldots \\ \text { SXA } & =\text { FAFL PH2 NRN }+\ldots \\ \text { AXS } / 1 & =\text { FAFL PH2 }+\ldots \end{aligned}$ | MSW of multiplier $\rightarrow A^{\prime}$ <br> MSW of multiplicand <br> $\left\{\begin{array}{l}\text { Uninverted multiplier } \\ \text { exponent } \\ \end{array}\right.$ |
|  |  | (Continued) | Mnemonic: $\mathrm{FMS}(3 \mathrm{~F}, \mathrm{BF})$, FML (IF, 9F) |

Table 3-134. Floating Multiply (FAFLM), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH2 <br> T6L <br> (Cont. | NC0-NC7 $\rightarrow$ D0-D7 if <br> multiplicand negative <br> or <br> $\mathrm{C} 0-\mathrm{C} 7 \rightarrow \mathrm{D} 0-\mathrm{D7}$ if <br> multiplicand positive <br> Force a one into CSO <br> S8-S31 $\longrightarrow$ B8-B31 if FMS <br> Set flip-flop FPR if final product is to be negative <br> Force a one onto LB31 address line <br> Force a one onto LR31 address line <br>  <br> Set flip-flop CX/1 if FMS |  |  <br> To remove $2 X$ bias from the exponent sum <br> Multiplier $\longrightarrow$ B8-B3I <br> Result must be reversed <br> Inhibits transmission of another clock until data release signal received |
| $\begin{aligned} & \text { PH3 } \\ & \text { T6L } \\ & \text { (FML) } \\ & \text { T6RL } \end{aligned}$ | $\begin{aligned} & \mathrm{A} 47-\mathrm{A} 71 \longrightarrow \text { S47-S71 } \\ & \mathrm{S} 47-\mathrm{S} 71 \rightarrow \mathrm{~B} 47-\mathrm{B} 71 \\ & \mathrm{~A} 0-\mathrm{A} 7+\mathrm{D} 0-\mathrm{D} 7+\mathrm{CS} 0 \longrightarrow \\ & \mathrm{~S} 0-\mathrm{S} 7 \end{aligned} \mathrm{C}$ <br> Clear P -register <br> MBO-MB3I $\longrightarrow \mathrm{CO}-\mathrm{C} 31$ if FML <br> Clear A"-register | SXA/3 $=$ FAFL PH3 $+\ldots$ <br> BXS $/ 1$ $=$ FAFL PH 3 <br> SXK/1 $=$ FAFL PH3 $+\ldots$ <br> SXPR/1 $=$ FAFL PH $13+\ldots$ <br> EXS $=$ FAFL PH $3+\ldots$ <br> PX $=$ FAFL PH $3+\ldots$ <br> See PH2  <br> AX/1 $=$ FAFL PH3 $+\ldots$ | Insignificant if FMS <br> Exponent product <br> Exponent product <br> Zeros $\longrightarrow \mathrm{CO}-\mathrm{C} 31$ <br> if $F M S$ <br> May be regenerated (see case 1 below) |
|  |  | (Continued) | Mnemonic: FMS (3F, BF), FML (IF, 9F) |

Table 3-134. Floating Multiply (FAFLM), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH3 <br> T6L <br> (FMS) <br> T6RL <br> (Cont.) | Case 1: NASN | $\begin{aligned} \mathrm{ASN}= & (\mathrm{A} 47+\mathrm{A} 48+\mathrm{A} 49+\mathrm{A} 50 \\ & +\mathrm{A} 51)(\mathrm{NA} 47+\mathrm{NA} 48 \\ & +\mathrm{NA} 49+\mathrm{NA} 50+\mathrm{NA} 51) \end{aligned}$ | A, not simple normalized case |
|  | S47-S71 $\rightarrow$ A47-A71 | AXS $/ 4=$ FAFL PH3 $\mathrm{N}(\mathrm{FAFLM}$ ASN $)$ | Regenerate $A^{\prime}$ |
|  | RRO-RR31 $\longrightarrow A 0-A 31$ if $F M L$ | $\begin{aligned} \text { AXRR }= & \text { FAFL PH3 N(FAFLM ASN) NO2 } \\ & +\ldots \end{aligned}$ | LSW of multiplier (zeros <br> $\longrightarrow A$ if $F M S$ ) |
|  | Set flip-flop NGX if multiplier negative | S $/$ NGX $=$ FAFL PH3 | For PH4 use |
|  | Clear $\mathrm{D}^{\prime}$-register | DX/1 = FAFLMD PH3 + $\ldots$ |  |
|  | Set flip-flop T8L | $\begin{aligned} \text { R/NT8L }= & \text { T8L }=\text { FAFL PH3 N(FAFLM ASN }) \\ & \text { FAFLMD }+\ldots \end{aligned}$ |  |
|  | Case 2: ASN NCSN | $\begin{aligned} \mathrm{CSN}= & (\mathrm{C} 47+\mathrm{C} 48+\mathrm{C} 49+\mathrm{C} 50 \\ & +\mathrm{C} 51)(\mathrm{NC} 47+\mathrm{NC} 48 \\ & + \text { NC49 }+\mathrm{NC} 50+\mathrm{NC} 51) \end{aligned}$ | ASN and C, not simple normalized case |
|  | C47-C31 $\rightarrow$ D47-D31 | DXC/6 = FAFLM PH3 ASN + MPP + $\ldots$ | Multiplicand $\rightarrow$ D" |
|  | Clear $A^{\prime \prime}$-register | $\mathrm{AX} / 1=$ See above, PH3 |  |
|  | Enable PH6 | BRPH6 $=$ FAFLM PH3 ASN $+\ldots$ |  |
|  | Case 3: ASN CSN $\Rightarrow$ MPP |  | A and $C$, simple normalized case |
|  | C47-C31 $\rightarrow$ D47-D31 | DXC/6 = FAFLM PH3 ASN + MPP + $\ldots$ | Multiplicand $\rightarrow$ D" |
|  | Enable MPP | MPP $=$ FAFLM PH3 ASN CSN $+\ldots$ | Prepare for multiply iterations |
|  | Clear A"-register | AX/1 $=$ MPP + | Redundant in this phase |
|  | C47-C31 $\longrightarrow$ D47-D31 | $\mathrm{DXC} / 6=\mathrm{MPP}+\ldots$ | Redundant in this phase |
|  | Force ones into CS47-CS31 if signs of multiplier and multiplicand | CSXI $=$ MPP (MWN $\oplus$ RN $)$ | To generate absolute value of product |
|  | opposite $\mathrm{B} 0-\mathrm{B} 29 \rightarrow \mathrm{~B} 2-\mathrm{B} 31$ | $\text { BXBR2 }=M P P+\ldots$ | $\left\{\begin{array}{l} \text { Examine multiplier bit } \\ \text { pair 2', } 2^{\circ} \text {. Set multi- } \end{array}\right.$ |
|  | Enable BCON <br> Set up flip-flops DXCM, DXNCM, DXCLIM, BC31 as functions of B30, B 31 , and BC 31 | BCON $=$ BXBR2 FAMDSF/M $+\ldots=$ MPP | plier control flip-flops to this bit-pair. Shift multiplier to bring next bit-pair into B30, B31 |
|  | Set flip-flop CXS | $S / C X S=M P P+\ldots$ | For PH9 use |
|  |  | (Continued) | Mnemonic: FMS (3F, BF), FML (1F, 9F) |

Table 3-134. Floating Multiply (FAFLM), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH3 <br> T6L <br> (FMS) <br> T6RL <br> (Cont. | Reset flip-flop IEN Enable PH9 | $\begin{aligned} & \text { R/IEN }=\text { MPP }+\ldots \\ & \text { BRPH9 }=M P P+\ldots \end{aligned}$ | Stop interruptibility <br> Pre-iterations phase |
| PH4 <br> T8L | (Entered only if NASN in PH3) <br> Case 1: $A^{\prime \prime}=0$ <br> Set flip-flop RTZ <br> Enable MRQ/1 <br> Reset flip-flop IEN <br> Force a one onto LR3I address line <br> Set flip-flop T10L if FML or on even R-field <br> Enable PH13 <br> Case 2: $A^{\prime \prime} \neq 0$ $\mid \text { A47-A31 } \mid \longrightarrow \text { S47-S31 }$ <br> Enable FPRENR <br> S51-S31 $\times 16 \rightarrow$ A47-A27 <br> Increment E0-E7 by one <br> Up-count P15-P18 <br> C47-C31 $\rightarrow$ D47-D31 if multiplicand not simple normalized |  | Product $=0$ <br> Memory request for next instruction <br> Stop interruptibility <br> NGX set in PH3 if multiplier negative <br> Prenormalize R operand Shift multiplier one hex to the left <br> Delete two multiply iterations |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | (Entered only from PH4 case 2) <br> 1-5 clocks if FMS <br> 1-13 clocks if FML |  |  |
|  |  | (Continued) | Mnemonic: FMS (3F, BF), FML (1F, 9F) |

Table 3-134. Floating Multiply (FAFLM), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}\right.$ | Case 1: NASN <br> Enable FPRENR <br> A47-A31 $\longrightarrow$ S47-S31 $\mathrm{S} 51-\mathrm{S} 31 \times 16 \rightarrow \mathrm{~A} 47-\mathrm{A} 27$ <br> Increment E0-E7 by one <br> Up-count P15-P18 <br> Sustain PH5 if NASN <br> Case 2: ASN NCSN <br> Advance to PH6 <br> Case 3: ASN -CSN $\Rightarrow$ MPP | $\begin{aligned} \text { FPRENR } & =\text { FAFLMD PH5 NASN }+\ldots \\ \text { SXA } & =\text { FAFL PH5 }+\ldots \\ \text { AXSL4 } & =\text { FPRENR }+\ldots \\ \text { MCTEI } & =\text { FPRENR }+\ldots \\ \text { PCTP5 } & =\text { FPRENR NA473IZ }+\ldots \\ \text { BRPH5 } & =\text { FPRENR PH5 }+\ldots \end{aligned}$ <br> Same as PH3, case 3 <br> MPP $\quad=$ FAFLM PH5 ASN CSN $+\ldots$ | Shift multiplier one hex to the left <br> Delete two multiply iterations <br> Prepare for multiply iterations (enable PH9) |
| $\begin{aligned} & \text { PH6 } \\ & \text { T6L } \end{aligned}$ | (Entered only from PH3, case 2 or PH5, case 2) $\text { D47-D31 } \longrightarrow \text { S47-S31 }$ <br> Enable FPRENM $\mathrm{S} 51-\mathrm{S} 31 \times 16 \longrightarrow \mathrm{~A} 47-\mathrm{A} 27$ <br> Decrement E0-E7 by one Enable S/CXS | $\begin{array}{ll} \text { SXD } & =\text { FAFLMD PH6 }+\ldots \\ \text { FPRENM } & =\text { FAFLMD PH6 } N(\text { PH7 ASN })+\ldots \\ \text { AXSL4 } & =\text { FPRENM }+\ldots \\ \text { MCTEI } & =\text { FPRENM FAFLM }+\ldots \\ S / C X S ~ & =\text { FAFLMD PH6 }+ \text { FPRENM NA473IZ } \end{array}$ | Multiplicand in D" <br> Prenormalize $M$ operand <br> Shift multiplicand one hex to the left <br> For PH7 use |
| $\left\lvert\, \begin{aligned} & \text { PH7 } \\ & \text { TóL } \end{aligned}\right.$ | (Entered from PH6) <br> 1-6 clocks if FMS <br> 1-14 clocks if FML <br> Case 1: $\mathrm{A}=0$ | Same as PH4, case 1 $(S / R T Z / 1)=\text { FAFLD PH7 NA4731Z }+\ldots$ | Product $=0$ (enable PH13) |
|  |  | (Continued) | Mnemonic: $\mathrm{FMS}(3 \mathrm{~F}, \mathrm{BF})$ FML (IF, 9F) |

Table 3-134. Floating Multiply (FAFLM), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH7 <br> T6L <br> (Cont.) | Case 2: $A \neq 0$, NASN <br> Enable FPRENM $\begin{aligned} & \mathrm{A} 47-\mathrm{A} 31 \longrightarrow \mathrm{~S} 47-\mathrm{S} 31 \\ & \mathrm{~S} 51-\mathrm{S} 31 \longrightarrow \mathrm{~A} 47-\mathrm{A} 27 \end{aligned}$ <br> Decrement E0-E7 by one $\mathrm{S} 47-\mathrm{S} 31 \longrightarrow \mathrm{C} 47-\mathrm{C} 31$ <br> Enable S/CXS again <br> Sustain PH7 is NASN <br> Case 3: $A \neq 0, A S N \Rightarrow M P P$ $\begin{aligned} & \mathrm{A} 47-\mathrm{A} 31 \longrightarrow \mathrm{~S} 47-\mathrm{S} 31 \\ & \mathrm{~S} 47-\mathrm{S} 31 \longrightarrow \mathrm{C} 47-\mathrm{C} 31 \end{aligned}$ | $\begin{aligned} & \text { FPRENM }=\text { FAFLMD PH7 N(PH7 ASN }) \\ & \text { SXA }=\text { FAFLMD PH7 }+\ldots \\ & \text { AXSL4 }=\text { FPRENM }+\ldots \\ & \text { MCTE1 }=\text { FPRENM FAFLM }+\ldots \\ & \text { CXS }=\text { See PH6 } \\ & \text { S/CXS }=\text { FPRENM NA473IZ }+\ldots \\ & \text { BRPH7 }=\text { FPRENM NA473IZ }+\ldots \\ & \text { Same as PH3, case 3 and } \\ & \text { MPP }=\text { FAFLM PH7 ASN }+\ldots \\ & \text { SXA }=\text { Same as above, case } 2 \\ & \text { CXS }=\text { PH6 or PH7, case } 2 \end{aligned}$ | Shift multiplicand left one hex <br> To save adjusted multiplicand <br> To save adjusted multiplicand <br> Prepare for multiply iterations (enable PH9) |
| $\begin{aligned} & \text { PH9 } \\ & \text { T6L } \end{aligned}$ | (Entered from PH3, case 3; PH5, case 2; or PH7, case 3) <br> or <br> or $\mathrm{C} 47-\mathrm{C} 31 \nrightarrow \text { D46-D30 }$ <br> or above | $\begin{aligned} & \text { SXPR }=\text { FAMDSF } / \mathrm{MPH} 9+\ldots \\ & \text { S/CXS }=\text { Enabled by MPP } \\ & \text { DXCM }=\text { Previously set by MPP } \\ & \text { DXNCM }=\text { Previously set by MPP } \\ & \text { DXCLIM }=\text { Previously set } \end{aligned}$ | Match multiplicand to multiplifier for \| product | <br> $\mathrm{PH} 3, \mathrm{PH} 5$, or PH 7 <br> First $C \rightarrow D$ <br> transfer as $f(B C O N)$ |
|  |  | (Continued) | Mnemonic: FMS (3F, BF), FML (IF, 9F) |

Table 3-134. Floating Multiply (FAFLM), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH9 <br> T6L (Cont. | Force a one into flip-flop DCWCM if ones complement transferred to $D^{\prime \prime}$ $\mathrm{B} 0-\mathrm{B} 29 \rightarrow \mathrm{~B} 2-\mathrm{B} 31$ <br> Sustain BCON <br> Set up flip-flops DXCM, DXWCM, DXCLIM, B31 as functions of B30, B31, BC31 <br> Set flip-flop MIT <br> Enable clock TIL if not a single clocking <br> Set flip-flop FLMC if significance in original multiplier is only in the least significant hex |  | One added later to make up two's complement <br> Examine bit-pair 2 ${ }^{3}, 2^{2}$. Set multiplier control flip-flops to this bit-pair. Shift multiplier to bring next bit-pair into B30, B31 <br> Only two PH10 clocks necessary |
| $\begin{aligned} & \text { PH10 } \\ & \text { TIL } \end{aligned}$ | 12 clocks (FMS) or 28 clocks (FML) two times number of prenormalization shifts. For each clock the following events occur: <br> $A^{\prime \prime} \oplus D^{\prime \prime} \oplus C^{\prime \prime} \longrightarrow$ PR47-PR31 <br> PR47-PR31 $\rightarrow$ A48-A31, B0, B1 <br> $A^{\prime \prime} D^{\prime \prime}+A^{\prime \prime} C S^{\prime \prime}+D^{\prime \prime} C S^{\prime \prime}$ <br> $\rightarrow$ G47-G31 <br> G47-G31 $\rightarrow$ CS48-CS32 <br> Contents of C" are transferred to D" under control of the multiplier control. Flip-flops DXCM, DXNCM, DXCLIM, set during previous clock <br> DCWCM set as before | $\text { AXPRR2 }=\text { MIT }$ $\text { CSXGRI }=\text { MIT }$ | Sums of the partial products <br> Carries of the partial products |
|  |  | (Continued) | Mnemonic: FMS (3F, BF), FML (1F, 9F) |

Table 3-134. Floating Multiply (FAFLM), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PHIO TIL (Cont.) | $\left.\begin{array}{l} \mathrm{B} 47-\mathrm{B} 69 \rightarrow \mathrm{~B} 49-\mathrm{B} 71 \\ \mathrm{~B} 70, \mathrm{~B} 71, \mathrm{~B} 4-\mathrm{B} 29 \rightarrow \\ \mathrm{~B} 4-\mathrm{B} 71 \end{array}\right\}$ <br> Sustain BCON <br> Set up flip-flops DXCM, DXNCM, DXCLIM, B31 as functions of B30, B31, BC31 <br> Count iterations using P15-P18 and MP19 <br> On the 26 count: <br> Other events listed above <br> Set flip-flop FLMC <br> Reset flip-flop TIL <br> On the 27 count: <br> Other events listed above <br> Set flip-flop MITEX <br> On the 28 count: <br> Other events listed above <br> Reset flip-flop MIT <br> Set flip-flop T8L <br> Advance to PHIl |  | Signal BRPH 10 disabled |
| $\left\lvert\, \begin{aligned} & \text { PHII } \\ & \text { TEL } \end{aligned}\right.$ | $\begin{aligned} & \left.\begin{array}{l} A 47-A 31+C S 47-C S 31 \\ +K 31 \longrightarrow S 47-S 31 \\ S 47-S 31 \rightarrow A 47-A 31 \\ B 0-B 1+C S 32, C S 33, \\ B C 1 \longrightarrow B 0-B 1 \end{array}\right\}, ~ \end{aligned}$ | $\begin{aligned} \text { SXADD } & =\text { FAMDSF } / M \text { PHII } \\ \text { AXS } & =\text { FAFLM PHI } 2+\ldots \\ \text { BXB } & =\text { FAMDSF } / M \text { PHII }+\ldots \end{aligned}$ | $K 31$ is end carry from B $\} \text { Last partial product }$ |
|  |  | (Continued) | Mnemonic: FMS (3F, BF), FML (IF, 9F) |

Table 3-134. Floating Multiply (FAFLM), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{aligned} & \text { PH11 } \\ & \text { T8L } \\ & \text { (Cont.) } \end{aligned}\right.$ | Contents of C" are transferred to D" under control of the multiplier control flip-flops DXCM, DXNCM, DXCLIM, which were set during last clock of PH 10 <br> Force a one into CS31 if one's complement transferred to D" <br> Enable $M R Q / 1$ <br> Set flip-flop T8L | $\begin{array}{ll} \text { CSXI/8 } & =\text { PHII (S/DCWCM) }+\ldots \\ \text { MRQ/1 } & =\text { FAFLM PHII }+\ldots \\ \text { R/NT8L } & =\text { T8L }=\text { FAFLMD PHII } \end{array}$ | Used in lieu of DCWCM <br> Memory request for next instruction |
| $\begin{aligned} & \text { PHI2 } \\ & \text { T8L } \end{aligned}$ | $\begin{aligned} & \mathrm{A} 47-\mathrm{A} 31+\mathrm{D} 47-\mathrm{D} 31 \\ & +\mathrm{CS} 31 \longrightarrow \mathrm{~S} 47-\mathrm{S} 31 \\ & \mathrm{~S} 47-\mathrm{S} 31 \longrightarrow \mathrm{H} 47-\mathrm{A} 31 \end{aligned}$ <br> Clear D"-register <br> Set flip-flop NGX <br> Set flip-flop G0003/1 if FMS and R-field is odd <br> Force a one on address line LR31 <br> Set flip-flop T10L if not FMS or the R-field is not odd | $\begin{array}{ll} \text { SXADD } & =\text { FAFLM PH12 } \\ & = \\ \text { AXS } & =\text { FAFLM PH12 }+\ldots \\ \text { DX/1 } & =\text { FAFL PHI2 }+\ldots \\ \text { S/NGX } & =\text { FAFL PH12 }+\ldots \\ (S / G 0003 / 1) & =\text { FAFL PH12 NFPRD } \\ \text { R/NLR31/2 } & =\text { LR31/2 } 12 \text { FAFL PH12 }+\ldots \\ \text { S/T10L } & =\text { FPRD PH12 }+\ldots \end{array}$ | \| Product | <br> For PH 13 use <br> Causes K71 in FPRR case |
| $\begin{aligned} & \text { PH13 } \\ & \text { T6L } \\ & \text { or } \\ & \text { T10L } \end{aligned}$ | One to two clocks, both T6L if FMS and R are odd; otherwsie, both are T10L <br> Case 1: NFPRR - Result Not Ready for Storage $\mathrm{A} 47-\mathrm{A} 31 \longrightarrow 547-531$ <br> Sustain PHI3 <br> Set flip-flop T10L if not FMS or R-field is not odd <br> Force a one on LR31 address line <br> Set flip-flop NGX | FPRR $=$ FAFLAS PHI3 NA47 <br>  N(NRTZ NFNF A4751Z) <br> SXA $=$ FAFL PHI3 NFPRR <br> BRPHI3 $=$ FAFL PHI3 NFPRR $+\ldots$ <br> S/T10L $=$ FAFL PH13 NFPRR <br>  N(FPPN A5255Z) FRD <br> R/NLR31/2 = LR31/2 = FAFL PHI3 NFPRR <br>  $+\ldots$ <br> S/NGX $=$ FAFL PHI3 NFPRR $+\ldots$ |  |
| (Continued) |  |  | Mnemonic: FMS (3F, BF), FML ( $1 \mathrm{~F}, \mathrm{PF}$ ) |

Table 3-134. Floating Multiply (FAFLM), Phase Sequence (Cont.)


Table 3-134. Floating Multiply (FAFLM), Phase Sequence (Cont.)

(If FMS is being implemented, the entire 32 bits of the multiplier is transferred from the even numbered private memory register to the A-register.)
a. PHI. At the PHl clock, the contents of the Aregister are transferred to the $B$-register by signal $B X S$, and the even numbered private memory register contents are transferred to the A-register. (If instruction FMS is being performed, this operation is redundant; if instruction FML is being implemented, the most significant word, MSW, of the multiplier is now in flip-flops A0 through A31 and the LSW of the multiplier is now in flip-flops B0 through B31.) Flip-flop RN is set at the PHI clock if the multiplier is negative.

The MSW of the multiplicand has already been transferred to the C -register during the preparation phases. Flip-flop MWN is set if the multiplicand is negative.

Signal CXCL32 is generated for use in PH2. Flip-flops CCl and CC. 2 are reset for underflow and overflow tests in PH15, and flip-flop IEN is set to start interruptibility. Ones are forced into flip-flops CS0 through CS7 by signal CSXI/5 to invert the multiplier exponent to its true form if the multiplier is negative.
b. PH2. At the PH2 clock, the fraction part of the multiplier MSW (or the complete fraction if FMS is being performed) is transferred from flip-flops A0 and A8 through A31 to flip-flops A47 and A48 through A71, respectively, by signal AXAL32. The fraction part of the multiplicand MSW is transferred to the C-register extension in the same manner by signal CXCL32.

The multiplier and the multiplicand exponents are set up in PH2 for exponent addition. The uninverted multiplier exponent is either present in flip-flops Al through A7 or is found by combining bits Al through A7 with bits CS0 through CS7 (all ones) in PH3 in an exclusive OR operation. The uninverted multiplier exponent is gated to the sum bus during PH 2 and, at the PH 2 clock, is transferred from the sum bus to flip-flops A0 through A7 by signal AXS/1.

The uninverted multiplicand exponent must be added to the uninverted multiplier exponent. The uninverted multiplicand is transferred to flip-flops D0 through D7 by signal DXNC (if the multiplicand is negative) or by signal DXC/6 (if the multiplicand is positive).

A one is forced into flip-flop CSO at the PH2 clock. When the exponents are added in PH3, the one in flip-flop CSO subtracts 128 from the exponent sum, removing the bias.

```
S/CSO = FAFLM PH2 +....
```

If Fivis is being performed, the complete multiplicr consists of only 32 bits. The fraction of the multiplier is transferred from the sum bus outputs S8 through S31 to flip-flops B8 through B3I by signal BXS. Flip-flop FPR is set if the product of the multiplication is to be negative (that is, if a
positive floating point number is to be multiplied by a negative floating point number).

Ones are forced on core memory address line LB31 and on private memory line LR3I for possible use in PH3 (with FML). If FML is being implemented, flip-flops MRQ (memory service request) and DRQ (inhibits transmission of another clock until data release signal is received from memory) are set to transfer the least significant word of the multiplicand to the C-register at the PH3 clock. Clock T6RL is enabled for PH3. If FMS is being implemented, flip-flop $C X / 1$ is set at the PH2 clock to force all zeros into flip-flops C0 through C31 in PH3.
c. PH3. During PH3, the most significant part of the multiplier fraction in flip-flops A47 through A71 is gated to the sum bus outputs S 47 throingh S 71 by signal $\mathrm{SXA} / 3$. At the PH3 clock, S47 through S71 are transferred to flip-flops B47 through B71 by signal BXS/1. (The transfer is insignificant if FMS is being performed.) The complete multiplier is held in flip-flops 847 through B31 if FML is being performed or in flip-flops B7 through B31 if FMS is in effect. This multiplier is the one involved in the actual multiply process in PH 10 and is saved in the B -register until that phase. The multiplier in the $A^{\prime \prime}$-register is the one involved in any prenormalization and is later discarded.

During PH3, the uninverted multiplier exponent in flip-flops A0 through A7, the uninverted multiplicand exponent in flip-flops D0 through D7, and the 1 in flip-flop CS0 are added, and their sum is gated to the sum bus. At the PH3 clock, the sum bus outputs on SO through S 7 are transferred to flip-flops E0 through E7 by signal EXS. Flip-flops E0 through E7 now hold the unbiased exponent sum.

At the PH3 clock, the P -register is cleared by signal PX. The P -register later serves as an iteration counter for the multiply iterations. If FML is being implemented, the LSW of the multiplicand is gated into C0 through C31 from the odd numbered private memory register. If FMS is being performed, zeros are read into C0 through C31 (no gating term enabled). The A-register is cleared by signal $A X / 1$. The contents of the A-register may be regenerated if the multiplier is not simple normalized.

The multiplier and multiplicand are examined in PH3. If the multiplier is simple normalized, signal ASN goes true. If the multiplicand is simple normalized, signal CSN goes true.

There are three normalization combinations in PH3. Each causes a different sequence of events to take place.

1. Case 1. The multiplier is not simple normalized. If signo! $A S N$ is false, sum bus outputs $S 47$ through $S 71$ are transferred to flip-flops A47 through A71, regenerating the contents of the $A$-register extension cleared by signal $A X / 1$. To regenerate this portion of the multiplier, the contents of the odd numbered private memory register are again
transferred to flip-flops A0 through A31 if FML is being performed. If FMS is in effect, zeros are clocked into flip-flops AC through A31. Flip-flop NGX is set if the multiplier is negative. The $\mathrm{D}^{\prime \prime}$-register is cleared and clock T8L is enabled for PH4.
2. Case 2. The multiplier is simple normalized, but the multiplicand is not simple normalized. Preparations are made to normalize the multiplicand. If signal ASN is true and if signal CSN is false, the multiplicand is transferred from the C"-register to the D"-register by signal DXC/6. The A-register is cleared by signal AX/1. PH6 is enabled.
3. Case 3. Both the multiplier and the multiplicand are simple normalized. Preparations are made to multiply the two operands. If signals ASN and CSN are both true, the multiplicand is transferred from the C-register to the D -register by signal $\mathrm{DXC} / 6$. The A-register is cleared by signal AX/1. Signal MPP (multiply preparation) is enabled. Ones are clocked into the CS"-register if the multiplier and the multiplicand signs are of opposite polarity. Buffer latch CXS is set for PH9 use. Flip-flop IEN is reset to stop interruptibility. Signal BCON (B control) goes true for the multiplication process. (The PH3 BCON functions and other BCON functions are described in PH9.) PH9 is enabled.

| S/D47 | $=C 47 \mathrm{DXC} / 6+\ldots$ |
| :--- | :--- |
| $\vdots$ | $\vdots$ |
| S/D31 | $=\mathrm{C} 31 \mathrm{DXC} / 6+\ldots$ |
| R/D47 through D31 | $=\mathrm{DX}=\mathrm{DXC} / 6+\ldots$ |
| C/D47 through D41 | $=C L-32 P 28$ (typical) |

d. PH4. PH4 is entered only if the multiplier is not simple normalized. The multiplicand may or may not be normalized at this point.
If the multiplier is zero, the product of the floating point multiplication is zero. Multiply iterations do not have to take place in this case and the first storage phase ( PHI 3 ) of the instruction may be enabled. If the multiplier is zero, flip-flop RTZ (result zero) is set. Signal MRQ/I (memory request) is enabled and flip-flop IEN is reset. A one is forced on private memory address line LR31 to select the odd numbered private memory register in the storage phase. Clock T1OL is enabled if FMS is not being performed or if the R-field is not odd. PH13 is enabled.

If the multiplier is not zero, the first simple normalization attempt is made in this phase. The absolute value of the multiplier in flip-flops A47 through A71 (FMS) or A47 through A31 (FML) is gated to the sum bus by signal SXADD during the phase. The multiplier is shifted one hex to the left by signal AXSL4, and the exponent sum is decremented by one to compensate for the shift. Flip-flops P15 through P18 and flip-flop MP19 are used during the multiply iterations to record the number of iterations performed (the description of iteration counting may be found in the multiply word opcode description). Since performing a prenormalization shift means that there are effective zeros in the four most significant bits of the multiplier, two multiply iterations may be discarded; the iteration counter is incremented
(from zero count) by two to record this fact (P18 is the $2^{1}$ bit position). If the multiplicand is not simple normalized, it is transferred from the C"-register to the D"-register by signal DXC/6 to prepare for simple normalization in PH6. PH5 is entered even if the multiplier is now simple normalized.
e. PH5. PH5 is entered only if the multiplier was not simple normalized in PH3, and if it is nonzero. If FMS is being performed, up to four normalization shifts may be used. If FML is being implemented, up to 12 normalization shifts are used. Since the multiplier is nonzero if this phase is entered, simple normalization is always accomplished at the end of the phase.

The absolute value of the multiplier (found in PH4) is gated to the sum bus by signal SXA. The prenormalization shift is performed by signal AXSL4. The exponent sum is decremented by one to record the shift. The iteration counter is incremented by two to delete two multiply iterations. If signal FPRENR is still true, PH5 is sustained and another prenormalization shift occurs.

If the multiplier is simple normalized after any PH5 clock, signal ASN goes true and signal FPRENR goes false. PH5 is no longer sustained. If the multiplicand is not simple normalized, PH6 is enabled; if the multiplicand is alsosimple normalized, signal MPP goes true and PH9 is enabled. Signal MPP true causes the same actions that are described in case 3 of PH 3 ; that is, the operands are prepared for the multiply iterations.
f. PH6. PH6 is entered from PH3 or PH6 if the multiplicand is not simple normalized. The multiplier is nonzero and simple normalized at this point.
The multiplicand in the $D^{\prime \prime}$-register is gated to the $S$-bus by signal SXD. Signal FPRENM is true if PH6 is entered. The multiplicand is shifted left one hex by signal AXSL4, and the exponent sum is decremented by one to compensate for the shift. The iteration counter remains unchanged since the number of significant multiplier digits, and not the multiplicand digits, determine the number of iterations. Buffer latch CXS is set for PH7 use. The above shift is insignificant if the multiplicand is all zeros.
g. PH7. PH 7 is entered from PH 6 only; the multiplicand was not simple normalized in PH3 or PH5. If the multiplicand is still not simple normalized and is nonzero, up to 13 prenormalization shifts may be used (up to five if FMS is being performed). The multiplicand is always simple normalized at the end of PH7. Clock T8L is used only for the first clock of PH7.

If the multiplicand is zero, flip-flop RTZ is set and PHI3 is enabled. Signal ( $S / R T Z / 1$ ) causes the same actions to occur as described in PH 4 .

If the multiplicand is not zero, it is gated to the sum bus by signal SXA. The first prenormalization shift of PH7 is performed by signal AXSL4. The exponent sum is decremented by one to compensate for the shift. Flip-flop CXS is set for the next PH7 clock. The adjusted multiplicand is transferred to the C"-register by signal CXS at each PH7 clock. Signal CXS is true during all the clocks of PH7.

At the end of PH7, the normalized multiplicand is in the C-register. If FPRENM is still true after the first shift, PH 7 is sustained and another prenormalization shift occurs.

If the multiplicand is simple normalized after any PH7 clock, signal ASN goes true and signal FPRENM goes false. PH7 is no longer sustained. Signal MPP goes true and PH9 is enabled. Signal MPP causes the same actions described in PH3 in preparation for the multiply iterations.
h. PH9. PH9 is entered from PH3, PH5, or PH7. To enter PH9, the multiplicand must be simple normalized and nonzero. The multiplier is nonzero and is in the B"-register. The prenormalized multiplier has been discarded, and the iteration counter has been incremented by two counts for every multiplier prenormalization shift. The CS-register is loaded with all ones if the original multiplier and multiplicand were of different signs (signal CSXI). The multiplicand in the D"-register is added to the contents of the CS"register in an exclusive OR operation, and the result transferred from the sum bus to the C"-register. The C"-register now holds the multiplicand with a polarity such that the product of the multiplication is the absolute value of the true product. The absolute value of the product is needed for the later truncation of the product.

Signal BCON was set during the same phase in which signal MPP went true. Signal $B C O N$ is high during the time that the multiplier bit-pairs are examined and is an enable signal to the examination logic. When BCON first went true, bit-pair $2^{1}, 2^{0}$ of the multiplier was examined and the multiplier control flip-flops DXCM, DXCLIM, and DXNCM were set up. At the same time, the B"-register shifted two bit positions to the right, bringing the second multiplier bit-pair into flip-flops B30 and B31. At the beginning of PH9, the multiplier control flip-flops have set up by the first bit-pair, and the next bit-pair is in position for examination.

Signal BCON is again enabled in PH9, and the following operations occur simultaneously at the PH9 clock:

1. The contents of the C"-register are clocked into the $D "$-register as a function of the multiplier control flip-flop set in the previous phase. If no multiplier control flip-flops are set, zeros are clocked into the D"register.
2. The multiplier control flip-flops are again set up by bit-pair $2^{3}, 2^{2}$ of the multiplier.
3. The B "-register shifts right two bit positions by signal BXBR2, bringing bit-pair $2^{5}, 2^{4}$ of the multiplier into flip-flops B30, B31.
4. Flip-flop MIT is set. Signo! MIT controls the number of multiply iterations.

## 5. Clock TIL is enabled for PH 10 .

6. Flip-flop FLMC is set if the original multiplier had significance only in the least significant hex (only two clocks of T 10 are to be used).
i. PHIO. PHIO is the multiply iterations phase of FAFLM. Figure 3-221 shows the register arrangement during the implementation of FMS and FML. The implementation is very similar to the implementation of opcodes MW and MI. A detailed description of the multiply process of this phase is therefore not given; only difference between FAFLM and FAMULNH are noted.

At the beginning of PH10, the $D$ "-register holds the first partial sum in flip-flop D46 through D31, the A'-register (flip-flops A47 through A31) is all zeros (cleared in phase preceding PH9), and the CS-register holds all zeros. The C"-register holds the multiplicand in bits C47 through C31 (FML) or bits C47 through C71 (FMS). The multiplier has been shifted so that it is now in flip-flops B47 through B71 and in B4 through B31 (FML) or B11 through B31 (FMS); the four least significant bits of the multiplier have been examined and discarded.

The maximum number of multiply iterations in PH 10 is 12 , if no prenormalization multiplier shifts have been performed, or if FMS is being performed. The maximum number is 28 if FML is being implemented. Since each prenormalization shift of the multipliers means that thereare four binary zeros in the more significant part of the multiplier, two times the number of prenormalization multiplier shifts is subtracted from 12 or 28 to give the number of multiply iterations that must be performed in PHIO . Each prenormalization multiplier shift has already been recorded by up-counting the iteration counter.

For each clock (iteration) of PH10, the following events occur:

1. The D"-register is combined with $A "$ - and $C S^{\prime \prime}-$ registers to produce the partial product for that iteration. Figure 3-222 shows the addition process and signal routing. The sums portion of the product is clocked into flip-flops A47 through A.31 and B0 through B.3. As the multiply iterations progress, the less significant bits of the partial product are lost (truncated) as they spill over to the right. The carries portion of the partial product is clocked into bit positions 47 through 33 of the CS"-register. The sums and carries are generated in the same manner as in instructions $M W, M I$, and MH.
2. The extreme higher-order and lower-order bits of the partial product are formed by special logic, logic identical to instructions MW, MI, and MH except for signal names. Bit A47 of the sum is used only for sign-padding the partial product and is a one whenever there is a one in bits A 47 or D46 or both. Bit A48 would normally be the sign bit in a straight addition, but it is a sum bit in carrysave addition since flip-flop CS48 may hold a carry after the addition. Flip-flops A49 through A31 and B0 and B1 are set by the propagate signal two orders to the left. Flipflop $B 3$ is set by signal BIS, equivalent to a propagate signal from bit position 33, and is true when there is a total of


Figure 3-221. FAFLM Register Organization (Phase 10)

1 or 3 ones in bits $\mathrm{BI}, \mathrm{BCl}$, and CS33. Flip-flop BCl is set by signal DCWCM and contains a one if the one's complement of the multiplicand was put in the D-register at the previous iteration. Paying the $\mathrm{D}^{\prime \prime}$-register the one needed to make a two's complement is done by adding a one to bit B3 of the partial product one clock after the addition of the $A^{\prime \prime}-, D^{\prime \prime}-$, and $C S^{\prime \prime}$-registers. The partial product has been shifted so that bit B 3 is in the same order that would have received the one if it had been added to the $D^{\prime \prime}$-register initially. Flip-flop $B 2$ is set by the propagate signal for bit position 32, PRE32; this is the same as the normal propagate signal except that only the CS"- and

B"-registers are combined. Flip-flop B2 is not set when there are both a PR32 signal and a generate signal from the 33rd bit position. Signal G33 amounts to a carry from bit position 33. The carry from bit position 33, if not resolved by setting flip-flop B2, is stored in flip-flop CS33. Flipflops CSI through CS32 are set by G0 through G31, respectively.
3. The contents of the C"-register are clocked into the $D$ "-register as a function of the multiplier control flip-flops set during the previous clock.

BEFORE
ADDITION


Figure 3-222. Floating Point Multiply Iteration Signal Routing
4. The next bit-pair of the multiplier is examined, and the multiplier control flip-flops are set.
5. The $\mathrm{B}^{\prime \prime}$-register shift right two bit positions by signal BXBR2 which brings a new bit pair into bit positions $B 30$ and B31.
6. The number of the iteration is counted. The iteration counter is made up of five flip-flops, P15 through P18 (cleared in PH3 by signal PX), and flip-flop MP19. The counter operates exactly as in instruction MW except that flip-flop FLMC is set on the 10th count for instruction FMS and the 28th count for instruction FML. The counter may have been up-counted before PH10 if the multiplier was prenormalized (see PH4 and PH5).

At the 26 th count ( 10 th if FMS), signal FLMC goes true. A true FLMC signal sets flip-flop MITEX at the 27th (11th) count. MITEX resets flip-flop MIT at the 28th (12th) count. At the 26 (10th) count, also, flip-flop TIL is reset to initiate the end of TIL (TIL timing lasts through PHIO). The 27th ( 11 th) count is the second-to-the-last transfer of the C"-register contents to the $\mathrm{D}^{\prime \prime}$-register under control of the multiplier control flip-flop. One more transfer occurs during PH 11 . The last carry-save addition of the $\mathrm{A}-, \mathrm{D}-$, and CS-register occurs during the 28th (12th) clock. Two more additions occur: in PHIl a partial product is assimilated and is put in the A-register; in PH12, this partial product is added to the last multiplicand transfer in the Dregister to form the final product of the multiplication. Clock T8L is enabled.
i. PHIl . PH 11 is used to assimilate the partial product of the multiplication from the results of the last iteration in PHIO . The sum portion of this partial product is contained in flip-flops A47 through A31 and in B0 through B3. The carries are contained in flip-flops CS47 through CS33. The contents of flip-flops A47 through A71, the contents of flip-flops CS47 through CS31, and K31 (carry from the lower order bits) are added by signal SXADD and are clocked into flip-flops A47 through A31 by signal AXS. The contents of flip-flops B0 through B3, CS32, CS33, and BC1 are added by signal BXB and clocked into flip-flops B0 through B3. Flip-flops A47 through A31 and B0 through B3 now hold the last partial product; the final product is found in PH 12.

At the PHIl clock, the last transfer to the D"-register takes place. The multiplier control flip-flops for this transfer were set during the last clock of PH 10 . A one is forced into flip-flop CS31 if the one's complement is transferred to the $D "$-register. Signal MRQ/1 (memory request) is enabled. Clock T8L is enabled.
k. PH12. During PH12, the final product is assimilated. This final product is the absolute value of the actual product (see PH 9 ). The partial product in the A-register is added to the last transfer of the multiplicand in the $D$ "-register (the transfer took place in PH 11 ). Bit CS 31 is also added, since it may contain a one if the one's complement were placed in
the $\mathrm{D}^{\prime \prime}$-register in PHII. The result of the addition, on S47 through S31, is clocked into the A-register. The D"register is cleared by signal $D X / 1$. Flip-flop NGX is set for use in PHI3. Signal ( $S / G 0003 / 1$ ) is enabled if FMS is being performed and the R -field of the instruction word is odd; flip-flop G0003/1 generates signal K71 for truncation of the short product. A one is forced on private memory address line LR31 to select the odd numbered private memory register in PH13. Clock T1OL is enabled if FMS is not being performed or if the R-field of the instruction word is not odd.
I. PHI3. PH 13 is the postnormalization phase of FAFLM. PHI 3 is entered from a phase preceding PHI 2 if the result of the multiplication is to be zero because of a zero multiplier or multiplicand; or from PH 12 if the multiplier is not zero. The result, at this time, is either ready for storage or not ready for storage. The result is not ready for storage if, at the beginning of PH 13 or after adjustment, bit A 47 is true or there is a nonzero result that must be postnormalized.

If the result is not ready for storage (NFPRR true), it is gated to the sum bus by signal SXA during PHI3. PHI 3 is sustained as long as signal NFPRR is true. At the first PH13 clock, clock T1OL is enabled if FMS is not being performed or if the R-field of the instruction word is not odd. A one is again forced on private memory address line LR31, and flip-flop NGX is set.

One of two courses is then followed:

1. If bit A47 is true, it signifies that the absolute value of the product is +1 . This can happen if the original operands were both $-1 / 16$. If both operands were $-1 / 16$, they are prenormalized to -1 , and changed to +1 for the multiplication, resulting in a product of +1 . The result must be shifted to the right to correct the overflow condition. The S-bus outputs are shifted one hex to the right, and the shifted result is transferred back into the $A^{\prime \prime}$ register at the PHI 3 clock. The exponent in the E-register is increased by one. The result is now ready for storage.
2. If bit A47 is false, if the result is nonzero, and if the result is not normalized, one postnormalization shift will normalize the product (only one postnormalization shift is required since the operands were both prenormalized, and there must be a one at least in the second most significant hex of the product). The result on the sum bus is shifted to the left one hex by signal AXSL4 and is clocked into the A-register. The E-register is decremented by one to adjust the exponent. The four least significant bits of the product, flip-flops in BO through B3, are also shifted leff by signal AXSL4.

When the result is ready for storage, one of three actions is taken:

1. The result is negated, and a one added for two's complement if FPR is true. The one for two's complementing
is provided bysignals K31 or K71 (ifFMS is being performed and if the R-field is odd). The negated result is gated to the sum bus by signal SXADD.
2. The result remains unaltered if FPR is false, and is gated to the sum bus by signal SXA.
3. Zeros are gated to the sum bus if the result is zero or if there was exponent underflow with $\mathrm{FZ}=0$.

If FML is being performed, there is no trap condition, and the R-field is not odd. Sum bus outputs S0 through S31, the LSW of the result, are transferred to the odd numbered private memory register at the PHI 3 clock (first or second). Sum bus outputs S 48 through $\mathrm{S71}$ are transferred to flip-flops A8 through A31 at the clock by signal AXAR32. The exponent result flip-flops in E1 through E7 is biased by adding 64 and is clocked into flip-flops Al through A7. Bias is achieved by reversing the state of flip-flop El. Ones are clocked into flip-flops CS0 through CS7 to invert the exponent if the final result is to be negative. The A-register now holds a zero in bit A0, the uninverted exponent in flip-flops Al through A7, and the most significant part of the fraction product in flip-flops A8 through A31.

Flip-flops DRQ, T8L, and PHI 5 are set at the PHI3 clock. Flip-flop DRQ inhibits transmission of another clock until a data release signal is received from memory.

If trap conditions exist, flip-flops TRAP and TR29 are set to provide a trap to memory location $X^{1} 44^{\prime}$ (68). Trap conditions are the following:

1. Exponent overflow. If the result is not equal to zero, exponent overflow causes an unconditional trap.
2. Underflow. Underflow causes a trap if the floating zero mode control bit, FZ, is a one.
m. PHI5. PH 5 is used to store the MSW of the result and toset the condition codes. If the result is not equal to zero, the MSW of the result is added to the contents of the CSregister in an exclusive OR operation (bit positions CSO through CS7 are all ones if the result is negative and invert the exponent and the sign bit in this case). The sum bus outputs, S0 through S31, are transferred to the even numbered private memory register if no trap condition exists. Signal RWDIS disables the transfer if a trap condition exists. The sum bus outputs are also transferred to flip-flops A0 through A31 for condition code use. A one is merged into bit A31 by signal A31X1 if the result was not equal to zero. This action is necessary because a portion of the result has already been stored ( PHI 3 ), and the most significant part may be zero.

Flip-flop TESTA is set to enable condition code bits 3 and 4 at the next clock. Condition code 1 is set if underflow has occurred, and if the result is not equal to zero. Condition code 2 is set if the overflow or underflow occurs,
and the result is nonzero. Condition code 3 is set if the result is positive and nonzero; condition code 4 is set if the result is negative. Signal ENDE is generated.

Flip-flop PREI is set to begin the preparation sequence for the next instruction, and clock T6L is enabled.

3-297 Floating Point Division (FAFLD)
3-298 GENERAL. The implementation of FDL is identical with the implementation of FDS with the exception of the number of fractional digits to be operated upon. The two instructions will be discussed together, with their differences noted in the discussion.

3-299 FLOATING POINT MODE CONTROL BITS. Mode control bit FZ, floating zero, is the only control bit influencing floating point division.

If mode control bit $\mathrm{FZ}=0$, underflow or a zero result causes the result to be set equal to true zero. If $F Z=1$, underflow causes the computer to trap to memory location X'44' (68). The contents of the general registers remain unchanged if the trap occurs.

If division by zero is attempted, or if exponent overflow occurs, the computer unconditionally traps to location $X^{\prime} 44^{\prime}(68)$.

3-300 CONDITION CODE SETTINGS. The condition code settings and their meanings for floating point division are shown in table 3-135.

3-301 BASIC STEPS IN FAFLD IMPLEMENTATION. To divide two floating point numbers in Sigma 7, the following basic steps are performed:
a. Transfer of operands ( PHI and PH 3 ). The numerator (from private memory) and the denominator (from core memory) are transferred to the arithmetic unit registers.
b. Exponent differencing ( PH 2 and PH 3 ). The uninverted biased denominator exponent is subtracted from the uninverted biased numerator exponent. The difference is the exponent of the quotient; bias has been removed by the subtraction process. This quotient exponent may be corrected as prenormalizing or postnormalizing shifts are performed on the fractions of the two operands.
c. Prenormalization (PH4-PH10). Before the two floating point numbers are divided, both are simple normalized. After the exponents are differenced (step b), the numerator and the denominator are examined; the following conditions are possible:

1. The numerator is zero, and the denominator is not simple normalized. The denominator is prenormalized to detect a zero value. The denominator is shifted right one hex at a time until it is simple normalized or is found

## XDS 901060

Table 3-135. Condition Codes for Floating Point Division

| CONDITION CODE |  |  |  | IF NO TRAP TO LOCATION X'44' OCCURS | IF TRAP TO LOCATION $\mathrm{X}^{\prime} 44^{\prime}$ OCCURS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 2 | 3 | 4 |  |  |
| 0 | 0 | 0 | 0 | $0 \div \mathrm{A}$ |  |
| 0 | 0 | 0 | 1 | Result negative |  |
| 0 | 0 | 1 | 0 | Result positive and nonzero | Impossible |
| 0 | 1 | 0 | 0 |  |  |
| 0 | 1 | 0 | 1 |  | Overflow, result negative |
| 0 | 1 | 1 | 0 | $=\\| \\|\\| \\|\\| \\|\\| \\|\\| \\|\\| \\|\\| \\|\\| \\|\\| \\|\\| \\|\\| \\|\\| \\|\\| \\|\\| \\|\\| \\|$ | Overflow, result positive and nonzero |
| 1 | 0 | 0 | 0 | $=$ Impossible |  |
| 1 | 0 | 0 | 1 |  |  |
| 1 | 0 | 1 | 0 |  |  |
| 1 | 1 | 0 | 0 |  |  |
| 1 | 1 | 0 | 1 |  | Underflow, result negative, FZ = 1 |
| 1 | 1 | 1 | 0 | $\square$ | Underflow, result positive and nonzero, $F Z=1$ |

to be zero. If the denominator is nonzero, a zero quotient is produced without going through the division process. If the denominator is zero, an unconditional trap results.
2. The numerator is zero, and the denominator is simple normalized. The division is not performed, and the result is set equal to true zero.
3. The numerator is nonzero and is not simple normalized (denominator may or may not be simple normalized). The numerator is shifted right one hex at a time until it is simple normalized. The exponent difference is decremented one with each shift. The denominator is then shifted right one hex at a time until it is simple normalized or is found to be zero. The exponent difference is incremented one with each shift. If the denominator is nonzero,
the division of the two operands occurs. If the denominator is zero, an unconditional trap results.
4. The numerator is nonzero and is simple normalized (denominator may or may not be simple normalized). The denominator is shifted to the right one hex at a time until it is simple normalized or is found to be zero. The exponent difference is incremented one with each shift. If the denominator is nonzero, the division of the two operands occurs. If the denominator is zero, an unconditional trap occurs.
d. Division (PHIl and PHI 2 ). The floating point numbers are divided after prenormalization of the fractions of both operands and provided that neither the denominator nor the numerator is zero. (Division methods are almost
identical to the nonrestoring division methods used for fixed-point numbers (DW and DH opcodes).
e. Storage (PHI3 and PH15). To bias it again, 64 is added to the exponent result. The biased exponent and the fraction result of the quotient are assimilated and are stored in memory in proper form, provided that there is no trap condition.

An example of FAFLD is shown in figure 3-223. The lettered steps correspond to the basic steps discussed.

3-302 DETAILED STEPS IN FAFLD IMPLEMENTATION. Figure 3-224 shows the FAFLD phases and the operations performed for each phase. The following discussion is supplemented by table 3-136 and by figure 3-224.
a. PH1. Signal CXCL32 is generated for use in PH2 . Flip-flops CCl and CC 2 are reset for underflow and overflow tests in PH15, and flip-flop IEN is set to start interruptibility. Ones are forced into flip-flops CSO through CS7 by signal CSXI/5 to invert the numerator exponent to its true form if the numerator is negative.
b. PH2. At the PH2 clock, the fraction part of the numerator MSW (or the complete fraction if FDS is being performed) is transferred from flip-flops A0 and A8 through A31 to A47 and A48 through A71, respectively, by signal AXAL32. The fraction part of the denominator MSW is transferred to the C -register extension in the same manner by signal CXCL32.

The numerator and denominator exponents are set up in PH 2 for exponent differencing. The uninverted numerator exponent is either present in flip-flops A1 through A7 or is found by combining bits A1 through A7 with CSO through CS7 (all ones) in PH3 in an exclusive OR operation. The uninverted numerator exponent is gated to the sum bus during PH2 and, at the PH2 clock, is transferred from the sum bus to flip-flops A0 through A7 by signal AXS/1.

The uninverted denominator exponent must be subtracted from the uninverted numerator exponent. The inverted denominator is therefore transferred to flip-flops DO through D7 by signals DXNC (if the denominator is negative) or to DXC/6 (if the denominator is positive).

A one is forced into flip-flop CS7 at the PH2 clock by signal CS7XI to complete the two's complemented form of the denominator exponent (needed for the subtraction). Ones are forced on core memory address line LB31 and on private memory line LR31 for possible use in PH3 (with FDL). If $F D L$ is being implemented, signal $M R Q$ (memory request) is enabled and flip-flop DRQ (data release) is set to transfer the least significant word of the denominator to the C register during PH3. Clock T6RL is enabled for PH3. If FDS is being implemented, flip-flop CS/1 is set at the PH2 clock to force all zeros into the C-register in PH3.

The division is performed such that the absolute value of the quotient is generated. Flip-flop FPR (floating result polarity reversed) is set in PH2 if the final (true) quotient is to be negative.
c. PH3. During PH3, the uninverted numerator exponent in flip-flops A0 through A7, the inverted denominator exponent in flip-flops D0 through D7, and the one in flipflops CS7 are added; their sum is gated to the sum bus. At the PH3 clock, the sum bus outputs on S0 through S7 are transferred to flip-flops EO through E7 by signal EXS. Flipflops E0 through E7 now hold the unbiased difference of exponents.

At the PH 3 clock, the P -register is cleared by signal PX . The P -register later serves as an iteration counter for the multiply iterations. The $A^{\prime \prime}$-register is cleared by signal $A X / 1$ but the contents are immediately regenerated by signals $S X A / 3$ and $A X S / 4$.

If FDL is being implemented, the LSW of the denominator is clocked into C0 through C31, and the LSW of the numerator is clocked into flip-flops A0 through A31. If FDS is being implemented, zeros are transferred to the $C$ - and A-register (no gating term enabled). Flip-flop NGX is set if the numerator is negative for use in PH 4 . The $\mathrm{D}^{\prime \prime}-$ register is cleared by signal $D X / 1$, and clock $T 8 L$ is enabled.
d. PH4. PH4 is used to examine the numerator and the denominator and to initiate simple normalization for either or both. There are four conditions possible at the beginning of PH 4 .

1. The numerator is zero and the denominator is not simple normalized. The denominator is prenormalized in this case to detect a possible zero value. The denominator in bits C47 through C31 is transferred to flip-flops D47 through D31 at the PH4 clock. The absolute value of the numerator (in this case, zeros) is transferred to the sum bus outputs by signal SXADD and into flip-flops B47 through B31 by signal BXS (for PH8 use). PH6 is enabled.
2. The numerator is zero, and the denominator is simple normalized (and cannot be zero). The multiplication is disabled and zeros are produced for the quotient result. Flip-flop RTZ is set, and flip-flop IEN is reset to stop interruptibility. Signal $M R Q / 1$ is generated to request the next instruction. A one is forced on private memory address line LR31 for PH13 use. Clock T10L is enabled if FDL is being performed, and PH 3 is enabled.
3. The numerator is nonzero and is not simple normalized (the denominator may or may not be simple normalized). The first prenormalization attempt is made in PH 4 . Further prenormalization attempts are made in PH 5 if necessary. Signal FPRENR is true if the numerator is not normalized. The absolute value of the numerator fraction is gated to S 47 through S 31 by signal SXADD and is shifted one hex to the left into flip-flops A47 through A27 by signal AXSL4.

| A. TRANSFER OF OPERANDS: | $\begin{array}{l\|lllllll\|llllllllllll} 0 & 1 & 0 & 0 & 1 & 0 & 1 & 1 & 0 & 0 & 0 & 0^{\prime} & 0 & 0 & 1 & 0^{\prime} & 0 & 0 & 0 & 0 \\ & \text { NUMERATOR } \\ & \left(2^{-7} \times 16^{11}\right) \\ 1 \mid 0 & 1 & 1 & 1 & 0 & 0 & 0 & 1 & 1 & 1 & 1^{\prime} 1 & 1 & 1 & 1^{1} 1 & 0 & 0 & 0 & \text { DENOMINATOR } \\ & & & & & & & & & & & \left.16^{7}\right) \\ \hline \end{array}$ |
| :---: | :---: |
| B. EXPONENT DIFFERENCING: | ```EXPONENT SIGN BIT 0 1 0 0 1 0 1 1 = +75 10111000=--(+71) < = (FOR TWO'S COMPLEMENT) (EXPONENT QUOTIENT)``` |
| C. PRENORMALIZATION OF OPERANDS: <br> EXAMINE NUMERATOR FRACTION AND DENOMINATOR FRACTION |  |
| SIMPLE NORMALIZE \|NUMERATOR| | SHIFT LEFT ONE <br> HEX DIGIT |
| ADJUST EXPONENT QUOTIENT | 0 0 0 0 0 1 0 0 <br>       -1  <br> EXPONENT QUOTIENT |
| SIMPLE NORMALIZE IDENOMINATOR\| ADJUST EXPONENT QUOTIENT |  |
| D. DIVISION OF FRACTIONS: <br> DIVIDE \|NUMERATOR| <br> BY \|DENOMINATOR | |  |
| E. STORAGE: <br> BIAS EXPONENT <br> ASSIMILATE FRACTION AND EXPONENT, CHANGETO PROPER FORM AND STORE |  |

Figure 3-223. Example of FAFLD Implementation


Table 3-136. Floating Divide (FAFLD), Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PREP | Same as general preparation sequence |  |  |
| $\left\lvert\, \begin{aligned} & \text { PHI } \\ & \text { T4RL } \end{aligned}\right.$ | $\text { RRO-RR31 } \leftrightarrows \text { A0-A31 }$ <br> Set flip-flop RN if numerator negative $\mathrm{MBO}-\mathrm{MB} 31 \longrightarrow \mathrm{C} 0-\mathrm{C} 31$ <br> Set flip-flop MWN if denominator negative <br> Set flip-flop CXCL32 <br> Reset flip-flop CCl <br> Reset flip-flop CC2 <br> Force all ones into CS0-CS7 <br> Set flip-flop IEN | $\begin{aligned} & \text { AXRR }= \text { RNXRR } / 2 \text { PH2 }+\ldots \\ &=\text { FAFL PHI }+\ldots \\ & \text { S/RN }= \text { RRO RNRXRRO }+\ldots \\ &=\text { RRO PH1 FAFL }+\ldots \\ & \text { Preparation control } \\ & \text { S/MWN }= \text { COC16 FAMDSF PHI }+\ldots \\ &=\text { MBO NP32 CXMB }+\ldots \\ & \text { S/CXCL32 }= \text { FAFL PHI }+\ldots \\ & \text { R/CCl }= \text { FAFL PHI }+\ldots \\ & \text { R/CC2 }= \text { FAMDSF PHI NFAMULH }+\ldots \\ & \text { CSX1/5 }= \text { FAFL PHI }+\ldots \\ & \text { S/IEN }= \text { FAMDSF NFAMUL PHI }+\ldots \end{aligned}$ | MSW of numerator <br> Stores numerator sign <br> MSW of denominator <br> Stores denominator sign <br> To invert numerator exponent if numerator negative <br> Start interruptibility |
| $\begin{array}{\|l\|l} \mathrm{PH} 2 \\ \mathrm{~T} 6 \mathrm{~L} \end{array}$ | $\begin{aligned} & \mathrm{A} 0, \mathrm{~A} 8-\mathrm{A} 31 \rightarrow \mathrm{~A} 47, \mathrm{~A} 48-\mathrm{A} 71 \\ & \mathrm{C} 0, \mathrm{C} 8-\mathrm{C} 31 \longrightarrow \mathrm{C} 47, \mathrm{C} 48-\mathrm{C} 71 \end{aligned} \mathrm{A0-A31+CS0-CS7} \mathrm{\longrightarrow} \begin{aligned} & \mathrm{S} 0-\mathrm{S} 31 \text { if numerator negative } \end{aligned}$ <br> or <br> $\mathrm{AO}-\mathrm{A} 31 \longrightarrow \mathrm{SO}-\mathrm{S} 31 \mathrm{if}$ numerator negative $\mathrm{SO} 0 \mathrm{~S} 7 \longrightarrow \mathrm{~A} 0-\mathrm{A} 7$ <br> NC0-NC7 $\rightarrow$ D0-D7 <br> if denominator positive <br> or $\mathrm{C} 0-\mathrm{C} 7 \longrightarrow \mathrm{D} 0-\mathrm{D} 7$ <br> if denominator negative | $\begin{aligned} \text { AXAL32 } & =\text { FAFL PH2 } \\ \text { CXCL32 } & =\text { Set in PHI } \\ \text { SXPR } & =\text { FAFL PH2 RN }+\ldots \\ & =\text { FAFL PH2 NRN }+\ldots \\ \text { SXA } & =\text { FAFL PH2 }+\ldots \\ \text { AXS/1 } & =\text { FAFL PH2 MWN }+\ldots \\ \text { DXNC } & \\ \text { DXC/6 } & =\text { FAFL PH2 }+N M W H+\ldots \end{aligned}$ | MSW of numerator <br> MSW of denominator <br> $\}$ <br> Uninverted numerator exponent <br> $\left\{\begin{array}{l}\text { Inverted denominator } \\ \text { exponent }\end{array}\right.$ |
|  |  |  | Mnemonic: $\operatorname{FDS}(3 E, B E)$, FDL (1E, 9D) |

Table 3-136. Floating Divide (FAFLD), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH2 <br> T6L <br> (Cont.) | Force a one into CS7 <br> Set flip-flop FPR if final quotient is to be negative <br> Force a one onto LB31 address line <br> Force a one onto LR31 address line <br> $\left.\begin{array}{l}\text { Enable MRQ } \\ \text { Set flip-flop DRQ } \\ \text { Enable T6RL }\end{array}\right\} \begin{aligned} & \text { if } \\ & \text { FDL }\end{aligned}$ <br> Set flip-flop CX/l if FDS |  | For two's complement subtraction (PH3) <br> Result must be reversed <br> Memory request for LSW <br> Inhibits transmission of another clock until data release signal received |
| $\begin{gathered} \text { PH3 } \\ \text { T6L } \\ \text { (FDS) } \\ \text { T6RL } \\ \text { (FDL) } \end{gathered}$ | $\begin{aligned} & \begin{array}{l} \text { A0-A7 }+ \text { D0-D7 }+\mathrm{CSO} \longrightarrow \\ \text { S0-S7 } \end{array} \\ & \text { S0-S7 } \longrightarrow \text { E0-E7 } \\ & \text { Clear P-register } \\ & \text { Clear A"-register } \\ & \left.\begin{array}{l} \text { A47-A71 } \rightarrow \text { S47-S71 } \\ \text { S47-S71 } \rightarrow \text { A47-A71 } \\ \text { RR0-RR31 } \rightarrow \text { A0-A31 } \\ \text { MB0-MB31 } \longrightarrow \text { C0-C31 } \end{array}\right\} \begin{array}{l} \text { if } \end{array} \text { inL } \end{aligned}$ <br> Set flip-flop NGX if numerator is negative <br> Clear D"-register <br> Set flip-flop T8L |  | Exponent quotient <br> $A^{\prime \prime}$-regenerated <br> LSW of numerator (zeros if FDS) <br> LSW of denominator (zeros if FDS) <br> For PH4 use |
|  |  | (Continued) | Mnemonic: FDS (3E, BE), FDL (1E, 9D) |

Table 3-136. Floating Divide (FAFLD), Phase Sequence (Cont.)


Table 3-136. Floating Divide (FAFLD), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH4 <br> T8L <br> (Cont.) | Enable DPP |  | $\left\{\begin{array}{l} \left\lvert\, \begin{array}{l} \mid \text { Denominator } \mid \\ \rightarrow-D^{\prime \prime} \end{array}\right. \end{array}\right.$ <br> Division may be performed |
| $\begin{aligned} & \text { PH5 } \\ & \text { T6L } \end{aligned}$ | (Entered from PH4, case 3) <br> 1-5 clocks (FMS) <br> 1-13 clocks (FML) <br> Case 1: ASN CSN $\Rightarrow$ DPP <br> Case 2: ASN NCSN <br> A47-A31 $\longrightarrow$ S47-S31 <br> S47-S31 $\rightarrow$ B47-B31 <br> Advance to PH6 <br> Case 3: NASN <br> $\mathrm{A} 47-\mathrm{A} 31 \longrightarrow \mathrm{~S} 47-\mathrm{S} 31$ <br> $(S 41-S 31) \times 16 \rightarrow \mathrm{~A} 47-\mathrm{A} 27$ | $\begin{aligned} & \text { Same actions as PH4, case } 4 \text { (enable PH9) } \\ & \text { DPP } \begin{array}{l} \text { = FAFLD PH5 ASN CSN }+\ldots \\ \text { NFPRENR } \end{array}=\text { FAFLMD PH5 ASN } \\ & \text { SXA }=\text { FAFL PH5 }+\ldots \\ & \text { BRPH5 }=\text { FPRENR PH5 + } \ldots \\ & \text { FPRENR }=\text { FAFLMD PH5 NASN } \\ & \text { SXA }=\text { FAFL PH5 + } \ldots \\ & \text { AXSL4 }=\text { FPRENR + } \ldots \end{aligned}$ | Shift absolute value of numerator one hex to the left |
|  |  | (Continued) | Mnemonic: FDS (3E, BE), FDL (1E, 9D) |

Table 3-136. Floating Divide (FAFLD), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH5 <br> T6L <br> (Cont.) | Decrement E0-E7 by one Sustain PH5 $S 47-S 31 \rightarrow B 47-B 31$ | $\begin{array}{ll} \text { MCTE } & =\text { FPRENR }+\ldots \\ \text { BRPH5 } & =\text { FPRENR PH5 }+\ldots \\ \text { BXS } & =\text { FAFLD PH5 NCSN }+\ldots \end{array}$ | Save normalized \| numerator | |
| PH6 <br> T6L | (Entered from PH4, cases 1 and 4, PH5 case 2) <br> D47-D31 $\longrightarrow$ S47-S31 $\mathrm{S} 51-\mathrm{S} 31 \times 16 \rightarrow \mathrm{~A} 47-\mathrm{A} 27$ <br> Increment E0-E7 by one <br> Enable S/CXS | $\begin{aligned} \text { FPRENM }= & \text { FAFLMD PH } 6+\ldots \\ \text { SXD }= & \text { FAFLMD PH } 6+\ldots \\ \text { AXSL4 }= & \text { FPRENM }+\ldots \\ \text { PCTE1 }= & \text { FPRENM FAFLD }+\ldots \\ \text { S/CXS }= & \text { FPRENM NA4731Z } \\ & + \text { FAFLMD PH } 6+\ldots \end{aligned}$ | Shift denominator one hex to the left |
| $\left\lvert\, \begin{aligned} & \mathrm{PH} 7 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}\right.$ | (Entered from PH6 only) <br> 1-6 clocks (FMS) <br> 1-14 clocks (FML) <br> Case 1: Denominator $=0$ <br> Set flip-flop CC2 <br> Set flip-flop RTZ <br> Case 2: Denominator $\neq 0$, NASN <br> $\mathrm{A} 47-\mathrm{A} 31 \longrightarrow$ S47-S31 <br> S51-S31 $\times 16 \longrightarrow$ A47-A31 <br> $\mathrm{S} 47-\mathrm{S} 31 \longrightarrow \mathrm{C} 47-\mathrm{C} 31$ <br> Increment E0-E7 by one <br> Set flip-flop CXS <br> Sustain PH7 | $\begin{aligned} & \text { S/CC2 }=\text { FAFLD PH7 A4731Z } \\ & (S / \text { RTZ } / 1)=\text { FAFLMD PH7 NA4731Z }+\ldots \end{aligned}$ <br> Other signals same as PH 4 , case 2 $\begin{aligned} \text { FPRENM } & =\text { FAFLM PH7 NASN }+\ldots \\ \text { SXA } & =\text { FAFLMD PH7 }+\ldots \\ \text { AXSL4 } & =\text { FPRENM }+\ldots \end{aligned}$ <br> CXS = See PH6 and PH7 <br> PCTE1 $=$ FPRENM FAFLD $+\ldots$ <br> $S / C X S=$ FPRENM NA4731Z $+\ldots$ <br> BRPH7 $=$ FPRENM NA473IZ $+\ldots$ | $(N \div 0)$ <br> Shift denominator one hex to the left |
|  |  | (Continued) | Mnemonic: FDS (3E, BE), FDL (1E, 9D) |

Table 3-136. Floating Divide (FAFLD), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH7 <br> T6L <br> (Cont.) | Case 3: Denominator $\neq 0, \mathrm{ASN}$ Advance to PH8 | $\begin{aligned} \text { NFPRENM } & =\text { FAFLM PH7 ASN }+\ldots \\ \text { BRPH7 } & =\text { FPRENM NA473IZ }+\ldots \end{aligned}$ |  |
| $\left\lvert\, \begin{array}{l\|} \text { PH8 } \\ \text { T6L } \end{array}\right.$ | (Entered from PH7 only) $\begin{aligned} & \mathrm{B} 47-\mathrm{B} 31 \longrightarrow \mathrm{~S} 47-\mathrm{S} 31 \\ & \mathrm{~S} 47-\mathrm{S} 31 \longrightarrow \mathrm{~A} 47-\mathrm{A} 31 \end{aligned}$ <br> Enable DPP | SXB $=$ FAFLD PH8 $+\ldots$ <br> AXS $=$ FAFLD PH $8+\ldots$ <br> DPP $=$ FAFLD PH $8+\ldots$ <br> Other signals same as PH 4 , case 4 | Retrieve normalized \|numerator| |
| $\begin{gathered} \text { PH9 } \\ \text { T8L } \\ \text { or } \\ \text { T6L } \end{gathered}$ | (Entered from PH4, PH5 or PH8 as the function of DPP) 1-2 clocks, 2 clocks only if $\mid$ numerator $\mid=1$ (in which case second clock is T6L) <br> Case 1: Numerator $=+1$ <br> $\mathrm{A} 47-\mathrm{A} 31 \longrightarrow$ S47-S31 $S 47-S 27 \times 1 / 16 \longrightarrow A 51-A 31$ <br> Increment E0-E7 by one <br> Sustain PH9 (advance to next PH9 clocked) <br> Case 2: Numerator $=0$ <br> Set flip-flop RTZ <br> Case 3: Numerator $\neq 0$, numerator < denominator $\mathrm{A} 47-\mathrm{A} 31 \longrightarrow \mathrm{~S} 47-\mathrm{S} 31$ $\mathrm{S} 47-\mathrm{S} 31 \times 2 \longrightarrow \mathrm{~A} 47-\mathrm{A} 31$ | SXA $=$ FAFLD PH9 $+\ldots$ <br> AXSR4 $=$ FAFLD PH9 A47 $+\ldots$ <br> PCTEI $\quad=$ FAFLD PH9 A47 $+\ldots$ <br> BRPH9 $\quad=$ FAFLD PH9 A47 $+\ldots$ $(S / R T Z / 1) \quad=\text { FAFLD PH9 A473IZ }+\ldots$ <br> Other signals same as PH 4 , case 2 $\begin{array}{ll} \text { SXA } & =\text { FAFLD PH9 }+\ldots \\ \text { AXSLI } & =\text { FAFLD PH9 NA47 }+\ldots \end{array}$ | Shift absolute value of numerator one hex to the right to avoid overflow in product <br> Enable PHI3 <br> Scale for division |
|  |  | (Continued) | Mnemonic: $\operatorname{FDS}(3 \mathrm{E}, \mathrm{BE})$, FDL (1E, 9D) |

Table 3-136. Floating Divide (FAFLD), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PH9 <br> T8L <br> or <br> T6L <br> (Cont.) | Set flip-flop T8L <br> Enable PHII <br> Case 4: Numerator $\neq 0$, numerator $\geq$ denominator <br> $\mathrm{A} 47-\mathrm{A} 31 \longrightarrow$ S47-S31 <br> S47-S31 $\times 2 \longrightarrow$ A47-A30 <br> Advance to PHIO <br> All cases: <br> Hold CS31 for first iteration in division (PH1) | ```R/NT8L = T8L = FAFLD PH9 NK46 NA4731Z + ... BRPH11 = FAFLD PH9 NK46 NA473IZ + ... SXA = FAFLD PH9 + ... AXSLI = FAFLD PH9 NA47 + ... R/CS31 = N(FAFLD PH9) +...``` | Scale for division |
| $\mathrm{PHIO}$ T6L | (Entered only from PH9, case 4) <br> $\mathrm{A} 47-\mathrm{A} 31 \longrightarrow$ S47-S31 <br> S47-S31 $\times 1 / 16 \rightarrow$ A51-A31 <br> $\mathrm{S} 28-\mathrm{S} 30 \longrightarrow \mathrm{BO}-\mathrm{B} 2$ <br> Increment E0-E7 by one <br> Hold CS31 for first PHIl iteration | $\left\{\begin{array}{l} \text { SXA }=\text { FAMDSF PH } 10+\ldots \\ \text { AXSR4 }=\text { FAFLD PH10 }+\ldots \\ \text { Gated by FAFLD PH10 }+\ldots \\ \text { PCTE1 }=\text { FAFLD PH } 10+\ldots \\ \text { R/CS31 }=\text { N(FAFLD PH10 }+\ldots \end{array}\right.$ | Shift numerator right one hex |
| $\begin{aligned} & \text { PHII } \\ & \text { T6L } \end{aligned}$ | 23 clocks if FDS, 35 clocks if FDL. During each clock, the following events occur <br> Enable signal DIT $\begin{aligned} & \xrightarrow{A 47-A 31+D 47-D 31+C S 31} \\ & S 48-S 31 \rightarrow A 7-S 31 \\ & B 0 \rightarrow A 31 \\ & B 47-B 31 \times 2 \rightarrow B 47-B 30 \end{aligned}$ | $\begin{aligned} \text { DIT }= & \text { FAMDSF/D PHII }+\ldots \\ \text { SXADD }= & \text { DIT }+\ldots \\ \text { AXSLI }= & \text { DIT }+\ldots \\ \text { S/A31 }= & \text { BO FAMDSF } / \mathrm{D} \mathrm{~N}[\text { FAFLD }(\text { PHII P26 } \\ & + \text { PHI2)] }+\ldots \\ \text { BXBLI }= & \text { DIT }+\ldots \end{aligned}$ |  |
|  |  | (Continued) | Mnemonic: FDS (3E, BE ), FDL (1E, 9D) |

Table 3-136. Floating Divide (FAFLD), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PHII T6L (Cont.) | Clock a quotient bit into B31 $\mathrm{NC} 47-\mathrm{NC} 31 \rightarrow \text { D47-D31 }$ <br> Force a 1 into CS31 $\text { C47-C31 } \nrightarrow \text { D47-D31 }$ <br> Count iterations, using P26-P31 <br> Sustain PHII <br> On the 22nd clock (FDS) or the 55th clock (FDL): <br> Other events listed above <br> Enable DITEX <br> Stop sustaining PHII <br> Enable MRQ/I <br> On the 23rd clock (FDS) or the 55th clock (FDL): <br> Set flip-flop T8L <br> Reset flip-flop IEN | ```S/B31 = K46 FAFLD PHII + ... DXNC/D = FAFLD PHIl (MWN \oplus K46) + ... S/CS31 = DXNC/D + ... DXC/D = FADIV PHII N(MWN }\oplus\mathrm{ K00) + ... PCTPI = DIT NDITEX + ... BRPHII = DIT NDITEX + ... DITEX = FAFLD O2 (P27 P29 P30) + FAFLD P26 P27 P29 P30 + ... BRPHII = DIT NDITEX + ... MRQ/1 = DIT DITEX + ... R/NT8L = T8L = FAFLMD PHII + ... R/IEN =: DIT DITEX + ...``` | Polarity of denominator clocked into D" and CS3I must be opposite to the residue clocked into $A "$ <br> Initiate end of iterations <br> Memory request for next instruction <br> Stop interruptibility |
| $\begin{array}{\|l\|l} \text { PH12 } \\ \text { T8L. } \end{array}$ | $\begin{aligned} & \mathrm{B} 47-\mathrm{B} 31 \longrightarrow \mathrm{~S} 47-\mathrm{S} 31 \\ & \mathrm{~S} 49-\mathrm{S} 31 \times 2 \longrightarrow \mathrm{~A} 18-\mathrm{A} 30 \\ & \mathrm{~K} 46 \rightarrow \mathrm{~A} 31 \end{aligned}$ <br> Clear D-register <br> Set flip-flop NGX <br> Force a one onto LR31 address line Set flip-floo TIOL if FDL | $\begin{array}{ll} \text { SXB } & =\text { FAFLD PH12 }+\ldots \\ \text { AXSL1 } & =\text { FAFLD PH12 }+\ldots \\ \text { S/A31 } & =\text { K46 FAFLD PHI } 2+\ldots \\ \text { DX/1 } & =\text { FAFL PH12 }+\ldots \\ \text { S/NGX } & =\text { FAFL PH } 12+\ldots \\ \text { R/NLR31/2 } & =\text { LR31 } / 2=\text { FAFL PH } 12+\ldots \\ \text { S/T10L } & =\text { FPRD PH } 12+\ldots \\ & =\text { FAFL NO2 PH } 12+\ldots \end{array}$ | $\} \mid$ Completes quotient $\mid$ |
|  |  | (Continued) | Mnemonic: $\operatorname{FDS}(3 \mathrm{E}, \mathrm{BE})$, FDL (1E, 9D) |

Table 3-136. Floating Divide (FAFLD), Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PHI3 <br> T10L <br> if FDL <br> T6L <br> (Cont.) | One clock only $\text { NA47-NA31 }+\mathrm{K} \longrightarrow \text { S47-S31 }$ <br> if product must be negative <br> A47-A31 $\longrightarrow$ S47-S31 <br> if product must be positive <br> All zeros into S47-S31 if result is zero or if exponent underflow with FZ $=0$ $\text { S0-S31 } \leftrightarrows \text { RW0-RW31 }$ <br> if FML and no trap $\mathrm{S} 48-\mathrm{S} 71 \longrightarrow \mathrm{~A} 8-\mathrm{A} 31$ $\mathrm{El}-\mathrm{E} 7+64 \rightarrow \mathrm{Al}-\mathrm{A} 7$ <br> Force ones into CSO-CS7 if result negative <br> Set flip-flop DRQ <br> Set flip-flop T8L <br> Set flip-flops TRAP and TR29 for trap to $X^{\prime} 44^{\prime}$ (68) if trap conditions exist |  | Store LSW of result <br> Most significant fraction quotient bits <br> $(\mathrm{NEI} \longrightarrow \mathrm{Al}, \mathrm{E} 2-\mathrm{E} 7$ A2-A7) uninverted exponent plus bias <br> Inhibit transmission of another clock until data release signal received <br> Exponent overflow <br> Exponent overflow <br> Exponent underflow with FZ $=$ 1. See PH7 |
| $\begin{aligned} & \text { PH15 } \\ & \text { T8L } \end{aligned}$ | $\mathrm{A} 0-\mathrm{A} 31 \oplus \mathrm{CSO}-\mathrm{CS7} \longrightarrow$ <br> S0-S31 if result does not equal zero <br> SO-S31 $\longrightarrow$ RW0-RW31 if NTRAP | $\begin{aligned} \text { SXPR }= & \text { FAFL PH15 N(RTZ }+ \text { FEUF NFZ }) \\ & +\ldots \\ \text { RW }= & \text { FAMDSF NFASHFX PH15 }+\ldots \end{aligned}$ | Invert exponent if result negative <br> Store MSW of result |
|  |  | (Continued) | Mnemonic: $\operatorname{FDS}(3 \mathrm{E}, \mathrm{BE})$, FDL (1E, 9D) |

Table 3-136. Floating Divide (FAFLD), Phase Sequence (Cont.)


The exponent difference in the E-register is decremented by one to compensate for the shift. If the denominator is not simple normalized, it is transferred to flip-flops D47 through D31 by signal DXC/6 in preparation for normalization in PH6. PH5 is entered.
4. The numerator is nonzero and is simple normalized (the denominator may or may not be simple normalized). The absolute value of the numerator is gated from flip-flops A47 through A31 to the sum bus outputs S 47 through S 31 by signal SXADD and back into flip-flops A47 through A31 by AXS. If the denominator is not simple normalized, it will be prenormalized to detect a possible zero value. The denominator is transferred to the D"-register, the absolute value of the numerator is transferred to the $\mathrm{B}^{\prime \prime}$-register, and PH6 is enabled as in case 1.

If the denominator is simple normalized (the denominator is nonzero), the division may take place. In this case, signal DPP (divide preparation) goes true, signifying that the two operands are being set up for the division. When signal DPP is true, one of two actions occur. If the denominator in the C"-register is negative, it is transferred to the D"register by signal DXC/6. If the denominator is positive, the inverted denominator is transferred to the D "-register by signal DXNC/1, and a one is forced into flip-flop CS31 to make up the two's complement of the inverted denominator. The B -register is cleared by signal $\mathrm{BX} / 1$. Clock T8L and PH9 are enabled.
e. PH5. PH5 is entered only if the numerator was not simple normalized at the beginning of PH 4 . At this point, the numerator may be simple normalized because of the one prenormalizing shift in PH4 or it may need further prenormalization shifting. Up to five clocks (FDS) or thirteen clocks (FDL) are used in PH5 to perform the prenormalization. There are three possible conditions at the start of PH5:

1. Numerator is simple normalized and denominator is simple normalized. If both ASN and CSN are true, signal DPP goes true and initiates the actions described in PH4, case 4.
2. Numerator is simple normalized and denominator is simple normalized. A true ASN disables PH5 and PH6 is entered to simple normalize the denominator. The absolute value of the simple normalized numerator in the A-register is gated to the sum bus by signal SXA and into the B-register by signal BXS at the PH5 clock. The numerator must be retained for later division.
3. Numerator is not simple normalized (denominator may or may not be normalized). If signal ASN is false, signal FPRENR is true, causing another prenormalization shift to be performed on the numerator. The fraction is shifted by signal AXSL4 and the exponent difference is decremented by one to compensate for the shift. PH5 is sustained by signal FPRENR. At each PH5 clock, the contents of the A"-register are gated
to the sum bus and, if CSN is false, are transferred to the $B^{\prime \prime}$ register by signal BXS. On the last clock of PH5, the B"register saves the simple normalized numerator if simple normalization is to be performed on the denominator.
```
FPRENR = FAFLMD PH5 NASN + ...
S47 = A47 SXA + ...
    SXA = FAFL PH5 + ...
S/A47 = S51 AXSL4 + ...
    . .
S/A27 = S31 AXSL4 + ...
```

f. PH6. PH6 is used to perform the first prenormalization shifton a denominator that is not simple normalized. The denominator may be zero at this point, but this condition is not detected until PH7. PH6 is entered only from PH4 or PH5.

During PH6, the denominator in the $\mathrm{D}^{\prime \prime}$-register is gated to sum bus outputs S 47 through S 31 by signal SXD. Signal FPRENM is true during this phase and causes a prenormalization shift to occur by enabling signal AXSL4. The denominator on the sum bus outputs are shifted one hex to the left and are clocked into flip-flops A47 through A27. The exponent difference in the E-register is incremented by one to compensate for the shift. (The shift is meaningless if the denominator is zero). Buffer latch CXS is set for PH7 use.
g. PH7. PH7 is entered only from PH 6 and is used to per formsimple normalization shifts of the denominator, if necessary, and to detect a zero denominator. Up to 6 clocks (FDS) or 14 clocks (FDL) may be used to perform further normalization shifts on the denominator. The following conditions may be present at the start of PH7:

1. Denominator $=0$. If the denominator equals zero, division is impossible and the computer traps to location $X^{\prime} 444^{\prime}$ (68). Flip-flop CC2 is set at the PH7 clock. Signal (S/RTZ/1) goes true with all zeros in flip-flops A47 through A 71 , and initiates the actions described in PH4. Step 2 (PHI3 is entered).
2. Denominator does not equal zero and is not simple normalized (another prenormalization shift is to be performed). Signal FPRENM is true and causes a prenormalizing shift to occur by enabling signal AXSL4. The denominator in flip-flops A47 through A31 is gated to the sum bus outputs S 47 through S 31 by signal SXA. The sum bus outputs S 47 through S31 by signal SXA. The sum bus outputs are shifted one hex to the teft and are transferred back to flip-flops

A47 through A27. The exponent difference in the E-register, is incremented by one to compensate for the shift. Buffer latch CXS is set for use in the next clock of PH7. PH7 is sustained.
3. Denominator is simple normalized. If the denominator is simple normalized, signal ASN goes true, and PH7 is not sustained for another clock. PH8 is then entered.

During all of the above cases, the sum bus outputs are transferred to C47 through C31 during each PH7 clock so that the simple normalized denominator is in the C"-register at the end of PH 7 (or PH 13 has been enabled for the zero denominator case).
h. PH8. If the denominator underwent simple normalization in PH6 and PH7, the absolute value of the normalized numerator was temporarily stored in the $B^{\prime \prime}$-register. During PH8, the numerator is clocked into the $A "$-register. Signal DPP goes true in PH8, initiating the same actions as described in PH4, step 4. PH9 is enabled.

i. PH9. PH9 is entered from PH4, PH5 , or PH8 after signal DPP goes true. At this point, the A"-register holds the absolute value of the simple normalized numerator, in the range $1 / 16 \leq \mathrm{N} \leq 1$ or equal to zero. (The zero case is possible only when PH9 is entered from PH8.) The D"register holds the negated form of the absolute value of the denominator with the absolute denominator in the range $1 / 16 \leq \mathrm{D} \leq 1$. The absolute value of the quotient of the division, if performed at this point, would be $1 / 16 \leq N \leq 1$ divided by $1 / 16 \leq D \leq 1$, or in the range $1 / 16 \leq Q \leq 16$. PH 9 and PHI 0 are used to adjust the numerator so that the absolute value of the quotient will always be a normalized number in the range $1 / 16 \leq Q<1$. There are two clocks in PH9 if the value of the numerator is +1 ; the first clock in this case is T8L and the second is T6L. In all other cases, only one T8L clock occurs. The following cases are possible.

1. Numerator is +1 . If the numerator is +1 , the $a b-$ solute quotient is in the range from 1 to 16 . The numerator is shifted one hex to the right to bring the quotient into the acceptable range. The numerator in flip-flops A47 through A31 is gated to the sum bus by signal SXA. At the

PH9 clock, the sum bus outputs are shifted one hex to the right into flip-flops A51 through A31 by signal AXSR4. The exponent difference in the E-register is incremented by one to compensate for the shift. PH9 is sustained, and one of cases 2, 3, or 4 is enabled.
2. Numerator equals zero. If the numerator is equal to zero, the quotient is also zero (the denominator must be nonzero for PH9 to be entered). Flip-flop RTZ is set, and PH 13 is enabled in the same manner as PH 4 , case 2. The division does not take place.
3. Numerator is nonzero and is less than the denominator. Bit D47 is a one (denominator negated), and bit A47 is a zero (numerator in absolute form). If the numerator is smaller than the denominator, there is no carry into the sign bit position (sum of numerator and denominator in a hypothetical addition would be negative); hence, there is no carry into bit position 46 . If $\mathrm{K} 46=0$, therefore, the numerator is smaller than the denominator; if $\mathrm{NA4731Z}=1$, the numerator is nonzero. If the conditions exist, the absolute value of the quotient must be in the normalized range and the division may take place. The numerator in flipflops A47 through A31 is gated to the sum bus by signal SXA and is shifted one bit position to the left by signal AXSLI back to the A "-register to prescale the numerator for the division (see PHIl ). Clock T 8 L and PHIl are enabled.
4. Numerator is nonzero and is greater than or equal to the denominator (but not equal to +1 ). If these conditions exist the absolute value of the quotient is greater than or is equal to one and is less than 16. The numerator must be shifted right to bring the quotient into the normalized range. The numerator is prescaled, as in case 3 , and PHIO is entered to perform the right shift.

In cases 1 through 4, flip-flop CS31 remains set to hold the one for the two's complemented (negated) denominator found in the phase where signal DPP was enabled.
i. PH 10 . PH 10 is entered from PH 9 only when case 4 of PH9 applies. The numerator in A47 through A30 is gated to the sum bus by signal SXA. The sum bus outputs S 47 through S31 are shifted one hex to the right and are clocked back into S51 through S31 by signal AXSR4. Sum bus outputs S28 through S30 are clocked into BO through B2, respectively. The exponent difference in the E-register is incremented by one to compensate for the shift. The one in CS31 is retained by not resetting the flip-flop.
k. PHIl. PH 11 is the divide iteration phase of FAFLD. Figure 3-225 shows the register arrangement during the implementation of FDS and FDL. The implementation is very similar to the implementation of opcodes DW and DH. A detailed description of the division process of this phase is therefore not given; only differences between FAFLD and FADIV are noted.
At the beginning of PHIl , the $\mathrm{A}^{\prime \prime}$-register holds two times the adjusted numerator in absolute form. The numerator was


901060A. 31412

Figure 3-225. FAFLD Register Organization (Phase 11)
shifted one bit position to the right in PH9 so that the first quotient bit produced is the $2^{-1}$ bit. The D"-register and flip-flop CS31 contain the first denominator transfer from the C"-register. The transfer was made so that the D"register contains the negated denominator, which is added to the numerator at the first clock of the nonrestoring division process.

There are 23 divide iterations in PHIl if FDS is being performed, or 55 divide iterations if FDL is being implemented. Signal DIT (divide iterations) is true as long as the iterations are to be performed. For each clock (iteration) of PHII, the following events occur:

1. The numerator is added to the contents of the D-register and flip-flop CS31 and the residue (see opcodes

DW and DH) is shifted one bit position to the left. The residue is clocked back into the A-register.
2. The contents of flip-flop BO are transferred to flipflop A31. Flip-flops B0 through B2 may contain a portion of the numerator (see PH10), and these least significant bits must be shifted into the residue as the iterations progress. Bit BO is transferred to flip-flop A31 with each clock until the 31st clock is reached, although only three transfers are actually necessary.
3. The B-register is shifted one bit position to the left by signal BXBLI. The B-register holds the partial quotients. Shifting one bit position to the left opens up B3l to receive a new quotient bit.
4. Another quotient bit is clocked into flip-flops B31. The quotient bit is a one when K 46 is a one, and is a zero when K46 is a zero. K46 takes the place of K00 used in instruction DW and DH and is the end carry for the nonrestoring division process.
5. The denominator or the inverted denominator is transferred from the $C "$-register to the $D "$-register. The transfer is made so that the contents of the D"-register are opposite polarity to the residue in the A"-register and enable the next addition in the nonrestoring process to occur. The true denominator is transferred by signal DXC/D if the residue is negative and the true denominator is positive or if the residue is positive and the true denominator is negative. The inverted denominator is transferred by signal DXNC/D if both the residue and the true denominator have like signs. A one is clocked into flip-flop CS31 in the latter case to make up the two's complement of the denominator when the next addition takes place.
6. The number of the iteration is counted. Flip-flops P26 through P31 make up a six bit iteration up-counter for instruction FDS and FDL. When the counter indicates 22 for FDS or 55 for FDL, signal DITEX goes true, enabling signal $M R Q / 1$ to request the next instruction. Signal BRPHIl goes false as DITEX is enabled. At the next clock, flip-flop T8L is set and flip-flop IEN is reset.
If FDS is being performed, bits $2^{-1}$ through $2^{-23}$ of the quotient are in flip-flops B9 through B31 at the end of PHIl . If FDL is in effect, bits $2^{-1}$ through $2^{-55}$ of the quotient are in flip-flops B49 through B31. One more iteration must be performed to complete the absolute value of the product.

1. PH 12 . PH 12 is used for the last iteration of the division process. The partial quotient in the $\mathrm{B}^{\prime \prime}$-register is shifted one bit position to the left and transferred into flip-flops A47 through A30 of the A"-register by signal AXSLI. The last quotient bit ( $2^{-24}$ if FDS or $2^{-56}$ if FDL $)$ is clocked into flip-flop A31. The A"-register now holds the complete absolute quotient.

Also at the PHI 2 clock, the $\mathrm{D}^{\prime}$-register is cleared by signal DX/1. Flip-flop NGX is set for possible negation of the quotient in PH 13 . A one is forced on private memory address line LR31 to select the odd numbered private memory register for storage of the quotient. Flip-flop TlOL is set if FDL is being performed.
m. PH13. At the start of PH 13 , the absolute value of the quotient is in flip-flops A8 through A31 ifFDS is being performed or is in flip-flops A48 through A31 if FDL is in effect. The result is ready for storage and signal FPRR is true. The quotient is normalized unless flip-flop RTZ is set. PH 13 and PH 15 are the two storage phases of FAFLD. One of three actions is now taken:

1. The result is negated and a one is added for two's complementing if FPR is true. The one for two's complementing
is provided by K31 (NGX set in PH12). The negated result is gated to the sum bus by signal SXADD.
2. The result remains unaltered if $F P R$ is false, and is gated to the sum bus by signal SXA.
3. Zeros are gated to the sum bus if the result is zero or if there was exponent underflow with $F Z=0$.

If FDL is being performed and if there is no trap condition, sum bus outputs S0 through S31, the LSW of the result, are transferred to the odd numbered private memory register at the PH 13 clock. Sum bus outputs S 48 through S 71 are trans ferred to flip-flops A8 through A31 at the clock by signal AXAR32. The exponent result flip-flops in El through E7 is biased by adding 64 and clocked into flip-flops Al through A7. Bias is achieved by reversing the state of flip-flop El. Ones are clocked into flip-flops CS0 through CS7 to invert the exponent if the final result is to be negative. The Aregister now holds a zero in bit $A 0$. It holds the uninverted exponent in bits Al through A7 and the most significant part of the fraction product in bits A8 through A31.

Flip-flops DRQ, T8L, and PH15 are set at the PH13 clock. Flip-flop DRQ inhibits transmission of another clock until a data release signal is received from memory.

If trap conditions exist, flip-flops TRAP and TR29 are set to provide a trap to memory location $X^{\prime} 44$ ' (68). Trap conditions are the following:

1. Exponent overflow. If the result is not equal to zero, exponent overflow causes an unconditional trap.
2. Underflow. Underflow causes a trap if the floating zero mode control bit, FZ, is a one.
n. PH15. If the result is not equal to zero, the MSW of the result is added to the contents of CS-register in an exclusive OR operation (bits CSO through CS7 are all ones if the result is negative and invert the exponent and sign bit in this case). The sum bus outputs, S0 through S31 are transferred to the even numbered private memory register if no trap condition exists. Signal RWDIS disables transfer if a trap condition exists. The sum bus outputs are also transferred to flip-flops A0 through A31 for condition code use. A one is merged into bit A31 by signal A31X1 if the result was not equal to zero. This action is necessary because a portion of the result has already been stored (PHI3) the most significant part of which may be zero.

Flip-flop TESTA is set to enable condition code bits 3 and 4 at the next clock. Condition code 1 is set if underflow has occurred and if the result is not equal to zero. Condition code 2 is set if overflow or underflow occurs and if the result is nonzero. Condition code 3 is set if the result is positive and nonzero; condition code 4 is set if the result is negative. Signal ENDE is generated.

## 3-303 PROCESSOR CONTROL PANEL

The Processor Control Panel (PCP) is divided into two separate functional sections. The upper section (MAINTENANCE SECTION) is reserved for maintenance controls and indicators; the lower section, which is not labeled, contains the controls and the indicators for the computer operator. All controls and indicators appearing on the lower section of the PCP are functionally duplicated on the Free-Standing Console (FSC). The Sigma 7 Processor Control Panel is shown in figure 2-1. The PCP switches, with their designators and output signals are listed in table 3-137. The PCP indicators, with their designators and associated lamp driver origins, are listed in table 3-138. The POWER and INTERRUPT pushbuttons in the center of the panel are illuminated. The NORMAL MODE, RUN, and WAIT assemblies are indicators only.

## 3-304 Common Output Signals

Three logic signals are not directly associated with any single control switch, but are the result of several combinations of switch settings. These logic signals are KAS/1, KAS/2, and NKAS/B. Table 3-139 shows the conditions under which these signals are true.

## 3-305 POWER Switch

The POWER switch is an illuminated push on-push off button that connects ac power to the computer and to units under its control. When the switch is engaged and the ac power is available at the power source, +8 volts are supplied to the internal indicator to light the pushbutton. When the power is turned off, the indicator goes out. The events that take place in the CPU when the power goes on and off are described in the paragraphs on power on and power off sequence under Entering PCP Phases.

## 3-306 CONTROL MODE Switch

The CONTROL MODE switch distributes +8 and -8 volts to points in the PCP depending on whether it is set to LOCAL, REMOTE, or LOCK. These voltages can enable or disable operation of the switches to which they are connected. When the CONTROL MODE switch is in the LOCAL position, all control functions can be carried out from the PCP. When the switch is in the REMOTE position, most control functions can be carried out from the Free-Standing Console (FSC). All controls and indicators on the maintenance section except the CLOCK MODE and SENSE switches are operative; all switches on the lower portion of the PCP except the POWER and INTERRUPT switches are inoperative. When the switch is in the LOCK position, all switches on the PCP are inoperative except the POWER, INTERRUPT, SENSE, and AUDIO switches. In the LOCK position, the switch connects +8 or -8 volts to the switch circuits in such a way that the COMPUTE switch appears to be in the RUN position; the WATCHDOG TIMER and INTERLEAVE SELECT switches appear to be in the NORMAL position; and the

PARITY ERROR MODE and CLOCK MODE switches appear to be in the CONT position.

## 3-307 CLOCK MODE Switch

When the CLOCK MODE switch is in the CONT position, signals $K C$ and KSC are false and signal NKC/B is true. The program sequences normally and clock enable signal CE is active. When the switch is placed in the center position, signal KSC goes true, signal KC goes false, and signal NKC/B remains true. Clock enable signal CE is inhibited by the following equation.

$$
C E=N(K S C \text { NSC2 })(\ldots)
$$

If the switch is held in the SINGLE STEP position, signal KSC remains true, signal KC goes true, and signal NKC/B goes false. Signal CE goes true long enough to allow a single clock pulse. Further clock pulses are inhibited by SCD as follows:

```
CE = N(KSC SCD) (...)
SCD = SCD SC2 + SC2 SCEN CL
S/SC2 = SC1
S/SCl = KSC KC
```

When the switch is returned to the center position or is set to CONT, NKC/B goes true, SCD drops, and clock pulses are again enabled as follows:

$$
\begin{aligned}
& R / S C 1=N K C / B S C D \\
& R / S C 2=N S C 1
\end{aligned}
$$

During single step operation, the watchdog timer is inoperative because signal KSC holds signal WDTR true and the watchdog timer is held in the reset state.

$$
\text { WDTR }=K S C+\ldots
$$

This logic is explained further in the following paragraphs.

## 3-308 WATCHDOG TIMER Switch

When the WATCHDOG TIMER switch is in the NORMAL position, switch output signal KWDTR is false, and the watchdog timer counter is reset by signal WDTR only at interruptible points during program execution.

$$
\text { WDTR }=\mathrm{IEN}+\mathrm{ENDE}+\mathrm{KWDTR}+\ldots
$$

where IEN signifies interrupt enable and ENDE is true during the last phase of instruction execution. If the counter reaches a count of 39 before an interruptible point is reached, timer runout has occurred, and the program traps to location $X^{\prime} 46$ '.

Table 3-137. PCP Control Switches

(Continued)

Table 3-137. PCP Control Switches (Cont.)

(Continued)

Table 3-137. PCP Control Switches (Cont.)

(Continued)

Table 3-137. PCP Control Switches (Cont.)

| Switch Name | Designator | Output Signals | Switch Position | Logic Level |
| :---: | :---: | :---: | :---: | :---: |
| DATA | S43 | KCLEARD/B | CLEAR <br> ENTER | True False |
|  |  | KENTERD/B | ENTER CLEAR | True False |
| INSTR ADDR | S20 | KINCRE/B | INCREMENT HOLD | True <br> False |
|  |  | NKHOID | HOLD <br> INCREMENT | True <br> False |
| DISPLAY | S22 | KDISPLAK/B | SELECT ADDR <br> INSTR ADDR | True False |
|  |  | KDISPLAQ/B | INSTR ADDR SELECT ADDR | True False |
| COMPUTE | S42 | KRUN/B | RUN IDLE STEP | True <br> False <br> False |
|  |  | KSTEP/B | RUN <br> IDLE <br> STEP | False <br> False <br> True |
| $\begin{aligned} & \text { SELECT } \\ & \text { ADDRESS } \end{aligned}$ | S24 | KSP31 | 1 | True |
|  | - |  | Center | False |
|  | S40 | KSP15 | 0 | False |
| ADDR STOP | S41 | KADDRSTOP | ON | True |
| DATA 0 | S75 | KNC0 | 1 | True |
|  |  |  | Center | True |
|  |  | KSO | 1 | True |
|  |  |  | Center 0 | False <br> False |
| DATA 31 | S44 | KNC31 | 1 | True |
|  |  |  | Center | True |
|  |  | KS31 | 0 1 | False True |
|  |  |  | Center 0 | False |

Table 3-138. PCP Indicators

| Indicator Name | Designator | Lamp Driver Origin |
| :---: | :---: | :---: |
| INSTRUCTION ADDRESS | DS39 | Q31/L |
|  | : | : |
|  | DS55 | Q15/L |
| TRAP |  |  |
| ARITH | DS56 | AM/L |
| DEC | DS57 | DM/L |
| MODE |  |  |
| MAP | DS58 | MAPF/L |
| SLAVE | DS59 | NMASTER/L |
| FLOAT MODE |  |  |
| NRMZ | DS60 | FNF/L |
| ZERO | DS61 | FZ/L |
| SIG | DS62 | FS/L |
| CONDITION CODE |  |  |
| 1 | DS66 | $\mathrm{CCl} / \mathrm{L}$ |
| 2 | DS65 | CC2/L |
| 3 | DS64 | CC3/L |
| 4 | DS63 | CC4/ |
| POINTER | DS29 | RP27/L |
|  | . | - |
|  | DS33 | RP23/L |
| INTRPT INHIBIT |  |  |
| EXT | DS34 | EI/L |
| I/O | DS35 | II/L |
| CTR | DS36 | CIF/L |
| WRITE KEY | DS37 | WKO/L |
|  | DS38 | WK2/L |
| DISPLAY |  |  |
| 31 | DS67 | S31/L |
| : | : | : |
| 0 | DS98 | S0/L |
| POWER | DS28 | $+8 \mathrm{~V}$ |
| NORMAL MODE | DS25 | Switch 55C-1 (on PT16 power supplies) |
| RUN | DS24 | RUN/L |
| WAIT | DS23 | WAIT/L |

(Continued)

Table 3-138. PCP Indicators (Cont.)

| Indicator Name | Designator | Lamp Driver Origin |
| :---: | :---: | :---: |
| INTERRUPT | DS22 | CPILITE/L |
| MEMORY FAULT |  |  |
| 1 | DS21 | MFO/L |
|  | - | . |
| 8 | DS14 | MF7 1 |
| ALARM | DS13 | ALARM/L |
| PHASES | DS12 | PRE4/L |
| PREPARATION | DS11 | PRE2/L |
|  | DS10 | PRE1/L |
| PCP | DS9 | PCP4/L |
|  | DS8 | PCP2/L |
|  | DS7 | PCPI/L |
| EXECUTION | DS6 |  |
|  | DS5 | PH4/L |
|  | DS4 | PH2/L |
|  | DS3 | PHI/L |
| INT/TRAP | DS2 | INTRAP2/L |
|  | DSI | INTRAPI/L |

Table 3-139. Switch Settings for Signals KAS/1, KAS/2, and NKAS/B

| SWITCH NAME | KAS/1* |  | KAS/2 * $\dagger$ | NKAS/B** |
| :---: | :---: | :---: | :---: | :---: |
|  | LOAD Switch Off and Any One of Switch Positions Shown | LOAD Switch Pressed and All Switch Positions as Shown | LOAD Switch Off and Any One of Switch Settings Shown | LOAD Switch Off and All of Switch Positions as Shown |
| INSERT | PSW1 or PSW2 | Center | PSW1 or PSW2 | Center |
| INSTR ADDR | INCREMENT | Center or HOLD | INCREMENT | Center or Hold |
| STORE | INSTR ADDR or SELECT ADDR | Center | INSTR ADDR or SELECT ADDR | Center |
| DISPLAY | INSTR ADDR <br> or SELECT ADDR | Center | $\begin{aligned} & \text { INSTR ADDR } \\ & \text { or } \\ & \text { SELECT ADDR } \end{aligned}$ | Center |
| DATA | CLEAR or <br> ENTER | Center | CLEAR <br> or <br> ENTER | Center |
| COMPUTE | RUN or STEP | IDLE | RUN or STEP | IDLE |

* Always true with CONTROL MODE switch in LOCK position
${ }^{\dagger}$ Always true with LOAD switch pressed
** Always false with LOAD switch pressed

Setting the switch to OVERRIDE holds WDTR true with KWDTR, and the counter is held in the reset state. Timer runout cannot occur in this condition.

## 3-309 INTERLEAVE SELECT Switch

When the INTERLEAVE SELECT switch is in the NORMAL position, signal KINLVSEL is false and has no effect on the memory. With the switch in the DIAGNOSTIC position, KINLVSEL is true, and memory interface signal /ORIL/ is developed to override the interleaving operation in core memory.

## 3-310 PARITY ERROR MODE Switch

When the PARITY ERROR MODE switch is in the CONT position, switch output signal KHOP is false. A memory parity error causes one of eight signals from memory, MFLO through MFL7, to go true, according to the memory module in which the parity error occurs. These signals light corresponding memory fault indicators on the PCP, and interrupt signal PEI is transmitted to the memory parity interrupt level.

Signal PEI is generated from parity error signal PEC from memory as follows.

```
PEI = PEFI + PEF2
    S/PEFI = PEL NINTEN
    PEL = PE + ...
    PE = /PEC/ (memory interface)
    NINTEN = N(KHOP PEL)
```

When the switch is in the HALT position, signal KHOP is true and computer clock enable signal CE is driven low, halting operation. The equation is as follows:

$$
\text { CE }=\text { NINTEN NCROF NWDTA (...) }
$$

When parity error signal PEC is received from memory, PEL goes true, and as a result, NINTEN goes low, disabling CE. The memory fault indicators are lighted in the same manner as when the switch is in the CONT position.

With KHOP true, a halt on fault signal is transmitted to memory as follows:

$$
/ \mathrm{HOF} /=\mathrm{KHOP}
$$

Signal HOF in memory causes parity error signal PE, which is in the module where the error occurred, to latch, thereby inhibiting the memory delay line in that module and preventing further access. While PE is latched, clock enable signal CE in the CPU is also held low. The latch may be reset by pressing the SYS RESET/CLEAR button on the PCP. This switch also turns off the memory fault indicators.

## 3-311 AUDIO Switch

The AUDIO switch, when in the ON position, connects signal AUDIO/L to the computer speaker. Signal AUDIO/L is generated from the MUSIC or the ALARM flip-flop as follows:

$$
\begin{aligned}
\text { AUDIO } / L= & \text { AUDIO } \\
\text { AUDIO }= & \text { MUSIC NALARM } \\
& + \text { ALARM KRUN } / \text { B IKC }
\end{aligned}
$$

The MUSIC flip-flop, referred to in the Sigma 7 reference manual as the program-controlled frequency flip-flop, is toggled by a Write Direct instruction in the internal mode. The frequency, therefore, is determined by the frequency of the Write Direct instructions.

The ALARM flip-flop is set and is reset by internal mode Write Direct instructions or by a RESET signal. The AUDIO switch and the ALARM flip-flop connect a l-kHz frequency to the computer speaker.

## 3-312 SENSE Switches

The four SENSE switches have outputs KSS1 through KSS4, which are true when the switches are in the 1 position and are false when the switches are in the zero position. These outputs are used to set the condition code flip-flops during a Read Direct or Write Direct internal mode instruction as follows:

$$
\begin{aligned}
(S / C C 1-S / C C 4)= & \text { FARWD SW1 B1619Z } \\
& (\text { KSSI-KSS4 })
\end{aligned}
$$

If the CONTROL MODE switch is in the REMOTE position, the +8 volts are removed from the SENSE switches, holding their outputs low and making them inoperative.

## 3-313 REGISTER DISPLAY Switch

The REGISTER DISPLAY switch is used in connection with the REGISTER SELECT switch to display the contents of the internal CPU registers shown on the PCP panel around the REGISTER SELECT switch in the DISPLAY indicators. When the REGISTER DISPLAY switch is on, signal KD is generated unless the CLOCK MODE switch is in the CONT position, thereby removing the +8 voltage from the KD circuit. Signal KD is used to generate signal SDIS, which enables sum bus information to be placed on the DISPLAY indicator lines SO/L through S31/L. The equation for SDIS is as follows:

```
SDIS = KD KSC NSCI
```

where KSC indicates that the CLOCK MODE switch is not in the CONT position and where NSCl indicates that the CLOCK MODE switch is not in the SINGLE STEP position.

## 3-314 REGISTER SELECT Switch

The REGISTER SELECT switch has 11 positions which allow the display of the contents of the registers indicated if the

REGISTER DISPLAY switch is in the ON position and if the CLOCK MODE switch is not in the CONT position. The switch positions, the logic signals generated, and the registers displayed are shown in table 3-140.

Table 3-140. REGISTER SELECT Switch Logic

| Switch Position | Information Displayed | DISPLAY Indicators Lighted | Switch Output Logic Signals |
| :---: | :---: | :---: | :---: |
| $A_{L}$ | A0-A31 | 0-31 | KSXA |
| $\mathrm{A}_{\mathrm{H}}$ | A47-A71 | 7-31 | KSXA, KDSHI |
| $\mathrm{B}_{\mathrm{L}}$ | B0-B31 | 0-31 | KSXB |
| ${ }^{\text {B }} \mathrm{H}$ | B47-B71 | 7-31 | KSXB, KDSHI |
| $\mathrm{CS}_{\mathrm{L}}$ | CS0-CS31 | 0-31 | KSXCS |
| $\mathrm{CS}_{\mathrm{H}} \mathrm{E}$ | $\begin{array}{\|l} \text { EO-E7 } \\ \text { CS48-CS71 } \end{array}$ | $\begin{aligned} & 0-7 \\ & 8-31 \end{aligned}$ | KSXCS, KDSHI, KSXE |
| $\mathrm{D}_{\mathrm{L}}$ | D0-D31 | 0-31 | KSXD |
| $\mathrm{D}_{\mathrm{H}}$ | D47-D71 | 7-31 | KSXD, KDSHI |
| P | P15-P31 | 15-31 | KSXP |
| $S_{L}$ | 50-531 | 0-31 | KSXS |
| $\mathrm{S}_{\mathrm{H}}$ | S47-S71 | 7-31 | KSXS, KDSHI |

The switch outputs gate the contents of the internal registers onto the sum bus as follows:

```
SXA = KSXA SDIS + ...
SXB = KSXB SDIS + ...
SXCS = KSXCS SDIS + ...
SXD = KSXD SDIS + ...
SXP = KSXP SDIS + ...
```

Signal SDIS is false when the COMPUTE switch is in the IDLE position and the REGISTER DISPLAY switch is off or when the CLOCK MODE switch is not in the center position or when the REGISTER DISPLAY switch is at $S_{L}$ or $S_{H}$ and the contents of the D-register are displayed by way of the sum bus:

```
SXD = PCP2 NRESET/F NSDIS + ...
```

The sum bus outputs are gated onto display indicator lines $S 0 / L$ through $S 31 / L$ by KSHI or NKSHI. Signal KSHI is generated as follows:

$$
\mathrm{KSHI}=\mathrm{KD} \mathrm{KDSHI} \mathrm{KSC}
$$

Signal KDSHI is true when the REGISTER SELECT switch is set at $A_{H}, B_{H}, C_{H} E, D_{H}$, or $S_{H}$ to display bits 47 through 71 of the selected register. If KDSHI is false, bits 0 through 31 of the register are displayed. A typical equation is as follows:

$$
\mathrm{S} 8 / \mathrm{L}=\mathrm{S} 8 \mathrm{NKSHI}+\mathrm{S} 48 \mathrm{KSHI}
$$

In the case of the setting $\mathrm{CS}_{\mathrm{H}} \mathrm{E}$, display indicators 0 through 7 display the contents of the E-register and indicators 8 through 31 display bits 48 through 71 of the CS-register. The following are typical equations:

$$
\begin{aligned}
\text { SO/L }= & S 0 \text { NKSHI }+\mathrm{E} 0 \text { KSXE } \\
\text { S7/L }= & \text { S7 NKSHI }+ \text { S47 KSHI NKSXE } \\
& +E 7 \text { KSXE } \\
\text { KSXE }= & \text { KSXCS KSHI }
\end{aligned}
$$

The second two equations cause $S 7 / L$ to display $E 7$ rather than CS47 because KSXE is always true in this position.

The P-register is displayed by way of S15I through S311 as follows:

$$
\begin{aligned}
(S 15-S 31) & =(S 15 I-S 31 I) \\
(S 15 I-S 31 I) & =(P 15-P 31 S X P)
\end{aligned}
$$

## 3-315 I/O RESET Pushbutton

The I/O RESET pushbutton, when pressed with the COMPUTE switch in the IDLE position, generates signal KIORESET. This signal is gated with NKAS/B to develop signal RIO and its resulting cable driver signal /RIO/ which is to be sent to the IOP. The /RIO/signal is used in the IOP to reset to the ready condition all peripheral devices under the control of the CPU and to reset all status, interrupt, and control indicators in the input/output system. Signal KIORESET is held false when the CONTROL MODE switch is in the LOCK position. The I/O RESET switch does not affect the current operation of the CPU.

## 3-316 UNIT ADDRESS Thumbwheels

The three UNIT ADDRESS thumbwheels decode into binary numers the three hexadecimal numbers which represent the address of the device, the device controller, and the IOP, respectively. Signals KUA21, KUA22, and KUA23 are the outputs of the left-hand switch, signals KUA24, KUA25, KUA26, and KUA27 are the outputs of the center switch, and signals KUA28, KUA29, KUA30, and KUA31 are the outputs of the right-hand switch. These signals are used in the logic that generates the bootstrap program so that the value of the UNIT ADDRESS switches may be inserted into the appropriate memory location during load operation.

## 3-317 INTERRUPT Switch

The INTERRUPT switch is an illuminated pushbutton with two outputs, KINTRP and KINTRP/B. When the pushbutton is pressed, signal KINTRP goes true and signal KINTRP/B goes false. Signal KINTRP is used to generate SRI3 which, in turn, is used to set interrupt flip-flop IS13. Signal NINTRP/B is used to reset service request interlock control flip-flop CNLK. When the control panel interrupt is operative, the program goes to interrupt location $X^{\prime} 5 D^{\prime}$. The interrupt does not occur if the interrupt inhibit bit in position 6 of program status doubleword 2 is set.

The indicator in the INTERRUPT pushbutton is lighted by signal CPILITE/L, which is the output of a lamp driver whose input is INT11. Signal INTll is true when flip-flops IP13 and IS13 in the interrupt circuits are set, indicating that the control panel interrupt signal has been received and that the interrupt is in the waiting state. The indicator goes out when the control panel interrupt goes to the active state.

## 3-318 SELECT ADDRESS Switches

The SELECT ADDRESS switches have outputs KSP15 through KSP31 which are used for three purposes:
a. To select the virtual address at which the program is to be halted when the ADDR STOP switch is in the ON position. In this case, the outputs are compared with the LM address lines to generate an ADMATCH signal if the address on the core memory address lines is the same as the address in the switch settings.
b. To select the virtual address of a memory location to be altered if the STORE switch is in the SELECT ADDR position. In this case, the switch outputs are used to set the P -register flip-flops as in the following equation:

```
S/P18 = KSP18 PXK
    PXK = PCP4 KSTORK/B + ...
```

c. To select the virtual address of a memory location whose contents are to be displayed if the DISPLAY switch is in the SELECT ADDR position. In this case, the switch outputs are used to set the P -register flip-flops as in the following equation:

```
S/P18= KSP18 PXK
    PXK = PCP4 KDISPLAK/B + ...
```


## 3-319 32 DATA Switches

The 32 DATA switches have outputs KNC0 through KNC31 and KSO through KS31. The KNC terms are true if the corresponding switch is in the 1 or center position and false if the switch is in the 0 position. The KS terms are true if
the corresponding switch is in the 1 position and are false if the switch is in the center or 0 position.

When the single DATA switch is operated, KENTERD/B is true, and, in the appropriate PCP phase, the D-register is loaded according to the 32 DATA switch settings. The logic sequence for these operations is explained in the paragraphs on the DATA ENTER/CLEAR function.

When one of the 32 DATA switches is in the 1 position, the associated KNC and KS signals are both true and the corresponding D-register flip-flop is set. When the switch is in the center position, the KNC signal is true and the KS signal is false, and the corresponding D-register flip-flop remains in its previous state. If the switch is in the 0 position, the KNC and KS signals are both false and the corresponding flip-flop is reset.

## 3-320 PCP Phase Sequencing

The PCP control operations described in the following paragraphs require one or more PCP phase sequences. These phase sequences are controlled by seven flip-flops, PCPI through PCP7. The logic for the PCP phase flip-flops is shown in the PCP phase sequence charts.

3-321 ENTERING PCP PHASES (See figure 3-226.) The PCP phases are entered when signal HALT/1 is true unless a trap or interrupt is active or an Execute instruction is in process.

$$
\begin{aligned}
S / P C P 1= & \text { NPCP3 [HALT/I ENDE } N(S / \text { INTRAPF }) \\
& \text { NFUEXU] }
\end{aligned}
$$

Signal HALT/1 is true whenever the HALT flip-flop is set or when DCSTOP is true. This occurs under the following conditions:
a. The COMPUTE switch is set to IDLE.

$$
\text { S/HALT }=\text { NKRUN/B PREI }+\ldots
$$

b. A Wait instruction has been executed.

```
S/HALT = FUWAIT PHI + ...
```

c. The ADDR STOP switch is set to ON, and the value in the SELECT ADDRESS switches is equal to the address on the memory address bus.

$$
\begin{aligned}
& \text { HALT/1 = DCSTOP } \\
& \text { DCSTOP }=\text { KADDRSTOP MR ADMATCH } \\
& \text { ADMATCH }=(\mathrm{LM} 15 \mathrm{KSP} 15)-(\mathrm{LM} 22 \mathrm{KSP22}) \\
& \text { (LB23 KSP23)-(LB31 KSP31) }
\end{aligned}
$$

d. A trap or an interrupt has occurred, and the instruction taken from the trap or interrupt location is not


Figure 3-226. Entering PCP Phases
a Modify and Test or Exchange Program Status Doubleword instruction.

$$
\mathrm{S} / \mathrm{HALT}=\mathrm{PHI} \text { INTRAPF } \mathrm{N}(\text { FAS7 }+ \text { FAPSD })
$$

e. Dc power is applied to or is removed from the system

```
S/HALT = RESET + ...
    RESET = START + ...
    START = /ST/
```

where /ST/ is a signal received from the power monitor when the power rises above or drops below a specified level.

3-322 COMPUTE SWITCH TO IDLE. When the PCP phases are entered as a result of setting the COMPUTE switch to IDLE, execution of the current instruction is completed as if nothing had happened. During the ENDE phase of the instruction, the next instruction (addressed by the P -register) is read into the $C$-register as usual, and the $P$-register is plus counted to obtain the next instruction address.

The CPU now goes into PRE1, and the instruction in the C-register is executed in the normal manner except that the HALT flip-flop is set in PREl as explained above. During the ENDE phase of this instruction, the $P$-register is not plus counted in the usual manner because this operation is disabled by signal PCPTIDIS:

$$
\begin{aligned}
\text { PCTPI } & =\text { ENDE NPCTPIDIS } \\
\text { PCTPIDIS } & =\text { ENDE }(\text { HALT }+\ldots)(\ldots)
\end{aligned}
$$

(The P -register is plus counted later as explained under STEP or RUN function.)

After the second instruction has been executed, the CPU can no longer go into another execution sequence because the HALT flip-flop is set.

```
S/PREI = ENDE (NHALT
    + FUEXU) N(S/INTRAPF)
```

Instead, phase PCP1 is entered

$$
\begin{aligned}
\mathrm{S} / \mathrm{PCPI}= & {[\mathrm{ENDE} \text { HALT/1 } \mathrm{N}(\mathrm{~S} / \text { INTRAPF }) \text { NFUEXU }] } \\
& \text { NPCP3 }
\end{aligned}
$$

followed by PCP2

```
S/PCP2 = (PCP1 NCLEAR + ...) NPCP3
```

The LOAD button is pressed when the program is in PCP2 and when one of the six control switches on the lower righthand side of the panel is operated. The computer advances to PCP3 when the CPU RESET/CLEAR and SYS RESET/CLEAR buttons are pressed simultaneously.

```
S/PCP3 = NPCP3 (PCP2 NHALT/1 NCLEAR
    KAS/1 KAS/2)
    + PCP2 NHALT/1 NCLEAR CLEARMEM
```

The PCP phase sequencing following PCP2 is described under the functions of the various control switches.

3-323 DCSTOP. If the CPU has been halted because of an ADMATCH signal when the ADDR STOP switch is on, the DCSTOP signal is latched by KRUN if the CONTROL MODE switch is in the LOCAL position, or by KSLOW if the CONTROL MODE switch is in the REMOTE position.

DCSTOP $\quad=$ DCSTOP DCSTOP $/ H$

+ KADDRSTOP MR ADMATCH

$$
\text { DCSTOP } / H=\text { NRESET }(K R U N+K S L O W)
$$

The CPU waits in PCP2 until the COMPUTE switch is moved from RUN to IDLE to STEP and back to RUN. When the free-standing console controls the PCP (PCP CONTROL MODE switch in REMOTE), the address match function operates only when the free-standing console is in SLOW.

## 3-324 POWER ON OR POWER OFF SEQUENCE. (See

 figure 3-227.) When the CPU enters the PCP phases as the result of application or removal of power, signal PON or lOFF forces an interrupt. In the case of power on, the /ST/ signal is received immediately from the power monitor, which generates a reset and forces the computer into PCP2.```
S/PCP2 = (RESET + ...) NPCP3
```

The RESET signal also disarms and disables all interrupts except the power interrupts and forces zeros into PSW1, PSW2,
and other control flip-flops, the D-register, and Q-register. The PON interrupt signal is received from the power monitor, and /ST/drops. This drives signal RESET low, allowing flip-flop HALT to be reset and PCP3 to be entered if the COMPUTE switch is in RUN (KAS/1 and KAS/2). The sequence goes through PCP4 to PCP5, and ENDE goes true, allowing flip-flop INTRAPF to be set and an interrupt sequence to be entered.

```
ENDE == PCP5 NKIDLE/B
    NKIDLE/B = KRUN + KSTEP
S/INTRAPF = NRESET (INT ENDE NINTRAPF
    NINTEN KRUN/B + ...)
```

In the case of power off, the interrupt sequence is entered as a result of signal IOFF from the power monitor, and is allowed from 5 to 20 milliseconds (adjustable in the power monitor) before signal /ST/ is generated. The CPU then goes to PCP2 as described above.

When the PCP phases are entered, flip-flop BWZ is reset by the CLEAR signal to permit the next instruction address in the $P$-register to be transferred to the $Q$-register in PCPI.

```
QXP = PCP1 NBWZ (...)
```

Any PCP operation that subsequently sequences through PCP7 causes BWZ to be set to prevent the $P$ - to $Q$-register transfer in any PCP1 phase except the first.

## 3-325 RESET FUNCTION (See figure 3-228.) Signal RESET

 is true if:a. The CPU RESET/CLEAR switch is pressed in PCP2
b. The SYS RESET/CLEAR switch is pressed in PCP2
c. Signal START is true

In cases $a$ and $b$ above, the COMPUTE switch must first be set to the IDLE state in order to put the computer in PCP2. The RESET signal generated by either of the two resetswitches is enabled by NKAS/B, which cannot be true with the COMPUTE switch in RUN; therefore, the reset switches do not affect the current operations of the CPU when in the run state. Signal START, however, causes a reset without placing the computer in the idle state.

The logical sequence of a reset operation when either the CPU RESET/CLEAR or the SYS RESET/CLEAR switch is pressed is shown in table 3-141.

3-326 COMPUTE STEP OR RUN FUNCTION (See figure 3-229.) When the CPU is waiting in PCP2 because the COMPUTE switch is in IDLE, setting the switch to STEP or to RUN causes the CPU to sequence to PCP3, PCP4, and PCP5. In PCP5, signal ENDE is forced true, all normal ENDE functions are performed, and the program branches


Figure 3-227. Power On or Power Off, Sequence Flow Diagram

Table 3-141. RESET Function, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Switch outputs <br> CPU RESET/CLEAR $\Rightarrow$ <br> SYS RESET/CLEAR $\Rightarrow$ <br> COMPUTE in IDLE $\Rightarrow$ <br> Power On or Off $\Rightarrow$ | KCPURESET, KCPURESET/B <br> KSYSR, KSYSR/B <br> NKAS/B, NKRUN (necessary for operation of either reset switch <br> START |  |
| $\begin{aligned} & \text { PCP2 } \\ & \text { or } \\ & \text { START } \end{aligned}$ | Idle phase - sustained until control switch operated <br> Generate RESET <br> Set HALT flip-flop <br> Disarm and disable all interrupts except power on and power off <br> Unlatch interrupt group active signals |  | Interrupt reset enable <br> Interrupt control flipflops <br> Interrupt level arm flipflop <br> Interrupt set - reset flip-flop <br> Interrupt phase flip-flop <br> CPURSET drops latch |
|  |  | (Continued) | Mnemonic: RESET |

Table 3-141. RESET Function, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\left\|\begin{array}{c} \text { PCP2 } \\ \text { or } \\ \text { START } \\ \text { (Cont.) } \end{array}\right\|$ | $0 \rightarrow$ PSWI <br> $0 \rightarrow$ PSW2 <br> $0 \rightarrow P$-register <br> Reset control flip-flops <br> Index <br> Alarm <br> Analyze <br> $B$ is zero <br> Map disconnect <br> Memory request <br> Switch flip-flops <br> Trap <br> Trap condition code flip-flops <br> Reset HALT when switch is released <br> KSYSR $\Rightarrow$ Reset I/O <br> If reset by switches (RESET/B true) X'02000000 $\longrightarrow$ D <br> $X^{\prime} 25^{\prime} \rightarrow Q$ <br> If start $0>Q$ <br> Reset memory fault indicators <br> If KSYSR or /ST/, reset memory control signals to initial state via interface cables /MRS/ or /ST/ |  | Clear program status doubleword |



Figure 3-228. CPU RESET/CLEAR and SYS RESET/CLEAR, Sequence Flow Diagram
to PREI. If the COMPUTE switch is in STEP, the HALT flip-flop is set in PREI. At the end of instruction execution, the CPU returns to PCP1 and then to PCP2, the idle phase. If the COMPUTE switch is in RUN, the HALT flipflop is not set, and the program resumes its normal sequence. The logic for the STEP and RUN functions is given in table 3-142.

3-327 INSERT FUNCTION (See figure 3-230). In the idle state, if the INSERT switch is set to PSWI, program status doubleword PSW1 is altered according to the settings of the DATA switches. If the INSERT switch is set to PSW2, program status doubleword PSW2 is altered according to the settings of the DATA switches. The entire program status doubleword is first transferred to the D-register so that in PCP5 the DATA switches can alter either the entire doubleword or only a portion of the word. In the 1 or 0 positions, the switches change the corresponding bit of the program status doubleword. In the center position, the switches cause the previous state of the PSW bit to be entered in the doubleword by transferring the corresponding bit in the

D-register to PSW1 or PSW2. The next instruction in the D-register is saved in the A-register and is returned to the D-register in PCP7. A sequence chart of the INSERT function is shown in table 3-143.

3-328 DATA ENTER/CLEAR FUNCTION (See figure 3-231). When the DATA switch is set to ENTER, the states of the 32 DATA switches are transferred to the D-register and are displayed in the 32 DISPLAY indicators. A switch in the up position places a one in the corresponding D -register bit. A switch in the down position enters a zero. A switch in the center position retains the previous D-register bit. The contents of the D-register are accepted as the next instruction to be executed after data has been transferred from the DATA switches into the D-register and the COMPUTE switch is set to either RUN or STEP. When the DATA switch is set to CLEAR, zeros are placed in the D-register.

A sequence chart of the ENTER/CLEAR function is given in table 3-144.

## 3-329 STORE INSTR ADDR/SELECT ADDR FUNCTION

(See figure 3-232). The STORE switch is operative only while the CPU is in the idle state. When the STORE switch is set to INSTR ADDR, the contents of the D-register are stored in the virtual memory address currently in the Qregister and are moved to the $P$-register for memory addressing. When the STORE switch is set to SELECT ADDR, the contents of the $D$-register are stored in the virtual address specified by setting the 17 SELECT ADDRESS switches.

A sequence chart of the store function is shown in table 3-145.
3-330 DISPLAYY INSTR ADDR/SELECT ADDR FUNCTION (See figure 3-233). If the DISPLAY switch is set to INSTR ADDR in the idle phase, the CPU reads into the D-register the contents of the memory location pointed to by the Qregister, which is moved to the P -register for memory addressing. If the DISPLAY switch is set to SELECT ADDR in the idle phase, the CPU reads into the D-register the contents of the memory location whose value is equal to the contents of the 17 SELECT ADDRESS switches. The data read from memory is displayed in the 32 DISPLAY indicators.

A sequence chart of the DISPLAY INSTR ADDR/SELECT ADDR function is shown in table 3-146.

If the SELECT ADDR switch has been operated, the $C$-register and the D-register contain the contents of the selected location at the end of the PCP phases. In order to return the current instruction to the $C$ - and D-registers for execution, the DISPLAY switch must be momentarily placed in the INSTR ADDR position.

3-331 INSTR ADDR HOLD/INCREMENT FUNCTION (See figure 3-234). The HOLD position of the INSTR ADDR switch in itself does not take the program into the PCP phases. When the COMPUTE switch is placed in the RUN or STEP position and when the INSTR ADDR switch is in the HOLD


Figure 3-229. PCP Sequence Beyond Wait State

Table 3-142. STEP, RUN Function, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Switch outputs <br> COMPUTE RUN $\Rightarrow$ <br> COMPUTE STEP $\Rightarrow$ <br> Either position $\Rightarrow$ | KRUN/B KSTEP/B KAS/1, KAS/2 |  |
| $\begin{aligned} & \text { PCP2 } \\ & \text { T6L } \end{aligned}$ | Idle phase <br> Set flip-flop PCP3 | $\begin{aligned} \mathrm{S} / \mathrm{PCP} 3= & \mathrm{PCP} 2 \text { NHALT NCLEAR } \\ & \text { KAS } / 1 \text { KAS } / 2 \text { NPCP3 } \end{aligned}$ | Go to PCP phase 3 |
| $\begin{aligned} & \mathrm{PCP3} \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | One clock long (Q15-Q31) $\longrightarrow$ (P15-P31) <br> Set latch CXS <br> Set flip-flop PCP4 <br> Reset flip-flop PCP2 <br> Reset flip-flop PCP3 | R/PCP2 $=$ PCP3 <br> PXQ $=P C P 3+\ldots$ <br> CXS $=$ PCP3 NKIDLE $/ B+\ldots$ <br> S/PCP4 $=P C P 3$ (NPCP7 NENDE) <br> $R / P C P 2$ $=P C P 3$ <br> $R / P C P 3$ $=\ldots$ | Program address into P-register <br> Prepare for $S \longrightarrow C$ in PCP4 <br> Go to PCP phase 4 |
| $\begin{aligned} & \mathrm{PCP4} \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | $\begin{aligned} & \text { D0-D31 } \longrightarrow \text { S0-S31 } \\ & \text { S0-S31 } \longrightarrow \text { C0-C31 } \\ & \text { Set flip-flop PCP5 } \\ & \text { Reset flip-flop PCP4 } \end{aligned}$ | $\begin{array}{ll} \text { CXS set in PCP3 } \\ & \\ \text { SXD } & =\text { PCP4 } \text { NKIDLE/B }+\ldots \\ \text { S/PCP5 } & =\text { PCP4 NPCP7 NENDE } \\ \text { R/PCP4 } & =\ldots \end{array}$ | Next instruction into C-register <br> Go to PCP phase 5 |
| $\left\lvert\, \begin{aligned} & \text { PCP5 } \\ & \text { T6L } \end{aligned}\right.$ | Force ENDE $P+1 \nrightarrow P$ | $\begin{aligned} \text { ENDE } & =\text { PCP5 NKIDLE } / B+\ldots \\ \text { PCTPI } & =\text { ENDE NPCTPIDIS } \\ \text { PCTPIDIS } & =\text { ENDE (HALT }+\ldots)(\ldots) \end{aligned}$ | Simulate end of instruction execution to prepare for PREI of next instruc tion <br> Add one to program address in P -register. Inhibited by HALT in PH1O of last instruction execution |
|  |  |  | Mnemonic: STEP, RUN |

Table 3-142. STEP, RUN Function, Phase Sequence (Cont.)



901060B. 3711

Figure 3-230. INSERT Function, Sequence Flow Diagram
position, signal NKAHOLD is false, PCPTIDIS is true, and upcounting of the $P$-register is inhibited during the ENDE
phase of any instruction that is being executed. The equations are as follows:

$$
\begin{aligned}
\text { PCTPIDIS } & =\text { ENDE }[\text { N }(N K A H O L D)+\ldots] \\
\text { PCTPI } & =\text { NPCTPIDIS }(\text { PCTPI }+ \text { ENDE })
\end{aligned}
$$

With the COMPUTE switch in RUN, the CPU repeatedly executes the instruction addressed by the $Q$-register and does not sequence to the next instruction.

With the COMPUTE switch in IDLE, moving the INSTRADDR switch to INCREMENT causes the current instruction address to be counted up by one and the contents of this updated address to be displayed in the DISPLAY indicators. Thus, the operator can display the contents of sequential memory locations by repeatedly moving the INSTR ADDR switch to INCREMENT.

A sequence chart of the INCREMENT function is given in table 3-147.

3-332 CLEAR MEMORY FUNCTION (See figure 3-235). When the CPU RESET/CLEAR and SYS RESET/CLEAR switche: are closed simultaneously with the COMPUTE switch in IDLE, signal CLEARMEM is true, and all core memory locations are cleared to zero.

When CLEARMEM is true, crossover is inhibited; therefore, core memory locations $X^{\prime} 0^{\prime}$ through $X^{\prime} 15$ ' are cleared, and scratch pad memory is not affected. Since one of the two clear switches closes before the other, a memory clear operation is always preceded by a reset operation, which ensures that no memory mapping can occur while memory is being cleared.

The clearing process takes place in PCP6, which is repeated until the CLEARMEM signal is no longer true. The sum bus contents, containing zeros, are transferred to the memory bus lines each PCP6. The contents of the P-register, which are being increased by one with each repetition of PCP6, are placed on the memory address lines so that each memory location in succession is cleared.

A sequence chart of the clear memory function is shown in table 3-148.

3-333 LOAD FUNCTION (See figure 3-236). If the LOAD pushbutton is pressed with the COMPUTE switch in the IDLE position, signal KFILL/B goes true, and the CPU goes into the PCP phases. The CPU forces a bootstrap program into core memory locations $X^{\prime} 20^{\prime}$ through $X^{\prime} 29$ ' by placing the decoded outputs of the $P$-register onto the sum bus and by writing into memory.

A sequence chart of the LOAD function is shown in table 3-149.
The bootstrap programand its function is shown in table 3-150. Execution of the bootstrap program starts at location 26.

Table 3-143. INSERT Function, Phase Sequence


Table 3-143. INSERTFunction, Phase Sequence (Cont.)


Table 3-143. INSERT Function, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PCP5 <br> T6L <br> (Cont.) | Set flip-flop PCP7 | $\begin{aligned} \text { S/PCP7 } & =(S / P C P 7) \text { NPCP7 NENDE } \\ (S / P C P 7)= & \text { PCP6 NCLEARMEM NKFILL/B } \\ & +\ldots \end{aligned}$ | Go to preparation phase 7 |
| PCP7 | One clock long $\begin{aligned} & \mathrm{A} 0-\mathrm{A} 31 \longrightarrow \mathrm{~S} 0-\mathrm{S} 31 \\ & \mathrm{~S} 0-\mathrm{S} 31 \longrightarrow \mathrm{C} 1 \longrightarrow-\mathrm{C} 31 \\ & \mathrm{C} 0-\mathrm{C} 31 \rightarrow \mathrm{D} 0-\mathrm{D} 31 \\ & \mathrm{P} 15-\mathrm{P} 31 \rightarrow \mathrm{Q} 15-\mathrm{Q} 31 \end{aligned}$ <br> Set flip-flop PCP 1 <br> Reset flip-flop PCP6 | $\begin{array}{ll} \text { SXA } & =\text { PCP7 KPSW } / B+\ldots \\ \text { CXS set in PCP6 } \\ \text { DXC } & =\text { PCP7 KPSW } / B+\ldots \\ \text { QXP } & =\text { PCP7 KPSW } / B+\ldots \\ \text { S/PCP1 } & =(P C P 7+\ldots) \text { NPCP3 } \\ \text { R/PCP6 } & =P C P 7+\ldots \end{array}$ | Return current instruction to C - and D-registers <br> Place new program address in Q-register <br> Go to preparation phase 1 |
| PCP1 | One clock long <br> Set HALT flip-flop <br> Set flip-flop PCP2 <br> Reset flip-flop PCPI | $\begin{aligned} S / \text { HALT }= & \text { PCP1 NPCP3 }+\ldots \\ S / P C P 2 & = \\ & (P C P 1 ~ N C L E A R+\ldots) \\ & \text { NPCP3 } \\ R / P C P 1 & \ldots \end{aligned}$ | Halt computer <br> Go to idle phase |
|  |  |  | Mnemonic: INSERT |



Figure 3-231. DATA ENTER/CLEAR, Sequence Flow Diagram

Address $X^{\prime} 25$ 'is placed in the $Q$-register when the SYS RESET/CLEAR switch is activated (see Reset Function). When the COMPUTE switch is set to RUN, this address is transferred to the P -register in PCP3 (see STEP, RUN Function). During PCP5, the ENDE signal forces $P+1 \longrightarrow P$, allowing location 26 to be addressed for the bootstrap program. The instruction executed after PCP5 is meaningless because nothing is in the C - or D-register.

## 3-334 Indicators

The PCP indicators, their designators, function, and associated lamp driver signals are listed in tables 2-1 and 2-2. The inputs to most of the lamp drivers are the outputs of CPU flip-flops. However, in some cases, gating is used to energize the lamp drivers, as explained in the paragraphs
below. The operation of the indicators in the POWER and the INTERRUPT switches is explained in the descriptions of these switches.

3-335 DISPLAY INDICATORS. The DISPLAY indicator lamp drivers, $S 0 /$ through $S 31 / L$, contain information that is gated onto the sum bus. The sum bus outputs are selected according to the state of signals KSHI and KSXE, as explained in the paragraphs on the REGISTER DISPLAY and the REGISTER SELECT switches.

3-336 NORMAL MODE INDICATOR. (See figure 3-237.) The NORMAL MODE indicator lights when the memory logic power margins are normal and when the following switches are in the positions indicated:

| WATCHDOG TIMER | NORMAL |
| :--- | :--- |
| INTERLEAVE SELECT | NORMAL |
| PARITY ERROR MODE | CONT |
| CLOCK MODE | CONT |

Under these conditions, with the CONTROL MODE switch in LOCAL, the MARGINS NORMAL input to the AND gate is true and the -8 local voltage cannot be connected to the second AND gate input. Therefore, the inverted output of the AND gate is low, and current flows through the indicator. With the CONTROL MODE switch in LOCK and with the MARGINS NORMAL input true, the lamp is unconditionally lighted because the switch input to the AND gate cannot be false.

3-337 RUN INDICATOR. The RUN indicator lamp driver signal, RUN/L, is true as a result of signal RUNLITE, whose equation is

$$
\text { RUNLITE }=\text { KRUN } / \mathrm{B} \text { NHALT } / 1
$$

where KRUN/B indicates that the COMPUTE switch is in the RUN position and where NHALT/l indicates that the HALT flip-flop is reset and that signal DCSTOP is false.

3-338 WAIT INDICATOR. The WAIT indicator receives a lamp driver output WAIT/L, which is true if HALT/1 is true, indicating that the halt flip-flop is set or that signal DCSTOP is true (ADDR STOP switch is set to ON and SELECT ADDRESS is located).

Table 3-144. DATA ENTER/CLEAR, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Switch outputs <br> DATA ENTER $\Rightarrow$ KENTER D $/$ B <br> DATA CLEAR $\Rightarrow$ KCLEAR D/B <br> Either position $\Rightarrow$ KAS/1, KAS/2 <br> DATA switches up $\Rightarrow$ KNC0-KNC31, <br> KSO-KS31 <br> DATA switches center $\Rightarrow$ KNCO- <br> KNC31 |  |  |
| PCP2 | Idle phase <br> Set flip-flop PCP3 | $\begin{aligned} S / P C P 3= & \text { PCP2 NHALT KAS } / 1 \text { KAS } / 2 \\ & \text { NPCP3 }+\ldots \end{aligned}$ | Go to PCP phase 3 |
| $\begin{aligned} & \text { PCP3 } \\ & \text { T6L } \end{aligned}$ | One clock long $\text { Q15-Q31 } \leftrightarrows \text { P15-P31 }$ <br> Set flip-flop PCP4 <br> Reset flip-flop PCP2 | $\begin{array}{ll} \text { PXQ } & =\text { PCP3 }+\ldots \\ \text { S/PCP4 } & =\text { PCP3 NPCP7 NENDE } \\ \text { R/PCP2 } & =\text { PCP3 } \end{array}$ | Program address into P -register <br> Go to PCP phase 4 |
| $\begin{aligned} & \text { PCP4 } \\ & \text { T6L } \end{aligned}$ | One clock long $\text { KCLEARD } / B \Rightarrow 0 \nrightarrow D$ <br> KENTERD/B $\Rightarrow$ <br> Data switches $\longrightarrow$ D <br> Set flip-flop PCP5 <br> Reset flip-flop PCP4 | $\begin{aligned} \text { DX }= & \text { PCP4 KCLEARD } / B+\ldots \\ \text { DXK }= & \text { PCP4 KENTRD } / B+\ldots \\ \text { S/D0-D31 }= & \text { KS0-KS31 DXK } \\ & + \text { D0-D31 KNC0-KNC31 DXK } \\ & +\ldots \\ \text { R/D0-D31 }= & \text { DXK } \\ \text { S/PCP5 }= & \text { PCP4 NPCP7 NENDE } \\ \text { R/PCP4 }= & \ldots \end{aligned}$ | Clear D-register <br> Transfer information from DATA switches into Dregister <br> Up position transfers ones down position transfers zeros; center position retains $D$-register bit <br> Go to PCP phase 5 |
| $\begin{aligned} & \text { PCP5 } \\ & \text { T6L } \end{aligned}$ | One clock long <br> Set flip-flop PCP6 <br> Reset flip-flop PCP5 | $\begin{aligned} \text { S/PCP6 } & =\text { PCP5 NPCP7 NENDE } \\ \text { R/PCP5 } & =\ldots \end{aligned}$ | Go to PCP phase 6 |
|  |  | (Continued) | Mnemonic: DATA ENTER/CLEAR |

Table 3-144. DATA ENTER/CLEAR, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PCP6 } \\ & \text { T6L } \end{aligned}$ | One clock long <br> Set flip-flop PCP7 | $\begin{aligned} \text { S/PCP7 }= & \text { PCP6 NCLEARMEM NKFILL/B } \\ & +\ldots\end{aligned}$ | Go to PCP phase 7 |
| $\left\lvert\, \begin{aligned} & \text { PCP7 } \\ & \text { T6L } \end{aligned}\right.$ | One clock long <br> Set flip-flop BWZ <br> Set flip-flop PCPI <br> Reset flip-flop PCP6 <br> Rese flip-flop PCP7 | $\begin{aligned} \mathrm{S} / \mathrm{BWZ} & =\mathrm{PCP7}+\ldots \\ \mathrm{S} / \mathrm{PCP} & =(\mathrm{PCP7}+\ldots) \mathrm{NPCP} 3 \\ \mathrm{R} / \mathrm{PCP} 6 & =\mathrm{PCP7}+\ldots \\ \mathrm{R} / \mathrm{PCP7} & =\ldots \end{aligned}$ | Prevent $P \longrightarrow Q$ transfer in PCP1 <br> Go to preparation phase 1 |
| $\begin{aligned} & \text { PCP1 } \\ & \text { T6L } \end{aligned}$ | Set HALT flip-flop Set flip-flop PCP2 Reset flip-flop PCPI | $\begin{aligned} \mathrm{S} / \mathrm{HALT} & =\mathrm{PCP} 1 \mathrm{NPCP} 3+\ldots \\ \mathrm{S} / \mathrm{PCP} 2 & =(\mathrm{PCP} 1 \mathrm{NCLEAR}+\ldots) \mathrm{NPCP} 3 \\ \mathrm{R} / \mathrm{PCP} 1 & =\ldots \end{aligned}$ | Go to PCP phase 2 |
| PCP2 | Idle phase $\text { D0-D31 } \longrightarrow \text { S0-S31 }$ <br> S0-S31 $\longrightarrow$ display indicators | $\text { SXD }=\text { PCP2 NRESET/F NSDIS }$ $\text { SOL-S3IL }=\text { S0-S3I NKSHI }$ | Display contents of D-register |
|  |  |  | Mnemonic: DATA ENTER/CLEAR |



Figure 3-232. STORE INSTR ADDR/SELECT ADDR, Sequence Flow Diagram


Figure 3-233. DISPLAY INSTR ADDR/SELECT ADDR, Sequence Flow Diagram

Table 3-145. STORE INSTR ADDR/SELECT ADDR, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Switch outputs <br> STORE SELECT ADDR $\Rightarrow$ KSTOR K/B <br> STORE INSTR ADDR $\Rightarrow$ KSTORQ/B <br> Either position $\Rightarrow K A S / 1, K A S / 2$, KSTOR/B |  |  |
| $\begin{aligned} & \text { PCP2 } \\ & \text { T6L } \end{aligned}$ | Idle phase <br> Set flip-flop PCP3 | $\begin{aligned} S / P C P 3= & P C P 2 \text { NHALT KAS } / 1, \mathrm{KAS} / 2 \\ & \text { NPCP3 } \end{aligned}$ | Go to PCP phase 3 |
| $\begin{aligned} & \text { PCP3 } \\ & \text { T6L } \end{aligned}$ | One clock long $\text { Q15-Q31 } \rightarrow P 0-P 31$ <br> Set flip-flop PCP4 <br> Reset flip-flop PCP2 | $\begin{array}{ll} \text { PXQ } & =\text { PCP3 }+\ldots \\ \text { S/PCP4 } & =\text { PCP3 NPCP7 NENDE } \\ \text { R/PCP2 } & =\text { PCP3 } \end{array}$ | Transfer INSTRUCTION ADDRESS indicator contents to P -register <br> Go to PCP phase 4 |
| $\begin{aligned} & \text { PCP4 } \\ & \text { T6L } \end{aligned}$ | One clock long <br> KSTORK $/ B \Rightarrow$ $\text { KSP15-KSP31 } \rightarrow \text { P15-P31 }$ <br> Set flip-flop DRQ <br> Generator memory request <br> Set flip-flop PCP5 <br> Reset flip-flop PCP4 | $\begin{array}{ll} \text { PXK } & =\text { PCP4 KSTORK/B }+\ldots \\ \text { S/P0-P31 } & =\text { PXK KSP15 KSP3I } \\ \text { S/DRQ } & =\text { PCP4 KSTOR/B } \\ & =\text { PCP (S/DRQ) } \\ \text { MRQ } & \\ S / P C P 5 & =P C P 4 \text { NENDE NPCP7 } \\ R / P C P 4 & =\ldots \end{array}$ | Place SELECT ADDRESS switch outputs in Pregister <br> Inhibits clock until data release signal received from memory <br> Request memory cycle to store D-register data <br> Go to PCP phase 5 |
| $\begin{aligned} & \text { PCP5 } \\ & \text { DR } \end{aligned}$ | Sustained until data release <br> Inhibit memory protection | PROTD = FAILD NPCP4 NPCP6 |  |
| (Continued) |  |  | Mnemonic: STORE |

Table 3-145. STORE INSTR ADDR/SELECT ADDR, Phase Sequence (Cont.)


Table 3-146. DISPLAY INSTR ADDR/SELECT ADDR, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Switch outputs <br> DISPLAY SELECT ADDR $\Rightarrow$ KDISPLAK/B <br> DISPLAY INSTR ADDR $\Longrightarrow$ KDISPLAQ/B <br> Either position $\Rightarrow \mathrm{KAS} / 1, \mathrm{KAS} / 2$ KDISPLA/B |  |  |
| PCP2 | Idle phase <br> Set flip-flop PCP3 | $\begin{aligned} S / P C P 3= & \text { PCP2 NHALT NCLEAR KAS } / 1 \\ & \text { KAS } / 2 \text { NPCP3 } \end{aligned}$ | Go to PCP phase 3 |
| $\begin{aligned} & \text { PCP3 } \\ & \text { T6L } \end{aligned}$ | One clock long $\text { Q15-Q31 } \longrightarrow \text { P13-P31 }$ <br> Set flip-flop PCP4 <br> Reset flip-flop PCP2 <br> Rese fflip-flop PCP3 | $\begin{array}{ll} \text { PXQ } & =\text { PCP3 }+\ldots \\ \text { S/PCP4 } & =\text { PCP3 NENDE NPCP7 } \\ \text { R/PCP2 } & =\text { PCP3 } \\ \text { R/PCP3 } & =\ldots \end{array}$ | Program address into P-register <br> Go to PCP phase 4 |
| PCP4 <br> T6L | One clock long <br> KDISPLAK $/ B \Rightarrow$ <br> KSP15-KSP31 $\rightarrow$ P15-P31 <br> Set flip-flop DRQ <br> Generate memory request <br> Set flip-flop PCP5 <br> Reset flip-flop PCP4 | $\begin{array}{ll} \text { PXK } & =\text { PCP4 KDISPLAK } / B+\ldots \\ \text { S/P15-P31 } & =\text { KSP15-KSP31 PXK }+\ldots \\ \text { S/DRQ } & =\text { PCP4 KDISPLA/B } \\ \text { MRQ } & =\text { PCP (S/DRQ }) \\ \text { S/PCP5 } & =\text { PCP4 NENDE NPCP7 } \\ \text { R/PCP4 } & =\ldots \end{array}$ | Contents of SELECT <br> ADDRESS switches $\qquad$ P -register <br> Inhibits clock until data release signal received from memory <br> Request memory cycle for data to display <br> Go to PCP phase 5 |
|  |  |  | Mnemonic: DISPLAY |

Table 3-146. DISPLAY INSTR ADDR/SELECT ADDR, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PCP5 <br> T6L <br> DR | Sustained until data release <br> Inhibit memory protection <br> P15-P31 $\longrightarrow$ LB15-LB31 <br> MB0-MB31 $\longrightarrow \mathrm{C} 0-\mathrm{C} 31$ $\mathrm{C} 0-\mathrm{C} 31 \rightarrow \text { D0-D31 }$ <br> Set flip-flop PCP6 <br> Reset flip-flop PCP5 | $\begin{array}{ll} \text { PROTD } & =\text { FAILD NPCP5 NPCP6 } \\ \text { LB15-LB31 } & =\text { P15-P31 NCMXQ NLMXC } \\ & =\text { DGC } \\ \text { CXMB } & \\ \text { DXC } & \\ \text { PCP5 KDISPLA/B } \\ \text { S/PCP6 } & =\text { PCP5 NENDE NPCP7 } \\ \text { R/PCP5 } & =\ldots \end{array}$ | Addressed from Pregister, which received Q-register contents in PCP3 <br> Display data gated into C- and D-registers when data gate signal received from memory. If KDISPLAK/B, location is contents of SELECT ADDRESS switches; if KDISPLAQ/B, location is contents of Q -register, either one now in P register <br> Go to PCP phase 6 |
| $\begin{aligned} & \text { PCP6 } \\ & \text { T6L } \end{aligned}$ | One clock long <br> Set flip-flop PCP7 | S/PCP7 = PCP6 NCLEARMEM NKFILL/B | Go to PCP phase 7 |
| $\begin{array}{\|l\|l\|} \hline \text { PCP7 } \\ \text { T6L } \end{array}$ | One clock long <br> Set flip-flop PCP1 <br> Reset flip-flop PCP6 <br> Reset flip-flop PCP7 | $\begin{aligned} \text { S/PCP1 } & =(P C P 7+\ldots) \text { NPCP3 } \\ \text { R/PCP6 } & =P C P 7+\ldots \\ \text { R/PCP7 } & =\ldots \end{aligned}$ | Go to PCP phase 1 |
| $\left\lvert\, \begin{gathered} \mathrm{PCPI} \\ \mathrm{~T} 6 \mathrm{~L} \end{gathered}\right.$ | One clock long <br> Set HALT flip-flop <br> Set flip-flop PCP2 <br> Reset flip-flop PCPI | $\begin{aligned} S / H A L T & =P C P 1 \text { NPCP3 }+\ldots \\ S / P C P 2 & =(P C P 1 \text { NCLEAR }+\ldots) \text { NPCP3 } \\ \text { R/PCP1 } & =\ldots \end{aligned}$ | Go to PCP phase 2 |
| PCP2 | Idle phase <br> D0-D31 $\longrightarrow$ display indicators | SXD = PCP2 NRESET NSDIS | Display D-register contents |
|  |  |  | Mnemonic: DISPLAY |



Figure 3-234. INSIR ADDR INCREMENT, Sequence Flow Diagram


Figure 3-235. CLEARMEM Function, Sequence Flow Diagram

Table 3-147. INSTR ADDR INCREMENT, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Switch outputs <br> INCREMENT $\Rightarrow$ KINCRE/B, KAS/1, KAS/2 <br> Center or INCREMENT $\Rightarrow$ <br> NKAHOLD |  |  |
| PCP2 <br> T6L | Idle phase <br> Set flip-flop PCP3 | $\begin{aligned} \mathrm{S} / \mathrm{PCP} 3= & \mathrm{PCP2} \text { NHALT KAS } / 1 \mathrm{KAS} / 2 \\ & \text { NPCP3 } \end{aligned}$ | Go to PCP phase 3 |
| PCP3 <br> T6L | One clock long $\text { Q15-Q31 } \rightarrow \text { P15-P31 }$ <br> Set flip-flop PCP4 <br> Reset flip-flop PCP2 <br> Reset flip-flop PCP3 | $\begin{aligned} \mathrm{PXQ} & =\mathrm{PCP3}+\ldots \\ \mathrm{S} / \mathrm{PCP} 4 & =\text { PCP3 NENDE NPCP7 } \\ \mathrm{R} / \mathrm{PCP} 2 & =\mathrm{PCP3} \\ \mathrm{R} / \mathrm{PCP} 3 & =\ldots \end{aligned}$ | Program address into P-register <br> Go to PCP phase 4 |
| PCP4 <br> T6L | One clock long $P+1 \longrightarrow P$ <br> Set flip-flop DRQ <br> Generate memory request <br> Set flip-flop PCP5 <br> Reset flip-flop PCP4 | $\begin{aligned} \mathrm{PCTPI} & =\mathrm{PCP} 4 \mathrm{KINCRE} / \mathrm{B}+\ldots \\ \mathrm{S} / \mathrm{DRQ} & =\mathrm{PCP} 4 \mathrm{KINCRE} / \mathrm{B}+\ldots \\ \mathrm{MRQ} & =\mathrm{PCP}(\mathrm{~S} / \mathrm{DRQ})+\ldots \\ \mathrm{PCP} & =P C P 4+\ldots \\ \mathrm{S} / \mathrm{PCP5} & =P C P 4 \text { NENDE NPCP7 } \\ R / P C P 4 & =\ldots \end{aligned}$ | Plus count the P -register by one <br> Inhibits clock until data release received from memory <br> Request contents of P -register address from memory <br> Go to PCP phase 5 |
| $\begin{aligned} & \text { PCP5 } \\ & \text { T6L } \end{aligned}$ | One clock long $\text { P15-P31 } \leftrightarrows \text { Q15-Q31 }$ | QXP = PC55 KINCRE/B | Return upcounted address to Q-register |
|  |  | (Continued) | Mnemonic: INSTR ADDR |

Table 3-147. INSTR ADDR INCREMENT, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PCP5 T6L (Cont.) | $\begin{gathered} \text { MBO-MB31 } \longrightarrow \mathrm{C} 0-\mathrm{C} 31 \\ \cdots \\ \mathrm{C} 0-\mathrm{C} 31 \longrightarrow \text { D0-D31 } \end{gathered}$ <br> Inhibit memory protection <br> Set flip-flop PCP6 <br> Reset flip-flop PCP5 | $\begin{array}{ll} \text { CXMB } & =\text { DGC } \\ \text { DXC } & =\text { PCP5 KINCRE/B } \\ \text { PROTD } & =\text { FAILD NPCP5 } \\ \text { S/PCP6 } & =\text { PCP5 NENDE NPCP7 } \\ \text { R/PCP5 } & =\ldots \end{array}$ | Data gated into Cregister from memory bus when data gate signal received from memory <br> Clock data into Dregister <br> Go to PCP phase 6 |
| \|PCP6 | One clock long <br> Reset latch AHCL <br> Set flip-flop PCP7 | $\begin{array}{ll} \mathrm{AHCL} & =\mathrm{N}(\text { NAHCL }) \\ \mathrm{NAHCL} & =(\text { PCP6 }+\ldots)(\ldots) \\ \mathrm{S} / \mathrm{PCP7} & =\text { PCP6 NCLEARMEM NKFILL/B } \end{array}$ | Memory address clock <br> Go to PCP phase 7 |
| $\begin{aligned} & \text { PCP7 } \\ & \text { T6L } \end{aligned}$ | One clock long <br> Set flip-flop PCP 1 <br> Reset flip-flop PCP6 <br> Reset flip-flop PCP7 | $\begin{aligned} \mathrm{S} / \mathrm{PCP1} & =(P C P 7+\ldots) \mathrm{NPCP} 3 \\ \mathrm{R} / \mathrm{PCP} 6 & =\mathrm{PCP7}+\ldots \\ \mathrm{R} / \mathrm{PCP} 7 & =\ldots \end{aligned}$ | Go to PCP phase 1 |
| PCPI | One clock long <br> Set HALT flip-flop <br> Set flip-flop PCP2 <br> Reset flip-flop PCPI | $\begin{aligned} S / \text { HALT } & =\text { PCP1 NPCP3 }+\ldots \\ \mathrm{S} / \mathrm{PCP} 2 & =\text { NPCP3 }(\text { PCP1 NCLEAR }+\ldots) \\ \mathrm{R} / \mathrm{PCP} 1 & =\ldots \end{aligned}$ | Go to PCP phase 2 |
| PCP2 | Idle phase <br> Display D-register | SXD = PCP2 NRESET NSDIS |  |
|  |  |  | Mnemonic: INSTR ADDR |

Table 3-148. CLEARMEM Function, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Switch outputs <br> CPU RESET/CLEAR $\Rightarrow$ KCPURESET <br> SYS RESET/CLEAR $\Rightarrow$ KSYSR/B <br> COMPUTE in IDLE $\Rightarrow$ NKAS $/ B$ |  |  |
| $\begin{aligned} & \mathrm{PCP} 2 \\ & \mathrm{~T} 6 \mathrm{~L} \end{aligned}$ | Id le phase <br> Generate RESET when first switch activated <br> Set flip-flop PCP3 when both switches activated | RESET $=$ NKAS $/ \mathrm{B}($ KCPURESET $/ \mathrm{B}$ <br>  + KSYSR/B $)+\ldots$ <br> S/PCP3 $=$ PCP2 NHALT NCLEAR <br>  CLEARMEM NPCP3 <br> CLEARMEM $=$ KCPURESET KSYSR NKAS/B | See RESET function |
| PCP3 <br> T6L | One clock long <br> Set flip-flop PCP4 <br> Reset flip-flop PCP2 <br> Reset flip-flop PCP3 | $\begin{aligned} \text { S/PCP4 } & =\text { PCP3 NENDE NPCP7 } \\ \text { R/PCP2 } & =\text { PCP3 } \\ \text { R/PCP3 } & =\ldots \end{aligned}$ | Go to PCP phase 4 |
| $\begin{aligned} & \text { PCP4 } \\ & \text { T6L } \end{aligned}$ | One clock long <br> Set flip-flop PCP5 <br> Reset flip-flop PCP4 | $\begin{aligned} \text { S/PCP5 } & =\text { PCP4 NENDE NPCP7 } \\ \text { R/PCP4 } & =\ldots \end{aligned}$ | Go to PCP phase 5 |
| $\begin{aligned} & \text { PCP5 } \\ & \text { T6L } \end{aligned}$ | One clock long <br> Set flip-flop PCP6 <br> Reset flip-flop PCP5 | $\begin{aligned} \text { S/PCP6 } & =\text { PCP5 NENDE NPCP7 } \\ \text { R/PCP5 } & =\ldots \end{aligned}$ | Go to PCP phase 6 |
| PCP6 <br> T6L | Repeated until NCLEARMEM <br> Set flip-flop DRQ <br> Generate memory request | $\begin{aligned} S / D R Q & =P C P 6 \text { CLEARMEM }+\ldots \\ M R Q & =P C P(S / D R Q)+\ldots \\ P C P & =P C P 6+\ldots \end{aligned}$ | Inhibits clock until data release received from memory <br> Prepare to write into core memory |
|  |  | (Continued) | Mnemonic: CLEARMEM |

Table 3-148. CLEARMEM Function, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PCP6 T6L (Cont.) | Generate memory write $(S 0-S 31) \longrightarrow(M B O-N B 31)$ $P+1 \rightarrow P$ <br> Inhibit crossover <br> Inhibit memory protection <br> Repeat PCP6 until switches released <br> P15-P31 $\rightarrow$ Q15-Q31 | $\begin{aligned} \text { MW }= & \text { PCP6 CLEARMEM }+\ldots \\ \text { MBXS }= & \text { MW }=\text { PCP6 CLEARMEM }+\ldots \\ \text { PCPTI }= & \text { PCP6 CLEARMEM }+\ldots \\ \text { CRO }= & \text { NCLEARMEM (address } 0-15) \\ \text { PROTD }= & \text { FAILD NPCP6 NPCP6 } \\ S / P C P 7= & \text { PCP6 NCLEARMEM NKFILL/B } \\ & +\ldots \\ \text { QXP }= & \text { CLEARMEM NINTRAP2 }+\ldots \end{aligned}$ | Write zeros intoaddressed memory location <br> Plus count the P -register by one to address next location <br> Clear locations 0-15 <br> Place current address in INSTRUCTION ADDRESS indicators |
| PCP7 <br> T6L | One clock long <br> Set flip-flop PCP! <br> Reset flip-flop PCP6 <br> Reset flip-flop PCP7 | $\begin{aligned} S / P C P 1 & =\text { NPCP3 }(P C P 7+\ldots) \\ R / P C P 6 & =P C P 7+\ldots \\ R / P C P 7 & =\ldots \end{aligned}$ | Go to PCP phase 1 |
| PCP1 <br> T6L | One clock long <br> Set HALT flip-flop <br> Reset flip-flop PCPI <br> Set flip-flop PCP2 | $\begin{aligned} \mathrm{S} / \mathrm{HALT} & =\text { PCP1 NPCP3 }+\ldots \\ \mathrm{R} / \mathrm{PCP} 1 & =\ldots \\ \mathrm{S} / \mathrm{PCP} 2 & =\text { NPCP3 (PCP1 NCLEAR }+\ldots) \end{aligned}$ | Go to PCP phase 2 |
| PCP2 | Idle phase |  |  |
|  |  |  | Mnemonic: CLEARMEM |



Figure 3-236. LOAD, Sequence Flow Diagram

Table 3-149. LOAD Function, Phase Sequence

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
|  | Switch outputs <br> LOAD $\Rightarrow$ KFILL/B, KAS/1, KAS/2 UNIT ADDRESS $\Rightarrow$ KUA21-KUA31 | - |  |
| $\begin{aligned} & \text { PCP2 } \\ & \text { T6L } \end{aligned}$ | Idle phase <br> Set flip-flop PCP3 | $\begin{aligned} S / P C P 3= & \text { PCP2 NHALT NCLEAR KAS } / 1 \\ & \text { KAS } / 2 \text { NPCP3 } \end{aligned}$ | Go to PCP phase 3 |
| $\begin{aligned} & \text { PCP3 } \\ & \text { T6L } \end{aligned}$ | One clock long <br> Set flip-flop PCP4 <br> Reset flip-flop PCP2 <br> Reset flip-flop PCP3 | $\begin{aligned} \mathrm{S} / \mathrm{PCP} 4 & =\text { PCP3 NENDE NPCP7 } \\ \mathrm{R} / \mathrm{PCP} 2 & =\text { PCP3 } \\ \mathrm{R} / \mathrm{PCP3} & =\ldots \end{aligned}$ | Go to PCP phase 4 |
| $\begin{aligned} & \text { PCP4 } \\ & \text { T6L } \end{aligned}$ | One clock long $x^{\prime} 20^{\prime} \nrightarrow P$ <br> Set flip-flop PCP5 <br> Reset flip-flop PCP4 | $\begin{aligned} \mathrm{S} / \mathrm{P} 26 & =\mathrm{PX} 20 \\ \mathrm{PX} 20 & =\mathrm{PCP} 4 \mathrm{KFILL} / \mathrm{B}+\ldots \\ \mathrm{PX} / 13 & =\mathrm{PX}=\mathrm{PX} 20 \\ \mathrm{~S} / \mathrm{PCP} 5 & =\text { PCP4 NENDE NPCP7 } \\ \mathrm{R} / \mathrm{PCP} 4 & =\ldots \end{aligned}$ | Bootstrap program starts at location $X^{\prime} 20^{\prime}$ <br> Go to PCP phase 5 |
| $\begin{aligned} & \text { PCP5 } \\ & \text { T6L } \end{aligned}$ | One clock long <br> Set flip-flop DRQ <br> Generate memory request <br> Set flip-flop PCP6 <br> Reset flip-flop PCP5 | $\begin{aligned} \mathrm{S} / \mathrm{DRQ} & =\mathrm{PCP5} \mathrm{KFILL} / \mathrm{B}+\ldots \\ \mathrm{MRQ} & =\mathrm{PCP}(\mathrm{~S} / \mathrm{DRQ}) \\ \mathrm{PCP} & =\text { PCP5 }+\ldots \\ \mathrm{S} / \mathrm{PCP6} & =\text { PCP5 NENDE NPCP7 } \\ \mathrm{R} / \mathrm{PCP5} & =\ldots \end{aligned}$ | Inhibits clock until data release signal received from memory <br> Prepare for memory write <br> Go to PCP phase 6 |
|  |  | (Continued) | Mnemonic: LOAD |

Table 3-149. LOAD Function, Phase Sequence (Cont.)

| Phase | Function Performed | Signals Involved | Comments |
| :---: | :---: | :---: | :---: |
| PCP6 T6L | Repeated until switch released <br> Set flip-flop DRQ <br> Generate memory request $\begin{aligned} & S 0-S 31 \longrightarrow M B 0-M B 31 \\ & P+1 \longrightarrow P \end{aligned}$ <br> Force bootstrap program on sum bus $\begin{aligned} & P=X^{\prime} 20^{\prime}, X^{\prime} 21^{\prime} 0 \longrightarrow S \longrightarrow M B \\ & P=X^{\prime} 22^{\prime} \Rightarrow X^{\prime} 020000 A 88^{\prime} \longrightarrow M B \\ & S \longrightarrow M \end{aligned}$ $\begin{aligned} & P=X^{\prime} 23^{\prime} \Rightarrow ' 0 E 000058^{\prime} \longrightarrow \\ & S \longrightarrow M B \end{aligned}$ $\begin{aligned} & P=X^{\prime} 24^{\prime} \Rightarrow X^{\prime} 00000011^{\prime} \longrightarrow M B \\ & S \longrightarrow X^{\prime} \longrightarrow \\ & P=X^{\prime} 25^{\prime} \Rightarrow M B \\ & S \longrightarrow X^{\prime} 00000 X X X^{\prime} \longrightarrow \\ & P=X^{\prime} 26^{\prime} \Rightarrow X^{\prime} 32000024^{\prime} \longrightarrow \end{aligned}$ |  | Inhibits clock until data release signal received from memory <br> Write bootstrap program <br> Address successive memory locations <br> Decode P -register to set sum bus bits |

Table 3-149. LOAD Function, Phase Sequence (Cont.)


Table 3-149. LOAD Function, Phase Sequence (Cont.)


Table 3-150. Bootstrap Program

| Location | Contents | Significance |
| :---: | :---: | :---: |
| 20 | 00000000 | Reserved for I/O |
| 21 | 00000000 | Reserved for I/O |
| 22 | 020000A8 | Bits 0 through 31 of I/O command doubleword. Specifies read order (02) and starting byte location $X^{\prime} A 88^{\prime}$. Word location is $X^{\prime} A 81 / 4$, or $X^{\prime} 2 A^{\prime}$ |
| 23 | OE000058 | Bits 32 through 63 of $\mathrm{I} / \mathrm{O}$ command doubleword. Contains flag bits 0 E , which specify halt on transmission error, interrupt on unusual end, and suppress incorrect length. X'58' specifies reading 88 bytes into consecutive memory locations |
| 24 | 0000001 | Command address of I/O command doubleword (shifted one bit position to the left in IOP to specify word location $X^{\prime} 22^{\prime}$ ) |
| 25 | 00000XXX | Address of I/O unit. (XXX represents address taken from UNIT ADDRESS switches) |
| 26 | 32000024 | Load Word instruction. Loads the contents of location $X^{\prime} 24^{\prime}\left(X^{\prime} 11 l^{\prime}\right)$ into private memory register 0 |
| 27 | CC000025 | Indirectly-addressed Start Input/Output instruction. Takes command doubleword from location specified in private memory register 0 and specifies device pointed to by address in location 25 |
| 28 | CD000025 | Indirectly-addressed Test Input/Output instruction |
| 29 | 69C00028 | Branch on Conditions Set (BCS) instruction. Branches to location $\mathrm{X}^{\prime} 28^{\prime}$ if condition code is not $\mathrm{X}^{\prime} \mathrm{C}^{\prime}$. If the device address used by the SIO and the TIO instructions is not recognized by any device condition codes CCl and CC 2 are set by both instructions, causing the BCS instruction to branch continuously to $X^{\prime} 28^{\prime}$ until operator intervention occurs |
|  |  | During a successful loading operation, when the TIO is executed the device should be busy because of the previous SIO instruction. As long as the device is busy, condition code CC2 is set when the TIO is executed, causing the BCS to branch continuously to $X^{\prime} 28^{\prime}$ <br> The next time the TIO is executed, when the device finishes its input operation, CC 2 is reset, causing the BCS not to branch, and allowing the CPU to sequence to location $X^{\prime} 2 A^{\prime}$ for the next instruction |



3-339 PHASE INDICATORS. The PREPARATION, PCP, and the EXECUTION phase indicators represent the binary encoding of the states of the phase flip-flops, PREI through PRE4, PCPI through PCP7, and PHI through PH15. A typical equation is as follows

$$
\begin{aligned}
\mathrm{PHI} / \mathrm{L}= & \mathrm{PHI}+\mathrm{PH} 3+\mathrm{PH} 5+\mathrm{PH} 7+\mathrm{PH} 9 \\
& +\mathrm{PHIl}+\mathrm{PH} 3+\mathrm{PH} 5
\end{aligned}
$$

The INT/TRAP phase indicators are lighted by the outputs of flip-flops INTRAP1 and INTRAP2 which define interrupt and trap phases.

3-340 MEMORY FAULT INDICATORS. MEMORY FAULT indicators 1 througn 8 are lighted by lamp drivers MFO/L through MF7/L, which are activated by memory fault indicator signals MFLO through MFL7 from the memory.

## 3-341 POWER DISTRIBUTION

The first five illustrations that follow give information needed to understand power distribution in Sigma 7. Figure 3-238 explains the cable designation code; figure 3-239 explains the cabinet and frame location codes; and figure $3-240$ shows the standard prong shapes of connectors. Figures 3-241 and 3-242 show typical positioning of power supplies and distribution units.

A typical system power distribution is shown in figure 3-243.

Figures 3-244 through 3-247 show a typical power configuration, interconnections, and functional diagram. These figures give general information; the installation conditions may make it necessary to use different cable lengths than those indicated. Specific installation information is provided by the XDS Customer Service department.

Table 3-151 lists installation drawings for peripheral equipment and power supplies. Table 3-152 lists the types of power cables used.

3-342 GLOSSARY TABLES

A glossary of signals is given as follows:
a. Table 3-153. Symbols Used in Glossaries and Equa tions, Miscellaneous Information.
b. Table 3-154. Glossary of CPU Signals.

Note
This glossary includes memory map, memory protect, and floating point signals, as well as certain interrupt signals.
c. Table 3-155. Glossary of Interrupt Signals. The glossary is divided into two parts, internal and external.

Figure 3-238. Cable Designation Code

2. FRAME LOCATION CODE

| CODE | FRAME LOCATION |
| :---: | :--- |
| F | FRONT |
| C | CENTER |
| R | REAR |

## EXAMPLES:

M3C MEMORY, THIRD CABINET, CENTER
D5R DEVICE CONTROLLER, FIFTH CABINET, REAR
R2R ACCESSORY TO THE RIGHT OF CPU, SECOND CABINET, REAR
Figure 3-239. Cabinet and Frame Location Codes


Figure 3-240. Male Connectors, Prong Shapes and Uses


Figure 3-241. PTI5 Power Supply, PT14 Power Supply, Main Power Distribution Box, and Power Junction Box (Typical Installation)


LEGEND
${ }_{1}^{1}$ circuit breaker symbol
ع0८1ع • $\because 090106$



Figure 3-245. System Ac Interconnections,


## NOTES:

THE PT14 AND PT15 POWER SUPPLIES AND THE MAIN POWER DISTRIBUTION BOX FOR CPU CABINET NO. 2 ARE USUALLY OPTIONAL. IF THE SYSTEM HAS FOUR MEMORY CABINETS, THEY ARE REQUIRED. EXCEPTION: THE MEMORY CABINETS MAY OBTAIN POWER FROM RIGHT ACCESSORY CABINET NO. 1 WITH PT14 AND PT15 POWER SUPPLIES WHEN THEY ARE AVAILABLE
(2) POWER EXTENSION CORDS TO THE FREE STANDING CONSOLE CAN CONNECT TO ANY JUNCTION BOX IF CABLE LENGTH, POWER, OR CONNECTOR LIMITATIONS OCCUR. (SEE ITEMS 4 AND 8)
(3) THE REMOTE LINE TO PERIPHERAL STATIONS CONNECT IN SEQUENCE IN THE ORDER OF STARTING SURGE (WITH THE HIGHEST ONE FIRST), UNLESS THE SYSTEM CONTAINS A RAD SUBSYSTEM. (SEE FIGURE 3-244, ITEM 8.) THE ORDER OF PERIPHERAL STATIONS, BY DEGREE OF STARTING SURGE (FROM THE HIGHEST TO THE LOWEST), IS: MAGNETIC TAPE CONTROLLER AND TRANSPORT, MAGNETIC TAPE TRANSPORT, RAD SUBSYSTEM, CARD PUNCH, LINE PRINTER, PAPER TAPE EQUIPMENT, AND CARD READER
(4) THE TOTAL LENGTH OF ANY 2-KHZ LINE (FROM THE PT15 POWER SUPPLY TO THE DC POWER) MUST NOT EXCEED 60 FEET. THE PREFERRED LENGTH OF 2-KHZ EXTENSION CORD CABLE (NO. 124418) IS LESS THAN 50 FEET. IF NECESSARY, 2-KHZ POWER FOR PERIPHERAL STATIONS MAY BE OBTAINED FROM PTI 5 POWER SOURCES OTHER THAN THE ONE LOCATED IN THE DEVICE CONTROLLER CABINET, WITH THE EXCEPTION OF THE LINE PRINTER. (SEE FIGURE 3-244, ITEM 7)
(5) THE LOCAL DESIGNATION INDICATES LOCAL LINE POWER. THIS REFERS TO SINGLE-PHASE POWER OBTAINED DIRECTLY FROM THE LINE BEFORE THE CONTACTOR. THE REMOTE DESIGNATION INDICATES INPUT THAT WILL ENERGIZE THE CONTACTOR
6) POWER INTERCONNECTIONS FROM THE MAIN POWER DISTRIBUTION BOX TO THE PCP ARE SHOWN BELOW. (THE CONNECTIONS FOR SIGMA 7 WITH A FREE STANDING CONSOLE APPEAR IN FIGURE 3-244)

| FROM MAIN POWER DISTRIBUTION BOX | TO SIGMA 7 PCP |
| :---: | :---: |
| LOCAL J1 | J 31 |
| REMOTE P1 | J 32 |

Pl ON ANY JUNCTION BOX (2-KHZ REMOTE IN) MUST CONNECT DIRECTLY OR BY MEANS OF AN EXTENSION CORD (NO. 124418-L) TO A PT15 POWER SUPPLY
8) WHEN CHAINING A 60-HZ LINE FROM J-BOX TO J-BOX, THE INPUT LINE ON THE FIRST J-BOX (WHERE P2 CONNECTS TO THE MAIN POWER DISTRIBUTION BOX) SHOULD NOT EXCEED 10 AMPERES. A TOTAL OF 28 FANS ARE SHOWN, DRAWING CURRENT THROUGH THE J-BOX INPUT LINE. EACH FAN DRAWS 0.16 AMPERES. THE TOTAL CURRENT $(0.16 \times 28)$ IS 4.5 AMPERES. ANY DEVICE DRAWING MORE THAN 5.5 AMPERES SHOULD NOT BE CONNECTED TO EITHER OF THE TWO J-BOXES
9) J3 AND J4 ON THE MAIN POWER DISTRIBUTION BOXES (60-HZ SWITCHED) ARE USED TO DRIVE FANS. J3 AND J4, PHASES Y AND X RESPECTIVELY, SHOULD BE CONNECTED TO DISTRIBUTE BOTH PHA'SES UNIFORMLY
10. AN ADDITIONAL J-BOX (NO. 117428) IS REQUIRED ONLY WHEN A REAR FIXED FRAME IS USED
(11) THE 60-HZ OUTLETS ARE AVAILABLE FOR CONNECTION TO THE J-BOX (OR BOXES) IN MEMORY CABINET NO. 2, PROVIDING POWER LIMITS ARE NOT EXCEEDED. (SEE ITEM 8.)

Figure 3-245. System Ac Interconnections, Typical (Sheet 3 of 3)


NOTES:
(1) EIGHT MAGNETIC TAPE UNITS ARE A MAXIMUM CONFIGURATION FOR A MAGNETIC TAPE SUBSYSTEM. SEE INSTALLATION DRAWING NO. 137114, MAGNETIC TAPE SUBSYSTEM
(2) THE REMOTE LINE TO PERIPHERAL STATIONS CONNECT IN SEQUENCE IN ORDER OF STARTING SURGE, WITH THE HIGHEST ONE FIRST, UNLESS THE SYSTEM CONTAINS A RAD SUBSYSTEM (SEE ITEM 4). THE ORDER OF THE PERIPHERAL STATIONS, BY DEGREE OF STARTING SURGE (FROM HIGHEST TO LOWEST), IS: MAGNETIC TAPE CONTROLLER AND TRANSPORT, MAGNETIC TAPE TRANSPORT, RAD SUBSYSTEM, CARD PUNCH, LINE PRINTER, PAPER TAPE EQUIPMENT, AND CARD READER
(3) THE TOTAL LENGTH OF ANY 2-KHZ LINE (FROM PT15 POWER SUPPLY TO DC POWER) MUST NOT EXCEED 60 FEET. THE PREFERRED LENGTH OF 2-KHZ EXTENSION CORD CABLE (NO. 124418) IS LESS THAN 50 FEET. IF NECESSARY, 2-KHZ POWER FOR PERIPHERAL STATIONS MAY BE OBTAINED FROM PTI5 POWER SOURCES OTHER THAN THE ONE LOCATED IN THE DEVICE CONTROLLER CABINET, WITH THE EXCEPTION OF THE LINE PRINTER (SEE ITEM 5)
(4) IF THE SYSTEM CONTAINS A RAD SUBSYSTEM, A DEVICE WITH A LOWER STARTING SURGE (SUCH AS CARD READER OR PAPER TAPE CABINET) SHOULD BE CONNECTED IN REMOTE-SEQUENCE FASHION IMMEDIATELY BEFORE THE RAD. THE PERIPHERAL STATION AND RAD SUBSYSTEM WILL TURN ON simultaneously after the previous line surge has settled
5. THE 2-KHZ POWER TO THE LINE PRINTER STATION MUST ORIGINATE FROM THE SAME 2-KHZ. SOURCE AS THAT TO WHICH THE LINE PRINTER CONTROLLER DC SUPPLIES ARE CONNECTED
(6) EIGHT RAD STORAGE UNITS ARE A MAXIMUM CONFIGURATION FOR A RAD SUBSYSTEM. SEE INSTALLATION DRAWING NO. 137115 FOR RAD SUBSYSTEM
7) WITH THE EXCEPTION OF THE RAD, PERIPHERAL STATIONS HAVE A THERMAL DELAY RELAY AT THE REMOTE INPUT. THE RELAY LIMITS POWER SURGES WHEN THE EQUIPMENT IS TURNED ON
(8) ONLY TWO PHASES ARE USED BY THE CARD PUNCH. THE THIRD PHASE IS NOT WIRED TO THE CONNECTOR

Figure 3-246. Peripheral Station Power Control, Functional Diagram, Typical (Sheet 2 of 2 )


NOTE : MARGINAL VOLTAGE CABLING MUST CONNECT TO
ALL PTIG POWER SUPPLIES IN THE SYSTEM AND CAN be Chalned IN ANY SEQUENCE

Figure 3-247. Marginal Voltage Indicator Interconnections, Typical

Table 3-151. Peripheral Equipment and Power Supply Installation Drawings

| Drawing Name | Drawing Number |
| :---: | :---: |
| Magnetic Tape Station | 128336 |
| Magnetic Tape susbystem | 137114 |
| RAD Memory | 132841 |
| RAD Memory | 126657 |
| RAD Subsystem | 137115 |
| Card Punch | 124638 |
| Card Reader | 124773 |
| Line Printer | 123898 |
| Paper Tape Station. | 127714 |
| PT14 Power Supply, PT15 Power Supply, and Main Power Distribution Box | 123310 |
| PT16 Power Supply | 123509 |
| PT17 Power Supply | 123636 |
| PT18 Power Supply | 127156 |
| PT19 Power Supply | 127192 |

Table 3-152. Types of Power Cables

| Cable Description | Part Number |
| :--- | :---: |
| $50-60 \mathrm{~Hz}$ extension cord | $129944-\mathrm{L}^{*}$ |
| $2-\mathrm{kHz}$ extension cord | $124418-\mathrm{L}^{*}$ |
| Marginal voltage indicator cable | $135663-L^{*}$ |
| *The designation -L indicates a length to be specified |  |

Table 3-153. Symbols Used in Glossaries, Equations, and Phase Sequence Charts

| SYMBOL | EXPLANATION |
| :---: | :---: |
| N | Prefixes |
|  | Not. The letter N, before a signal, has the same meaning as the bar that previously appeared over the signal |
| S/ | Set input to flip-flop |
| R/ | Reset input to flip-flop |
| C/ | Clock input to flip-flop |
| E/ | Erase input to flip-flop (DC reset) |
| F/ | Force input to flip-flop (DC set) |
| W/ | Data write input to high-speed memory |
| L/ | Address line to high-speed memory |
| K/ | Read/write control to high-speed memory |
|  | Suffixes |
| - | Dash (-) followed by number or letter: same logic signal generated by different driver. Example: <br> PXQ-2 $=1$ NPXQ NMULC NMRQ/1 <br> $P X Q-3=1$ NPXQ NMULC $N M R Q / 1$ |
|  | Note |
|  | PXQ-3 is the output of another inverter |
| 1 | Slash $(\triangle)$ followed by number or letter: similar logic signal generated by different driver. Example: $\begin{aligned} & \text { PX/13 }=1 \text { NPX NPXS NMULC } \\ & \text { PX/12 }=1 \text { NPX NPXS NMULC NPX/2 } \end{aligned}$ |
| z | Usually means 0 , as in A0031Z, which means A0 through A31 $=0$. Exception: P31Z means force a 0 into P31 |
| w | Usually means a 1 |
| F | Either floating point of flip-flop |
|  | Miscellaneous Symbols |
| S/name | Flip-flop set input |
| $\longrightarrow$ | Implies |
| $\longrightarrow$ | Transfer to |
| 1 | Clocked transfer to (CL clock) |
| - | Logical AND |
| + | Logical OR |
| $\oplus$ | Exclusive OR |

Table 3-154. Glossary of CPU Signals

| Signal | Definition |
| :---: | :---: |
| A0004W | A0-A4 contain ones |
| A0004Z | A0-A4 contain zeros |
| A0007Z | A0-A7 contain zeros |
| A0015Z | A0-A15 contain zeros |
| A003.1Z | A0-A31 contain zeros |
| A0107Z | A1-A7 contain zeros |
| A0115Z | Al-A15 contain zeros |
| A0131Z | Al-A31 contain zeros |
| Al6312 | A16-A31 contain zeros |
| A1731Z | A17-A31 contain zeros |
| A47712 | A47-A71 contain zeros |
| A8X1 | A8 loaded by clock with a one |
| A9X1 | A9 loaded by clock with a one |
| ABOi | Where i = A, B, or C. Abort core memory port N because of memory lockout |
| ADMATCH | Address match between the LM and KSP lines 15-31 |
| AH | Add halfword, hexadecimal opcode 10 or 90 |
| AHCL | Memory address here clock |
| AHi | Where $\mathbf{i}=A, B$, or $C$. Core memory address; signal sent from port $\mathbf{i}$ |
| ALARM | Causes PCP ALARM light to light, and causes a 1 KC alarm to sound if the COMPUTE switch is set to RUN and the AUDIO switch is set to ON |
| AM | Flip-flop holding the arithmetic mask bit for program status word 1 |
| AND | AND word, hexadecimal opcode $4 B$ or $C B$ |
| ANLZ | Flip-flop used during execution of analyze instruction |
| ARQ | Flip-flop indicating that the next clock will not occur until the address release signal (ARC) has been received from memory if there is a memory request out |
| ARi | Where $\mathbf{i}=\mathrm{A}, \mathrm{B}$, or C . Core memory address release signal sent from port $\mathbf{i}$ |
| ASN | A simple normalized (that is, $-1 \leq A<-\frac{1}{16}$ or $\frac{1}{16} \leq A<1$ ) |
| ATE | Memory address time elapsed |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| AUDIO | Signal sent to the PCP speaker |
| AX | Signal is true to load or reset the A-register. This reset term is voided if a simultaneous set occurs |
| AX/1 | $0 \longrightarrow$ A0-A31, $0 \longrightarrow$ A47-A71 |
| AXAL32 | $\mathrm{A} 0+\mathrm{A} 47 \longrightarrow \mathrm{~A} 47, \mathrm{~A} 8+\mathrm{A} 48 \longrightarrow \mathrm{~A} 48, \ldots \mathrm{~A} 31+\mathrm{A} 71 \longrightarrow \mathrm{~A} 1$ |
| AXE | $\mathrm{E} 0-\mathrm{E} 7 \longrightarrow \mathrm{~A} 0-\mathrm{A} 7,0 \longrightarrow \mathrm{~A}$-A31, $0 \longrightarrow$ A47-A71. Special action to A 0 and Al during FAMDSF |
| AXE/I | $\mathrm{E} 0+\mathrm{A} 0 \longrightarrow \mathrm{~A} 0, \mathrm{El}+\mathrm{Al} \longrightarrow \mathrm{Al}, \ldots \mathrm{E} 7+\mathrm{A} 7 \rightarrow \mathrm{~A} \rightarrow$. Special action to A 0 and Al during FAMDSF |
| AXPRR2 | $\qquad$ $\mathrm{A} 0, \mathrm{~A} 31 \longrightarrow \mathrm{Al}$ PRO-20 $\qquad$ A2-A31, A47 D46 $\qquad$ A47. Special action to $A 0$ and $A 1$ during FAMDSF |
| AXR | $\mathrm{R} 28-\mathrm{R} 31 \longrightarrow \mathrm{~A} 28-\mathrm{A} 31,0 \longrightarrow \mathrm{~A} 0-\mathrm{A} 27,0 \longrightarrow \mathrm{~A} 57-\mathrm{A} 71$ |
| AXRR | RR0-RR31 $\rightleftharpoons$ A0-A31, $0 \longrightarrow$ A47-A71 |
| AXRR/2 | RR16-RR31 $\rightarrow$ A16-A31, $0 \longrightarrow$ A0-A15, $0 \longrightarrow$ A47-A71 |
| AXRR/3 | RR24-RR31 $\rightarrow$ A24-A31, $0 \rightarrow$ A0-A23, $0 \rightarrow$ A47-A71 |
| AXRRLI | RR16-RR31 $\rightarrow$ A15-A30, $0 \rightarrow$ A0-A14, $0 \rightarrow$ A31, $0 \rightarrow$ A47-A71 |
| AXRRR1 | RR14-RR30 $\longrightarrow$ A15-A31, RR31 P32, $\longrightarrow$ P33, $\longrightarrow$ A47-A71 |
| AXRRR2 | $\text { RR13-RR29 } \rightarrow \text { A15-A31, RR30-RR3i } \rightarrow \text { P32-P33, } 0 \rightarrow \text { A47-A71 }$ |
| AXS | S0-S31 $\rightarrow$ A0-A31, S47-S71 $\rightarrow$ A47-A71 |
| AXS/1 | S0-S7 $\longrightarrow \mathrm{A} 0-\mathrm{A} 7,0 \longrightarrow \mathrm{~A} 8-\mathrm{A} 31,0 \longrightarrow \mathrm{~A} 47-\mathrm{A} 71$ |
| AXS/2 | $\mathrm{S} 0-\mathrm{S} 15 \rightarrow \mathrm{~A} 0-\mathrm{Al5,0} \rightarrow \mathrm{Al6-A31,0} 4$ A47-A71 |
| AXS/3 | $\mathrm{S} 8-\mathrm{S} 15 \longrightarrow \mathrm{~A} 8-\mathrm{A} 31,0 \longrightarrow \mathrm{~A} 0-\mathrm{A} 7,0 \longrightarrow \mathrm{~A} 47-\mathrm{A} 71$ |
| AXS/4 | S47-S71 $\longrightarrow$ A47-A71, $0 \rightarrow$ A0-A31 |
| AXSLI | $\mathrm{S} 1-\mathrm{S} 31 \rightarrow \mathrm{~A} 1 \rightarrow \mathrm{~A} 30, \mathrm{~A} 0 \rightarrow \mathrm{~A} 31, \mathrm{~S} 48-\mathrm{S} 71 \rightarrow \mathrm{~A} 47-\mathrm{A} 70, \mathrm{SO} \rightarrow \mathrm{A} 71$. Special action to A31 during FAMDSF |
| AXSLI/1 | $\mathrm{S} 9-\mathrm{S} 31 \longrightarrow \mathrm{~A} 8-\mathrm{A} 30, \mathrm{~A} 0 \longrightarrow \mathrm{~A} 31, \mathrm{~S} 48 \longrightarrow \mathrm{~A} 47,0 \longrightarrow \mathrm{~A} 48-\mathrm{A} 71$. Special action to A31 during FAMDSF |
| AXSL4 | $\begin{aligned} & \mathrm{S} 4-\mathrm{S} 31 \rightarrow \mathrm{~A} 1 \rightarrow \mathrm{~A}-\mathrm{A} 27, \mathrm{~A} 0-\mathrm{A} 3 \rightarrow \mathrm{~A} \rightarrow \mathrm{~A} 8-\mathrm{A} 31, \mathrm{~S} 51-\mathrm{S} 71 \rightarrow \mathrm{~A} 4-\mathrm{A} 67, \mathrm{~S} 0-\mathrm{S} 3 \longrightarrow \mathrm{~A} \rightarrow 8-\mathrm{A} 71 \text {. } \\ & \text { Special action to } \mathrm{A} 28-\mathrm{A} 31 \text { during FAMDSF } \end{aligned}$ |
| AXSR4 | $\mathrm{S} 68-\mathrm{S} 71 \rightarrow \mathrm{~A} 0-\mathrm{A} 3, \mathrm{~S} 0-\mathrm{S} 27 \rightarrow \mathrm{~A} 4-\mathrm{A} 31, \mathrm{~S} 47-\mathrm{S} 67 \rightarrow \mathrm{~A} 51-\mathrm{A} 71,0 \rightarrow \mathrm{~A} 47-\mathrm{A} 50$ <br> Special action to A50 during FAFLAS |
| AXSR32 | $\mathrm{S} 48+\mathrm{A} 8 \longrightarrow \mathrm{~A}, \mathrm{~S} 49+\mathrm{A} 9 \longrightarrow \mathrm{~A} 9 \ldots \mathrm{~S} 71+\mathrm{A} 31 \longrightarrow \mathrm{~A} 31$ |

(Continued)

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| BOS | B0 sum |
| B1S | Bl sum |
| B1619ONE | Flip-flops B16-B19 contain 0001 |
| B16192 | B16-B19 contain zeros |
| B31X1 | Load B31 by clock with a one |
| BCl | B carry into position 1 (used in multiply) |
| BC31 | B carry into position 31 (used in BCON logic; also used in shift) |
| BCON | B control, high during multiply when the multiplier is being interrogated |
| BR | BRPHI + ... + BRPH15 + CLEAR + MITEX |
| BRPHi | Where $\mathbf{i}=1-15$. Branch to phase $\mathbf{i}$ and inhibit the nonbranch phase setting |
| BRQ | Causes $Q \longrightarrow P$, used during trapping or interrupting to make sure that the address stored by the XPSD instruction points at the right instruction |
| BWZ | B was zero. Used in divide overflow logic (fixed point) |
| $B X / 1$ | $0 \longrightarrow \mathrm{~B} 0-\mathrm{B} 31,0 \longrightarrow \mathrm{B47-B71}$ |
| BXB | $\mathrm{PR} 32 \oplus \mathrm{G} 33 \longrightarrow \mathrm{~B} 3, \mathrm{~B} 1 \oplus \mathrm{BCl} \oplus \mathrm{CS} 33 \longrightarrow \mathrm{~B}, \mathrm{~B} 2-\mathrm{B} 7 \longrightarrow \mathrm{~B} 2-\mathrm{B} 7$. Special action to B47-B71 during FAFLM |
| BXBLI | $\mathrm{B1} \oplus \mathrm{BCl} \oplus \mathrm{CS33} \longrightarrow \mathrm{~B} 0, \mathrm{~B} 2-\mathrm{B} 31 \longrightarrow \mathrm{~B} 1-\mathrm{B} 30, \mathrm{~B} 0 \longrightarrow \mathrm{~B} 31,0 \longrightarrow \mathrm{~B} 47, \mathrm{~B} 49-\mathrm{B} 71 \longrightarrow$ B48-B70, $\mathrm{BO} \rightarrow$ B71. Special action to B31 during FAMDSF |
| BXBL4 | $\mathrm{B} 4-\mathrm{B} 31 \rightarrow \mathrm{~B} 0-\mathrm{B} 27,0 \longrightarrow \mathrm{~B} 28-\mathrm{B} 31,0 \longrightarrow \mathrm{~B} 47-\mathrm{B} 71$. Special action to B28-B31 during FASHFX |
| BXBR2 | $\mathrm{B} 30-\mathrm{B} 31 \rightarrow \mathrm{BO}-\mathrm{B} 1, \mathrm{~B} 0-\mathrm{B} 29 \rightarrow \mathrm{~B} 2-\mathrm{B} 31$. Special action to $\mathrm{B} 0-\mathrm{B} 3$ during FAMDSF. Special action to $\mathrm{B} 4-\mathrm{Bl} 1$ and $\mathrm{B} 48-\mathrm{B} 71$ during FAFLM |
| BXND | $\mathrm{NDI}-\mathrm{ND} 7 \rightarrow \mathrm{Bl}-\mathrm{B} 7,0 \longrightarrow \mathrm{~B} 0,0 \rightarrow \mathrm{~B} 8-\mathrm{B} 31,0 \longrightarrow \mathrm{B47-B71} \longrightarrow$ |
| BXS | $\mathrm{S} 0-\mathrm{S} 31 \rightarrow \mathrm{~B} 0-\mathrm{B} 31, \mathrm{~S} 47-\mathrm{S} 11 \rightarrow \mathrm{B47-B71} \longrightarrow$ |
| $B X S / 1$ | $\mathrm{S} 47+\mathrm{B} 47 \rightarrow \mathrm{~B} 47, \mathrm{~S} 48+\mathrm{B} 48 \longrightarrow \mathrm{~B} 48, \ldots \mathrm{~S} 71+\mathrm{B} 71 \longrightarrow \mathrm{~B} 71$ |
| COCl 6 | Holding C 0 or Cl 6 depending on P32 |
| C0C16/1 | 7 used for sign extension in $C \rightarrow$ transfers |
| $\mathrm{COCl} 6,12$ | 5 used for sign extension in $\mathrm{C} \longrightarrow \mathrm{D}$ transfers |
| CCl | Condition code 1 |
|  | Condition code 2 |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| CC3 | Condition code 3 |
| CC4 | Condition code 4 |
| CCXDU | $\begin{aligned} & \mathrm{DUO} \longrightarrow 1 \rightarrow \mathrm{CC1}, \mathrm{DU6} \longrightarrow 0 \rightarrow \mathrm{CC1}, \mathrm{DU1} \longrightarrow 1 \rightarrow \mathrm{CC} 2, \mathrm{DU7} \longrightarrow 0 \rightarrow \\ & \mathrm{CC} 2 \end{aligned}$ |
| CCXDU/1 | DU2 $\rightarrow$ CC3, DU3 $\rightarrow$ CC4 |
| CCXS | $\mathrm{SO}-\mathrm{S3} \rightarrow \mathrm{CCl}-\mathrm{CC} 4$ |
| CCXTRACC | TRACC1-TRACC4 $\rightarrow$ CCl-CC4 |
| CCWCM | C-register contains one's complement for multiply |
| CCZ | True if CC1 $=$ CC2 $=$ CC3 $=$ CC4 $=0$ |
| CE | Clock enable |
| CEINT | Causes next clock to be synchronized with 2.048 MHz interrupt clock. Clock enable by interrupt |
| CK/1 | Scratch pad register clock, also CK/2-CK/12 |
| CKT2NL | Scratch pad register clock from DL3/040 NDL3/080 where $N=2,3,4$, or 5 for T4L, T6L, or T10L, respectively |
| CL/1 | Ac for clock for CPU, also CL/2-CL/12 |
| CLEAR | True if ENDE or S/INTRAPF or RESET |
| CLEARMEM | True if both SYSTEM RESET/CLEAR and CPU RESET/CLEAR are set simultaneously |
| CLEXT | Extended clock |
| CLEXTE | Extended clock enable |
| CLTILE | TIL even clock |
| CLTILO | TIL odd clock |
| CLT2NL | CL clock from $\mathrm{DL} 3 / 060 \mathrm{NDL} 3 / 100$ where $\mathrm{N}=2,3,4$, or 5 for T4L, T6L, T8L, or T1OL, respectively |
| CLT4LG | Generate T4L clock |
| CLT6LG | Generate T6L clock |
| CLT8LG | Generate T8L clock |
| CLTIOLG | Generate TIOL clock |
| CPULi | Where $\mathrm{i}=1-4$. Count pulses for the counter interrupts |
| CRO | Decoded from LM15-LM22 and LB23-LB27. Crossover from core memory address to fast memory address |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| CROF | Crossover flip-flop (actually buffer latch) indicating that crossover addressing is being used |
| CS32 | Extension of CS-register, needed for multiply |
| CS33 | Extension of CS-register, needed for multiply |
| CS7X1 | $1 \rightarrow$ CS7 |
| CSi | Carry-save register. Where $\mathbf{i}=0-33$ or 47-71 |
| CSN | C simple normalized (that is, $-1 \leq \mathrm{C}<-\frac{1}{16}$ or $\frac{1}{16} \leq \mathrm{C}<1$ ) |
| CSX1 | $1 \mathrm{~s} \rightarrow$ CS0-CS31, 1's $\longrightarrow$ CS47-CS71, but not CS32 or CS33 |
| CSX1/1 | $1 \mathrm{~s} \rightarrow$ CSO-CS29 |
| CSXI/2 | $1 ' s \rightarrow$ CSO-CS27 |
| CSX1/3 | $1 \mathrm{~s} \rightarrow \mathrm{CSO}-\mathrm{CS15}$ |
| $\operatorname{CSX1} 1 / 5$ | l 's $\longrightarrow$ CSO-CS7 |
| CSX1/8 | $1 \mathrm{~s} \rightarrow$ CS31 |
| CSXI/9 | CS0-CS27 loaded by clock with ones. Intermediate control term |
| CSX1/10 | CS28-CS31 and CS47-CS71 loaded by clock with ones. Intermediate control term |
| CSXGRI | $\begin{aligned} & \text { G0-G31 } \nrightarrow \mathrm{CS} 1-\mathrm{CS} 32, \mathrm{BO} \mathrm{CS} 32+\mathrm{PR} 32 \mathrm{G} 33 \longrightarrow \mathrm{CS} 33, \mathrm{G} 47-\mathrm{G} 70 \text { CS48-CS71, DCWCM } \\ & \Rightarrow 1 \xrightarrow[\mathrm{BCl}]{\Rightarrow 1} \end{aligned}$ |
| CX/1 | Causes $\mathrm{O}^{\prime} \mathrm{s} \rightarrow \mathrm{CO}-\mathrm{C} 31$ and $\mathrm{O} \longrightarrow \mathrm{COC16}$ |
| CXCL32 dc rep | $\mathrm{C} 0 \rightarrow \mathrm{C} 47, \mathrm{C} 8-\mathrm{C} 31 \quad \mathrm{C} 48-\mathrm{C} 71$ |
| CXMB | C0-C31 loaded from the memory bus data lines MB0-MB31 |
| CXMB/D | CXMB after a 50 nanosecond time delay |
| CXMB/i | Where $\mathrm{i}=1-4$ or 10-13. Same as $\mathrm{CXMB} / \mathrm{D}$ |
| CXRR | Causes RR0-RR31 $\rightarrow$ C0-C31, NP32 $\Rightarrow$ RRO $\rightarrow \mathrm{COC16}, \mathrm{P32} \Rightarrow \mathrm{RR1} 6 \rightarrow \mathrm{COCl} 6$ |
| CXS | Causes S0-S31 $\rightarrow$ C0-C31 and S47-S71 $\longrightarrow \mathrm{C} 47-\mathrm{C} 71$ |
| D27X1 | D27 loaded by clock with a one |
| DCH | DC hold clock for CXS and CXRR (C-register latch) |
| DCSTOP | Signal to halt the CPU if a core memory parity error occurs with the PARITY ERROR MODE switch in the HALT position, or if an address match occurs with the ADDR STOP switch on |
| DCWCM | D-register contains one's complement for multiply |

(Continued)

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| DEOPTION | True if decimal option implemented |
| DIO48X1 | $1 \longrightarrow / D I O 48 /$ (RD/WD function strobe) |
| DIO50X1 | $1 \longrightarrow /$ DIO50/ (indicates WD instruction) |
| DIOXB | B16-B31 $\longrightarrow$ /DIO32-DIO47/(RD/WD address lines) |
| DIOXS | S0-S31 $\longrightarrow /$ DIO0-DIO31/(RD/WD data lines) |
| DIT | High during divide iterations |
| DITEX | Exit from DIT (high last clock) |
| DL1 | CPU delay line 1 for clock timing |
| DLI/DI | Positive timing pulse with delay D1 (DL1/030) with respect to CL-1 leading edge |
| DL1/D2 | DL1 tap after delay D2 (DL1/050) with respect to $\mathrm{CL}-1$ leading edge |
| DLI/iii | Delay line 1 tap for iii ns |
| DLIE | CPU DL1 enable |
| DLIE/S | DLI enable set (CPU DLI/180) |
| DLIPC | Delay line 1 pulse cutoff (CPU DLI/080) |
| DLIPE | Delay line 1 pulse width expander (CPU DLI/020) |
| DL2 | CPU delay line 2, clock timing |
| DL2/D1 | DL2 tap after delay D1 (DL2/100) |
| DL2/D2 | DL2 tap after delay D2 (DL2/150) |
| DL2I | DL2 initiate |
| DL2PC | Delay line 2 pulse cutoff (DL2/080) |
| DL2PE | Delay line 2 pulse width expander (DL2/020) |
| DL2R | DL2 recirculate |
| DL2RE | DL2 recirculate enable |
| DL2TC1 | DL2 trip counter first flip-flop |
| DL2TC2 | DL2 trip counter second flip-flop |
| DL2TCC | DL2 trip counter clock |
| DL3 | CPU delay line 3, clock phase |
| DL3PC | Delay line 3 pulse width cutoff (DL3/080) |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| DL3PE | Delay line 3 pulse width expander (DL3/020) |
| DL4 | CPU delay line 4, extended clock generator |
| DLSE 1 | CPU delay line sensor enable 1, qualifies CLT1LO, CLT4LG, CLT6LG, and CLT8LG |
| DLSE1/S | Set delay line sensor enable 1 (CPU DLI/120) |
| DLSE2 | CPU delay line sensor enable 2, qualifies DL2I and CLT10LG |
| DLSE2/S | Set delay line sensor enable 2 (CPU DLI/240) |
| DLSE3 | CPU delay line sensor enable 3, DL2R and (TP520 NTP560) |
| DLSE3/S | Set delay line sensor enable 3 (CPU DL2/150) |
| DPP | Divide preparation |
| DR | Data release signal from memory after the buffer cable receiver |
| DRi | Where $\mathbf{i}=A, B$, or $C$. Core memory data release signal sent from port $\mathbf{i}$ |
| DRQ | Flip-flop indicating that the next clock will not occur until the data release signal has been received from memory if there is a memory request out |
| DU0-DU7 | Data lines to decimal unit |
| DU8 | DUCLOCK signal to decimal unit |
| DU9 | DUSTART signal to decimal unit |
| DU10 | DUEND signal from decimal unit |
| DU11 | DUCLEAR signal to decimal unit |
| DU12 | DUMDM signal to decimal unit |
| DUCLEAR | Reset signal to decimal unit (DU11 on cable) |
| DUCLOCK | Signal used to gate clock in decimal unit (DU8 on cable) |
| DUEND | Signal from decimal unit indicating the end of a particular phase of decimal unit operation (DU10 on cable) |
| DUMDM | Decimal trap mask or EBS mark option or interrupt request for use during DM and DD (DU12 on cable) |
| DUSTART | Signal indicating the beginning of a decimal instruction (DU9 on cable) |
| DUTI | Decimal unit trap immediately |
| DUTEI | Decimal unit trap at end of instruction |
| DUXCC | CCl-CC4 $\longrightarrow /$ DU0-DU3/ |
| DUXO | O4-O7 $\longrightarrow / D U 4-D U 7 /$ |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| DUXR | R28-R31 $\longrightarrow /$ DU0-DU3/ |
| DUXS | S24-S31 $\longrightarrow$ /DU0-DU7/ |
| DX/1 | $0 \rightarrow$ D0-D31, $0 \rightarrow$ D46-D71 |
| DXC/1 | $\mathrm{C} 24-\mathrm{C} 31 \rightarrow$ D24-D31, $\mathrm{C} 47 \rightarrow$ D46-D47, $\nrightarrow$ D0-D23, $0 \rightarrow$ D48-D71 |
| DXC/2 | $\mathrm{C} 0 \mathrm{C16} \rightarrow$ D0-D15, $\mathrm{Cl} 16-\mathrm{C} 31 \rightarrow$ D16-D31, $447 \rightarrow$ D46-D47, $0 \rightarrow$ D48-D71 |
| DXC/3 | $\mathrm{C} 12-\mathrm{C} 31 \rightarrow$ D12-D31, $\mathrm{C} 47 \rightarrow$ D46-D47, $\rightarrow$ - $40-\mathrm{D} 11,0 \rightarrow$ D48-D71 |
| DXC/4 | $\mathrm{C} 12 \rightarrow$ D0-D11, $\mathrm{C} 12-\mathrm{C} 31 \rightarrow$ D12-D31, $447 \rightarrow$ D46-D47, $0 \rightarrow$ D48-D71 |
| DXC/5 | Downward align halfword C to D according to P32, NP32 $\longrightarrow$ DXCR16 P32 $\longrightarrow$ DXC/2 |
| DXC/6 | $\begin{aligned} & \text { C0-C31 } \rightarrow \text { D0-D31, C47 } \rightarrow \text { D46, C47-C63 } \rightarrow \text { D47-D63 FAFL } \longrightarrow \text { C64-C71 } \\ & \text { D64-D71 NFAFL } \rightarrow 0 \rightarrow \text { D64-D67, I's } \rightarrow \text { D68-D70, C0 } \end{aligned}$ |
| DXC/7 | $\mathrm{C} 16 \mathrm{D} 16 \rightarrow$ D16, $\mathrm{C} 17 \mathrm{D} 17 \rightarrow$ D17, ... C31 D31 $\rightarrow$ D31, C47 D46 $\rightarrow$ D46, C47 D47 $\leftrightarrows$ D47, Intermediate control signal |
| DXC/8 | $\mathrm{Cl2} \mathrm{D} 12 \rightarrow \mathrm{D} 12, \mathrm{Cl3} \mathrm{D13} \rightarrow \mathrm{D} 13, \ldots \mathrm{Cl} 5 \mathrm{D} 15 \rightarrow$ D15, Intermediate control signal |
| DXC/9 | $\mathrm{C} 4-\mathrm{Cl} 5 \rightarrow$ D20-D31, $0 \rightarrow$ D0-D19, $0 \rightarrow$ D46-D71 |
| DXC/10 | DXC/6 + DXCM + DXC/D |
| DXC/13 | $D X C / 1+D X C / 7+D X C / D+D X C M$ |
| DXC/D | DXC generated by divide instructions |
| DXCBP | Downward align byte C to D according to P32 and P33 <br> NP32 NP33 $\longrightarrow$ NDXCR24 <br> NP32 P33 $\longrightarrow$ NDXCR16/1 <br> P32 NP33 $\longrightarrow$ NDXCR8 <br> P32 P33 $\longrightarrow$ NDXC $/ 1$ |
| DXCC | $\mathrm{CC1}-\mathrm{CC4} \rightarrow$ D28-D31, $0 \rightarrow$ D0-D27, $0 \rightarrow$ D46-D71 |
| DXCL/M | Multiplicand control flip-flop (2C $\rightarrow$ D) |
| DXCLI | Load the D-register from the C-register with a left one shift and a clock |
| DXCM | Multiplicand control flip-flop ( $C \rightarrow$ D) |
| DXCR8 | $\mathrm{C} 16-\mathrm{C} 23 \rightarrow$ D24-D31, $0 \rightarrow$ D0-D23, $0 \rightarrow$ D46-D71 |
| DXCR16 | $\mathrm{C} 0-\mathrm{Cl} 5 \rightarrow$ D16-D31, $\mathrm{C} 0-\mathrm{Cl} 6 \rightarrow$ D0-D15, 0 's $\longrightarrow$ D46-D71 |
| DXCR16/1 | $\mathrm{C} 8-\mathrm{Cl} 5 \rightarrow$ D24-D31, $0 \rightarrow$ D0-D23, $0 \rightarrow$ D46-D71 |
| DXCR24 | $\mathrm{C} 0-\mathrm{C} 7 \rightarrow$ D24-D31, $0 \rightarrow$ D0-D23, $0 \rightarrow$ D46-D71 |
| DXDIO | D100-DI31 $\rightarrow$ D0-D31, $0 \rightarrow$ D46-D71 |

(Continued)

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| DXDU | DU0-DU7 $\rightarrow$ D24-D31, $\rightarrow$ D0-D23, $\longrightarrow$ D46-D71 |
| DXK | $\begin{aligned} & \mathrm{KSO}+\mathrm{KNCO} \mathrm{DO} \underset{\mathrm{D}}{\longrightarrow} \mathrm{D} 0, \mathrm{KS1}+\mathrm{KNCl} \mathrm{D1} \rightarrow \mathrm{D} 1, \ldots \mathrm{KS} 31+\mathrm{KNC} 31 \mathrm{D} 31 \rightarrow \text { D46-D71 } \\ & \mathrm{D} 31,0 \xrightarrow{\longrightarrow} \end{aligned}$ |
| DXNC | NC0-NC31 $\rightarrow$ D0-D31, NC47 $\rightarrow$ D46-D47, NC48-NC63 $\rightarrow$ D48-D63 FAFL $\longrightarrow$ NC64-NC71 $\rightarrow$ D64-D71 NFAFL $\rightarrow 0 \rightarrow$ D64-D67, I's $\rightarrow$ D68-D70, $\mathrm{NCO} \rightarrow$ D71 |
| DXNC/1 | Same as NDXNC and $1 \rightarrow$ CS31 |
| DXNC/2 | $\mathrm{NC0C16} \rightarrow$ D0-D11,NC16-NC31 $\rightarrow$ D16-D31, NC47 $\rightarrow$ D46-D47 $0 \rightarrow$ D48-D71 |
| DXNC/3 | Downward align halfword NC to D according to P32 NP32 $\longrightarrow$ NDXNCR16 P32 $\longrightarrow$ NDXNC/2 |
| DXNCM | Multiplicand control flip-flop (NC $\longrightarrow$ D) |
| DXNCRIG | $\mathrm{NCOC1G} \rightarrow$ D0-D11, $\mathrm{NC0-NC15} \rightarrow$ D16-D31, $0 \rightarrow$ D46-D71 |
| DXPARITY | MFL0-MFL7 $\longrightarrow$ D24-D31, 0's $\longrightarrow$ D0-D23 and D46-D71 |
| DXPCP | $\mathrm{PCP} \longrightarrow \mathrm{D}$ |
| DXPSW1 | $\begin{aligned} & \mathrm{CCl-CC4} \rightarrow \text { D0-D3, FS } \rightarrow \text { D5, FZ } \rightarrow \text { D6, FNF } \rightarrow \text { D7, MASTERF } \rightarrow \text { D8, } \\ & \text { MAPF } \rightarrow \text { D9, DM } \rightarrow \text { D10, AM } \rightarrow \text { D11, } \rightarrow \text { D4, } \rightarrow \text { ' } \rightarrow \text { D12-D31 and D46-D71 } \end{aligned}$ |
| DXPSW2 | WK0-WK1 $\rightarrow$ D2-D3, CIF $\rightarrow$ D5, $\mathrm{II} \rightarrow$ D6, $\mathrm{EI} \rightarrow$ D7, RP23-RP27 $\rightarrow$ D23-D27, 0's $\rightarrow$ D0, D1, D4, D8-D22, D28-D31 and D46-D71 |
| DXTRACC | $\begin{aligned} & \mathrm{TRACC1}+\mathrm{D} 28 \longrightarrow \mathrm{D} 28, \text { TRACC2 }+\mathrm{D} 29 \rightarrow \mathrm{D} 29, \text { TRACC3 }+\mathrm{D} 30 \rightarrow \mathrm{D} 30, \\ & \mathrm{TRACC} 4+\mathrm{D} 31 \rightarrow \mathrm{D} 31 \end{aligned}$ |
| $(E=1)$ | $E=1$ |
| ( $\mathrm{E}=1$ or 2 ) | $E=1$ or 2 |
| E05Z | E0-5 $\neq 0$ |
| E06Z | E0-6 $\neq 0$ |
| EIXI | $1 \longrightarrow \mathrm{El}$ |
| E6X1 | $1 \longrightarrow \mathrm{E} 6$ |
| E7X1 | $1 \rightarrow \mathrm{E} 7$ |
| EDR | Early data release signal from memory after the buffer cable receiver |
| EDRi | Where $\mathbf{i}=\mathrm{A}, \mathrm{B}$, or C . Early data release signal in memory for port $\mathbf{i}$ |

(Continued)

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| ENDE | Signal that is true during the last execution phase of an instruction (end execution) <br> ENDE $\longrightarrow$ NDXC/6 <br> ENDE $\longrightarrow$ NORXC <br> ENDE $\longrightarrow$ NOXC <br> ENDE NHALT N(S/INTRAPF) $\Rightarrow$ S/PREI <br> ENDE $\rightarrow(S / L R X D)$ <br> ENDE HALT $N(S /$ INTRAPF $) \Rightarrow S / P C P I$ <br> ENDE $\longrightarrow$ CLEAR <br> ENDE N(TRAP + HALT + FUEXU + KAHOLD) $\Rightarrow$ PCTPI |
| ES4 | If ES4 is false when MCTE1 is true, $E-4 \rightarrow E$ is performed If ES4 is true when MCTE1 is true, $E-1 \nLeftarrow E$ is performed |
| EX | $0 \longrightarrow$ E0-E7, intermediate control signal |
| EX/1 | $0 \rightarrow E 0-E 7$ |
| EXB | $\mathrm{NB1} \rightarrow \mathrm{E} 0-\mathrm{E} 1, \mathrm{~B} 2-\mathrm{B7} \rightarrow \mathrm{E} 2-\mathrm{E} 7$ |
| EXCC | $\mathrm{CCl}-\mathrm{CC} 4 \rightarrow$ E4-E7, $0 \rightarrow$ E0-E3 |
| EXS | S0-S7 $\longrightarrow$ E0-E7 |
| EXU | Execute flip-flop, high from PH1 through ENDE of all instructions |
| FABC | Family of branch on conditions ( $B C R, B C S$ ) |
| FABO | Family of byte operations (TTBS, TBS, CBS, MBS, EBS) with NPHA |
| FABO/1 | Family decode for MBS, CBS, TBS, and TTBS instructions |
| FABO/2 | Family decode for MBS, CBS, and EBS instructions |
| FABOA | Family of byte operations (TTBS, TBS, CBS, MBS, EBS) with PHA |
| FABOA/1 | Same as FABO/1 with PHA |
| FABOA/2 | Same as FABO/2 with PHA |
| FABOX | Family of byte operations (TTBS, TBC, CBS, MBS, EBS) |
| FABR | Family of branch on decrementing or incrementing register (BDR, BIR) |
| FABRANCH | BDR, BIR, BCR, BCS, BAL |
| FABS | Family decode for byte string instructions (MBS, CBS) |
| FABSA | Same as FABS with PHA |
| FACAL | CALI, 2, 3, 4. Family of CALL instructions |
| FACV | Family decode for conversion (CVA, CVS) |
| FADE | Family decode for decimal (DL, DST, DA, DS, DM, DD, DC, DSA, PAK, UNPK) |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| FADIO | Family of direct and input/output instructions (SIO, TIO, TDV, HIO, AIO, RD, WD) |
| FADIV | Family of divide instructions, fixed-point (DW, DH) |
| FADIVH | DH |
| FADIVW | DW |
| FADW | Family of double word instructions. Consists of 19 instructions, opcodes 08 through 1F, inclusive |
| FAFL | Family decode for floating point arithmetic instructions (FAL, FSL, FML, FDL, FAS, FSS, FMS, FDS) |
| FAFLAS | Floating point add and subtract (FAS, FSS, FAL, FSL) |
| FAFLD | Family of floating divide instructions (FDL, FSD) |
| FAFLM | Family of floating multiply instructions (FML, FMS) |
| FAFLMD | Floating point multiply and divide (FMS, FD, FML, FDL) |
| FAFRR | S, STD, MI |
| FAFRR/1 | DW, MW, STS, FML |
| FAILL | Family of illegal instructions. Consists of all of the following illegal opcodes, both directly and indirectly addressed, plus all indirectly addressed immediate instructions: $00,01,03,0 C, O D$, $14,16,17,26,27,2 C, 2 D, 34,42,43,54,59,5 C, 5 D, 5 E, 5 F, 62$ |
| FAIM | Family of immediate instructions (LCFI, AI, CI, LI, MI, TTBS, TBS, CBS, MBS, EBS) |
| FAIO | Family of input/output instructions (SIO, TIO, TDV, HIO, AIO) |
| FAIO/1 | SIO, TIO, TDV, HIO |
| FAMDSF | Family of multiply, divide, shift, and floating instructions (MW, MH, MI, DW, HD, S, SF, FSL, FAL, FDL, FML, FSS, FAS, FD, FMS) |
| FAMDSF/D | Family of divide instructions (DW, DH, FDL, FDS) |
| FAMDSF/M | Family of multiply instructions (MW, MH, MI, FML, FMS) |
| FAMUL | Family of fixed-point multiply instructions (MW, MH, MI) |
| FAMULH | Family of multiply halfword (MH) |
| FAMULI | Family of multiply immediate (MI) |
| FAMULNH | Family of multiply not halfword (MW, MI) |
| FAMULW | Family of multiply word (MW) |
| FANIMP | Family of nonimplemented instructions. Consists of the floating point, decimal, and edit instructions, but the decoding signal is gated with either NFPOPTION or NDEOPTION |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| FAPRIV | Family of privileged instructions (LPSD, XPSD, WAIT, LRP, MMC, RD, WD, SIO, TIO, TDV, HIO, AIO) |
| FAPSD | Family of program status doubleword instructions (LPSD, XPSD) |
| FARWD | Family of read and write direct instructions (RD, WD) |
| FASI | CLM, CLR |
| FAS2 | SD, CD |
| FAS3 | AD, SD |
| FAS6 | CS, STS, LS |
| FAS7 | MTW, MTH, MTB |
| FAS8 | MTW, AWM |
| FAS9 | XW, OR, EOR, AND |
| FASIO | LAW, LAH |
| FASII | $\mathrm{CI}, \mathrm{CW}, \mathrm{CH}, \mathrm{CB}$ |
| FAS12 | AI, AW, SW, AH, SH |
| FAS13 | MTH, MTB |
| FAS14 | STS, STD |
| FAS15 | CS, LS |
| FASI6 | LCD, LAD, LD |
| FAS17 | LCF, LCFI |
| FAS18 | STCF, STB, STW, STH |
| FASI9 | LCD, LAD |
| FAS21 | LW, LH, LB, LI, LCW, LCH, LAW, LAH |
| FAS22 | AD, CD, SD, CLM, CLR |
| FAS23 | LW, LH, LB, LI, LCW, LCH |
| FAS24 | AWM, MTW, MTB, MTH |
| FAS26 | LCW, LAW |
| FASH | Family of shift instructions (S, SF) |
| FASHFL | Family term for the floating point shift instruction (SF) |

(Continued)

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| FASHFX | Family term for the fixed-point shift instruction (S) |
| FASi | Families of simple opcodes where i equals a number from 1 to 26 |
| FAST/1 | Family of stack instructions (PLW, PSW, PLM, PSM, MSP, LM, STM) |
| FAST | PLM, PSW, PSM, MSP, LM, STM, PLW (with NPHA) |
| FASTA | (FAST PHA) |
| FATR | TBS, TTBS. Family of translate instructions (with NPHA) |
| FATR5 | TBS, TTBS. Family of translate instructions (with NPHA, PH5) |
| FATRA | TBS, TTBS. Family of translate instructions (with PHA) |
| FAW | Family of word instructions. Consists of all of the following opcodes, whether implemented or not: 04-07, 24-3F, 44-4F, 64-6F |
| FEOF | Floating point exponent overflow |
| FEUF | Floating point exponent underflow |
| FLMC | On during next-to-last clock of MIT in floating multiply |
| FLPN | Floating point post-normalize |
| FLRR | Floating point result ready |
| FMOF | Floating point mantissa overflow |
| FPOPTION | Floating point option |
| FPR | Floating point polarity (of result) reversed |
| FSZNXS | $\mathrm{S} 5 \rightarrow \mathrm{FS}, \mathrm{S} 6 \rightarrow \mathrm{FZ}, \mathrm{S7} \rightarrow \mathrm{FNF}$ |
| FUAD | AD |
| FUAND | AND |
| FUANLZ | ANLZ |
| FUAWM | AWM |
| FUBAL | BAL |
| FUCB | CB |
| FUCI | Cl |
| FUCLM | CLM |
| FUCLR | CLR |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| FUCS | CS |
| FUCVS | CVS |
| FUEBS | EBS (with NPHA) |
| FUEBS8 | EBS (with NPHA PH8) |
| FUEBS9 | EBS (with NPHA PH9) |
| FUEBSI4 | EBS (with NPHA PH14) |
| FUEBSA | EBS (with PHA) |
| FUEOR | EOR |
| FUEXD | EXU |
| FUiii | A signal decoded from the opcode register for the function of one particular instruction, iii |
| FUINT | INT |
| FULAD | LAD |
| FULCD | LCD |
| FULD | LD |
| FULI | LI |
| FULRP | LRP |
| FULS | LS |
| FUMMC | MMC |
| FUMTB | MTB |
| FUMTH | MTH |
| FUMTW | MTW |
| FUOR | OR |
| FUSTCF | STCF |
| FUSTD | STD |
| FUSTH | STH |
| FUSTS | STS |
| FUSTW | STW |
| FUWAIT | WAIT |

(Continued)

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| FUXW | XW |
| GN | Where $N=0-31$ or 33 or 47-71. Carry generate term activated by two or more ones in its respective binary digit |
| (S/NGX) | Terms for $-A$ or $-D \longrightarrow S$ (preset) |
| HALT | Flip-flop that causes the CPU to halt in PCP2 |
|  | S/HALT $=$ FUWAIT + NKRUN $/ \mathrm{BPH1}+\mathrm{PCP7}+$ DCSTOP PHI + RESET |
|  | R/HALT $=$ INT NDCSTOP PCP2 KRUN/B + PCP2 NKAS/B |
| HOF | Halt on fault in memory |
| IA | Indirect address flip-flop set by bit 0 of the instruction word |
| IEN | Interrupt enable. An interrupt can be accepted on any clock if this flip-flop is set; otherwise, an interrupt can be accepted only at ENDE |
| INDX | Nonzero index field and not an immediate instruction. Indexing is to be performed |
| INHXWD | True during PH2 of internal mode WD which sets or resets interrupt inhibits |
| INT | Flip-flop indicating that an interrupt request from the interrupt logic is present. Also the mnemonic for the interpret instruction with hexadecimal opcode 6 B or EB |
| INTRAPF | Flip-flop that indicates an XPSD, MTW, MTH, or MTB is being executed as the result of an interrupt or trap |
| (S/INTRAPF/1) | Signal that when true indicates that the CPU is halted by a parity error or an address stop or that the COMPUTE switch is not in RUN |
| INTRAPi | Where $\mathrm{i}=1$ or 2, interrupt or trap phase flip-flops |
| IOPXFCAD | $02 \longrightarrow / \mathrm{FNCO} /, 06 \longrightarrow / \mathrm{FNC1} /, 07 \longrightarrow / \mathrm{FNC2} /, \mathrm{B} 21-\mathrm{B} 23 \longrightarrow / \mathrm{IOPAO}-2 /, \mathrm{CPU} \text { to }$ IOP. Function code lines and IOP address |
| IOPXSTRB | $1 \longrightarrow / \mathrm{CNST} /$, CPU to IOP strobe |
| INTRAPF | The interrupt or trap flip-flop |
| IORESET | Signal that when false indicates that the I/O RESET switch is set or that power is going off or on |
| IX | Index flip-flop set by a nonzero index field (bits 12-14) of the instruction word. |
| K 00 H | Flip-flop for holding K00 (end-carry) for double precision floating shifts |
| K31 | Carry into position 31 of the adder |
| KADDRSTOP | True if ADDR STOP switch is ON |

(Continued)

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| KAHOLD | True if INSTR ADDR switch is in HOLD position |
| $\begin{aligned} & \mathrm{KAS} / 1 \text { and } \\ & \mathrm{KAS} / 2 \end{aligned}$ | If KAS $/ 1$ is true and NKAS $/ 2$ is false, one of the following PCP switches is set: DATA ENTER, DATA CLEAR, STORE SELECT ADDR, STORE INSTR ADDR, INSERT PSW2, INSERT PSWI, COMPUTE STEP, COMPUTE RUN, DISPLAY SELECT ADDR, DISPLAY INSTR ADDR, INSTR ADDR INCREMENT, FILL, or both SYSTEM RESET/CLEAR and CPU RESET/CLEAR |
| KAS/B | If KAS/B is true, one or more of the following PCP switches is set: DATA ENTER, DATA CLEAR, STORE SELECT ADDR, STORE INSTR ADDR, INSERT PSW2, INSERT PSW1, COMPUTE STEP, COMPUTE RUN, DISPLAY SELECT ADDR, DISPLAY INSTR ADDR, INSTR ADDR INCREMENT, FILL, or both SYSTEM RESET/CLEAR and CPU RESET/CLEAR |
| KC | True if CLOCK MODE switch is in SINGLE STEP position (normally open contact) |
| KC/B | True if CLOCK MODE switch is in SINGLE STEP position (normally closed contact generates NKC/B) |
| KCLEARD/B | True if DATA CLEAR switch is set |
| KCPURESET | True if CPU RESET switch is set (normally open contact) |
| KCPURESET/B | True if CPU RESET switch is set (normally closed contact generates NKCPURESET/B) |
| KD | True if REGISTER DISPLAY switch is in the ON position and CLOCK MODE switch is not in the CONT position |
| KDISPLA/B | True if either the DISPLAY SELECT ADDR switch or the DISPLAY INSTR ADDR switch is set |
| KDISPLAK/B | True if DISPLAY SELECT ADDR switch is set |
| KDISPLAQ/B | True if DISPLAY INSTR ADDR switch is set |
| KDSHI | True if REGISTER SELECT switch is in any of the following positions: $\mathrm{AH}, \mathrm{BH}, \mathrm{CSHE}, \mathrm{DH}, \mathrm{SH}$ |
| KENTERD/B | True if DATA ENTER switch is set |
| KFILL/B | True if LOAD switch is set |
| KHOP | True if PARITY ERROR MODE switch is in the HALT position |
| Kii | Where $\mathrm{i}=0-31$ or 47-70. Carry into position NN of adder |
| KIDLE/B | True if COMPUTE switch is in the IDLE position |
| KINCRE/B | True if INSTR ADDR INCREMENT switch is set |
| KINLVSEL | True if INTERLEAVE SELECT switch is in the DIAGNOSTIC position |
| KINTRP | True if INTERRUPT switch is set (normally open contact generates NKINTRP) |
| KINTRP/B | False if INTERRUPT switch is not set (normally closed contact) |
| KIORESET | True if I/O RESET switch is set |
| KNCO | True if DATA 0 switch is in either center or in the 1 position |

(Continued)

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| KNCl-31 | Same as KNC0 for switch positions 1-31 |
| KPSW/B | True if either the INSERT PSW1 switch or the INSERT PSW2 switch is set |
| KPSWI/B | True if INSERT PSWl switch is set |
| KPSW2/B | True if INSERT PSW2 switch is set |
| KRUN/B | True if the COMPUTE RUN switch is set |
| KSO | True if DATA 0 switch is in the 1 position |
| KS1-31 | Same KSO for switch positions 1-31 |
| KSC | True if CLOCK MODE switch is not in the CONT position |
| KSHI | True if REGISTER DISPLAY switch is in the ON position, CLOCK MODE switch is not in the CONT position, and REGISTER SELECT switch is in any of the following positions: AH, BH, CSHE, DH, SH |
| KSP15 | True if SELECT ADDRESS switch 15 is in the 1 position |
| KSP16-31 | Same as KSP15 for switch positions 16-31 |
| KSS1 | True if SENSE 1 switch is in the ON position |
| KSS2-4 | Same as KSSI for switch positions 2-4 |
| KSTEP/B | True if COMPUTE STEP switch is set |
| KSTOR/B | True if either the STORE INSTR ADDR switch or the STORE SELECT ADDR switch is set |
| KSTORK/B | True if the STORE SELECT ADDR switch is set |
| KSTORQ/B | True if the STORE INSTR ADDR switch is set |
| KSXA | True if the REGISTER SELECT switch is either in the AL or AH position |
| KSXB | True if REG ISTER SELECT switch is either in the BL or BH position |
| KSXCS | True if REGISTER SELECT switch is either in the CSL or CSHE position |
| KSXD | True if REGISTER SELECT switch is either in the DL or DH position |
| KSXP | True if REGISTER SELECT switch is in the $P$ position |
| KSXS | True if REGISTER SELECT switch is either in the SL or SH position |
| LB31/1 | OR-gates a 1 into register address for doubleword operation |
| LBii | Where $\mathrm{ii}=15-31$. Address lines to memory |
| /LBii/ | Where $\mathrm{i} \mathrm{i}=15-31$. Core memory address lines to memory after all CPU logic |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| L/LK | Memory protection flip-flop address |
| LMii | Where $\mathrm{i}=15-31$. Memory address lines into the map logic |
| LMXC | Transfer onto the address lines into the map logic from the C -register. C15-C22 $\longrightarrow$ LM15-LM22, C23-C31 $\longrightarrow$ LB23-LB31 |
| LMXQ | Transfer onto the address lines into the map logic from the Q-register. Q15-Q22 $\longrightarrow$ LM15-LM22, Q23-Q31 $\longrightarrow$ LB23-LB31 |
| LR31/2 | Flip-flop to force $1 \longrightarrow$ LR31 (preset) |
| LRXD | Transfer onto the address lines for the registers from the D-register index bits. D12-D14 $\longrightarrow$ LR29-LR31. Also resets LRXR |
| LRXLB | $L B \longrightarrow L R$ (crossover) |
| /LRii/ | Where $\mathrm{i}=23-31$. The address lines for the registers in the fast memory |
| LRXR | Transfer onto the address lines for the registers from the flip-flops holding the R-field of the instruction. R28-R31 $\longrightarrow$ LR28-LR31 |
| MAA | Memory state flip-flop for no memory requests pending |
| MAP | If this signal is true, program addresses are transformed by the map |
| MAPDIS | Map disconnect. This flip-fio, inhibits mapping regardless of the state of MAPF |
| MAPF | Map flip-flop holding the mapping bit of program status word 1 |
| MASTER | If this signal is true, the CPU operates in the master mode. MASTER will be true if either MASTERF or INTRAPF is high |
| MASTERF | Master flip-flop holding the master/slave bit of program status word 1 |
| MBB | Memory state flip-flop for one memory request sent and address release not yet received |
| MBii | Where $\mathrm{ii}=00-31$. Memory data lines to and from CPU |
| MBXS/0 | S0-S7 $\longrightarrow / \mathrm{MBO}-\mathrm{MB7} / \mathrm{l} \mathrm{l} \longrightarrow / \mathrm{MWO} /$ special action if LRXLB is true |
| MBXS/I | S8-S15 $\longrightarrow / \mathrm{MB8}-\mathrm{MB15} / \mathrm{l} \longrightarrow / \mathrm{MWI} /$ special action if LRXLB is true |
| MBXS/2 | S16-S23 $\longrightarrow / \mathrm{MB16-MB23/}, \longrightarrow / \mathrm{MW} 2 /$ special action if LRXLB is true |
| MBXS/3 | S24-S31 $\longrightarrow / \mathrm{MB24-MB31/} 1 \mathrm{l} \longrightarrow / \mathrm{MW} 3 /$ special action if LRXLB is true |
| MCC | Memory state flip-flop for one memory request sent and address release received |
| MCTE1 | $\mathrm{ES4} 4 \mathrm{E}-1 \longrightarrow \mathrm{E}$; NES4 $\Rightarrow \mathrm{E}-4 \longrightarrow \mathrm{E}$; minus count exponent by one |
| MCTP 1 | Minus count the P-register (decrement), flip-flops P26-P31 minus one |

(Continued)

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| MCTP2 | Minus count control for P26-P29 (equals MCTP1 NP30 NP31) |
| MCTP5 | Minus count the P-register (decrement). Only used to count P15-P18 down from 0000 to 1111 |
| MCTR | Minus count the R-register, $\mathrm{R}-1 \longrightarrow \mathrm{R}$ |
| MDD | Memory state flip-flop for remembering that a second memory request has been sent before the first request has received its data release |
| MEE | Memory state flip-flop for a satisfied first memory request, but a pending second request |
| MFF | Memory state flip-flop for one memory request sent and early data release received |
| MFLi | Where $\mathbf{i}=0-7$. Core memory fault lights |
| MGG | Memory state flip-flop for one memory request sent and data release received |
| MIT | Flip-flop high during multiply iterations |
| MITEX | Flip-flop exit from MIT (high during last clock) |
| MULC | Flip-flop, on during next to last clock if MIT in fixed multiply |
| MUSIC | If the alarm flip-flop is off, the music flip-flop drives the PCP speaker |
| MW | Write word to core memory MW $\Rightarrow$ MBXS $/ 0-3$ |
| MWB | Write byte to core memory according to P32 and P33 |
|  | $\begin{aligned} & \text { NP32 } N \text { N33 } \Rightarrow \text { MBXS } / 0 \\ & \text { NP32 P33 } \Rightarrow \text { MBXS } / 1 \\ & \text { P32 } \\ & \text { NP33 } \Rightarrow M B X S / 2 \\ & \text { P32 P33 } \Rightarrow M B X S / 3 \end{aligned}$ |
| MWBO | Write to core memory byte 0 |
| MWB1 | Write to core memory byte 1 |
| MWB2 | Write to core memory byte 2 |
| MWB3 | Write to core memory byte 3 |
| MWH | Write halfword to core memory according to P32 |
|  | $\begin{aligned} & \text { NP32 } \Rightarrow M B X S / 0, M B X S / 1 \\ & \text { P32 } \Rightarrow M B X S / 2, M B X S / 3 \end{aligned}$ |
| MMC | Move to memory control, hexadecimal opcode 6F or EF (privileged) |
| MNN | Margins not normal (from PT16 logic power supplies) |
| MP19 | Flip-flop represents P19 during multiply iterations |
| MPP | Multiply preparation |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| $M Q i$ | Where $\mathrm{i}=\mathrm{A}, \mathrm{B}$, or C . Request for core memory access through port $\mathbf{i}$ |
| MR | Any CPU core memory request. MR through a cable driver becomes/MQC/ |
| MRDL | Memory request delay line |
| MRTC | Memory request timing control |
| MRQ | Causes a request for memory service with the P -register specifying the address. Special action if $\mathrm{P} 15-\mathrm{P} 22=0$ |
| (S/MRQ/1) | Sets $M R Q$ and causes $Q \nrightarrow P$. Use to initiate accessing of next instruction when set $R Q$ is not allowed |
| MWH | Write to memory, halfword |
| MWiA | Where $\mathbf{i}=0-3$. Memory write byte lines |
| MWiB | Where $\boldsymbol{i}=0-3$. Memory write byte lines |
| MWiC | Where $\mathrm{i}=0-3$. Memory write byte lines |
| MWN | Flip-flop memory word negative |
| Oi | Where $\mathbf{i}=1-7$. The opcode register which remembers bits $1-7$ of the instruction word |
| OLi | Where $\mathbf{i}=0$ through F . The decoding of the low order four bits of the opcode field, using the opcode register flip-flops O4, O5, O6, and O7 |
| OPRQ | Dc flip-flop that is true during preparation for those instructions for which the memory request for an operand is made during preparation |
| ORIL | Override interleave |
| ORSP | Override slow sorts |
| ORXC | $\mathrm{C} 0 \rightarrow \mathrm{IA}, \mathrm{Cl}-\mathrm{C} 7 \rightarrow \mathrm{Ol}-\mathrm{O} 7, \mathrm{C8}-\mathrm{Cll} \rightarrow \mathrm{R} 28-\mathrm{R} 31$ |
| OUi | Where $\mathbf{i}=0-7$. The decoding of the high order (upper) three bits of the opcode field, using the opcode register flip-flops $\mathrm{O} 1, \mathrm{O} 2$, and O 3 |
| OVER | Overflow signal, true if $\mathrm{AO}=\mathrm{DO}=1$ and $\mathrm{K} 0=0$ or if $\mathrm{A} 0=\mathrm{DO}=0$ and $\mathrm{K} 0=1$ |
| OX/1 | $1 \rightarrow \mathrm{O} 1,0 \rightarrow \mathrm{O} 2-\mathrm{O} 4,1 \rightarrow \mathrm{O}, 0 \rightarrow \mathrm{O} 6-\mathrm{O} 7$ |
| OXC | Load the O -register from C . $\mathrm{Cl}-\mathrm{C} 7 \rightarrow \mathrm{Ol-O7}$ also load the indirect address flip-flop. $\mathrm{CO} \nrightarrow \mathrm{IA}$ |
| P1929W | P19-29 contain ones |
| P2329W | P23-29 contain ones |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| P2629W | P26-29 contain ones |
| P2629Z | P26-29 contain zeros |
| P312 | Force P31 = 0 if S $\longrightarrow \mathrm{P}$ (used in double operand accessing for even location word) |
| PA22 | Positive add with P22 instead of P20 as the least significant flip-flop |
| PA33 | Positive add (or decrement) with P33 instead of P31 as the least significant flip-flop |
| PCB | Indicates that CPU is operating in map mode and not in master mode |
| PCP | True during PCP2-PCP6 |
| PCPi | Where $\mathrm{i}=1-7$. Processor control panel phase flip-flops |
| PCTEI | $E+1 \longrightarrow E$ |
| PCTP1 | Plus count the P-register (increment): if NPA33, then P15-P31, plus one, if PA33, then P15-P33 plus one |
| PCTP2 | Plus count control for P26-P29 |
| PCTP2/1 | PCTP1 and carry information from P30-P33 |
| PCTPIDIS | PCTPI disable, prevents incrementing of P -register |
| PCTP3 | Plus count control for P23-P25 (equals PCTP2/1 P2629W) |
| PCTP4 | Plus count control for P19-P22 (equals PCTP2/1 P2329W + PCTP4/1) |
| PCTP4/1 | Plus count the P -register (increment): if NPA22, then P15-P20 plus one, if PA22, then P15-P22 plus one |
| PCTP5 | Plus count control for P15-P19 |
| PCTP5/3 | Plus count the P-register flip-flops P15-P18 |
| PCTR | $R+1 \longrightarrow R$ |
| PE | Core memory parity error. /PEC/through a cable receiver becomes PE |
| PEFI and PEF2 | Flip-flops used to generate 3-ns interrupt input signal when a parity error is signaled from memory |
| PEi | Where $\mathrm{i}=\mathrm{A}, \mathrm{B}$, or C . Core memory parity error signal sent from port $\mathbf{i}$ |
| PEI | Parity error interrupt signal |
| PEL | Dc flip-flop set by parity error signal from memory |
| PFSR | Power fail-safe and reset signal to memory |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| PHA | Additional phase flip-flop used to generate 15 additional phases for complex instructions (that is, PHI, NPHA-PHI5 NPHA, PHI PHA-PHI5 PHA). Used by stack and byte string instructions |
| PHi | Instruction execution phase flip-flops where $i=1-15$ |
| Pii | Where $\mathrm{i}=15-33$. The P -register flip-flops for holding program address, and counting for various instructions |
| POF | Buffered power off |
| PON | Buffered power on |
| PREDO | Preparation for double operand instructions (AD, CD, LD, SD, CLM, LCD, LAD). Generated from the O-register |
| PREFADO | True for those instructions requiring two operands during preparation. Generated from the C-register |
| PREFLL | True for floating long instructions that require during preparation only, one operand which must be the low order 32 bits of a memory doubleword. Generated from the C-register |
| PREi | Preparation phase flip-flops where $i=1,2,3$, or 4 |
| PREIM | Preparation for some immediate instructions (LCFI, AI, LI, CBS, MBS, EBS) which go from PREI directly to PHI during preparation. Generated from the O-register |
| PREOPRQ// <br> and <br> PREOPRQ/2 | One of these signals will be true for all instructions requiring either one or two operands during preparation. Generated from the C-register |
| PREP | True during PRE1 through PRE4 |
| PRERQ | True for those instructions for which RQ should be set during preparation |
| PRi | Where $\mathbf{i}=0-32$ or 47-71. Carry propagate term activated by an odd number of ones in its respective binary digit |
| PROTECTD | Protect or lock fail on data flip-flop to be sensed at data ready clock; sets trap unless specially prevented |
| PROTECTDIS | Protect disable. This signal inhibits PROTECTD from causing a trap |
| PROTECTI | Protect or lock fail on instruction flip-flop sensed at ENDE only |
| PRX | Carry propagate enable flip-flop for addition and exclusive OR functions |
| PSWIXS | SO -S3 $\rightarrow \mathrm{CCl}-\mathrm{CC} 4, \mathrm{~S} 8 \rightarrow$ MASTERF, $\mathrm{S} 9 \rightarrow \mathrm{MAPF}, \mathrm{SIO} \rightarrow \mathrm{DM}, \mathrm{S11} \rightarrow \mathrm{AM}$ |
| PSW2XD | D2-D3 $\rightarrow$ WK0-WK1, D5 $\rightarrow$ CIF, D6 $\rightarrow$ II, D7 $\rightarrow$ EI, D23-D27 $\rightarrow$ RP23-RP27 Special action to WKO and EI during RESET/B |
| PX | $0 \rightarrow$ P15-P33 |
| PX/1 | $0 \rightarrow$ P32-P33 |
| PX/2 | $0 \rightarrow$ P15-P22 |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| PX20 | $1 \rightarrow$ P26 for load |
| PXINT | INT0-INT8 $\rightarrow$ P23-P31, $0 \rightarrow \mathrm{P} 15-\mathrm{P} 22,0 \rightarrow \mathrm{P} 32-\mathrm{P} 33$ |
| PXK | KSP15-KSP31 $\rightarrow$ P15-P31, $0 \rightarrow$ P32-P33 |
| PXP3233 | P32 and P33 P32 and P33 when PXS |
| PXQ | Q15-Q31 $\rightarrow$ P15-P31, $0 \rightarrow$ P32-P33 |
| PXS | S15-S30 $\rightarrow$ P15-P30, S31 NP31Z $\rightarrow$ P31, P32-P33 $\rightarrow$ P32-P33 |
| PXS/1 | S15-S30 P P15-P30, S31 NP31Z $\rightarrow$ P31, S0-S1 $\rightarrow$ P32-P33 |
| PXTR | $1 \rightarrow$ P25, TR28-TR31 P $\rightarrow$ P28-P31, $0 \rightarrow$ P15-P24, $0 \rightarrow$ P26-P27, $0 \rightarrow$ P32-P33 |
| RATE/L | Signal that drives the instruction rate indicator on the free-standing console. Driven by PRE1 |
| RESET | CPU RESET switch (normally open contact) if NKAS/B is true, or Start signal from the power monitor option |
| RESET/B | CPU RESET switch (normally closed contact) if NKAS/B is true |
| RESETCL | Reset signal for clock |
| Rii | Where $\mathrm{i}=28-31$. The register address flip-flops holding the R-field from the instruction |
| RIDL | Memory request in delay line |
| RIP | Memory request in progress |
| RN | Flip-flop high when $R$ is negative |
| W/RPOBO/0 | Write control line for register page 0, byte 0, bit 0 |
| W/RPaBb/c | Where $a=0-3, b=0-3$, and $c=0-31$ : similar to W/RPOBO/0 |
| RPii | Register page flip-flops where ii equals 23-27 |
| RPXD | D23-D27 $\longrightarrow$ RP23-RP27 |
| RQ | $R Q$ is set during certain instructions at the same time as the memory request for the last operand required by that instruction. If $R Q$ is set when the address release signal associated with that operand access is received, another memory request is initiated with the $Q$-register specifying the address. Since the $Q$-register contains the address of the next instruction, $R Q$ results in the next instruction being accessed |
| RQC | RQC causes a memory request during either PRE1 or PRE4. The C-register specifies the address |
| RRii | Where $\mathbf{i i}=00-31$. Register read (fast memory) data lines |
| /RRWii/ | Where ii $=00-31$. Register read and write (fast memory) data lines on bidirectional cable |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| RRWXS-0 | S0-S7 $\longrightarrow /$ RRW0/through /RRW7/: byte 0 |
| RRWXS-1 | S8-S15 $\longrightarrow$ /RRW8/ through /RRW15/: byte I |
| RRWXS-2 | S16-S23 $\longrightarrow$ /RRW16/through /RRW23/: byte 2 |
| RRWXS-3 | S24-S31 $\longrightarrow$ /RRW24/ through /RRW31/: byte 3 |
| RTZ | Flip-flop high when the result is 0 |
| RUN/L | PCP RUN light |
| RW | Write word to fast memory RW $\Longrightarrow$ RWB0-RWB3 |
| RWBi | Where $\mathbf{i}=0-3$. Control for RRWXS-i. Register write byte $\mathbf{i}$ |
| RWDIS | Register (fast memory) write disable. When RWDIS is true, RWBO-RWB3 do not cause a write into fast memory |
| RWii | Where i ( $=00-31$. Register write (fast memory) control lines |
| RWXS -0 | S0-S7 $\longrightarrow$ RW0-RW7: byte 0 |
| RWXS-1 | S8-S15 $\longrightarrow$ RW8-RW15: byte 1 |
| RWXS-2 | S16-S23 $\longrightarrow$ RW16-RW23: byte 2 |
| RWXS-3 | S24-S31 $\longrightarrow$ RW24-RW31: byte 3 |
| RXI | R28-R3i loaded by clock with ones |
| $R Z$ | $\mathrm{R}=0$ |
| QX26 | Set $Q=X^{\prime} 26^{\prime}$ |
| QXP | P15-21 $\rightarrow$ Q15-31 |
| S00XK00 | SOOXK00 $\Rightarrow 1 \longrightarrow$ S00X |
| SOOXN | SOOXN $\Rightarrow N(A 0 \oplus D 0) \longrightarrow S 00 X$ |
| S00XP | SOOXP $\Rightarrow(A 0 \oplus D O) \longrightarrow$ S00X |
| SCl | A flip-flop clocked by the 1.024 MHz clock used to detect the SINGLE STEP switch when single clocking |
| SC2 | A flip-flop clocked by the 1.024 MHz clock. SC2 is the same as SC1 delayed by $1 \mu \mathrm{~s}$ |
| SCD | SCD is a buffer latch used during single clocking to disable CE after a clock has occurred as a result of setting the SINGLE STEP switch |
| SCEN | Single clock enable. When SCEN is false during single clocking, CE does not go false after the first clock, but stays true, allowing another clock to occur. Used when single clocking interrupt processing |

(Continued)

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| SDIS | Select display. When SDIS is false, the register selected by the REGISTER SELECT switch is displayed in the DISPLAY REGISTER |
| SFTL | Shift left |
| SFTLI | Shift left one binary place |
| SFTL4 | Shift left four binary places (one hexadecimal place) |
| SFTR | Shift right |
| SFTR2 | Shift right two binary places |
| SHEX | Exit from shifting phase of shift instructions |
| SHPC | P control flip-flop used in shifts |
| SRA | Second memory request allowed signal from memory after CPU cable receiver |
| SRAF | Second memory request allowed flip-flop (actually buffer latch) set by SRA and reset by AR or RESETM |
| SRAi | Where i $=A, B$, or $C$. Second core memory access request allowed |
| ST | Start signal from the power monitor during power on and power off |
| START | Buffered ST signal |
| STRAP | A dc buffer latch that causes a trap to occur if WDTLATCH is set |
| SWi | Where $\mathbf{i}=1-4$. Four general purpose flip-flops for use during instruction execution |
| SXA | A0-A31 $\longrightarrow$ S0-S31, A47-A71 $\longrightarrow$ S47-S71 |
| SXA/1 | $\mathrm{A} \longrightarrow \mathrm{SO}-\mathrm{S} 23$ |
| SXA/2 | $A \longrightarrow$ S24-S31 |
| SXA/3 | A47-A71 $\longrightarrow$ S47-S71 |
| SXADD | $\begin{aligned} & \text { PR0 }+\mathrm{K} 0 \longrightarrow \text { S0, PR1 }+\mathrm{K} 1 \longrightarrow S 1, \ldots \mathrm{PR} 31+\mathrm{K} 31 \longrightarrow \text { S31, PR47 }+\mathrm{K} 47 \longrightarrow \mathrm{~S} \longrightarrow \mathrm{~S} 47, \\ & \ldots \mathrm{SR} 70+\mathrm{K} 70 \longrightarrow \mathrm{~S} 0, \mathrm{PR} 71+\mathrm{K} 00 \longrightarrow \mathrm{~S} 1 \end{aligned}$ |
| SXB | B0-B31 $\longrightarrow$ S0-S31, B47-B71 $\longrightarrow$ S47-S71, special action to B0 during FAMUL and FAFLM |
| SXCS | $\mathrm{CSO}-\mathrm{CS31} \longrightarrow$ S0-S31, $\mathrm{CS} 47-\mathrm{CS} 71 \longrightarrow$ S47-S71 |
| SXD | D0-D31 $\longrightarrow$ S0-S31, D47-D71 $\longrightarrow$ S47-S71 |
| SXD/1 | D24-D31 $\longrightarrow$ S24-S31, D47 $\longrightarrow$ S47 |
| SXD/2 | D16-D31 $\longrightarrow$ S16-S31, D47 $\longrightarrow$ S47 |

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| SXK | $\mathrm{K} \longrightarrow \mathrm{S}$ |
| SXK/1 | $\mathrm{K} \longrightarrow$ S0-S7 |
| SXP | $\mathrm{P} 15-\mathrm{P} 31 \longrightarrow$ S15-S31, P32-P33 $\longrightarrow$ S0-S1 |
| SXPR | PR0-PR31 $\longrightarrow$ S0-S31, PR47-PR71 $\longrightarrow$ S47-S71 |
| SXPR/1 | $\mathrm{PR} \longrightarrow$ S0-S7 |
| SXUAB |  |
| SXUAH | $\begin{aligned} & \mathrm{K} 15-\mathrm{K} 30 \longrightarrow \text { S0-S15, A16 } \longrightarrow \mathrm{B} 16 \longrightarrow \text { S16, A17 }+\mathrm{B} 17 \longrightarrow \text { S } 17, \ldots, \mathrm{~A} 31+\mathrm{B} 31 \longrightarrow \\ & \mathrm{~S} 31, \mathrm{~B} 47 \longrightarrow \text { S47. Load S with an upward aligned halfword } \end{aligned}$ |
| SXUAH/1 | $\mathrm{K} 15-\mathrm{K} 30 \longrightarrow$ SO-S15 |
| TIL | T1 clock request line for 150-ns period clock for multiply inner loop |
| T10L | Replace T6L when addressing any private memory bank whose address is greater than three |
| TIOLE | T10 clock request line enable |
| TILEE | TIL even enable |
| TILOE | TIL odd enable |
| TILPE | TIL post enable; time interval between last TIL clock and next clock (T6L or T8L) |
| T4L | T4 clock request line for 280-ns period clock. Index add, straight forward operation without carry |
| T4RL | Sets T4L if RP contains $0,1,2$, or 3 ; sets T10L otherwise |
| T6L | T6 clock request line for 320-ns period clock |
| T6RL | Sets TIOL if PR does not contain $0,1,2$, or 3 when reading out of fast memory |
| T8L | T8 clock request line for 380 -ns period clock. Use for write to scratchpad when it would have been T4L, if it were $S \longrightarrow A$; that is, four levels extra for writing to scratchpad. Also for controls with late inputs |
| TESTA and TESTA/I | TESTA NTESTA/ $1 \Rightarrow$ NA0 NA003IZ $\rightarrow$ CC3 <br> TESTA/1 $\Rightarrow$ NKOOH NA0031Z $\rightarrow$ CC3 <br> TESTA NTESTA/ $1 \Rightarrow \mathrm{~A} 0 \rightarrow \mathrm{CC} 4$ <br> TESTA/1 $\Rightarrow \mathrm{KOOH}$ NA0031Z $\rightarrow \mathrm{CC} 4$ |
| TiL | Ti clock request line to clock generator where $i=1,4,6,8$, or 10 |
| TP100 | Timing point 100, 100 ns from last falling to next leading edge (CPU DLI/140) |
| TP140 | Timing point 140, 140 ns from last falling to next leading edge (CPU DLI/180) |

(Continued)

Table 3-154. Glossary of CPU Signals (Cont.)

| Signal | Definition |
| :---: | :---: |
| TP520 | Timing point 520 (DL2/260) |
| TP560 | Timing point 560 (DL2/300) |
| TP700 | Timing point 700 (DL2/140) |
| TP1140 | Timing point 1140 (DL2/280) |
| TP1180 | Timing point 1180 (DL2/020) |
| TP1300 | Timing point 1300 (DL2/140) |
| TP1300E | TP1300 enable |
| TR28-TR31 | Four flip-flops that are set when TRAP is set. TR28-TR31 + 64 is the trap address |
| $\begin{aligned} & \text { TRACC1 - } \\ & \text { TRACC4 } \end{aligned}$ | Four trap condition code flip-flops that are set when TRAP is set. TRACC1-TRACC4 are merged into the CC-register and are added to the P -register during the XPSD caused by a trap |
| TROVER | Trap on fixed point overflow when $A M$ is high |
| WAIT/L | PCP WAIT light |
| WCTi | Where $\mathbf{i}=1-6$. Watchdog counter flip-flops |
| WDLATCH | Watchdog latch set by $40 \mu \mathrm{scount}$ (WDTA) and reset by TRAP |
| WDTA | Watchdog timer activate, high when the watchdog counter has counted 40 ms |
| WDTR | Watchdog timer restart |
| WDTRAC | Watchdog timer restart and check for present count of 40 ms |
| WKi | Where $\mathbf{i}=0$ or 1 . Write key flip-flops for protection against writing into memory |
| WRITE | WRITE is true whenever a write to core memory is taking place |

Table 3-155. Glossary of Interrupt Signals

| SIGNAL | DEFINITION |
| :--- | :--- |
|  |  |

Table 3-155. Glossary of Interrupt Signals (Cont.)

| SIGNAL | DEFINITION |
| :---: | :---: |
|  | Internal Interrupts |
| NAE | Not arm and enable. A decode of the WD function code |
| AEADB | (Arm and enable) or (arm and disable) |
| AEENLE | (Arm and enable) or (enable) or (load enables) |
| AIB | Control flip-flop set by LEVACT, the leave-active-state signal from the CPU. This flip-flop, if set, remains true for one clock period. Part of the logic for turning off the arm flip-flop |
| AIEA | Control flip-flop set by ENTACT, the enter-active-state signal from the CPU. This flip-flop, if set, remains true for one clock period |
| AIEB | Control flip-flop set by AIEA. This flip-flop, if set, remains true for one clock period |
| ARE | Action response to the CPU. Acknowledges receipt of an enter-active-state signal or a leave-activestate signal |
| ARMCTR | Arm counter group signal. Sets arm flip-flop when counter group leaves active state |
| ARMIO | Arm input/output interrupt signal. Sets arm flip-flop when I/O group leaves active state |
| ARMOVD | Arm override interrupt signal. Sets arm flip-flop when override group leaves active state |
| BUSI | Priority chain busy signal |
| /BUSI/ | Cable input signal to the counter group |
| BUS2 | Priority chain busy signal |
| /BUS2/ | Cable input signal to the I/O group |
| CHAO | Override group active signal |
| CHAI | Counter group active signal |
| CHA2 | I/O group active signal |
| Cl | Counter interrupt group inhibit. Bit position 37 of the WD PSD. If CI contains a one, counter interrupts are inhibited |
| CNA | Control flip-flop. Set by the enable WD mode signal EWDM through SCNA |
| CNB | Control flip-flop. Set by the true output of flip-flop CNA |
| CNLK | Service request interlock control flip-flop |
| CNLN7 | Counter group requesting address line 7 |
| CNLN8 | Counter group requesting address line 8 |

(Continued)

Table 3-155. Glossary of Interrupt Signals (Cont.)

| SIGNAL | DEFINITION |
| :---: | :---: |
|  | Internal Interrupts |
| CNRQ | Counter group service request |
| CNTZREQ | Counter zero request |
| CPULI, CPUL2, CPUL3, and CPUL4 | Counter-count-pulse 1, 2, 3, or 4 service request |
| CPUREST | CPU reset buffer. When this term is true, all is and IP flip-flops are reset |
| /CPURST/ | RESET-1 cable driver |
| NCPURST | RESET-1 inverter |
| DARM | Disarm. A decode of the WD function code. Reset term for IS and IP flip-flops |
| DAT16 through DAT31 | Data signals transmitted to the external interrupts |
| DATA16 through DATA31 | Buffers for data and control bits 16-31 of the WD interrupt control instruction. Inputs from the CPU to these buffers are /DIO16/ through /DIO30/ |
| NDB | Not disable. A decode of the WD function code |
| /DIO37/ <br> through /DIO39/ | Direct $\mathrm{I} / \mathrm{O}$ signals of the WD interrupt control instruction decoded to form function lines ADDRO5, ADDR06, and ADDR07 |
| /DIO44/ through /DIO47/ | Direct I/O signals of the WD interrupt control instruction decoded to form group address lines ADDR12 through ADDR15, which become GRPADR00-GRPADR03 |
| /DIO48/ | Function strobe signal from the CPU |
| /DIO49/ | Function strobe acknowledge signal sent to the CPU |
| EI | External interrupt group inhibit. Bit position 39 of the WD PSD. If EI contains a one, external interrupts are inhibited |
| ENCNTR | Enable counter group |
| ENEXSTR | (Enter strobe) or (exit strobe) |
| /ENEXSTR/ | ENEXSTR driver |
| ENFNL | Enable function lines. This term goes true as the result of the EWDM mode signal having been true. See RCENFNL |

Table 3-155. Glossary of Interrupt Signals (Cont.)

| SIGNAL | DEFINITION |
| :---: | :---: |
|  | Internal Interrupts |
| ENIO | Enable I/O group |
| ENOVRD | Enable override group |
| ENTACT | Enter active state signal from the CPU |
| EWDM | Enable WD mode signal. This signal is true if FNL00, FNL01, or FNL02 is true |
| EWDMI and EWDM2 | Buffer amplifiers for EWDM |
| FNLOO, FNLO1, and FNL02 | Function lines carrying bits from the WD control instruction for control of the IS, IN, and IP flip-flops |
| /FNLOO/, /FNL01/, and /FNLO2/ | Input drivers for FNL00, FNL01, and FNL02 |
| FS | Function strobe from the CPU |
| FSA | Function strobe acknowledge signal to the CPU |
| GARF | Action response flip-flop. One of the input terms to the ARE buffer |
| GATCLOCK | The $1-\mathrm{MHz}$ clock gated by the AIEA control flip-flop. When AIEA is set, there is no clock pulse. GATCLOCK is the gated clock input to the interrupt level flip-flops IN, IS, and IP |
| GCLK1 and GCLK2 | One megahertz gated clock signal. Same signal as GATCLOCK, but through different buffers |
| /GPADRO/ <br> through /GPADR3/ | Buffer cable drivers driven by GRPADR00-GRPADR03 |
| GRPO | Internal interrupt group select signal. This signal selects the group to be acted upon by the WD instruction. GRPO includes all internal interrupts except PONN and POFF |
| GRPADROO throgh GRPADR03 | Group address lines from the WD control instruction. These lines specify which group of interrupts are acted upon |
| HBZI | Higher-priority-group -busy signal received by counter group |
| HBZ2 | Higher-priority-busy signal received by I/O group |
| HRQBZI | Higher-priority-group-requesting-or-busy signal received by the counter group |
| HRQBZ2 | Higher-priority-group-requesting-or-busy signal received by the l/O group |
| NHRQ1 | An inverter with the input RQY1, counter group request signal |

(Continued)

Table 3-155. Glossary of Interrupt Signals (Cont.)

| SIGNAL | DEFINITION |
| :---: | :---: |
|  | Internal Interrupts |
| NHRQ2 | An inverter with the input RQY2, the I/O group request signal |
| II | The I/O interrupt group inhibit. Bit position 38 of the WD PSD. If II contains a one, I/O interrupts are inhibited |
| IB0 | Reset highest active level of the override group |
| IB1 | Reset highest active level of the counter 0 group |
| IB2 | Reset highest active level of the I/O group |
| IE0 | Set highest waiting level to active for override group |
| IE1 | Set highest waiting level to active for counter 0 group |
| IE2 | Set highest waiting level to active for I/O group |
| IEN | Interrupt enable. An interrupt can be accepted on any clock if this flip-flop is true. Used to interrupt during multi-operand instructions |
| IN0 through IN 15 | Level enable flip-flops for a group of 16 interrupts. An IN flip-flop is one of three basic flip-flops for each interrupt level and is physically located on an LT16 module |
| INT | Set-reset flip-flop set by INT9. INT indicates that an interrupt request from the interrupt logic is present |
| INT0 through INT8 and /INT00/ through /INT08/ | Interrupt buffer cable receivers for / INT00/through /INT08/. These terms designate the interrupt address location in memory interrupt service routine address lines |
| INT9 | Interrupt service request |
| /INT09/ | Interrupt address request sent to the CPU |
| /INT11/ | PCP interrupt light signal |
| /INT12/ | One megacycle clock signal to the CPU |
| /INT13/ | One kilocycle clock signal to the CPU |
| INT14 through INT26 | Control signals from the CPU |
| INTRAPI | Interrupt (or trap) phase flip-flop |
| INTRAP2 | Interrupt (or trap) phase flip-flop |

Table 3-155. Glossary of Interrupt Signals (Cont.)

| SIGNAL | DEFINITION |
| :---: | :---: |
|  | Internal Interrupts |
| INTRAPF | Set-reset flip-flop, which indicates an XPSD, MTW, MTH, or MTB is being executed as the result of an interrupt or trap |
| IOLN7 | I/O interrupt group requesting line 7 |
| IOLN8 | I/O interrupt group requesting line 8 |
| IOREQ | I/O interrupt group service request |
| IP0 through IP15 | Level arm flip-flops for a group of 16 interrupts. An IP flip-flop is one of three basic flip-flops for each interrupt level and is physically located on an LT16 module |
|  | Interrupt request from the IOP |
| IS through IS15 | Level request flip-flops for a group of 16 interrupts. An IS flip-flop is one of three basic flip-flops for each interrupt level and is physically located on an LT16 module |
| NISINO through NISIN15 | Priority control signals for a group of 16 interrupts. These terms are used for forming address lines to the CPU when an interrupt enters the waiting-enabled state. For example, if NISIN11 is true, interrupt level 11 is in the waiting-enabled state, and no higher priority flip-flops are in the active state or waiting-enabled state |
| NISNIPO through NISNIP15 | Priority control signals for a group of 16 interrupts. These terms are used to indicate the active state of higher priority interrupt levels. For example, if interrupt level 7 is active, NISNIP8 through NISNIP15 are true |
| KINTRP | Console switch signal for generating an interrupt request to memory location $\mathrm{X}^{\prime} 5 \mathrm{D}^{\prime}$ |
| LEN | Load enables. Output term of an inverter with NLE input |
| LEVACT | Leave active state signal |
| LEVARM | Leave in armed state signal. If this signal is true, a level remains in the armed state after leaving the active state |
| LIN00 through LIN08 | Interrupt service routine address line signals from the external interrupts |
| LINREQ | Interrupt service request to the CPU received from external interrupts |
| OF | Counter overflow flip-flop |
| OVLN6, OVLN7, OVLN8 | Override interrupt group requesting address lines 6, 7, or 8 |
| OVRQ | Override interrupt group service request |

Table 3-155. Glossary of Interrupt Signals (Cont.)

| SIGNAL | DEFINITION |
| :---: | :---: |
|  | Internal Interrupts |
| PEI | Parity error interrupt signal |
| PCBZC | Priority chain counter interrupt busy signal. CHAl is the input signal to this buffer |
| PCBZ 1 | Priority chain I/O interrupt busy signal. CHA2 is the input signal to this buffer |
| PCBZO | Priority chain override interrupt busy signal. CHAO is the input signal to this buffer |
| /PCBZC/ | Buffer cable driver output signal indicating the counter interrupt priority chain is busy. Input to this buffer is PCBZC |
| /PCBZI/ | Buffer cable driver output signal indicating the I/O interrupt priority chain is busy. Input to this buffer is PCBZI |
| /PCBZO/ | Buffer cable driver output signal indicating the override interrupt priority chain is busy. Input to this buffer is PCBZO |
| PCRQBZC | Priority chain counter interrupt request for service or busy signal |
| PCRQBZI | Priority chain I/O interrupt request for service or busy signal |
| PCRQBZO | Priority chain override interrupt request for service or busy signal |
| /PCRQBZC/ | Buffer cable driver output signal indicating a counter interrupt request for service or busy signal. Input to this buffer is PCR QBZC |
| /PCRQBZI/ | Buffer cable driver output signal indicating an I/O interrupt request for service or busy signal. Input to this buffer is PCRQBZI |
| /PCRQBZO/ | Buffer cable driver output signal indicating an override interrupt request for service or busy signal. Input to this buffer is PCRQBZO |
| P OFF | Power-off signal to the IS0 flip-flop of the power fail-safe system |
| PON | Power-on signal to the IS1 flip-flop of the power fail-safe system |
| PXINT | Transfers the interrupt address, INT0-INT8, to the P-register, P23-P31 |
| $\begin{aligned} & \text { R0, R2, R4, } \\ & \text { R6, R8, R10, } \\ & \text { R12, R14 } \end{aligned}$ | Part of the LT16 decode logic |
| NR01, NR23, NR45, NR67, NR89, NR911, NRIO11, NR1213, NR1315, NR1357, NR1415 | Part of the LT16 decode logic used to form interrupt subroutine addresses. For example, if NRO1 is false, then interrupt level 0 or 1 is signalling for a request |

(Continued)

Table 3-155. Glossary of Interrupt Signals (Cont.)

| SIGNAL | DEFINITION |
| :---: | :---: |
|  | Internal Interrupts |
| RCCHAO, <br> RCCHAI, <br> RCCHA2 | Recirculate group 0, 1, or 2 active signal. These are the recirculate terms for the channel active signals CHA0, CHA1, CHA2 |
| $\begin{aligned} & \text { RCDAT26 } \\ & \text { RCDAT27 } \end{aligned}$ | Recirculate terms for DAT26 and DAT27 dc latches |
| RCENFNL | Recirculate enable function lines. Recirculate term for the ENFNL dc latch |
| RCNB | Part of the reset term logic for the CNB flip-flop |
| REIP1, REIP3, REIP5, REIP7, REIP9, REIPII, REIP13, REIP15 | Control signals which establish priority for interrupt levels in the waiting-enabled state |
| REN | Reset enable. (CPURESTI) or (load enable and GRPO). One of the reset logic terms for the $\operatorname{IN}$ flip-flops |
| RIJ | Reset term for OF, IJ8, IV9, IJ10, and LJ11 |
| RQY1 | Higher priority request or busy signal received by the counter interrupts from the priority chain |
| RQY2 | Higher priority request or busy signal received by the I/O interrupts from the priority chain |
| SCNA | Part of the set term logic for the CNA flip-flop |
| NSDARM | Not DARM |
| (S/INTRAPF) | This term initiates the interrupt sequence when all conditions exist for an interrupt |
| SR8, SR9, SR10, SR11, SR13 | Part of the set term logic for request flip-flops IS8, IS9, IS10, IS11, and IS13 |
| TNIO through TNi08 | Interrupt service routine address lines to the CPU. Input terms to /INT00/through /INT08/ |
| TNIREQ | Interrupt service request line to the CPU. Input term to /INT09/ |
| TRIG | Trigger signal. Part of the logic used to set the IS request flip-flops and trigger an interrupt. Not used for power fail-safe |
| TRIG 1 | Buffer with TRIG input. Same as TRIG |
| WD | Write direct. Privileged instruction which can be used to control various states of the interrupts |

Table 3-155. Glossary of Interrupt Signals (Cont.)


## SECTION IV

## INSTALLATION AND MAINTENANCE

## 4-1 INTRODUCTION

This section provides installation and maintenance data for the Sigma 7 computer. A basic Sigma 7 computer consists of a central processing unit (CPU), a multiplexing input/ output processor (MIOP), and a 4 K memory with optional features, devices, and device controllers for peripheral equipment added as applicable.

A set of documents provided with each Sigma 7 system in cludes an installation material list (IML), installation drawings, module location charts, assembly drawings, logic equations, and diagnostic programs (refer to table 4-1).

The Sigma 7 computer and peripheral equipment are installed by XDS personnel. To facilitate system expansion or relocation, the primary installation requirements for main units and optional features in the mainframe are included in this section.

## 4-2 INSTALLATION

4-3 BASIC CABINET INSTALLATION REQUIREMENTS

## 4-4 Floor Space

Space assignments for Sigma 7 computer cabinets must allow for the sweep of access doors and frames, as indicated on installation drawings. Space must also be allowed to permit access by maintenance personnel with test equipment while the frames are extended. A summary of space requirements is provided in table 4-2.

## 4-5 Power

The power requirements of each main unit, optional feature, and device controller are summarized in the related installation drawing. Power supplies are installed in each cabinet as indicated in figure 1-2. The primary reference sources

Table 4-1. Reference Documents for Sigma 7 Installation

| Document | Identification Number | Contents |
| :---: | :---: | :---: |
| Installation Material List | Unique to each installation | All parts of a specific Sigma 7 installation, including layout drawing showing each major item of Sigma 7 computer and peripheral equipment. Point-to-point cabling instructions provided |
| Installation Drawing | 134056 | General information about Sigma 7 computer installation and cabling |
| Power Interconnection Diagram | 139273 | General information about power connections for Sigma 7 computer and peripheral equipment |
| Basic Cabinet |  | General information about cabinet for Sigma 7 computer |
| Assembly | 131416 |  |
| Installation | 131417 |  |
| Free Standing Console |  | General information about optional FSC |
| Assembly | 127418 |  |
| Installation | 127441 |  |

Table 4-2. Space Requirements for Sigma 7 Cabinets

| Equipment | Overall Dimensions | Clear Area |
| :---: | :---: | :---: |
| Basic cabinet | Width - 31 in | Front - 3 ft |
|  | Depth - 29 in | Rear - 3 ft |
|  | Height - 64 in |  |
| Free standing console | Width - 60 in | Front - 4 ft |
|  | Depth - 30 in | Rear - 3 ft |
|  | Height - 41 in |  |

for power distribution are the IML and the Sigma system power interconnection installation drawing (refer to table 4-1).

## 4-6 Cable Connections

Cable connections consist of combinations of elements listed in table 4-3. The length of cable, number of connections, and restrictions are summarized in the installation drawings for each main unit, optional feature, and device controller.

## 4-7 MAIN UNIT INSTALLATION REQUIREMENTS

## 4-8 Central Processing Unit

The CPU occupies the forward and the center frame of one cabinet and part of the forward frame of a second cabinet. Preassigned locations in the CPU are reserved for modules for the following optional features: two additional real time clocks, power fail-safe, memory protection, memory map, private memory register extension and floating point arithmetic.

Table 4-3. Sigma 7 Cable Connections

| Part No. | Function |
| :---: | :--- |
| 129796 | Interconnecting cable assembly. Intercon- <br> nects component sides of modules |
| 129797 | Interconnecting cable assembly. Intercon- <br> nects etched sides of modules |
| 127314 | Interconnecting cable assembly. Connects <br> module etched side to component side |
| 127315 | Resistor connector assembly. Terminates <br> cable chain at module |
| 115832 | Terminator. Terminates I/O priority cable <br> chain. <br> Blank cable terminal |

The following engineering documents contain information required for installation of the CPU:

| Document | Document No. |
| :--- | :---: |
| Assembly drawing | 117307 |
| Module location chart | 127092 |
| Installation drawing | 117333 |
| System installation drawing | 134056 |

## 4-9 OPTIONAL FEATURE INSTALLATION REQUIREMENTS

## 4-10 Real-Time Clock

The real-time clock feature consists of two modules installed in the CPU cabinet as indicated in the CPU module location chart. Reference documents for the real-time clock feature are:

| Document | Document No. |
| :--- | :---: |
| Assembly drawing | 117616 |
| Module location chart | 127092 |
| Installation drawing | 117333 |

Two real-time clocks are included in the CPU; two optional real-time clocks may be added. Counters 1, 2, and 3 of the real-time clock feature are controlled by address selector module ST14 as illustrated in figure 4-1. Counter 4 is fixed at 400 Hz . Counters 3 and 4 are part of the CPU; counters 1 and 2 are optional.

## 4-11 Power Fail-Safe

The power fail-safe feature consists of one module installed in the CPU cabinet as indicated in the CPU module location chart. Reference documents for the power fail-safe feature are:

| Document | Document No. |
| :--- | :---: |
| Assembly drawing | 117612 |
| Module location chart | 127092 |
| Installation drawing | 117333 |

## 4-12 Memory Protection

The memory protection feature consists of five modules installed in the CPU cabinet as indicated in the CPU module location chart. Reference documents for the memory protection feature are:

| Document | Document No. |
| :--- | :---: |
| Assembly drawing | 117617 |
| Module location chart | 127092 |
| Installation drawing | 117333 |

## 4-13 Memory Map

The memory map feature consists of 21 modules installed in the CPU cabinet as indicated in the CPU module location chart. Reference documents for the memory map feature are:

| Document | Document No. |
| :--- | :---: |
| Assembly drawing | 117615 |
| Module location chart | 127092 |
| Installation drawing | 117333 |

## 4-14 Private Memory Register Extension

Each private memory register extension consists of four fastaccess memory $16 \times 8$-bit FT25 modules and additional modules as necessary. Four FT25 modules are included in the CPU; additional private memory registers may be added as an optional feature in banks of 16 registers (four FT25 modules). The first three banks of four FT25 modules may be added by inserting the modules in preassigned locations in the CPU. Additional banks are added by including a 32module chassis in one of the available locations within a frame with the four FT25 modules and the additional modules which form the interface between the CPU and the private memory extension options. A maximum of 112 additional FT25 modules in seven 32 -module chassis can be installed after the first 12 additional FT25 modules are inserted in the preassigned locations in the CPU.


Figure 4-1. Address Selector Module ST14

The following reference documents are required for installation of the private memory register extension:

Document

| Assembly drawing | 117621 |
| :--- | :--- |
| Module location chart | 124819 |
| Register extension unit assembly | 130071 |
| Register interface assembly | 132208 |
| Logic equations | 124817 |
| Installation drawing | 124816 |
| Module location chart (CPU) | 127092 |
| Installation drawing (System) | 134056 |
| Installation drawing (CPU) | 117333 |
| Modules list | 129698 |

Interconnections between each register extension unit assembly and the CPU are indicated on Sigma 7 system installation drawing 134056. A switch. comparator LT26 module is included on each register extension unit assembly to establish the address (see table 4-4 and figure 4-2).

Table 4-4. LT26 Switch Settings -
Register Extension Address

| Register Extension <br> Unit Assembly | Switch Setting |  |  |
| :---: | :---: | :---: | :---: |
|  | S3-2 | S3-1 | S2-2 |
| $4-7$ | 0 | 0 | 1 |
| $8-11$ | 0 | 1 | 0 |
| $12-15$ | 0 | 1 | 1 |
| $16-19$ | 1 | 0 | 0 |
| $20-23$ | 1 | 0 | 1 |
| $24-27$ | 1 | 1 | 0 |
| $28-31$ | 1 | 1 | 1 |

As each register extension unit assembly beyond the first is added, CPU jumper wires must be connected as follows:

Register Extension

Unit Assembly

| 1 | None |
| :--- | :--- |
| 2 | 28 U 03 to 29 U 17 |
| 3 | 28 O to 29 U 9 |
| 4 | 28 U 10 to 29 U 21 |
| 5 | 28 U 4 to 29 U 23 |
| 6 | 28 U 18 to 29 U 25 |
| 7 | 28 U 22 to 29 U 27 |



901060A. 401

Figure 4-2. Switch Comparator LT26

## 4-15 Floating Point

The floating point feature consists of 41 modules installed in the CPU cabinet as indicated on the CPU module location chart. Reference documents for the floating point feature are:

| Document | Document No. |
| :--- | :---: |
| Assembly drawing | 117611 |
| Module location chart | 127092 |
| Installation drawing | 117333 |
| 4-16 Decimal Arithmetic |  |

The decimal arithmetic feature consists of three 32 -module chassis and the associated modules. The three chassis must be installed in one of the CPU cabinets. Additional decimal arithmetic feature modules are also placed in the CPU frames. Reference documents for the decimal arithmetic feature are:

## Document

Assembly drawing
Module location chart
Installation drawing
Module location chart (CPU)

Document No.
117613

124823
124820

127092

## 4-17 External Interrupt Chassis

Each external interrupt chassis consists of a 32 -module chassis and the associated modules. Each external interrupt chassis contains a maximum of 16 programmable interrupts and is installed within an available cabinet. The control elements of each external interrupt chassis consist of 13 modules; interrupt levels are added in increments of two by inserting up to eight LT16 priority interrupt modules. A maximum of 14 chassis, each containing 16 interrupt levels can be included to provide 224 interrupt levels. Reference documents for the external interrupt chassis are:

## Document <br> Document No.

| Assembly drawing | 117330 |
| :--- | :---: |
| Modules | 129699 |
| Modules | 132206 |
| Module location chart | 129700 |
| Installation drawing | 124469 |
| Logic equations | $124470-001$ |

## 4-18 Free-Standing Console

The free-standing console (FSC) contains three 32 -module chassis with the associated modules in addition to power supplies, control panels, and indicator panels. The FSC is cable-connected to the Sigma 7 computer. Reference documents for the FSC are:

| Document | Document No. |
| :--- | :---: |
| Assembly drawing | 127418 |
| Module location chart | 127547 |
| Installation drawing | 127441 |
| Logic equations | $127546-001$ |
| Schematic diagrams | 127439 |
| MAINTENANCE |  |
| SPECIAL TOOLS AND TEST EQUIPMENT |  |

Special tools and test equipment recommended for repair or maintenance of the Sigma 7 computer are listed in table 4-5.

Table 4-5. Special Tools and Test Equipment

| Name | Manufacturer's <br> Part No. | Manufacturer |
| :--- | :---: | :---: |
| P6010 IBM accessories <br> and probe package <br> Oscilloscope | $010-0186$-00 | Tektronix, Bea- <br> verton, Oregon |
| Wirewrap tool | 1453 | 14XA2 <br> Wirewrap bit <br> Grand Haven, <br> Mich. |
| Wirewrap sleeve | 502129 | 502128 | | Wire unwrap tool |
| :--- |

## 4-21 PREVENTIVE MAINTENANCE

Preventive maintenance of the Sigma 7 computer consists of scheduled diagnostic testing in addition to visual inspection and routine maintenance. Because there are no mechanical devices in the Sigma 7 computer, lubrication and mechanical adjustments are not required.

External surfaces of the Sigma 7 computer cabinets must be kept clean and dust-free. Doors and panels must close
completely and must be in reasonable alignment. The topside of cabinets must remain cleared to permit fans to exhaust properly.

The interior of cabinets must be free of wire cuttings, dust, and other foreign matter. No clip leads or push-on jumpers should be in use during normal operation and all cables must be neatly dressed by clamps or routing. All chassis and frames must be properly bolted down with all hardware in place. Air filters should be checked for cleanliness and be replaced periodically.

## 4-22 DIAGNOSTIC TESTING

The following diagnostics are available for testing the performance of the Sigma 7 CPU and the related options. These diagnostics should be run whenever preventive maintenance is performed or when corrective maintenance is necessary. Information on loading and operating the diagnostics is included within each diagnostic program manual.

## 4-23 CPU Diagnostic System (SENSE)

This diagnostic locates malfunctions associated with the controls and the indicators on the Processor Control Panel (PCP). In addition, the proper operation of a basic instruction set (LPSD, XPSD, LW, STW, BCS, BCR, WAIT) is verified for use in sections of the more complex diagnostic programs. The program is written in three procedural steps. The first step checks the basic CPU controls and is entirely manual. The second step checks the controls used to enter and to retrieve data. The third step checks the operation of the Sense switches and verifies the operation of the basic instruction set.

Because of its simplicity, this diagnostic should not be run unless other CPU diagnostics fail. The first step of this diagnostic is time consuming and should not be run unless the operator is completely unfamiliar with the PCP switches.

| Document No. | Description |
| :---: | :---: |
| 900824 | Sigma 7 CPU Diagnostic System <br> (Sense), Diagnostic Program <br> Manual |
| $704041-83$ | Diagnostic program on absolute <br> binary paper tape |
| $704041-84$ | Diagnostic program on absolute <br> binary cards |

## 4-24 CPU Diagnostic System (VERIFY)

This diagnostic tests and diagnoses errors pertaining to the instructions LPSD, XPSD, LW, STW, BCS, WAIT, AND, EOR, and BIR. VERIFY assumes that all the functions tested by the SENSE diagnostic are operating correctly.

| Document No. | Description |
| :---: | :---: |
| 900870 | Sigma 5 and 7 CPU Diagnostic <br> Program (VERIFY), Diagnostic <br> Program Manual |
| $704042-83$ | Diagnostic program on absolute <br> binary paper tape |
| $704042-84$ | Diagnostic program on absolute <br> binary cards |
| $4-25$ CPU Diagnostic System (PATTERN) |  |

This diagnostic tests and diagnoses errors pertaining to the ability of the CPU to address and to access all available core memory, and private memory registers. The functions and operations tested by AUTO must be working before PATTERN is run.

| Document No. | Description |
| :---: | :--- |
| 900891 | Sigma 7 CPU Diagnostic System <br> (Pattern), Diagnostic Program <br> Manual |
| $704043-83$ | Diagnostic program on absolute <br> binary paper tape |
| $704043-84$ | Diagnostic program on absolute <br> binary cards |

## 4-26 CPU Diagnostic System (AUTO)

This diagnostic tests and diagnoses errors pertaining to all Sigma 7 instructions excluding decimal, floating point, byte string, stack, multiple, and convert instructions which are tested by other diagnostics. The functions and operations tested by VERIFY must be working before AUTO is run.

| Document No. | Description |
| :---: | :--- |
| 900872 | Sigma 7 CPU Diagnostic-Auto, <br> Diagnostic Program Manual |
| $704044-83$ | Diagnostic program on absolute <br> binary paper tape |
| $704044-84$ | Diagnostic program on absolute <br> binary cards |

> 4-27 CPU Diagnostic System (SUFFIX)

The diagnostic tests and diagnoses errors pertaining to the instructions CBS, MBS, TBS, TTBS, PSW, PSM, PLW, PLM, MSP, STM, LM, CVA, and CVS.

| Document No. | Description |
| :---: | :---: |
| 900893 | Sigma 7 CPU Diagnostic (Suffix), <br> Diagnostic Program Manual |
| $704045-83$ | Diagnostic program on absolute <br> binary paper tape |
| $704045-84$ | Diagnostic program on absolute <br> binary cards |
| CPU Diagnostic System (FLOAT) |  |

This diagnostic tests and diagnoses errors pertaining to all Sigma 7 floating point instructions excluding Floating Shift (SF). Successful operation of AUTO is a prerequisite to the running of FLOAT.

| Document No. | Description |
| :---: | :---: |
| 900898 | Sigma 5 and 7, CPU Diagnostic- <br> Float, Diagnostic Program Manual |
| $704046-83$ | Diagnostic program on absolute <br> binary paper tape |
| $704046-84$ | Diagnostic program on absolute <br> binary cards |

## 4-29 CPU Diagnostic System (MAP)

This diagnostic tests and diagnoses errors pertaining to the optional memory map feature, including the instruction MMC.

| Document No. | Description |
| :---: | :--- |
| 900920 | Sigma 7 MAP Diagnostic Program, <br> Diagnostic Program Manual |
| $704048-83$ | Diagnostic program on absolute <br> binary paper tape |
| $704048-84$ | Diagnostic program on absolute <br> binary cards |

4-30 Sigma 5 and 7 Real-Time Clock Test
This diagnostic tests and diagnoses errors pertaining to the operation of the real-time clocks by computing the time of day or elapsed time using the real-time clocks.

| Document No. | $\quad$Description <br> 901136 |
| :---: | :--- |
| Sigma 5 and 7 Real-Time Clock |  |
| Test, Diagnostic Program Manual |  |
| 704017-83 | Diagnostic program on absolute <br> binary paper tape |
|  | Diagnostic program on absolute <br> binary cards |

## 4-31 Sigma 5 and 7 Memory Protect Diagnostic

This diagnostic tests and diagnoses errors pertaining to the optional memory protect feature by checking the operation of the Write Locks and Keys.

| Document No. | Description |
| :---: | :--- |
| 901516 | Sigma 5 and 7 CPU Diagnostic <br> Program (Memory Protect), <br> Diagnostic Program Manual |
| $704062-83$ | Diagnostic program on absolute <br> binary paper tape |
| $704062-84$ | Diagnostic program on absolute <br> binary cards |

## 4-32 Sigma 5 and 7 Power Fail-Safe Test

This diagnostic tests and diagnoses errors pertaining to the optional Power Fail-Safe feature by checking the operation of the power-on and power-off interrupts.

| Document No. | Description |
| :---: | :--- |
| 901135 | Sigma 5 and 7 Power Fail-Safe <br> Test, Diagnostic Program Manual |
| $704122-83$ | Diagnostic program on absolute <br> binary paper tape |
| $704122-84$ | Diagnostic program on absolute <br> binary cards |

4-33 Sigma 5 and 7 Interrupt Test
This diagnostic tests and diagnoses errors pertaining to the interrupt system.

| Document No. | Description |
| :---: | :--- |
| 901134 | Sigma 5 and 7 Interrupt Test, <br> Diagnostic Program Manual |
| 704143-83 | Diagnostic program on absolute <br> binary paper tape |
| $704143-84$ | Diagnostic program on absolute <br> binary cards |

## 4-34 Sigma 5 and 7 Systems Test Monitor (SEVA)

This diagnostic tests and diagnoses errors pertaining to peripheral devices. The monitor program (SEVA) is loaded with individual peripheral diagnostic routines, and the program attempts to verify the operation of a number of peripherals running concurrently. The object of the program is not to isolate malfunctions within a peripheral, but rather to isolate malfunctions within the system.

| Document No. | Description |
| :---: | :--- |
| 901076 | Sigma 5 and 7 Systems Test <br> Monitor, Diagnostic Program <br> Manual |
| $704138-83$ | Diagnostic program on absolute <br> binary paper tape |
| $704138-84$ | Diagnostic program on absolute <br> binary cards |

Refer to the individual peripheral technical manuals for information on the individual peripheral diagnostic routines used with this monitor program.

## 4-35 CORRECTIVE MAINTENANCE

The following paragraphs contain information relating to some of the more common procedures encountered in troubleshooting the CPU.

## 4-36 Power

An electronic circuit breaker exists in each PT15 Power Supply located at the top rear of most cabinets. The 115 $\mathrm{Vac}, 2 \mathrm{kHz}$ output can be checked at any of the 3 -prong receptacles on the side of the PT15.

A circuit breaker and three fuses are located on each PT 16 Power Supply mounted on the hinged side of each frame. The PT16 plugs into a junction box on the bottom of the cabinet. The junction box is plugged into the PTI5.

If a free-standing console is in the system, its power switch is in series with the power switch on the PCP. Both must be on to power-up the system.

Inability to operate the switches on the PCP may be caused by the power monitor signal ST always being true. Check its input to the CPU logic at frame 1, as noted in the logic equations.

## 4-37 Clocks

Pressing the CPU RESET switch with the CLOCK MODE switch in CONTINUOUS and the COMPUTE switch in IDLE should initialize and start the clock generation logic. All of the PCP phases use only the T6L clock. Other clock intervals can be checked by executing the instructions using those clock intervals as noted in the phase sequence charts. There are no clock margins other than the secondary effects, which occur when the three-position voltage margin switches on each of the PTI6 Power Supplies are manipulated.

Single clock logic can be checked by moving the CLOCK MODE switch from CONTINUOUS to its center (unlabeled) position, which inhibits all clocks. With an instruction in the 32 DISPLAY indicators, and the COMPUTE switch in
the RUN position, a subsequent depression of the CLOCK MODE switch to the SINGLE STEP position produces one clock and should cause the PHASE indicators to advance, depending upon the instruction.

If single clocking through a PCP phase, the appropriate PCP switch must be manually held in position and the COMPUTE switch must be in IDLE.

If single clocking through an interrupt sequence, two clocks rather than one are produced in INTRAP1 and in the phase used to clear the interrupt level during the execution of either an LPSD or Modify and Test instruction.

## 4-38 Memory

Memory operation can be quickly checked by using the STORE and the DISPLAY switches on the PCP using both core memory and private memory register addresses. These PCP functions use much of the memory request logic within the CPU. These functions can be repeated easily by grounding the set input to the HALT flip-flop at location 20A50, and by holding (or taping) the PCP switch in position.

If the memory request state flip-flops (MAA through MGG) seem to be out of step, it may first show up in the operation of the DISPLAY SELECT ADDRESS function. The first time that the switches are operated, the contents of the current instruction address is displayed instead of the select address. The second time that the switches are operated, the correct information is displayed.

## 4-39 Instructions

Instructions may be executed one at a time directly from the control panel, or a short program may be stored and executed from either core memory or the private memory registers.

To iterate any nonbranching instruction at its maximum rate, use the INSTRUCTION ADDRESS switch in the HOLD position. The instruction to be iterated (or held) must reside in memory. Use the DISPLAY switch to access it from memory and to put it into the DISPLAY indicators, then place the INSTRUCTION ADDRESS switch in the HOLD position and the COMPUTE switch to RUN.

If an instruction hangs up in a phase, place an XPSD instruction in the trap location $X^{\prime} 46$ ' with a new instruction address equal to the address of the instruction which is hanging up. In this way, the watchdog timer can be used automatically to cause the computer to return to that instruction for scoping purposes.
If an instruction fails during the running of the diagnostic, it is sometimes useful to place the diagnostic in a short loop using the sense switch options called out in the diagnostic program manual, and to set the SELECT ADDRESS switches to the location of the Execute instruction within the driver portion of the diagnostic. In this manner a sync pulse is
generated whenever the Execute instruction is accessed. This sync pulse is the logic term ADMATCH, which can be found in frame 3 of the CPU logic equations.

If problems are being experienced in loading programs, the Bootstrap program, inserted into core memory through the LOAD switch, can be easily checked by inserting an existing teletype unit address number into the UNIT ADDRESS switches, and by attempting to load from the teletype. The Bootstrap program can also be changed quite easily to perform an output operation by changing the structure of the I/O Command Doubleword.

4-40 Replacement of Miniature Incandescent Lamps (DS1 through DS21 and DS29 through DS98) (See figure 4-3).

When a miniature lamp of the soldered lead type ( $\mathrm{P} / \mathrm{N}$ 123710) used for indicators DS1 through DS29 and DS29 through DS98 becomes defective, it shall be replaced with a new plug-in type lamp ( $\mathrm{P} / \mathrm{N}$ 108814-009). Installation of each new lamp requires the addition of one new lamp holder ( $\mathrm{P} / \mathrm{N}$ 180223) and one new O-ring ( $\mathrm{P} / \mathrm{N}$ 111344-001).

Replace the defective soldered lead type lamp with the new plug-in type lamp as follows:
a. Cut leads of defective lamp as close as possible to base of lamp. Remove lamp by releasing mounting
spring clip. Keep clip to install new lamp. Discard defective lamp.

## CAUTION

Do not allow physical shocks to occur to lamp during installation.
b. Insert new type lamp through mounting hole in front of panel until lamp shoulder butts against front panel surface.
c. Install O-ring over terminal end of lamp module and slide O-ring forward until it is flush with back surface of panel.
d. Using long nose pliers, open spring clip by gently squeezing two opposing tabs together. Slide spring clip over terminal end of lamp module and move clip forward until its legs fit over O-ring and contact panel. Lock spring clip in position by releasing tabs.
e. Install lampholder over lamp module by inserting lamp terminals in matching terminals of lampholder and then gently pushing lampholder forward.
f. Using long nose pliers, separately connect ends of two lamp leads to two lampholder terminals and solder connections.


Figure 4-3. Plug-In Lamp Assembly Installation

## APPENDIX A <br> PARTS LIST

## A-1 INTRODUCTION

Appendix A lists and illustrates replaceable parts of the basic Sigma 7 CPU as well as its optional features, but does not include the Sigma 7 peripheral equipment or device controllers. Parts below the level of XDS circuit modules are not listed.

## A-2 TABULAR LISTING

Appendix A is arranged in parts list of tables, starting with a listing of the main assemblies of the basic Sigma 7 Central Processing Unit Model 8401. Breakdown of the Sigma 7 CPU optional equipment by tables follows.

## A-3 ILLUSTRATIONS

In some cases, the parts tables refer to accompanying illustrations to indicate the parts described in the table and to show their locations in the assembly.

## A-4 REPLACEABLE PARTS

Replaceable parts are defined as parts having maintenance significance, that is, parts which can be replaced because of wear, damage, or for malfunctions caused by normal use of the equipment. Standard hardware, such as nuts, screws and washers, parts that are normally supplied in bulk, such
as wire and tubing, and structural parts, such as panels and brackets, are not considered replaceable parts. In some instances, however, the parts list tables do list such nonreplaceable parts for reference purposes only.

## 4-5 PARTS LIST TABLES

Each parts list table is arranged in six columns as follows:
a. Figure and index number of the listed part, where applicable
b. Brief description of the part
c. Reference designator of the part, if applicable
d. Manufacturer code number
e. Manufacturer's part number
f. Quantity of the part used for each assembly

## A-6 MANUFACTURERS CODE INDEX

Table 4-30 contains the names and addresses of manufacturers identified by code number given in the previous tables.

Table A-1. Sigma 7 Central Processing Unit Model 8401, Replaceable Parts

| Fig. \& Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-1 | Assembly, Central Processing Unit, Sigma 7 <br> - Basic cabinet, Model 8900 (see table A-29 for breakdown) <br> - Power Supply ModeI PT14 <br> - Power Supply ModeI PTI5 <br> - Power Distribution Box <br> - Quartz crystal, 2.048 MHz <br> - Frame No. 1, CPU cabinet No. 1 (see table A-2 for breakdown) <br> - Frame No. 2, CPU cabinet No. 1 (see table A-6 for breakdown) <br> - Frame No. 1, CPU cabinet No. 2. (see table A-10 for breakdown) |  | XDS | 117307 | 1 |
|  |  |  | XDS | 131416 | 3 |
|  |  |  | XDS | 117262 | 2 |
|  |  |  | XDS | 117263 | 2 |
|  |  |  | XDS | 117428 | 2 |
|  |  |  | XDS | 128131-017 | 1 |
|  |  |  | XDS | 117309 | 1 |
|  |  |  | XDS | 117308 | 1 |
|  |  |  | XDS | 126601 | 1 |



Figure A-1. CPU Cabinet No. 1

Table A-2. Frame No. 1, CPU Cabinet No. 1, Replaceable Parts

| Fig. \& Index No. | Description. | Reference Desginator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-1 | Assembly, Frame No. 1, CPU Cabinet No. 1 (see table A-1 for next higher assembly) |  | XDS | 117309 | $1$ |
|  | - Power Supply PT16 |  | XDS | 117264 | 1 |
|  | - Cables, busbar pickup |  | XDS | 131891-005 | 2 |
|  | - Cables, 33 ohm, single condition |  | XDS | 128147-372 | 5 |
|  | - Cable, intraframe |  | XDS | 128060-171 | 19 |
|  | . Cable, intraframe |  | XDS | 128060-292 | 1 |
|  | - Cable, intraframe |  | XDS | 128060-302 | 1 |
|  | - Cable, intraframe |  | XDS | 128060-182 | 1 |
|  | - Chassis No. 1 (Logic), cabinet No. 1 |  | XDS | 117313 | 1 |
|  | . . Assembly, top fan (see table A-29 for breakdown) |  | XDS | 123943 | 1 |
|  | . . Assembly, bottom fan (see table A-29 for breakdown) |  | XDS | 117320 | 1 |
|  | . . Assembly, wired board A, B, C (see table A-3 for breakdown) |  | XDS | 124729 | 1 |
|  | . . Assembly, wired board D, E, F (see table A-4 for breakdown) |  | XDS | 124727 | 1 |
|  | - Assembly, wired board G, H, J (see table A-5 for breakdown) |  | XDS | 124724 | 1 |

Table A-3. Wired Board Assembly (A, B, C), Replaceable Parts

| Fig. \& Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-1 |  |  | XDS | 124729 | Ref |
|  |  |  | XDS | 127797 | 1 |
|  |  |  | XDS | 116056 | 3 |
|  |  |  | XDS | 116029 | 3 |
|  |  |  | XDS | 125262 | 3 |
|  |  |  | XDS | 126613 | 2 |
|  |  |  | XDS | 124713 | 6 |
|  |  |  | XDS | 124881 | 5 |
|  |  |  | XDS | 125264 | 7 |
|  |  |  | XDS | 126747 | 7 |
|  |  |  | XDS | 128188 | 1 |
|  |  |  | XDS | 128190 | 6 |
|  |  |  | XDS | 128192 | 7 |
|  |  |  | XDS | 123016 | 1 |
|  |  |  | XDS | 123017 | 12 |
|  |  |  | XDS | 124717 | 3 |
|  |  |  | XDS | 126615 | 2 |
|  |  |  | XDS | 116257 | 8 |
|  |  |  | XDS | 128164 | 1 |

Table A-4. Wired Board Assembly (D, E, F), Replaceable Parts


Table A-5. Wired Board Assembly (G, H, J), Replaceable Parts


Table A-6. Frame No. 2, CPU Cabinet No. 1, Replaceable Parts

| Fig. \& Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-1 | Assembly, Frame No. 2, CPU Cabinet No. 1 (see table A-1 for next higher assembly) |  | XDS | 117308 | 1 |
|  | - Power Supply PT16 |  | XDS | 117264 | 1 |
|  | . Cable, busbar pickup |  | XDS | 131891-005 | 7 |
|  | . Cable, 33 ohm, single condition |  | XDS | 128147-372 | 27 |
|  | - Cable, intraframe |  | XDS | 128060-182 | 1 |
|  | - Cable, intraframe |  | XDS | 128060-171 | 14 |
|  | . Chassis No. 2 (Logic), cabinet No. 1 |  | XDS | 117314 | 1 |
|  | . . Assembly, top fan (see table A-29 for breakdown) |  | XDS | 123943 | 1 |
|  | . . Assembly, bottom fan (see table A-29 for breakdown) |  | XDS | 117324 | 1 |
|  | . . Assembly, wired board K, L, M (see table A-7 for breakdown) |  | XDS | 124728 | 1 |
|  | . . Assembly, wired board $N, P, Q$ (see table A-8 for breakdown) |  | XDS | 124730 | 1 |
|  | . . Assembly, wired board R, S, T (see table A-9 for breakdown) |  | XDS | 124736 | $!$ |

Table A-7. Wired Board Assembly (K, L, M), Replaceable Parts


Table A-8. Wired Board Assembly (N, P, Q), Replaceable Parts


Table A-9. Wired Board Assembly (R, S, T), Replaceable Parts

| Fig. \& Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-1 | Assembly, Wired Board R, S, T (see table A-6 for next higher assembly) |  | XDS | 124736 | Ref |
|  | . Cable Driver/Receiver AT11 |  | XDS | 123019 | 2 |
|  | . Cable Driver AT21 |  | XDS | 127797 | 2 |
|  | . Gated Buffer No. 1 BT 16 |  | XDS | 125262 | 5 |
|  | . Gated Buffer BT17 |  | XDS | 126330 | 1 |
|  | - BAND Gate BT18 |  | XDS | 126613 | 3 |
|  | . Register Flip-Flop FT17 |  | XDS | 124628 | 12 |
|  | . Counter Flip-Flop FT18 |  | XDS | 124634 | 2 |
|  | . Universal Flip-Flop FT22 |  | XDS | 124713 | 4 |
|  | - Fast Access Memory FT25 |  | XDS | 126743 | 2 |
|  | . Gate Expander No. 2 GTll |  | XDS | 124881 | 4 |
|  | . Gated Inverter IT 16 |  | XDS | 125264 | 5 |
|  | . NAND Gate IT25 |  | XDS | 128190 | 1 |
|  | . Adder No. 1 LTI7 |  | XDS | 123554 | 8 |
|  | - Carry No. 1 LT18 |  | XDS | 123590 | 2 |
|  | - Terminator XT10 |  | XDS | 116257 | 5 |
|  | . Clock Terminator No. 1 XT18* |  | XDS | 132009 | 2 |

Table A-10. Frame No. 1, CPU Cabinet No. 2, Replaceable Parts

| Fig. \& Index No. | Description | Reference Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-2 | Assembly, Frame No. 1, CPU Cabinet No. 2 (see table A-1 for next higher assembly) |  | XDS | 126601 | 1 |
|  | . Cable, 33 ohm, single condition |  | XDS | 128147-372 | 6 |
|  | . Cable, intraframe |  | XDS | 137481-171 | 1 |
|  | - Power Supply PTI6 |  | XDS | 117264 | 1 |
|  | - Assembly, CPU Chassis No. 3 |  | XDS | 126593 | 1 |
|  | Assembly, top fan (see table A-29 for breakdown) |  | XDS | 123943 | 1 |
|  | Assembly, bottom fan (see table A-29 for breakdown) |  | XDS | 117320 | 1 |
|  | . . Blank Panel Simulator |  | XDS | 129694 | 5 |
|  | . . Assembly, wired board U, V, W (see table A-11 for breakdown) |  | XDS | 126594 | 1 |
|  | - Assembly, wired board $Y$ (see table A-12 for breakdown) |  | XDS | 126596 | 1 |



Table A-11. Wired Board Assembly (U, V, W), Replaceable Parts


Table A-12. Wired Board Assembly (Y), Replaceable Parts

| Fig. \& Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-2 | Assembly, Wired Board $Y$ (see table A-10 for next higher assembly) <br> - Cable Driver AT 12 <br> . Buffered AND/OR Gate BTIO <br> . Gated Buffer No. 1 BT16 <br> . Gated Inverter IT 16 <br> . Terminator XTIO <br> . Clock Terminator No. 2 XT19* <br> . Clock Terminator No. $2 \times T 19^{\dagger}$ | XDSXDSXDSXDSXDSXDSXDSXDS |  | 126596 | Ref |
|  |  |  |  | 124629 | 1 |
|  |  |  |  | 116056 | 1 |
|  |  |  |  | 125262 | 1 |
|  |  |  |  | 125264 | 1 |
|  |  |  |  | 116257 | 1 |
|  |  |  |  | 132015 | 2 |
|  |  |  |  | 132015 | 1 |

Table A-13. Processor Control Panel Assembly, Replaceable Parts

(Continued)

Table A-13. Processor Control Panel Assembly, Replaceable Parts (Cont.)




Figure A-3. Assembly, Processor Control Panel (Sheet 2 of 2)

Table A-14. Floating Point Arithmetic Assembly, Replaceable Parts


Table A-15. Decimal Arithmetic Assembly, Replaceable Parts

| Fig. \& Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-1 | Assembly, Decimal Arithmetic |  | XDS | 117613 | 1 |
|  | . Cable Driver/Receiver AT11 |  | XDS | 123019 | 1 |
|  | . Gated Buffer BT17 |  | XDS | 126330 | 1 |
|  | - Gated Inverter IT16 |  | XDS | 125264 | 1 |
|  | - Logic Element LT20 |  | XDS | 124717 | 1 |
|  | - Cable Driver/Receiver AT11 |  | XDS | 123019 | 1 |
|  | - Buffered AND/OR Gate BT10 |  | XDS | 116056 | 5 |
|  | . BAND Gate BTII |  | XDS | 116029 | 5 |
|  | - Gated Buffer No. 1 BT16 |  | XDS | 125262 | 1 |
|  | - BAND Gate BT18 |  | XDS | 126613 | 4 |
|  | - Register Flip-Flop FT17 |  | XDS | 124628 | 4 |
|  | - Counter Flip-Flop FT18 |  | XDS | 124634 | 5 |
|  | . Universal Flip-Flop FT22 |  | XDS | 124713 | 3 |
|  | . Fast Access Memory FT25 |  | XDS | 126743 | 3 |
|  | - Buffered Latch No. 3 FT26 |  | XDS | 126856 | 1 |
|  | - Gate Expander No. 2 GTIl |  | XDS | 124881 | 6 |
|  | - Gated Inverter IT15 |  | XDS | 117375 | 1 |
|  | . Gated Inverter IT16 |  | XDS | 125264 | 5 |
|  | - NAND Gate IT25 |  | XDS | 128190 | 1 |
|  | - Parity Generator LT12 |  | XDS | 117382 | 7 |
|  | . Carry No. 1 LT18 |  | XDS | 123590 | 2 |
|  | - Logic Element LT20 |  | XDS | 124717 | 1 |
|  | - Logic Element LT21 |  | XDS | 126615 | 24 |
|  | - Terminator XT10 |  | XDS | 116257 | 4 |
|  | . Cable Plug ZT23 |  | XDS | 128164 | 1 |

Table A-16. Memory Map Assembly, Replaceable Parts

|  <br> Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-2 | Assembly, Memory Map |  | XDS | 117615 | 1 |
|  | . NAND/NOR Gate IT24 |  |  |  |  |
|  | . Fast Access Memory FT25 |  | XDS | 128188 | 1 |
|  |  |  |  |  |  |
|  |  |  |  | 126743 | 20 |

Table A-17. Real Time Clock Assembly, Replaceable Parts

|  <br> Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-2 | Assembly, Real Time Clock |  | XDS | 117616 | 1 |
|  | . Priority Interrupt LT16 |  | XDS | 123379 | 2 |
|  |  |  |  |  |  |

Table A-18. Power Fail-Safe Assembly, Replaceable Parts

|  <br> Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-2 | Assembly, Power Fail-Safe |  |  | XDS | 117612 |
|  | . Priority Interrupt LT16 |  |  | 1 |  |
|  |  |  |  | 123379 | 1 |

Table A-19. Additional Register Banks Assembly, Replaceable Parts

| Fig. \& Index No. | Description | Reference Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-1 | Assembly, High Speed Register Bank |  | XDS | 117621 | 1 |
|  | - Fast Access Memory, FT25* |  | XDS | 126743 | 4 |
|  | - Fast Access Memory, FT25 ${ }^{\dagger}$ |  | XDS | 126743 | 4 |
|  | - Fast Access Memory, FT25** |  | XDS | 126743 | 4 |
| *First additional register bank <br> ${ }^{\dagger}$ Second additional register bank |  |  |  |  |  |

Table A-20. Register Extension Unit Assembly and Register Extension Unit Interface, Replaceable Parts

| $\begin{aligned} & \text { Fig. \& } \\ & \text { Index No. } \end{aligned}$ | Description | Reference Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-3 | Assembly, Register Extension Unit |  | XDS | 130071 | 1 |
|  | - Cable Driver/Receiver AT11 |  | XDS | 123019 | 5 |
|  | - Gated Buffer No. 1 BT 16 |  | XDS | 125262 | 2 |
|  | . Fast Access Memory FT25 |  | XDS | 126743 | 4 |
|  | - Gated Inverter IT16 |  | XDS | 125264 | 1 |
|  | - Switch Comparator LT26 |  | XDS | 126982 | 1 |
|  | - Terminator XT10 |  | XDS | 116257 | 3 |
|  | . Cable Plug ZT23 |  | XDS | 128164 | 1 |
|  | - Fast Access Memory FT25* |  | XDS | 126743 | 4 |
|  | - Fast Access Memory $\mathrm{FT} 25^{\dagger}$ |  | XDS | 126743 | 4 |
|  | - Fast Access Memory FT25** |  | XDS | 126743 | 4 |
|  | Register Extension Unit Interface |  | XDS | 132208 | 1 |
| *Second register bank <br> ${ }^{\dagger}$ Third register bank <br> **Fourth register bank |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |

Table A-21. Memory Protect Assembly, Replaceable Parts

|  <br> Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-2 | Assembly, Memory Protect |  |  |  |  |
|  | . NAND/NOR Gate IT24 |  |  |  |  |
|  | . Fast Access Memory FT25 |  | XDS | 117617 | 1 |
|  |  |  | XDS | 128188 | 1 |

Table A-22. Priority Interrupt Assembly, Replaceable Parts


Table A-23. Basic Memory, 4096 Words, Assembly, Replaceable Parts

| Fig. \& Index No. | Description | Reference Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-4 | Assembly, Basic Memory, 4096 Words |  |  |  |  |
|  | - Basic Cabinet Model 8900 (see table A-29 for breakdown) |  | XDS | 131416 | 1 |
|  | . Power Supply PT16 |  | XDS | 117264 | 1 |
|  | - Power Supply PT17 |  | XDS | 117265 | 1 |
|  | . Assembly, Basic Memory, $4 \mathrm{~K} \times 33$ bit, Model 8251 |  | XDS | 132546 | 1 |
|  | . . Memory Frame |  | XDS | 117500 | 1 |
|  | . . Resistor Connector |  | XDS | 127315 | 8 |
|  | . . Cable Receiver ATIO |  | XDS | 123018 | 1 |
|  | . . Cable Driver/Receiver ATII |  | XDS | 123019 | 6 |
|  | . . Rejection Gate AT16 |  | XDS | 126611 | 2 |
|  | . . Cable Driver/Receiver AT31 |  | XDS | 133053 | 1 |
|  | . . Gated Buffer BT16 |  | XDS | 125262 | 6 |
|  | . . Fast Buffer BT22 |  | XDS | 127393 | 11 |
|  | . . Buffered AND/OR Gate BT24 |  | XDS | 130967 | 3 |
|  | . . BAND Gate BT25 |  | XDS | 130947 | 1 |
|  | . Delay Line DT11 |  | XDS | 126963 | 2 |
|  | . . Buffered Latch No. 2, FT37 |  | XDS | 130942 | 3 |
|  | . Buffered Latch No. 3, FT38 |  | XDS | 130952 | 6 |
|  | . . Memory Sense Amplifier, HTIl |  | XDS | 123010 | 6 |
|  | . . Delay Line Sensor, HT 15 |  | XDS | 127391 | 3 |
|  | . . Memory Preamplifier, HT26 |  | XDS | 131633 | 6 |
|  | . . Gated Inverter, IT14 |  | XDS | 126617 | 6 |
|  | . . Gated Inverter, IT16 |  | XDS | 125264 | 3 |
|  | . . NAND/NOR Gate IT24 |  | XDS | 128188 | 1 |
|  | . . NAND Gate IT25 |  | XDS | 128190 | 2 |
|  | . . Logic Element LTI9 |  | XDS | 123915 | 1 |
|  | . . Logic Element w/ Inverter LT20 |  | XDS | 124717 | 1 |

(Continued)

Table A-23. Basic Memory, 4096 Words, Assembly, Replaceable Parts (Cont.)

| Fig. \& Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { A-4 } \\ \text { (Cont.) } \end{gathered}$ | . . Logic Element w/ Buffer LT21 |  | XDS | 126615 | 5 |
|  | . . Parity Generator LT34 |  | XDS | 130958 | 9 |
|  | . . Memory Switch A ST10 |  | XDS | 123005 | 10 |
|  | . Memory Switch B STIl |  | XDS | 123006 | 16 |
|  | . . Toggle Switch ST14 |  | XDS | 123008 | 2 |
|  | . . Memory Preamplifier Selector ST15 |  | XDS | 123012 | 1 |
|  | . . Voltage Regulator STI7 |  | XDS | 131292 | 1 |
|  | . . Inhibit Driver ST21 |  | XDS | 132153 | 6 |
|  | . . Terminator XT10 |  | XDS | 116257 | 14 |
|  | . . Resistor Module C XTI3 |  | XDS | 127791 | 9 |
|  | . . Resistor Module D XTI4 |  | XDS | 127793 | 1 |
|  | . . Ribbon Cable ZT35 |  | XDS | 132277 | 3 |
|  | . . Core Diode Module, 8-bit |  | XDS | 115549 | 3 |
|  | . . Core Diode Module, 9-bit |  | XDS | 115550 | 1 |
|  | . . Memory Driver ST22 |  | XDS | 132159 | 4 |



Figure A-4. Memory Cabinet

Table A-24. Memory Increment, 4096 Words, Replaceable Parts

| Fig. \& Index No. | Description | Reference Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-4 | Assembly, Memory Increment, 4096 Words |  |  |  |  |
|  | - Memory Expansion Kit, 4K to 8K |  | XDS | 117638 | 1 |
|  | . . Memory Preamplifier HT26 |  | XDS | 131633 | 5 |
|  | . Memory Switch A STIO |  | XDS | 123005 | 2 |
|  | . . Memory Switch B STII |  | XDS | 123006 | 16 |
|  | . . Memory Driver ST22 |  | XDS | 132159 | 1 |
|  | . . Core Diode Module, 8-bit |  | XDS | 111549 | 3 |
|  | . . Core Diode Module, 9-bit |  | XDS | 111550 | 1 |
|  | - Memory Expansion Kit 8K to 12K |  | XDS | 117639 | 1 |
|  | . . Memory Preamplifier HT26 |  | XDS | 131633 | 6 |
|  | . Memory Switch A STIO |  | XDS | 123005 | 8 |
|  | . . Memory Driver ST22 |  | XDS | 132159 | 1 |
|  | . . Core Diode Module, 8-bit |  | XDS | 111549 | 3 |
|  | . . Core Diode Module, 9-bit |  | XDS | 111550 | 1 |
|  | - Memory Expansion Kit 12K to 16K |  | XDS | 117640 | 1 |
|  | . . Memory Preamplifier HT26 |  | XDS | 131633 | 5 |
|  | . . Core Diode Module, 8-bit |  | XDS | 111549 | 3 |
|  | . . Core Diode Module, 9-bit |  | XDS | 111550 | 1 |

Table A-25. Three-Way Access Memory (Port A), Replaceable Parts

| Fig. \& Index No. | Description | Reference Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-4 | Assembly, Port Expansion, $1 \times 2$ |  | XDS | 129463 | 1 |
|  | - Resistor Connector |  | XDS | 127315 | 4 |
|  | - Interconnecting Cable |  | XDS | 127314-102 | 5 |
|  | - Cable Receiver ATIO |  | XDS | 123018 | 1 |
|  | - Cable Driver/Receiver ATII |  | XDS | 123019 | 3 |
|  | - Buffered Latch No. 2 FT37 |  | XDS | 130942 | 3 |
|  | - Logic Element w/Inverter LT20 |  | XDS | 124717 | 1 |
|  | . Logic Element w/Buffer LT21 |  | XDS | 126615 | 1 |

Table A-26. Six-Way Access Memory, Replaceable Parts

| Fig. \& Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-4 | Assembly, Six-Way Access Memory |  |  |  |  |
|  | . Memory Port Expander F |  | XDS | 130625 | 1 |
|  | . . Cable Receiver AT10 |  | XDS | 123018 | 4 |
|  | . Cable Driver/Receiver ATII |  | XDS | 123019 | 16 |
|  | . . Rejection Gate AT16 |  | XDS | 126611 | 2 |
|  | . . Gated Buffer BT15 |  | XDS | 117389 | 1 |
|  | . . Fast Buffer BT22 |  | XDS | 127393 | 3 |
|  | .. Buffered AND/OR Gate BT24 |  | XDS | 130967 | 1 |
|  | . . Buffered Latch No. 3 FT26 |  | XDS | 126856 | 1 |
|  | . . Buffered Latch No. 2a FT27 |  | XDS | 126986 | 14 |
|  | . . Buffered Latch No. 3a FT38 |  | XDS | 130952 | 7 |
|  | . . Gated Inverter IT15 |  | XDS | 117375 | 1 |
|  | . . Gated Inverter IT16 |  | XDS | 125264 | 6 |
|  | . . Logic Element w/Inverter LT20 |  | XDS | 124717 | 4 |
|  | . . Logic Element w/Buffer LT21 |  | XDS | 126615 | 4 |
|  | . . Address Selector ST14 |  | XDS | 123008 | 2 |
|  | . Terminator XTIO |  | XDS | 116257 | 7 |
|  | . . Twisted Pair Cable ZT38 |  | XDS | 133625 | 5 |
|  | - Memory Expander S |  | XDS | 130626 | 1 |
|  | . . Rejection Gate AT16 |  | XDS | 126611 | 2 |
|  | . . Gated Buffer BT 15 |  | XDS | 117389 | 1 |
|  | . . Fast Buffer BT22 |  | XDS | 127393 | 2 |
|  | . . Buffered AND/OR Gate BT24 |  | XDS | 130967 | 1 |
|  | . . Buffered Latch No. 3a FT38 |  | XDS | 130952 | 7 |
|  | . . Gated Inverter IT15 |  | XDS | 117375 | 1 |
|  | . . Gated Inverter IT16 |  | XDS | 125264 | 1 |
|  | . . Logic Element w/Inverter LT20 |  | XDS | 124717 | 4 |
|  | . . Logic Element w/Buffer LT21 |  | XDS | 126615 | 4 |
|  | . . Address Selector ST14 |  | XDS | 123008 | 2 |

(Continued)

Table A-26. Six-Way Access Memory, Replaceable Parts (Cont.)

| Fig. \& Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { A-4 } \\ \text { (Cont.) } \end{gathered}$ | . Terminator XT10 |  | XDS | 116257 | 5 |
|  | . . Twisted Pair Cable ZT38 |  | XDS | 133625 | 5 |
|  | . . Ribbon Cable ZT45 |  | XDS | 133218 | 4 |

Table A-27. Multiplexor I/O Processor, Replaceable Parts

| Fig. \& Index No. | Description | Reference Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-2 | Assembly, Multiplexer I/O Processor |  | XDS | 117610 | 1 |
|  | . Cable Receiver AT10 |  | XDS | 123018 | 1 |
|  | - Cable Driver/Receiver ATII |  | XDS | 123019 | 6 |
|  | - Cable Driver AT12 |  | XDS | 124629 | 2 |
|  | - Cable Driver/Receiver AT13 |  | XDS | 125260 | 1 |
|  | . Clock Driver No. 2 AT24 |  | XDS | 128168 | 1 |
|  | . BAND Gate BTII |  | XDS | 116029 | 9 |
|  | . Delay Line DTII |  | XDS | 126963 | 2 |
|  | - Increment/Decrement Register FT23 |  | XDS | 126749 | 5 |
|  | - Buffered Latch No. 1 FT24 |  | XDS | 126745 | 19 |
|  | - Fast Access Memory FT25 |  | XDS | 126743 | 5 |
|  | - Buffered Latch No. 3 FT26 |  | XDS | 126856 | 5 |
|  | - Buffered Latch No. 2 FT27 |  | XDS | 126986 | 6 |
|  | - Delay Line Sensors HT15 |  | XDS | 127391 | 2 |
|  | - Gated Inverter IT16 |  | XDS | 115264 | 5 |
|  | . NAND Gate IT25 |  | XDS | 128190 | 12 |
|  | - Parity Generator LT12 |  | XDS | 117382 | 1 |
|  | . Buffer Inverter LTI3 |  | XDS | 123016 | 4 |
|  | - Logic Element LT21 |  | XDS | 126615 | 3 |
|  | - Switch Comparator LT26 |  | XDS | 126982 | 1 |
|  | - Terminator XT10 |  | XDS | 116257 | 8 |

Table A-28. Additional IOP/DC Expansion (Up to 8 Channels), Replaceable Parts

|  <br> Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :--- | :---: | :---: | :---: | :---: |
| A-2 | Assembly, IOP/DC Expansion (up to 8 <br> channels) <br> . Fast Access Memory FT25 |  | XDS | 117618 | 1 |

Table A-29. Basic Cabinet Hardware, Replaceable Parts

| Fig. \& Index No. | Description | Reference Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A-1 | Basic Cabinet (see table A-1 for next higher assembly) |  | XDS | 131416 | 1 |
|  | . Cabinet, basic structure |  | XDS | 117419 | 1 |
|  | - Cap, cabinet top |  | XDS | 134232 | 1 |
|  | . Angle, mounting |  | XDS | 117422 | 4 |
|  | . Plate, bottom |  | XDS | 130146 | 1 |
|  | . Assembly, power distributor box |  | XDS | 117428 | 1 |
|  | - Panels, side |  | XDS | 117338 | 1 |
|  | . Door, cabinet |  | XDS | 131419 | 1 |
|  | . . Trim, door |  | XDS | 127336 | 1 |
|  | . . Hinge, door |  | XDS | 127335-002 | 1 |
|  | . . Trim, side |  | XDS | 127384 | 4 |
|  | . . Catch, spring loaded |  | XDS | 106829 | 2 |
|  | - Assembly, power distributor box, chassis panel |  | XDS | 130155 | 1 |
|  | . Casters, full swivel, 16-32-1/2-xK |  | 373 |  | 4 |
|  | . Frame, swing |  | XDS | 117319 | 1 |
|  | - Door, chassis column |  | XDS | 124386 | 1 |
|  | . Bracket, pin protect |  | XDS | 132165-002 | 2 |
|  | - Block, stop |  | XDS | 132523 | 2 |
|  | - Assembly, bus bar |  | XDS | 130111 | 1 |
|  | - Cable Clamp |  | XDS | 100657-002 | 6 |
|  | - Cable Clamp |  | XDS | 100657-004 | 3 |

(Continued)

Table A-29. Basic Cabinet Hardware, Replaceable Parts (Cont.)

| Fig. \& Index No. | Description | Reference <br> Designator | Manufacturer | Part No. | Qty |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $A-1$ <br> (Cont.) | - Door, Chassis column |  | XDS | 1341 ? | 1 |
|  | - Assembly, top fan (see tables A-2, A-6, and A-10 for next higher assembly) |  | XDS | 123943 | 1 |
|  | . . Bracket, fan |  | XDS | 117281 | 2 |
|  | . . Cord, ac |  | XDS | 126374-001 | 1 |
|  | . . Bushing, strain relief |  | 374 | SR | 3 |
|  | . . Fan, electric |  | 139 | MARK 4 | 3 |
|  | . . Guard, fan |  | XDS | 111187 | 3 |
|  | - Assembly, bottom fan (see tables A-2, A-6, and A-10 for next higher assembly) |  | XDS | 117320 | 1 |
|  | . . Support, side, blower chassis |  | XDS | 126337 | 2 |
|  | . . Plate, base, blower chassis |  | XDS | 126338 | 1 |
|  | . . Filter Air |  | XDS | 117427 | 1 |
|  | . Cord, ac |  | XDS | 126374-001 | 1 |
|  | . . Bushing, strain relief |  | 374 | SR | 1 |
|  | . . Shim, sponge rubber, 34 inches |  | XDS | 100238-001 | 1 |
|  | . . Fan, electric |  | 137 | MARK 4 | 3 |

Table A-30. Manufacturer's Code Index

| Code No. | Name | Address |
| :---: | :--- | :--- |
| 55 | Centralab Electronics | 900 E. Keefe Ave., Milwaukee, Wisc. 53201 |
| 56 | Eldema Corp. | 18345 Susana Rd., Compton, Calif. 90221 |
| 84 | General Electric Co., Miniature Lamp Dept. | Nela Park, Cleveland, Ohio 44112 |
| 102 | Harvey Hubbell Inc. | Harvey St. and Bostwick, Bridgeport, Conn. 06600 |
| 107 | Allen-Bradley Co. | 1201 Second St., Milwaukee, Wisc. 53204 |
| 139 | Rotron Mfg. Co. | Woodstock, N. Y. 12498 |
| 140 | The Digitran Co. | 855. S. Arroyo Pkwy., Pasadena, Calif. 91105 |
| 203 | Honeywell, Micro Switch Div. | 11 W. Spring St., Freeport, IlI. 61033 |

Table A-30. Manufacturer's Code Index (Cont.)


## XDS

READER SURVEY


XEROX
701 South Aviation Boulevard El Segundo, California 90245
213 679-4511


[^0]:    (Continued)

[^1]:    *First opcode specifies direct addressing; second specifies indirect addressing

[^2]:    *First opcode specifies direct addressing; second specifies indirect addressing

[^3]:    （Continued）

