# **GD** CONTROL DATA CDC® CYBER 170 COMPUTER SYSTEMS MODELS 815, 825, 835, 845, AND 855 CDC® CYBER 180 COMPUTER SYSTEMS MODELS 810, 830, 835, 840, 845, 850, 855, 860, AND 990 # **VIRTUAL STATE** VOLUME II INSTRUCTION DESCRIPTIONS PROGRAMMING INFORMATION ## **REVISION RECORD** | REVISION | DESCRIPTION | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 01<br>(06-06-83) | Manual released. | | A<br>(04-15-84) | Manual updated to add support of CYBER 170 Model 845 and CYBER 180 Models 810, 830, 835, 845, 855, and 990. Due to extensive changes, revision bars and dots are not used and all pages reflect the latest revision level. This edition obsoletes all previous editions. | | B<br>(11-02-84) | Manual updated to add support of CYBER 180 Models 840, 850, and 860. | | C<br>(05-03-85) | Manual revised; includes Engineering Change Order 46891. Front Cover through 5, 7/8, 14, 16, II-1-30, II-2-1, II-2-78, II-2-127, II-2-129, II-2-130, II-2-134, II-2-136 through II-2-138, and II-2-145 through II-2-147 are revised. Page II-2-149 is added. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | | | | | | | | | | | REVISION LETTERS I, O, Q, S, X AND Z ARE NOT USED. © 1983, 1984, 1985 by Control Data Corporation All rights reserved Printed in the United States of America Address comments concerning this manual to: Control Data Corporation Publications and Graphics Division 4201 North Lexington Avenue St. Paul, Minnesota 55112 or use Comment Sheet in the back of this manual. # LIST OF EFFECTIVE PAGES New features, as well as changes, deletions, and additions to information in this manual, are indicated by bars in the margins or by a dot near the page number if the entire page is affected. A bar by the page number indicates pagination rather than content has changed. | PAGE | REV | PAGE | REV | PAGE | REV | PAGE | REV | PAGE | REV | |--------------------|--------|--------------------|-----|----------------------|--------|--------------------|--------|------------------------|-----| | Front Cover | _ | II-1-42 | Α | 11-1-101 | A | 11-2-23 | A | II-2-82 | A | | Title Page | - | II-1-43 | A | II-1-102 | A | 11-2-24 | A | 11-2-83 | A | | 2 | C | II-1-44 | A | II-1-103 | A | II-2-25 | A | II-2-84 | A | | 3 | c | II-1-45 | A | II-1-104 | A | II-2-26 | A | II-2-85 | - A | | 4 | C | II-1-46 | A | II-1-105 | A | 11-2-27 | A | 11-2-86 | Α - | | 5 | C | II-1-47 | A | II-1-106 | A | 11-2-28 | A | II-2-87 | A | | 6 | A | II-1-48 | A | II-1-107 | A | II-2-29 | A | 11-2-88 | A | | 7/8 | C | II-1-49 | A | II-1-108 | A | II-2-30 | A | 11-2-89 | A | | 9 | В | II-1-50 | A | II-1-109 | A | II-2-31 | A | II-2-90 | A | | 10 | A | II-1-51 | A | II-1-110 | A | II-2-32 | A | II-2-91 | A | | 11 | A | II-1-52 | A | II-1-111 | A | II-2-33 | A | 11-2-92 | A | | 12 | A | II-1-53 | A | II-1-112 | A | 11-2-34 | A | 11-2-93 | A | | 13 | В | II-1-54 | A | II-1-113 | A | II-2-35 | A | II-2-94 | A | | 14 | C | II-1-55 | A | II-1-114 | A | 11-2-36 | A | II-2-95 | A | | 15 | В | II-1-56 | A | II-1-115 | A | II-2-37 | A | 11-2-96 | A | | 16 | C | II-1-57 | A | II-1-116 | A | II-2-38 | A | II-2-97 | A | | II-1-1 | A | II-1-58 | В | II-1-117 | A | II-2-39 | A | 11-2-98 | A | | II-1-2 | A | II-1-59 | A | II-1-118 | A | 11-2-40 | A | 11-2-99 | A | | II-1-3 | A | 11-1-60 | A | II-1-119 | A | 11-2-41 | A | 11-2-100 | A | | II-1-4 | A | II-1-61 | A | II-1-120 | A | II-2-42 | A | II-2-101 | A | | II-1-5 | В | II-1-62 | A | II-1-121 | A | 11-2-43 | A | II-2-102 | A | | II-1-6 | A | II-1-63 | В | II-1-122 | A | 11-2-44 | A | 11-2-103 | В | | II-1-7 | A | II-1-64 | A | II-1-123 | A | 11-2-45 | A | 11-2-104 | A | | II-1-8 | A | II-1-65 | A | II-1-124 | A | 11-2-46 | A | II-2-105 | A | | II-1-9 | В | II-1-66 | A | II-1-125 | A | II-2-47 | A | 11-2-106 | A | | II-1-10 | В | II-1-67 | A | II-1-126 | A. | 11-2-48 | A | 11-2-107 | A | | II-1-11 | A | 11-1-68 | A | II-1-127 | A | 11-2-49 | A | 11-2-108 | Α. | | II-1-12 | A | 11-1-69 | A | 11-1-128 | A | II-2-50 | A | II-2-109<br> II-2-110 | A | | II-1-13 | A | 11-1-70 | A | II-1-129 | A | II-2-51 | A | | A | | II-1-14 | A | II-1-71 | A | II-1-130<br>II-1-131 | A | II-2-52 | A | II-2-111 | A | | II-1-15<br>II-1-16 | A | II-1-72<br>II-1-73 | A | 11-1-131 | A<br>A | II-2-53 | A | II-2-112<br>II-2-113 | A | | II-1-16<br>II-1-17 | A<br>A | II-1-74 | A | 11-1-132 | A | II-2-54<br>II-2-55 | A<br>A | II-2-113 | A | | II-1-17<br>II-1-18 | A | II-1-75 | A | II-1-134 | A | II-2-56 | A | II-2-114<br>II-2-115 | В | | II-1-18<br>II-1-19 | A | II-1-76 | A | 11-1-135 | A | II-2-57 | A | 11-2-115 | A | | II-1-19<br>II-1-20 | Â | II-1-77 | A | II-1-136 | A | II-2-58 | A | II-2-110<br>II-2-117 | A | | II-1-21 | A | 11-1-78 | A | 11-1-137 | A | 11-2-59 | A | 11-2-118 | Â | | 11-1-22 | В | 11-1-79 | Â | 11-2-1 | c | 11-2-60 | Â | 11-2-119 | A | | 11-1-23 | В | 11-1-80 | Â | 11-2-2 | Ă | 11-2-61 | Â | 11-2-120 | A | | II-1-24 | В | II-1-81 | A | II-2-3 | A | 11-2-62 | A | II-2-121 | В | | II-1-25 | В | II-1-82 | A | 11-2-4 | Ā | 11-2-63 | A | II-2-122 | A | | II-1-26 | В | II-1-83 | A | II-2-5 | A | 11-2-64 | A | II-2-123 | A | | II-1-26.1/ | | II-1-84 | A | 11-2-6 | A | II-2-65 | A | II-2-124 | A | | II-1-26.2 | В | II-1-85 | A | II-2-7 | A | II-2-66 | Ā | II-2-125 | Α | | II-1-27 | A | 11-1-86 | A | 11-2-8 | A | II-2-67 | A | 11-2-126 | A | | II-1-28 | A | II-1-87 | A | 11-2-9 | A | 11-2-68 | A | II-2-127 | C | | II-1-29 | A | II-1-88 | A | II-2-10 | A | II-2-69 | A | 11-2-128 | A | | II-1-30 | c | II-1-89 | A | II-2-11 | A | II-2-70 | A | II-2-129 | c | | II-1-31 | A | II-1-90 | В | 11-2-12 | A | II-2-71 | A | 11-2-130 | C | | II-1-32 | A | II-1-91 | A | II-2-13 | A | II-2-72 | A | 11-2-131 | Α | | II-1-33 | A | II-1-92 | A | 11-2-14 | В | II-2-73 | A | 11-2-132 | A | | II-1-34 | A | II-1-93 | A | II-2-15 | A | II-2-74 | A | II-2-133 | A | | II-1-35 | A | II-1-94 | A | II-2-16 | A | II-2-75 | A | II-2-134 | С | | II-1-36 | A | II-1-95 | A | II-2-17 | A | 11-2-76 | A | II-2-135 | A | | II-1-37 | A | 11-1-96 | A | II-2-18 | A | II-2-77 | A | II-2-136 | С | | II-1-38 | A | II-1-97 | A | 11-2-19 | A | II-2-78 | c | II-2-137 | C | | II-1-39 | A | II-1-98 | A | 11-2-20 | A | 11-2-79 | A | II-2-138 | С | | II-1-40 | A | II-1-99 | A | II-2-21 | A | 11-2-80 | A | II-2-139 | A | | II-1-41 | A | II-1-100 | A | 11-2-22 | A | II-2-81 | A | II-2-140 | A | | PAGE | REV | PAGE | REV | PAGE | REV | PAGE | REV | PAGE | REV | |----------------------|--------|------------|-----|------|-----|------|----------|------|-------| | II-2-141 | A | | | | | | | | | | 11-2-142 | A | | | | | | | | | | 11-2-143 | A | | | | | | | , | | | 11-2-144 | A | | | | 1 1 | | | | | | 11-2-145 | C | | | | | | | | | | 11-2-146 | C | | | | | | | | | | II-2-147<br>II-2-148 | C | , i | | | ŀ | • | | 4 | | | II-2-149 | C | | 1 | | | | | | | | II-A-1 | Ă | | | | | | | | | | II-A-2 | A | | | | l 1 | | | | 1 | | II-A-3 | A | | | | ] I | | | | | | II-B-1 | A | | 1 | | 1 1 | | | | | | II-B-2 | A | | | | | | | | ŀ | | II-B-3<br>II-B-4 | A<br>A | | | | | | İ | | | | II-B-4<br>II-B-5 | A | | | | | | | | | | II-C-1 | В | | | | | | | | | | II-C-2 | Ā | | | | | | | | 1 | | II-C-3 | A | 1 | | | | | | | | | II-C-4 | A | | | | | | | | | | II-C-5 | A | | | | | | | 1 | | | II-C-6<br>II-C-7 | A | | | | | | | | | | II-C-7 | A | | | | | | | | | | II-C-9 | A | | | | | | | ' | | | II-C-10 | A | | | | | | <b>!</b> | | | | II-C-11 | A | | | | | | | | | | II-D-1 | A | | | | | | 1 1 | ł | | | II-D-2 | A | | | | | | | | 1 | | II-D-3 | В | | | | 1 1 | | 1 1 | | | | II-D-4<br>II-D-5 | B<br>B | | | | | | | | | | 11-D-6 | A | | | | | | | | | | II-D-7 | В | | | | | | | | | | II-D-8 | A | | ŀ | | | | | | | | II-D-9 | A | | | | | | | | | | II-D-10 | A | | | | | | | | | | II-D-11 | A | | | | | | i i | | ] [ | | II-D-12<br>II-D-13 | A<br>A | | | | | | | | | | II-D-13<br>II-D-14 | A | | | | | | | | | | II-D-15 | A | | . [ | | | | 1 | | | | II-D-16 | A | | | • | | | | 1 | | | Index-1 | В | | Ė | | | | | | | | Index-2 | В | . | .[ | | 1 | | 1 | | | | Index-3 | В | | | | | | 1 | | | | Index-4 | B<br>B | | | 1 | | | | | | | Index-5<br>Index-6 | В | | | | | | | 1 | | | Index-7 | В | | | | | | | * . | | | Comment Sheet | C | | | | | | | | | | Back Cover | - | | | | | | | | 1 1 | | | 1 | | | | | | [ | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | . | | | | 1 | ł | <b> </b> | | | | | | | | | 1 | | | | | | | | | Į . I | | | | | | | | . | | | | | | | | | | | | | | | | | | | ' | | | ` · | | | | | | | | | | | | | | | | 1 | l: | | 1 | | 1 | | | | | | | 1 | | | | | | | | | | 1 | 1 | | | | | | | | ļ | | 1 | | | | | | | | 4 4 | | | | I | | | | | | | | | | | 1 | ; <u> </u> | | l | | | | | | ## PREFACE This manual contains hardware reference information for the CDC® CYBER 170 Models 815, 825, 835, 845, and 855 computer systems, and the CYBER 180 Models 810, 830, 835, 840, 845, 850, 855, 860, and 990 computer systems, in their Virtual State of operation. This manual provides model-independent instruction descriptions and programming information relative to the computer systems hardware. Additional hardware reference information regarding operation of the computer systems in both their CYBER 170 State and Virtual State environments is available in manuals listed in the system publications index on the following page. ## **AUDIENCE** This manual is for use by programming and engineering services personnel who operate, program, and maintain the computer systems. Other manuals applicable to the CYBER 170 and CYBER 180 computer systems are: | Control Data Publication | Publication Number | |-----------------------------------------------------------------|--------------------| | NOS Version 2 Operator/Analyst Handbook | 60459310 | | NOS Version 2 Systems Programmer's Instant | 60459370 | | NOS Version 1 Operator's Guide | 60457700 | | NOS Version 1 Systems Programmer's Instant | 60457790 | | NOS/BE Version 1 Operator's Guide | 60457380 | | NOS/BE Version 1 System Programmer's Reference Manual, Volume 1 | 60458480 | | NOS/BE Version 1 System Programmer's Reference Manual, Volume 2 | 60458490 | | NOS/VE Analysis Usage | 60463915 | | NOS/VE Operations Usage | 60463914 | | Codes Booklet | 60458100 | | Maintenance Register Codes Booklet | 60458110 | | CDC® 721 Enhanced Display Terminal (CC634B) HRM | 62950102 | | | | Publication ordering information and latest revision levels are available from the Literature Distribution and Services catalog, publication number 90310500. 60458890 C ## WARNING This equipment generates, uses and can radiate radio frequency energy and if not installed and used in accordance with the instructions manual, may cause interference to radio communications. As temporarily permitted by regulation, it has not been tested for compliance with the limits for Class A computing device pursuant to Subpart J of Part 15 of the FCC Rules which are designed to provide reasonable protection against such interference. Operation of this equipment in a residential area is likely to cause interference in which case the user at his own expense will be required to take whatever measures may be required to correct the interference. # **CONTENTS** | 1. | INSTRUCTION DESCRIPTIONS | II-1-1 | E-1 V1/V0 T 12 | | |-----|----------------------------------------|------------------|-----------------------------------|---------| | 1. | INSTRUCTION DESCRIPTIONS | 11-1-1 | Enter X1/X0, Immediate<br>Logical | 11-1-24 | | Vir | tual State CP Instructions | II-1-1 | Enter X1/X0, Signed | 11 1 27 | | | Instruction Formats | II-1-1 | Immediate | II-1-25 | | | struction Description Nomenclature | | Enter, Signed Immediate | II-1-25 | | | errupts | II-1-3 | CP Shift Instructions | II-1-25 | | | General Instructions | II-1-4 | | | | | CP Load and Store Instructions | II-1-5 | Shift Word, Circular | II-1-26 | | | Load/Store Multiple | II-1-6 | Shift End-Off, Word/Half-<br>Word | TT 1.07 | | | Load/Store Word | II-1-7 | CP Logical Instructions | II-1-27 | | | Load/Store Word, Indexed | II-1-7 | | II-1-27 | | | Load/Store Address | II-1-8 | Logical Sum/Difference/ | TT 1 00 | | | Load/Store Address, Indexed | II-1-8 | Product | II-1-28 | | | Load/Store Bytes | II-1-0<br>II-1-9 | Logical Complement | II-1-28 | | | Load/Store Bytes, Immediate | II-1-9 | Logical Inhibit | 11-1-29 | | | | II-1-9 | CP Register Bit String | | | | Load Bytes, Relative<br>Load/Store Bit | | Instructions | 11-1-29 | | | · · · · · · · · · · · · · · · · · · · | II-1-10 | Bit String Descriptor | 11-1-29 | | | CP Integer Arithmetic | | Isolate Bit Mask | II-1-30 | | | Instructions | II-1-11 | Isolate | II-1-30 | | | Half-Word Integer Sum | II-1-12 | Insert | II-1-30 | | | Integer Sum | II-1-13 | CP Mark to Boolean | | | | Half-Word Integer Difference | II-1-14 | Instruction | II-1-30 | | | Integer Difference | II-1-14 | BDP Instruction Descriptions | II-1-31 | | | Half-Word Integer Product | II-1-14 | BDP Nomenclature | II-1-32 | | | Integer Product | II-1-15 | BDP Numeric Instructions | II-1-32 | | | Half-Word Integer Quotient | II-1-15 | Decimal Arithmetic | II-1-34 | | | Integer Quotient | II-1-16 | Decimal Compare | II-1-35 | | | Half-Word Integer/Integer | | Numeric Move | II-1-36 | | | Compare | II-1-16 | Decimal Scale | II-1-37 | | | CP Branch Instructions | II-1-17 | BDP Byte Instructions | II-1-38 | | | Branch Relative | II-1-17 | Byte Compare | II-1-39 | | | Branch Intersegment | II-1-18 | Byte Translate | II-1-40 | | | Branch on Half-Word | II-1-18 | Move Bytes | II-1-40 | | | Branch | II-1-19 | Edit | II-1-41 | | | Branch and Increment | II-1-19 | Edit Mask | II-1-42 | | | Branch on Segments Unequal | 11-1-20 | Edit Operation | II-1-42 | | | CP Copy Instructions | II-1-20 | MOP Description | | | | Copy Address | II-1-21 | Nomenclature | II-1-42 | | | Copy Half Word | II-1-21 | End Suppression Toggle | II-1-43 | | | Copy Full Word | II-1-22 | Special Characters Table | | | | CP Address Arithmetic | | Symbol | II-1-43 | | | Instructions | II-1-22 | Negative Sign Toggle | II-1-43 | | | Address Increment, Indexed | II-1-22 | | | | | Address Increment, Signed | 11 1 22 | Zero Field Toggle | II-1-43 | | | Immediate | TT_1_22 | Skipping of Signs | II-1-44 | | | Address Relative | II-1-23 | Microoperation 0 | II-1-44 | | | | II-1-23 | Microoperation 1 | II-1-44 | | | Address Increment, Modulo | II-1-23 | Microoperation 2, 3 | II-1-44 | | | CP Enter Instructions | II-1-23 | Microoperation 4 | II-1-44 | | | Enter Zeros/Ones/Signs | II-1-24 | Microoperation 5 | II-1-44 | | | Enter, Immediate Positive/ | | Microoperation 6 | II-1-45 | | | Negative | II-1-24 | Microoperation 7 | II-1-45 | 60458890 B | Microoperation 8 | II-1-45 | Return | II-1-74 | |-----------------------------------|--------------------|-----------------------------------------------|--------------------| | Microoperation 9 Microoperation A | II-1-45 | Pop | II-1-75 | | Microoperation B | II-1-46<br>II-1-46 | Copy Free Running Counter | II-1-76 | | Microoperation C | II-1-46 | Test and Set Bit Test and Set Page | II-1-77<br>II-1-77 | | Microoperation D | II-1-46 | · · · · · · · · · · · · · · · · · · · | II-1-78 | | Microoperation E | II-1-47 | Call Relative | II-1-78 | | Microoperation F | II-1-47 | Compare Swap<br>Call Indirect | II-1-81 | | Edit Function NUMERIC | II-1-47 | | II-1-83 | | Termination of the | 11-1-47 | Reserved Operation Codes<br>Execute Algorithm | II-1-83 | | Edit Instruction | II-1-47 | Local Privileged System | 11-1-05 | | Byte Scan While Nonmember | II-1-48 | Instructions | II-1-83 | | BDP Subscript and Immediate | 11 1 40 | Load Page Table Index | II-1-84 | | Data Instructions | II-1-48 | Global Privileged System | 11 1 04 | | Calculate Subscript and Add | II-1-49 | Instruction | II-1-84 | | Move Immediate Data | 11-1-50 | Processor Interrupt | II-1-84 | | Compare Immediate Data | 11-1-51 | Monitor Mode Instructions | II-1-85 | | Add Immediate Data | 11-1-52 | Mixed-Mode Instructions | II-1-86 | | Floating-Point Instruction | 11 1 32 | Purge Buffer | II-1-86 | | Descriptions | II-1-52 | Copy to/from State Buffer | II-1-87 | | Double-Precision Register | | Branch on Condition Register | II-1-88 | | Designators | II-1-53 | Peripheral Processor Instruction | 11 1 00 | | Floating-Point Conversion | | Descriptions | II-1-90 | | Instructions | II-1-53 | PP Instruction Formats | II-1-90 | | Convert From Integer to FP | II-1-53 | PP Data Format | 11-1-90 | | Convert From FP to Integer | II-1-53 | PP Relocation Register Format | II-1-91 | | Floating-Point Arithmetic | | PP Load and Store Instructions | II-1-93 | | Instructions | II-1-54 | PP Arithmetic Instructions | II-1-97 | | Floating-Point Sum/ | | PP Logical Instructions | II-1-103 | | Difference | II-1-55 | PP Replace Instructions | II-1-108 | | Floating-Point Product | II-1-56 | PP Branch Instructions | II-1-113 | | Floating-Point Quotient | II-1-57 | PP Central Memory Access | | | Floating-Point Branch | II-1-58 | Instructions | II-1-116 | | Normal Exit | II-1-58 | PP Input/Output Instructions | II-1-124 | | Branch Exit | II-1-58 | Other IOU Instructions | II-1-135 | | Group Interrupt Conditions | II-1-58 | Exchange Jumps | II-1-136 | | Floating-Point Branch on | | Dicharge damps | 11 1 13 | | Comparison | II-1-59 | | | | Floating-Point Branch on | 22 2 37 | 2. PROGRAMMING INFORMATION | 11-2-1 | | Condition | II-1-59 | 2. Involution Information | | | Floating-Point Compare | II-1-60 | CP Exchange Operations | II-2-1 | | Vector Instruction Descriptions | II-1-60 | Virtual State Job-to-Monitor | | | Vector Instruction Format | II-1-61 | Exchange Operations | II-2-3 | | Integer Vector Arithmetic | II-1-63 | Virtual State Monitor-to-Job | , | | Integer Vector Compare | II-1-63 | Exchange Operations | II-2-3 | | Logical Vector Arithmetic | II-1-64 | Exchange Packages | II-2-3 | | Integer/Floating-Point | | CP Registers | II-2-6 | | Vector Conversion | II-1-64 | Process State Registers | II-2-6 | | Floating-Point Vector | | CP Base Constant (BC) | 11 2 0 | | Arithmetic | II-1-64 | Register | II-2-6 | | Special Purpose Vector | 0. | CP Debug Index (DI) Register | | | Instructions | II-1-65 | CP Debug List Pointer (DLP) | | | System Instruction Descriptions | II-1-71 | Register | II-2-6 | | Nonprivileged System | | CP Debug Mask Register (DM) | | | Instructions | II-1-72 | Register (MI) | 11-2-7 | | Program Error | II-1-72 | CP Flag Register | II-2-8 | | Scope Loop Sync | II-1-73 | Critical Frame Flag | | | Exchange | II-1-73 | (CFF) | II-2-8 | | | On-Condition Flag (OCF) | II-2-8 | CP Job Process State (JPS) | 11-2-14 | |----|---------------------------------------|-----------------|----------------------------------|--------------| | | Process-Not-Damaged | 0 0 | Register | | | | (PND) Flag | 11-2-8 | CP Model Dependent Word (MDW) | | | | CP Largest Ring Number (LRN) | | Register | 11-2-14 | | | Register | II-2-8 | CP_Monitor Process (MPS) | 0 15 | | | CP Last Processor | | Register | 11-2-15 | | | Identification (LPID) | | CP System Interval Timer | * | | | Register | II-2-8 | (SIT) Register | II-2-15 | | | CP Monitor Condition Registe | r | CP Virtual Machine | | | | (MCR) | II-2-8 | Capability List (VMCL) | II-2-15 | | | CP Monitor Mask Register | 11-2-8 | CM Registers | 11-2-16 | | | Operand X Registers | 11-2-9 | CM Corrected Error Log (CEL) | | | | CP Process Interval Timer | | Register | 11-2-16 | | | (PIT) | 11-2-9 | CM Element Identifier (EID) | | | | · · · · · · · · · · · · · · · · · · · | | | II-2-17 | | | CP Program Address (P) | TT 2 0 | Register | 11 2 17 | | | Register | II-2 <b>-</b> 9 | CM Environment Control (EC) | II-2-17 | | | CP Segment Table Address | 0 10 | Register | | | | (STA) Register | 11-2-10 | CM Free-Running Counter Register | 11-2-17 | | | CP Segment Table Length | | CM Options Installed (01) | 0 1 <b>-</b> | | | (STL) Register | II-2-10 | Register | II-2-17 | | | CP Top-of-Stack (TOS) | | CM Port Bounds Register | 11-2-17 | | | Pointer Register | 11-2-10 | CM Status Summary Register | II-2-17 | | | CP Trap Enable (TE) Register | II-2-10 | CM Uncorrectable Error Log | | | | CP Trap Pointer (TP) | | (UEL) Register | II-2-18 | | | Register | II-2-10 | IOU Registers | II-2-18 | | | CP Untranslatable Pointer | | IOU Element Identifier (EID) | | | | (UTP) Register | II-2-11 | Register | II-2-19 | | | CP Untranslatable Virtual | | IOU Environment Control (EC) | | | | Machine Identifier | | Register | II-2-19 | | | (UVMID) Register | 11-2-11 | IOU Fault Status (FS) Registers | II-2-19 | | | | 11 2 11 | IOU Fault Status Mask Register | II-2-19 | | | CP User Condition Register | 11-2-11 | | | | | (UCR) | | IOU Options Installed (OI) | 11-2-19 | | | CP User Mask Register (UMR) | 11-2-11 | Register | 11-2-19 | | | CP Virtual Machine | TT 0 10 | IOU OS Bounds Register | II-2-19 | | | Identifier (VMID) Register | | IOU Status Summary Register | | | CP | Processor State Registers | 11-2-12 | IOU Test Mode (TM) Register | 11-2-20 | | | CP Options Installed (OI) | | CP Condition and Mask Registers | 11-2-20 | | | Register | II-2-13 | CP Condition Register Bit | 0 00 | | | CP Page Size Mask (PSM) | | Grouping | 11-2-23 | | | Register | II-2-13 | CP Interrupts | II-2-25 | | | CP Page Table Address | | Exchange Interrupts | 11-2-25 | | | (PTA) Register | II-2-13 | Trap Interrupts | II-2-25 | | | CP Page Table Length (PTL) | | Interrupt Conditions | 11-2-26 | | | Register | II-2-13 | Access Violation (MCR 54) | II-2-26 | | | CP Processor Fault Status | | Address Specification | | | | (PFS) Registers | II-2-13 | Error (MCR 52) | II-2-27 | | | CP Processor Identifier | 11 2 15 | Arithmetic Loss-of- | | | | | 11-2-13 | Significance (UCR 62) | II-2-27 | | | (PID) Register | 11 2 15 | Arithmetic Overflow (UCR 57) | | | | CP Processor Test Mode (PTM) | TT 0 10 | Code of Energy Elec (UCB 53) | TT-2-29 | | | Register | II-2-13 | Critical Frame Flag (UCR 53) | | | | CP Status Summary (SS) | | Debug (UCR 56) | II-2-28 | | | Register | 11-2-13 | Divide Fault (UCR 55) | 11-2-28 | | | CP Cache/Map Corrected | | Environment Specification | | | | Error Log (CCEL/MCEL) | | Error (MCR 55) | II-2-28 | | | Register | II-2-14 | Exponent Overflow (UCR 58) | 11-2-29 | | | CP Dependent Environment | | Exponent Underflow (UCR 59) | II-2-29 | | | Control (DEC) Register | 11-2-14 | External Interrupt (MCR 56) | II-2-29 | | | CP Element Identifier (EID) | | Floating-Point Indefinite | | | | Register | II-2-14 | (UCR 61) | II-2-29 | | | <del>-</del> | | | | | Floating-Point Loss-of- | | Data Type 1: Packed | | |---------------------------------|---------|-----------------------------|---------| | Significance (UCR 60) | 11-2-30 | Decimal, Unsigned Slack | | | Free Flag (UCR 50) | 11-2-30 | Digit | II-2-42 | | Instruction Specification | | Data Type 2: Packed | | | Error (MCR 51) | 11-2-30 | Decimal, Signed | 11-2-43 | | Inter-Ring Pop (UCR 52) | 11-2-31 | Data Type 3: Packed | | | Invalid BDP Data (UCR 63) | 11-2-31 | Decimal, Signed, Slack | | | Invalid Segment/Ring | | Digit | 11-2-43 | | Number Zero (MCR 60) | II-2-31 | Data Type 4: Unpacked | | | Not Assigned (MCR 49) | II-2-31 | Decimal, Unsigned | II-2-43 | | Outward Call/Inward Return | | Data Type 5: Unpacked | | | (MCR 61) | II-2-31 | Decimal, Trailing Sign | | | Page Table Search | | Combined Hollerith | II-2-44 | | Without Find (MCR 57) | 11-2-32 | Data Type 6: Unpacked | | | Privileged Instruction | | Decimal, Trailing Sign | | | Fault (UCR 48) | II-2-32 | Separate | II-2-44 | | Process Interval Timer | | Data Type 7: Unpacked | | | (UCR 51) | II-2-32 | Decimal, Leading Sign | | | Detected Uncorrectable | | Combined Hollerith | II-2-44 | | Error (MCR 48) | 11-2-32 | Data Type 8: Unpacked | | | CYBER 170 State Exchange | 11 2 32 | Decimal, Leading Sign | | | Request (MCR 53) | 11-2-32 | Separate | II-2-44 | | Short Warning (MCR 50) | 11-2-32 | Data Type 9: Alphanumeric | 11-2-45 | | Soft Error Log (MCR 62) | 11-2-33 | Data Type 10: Binary, | 11-2-4. | | System Interval Timer | 11-2-33 | * * · | 11-2-45 | | | TT 2 22 | Unsigned | 11-2-4. | | (MCR 59) | II-2-33 | Data Type 11: Binary, | TT 2 / | | Trap Exception (MCR 63) | 11-2-33 | Signed | II-2-45 | | Unimplemented Instruction | ~~ 0 00 | Slack Digit | 11-2-45 | | (UCR 49) | II-2-33 | Undefined Results | 11-2-45 | | Multiple Interrupt Conditions | 11-2-33 | Overlap | 11-2-45 | | Flags | II-2-35 | Invalid Data | II-2-45 | | Stack Manipulating Operations | II-2-36 | Vector Programming | 11-2-46 | | Stack Frames and Save Areas | 11-2-36 | Vector Length (Number of | | | Stack Frame Save Area Format | II-2-36 | Operations) | 11-2-47 | | Stack Frame Save Area | | Vector Page Size | II-2-48 | | Descriptor Field | II-2-37 | Vector Broadcast | II-2-48 | | Virtual Machine Identifier | | Vector Interrupts | II-2-48 | | (VMID) Field | 11-2-38 | Vector Overlap | II-2-48 | | User Mask/Condition and | | Floating-Point Programming | II-2-48 | | Monitor Condition Fields | II-2-39 | Floating-Point Data Formats | II-2-49 | | Assigned Registers During Stack | | Standard and Nonstandard FP | | | Operation | II-2-39 | Numbers | II-2-51 | | Top-of-Stack Pointers | II-2-39 | Floating-Point Zero | 11-2-51 | | Dynamic Space Pointer (A0) | 11-2-39 | Floating-Point Nonzero | II-2-51 | | Current Stack Frame Pointer | | Floating-Point Infinite | 11-2-51 | | (A1) | II-2-39 | Floating-Point Indefinite | 11-2-52 | | Previous Save Area Pointer | 11 2 37 | Double-Precision Non- | 11 2 32 | | (A2) | 11-2-39 | standard FP Numbers | 11-2-52 | | Binding Section Pointer | 11 2 37 | | 11-2-52 | | (A3) | 11-2-40 | Exponent Arithmetic | | | | II-2-40 | Normalization | 11-2-52 | | Argument Pointer (A4) | 11-2-40 | Floating-Point Sum and | TT 0 50 | | Exceptions During Stack | TT 2 40 | Difference | II-2-52 | | Operations | 11-2-40 | Floating-Point Multiply | II-2-53 | | Business Data Processing | TT 0 /0 | Floating-Point Divide | II-2-53 | | Programming | II-2-40 | Floating-Point End Cases | II-2-54 | | BDP Data Descriptors | 11-2-40 | Program Monitoring | II-2-64 | | BDP Data Types | 11-2-41 | Debug | 11-2-64 | | Data Type 0: Packed | 0 | Debug List | II-2-64 | | Decimal, Unsigned | 11-2-42 | Debug List Pointer Register | II-2-65 | | | | | | | Debug Index Register | 11-2-65 | Return from Virtual State | | |-----------------------------------|----------------------|--------------------------------------------------------------|-----------| | Debug Mask Register | 11-2-66 | <del></del> | II-2-105 | | Enabling Debug | II <b>-</b> 2-68 | Exchange Packages used in | _ | | Debug Scan Operation | 11-2-68 | CYBER 170 State | II-2-107 | | Interrupts During Debug Scan | 11-2-69 | | 11-2-107 | | Debug-Software Interaction, | | Program Address (P) | | | Debug Enabled | 11-2-70 | Register | II-2-109 | | Debug-Software Interaction, | | Stack Pointers | II-2-109 | | Debug Disabled | II-2-70 | EM Register | 11-2-109 | | Virtual and Central Memory | | Flags | 11-2-110 | | Programming | II-2-77 | Unified Extended Memory | | | Process Virtual Memory | 11-2-78 | (UEM) Enable Flag | 11-2-110 | | System Virtual Memory | 11-2-78 | Expanded Addressing | | | Real Memory | II-2-79 | Select Flag | 11-2-110 | | Address Tables | 11-2-83 | Enhanced Block Copy Flag | II-2-110 | | Segment Descriptor Table | II-2-84 | Software Flag (Word 4, | | | System Page Table | II-2 <b>-</b> 86 | Bit 28) | 11-2-110 | | Page Table Search | 11-2-86 | Instruction Stack Purge | | | Page Table Entries | 11-2-87 | Flag | II-2-111 | | PTE Control Fields | 11-2-88 | Software Flag (Word 4, | | | PTE Segment/Page | | Bit 26) | II-2-111 | | Identifier Field | II-2-88 | CYBER 170 State Monitor | | | PTE Page Frame KMA Field | II-2-89 | Flag | II-2-111 | | Listing of Pages in | | Exit Mode Halt Flag | 11-2-111 | | Page Table | 11-2-90 | RAC Register | II-2-111 | | Process Binding Section | II-2-90 | FLC Register | II-2-111 | | Access Protection | 11-2-91 | Monitor Address (MA) | | | Ring Structure | 11-2-95 | Register | II-2-111 | | Ring Voting | 11-2-95 | Address (A) Registers | II-2-112 | | Effect of RN = 0 | II-2-96 | RAE Register | II-2-112 | | RN for Read/Write Access | | FLE Register | II-2-112 | | RN for Execute Access | 11-2-96 | Virtual State Ring | | | RN Effect on Pop | 11-2-90 | Numbers | II-2-112 | | Instruction | 11-2-97 | Index (B) Registers | II-2-112 | | Effect of RN Violations | II-2-98 | Operand (X) Registers | 11-2-112 | | _ | 11-2-90 | CYBER 170 State Exchange Package | | | Execute Access Privilege/<br>Mode | 11-2-98 | Interstate Stack Frame Save Area | | | | 11-2-99 | Code Modification in CYBER 170 | 11 2 113 | | Keys/Locks | II-2-102 | State | II-2-115 | | Interstate Programming | II-2-102<br>II-2-102 | | II-2-115 | | Operation in CYBER 170 State | 11-2-102 | Debug/Performance Monitoring Exception Handling in CYBER 170 | 11-2 113 | | Memory Addressing in CYBER 170 | TT 0 100 | | 11-2-115 | | State | 11-2-103 | State | II-2-115 | | Cache Invalidation in CYBER 170 | | Software Exception Conditions | II-2-119 | | State (Models 835 through | TT 0 100 | Address Errors | II-2-119 | | 860 Only) | II-2-103 | Illegal Instructions | 11-2-120 | | State-Switching Operations | 11-2-104 | Extended Memory Transfer | II-2-120 | | Virtual State Monitor Mode- | | Exceptions | 11-2-120 | | to-CYBER 170 State | 0 10/ | Hardware Exceptions in | TT 0 101 | | Exchange | 11-2-104 | CYBER 170 State | 11-2-121 | | CYBER 170 State-to- | | 10U Peripheral Processor | TT 0 101 | | Virtual State Monitor | | Programming | II-2-121 | | Mode Exchange | 11-2-104 | Central Memory Addressing by | TT. 0 101 | | Exchanges Within CYBER 170 | | PPs | 11-2-121 | | State | II-2-104 | Absolute and Relocation | | | Call from Virtual State | | Addressing | 11-2-121 | | to CYBER 170 State | 11-2-105 | OS Bounds Test | 11-2-122 | | Trap Interrupt from | | PP Central Memory Read | 11-2-122 | | CYBER 170 State to | | PP Central Memory Write | 11-2-122 | | Virtual State | II-2-105 | PP Memory Addressing by PPs | II-2-123 | 13 | Direct 6-Bit Operand | 11-2-123 | IOU Dedicated Channels | II-2-136 | |---------------------------------|----------|----------------------------------|------------| | Direct 18-Bit Operand | 11-2-123 | Two-Port Multiplexer Programming | 11-2-138 | | Direct 6-Bit Address | 11-2-123 | Function Words | 11-2-139 | | Direct 12-Bit Address | 11-2-123 | Terminal Select (7XXX) | 11-2-139 | | Indexed 12-Bit Address | 11-2-123 | Terminal Deselect (6XXX) | II-2-139 | | Indirect 6-Bit Address | 11-2-123 | Calendar Clock/Auto Dial- | | | Channel Input/Output Operations | 11-2-124 | Out (1XXX) | 11-2-140 | | Channel Flags | II-2-124 | Read Summary Status (00XX) | II-2-141 | | Channel Active Flag | II-2-124 | PP Terminal Data (OlXX) | 11-2-141 | | Register-Full Flag | II-2-124 | PP Write Output Buffer | | | Channel (Marker) Flag | 11-2-125 | (02XX) | II-2-142 | | Error Flag | II-2-125 | Set Operation Mode to | | | Programming for Channel Input/ | | Terminal (03XX) | II-2-142 | | Output | II-2-125 | Set/Clear Data Terminal | | | Inter-PP Communications | II-2-126 | Ready (DTR) (04XX) | II-2-143 | | PP Program Timing Consideration | II-2-127 | Set/Clear Request to Send | | | Cache Invalidation | II-2-127 | (RTS) (05XX) | II-2-143 | | Error Detection and Recovery | II-2-128 | Master Clear (07XX) | II-2-143 | | PP Hardware Errors | II-2-128 | Programming Considerations | II-2-143 | | Channel Parity Errors | II-2-128 | Data Output | II-2-143 | | Parity Errors on Output | | Data Input | II-2-144 | | Data | 11-2-128 | Maintenance Channel Programming | II-2-144 | | Parity Errors on Input | | MCH Function Words | II-2-144 | | Data | 11-2-129 | MCH Control Words | II-2-145 | | Timeout | II-2-129 | MCH Programming for Halt/ | | | Initialization | II-2-129 | Start (Opcode $0/1$ ) | II-2-145 💂 | | Display Station Programming | | MCH Clear LED (Opcode 3) | II-2-145 | | (Channel 10 <sub>8</sub> ) | 11-2-130 | MCH Programming for Read/ | _ | | Keyboard | 11-2-130 | Write (Opcode 4/5) | II-2-146 | | Data Display | II-2-130 | MCH Programming for Master | | | Character Mode | II-2-130 | Clear/Clear Errors | | | Dot Mode | II-2-130 | (Opcode 6/7) | II-2-147 | | Codes | II-2-133 | MCH Echo (Opcode 8) | II-2-147 | | Programming Example | 11-2-134 | MCH Programming for Read | - | | Program Timing Consideration | 11-2-134 | IOU Summary Status | | | Real-Time Clock Programming | 11-2-136 | (Opcode C, IOU Only) | II-2-147 | | | | | | | | | | | ## **APPENDIXES** | A. GLOSSARY | II-A-1 | Twelve-Bit Channel | | |--------------------------|--------|----------------------------|--------| | | , | Control Signals | II-C-2 | | | | Maintenance Channel | | | B. EDIT EXAMPLES | II-B-1 | Signals | II-C-3 | | | | Control Signals | II-C-3 | | | | Signals and Cables | II-C-3 | | C. INTERFACE INFORMATION | II-C-1 | Data Signals | II-C-5 | | | | PP and Channel Interaction | II-C-5 | | Interfaces | II-C-1 | Active Flag | II-C-5 | | Twelve-Bit External | | Full Flag | II-C-5 | | Interface | II-C-1 | Function Instructions | II-C-5 | | Maintenance Channel | | External Channel Input/ | | | Interface | II-C-1 | Output Sequences | II-C-5 | | Two-Port Multiplexer | | | | | Interface | II-C-1 | | | | Signals | II-C-2 | D. INSTRUCTION INDEX | II-D-1 | ## **INDEX** # **FIGURES** | II-1-1 | Vector Instruction Format | II-1-61 | II-2-16 | Virtual BN-to-Page Number/ | 0 00 | |------------------|---------------------------------------|----------------------|--------------------|-----------------------------|--------------------| | II-1-2 | Gather Instruction | II-1-67 | | Page Offset Conversion | 11-2-82 | | II-1-3 | Scatter Instruction | II-1-69 | II-2-17 | PVA-to-RMA Conversion | 11-2-83 | | II-1-4 | PP Instruction Formats | | 11-2-18 | Segment Descriptor Table | | | | and Nomenclature | II-1-91 | | Entry Format | II-2-85 | | II-1-5 | PP Data Format | II-1-92 | II-2-19 | Page Table Search, Start | | | II-1-6 | PP Relocation Register | | | RMA Formation | 11-2-87 | | | Format | II-1-92 | II-2-20 | Page Table Entry Format | 11-2-89 | | II-1-7 | Relocation and Address | | 11-2-21 | Code Base Pointer Format | 11-2-91 | | | Formation | II-1-117 | II-2-22 | PVA-to-SVA Conversion, | | | II-2-1 | CP Calls, Returns and | | | Read/Write | II-2-93 | | | Interrupts | II-2-2 | II-2-23 | PVA-to-SVA Conversion, | | | II-2-2 | Virtual State Exchange | | | Execute | II-2-94 | | | Package | II-2-5 | II-2-24 | Call Indirect Access | | | II-2-3 | Interrupt Flowchart | II-2-34 | | Requirements | II-2-101 | | II-2-4 | Format of XO for Call | | 11-2-25 | Interstate Calls, Returns | | | | Instructions | II-2-37 | | and Interrupts | II-2-106 | | II-2-5 | Virtual State Stack Frame | 11 2 3, | 11-2-26 | Interstate Exchange | | | 11 2 3 | Save Area | 11-2-37 | 11 2 20 | Package | 11-2-108 | | II-2-6 | Stack Frame Save Area | 11 2 37 | 11-2-27 | CYBER 170 State Exchange | 11 1 100 | | 11-2-0 | Descriptor | 11-2-38 | 11-2-21 | Package | 11-2-113 | | II-2-7 | • | II-2-41 | II-2-28 | Interstate Stack Frame | 11 2 113 | | | BDP Data Descriptor Format | 11-2-41 | 11-2-20 | | 11-2-114 | | II-2-8 | Floating-Point Data | TT 0 40 | TT 0 00 | Save Area | 11-2-114 | | TT 0 0 | Formats | 11-2-49 | II-2-29 | Display Station Output | TT 0 100 | | II-2-9 | Debug List Entry | II-2-67 | | Function Code | II-2-133 | | II-2-10 | Debug Condition Select | II-2-66 | II-2-30 | Coordinate Data Word | II-2-133 | | II-2-11 | Central Memory Addressing | | 11-2-31 | Character Data Word | 11-2-133 | | | from CP | II-2-77 | II-2-32 | Receive and Display | | | II-2-12 | Process Virtual Address | | | Program Flowchart | 11-2-135 | | | (PVA) Format | II-2-78 | II-2-33 | IOU Dedicated Channels, | | | II-2-13 | System Virtual Address | | | Models 810, 815, 825, | | | | (SVA) Format | II <del>-</del> 2-79 | | and 830 | 11-2-136 | | II-2-14 | Segment/Page Identifier | | 11-2-34 | IOU Dedicated Channels, | | | | (SPID) Format | 11-2-80 | | Models 835, 840, 845, | | | II-2-15 | Real Memory Address (RMA) | | | 850, 855, 860, and 990 | 11-2-137 | | | Format | II-2-81 | II-C-1 | Data Sequences Timing | II-C-11 | | | | | - | | | | | | | | | | | | | | | | | | | | TABL | ES | | | | | | | | | | | II-1-1 | CP Load and Store | | 11-1-11 | BDP Numeric Instructions | II-1-32 | | | Instructions | II-1-5 | II-1-12 | BDP Divide Fault | II-1-35 | | II-1-2 | CP Integer Arithmetic | | II-1-13 | BDP Byte Instructions | 11-1-38 | | | Instructions | II-1-11 | | BDP Subscript and | | | II-1-3 | CP Branch Instructions | II-1-17 | | Immediate Data | | | II-1-4 | CP Copy Instructions | II-1-20 | | Instructions | II-1-48 | | II-1-5 | CP Address Arithmetic | | II-1-15 | Floating-Point Conversion | | | 11 1 3 | Instructions | II-1-22 | | Instructions | II-1-53 | | II-1-6 | CP Enter Instructions | II-1-23 | 11-1-16 | Floating-Point Arithmetic | | | II-1-7 | CP Shift Instructions | II-1-25 | 11 1 10 | Instructions | II-1-54 | | II-1-8 | | II-1-27 | II-1-17 | Floating-Point Branch | 11 1 31 | | II-1-6<br>II-1-9 | CP Pogical Instructions | 11-1-71 | TT - 1-1/ | Instructions | 11-1-58 | | TT-1-2 | CP Register Bit String Instructions | II-1-29 | II-1-18 | Vector Instructions | II-1-62 | | II-1-10 | | 11-1-72 | II-1-10<br>II-1-19 | Nonprivileged Instructions | II-1-02<br>II-1-72 | | 11-1-10 | Compare j Field and X1 Bits 32 and 33 | 11-1-31 | 11-1-13 | moubiliviteded instructions | 11-1-12 | | | DILS JE AUG JJ | 11-111 | | | | | 6045000 | n. | | | | 15 | | II-1-20 | Local Privileged | | II-2-12 | FP Compare Results | 11-2-55 | |------------------|------------------------------|----------|---------|----------------------------|----------| | | Instructions | II-1-83 | II-2-13 | FP Sum Results, UM Clear | 11-2-56 | | II-1-21 | Mixed Mode Instructions | II-1-86 | II-2-14 | FP Sum Results, UM Set | 11-2-57 | | 11-1-22 | PP Load and Store | | II-2-15 | FP Difference Results, | | | | Instructions | II-1-93 | | UM Clear | 11-2-58 | | II-1-23 | PP Arithmetic Instructions | II-1-98 | 11-2-16 | FP Difference Results, | | | II <b>-</b> 1-24 | PP Logical Instructions | II-1-103 | | UM Set | II-2-59 | | II-1-25 | PP Replace Instructions | II-1-108 | 11-2-17 | FP Product Results, | | | II-1-26 | PP Branch Instructions | II-1-113 | | UM Clear | 11-2-60 | | II-1-27 | PP Central Memory Access | | 11-2-18 | FP Product Results, | | | | Instructions | II-1-116 | | UM Set | 11-2-61 | | II-1-28 | PP Input/Output | | 11-2-19 | FP Quotient Results, | | | | Instructions | II-1-124 | | UM Clear | 11-2-62 | | 11-2-1 | Process State Registers | II-2-7 | 11-2-20 | FP Quotient Results, | | | 11-2-2 | Processor State Registers | II-2-12 | | UM Set | II-2-63 | | II-2-3 | CM Maintenance Registers | II-2-16 | II-2-21 | Debug Conditions | 11-2-72 | | II-2-4 | IOU Maintenance Registers | 11-2-18 | 11-2-22 | System Instruction | | | II <b>-2-</b> 5 | Monitor Condition/Mask | | | Privilege and Mode | 11-2-99 | | | Register Bit Assignments | II-2-21 | II-2-23 | CYBER 170 State Exceptions | II-2-117 | | II-2-6 | User Condition/Mask Register | r | II-2-24 | Keyboard Character Codes | II-2-131 | | | Bit Assignments | II-2-22 | II-2-25 | Display Character Codes | II-2-132 | | II-2-7 | Interrupt Condition Groups | II-2-24 | 11-2-26 | MCH Function Word Bit | | | II-2-8 | Condition of Flags | | | Assignments | II-2-148 | | | Following Call, Return, | | II-C-1 | Maintenance Channel | | | | Pop, Exchange, and Trap | | | Signals | II-C-3 | | | Operations | 11-2-35 | II-C-2 | Data Input Sequence | II-C-6 | | II-2-9 | BDP Operand Types and Field | | II-C-3 | Data Output Sequence | II-C-7 | | | Lengths | II-2-42 | II-C-4 | MCH Input Sequence | II-C-8 | | II-2-10 | Vector Operations | II-2-47 | II-C-5 | MCH Output Sequence | II-C-9 | | II-2-11 | Floating Point | | | | | | | Representation | II-2-50 | | | | 1 This section contains the Virtual State ${\tt CP}$ instruction descriptions and ${\tt PP}$ instruction descriptions. ## **VIRTUAL STATE CP INSTRUCTIONS** The Virtual State CP instructions comprise the following five groups: - General - Business data processing (BDP) - Floating-point (FP) - Vector - System # **CP INSTRUCTION FORMATS** The CP instructions are 16 or 32 bits long, and have 4 basic formats. Format jkiD (32 Bits) Format SjkiD (32 Bits) | ( | ) 4 | 5 7 | 8 11 | 12 15 | 16 19 | 20 | 31 | |---|-------------|-----|------|-------|-------|----|----| | | OP-<br>CODE | s | j | k | i | D | | | ٠ | 5 | 3 | 4 | 4 | 4 | 12 | | <u>Field</u> Description Opcode Operation code. j,k,i Register designators. D Signed shift count, positive displacement, or bit string descriptor. S Suboperation code. ## Format jk (16 Bits) ## Field #### Description Opcode Operation code. j Register designator, suboperation code, or immediate operand. k Register designator or immediate operand. BDP instructions using this format have two data descriptor words which are stored in CM immediately after the instruction. (Refer to BDP Data Descriptors in this section.) ## Format jkQ (32 Bits) ## Field ## Description **Opcode** Operation code. j,k Register designators, suboperation codes, or immediate operand value. Q Signed displacement or immediate operand value. ## INSTRUCTION DESCRIPTION NOMENCLATURE The instruction descriptions in this section use the following address, register, and instruction designators: | Designator | Description | | | | | | | |--------------------|-------------------------------------------------------------------------|--|--|--|--|--|--| | j,k,i,Q,<br>D or S | Refer to corresponding field in CP Instruction Formats in this section. | | | | | | | | Aj or Ak | One of sixteen 48-bit A registers (A0-AF) specified by j or k field. | | | | | | | | Xj or Xk | One of sixteen 64-bit X registers (XO-XF) specified by j or k field. | | | | | | | | Designator | Description | |-----------------------|-----------------------------------------------------------------------------------------------| | XXj or XXk | A double-length X register comprised of Xj and $X(j+1)$ , or Xk and $X(k+1)$ . | | XjL or XkL | Bits 0 through 31 of an X register. | | XjR or XkR | Bits 32 through 63 of an X register. | | 2n*Xk<br>2n*Q<br>2n*D | Xk, Q or D left-shifted n places with zero fill on right (e.g., $8*Q$ shifts Q three places). | | BN | Byte number field of a process virtual address. | | SEG | Segment number field of a process virtual address. | | RN | Ring number field of a process virtual address. | | ( ) | Content of memory location (address is the quantity in parentheses). | ${\tt Additional\ designators\ used\ with\ the\ BDP\ instructions\ are\ listed\ in\ BDP\ Nomenclature\ in\ this\ section.}$ ## **INTERRUPTS** Refer to CP Interrupts in section 2 of this volume for further information on interrupts. Exceptions caused by instruction execution are listed with instruction descriptions. The following exceptions occur independently of instruction execution and, therefore, are not listed: | Bit | Description | |--------|-----------------------------------| | MCR 48 | Detected uncorrectable error. | | MCR 50 | Short warning. | | MCR 53 | CYBER 170 State exchange request. | | MCR 56 | External interrupt. | | MCR 59 | System interval timer. | | MCR 62 | Soft error log. | | MCR 63 | Trap exception. | | UCR 51 | Process interval timer. | | UCR 50 | Free flag. | ## **CP GENERAL INSTRUCTIONS** The 84 CP general instructions are divided into 10 subgroups. Tables II-1-1 through II-1-10 list the instructions in each subgroup. The subgroups are as follows: - Load and store. - Integer arithmetic. - Branch. - Copy. - Address arithmetic. - Enter. - Shift. - Logical. - Register bit string. - Mark to Boolean. ## **CP LOAD AND STORE INSTRUCTIONS** The load and store instructions (table II-l-l) transfer a single bit, byte string, 64-bit word, or multiple 64-bit words between one or more registers and one or more CM locations. Store instructions do not alter any register serving as the source of the data transferred to CM. Table II-1-1. CP Load and Store Instructions | 0pcode | Format | Instruction | Mnemonic | |--------|--------|------------------------|----------| | 80 | jkQ | Load multiple | LMULT | | 81 | jkQ | Store multiple | SMULT | | 82 | jkQ | Load word | LX | | 83 | jkQ | Store word | SX | | 84 | jkQ | Load address | LA | | 85 | jkQ | Store address | SA | | 86 | jkQ | Load bytes, relative | LBYTP,j | | 88 | jkQ | Load bit | LBIT | | 89 | jkQ | Store bit | SBIT | | Α0 | jkiD | Load address, indexed | LAI | | A1 | jkiD | Store address, indexed | SAI | | A2 | jkiD | Load word, indexed | LXI | | А3 | jkiD | Store word, indexed | SXI | | A4 | jkiD | Load bytes | LBYT,X0 | | A5 | jkiD | Store bytes | SBYT,X0 | | DO-D7 | SjkiD | Load bytes, immediate | LBYTS,S | | D8-DF | SjkiD | Store bytes, immediate | SBYTS,S | The following interrupt conditions apply to all load and store instructions. Refer to CP Interrupts in section 2 of this volume for descriptions of these conditions. - Address specification error. - Invalid segment/ring number zero. - Access violation. - Page table search without find. - Debug. ## Load/Store Multiple | 80jkQ | Load Multiple Registers, from | LMULT | Xk,Aj,Q | |-------|--------------------------------------------|-------|---------| | | (Aj displaced by 8*Q), selectivity per XkR | | | | | | | | 81jkQ Store Multiple Registers, SMULT Xk,Aj,Q at (Aj displaced by 8\*Q), selectivity per XkR | 0 -7 | 8 11 | 12 15 | 16 31 | |-------|------|-------|-------| | 80,81 | j | k | Q | These instructions transfer data between the A and X registers and contiguous word locations in ${\tt CM}_{\:\raisebox{1pt}{\text{\circle*{1.5}}}}$ The CM starting address forms by left-shifting Q three places with zero insertion on right, and adding the shifted Q to the byte number (BN) field of the process virtual address (PVA) from Aj. XkR bits 48 through 63 specify which contiguous A and X registers are transferred as follows: | 4 | 48 51 | 52 55 | 56 59 | 60 63 | |---|-------|-------|-------|-------| | | A | X- | A- | X- | | | FIRST | FIRST | FIRST | LAST | | 1 | | | | | | XkR Bits | Register Transferred | |----------|----------------------| | 48-51 | First A register. | | 52-55 | First X register. | | 56-59 | Last A register. | | 60-63 | Last X register. | The A registers transfer first. When A-first exceeds A-last, no A registers transfer. When X-first exceeds X-last, no X registers transfer. For example, when: A-first = $B_{16}$ , X-first = $2_{16}$ A-last = $4_{16}$ , X-last = $C_{16}$ the instruction does not transfer any A registers and transfers X registers 2 through C. The store multiple instruction clears CM bits 0 through 15 when storing the A registers. The load multiple instruction unconditionally transfers bits 20 through 63 of each CM word to the corresponding bits of the designated A registers. Bits 16 through 19 (RN-field) of each A register are set to the largest of the following: - Bits 16 through 19 of the CM word. - Bits 16 through 19 of Aj. - Bits 8 through 11 (R1 field) of the segment descriptor associated with the PVA in Aj. During a debug scan operation, the PVA resulting from the addition of Aj and Q is the only data read argument for the load multiple instruction, or the only data write argument for the store multiple registers instruction. Refer to Debug in section 2 of this volume. ## Load/Store Word 82jkQ Load Xk, from (Aj displaced by 8\*Q) LX Xk,Aj,Q 83jkQ Store Xk, at (Aj displaced by 8\*Q) SX Xk,Aj,Q | 0 7 | 8 11 | 12 15 | 16 31 | |-------|------|-------|-------| | 82,83 | j | k | α | These instructions transfer one word between Xj and CM. The CM address of the word transferred is the sum 8 times Q plus the BN field from Aj. #### Load/Store Word, Indexed A2jkiD Load Xk, from (Aj displaced by 8\*D and indexed by 8\*XiR) LXI Xk,Aj,Xi,Q A3jkiD Store Xk, at (Aj displaced by 8\*D and indexed by 8\*XiR) SXI Xk,Aj,Xi,Q | 0 | 78 | 11 | 12 15 | 16 19 | 20 | | 31 | |-------|----|----|-------|-------|----|---|----| | A2,A3 | j | i | k | i | | D | | These instructions transfer one word between Xk and a word address in CM. The CM address of the word is the BN field from Aj plus 8 times XiR (index), plus 8 times D (displacement). For indexing, these instructions interpret the XO contents as zeros. Aj bits 61 through 63 must be zeros or an address specification error occurs. ## **Load/Store Address** 84jkQ Load Ak, from (Aj displaced by Q) LA Ak, Aj, Q 85jkQ Store Ak, at (Aj displaced by Q) SA Ak, Aj, Q | 9 | 7 | 8 11 | 12 15 | 16 | 31 | |---|-------|------|-------|----|----| | | 84,85 | j | k | Q | | These instructions transfer a 6-byte field between Ak and CM. The field's leftmost byte address is the sum of Q (sign-extended to 32 bits) plus the BN field from Aj. The load Ak instruction transfers the rightmost 44 bits of the 6-byte CM field to Ak bits 20 through 63. The value transferred to Ak bits 16 through 19 is the largest of the following: - Leftmost 4 bits of the 6-byte CM field. - Initial Aj bits 16 through 19. - Bits 8 through 11 (R1 field) of the segment descriptor associated with the PVA in Aj. ## Load/Store Address, Indexed A0jkiD Load Ak, from (Aj displaced by D and indexed by XiR) LAI Ak, Aj, Xi, D AljkiD Store Ak, at (Aj displaced by D and indexed by XiR) SAI Ak,Aj,Xi,D | 0 | 78 1 | 11 12 15 | 16 19 | 20 | 31 | |-------|------|----------|-------|----|----| | A0,A1 | j | k | i | D | | These instructions transfer 6 bytes between Ak and a 6-byte CM field. The starting (leftmost) CM address of the 6-byte field is the sum of the displacement D plus the index value XiR plus the BN field from Aj. For indexing, these instructions interpret the XO contents as zeros. The load Ak instruction unconditionally transfers only the rightmost 44 bits of the 6-byte CM field to Ak bit positions 20 through 63. The instruction transfers to Ak bits 16 through 19 a value that is the largest of the following: - Leftmost 4 bits of the 6-byte CM field. - Aj bits 16 through 19. - Bits 8 through 11 (R1 field) of the segment descriptor for the PVA in Aj. ## Load/Store Bytes A4jkiD Load Bytes, to Xk from (Aj displaced by D and indexed by XiR), length per XO LBYT, XO Xk, Aj, Xi, D A5jkiD Store Bytes, from Xk at (Aj displaced by D and indexed by XiR), length per XO SBYT, XO Xk, Aj, Xi, D | 0 | 78 11 | 12 15 | 16 19 | 20 31 | |-------|-------|-------|-------|-------| | A4,A5 | j | k | i | D | These instructions transfer a field of bytes between Xk and CM. The byte field length equals 1 plus XO bits 61 through 63. For lengths less than 8, the load byte instruction right-justifies and zero-extends the bytes loaded into Xk. The beginning (leftmost) CM address of the byte field is the sum of D (zero-extended to 32 bits) plus XiR, plus the BN field from Aj. ## Load/Store Bytes, Immediate DSjkiD Load Bytes, to Xk from (Aj displaced by D and indexed by XiR), length per S LBYTS, S Xk, Aj, Xi, D (DS = D0 through D7) DSjkiD Store Bytes, from Xk at (Aj displaced by D and indexed by XiR), length per S (DS = D8 through DF) SBYTS,S Xk,Aj,Xi,D 0 45 78 11 12 15 16 19 20 31 D0-DF S j k i D These instructions transfer a field of bytes between Xk and CM. The field length equals S plus one. For lengths less than eight, the load instruction right-justifies and zero-extends the bytes loaded into Xk. The beginning (leftmost) CM address of the byte string is the sum of D (displacement) plus XiR (index), plus the BN field of Aj. For indexing, these instructions interpret the XO contents as zeros. #### Load Bytes, Relative 86jkQ Load Bytes, to Xk LByTP,j from (P displaced by Q), length per j | 0 7 | 8 11 | 12 15 | 16 | 31 | |-----|------|-------|----|----| | 86 | j | k | Q | | This instruction transfers a field of bytes from CM to Xk. The CM byte field length is the value of the rightmost 3 bits of j plus 1. For lengths less than 8, the byte(s) loaded into Xk are right-justified and zero-extended on the left. The starting (leftmost) CM byte address is the sum of Q (sign-extended to 32 bits) plus the BN field from P. For this instruction, the CP considers the read operation for the byte field an instruction fetch rather than a data read, and therefore tests the fetch for execute access validity. Refer to Access Protection in section 2 of this volume. #### Load/Store Bit 88jkQ Load Bit, to Xk from (Aj displaced by Q and bit-indexed by XOR) LBIT Xk,Aj,Q,XO 89jkQ Store Bit, from Xk at (Aj displaced by Q and bit-indexed by XOR) SBIT Xk,Aj,Q,XO | 0 7 | 8 11 | 12 15 | 16 31 | |-------|------|-------|-------| | 88,89 | j | k | Q | These instructions transfer a single bit between XkR bit 63 and a bit position in CM. The load bit instruction also clears Xk bits 0 through 62. The instructions first generate the CM address of the byte containing the bit loaded or stored as follows: - 1. Form byte index by right-shifting XOR 3 bit positions, end-off, and sign-extend to $32\ \mathrm{bits}$ . - 2. Form the sum of this 32-bit byte index plus Q (sign-extended to 32 bits) plus BN field from Aj. These instructions then use the original XOR bits 61 through 63 to select the bit position within the addressed byte. Binary values 0 through 7 for these 3 bits select the corresponding bit position (0 through 7) within the byte. The store bit (89) instruction executes as follows: the byte containing the bit to be stored is read, modified in the appropriate bit position, and written. No other accesses from any port to the addressed byte are permitted between these read and write accesses. Clearing a synchronization lock with this instruction requires preserialization which can be achieved as follows: a test and set bit (14) instruction (which postserializes) issues immediately before the store bit instruction. This postserialization effectively preserializes the lock clearing. For the store bit instruction, operand access validation consists of write access validation only. ## **CP INTEGER ARITHMETIC INSTRUCTIONS** The instructions in this subgroup (table II-1-2) perform integer arithmetic on signed two's complement words or half words in Xk or XkR. The sign bit is bit 0 for full-word integers, or bit 32 for half-word integers. Table II-1-2. CP Integer Arithmetic Instructions | 0pcode | Format | Instruction | Mnemonio | |--------|--------|---------------------------------------------|----------| | 10 | jk | Integer sum, immediate | INCX | | 11 | jk | Integer difference | SUBX | | 20 | jk | Half-word integer sum | ADDR | | 21 | jk | Half-word integer difference | SUBR | | 22 | jk | Half-word integer product | MULR | | 23 | jk | Half-word integer quotient | DIVR | | 24 | jk | Integer sum | ADDX | | 25 | jk | Integer difference | SUBX | | 26 | jk | Integer product | MULX | | 27 | jk | Integer quotient | DIVX | | 28 | jk | Half-word integer sum, immediate | INCR | | 29 | jk | Half-word integer difference, immediate | DECR | | 2C | jk | Half-word integer compare | CMPR | | 2D | jk | Integer compare | СМРХ | | 8A | jkQ | Half-word integer sum, signed immediate | ADDRQ | | .8B | jkQ | Integer sum, signed immediate | ADDXQ | | 8C | jkQ | Half-word integer product, signed immediate | MULRQ | | В2 | jkQ | Integer product, signed immediate | MULXQ | The integer format is as follows: The half-word integer instructions do not alter X register bits 0 through 31. The arithmetic overflow interrupt condition applies to all integer arithmetic instructions. Individual instruction descriptions list additional interrupt conditions where applicable. (Refer to CP Interrupts in section 2 of this volume for descriptions of these conditions). ## Half-Word Integer Sum 20jk Half-Word Integer Sum, XkR replaced by XkR plus XjR ADDR Xk,Xj This instruction forms XkR plus XjR and transfers the 32-bit sum to XkR. 28jk Half-Word Integer Sum Immediate, XkR replaced by XkR plus j INCR Xk,j This instruction forms XkR plus j zero-extended to 32 bits, and transfers the 32-bit sum to XkR. 8AjkQ Half-Word Integer Sum, Signed Immediate, XkR replaced by XjR plus Q ADDRQ Xk,Xj,Q This instruction forms XjR plus Q sign-extended to 32-bits, and transfers the 32-bit sum to XkR. ## Integer Sum 24jk Integer Sum, Xk replaced by Xk plus Xj ADDX Xk,Xj This instruction forms Xk plus Xj and transfers the 64-bit sum to Xk. 10jk Integer Sum Immediate, Xk replaced by Xk plus j INCX Xk,j This instruction forms Xk plus j zero-extended on the left to 64 bits, and transfers the 64-bit sum to Xk. 8BjkQ Integer Sum Signed Immediate, Xk replaced by Xk minus Xj ADDXQ Xk,Xj,Q This instruction forms Xk plus Q sign-extended to 64 bits, and transfers the 64-bit sum to Xk. ## Half-Word Integer Difference 21jk Half-Word Integer Difference, XkR replaced by XkR minus XjR SUBR Xk,Xj 29jk Half-Word Integer Difference Immediate, XkR replaced by XkR minus j DECR Xk,j These instructions subtract the 32-bit subtrahend in XjR, or in the j field zero-extended to 32 bits on the left, from the 32-bit minuend in XkR, and transfer the 32-bit difference to XkR. The instructions treat each half-word as a signed two's complement integer. ## **Integer Difference** 25jk Integer Difference, Xk replaced by Xk minus Xj DECX Xk,j lljk Integer Difference Immediate, Xk replaced by Xk minus j SUBX Xk,Xj | 0 | 78 | 11 | 12 | 15 | |-------|----|----|----|----| | 11,25 | | j | k | | These instructions subtract Xj, or j zero-extended to 64 bits on the left, from Xk, and transfer the 64-bit difference to Xk. The instructions treat each word as a signed two's complement integer. ## Half-Word Integer Product 22jk Half-Word Integer Product, XkR replaced by XkR times XjR MULR Xk,Xj 8CjkQ Half-Word Integer Product Signed Immediate, XkR replaced by XjR times Q MULRQ Xk,Xi,Q | 0 7 | 8 11 | 12 15 | 16 31 | |-----|------|-------|-------| | 8C | j | k | Q | The first instruction multiplies XkR by XjR. The second instruction multiplies the Q field (sign-extended to 32 bits) by XjR. The multiplication forms an algebraically-signed, 64-bit intermediate product. The rightmost 32 bits of this intermediate product transfer to XkR as the final product. ## **Integer Product** 26jk Integer Product, Xk replaced by Xk times Xj MULX Xk,Xj This instruction multiplies the signed two's complement integers in Xk and Xj to form an algebraically-signed, 128-bit intermediate product. The rightmost 64 bits of this intermediate product transfer to Xk as the final product. B2jkQ Integer Product Signed Immediate, Xk replaced by Xj times Q MULXQ Xk,Xj,Q | 0 7 | 8 11 | 12 15 | 16 31 | |-----|------|-------|-------| | B2 | j | k | Q | The first instruction multiplies the signed two's complement integer from Xk by Xj. The second instruction multiplies the Q field sign-extended to 64 bits by Xj. An algebraically-signed, 128-bit intermediate product forms. The rightmost 64 bits of this intermediate product transfer to Xk as the final product. ## Half-Word Integer Quotient 23jk Half-Word Integer Quotient, XkR replaced by XkR divided by XjR DIVR Xk,Xj | 0 | 78 | 11 1 | 2 15 | |----|----|------|------| | 23 | | j | k | This instruction divides XkR by XjR, and transfers the algebraically-signed, 32-bit quotient to XkR. A divide fault (UCR bit 55) interrupt condition will occur if XjR is equal to zero. ## **Integer Quotient** 27jk Integer Quotient, Xk replaced by Xk divided by Xj DIVX Xk,Xj This instruction divides the word in Xk by the 64-bit word in Xj, and transfers the result, consisting of an algebraically-signed, 64-bit quotient to Xk. A divide fault (UCR bit 55) interrupt condition will occur if Xj is equal to zero. ## Half-Word Integer/Integer Compare 2Cjk Half-Word Integer Compare, XjR to XkR, result to XlR CMPR Xi,Xj,Xk 2Djk Integer Compare, Xj to Xk, result to XlR CMPX Xi,Xj,Xk | 0 | 78 | 11 | 12 15 | |-------|----|----|-------| | 2C,2D | , | j | k | These instructions algebraically compare the two's complement binary integer in XjR or Xj to the signed two's complement binary integer in XkR or Xk, respectively. XO consists of all zeros. Based on the comparison result, XIR sets as follows: | Condition | Action Taken | |----------------|---------------------------------------------------| | Xj = Xk | Clear X1R bits 32 through 63. | | $xj \ge xk$ | Clear X1R bits 32 and 34 through 63, set bit 33. | | $x_j \leq x_k$ | Clear XIR bits 34 through 63, set bits 32 and 33. | ## **CP BRANCH INSTRUCTIONS** This subgroup (table II-1-3) consists of both conditional and unconditional branch instructions. Each conditional branch instruction compares the contents of two general registers to determine whether a normal or a branch exit is taken. Table II-1-3. CP Branch Instructions | Opcode | Format | Instruction | Mnemonic | |--------|--------|-------------------------------------------|----------| | 2E | jk | Branch relative | BREL | | 2F | jk | Branch intersegment | BRDIR | | 90 | jkQ | Branch on half-word equal | BRREQ | | 91 | j kQ | Branch on half-word not equal | BRRNE | | 92 | jkQ | Branch on half-word greater than | BRRGT | | 93 | jkQ | Branch on half-word greater than or equal | BRRGE | | 94 | jkQ | Branch on equal | BRXEQ | | 95 | jkQ | Branch on not equal | BRXNE | | 96 | jkQ | Branch on greater than | BRXGT | | 97 | jkQ | Branch on greater than or equal | BRXGE | | 9C | jkQ | Branch and increment | BRINC | | 9D | jkQ | Branch on segments unequal | BRSEG | The debug interrupt condition applies to all branch instructions. Individual instruction descriptions list additional interrupt conditions where applicable. Refer to CP Interrupts in section 2 of this volume for a description of these conditions. ## **Branch Relative** 2Ejk Branch to P Indexed by 2\*XkR BRREL Xk | 0 | 7 | 8 11 | 12 15 | į | |---|----|------|-------|---| | | 2E | | le · | l | | | 21 | , | " | ۱ | This instruction causes an unconditional branch to the CM address formed by adding 2 times XkR to the BN field in $P_{\:\raisebox{1pt}{\text{\circle*{1.5}}}}$ ## **Branch Intersegment** 2Fjk Branch Branch to Aj indexed by 2\*XkR BRDIR Aj, Xk | 0 | 7 | 8 11 | 12 15 | |---|----|------|-------| | | 2F | j | k | This instruction causes an unconditional branch by modifying the key (KEY), segment number (SEG), and byte number (BN) fields of the PVA in P, as follows: - 1. The key in P copies to the lock of the branched-to segment. The branch is permitted if the key and lock are equal, if the key is a master key, or if the lock is zero or equals no lock. - 2. The 12-bit SEG field in Aj (bits 20 through 31) transfers to P bits 20 through 31. - 3. A value 2 times XkR adds to the rightmost 32 bits from Aj. XO consists of all zeros. This sum transfers to bit positions 32 through 63 of P. This instruction can cause the following exception conditions: - Address specification error. - Invalid segment/ring number zero. - Access violation. #### **Branch on Half-Word** | 90jkQ | Branch to P Displaced by 2*Q, if XjR equal to XkR | BRREQ | Xj,Xk,Q | |-------|-------------------------------------------------------------------|-------|---------| | 91jkQ | Branch to P Displaced by 2*Q, if XjR not equal to XkR | BRRNE | Xj,Xk,Q | | 92jkQ | Branch to P Displaced by 2*Q, if XjR greater than XkR | BRRGT | Xj,Xk,Q | | 93jkQ | Branch to P Displaced by 2*Q, if XjR greater than or equal to XkR | BRRGE | Xj,Xk,Q | | 0 7 | 8 11 | 12 15 | 16 | 31 | |-------------|------|-------|----|----| | 90,91,92,93 | j | k | Q | | These instructions algebraically compare XjR with XkR, treating each as a signed two's complement binary integer. XO consists of all zeros. If the comparison between XjR and XkR does not satisfy the branch condition specified, the instruction takes a normal exit by adding 4 to the BN field in P to generate the next instruction address. If the Xj right (XjR) and Xk right (XkR) comparison satisfies the branch condition, the instruction takes a branch exit by adding 2 times Q to the BN field in P to form the next instruction address. ## **Branch** | 94jkQ | Branch to P Displaced by 2*Q, if Xj equal to Xk | BRXEQ | Xj,Xk,Q | |-------|-----------------------------------------------------------------|-------|---------| | 95jkQ | Branch to P Displaced by 2*Q, if Xj not equal to Xk | BRXNE | Xj,Xk,Q | | 96jkQ | Branch to P Displaced by 2*Q, if Xj greater than Xk | BRXGT | Xj,Xk,Q | | 97jkQ | Branch to P Displaced by 2*Q, if Xj greater than or equal to Xk | BRXGE | Xj,Xk,Q | | 0 | 78 | 11 | 12 | 15 16 | | 31 | |-----------|-----|----|----|-------|---|-------| | 94,95,96, | ,97 | j | k | | Q | N. J. | These instructions algebraically compare the Xj word with the Xk word, treating each as a signed two's complement binary integer. XO consists of all zeros. If the comparison between Xj and Xk does not satisfy the branch condition specified, the instruction takes a normal exit by adding 4 to the BN field in P to generate the next instruction address. If the comparison satisfies the branch condition, the instruction causes a branch exit by adding 2 times Q to the BN field in P to form the the next instruction address. ## **Branch and Increment** 9CjkQ Branch to P Displaced by 2\*Q and Increment Xk, if Xj greater than Xk BRINC Xj,Xk,Q | ( | 7 | 8 11 | 12 15 | 16 | 31 | |---|----|------|-------|---------------------------------------|-----------------------------------------| | ſ | | | | | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | 9C | j | k | Q | | | · | | | · | · · · · · · · · · · · · · · · · · · · | | This instruction algebraically compares the Xj word with the Xk word, treating each as a signed two's complement binary integer. For Xj only, the instruction interprets XO as all zeros. The comparison results are as follows: | Condition | Action Taken | | |-----------------------------|--------------------------------------------------------------------------------------------------------|------------| | $x_j \leq x_k$ Normal exit. | Add 4 to BN field in P to form next instruction address | <b>3</b> • | | | Add 2 times Q to BN field in P to form next instruction increase word in Xk by 1. Overflow is ignored. | n | ## **Branch on Segments Unequal** 9DjkQ Branch to P Displaced by 2\*Q, if segments unequal, else compare byte numbers, result to X1R. BRSEG Xi,Aj,Ak,Q | 0 7 | 8 11 | 12 15 | 16 31 | |-----|------|-------|-------| | 9D | j | k | Q | This instruction performs a bit-for-bit comparison between the SEG fields in Aj and Ak (bits 20 through 31). If the SEG fields are unequal, the instruction takes a branch exit by adding 2 times Q to the BN field in P to form the next instruction address. If the SEG fields are equal, the instruction takes a normal exit by adding 4 to the BN field in P to form the next instruction address. The instruction also algebraically compares Aj bits 32 through 63 with Ak bits 32 through 63, treating each 32-bit quantity as a signed two's complement binary integer, and stores the comparison result in X1R, as follows: | Result | Action Taken | | | | |---------|--------------------------------------------------|--|--|--| | AJ = Ak | Clear X1R. | | | | | Aj > Ak | Clear X1R bits 32 and 34 through 63, set bit 33. | | | | | Ai < Ak | Clear XIR hits 34 through 63 set hits 32 and 33. | | | | ## **CP COPY INSTRUCTIONS** The copy instructions (table II-1-4) transfer information between registers. Table II-1-4. CP Copy Instructions | 0pcode | Format | Instruction | Mnemonic | |--------|--------|----------------------|----------| | 09 | jk | Copy address, A to A | СРЧАА | | OA | jk | Copy address, X to A | СРУХА | | ОВ | jk | Copy address, A to X | СРЧАХ | | oc | jk | Copy half word | CPYRR | | ОД | jk | Copy full word | СРҮХХ | ## **Copy Address** 09jk Copy, Ak replaced by Aj CPYAA Ak, Aj This instruction transfers the 48 bits in Aj to Ak. 0Ajk Copy, Ak replaced by Xj CPYXA Ak,Xj This instruction unconditionally transfers Xj bits 20 through 63 to the corresponding bit positions of Ak. The instruction also compares Xj bits 16 through 19 with P bits 16 through 19, and transfers the larger field to Ak bits 16 through 19. 0Bjk Copy, Xk replaced by Aj CPYAX Xk,Aj This instruction transfers the 48 bits in Aj to Xk bit positions 16 through 63, and clears Xk bits 0 through 15. ## **Copy Half Word** 0Cjk Copy, XkR replaced by XjR ' CPYRR Xk,Xj This instruction transfers the half-word in XjR to XkR. The XkL content does not change. ## **Copy Full Word** 0Djk Copy, Xk replaced by Xj CPYXX Xk,Xj This instruction transfers the Xj word to Xk. ### **CP ADDRESS ARITHMETIC INSTRUCTIONS** Address arithmetic instructions (table II-1-5) perform address arithmetic in two's complement ignoring overflow. Table II-1-5. CP Address Arithmetic Instructions | Opcode | Format | Instruction | Mnemonic | |--------|--------|-------------------------------------|----------| | 2A | jk | Address increment, indexed | ADDAX | | 8E | jkQ | Address increment, signed immediate | ADDAQ | | 8F | jkQ | Address relative | ADDPXQ | | A7 | jkiD | Address increment, modulo | ADDAD | # Address Increment, Indexed 2Ajk Address Ak Replaced by Ak plus XjR ADDAX Ak,Xj This instruction adds XjR and Ak bits 32 through 63, and returns the sum to Ak bits 32 through 63. ## Address Increment, Signed Immediate 8EjkQ Address Ak replaced by Aj plus Q. ADDAQ Ak, Aj, Q | 0 7 | 8 11 | 12 15 | 16 | 31 | |-----|------|-------|----|----| | 8E | j | k | Q | | This instruction transfers Aj bits 16 through 31 to the corresponding Ak bit positions. Also, the instruction adds Q (sign-extended to 32 bits) and Aj bits 32 through 63, and transfers the sum to Ak bits 32 through 63. Overflow is ignored. #### **Address Relative** 8FjkQ Address Ak replaced by P plus 2\*XjR plus 2\*Q ADDPXQ Ak,Xj,Q This instruction transfers P bits 16 through 31 to the corresponding 16 bit positions of Ak. The instruction also adds Q (sign-extended to 32 bits) to the rightmost 32 bits of P, adds this 32-bit sum to 2 times the XkR value, and transfers the final sum to Ak bits 32 through 63. Overflow is ignored. The instruction interprets XO as all zeros. ### Address Increment, Modulo A7jkiD Address Ak Replaced by Ai plus D per j ADDAD Ak,Ai,D,j | A7 j | k i | i | D | |------|-----|---|---| This instruction transfers Ai bits 16 through 31 to the corresponding bit positions of Ak. The instruction also adds D (zero-extended to 32 bits on left) to Ai bits 32 through 63, and transfers bits 32 through 60 of this sum to Ak bits 32 through 60. The instruction performs a logical product (AND) between bits 61 through 63 of this 32-bit sum and the rightmost 3 bits of j, and transfers the 3-bit logical product to Ak bits 61 through 63. Overflow is ignored. The following is an example of the logical product (AND) operation: First operand Second operand 0011 Result (AND) $\frac{0101}{0001}$ #### **CP ENTER INSTRUCTIONS** The instructions in this subgroup (table II-1-6) enter immediate operands (consisting of logical quantities or signed two's complement binary integers) into the X registers. Table II-1-6. CP Enter Instructions | Opcode | Format | Instruction | Mnemonic | |------------|--------|-----------------------------|----------| | 1 F | jk | Enter zeros | ENTZ | | 1 F | jk | Enter ones | ENTO | | 1 <b>F</b> | jk | Enter signs | ENTZ | | 39 | jk | Enter Xl, immediate logical | ENTX | | 3D | jk | Enter, immediate positive | ENTP | | 3E | jk | Enter, immediate negative | ENTN | | 3F | jk | Enter XO, immediate logical | ENTL | | 87 | jkQ | Enter Xl, signed immediate | ENTC | | 8D | jkQ | Enter, signed immediate | ENTE | | В3 | jkQ | Enter XO, signed immediate | ENTA | # **Enter Zeros/Ones/Signs** | lFjk | Enter XkL with Zeros | ENTZ | Xk | |------|----------------------|------|----| | 1Fjk | Enter XkL with Ones | ENTO | Χk | | lFjk | Enter XkL with Signs | ENTS | Xk | | 0 | 78 | 11 | 12 | 15 | |----|----|----|----|----| | 1F | | i | ı | , | This instruction translates the rightmost 2 bits of j as follows: | j Field | Action Taken | |---------|--------------------------------------------------------| | жж00 | Clear XkL bits 0 through 31. | | xx01 | Set XkL bits 0 through 31. | | xx10 | Copy bit 32 (sign) of XkR to bits 0 through 31 of XkI. | ### **Enter, Immediate Positive/Negative** Enter Xk with plus j ENTP Xk,j 3Ejk Enter Xk with minus j ENTN Xk,j These instructions zero-extend j to 64 bits and transfer this result, or the two's complement of this result, to Xk. ## Enter X1/X0, Immediate Logical 39jk Enter Xl with Logical jk ENTX X1,jk 3Fjk Enter XO with Logical jk ENTL XO,jk These instructions transfer k to bits 60 through 63, and j to bits 56 through 59 of X0 or X1. The instructions clear bits 0 through 55. ### Enter X1/X0, Signed Immediate 87jkQ Enter Xl with Sign-Extended jkQ ENTC X1,jkQ B3jkQ Enter XO with Sign-Extended jkQ ENTA XO,jkQ These instructions expand the 24-bit concatenation of j, k, and Q to 64 bits (right-justified) by extending the leftmost bit of j through bits 0 through 39. The 64-bit result transfers to XO or XI. ## **Enter, Signed Immediate** 8DjkQ Enter Xk with Sign-Extended Q ENTE Xk,Q | 9 | 0 7 | 8 11 | 12 15 | 16 | 31 | |---|-----|------|-------|----|----| | | 8D | j | k | a | | This instruction sign-extends Q to 64 bits, and transfers this value to Xk. ## **CP SHIFT INSTRUCTIONS** The shift instructions (table II-1-7) shift the Xj 64 bits through the number of bit positions determined from a computed shift count. The result transfers to Xk. Table II-1-7. CP Shift Instructions | Opcode | Format | Instruction | Mnemonic | |--------|--------|--------------------------|----------| | A8 | jkiD | Shift word, circular | SHFC | | A9 | jkiD | Shift word, end-off | SHFX | | AA | jkiD | Shift half word, end-off | SHFR | The computed shift count is the sum of the D field rightmost 8 bits plus XiR bits 56 through 63. An overflow from this 8-bit sum is ignored. The instructions interpret XO as all zeros. The computed shift count is determined by the following: 1. The leftmost bit of the 8-bit computed shift count determines the shift direction: Positive sign: Left shift. Negative sign: Right shift. 2. The actual shift count is the two's complement of the rightmost 5 or 6 bits of the computed shift count for 32- and 64-bit operands, respectively. Thus, half words can be shifted from 0 to 31 places left or from 1 to 32 places right. Similarly, full words can be shifted from 0 to 63 places left or from 1 to 64 places right. The shifts are as follows: | Shift Count | 32-Bit Shifts | Shift Count | 64-Bit Shifts | |----------------|------------------------------|-------------|----------------| | 0111 1111 | Left shift 31 (repeating) | 0111 1111 | Left shift 63 | | 0010 0000 | Left shift 0 | 0100 0000 | Left shift 0 | | 0001 1111 | Left shift 31 | 0011 1111 | Left shift 63 | | <b>1</b> | 1 1 | <b>↓</b> | <b>\</b> . | | 0000 0000 | Left shift 0 | 0000 0000 | Left shift 0 | | 1111 1111<br>I | Right shift 1 | 1111 1111 | Right shift 1 | | 1110.0000 | Diebe ebise 22 | 1100 0000 | Right shift 64 | | 1110 0000 | Right shift 32 | | • | | 1101 1111 | Right shift l<br>(repeating) | 1011 1111 | Right shift l | | 1000 0000 | Right shift 32 | 1000 0000 | Right shift 64 | 3. If the computed shift count results in an actual shift count of zero, Xj transfers to Xk without shifting. # Shift Word, Circular A8jkiD Shift Circular, Xk replaced by Xj, direction and count per XiR plus D SHFC Xk, Xj, Xi, D | 0 | 78 11 | 12 15 | 16 19 | 20 31 | |----|-------|-------|-------|-------| | A8 | j | k | i | D. | This instruction shifts the Xj word by the computed shift count, and transfers the result to Xk. The shift is circular. Bits that shift out one end of the word transfer into bit positions which become unoccupied at the opposite end of the word. ### Shift End-Off, Word/Half-Word A9jkiD Shift End-Off, Xk replaced by Xj, direction and count per XiR plus D SHFX Xk,Xj,Xi,D AAjkiD Shift End-Off, XkR replaced by XjR, direction and count per XiR plus D SHFR Xk,Xj,Xi,D | 0 | 78 <u>11</u> | 12 15 | <u>16 19</u> | 20 31 | |----|--------------|-------|--------------|-------| | A9 | j | k | i | D | These instructions shift the Xj word, or the XjR half-word, and transfer the result to Xk or XkR. The computed shift count determines the direction and number of bit positions to be shifted. In a right shift, the instruction right-shifts the word end-off on the right, and sign-extends on the left. In a left shift, the instruction left-shifts the word end-off on the left and inserts zeros on the right. ### **CP LOGICAL INSTRUCTIONS** The instructions in this subgroup (table II-1-8) perform logical (Boolean) operations on 64-bit operands in the X registers: Table II-1-8. CP Logical Instructions | Opcode | Format | Instruction | Mnemonic | |--------|--------|--------------------|----------| | 18 | jk | Logical sum | IORX | | 19 | jk | Logical difference | XORX | | 1A | jk | Logical product | ANDX | | 1B | jk | Logical complement | NOTX | | 1C | jk | Logical inhibit | INHX | | 18jk | Logical Sum, Xk replaced by Xk OR Xj | IORX | Xk,Xj | |------|-------------------------------------------------|------|-------| | 19jk | Logical Difference,<br>Xk replaced by Xk XOR Xj | XORX | Xk,Xj | | lAjk | Logical Product,<br>Xk replaced by Xk AND Xj | ANDX | Xk,Xj | | 0 | 7 | 8 | 11 | 12 | 15 | |---------|---|---|----|----|----| | 18,19,1 | \ | j | | k | | These instructions form the logical sum, difference, or product between the words in Xj and Xk, and return the 64-bit Boolean result to Xk. Examples of these operations are as follows: | | Logical<br>Sum<br>(OR) | Logical Difference (XOR) | Logical<br>Product<br>(AND) | |----------------|------------------------|--------------------------|-----------------------------| | First operand | 0011 | 0011 | 0011 | | Second operand | 0101 | 0101 | 0101 | | Result | 0111 | 0110 | 0001 | ## **Logical Complement** 1Bjk Logical Complement, Xk replaced by Xj NOT NOTX Xk,Xj | 0 | 78 | 11 | 12 | 15 | |----|----|----|----|----| | 1E | | j | k | | This instruction transfers the one's complement of the Xj word to Xk. The one's complement of a number results from subtracting the original number, bit for bit, from a number consisting of all ones. For example: One's Complement Ones 1111 Xj 0110 Xk 1001 # Logical Inhibit 1Cjk Logical Inhibit, Xk replaced by Xk AND Xj NOT INHX Xk,Xj | 0 | 78 | 11 | 12 15 | |----|----|----|-------| | 10 | | j | k | This instruction forms the logical product (AND) between the one's complement of the Xj number and the Xk number, and returns the result to Xk. For example: | | Logical<br>Inhibit | |---------------|--------------------| | Xj | 0011 | | NOT Xj | 1100 | | Xk | 0101 | | Xk AND Xj NOT | 0100 | ### **CP REGISTER BIT STRING INSTRUCTIONS** The instructions in this subgroup (table II-1-9) address a contiguous string (field) of bits within a register, beginning and ending at any bit position. The instructions interpret XO as all zeros. Table II-1-9. CP Register Bit String Instructions | 0pcode | Format | Instruction | Mnemonic | |--------|--------|--------------------|----------| | AC | jkiD | Isolate bit mask | ISOM | | AD | jkiD | Isolate bit string | ISOB | | AE | jkiD | Insert bit string | INSB | #### **Bit String Descriptor** The beginning bit position and bit string length are specified by a bit string descriptor. The descriptor is the rightmost 12 bits of the sum of D (sign-extended) plus XiR, and has the following format: | 52 | 57 ( | 58 | 63 | |----|------|------------------|----| | | | String<br>Length | | XiR Bits Description 52-57 Beginning (leftmost) bit position. 58-63 Length, one less than the number of bits in the string. The instruction specification error interrupt condition applies to all register bit string instructions. Refer to CP Interrupts in section 2 of this volume for a description of this condition. #### Isolate Bit Mask ACjkiD Isolate Bit Mask, into Xk per XiR plus D ISOM Xk,Xi,D | 0 | 78 11 | 12 15 | 16 19 | 20 | 31 | |----|-------|-------|-------|----|----| | AC | j | k | i | D | | This instruction generates a bit mask consisting of a contiguous field of ones, and places this field into Xk. The bit string descriptor defines the leftmost bit position and the length of the Xk field. All Xk bits outside the specified string clear. #### Isolate ADjkiD Isolate, into Xk from Xj per XiR plus D ISOB Xk,Xj,Xi,D | 0 7 | '8 11 | 12 15 | 16 19 | 20 31 | |-----|-------|-------|-------|-------| | AD | j | k | i | D | This instruction clears Xk and transfers a field of contiguous data from Xj into Xk, right-justified. The bit string descriptor defines the leftmost bit position and Xj field length. #### Insert AEjkiD Insert, into Xk from Xj per XiR plus D INSB Xk,Xj,Xi,D | 0 | 7 | 8 11 | 12 15 | 16 19 | 20 31 | |---|----|------|-------|-------|-------| | | AE | j | k | i | D | This instruction transfers a field of contiguous bits from Xj to Xk. The field is obtained from the Xj rightmost bit positions, with the length specified by the bit string descriptor. The field inserts into Xk with the leftmost bit position and the field length also specified by the bit string descriptor. All Xk bit positions outside the specified field remain unchanged. #### **CP MARK TO BOOLEAN INSTRUCTION** The following instruction tests X1R bits 32 through 33 for values specified by the j field. lEjk Mark to Boolean, set Xk per j and XlR MARK Xk, Xi, j | 0 | 78 | 11 | 12 15 | |----|----|----|-------| | 1E | | j | k | This instruction tests XjR bits 32 through 33 for a bit combination by comparing j and XlR bits 32 through 33 for an equal condition (EQ) as shown in table II-1-10. If XlR bits 32 through 33 equal a value specified by j, the instruction clears Xk bits 01 through 63 and sets Xk bit 0. The instruction clears Xk if no equality occurs. From left to right, the 4 bits of j are individual pointers associated with the 4 possible values of XIR bits 32 and 33 (00, 01, 10, 11). When set, the first bit in the j field tests bits 32 and 33 for a value of 00, the second bit for 01, the third bit for 10, and the fourth bit for 11. For example, if j equals 0101, equality occurs when bits 32 and 33 are either 01 or 11. Table II-1-10. Compare j Field and X1 Bits 32 and 33 | | 1 | | <del></del> | | | | | | |-------|--------------------------|--------------------------|-------------|------------------------|--|--|--|--| | j | Register X1R Bits 32, 33 | | | | | | | | | Field | 00 | 01 | 10 | 111 | | | | | | 0000 | Uncor | Unconditional Inequality | | | | | | | | 0001 | | | | EQ | | | | | | 0010 | | | EQ | | | | | | | 0011 | | : | EQ | EQ | | | | | | 0100 | | EQ | | | | | | | | 0101 | | EQ | | EQ | | | | | | 0110 | | EQ | EQ | * . | | | | | | 0111 | | EQ | EQ | EQ | | | | | | 1000 | EQ | 34 J | | | | | | | | 1001 | EQ | | - | EQ | | | | | | 1010 | EQ | | EQ | | | | | | | 1011 | EQ | | EQ | EQ | | | | | | 1100 | EQ | EQ | | · | | | | | | 1101 | EQ | EQ | | EQ | | | | | | 1110 | EQ | EQ | EQ | | | | | | | 1111 | Uncor | nditiona | l Equal | Unconditional Equality | | | | | # **BDP INSTRUCTION DESCRIPTIONS** The business data processing (BDP) instruction group consists of 18 operation codes in 3 subgroups: - BDP numeric. - Byte. - Subscript and immediate data. Tables II-1-11 through II-1-14 list the instructions within each subgroup. For descriptions of source and destination fields, data descriptors, access types, data formats, and data types, refer to Business Data Processing Programming in section 2 of this volume. ### **BDP NOMENCLATURE** The BDP instruction descriptions use the following additional terms: | Term | Description | |---------|-------------------------------------------------------------------------------------------------| | D(Aj) | Source data field addressed by PVA in Aj. | | D(Ak) | Other source data field, or destination data field, addressed by PVA in Ak. | | D(Ai+D) | Edit mask addressed by PVA in Ai plus displacement D. The edit instruction (ED) uses this term. | ### **BDP NUMERIC INSTRUCTIONS** The instructions in this subgroup (table II-1-11) perform arithmetic, shift, conversion, and comparison operations on byte fields from CM. Table II-1-11. BDP Numeric Instructions | Opcode | Format | Instruction | Mnemonic | |--------|--------|-----------------------|--------------| | 70 | jk | Decimal sum | ADDN,Aj,XO | | 71 | jk | Decimal difference | SUBN, Aj, XO | | 72 | jk | Decimal product | MULN,Aj,XO | | 73 | jk | Decimal quotient | DIVN,Aj,XO | | 74 | jk | Decimal compare | CMPN,Aj,XO | | 75 | jk | Numeric move | MOVN, Aj, XO | | E4 | jkiD | Decimal scale | SCLN,Aj,XO | | Е5 | jkiD | Decimal scale rounded | SCLR,Aj,XO | After completing the required operation, the instructions store the right-justified result in the destination field. These instructions also do the following: - Zero-fill the high-order destination field positions if the decimal result is shorter than the destination field. - Truncate the result's leftmost bits if the result exceeds the destination field. - Treat a decimal numeric value of minus zero as equal to plus zero. - Do not store minus zero as a result, except when truncation takes place. An instruction specification error occurs if the length and type fields in the source and destination field data descriptors do not conform to the length and type allowed for a particular instruction. This inhibits instruction execution and initiates the corresponding program interrupt. The following conditions apply to all BDP numeric instructions: - Instruction specification error. - Address specification error. - Invalid segment/ring number zero. - Access violation. - Page table search without find. - Debug. - Invalid BDP data. A destination BDP operand of length zero transforms the instruction into a no-operation. However, when the source field length is nonzero, exception sensing for the source field occurs. This includes testing for arithmetic loss-of-significance and for overflow, but excludes testing for a divide fault. Individual instruction descriptions list additional interrupt conditions, where applicable. Refer to CP Interrupts in section 2 of this volume for descriptions of these conditions. ### **Decimal Arithmetic** | 70jk | (2 descriptors) Decimal Sum, D(Ak) replaced by D(Ak) plus D(Aj) | ADDN,Aj,XO | Ak,Xi | |------|----------------------------------------------------------------------------|--------------|-------| | 71jk | (2 descriptors) Decimal Difference, D(Ak) replaced by D(Ak) minus D(Aj) | SUBN, Aj, XO | Ak,Xi | | 72jk | (2 descriptors) Decimal Product, D(Ak) replaced by D(Ak) times D(Aj) | MULN, Aj, XO | Ak,Xi | | 73jk | (2 descriptors) Decimal Quotient, D(Ak) replaced by D(Ak) divided by D(Aj) | DIVN,Aj,XO | Ak,Xi | | 0 | 7.8 11 12 15 | ~ | | | 0 7 | <u>8 11</u> | <u>12 15</u> | |-------------|-------------|--------------| | 70,71,72,73 | j | k | These instructions perform arithmetic operations on the initial destination field (an augend, minuend, multiplicand, or dividend) and the source field (an addend, subtrahend, multiplier, or divisor). The decimal result (sum, difference, product, or quotient) transfers to the destination field. The instructions allow packed and unpacked decimal data types 0 through 6. They do not support unpacked decimal leading sign data types 7 and 8. A numeric move instruction (75) must be used to format operands of these types prior to use in arithmetic operations. The instruction results are algebraically signed. If the results equal zero with no loss-of-significance, a positive sign is entered. The result translates to the preferred codes of the data type specified by the destination field data descriptor. These instructions can cause the following exception conditions: - Arithmetic overflow. - Divide fault (instruction 73 only, refer to table II-1-12). Table II-1-12. BDP Divide Fault | 1 | | | | | | |-------------------------------------------------------|------------|----------------------|------------|-----------------|--| | K<br>Field<br>Length | K<br>Value | J<br>Field<br>Length | K<br>Value | Divide<br>Fault | | | 0 | * | 0 | * | No | | | 0 | * | Nonzero | 0 | No | | | 0 | * | Nonzero | Nonzero | No | | | | | | | | | | Nonzero | 0 | 0 | * | Yes | | | Nonzero | 0 | Nonzero | 0 | Yes | | | Nonzero | 0 | Nonzero | Nonzero | No | | | | | | | | | | Nonzero | Nonzero | 0 | * | Yes | | | Nonzero | Nonzero | Nonzero | 0 | Yes | | | Nonzero | Nonzero | Nonzero | Nonzero | No | | | *Since field length is zero, the data is disregarded. | | | | | | # **Decimal Compare** 74jk (2 descriptors) Decimal Compare, D(Aj) to D(Ak), result to X1R CMPN, Aj, XO Ak, Xi | 0 | 78 | 1 | 112 | <u> 15</u> | |----|----|---|-----|------------| | 74 | | j | k | | This instruction algebraically compares the decimal contents of the source and destination fields, and depending on the comparison results, transfers a half word to X1R as follows: | Condition | | Action Taken | | |-------------------|-------------------|---------------------------------|--| | D(Aj) = D(Ak) | Clear XlR. | | | | D(Aj) > D(Ak) | Clear X1R bits 32 | and 34 through 63, set bit 33. | | | $D(A_1) < D(A_k)$ | Clear XIR bits 34 | through 63, set bits 32 and 33. | | The instruction allows data types 0 through 6. The maximum operand length is a function of the data type. The instruction accommodates unequal field lengths by using decimal zero fill in the leftmost positions of the shorter-length field. #### **Numeric Move** 75jk (2 descriptors) Numeric Move, D(Ak) replaced by D(Aj) after formatting MOVN, Aj, XO Ak, Xi This instruction obtains a number from the source field, validates the number according to the T field from its associated data descriptor, reformats it according to the T field in the destination field data descriptor, and transfers the result to the destination field. The instruction can convert and format any combination of data types 0 through 8, and 10 or 11. If the conversion is from a decimal data type to a binary data type, the decimal data type determines the maximum length for the source as follows: | Source Field Data Type | Maximum<br>Source Field<br>Length (Bytes) | | |------------------------|-------------------------------------------|--| | 0 through 3 | 19 | | | 4 through 8 | 38 | | The maximum destination field length is eight bytes. The instruction truncates the leftmost bytes if the destination field is not long enough to accommodate the entire binary number, or extends the sign bit on the left if the destination field exceeds the conversion result. When truncation places a negative zero into the destination field, it is not changed to positive zero. The same length restrictions apply if the source is a binary data type and the destination is a decimal data type, except that if the receiving field exceeds the converted number, the instruction adds leading zeros according to the decimal data type [ASCII character zero $(30_{16})$ or digit zero $(0_{16})$ ]. When both operands are decimal, the destination field fills from right to left. If the field lengths are unequal, the instruction either truncates leading digits or inserts leading zeros according to the destination data type. This instruction can cause the arithmetic loss-of-significance exception condition. #### **Decimal Scale** E4jkiD (2 descriptors) Decimal Scale, D(Ak) replaced by D(Aj), scaled per XiR plus D SCLN, Aj, XO Ak, X1, Xi E5jkiD (2 descriptors) Decimal Scale Rounded, D(Ak) replaced by rounded D(Aj), scaled per XiR plus D SCLR, Aj, XO Ak, X1, Xi | 0 7 | 8 11 | 12 15 | 16 19 | 20 | 31 | |-------|------|-------|-------|----|----| | E4,E5 | j · | k | i | D | | These shift instructions move data from the source field to the destination field, shifting the data under control of a computed shift count. This count is the 8-bit sum of the two's complement 32-bit integer from XiR plus the D-field rightmost 8 bits of the instruction. Any overflow from the 8-bit sum is ignored. The XO contents interpret as all zeros. The instruction acts as a move instruction if the shift count equals zero. With positive shift count (bit 56 = 0), the source data left-shifts as determined by bits 57 through 63 of the computed shift count. A negative shift count (bit 56 = 1) causes a shift to the right. In this case, the number of positions is determined by the two's complement of bits 57 through 63 of the computed shift count. A value of 1000 0000 interprets as a right shift of 128 positions. A positive shift count effectively multiplies the source data by powers of 10; a negative shift count divides the source data by powers of 10. The shifting occurs as the data moves from the source to the destination field. Shifting is end-off with zero-fill as required to accommodate the length and type specified for the destination field. The source field sign moves the destination field unchanged. The shift counts are interpreted as follows: The instruction allows data types 0 through 6 for the source and destination fields. The decimal scale rounded (E5) instruction rounds upward the absolute value of the right-shift result. This occurs by adding 5 to the last digit shifted end-off, and propagating carries through the decimal result. These instructions may cause the arithmetic loss-of-significance exception condition. ## **BDP BYTE INSTRUCTIONS** The instructions in this subgroup (table II-1-13) compare, translate, move, edit, or scan byte fields in CM. Table II-1-13. BDP Byte Instructions | Opcode | Format | Instruction | Mnemonic | |--------|--------|---------------------------|---------------| | 76 | jk | Move bytes | MOVB,Aj,XO | | 77 | jk | Byte compare | CMPB,Aj,XO | | Е9 | jkiD | Byte compare, collated | CMPC,Aj,X0 | | ЕВ | jkiD | Byte translate | TRANB, Aj, XO | | ED | jkiD | Edit | EDIT, Aj, XO | | F3 | jkiD | Byte scan while nonmember | SCNB,XO | The following conditions apply to all byte instructions: - Instruction specification error. - Address specification error. - Access violation. - Page table search without find. - Debug. Individual instruction descriptions list additional interrupt conditions where applicable. Refer to CP Interrupts in section 2 of this volume for descriptions of these conditions. ### **Byte Compare** 77jk (2 descriptors) Byte Compare, D(Aj) to D(Ak), result to X1R, index to X0R CMPB, Aj, XO Ak, X1 | 0 | | 78 | 111 | 12 1 | 5 | |---|----|----|-----|------|---| | | 77 | j | | k | | E9jkiD (2 descriptors) Byte Compare Collated, D(Aj) to D(Ak), both translated per (Ai plus D), result to X1R, index to X0R CMPC, Aj, XO Ak, Xl, Ai, D These instructions compare the bytes in the source and destination fields, and set X1R according to the result. The comparison proceeds from left to right. When the field lengths are unequal, trailing space characters $(20_{16})$ are used for the shorter field. The maximum operand length is 256 bytes. Data types are ignored. The comparison continues until the longer field is exhausted or the instructions detect an inequality, as follows: Compare (77) The byte comparison ends when the instruction detects an inequality between corresponding bytes in the source and destination field. Compare Collated (E9) An inequality detected between corresponding bytes from the source and destination fields results in the translation of both bytes, using a translation table in CM. If the translated bytes are unequal, the comparison stops with the results shown in the following list. If the translated bytes are equal, the comparison continues until the longer field is exhausted, or until the instruction detects another inequality. In the later case, another translation and comparison occurs. The comparison results are indicated in XIR as follows: | Condition | Action Taken | |---------------|---------------------------------------------------| | | | | D(Aj) = D(Ak) | XlR cleared. | | D(Aj) > D(Ak) | Clear X1R bits 32 and 34 through 63, set bit 33. | | D(Aj) < D(Ak) | Clear XIR bits 34 through 63, set bits 32 and 33. | An unequal comparison places the sequence number of the byte causing the inequality into XOR. The instruction adds each field's leftmost byte address to the sequence number in XOR to determine the byte addresses within the source and destination fields causing the unequal comparison. Register XOR does not change if inequalities do not exist. The user determines the translation table contents used by the compare collated instruction, and preloads the table into CM. The translation table contains 256 bytes. Its starting address forms by adding the BN field in Ai to the zero-extended D field from the instruction. Each translated byte adds as a positive offset to the translation table starting address, forming the address of the translated byte read from CM. ## **Byte Translate** **EBjkiD** (2 descriptors) Byte Translate, D(Ak) replaced by D(Aj), translated per (Ai plus D) TRANB, Aj, XO Ak, Xi, D | 0 | 7 | 8 11 | 12 15 | 16 19 | 20 31 | |---|----|------|-------|-------|-------| | | EB | j | k | i | D | This instruction translates each source field byte according to a user-generated translation table in CM, and transfers the results to the destination field. The source and destination field lengths are limited to 256 bytes. Data types are ignored. The translation proceeds from left to right. The instruction uses each source field byte as a positive offset which it adds to the translation table address to locate the translated byte. Translated bytes transfer to the destination field. The translation terminates after the destination field length has been exhausted. If the source field exceeds the destination field, the instruction truncates the rightmost bytes of the source field. When the source field is shorter than the destination field, the instruction fills the destination field rightmost byte positions with translated space characters. The user determines the translation table contents and preloads the table into CM. This table contains 256 bytes; its starting address forms by adding the BN field in Ai to the zero-extended D field from the instruction. ### **Move Bytes** 76jk (2 descriptors) Move Bytes, D(Ak) replaced by D(Aj) MOVB, Aj, XO Ak, Xi This instruction moves bytes from the source field to the destination field. The move operation is from left to right; data types are ignored. Maximum field lengths are 256 bytes. Unequal field lengths result in truncating trailing characters from the source field or inserting trailing space characters into the destination field. ### **Edit** EDjkiD (1 descriptor) Edit, D(Ak) replaced by D(Aj) edited per D(Ai+D) EDIT, Aj, XO Ak, Xi, Ai, D | 0 | 78 1 | 1 12 15 | 16 19 | 20 31 | |----|------|---------|-------|-------| | ED | j | k | i | D | Under control of a CM byte field called an edit mask, this instruction edits digits or characters from the source field and transfers the result to the destination field. It can perform the following editing functions: - Move source field digits/characters to destination field. - Move characters from the edit mask to destination field. - Specify and insert a string of 0 through 15 characters (symbol) into the destination field. - Specify an 8-byte special character table (SCT) and insert any character from this table. - Insert suppression characters and floating signs to the left of the first significant digit. - Perform insertion of signs, suppression characters, blanks, symbols, or SCT characters based on whether the source field is positive or negative. - Spread suppression character through the destination field. - Write suppression characters if destination field is zero. The source data descriptor type fields are restricted to data types 0 through 9. The instruction ignores the destination data descriptor type fields. ### Edit Mask The edit mask consists of a length-indication byte followed by up to 254 micro-operation bytes. The length is a binary number indicating the number of bytes in the edit mask (including the length-indication byte). If the length-indicating byte is either zero or one, the associated edit instruction results in a no-operation. After the length indicator, the mask contains a string of one-byte microinstructions. The edit mask address is the sum of the BN field from Ai plus the zero-extended D field from the instruction. The edit mask format is as follows: ### **Field** ## Description LENGTH Binary number indicating the total number of bytes in the edit mask $(0 \text{ to } 255_{10}).$ MOP Microoperator specifying the editing function. SV Binary specification value from 0 through 15. Meaning varies according to the associated MOP. #### Edit Operation The edit operation uses the tables and toggles described in the following paragraphs. Edit control proceeds from left to right on the mask, one character at a time. The instruction performs the editing function specified by the MOP and the SV. Indexing through the source field is by bytes unless its data type is packed-numeric. Packed-numeric data is indexed by half-bytes. Indexing through the destination field is by bytes. ## MOP Description Nomenclature The MOP descriptions use the following additional terms: | Term | Description | |------|------------------------------------------------------| | ES | End suppression toggle. | | SCT | Special characters table. | | sv | Specification value (Refer to Edit Mask, preceding). | | SM | Symbol. | | SN | Negative sign toggle. | | ZF | Zero field. | #### End Suppression Toggle The end suppression (ES) toggle controls zero suppression. Hardware sets the ES toggle false at the start of edit. The ES toggle sets true when zero suppression ends, when the first nonzero leading digit is encountered, or by a MOP. #### Special Characters Table The eight-byte special characters table (SCT) is stored in hardware. Entries are written by the micro operation code D. For proper editing, the SCT must be as follows: #### Symbo1 The symbol (SM) is a string of 0 through 15 characters that the edit instruction creates and inserts into the destination field, under edit mask control. Once the symbol has been inserted, the instruction must recreate it before reinserting it. The symbol has a length of zero when an edit operation begins. The system uses the symbol for the floating-sign and floating-currency editing features, and for sign-sensitive and significance-sensitive character string insertion. ### Negative Sign Toggle The negative sign toggle (SN) provides the source field sign. At start of edit, hardware sets the SN toggle false if the source field is an alphanumeric, an unsigned numeric, or a positive numeric. The SN toggle is initialized true only for a negative numeric source field. ## Zero Field Toggle The zero field (ZF) toggle depicts a zero or nonzero source field. It is initialized true, and sets false after encountering the first nonzero character. ## Skipping of Signs The edit instruction (under edit mask control) automatically skips signs when reading numeric data types. The signs interpret numerically when reading combined signed data types, also under edit mask control. #### Microoperation 0 This MOP translates source field characters to ASCII and moves these to the destination field as follows. The translation performs as described in the Edit Function NUMERIC in this section. - 1. Set ES true if SV is not equal to zero. - Translate SV digits from the source field to the equivalent ASCII characters and copy these into the destination field. ### Microoperation 1 This MOP moves type 9 characters as follows: - 1. Set ES true if SV is not equal to zero. - 2. Move SV characters from the source field to the destination field. The source field must be type 9 or an invalid BDP data condition occurs. #### Microoperation 2,3 These MOPs are no-operations. ## Microoperation 4 This MOP moves the next edit mask SV bytes to the destination field. ### Microoperation 5 This MOP sets the symbol to a single character from SCT, respresenting the source data field sign as follows: - Negative source data field. Copy SCT byte 3 to destination field. - Positive source data field. Copy SCT byte SV into symbol field. The SV rightmost 3 bits provide an index into the SCT. ## Microoperation 6 This MOP moves the next edit mask SV bytes to the symbol. ### Microoperation 7 This MOP conditionally translates source field SV digits to their equivalent ASCII characters and copies them to the destination field. The translation performs as described in the Edit Function NUMERIC in this section. - ES false and zero source field digit. Copy SCT byte one to destination field. - ES false and nonzero source field digit. Set ES true and copy symbol to destination field followed by the translated digit. - ES true. Copy translated digit to destination field. ### Microoperation 8 This MOP conditionally copies the symbol to the destination field as follows: - ES true. No operation. - ES false. Copy symbol to destination field and set ES true. ## Microoperation 9 This MOP conditionally copies the symbol or SCT character to the destination field as follows: - SV > 7 Copy symbol to destination field. - SV ≤ 7 Copy SCT byte SV into destination field. The SV rightmost 3 bits provide an index into SCT. ## Microoperation A This MOP conditionally copies the symbol or SCT character to the destination field as follows: - SV > 7 and source field positive. Copy symbol to destination field. - SV > 7 and source field negative. Copy SCT byte 0 to destination field, once for each symbol character. - SV ≤ 7 and source field positive. Copy SCT byte SV into destination field. The SV rightmost 3 bits provide an index into SCT. - SV ≤ 7 and source field negative. Copy SCT byte 0 into destination field. ## ${\tt Microoperation}\ {\tt B}$ This MOP is identical to MOP A, but with the action caused by a reversal of the source field sign. #### Microoperation C This MOP conditionally copies the symbol or SCT character to the destination field as follows: - SV > 7 and ES true. Copy symbol to destination field. - SV > 7 and ES false. Copy SCT byte 1 character to destination field, once for each symbol character. - SV ≤ 7 and ES true. Copy SCT byte SV into destination field. The SV rightmost 3 bits provide an index into SCT. - SV $\leq$ 7 and ES false. Copy SCT byte 1 into destination field. ### Microoperation D This MOP copies the next edit mask character into the SCT byte determined by using the SV rightmost 3 bits as an index into the SCT. ## Microoperation E This MOP copies SCT byte 1 into the destination field, SV times. #### Microoperation F This MOP conditionally copies SCT character into the destination field as follows: - No-operation when SV = 0. - ZF false and nonzero source field: terminate the edit instruction. - ZF true and zero source field: reset to start of destination field and copy SCT byte 1 into destination field SV times. ### Edit Function NUMERIC Micro-operations 0 and 7 translate and move a source digit into the destination field as follows: - Each source digit is checked. Invalid decimal digits cause an Invalid BDP Data condition. A program interrupt occurs when enabled. - When the source field is packed-numeric, appropriate ASCII zone bits are supplied for the destination character. - A nonzero digit causes the ZF toggle to be set false. #### Termination of the Edit Instruction The edit instruction terminates when the edit mask is exhausted, or when a MOP 15 is read and the zero field (ZF) toggle is false. The CP detects no exception conditions for either condition, even though the instruction may not have exhausted the source or destination fields. If the instruction terminates with the destination field not full, the remaining portion of the destination field is not altered. If the source field is not exhausted when the instruction terminates, the source field is checked for invalid BDP data, and the sign is examined. The edit instruction may cause the invalid BDP data exception condition. ### **Byte Scan While Nonmember** F3jkiD (1 descriptor) Byte Scan While Nonmember, D(Ak) for presence bit in (Ai+D), character to X1R, index to X0R SCNB, Aj, XO Ak, Xi | 0 7 | 8 11 | 12 15 | 16 19 | 20 31 | |-----|------|-------|-------|-------| | F3 | j | k | i | D | This instruction detects possible unwanted characters in a character string by inspecting a 256-bit table in CM. The starting byte address of the table forms by adding the BN field from Ai to the zero-extended D field from the instruction. The scan proceeds from left to right, one character at a time. The data type is ignored. The binary value of each character addresses a bit in the table. The scan terminates if this bit is a l or if the source field has been exhausted. If the scan terminates because the addressed bit is set, the following occurs: - The binary value of the sequence number (index) pointing to the byte causing scan termination is placed right-justified into XOR. - The binary value of the character causing scan termination is placed right-justified into XIR. If the scan terminates from exhaustion of characters in the byte string, XOR contains the original byte string length, XIR bit 32 sets, and bits 33 through 63 clear. This instruction can also perform the Byte Scan While Member function. In this case, the table specifying the nonallowed byte string characters is logically complemented before the instruction executes. #### **BDP SUBSCRIPT AND IMMEDIATE DATA INSTRUCTIONS** The instructions in this subgroup are listed in table II-1-14. Table II-1-14. BDP Subscript and Immediate Data Instructions | Opcode | Format | Instruction | Mnemonic | |--------|--------|-----------------------------|---------------| | F4 | jkiD | Calculate subscript and add | CALDF, Aj, XO | | F9 | jkiD | Move immediate data | MOVI,Xi,D | | FA | jkiD | Compare immediate data | CMPI,Xi,D | | FB | jkiD | Add immediate data | ADDI,Xi,D | The following conditions apply to all subscript and immediate data instructions. - Instruction specification error. - Address specification error. - Invalid segment/ring number zero. - Access violation. - Page table search without find. - Debug. - Invalid BDP data. Individual instruction descriptions list additional interrupt conditions where applicable. Refer to CP Interrupts in section 2 of this volume. ### Calculate Subscript and Add F4jkiD (1 descriptor) Calculate Subscript and Add, D(Aj) checked and modified per (Ai plus D), result added to XkR CALDF, Aj, XO Ak, Xi, Ai, D | 0 | 78 11 | 12 15 | 16 19 | 20 31 | |----|-------|-------|-------|-------| | F4 | j | k | i | D | This instruction uses a subscript range table (SRT) contained in CM. The SRT contains one or more 64-bit entries with each entry divided into three binary integer values as follows: | 0 | 78 | 11 1 | 12 15 | |----|----|------|-------| | 3A | | j | k | Field ## Description SIZE Sixteen bits, unsigned. Specifies number of elements in one dimension of an array (table). MIN Sixteen bits, signed. Specifies minimum allowable value of source field. MAX Thirty-two bits, signed. Specifies maximum allowable value of source field. This instruction forms the PVA of the subscript range table entry using 1) RN and SEG from Ai, and 2) the byte number (BN) generated by adding the BN field from Ai to the instruction D field (expanded to 32 bits using zeros in the high-order bit positions). A signed, 32-bit two's complement binary integer is obtained from the CM source field at location D(Aj). The instruction uses binary source field data unchanged and converts decimal data to its binary equivalent. The occurrence number is the difference between the binary value of the source field's rightmost 32 bits and the MIN value (sign-extended to 32 bits). The occurrence number is a signed, 32-bit two's complement integer. To calculate the subscript, the instruction multiplies the OCCURRENCE NUMBER by SIZE, and adds the product to the index value in the destination register XkR. The CP does not detect overflow during any arithmetic operation associated with this instruction. The source field is restricted to data types 0 through 6, 10, and 11, with the maximum field lengths determined by the source field data type. #### Move Immediate Data F9jkiD (1 descriptor) Move Immediate Data, D(Ak) replaced by XiR plus D per j MOVI, Xi, D Ak, Xi, j | 0 | 7 | 8 11 | 12 15 | 16 19 | 20 31 | |---|----|------|-------|-------|-------| | ſ | F9 | j | k | i | D | The immediate data byte is the two's complement sum of XiR bits 56 through 63, plus the rightmost 8 bits of the instruction D field. Overflow is ignored on this summation. X0 consists of all zeros. This instruction moves the immediate data to the destination field after format conversion specified by the destination field data type and the j-field suboperation code. The conversion is encoded in the least significant 2 bits (bits 10, 11) of the instruction's j field as follows: | j Field<br>Bits 10,11 | <u>Operation</u> | |-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00 | The positive, unsigned numeric value (type 10) in the immediate data byte moves right-justified to the destination field. The destination field is restricted to data types 10 or 11. | | 01 | The decimal numeric (type 4) immediate data byte moves right-justified to the destination field after reformatting (if necessary). A positive sign is supplied as required. The destination field is restricted to decimal data types 0 through 6. | | 10 | The ASCII character in the immediate data byte repeats left-to-right in the destination field. Destination data type is ignored. | | 11 | The ASCII character in the immediate data byte moves, left-justified, into the destination field; the remainder of the field fills with space characters. The destination data type is ignored. | The slack digit of destination field types 1 and 3 is unchanged by this instruction. The instruction may cause the arithmetic loss-of-significance exception condition. # Compare Immediate Data FAjkiD (1 descriptor) Compare Immediate Data, XiR plus D to D(Ak) per j, result to XiR CMPI,Xi,D Ak,Xi,j | 0 7 | 8 11 | 12 15 | 16 19 | 20 31 | |-----|------|-------|-------|-------| | FA | j | k | i | D | The immediate data byte is the two's complement sum of XiR bits 56 through 63, plus the rightmost 8 bits of the instruction D field. Overflow is ignored on this summation. XO consists of all zeros. This instruction performs a format conversion on the immediate data byte as specified by destination field data type and the j field suboperation code. The instruction then compares the reformatted immediate data byte to the contents of D(Ak). The instruction j field encodes the operation as follows: | j Field<br>Bits 10,11 | Operation | |-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00 | The positive, unsigned numeric value (type 10) in the immediate data byte compares to the contents of D(Ak). The destination field is restricted to data types 10 or 11. If field D(Ak) exceeds one byte, the immediate data byte zero-fills in its high-order positions. | | 01 | The decimal numeric (type 4) immediate data byte compares to the contents of D(Ak) after reformatting (if necessary) to match the data type of field D(Ak). A positive sign is supplied as required. The D(Ak) field is restricted to decimal data types 0 through 6. If D(Ak) exceeds one byte, the immediate data byte zero-fills in its high-order positions. | | 10 | The ASCII character in the immediate data byte compares left-to-right to the D(Ak) field. Then (DAk) field data type is ignored. | | 11 | The ASCII character in the immediate data byte compares to the leftmost byte in field D(Ak). If the comparison is equal and field D(Ak) exceeds one byte, a space character compares left-to-right with each successive byte remaining in the D(Ak) field. The D(Ak) field data type is ignored. | A half-word transfers to X1R to indicate the comparison result as follows: | Results of<br>Compare | Register XlR | |-----------------------|-----------------------------------------------| | Source = Destination | Clear X1R. | | Source > Destination | Clear bits 32 and 34 through 63, set bit 33. | | Source < Destination | Clear bits 34 through 63, set bits 32 and 33. | #### **Add Immediate Data** FBjkiD (1 descriptor) Add Immediate Data, D(Ak) replaced by D(Ak) plus XiR plus D per j ADDI,X1,D Ak,Xi,j | 0 | 78 11 | 12 15 | 16 19 | 20 31 | |----|-------|-------|-------|-------| | FB | j | k | i | D | The add immediate instruction converts the source field immediate data to match the destination field data type (if required), and adds the immediate data byte to D(Ak). The immediate data byte stores the integer value of the addend. The instruction j field encodes the data type contained in the immediate data byte. The j field least significant bit (bit 11) decodes as follows: | j Field<br>Bit 11 | Data Type<br>Immediate Data Byte | | | | | |-------------------|------------------------------------------------------------------|--|--|--|--| | 0 | Data type = 10. Unsigned (positive) binary integer value. | | | | | | 1 | Data type = 4. One ASCII character representing a decimal digit. | | | | | If the source field is data type 10, the destination field is restricted to data types 10 or 11. If source data is type 4, the destination is restricted to types 0 through 6. This instruction may cause the arithmetic overflow exception condition. ## FLOATING-POINT INSTRUCTION DESCRIPTIONS Refer to Floating-Point Programming in section 2 of this volume for descriptions of floating-point data formats, standard and nonstandard numbers, and normalization. The floating-point (FP) instructions consists of 18 operation codes in 4 subgroups: - Conversion. - Arithmetic. - Branch. - Compare. Tables II-1-15 through II-1-17 list the instructions in the first 3 subgroups. ### **DOUBLE-PRECISION REGISTER DESIGNATORS** The double-precision FP add, subtract, multiply, and divide instructions operate on double-length registers, designated as follows: ### FLOATING-POINT CONVERSION INSTRUCTIONS The instructions in this subgroup (table II-1-15) convert 64-bit words between FP and integer formats. Table II-1-15. Floating-Point Conversion Instructions | 0pcode | Format | Instruction | Mnemonic | |--------|--------|----------------------------|----------| | 3A | jk | Convert from integer to FP | CNIF | | 3в | jk | Convert from FP to integer | CNFI | ### Convert From Integer to FP 3Ajk Convert, floating-point Xk formed from integer Xj CNIF Xk,Xj | 0 | 7 | 8 | 11 | 12 | 15 | |----|---|---|----|----|----| | 3A | | j | | k | | This instruction converts the signed 64-bit two's complement binary integer from Xj to its normalized FP representation, and transfers the 64-bit result to Xk. During conversion, the instruction truncates the rightmost bits of integers outside the range $-2^{48}$ through $(2^{48})-1$ . When Xj is all zeros, it transfers unchanged to Xk. ## Convert From FP to Integer 3Bjk Convert, integer Xk formed from floating-point Xj. CNFI Xk, Xj | 0 | 78 | 11 | 12 15 | |----|----|----|-------| | 3В | | j | k | This instruction converts the 64-bit FP number in Xj to a signed two's complement binary integer and transfers the result to Xk. The fractional part of the binary equivalent truncates. This conversion results in an integer consisting of all zeros if the FP number: - Is indefinite. - Has an exponent equal to zero. - Has a fraction equal to zero. - Is infinite. This instruction may cause the arithmetic loss-of-significance, ${\tt FP}$ indefinite, and ${\tt FP}$ infinite exception conditions. ### FLOATING-POINT ARITHMETIC INSTRUCTIONS The instructions in this subgroup (table II-1-16) perform arithmetic operations on ${\rm FP}$ numbers. Table II-1-16. Floating-Point Arithmetic Instructions | Opcode | Format | Instruction | Mnemonic | |--------|--------|--------------------------------|----------| | 30 | jk | FP sum | ADDF | | 31 | jk | FP difference | SUBF | | 32 | jk | FP product | MULF | | 33 | jk | FP quotient | DIVF | | 34 | jk | Double-precision FP sum | ADDD | | 35 | jk | Double-precision FP difference | SUBD | | 36 | jk | Double-precision FP product | MULD | | 37 | jk | Double-precision FP quotient | DIVD | The following conditions apply to all FP arithmetic instructions: - Exponent overflow. - Exponent underflow. - Floating-point loss-of-significance. - Floating-point indefinite. Individual instruction descriptions list additional interrupt conditions where applicable. Refer to CP Interrupts in section 2 of this volume. ### Floating-Point Sum/Difference | 30jk | Floating-Point Sum,<br>Xk replaced by Xk plus Xj | ADDF | Xk,Xj | |------|---------------------------------------------------------------------------|------|-------| | 31jk | Floating-Point Difference,<br>Xk replaced by Xk minus Xj | SUBF | Xk,Xj | | 34jk | Double-Precision Floating-Point Sum,<br>XXk replaced by XXk plus XXj | ADDD | Xk,Xj | | 35jk | Double-Precision Floating-Point Difference, XXk replaced by XXk minus XXj | SUBD | Xk,Xj | | 0 7 | 8 11 | 12 15 | |-------------|------|-------| | 30,31,34,35 | j | k | The following instruction description applies to either single- or double-precision operations. References to Xk or Xj in the description also apply to XXk or XXj for the double-precision instructions. These instructions algebraically compare the exponents of the two FP operands in Xk and Xj. If the exponents are equal, no adjustment is necessary. If the exponents are unequal, the instruction aligns the coefficients by right-shifting the coefficient with the smaller exponent the number of bit positions designated by the difference between the exponents. The maximum shift is 48 positions for single-precision instructions or 96 positions for double-precision instructions. The two aligned coefficients consist of a signed 48-bit single-precision or 96-bit double-precision fraction. The instructions add or subtract the two coefficients as determined by the operation code, using the Xj coefficient as the addend or subtrahend. The algebraic result is a signed coefficient with 48 bits (single-precision) or 96 bits (double-precision), plus an overflow bit. The overflow bit provides the required allowance for true addition (FP sum of coefficients with like signs or FP difference of coefficients with unlike signs). If coefficient overflow occurs (overflow bit = 1), the instruction right-shifts the coefficient one place, inserts the overflow bit in the high order bit position (bit 16), increases the exponent by one, and places the result in Xk. If the coefficient overflow bit is zero and the coefficient is not all zeros, the instructions normalize the result before placing the result in Xk. If either or both of the input operands in Xk and Xj consists of an infinite or indefinite FP number, the result transferred to Xk is a nonstandard FP number. Refer to Floating-Point Standard and Nonstandard Numbers in section 2 of this volume. Xk,Xj #### Floating-Point Product 32jk Floating-Point Product, Xk replaced by Xk times Xj MULF 36jk Double Precision Floating-Point Product, XXk replaced by XXk times XXj MULD Xk,Xj | 0 | 78 | 11 | 12 15 | |-------|----|----|-------| | 32,36 | 3 | j | k . | The following instruction description applies to either single- or double-precision operations. References to Xk or Xj in the description also apply to XXk and XXj for the double-precision instructions. The multiply FP instructions algebraically add the signed exponents for the two FP operands in Xk and Xj, using the result as an intermediate exponent. The instructions multiply the coefficient in Xk by the coefficient in Xj to produce an algebraically-signed product consisting of 96 bits (single-precision) or 192 bits (double precision). If the products high-order bit (bit 16) is a one, the product is already normalized and the high-order 48 bits (single-precision) or 96 bits (double-precision) become an intermediate coefficient. If the high-order bit is a zero, the instructions left-shift the 96-bit or 192-bit product one bit position, decrease the intermediate exponent by one, and use the high-order 48 bits (single-precision) or 96 bits (double-precision) as the intermediate coefficient. This one-position shift results in a normalized product if both input operands were normalized before executing the multiply instruction. If the intermediate exponent (including the adjustment for normalization) is not equal to an out-of-range value, the intermediate exponent and the intermediate coefficient (with its sign) transfer to Xk to form the final result. If one or both of the input operands in Xk and Xj consist of an infinite, indefinite, or zero FP number, the result transferred to Xk is a nonstandard FP number. Refer to Floating-Point Standard and Nonstandard Numbers in section 2 of this volume. # Floating-Point Quotient 33jk Floating-Point Quotient, Xk replaced by Xk divided by Xj DIVF Xk,Xj 37jk Double-Precision Floating-Point Quotient, XXk replaced by XXk divided by XXj DIVD Xk,Xj | 0 | 78 | 11 12 | <u> 15</u> | |-------|----|-------|------------| | 33,37 | j | ı | ζ | The following instruction description applies to either single- or double-precision operations. References to Xk or Xj in the description also apply to XXk or XXj for the double-precision instructions. The divide FP instructions subtract the Xk exponent (divisor) from the Xk exponent (dividend), and use the signed result as an intermediate exponent. These instructions divide the Xk signed coefficient by the Xj signed coefficient. If the Xj coefficient is unnormalized before instruction execution, and can be divided into the Xk coefficient by a factor exceeding or equal to 2, the CP detects a divide fault. If the CP does not detect errors, the division results in an algebraically-signed quotient with 48 bits (single-precision) or 96 bits (double-precision), plus an overflow bit. The overflow bit allows for cases in which the divisor can be divided into the dividend by a factor equal to or exceeding one, but less than two. If the overflow bit is a zero, the sign bit and 48- or 96-bit quotient require no further adjustments. If the overflow bit is a one, the instruction right-shifts the quotient one position, end-off, with the overflow bit inserted into the high-order bit position, and the exponent increased by one. The intermediate exponent and intermediate coefficient (with its sign) transfer to Xk to form the final result. When one or both of the input operands in Xk and Xj consist of an infinite, indefinite, or zero FP number, the result transferred to Xk is a nonstandard FP number. (Refer to Floating-Point Standard and Nonstandard Numbers in section 2 of this volume.) This instruction may cause a divide fault exception condition. ### FLOATING-POINT BRANCH INSTRUCTIONS This subgroup (table II-1-17) consists of five conditional branch instructions. Each instruction compares two FP numbers and performs either a normal or branch exit based on the comparison results. Table II-1-17. Floating-Point Branch Instructions | Opcode | Format | Instruction | Mnemonic | |--------|--------|---------------------------------------|----------| | 98 | jkQ | FP branch on equal | BRFEQ | | 99 | jkQ | FP branch on not equal | BRFNE | | 9A | jkQ | FP branch on greater than | BRFGT | | 9в | jkQ | FP branch on greater than or equal to | BRFGE | | 9E | jkQ | FP branch on overflow | BROVR | | 9E | jkQ | FP branch on underflow | BRUND | | 9Е | jkQ | FP branch on indefinite | BRINF | | 3C | jk | FP compare | CMPF | #### **Normal Exit** The instruction takes a normal exit if the branch condition is not satisfied. The next instruction address forms by adding 4 to the BN field of the current PVA in P. # **Branch Exit** The instruction takes a branch exit if the branch condition is satisified. The next instruction address forms by adding 2 times the Q field value (from the branch instruction) to the BN field of the current PVA in P. ### **Group Interrupt Conditions** The following interrupt conditions apply to all FP branch instructions. - Debug. - Floating-point loss-of-significance. - Floating-point indefinite. Refer to CP Interrupts in section 2 of this volume for descriptions of these conditions. ### Floating-Point Branch on Comparison | 98jkQ | Branch to P Displaced by 2*Q, if floating-point Xj equal to Xk | BRFEQ | Xj,Xk,Q | |-------|--------------------------------------------------------------------------------|-------|---------| | 99jkQ | Branch to P Displaced by 2*Q, if floating-point Xj not equal to Xk | BRFNE | Xj,Xk,Q | | 9AjkQ | Branch to P Displaced by 2*Q, if floating-point Xj greater than Xk | BRFGT | Xj,Xk,Q | | 9BjkQ | Branch to P displaced by 2*Q, if floating-point Xj greater than or equal to Xk | BRFGE | Xj,Xk,Q | | 0 | 78 | 11 | 12 15 | 16 31 | |------------|----|----|-------|-------| | 98,99,9A,9 | В | j | k | Q | Each compare and branch instruction performs an algebraic comparison between the 64-bit words in Xj and Xk. If the branch conditions are satisfied, the instruction takes a branch exit. If the conditions are not satisfied, a normal exit results. These instructions treat the 64-bit words in Xj and Xk as single-precision FP numbers. If Xj or Xk specifies register XO, these instructions interpret XO as all zeros. For the results with the various combinations of comparison input data, refer to Floating-Point Standard and Nonstandard Numbers in section 2 of this volume. ### Floating-Point Branch on Condition 9EjkQ Branch to (P) Displaced by 2\*Q, if floating-point Xk is exception per j | | j Field | | Xk Tested For | | | | |----|------------------------|------|----------------------|-------|-------|------| | | 00 Exponent overflow. | | 00 | | BROVR | Xk,Q | | | 01 Exponent underflow. | | | BRUND | Xk,Q | | | | 10/1 | 1 | Exponent indefinite. | | BRINF | Xk,Q | | 0_ | 7 | 8 11 | 12 15 | 16 31 | | | | | 9E | j | k | Q | | | The instruction takes a branch exit if the exception condition designated by bits 10 and 11 of the instruction j field applies to the 64-bit FP number in Xk. A normal exit occurs if the exception condition designated by j field bits 10 and 11 does not apply to the 64-bit FP number in Xk. ### Floating-Point Compare CMPF Xi,Xj,Xk This instruction algebraically compares the Xj 64-bit word to the Xk 64-bit word, and indicates the result by setting bits in XlR. The instruction treats the 64-bit words in Xj and Xk as single-precision FP numbers. If Xj or Xk specifies register XO, the instruction interprets XO as all zeros. XIR bits are set as follows: | Results of<br>Compare | Register<br>X1R | |-----------------------|-----------------------------------------------| | Xj = Xk | Clear XIR. | | Xj > Xk | Clear bits 32 and 34 through 63, set bit 33. | | Xj < Xk | Clear bits 34 through 63, set bits 32 and 33. | | Indefinite | Clear bits 33 through 63, set bit 32. | If the comparison results are indefinite, the CP records an FP indefinite condition and sets register X1R as shown in the preceding table. If the corresponding user mask bit is set and the trap enabled, the corresponding program interrupt occurs. # **VECTOR INSTRUCTION DESCRIPTIONS** The vector instruction group consists of 20 operation codes in 6 subgroups: - Integer vector arithmetic. - Integer vector compare. - Logical vector arithmetic. - Integer/floating-point vector conversion. - Floating-point vector arithmetic. - Special-purpose vector instructions. Table II-1-18 lists the instructions within each subgroup. For descriptions of vector length, page size, broadcast, interrupts, and overlap, refer to Vector Programming in section 2 of this manual. # **VECTOR INSTRUCTION FORMAT** The vector instruction group utilizes the jkiD format (refer to figure II-1-1). Figure II-1-1. Vector Instruction Format | <u>Field</u> | Description | | | | | |--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | j | Designates register Aj which contains the starting address of a source vector, VAj. | | | | | | k | Designates register $Ak$ which contains the starting address of a destination vector, $VAk$ . | | | | | | i | Designates register Ai which contains the starting address of a second source vector, VAi. May also designate register Xi which contains the interval for gather and scatter instructions. | | | | | | D | Specifies vector length (number of operations). For further information, refer to Vector Length described under Vector Programming in section 2 of this manual. | | | | | Table II-1-18. Vector Instructions | Instruction Name | Opcode | Mnemonic | |--------------------------------------------------------------|--------------------|--------------| | Integer Vector Sum | 44jkiD | ADDXV | | Integer Vector Difference | 45 jkiD | SUBXV | | Integer Vector Compare, = | 50jkiD | СМРЕQV | | Integer Vector Compare, < | 51 jkiD | CMPLEV | | Integer Vector Compare, $\geq$ | 52jkiD | CMPGEV | | Integer Vector Compare # | 53jkiD | CMPNEV | | Shift Vector Circular | 4DjkiD | SHFV | | Logical Vector Sum | 48jkiD | IORV | | Logical Vector Difference<br>Logical Vector Product | 49jkiD<br>4AjkiD | XORV<br>ANDV | | 20great vector floatet | ANJELD | MUV | | Convert Vector from Int. to FP | 4BjkiD | CNIFV | | Convert Vector from FP to Integer | 4C jkiD | CNFIV | | Floating Point Vector Sum | 40jkiD | ADDFV | | Floating Point Vector Difference | 41 jkiD | SUBFV | | Floating Point Vector Product Floating Point Vector Quotient | 42 jkiD<br>43 jkiD | MULFV | | Floating Fornt vector Quotient | 45 JK1 <i>U</i> | DIVEN | | Floating Point Vector Summation | 57jkiD | SUMFV | | Merge Vector | 54jkiD | MRGV | | Gather Vector | 55jkiD | GTHV | | Scatter Vector | 56 jkiD | SCTV | # Integer Vector Arithmetic The instructions in this subgroup perform arithmetic operations on pairs of integers that compose source vectors from CM. After completing the required operation, the instructions store the results in the destination vector into CM. | 44jkiD | <pre>Integer Vector Sum, V(Ak) replaced by V(Aj) plus V(Ai)</pre> | ADDXV | |--------|-------------------------------------------------------------------|-------| | 45jkiD | Integer Vector Difference, V(Ak) replaced by V(Aj) minus V(Ai) | SUBXV | These instructions perform the indicated arithmetic operation on the first element from V(Ai) and V(Ai) and store the result as the first element of V(Ak). This operation repeats for successive elements until the required number of operations has been performed. ### Integer Vector Compare The instructions in this subgroup perform comparisons between pairs of integers that compose source vectors from CM. After completing the required operation, the instructions store the results in a destination vector that returns to CM. | 50jkiD | <pre>Integer Vector Compare, V(Ak) replaced by V(Aj) equal to V(Ai)</pre> | CMPEQV | |--------|-------------------------------------------------------------------------------------------|--------| | 51jkiD | <pre>Integer Vector Compare, V(Ak) replaced by V(Aj) less than V(Ai)</pre> | CMPLTV | | 52jkiD | <pre>Integer Vector Compare, V(Ak) replaced by V(Aj) greater than or equal to V(Ai)</pre> | CMPGTV | | 53jkiD | <pre>Integer Vector Compare, V(Ak) replaced by V(Aj) not equal V(Ai)</pre> | CMPNEV | These instructions perform the indicated integer arithmetic comparison on the first elements from V(Aj) and V(Ai). If the comparison is true, bit 0 is set and bits 1 through 63 are cleared in the first element of V(Ak). If the comparison is false, bits 0 through 63 are cleared in the first element of V(Ak). This operation repeats for successive elements until the required number of operations has been performed. When broadcast of V(Aj) is selected and j=0, the content of X0 interprets as all zeros (refer to Vector Broadcast under Special Purpose Vector Instructions later in this section). The instructions in this subgroup perform logical operations between pairs of elements that compose source vectors from CM. After completing the required operation, the instructions store the results in a destination vector that returns to CM. | 48jkiD | Logical Vector Sum, V(Ak) replaced by V(Aj) OR V(Ai) | IORV | |--------|-----------------------------------------------------------------------|------| | 49jkiD | Logical Vector Difference, V(Ak) replaced by V(Aj) exclusive-OR V(Ai) | XORV | | 4AjkiD | Logical Vector Product, V(Ak) | ANDV | These instructions perform the indicated logical operation on the first element from V(Aj) and V(Ai) and store the result as the first element of V(Ak). This operation repeats for successive elements until the required number of operations has been performed. #### Integer/Floating-Point Vector Conversion The instructions in this subgroup perform conversions on successive element that compose a source vector from CM. After completing the required operation, the instructions store the results in a destination vector that returns to CM. | 4BjkiD | Convert Vector, floating-point V(Ak) formed from integer V(Aj) | CNIFV | |--------|----------------------------------------------------------------|-------| | 4CjkiD | Convert Vector, integer V(Ak) formed from floating-point V(Aj) | CNFIV | These instructions perform the indicated conversion on the first element from V(Aj) and store the result as the first element of V(Ak). This operation repeats for successive elements until the required number of conversions has been performed. ### Floating-Point Vector Arithmetic The instructions in this subgroup perform arithmetic operations on pairs of floating-point operands that compose source vectors from CM. After completing the required operation, the instructions store the results in a destination vector that returns to CM. | 40 jkiD | Floating-Point<br>V(Ak) replaced | Vector Sum,<br>by V(Aj) plus V(Ai) | ADDFV | |---------|----------------------------------|-----------------------------------------|-------| | 41 jkiD | | Vector Difference,<br>by V(Aj) minus | SUBFV | | 42 jkiD | | Vector Product,<br>by V(Aj) times | MULFV | | 43jkiD | | Vector Quotient,<br>by V(Aj) divided by | DIVFV | These instructions perform the indicated arithmetic operations on the first element from V(Aj) and V(Ai) and store the result as the first element of V(Ak). This operation repeats for successive elements until the required number of operations has been performed. #### **Special Purpose Vector Instructions** The instructions in this subgroup perform various manipulative operations on source vectors from $\text{CM}_{\bullet}$ 4DjkiD Shift Vector Circular, V(Ak) SHFV replaced by V(Ai), direction and count per V(Aj) This instruction performs a circular shift on the first element from V(Ai) as directed by the first element of V(Aj) and stores the result as the first element of V(Ak). This operation repeats for successive elements until the required number of operations has been performed. The shift count for each element in V(Ai) is taken from the rightmost 8 bits of the corresponding element of V(Aj). The sign bit in the leftmost position of the 8-bit shift count determines the shift direction. A positive shift count (sign bit = 0) left-shifts the instruction; a negative shift count (sign bit = 1) right-shifts the instruction. Shifts may be from 0 through 63 bits left and from 1 through 64 bits right. (A shift count of 0 causes the associated instruction to transfer the initial element of V(Ai) to the corresponding element in V(Ak) with no shift performed.) When vector broadcast of V(Aj) is selected and j=0, the XO contents interpret as all zeros. 54jkiD Merge Vector, V(Ak) partially replaced by V(Aj) per mask V(Ai) MRGV This instruction replaces the first element of V(Ak) with the first element of V(Aj) if bit 0 is set in the first element of V(Ai). If bit 0 is clear, the first element of V(Ak) is left unchanged. This operation repeats for successive elements until the required number of operations has been performed. 55 jkiD Gather Vector, V(Ak) replaced by gathered V(Aj) with interval Xi GTHV This instruction forms the contiguous vector V(Ak) by gathering elements from V(Aj) at interval Xi (refer to figure II-1-2). This instruction obtains the first element from V(Aj) and stores it as the first element of V(Ak). The second element to be stored in V(Ak) is taken from the address formed by adding the rightmost 32 bits of Xi, left-shifted 3 places with zero-fill, to the rightmost 32 bits of the previous address. The nth element of V(Ak) is replaced by V(Ak) whose address is (Aj)+8\*(n-1)(Xi). Execution does not alter the Xi contents. Figure II-1-2. Gather Instruction 56jkiD Scatter Vector, V(Ak) replaced by scattered V(Aj) with interval Xi SCTV This instruction scatters the contiguous V(Aj) elements in V(Ak) at interval Xi (refer to figure II-1-3). This instruction obtains the first element from V(Aj) and stores it as the first element of V(Ak). The second contiguous element from V(Aj) is stored into V(Ak) at the address formed by adding the rightmost 32 bits of Xi, left-shifted 3 places with zero-fill, to the rightmost 32 bits of A(k). Successive elements from V(Aj) are stored into the addresses formed by adding the rightmost 32 bits of Xi, left-shifted 3 places with zero-fill, to the rightmost 32 bits of the previous address. The $n^{th}$ element of V(Aj) is stored into V(Ak) at Figure II-1-3. Scatter Instruction 57 jkiD Floating-Point Vector Summation, Xk replaced by summation of elements in V(Ai) SUMFV This instruction adds together all the elements in V(Ai) and stores the sum in Xk. The individual add operations which together form this instruction are single-precision sums and may be performed in any order. II-1-70 7976 # SYSTEM INSTRUCTION DESCRIPTIONS The system instructions consist of 27 operation codes in 5 classes. The classes are based on the characteristics of the code segment from which the instructions are accessed, or the CP mode in which the instructions may operate. The classes are as follows: - Nonprivileged. - Local privileged. - Global privileged. - Virtual State. - Virtual State monitor mode. - Mixed mode. Local and global privileged instructions execute only when the XP field of the associated segment descriptor designates the appropriate privilege (with the CP in any mode). Virtual State monitor mode instructions execute only when the CP is in Virtual State monitor mode. Mixed mode instruction parameters within the instruction determine their privilege/mode requirements. Refer to Access Protection in section 2 of this volume for more information. ## NONPRIVILEGED SYSTEM INSTRUCTIONS The instructions in this subgroup are listed in table II-1-19. In some cases, a portion of the instruction word is unused, as indicated in the instruction format. Instruction execution is not affected by these unused bits, but it is recommended these bits be zeros. Table II-1-19. Nonprivileged Instructions | Opcode | Format | Instruction | Mnemonic | |--------|--------|----------------------------|------------| | 00 | jk | Program error | HALT | | 01 | jk | Scope loop synchronization | SYNC | | 02 | jk | Exchange | EXCHANGE | | 04 | jk | Return | RETURN | | 06 | jk | Рор | POP | | 08 | jk | Copy free running counter | CPYTX | | 14 | jk | Test and set bit LBSET | | | 16 | jk | Test and set page TPAGE | | | во | jkQ | Call relative | CALLREL | | в4 | jkQ | Compare swap | CMPXA | | в5 | jkQ | Call indirect CALLSEG | | | BE,BF | jkQ | Reserved opcodes | | | CO-C7 | SjkiD | Execute algorithm | EXECUTE, S | ## **Program Error** 00**j**k Program Error HALT This instruction causes an instruction specification error with the corresponding program interrupt or halt. # Scope Loop Sync 01jk Scope Loop Sync SYNC For the model 855, set CP breakpoint register 32 to $101_{16}$ by performing the CMSE command ER2,32 = $101_{16}$ . The instruction triggers at TP 44 at location 3Al-ClC. This instruction is a no-operation within the CP. The instruction generates a pulse to a test point for oscilloscope synchronization. ### Exchange 02jk Exchange **EXCHANGE** This instruction exchanges the current process registers (formatted as an exchange package) with another set stored in CM, and does the following: - When executed with CP in Virtual State monitor mode, the processor switches from monitor to job mode. - When executed in Virtual State job mode, the processor switches from job to monitor mode and the system call bit sets in the monitor condition register (MCR 10). In either case, the P register stored in the outgoing exchange package points to the next instruction that would have executed if the exchange had not occurred. This instruction can cause the following exception conditions: - Environment specification error. - System call. Refer to CP Modes of Operation in section 2 of this volume for further information. #### Return 04jk Return RETURN This instruction requires the following register assignments: (A0) Dynamic space pointer (DSP). (A1) Current stack frame (CSF) pointer. (A2) Previous save area (PSA) pointer. In exchange package Top of stack (TOS) pointer for current ring of execution. In exchange package TOS pointer for previous ring of execution. This instruction reestablishes the stack frame and environment of the previous procedure (which must be executing in an equal or less privileged ring as the current procedure). This operation does not load MCR or UCR. The instruction executes as follows: - Update the TOS pointer by storing the CSF pointer from Al into the TOS pointer for the current ring of execution. This has the effect of cancelling the current stack frame. - 2. Load the environment from the previous save area (as defined by PSA pointer in A2 and the stack frame descriptor in PSA) as follows: - P register (all fields). - VMID (CP state switch may take place). - CFF and OCF. - User mask register. - A0 through At (per SFSA descriptor). - Xs through Xt (per SFSA descriptor). - 3. Set the RN field of each A register loaded from SFSA equal to the largest of the following: - A(RN) from SFSA. - Initial A2(RN). - Rl of SDE for initial A2. - 4. If the final P(RN) does not equal the initial P(RN), set any A(RN) not loaded from PSA in step 2 (and less than the final P(RN)) equal to the final P(RN). - 5. Update TOS pointer in the exchange package. - 6. Clear trap enable delay. - 7. If any A(RN) loaded from PSA in step 2 is zero, set MCR 60, with interrupt or halt. When this happens, the instruction execution completes and UTP is unaltered. This instruction can cause the following exception conditions: - Address specification error. - Invalid segment/ring number zero. - Access violation. - Environment specification error. - Page table search without find. - Outward call/inward return. - Critical frame flag. - Debug. Pop 06jk Pop POP This instruction requires the following register assignments: (A0) Dynamic space pointer (DSP). (A1) Current stack frame (CSF) pointer. (A2) Previous save area (PSA) pointer. In exchange package Top of stack (TOS) pointer for current ring of execution. This instruction moves the CSF, PSA, and TOS pointers to eliminate the stack frame without changing the P-counter. This instruction reestablishes the stack frame (but not the environment) of the previous procedure, which must be in the same ring of execution as the current procedure. The stack frame is reestablished as follows: - Obtain the stack frame descriptor from the PSA (SFSA for the previous procedure) using the PSA pointer in A2. - Update the CSF pointer by loading Al with word 2 from the PSA. Set Al ring number equal to P ring number. - 4. Load the critical frame flag (CFF) and the on-condition flag from the PSA. - 5. Update the TOS pointer by storing the CSF pointer from final Al into the TOS pointer for the current ring of execution. This has the effect of cancelling the current stack frame. - 6. If any Al(RN) or A2(RN) loaded from PSA in step 2 is zero, set MCR60, with interrupt or halt. Instruction execution completes and UTP is unaltered. This instruction may cause the following exception conditions: - Address specification error. - Invalid segment/ring number zero. - Access violation. - Environment specification error. - Page table search without find. - Inter-ring pop. - Critical frame flag. - Debug. # **Copy Free Running Counter** O8jk Copy Free Running Counter to Xk at XjR CPYTX Xk,Xj This instruction copies the free running counter in CM into Xk (the free-running counter consists of either 64 bits of counter, or 48 bits of counter which are right-justified with zero-fill in the leftmost 16 bits). XjR bits 32 and 34 through 63 are zeros. XjR bit 33 specifies which processor port the instruction uses to read the counter as follows: # Bit 33 ### Port Selected 0 Local processor port to CM. . 1 External processor port to CM of another system. #### **Test and Set Bit** 14jk Load Bit to XkR from Aj Bit Indexed by XOR and Set Bit in CM LBSET Xk,Aj,X0 | 0 | 78_ | 11 | 12 15 | |----|-----|----|-------| | 14 | | j | k | This instruction transfers one bit from CM into XkR bit position 63 and clears Xk bits 0 through 62. The instruction also sets that bit in CM without changing any other bits in CM. The instruction addresses the CM byte containing the bit by adding bits 32 through 60 of XOR (right-shifted 3 positions, end-off, with sign extension on the left), to bits 32 through 63 of Aj. The instruction uses XOR bits 61 through 63 to locate the bit position within the addressed byte. Values 0 through 7 for these 3 bits select corresponding bits 0 through 7 from the addressed byte. No other CM accesses (from any port) to the CM byte containing that bit are permitted from the start of the read access until the end of the write access (when the instruction sets the bit in CM). The system performs a serialization function before and after instruction execution. The CP delays instruction execution until all previous CM accesses by previous instructions complete, and delays execution of the next instruction until all CM accesses from this instruction complete. To establish operand access validity, the instruction uses read—and write-type CM accesses. The read access bypasses cache memory. Termination of the write access purges the associated cache entry. This instruction may cause the following exception conditions: - Address specification error. - Invalid segment/ring number zero. - Access violation. - Page table search without find. - Debug. # **Test and Set Page** 16jk Test page (Aj) and set XkR TPAGE Xk, Aj | 0 | 78 | 11 | 12 | <u>15</u> | |----|----|----|----|-----------| | 16 | j | | k | | This instruction tests CM for the presence of the page (corresponding to the PVA in Aj) in the system page table with its valid bit set in the associated page descriptor. If the tested page is in CM, the used bit in the associated page descriptor sets, and the real memory address translated from the PVA from Aj transfers to XkR. If the tested page is not in CM, the instruction sets XkR bit 32 and clears XkR bits 33 through 63. This instruction may cause the following exception conditions: - Address specification error. - Invalid segment/ring number zero. ### **Call Relative** B0jkQ Call to P displaced by 8\*Q, binding section pointer per Aj, arguments per Ak CALLREL Aj, Ak, Q | 0 7 | 8 11 | 12 15 | 16 31 | |-----|------|-------|-------| | ВО | j | k | Q | Register assignments are as follows: (A0) Dynamic space pointer (DSP). (A1) Current stack frame (CSF) pointer. (A2) Previous save area (PSA) pointer. (A4) Argument pointer. In exchange package Top of stack (TOS) pointer per RN in P. This instruction saves the current procedure (caller) environment and calls another procedure (callee) within the same segment as the caller. The RN and SEG fields of P remain unaltered. The caller's environment is saved by storing designated process and processor registers into a stack frame save area (SFSA) generated on top of the current stack frame. The DSP in AO, rounded to the next available full word address, is the PVA of the first word in this SFSA. The instruction saves some CP registers in the SFSA unconditionally. These registers are as follows: - P register. - Stack frame descriptor. - User mask. - Virtual machine identifier. - Register A0. The caller specifies other registers saved. A0 is always the first register saved, and XOR specifies other A and X registers to be saved. XOR has the following format: | XO Bits | Registers Saved | |---------|-------------------| | 52-55 | First X register. | | 56-59 | Last A register. | | 60-63 | Last X register. | The call instruction does not store any X register if the value of X-last exceeds X-first. After storing the registers in the SFSA, the instruction executes as follows: - 1. Modify dynamic space pointer (DSP) in AO by adding 8 times the number of SFSA words to the BN in AO. - 2. Update the top of stack (TOS) pointer in the exchange package by storing the modified DSP into the exchange package TOS entry corresponding to the current ring of execution, as determined by the RN in P. This creates a new stack frame. - Form the target address by adding 8 times Q to the BN in P. Bits 61 through 63 of P are forced to zero. - 4. Establish the stack frame of the callee by loading AO, Al, and A2 from the PSA (SFSA of the callee). - 5. Copy Aj to A3 and Ak to A4 to reflect parameter changes required to transfer control to the callee. This instruction may cause the following exception conditions. - Instruction specification. - Address specification error. - Invalid segment/ring number zero. - Access violation. - Page table search without find. - Debug. #### **Compare Swap** B4jkQ Compare Xk to (Aj), if locked, branch to P displaced by 2\*Q, if unlocked, load/store (Aj), result to X1R CMPXA Xk,Aj,X0,Q | 0 7 | 8 11 | 12 15 | 16 31 | |-----|------|-------|-------| | B4 | j | k | Q | If the leftmost 32 bits of a 64-bit word in CM location Aj are all ones (Aj locked), the instruction takes a branch exit. The target address forms by adding the value 2 times Q (sign-extended) to the BN field of the PVA in P. If the above condition is absent, the instruction compares the Xk 64-bit word with the word in CM location Aj (64-bit integer compare). If the two words are equal, the instruction stores XO in location Aj and clears XIR. If the two words are unequal, the instruction loads the word in CM location Aj into Xk and sets XIR as follows (in either case, the instruction takes a normal exit): | Results of<br>Compare | Action Taken | |-----------------------|--------------------------------------------------------------------------| | Xk = (Aj) | Store XO at (Aj), clear X1R. | | Xk > (Aj) | Load (Aj) into Xk, clear X1R bits 32 and 34 through 63, set X1R bit 33. | | Xk < (Aj) | Load (Aj) into Xk, clear X1R bits 34 through 63, set X1R bits 32 and 33. | Within a given CP, execution of this instruction delays until all previous CM accesses complete. Execution of all subsequent instructions delays until all CM accesses due to this instruction complete. In dual CP systems, if a second CP executes a compare swap instruction while the other CP is processing one, the second CP reads the 64-bit word in location Aj, finds the leftmost 32 bits all ones (locked), and branch-exits. The hardware, however, does not inhibit other instruction codes issued from the other CP (or any PP instructions) from accessing and altering location Aj. The read access bypasses cache, and the write access purges the associated cache entry. For the debug scan, $\Delta j$ is both a read and a write address, whereas P+2Q is a branch target address only when the branch occurs. This instruction may cause the following exception conditions: - Instruction specification. - Address specification error. - Invalid segment/ring number zero. - Access violation. - Page table search without find. - Debug. #### **Call Indirect** B5jkQ Call per (Aj Displaced by 8\*Q), arguments per Ak CALLSEG Aj, Ak, Q | 0 | 78 1 | 1 12 15 | 16 31 | |------------|------|---------|-------| | <b>B</b> 5 | j | k | Q | The instruction uses the following assigned registers: | Register | Description | |---------------------|----------------------------------------------------------------| | (A0) | Dynamic space pointer (DSP). | | (A1) | Current stack frame pointer. | | (A2) | Previous save area pointer. | | (A3) | Binding section pointer. | | (A4) | Argument pointer. | | In exchange package | Top of stack (TOS) pointer for the caller's ring of execution. | | In exchange package | TOS pointer for the callee's ring of execution. | | In CM | Code base pointer (CBP) addressed by A3+8*Q. | This instruction saves the current procedure (caller) environment and calls another procedure (callee) indirectly. The callee must be executing within the same or in a higher privileged ring as the caller. The indirect target address is listed in the CBP addressed by (Aj displaced by 8 times sign-extended Q). The instruction saves the environment (as specified by XOR) in the SFSA generated on top of the current stack frame. For details, refer to the call relative instruction described in this section. #### The instruction executes as follows: - 1. Add 8 times Q to the BN field from register Aj to form the PVA of a CBP from a binding section segment (which contains the target PVA). - 2. Round DSP upward as follows: Add 7 to AO, then force AO bits 61 through 63 to zero. - 3. Store environment in SFSA, per XOR. - 4. Copy P bits 0 through 31 to XOR (callers ID). - 5. Modify DSP in AO by adding 8 times the number of SFSA words to AO bits 32 through 63. - 6. Adjust TOS pointer in the exchange package by storing this modified DSP in the TOS entry for the current ring of execution, as determined by the RN field in P. - 7. Load P key with segment descriptor lock for callee. - If P ring number is less than callee segment descriptor R2 (inter-ring call), go to step 12. - 9. Set P ring number equal to callee segment descriptor R2. - 10. Load P SEG and BN fields with code base pointer SEG and BN fields. - 11. If CBP VMID = 1 (call is to CYBER 170 State), go to step 17. - 12. If internal procedure (code base pointer EPF = 0), go to step 16. - 13. Load A3 with new binding section pointer, setting RN equal to the larger of the RN in CBP and the new RN in P register. - 14. If trap operation, go to step 17; if call instruction, copy Ak to A4 (pass parameters). When k is 0 through 3, the final contents of A4 is with respect to which A register is copied. - 15. Copy (A0) to A2 (DSP from step 2 to PSA pointer). - 16. Clear on-condition flag. - 17. Load Al with top of stack pointer from exchange package per final P ring number, and clear the critical frame flag. - 18. Set dynamic space pointer in AO equal to current stack frame pointer in Al. - 19. Copy VMID from CBP to the VMID register. # NOTE The trap interrupt operation unconditionally includes all the above steps except items 10, 11, and 14. ## This instruction may cause the following exception conditions: - Instruction specification. - Address specification error. - Invalid segment/ring number zero. - Access violation. - Environment specification error. - Page table search without find. - Outward call/inward return. - Debug. # **Reserved Operation Codes** BEjkQ Reserved for user BFjkQ Reserved for user | 0 7 | 8 11 | 12 15 | 16 | 31 | |-------|------|-------|----|----| | BE,BF | j | k | Q | | These two instructions are reserved for the user for software simulation of operations that executive state does not provide through trap interrupts. These operation codes will not be used in future hardware extensions. When not implemented, these instructions cause the unimplemented instruction exception, with interrupt or halt. # **Execute Algorithm** CSjkiD Execute Algorithm per S EXECUTE,s j,k,i,D This instruction is reserved for future expansion. When not implemented, this instruction causes the unimplemented instruction exception, with interrupt or halt. ### LOCAL PRIVILEGED SYSTEM INSTRUCTIONS Instructions in this subgroup (table II-1-20) can execute only from segments which (by the associated segment descriptor) have either local or global privilege. If a local privileged instruction is fetched from a segment without either local or global privilege, the CP detects a privileged instruction fault, inhibits execution, and initiates the corresponding program interrupt or halt. Table II-1-20. Local Privileged Instructions | 0pcode | Format | Instruction | Mnemonic | |--------|--------|-----------------------|----------| | 17 | jk | Load page table index | LPAGE | ### Load Page Table Index 17jk Load Page Table Index per Xj to XkR and set XlR LPAGE Xk, Xj, Xi | 0 | 78 | 11 | 12 15 | |----|----|----|-------| | 17 | | j | k | This instruction searches the page table in CM for the presence of a page, returns the final search index value to XkR, and sets XlR to indicate the search results. The SVA in Xj defines the required page table entry. The SVA determines the starting point in the page table search. The search continues until the corresponding page descriptor is found, a continue bit equal to zero is detected, or 32 entries have been searched. The validity bit is ignored. When the page is found, the page table index associated with that entry transfers to XkR, the number of entries searched transfers to XlR bits 33 through 63 (right-justified with zeros extended), and XlR bit 32 sets to indicate the find. When a page corresponding to the SVA in Xj is not found, the page table index value of the last entry tested transfers to XkR, the number of entries searched transfers to XlR bits 33 through 63 (right-justified with zeros extended), and XlR bit 32 clears. If the instruction's k field equals 1, register X1R loads with the result-indication bit and the number of entries searched instead of the index value. This instruction can cause the following exception conditions: - Privileged instruction fault. - Address specification error. ### **GLOBAL PRIVILEGED SYSTEM INSTRUCTION** The processor interrupt instruction can execute only from segments which (by the associated segment descriptor) have global privilege. If this instruction is fetched from a segment without global privilege, the CP detects a privileged instruction fault, inhibits execution, and initiates the corresponding program interrupt or halt. # Processor Interrupt 03jk Processor Interrupt per Xk INTRUPT Xk,j This instruction sends an external interrupt to one or more CPs (including the executing CP) through their CM ports. The interrupting CP sends Xk to CM. CM then sends an external interrupt to the processor(s) connected to the ports whose numbers correspond to the bits set in Xk as follows: | Xk Bit | Port Number | |--------|-------------| | 60 | 3 | | 61 | 2 | | 62 | 1 | | 63 | 0 | Bits 0 through 59 are not used to send interrupts and are ignored by the CM, but have correct parity. When two ports of the same memory connect to the interrupting CP, the state of Xk bit 33 selects the port the CP uses to send Xk to CM along with the interrupt. (Xk bit 33 thus overrides RMA bit 33 for memory port selection). | State of<br>Bit 33 | Memory<br>Port Used | |--------------------|---------------------| | Clear | 0 | | Set | 1 | The system delays this instruction's execution until all previous CM accesses by the interrupting CP complete. If a CP sends an interrupt to itself, this instruction completes executing before the interrupt is taken. This instruction can cause the privileged instruction fault exception condition. ### MONITOR MODE INSTRUCTIONS Instructions in this subgroup can execute only with the processor in executive monitor mode. Otherwise, the CP detects an instruction specification error, inhibits instruction execution, and initiates the corresponding program interrupt. Refer to Mixed Mode Instructions in the following description. ### MIXED MODE INSTRUCTIONS The execution of instructions in this subgroup (table II-1-21) depends on an instruction parameter. The parameter value determines whether the instruction is executable from nonprivileged, local-privileged, or global-privileged segments, or whether the CP must be in Virtual State monitor mode. Table II-1-21. Mixed Mode Instructions | 0pcode | Format | Instruction | Mnemonic | |------------|--------|------------------------------|----------| | 05 | jk | Purge buffer | PURGE | | 0E | jk | Copy from state register | CPYSX | | OF | jk | Copy to state register | CPYXS | | 9 <b>F</b> | jk | Branch on condition register | BRCR | # **Purge Buffer** 05jk Purge buffer k of entry per Xj PURGE Xj,k | 0 | 78 | 11 | 12 | 15 | |----|----|----|----|----| | 05 | | į | k | | This instruction invalidates entries in the cache (models 835, 845, 855, and 990), map, or instruction buffer, selectable as follows: - All entries in cache (models 835, 845, 855, and 990), map or instruction buffer. - All entries for a given segment in cache (models 835, 845, 855, and 990) or map. - All entries for a given page in cache (models 835, 845, 855, and 990) or map. - All entries for a given 512-byte block in cache (models 835, 845, 855, and 990). Xj contains the required address information as either the system virtual address (SVA) or the process virtual address (PVA). The k value determines the buffer to be purged, the range of entries to be purged, and the addressing type used, as follows: | Value of k | Description | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------| | k = 0 | Purge all cache entries in a 512-byte block defined by SVA in Xj. | | k = 1 | Purge all cache entries in ASID defined by SVA in Xj. | | k = 2 | Purge all cache entries. | | k = 3 | Purge all cache entries in 512-byte block defined by PVA in Xj. | | k = 4 through 7 | Purge all cache entries in SEG defined by PVA in Xj. | | k = 8 | Purge all map entries in page associated with page table entry defined by SVA in Xj. (Page size is determined from page size mask register.) | | k = 9 | Purge all map entries pertaining to page table entries included in segment defined by SVA in Xj. | | k = A | Purge all map entries pertaining to page table entry defined by PVA in Xj. Page size mask register specifies number of bytes in page. | | k = B | Purge all map entries pertaining to segment table entry defined by PVA in Xj, and to all page table entries included within that segment. | | k = C through F | Purge all map entries, ignore Xj. | If k = 0, 1, 2, or 8 through F, this instruction is a local privileged instruction. It is a nonprivileged instruction for all other k values. The system performs a serialization function before this instruction begins execution, and again when execution completes. The system delays instruction execution until all previous accesses to CM by this processor complete, and delays the fetch or execution of subsequent instructions until all CM accesses for this instruction complete. This instruction may cause the following exception conditions: - Privileged instruction fault. - Address specification error (k = 0, 1, 8, or 9). - Invalid segments. # Copy to/from State Buffer These instructions copy certain state registers to and from X registers. If a copy instruction reads a nonexistent register or any register restricted to MCU access only, the system clears all 64 bits of Xk. A copy instruction used to write a nonexistent register, or any register restricted to read only or MCU access only, results in a no-operation. 0Ejk Copy to Xk from State Register per Xj CPYSX Xk,Xj This instruction copies the state register addressed by Xj into Xk. 0Fjk Copy to state register from Xk per Xj CPYXS Xk,Xj This instruction copies Xk into the state register addressed by Xj. Refer to tables I-2-1 and I-2-2 in volume 1. These instructions can cause the following exception conditions: - Instruction specification error. - Privileged instruction fault (CPYXS only). # **Branch on Condition Register** 9FjkQ Branch to P Displaced by 2\*Q and Alter Condition Register per jk BRCR j,k,Q | 0 7 | 8 11 | 12 15 | 16 | 31 | |-----|------|-------|----|----| | 9F | j | k | Q | | This instruction tests the state of a bit in the monitor or user condition register (MCR or UCR), as selected by the instruction j and k fields. The j field selects the bit within the register, and the k field selects the register, branch condition, and bit alteration. When the branch condition is satisfied, the target address forms by adding 2 times Q (sign-extended) to the BN in P. The instruction depends on k as follows: | Value of k | Description | |--------------|-----------------------------------------------| | k = 0 or 8 | If bit j of MCR is set, clear bit and branch. | | k = 1 or 9 | If bit j of MCR is clear, set bit and branch. | | k = 2 or A | If bit j of MCR is set, branch. | | k = 3 or B | If bit j of MCR is clear, branch. | | k = 4 or C | If bit j of UCR is set, clear bit and branch. | | k = 5 or D | If bit j of UCR is clear, set bit and branch. | Value of k Description k = 6 or E If bit j of UCR is set, branch. k = 7 or F If bit j of UCR is clear, branch. When the k field is 0, 8, 1, or 9, this instruction executes in Virtual State monitor mode only. If the processor is not in monitor mode with execution restricted to that mode, the CP detects an instruction specification error, inhibits instruction execution, and initiates the corresponding program interrupt or halt. This instruction can cause the following exception conditions: - Instruction specification error. - Debug. # PERIPHERAL PROCESSOR INSTRUCTION DESCRIPTIONS The peripheral processor (PP) instruction set comprises the following eight subgroups: - Load and store. - Arithmetic. - Logical. - Replace. - Branch. - Central memory (CM) access. - Input/Output (I/O). - Other IOU. The Virtual State PP instruction set includes the CYBER 170 State PP instructions as a subset. The instruction set uses a 7-bit operation code (opcode) which includes the CYBER 170 State 6-bit operation code. Extensions to the instruction set allow programs to manipulate 16-bit IOU words, 64-bit CM words (as both 12- and 16-bit bytes), and to reference 28-bit CM addresses. ## **PP INSTRUCTION FORMATS** Figure II-1-4 shows and describes Virtual State PP instruction formats. PP instructions are 16 or 32 bits long. In instruction descriptions, the opcode is represented by four or five octal digits. The fifth digit, when used, indicates the state of bit 58/42 (zero or one) in 1/0 instructions. #### PP DATA FORMAT Figure II-1-5 shows PP data formats, the packing of PP data into CM words, and the unpacking of CM words into PP words. # PP RELOCATION REGISTER FORMAT Figure II-1-5 shows the PP relocation register format. This register is loaded/stored by instructions 24 and 25 (load/store R register). | 57 | 58 | 63 | |----|----|-------| | | | d. | | | 57 | 57 58 | | 32 | 41 42 | 47 48 | 515 | 2 63 | |--------|-------|-------|-----|------| | OPCODE | | 9 00 | 00 | m | | 48 | <b>57</b> 5 | 8 59 | 63 | |--------|-------------|------|----| | OPCODE | s | С | | | 32 | 41 42 | 43 47 | 48 51 | 52 | 6 | 3 | |--------|-------|-------|-------|----|---|---| | OPCODE | s | С | 0000 | | m | | | Term | Description | |--------|------------------------------------------------------------------------------------------------------------------| | OPCODE | Instruction operation code; bits 49 through 51 or 33 through 35 of which are zeros. | | d | Operand, direct/indirect address, shift count. | | m m | Operand, direct address or I/O function code. | | dm | Operand. | | s | I/O instruction subcode. | | c | I/O instruction channel number. | | A | Eighteen-bit arithmetic register. | | P | Twelve-bit program address counter. | | R | Twenty-eight-bit relocation register for central memory addressing (bits 58 through 63 of R are appended zeros). | | () | Quantity in brackets is a direct address (used when required for clarity). | | (( )) | Quantity in brackets is an indirect address (used when required for clarity). | Figure II-1-4. PP Instruction Formats and Nomenclature Figure II-1-5. PP Data Format Figure II-1-6. PP Relocation Register Format ## PP LOAD AND STORE INSTRUCTIONS Load and store instructions (table II-1-22) transfer 6-, 12-, 16-, and 18-bit quantities between the PP A register and the PP memory. Table II-1-22. PP Load and Store Instructions | 0pcode | Instruction | |--------|--------------------| | 0014 | Load d | | 0015 | Load complement d | | 0020 | Load dm | | 0030 | Load (d) | | 1030 | Load (d) long | | 0034 | Store (d) | | 1034 | Store (d) long | | 0040 | Load ((d)) | | 1040 | Load ((d)) long | | 0044 | Store ((d)) | | 1044 | Store ((d)) long | | 0050 | Load (m+(d)) | | 1050 | Load (m+(d)) long | | 0054 | Store (m+(d)) | | 1054 | Store (m+(d)) long | 0 0014d Load d LDN d This instruction clears the A register and loads the rightmost 6 bits of A with a copy of the 6-bit positive integer in the d field. The leftmost 12 bits of A are zeros. 0015d Load Complement d LCN d This instruction clears the A register and loads the rightmost 6 bits of A with a one's complement copy of the d field. The leftmost 12 bits of A are ones. 0020dm Load dm LDC dm This instruction clears the A register and loads A with an 18-bit operand consisting of d as the leftmost 6 bits and m as the rightmost 12 bits. 00304 Load (d) LDD d This instruction clears the A register and loads A with the rightmost 12 bits of the positive integer from PP memory location d. The leftmost 6 bits of A are zeros. Load (d) long LDDL d | 48 | : | 57 58 | 63 | |----|------|-------|----| | | 1030 | | d | This instruction clears the A register and loads A with the 16-bit positive integer from PP memory location d. The leftmost 2 bits of A are zeros. 0034d Store (d) STD d | 48 | 57 | 58 | <u>63</u> | |------|----|----|-----------| | 0034 | | | d | This instruction stores the quantity contained in the A register rightmost 12 bits in location d, and clears the leftmost 4 bits of location d. The operation does not alter the contents of A. 1034d Store (d) Long STDL d | 57 58 | 63 | |-------|----| | 34 | d | | | | This instruction stores the A register rightmost 16 bits in location $d_{\bullet}$ . The operation does not alter the contents of $A_{\bullet}$ 0040d Load ((d)) LDI d This instruction clears the A register and loads A with the rightmost 12 bits of an operand obtained by indirect addressing. The leftmost 6 bits of A are zeros. To perform indirect addressing, the IOU reads a word from PP memory location d and uses it as the operand address. Load ((d)) Long LDIL d | 48 | | 57 | 58 | 63 | |----|------|----|----|----| | | 1040 | | | d | This instruction clears the A register and loads A with a 16-bit operand obtained by indirect addressing. Refer to instruction 0040. The leftmost 2 bits of A are zeros. 0044d Store ((d)) STI d | 48 | 57 | 58 | 63 | |------|----|----|----| | 0044 | | | d | This instruction stores the A register rightmost 12 bits in the location specified by the location d contents. The leftmost 4 bits of ((d)) are zeros and the A register contents are unaltered. 1044d Store ((d)) Long STI d | 48 | 57 5 | 63 | |------|------|----| | 1044 | | d | This instruction stores the A register rightmost 16 bits at a location obtained by indirect addressing. Refer to instruction 0044. 0050dm Load (m+(d)) LDM m,d This instruction clears the A register and loads A with the rightmost 12 bits of an operand read from PP memory using indexed direct addressing. The leftmost 6 bits of A are zeros. To accomplish indexed direct addressing, the IOU adds an index value to a base address to form the operand address. The m field contains the base address and the d field specifies the PP memory location containing the index value. If d equals 0, the m field base address is the operand address. Load (m+(d)) Long LDML m,d This instruction clears the A register and loads A with a 16-bit operand read from PP memory using indexed direct addressing. Refer to instruction 0050. The leftmost 2 bits of A are zeros. 0054dm Store (m+(d)) STM m,d This instruction stores the A register rightmost 12 bits in the location determined by indexed direct addressing. Refer to instruction 0050. Bits 48 through 51 of (m+(d)) clear. 1054dm Store (m+(d)) Long STML m,d This instruction stores the A register rightmost 16 bits in the location determined by indexed direct addressing. Refer to instruction 0050. #### PP ARITHMETIC INSTRUCTIONS The PP arithmetic instructions (table II-1-23) perform integer arithmetic using the PP A register contents as one operand, with the other operand specified by the instruction. The result replaces the original contents of A. The IOU considers the operands as one's complement integers and performs the arithmetic in one's complement. Table II-1-23. PP Arithmetic Instructions | 0pcode | Instruction | |--------|-----------------------| | 0016 | Add d | | 0017 | Subtract d | | 0021 | Add dm | | 0031 | Add (d) | | 1031 | Add (d) long | | 0032 | Subtract (d) | | 1032 | Subtract (d) long | | 0041 | Add ((d)) | | 1041 | Add ((d)) long | | 0042 | Subtract ((d)) | | 1042 | Subtract ((d)) long | | 0051 | Add (m+(d)) | | 1051 | Add (m+(d)) long | | 0052 | Subtract (m+(d)) | | 1052 | Subtract (m+(d)) long | Add d ADN d | 48 | 57 58 | 63 | |------|-------|----| | 0016 | d | | This instruction adds d (treated as a 6-bit positive quantity) to the A register contents. 0017d Subtract d SBN d | 48 | | 57 | 58 | 63 | |----|------|----|----|----| | | 0017 | | d | | This instruction subtracts d (treated as a 6-bit positive quantity) from the A register contents. Add dm ADC dm This instruction adds an 18-bit value comprised of the 6-bit d field and the m field rightmost 12 bits to the A register operand. The d field becomes the rightmost 6 bits and m becomes the rightmost 12 bits of the value. 0031d Add (d) ADD d This instruction adds the rightmost 12 bits of the operand in location d to the A register contents. 1031d Add (d) Long ADDL d | 48 | | 57 | 58 | 63 | |----|------|----|----|----| | | 1031 | | d | | This instruction adds the 16-bit operand in location d to the A register contents. 0032d Subtract (d) SBD d This instruction subtracts the 12-bit operand in location d from the A register contents. Subtract (d) Long SBDL d This instruction subtracts the 16-bit operand in location d from the A register contents. 0041d Add ((d)) ADI d | <u>63</u> | 58 E | 57 | 48 | |-----------|------|----|------| | | d | | 0041 | | | d | | 0041 | This instruction reads a 12-bit operand from PP memory (PPM) using indirect addressing, and adds the rightmost 12 bits to the A register contents. To perform indirect addressing, the PP reads a word from PPM location d and uses it as the operand address. 1041d Add ((d)) Long AIDL d | 48 | | 57 58 | 3 | 63 | |----|-----|-------|---|----| | 1 | 041 | | d | | This instruction reads a 16-bit operand from PP memory (PPM) using indirect addressing, and adds the operand to the A register contents. To perform indirect addressing, the PP reads a word from PPM location d and uses it as the operand address. 0042d Subtract ((d)) SBIL d This instruction reads a 12-bit operand from PP memory (PPM) using indirect addressing, and subtracts the operand from the A register contents. To perform indirect addressing, the PP reads a word from PPM location d and uses it as the operand address. Subtract ((d)) Long SBIL d This instruction reads a 16-bit operand from PP memory (PPM) using indirect addressing, and subtracts the operand from the A register contents. To perform indirect addressing, the PP reads a word from PPM location d and uses it as the operand address. 0051dm Add (m+(d)) ADM m,d This instruction reads an operand from PP memory (PPM) using indexed direct addressing, and adds the rightmost 12 bits to the A register contents. To accomplish indexed direct addressing, the PP adds an index value to a base address to form the operand address. The m field contains the base address and the d field specifies the PPM location containing the index value. If d equals 0, the m field base address is the operand address. 1051dm Add (m+(d)) Long ADML m,d This instruction reads a 16-bit operand from PP memory (PPM) using indexed direct addressing and adds the operand to the A register contents. To accomplish indexed direct addressing, the PP adds an index value to a base address to form the operand address. The m field contains the base address and the d field specifies the PPM location containing the index value. If d equals 0, the m field base address is the operand address. Subtract (m+(d)) SBM m,d This instruction reads an operand from PP memory (PPM) using indexed direct addressing and subtracts the rightmost 12 bits of the operand from the A register contents. To accomplish indexed direct addressing, the PP adds an index value to a base address to form the operand address. The m field contains the base address and the d field specifies the PPM location containing the index value. If d equals 0, the m field base address is the operand address. 1052dm Subtract (m+(d)) Long SBML m,d This instruction reads a 16-bit operand from PP memory (PPM) using indexed direct addressing, and subtracts this operand from the A register contents. To accomplish indexed direct addressing, the PP adds an index value to a base address to form the operand address. The m field contains the base address and the d field specifies the PPM location containing the index value. If d equals 0, the m field base address is the operand address. ## **PP LOGICAL INSTRUCTIONS** The logical instructions (table II-l-24) perform operations with one operand as the PP A register contents, and the other as specified by the instruction. The result replaces the original contents of $A_{\bullet}$ Table II-1-24. PP Logical Instructions | 0pcode | Instruction | |--------|---------------------------------| | 0010 | Shift d | | 0011 | Logical difference d | | 0012 | Logical product d | | 0013 | Selective clear d | | 0022 | Logical product dm | | 1022 | Logical product (d) long | | 0023 | Logical difference dm | | 1023 | Logical product ((d)) long | | 1024 | Logical product (m+(d)) long | | 0033 | Logical difference (d) | | 1033 | Logical difference (d) long | | 0043 | Logical difference ((d)) | | 1043 | Logical difference ((d)) long | | 0053 | Logical difference (m+(d)) | | 1053 | Logical difference (m+(d)) long | Shift A by d SHN d | | 57 | 58 | 63 | |------|------|----|-----------------| | 0010 | | d | ı | | | 0010 | | 57 58<br>0010 d | This instruction shifts the A register operand in the direction and by the number of places specified by the d field value. If d is in the range 00 through 37 (a positive value), the shift is left-circular, d positions. A circular shift means that a bit shifted out of the highest-order position moves into the lowest-order position. If d is in the range 40 through 77 (a negative value), the shift is to the right, end-off. Thus, d equal to 06 causes a left shift of 6 places; d equal to 71 causes a right shift of 6 places. 0011d Logical Difference d LMN d | 48 | 57 58 | 63 | |------|-------|----| | 0011 | | d | This instruction forms the logical difference between the d field contents and the rightmost 6 bits of the A register operand. The operation does not alter the most significant 12 bits of A. The logical difference (exclusive OR) results from a bit-for-bit logical comparison of the two binary quantities, as illustrated by the following example: Operand 1 0011 Operand 2 0101 Result 0110 This comparison is equivalent to complementing the first operand bits corresponding to the second operand bits that are ones. 0012d Logical Product A and d LPN d This instruction forms the logical product of the d field contents and the rightmost 6 bits of the A register operand. The leftmost 12 bits of A are zeros. The logical product results from a bit-for-bit logical comparison of the two binary quantities, as illustrated by the following example: Operand 1 0011 Operand 2 0101 Result 0001 The individual result bits are ones if the corresponding bits in the first and second operand are ones. 0013d Selective Clear d SCN d | 48 | 57 58 | 63 | |------|-------|----| | 0013 | | d | This instruction clears each of the rightmost 6 bits of the A register operand if the corresponding d field bit is a 1. The operation does not alter the leftmost 12 bits of A. 0022dm Logic Product dm LPC dm This instruction forms the bit-for-bit logical product of the A register operand and an 18-bit operand consisting of d as the leftmost 6 bits and m as the rightmost 12 bits. Refer to instruction 0012 for an example of the logical product operation. 1022d Logical Product (d) Long LPDL d This instruction forms the bit-for-bit logical product of the A register operand and the 16-bit quantity from location d. The result replaces the original contents of A; bits 46 and 47 of A clear. Refer to instruction 0012 for an example of the logical product operation. 0023dm Logical difference dm LMC dm This instruction replaces the A register contents with the bit-for-bit logical difference between the A register operand and the 18-bit quantity dm. Refer to instruction 0011 for an example of the logical difference operation. Logical Product ((d)) Long LPIL d This instruction forms the logical product of a 16-bit operand read from storage (using indirect addressing) and the original contents of A. Bits 46 and 47 of A clear. The d field contents specify the PP memory location containing the operand address. 1024dm Logical Product (m+(d)) Long LPMLm d This instruction replaces the A register contents with the logical product of the A register rightmost 16 bits and a 16-bit operand read by indexed direct addressing. Bits 46 and 47 of A clear. Indexed direct addressing uses the m field contents as a base address. The d field specifies a PP memory location containing the index value which adds to the base address to form the operand address. 00334 Logical Difference (d) LMD d This instruction replaces the A register contents with the logical difference between the A register rightmost 12 bits and the rightmost 12 bits of the operand in the location specified by the d field. The operation does not alter the leftmost 6 bits of A. 1033d Logical Difference (d) Long LMDL d This instruction replaces the A register contents with the logical difference between the A register rightmost 16 bits and the operand in the location specified by the d field. The operation does not alter the most significant 2 bits of A. Logical Difference ((d)) LMI d This instruction replaces the A register contents with the logical difference between the A register rightmost 12 bits and the rightmost 12 bits of an operand read by indirect addressing. The operation does not alter the leftmost 6 bits of A. Refer to instruction 0011 for an example of the logical difference operation. The d field contents specify the PP memory location containing the operand address. 1043d Logical Difference ((d)) Long LMIL d This instruction replaces the A register contents with the logical difference between the A register rightmost 16 bits and an operand read by indirect addressing. The operation does not alter the leftmost 2 bits of A. Refer to instruction 0011 for an example of the logical difference operation. The d field contents specify the PP memory location containing the operand address. 0053dm Logical Difference (m+(d)) LMM m,d This instruction replaces the A register contents with the logical difference between the A register rightmost 12 bits and the rightmost 12 bits of an operand read by indexed direct addressing. The operation does not alter the most significant 6 bits of A. Refer to instruction 0011 for an example of the logical difference operation. Indexed direct addressing uses the m field contents as a base address. The d field specifies the PP memory location containing the index value which the PP adds to the base address to form the operand address. 1053dm Logical Difference (m+(d)) Long LMML m,d This instruction replaces the A register contents with the logical difference between the A register rightmost 16 bits and an operand read by indexed direct addressing. The operation does not alter the leftmost 2 bits of A. Refer to instruction 0011 for an example of the logical difference operation. Refer to instruction 0053 for a description of indexed direct addressing. #### PP REPLACE INSTRUCTIONS The replace instructions (table II-1-25) perform integer arithmetic with one operand as the contents of A and the other as specified by the instruction. The result replaces the original contents of A and the contents of the other operand's location. The result stored in location d is either the rightmost 12 bits (for the normal instructions) or the rightmost 16 bits (for the long instructions) of the A register. Therefore, since A contains 18 bits, the value remaining in A cannot equal the value stored in PP memory location d. The PP considers the operands as one's complement integers and performs one's complement arithmetic. Table II-1-25. PP Replace Instructions | Opcode | Instruction | |--------|-----------------------------------| | 0035 | Replace add (d) | | 1035 | Replace add (d) long | | 0036 | Replace add one (d) | | 1036 | Replace add one (d) long | | 0037 | Replace subtract one (d) | | 1037 | Replace subtract one (d) long | | 0045 | Replace add ((d)) | | 1045 | Replace add ((d)) long | | 0046 | Replace add one ((d)) | | 1046 | Replace add one ((d)) long | | 0047 | Replace subtract one ((d)) | | 1047 | Replace subtract one ((d)) long | | 0055 | Replace add (m+(d)) | | 1055 | Replace add (m+(d)) long | | 0056 | Replace add one (m+(d)) | | 1056 | Replace add one (m+(d)) long | | 0057 | Replace subtract one (m+(d)) | | 1057 | Replace subtract one (m+(d)) long | 00354 Replace Add (d) RAD d | 48 | | 57 58 | 63 | |----|------|-------|----| | | 1035 | | d | This instruction adds the rightmost 12 bits of the location d contents to the A register, and stores the rightmost 12 bits of A, zero-extended, at location d. The result also remains in A at the end of the operation, with the original contents purged. 1035d Replace Add (d) Long RADL d | 48 | | 57 | 58 | 63 | |----|------|----|----|----| | | 1035 | | d | | This instruction replaces the operand in the PP memory (PPM) location d with the sum of the PPM location d operand plus the A register rightmost 16 bits. Refer to instruction 0035. 0036d Replace Add One (d) AOD d | 48 | 57 | 58 | <u>63</u> | |------|----|----|-----------| | 0036 | 3 | | d | This instruction clears the A register, loads A with the location d rightmost 12 bits, and adds one to A. The instruction then stores the rightmost 12 bits of A, zero-extended, at location d. The result remains in the A register at the end of the operation, with the original contents purged. 1036d Replace Add One (d) Long AODL d | 48 | <u>57 58</u> | 63 | |------|--------------|----| | 1036 | | d | | 1000 | | | This instruction replaces the operand in PP memory (PPM) location d with the sum of the original operand value plus 1. Refer to instruction 0036. 0037d Replace Subtract One (d) SOD d This instruction replaces the rightmost 12 bits of the operand in PP memory (PPM) location d with the original operand value minus 1. Refer to instruction 0036. Replace Subtract One (d) Long SODL d This instruction replaces the operand in PP memory (PPM) location d with the difference of the original operand value minus 1. Refer to instruction 0036. 0045d Replace Add ((d)) RAI d | 48 | 57 | 58 | 63 | |------|----|----|----| | 0045 | • | | | This instruction replaces the rightmost 12 bits of the operand at the address specified by the PP memory (PPM) location d contents with the sum of the original operand value plus the A register rightmost 12 bits. Refer to instruction 0035. 1045d Replace Add ((d)) Long RAIL d | 48 | 57 | 58 | 63 | |------|----|----|----| | 1045 | | d | | This instruction replaces the 16-bit operand at the address specified by the PP memory (PPM) location d contents with the sum of the original operand value plus the A register contents. Refer to instruction 0035. 00464 Replace Add One ((d)) AOI d | <u>48</u> | | 57 58 <b>6</b> 3 | | | |-----------|------|------------------|---|--| | | 0046 | | d | | This instruction replaces the rightmost 12 bits of the operand at the address specified by the PP memory (PPM) location d contents with the sum of the original operand value plus 1. Refer to instruction 0036. 1046d Replace Add One ((d)) Long AOIL d This instruction replaces the operand at the address specified by the PP memory (PPM) location d contents with the sum of the original operand value plus l. Refer to instruction 0036. Replace Subtract One ((d)) SOI d | 48 | _ | 57 | 58 | 63 | |----|------|----|----|----| | | 0047 | | | d | This instruction replaces the rightmost 12 bits of the operand at the address specified by the PP memory (PPM) location d contents with the original operand value minus $1 \cdot$ Refer to instruction 0036. 1047d Replace Subtract One ((d)) SOIL d | 48 | 57 58 | 63 | |-----|-------|----| | 104 | 7 d | 1 | This instruction replaces the operand at the address specified by the PP memory (PPM) location d contents with the original operand value minus 1. Refer to instruction 0036. 0055dm Replace Add (m+(d)) RAM m,d This instruction reads the rightmost 12 bits of an operand from PP memory (PPM) using indexed direct addressing, and adds the operand to the the A register contents. The sum's rightmost 12 bits replace the original PPM operand. The result remains in A at the end of the operation, with the original contents of A purged. Indexed direct addressing uses the m field contents as a base address. The d field specifies the PPM location containing the index value which the PP adds to the base address to form the operand address. 1055dm Replace Add (m+(d)) Long RAML m,d This instruction reads a 16-bit operand from PP memory (PPM) using indexed direct addressing, adds the operand to the A register contents, and replaces the original PPM operand with the sum's rightmost 16 bits. The result remains in A at the end of the operation. Refer to instruction 0055. Replace Add One (m+(d)) AOM m,d This instruction adds one to the rightmost 12 bits of a PP memory (PPM) operand read using indexed direct addressing, and replaces the original PPM operand with the sum's rightmost 12 bits. Refer to instruction 0055. 1056dm Replace Add One (m+(d)) Long AOML m,d This instruction adds one to a 16-bit PP memory (PPM) operand read using indexed direct addressing, and replaces the original PPM operand with the sum's rightmost 16 bits. Refer to instruction 0055. 0057dm Replace Subtract One (m+(d)) SOM m,d This instruction subtracts one from the rightmost 12 bits of a PP memory (PPM) operand read using indexed direct addressing, and replaces the original PPM operand with the rightmost 12 bits of the difference. Refer to instructions 0036, 0055. 1057dm Replace Subtract One (m+(d)) Long SOML m, d This instruction subtracts one from a 16-bit PP memory (PPM) operand read using indexed direct addressing, and replaces the original PPM operand with the rightmost 16 bits of the difference. Refer to instructions 0036, 0055. ## PP BRANCH INSTRUCTIONS The branch instructions (table II-1-26) allow departure from sequential instruction execution. Table II-1-26. PP Branch Instructions | Opcode | Instruction | |--------|----------------------| | 0001 | Long jump to m+(d) | | 0002 | Return jump to m+(d) | | 0003 | Unconditional jump d | | 0004 | Zero jump d | | 0005 | Nonzero jump d | | 0006 | Plus jump d | | 0007 | Minus jump d | 0001dm Long Jump to m+(d) LJM m,d The long jump instruction branches to the address formed by adding the m field rightmost 12 bits to the location d rightmost 12 bits. The result is the first word's address in the new instruction sequence. If d equals zero, the m field contents is the jump address. Return Jump to m+(d) RJM m,d This instruction stores the current program address plus two (P+2) in the address formed from m+(d). (If the d field is zero, the m field contents is the address.) The instruction then branches to location m+(d)+1. This instruction interrupts the current program sequence and jumps to a subroutine while providing the means for a return to the original program. The entry point address to the subroutine forms from m+(d). The called subroutine must have a common exit point in the form of a long-jump-to-m instruction (operation code 0001) preceding the entry point (location m+(d)-1). The return jump instruction stores the current program address plus two (P+2) in the first word of the subroutine (location m+(d)). This word is the second half of the long jump instruction (its m field) and is the return address to the original program sequence. The instruction then branches to m+(d)+1. When the subroutine completes, the long jump instruction at location m+(d)-1 executes and performs a branch to the return address in the original program sequence. 0003d Unconditional Jump d UJN d | 48 | 57 58 | 63 | |-----|-------|----| | 000 | 3 0 | | This instruction causes an unconditional branch to any address up to 31 (decimal) locations forward or backward from the current program address. If d is positive (01 through 37 octal), the jump is forward. If d is negative (40 through 76 octal), the jump is backward. 0004d Zero Jump d ZJN d If the contents of A is zero, this instruction causes an unconditional branch to any address up to 31 (decimal) locations forward or backward from the current program address. The instruction adds the d value to the current program address. If d is positive (01 through 37 octal), the jump is forward. If d is negative (40 through 76 octal), the jump is backward. Nonzero Jump d NJN d | 48 | 57 58 | 63 | |------|-------|----| | 0005 | | t | If the contents of A is nonzero, this instruction causes an unconditional branch to any address up to 31 (decimal) locations forward or backward from the current program address. If d is positive (01 through 37 octal), the jump is forward. If d is negative (40 through 76 octal) the jump is backward. 0006d Plus Jump d PJN d | 48 | | 57 58 | 63 | |----|------|-------|----| | | 0006 | d | | If the contents of A is positive, this instruction causes an unconditional branch to any address up to 31 (decimal) locations forward or backward from the current program address. The instruction adds the d value to the current program address. If d is positive (01 through 37 octal), the jump is forward. If d is negative (40 through 76 octal), the jump is backward. 0007d Minus Jump d MJN d | 48 | | 57 58 | 3 63 | |----|------|-------|------| | | 0007 | | d | If the contents of A is negative, this instruction causes an unconditional branch to any address up to 31 (decimal) locations forward or backward from the current program address. The instruction adds the d value to the current program address. If d is positive (01 through 37 octal), the jump is forward. If d is negative (40 through 76 octal), the jump is backward. #### PP CENTRAL MEMORY ACCESS INSTRUCTIONS The CM access instructions (table II-1-27) provide the capability to read and write CM words to and from PP memory. The PPs have read access to all CM storage locations, while the OS bounds register controls write and exchange accesses. (Refer to IOU Maintenance Registers in section 2 of volume 1.) The IOU performs CM addressing with real memory word addresses. To address all locations in the larger CM sizes available, the IOU uses address relocation to modify the CM address in the A register of the PP. Refer to figure II-1-7. If bit 46 in A is a 1 during a PP central memory read or write instruction, the IOU adds the R register contents to A register bits 47 through 63 to produce the CM address. If bit 46 of A is 0, the IOU does not perform address relocation but uses the A address. The R register contains an absolute 64-word starting boundary within CM. When relocation is desired, an absolute CM address forms by concatenating six Os to the rightmost end of the R contents, and adding bits 47 through 63 of A. Table II-1-27. PP Central Memory Access Instructions | 0pcode | Instruction | |--------|--------------------------------------------| | 0024 | Load R register | | 0025 | Store R register | | 0060 | Central read from (A) to d | | 1060 | Central read from (A) to d long | | 0061 | Central read (d) words from (A) to m | | 1061 | Central read (d) words from (A) to m long | | 0062 | Central write to (A) from d | | 1062 | Central write to (A) from d long | | 0063 | Central write (d) words to (A) from m | | 1063 | Central write (d) words to (A) from m long | | 1000 | Central read and set lock from d to (A) | | 1001 | Central read and clear lock from d to (A) | Figure II-1-7. Relocation Address Formation 0024d Load R Register LRD d | 48 | | 57 5 | <u>8 63</u> | |----|------|------|-------------| | | 0024 | | d | See figure II-1-6. This instruction loads the 22-bit R register from PP memory (PPM) locations d and d+1. If the instruction d field is not zero, the instruction loads bits 47 through 57 of R from bits 52 through 63 of location (d)+1. Bits 36 through 45 of R are loaded from bits 54 through 63 of (d). If the d field is zero, this instruction is a pass. 0025d Store R Register SRD d See figure II-1-3. This instruction stores the 22-bit R register contents into PP memory locations d and d+1. If d is nonzero, the instruction stores bits 46 through 57 of R in bit positions 52 through 63 of (d)+1, and bits 36 through 45 of R store in bit positions 54 through 63 of (d). Bits 48 through 51 of (d)+1 and 48 through 53 of (d) clear. If the d field is zero, this instruction is a pass. D060d Central Read from (A) to d CRD d | 48 | 57 58 | 63 | |------|-------|----| | 0060 | | d | This instruction transfers the rightmost 60 bits of one CM word to the rightmost 12 bits of 5 consecutive PP memory (PPM) words. The IOU discards the leftmost 4 bits of the CM word and disassembles the remaining 60 bits from left to right into five 12-bit bytes. The following illustrations show this unpacking. R+A specifies the CM word address (refer to figure II-1-7); d specifies the first PPM word address. The CM word is as follows: | 0 3 | 4 15 | 16 27 | 28 39 | 40 51 | 52 63 | |-----|--------|--------|--------|--------|--------| | (4) | a (12) | b (12) | c (12) | d (12) | e (12) | The PPM words formed by unpacking one CM word are as follows: | 48 51 52 | | 63 | |----------|--------|----| | 0 (4) | a (12) | | | 0 (4) | b (12) | | | 0 (4) | c (12) | | | 0 (4) | d (12) | | | 0 (4) | e (12) | | 1060d Central Read from (A) to d Long CRDL d This instruction transfers one CM word to four consecutive PP memory (PPM) words. The IOU disassembles the CM word from the left. The following illustrations show this unpacking. R+A specifies the CM word address (refer to figure II-1-7); d specifies the first PPM word address. The CM word is as follows: | 0 15 | 16 31 | 32 | 47 48 63 | |--------|--------|--------|----------| | a (16) | b (16) | c (16) | d (16) | The PP memory words formed by unpacking one CM word are as follows: | 48 | | 63 | |----|--------|----| | | a (16) | | | | b (16) | | | | c (16) | | | | d (16) | | 0061dm Central Read (d) Words from (A) to m CRM m,d This instruction transfers the rightmost 60 bits of consecutive CM words to the rightmost 12 bits of consecutive PP memory (PPM) words. The PP discards the leftmost 4 bits of each CM word and disassembles the remaining 60 bits from the left into five 12-bit bytes. Refer to instruction 0060 for an illustration of unpacking. R+A specifies the first CM word address (refer to figure II-1-7), m specifies the first PPM word address, and location d specifies the number of CM words transferred. Upon completion, A contains the nonrelocated portion of the CM address (plus one) for the last word transferred. ## NOTE If the value of the rightmost 17 bits of A exceeds $(2^{17})$ -1, the leftmost bit toggles, switching the operation from direct address to relocation address mode. If the last word transferred is from a relative address of $377776_8$ and relocation is in effect, the PP clears the A register and the value returned to A may not point to the last word transferred plus 1. Also, when bit 17 switches to 0, addressing switches to the direct addressing mode. Central Read (d) Words from (A) to m Long CRML m,d | 32 | 11 42 | 47 48 51 | 52 63 | |------|-------|----------|----------| | 1061 | d | ZER0\$ | <b>m</b> | This instruction transfers consecutive CM words to consecutive PP memory (PPM) words. The IOU disassembles each CM word from the left. Refer to the 1060 instruction for an illustration of this unpacking. R+A specifies the first CM word address (refer to figure II-1-7), m specifies the first PP memory word address, and location d specifies the number of CM words transferred. On completion, A contains the nonrelocated portion of the CM address (plus one) for the last word transferred. ## NOTE If the value of the rightmost 17 bits of A exceeds $(2^{17})$ -1, the leftmost bit toggles, switching the operation from direct address to relocation address mode. If the last word transferred is from a relative address of 3777768 and relocation is in effect, the PP clears the A register and the value returned to A may not point to the last word transferred plus 1. Also, when bit 17 switches to zero, addressing switches to the direct addressing mode. 0062d Central Write to (A) from d CWD d This instruction transfers the rightmost 12 bits of 5 consecutive PP memory (PPM) words to the rightmost 60 bits of one CM word. (The IOU ignores the leftmost 4 bits of the words.) These words are assembled from left to right, as shown in the following illustration. R+A specifies the CM word address (see figure II-1-7); d specifies the first PPM word address. The IOU verifies each CM address against the OS bounds address. PPM words are as follows: | 48 51 52 | | 63 | |----------|--------|----| | 0 (4) | a (12) | | | 0 (4) | b (12) | | | 0 (4) | c (12) | | | 0 (4) | d (12) | | | 0 (4) | e (12) | | The CM word formed by packing five 12-bit PP memory words is as follows: | <u>0 3</u> | 4 15 | 16 27 | 28 39 | 40 51 | 52 63 | |------------|--------|--------|--------|--------|--------| | (4) | a (12) | b (12) | c (12) | d (12) | e (12) | 1062d Central Write to A from d Long CWDL d | 48 | | 57 | 58 | | 63 | |----|------|----|----|---|----| | Ī | 1000 | | | _ | | | | 1062 | | | a | | This instruction transfers four consecutive PP memory (PPM) words to one CM word, as shown in the following illustration. R+A specifies the CM word address (see figure II-1-7); d specifies the first PPM word address. The IOU verifies each CM address against the OS bounds address. The PPM words are as follows: | 48 | | 63 | |----|--------|----| | | a (16) | | | | b (16) | | | - | c (16) | | | | d (16) | | The CM word formed by packing four 16-bit PPM words is as follows: | 0 15 | 16 31 | 32 47 | 48 63 | |--------|--------|--------|--------| | a (16) | b (16) | c (16) | d (16) | Central Write (d) Words to (A) from m CWM m,d This instruction transfers the rightmost 12 bits of consecutive PP memory (PPM) words to the rightmost 60 bits of consecutive CM words. Refer to the instruction 0062 for an illustration of this packing. R+A specifies the first CM word address (see figure II-1-7), m specifies the first PPM word address, and d specifies the number of CM words transferred. The IOU verifies the CM address against the OS bounds address. On completion, A contains the nonrelocated portion of the CM address (plus 1) for the last word transferred. #### NOTE If the value of the rightmost 17 bits of A exceeds (2<sup>17</sup>)-1, the leftmost bit toggles, switching the operation from direct address to relocation address mode. If the last word transferred is from a relative address of 3777768 and relocation is in effect, the PP clears the A register and the value returned to A may not point to the last word transferred plus one. Also, when bit 17 switches to 0, addressing switches to the direct addressing mode. 1063dm Central Write (d) Words to (A) from m Long CWML m,d This instruction transfers consecutive PP memory (PPM) words to consecutive CM words. The IOU packs four PPM words (from the left) into each CM word. R+A specifies the first CM word address (see figure II-1-7), m specifies the first PPM word address, and d specifies the number of CM words transferred. The IOU verifies each CM address against the OS bounds address. On completion, A contains the nonrelocated portion of the CM address (plus 1), for the last word transferred. #### NOTE If the value of the rightmost 17 bits of A exceeds (2<sup>17</sup>)-1, the leftmost bit toggles, switching the operation from direct address to relocation address mode. If the last word transferred is from a relative address of 3777768 and relocation is in effect, the PP clears the A register and the value returned to A may not point to the last word transferred plus 1. Also, when bit 17 switches to 0, addressing switches to the direct addressing mode. 1000d Central Read and Set Lock from d to (A) RDSL d | 48 | | 57 58 | 63 | |----|------|-------|-----| | | 1000 | | d . | This instruction performs a logical OR function between four consecutive PP memory (PPM) words and one CM word. The original CM word contents replace the four PPM words; the logical OR result replaces the original CM word. Refer to the instructions 1060 and 1062 for packing and unpacking of the words. R+A specifies the CM word address (see figure II-1-7); d is the first PPM word address. The IOU verifies each CM address against the OS bounds address. The instruction does not start execution until the IOU completes all previous CM accesses. The CM does not permit any other port to access the CM word from the start of the read until the end of the write. The instruction delays subsequent instruction execution by the IOU until all CM accesses for the instruction complete. 1001d Central Read and Clear Lock from d to (A) RDCL d | 48 | 57 | 58 | 63 | |------|----|----|-----| | 1001 | | | d . | This instruction performs a logical AND function between four consecutive PP memory (PPM) words and one CM word. The original CM word contents replace the four PPM words; the logical AND result replaces the original CM word. See the 1060 and 1062 instructions for packing and unpacking of the words. R+A specifies the CM word address (see figure II-1-7); d is the first PPM word address. The IOU verifies each CM address against the OS bounds address. The instruction does not start execution until all previous CM accesses by the IOU complete. The CM does not permit any other port to access the CM word from the start of the read until the end of the write. The instruction delays execution of subsequent instructions by the IOU until all CM accesses for the instruction complete. # PP INPUT/OUTPUT INSTRUCTIONS The 26 instructions (in table II-1-28) direct activity on the I/O channels. They select an external device and transfer data to or from that device. The instructions also determine whether a channel or external device is available and ready to transfer data. The preparatory steps ensure that the channels carry out an orderly data transfer. Each external device has a set of external function codes the PP uses to establish operation modes, and to start and stop data transfer. The devices can also detect certain errors which are indicated to the controlling PP. Table II-1-28. PP Input/Output Instructions (Sheet 1 of 2) | 0 | )pcode | Instruction | | |------|--------|-------------------------------------------|---| | | 00640 | Jump to m if channel c active | | | | 00641 | Test and set channel c flag | | | | 1064X | Jump to m if channel c flag set | | | | 00650 | Jump to m if channel c inactive | | | | 00651 | Clear channel c flag | | | | 1065X | Jump to m if channel c flag clear | | | | 00660 | Jump to m if channel c full | | | | 00661 | Test and clear channel c error flag set | | | | 00670 | Jump to m if channel c empty | | | | 00671 | Test and clear channel c error flag clear | | | | 00700 | Input to A from channel c when active | | | | 00701 | Input to A from channel c if active | | | | 00710 | Input A words to m from channel c | | | | 10710 | Input A words to m from channel c packed | | | | 00720 | Output from A to channel c when active | | | ** | 00721 | Output from A on channel c if active | | | + 1. | 00730 | Output A words from m on channel c | | | | 10730 | Output A words from m on channel c packed | : | | | 00740 | Activate channel c | | | | 00741 | Unconditionally activate channel c | | | | 00750 | Deactivate channel c | | Table II-1-28. PP Input/Output Instructions (Sheet 2 of 2) | 0pcode | Instruction | |--------|---------------------------------------| | 00751 | Unconditionally deactivate channel c | | 00760 | Function A on channel c when inactive | | 00761 | Function A on channel c if inactive | | 00770 | Function m on channel c when inactive | | 00771 | Function m on channel c if inactive | 00640cm Jump to m if Channel c Active AJM m,c This instruction branches to the location specified by m if channel c is active. 00641cm Test and Set Channel c Flag SCF m,40B+c) This instruction branches to the location specified by m if the channel c flag is set. Otherwise, it sets the channel flag and exits. Setting m to P+2 unconditionally sets the channel flag. ## NOTE A conflict condition may occur when two or more PPs in the same time slot attempt to simultaneously execute a 00641 instruction on the same channel. Only the maintenance channel (17g) resolves this condition by letting the PP in the lowest physical barrel see the true status of the flag. The flag appears set to the other PPs in conflict and the PPs take the branch. 1064Xcm Jump to m if Channel c Flag Set FSJM m,c This instruction branches to the location specified by m if the channel c flag is set. 00650cm Jump to m if Channel c Inactive IJM m,c This instruction branches to the location specified by $\boldsymbol{m}$ if channel c is inactive. 00651cm Clear Channel c Flag CCF c This instruction clears the channel c flag, and requires but does not use the m field. 1065Xcm Jump to m if Channel c Flag Clear FCJM m,c This instruction branches to the location specified by m if the channel c flag is clear. 00660cm Jump to m if Channel c Full FJM m,c This instruction branches to the location specified by m if channel c is full. 00661cm Test and Clear Channel c Error Flag Set SFM m,40B+c If the channel c error flag is set, this instruction branches to the location specified by m and clears the error flag. 00670cm Jump to m if Channel c Empty EJM m,c This instruction branches to the location specified by m if channel c is empty. 00671cm Test and Clear Channel c Error Flag Clear CFM m, 40B+c If the channel c error flag is clear, this instruction branches to the location specified by $m_{\bullet}$ If the error flag is set, this instruction clears it. 00700c Input to A from Channel c When Active IAN c This instruction transfers one word from channel c to the low-order 16 bits of A. The high-order 2 bits of A are zeros. The instruction waits for the channel to become active and full. # NOTE If the channel uses a 12-bit external interface, the high-order 6 bits of A are 0s. If it uses an 8-bit external interface, the high-order 10 bits of A are 0s. 00701c Input to A from Channel c if Active IAN 40B+c | 48 | 57 58 | 59 63 | |------|-------|-------| | 0070 | 1 | С | This instruction transfers one channel c word to the low-order 16 bits of A. The high-order 2 bits of A are zeros. If the channel is inactive or becomes inactive before becoming full, no transfer occurs and the instruction exits with A = 0. ## NOTE If the channel uses a 12-bit external interface, the high-order 6 bits of A are 0s. If it uses an 8-bit external interface, the high-order 10 bits of A are 0s. If the addressed channel is not connected, the instruction exits with A = 1777778. 0071Ccm Input A Words to m from Channel c IAM m,c This instruction transfers successive words from channel c to PP memory (PPM). The m field specifies the first PPM word address; (A) specifies the number of words transferred. The transfer completes when either A = 0 or the channel becomes inactive. If an inactive channel caused termination, the instruction clears the next PPM word, and A contains the difference between its initial value and the number of channel words actually transferred. No transfer takes place if the instruction executes with the channel initially inactive. The instruction exits with A unchanged and the PPM word specified by m sets to 0. However, if the addressed channel is not connected, the instruction exits with A = 1777778. ## NOTE If the channel uses a 12-bit external interface, the high-order 4 bits of the PP memory word are 0s. If it uses an 8-bit external interface, the high-order 8 bits of the PP memory word are 0s. 10710cm Input A Words to m from Channel c Packed IAPM m,c This instruction transfers the low-order 12 bits of successive channel c words to consecutive PP memory (PPM) words. During this transfer, the IOU packs four 12-bit words (48 bits) into three PPM words. (Refer to the following paragraphs.) The high-order 4 bits of the channel words are ignored. The m field specifies the first PPM word address; A specifies the number of channel words transferred. A complete transfer depends on the channel word count being a multiple of 4. If the channel word count is not a multiple of 4, the IOU fills the bits left over when A is counted to zero (these bits copy the corresponding bits on the channel). When the channel is inactive or empty, these bits are zeros and, hence, the fill is with zeros. When, however, the external device and the PP have different word counts, or for some other reason the channel bits are nonzero, the fill is not zero-fill. The instruction exits when A is zero or when the channel becomes inactive. If an inactive channel causes termination, the leftover bits from the previous channel word will fill up to the next four-channel-word boundary as described above. No transfer takes place if the instruction executes with the channel initially inactive. The instruction exits with A unchanged, and the next three PPM words specified by m, m+l, and m+2 fill as described above. 60458890 A This instruction allows 16-bit PPM words to be read from 12-bit external devices. The channel words are as follows: | 48 51 | 52 | | 63 | | | | |-------|-------------|--------|----|--|--|--| | (4) | a (12) | | | | | | | (4) | b (4) c (8) | | | | | | | (4) | d (8) e (4) | | | | | | | (4) | | f (12) | | | | | The PPM words are as follows. | 48 51 | 52 5 | 5 56 5 | 960 63 | |-------------|-------|--------|--------| | | a (12 | ) | b (4) | | c (8) d (8) | | | | | e (4) | | f (12) | | 00720c Output from A on Channel c when Active OAN c | 48 | | 57 5 | 8 59 | 63 | |----|------|------|------|----| | | 0072 | 0 | С | | This instruction transfers one word from the A register low-order 12 bits to channel c. The instruction waits for an active and empty channel before executing. # NOTE If the channel uses a 12-bit interface, it does not transmit the channel word high-order 4 bits to the external device. Similarly, if it uses an 8-bit external interface, it does not transmit the channel word high-order 8 bits. 00721c Output from A on Channel c if Active OAN 40B+c This instruction transfers the A register low-order 16 bits to channel c. If the channel is inactive, no transfer occurs and the instruction exits. The operation does not alter the contents of A. ## NOTE If the channel uses a 12-bit interface, it does not transmit the channel word high-order 4 bits to the external device. Similarly, if it uses an 8-bit external interface, it does not transmit the channel word high-order 8 bits. 00730cm Output A words from m on Channel c OAM m,c This instruction transfers the contents of successive PP memory (PPM) words as successive words on channel c. The m field specifies the first PPM word address; A specifies the number of words to be transferred. The transfer completes when either A = 0 or the channel becomes inactive. If an inactive channel caused termination, A contains the difference between its initial value and the number of words transferred on the channel. If the instruction executes with the channel initially inactive, no transfer occurs and the instruction exits with A unchanged. # NOTE If the channel uses a 12-bit interface, it does not transmit the channel word high-order 4 bits to the external device. Similarly, if it uses an 8-bit external interface, it does not transmit the channel word high-order 8 bits. 10730cm Output A Words from m on Channel c Packed OAPM m,c This instruction transfers consecutive PP memory (PPM) words as the low-order 12 bits of successive words on channel c. During the transfer, processing occurs such that the contents of three PPM words result in four channel words. The high-order 4 bits of the 16-bit channel words set to zeros. This packing is illustrated in the 1071 instruction. The m field specifies the first PP word address; A specifies the number of channel words to be transferred. The transfer completes when either A = 0 or the channel becomes inactive. If an inactive channel caused termination, A contains the difference between its initial value and the number of words actually transferred on the channel. If the instruction executes with the channel initially inactive, no transfer occurs and the instruction exits with A unchanged. 00740c Activate channel c ACN c This instruction sets channel c active to prepare it for I/O transfer operations. If the channel is initially active, the instruction waits for the channel to become inactive before executing. 00741c Unconditionally Activate Channel c ACN 40B+c This instruction sets channel c active to prepare it for I/O transfer operations. The instruction executes regardless of the channel's active/inactive status. 00750c Deactivate channel c DCN c This instruction sets channel c inactive to terminate I/O operations on the channel. If the channel is initially inactive, the instruction waits for the channel to become active before executing. If this instruction executes after an output instruction without waiting for the channel to become empty, the last channel word transferred may be lost. 00751c Unconditionally Deactivate Channel c DCN 40B+c This instruction sets channel c inactive to terminate I/O operations on the channel. If the channel is initially inactive, the instruction executes regardless of the channel's active/inactive state. If this instruction executes after an output instruction without waiting for the channel to become empty, the last channel word transferred may be lost. 00760c Function A on Channel c when Inactive FAN c | 48 | | 575 | 8 59 | 63 | |----|------|-----|------|----| | | 0076 | 0 | С | | This instruction transfers the low-order 16 bits of A to channel c as a function code. If the channel is initially active, the instruction waits for the channel to become inactive before executing. The operation does not alter the contents of A. ## NOTE If the channel uses a 12-bit interface, it does not transmit the channel word high-order 4 bits to the external device. Similarly, if it uses an 8-bit external interface, it does not transmit the channel word high-order 8 bits. Parity, however, is always calculated on the rightmost 16 bits of A when outputting a function word from A. 00761c Function A on Channel c if Inactive FAN 40B+c This instruction transfers the low-order 16 bits of A to channel c as a function code. If the channel is initially active, the IOU does not transfer the function on the channel, and the instruction exits. # NOTE If the channel uses a 12-bit interface, it does not transmit the channel word high-order 4 bits to the external device. Similarly, if it uses an 8-bit external interface, it does not transmit the channel word high-order 8 bits. 00770cm Function m on Channel c when Inactive FNC m,c This instruction transfers the m field contents to channel c as a function code. If the channel is initially active, the instruction waits for the channel to become inactive before executing. ## NOTE If the channel uses a 12-bit interface, it does not transmit the channel word high-order 4 bits to the external device. Similarly, if it uses an 8-bit external interface, it does not transmit the channel word high-order 8 bits. 00771cm Function m on Channel c if Inactive FNC m,40B+c This instruction transfers the m field contents to channel c as a function code. If the channel is initially active, the IOU does not transfer the function on the channel and the instruction exits. ## NOTE If the channel uses a 12-bit interface, it does not transmit the channel word high-order 4 bits to the external device. Similarly, if it uses an 8-bit external interface, it does not transmit the channel word high-order 8 bits. #### **OTHER IOU INSTRUCTIONS** | 002400 | Pass | |--------|------| | 000000 | Pass | | 002500 | Pass | PSN | 48 | 57 | 58 | 3 59 | 63 | |----|----|----|------|----| | 24 | | 0 | d | | The pass instructions perform no operation. 0027d PP Keypoint KPT d | 48 | 57 58 | 63 | |------|-------|----| | 0027 | d | 1. | This instruction executes as a pass instruction, but allows test-point sensing of its execution by way of external monitoring equipment. ### **Exchange Jumps** The exchange jump instructions allow PP programs to request CYBER 170 State exchanges in the CP. The IOU transmits the exchange request to the CP designated for executing CYBER 170 State instructions. Bit 05 of the monitor condition register sets to indicate an outstanding IOU exchange request. If an exchange request for any PP is outstanding, another exchange request from any other PP causes the second PP to wait until the outstanding exchange request completes. The d field value controls the action taken to process the exchange request in CYBER 170 State, as described in the following paragraphs. 00260x Exchange Jump EXN d This is an unconditional exchange jump performed with the exchange package at address R+A (see figure II-1-4). The IOU verifies this address against the OS bounds address and, if in the prohibited region, the exchange does not occur. In this case, the OS bounds fault sets and, if the enable error stop bit is set in the environment control register, the PP is idled. 00261x Monitor Exchange Jump MXN d This is a conditional exchange jump performed with the exchange package at address R+A (see figure II-1-7). The IOU verifies this address against the OS bounds address and, if in the prohibited region, the exchange does not occur. The OS bounds fault sets and, if the enable error stop is set in the environment control register, the PP is idled. If monitor flag is clear, the exchange jump occurs and the monitor flag sets. If the monitor flag is set before this instruction begins to execute, the exchange jump is not performed. 00262x Monitor Exchange Jump to MA MAN d This is a conditional exchange jump performed with the exchange package at the address in the CP monitor address register. If the monitor flag is clear, the exchange jump occurs and the monitor flag sets. If the monitor flag is set before this instruction begins to execute, the exchange jump is not performed. 00263x Instruction executes as if d = 2x. 1026d Interrupt Processor INPN d | 48 | 57 | 58 | 63 | |----|-----|----|----| | 10 | )26 | | d | This instruction causes the IOU to transmit an interrupt for a CP on the memory port specified by d. This interrupt signal causes the external interrupt bit to set in the monitor condition register. Refer to CP Interrupts in section 2 of this volume. # PROGRAMMING INFORMATION This section contains programming information for the CP, CM, IOU, system console, and two-port multiplexer. ### **CP EXCHANGE OPERATIONS** Figure II-2-1 shows CP modes of operation. Exchange operations switch the CP between monitor and job modes in both Virtual State and CYBER 170 State. Exchange operations may also switch states while switching modes. Refer to Interstate Programming Information in this section for a description of state-switching operations. An exchange operation exchanges the process running in CP with another process and switches CP modes. The exchange stores the CP registers of the outgoing process in CM as an exchange package (refer to Exchange Package, figure II-2-2), and reads the registers of the incoming process from another exchange package in CM into the CP registers. Exchange operations are caused by the following: - Execution of a Virtual State exchange instruction in the CP. - Execution of the interrupt processor instruction (0026) in any PP. - Hardware-detected fault or exception with the CP in Virtual State job mode. Such exchange operations are called exchange interrupts. 60458890 C Figure II-2-1. CP Calls, Returns and Interrupts #### VIRTUAL STATE JOB-TO-MONITOR EXCHANGE OPERATIONS The CP performs an exchange from Virtual State job mode to Virtual State monitor mode as follows: - 1. It stores the outgoing job process registers as an exchange package starting at the CM address in the job process state (JPS) pointer register. - 2. It disables exchange interrupts. - 3. It loads the incoming monitor process registers (from another exchange package in CM) into the CP registers, starting at the CM address in the monitor process state (MPS) pointer register. Exchange interrupt conditions occurring with the CP in monitor mode do not cause an exchange interrupt, but may cause a trap interrupt. Refer to CP Interrupts in this section. #### VIRTUAL STATE MONITOR-TO-JOB EXCHANGE OPERATIONS The CP performs an exchange from Virtual State monitor mode to Virtual State job mode as follows: - 1. It stores the outgoing monitor process registers as an exchange package starting at the CM address in the monitor process state (MPS) pointer register. - 2. It enables exchange interrupts. - 3. It loads the incoming job process registers (stored in CM as another exchange package into the CP registers) starting at the CM address in the job process state pointer register. When a Virtual State monitor-to-job mode exchange operation sets MCR bit 55 (environment specification error), the CP completes the exchange and initiates a job-to-monitor mode (JPS) exchange in response to the error. Refer to Interrupts in this section. #### **EXCHANGE PACKAGES** Before initiating a Virtual State monitor-to-job exchange, the operating system specifies the process environment by composing in CM an exchange package for that process. When the process is suspended, hardware records system conditions into the same exchange package in CM, permitting process reactivation (in the absence of uncorrectable errors) without violating process integrity. Each suspended process (including the monitor program) has one exchange package stored in CM. Each exchange package contains the process registers in fifty-two 64-bit words as shown in figure II-2-2. Refer to Process State Registers in this section for descriptions of the exchange package entries. The CP uses the following types of exchange packages: - For exchanges between Virtual State monitor and job modes (exclusively within Virtual State), the exchange package format is shown in figure II-2-2. - For exchanges between Virtual State monitor and job modes (including switching between Virtual State and CYBER 170 State), the exchange package format is shown in figure II-2-27. - For exchanges with CYBER 170 State monitor and job modes, the exchange package format is shown in figure II-2-28. - For exchanges exclusively within CYBER 170 State, the exchange package format is shown in the appropriate CYBER 170 State hardware reference manual listed in the preface. Exchange package addresses, used by hardware to locate exchange packages during exchange operations, are real memory addresses (RMAs) in hardware registers designated as follows: - For exchanges to Virtual State monitor mode, the RMA is in the monitor process state (MPS) pointer register. - ullet For exchanges to Virtual State job mode, the RMA is in the job process state (JPS) pointer register. Exchange operations do not copy an exchange package into cache memory. Figure II-2-2. Virtual State Exchange Package ### **CP REGISTERS** The CP registers comprise two classes: process state registers and processor state registers. This distinction arises because the state of the process, and the state of the processor, characterize CP operation. Both classes of registers are accessible to the CP and PPs. Bits within the registers number consecutively from left to right, with the rightmost bit always equal to 63. #### PROCESS STATE REGISTERS The process state registers relate to a specific Virtual State process executing in the CP. Various process state registers also support CYBER 170 State operation. The contents of the process state registers can be written into memory as a Virtual State exchange package for either a Virtual State process or a CYBER 170 State process (refer to figures II-2-2 and II-2-27). The exchange package for each process contains the step-by-step operating register contents as directed by process execution. In addition, the exchange package holds other detailed process state information such that the CP may dynamically switch between exchange packages (processes) while preserving process integrity. When a process executes in the CP, its exchange package resides in the process state registers. When a process awaits execution, its exchange package resides in central memory. Table II-2-1 lists the processor state registers and permissible access types for CP copy-to/from-state-register instructions and for maintenance channel (MCH) access. ### CP Base Constant (BC) Register The 32-bit BC register provides a means for communication with the operating system. The contents of this register do not directly affect hardware operation. ### CP Debug Index (DI) Register The 6-bit DI register is added to the debug list pointer (DLP) register to form the PVA of each word read from the debug list (DL). DI increments after each word is read. When a DL match occurs, DI+DLP points to the second word of the matched DL entry. # CP Debug List Pointer (DLP) Register The 48-bit DLP register contains the PVA of the first debug list entry. DLP bits 61 through 63 must be zeros or an address specification error (MCR 52) occurs. Table II-2-1. Process State Registers | | No.<br>of | | Access<br>Type | | |---------------------------------------------------|-----------|------------------|----------------|-----| | Register Name | Bits | Address | Сору | MCH | | Address (AO through AF) (16 registers) | 48 | · <del>-</del> | _ | _ | | Base constant (BC) | 32 | 47 | R | R/W | | Debug index (DI) | 6 | E4 | R/W | R/W | | Debug list pointer (DLP) | 48 | C5 | R/L | R/W | | Debug mask (DM) | 1 7 | E5 | R/W | R/W | | Flags | | | · | | | Critical-frame flag (CFF) | 1 1 | EO,E1 | R/W | R/W | | On-condition flag (OCF) | 1 1 | E2,E3 | R/W | R/W | | Process-not-damaged (PND) flag | 1 1 | · <u>-</u> | _ | _ | | Largest ring number (LRN) | 4 | | - | CM | | Last processor identification (LPID) | 8 | - | _ | - | | Monitor condition (MCR) | 16 | 43 | R | R/W | | Monitor mask (MMR) | 16 | 60 | R/W | R/W | | Operand (XO through XF) (16 registers) | 64 | <b>-</b> , , , , | - | - | | Process interval timer (PIT) | 32 | . C9 | R/L | R/W | | Program address (P) | 64 | 40 | R | R/W | | Segment table address (STA) | 32 | 45 | R | R/W | | Segment table length (STL) | 12 | 45 | R | R/W | | Top-of-stack (TOS) pointer (15 registers) | 48 | . <del>-</del> | - | CM | | Trap enable (TE) | 2 | CO-C3 | R/L | R/W | | Trap pointer (TP) | 48 | C4 | R/L | R/W | | Untranslatable pointer (UTP) | 48 | 44 | R | R/W | | Untranslatable virtual machine identifier (UVMID) | 4 | | _ | _ | | User condition (UCR) | 16 | 43 | R | R/W | | User mask (UMR) | 16 | E6 | R/W | R/W | | Virtual machine identifier (VMID) | 4 | | | | Notes: R: Unprivileged read W: Unprivileged write G: Globally-privileged write CM: In central memory (indirectly accessible) # CP Debug Mask (DM) Register The 7-bit DM register contains 2 flag bits and 5 mask bits. The flag bits control debug initiation and termination. A mask bit, when set, enables the corresponding debug interrupt. DM has the following bit assignments: | DM Bit | Description | |--------|--------------------------------------| | 9 | End-of-list-seen flag | | 10 | Debug scan-in-progress flag | | 11 | Data-read mask | | 12 | Data-write mask | | 13 | Instruction-fetch mask | | 14 | Branch target instruction-fetch mask | | 15 | Call target instruction-fetch mask | #### **CP Flag Register** The 4-bit flag register contains the flag bits described in the following paragraphs. # Critical-Frame Flag (CFF) Software sets this flag to indicate that the stack frame in use (when the flag is set) requires special attention before this frame may be abandoned. Executing return/pop instructions with CFF set causes an interrupt (other enables-permitting). Call instructions and trap interrupts record CFF in the stack frame save area (SFSA) and proceed to clear CFF; return instructions restore the previous CFF condition. ### On-Condition Flag (OCF) Software sets this flag to assist the operating system in the handling of certain trap interrupts. Call instructions and trap interrupts record OCF in the SFSA and proceed to clear OCF; return instructions restore the previous OCF condition. #### Process-Not-Damaged (PND) Flag Hardware sets this flag in the outgoing exchange package after an uncorrectable error (MCR 48) occurs. PND indicates that the interrupted process is undamaged and may be restarted. Hardware ignores PND in an incoming exchange package. ### **CP Largest Ring Number (LRN) Register** The 4-bit LRN register contains the largest ring number for which there is a top-of-stack (TOS) entry in the associated TOS register. (In model 835, this register is not used as the TOS pointers are kept in $CM_{\bullet}$ ) ### CP Last Processor Identification (LPID) Register In dual-CP systems, the 8-bit LPID register identifies the last CP which executed the process defined by the exchange package. ### **CP Monitor Condition Register (MCR)** The 16-bit MCR register records system exception conditions which the operating system must resolve (for example, hardware errors, instruction specification errors, and access violations). Refer to CP Interrupts in this section for further information. #### **CP Monitor Mask Register** The 16-bit MMR register enables or masks certain software-specified conditions directly associated with the monitor condition register (MCR). An interrupt occurs when an MCR bit is set with the corresponding MMR bit set (other enables-permitting). Refer to CP Interrupts in this section for further information. ## **Operand X Registers** The sixteen 64-bit X registers, numbered XO through XF, supply operands for arithmetic operations and data manipulation. Depending on the operation, the registers contain a logical quantity, a signed binary integer, or a signed FP number. CP instructions which only require 32 data bits access the X registers as X-left (bits 0 through 31) or X right (bits 32 through 63). The X-register formats are as follows (the S-field is the sign bit): Store operations to X-left (XkL) do not alter X-right (XkR). Store operations to XkR do not alter XkL. ### **CP Process Interval Timer (PIT)** The 32-bit PIT register allows each process to track its own execution time. PIT is set either by a Copy-To-State-Register instruction with local privilege or from an incoming exchange package. The CP records PIT in an outgoing exchange package. PIT can be read via a Copy-From-State-Register instruction. PIT decrements at a 1-microsecond rate without stopping. A trap interrupt occurs whenever the count equals zero (other enables-permitting). # CP Program Address (P) Register The 64-bit P register contains the PVA of an instruction during the time the CP interprets and executes it. The P register also contains bits which define memory access protection. The P-register format is as follows: | 0 | 9 10 | 15 1 | 16 19 | 20 | 31 | 32 | 33 | 63 | |---|------|------|-------|-----|----|----|----|----| | | | | | | | | | | | | | KEY | RN | SEG | | ٧ | BN | 1 | | | //// | | | | | | | | | <u>Field</u> | Name | Description | |--------------|-------------------|------------------------------------------------------------------------------------------------------------| | KEY | Key | Access permission attribute (refer to Access Protection under Virtual Memory Programming in this section). | | RN | Ring<br>Number | Access privilege indicator (refer to Access Protection under Virtual Memory Programming in this section). | | SEG | Segment<br>Number | Process segment number (refer to Access Protection under Virtual Memory Programming in this section). | | V | Valid bit | Validity indicator (refer to Process Virtual Memory under Virtual Memory Programming in this section. | | <u>Field</u> | Name | Description | |--------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BN | Byte<br>Number | Byte displacement within the 231 bytes in a segment. Bit 32 in the final PVA used as a validity indicator and must be a zero or the PVA is rejected. Bit 32 in an A register may be a one, provided indexing or displacement changes this bit to a zero in the final PVA. | ### CP Segment Table Address (STA) Register The 32-bit STA register contains the real memory address (RMA) of the first segment descriptor table entry (interpreted as a byte address). Hardware ignores the rightmost 3 bits of STA. Refer to Virtual Memory Programming in this section for further information. ### CP Segment Table Length (STL) Register The 12-bit STL register contains a count equal to one less than the number of 64-bit entries in the associated segment descriptor table. The virtual addressing mechanism uses this count to verify that segment table references are to an address within the segment table boundaries. Refer to Virtual Memory Programming in this section for further information. ### CP Top-of-Stack (TOS) Pointer Register The operating system has for each process fifteen 48-bit TOS pointers to guarantee access protection. The TOS pointers are located in words 37 through 51 of an exchange package in CM. Each TOS is associated with one of the 15 rings of access protection; hardware uses the pointers to switch stacks during call/return instructions. Each TOS is a PVA pointing to the top of its associated stack when this stack is not in active use. Refer to Stack Manipulating Operations in this section, and Access Protection under Virtual Memory Programming in this section, for further information. ### CP Trap Enable (TE) Register The 2-bit TE register contains information that determines how traps are enabled. The TE register bits are represented as follows: • Trap-enable flip-flop (TEF) When set, TEF is one of the conditions which enable trap interrupts. TEF is normally set by a Copy-To-State-Register instruction and cleared by hardware when a trap interrupt occurs. TEF can also be cleared by another Copy-To-State-Register instruction. Trap-enable delay (TED) flip-flop The TED flip-flop disables a trap interrupt until after the next return instruction completes execution. TED is normally set by a Copy-To-State-Register instruction and cleared by a return instruction. TED can also be cleared by another Copy-To-State-Register instruction. ### CP Trap Pointer (TP) Register The 48-bit TP register contains a PVA which is the indirect address of the entry point into the trap interrupt target procedure (refer to CP Interrupts in this section). The code base pointer (CBP) is the direct address to which TP points. An incoming exchange package loads the TP register. TP can also be written by a Copy-To-State-Register instruction with local privilege, and read by a Copy-From-State-Register instruction. ### **CP Untranslatable Pointer (UTP) Register** When an interrupt occurs because the CP cannot translate a PVA or SVA to an RMA, the 48-bit UTP register contains the untranslatable PVA or SVA. UTP is set to PVA when the following MCR conditions occur: - MCR 52 sets (except during load-page or purge instructions). - MCR 54 or 57 sets. - MCR 60 sets due to invalid SDE or exceeded STL. - MCR 60 sets due to code base pointer (CBP) RN-field of zero during a call-indirect instruction. In the following cases, UTP may be set to either PVA or SVA: - MCR 52 sets during load-page instruction. - MCR 52 sets during purge instruction with k=0/1/8/9. No other interrupt alters the UTP register. # CP Untranslatable Virtual Machine Identifier (UVMID) Register Hardware sets the 4-bit UVMID register when an exchange operation, call-indirect instruction, or return instruction is interrupted due to an attempt to switch the CP to a state for which there is no set bit in the virtual machine capability list. In such a case, hardware sets the UVMID code to indicate which VMCL bit is missing. Values of 0 through 15 of UVMID correspond to VMCL bits 48 through 63 as follows: | UVMID | Missing VMCL Bit | |--------------|--------------------------| | 0 | 48 (Virtual State) | | 1 | 49 (CYBER 170 State) | | 2 through FF | 50 through 63 (reserved) | #### CP User Condition Register (UCR) The 16-bit UCR register records conditions that normally do not require an exchange to monitor mode for corrective action. Each bit indicates detection of a particular error or exception condition in the CP (for example, divide fault, arithmetic overflow and underflow, or invalid BDP data). A trap interrupt occurs when a UCR bit sets with the trap enable flip-flop set, the corresponding user mask register (UMR) bit set, and trap-enable delay flip-flop clear. Refer to CP Interrupts in this section for further information. #### CP User Mask Register (UMR) The 16-bit UMR register enables or masks certain software-specified conditions directly associated with the user condition register (UCR). An interrupt occurs when a UCR bit is set with the corresponding UMR bit set (other enables-permitting). Refer to CP Interrupts in this section for further information. II-2-11 ## CP Virtual Machine Identifier (VMID) Register- The 4-bit binary code in the VMID register identifies the virtual machine capability being used, as follows: | VMID | Virtual Machine Capability | |--------------|----------------------------| | 0 | Virtual State | | 1 | CYBER 170 State | | 2 through FF | Reserved | ### CP PROCESSOR STATE REGISTERS The processor state registers contain information about the state of the CP hardware, rather than a unique process. Included among this category of registers are the CP maintenance registers, which provide additional information about the condition of the CP hardware for diagnostic purposes. Other processor state registers contain such information as parameters of tables and pointers to exchange packages in CM. Table II-2-2 lists the processor state registers and permissible access types for CP Copy-To/From-State-Register instructions and for maintenance channel (MCH) access. Table II-2-2. Processor State Registers | | No.<br>of | | Acce<br>Typ | | |-------------------------------------------|-----------|---------|-------------|-----| | Register Name | Bits | Address | Сору | мсн | | Cache/map corrected error log (CCEL/MCEL) | 64 | 92/93 | R/G | R/W | | Dependent environment control (DEC) | 64 | 30 | _ | R/W | | Element identifier (EID) | 32 | 10 | R | R | | Job process state (JPS) | 32 | 61 | R/M | R/W | | Model-dependent word (MDW) | 64 | 51 | R | R/W | | Monitor process state (MPS) | 32 | 41 | R | R/W | | Options installed (OI) | 64 | 12 | R | R | | Page size mask (PSM) | 7 | 4A | R | R/W | | Page table address (PTA) | 32 | 48 | R | R/W | | Page table length (PTL) | 8 | 49 | R | R/W | | Processor fault status (PFS) | 64 | 80-81 | R/G | R/W | | Processor identifier (PID) | 8 | 11 | R | R | | Processor test mode (PTM) | 64 | AO | R/G | R/W | | Status summary (SS) | 6 | 00 | - | R | | System interval timer (SIT) | 32 | 62 | R/M | R/W | | Virtual machine capability list (VMCL) | 16 | 13 | R | R | Notes: R: R: Unprivileged read W: Unprivileged write G: Globally-privileged write M: Virtual State monitor mode write ### **CP** Options Installed (OI) Register The 64-bit OI register is a hard-wired register identifying the options installed in the CP. Refer to the Maintenance Register Codes Booklet listed in the preface for model-dependent information contained in the OI register. ## CP Page Size Mask (PSM) Register The 7-bit PSM register specifies the page size used in allocating real memory. Page sizes are selectable at system initialization time and range from 2K to 16K bytes. Refer to Virtual Memory Programming in this section for further information. # CP Page Table Address (PTA) Register The 32-bit PTA rgister is a real-memory byte address pointing to the first page table entry. Refer to Virtual Memory Programming in this section for further information. #### CP Page Table Length (PTL) Register The 8-bit PTL register is a mask specifying the page table length. The page table ranges from 512K to 131K words in 512K-word increments. Refer to Virtual Memory Programming in this section for further information. ### CP Processor Fault Status (PFS) Registers The PFS registers record hardware-detected errors occurring within the CP. Refer to the Maintenance Register Codes Booklet listed in the preface for model-dependent information contained in the PFS registers. #### CP Processor Identifier (PID) Register The 8-bit PID register is a hard-wired register identifying each processor in the system. Refer to the Maintenance Register Codes Booklet listed in the preface for model-dependent information contained in the PID register. #### **CP Processor Test Mode (PTM) Register** The 64-bit PTM register provides a maintenance capability which forces faults for the purpose of testing hardware-fault sensing within the CP. Refer to the Maintenance Register Codes Booklet listed in the preface for model-dependent information contained in the PTM register. # CP Status Summary (SS) Register The 6-bit SS register indicates CP status (similar registers exist in the CM and IOU). Aside from the Virtual State monitor mode bit, if any SS bit is set the SS bit also sets in the IOU status summary register. Refer to the Maintenance Register Codes Booklet listed in the preface for further information. 60458890 A ## CP Cache/Map Corrected Error Log (CCEL/MCEL) Register The CCEL/MCEL register contains model-dependent diagnostic information. Refer to the Maintenance Register Codes Booklet listed in the preface for further information. #### CP Dependent Environment Control (DEC) Register The 64-bit DEC register is a maintenance register which controls CP operating conditions. The model-independent bit is as follows: | Bit | Description | |-----|------------------------------------------------------------------------------------------------------------------------------------------| | 35 | Disable corrected error to status summary. When set, disables the setting of corrected error (bit 62) in the CP status summary register. | Refer to the Maintenance Register Codes Booklet listed in the preface for model-dependent bit descriptions. #### **CP Element Identifier (EID) Register** The 32-bit EID register is a backpanel-wired register identifying each system hardware element. The EID bits are represented as follows: | EID Bits | Description | | |---------------|-----------------------------|--| | 32 through 39 | Element type | | | 40 through 47 | Model number | | | 48 through 63 | Serial number (hexadecimal) | | Refer to the Maintenance Register Codes Booklet listed in the preface for model-dependent information contained in the EID register. # CP Job Process State (JPS) Register The 32-bit JPS register contains the real memory address (RMA) of the first word of a Virtual State job mode exchange package. Hardware aligns the JPS address with bits 32 through 63 of RMAs, and interprets the JPS address as zero, modulo 16. The CP ignores bit 32 and interprets bits 60 through 63 as zeros. System deadstart procedures load the initial JPS. ### CP Model Dependent Word (MDW) Register The MDW register (models 810, 815, 825, 830, and 835 only) contains the PVA of the instruction that caused the last branch to take place in the CP. The PVAs include those of call and return instructions. ### CP Monitor Process (MPS) Register The 32-bit MPS register contains the real memory address (RMA) of the first word of a Virtual State monitor mode exchange package. Hardware aligns the MPS address with bits 32 through 63 of RMAs, and interprets the MPS address as zero, modulo 16. The CP ignores bit 32 and interprets bits 60 through 63 as zeros. System deadstart procedures load the initial MPS. | Bit | Description | |-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 58 | Virtual State monitor mode. | | 59 | Short warning. Sets to warn the system of an imminent environmental failure (for example, system power failure, local 50-Hz/60-Hz power failure, or cooling unit fault). | | 60 | Processor halted. | | 61 | Uncorrectable error. Sets whenever the detected uncorrectable error (DUE) bit in MCR sets. | | 62 | Corrected error. Sets after the CP corrects an error. The dependent environment control (DEC) register can be set to disable the recording of corrected errors. | | 63 | Long environment warning. Sets to indicate an imminent failure condition (for example, high-temperature warning, blower fault, or low-temperature fault). | ### **CP System Interval Timer (SIT) Register** The 32-bit SIT register is a timer which establishes maximum time intervals for process execution. The operating system first sets the timer to the desired value. The timer then decrements at a 1-microsecond rate until the count equals zero (the timer does not stop counting at zero; it decrements to all ones and continues decrementing). When enabled, the zero count causes an interrupt. ### CP Virtual Machine Capability List (VMCL) The 16-bit VMCL register is a backpanel-wired register indicating CP capabilities. The VMCL format is as follows: | VMCL Bit | Capability | | | | |---------------|-----------------|--|--|--| | 48 | Virtual State | | | | | 49 | CYBER 170 State | | | | | 50 through 63 | Reserved | | | | ## CM REGISTERS The CM contains maintenance registers which hold memory status and error information (refer to table II-2-3). CM maintenance registers are accessible through the maintenance channel (register 80 is also accessible through the memory ports). Table II-2-3. CM Maintenance Registers | | No<br>of | | Acce<br>Typ | | |---------------------------------|----------|------------|-------------|-----| | Register Name | Bits | Address | Сору | MCH | | | | | | | | Corrected error log (CEL) | 64 | <b>A</b> 0 | - | R/W | | Element identifier (EID) | 32 | 10 | - | R | | Environment control (EC) | 64 | 20 | - | R/W | | Free-Running counter | 48 | во | R | W | | Options installed (OI) | 32 | 12 | - | R | | Port bounds register | 64 | 21 | - | R/W | | Status summary | 6 | 00 | - | R | | Uncorrectable error log (UEL) 1 | 64 | <b>A</b> 4 | - | R/W | | Uncorrectable error log (UEL) 2 | 64 | A8 | - | R/W | NOTE: The free-running counter can be read from the CP by the Copy Free Running Counter (08) instruction. # CM CORRECTED ERROR LOG (CEL) REGISTER The 64-bit CEL register contains details concerning the first corrected error since this register was last reset. The model-independent bits are represented as follows: | Bit | Description | |-----|-------------------------------------------------------------------------------------------------------------------------------------------| | 0 · | Valid bit. Indicates that the CEL contains a valid entry. When this bit is set, further correctable errors are discarded. | | 1 | Unlogged corrected error. Indicates that a correctable error occurred but could not be logged because the CEL already contained an entry. | The CEL register contains model-dependent information regarding the address, parity, and encoded number of the memory port associated with the error. Refer to the Maintenance Register Codes Booklet listed in the preface for model-dependent information contained in the CEL register. ## CM ELEMENT IDENTIFIER (EID) REGISTER The 32-bit EID register is set by switches on logic panels. EID identifies each system hardware element according to the following bit assignments: | Bits | Description | |---------------|-----------------------------| | 32 through 39 | Element type | | 40 through 47 | Model number | | 48 through 63 | Serial number (hexadecimal) | Refer to the Maintenance Register Codes Booklet listed in the preface for model-dependent information contained in the EID register. ## CM ENVIRONMENT CONTROL (EC) REGISTER The 64-bit EC register controls CM error-checking and interleaving. Refer to the Maintenance Register Codes Booklet listed in the preface for information contained in the EC register. #### CM FREE-RUNNING COUNTER REGISTER This counter register consists of either 64 counter bits, or 48 counter bits right-justified with zero-fill in the leftmost 16 bits. The counter increments at a 1-microsecond rate. Successive reads of the free-running counter guarantee different values. The free-running counter can be written at any time through the maintenance channel. The CP can read the counter using the Copy Free Running Counter (08) instruction. ## CM OPTIONS INSTALLED (OI) REGISTER The 64-bit OI register identifies the memory configuration and is set by field-modifiable switches on logic panels. Refer to the Maintenance Register Codes Booklet listed in the preface for model-dependent information contained in the OI register. # CM PORT BOUNDS REGISTER This 64-bit register controls the range of addresses accessible during a write operation through specified ports. For ports specified by bounds-register bits, write access is limited to an area between two real memory addresses (RMAs) in this register. Refer to Maintenance Channel Programming in this section for further information. ## CM STATUS SUMMARY REGISTER This 64-bit register provides information about the CM clock, error status, and physical environment condition. Refer to the Maintenance Register Codes Booklet listed in the preface for specific information contained in the CM status summary register. # CM UNCORRECTABLE ERROR LOG (UEL) REGISTERS The two 64-bit UEL registers contain details of the first two uncorrected CM errors which occurred since the registers were last reset. The model-independent bits are represented as follows: | Bit | Description | |-----|--------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Valid bit. Indicates that the UEL contains a valid entry. When this bit is set, further uncorrectable errors are discarded. | | 1 | Unlogged uncorrectable error. Indicates that an uncorrectable error occurred but could not be logged because the UEL already contained an entry. | The UEL registers also contain information about the source of the error. This information includes the illegal function, memory bounds fault, and multiple-bit memory error. Refer to the Maintenance Register Codes Booklet listed in the preface for model-dependent information contained in the UEL registers. ## **IOU REGISTERS** The IOU contains maintenance registers which hold IOU status and error information (refer to table II-2-4). IOU registers are accessible through the maintenance channel. Table II-2-4. IOU Maintenance Registers | | No.<br>of | | Access<br>Type | | |---------------------------------|-----------|---------|----------------|-----| | Register Name | Bits | Address | Сору | МСН | | Element identifier (EID) | 32 | 10 | _ | R | | Environment control (EC) | 32 | 30 | _ | R/W | | Fault status (FS) l | 64 | 80 | - | R/W | | Fault status (FS) 2 | 64 | 81 | | R/W | | Fault status mask | 64 | 18 | - | R/W | | Options installed (OI) | 64 | 12 | - | R | | 0S bounds | 64 | 21 | - | R/W | | Status summary | 6 | 00 | · - | R | | Test mode | 16 | AO | _ * . | R/W | | Uncorrectable error log (UEL) 2 | 64 | A8 | - | R/W | ### IOU ELEMENT IDENTIFIER (EID) REGISTER The 32-bit EID register is a backpanel-wired register identifying each system hardware element. The EID bits are represented as follows: | Bits | Description | |---------------|-----------------------------| | 32 through 39 | Element type | | 40 through 47 | Model number | | 48 through 63 | Serial number (hexadecimal) | ### IOU ENVIRONMENT CONTROL (EC) REGISTER The 64-bit EC register controls timing margins, test mode and deadstart, PP memory dumps, reconfiguration, and stop-on-error conditions for the IOU. It also selects PP internal registers for reading. Refer to the Maintenance Register Codes Booklet listed in the preface for further information. ## IOU FAULT STATUS (FS) REGISTERS The 64-bit FS registers indicate the presence of uncorrectable faults in the IOU, PP memories, I/O channels, or PP hardware. Refer to the Maintenance Register Codes Booklet listed in the preface for further information. ### IOU FAULT STATUS MASK REGISTER This 64-bit register controls IOU fault reporting to the IOU fault status (FS) registers. Refer to the Maintenance Register Codes Booklet listed in the preface for further information. # IOU OPTIONS INSTALLED (OI) REGISTER The 64-bit 0I register identifies the options installed in the I0U. Refer to the Maintenance Register Codes Booklet listed in the preface for further information. #### IOU OS BOUNDS REGISTER The 64-bit operating system (OS) bounds register divides the CM into an upper and a lower region for system protection. The OS bounds register contains a bit for each PP which indicates the region in CM into which the specified PP may initiate exchange operations or writes. Refer to the Maintenance Register Codes Booklet listed in the preface for further information. # IOU STATUS SUMMARY REGISTER The status summary register indicates errors in the CP, CM and IOU. It also provides information about the PP-halt, error status, and physical environment conditions. Refer to the Maintenance Register Codes Booklet listed in the preface for further information. ### IOU TEST MODE (TM) REGISTER The 64-bit TM register forces faults in the IOU for testing of the fault sensing logic. Bits 48 through 63 of this register serve a dual role. With the Enable Test Mode Register bit set in the EC register, these bits are used to force test conditions (refer to the Maintenance Register Codes Booklet listed in the preface for further information). When the Enable Test Mode Register bit is clear, these read/write bits can be used by software as interlock/flag status bits. ## **CP CONDITION AND MASK REGISTERS** The CP contains a monitor condition register (MCR) and a user condition register (UCR), each of which records interrupt causes and displays flag conditions. Each condition register has a corresponding mask register controlling the action taken when a condition register bit sets. Table II-2-5 lists the bit assignments in the monitor condition and mask registers. Table II-2-6 lists the bit assignments in the user condition and mask registers. The significance of the individual bits is further described in Interrupt Conditions in this section. Section 2 in volume 1 also describes all CP registers. In general, MCR and UCR bits may be altered by the following: - CP hardware indicating a processor condition or external event. - Branch-on-condition register instruction (9F). - PP communication over the maintenance channel. - Software with the condition register stored in an exchange package in CM. - Trap interrupts which clear any condition register bits for which the corresponding mask register bit is set. Monitor condition and user mask register bits may be altered by the following: - Copy to state register instruction (OF). - PP communication over the maintenance channel. - Software with the mask register stored in an exchange package in CM. Table II-2-5. Monitor Condition/Mask Register Bit Assignments | | | | | | Asso | ciated 1 | MCR Bit | | | |--------|----------|----------------|-----------------------------------------------|---------|---------|----------|----------|--------|--| | | | | | S | et | Se | et | Clear | | | | | T | <u> </u> | † | Cond | ition o | f Traps | L | | | | | | | Enab. | | Disa | | Any | | | | Exchange | | | - | | | | | | | MCR | package | Туре | Description | | CP Mo | de of O | peration | | | | bit | bit | | | Job | Mon | Job | Mon | Any | | | 48 | 0 | хх | Detected uncorrect-<br>able error. | Exch | Trap | Exch | Halt | Halt | | | 49 | 1 | хх | Not assigned. | Exch | Trap | Exch | Halt | Halt | | | 50 | 2 | EN | Short warning. | Exch | Trap | Exch | Stack | Stack | | | 51 | 3 | ST | Instruction | Exch | Trap | Exch | • Halt | Halt | | | | | | specification error. | | · | | | | | | 52 | 4 | ST | Address specification error. | Exch | Trap | Exch | Ha1t | Halt | | | 53 | 5 | EN | CYBER 170 State exchange request. | Exch | Trap | Exch | Stack | Stack | | | 54 | 6 | ST | Access violation. | Exch | Trap | Exch | Halt | Halt | | | 55 | 7 | S 1 | Environment | Exch | Trap | Exch | Halt | Halt | | | | | | specification error. | | | | | | | | 56 | 8 | EN | External interrupt. | Exch | Trap | Exch | Stack | Stack | | | 57 | 9 | ST | Page table search | Exch | Trap | Exch | Halt | Halt | | | | | <del>-</del> . | without find. | | | | | | | | 58 | 10 | EN | System call (status bit). | None | None | None | None | None | | | 59 | 11 | EN | System interval timer. | Exch | Trap | Exch | Stack | Stack | | | | | | | | | | | | | | 60 | 12 | S 2 | Invalid segment/<br>ring number zero. | Exch | Trap | Exch | Halt | Halt | | | 61 | 13 | ST | Outward call/<br>Inward return. | Exch | Trap | Exch | Halt | Halt | | | 62 | 14 | EN | Soft error. | Exch | Trap | Exch | Stack | Stack | | | 63 | 15 | ST | Trap exception | None | None | None | None | None | | | | | | (status bit). | | | | | | | | Notes: | Refer to | Interrupt | Conditions in this sect | ion for | r bit d | escript | ions. | | | | | Stack | Test for | opportunity to trap or | exchan | ge at e | ach ins | truction | fetch. | | | | X | | ondition may happen. | | | | | | | | | E | | on completed. | | | | | | | | | S | | n suppressed. | | | | | | | | | N | | of next instruction. | | | | | | | | | T | P = PVA | of this instruction. | | | | | | | | | 1 | | 0 on Load A, Return or T; for invalid segment | | | or RN = | 0 on Ca | ll or | | | | 2 | For exch | nange operations, 2 = N; | Call, I | Return | or Pop, | 2 = T. | | | Table II-2-6. User Condition/Mask Register Bit Assignments | | | | | | Assoc<br>Set | | | Clear | |-----|----------------|------------|----------------------|------|--------------|----------|---------|-------| | | | | | 36 | e C | Se | | Clear | | | | | | | Condi | tion of | Traps | | | | | | | Enab | Led | Disab | led | Any | | UCR | Exchange | Termo | Description | | CP Mod | le of Op | oration | | | bit | package<br>bit | Type | Description | Job | Mon | Job | Mon | Any | | DIL | DIL | | | 300 | PIOII | 300 | Hon | Ally | | 48 | 0 | ST | Privileged in- | | | | | | | | | | struction fault. | Trap | Trap | Exch | Halt | _ | | 49 | 1 | ST | Unimplemented | 1 - | • | | | | | | | | instruction. | Trap | Trap | Exch | Halt | _ | | | | | | | • | | | | | 50 | 2 | EN | Free flag. | Trap | Trap | Stack | Stack | - | | 51 | 3 | т | Process interval | 1 | • | ĺ | | | | | | | timer. | Trap | Trap | Stack | Stack | - | | 52 | 4 | <b>S</b> T | Inter-ring pop. | Trap | Trap | Exch | Halt | - | | 53 | 5 | т | Critical frame | Trap | Trap | Exch | Halt | | | | | | flag. | - | | | | | | 54 | 6 | | Reserved. | Trap | Trap | Stack | Stack | - | | 55 | 7 | SN | Divide fault. | Trap | Trap | Stack | Stack | Stack | | 56 | 8 | S Т | Debug. | Trap | Trap | Stack | Stack | Stack | | 57 | 9 | ST | Arithmetic overflow. | Trap | Trap | Stack | Stack | Stack | | 58 | 10 | ET | Exponent overflow. | Trap | Trap | Stack | Stack | Stack | | 59 | 11 | ET | Exponent underflow. | Trap | Trap | Stack | Stack | Stack | | | | | | · | | | | | | 60 | 12 | ET | FP loss of | 1_ | | ١ | | | | | | l | significance. | Trap | Trap | Stack | Stack | Stack | | 61 | 13 | ST | FP indefinite. | Trap | Trap | Stack | Stack | Stack | | 62 | 14 | ST | Arithmetic loss | _ | _ | | | a. 1 | | | | | of significance. | Trap | Trap | Stack | Stack | Stack | | 63 | 15 | ET | Invalid BDP data. | Trap | Trap | Stack | Stack | Stack | Notes: Refer to Interrupt Conditions in this section for bit descriptions. | Stack | Test for opportunity to trap or exchange at each instruction fetch. | |-------|---------------------------------------------------------------------| | E | Execution of instruction completed. | | S | Execution of instruction suppressed. | | N | P = PVA of next instruction. | | T | P = PVA of this instruction. | ## **CP CONDITION REGISTER BIT GROUPING** Refer to Interrupt Conditions in this section for bit descriptions. The four groups of condition register bits shown in table II-2-7 are a function of the characteristics of the event detected, and of the P register PVA at time of interrupt. The PVA from the P register stored in the exchange package during exchange interrupts [or in the stack frame save area (SFSA) during trap interrupts] points to an instruction address dependent on the condition register bit group as follows: | Group | PVA in P Stored During Interrupt | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Points to the instruction executing when the malfunction was detected. This instruction did not necessarily initiate the activity resulting in the malfunction. | | 2a,2b | Points to the instruction that would have been executed if the interrupt had not occurred. After executing an exchange or return to the interrupted procedure, processing continues (from the PVA stored in the exchange package) as though the interrupt had not occurred. | | 3 | Points to the instruction causing the interrupt. | Table II-2-7. Interrupt Condition Groups | | · | | | Occurrence | | |-------------|-------------------------------------------------|----------------|----------|------------|------------| | Group | Interrupt Condition | MCR/UCR<br>Bit | Туре | CY170 | Virtual | | Malfunction | ns Not Neccessarily Related to Curre | ent Instruc | tion | | | | 1 | Detected uncorrectable error | MCR 48 | Mon | X | <b>X</b> | | Tested Bety | ween Instructions, Not Generated by | Instruction | ns | | | | 2a | Short warning | MCR 50 | Sys | х | X | | , | System interval timer | MCR 51 | Sys | X | X | | | Soft error | MCR 52 | Sys | X | X | | | External interrupt | MCR 59 | Sys | Х | X | | | Free flag | UCR 50 | User | X | X | | | Process interval timer | UCR 51 | User | х | X | | | CYBER 170 State exchange request | MCR 53 | Sys | X | Х | | Tested Bet | ween Instructions, Generated by Ins | tructions | | | | | 2b | System call | MCR 58 | Status | | х | | 25 | Exponent overflow | UCR 58 | User | 1 | X | | | Exponent underflow | UCR 59 | User | | l x | | 4.5 | FP loss-of-significance | UCR 60 | User | | X | | | Invalid segment/RN zero (Note 1) | MCR 60 | Mon | x | X | | | | MCR 55 | Mon | X | x | | | Environment specification error (Note 2) | MCK 33 | Mon | ^ | ^ | | Tested Bef | ore Execution, Generated by Instruc | tion | | | | | 3 | Instruction specification error | MCR 62 | Mon | | х | | | Address specification error | MCR 52 | Mon | . Х | X | | | Invalid segment/RN zero (Note 1) | MCR 60 | Mon | X | X | | | Access violation | MCR 54 | Mon | X | X | | | Environment specification error | MCR 55 | Mon | Х | X | | | (Note 2) | WCD 57 | Mon | x | x | | | Page table search without find | MCR 57 | Mon | 1 | 1 | | | Outward call/inward return | MCR 61 | Mon | X | X | | | Trap exception | MCR 63 | Status | X | X | | | Privileged instruction fault | UCR 48 | Mon | X | X | | | Unimplemented instruction | UCR 49 | Mon | X | X | | | Inter-ring pop | UCR 52 | Mon | | X | | | Critical frame flag | UCR 53 | Mon | X | X | | ; | Divide fault | UCR 55 | User | | X | | | Debug | UCR 56 | User | | X | | | Arithmetic overflow | UCR 57 | User | | X | | | FP indefinite | UCR 61 | User | | X | | | Arithmetic loss-of-significance | UCR 62 | User | | x | | | Invalid BDP data | UCR 63 | User | | x | | | Invalle but data | 100100 | Josef | - | ] | | Notes: 1 | MCR 60 set by load address, return in group 2b. | , or pop in | nstructi | ons wher | RN = 0, is | | | MCR 60, set by call or trap instru | ctions whe | n RN = ∩ | or set | by an | | | invalid segment, is in group 3. | CCIOIIS WILE | | , 02 000 | . J, L | | 2 | MCR 55 set by exchange operations | ie in arco | n 2h | | | | . 7 | MIK 33 COT NV OYCHANGO CHORATIONS | is in grou | U 4D. | | | ### **CP INTERRUPTS** Exchange interrupts and trap interrupts comprise the CP interrupt structure. The following paragraphs describe the characteristics of the two interrupt types. #### **EXCHANGE INTERRUPTS** An exchange interrupt causes an exchange operation as described in Exchange Operations in this section. Exchange interrupts switch the system from Virtual State job mode (Virtual State or CYBER 170 State environment) to Virtual State monitor mode. Exchange interrupts are disabled in Virtual State monitor mode. Exchange interrupts initiate from conditions that set a bit in the monitor condition register (and in some cases in the user condition register). Exchange interrupts can only occur when the CP is in Virtual State job mode and the corresponding mask register bit is set. Refer to tables II-2-5 and II-2-6. #### TRAP INTERRUPTS A trap interrupt acts as an implicit call indirect (BO) instruction to an interrupt-handling procedure. Trap interrupts save the current stack frame save area (SFSA) environment, push the stack, and switch control to a software procedure for trap handling. Trap interrupts occur in response to the setting of UCR or MCR bits (as shown in tables II-2-5 and II-2-6) in the following environments: - Within Virtual State monitor mode. - Within Virtual State job mode. - Upon switch from CYBER 170 state to Virtual State job mode (refer to State Switching Operations in this section). The trap interrupt creates the maximum (33 word) SFSA descriptor and preserves the contents of the following in the associated SFSA: the P register, A and X registers, VMID, SFSA descriptor, monitor mask and condition registers, and user mask and condition registers. After the trap interrupt stores these registers in the SFSA, the CP clears the UCR or MCR bits causing the trap interrupt. The trap interrupt target address is obtained by the CP using the PVA in the trap pointer register to access a code base pointer (CBP) in a system binding section. This CBP contains the PVA of the next instruction to be executed. The external procedure flag must be set in the CBP. Refer to CP Stack Manipulating Operations in this section. A trap interrupt disables further trap interrupts. Software may reenable traps by either setting the trap enable delay flip-flop and executing the return (04) instruction, or by setting the trap enable flip-flop. The return instruction reestablishes the suspended environment but does not load the monitor/user condition registers from the SFSA into the CP. If an exception condition arises during execution of a trap operation, the trap interrupt aborts and the following actions occur: - 1. The trap exception bit (MCR 63) sets. - 2. The appropriate UCR/MCR bit sets for the condition causing the trap to abort. - 3. The trap enable flip-flop condition (set) is recorded in the exchange package stored for the interrupted procedure. - 4. The exchange or halt performs as indicated in tables II-2-5 and II-2-6. Virtual State job mode processes can control trap interrupts by setting bits in the user mask register. Bits set in the user mask register permit the trap interrupt when the corresponding UCR bit sets. Trap conditions occurring when traps are disabled have effect as listed in tables II-2-5 and II-2-6. #### INTERRUPT CONDITIONS The following paragraphs present the various conditions causing system interrupts. Each condition description includes a reference to the corresponding MCR or UCR bit that sets upon condition detection. Refer to Condition and Mask Registers in this section. #### Access Violation (MCR 54) This bit sets when the CP attempts a CM access without the required access permission. The CM access is blocked. The following conditions result in a CM access violation: - Attempt to read a nonreadable segment. - Attempt to read outside the read ring limit. - Attempt to write into a nonwritable segment. - Attempt to write outside the write ring limit. - Attempt to execute from a nonexecutable segment. - Attempt to execute from outside the execute ring bracket. - Attempt to call indirect when the code base pointer is not in a binding section segment. - Attempt to call indirect from a process outside the code base pointer call ring limit. - Key/lock violation. The PVA in P points to the instruction attempting the illegal access. ## Address Specification Error (MCR 52) This bit sets when the CP attempts to use an improper address. This includes: • Data address with nonzero bits 61 through 63 generated by the following instructions: | Opcode | Instruction | |--------|----------------------| | 04 | Return. | | В5 | Call indirect. | | 80 | Load multiple. | | 81 | Store multiple. | | 82 | Load word. | | 83 | Store word. | | во | Call relative. | | F4 | Calculate subscript. | - Instruction address with nonzero bits 62 and 63 generated by unconditional branch instruction (2F). - Any PVA with nonzero bit 32. The following instructions may also detect an address specification error: - Decimal arithmetic (70 to 75, E4, and E5). - Move immediate data (F9). - Convert from floating point to integer (3B). - Test and set page (16). The PVA in P points to the instruction specifying the incorrect address. ### Arithmetic Loss-of-Significance (UCR 62) This bit sets when significant digit(s) in the result are truncated or not stored in CM during execution of the following instructions: - Decimal arithmetic (70 to 75, E4, and E5). - Move immediate data (F9). - Convert from floating point to integer (3B). The PVA in P points to the instruction causing this condition. #### Arithmetic Overflow (UCR 57) This bit sets as a result of one of the following conditions: Integer sum instructions (10, 20, 24, 28, 8A, and 8B) when augend and addend have same signs but sum has opposite sign. - Integer difference instructions (11, 21, 25, and 29) when minuend and subtrahend have opposite signs but difference sign is opposite of minuend sign. - Half-word integer product instructions (22 and 8C) when most significant 32 bits of intermediate product are not equal to sign bit. - Integer product instructions (26 and B2) when leftmost 64 bits of intermediate product are not equal to sign bit. - Half-word integer quotient instruction (23) when $-2^{31}$ is divided by $-2^{0}$ . - Integer quotient instruction (27) when -264 is divided by -20. - Decimal arithmetic instructions (70 to 73) when result length exceeds destination field length. - Add immediate data instruction (FB) when source or destination field data descriptors specify invalid data type. The PVA in P points to the instruction causing the arithmetic overflow condition. # Critical Frame Flag (UCR 53) This bit sets when the CP attempts to execute a pop or return instruction from a critical stack frame. The PVA in P points to the pop or return instruction causing this interrupt. # Debug (UCR 56) This bit sets when a debug match occurs. Refer to Debug in this section for a description of this condition. The PVA in P points to the instruction causing the debug interrupt. #### Divide Fault (UCR 55) This bit sets when the CP detects a divisor equal to zero during execution of one of the integer quotient instructions (23, 27, 33, 37, and 73). Also, for the floating point quotient instructions (33 and 37), the CP detects a divide fault if the divisor coefficient is a nonstandard value of zero, or is unnormalized and divisible into the dividend coefficient by a factor exceeding or equal to 2. The PVA in P points to the instruction causing the divide fault condition. #### **Environment Specification Error (MCR 55)** This bit sets when the CP detects an error in the environment during a call, return, or pop instruction, or during an exchange or trap operation. The PVA in P at the time of interrupt points to the instruction causing the error when the error results from any of the following conditions: - A mismatch between VMCL and the VMID obtained from the code base pointer on a call indirect instruction (B5). - A mismatch between VMCL and the VMID obtained from the stack frame save area (SFSA) on a return instruction (04). - Initial A2 (previous save area pointer) not equal to A0 (dynamic space pointer) in the SFSA on a return (04) or pop (06) instruction. - In the previous stack frame descriptor, the field value designating the last A register to be loaded is less than 2 on a return instruction (04). When this error results from the following condition, the PVA in P at the time of interrupt points to the next instruction which would have executed: A mismatch between VMCL and the VMID obtained from the exchange package during an exchange operation. When this error results from the following conditions, the PVA in P at the time of interrupt points to the instruction as defined under the condition causing the trap operation: - A mismatch between VMCL and the VMID obtained from the code base pointer during a trap interrupt. - External procedure flag not set in the code base pointer during a trap interrupt. - The VMID from the code base pointer not equal to zero when executing a trap interrupt. ## **Exponent Overflow (UCR 58)** Exponent overflow occurs when an FP comparison or arithmetic instruction produces an exponent with an actual value between $2^{4096}$ and $2^{12187}$ . The PVA in P points to the next instruction that would have executed. # **Exponent Underflow (UCR 59)** Exponent underflow occurs when an FP arithmetic instruction produces an intermediate exponent value between $-2^{4096}$ and $-2^{12287}$ . The PVA in P points to the next instruction that would have executed. ## External Interrupt (MCR 56) This bit sets as a result of a processor interrupt instruction (03) in the interrupted CP (or in another CP in a multiprocessor system), through the CM port the instruction specifies. At the time of interrupt, the PVA in P points to the next instruction that would have executed. ### Floating-Point Indefinite (UCR 61) This bit sets when an FP arithmetic instruction produces a final nonstandard indefinite result. The PVA in P points to the instruction causing the FP indefinite condition. #### Floating-Point Loss-of-Significance (UCR 60) This bit sets when an FP arithmetic instruction produces an intermediate result with an overflow bit and coefficient of all zeros. The PVA in P points to the next instruction that would have executed. #### Free Flag (UCR 50) The free flag is normally set by software in an exchange package in CM: this bit causes an immediate trap interrupt after an exchange operation loads this exchange package into the CP. Software conventions dictate the use of this flag; hardware does not set this bit. The PVA in P points to the next instruction that would have executed. ### Instruction Specification Error (MCR 51) #### This bit sets: - During isolate/insert instructions (AC, AD, and AE) when the sum of the leftmost position designator plus the length designator exceeds 63. - During business data processing (BDP) instructions when the length specified by the data descriptor L field exceeds the maximum length for applicable data type. - If data type fields in source and/or destination data descriptors are invalid during the following BDP instructions: | <u>Opcode</u> | Instruction | |---------------|------------------------------| | 70 | Decimal sum. | | 71 | Decimal difference. | | 72 | Decimal product. | | 73 | Decimal quotient. | | 74 | Decimal compare. | | 75 | Numeric move. | | E4 | Decimal scale. | | E5 | Decimal scale rounded. | | ED | Edit. | | F4 | Calculate subscript and add. | | F9 | Move immediate data. | | FA | Compare immediate data. | | FB | Add immediate data. | | | | - Execution of BDP calculate subscript and add instruction (FA) when PVA bits 61 through 63 (used to access the subscript range table (SRT)) do not equal 0. - Execution of the program error instruction (00). - Execution of the Copy-To-State-Register instruction (OF), or the Branch-on-Condition-Register instruction (9F), when execute access is restricted to Virtual State monitor mode with the CP not in this mode. - Execution of a call instruction (BO/B5) when the number of the last A register field (At) in XOR bits 56 through 59) is less than 2. The P register contains the PVA of the instruction with the error. ### Inter-Ring Pop (UCR 52) This bit sets from an attempt to pop a stack frame in one ring with a pop instruction (06) executing in a different ring. The pop instruction moves the CSF, PSA, and TOS pointers to eliminate the stack frame without changing the P-counter. The PVA in P points to the pop instruction attempting the inter-ring pop. ## Invalid BDP Data (UCR 63) This bit sets when the CP detects an invalid decimal digit during execution of the following instructions: BDP decimal numeric, calculate subscript and add, compare immediate data, move immediate data, edit, and convert floating point to integer. The PVA in P points to the instruction causing this condition. # Invalid Segment/Ring Number Zero (MCR 60) This bit sets for the following reasons: - A PVA was untranslatable into an RMA because the segment table length was exceeded or the segment descriptor was invalid. The PVA in P points to the instruction attempting the CM access. - A call (BO or B5) instruction attempted to execute with a code base pointer (CBP) ring number (RN) equal to zero. The PVA in P points to the instruction attempting the CM access. - An A register was loaded with a PVA with RN equal to zero during a load A (80, 84, A0), return (04) or pop (06) instruction. The PVA in P points to the next instruction that would have executed. #### Not Assigned (MCR 49) When set explicitly by software, this bit causes an interrupt identical to the detected uncorrectable error (MCR 48). ## Outward Call/Inward Return (MCR 61) This bit sets when the CP attempts an outward call or an inward return. The PVA in P points to the instruction attempting the outward call or inward return. 60458890 A II-2-31 ## Page Table Search Without Find (MCR 57) This bit sets when a page table search does not locate the requested page table entry. The PVA in P points to the instruction attempting the CM access that resulted in this condition, except when this exception is caused by an instruction fetch directly after a branch exit. In this case, the PVA in P points to the branched-to instruction. ## Privileged Instruction Fault (UCR 48) This bit sets when: - An attempt is made to execute a local privileged instruction from other than a locally-privileged or globally-privileged segment. - An attempt is made to execute a globally-privileged instruction from other than a globally-privileged segment. - A trap (017) instruction executes in CYBER 170 State. The PVA in P points to the instruction causing the privileged instruction fault interrupt. # Process Interval Time (UCR 51) This bit sets when the process interval timer decrements to zero. The PVA in P points to the next instruction that would have executed. #### **Detected Uncorrectable Error (MCR 48)** This bit sets when the CP detects an uncorrectable error condition in the processor, or on a processor-initiated memory reference. Typical examples are a parity error in data from memory that cannot be retried, an uncorrectable error in control storage, and CP errors that cannot be corrected or retried. A CM bounds violation also causes this exception. The PVA in P does not necessarily point to the instruction causing the malfunction. ## CYBER 170 State Exchange Request (MCR 53) This bit sets when the CP receives the CYBER 170 State exchange request signal from the IOU, indicating that a PP in the IOU has executed one of the following instructions: exchange jump (00260X), monitor exchange jump (00261X), or monitor exchange jump MA (00262X). When the CP is in Virtual State, the operating system must switch the CP to CYBER 170 State job mode before the exchange can occur. The PVA in P points to the next instruction that would have executed. #### Short Warning (MCR 50) This bit sets when certain power distribution and warning system faults occur (refer to the appropriate power system manual listed in the preface). The PVA in P points to the next instruction that would have executed. This bit remains set until the condition returns to normal, at which time it clears. ## Soft Error Log (MCR 62) This bit sets to indicate error detection and correction by the hardware regarding the following: - A corrected error in CM for the port used by this CP (also recorded in the CM corrected-error register). - A corrected hardware malfunction in the CP. The PVA in P points to the next instruction that would have executed. #### System Interval Timer (MCR 59) This bit sets when the system interval timer decrements to zero. The PVA in P points to the next instruction that would have executed. ## Trap Exception (MCR 63) This bit sets when the system detects a fault during a trap interrupt operation. In such a case, at least one other MCR bit indicates the cause of the trap exception. The PVA in P points to the PVA that would have been stored in the stack frame, word 0, if the trap had completed without any exception conditions. ### **Unimplemented Instruction (UCR 49)** This bit sets when an instruction not implemented in the CP attempts to execute. The instruction descriptions in section II-l specify which instructions are model-dependent. The PVA in P points to the instruction causing the interrupt. The CYBER 170 State compare/move instructions (464-467) also cause this interrupt. # **MULTIPLE INTERRUPT CONDITIONS** Tables II-2-5 and II-2-6 list the interrupt action taken in various operating modes. When more than one bit sets in the MCR/UCR, the interrupts are processed with the following priority: - 1. Halt (any halt condition present). - 2. Exchange (no halt condition present, and any exchange condition present). - 3. Trap (no halt or exchange condition present, and any trap condition present). - 4. Stack (none of the above conditions present). Figure II-2-3 is a flowchart showing the CP detecting an exception condition and taking action on it. Figure II-2-3. Interrupt Flowchart ## **FLAGS** Table II-2-8 indicates the state of the critical frame flag, on-condition flag, trap enable flip-flop, and trap enable delay flip-flop following the execution of the Virtual State call, return, pop, exchange, and trap operations. Table II-2-8. Condition of Flags Following Call, Return, Pop, Exchange, and Trap Operations | | | | | F1a | | - | |-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|-----|-----|-----|----------| | Operations | | | CFF | OCF | TEF | TED | | Call | | | С | С | A | A | | Return | | | PS | PS | A | <b>C</b> | | Pop | | | PS | PS | A | <b>A</b> | | Exchange | | | ХP | ХP | ХP | XP | | Trap | | | С | С | С | A | | Notes: C<br>A<br>PS<br>XP<br>CFF<br>OCF<br>TEF<br>TED | Cleared by operation. As is (unchanged by operation). Loaded by operation from previous stack frame save area. Loaded by operation from exchange package. Critical frame flag. On-condition flag. Trap enable flip-flop. Trap enable delay. | | | | | | ## STACK MANIPULATING OPERATIONS Each process has up to 15 stacks: one for each ring of execution privilege as defined by the RN field (bits 16 through 19) of the hardware P register. Hardware accesses these stacks to save/restore the process registers and operating conditions during trap interrupts, and during the following Virtual State instructions: - Call indirect. - Call relative. - Return. - Pop. - Trap. These 15 stacks are used as parts of a single stack divided solely to guarantee access protection. The buildup and reduction of the 15 stacks always occurs through the same locations (in opposite directions), switching from stack to stack only when the P register ring number changes. The operating system allocates stack space to each process. One use of the critical frame flag (CFF) is to mark the first frame in each stack to indicate the beginning of the stack. The operating system may also check for a maximum allowable stack length when assigning a new page to the stack through the virtual memory demand paging mechanism. The 15 stacks operate in conjunction with assigned registers AO through A4 and 15 top-of-stack (TOS) pointers for the specific process. An exchange operation switches stacks by providing new AO through A4 and new TOS pointers. ## **STACK FRAMES AND SAVE AREAS** A procedure may use its stack for storing its dynamic variables. At times it may call another procedure, which in turn may call another procedure, and so on. Also, at any time, a trap interrupt condition may initiate a call-type operation. Each time a call occurs, hardware saves the registers of the suspended part of the process (the caller) in the currently active stack, together with some status information. This leaves these registers free for use by the branched-to software (the callee). The area in which the registers are stored is the stack frame save area (SFSA). The SFSA combines with the previously stored dynamic variables (if any) to comprise a stack frame. The CP hardware design provides that the string of successively-called procedures may include previously called procedures (recursive calls), provided code modification is not used. ## Stack Frame Save Area Format For call instructions, the programmer specifies the number of registers stored in SFSA (from 4 to 33) by way of a descriptor placed into X0, as shown in figure II-2-4. Trap interrupts always generate the maximum save area of 33 words. Figure II-2-5 shows the format of SFSA. Figure II-2-4. Format of XO for Call Instructions Figure II-2-5. Virtual State Stack Frame Save Area ### Stack Frame Save Area Descriptor Field The SFSA descriptor (figure II-2-6) is in word 2, bits 0 through 15 of the SFSA. It records the number of X and A registers saved in the SFSA, and also the state of the critical-frame flag (CFF), the on-condition flag (OCF), and the process-not-damaged (PND) flag when the SFSA is generated. The CFF and the OCF are hardware register flags set/cleared by copy to/from state register instructions, and which may also be prerecorded in an exchange package or the SFSA. CFF set for the current stack frame inhibits instruction execution and causes an interrupt when encountered during a return or pop instruction. Executing a call instruction or a trap interrupt stores the CFF and OCF in the SFSA descriptor generated for the current stack frame and clears these flags. Executing a return instruction loads these flags from the previous SFSA. The PND flag indicates whether or not a process being executed was damaged and whether the process may be restarted. This flag is intended to allow recovery of monitor mode processes where possible. The PND flag is valid when set during a Virtual State monitor mode trap operation caused by an uncorrectable error. In this case, the flag indicates that the executing process was undamaged and that it may be restarted. The PVA in P of the stack frame is the restart address for the process, but is not necessarily the address of the instruction which initiated the malfunction. The default (clear) state of the PND flag interprets the process as damaged. The hardware ignores the flag when loading a stack frame. Figure II-2-6. Stack Frame Save Area Descriptor # Virtual Machine Identifier (VMID) Field A call instruction or a trap interrupt stores the virtual machine identifier in SFSA word 1, bits 4 through 7. A return instruction loads the VMID from the previous SFSA into the CP, with the exception that an attempt to load a VMID = 1 requires global privilege. ## User Mask/Condition and Monitor Condition Fields A trap interrupt (but not a call instruction) stores the UCR and MCR in words 5 and 6, respectively (bits 0 through 15), in the SFSA. The CP clears the condition register bit(s) causing the trap interrupt. The return instruction does not restore the condition registers from the SFSA to the CP. #### ASSIGNED REGISTERS DURING STACK OPERATION Stack manipulating operations change registers AO through A4 and TOS pointers from the exchange package. For proper operation, the programmer must use registers AO through A4 as designated. ### **Top-of-Stack Pointers** An exchange package contains 15 top-of-stack (TOS) fields which initially point to the next available vacant word in each stack, as set by the operating system. In subsequent use, TOS for the active stack points to the first word in the current stack frame. Hardware updates TOS when any stack frame is pushed or popped. Hardware uses TOS only when stacks switch. The TOS pointers remain in the exchange package stored in CM and are accessed from there by hardware. #### **Dynamic Space Pointer (A0)** Register AO has the role of dynamic space pointer (DSP), pointing to the first available vacant byte number in the active stack. Hardware updates DSP when a stack frame is pushed or popped. Software must update DSP when storing/removing process dynamic variables in the stack. # **Current Stack Frame Pointer (A1)** Register Al has the role of current stack frame pointer (CSF), pointing to the first word in the current stack frame. CSF updates when a stack frame is pushed or popped. The process must not reduce a stack frame below CSF, and must not change CSF. #### Previous Save Area Pointer (A2) Register A2 has the role of previous save area pointer (PSA), pointing to the first word of the previous save area (not necessarily in the currently active stack). PSA updates when a stack frame is pushed or popped. The process must not change PSA. ## **Binding Section Pointer (A3)** A binding section pointer (BSP) points to the first word in a list of indirect addresses (called code base pointers, or CBP) for use by call indirect instructions or other information determined by software conventions. During call indirect instructions to an external procedure (which has its own binding section), register A3 always provides the BSP of this external procedure. The call indirect instruction first uses the BSP in Aj to access the CBP containing the target address. When this CBP has its external procedure flag set, the word stored in CM immediately after this CBP loads into A3. ## **Argument Pointer (A4)** Register A4 has the role of argument pointer, used through software conventions. It copies from Ak during call indirect instructions. The process may use A4 as permitted through software conventions. #### **EXCEPTIONS DURING STACK OPERATIONS** When an exception causes a call instruction or trap interrupt to abort, the following may precede the abort: - Dynamic space pointer (A0) may be rounded up. - Portions of the environment may be stored into the save area on top of the current stack frame. ### **BUSINESS DATA PROCESSING PROGRAMMING** Business data processing (BDP) instructions operate on CM data fields which may be 1 through 8, 19, 38, or 256 bytes in length. BDP instructions utilize two forms of data fields in CM: 1) the source field, and 2) the destination field. The former modifies, replaces, or compares to the latter. These fields are independently designated by BDP data descriptors, described in the following paragraphs. The CP accommodates 9 types of packed and unpacked binary-coded decimal (BCD) data, plus alphanumeric, binary-unsigned, and binary-signed data types. In many cases the data types may be freely mixed as the hardware performs the necessary type translations. The CP also manipulates alphanumeric data fields. ## **BDP DATA DESCRIPTORS** The source and destination field data is described by one or two data descriptors obtained from the CM at locations immediately following a BDP instruction. The instructions using the format jk have two descriptors. The instructions using the format jkQ have either one or two descriptors. As shown in figure II-2-7, each BDP data descriptor is a 32-bit half word describing the source or destination field data type, number of bytes, and relative memory location. | | 0 1 3 4 7 8 15 16 31 | |-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | F D T L O | | | | | Field | Description | | F | (1 bit) Function of the L field. Length retrieval information, as follows: | | * | F = 0 Length is obtained from the L field. | | • | F = 1 Length of the descriptor associated with Aj is obtained from XOR bits 55 through 63. Length of the descriptor associated with Ak is obtained from X1R bits 55 through 63. Other bits in XOR and X1R are not used. | | D | (3 bits) Reserved. | | T | (4 bits) Data type (refer to table II-2-5). | | L | (8 bits) Length (in bytes) of the source or destination field (refer to table II-2-5). The maximum length is restricted according to the operand data type. When the maximum length is exceeded, an instruction specification error occurs, causing an interrupt or halt. | | 0 | (16 bits) Offset. PVA of the leftmost byte of source or destination field is obtained by adding the sign-extended O field to the BN field of the base PVA in Aj or Ak, respectively. | Figure II-2-7. BDP Data Descriptor Format # **BDP DATA TYPES** The 12 data types listed in table II-2-9 are described in this subsection, including the permitted range of values for each data type with respect to digits (D), characters (C), signs (S), and maximum length (L). Table II-2-9. BDP Operand Types and Field Lengths | T | Data Type | Maximum Length (Bytes) | |----|-----------------------------------------------------|------------------------| | 0 | Packed decimal, no sign. | | | 1 | Packed decimal, no sign, leading slack digit. | 19 | | 2 | Packed decimal, signed. | | | 3 | Packed decimal, signed, leading slack digit. | | | 4 | Unpacked decimal, unsigned. | | | 5 | Unpacked decimal, trailing sign combined Hollerith. | | | 6 | Unpacked decimal, trailing sign separate. | 38 | | 7 | Unpacked decimal, leading sign combined Hollerith. | | | 8 | Unpacked decimal, leading sign separate. | | | 9 | Alphanumeric. | 256 | | 10 | Binary, unsigned. | 8 | | 11 | Binary, signed. | _ | # Data Type 0: Packed Decimal, Unsigned | | DD | DD | DD | | DD | DD | DD | |------|----|----|----|----|----|----|----| | Byte | 0 | 1 | 2 | 7) | 16 | 17 | 18 | 1 D: Hex 0 through 9. L: 19 bytes maximum. This format corresponds to an even number of digits in the decimal number. # Data Type 1: Packed Decimal, Unsigned Slack Digit Hex 0. 0: D: Hex 0 through 9. L: 19 bytes maximum. This format corresponds to an odd number of digits in the decimal number. # Data Type 2: Packed Decimal, Signed Byte | DD | DD | DD | 7) | DD | DD | DS | |----|----|----|----|----|----|----| | 0 | 1 | 2 | 7, | 16 | 17 | 18 | D: Hex 0 through 9. S: (Positive sign) hex A, B, C, E, or F (C preferred); (Negative sign) hex D. L: 19 bytes maximum. This format corresponds to an odd number of digits in the decimal number. # Data Type 3: Packed Decimal, Signed, Slack Digit Byte | 0 | DD | DD | ,, | DD | DD | DS | |---|----|----|----|----|----|----| | 0 | 1 | 2 | 7, | 16 | 17 | 18 | 0: Hex 0. D: Hex 0 through 9. S: (Positive sign) hex A, B, C, E, or F (C preferred); (Negative sign) hex D. L: 19 bytes maximum. This format corresponds to an even number of digits in the decimal number. # Data Type 4: Unpacked Decimal, Unsigned Byte | D | D | D | D | -)) | D | D | D | D | |----|----|----|----|-----|----|----|----|----| | 00 | 01 | 02 | 03 | 7) | 34 | 35 | 36 | 37 | D: ASCII characters 0 through 9 (represented by hex 30 through 39). L: 38 bytes maximum. # Data Type 5: Unpacked Decimal, Trailing Sign Combined Hollerith Byte 00 01 02 03 34 35 36 37 In the following, the preferred characters and codes are underlined. D: ASCII character 0 to 9 (represented by hex 30 through 39). C: ASCII character decoded as follows: ASCII 1 to 9 (hex 31 through 39) represents +1 through +9, or ASCII $\frac{A}{J}$ through $\frac{I}{R}$ (hex 41 through $\frac{49}{4F}$ ) represents +1 through +9. ASCII $\frac{J}{J}$ through $\frac{I}{R}$ (hex 4A through $\frac{4F}{4F}$ and hex 50 through 52) represents -1 through -9. ASCII $\frac{I}{J}$ , [, 0, 8 (hex 7B, 3C, 30, 26) represents +0. ASCII $\frac{I}{J}$ , ], - (hex $\frac{I}{I}$ D, 21, 2D) represents -0. L: 38 bytes maximum. ## Data Type 6: Unpacked Decimal, Trailing Sign Separate Byte 0 1 2 33 34 35 36 37 D: ASCII character 0 through 9 (hex 30 through 39). S: ASCII character + (hex 2B), positive sign; ASCII character - (hex 2D), negative sign. L: 38 bytes maximum. # Data Type 7: Unpacked Decimal, Leading Sign Combined Hollerith Byte | С | D | D | . D | <br>D | D | D | D | |---|---|---|-----|-------|----|----|----| | 0 | 1 | 2 | 3 | 34 | 35 | 36 | 37 | D: Same as data type 5. C: Same as data type 5. L: 38 bytes maximum. # Data Type 8: Unpacked Decimal, Leading Sign Separate S D D D D D D D 0 1 2 3 34 35 36 37 S: Same as data type 6. D: Same as data type 6. L: 38 bytes maximum. Byte # Data Type 9: Alphanumeric C: Any ASCII character code. L: 256 bytes maximum. ## Data Type 10: Binary, Unsigned L: 8 bytes maximum. The L bytes of the type 10 data field contain the positive binary operand value. Negatively-signed data moved to a type 10 destination field is considered positive. #### Data Type 11: Binary, Signed L: 8 bytes maximum. The L bytes of the type 11 data field contain the signed binary operand value. Negative values are represented in two's complement form. ## **Slack Digit** With data types 1 and 3, the slack digit value as read from CM is ignored and treated as zero. The slack digit value as written into CM is forced to zero and is not affected by any arithmetic overflow or arithmetic loss-of-significance that may occur. #### **UNDEFINED RESULTS** ## Overlap BDP instruction execution produces undefined results whenever the source and destination fields overlap and the leftmost and rightmost byte positions do not coincide. #### **Invalid Data** As a rule, invalid BDP data causes undefined results to be stored in the destination field in CM only when the corresponding mask bit is clear or traps are disabled. An exception: the decimal-compare and numeric-move instructions always store undefined results in X1R when invalid BDP data is detected. # **VECTOR PROGRAMMING** Vector operations are memory-to-memory operations; that is, the CP accesses one or two source vector streams from CM, repeats an operation on successive elements, and returns the results to CM in a destination vector stream. These operations occur without modifying the CP operating registers. Refer to Vector Instruction Descriptions in section 1 of this manual for detailed descriptions of the vector instructions. Most vector instructions stream results at a one-clock-period rate. The source and destination vectors may be consecutive streams of: - Floating-point operands (12-bit exponent plus sign bit, 48-bit coefficient plus sign bit). - 64-bit integers. - 64-bit elements (shift/compare/logical data). Refer to table II-2-10 for the source- and destination-vector characteristics of each type of vector operation. Table II-2-10. Vector Operations | Vector Operation | Source Vector A | Source Vector B | Destination Vector | |------------------------------|--------------------------------|-----------------|-----------------------------------| | Integer Arithmetic | 64-bit integers | 64-bit integers | 64-bit integers | | Integer Compare | 64-bit integers | 64-bit integers | 64-bit elements | | Logical Arithmetic | 64-bit elements | 64-bit elements | 64-bit elements | | Floating-Point<br>Arithmetic | F.P. operands | F.P. operands | F.P. operands | | Floating-Point<br>Summation | <u>-</u> | F.P. operands | F.P. operand† | | Shift Circular | 64-bit elements | 64-bit elements | 64-bit elements | | Merge | 64-bit elements | 64-bit elements | 64-bit elements | | Gather | Nonconsecutive 64-bit elements | interval†† | Consecutive<br>64-bit elements | | Scatter | Consecutive<br>64-bit elements | interval†† | Nonconsecutive<br>64-bit elements | # **VECTOR LENGTH (NUMBER OF OPERATIONS)** The D-field rightmost 10 bits, when nonzero, specify the length or number of operations to be performed (1 through 512). XIR specifies the length when the D-field rightmost 10 bits equal zeros, as follow: - When XIR is positive and less than 512, this number provides the vector length. - When XIR is positive and greater than 512, the vector length is 512. An instruction specification error (MCR 51) occurs when X1R is negative or when the D-field rightmost 10 bits are greater than 512. When the D-field rightmost 10 bits and all 32 bits of XIR are zeros, no memory reference occurs but the instruction undergoes normal address-exception detection. #### **VECTOR PAGE SIZE** Vector operations require a page size of 4096 bytes (512 words) or larger. (A page size of less than 4096 bytes inhibits the vector instruction and results in an environment specification error, MCR 55.) Since a vector may be from 1 to 512 elements long and may overlap page boundaries, it may occupy at most two partially-filled pages. Exceptions to this are the gather and scatter instructions, which by nature may require up to 512 pages per vector. #### **VECTOR BROADCAST** Vector broadcast is an additional feature for use with all vector instructions except Floating-Point Summation. Vector broadcast generates a source vector by repeating a single 64-bit element contained in the Xj register in place of V(Aj) if the leftmost D-field bit is a one. #### **VECTOR INTERRUPTS** Vector instructions (other than gather and scatter) may not be interrupted after any results in the destination vector stream have been stored in CM. Instruction execution completes before a monitor mode routine can process the interrupt. A program interrupt occurring before any results are stored inhibits the instruction. For the gather and scatter instructions, interrupts may occur after results have been partially stored in CM. Interrupting a vector instruction prevents the addressing section from making additional memory requests, and purges all unused operands assembled for execution. #### **VECTOR OVERLAP** Source and destination vectors for the same instruction may overlap only when the destination-vector starting address is less than or equal to the source-vector starting address. All other cases of source- and destination-vector overlap within a single instruction cause undefined results. ## FLOATING-POINT PROGRAMMING Floating-point (FP) arithmetic automatically maintains binary point placement during computations involving large numeric values or values within a widely varying range. This occurs by separating a number's significant digits from the number size to express the number as a fraction multiplied by a power of 2. Thus, each FP number contains two values as follows: - Coefficient (fraction) represents the number's significant digits. The binary point of the coefficient is always directly left of its most significant bit. - Exponent (characteristic) is a power of 2 by which the coefficient must be multiplied to obtain the whole FP number value. #### FLOATING-POINT DATA FORMATS FP data exists in 64- and 128-bit fixed-length formats (single precision and double precision), as shown in figure II-2-8. Figure II-2-8. Floating-Point Data Formats Table II-2-11. Floating-Point Representation | Exponent With Coefficient Sign Hexadecimal | Actual<br>Exponent<br>(Binary) | Input<br>Arguments | Term Used for<br>Numbers in<br>This Range | |--------------------------------------------|---------------------------------------|---------------------|-------------------------------------------| | | Positive Number | s (Coefficient sign | | | 7xxx | | Indefinite | +IND | | 6FFF<br>↑ | 12278 | Infinite | +Φ | | 5000 | 4096 | | | | 4FFF<br>4000 | 4095<br><b>†</b> | | +N | | 3FFF<br>3000 | 0 -1 | Standard | +23 | | 2FFF | -4096<br>-4097 | Zero | +22 | | 1000<br>0XXX | -12288 | Zero | +21 | | · ] | Negative Numbers | (Coefficient sign | = 1) | | 8XXX | · · · · · · · · · · · · · · · · · · · | Zero | -Z1 | | 9000 | -12288 | 7.000 | - | | AFFF<br>8000 | -4096<br>-4096 | Zero | -Z2 | | | -4090<br> | | -z3 | | 8FFF<br>COOO | -1<br>0 | Standard | | | CFFF | 4095 | | - <b>n</b> | | D000 | 4096<br>↓ | Infinite | -ω | | EFFF<br>FXXX | 12287 | Indefinite | -IND | #### STANDARD AND NONSTANDARD FP NUMBERS Nonstandard FP numbers are FP numbers outside the capacity of standard FP numbers. Special exponent field codes identify the three nonstandard FP numbers: zero ( $\pm$ Z1, $\pm$ Z2), infinity ( $\pm$ $\infty$ ), and indefinite ( $\pm$ INDEF). Table II-2-11 lists hexadecimal exponent codes for nonstandard and standard FP numbers. ## Floating-Point Zero Nonstandard FP operands with bits 01 and 02, or 01 and 03 clear, are treated as if consisting of all zeros. The nonstandard zero FP numbers are represented as $\pm Z1$ or $\pm Z2$ as shown in table II-2-11. The specific number in the $\pm Z1$ range which consists of all (64) zeros is termed $\pm 0$ . Thus, wherever $\pm Z1$ is indicated, the $\pm 0$ is also included since it is a member of $\pm Z1$ . The standard zero FP numbers are represented as ±23 as shown in table II-2-11. #### Floating-Point Nonzero Standard FP operands which have nonzero coefficients are represented as +N in table II-2-11. ## **Floating-Point Infinite** Nonstandard FP operands with bit 01 set, and bit 02 not equal to bit 03, are treated as infinite values. The nonstandard FP numbers in the Infinite range are represented as $\pm \infty$ as shown in table II-2-11. The specific number in the $\pm \infty$ range consists of 5000---000. The specific number in the $\pm \infty$ range consists of $\pm 0000---000$ . 60458890 A #### Floating-Point Indefinite Nonstandard FP numbers with bits 01, 02, and 03 set are treated as indefinite values. The nonstandard FP numbers in the Indefinite range are represented as $\pm IND$ as shown in table II-2-11. The specific number in the $\pm IND$ range consists of 7000--000. The specific number in the $\pm IND$ range consists of ### **Double-Precision Nonstandard FP Numbers** When nonstandard results are generated, the rightmost part of a double-precision FP result is made identical to the leftmost part. ### **EXPONENT ARITHMETIC** When the operand exponent fields are added (as in FP multiplication) or subtracted (as in FP division), the exponent arithmetic performs algebraically in two's complement mode. Such operations take place as if the bias were removed. Exponent underflow and overflow conditions are detected for all single-precision results, but only for the leftmost part of double-precision results. #### **NORMALIZATION** Normalized operands ensure the highest possible precision in the result. An FP number is normalized when the coefficient bit 16 is a 1. Normalization takes place when intermediate results become final results. It occurs by left-shifting the 48-bit fraction until bit 16 is a 1, and by reducing the exponent value by the number of positions shifted. Numbers with zero fractions cannot be normalized and remain equal to zero. When normalizing a double-precision FP number, the entire 96-bit fraction left-shifts until bit 16 is a 1, with a corresponding exponent value reduction. If the coefficient of an intermediate result overflows, the fraction right-shifts 1 bit position and the exponent increases by 1. If the input operands for the FP multiply (32 and 36) and the FP divide (33 and 37) instructions are unnormalized, the result may be unnormalized. # FLOATING-POINT SUM AND DIFFERENCE When two FP operands with unequal exponents are added or subtracted, the hardware aligns copies of these operands before the addition or subtraction performs, as follows: the fraction with the smaller exponent is right-shifted, end-off, by the number of bit positions equal to the difference between the exponents. The maximum shift is 48 positions (single-precision) or 96 positions (double-precision). After copies of the fractions have been aligned in this manner, they are added or subtracted. The result generated is 48 bits (single-precision) or 96 bits (double-precision). When summing coefficients with like signs or subtracting coefficients with unlike signs, the result may overflow/underflow by 1 bit; this bit is saved. In such case, the 48- or 96-bit intermediate result fraction shifts right 1 position, end-off. The overflown bit inserts into the high-order position. The result's exponent increases by 1 to adjust for the right shift of the coefficient. The adjusted exponent and the 48-bit or 96-bit fraction and its sign bit are the final result. #### FLOATING-POINT MULTIPLY The signed exponents for the two input operands to be multiplied are algebraically added, with the result used as an intermediate exponent. The multiplied fractions generate an intermediate product with 96 bits (single-precision) or 192 bits (double-precision). The correct sign bit is algebraically determined. If the high-order bit in the product is a 1, the product is already normalized and remains unchanged. If the high-order bit in the product is a zero, the entire 96- or 192-bit product left-shifts 1 bit position and the intermediate exponent decreases by 1. This one-position shift normalizes the product if the original input operands were normalized. The high-order 48 or 96 bits of the product or shifted product become an intermediate coefficient. If the final intermediate exponent indicates a standard FP number, the intermediate exponent and the intermediate coefficient with its sign bit are the final result. ### FLOATING-POINT DIVIDE During execution of an FP divide instruction, the divisor (Xj or XXj) exponent is subtracted from the dividend (Xk or XXk) exponent, and the signed result provides an intermediate exponent. The dividend (Xk or XXk) fraction is divided by the divisor (Xj or XXj) fraction. The result's sign is determined algebraically from the operand signs. If the fraction in Xj or XXj is initially unnormalized and can be divided into the fraction in Xk or XXk by a factor equal to or exceeding 2, a divide fault occurs, setting UCR bit 55, with an interrupt (when enabled). If no error occurs, the intermediate quotient generated is 48 or 96 bits. When the divisor can be divided into the dividend by a factor equal to or exceeding 1, but less than 2, an overflow bit also generates. If the overflow bit is a zero, the sign bit and the 48- or 96-bit fraction require no further adjustment. When the overflow bit is a 1, the 48- or 96-bit fraction right-shifts 1 position, end-off, and the overflow bit inserts into the high-order bit position. In such a case, the exponent increases by 1 to compensate for the shift. The intermediate exponent and the intermediate fraction (with its sign) then transfer as the final result to the Xk register. 60458890 A II-2-53 #### **FLOATING-POINT END CASES** Tables II-2-12 through II-2-20 list FP end cases. The nomenclature used is as follows: - N Standard FP number: $(3000)_{16} \le \text{exponent} < (5000)_{16} \text{ nonzero, coefficient normalized or unnormalized.}$ - O Zero: sign bit followed by 63 zero bits. - Z1 Zero: FP numbers with exponents in the range $0000_{16} \le \text{exponent} < 1000_{16}$ . - Underflow, zero: FP numbers with exponents in the range $1000_{16} \le \text{exponent} < 3000_{16}$ . - Z3 Zero: An unnormalized FP number with a zero coefficient and a standard exponent. That is, $3000_{16} \le \text{exponent} < 5000_{16}$ . - INF FP numbers with exponents in the range $5000_{16} \le \text{exponent} < 7000_{16}$ . - $\infty$ Infinite: The nonstandard FP number sign, 5000 0000 0000 0000 $_{16}$ . - INDEF FP numbers with exponents in the range $7000_{16} \le \text{exponent} \le 7 \text{FFF}_{16}$ . - +IND Indefinite: The nonstandard FP number 7000 0000 0000 0000<sub>16</sub>. - INDC A result of indefinite generated by the FP compare instruction. That is, a value for X1R = $8000\ 0000_{16}$ . - S Algebraic sum of two FP numbers (excluding Z3). - D Algebraic difference of two FP numbers (excluding Z3). - P Algebraic product of two FP numbers (excluding Z3). - Q Algebraic quotient of two FP numbers (excluding Z3). - DVF Divide fault condition. - OVL Exponent overflow, FP. - UNL Exponent underflow, FP. - LOS Loss of significance, FP. - IND Indefinite, FP. Table II-2-12. FP Compare Results | | | Standard N | lumbers | Nonstandard Numbers | | | | | |-------------|-------------------------------|-------------------------------|-------------------|---------------------|------------|--------|--------|--------| | Xj<br>Xk | +N | -N | +23 | -z3 | +Z1<br>+Z2 | +INF | -INF | +INDEF | | +N | +D, +Z2<<br>-D, -Z2><br>+Z3 = | < | +D, +Z2<<br>+Z3 = | < | < | > | < | | | -n | > | +D, +Z2<<br>-D, -Z2><br>+Z3 = | > | -D, -Z2><br>+Z3 = | > | > | < | | | +23 | -D, -Z2><br>+Z3 = | < | +23 = | < | < | > | < | Note 1 | | <b>-</b> Z3 | > | +D, +Z2<<br>+Z3 = | > | +Z3 = | > | > | < | | | +Z1<br>+Z2 | > | < | > | < | = | > | < | | | +INF | < | < | < | < | < | Note 1 | < | | | -INF | > | > | <b>&gt;</b> | > | > | > | Note 1 | · | | +INDEF | Note 1 | | | | | | | | Note: 1. FP branch instructions perform normal exit and record FP indefinite (UCR 61). FP compare instructions set X1 to INDC and record FP indefinite (UCR 61), except when UMR 61 is set traps are enabled, in which case X1 is unaltered. Table II-2-13. FP Sum Results, UM Clear | | | Standard N | Numbers | | Nonstandard Numbers | | | | | | |----------------------------|-------------------------|------------------------|------------------------|------------------------|---------------------|---------|----------|----------------|--|--| | Xj<br>Xk | +N | -n | +23 | -Z3 | +Z1<br>+Z2 | +INF | -INF | <u>+</u> Indef | | | | +n | +S<br>+ © OVL<br>+0 UNL | +S<br>+0 UNL<br>+0 LOS | +S<br>+0 UNL<br>+0 LOS | +S<br>+0 UNL<br>+0 LOS | +N<br>+O UNL | +& 0VL | +@ OVL | +IND IND | | | | -N | | -S<br>- OVL<br>+O UNL | -S<br>+0 UNL<br>+0 LOS | -S<br>+0 UNL<br>+0 LOS | -N<br>+O UNL | +co ovl | +∞ OVL | +IND IND | | | | +23 | | | +0 LOS | +0 LOS | +0 LOS | +∞ 0VL | +∞ 0VL | +IND IND | | | | -z3 | | | | +0 LOS | +0 LOS | +∞ 0VL | +∞ 0VL | +IND IND | | | | <u>+</u> Z1<br><u>+</u> Z2 | | | +0 LOS | +0 LOS | +0 | +∞ 0VL | +co ovl | +IND IND | | | | +INF | | | | - | | +∞ 0VL | +IND IND | +IND IND | | | | +INF | | | | | | | +∞ ovl | +IND IND | | | | +INDEF | | | | | | | | +IND IND | | | Table II-2-14. FP Sum Results, UM Set | | | Standard | Numbers | Nonstandard Numbers | | | | | | |-------------|--------------------------|--------------------------|--------------------------|--------------------------|---------------|-------------------------|----------|---------|--| | Xj<br>Xk | +N | -n | +23 | -z3 | +Z1<br>+Z2 | +INF | -INF | +INDEF | | | +N | +S<br>+co OVL<br>+Z2 UNL | +S<br>+Z2 UNL<br>+Z3 LOS | +S<br>+Z2 UNL<br>+Z3 LOS | +S<br>+Z2 UNL<br>+Z3 LOS | +N<br>+Z2 UNL | +∞ 0VL | -ω OVL | +IND IN | | | <b>-</b> N | | -S<br>-& OVL<br>+Z2 UNL | -S<br>-Z2 UNL<br>+Z3 LOS | -S<br>-Z2 UNL<br>+Z3 LOS | -N<br>-Z2 UNL | +\omega OVL +\omega OVL | -ω OVL | +IND IN | | | +Z3 | | | +Z3 LOS | +Z3 LOS | +z3 Los | +∞ 0VL | +∞ OVL | +IND IN | | | <b>-</b> Z3 | | | | +z3 Los | +Z3 LOS | +co ovl | +ω ovl | +IND IN | | | +Z1<br>+Z2 | | | +Z3 LOS | +Z3 LOS | +0 | +co ovl | +∞ 0VL | +IND IN | | | +INF | | | | | | +co ovl | +IND IND | +IND IN | | | +INF | | | | | | | -co ovl | +IND IN | | | +INDEF | | | | | | | | +IND IN | | Table II-2-15. FP Difference Results, UM Clear | | | Standard Numbers | | | | Nonstandard Numbers | | | | | |----------------------------|------------------------|------------------------|------------------------|------------------------|--------------|---------------------|----------|----------|--|--| | Хj | +N | -N | +23 | -z3 | <u>+</u> Z1 | +INF | -INF | +INDEF | | | | Xk | | · | | Í | +Z2 | | | | | | | +N | -D<br>+0 UNL<br>+0 LOS | +D<br>+© OVL<br>+O UNL | +D<br>+0 UNL<br>+0 LOS | +D<br>+0 UNL<br>+0 LOS | +N<br>+O UNL | -ω OVL | +∞ 0VL | +IND IND | | | | -и | -D<br>-© OVL<br>+O UNL | +D<br>+0 UNL<br>+0 LOS | -D<br>+0 UNL<br>+0 LOS | -D<br>+0 UNL<br>+0 LOS | -N<br>+O UNL | −∞ ovl | +∞ 0VL | +IND IND | | | | +23 | -D<br>+0 UNL<br>+0 LOS | +D<br>+0 UNL<br>+0 LOS | +0 LOS | +0 LOS | +0 LOS | +c ovr | +∞ 0VL | +IND IND | | | | -Z3 | -D<br>+0 UNL<br>+0 LOS | +D<br>+O UNL<br>+O LOS | +0 LOS | +0 LOS | +0 LOS | + © 0VL | +∞ 0VL | +IND IND | | | | <u>+</u> Z1<br><u>+</u> Z2 | -N<br>+O UNL | +N<br>+O UNL | +0 LOS | +0 LOS | +0 | +∞ OVL | +co ovl | +IND IND | | | | +INF | +© OVL | +∞ 0VL | +∞ 0VL | +∞ 0VL | +co ovl | +IND IND | + @ OVL | +IND IND | | | | -INF | -co ovl | -ω ovl | -∞ ovl | - co ovl | - co ovl | −œ ovl | +IND IND | +IND IND | | | | +INDEF | +IND IND | | Table II-2-16. FP Difference Results, UM Set | | | Standard | Numbers | | Nonstandard Numbers | | | | | |------------|---------------------------|--------------------------|--------------------------|--------------------------|---------------------|----------|----------|----------|--| | Xj<br>Xk | +N | -N | +23 | -z3 | +z1<br>+z2 | +INF | -INF | +INDEF | | | +N | +D<br>+Z2 UNL<br>+Z3 LOS | +D<br>+ OOVL<br>+Z2 UNL | +D<br>+Z2 UNL<br>+Z3 LOS | +D<br>+Z2 UNL<br>+Z3 LOS | +N<br>+Z2 UNL | −∞ ovl | +ω OVL | +IND IND | | | -N | -D<br>- OO OVL<br>-Z2 UNL | +D<br>+Z2 UNL<br>+Z3 LOS | -D<br>-Z2 UNL<br>+Z3 LOS | -D<br>-Z2 UNL<br>+Z3 LOS | -N<br>-Z2 UNL | -ω ovl | +co OVL | +IND IND | | | +23 | -D<br>-Z2 UNL<br>+Z3 LOS | +D<br>+Z2 UNL<br>+Z3 LOS | +Z3 LOS | +z3 LOS | +Z3 LOS | + co ovl | +∞ OVL | +IND IND | | | -z3 | -D<br>+Z2 UNL<br>+Z3 LOS | +D<br>+Z3 UNL<br>+Z3 LOS | +Z3 LOS | +Z3 LOS | +Z3 LOS | + co ovr | +∞ ovl | +IND IND | | | +Z1<br>+Z2 | -N<br>-Z2 UNL | +N<br>+Z2 UNL | +z3 LOS | +Z3 LOS | +0 | + 0 0VL | + © OVL | +IND IND | | | +INF | + 0 OVL | +∞ 0VL | +∞ 0VL | + 00 OVL | +© OVL | +IND IND | + 0 0VL | +IND IND | | | -INF | -co ovl | -co ove | −∞ ovl | −∞ ovr | -ω ovl | -ω OVL | +IND IND | +IND IND | | | +INDEF | +IND IND | Table II-2-17. FP Product Results, UM Clear | | · | Standard | Numbers | | Nonstandard Numbers | | | | | | |------------|-------------------------------|-------------------------------|-------------------------------|------------------------------|---------------------|----------|----------|----------|--|--| | Xj<br>Xk | +N | -N | +23 | -z3 | +Z1<br>+Z2 | +INF | -INF | +INDEF | | | | +N | +P<br>+© OVL<br>+0 UNL<br>+Z3 | -P<br>- OVL<br>+O UNL<br>+Z3 | +0 OVL<br>+0 UNL<br>+23 | +0 OVL<br>+0 UNL<br>+23 | +0 | -co ovr | +co ovl | +IND IND | | | | -и | | +P<br>+© OVL<br>+O UNL<br>+Z3 | - \omega OVL<br>+0 UNL<br>+Z3 | +\infty OVL<br>+0 UNL<br>+Z3 | +0 | -ω ovl | +co OVL | +IND IND | | | | +23 | | | +\infty OVL<br>+0 UNL<br>+Z3 | - co ovl<br>+0 unl<br>+23 | +0 | +∞ OVL | +∞ 0VL | +IND IND | | | | -z3 | | | | + © OVL<br>+ O UNL<br>+ Z 3 | +0 | - co ove | +∞ ovl | +IND IND | | | | +Z1<br>+Z2 | | | +0 | +0 | +0 | +IND IND | +IND IND | +IND IND | | | | +INF | | | ` | | | +co ovl | -co ovr | +IND IND | | | | -INF | | | | | | | +00 OVL | +IND IND | | | | +INDEF | | | · | | | | | +IND IND | | | Table II-2-18. FP Product Results, UM Set | · | | Standard | l Numbers | | Nonstandard Numbers | | | | |--------|--------------------------------|--------------------------------|--------------------------|--------------------------|---------------------|----------|----------|----------| | Xj | +N | -n | +23 | -z3 | <u>+</u> Z1 | +INF | -INF | +INDEF | | Xk | | | | | <u>+</u> Z2 | | | | | +N | +P<br>+© OVL<br>+Z2 UNL<br>+Z3 | -P<br>-@ OVL<br>+Z2 UNL<br>+Z3 | +P OVL<br>+Z2 UNL<br>+Z3 | -P OVL<br>+Z2 UNL<br>+Z3 | +0 | −∞ ovl | +ω OVL | +IND IND | | -N | | +P<br>+© OVL<br>+Z2 UNL<br>+Z3 | -P OVL<br>-Z2 UNL<br>+Z3 | +P OVL<br>+Z2 UNL<br>+Z3 | +0 | −œ ovl | +ω ovl | +IND IND | | +23 | | | +P OVL<br>+Z2 UNL<br>+Z3 | -P OVL<br>-Z2 UNL<br>+Z3 | +0 | +© 0VL | -ω ovl | +IND IND | | -z3 | | | | +P OVL<br>+Z2 UNL<br>+Z3 | +0 | -© 0VL | +∞ 0VL | +IND IND | | | | | | | | | | | | +Z1 | | | +0 | +0 | +0 | +IND IND | +IND IND | +IND IND | | +Z2 | | | | | | | | | | +INF | | | | | | +œ ovl | - ω ovl | +IND IND | | -INF | | | | | | | +00 OVL | +IND IND | | +INDEF | | | | | | | | +IND IND | Note: This chart is for traps disabled. For traps enabled, replace +IND with Xk. Table II-2-19. FP Quotient Results, UM Clear | | | Standard N | umbers | • | | Nonstandar | d Numbers | | |----------------------------|----------------------------------------------|------------------------------------------|---------|---------|------------|------------|-----------|----------| | X <sub>j</sub> | +N | -N | +23 | -Z3 | +Z1<br>+Z2 | +INF | -INF | +INDEF | | +N | +Q<br>+\infty OVL<br>+0 OVL<br>+Z3<br>Xk DVF | -Q<br>- ∞ OVL<br>+0 OVL<br>+Z3<br>Xk DVF | Xk DVF | Xk DVF | Xk DVF | +0 | +0 | +IND IND | | -N | -Q<br>+ © OVL<br>+0 UNL<br>+Z3<br>Xk DVF | +Q<br>+ © OVL<br>+O UNL<br>+Z3<br>Xk DVF | -P OVL | +P OVL | Xk DVF | +0 | +0 | +IND IND | | +23 | + co ovl<br>+0 unl<br>+z3 | +0 OVL<br>+0 UNL<br>+23 | Xk DVF | Xk DVF | Xk DVF | +0 | +0 | +IND IND | | -z3 | +\infty OVL<br>+0 UNL<br>+Z3 | + 0 OVL<br>+0 UNL<br>+Z3 | Xk DVF | Xk DVF | Xk DVF | +0 | +0 | +IND IND | | <u>+</u> z1<br><u>+</u> z2 | +0 | +0 | +0 | +0 | Xk DVF | +0 | +0 | +IND IND | | +INF | +co ovl | +co ovl | +∞ 0VF | −œ ovf | Xk DVF | +IND IND | +IND IND | +IND IND | | -INF | +∞ 0VL | + co ovl | −∞ ovf | +co ovf | Xk DVF | +IND IND | +IND IND | +IND IND | | +INDEF | +IND IND | +IND IND | IND IND | IND IND | Xk DVF | +IND IND | +IND IND | +IND IND | Table II-2-20. FP Quotient Results, UM Set | | | Standard | Numbers | | 1 | Nonstandar | i Numbers | | |------------|--------------------------------------------|-------------------------------------------------|------------|-----------|-------------|------------|------------|----------| | Хj | +N | -N | +23 | -z3 | <u>+</u> Z1 | +INF | -INF | +INDEF | | Xk | | * * | | | <u>+</u> Z2 | | | | | +N | +0 +<br>+© OVL<br>+Z2 UNL<br>+Z3<br>Xk DVF | -0<br>-& OVL<br>-Z2 UNL<br>+Z3<br>Xk DVF | Xk DVF | Xk DVF | Xk DVF | +0 | +0 | +IND IND | | -n | -0<br>-∞ ovl<br>+z2 unl<br>+z3<br>Xk dvf | +0 +<br>+\infty OVL<br>+Z2 UNL<br>+Z3<br>Xk DVF | Xk DVF | Xk DVF | Xk DVF | +0 | +0 | +IND IND | | +23 | +Q OVL<br>+Z2 UNL<br>+Z3 | -Q OVL<br>+Z2 UNL<br>+Z3 | Xk DVF | Xk DVF | Xk DVF | +0 | +0 | +IND IND | | -z3 | -Q OVL<br>-Z2 UNL<br>+Z3 | +Q OVL<br>+Z2 UNL<br>+Z3 | Xk DVF | Xk DVF | Xk DVF | +0 | +0 | +IND IND | | +Z1<br>+Z2 | +0 | +0 | +0 | +0 | Xk DVF | +0 | +0 | +IND IND | | +INF | +∞ 0VL | −∞ 0VL | +co ove | −∞ ovf | +ω OVF | +IND IND | +IND IND | +IND IND | | -INF | -co ovl | +00 0VL | −∞ ovf | +∞ ovf | - co ovf | +IND IND | +IND IND | +IND IND | | +INDEF | +IND IND | Note: | This chart | is for tr | aps disabl | ed. For t | raps enabl | ed, replac | e +IND wit | h Xk• | Note: This chart is for traps disabled. For traps enabled, replace the with his ### PROGRAM MONITORING The CP provides a debug feature to aid the debugging of new Virtual State programs. The debug feature causes a debug trap interrupt (when enabled), when a CM access of a given type into a given PVA range occurs. The user can specify up to 32 access ranges and 5 access types for simultaneous debugging. ### **DEBUG** When enabled, the debug feature tests all executive state memory accesses by scanning a list of up to 32 entries of selected access type and PVA range combinations. When a match is found, UCR bit 56 sets and, if enabled, a trap interrupt occurs. A debug address range may span an entire process virtual segment or any contiguous byte field within the segment. Any or all of the following access types can be selected: - Data read. - Data write. - Instruction fetch (excluding target instruction fetch). - Branch or return target instruction fetch (excluding call target instruction fetch). - Call target instruction fetch. Debug is enabled by setting UMR bit 56 and the trap enable flip-flop. Debug is controlled by the following: - Debug list lists access types and PVA ranges. - Debug list pointer register PVA of first entry in debug list. - Debug mask register enables/disables any or all access types. - Debug index registers record number of debug list entries scanned during debug of a single instruction. ### **Debug List** The debug list has up to 32 double-word entries (refer to figure II-2-9), each one aligned at a word boundary. The end of list (debug code bit 5) is interpreted after all other bits in the same debug code have been interpreted and acted upon. Any or all access types can be selected for debug by the debug code. Access types are defined by the type of access privilege required (read, write, or execute). ### **Debug List Pointer Register** This register is a process register containing a PVA that points to the first debug list entry. ### **Debug Index Register** This register is a process register which increments as the debug scan proceeds. It contains a 6-bit word index that is added to the debug list pointer register contents. This generates the debug list entry addresses during a debug scan initiated by each instruction accessing virtual memory. The debug index register format is as follows: #### **Debug Mask Register** This register (figure II-2-10) is a process register which activates the access types selected in the debug code field of a debug list entry. Each access type selected in the debug code is activated for debugging only if the corresponding debug mask bit is also set, as shown in figure II-2-10. Figure II-2-9. Debug List Entry Figure II-2-10. Debug Condition Select ### **Enabling Debug** The debug operation may be enabled by any of the following: - Exchange to a Virtual State process where traps are enabled and UMR 56 is set. - Return (04) to a Virtual State process where the return operation enables traps and UMR 56 is set in the user mask register being loaded. - Set UMR 56 by way of Copy-To-State-Register instruction when traps are enabled. The debug flags and index must be zero prior to execution of the Copy-To-State-Register instruction or an undefined initial debug scan follows the instruction. - Enable traps by way of Copy-To-State-Register instruction when UMR 56 is set. The debug flags and index must be zero prior to execution of the Copy-To-State-Register instruction or an undefined initial debug scan follows the Copy-To-State-Register instruction. ### **Debug Scan Operation** Debug conditions apply to specific instructions as described in table II-2-21. BN(low) and BN(high) are matched against the address of the leftmost byte of a piece of information only, whether it is a word, half word, byte string, or 16-bit instruction. The match is as follows: $BN(low) \leq Address \leq BN(high)$ If BN(low) exceeds BN(high) in any debug list entry, the scan proceeds to the next double-word entry. If either BN(low) or BN(high) bit 32 is set, the comparison results are undefined. The CP starts the debug list scan (after instruction fetch but before instruction execution) if all of the following conditions exist: - Traps are enabled. - Debug mask bit in user mask register is set (UMR 56). - One or more bits in debug mask register are applicable to the type of access. Refer to table II-2-19. - End-of-list flag in debug mask register is clear. When the debug scan initiates, the debug scan-in-progress flag is clear and the debug index register is zero. The debug scan locates a debug list entry by adding the debug list pointer and debug list index registers. The debug scan proceeds (not necessarily in the exact order given) as follows: - 1. Set debug scan-in-process flag in debug mask register. - Read first half of debug list entry. If end-of-list code, set end-of-list-seen flag in debug mask register. - 3. Add one to debug index register and read second half of debug list entry. - 4. Set UCR 56 (triggering a trap interrupt) if a debug list match is found as follows: - Accessed PVA is within address bracket of debug list entry. - One or more debug code bits of debug list entry match the type of access, with the corresponding bit set in the debug mask register. - 5. If step 4 triggered a debug interrupt, proceed to step 8. - 6. If end-of-list flag is set, or 32 entries have been read, proceed to step 8. - 7. Add one to debug index register and repeat from step 2. - 8. Clear debug index register, debug scan-in-process flag, and end-of-list-seen flag to complete the debug scan. - 9. Execute the instruction triggering the scan. Debug list scanning prior to instruction execution includes all instruction results except the following (which may occur before the debug scan completes): - 1. Setting the page-used bit, either explicitly as in test and set page instruction (16), or implicitly as with any instruction. - 2. Setting of condition register bits. - 3. Rounding of AO on call instructions. - 4. Storing the environment into SFSA on call instructions (a debug trap also stores the environment into SFSA). The exception testing and debug scan are not constrained to occur in any given sequence relative to each other. Two or more matches within the same entry produce only one trap. The traps due to execution testing may occur concurrently with a debug trap (several bits set in MCR and/or UCR) or separately, either before or after the debug scan. #### Interrupts During Debug Scan The debug index and flags provide the means for properly initiating, resuming, and terminating debug scan operations, particularly when an instruction's execution has been inhibited by one or more interrupts. These interrupts may either be trap or exchange interrupts. Exchange interrupts cause the flags and debug index register to be stored in the exchange package, for example, to allow resumption of a partially completed debug entry list scan. On trap interrupts, the processor retains the flags and index register to allow proper completion of the debug scan upon return from the trap interrupt. When enabling traps during the processing of a debug trap interrupt, software must not reenable debug to prevent loss of integrity of the interrupted debug scan. # Debug-Software Interaction, Debug Enabled The following items describe interactions with the debug facility that are available with debug enabled: - Debug mask bits 11 through 15 of debug mask register may be set or cleared by way of a Copy-To-State-Register instruction; the new bits will be in effect for the debug scan on the instruction following the copy instruction. - Any copy to the debug flags or index must clear both flags and the index or the following debug scan is undefined. - UMR 56 may be cleared or traps disabled by way of a Copy-To-State-Register instruction with no scan performed on the instruction following the copy instruction. - A return instruction disables debug by loading a user mask register with bit 56 clear, or by entering CYBER 170 State. In such a case, no scan is performed on the next instruction. ### Debug-Software Interaction, Debug Disabled When debug is disabled after a debug match (after which an exchange or trap interrupt occurs), the scan-in-progress flag sets and, if applicable, the end-of-list flag sets. In this case, the following software action may be taken through a Copy-To-State-Register instruction after a trap interrupt, or through altering the exchange package in CM after an exchange interrupt: - Any of the debug mask register bits 11 through 15 may be set or cleared. The new mask bits affect the first debug scan when debug is reenabled for this process. - Debug flags and index may be cleared to reinitiate the debug scan from the beginning when debug is reenabled. - Debug index may be modified by multiples of 2 as the final value is greater than or equal to 1 and less than or equal to 61. - End-of-list-seen flag may be set to terminate the current debug scan when debug is reenabled. The scan-in-progress flag may (but need not) be altered when setting this flag. - The end-of-list-seen flag may be cleared and the scan-in-progress flag set to continue a scan that terminated. The debug index may also be modified by multiples of 2 as long as the final value is greater than or equal to 1 and less than or equal to 61. When a debug match is absent, the debug may also be disabled by any of the following: - Trap interrupt. - Exchange interrupt. - Copy-To-State-Register instruction which clears UMR 56 or disables traps. - Call to CYBER 170 State. - Return which clears UMR 56. - Return to CYBER 170 State. When a debug match is absent, and the debug is disabled by any of the six methods described in the preceding paragraph, only the following software actions may be taken: - Any of the debug mask register bits 11 through 15 may be set or cleared. The new mask bits affect the first debug scan when debug is enabled for this process. - The debug flags and index may be cleared to reinitiate the full debug scan when debug is enabled. Table II-2-21. Debug Conditions (Sheet 1 of 5) | 0pcode | Mnemonic | Instruction | Debug Conditi | on | |-----------|------------|---------------------------|---------------------------------------------------|----------------------------------| | | | Bit 0: Data Read | | | | DO-D8 | LBYTS,S | Load bytes, immediate | LO ≤ Aj+Xi+D | <u> </u> | | A2 | LXI | Load word, indexed | LO < Aj+8*Xi+8*D | <u> </u> | | 82 | LX | Load word | LO ≤ Aj+8*Q | ≤ ні | | <b>A4</b> | LBYT,X0 | Load bytes | LO ≤ Aj+Xi+D | <u>&lt;</u> HI | | 88 | LBIT | Load bit | LO < Aj+Q+X0/8 | <u> </u> | | A0 | LAI | Load address, indexed | LO < Aj+Xi+D | <u> </u> | | 84 | LA | Load address | LO ≤ Aj+Q | <u> </u> | | 80 | LMULT | Load multiple | LO ≤ Aj+8*Q | ≤ ні | | 70 | ADDN,Aj,XO | Decimal sum | LO \(\leq \text{Aj+01}\) LO \(\leq \text{Ak+02}\) | <u>&lt;</u> HI<br><u>&lt;</u> HI | | 71 | SUBN,Aj,XO | Decimal difference | LO \(\leq \text{Aj+01}\) LO \(\leq \text{Ak+02}\) | <u>&lt;</u> HI<br><u>&lt;</u> HI | | 72 | MULN,Aj,XO | Decimal product | LO \(\leq \text{Aj+01}\) LO \(\leq \text{Ak+02}\) | ≤ HI ≤ HI | | 73 | DIVN,Aj,XO | Decimal quotient | LO \(\leq \text{Aj+01}\) LO \(\leq \text{Ak+02}\) | <hr/> ≤ HI | | E4 | SCIN,Aj,XO | Decimal scale | LO ≤ Aj+01 | ≤ HI | | E5 | SCLR,Aj,XO | Decimal scale, rounded | LO ≤ Aj+01 | <u>≤</u> ні | | 74 | CMPN,Aj,XO | Decimal compare | L0 ≤ Aj+01<br>L0 ≤ Ak+02 | <u>≤</u> ні<br><u>≤</u> ні | | 77 . 4 | CMPB,Aj,XO | Byte compare | LO ≤ Aj+01<br>LO ≤ Ak+02 | ≤ HI | | Е9 | CMPC,Aj,XO | Byte compare, collated | LO ≤ Aj+01<br>LO ≤ Ak+02<br>LO ≤ Ai+D | <u> </u> | | F3 | SCNB,XO | Byte scan while nonmember | LO < Ak+01<br>LO < Ai+D | ≤ HI ≤ HI | Table II-2-21. Debug Conditions (Sheet 2 of 5) | Opcode | Mnemonic | Instruction | Debug Condition | n | |-----------|-------------|-----------------------------|------------------------------------------------------------------------------------------|----------------| | | | Bit 0: Data Read Contin | ued | | | E8 | TRANB,Aj,XO | Byte translate | LO ≤ Aj+O1<br>LO ≤ Ai+D | ≤ HI<br>≤ HI | | 76 | MOVB,Aj,XO | Move bytes | LO ≤ Aj+01 | <u>&lt;</u> HI | | ED | EDIT,Aj,XO | Edit | $\begin{array}{c} \text{LO} \leq \text{Aj+O1} \\ \text{LO} \leq \text{Ai+D} \end{array}$ | ≤ HI<br>≤ HI | | 75 | MOVN,Aj,XO | Numeric move | LO ≤ Aj+01 | <u>&lt;</u> HI | | F4 | CALDF,Aj,XO | Calculate subscript and add | $\begin{array}{c} \text{LO} \leq \text{Aj+Ol} \\ \text{LO} \leq \text{Ai+D} \end{array}$ | ∠ HI<br>∠ HI | | В5 | CALLSEG | Call indirect | LO ≤ Aj+8*Q | <u>≤</u> HI | | 04 | RETURN | Return | LO ≤ A2 | <u> </u> | | 06 | POP | Pop | LO ≤ A2 | <u>&lt;</u> HI | | 14 | LBSET | Test and set bit | LO ≤ Aj+XO/8 | <u>&lt;</u> HI | | В4 | CMPXA | Compare swap | LO ≤ Aj | <u>&lt;</u> HI | | FA | CMPI,Xi,D | Compare immediate data | LO ≤ Ak+01 | <u>&lt;</u> HI | | FB | ADDI,Xi,D | Add immediate data | LO ≤ Ak+O1 | | | | : , | Bit 1: Data Write | | | | D8-DF | SBYTS,S | Store bytes, immediate | LO ≤ Aj+Xi+D | <u> </u> | | А3 | SXI | Store word, indexed | LO ≤ Aj+8*Xi+8*D | <u> </u> | | 83 | SX | Store word | LO ≤ Aj+8*Q | ≤ HI | | A5 | SBYT,XO | Store bytes | LO ≤ Aj+Xi+D | <u>&lt;</u> HI | | 89 | SBIT | Store bit | $LO \leq Aj+Q+XO/8$ | ≤ HI | | <b>A1</b> | SAI | Store address, indexed | LO ≤ Aj+Xi+D | ∠ HI | | 85 | SA | Store address | LO ≤ Aj+Q | ≤ HI | | 81 | SMULT | Store multiple | LO ≤ Aj+8*Q | ≤ HI | | 70 | ADDN,Aj,XO | Decimal sum | LO ≤ Ak+02 | ≤ HI | Table II-2-21. Debug Conditions (Sheet 3 of 5) | 0pcode | Mnemonic | Instruction | Debug Condition | on | |--------|---------------|--------------------------|-----------------------|----------------| | | | Bit 1: Data Write Contin | ued | | | 71 | SUBN,Aj,XO | Decimal difference | LO ≤ Ak+02 | <u> </u> | | 72 | MULN,Aj,XO | Decimal product | LO ≤ Ak+02 | ≤ HI | | 73 | DIVN,Aj,XO | Decimal quotient | LO ≤ Ak+02 | ≤ HI | | E4 | SCLN,Aj,XO | Decimal scale | LO ≤ Ak+O2 | ≤ ні | | E5 | SCLR,Aj,XO | Decimal scale, rounded | LO ≤ Ak+O2 | ≤ HI | | EB | TRANB, Aj, XO | Byte translate | LO ≤ Ak+O2 | ≤ ні | | 76 | MOVB,Aj,XO | Move bytes | LO ≤ Ak+O2 | <u>≤</u> нI | | ED | EDIT,Aj,XO | Edit | LO ≤ Ak+O2 | <u>&lt;</u> нI | | 75 | MOVN,Aj,XO | Numeric move | LO ≤ Ak+02 | <u>&lt;</u> HI | | В5 | CALLSEG | Call indirect | LO $\leq$ AQ+7, mod 8 | <u> </u> | | во | CALLREL | Call relative | LO $\leq$ AQ+7, mod 8 | <u> </u> | | 14 | LBSET | Test and set bit | LO ≤ Aj+XO/8 | ≤ HI | | В4 | СМРХА | Compare swap | LO ≤ Aj | ≤ ні | | F9 | MOVI,Xi,C | Move immediate data | LO ≤ Ak+01 | <u> </u> | | FB | ADDI,Xi,D | Add immediate data | LO ≤ Ak+O1 | <u> </u> | Bit 2: Instruction Fetch All instruction fetches initiate a debug trap interrupt when the PVA accessed is within an address bracket on the debug list. However: - The load bytes relative (DO-D7) reference to P+Q is not detected. - Unimplemented instruction, program error, and execute algorithm is not necessarily detected. - The descriptors for BDP instructions are not detected. - The test is applied for each instruction rather than for each instruction word. Table II-2-21. Debug Conditions (Sheet 4 of 5) | Opcode | Mnemonic | Instruction | Debug Condit | ion | |------------|----------|-------------------------------------------|--------------|----------------| | | | Bit 3: Branch Target Instru | ction | | | 94 | BRXEQ | Branch on equal | LO ≤ P+2*Q | <u>≤</u> ні | | 95 | BRXNE | Branch on not equal | LO ≤ P+2*Q | ≤ ні | | 96 | BRXGT | Branch on greater than | LO ≤ P+2*Q | ≤ ні | | 97 | BRXGE | Branch on greater than or equal | LO ≤ P+2*Q | ≤ ні | | 90 | BRREQ | Branch on half word<br>equal | LO ≤ P+2*Q | ≤ ні | | 91 | BRRNE | Branch on half word not equal | LO ≤ P+2*Q | ≤ ні | | 92 | BRRGT | Branch on half word greater than | LO ≤ P+2*Q | <u>&lt;</u> HI | | 93 | BRRGE | Branch on half word greater than or equal | LO ≤ P+2*Q | <u>&lt;</u> HI | | 9C | BRINC | Branch and increment | LO ≤ P+2*Q | <u>≤</u> ні | | 9р | BRSEG | Branch on segments unequal | LO ≤ P+2*Q | <u>&lt;</u> HI | | 2E | BRREL | Branch relative | LO ≤ P+2*Xk | <u>≤</u> ні | | 2F | BRDIR | Branch intersegment | LO ≤ Aj+2*Xk | <u>≤</u> нI | | 98 | BRFEQ | FP branch on equal | LO ≤ P+2*Q | <u>≤</u> ні | | 99 | BRFNE | FP branch on not equal | LO ≤ P+2*Q | <u>≤</u> нI | | 9A | BRFGT | FP branch on greater than | LO ≤ P+2*Q | <u> </u> | | 9в | BRFGE | FP branch on greater than or equal | LO ≤ P+2*Q | ≤ ні | | 9Е | BROVR | FP branch on overflow | LO ≤ P+2*Q | ≤ HI | | 9E | BRUND | FP branch on underflow | LO ≤ P+2*Q | <u>≤</u> ні | | 9E | BRINF | FP branch on indefinite | LO ≤ P+2*Q | <u>≤</u> ні | | 04 | RETURN | Return | LO ≤ FINAL P | <u> </u> | | 9 <b>F</b> | BRCR | Branch on condition register | LO ≤ P+2*Q | ≤ нт | 60458890 A Table II-2-21. Debug Conditions (Sheet 5 of 5) | Opcode | Mnemonic | Instruction | Debug Condition | |--------|----------|-------------------------|--------------------------------| | | Ві | t 4: Call Target Instru | uction Fetch | | В5 | CALLSEG | Call indirect | LO ≤ CBP ≤ HI | | во | CALLREL | Call relative | $LO \leq P+8*Q, mod 8 \leq HI$ | # VIRTUAL AND CENTRAL MEMORY PROGRAMMING Figure II-2-11 shows how a process virtual address (PVA) converts to a system virtual address (SVA), and then to a real memory address (RMA). The operating system provides a segment descriptor table and a system page table to make the conversion possible. #### PROCESS VIRTUAL MEMORY To the user, memory is a set of segments in process virtual memory space. Each segment is a contiguous byte string of $2^{31}-1$ bytes. A maximum of 4096 segments may exist for each process at any one time. During process execution, the CP presents process virtual addresses (PVAs) for hardware translation, first to system virtual addresses (SVAs), and then to real memory addresses (RMAs) where the requested data resides in CM. The PVA is the address seen by the user and used by executing code. The PVA may identify a P register address or a CM operand address. The PVA format is shown in figure II-2-12. | 16 19 20 | 31 32 33 | 63 | |----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RN | SEG 0 | BN | | Field | Name | Description | | RN | Ring Number | Access privilege indicator that selectes 1 of 16 rings. Refer to Access Protection in this section for further information. | | SEG | Segment | Process segment number. The same shared segment may be addressed by different segment numbers. | | BN Byte number | | Byte location within the $2^{31}$ -1 bytes in a segment. Bit 32 in the final PVA used is a validity indicator and must be zero or the PVA is rejected. Bit 32 in an A register may a one provided indexing or displacement changes this bit to a zero in the final PVA. | Figure II-2-12. Process Virtual Address (PVA) Format ## SYSTEM VIRTUAL MEMORY The operating system sees virtual memory as a set of system-wide active segments that totals all of the process segments. An active segment is the virtual memory division for uniquely identifying system data. System virtual addresses (SVAs) address the active segments. Figure II-2-13 shows how hardware translates a PVA to an SVA. In the translation, an active segment identifier (ASID) replaces the RN and SEG fields of the PVA. All segments active in the system are assigned unique ASIDs to ensure unique system data. The 16-bit ASID field in the SVA defines a total of 65,536 active segments that may simultaneously exist in the system. The ASID resides in the segment descriptor table that the operating system maintains for each process. Any number of ASIDs can be listed in various process segment descriptor tables against the same segment. This forms the basis for code sharing. During the translation, hardware also verifies permission to access the segment containing the SVA. This occurs by way of the access protection attributes listed in the segment descriptor table for that segment. Figure II-2-13. System Virtual Address (SVA) Format #### **REAL MEMORY** The operating system sees real memory as pages in CM or external mass storage. It maintains the necessary tables to identify, address, and retrieve the stored information when an executing process requests it. A page ranges in size from 2K bytes to 16K bytes, as selected at system initialization via the page size mask register. CM corresponds with virtual memory by page frames. Page frames are the same size as pages, and provide the means for swapping pages between CM and external mass storage. A page frame may be empty, contain new information being created, or contain a copy of a page from external mass storage that is being examined, modified, or executed. The operating system manages CM by way of demand paging. In demand paging, the CP retrieves the requested page(s) from external mass storage to CM as needed for process execution. This frees the operating system from having to collect in CM all the pages necessary to complete process execution. In operation, the CP executes a process until a page fault occurs, whereby the CP switches execution to another process while it retrieves the page from external mass storage. The CP always retrieves a copy of a page, and not the page itself, from external mass storage. Pages in such storage remain unaltered unless or until the CP overwrites the new page back to its location in external mass storage. (Hardware keeps track of pages in CM which are still true copies of pages in external mass storage.) The CP writes pages back to external mass storage to make room for new pages. The operating system identifies candidate pages for transfer by way of an algorithm which determines the least-used and least-recently-used pages. Hardware uses the system page table in CM (described under Address Tables later in this section) to convert SVAs to RMAs and to complete address translation. In the SVA-to-RMA conversion, hardware uses a hashing algorithm to replace the ASID and PN fields of the SVA with a system/page identifier (SPID) [refer to figure II-2-14]. The SPID resides in the single system page table that the operating system maintains for all processes. Figure II-2-14. Segment/Page Identifier (SPID) Format Once obtained, the SPID provides an index into a list of coincident hashed entries in the system page table. The CP linearly searches up to 32 coincident entries in comparing the true SPID (maintained by the operating system) to the system page table entries. The search continues until a valid page with the requested entry is found, or until 32 entries have been searched. If the requested entry is not found among the 32 entries, a page fault occurs and the CP retrieves the page and accompanying entry from external mass storage. A successful search of the system page table results in identifying the desired page and the corresponding page frame address listed with the SPID. The page frame address lists the destination of the page in real memory. The page offset (carried directly from the SVA) identifies the memory word containing the requested byte. The rightmost 3 bits select the requested byte within the word. The RMA, formed by the page frame address and the page offset, has a format as shown in figure II-2-15. The conversion of the virtual byte number (BN) to the page number and page offset is shown in figure II-2-16. Figure II-2-15. Real Memory Address (RMA) Format Figure II-2-16. Virtual BN-to-Page Number/Page Offset Conversion #### **ADDRESS TABLES** The PVA-to-SVA-to-RMA translation with access protection depends upon the operating system keeping the following tables in CM: - A segment descriptor table (SDT) for each process. Hardware accesses the SDT for converting PVAs to SVAs and for enforcing access protection. - A system page table (SPT) common for all processes. Hardware accesses the SPT for converting SVAs to RMAs and for keeping track of modified/used pages. The PVA-to-RMA Conversion with reference to the address tables is shown in figure II-2-17. Figure II-2-17. PVA-to-RMA Conversion Each process obtaining call-indirect and trap-interrupt target addresses requires binding section segments. Hardware accesses the binding segments during call-indirect instructions and trap interrupts to obtain entry point addresses (code base pointers) and additional access protection information. ### **Segment Descriptor Table** A segment descriptor table (SDT) for each process lists the process segments against the active system segments and provides access protection information. The SDT starts at a word boundary and is defined by the following fields in an incoming exchange package: - Segment table address (STA): An RMA pointing to the first SDT entry. - Segment table length (STL): The number of SDT entries, minus 1. For each process segment, the SDT maintains an entry listing the corresponding ASID and access attributes, and whether or not the segment is a cache bypass segment. Refer to figure II-2-18 for the SDT entry format. The CP reads cache bypass segments directly from CM without copying the accessed information to cache memory. The CP purges the relevant cache entry when it writes cache bypass segments. The CP does not update or purge cache when it reads or writes CM using an RMA stored in hardware such as MPS or JPS. The SDT entry (SDE) lists the ASID corresponding to each segment number. The segment numbers index the table, and combine with the STA to provide the required SDT address. Invalid SDEs can be marked as such; thus, process segment numbers need not form a consecutive set (although this is often the case). An interrupt condition occurs when: - Hardware attempts to use a segment number for which there is no valid SDE. - Hardware attempts to use a segment number which exceeds the segment table length. Each SDE also lists the segment access protection attributes as established by software convention. (Refer to Access Protection in this section for further information.) The information in CM which is subject to change without cache update or purge must be kept in cache bypass segments. For example, Virtual State exchange operations to MPS and JPS use RMAs; thus, the CP does not update cache data because cache is organized by SVAs. (CYBER 170 State exchange operations treat target addresses as PVAs; thus, cache is updated.) | 0123 | 345678 1112 1 <b>5</b> | 32,33<br>16 31 34 39 40 63 | |-------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | RPWP R1 R2 | ASID 01 LOCK | | Field | Name | Description | | VL | Validity | Entry validity indicator 00 Invalid entry. 01 Reserved. 10 Valid entry, regular segment. 11 Valid entry, cache bypass segment. | | XP | Execute<br>permission | Permissible access type indicator 00 Nonexecutable segment. 01 Nonprivileged executable segment. 10 Locally privileged executable segment. 11 Globally privileged executable segment. | | RP | Read<br>permission | Permissible access type indicator 00 Nonreadable segment. 01 Read controlled by key/lock. 10 Read not controlled by key/lock. 11 Binding section segment, read not controlled by key/lock (may be read as if RP = 10). | | WP | Write<br>permission | Permissible access type indicator 00 Nonwritable segment. 01 Write controlled by key/lock. 10 Write not controlled by key/lock. 11 (Reserved). | | R1 | Ring l | <ul> <li>Ring requirement indicator</li> <li>For execute access, RN of PVA used may not be less the R1 of the accessed segment's SDE.</li> <li>For write access, RN of PVA used may not exceed R1 of the accessed segment's SDE.</li> </ul> | | R2 | Ring 2 | Ring requirement indicator • For execute access, RN of PVA used may not exceed R2 of the accessed segment's SDE. • For read access, RN of PVA used may not exceed R2 of taccessed segment's SDE. | | ASID | Active<br>segment<br>identifier | A global segment name which uniquely identifies each active segment in the system | | LOCK | Lock | One of 64 locks. A zero value indicates a no-lock condition. | Figure II-2-18. Segment Descriptor Table Entry Format ### System Page Table The system has a system page table which lists via an SPID each virtual page resident in CM against the physical address of the assigned page frame. This table is defined by the following: - Page table address (PTA). This is an RMA pointing to the first page table entry, which must be zero, modulo the page table length. - Page table length (PTL). The page table length in modulo 512 words is as follows. | DOT | Words in | Bytes in | |-----------|----------|-----------| | PTL | Page | Page | | 0000 0000 | 512 | 4 096 | | 0000 0001 | 1 024 | 8 192 | | 0000 0011 | 2 048 | 16 384 | | 0000 0111 | 4 096 | 32 768 | | 0000 1111 | 8 192 | 65 536 | | 0001 1111 | 16 338 | 131 072 | | 0011 1111 | 32 768 | 262 144 | | 0111 1111 | 65 536 | 524 288 | | 1111 1111 | 131 072 | 1 048 576 | • Page size mask (PSM). The page size in modulo 512 bytes is as follows. | PSM | Words in Page | Bytes in Page | |----------|---------------|---------------| | 111 1100 | 256 | 2 048 | | 111 1000 | 512 | 4 096 | | 111 0000 | 1 024 | 8 192 | | 110 0000 | 2 048 | 16 384 | #### Page Table Search Hardware converts SVAs to RMAs by searching up to 32 page table entries for a SPID matching the SVA (ASID-PN) being converted. Figure II-2-19 depicts how hardware obtains a starting address for the 32-entry linear search by combining information from the ASID, page table length, and virtual page number. The technique is called hashing. The page table search is necessary because many SVAs hash to the same page table search starting address. Figure II-2-19. Page Table Search, Start RMA Formation ## Page Table Entries Page table entries (refer to PTE in figure II-2-20) list all pages residing in CM by listing the SPID against the allocated CM page frame (physical) address. The operating system ensures that only one copy of any active page exists in CM at a time. The PTEs described also contain 4 control bits. ### PTE Control Fields The PTE contains 4 control bits: valid (V), continue (C), used (U), and modified (M). Hardware decodes and translates these fields during the page table search as follows: - The valid (V) bit, when set, causes the PTE under examination to be tested for a SVA-RMA match. When clear, that PTE is ignored. - The continue (C) bit, when set, causes the hardware search to continue with the next PTE. When clear, the hardware search may be halted after testing the current PTE. - The used (U) bit is set by hardware whenever a PTE is used for address translation. This bit is cleared by software only. - The modified (M) bit is set by hardware whenever a PTE is used for a write access to indicate that the page has been modified. #### PTE Segment/Page Identifier Field The Segment/Page Identifier (SPID) is the PTE field tested for a match against the 38-bit ASID-PN combination from the SVA. When the page size exceeds 512 bytes, the PN is less than 22 bits. In this case, the unused rightmost bits are zeros to obtain proper alignment. ### PTE Page Frame RMA Field This 22-bit field is the page frame physical starting address. When the page size exceeds 512 bytes, the rightmost address bits must be zeros to obtain proper alignment. Figure II-2-20. Page Table Entry Format ### Listing of Pages in Page Table To continuously guarantee the same data for all processes, the operating system ensures that only one copy of a page resides in CM at a time. Therefore, each page has the same page frame address and is listed against a unique ASID in the page table. Also, the operating system lists pages in the page table so that a page table search always results in finding the requested page if it is in CM. Due to the vast number of possible virtual pages, special techniques are used to list pages in the page table. The system page table length is, typically, 2 to 4 times the number of available page frames, and the 16-bit ASID numbers are assigned nonsequentially to facilitate page listing. If a vacant spot is not found when attemting to list a page, the operating system takes further action such as cancelling a page to make room for the new page, changing the ASID number, or rearranging CM and enlarging the page table size. #### PROCESS BINDING SECTION Binding sections bind different segments into one process. Each process has at least one binding section for use by hardware during the call indirect (CALLSEG, B5) instruction and during trap interrupts. A binding section used for such purposes resides in a segment for which the SDE(RP) = 11; such a segment represents a binding segment and lists entry points (code base pointers, CBP) into called code segments. The 64-bit CBPs (figure II-2-21) reside at a word boundary and are addressed by PVAs as follows: - For use by CALLSEG: The relevant CBP is addressed by (Aj+8\*Q) from the instruction. - For use by trap interrupts: The relevant CBP is addressed by the trap pointer (TP) field from the exchange package. A called procedure may have, and a trap interrupt target procedure always has, its own binding section. In such a case, the external procedure flag (EPF) sets in the relevant CBP. After a CBP with its EPF set is accessed, the word stored following that CBP loads into A3 as the new binding section pointer. Figure II-2-21. Code Base Pointer Format ### **ACCESS PROTECTION** Access protection is by way of segments, based on the following elements: - Process segment table - The process segment table defines the process address space. A process may access only the segments listed in its segment descriptor table. Refer to Segment Descriptor Table in this section. - Ring structure - All PVAs used have a 4-bit ring number (RN) field specifying an access privilege from 1 to 15. (A lower RN in a PVA indicates a higher PVA access privilege.) All SDEs and CBPs list access privilege requirements. (A lower RN listed indicates a higher privilege requirement.) - Type of access - SDE control fields permit the type of access attempted (read, write, or execute). Refer to figure II-2-16. - Execute access privilege - Some system instructions require special codes in SDE execute permission control fields. (A local/global execution privilege requirement.) - Execute access mode Some system instructions may execute only in Virtual State monitor mode. - Keys and locks SDE control fields may further specify that a 6-bit key number in the P register must equal a 6-bit lock number in the SDE. - Code base pointers Call indirect instructions and trap interrupts use additional access protection attributes in CBPs, which must be listed in binding section segments. Figure II-2-22 and II-2-23 illustrate access protection as it pertains to the PVA-to-SVA conversion for the read/write and execute cases, respectively. Figure II-2-22. PVA-to-SVA Conversion, Read/Write Figure II-2-23. PVA-to-SVA Conversion, Execute ### **Ring Structure** The ring hierarchy controls read, write, and execute accesses to a segment, as follows: - ullet All PVAs have a 4-bit ring number (RN) field specifying an access privilege from 1 to 15. - R1 and R2 fields in SDEs, and the R3 field in CBPs, specify (PVA)RN requirements for access. #### Ring Voting During certain conditions, the RN loaded into an A register is the largest of the following: - The RN initially in the A register. - The RN accessed in memory. - The R1 of the SDE used to access the RN in memory. Such conditions and the resulting RN loaded are as follows: - Load AK instructions (A0, 84) load a new Ak(RN) which is the largest of the following: - 1. Initial Aj(RN). - 2. SDE(R1) addressed by initial Aj(SEG). - 3. Aj(RN) from memory. - Load multiple instruction (80) loads new A(RN)s which are the largest of the following: - 1. Initial Aj(RN). - 2. SDE(RN) addressed by initial Aj(SEG). - The relevant A(RN) from memory. - Call indirect instruction (B5), when the caller's CBP(EPF) = 1, loads a new A3(RN) which is the largest of the following: - 1. New CBP(RN) from (Aj+8\*Q+8). - 2. New P(RN). - Return instruction (04) loads new A(RN)s which are the largest of the following: - 1. Initial A2(RN). - 2. SDE(RN) addressed by initial A2(SEG). - 3. A(RN) from SFSA in memory. When the return instruction loads new P(RN), any A(RN) not specified for loading by the SFSA descriptor are set to the largest of the following: - 1. Initial A(RN) of the relevant A register. - 2. New P(RN). ### Effect of RN = 0 RN = 0 can serve as a flag to the operating system to link segments on a demand basis. RN = 0 causes an interrupt condition (setting MCR bit 60), when detected as follows: - Call indirect instruction (B5) and CBP(RN) = 0. - Return instruction (04) and an A(RN) in memory (specified for loading by SFSA descriptor) is zero. - Pop instruction (06) and Al(RN) or A2(RN) in SFSA is zero. - Load Ak instructions (80, 84) and new Ak(RN) in memory are zero. - Load multiple instruction (80) and any A(RN) accessed in memory is zero. - Trap interrupt and CBP(RN) is zero. No test occurs for RN zero when the A registers are loaded by an exchange operation, or when an A register serves as an address source to access memory. ## RN for Read/Write Access PVAs used for read/write are in A registers and must have RN as follows: • For a write access, the A(RN) used may not exceed the accessed segment's SDE(R1): $$A(RN) \leq SDE(R1)$$ (write limit test). • For a read access, the A(RN) used may not exceed the accessed segment's SDE(R2): A(RN) $$\leq$$ SDE(R2) (read limit test). ### RN for Execute Access The RN for execute access are verified only for operations having the capability to switch segments. The PVA used may originate from an A register, from a CBP, or from the P register. PVA(RN) requirements are as follows: For accessing a branch intersegment target instruction, initial P(RN) and Aj(RN) must fall within the execute bracket given by target segment's SDE(R1) and SDE(R2): SDE(R1) $$\leq$$ P(RN) $\leq$ SDE(R2) (prevents branches to outside the execute ring bracket of the target segment). SDE(R1) ≤ Aj(RN) ≤ SDE(R2) (prevents branches to outside the execute ring bracket of the target segment). For access to a call indirect target instruction, initial P(RN) must not exceed R3 of CBP used, and also not less than R1 of SDE for target instruction. Refer to figure II-2-24. Also, the initial Aj(RN) must not exceed R3 of CBP used: ``` P(RN) ≤ CBP(R3) (a limit set by the operating system). P(RN) ≥ SDE(R1) (prevents outward calls). Aj(RN) ≤ CBP(R3) (a limit set by the operating system). ``` • For accessing a trap interrupt target instruction, initial P(RN) must not exceed R3 of CBP used, and also not less than R1 of SDE for target instruction. Also, the trap pointer (TP) ring number must not exceed R3 of CBP used: ``` P(RN) ≤ CBP(R3) (a limit set by operating system). P(RN) ≥ SDE(R1) (prevents outward trap interrupts). TP(RN) ≤ CBP(R3) (a limit set by operating system). ``` • For access to a return target instruction, P(RN) loaded from SFSA may not be less than initial previous save area pointer A2(RN): ``` Initial A2(RN) \leq final P(RN) (prevents user from setting P(RN) in SFSA for an inward return as user cannot diminish A2(RN)). ``` ### RN Effect on Pop Instruction A pop instruction loads Al, A2, CFF, and OCF from SFSA, and updates TOS pointer. It does not alter P or A0, and must not alter the ring number in which the stack resides. The entire initial A2 must equal A0 in SFSA, and the initial A2(RN) must equal P(RN). The tests are: ``` Initial A2 = A0 in SFSA Initial A2(RN) = P(RN) (which equals A0(RN) by the previous test). ``` ### Effect of RN Violations Ring number violations and the detection of RN = 0 have effect as follows: | Operation | Violation | Effect | |------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------| | Write | Aj(RN) > SDE(R1) | Access violation (MCR 54) | | Read | Aj(RN) > SDE(R2) | Access violation (MCR 54) | | Branch<br>Intersegment | SDE(R1) > P(RN) > SDE(R2) | Access violation (MCR 54) | | Call Indirect | P(RN) > CBP(R3) Aj(RN) > CBP(R3) P(RN) < SDE(R1) CBP(RN) = 0 | Access violation (MCR 54) Access violation (MCR 54) Outward call (MCR 61) RN zero (MCR 60) | | Return | A2(RN) > P(RN) in SFSA<br>Any A(RN) from SFSA = 0 | Inward return (MCR 61)<br>RN zero (MCR 60) | | Pop | Initial A2 ≠ A0 in SFSA Initial A2(RN) ≠ P(RN) A1(RN) from SFSA = 0 A2(RN) from SFSA = 0 | Environment specification error (MCR 55)<br>Interring pop (UCR 52)<br>RN zero (MCR 60)<br>RN zero (MCR 60) | | Load A | Accessed $A(RN) = 0$ | RN zero (MCR 60) | | Trap<br>interrupt | P(RN) > CBP(R3)<br>TP(RN) > CBP(R3)<br>P(RN) < SDE(R1)<br>CBP(RN) = 0 | Access violation (MCR 54) Access violation (MCR 54) Outward call (MCR 61) RN zero (MCR 60) | # Execute Access Privilege/Mode Execution of some system instructions may occur only in a Virtual State monitor process, or require global/local privilege. An instruction is globally privileged when it is fetched from a segment for which the SDE(XP) is 11. An instruction is locally privileged when it is fetched from a segment for which the SDE(XP) is 10. An instruction which has global privilege also has local privilege. In some cases the requirements are dependent on an instruction parameter. Such system instructions are listed in table II-2-22. Table II-2-22. System Instruction Privilege and Mode | | Instruction | Privilege<br>Required | Mode<br>Required | Effect of<br>Violation | |---|------------------------------------------------------|----------------------------------------------------------------|-----------------------|----------------------------| | | Interrupt<br>processor(03) | Global | Any | UCR 48 | | | Copy to state<br>register<br>60-7F<br>80-BF<br>CO-DF | None<br>Global<br>Local/global | Monitor<br>Any<br>Any | MCR 51<br>UCR 48<br>UCR 48 | | | Return(04) with<br>SFSA(VMID) = 1 | Global | | MCR 55 | | | | | Job | Undefined operation | | | Load page<br>Cable index(17) | Local/global | Any | UCR 48 | | | Branch, alter<br>condition<br>register(9F) | | | | | | k = 0/1/8/9 | None | Monitor | MCR 51 | | | Purge buffer k<br>(05) | | | | | · | k = 0/1/2/8-F | Local/global | Any | UCR 48 | | | Notes: UCR 48<br>MCR 55<br>MCR 51 | Privileged instructi Environment specific Instruction specific | ation error. | | # **Keys/Locks** The key/lock access protection mechanism is independent of other access protection facilities, and consists of the following: - Each SDE has a 6-bit field specifying a lock. - The P register has a 6-bit field specifying a key. Unlike the ring mechanism, the key-lock mechanism is not hierarchical. For access permission, a specified lock requires an exact match with the key tested, except as follows: - A zero lock is a no-lock condition accessible by any key. - A zero key is a master key opening all locks. Key/lock tests perform under the following conditions: - For read access when the accessed segment's SDE(RP) = 01. - For write access when the accessed segments SDE(WP) = 01. Any segment, except a binding segment used during call indirect access, can be locked as follows: - When LOCK = 0, the segment is unlocked. - When LOCK # 0, the segment is locked. Read or write access to a segment is permitted only when the P register providing the PVA of the instruction attempting the access has a KEY as follows: • To access a locked segment, P(KEY) must exactly equal the accessed segment's SDE(LOCK), P(KEY) must be a master key, or the segment's SDE(LOCK) must be a no-lock. Call indirect/relative instructions always set the final P(KEY) equal to the accessed segment's SDE(LOCK). The call indirect access requirements are shown in figure II-2-24. Figure II-2-24. Call Indirect Access Requirements # INTERSTATE PROGRAMMING The CYBER 170 State environment is a substate of Virtual State job mode, within which the CP uses CYBER 170 State compatible instructions, exchanges, and data formats. This subsection contains some general aspects of the CYBER 170 State and a detailed description of interaction between the CYBER 170 State and Virtual State. The CYBER 170 State is described in detail in the appropriate computer system (CYBER 170 State) hardware reference manual listed in the preface. The general characteristics of the CYBER 170 State are as follows: - The CYBER 170 State user sees the P register as a CYBER 170 State register. Hardware, however, treats the P register the same as in Virtual State and performs the PVA-to-SVA-to-RMA conversion with access protection. - The CYBER 170 State user sees CM addresses as CYBER 170 State addresses. Hardware, however, treats these as PVAs and fills in the missing RN and SEG fields from P register data. - The entire CYBER 170 State memory exists in one system virtual segment with an ASID of FFFF16. - Virtual pages into which PPs write 60-bit words map 1:1 into real memory. - Virtual State procedures execute the CYBER 170 State compare/move instructions (464 through 467) by way of trap interrupts. - Virtual State procedures handle some CYBER 170 State exception conditions, such as system or job timer interrupts, hardware errors, or conditions which halt model 173. For the latter case, refer to the CYBER 170 Model 173 hardware reference manual listed in the preface. # **OPERATION IN CYBER 170 STATE** Virtual State programs establish the CYBER 170 State environment and provide recovery facilities for all hardware and some software errors occurring in CYBER 170 State. The general operation is as follows: - Virtual State programs build the page table, segment table, and exchange packages for the CYBER 170 State environment. - A Virtual State program switches the CP to CYBER 170 State through one of the following: An exchange from Virtual State monitor mode to Virtual State job mode, CYBER 170 State monitor/job mode. A call/return within Virtual State job mode, from Virtual State to CYBER 170 State monitor/job mode. • The CP runs in CYBER 170 State, with exchanges between CYBER 170 State monitor and job modes, until one of the following occurs: An exchange interrupt to Virtual State monitor mode. A trap interrupt within Virtual State job mode, from CYBER 170 State to Virtual State. Virtual State programs determine the cause of the exchange or trap interrupt and take appropriate action. #### **MEMORY ADDRESSING IN CYBER 170 STATE** The CM space allocated to CYBER 170 State is addressed as a single segment. An ASID of $FFFF_{16}$ is globally reserved for this segment. For models 835, 845, and 855, hardware uses this ASID value for cache invalidation, described under Cache Invalidation in CYBER 170 State in this section. Hardware treats all CM addresses supplied by CYBER 170 State programs as PVAs and converts these first to SVAs, and then to RMAs. The P register provides the key, ring number, and segment number for all CM accesses. The PVA-to-RMA conversion includes instruction fetch, load/store, extended memory transfers, and CYBER 170 State exchanges to MA, Bj+K, or R+A. The operating system supplies the P register KEY, RN, and SEG fields to make the PVA-to-RMA conversion possible; these cannot be changed by CYBER 170 State programs. The entire P register, including the KEY, RN, and SEG fields, loads as follows: - During Virtual State monitor mode-to-CYBER 170 State monitor/job mode exchanges from the exchange package at (JPS). The exchange package used is specially formatted for such an exchange. - During calls from Virtual State job mode to CYBER 170 State job/monitor mode, from the code base pointer. - During returns from Virtual State job mode to CYBER 170 State job/monitor mode, from the stack frame save area. ### CACHE INVALIDATION IN CYBER 170 STATE (MODELS 835, 840, 845, 850, 855, AND 860 ONLY) When a PP writes a 60-bit word into CM, cache memory is updated by cancelling any copy of that word in cache memory. The RMA used to write CM is also supplied to cache memory. Hardware treats this RMA as a SVA with an ASID of $FFFF_{16}$ . To fulfill the requirements of cache invalidation addressing, the operating system assigns an ASID of $FFFF_{16}$ for the virtual memory segment used as CYBER 170 State memory, and must also map the virtual pages into which PPs write 60-bit words, 1:1, into real memory. In such a case, the RMA supplied is numerically equal to the SVA information necessary to locate the addressed word in cache memory. The operating system maps CYBER 170 State address 0 into BN 0 of system virtual segment $FFFF_{16}$ . Cache is not purged when PPs write 64-bit words into CM. Therefore, it is possible to have other than 1:1 mapping of CM for CYBER 170 State PP-write-to-CM instructions in conjunction with software cache invalidation. 60458890 B #### STATE-SWITCHING OPERATIONS Figure II-2-25 depicts the state-switching operations. The CP switches states when its virtual machine identifier (VMID) changes states through the following: - Exchanges between Virtual State monitor mode and CYBER 170 State. The new VMID loads from the exchange package. - Calls within Virtual State job mode, from Virtual State to CYBER 170 State. The new VMID loads from the code base pointer. - Returns within Virtual State job mode, from Virtual State to CYBER 170 State. The new VMID loads from the stack frame save area. - Trap interrupts within Virtual State job mode, from CYBER 170 State to Virtual State. The new VMID is loads from the code base pointer addressed by the trap pointer. #### Virtual State Monitor Mode-to-CYBER 170 State Exchange The interstate exchange (02) instruction executes the same as a Virtual State exchange instruction, except the incoming exchange package is formatted as shown in figure II-2-26. #### CYBER 170 State-to-Virtual State Monitor Mode Exchange An exchange from a CYBER 170 State process to Virtual State monitor mode is through an interstate exchange interrupt, which executes the same as a Virtual State exchange interrupt, except the outgoing interstate exchange package is formatted as shown in figure II-2-27. Such an interrupt initiates as follows: - By conditions which set a bit in the monitor or user condition register (when enabled). - By software conditions which cause a model 173 CP to halt. Such conditions set the exit mode halt flag in the interstate exchange package at (JPS). Refer to the CYBER 170 Model 173 hardware reference manual listed in the preface. - By a Central Exchange Jump (013) instruction when the CYBER 170 State monitor flag is set. This exchange does not update the CYBER 170 State exchange package. Virtual State monitor mode software may, however, perform the update. Refer to the operating systems manual listed in the preface for further information. ### **Exchanges Within CYBER 170 State** Within the CYBER 170 State, CYBER 170 State-compatible exchange jumps and interrupts occur between the CYBER 170 State monitor and job modes. Refer to the appropriate computer system (CYBER 170 State) hardware reference manual listed in the preface. Such exchanges use the exchange package format shown in figure II-2-27. The interstate exchange package is not altered by this exchange. #### Call from Virtual State to CYBER 170 State The interstate call indirect instruction (B5) executes identical to a Virtual State call indirect instruction, except the stack frame save area (SFSA) has the format shown in figure II-2-28. The operating system arranges the Virtual State A and X registers so the required parameters pass to the CYBER 170 State procedure (the call instruction leaves these registers unchanged in hardware). Figure II-2-28 also shows the register formats in hardware. The call instruction does not store the user and monitor condition registers in SFSA. The BN of P supplied by the code base pointer is the P + RAC of the called procedure target address; BN bits 32 through 39 and 61 through 63 must be zeros. # Trap Interrupt from CYBER 170 State to Virtual State The interstate trap interrupt causes the same action as the Virtual State trap interrupt described in this section, except the SFSA has the format shown in figure II-2-28. This trap interrupt occurs when traps are enabled and a bit sets in the user condition register as listed in table II-2-20. Bits 0 through 3 of the X register fields in SFSA are undefined. The VMID and the P register ring number load from the code base pointer addressed by the trap pointer. The BN of P stored in SFSA is the P + RAC of the interrupted procedure; BN bits 32 through 39 and 63 are zeros, and bits 61 and 62 denote the parcel address within the instruction word. # Return from Virtual State to CYBER 170 State The interstate return instruction (04) executes the same as the Virtual State return instruction, except the SFSA from which the CYBER 170 State registers are restored is formatted as shown in figure II-2-28. The return instruction with VMID = 1 in SFSA is a global-privileged instruction. The BN of P loaded from SFSA must be P+RAC into the CYBER 170 State process, where BN bits 32 through 39 and 63 are zeros, and bits 61 and 62 denote the parcel where execution starts. Figure II-2-25. Interstate Calls, Returns and Interrupts #### **EXCHANGE PACKAGES USED IN CYBER 170 STATE** The CP uses two types of exchange packages with CYBER 170 State operations: - Exchange package for interstate exchanges. - Exchange package for exchanges within CYBER 170 State. Before Virtual State monitor mode initiates an exchange to CYBER 170 State monitor/job mode, the following exchange packages must be ready in CM: - An interstate exchange package for exchanging from Virtual State monitor mode to CYBER 170 State monitor/job mode. - An interstate exchange package for exchanging back to Virtual State monitor mode. - A CYBER 170 State exchange package for a possible immediate exchange to CYBER 170 State monitor mode (when exchanging from Virtual State monitor mode to CYBER 170 State job mode). # Interstate Exchange Package The job process state (JPS) pointer locates the first word in this exchange package. The exchange package format is shown in figure II-2-26. The format is a modified format of the exchange package used within Virtual State. The CYBER 170 State A, B, X, and other registers reside in locations occupied by the Virtual State A and X registers in the Virtual State exchange package. Therefore, after a trap interrupt, the Virtual State program entered has access to these CYBER 170 State registers by accessing the registers as if they were Virtual State registers. The following paragraphs describe the modified fields of the exchange package. For other fields, refer to Exchange Package in this section. 60458890 A II-2-107 Figure II-2-26. Interstate Exchange Package # Program Address (P) Register The P field (word 1, bits 0 through 63) contains the Virtual State P register, which supplies the PVA for the CYBER 170 State where instruction execution is to begin or resume. The KEY field contains the process key for access protection. The BN field of the PVA interprets as the CYBER 170 State P register plus RAC, appended with the parcel address. The P register part of the parcel address must not exceed 18 bits (because exchanges within CYBER 170 State truncate the P register to 18 bits). The user must also ensure that the CYBER 170 State P register does not count past 18 bits, which is possible. The format is as follows: | Bits | Description | |-------|-------------------------| | 00-01 | Not used. | | 02-07 | Not used. | | 08-09 | Not used. | | 10-15 | Key (KEY). | | 16-19 | Ring number (RN). | | 20-31 | Process segment (SEG). | | 32-43 | Must be zero. | | 43-60 | P + RAC (word address). | | 61-62 | Parcel address. | | 63 | Must be zero. | | | | CP operation is out of range or undefined when CYBER 170 State P + RAC > $7777777_8$ , or when P > $777777_8$ . # Stack Pointers The 48-bit AO, Al, and A2 fields (words 1 through 3, bits 16 through 63) are Virtual State A registers. These registers function as stack pointers after a trap interrupt from CYBER 170 State to Virtual State. #### EM Register The EM register contains the exit mode selection bits for use in CYBER 170 State: | Interstate<br>Pack | | | | CYBER 17<br>Exchange | | |--------------------|-----|----------------------------|--|----------------------|-----| | Word | Bit | Description | | Word | Bit | | 4 | 20 | Hardware error (not used). | | 3 | 59 | | 4 | 21 | Hardware error (not used). | | 3 | 58 | | 4 | 22 | Hardware error (not used). | | 3 | 57 | | 4 | 29 | Indefinite operand. | | 3 | 50 | | 4 | 30 | Infinite operand. | | 3 | 49 | | 4 | 31 | Address out of range. | | 3 | 48 | | | | <u> </u> | | | | ### NOTE Hardware errors in CYBER 170 State cause an exchange to Virtual State monitor mode. Bits 20 through 22 function as software flags preserved during exchanges. # Flags The flag formats are as follows: | Virtual<br>Exchange | State<br>Package | | CYBER 170 State<br>Exchange Package | | |---------------------|------------------|----------------------------------|-------------------------------------|-----| | Word | Bit | Description | Word | Bit | | 4 | 23 | UEM enable flag. | 4 | 56 | | 4 | 24 | Expanded addressing select flag. | 4 | 55 | | 4 | 25 | Enhanced block copy flag. | Ž. | 54 | | 4 | 26 | Software flag. | 4 | 53 | | 4 | 27 | Instruction stack purge flag. | Ä | 52 | | 4 | 28 | Software flag. | 4 | 51 | | 5 | 31 | CYBER 170 State monitor flag. | · · | - | | 6 | 31 | Exit mode halt flag. | | _ | # Unified Extended Memory (UEM) Enable Flag If set, this flag enables the CM block copy and single-word copy instructions (011, 012, 014, and 015) to access CM. # Expanded Addressing Select Flag If set, slects expanded addressing mode, which provides addressing up to 24 bits in a 30-bit format for data transfer between CM and UEM. If clear, selects standard addressing mode, which provides addressing up to 21 bits in a 24-bit format for data transfer between CM and UEM. # Enhanced Block Copy Flag If set, CYBER 170 State block copy instructions (011, 012) use XO bits 30 through 50 rather than AO to determine the CM address. # Software Flag (Word 4, Bit 28) This is a reserved flag described in software documentation. # Instruction Stack Purge Flag If set, this flag causes instruction stack purges as described under Code Modification in CYBER 170 State in this section. ### Software Flag (Word 4, Bit 26) This is a reserved flag described in software documentation. ### CYBER 170 State Monitor Flag If set in an incoming exchange package, this flag indicates that the CYBER 170 State process is to start (or resume) execution in CYBER 170 State monitor mode. If set in an outgoing exchange package, this flag indicates that the interrupted process was executing in CYBER 170 State monitor mode. ### Exit Mode Halt Flag If set, this flag indicates a software error that would halt a model 173 CP. This bit does not set for hardware errors that would have halted a model 173 CP. Refer to the hardware reference manual (listed in the preface) that describes the CYBER 170 Model 173. ### RAC Register The 32-bit RAC field (word 4, bits 31 through 63) contains the 21-bit CYBER 170 State reference address for CM addressing. CP operation is undefined when RAC > 7 777 7778 or RAC + FLC > 7 777 7778. #### FLC Register The 32-bit FLC field (word 5, bits 31 through 63) contains the 21-bit CYBER 170 State field length for CM addressing. CP operation is undefined when FLC > 7 777 7778 or RAC + FLC > 7 777 7778. # Monitor Address (MA) Register The 32-bit MA field (word 6, bits 31 through 63) contains the 18-bit CYBER 170 State MA register pointing to the CYBER 170 State exchange package starting address used when executing the following instructions with the CP in CYBER 170 State job mode: - CYBER 170 State central exchange jump (013). - PP monitor exchange jump to MA (262x). CP operation is undefined when MA $> 777 777_8$ . ### Address (A) Registers The eight 18-bit A fields (words 9 through 16, bits 46 through 63) are CYBER 170 State CM address (A) registers. ### RAE Register The 32-bit RAE field (word 7, bits 31 through 63) contains the 21-bit CYBER 170 State RAE register supplying the reference address for UEM addressing (instructions 011, 012, 014, 015). CP operation is undefined when RAE > 77777778 or when the RAE rightmost 6 bits are nonzero. ### FLE Register The 32-bit FLE field (word 8, bits 31 through 63) contains the 24-bit CYBER 170 State FLE register supplying the field size for UEM addressing (instructions 011, 012, 014, and 015). CP operation is undefined when FLE > 777777778 or when the FLE rightmost 6 bits are nonzero. #### Virtual State Ring Numbers The operating system supplies the A register Virtual State ring numbers (words 04 through 16, bits 16 through 19) for use after an interrupt to Virtual State. These must not be altered in CYBER 170 State. # Index (B) Registers The 18-bit CYBER 170 State B registers 1 through 7 (words 18 through 24, bits 46 through 63) are used primarily as indexing registers. Register BO is not included in the exchange package; this register always contains all zeros. # Operand (X) Registers Words 25 through 32, bits 04 through 63 contain the CYBER 170 State operand (X) registers. Hardware sign-extends the X registers in an outgoing exchange package to 64 bits. The operating system sign-extends the X registers in an incoming exchange package to 64 bits. #### **CYBER 170 STATE EXCHANGE PACKAGE** The CYBER 170 State exchange package (figure II-2-27) resides within the CYBER 170 State process segment in memory. During exchange operations between CYBER 170 State monitor and job modes, the current CP CYBER 170 State registers store into an outgoing CYBER 170 State exchange package and reload from the incoming CYBER 170 State exchange package. These two exchange packages store into the same CM locations and, thus, the outgoing exchange package replaces the incoming exchange package in CM. Refer to the appropriate computer system (CYBER 170 State) hardware reference manual listed in the preface for further information. | | | 18 17 | 0<br><del> </del> _ • | |--------------|----|---------------------------------------|-------------------------| | P | A0 | | 0 | | RAc | A1 | B1 | 1 1 | | FLc | A2 | B2 | 2 | | EM Flags* EM | A3 | В3 | 3 | | RAe | A4 | B4 | 7 4 | | FLe | A5 | B5 | 7 5 | | MA | A6 | B6 | 6 | | | A7 | B7 | 7 | | | XO | | 8 | | | X1 | | 9 | | | X2 | | 10 | | | Х3 | - | 11 | | | X4 | | 12 | | | X5 | · · · · · · · · · · · · · · · · · · · | 13 | | | X6 | | 14 | | | X7 | | 15 | | <u> </u> | | | J | | | | | | Figure II-2-27. CYBER 170 State Exchange Package # INTERSTATE STACK FRAME SAVE AREA Interstate calls/returns and trap interrupts use a SFSA with the format shown in figure II-2-29. For the description of modified fields, refer to the corresponding fields in the Interstate Exchange Package in this section, except as follows: - The user and monitor condition registers are stored only during trap interrupts. - The user and monitor condition registers are not loaded by a return instruction to CYBER 170 State. - X register field bits 0 through 3 are undefined in the SFSA after a call, return, or trap interrupt. Hardware does not sign-extend these fields. Figure II-2-28. Interstate Stack Frame Save Area #### **CODE MODIFICATION IN CYBER 170 STATE** In model 173, the CYBER 170 State return jump (010), extended memory read or write (011, 012), exchange jump (013), or long jump (02) instructions purge the instruction buffer. This is also the case in models 810 through 860. Additionally, when the operating system sets the CYBER 170 State instruction stack purge flag in the interstate exchange package or SFSA, the conditional jump instructions (03 through 07) and store instructions (50 through 57 with i=6 or 7) also purge the instruction stack. In such case, the modified code always executes, even with the previous code in the same instruction word as the modifying code. With the instruction stack purge flag clear, execution of unmodified code in the instruction buffer may occur but can never be guaranteed, since an exchange interrupt may clear all instructions in the buffer at any time, including instructions in the same instruction word as the code-modifying instruction. ### **DEBUG/PERFORMANCE MONITORING** The CYBER 170 State environment does not support the Virtual State debug feature. Other information related to performance monitoring may be collected through the maintenance channel. ## **EXCEPTION HANDLING IN CYBER 170 STATE** During execution of CYBER 170 State programs, certain hardware or software errors cause an exchange to Virtual State monitor mode, or a trap interrupt to Virtual State, as described in the following paragraphs. Such exceptions do not set exit condition bits or store the P register at location RAC. Instead, RAC+P stores in the outgoing exchange package or in SFSA. #### **SOFTWARE EXCEPTION CONDITIONS** Table II-2-23 lists CYBER 170 State exception conditions. In general, software errors occurring in CYBER 170 State job mode with the corresponding exit mode selected cause an exchange to CYBER 170 State monitor mode. Corresponding software errors occurring in CYBER 170 State monitor mode which result in an exchange from CYBER 170 State to Virtual State monitor mode with no MCR bits set and the CYBER 170 State halt flag in the outgoing exchange package set are as follows: - Illegal instruction in CYBER 170 State monitor mode. - Read or write address out of range (with exit mode selected for this error) in CYBER 170 State monitor mode. - Instruction fetch address or branch target address out of range in CYBER 170 State monitor mode. - Infinite or indefinite value detected (with exit mode selected for this error) in CYBER 170 State monitor mode. - 00 instruction in CYBER 170 State monitor mode. Exceptions that may only occur immediately after entering or leaving the CYBER 170 State environment, and which cause an exchange from CYBER 170 State to Virtual State monitor mode, with an MCR bit set and the CYBER 170 State halt flag in the outgoing exchange package clear, are as follows: | Bit | Description | |--------|-----------------------------------| | MCR 55 | Environment specification error. | | MCR 60 | Invalid segment/ring number zero. | | MCR 52 | Address specification error. | | MCR 54 | Access violation. | | MCR 61 | Outward call/inward return. | | MCR 63 | Trap exception. | | | | Table II-2-23. CYBER 170 State Exceptions (Sheet 1 of 2) | | Job Process<br>State | | CYBER<br>Sta | | · | |--------------------|----------------------------|-----------------------------------------------------------------------|--------------|--------------|------------------------------------------------------------------------------------------------| | MCR/<br>UCR<br>Bit | Exchange<br>Package<br>Bit | Error | Mode | Exit<br>Mode | Response | | MCR 48 | - | Hard errors: Parity Double<br>SECDED CM port bounds. | Any | Any | When address error, inhibit write to that address. | | | | | : | | Complete current instruction; exchange to (MPS); P = RAC + next fetch address (not necessarily | | | | | | | related to error). | | MCR 50 | - : . | Short warning. | Any | Any | Complete current instruction; | | MCR 53 | , <del>-</del> , | CYBER 170 State exchange request (PP). | | | exchange to (MPS);<br>P = RAC + next fetch | | MCR 56 | _ | External interrupt (CP). | | | address (not necessarily related to condition). | | MCR 59 | _ | System interval timer. | | | | | MCR 62 | - | Soft error. | | | | | MCR 55 | <br> | No CYBER 170 State<br>bit in VMCL on entering<br>CYBER 170 State. | Any | Any | Inhibit execution of target instruction; exchange to (MPS); P = RAC + target fetch address. | | MCR 60 | <b>-</b> | RN = 0 on return to CYBER 170 State. | | | | | MCR 52 | _ | Address specification error when CYBER 170 State entered. | Any | Any | Inhibit execution of target instruction; exchange to (MPS); P = RAC + target fetch address. | | MCR 54 | _ | Access violation when CYBER 170 State entered. | | | | | MCR 60 | - | Invalid segment when CYBER 170 State entered. | | | | | MCR 60 | | RN = 0 on call to CYBER 170<br>State or trap from CYBER<br>170 State. | | | | | MCR 61 | - | Outward call/inward return to CYBER 170 State. | | | | | MCR 63 | - | Trap exception on trap from CYBER 170 State. | | | | Table II-2-23. CYBER 170 State Exceptions (Sheet 2 of 2) | _ | | | | | | | |---|------------|----------------------------------|------------------------------------------------------------------|---------------|--------------|----------------------------------------------------------------------------------------------------------| | | MCR/ | Job Process<br>State<br>Exchange | | CYBER<br>Stat | | | | | UCR<br>Bit | Package<br>Bit | Error | Mode | Exit<br>Mode | Response | | | MCR 57 | - | Page fault without FLC or FLE violation. | Any | Any | <pre>Interrupt execution; exchange to (MPS); P = RAC + this/next fetch address.</pre> | | | UCR 48 | <b>-</b> | Trap to executing instruction (017). | Any | Any | Trap to TP in exchange package; P = RAC + next fetch address. | | | UCR 49 | - | Unimplemented instruction fetched. | Any | Any | Inhibit execution;<br>trap to TP in exchange<br>package; P = RAC + this<br>fetch address. | | | UCR 50 | <b>-</b> | Free flag in incoming exchange package. | Any | Any | Inhibit next instruction;<br>trap to TP in exchange<br>package; P = RAC + next<br>fetch address. | | | UCR 51 | - | Process interval timer. | | | | | | UCR 53 | - · | Critical frame on return to CYBER 170 State. | Any | Any | Inhibit execution of target instruction; trap to TP in exchange package; P = RAC + target fetch address. | | | | 29 | FP indefinite. FP infinite. | Mon | Se1 | Exchange to (MPS); P = RAC + this/next fetch address. | | | | 30 | FP indefinite. FP infinite. | Mon | Sel | Exchange to (M,PS);<br>P = RAC + this/next<br>fetch address. | | | · - | 31 | FLC violation, incremental read or write. | Mon | Se1 | Interrupt execution; X or CM = unchanged; A = read address less | | | | | | | | RAC; exchange to (MPS); P = RAC + this/next fetch address. | | | - | 31 | FLE violation,<br>block transfer instruction<br>011, 012. | Mon | Se1 | Execute as pass;<br>exchange to (MPS);<br>P = RAC + next fetch<br>address. | | | _ | 31 | FLE violation, single-<br>word transfer instruction<br>014, 015. | Mon | Se1 | Execute as pass;<br>exchange to (MPS);<br>P = RAC + this/next<br>fetch address. | The following exception causes an exchange from CYBER 170 State to Virtual State monitor mode with an MCR bit set and the CYBER 170 State halt flag in the outgoing exchange package clear: Bit Description MCR 57 Page table search without find. Exceptions that may occur only immediately after entering or leaving the CYBER 170 State environment, and which cause a trap interrupt from CYBER 170 State to Virtual State, with a UCR bit set, are as follows: Bit Description UCR 50 Free flag set in incoming exchange package. UCR 53 Return with critical frame flag set. Exceptions causing a trap interrupt from CYBER 170 State to Virtual State, with a UCR bit set, are as follows: Bit Description UCR 48 Trap to Virtual State (017) instruction in the CYBER 170 State instruction set. UCR 49 Unimplemented instructions. A trap interrupt attempted with trap interrupts disabled causes an exchange or stack operation as described in table II-2-6. #### **Address Errors** An address error does not change the destination CM location or register. Read/write address errors occurring in CYBER 170 State monitor mode initiate an exchange to Virtual State monitor mode only with the corresponding exit mode selected. Instruction fetch address errors and target instruction fetch address errors in CYBER 170 State monitor mode always initiate the exchange. A page-table-search-without-find fault (page fault) in CYBER 170 State (MCR bit 57) causes an exchange to Virtual State monitor mode only in the absence of a simultaneous FLC or FLE violation. When the exchange does occur, the interrupted process is restartable only when the page fault occurred during execution of a CYBER 170 State UEM transfer instruction (011, 012, 014, 015). When the page fault causes the exchange, the CP places the PVA causing the page fault into the untranslatable pointer register, including the SEG and RN fields of the PVA. The CP tests each CM reference for an address specification error, invalid segment, or access violation. When an interrupt occurs because of these conditions, the interrupted CYBER 170 State process may not be restartable. # **Illegal Instructions** The following CYBER 170 State instructions, when executed in CYBER 170 State monitor mode, cause an exchange to Virtual State monitor mode with the CYBER 170 State halt flag set in the exchange package: - Any 30-bit instruction at parcel 3. - Instructions 011 through 013 at parcel 1, 2, or 3. - Instruction 016. - Instructions 011, 012, 014, and 015 with certain parameters as described below. # **Extended Memory Transfer Exceptions** Instructions 011 and 012 in CYBER 170 State monitor mode, with exit mode selected, cause exceptions with the following priority: | | Exception | Response | |----|------------------------------------------|-------------------------| | 1. | Not in parcel 0 | Illegal instruction. | | 2. | UEM enable flag clear (exchange package) | Illegal instruction. | | 3. | FLC violation | Address range error. | | 4. | Negative blocklength | Address range error. | | 5. | FLE violation | Address range error. | | 6. | Zero blocklength | Fetch next instruction. | Instructions 014 and 015 in CYBER 170 State monitor mode, with exit mode selected, cause exceptions with the following priority: | | Exception | Response | |----|------------------------------------------|----------------------| | 1. | UEM enable flag clear (exchange package) | Illegal instruction. | | 2. | FLE violation | Address range error. | | 3. | Xk (CYBER 170 State) bit 21/22/23 set | Address range error. | ### HARDWARE EXCEPTIONS IN CYBER 170 STATE Table II-2-20 lists CYBER 170 State exception conditions. In general, hardware exceptions cause an exchange to Virtual State monitor mode or a trap interrupt to Virtual State job mode. Hardware exceptions causing an exchange from CYBER 170 State to Virtual State monitor mode are as follows: Bit Description MCR48 Detected uncorrectable error. MCR50 Short warning. MCR56 External interrupt. MCR59 System interval timer. MCR62 Soft error. Hardware exceptions causing a trap interrupt to Virtual State job mode are as follows: Bit Description UCR53 Process interval timer. ### IOU PERIPHERAL PROCESSOR PROGRAMMING The PPs may access all CM storage locations. One CM word or a block of CM words can transfer from a peripheral processor memory (PPM) to CM or from CM to a PPM. Data from external devices is read into a PPM, and with additional instructions, transfers to CM. Conversely, data is transferred from CM to a PPM and then transfers by way of additional instructions to external devices. #### **CENTRAL MEMORY ADDRESSING BY PPs** Addresses sent to CM from PPs are real memory addresses. PPs address CM using either absolute or relocation addressing. Every PP can read all CM locations without restriction. Every PP has write access to CM as determined by the OS bounds register in the IOU. The port bounds register in CM may also be set to limit write access from IOU. ## **Absolute and Relocation Addressing** 60458890 B If A register bit 46 is a zero, bits 47 through 63 of A specify an absolute CM address 0 through $377777_8$ . If bit 46 of A is a 1, bits 47 through 63 of A are added to the 28-bit relocation register R to specify an absolute CM address 0 through $177777777_8$ . If bit 46 of A changes during a transfer, the addressing mode changes accordingly. Figure II-1-7 shows how a relocation address forms. Instructions 0024/0025 load/store the relocation register. The leftmost 7 bits of R represent (unused) extra addressing capacity. The rightmost 6 bits of R are appended zeros. Figure II-1-6 shows how R stores in PP memory. #### **OS Bounds Test** The OS bounds test restricts write access from selected PPs to an upper or a lower region in CM. The PP instructions for which the OS bounds test performs are as follows: Exchange jumps (00260, 00261, 00262). Central write (0062, 1062). Central write (d) words (0063, 1063). Central read and set/clear lock (1000/1001). ### **PP Central Memory Read** Instructions which read CM data into PPM are as follows: • 60-bit CM words to five 12-bit PP words Central read from A to d (0060). Central read (d) words from (A) to m (0061). • 64-bit CM words to four 16-bit PP words Central read from A to d long (1060). Central read (d) words from (A) to m long (1061). Central read and set lock from d to (A) (1000). Central read and clear lock from d to (A) (1000). It is possible, by way of block read (0061, 1061) to read up to 4095 CM words, over-writing PP memory cyclically. Hardware, however, uses PPM location 0 to hold the program counter during block transfers. Refer to instructions 0061 and 1061 in section II-1. ### **PP Central Memory Write** Instructions which write PPM data from into CM are as follows: - Five 12-bit PP words to 60-bit CM words - Central write to (A) from d (0062). Central write (d) words to (A) from m (0063). Four 16-bit PP words to 64-bit CM words Central write to (A) from d long (1062). Central write (d) words to (A) from m long (1063). It is possible by way of block write (0063, 1063) to write up to 4095 CM words, repeating PP memory cyclically. Hardware, however, uses PPM location 0 to hold the program counter during block transfers. Refer to instructions 1062 and 1063 in section II-1. #### PP MEMORY ADDRESSING BY PPs PP instructions use 6-bit/18-bit direct operands or obtain the operand from PP memory using direct, indirect, or indexed addressing. #### **Direct 6-Bit Operand** PP instructions of this type are no-address instructions. They have the format OPCODEd. The d-field provides a 6-bit direct operand zero-extended to 18 bits in calculations. #### **Direct 18-Bit Operand** PP instructions of this type are constant address instructions. They have the format OPCODEdm. The combined d and m field provides an 18-bit operand. #### **Direct 6-Bit Address** PP instructions of this type are direct address instructions. They have the format OPCODEd. The d field provides a 6-bit direct address, accessing PPM locations 0 to 778. ### **Direct 12-Bit Address** PP instructions of this type are indexed direct address instructions, with zero index. They have the format OPCODEdm, d=0. The m field provides a 12-bit direct address, accessing PP memory locations 0 through 77778. # **Indexed 12-Bit Address** PP instructions of this type are indexed direct address instructions. They have the format OPCODEdm, d=0. The m field provides a 12-bit direct address (base address). The d field specifies a PP memory location from 0 to $77_8$ , the contents of which is a 12-bit index. The indexed direct address forms by adding the index to the base address as signed one's complement numbers, ignoring overflow. When m+(d)=7777 the result sets to 0000, except in the addition 7777+7777=7777. #### **Indirect 6-Bit Address** PP instructions of this type are indirect address instructions. They have the format OPCODEd. The 6-bit d field addresses PP locations 0 through $77_8$ . The 12 rightmost bits of the addressed location provide an address to access PP memory locations 0 through $7777_8$ . # CHANNEL INPUT/OUTPUT OPERATIONS All PPs may access all external devices through internal and external interfaces. Each internal interface contains a data register and channel control flags. The internal interfaces connect to external interfaces communicating with the external devices. #### **CHANNEL FLAGS** Channel operation is controlled by the channel flags, which are set/reset by PP instructions and by signals from the external devices. The channel flags are as follows: - Channel active/inactive flag. - Register full/empty flag. - Channel (marker) flag. - Error flag. The active flag and the full flag control the channel input/output transfers. The status of these two flags determines the channel active, inactive, full, or empty. The marker flag is for software use, and the error flag indicates transmission parity errors. ## **Channel Active Flag** A PP sets the active flag to indicate a reserved channel (channel active). The PP or the external device clears the active flag to indicate a free channel (channel inactive). Devices connected through the CYBER 170 State 12-bit channels may also set this flag to request attention. A PP sets the active flag by the activate instruction (0074) or function instructions (0076, 0077). A PP clears the active flag with the deactivate instruction (0075). Normally, external devices clear the active flag in response to a function instruction, or when they have no more data to send. A PP senses the active flag state using the jump on active/inactive instructions (00640 and 00650). #### Register-Full Flag A register is full when it contains a function or data word for an external device, or when it contains a similar word received from the external device. The register is empty after the word is read. The flag turns on or off as the register changes states. A channel can only be full when it is active. When set, the register-full flag signals the destination that data is available, and signals the sender that no more immediate data can be sent. When clear, full flag signals the destination to wait for the next data word, and signals the sender to send another word. During block transfers, the register-full flag sets once for each word written into the register. The register-full flag also clears when the channel goes inactive for any reason. The PPs can sense the flag state using the jump-on-full/empty instructions (00660/00670). # Channel (Marker) Flag This flag is used by software as a marker and does not affect hardware operation. The flag provides dual PP I/O driver programs with a synchronization mechanism. The flag is inaccessible to external devices. The marker flag is set/cleared by the channel flag instructions (00641/00751). A PP can sense the marker flag state using the jump-on-set/clear instructions (1064/1065). Priority conflicts exist when PPs in the same time slot use this flag. Hardware resolves the marker flag priority conflicts for the maintenance channel 178. For other channels, the problem is resolved by software interlocks kept in CM, or by not assigning PPs in the same time slot to the same channel. Any five consecutively-numbered PPs are not in the same time slot. ### **Error Flag** This flag indicates a data parity error on a channel transfer. The IOU interface sets the error flag when it detects a data parity error on input data. External devices connected through 16-bit channels can also set this flag when detecting an output data parity error. When this flag sets in any internal interface, the channel parity error bit also sets in the IOU fault status register. PP instructions 00661 and 00671 clear and sense the error flag. # PROGRAMMING FOR CHANNEL INPUT/OUTPUT Data transfers to/from external devices are controlled by PP instructions 0064 through 0077. The same instruction set services 8-, 12-, and 16-bit channels. The assignment of PPs, transfer priorities, and resolution of conflicts is a software responsibility. The channel marker flag and/or software interlocks in central memory provide for channel parity and reservation. Proceed as follows after resolving conflicts: # Action # Typical Instruction 1. Clear error flag. - Jump if error flag set, and clear flag (00661). - 2. Verify channel availability. - Jump if active (00640). - 3. Verify device availability: Request device to send status. Wait until device responds. Activate channel. Read device status. Verify error status. Analyze device status. Function m (00770). Jump if active (00640). Activate (00740). Input to A (00700). Jump if error flag set (00661). Logical product (0012), zero jump (0004). #### 4. Prepare for input/output: Enter number of words to A. Verify channel inactive. Prepare device for read/write. Wait until device responds. Load d (0014). Jump if active (00640). Function m (00770). Jump if active (00640). # 5. Read/write data: Activate channel. Read/write data. If write, loop until empty. Disconnect Channel. Verify inactive status. Activate (00740). Input/output A words (0071/0073). Jump if full (00660). Deactivate (00750). Jump if active (00640). #### 6. Verify transfer integrity: Verify A words were transferred (note 1). Verify error status. Verify inactive status. Request device. to send status. Wait until the device responds. Activate channel. Read device status. Verify error status. Analyze device status. Verify inactive status. Nonzero jump (0005). Jump if error flag set (00661). Jump if active (00640). Function m (00770). Jump if active (00640). Activate (00740). Input to A (00700). Jump if error flag set (00661). Logical product (0012), nonzero jump (0005) Jump if active(00640). ### NOTE If A = original value, no words were transferred. If A is not equal to 0, device or another PP ended transfer. ### INTER-PP COMMUNICATIONS Any PP can communicate with any other PP using any channel (except the real-time clock) by omitting the conditioning of that channel's external devices for a data transfer. Both single-word and block transfers can be used. Either the sending PP or the receiving PP can activate the channel used, after which the sending PP outputs data into the data register and the receiving PP inputs data from the same register. The transfer rate is one word every 250 nanoseconds, except when the transfer is between PPs in different barrels but the same time slot. In such a case, the transfer rate is one word every 500 nanoseconds. PPs using the same time slots are as follows: | Models 810, 815 and 825, and 8 | Models | nd 825, and | 15 an | 10, | Models | |--------------------------------|--------|-------------|-------|-----|--------| |--------------------------------|--------|-------------|-------|-----|--------| Models 835, 840, 845, 850, 855, 860, and 990 | Slot | PP N | lumber | | Slot | PP Number | |------|------|--------|--|------|---------------| | 1 | 0 | 10 | | 1 | 0, 5, 20, 25 | | 2 | 1 | 11 | | 2 | 1, 6, 21, 26 | | 3 | 2 | 12 | | 3 | 2, 7, 22, 27 | | 4 | 3 | 13 | | 4 | 3, 10, 23, 30 | | 5 | 4 | 14 | | 5 | 4, 11, 24, 31 | | 6 | 5 | 15 | | | | | 7 | 6 | 16 | | | | | 8 | 7 | 17 | | | | | 9 | 8 | 18 | | | | | 10 | 9 | 19 | | | | Software must resolve priority and reservation problems arising in inter-PP communications. #### PP PROGRAM TIMING CONSIDERATION Some external equipment requires timing considerations in issuing a function, activate, or input instruction. Refer to the applicable external equipment reference manual. Such timing considerations may be required, for example, to ensure that the equipment attains a proper speed before data is sent (required by some magnetic tape equipment). Also, equipment terminating a data transfer by resetting the active flag often requires timing considerations in issuing the next function instruction. ### **CACHE INVALIDATION** When a PP executes 60-bit central write instructions, the IOU sends cache memory invalidation requests to the CP. The CP responds by purging the cache memory of any former copies of the words stored in CM. Such invalidation requests are sent during the following central write instructions: - Central write A to d (0062), with every 60-bit word. - Central write (d) words from m to (A) (0063), when an address with bits 62 and 63 set is sent to CM, and with the last word written. NOTE Cache is not invalidated during the execution of instructions 1001, 1002, 1062, and 1063. #### ERROR DETECTION AND RECOVERY The IOU and each PP have fault detection and reporting hardware. The IOU generates and checks parity on all data transferred between PP and PP memory, CM and IOU, and IOU and external devices. #### **PP Hardware Errors** When a PP hardware error occurs with the enable error stop bit set in the IOU environment control register, the PP with the fault halts (idles). In this case, another PP may perform error detection and logging. When one PP halts from error detection, the remaining PPs are affected only when a PP is waiting for the halted PP to perform some action. Error reporting from any PP with a fault can be disabled by setting the relevant bit in the IOU fault status mask register. This is normally done when removing a PP from service, and restores normal error reporting from other PPs through the summary status byte. #### **Channel Parity Errors** The output register 16 bits are checked for parity whenever the register is full. When a parity error is detected, the following takes place: - Channel error flag in the channel concerned sets. - Fault status register bit for this channel sets. - Uncorrected error bit in IOU status summary register sets. Error reporting from any channel with a fault can be disabled by setting the relevant bit in the IOU fault status mask register. This is normally done when removing a channel from service, and restores normal error reporting from other PPs through the summary status byte. #### Parity Errors on Output Data The IOU sends a data or function word to the channel with parity calculated on all 16 bits of the channel output register. In case of 8- and 12-bit channels, software must ensure that the missing bits in the output register are zeros. This ensures correct channel parity after the unused bits discard. Software must verify the integrity of a 12-bit channel output data transfer by requesting a status word from the device concerned. When a device detects a parity error on a 12-bit function word output, it does not send any response and the channel remains active and full. Devices connected through 16-bit channels or the maintenance channel respond to a data word parity error detected at the device by resetting the channel full flag and setting the error flag. The channel remains active and execution of the current output instruction continues. These devices respond to a function word parity error by resetting the active flag and setting the error flag. The 12-bit channel contains a switch to disable parity checking. ### Parity Errors on Input Data For all channels, the IOU sets the channel error flag whenever it detects a parity error on input data. The IOU regenerates correct parity before storing the data into PP memory. # Timeout The maintenance channel interface provides a 100-microsecond timeout counter to ensure that the PP dealing with that channel continues operations when the maintenance channel does not respond to a data transfer command. The timeout interval starts when the maintenance channel goes active or full, and resets when the channel goes inactive or empty. If the IOU receives no response by the end of the timeout interval, it clears the channel active flag. Function word output does not activate the timeout counter. This allows software to recover from a maintenance access control malfunction. To allow inter-PP communications without timeout, the timeout is disabled when the maintenance channel interface is deselected from channel $17_8$ using connect codes 8 through F. # INITIALIZATION System initialization begins with the IOU, which requires no external hardware or software aid to initialize itself. After the operator presses the deadstart button (CC545) or presses the CTRL G key (CC634B, model 990 only), a storage device in the IOU provides initialization programs and data for further action. After the IOU has self-initialized, any or all of the following operations may be performed by way of the system console and deadstart options: - Load CP control memory. - Initialize CM. - Dump CM. - Run CP quick look test. - Begin maintenance system load. - Begin operating system load. # SYSTEM CONSOLE PROGRAMMING (CHANNEL 108) #### **KEYBOARD** A PP must transmit a one-word function code (7020<sub>8</sub>) to request data from the system console keyboard. The code prepares the display controller for an input operation. The PP then activates the input channel and receives one character from the keyboard. This character enters as the lower 6 bits of the word, and the upper bits clear. There is no status report by the keyboard. Table II-2-24 lists the keyboard character codes. ### **DATA DISPLAY (CC545)** Data is displayed within an 203.2 mm (8-in) area of a cathode-ray tube (CRT). The display can be alphanumeric (character mode) or graphic (dot mode). There are 262144 dot locations arranged in a 512-by-512 format. Each dot position is determined by the intersection of X and Y coordinates. The lower left corner dot is octal address X = 6000 and Y = 7000, and the upper right corner dot is octal address X = 6777 and Y = 7777. (Model 990 also uses a CC634B system console. Refer to the hardware reference manual listed in the preface for information regarding this terminal.) #### **Character Mode** Large, medium, and small characters are provided in character mode. Large characters are arranged in a 32-by-32 dot format with 16 characters per line. Medium characters are arranged in a 16-by-16 dot format with 32 characters per line. Small characters are arranged in an 8-by-8 dot format with 64 characters per line. Table II-2-25 lists the display character codes. ### **Dot Mode** In dot mode, display dots are positioned by the X and Y coordinates. The X coordinates position the dots horizontally. The Y coordinates position the dots vertically and unblank the CRT for each dot. Horizontal lines form from a series of X and Y coordinates. Vertical lines form from a single X coordinate and a series of Y coordinates. Table II-2-24. Keyboard Character Codes | · | | | | | |------------|------|-----------------|------|--| | Character | Code | Character | Code | | | No data | 00 | 0 | 33 | | | A | 01 | 1 | 34 | | | В | 02 | 2 | 35 | | | С | 03 | 3 | 36 | | | D | 04 | 4 | 37 | | | E | 05 | 5 | 40 | | | F | 06 | 6 | 41 | | | G | 07 | 7 | 42 | | | H | 10 | 8 | 43 | | | ı | 11 | 9 | 44 | | | J | 12 | + | 45 | | | K | 13 | | 46 | | | L | 14 | * | 47 | | | <u>M</u> | 15 | / | 50 | | | N | 16 | . ( | 51 | | | 0 | 17 | <b>)</b> | 52 | | | P | 20 | Left blank key | 53 | | | Q | 21 | = | 54 | | | R | 22 | Right blank key | 55 | | | s | 23 | , | 56 | | | T | 24 | • | 57 | | | Ū | 25 | Carriage return | 60 | | | · <b>v</b> | 26 | Backspace | 61 | | | W W | 27 | Space | 62 | | | x | 30 | | | | | Y | 31 | | | | | Z | 32 | | | | Table II-2-25. Display Character Codes | Character | Code | Character | Code | |-----------|------|-----------|------| | No data | 00 | 0 | 33 | | A | 01 | i | 34 | | В | 02 | 2 | 35 | | С | 03 | 3 | 36 | | D | 04 | 4 | 37 | | E | 05 | 5 | 40 | | F | 06 | 6 | 41 | | G | 07 | 7 | 42 | | н | 10 | 8 | 43 | | I | 11 | 9 | 44 | | J | 12 | + | 45 | | к | 13 | - | 46 | | L L | 14 | * | 47 | | M | 15 | / | 50 | | N | 16 | ( | 51 | | 0 | 17 | ) | 52 | | P | 20 | Space | 53 | | Q | 21 | = | 54 | | R | 22 | Space | 55 | | s | 23 | , | 56 | | <b>T</b> | 24 | • | 57 | | Ū | 25 | | | | v | 26 | | | | W | 27 | | | | <b>X</b> | 30 | | | | Y | 31 | | | | Z | 32 | | | # Codes A single function word transmits to select the presentation, mode, and character size (character mode only). Figure II-2-29 illustrates the function word format. The word following the function word specifies the starting coordinates for the display (for either mode). Figure II-2-30 illustrates the coordinate data word. Figure II-2-31 illustrates the character word. Figure II-2-29. Display Station Output Function Code Figure II-2-30. Coordinate Data Word Figure II-2-31. Character Data Word The controller regulates character spacing on the line once the display operation starts. A new Y coordinate data word must be sent to start each line. If a new Y coordinate is not specified, data is written on the line specified by the active Y coordinate word, and information already on that line is overwritten. Character sizes can be mixed by sending a new function word and coordinate word for each size change. Spacing on a line can be varied by sending a coordinate word for the character which is to be spaced differently. #### PROGRAMMING EXAMPLE The following programming example (figure II-2-32) requests an input of one line of data from the system console, and displays this data on the CRT as it is being typed. #### PROGRAM TIMING CONSIDERATION When performing an output operation, the computer must wait for a channel empty condition at the end of the output to prevent loss of coordinates or data. A full jump at the end of the output ensures the channel empty and acceptance of the last output word by the display controller before disconnecting from the channel. Figure II-2-32. Receive and Display Program Flowchart # **REAL-TIME CLOCK PROGRAMMING** Channel 148 is reserved for the real-time clock. This channel is always active and full, and may be read at any time. The real-time clock is a 12-bit free-running counter incrementing at a 1-megahertz rate from 0 to $4095_{10}$ . # **IOU DEDICATED CHANNELS** Figure II-2-33 illustrates the IOU dedicated channels for models 810, 815, 825, 830, and 990. Figure II-2-34 illustrates the IOU dedicated channels for models 835, 840, 845, 850, 855, and 860. Figure II-2-33. IOU Dedicated Channels, Models 810, 815, 825, 830, and 990 Figure II-2-34. IOU Dedicated Channels, Models 835, 840, 845, 850, 855, and 860 # TWO-PORT MULTIPLEXER PROGRAMMING Channel 158 provides serial communications capability with two external devices through the two-port multiplexer. One port is reserved for maintenance use. With both ports deselected, this channel can also be used for PP-to-PP communications. The arrangement is as shown below. The two-port multiplexer can communicate with all devices which use EIA standard RS-232 serial asynchronous interface at baud rates of 110, 300, 600, 1200, 2400, 4800, or 9600. (Additionally, a baud rate of 19 200 can be used with the models 815 and 825.) The baud rate for each port is independently selectable by switches on the two-port multiplexer PCB. The multiplexer ports can accommodate data with odd/even parity, 5 to 8 bits per character, and 1 or 2 stop bits. The format is set by issuing appropriate function codes. The following table lists the devices which the two-port multiplexer can use to display the system deadstart settings: | | | IOU<br>(model<br>810,815) | 10U<br>(mode1<br>825) | 10U<br>(mode1<br>830) | 10U<br>(models<br>835-860) | 10U<br>(mode1<br>990) | |----------------------|-----------------------|---------------------------|-----------------------|-----------------------|----------------------------|-----------------------| | | CC 545 SYSTEM CONSOLE | | X | X | | X | | TWO- | CC634B SYSTEM CONSOLE | | | | 1.0 | X | | PORT<br>MUX | CDC 752/722 TERMINAL | | х | X | | | | DISPLAY | CDC 721 TERMINAL | х | | х | | | | SWITCH PANEL DISPLAY | | | | | X | | The models 810, 815, 825, 830, and 990 IOU multiplexer supports the following special features: - Remote deadstart. - Calendar clock. - Internal port-baud-rate selection. The models 810 and 830 IOU multiplexer additionally supports the following special features: - Auto dial-out. - Remote power control. # **FUNCTION WORDS** The two-port multiplexer uses the channel 158 rightmost 12 bits as a function word from the PP. The function word specifies the following: | Octal<br>Code | Description | |---------------|--------------------------------------------------------------| | 7xxx | Terminal select. | | 6XXX | Terminal deselect. | | 1XXX | Calendar clock/auto dial-out operations. | | 00XX | Read summary status. | | 01XX | Read terminal data. | | 02XX | Output to first in, first out (FIFO) buffer. | | 03XX | Set operation mode to terminal. | | 04XX | Set/clear terminal control signal DATA TERMINAL READY (DTR). | | 05XX | Set/clear terminal control signal REQUEST TO SEND (RTS). | | 06XX | Not used. | | 07XX | Master clear selected port. | ## **Terminal Select (7XXX)** This code selects the terminal to which the function codes and data transmissions apply: | Code | Description | |------|----------------------------------| | 7000 | Select port 0 (future use). | | 7001 | Select port 1 (maintenance use). | # Terminal Deselect (6XXX) This code deselects the two-port multiplexer from channel 15g. When deselected, channel 15g can be used for 16-bit PP-to-PP communications. Inter-PP communications over channel 15g should be used with caution since the transfer rate is variable (5 microseconds/word through 1 millisecond/word, with 100 microseconds/word typical). # Calendar Clock/Auto Dial-Out (1XXX) This code can select several functions which pertain mostly to the calendar clock and auto dial-out functions. These particular functions involve a data transfer from the microprocessor memory to the PPs. | Code | | Description | |-------|---------------------------------------------------|----------------------------------------------------------------------------------------------------| | 1X02 | which initiated the las | terminal type and port number of | | 1X03 | Set Port Baud Rate. Se is currently selected. | ets the baud rate of the port which | | 1X04 | Read Calendar Clock. R<br>multiplexer selects eit | Reads the calendar clock after the ther port 0 or port 1. | | 1X05 | | Writes the calendar clock after seither port 0 or port 1. | | 1X06 | Prepares the multiplexe | ta (models 810 and 830 only). er for an auto dial-out write t be selected before this function | | | Bit | Bit Description | | | 56 through 59 | First number | | | 60 through 63 | Second number | | 1 x07 | Requests the multiplexe | tus (models 810 and 830 only). er for an auto dial-out status t be selected before this function | | | Bit | Bit Description | | | 52 through 59 | First number | | | 60 | Abandon call | | | 61 | Call origination status | | | 62 | Data line occupied | | | 63 | Power indication | | 1X10 | | 0 and 830 only). Requests that the call currently being | # Read Summary Status (00XX) This code prepares the channel for status input from the selected terminal. A one word input must follow to read the 12-bit status response, which is as follows: | Bit | Description | |---------------|------------------------------------| | 52 through 58 | Not used. | | 59 | Output buffer not full. | | 60 | Input ready. | | 61 | Data carrier detect or carrier on. | | 62 | Data set ready. | | 63 | Ring indication. | # PP Read Terminal Data (01XX) This code prepares the channel for data input from the selected terminal. Channel 15g must be activated and one word data input instructions must follow to read in the terminal data. The 12-bit data word has the following format: | Bit | Description | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 52 | Data set ready. Indicates that the DATA SET READY (DSR) signal is active. | | 53 | Data set ready and data carrier detector. Indicates that both DATA SET READY (DSR) and DATA CARRIER DETECTOR (DCD) signals are active. | | 54 | Overrun. Indicates that the previously received character was not read by the PP before the present character over-wrote the previous character. | | 55 | Framing or parity error. Indicates that the received character does not have a valid stop bit (framing error) or that the received character parity does not agree with the selected parity (parity error). | | 56 through 63 | Data character. | # PP Write Output Buffer (02XX) This code prepares the multiplexer for an output operation to the 64-character output buffer memory. The channel 15g active flag must be set before an output operation can proceed. When an output operation fills the buffer completely and no more locations are available, the multiplexer arbitrarily resets the channel active flag. #### Set Operation Mode to Terminal (03XX) This code sets data terminal operation mode as follows. | Code Bit | Description | | | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 58 | Enable loop back (models 815 and 825 only). When set, this bit enables a round-trip data path from channel $15_8$ to the selected RS-232 port and back to channel $15_8$ . The RS-232 interface does not transmit data externally in this mode. | | | | 59 | No parity. When set, this bit eliminates parity bit from transmitted and received character. In such a case, stop bit(s) immediately follow the last data bit. | | | | 60 | Number of stop bits. Selects number of stop bits (1 or 2) which follow immediately after parity bit: | | | | | Bit 60 Description | | | | | Clear l stop bit. | | | | | Set 2 stop bits. | | | | 61 through 62 | Number of bits per character. Select 5, 6, or 7 bits per character: | | | | Code | Bits/Character | |------|----------------| | 00 | · 5 | | 01 | 6 | | 10 | 7 | | 11 | 8 | 63 Odd/even parity select. Selects type of parity appended immediately after data bits. Also determines the parity checked on input. When set, selects even parity. # Set/Clear Data Terminal Ready (DTR) (04XX) This code conditions the data terminal to send or discontinue the DATA TERMINAL READY (DTR) control signal as follows: Set DTR set active. Clear DTR set inactive. # Set/Clear Request to Send (RTS) (05XX) This code sets or clears the terminal control signal REQUEST TO SEND (RTS) as follows: Set RTS set active. Clear RTS set inactive. # Master Clear (07XX) This code master clears the selected port, including any buffer-stored data. The DTR and RTS terminal control signals are not affected. #### PROGRAMMING CONSIDERATIONS Channel 15g communicates one at a time with the terminals connected to the external interface. To establish communications between a PP and the terminal, the following takes place: - 1. PP issues a coded function word to select the terminal. - Multiplexer responds by resetting the channel active flag to acknowledge receipt of the function code. The multiplexer now routes all data to the selected terminal; other function words and data input/output follow. #### Data Output The multiplexer can buffer-store a maximum of 64 characters per port. After 64 characters are stored in the buffer, the multiplexer resets the channel active flag on the last output word. The multiplexer terminates an output transfer when it receives an inactive signal from the channel. The multiplexer does not permit output to a full buffer. Whenever the output buffer is full and the multiplexer decodes a function code 02XX (PP write output buffer), the multiplexer resets the channel active flag. #### **Data Input** The multiplexer does not buffer-store input data from the terminal. When the PP does not input the previous data before the new data arrives, a lost data condition (overrun) exists. Request to Send and Data Terminal Ready Request to send and data terminal ready signals are automatically brought up by the hardware under the following conditions (regardless of the software RTS and DTR bits): - Data in the universal asynchronous receiver-transmitter (UART) output register. - Data in the FIFO output buffer register. When no data is in the FIFO or UART, the software bit determines RTS and DTR. # MAINTENANCE CHANNEL PROGRAMMING Any PP in the IOU can be programmed to perform any or all of the following operations on the CP, CM, and IOU through the 8-bit maintenance channel (MCH): - Initializing registers, controls, and memories. - Monitoring and recording error information. - Verifying error detection and correction hardware. The PP performing such operations is often called the maintenance control unit. The MCH consists of the MCH interface on channel 178, a maintenance access control in CP, CM, and IOU, and two sets of interconnecting cables. The MCH interface contains a selector that connects the MCH to one of up to seven isolated sets of cables. The IOU is element 0 and its maintenance access control connects internally to the selector. The CP and the CM (models 810, 815, 825, 830, and 835) are assigned arbitrary element numbers depending on the connector used at the MCH interface. (The models 845 and 855 CM shares a common cable and element number with the CP.) The CP and the CM (models 810, 815, 825, 830, and 835) connect to the IOU by separate cables and gates. This arrangement results in a radial connection that allows the CP or the CM (models 810, 815, 825, 830, and 835) to be shut down or removed without affecting communication with the other unit. #### MCH FUNCTION WORDS The MCH function word consists of the connect, opcode, and type fields used as described below. Table II-2-26 describes the MCH function word bit assignments. The connect field specifies the unit to which the MCH is connected [CP, CM (models 810, 815, 825, 830, and 835), or IOU], controlling selection within the IOU only. The unit remains connected until another connect code selects a different unit. Connect codes $10_8$ to $17_8$ leave the MCH unconnected; in this state the interface can be used for PP-to-PP communications without timeout restrictions. II-2-144 60458890 A The OPCODE field controls the unit selected by the connect code; preparing the unit for a coming read/write/echo operation; or causing the unit to halt, start, clear, or deadstart. The use of the TYPE field depends on the connected unit. With the CP the connected unit, type codes 1 to $A_{16}$ (models 810-835) or 1 through 7 (models 840 through 860) specify the CP register connected. Also, for the CP, type code 0 specifies that the internal address of the CP register to be connected is specified in a control word sent as two data words immediately following the function word. With the IOU the connected unit, type codes 0 to 7 specify the starting byte number for read/write operations (all models except 990). For model 990, the TYPE field must be set to all zeroes. For the models 810, 815, 825, 830, and 835, the CM ignores the type code. For the models 845 and 855, type code A selects access to CM. #### MCH CONTROL WORDS Some function words must be followed by a 16-bit control word specifying the internal address of the register to be connected. The control word must issue as two 8-bit data words (sometimes called address bytes). This is accomplished by outputting two 16-bit words from PP memory where each word's rightmost 8 bits comprise the 16-bit control word. Such control words are required after the following: - 1. Function words to CP (models 810, 815, 825, 830, and 835) with opcodes 4/5 (read/write) and typecode 0. - 2. Function words to CP (models 840, 845, 850, 855, 860, and 990) with opcodes 4/5. - 3. Function words to CM and IOU with opcodes 4/5. - 4. Function words to CP, CM, and IOU with opcode 8 (echo). #### MCH Programming for Halt/Start (Opcode 0/1) These operations consist of the function word output. A halt opcode halts the processor without damaging the executing process, including the integrity of the halted processor's interunit communications such as CYBER 170 State exchange request communication, central memory communications, and the process state. If the process is restarted without performing any other MCH operations, or after performing read/write with precautions as described in the Operating Systems Manual, the process continues undamaged. #### MCH Clear LED (Opcode 3) This operation clears all LEDs associated with pak errors and is intended, however not required, for use at system initialization. For maintenance reasons, this operation can also clear LEDs without initializing and master clearing. #### MCH Programming for Read/Write (Opcode 4/5) Refer to Programming for PP Data Input/Output in this section for a more complete procedure. In general terms, proceed as follows: - 1. Issue function with opcode 4/5. - 2. Output data word (leftmost half of control word). - 3. Verify error flag clear. - 4. Output data word (rightmost half of control word). - 5. Verify error flag clear. - 6. Input/output required number of data words. - 7. Verify error flag clear. Reading a nonexistent register returns all zeros. Writing to a read-only register, or to a nonexistent register, does not alter any register. Most registers are read/written as 64-bit (8-byte) registers, requiring the input/output of eight MCH data words. Most registers physically smaller than eight bytes are right-justified with zero-fill. Reading a status summary register is an exception in that the status information repeats in each byte. The IOU may disconnect the MCH without affecting subsequent MCH operations after the following: - Reading one to eight bytes from any register. - Writing one byte to a corrected error log register. - Writing one byte to a uncorrectable error log register. The following MCH operations on CP registers can be performed with the CP running or halted (when reading or writing registers which may change while being accessed, the CP should be halted to avoid erroneous results): - Read CP status summary register. - Read CP fault status register. - Read CP corrected error log registers. - Read CP options installed. - Read CP equipment ID register. - Read/write CP dependent environmental control register. - Read/write test mode control registers. - Clear errors. To read/write other CP registers, the CP must be running since microcode accesses these registers. Refer to table II-2-26. When reading or writing registers which may change while being accessed, precautions must be taken as described in the operating systems manual listed in the preface. # MCH Programming for Master Clear/Clear Errors (Opcode 6/7) These operations consist of a single function word output. The master clear immediately and arbitrarily clears the connected unit without regard to possible information loss. The clear-errors operation clears the connected unit error indicators. The unit concerned should be halted to avoid loss of possible (next) error reporting while the errors are cleared. #### MCH Echo (Opcode 8) This operation checks the data path between the MCH and the IOU MAC. Following the operation MCH is activated and two bytes are sent to IOU MAC. IOU ignores the first byte and latches the second byte in the Address Holding Register, in any data pattern. MCH is deactivated after the second byte is accepted in IOU MAC and the channel is activated followed by an input sequence. IOU MAC sends data (contents of Address Holding Register) upon receiving the Active signal and subsequent Empty signals. There is no restriction on the number of data words read. ## MCH Programming for Read IOU Summary Status (Opcode C, IOU Only) This operation is an alternative, faster means of reading the IOU summary status register. In general terms, proceed as follows: - 1. Issue function with opcode c. - 2. Input summary status byte. Table II-2-26. MCH Function Word Bit Assignments (Sheet 1 of 2) | Field | Code (Hex) | Description | |---------------------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | МС | H Function Word to IOU | | CONNECT<br>(bits<br>8-11) | 0<br>8-F | Connect IOU maintenance registers. PP-to-PP communications. | | OPCODE | 4<br>5<br>6<br>7<br>8<br>C | Prepare for read (control word required). Prepare for write (control word required). Master clear ADU and R barrel. Clear fault status registers. Echo. Read IOU summary status (reads one byte, control word not required). | | TYPE (bits 0-3) | 0-7 | IOU registers are read circularly (byte O follows byte 7) from the byte specified by the TYPE field. | | MCH Fun | ction Word to CM | (Models 810, 815, 825, 830, and 835 Only) | | CONNECT (bits 8-11) | 1 | Connect CM maintenance register. | | OPCODE | 4<br>5<br>6<br>7<br>8 | Prepare for read (control word required). Prepare for write (control word required). Master clear. Clear fault status register. Echo. | Table II-2-26. MCH Function Word Bit Assignments (Sheet 2 of 2) | CONNECT (bits 8-11) OPCODE TYPE (Models 810, 815, 825, 830, and 835 TYPE (Models 840, 845, 850, 855, and 860) TYPE (Model 990) | xadecimal) | Description | | | | |-------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | (bits<br>8-11)<br>OPCODE<br>TYPE<br>(Models<br>810, 815,<br>825, 830,<br>and 835<br>TYPE<br>(Models<br>840, 845,<br>850, 855,<br>and 860) | MCH Function Word to CP | | | | | | TYPE (Models 810, 815, 825, 830, and 835 TYPE (Models 840, 845, 850, 855, and 860) TYPE (Model | 2 | Connect CP maintenance registers. | | | | | (Models<br>810, 815,<br>825, 830,<br>and 835<br>TYPE<br>(Models<br>840, 845,<br>850, 855,<br>and 860) | 0<br>1<br>4<br>5<br>6<br>7<br>8 | Halt processor. Start processor. Prepare for read (control word required). Prepare for write (control word required). Master clear. Clear errors. Echo. | | | | | (Models<br>840, 845,<br>850, 855,<br>and 860)<br>TYPE<br>(Model | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>A | Control word required. Read/write cache data buffer. Read/write map segment files. Read maintenance scan. Read map page files. Read/write register file A. Read/write register file B. Write maintenance scan limit. Read/write control store. Read AD register. | | | | | (Model | 0<br>1<br>3<br>4<br>5<br>6<br>7<br>A | CP process state register. Control store micrand data. Maintenance access control reference (ROM). Soft control memories. BDP control memories. Instruction fetch decode memories. Register file. CMC maintenance registers. | | | | | | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>A<br>B<br>C-F | CP process state register. Control store micrand data. Maintenance access control (echo) function. Reserved for future use. Soft control memories. BDP control memories. Operand cache. Register file. Load and store section control memories. Error processing network. CMC maintenance registers. Maintenance access control extended echo. Reserved for future use. | | | | # **GLOSSARY** | A register | Address register | |------------|----------------------------------------------------| | ASCII | American Standard Code for Information Interchange | | ASID | Active segment identifier | | ВС | Base constant | | BDP | Business data processing | | BN | Byte number | | BS | Binding section | | CBP | Code base pointer | | CEJ/MEJ | Central exchange jump/monitor exchange jump | | CEL | Corrected error log | | CEM | Configuration environment monitor | | CF | Critical frame pointer | | CFF | Critical frame flag | | CM | Central memory | | CP | Central processing unit | | CSF | Current stack frame pointer | | DEC | Model-dependent environment control | | DI | Debug index | | DLP | Debug list pointer | | DM | Debug mask | | DMR | | | DSC | Debug mask register | | DSP | Display station controller | | | Dynamic space pointer | | DSR | Data set ready | | DTR | Data terminal ready | | EBCDIC | Expanded binary coded decimal interchange code | | ECL | Emitter-coupled logic | | ECM | Extended central memory | | ECS | Extended core storage | | EIA | Electronics Industries Association | | EID | Element identifier | | EPF | External procedure flag | | ES | End suppression toggle (BDP edit instruction) | | FIFO | First-in, first-out | | FL | Field length | | FLC | Central memory field length register | | FLE | Extended core storage field length register | | FP | Floating-point | | G/L | Global/local | | IC | Integrated circuit | | ILH | Instruction look-ahead | | I/O | Input/output | | IOU | Input/output unit | | JPS | Job process state pointer | | KEY | Key | | LOCK | Lock | | LPID | Last processor identification | | LRN | Largest ring number | | LSI | Large-scale integration | | MA | Monitor address | | MAC | Maintenance access control | | == | | | | | MCH Maintenance channel Monitor condition register MCR Model-dependent flags MDF MDW Model-dependent word Monitor flag MF MMR Monitor mask register Micro-operator (BDP edit instruction) MOP MOS Metal-oxide-semiconductor MPS Monitor process state pointer NOS Network Operating System NS Negative sign toggle OCF On-condition flag ΟI Options installed ON Occurrence number OP CODE Operation code Program address register P register PFA Page frame address **PFS** Processor fault status PID Processor identifier PIT Process interval timer **PMF** Performance monitoring flag PN Page number PND Process-not-damaged flag PO Page offset PP Peripheral processor PPM Peripheral processor memory **PSA** Previous save area pointer **PSF** Previous stack frame PSM Page size mask PTA Page table address PTE Page table entry PTL Page table length PTM Processor test mode **PVA** Process virtual address Central memory reference address register RAC RAE Extended core storage reference address register RAM Random-access-memory RMA Real memory address Ring number ROM Read-only memory RP Read permission (segment descriptor field) RTS Request to send Special characters table (BDP edit intruction) SCT Segment descriptor table entries SDE SDT Segment descriptor table SECDED Single error correction/double error detection SEG Process segment number SFSA Stack frame save area SIT System interval timer The symbol (BDP edit instruction) SM SN Negative sign (BDP edit instruction) SPID Segment page identifier SPT System page table SRT Subscript range table SS Status summary STA Segment table address STL Segment table length SV Specification value | SVA | System virtual address | |-------|---------------------------------------------------| | TED | Trap-enable delay | | TEF | Trap-enable flip-flop | | TOS | Top of stack | | UART | Universal asynchronous receiver-transmitter | | UCR | User condition register | | UEL | Uncorrected error log | | UMR | User mask register | | UTP | Untranslatable pointer | | UVMID | Untranslatable virtual machine identifier | | VC | Search control code (page descriptor field) | | VL | Segment validation (segment descriptor field) | | VMCL | Virtual machine capability list | | VMID | Virtual machine identifier | | WP | Write access control (segment descriptor field) | | XP | Execute access control (segment descriptor field) | | ZF | Zero field toggle (BDP edit instruction) | This appendix contains edit examples for the BDP edit instruction (ED). # NOTE For examples in this appendix, the destination field is assumed to have the same length and decimal point position as the source field, except for the differences necessitated by insertion characters. Edit Masks 1 through 25. These edit masks are used in the examples given in the following pages. | Mask<br>Number | COBOL<br>Picture | Edit Mask (Hexadecimal with insertion characters *, \$, 0, /, b, C and R shown as alphanumerics) | |----------------------|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | \$ZZ,ZZ9.99 | 08 96 72 C4 72 01 95 02 | | 2 | \$ZZ,ZZZ.99 | 07 96 72 C4 73 95 02 | | 3 | \$ZZ,ZZZ.ZZ | 08 96 72 C4 73 95 02 FA | | 4 | -zzzz9.99 | 06 B3 74 01 95 02 | | 5<br>6 | ZZZZ9.99+<br>ZZ.999,99 | 07 74 01 95 02 52 98<br>06 72 C5 03 94 02 (Decimal point is comma) | | 7 | \$\$\$\$.99CR | OB 61 \$ 73 80 95 02 62 C R B8 | | 8 | \$\$\$,\$\$\$.\$\$ | OA 61 \$ 72 C4 73 80 95 02 FA | | 9 | \$\$\$\$99,99CR | OC 61 \$ 73 80 02 94 02 62 C R B8 | | 10 | \$\$\$,\$\$9.99 | DA 61 \$ 72 C4 72 80 01 95 02 | | 11 | \$99.99 | 05 96 02 95 02 | | 12<br>13<br>14<br>15 | \$**,**9.99<br>\$**,***.**BCR<br>\$**,***.**<br>**,***,**+<br>99999,99 | OA 96 D1 * 72 C4 72 O1 95 O2<br>11 96 D1 * 72 C4 73 95 O2 63 b C R B8 F7 95 E5<br>OC 96 D1 * 72 C4 73 95 O2 F7 95 E2<br>OD D1 * 72 C4 73 95 O2 52 98 F6 95 E3<br>O7 50 71 80 O5 94 O2 | | 17<br>18 | <b>.</b> 99<br><del>++++</del> 99 | 06 50 73 80 95 02<br>05 52 73 80 02 | | Mask<br>Number | COBOL<br>Picture | Edit Mask (Hexadecimal with insertion characters *, \$, 0, /, b, C and R shown as alphanumerics) | |----------------|------------------|--------------------------------------------------------------------------------------------------| | 19 | 00999.00 | 09 42 0 0 03 95 42 0 0 | | 20 | 99,999 | 05 02 C4 03 F6 (blank when zero) | | 21 | XX/XX/XX | 08 12 41 / 12 41 / 12 | | 22 | BBB99.99- | 09 43 ь ь в 02 95 02 в3 | | 23 | 999.00 | 06 03 95 42 0 0 | | 24 | 999.BB | 06 03 95 42 ъ ъ | | 25 | 9B9B9 | 06 01 91 01 91 01 or | | | | 08 01 41 b 01 41 b 01 | Edit Examples Using Edit Masks 1 through 8. | Example | Source<br>Field | | Mask<br>Used | Destination<br>Field | |---------|----------------------|-----|--------------|----------------------------| | 1<br>2 | 00000.00<br>00000.01 | | 1 | \$55550.00 | | 3 | 00000.01 | | 1 | \$66660.01 | | 4 | 00001.00 | | 1 | \$ЪЪЪЪЪО.10 | | 5 | 00010.00 | | 1 | \$66661.00 | | 6 | 00100.00 | | 1 | \$666610.00 | | 7 | 01000.00 | | 1 | \$bbb100.00<br>\$b1,000.00 | | 8 | 10000.00 | | 1 | \$10,000.00 | | 9 | 00000.00 | | 2 | \$bbbbbb.00 | | 10 | 00000.00 | | 3 | bbbbbbbbb | | 11 | 00000.01 | | 3 | \$bbbbbb.01 | | 12 | 00001.00 | | 3 | \$ььььь1.00 | | 13 | 10000.00 | | 3 | \$10,000.00 | | 14 | -00000.00 | | 4 | -ьььь0.00 | | 15 | +00000.00 | | 4 | <b>bbbbb0.00</b> | | 16 | -12345.67 | | 5 | 12345.67- | | 17 | +00012.34 | | 5 | ььь12.34+ | | 18 | 00000.00 | | 6 | ььь000,00 | | 19 | 01000.00 | | 6 | ы.000,00 | | 20 | -123.45 | | 7 | \$123.45CR | | 21 | -023.45 | | 7 | ъ\$23.45CR | | 22 | 003.45 | | 7 | bb\$3.45bb | | 23 | 000.45 | | 7 | bbb\$.45bb | | 24 | 00000.00 | · · | 8 | bbbbbbbbb | | 25 | 00000.01 | | 8 | bbbbbb\$.01 | Edit Examples Using Edit Masks 9 through 16. | Example | Source<br>Field | Mask<br>Used | Destination<br>Field | |---------|-----------------|--------------|----------------------| | 26 | 00001.00 | 8 | <b>ььььь</b> \$.10 | | 27 | 00001.00 | 8 | ььььь\$1.00 | | 28 | 00010.00 | 8 | ьььь\$10.00 | | 29 | 00100.00 | 8 | ььь\$100.00 | | 30 | 01000.00 | 8 | ь\$1,000.00 | | 31 | 10000.00 | 8 | \$10,000.00 | | 32 | -0000000 | 9 | ььь \$00,00СК | | 33 | 0010000 | 9 | ьь\$100,00ьь | | 34 | 0100000 | 9 | ъ\$1000,00ъъ | | 35 | -1000000 | 9 | \$10000,00CR | | 36 | 00000.00 | 10 | ьььь\$0.00 | | 37 | 10000.00 | 10 | \$10,000.00 | | 38 | 00.00 | 11 | \$00.00 | | 39 | 12.34 | 11 | \$12.34 | | 40 | 00000.00 | 12 | \$****0.00 | | 41 | 00000.01 | 12 | \$ <b>****</b> 0.01 | | 42 | 00000.10 | 12 | \$ <b>****</b> 0.10 | | 43 | 00001.00 | 12 | \$****1.00 | | 44 | 00010.00 | 12 | \$****10.00 | | 45 | 00100.00 | 12 | \$***100.00 | | 46 | 01000.00 | 12 | \$*1,000.00 | | 47 | 10000.00 | 12 | \$10.000.00 | | 48 | 00000.00 | 13 | ****** **** | | 49 | -00000.01 | 13 | \$**,***.01bCR | | 50 | 00000.01 | 13 | \$**,***.01bbb | | 51 | -00000.00 | 13 | ******* | | 52 | 00000.00 | 14 | ****** | | 53 | -00000.01 | 14 | \$*****.01 | | 54 | 00000.00 | 15 | ***** | | 55 | -00000.00 | 15 | ****** | | 56 | 12345.67 | 15 | 12,345.67+ | | 57 | -12345.67 | 15 | 12,345.67- | | 58 | -00000000 | 16 | ъ-00000,00 | | 59 | -12345678 | 16 | -123456,78 | | 60 | 00000000 | 16 | ьь00000,00 | | 61 | 12345678 | 16 | ь123456,78 | Edit Examples Using Edit Masks 17 through 25. | Example | Source<br>Field | Mask<br>Used | Destination<br>Field | |---------|-----------------|--------------|----------------------| | 62 | -000.00 | 17 | bbb00 | | 63 | 000.00 | 17 | bbbb.00 | | 64 | -001.00 | 17 | bb-1.00 | | 65 | 010.00 | 17 | bb10.00 | | 66 | -100.00 | 17 | -100.00 | | 67 | 00000 | 18 | ььь+00 | | 68 | -00000 | 18 | bbb-00 | | 69 | 00012 | 18 | bbb+12 | | 70 | -00123 | 18 | bb-123 | | 71 | 01234 | 18 | b+1234 | | 72 | -12345 | 18 | -12345 | | 73 | 000 | 19 | 00000.00 | | 74 | -123 | 19 | 00123.00 | | 75 | 123 | 19 | 00123.00 | | 76 | 00000 | 20 | bbbbbb | | 77 | 00001 | 20 | 00,001 | | 78 | HHMMSS | 21 | HH/MM/SS | | 79 | -00.00 | 22 | ььь00.00- | | 80 | 00.00 | 22 | ььь00.00ь | | 81 | 12.34 | 22 | bbb12.34b | | 82 | 000 | 23 | 000.00 | | 83 | -123 | 23 | 123.00 | | 84 | 123 | 23 | 123.00 | | 85 | 000 | 24 | 000.ьь | | 86 | -123 | 24 | 123. ьь | | 87 | 123 | 24 | 123. bb | | 88 | 000 | 25 | 0ь0ь0 | | 89 | 123 | 25 | 1ь2ь3 | | | | | 10203 | Edit Mask 26. Example Number 90 Using Edit Mask Number 26. Source Field: 0 0 0 0 0 0 0 0 0 0 0 0 0 . 0 0 0 0 0 Example Number 91 Using Edit Mask Number 26. Source Field: 1 2 3 4 5 6 7 8 9 0 1 2 . 6 5 4 3 2 1 Destination Field: \$ 1 2 3 , 4 5 6 , 7 8 9 , 0 1 2 . 6 5 4 , 3 2 1 INTERFACE INFORMATION C # **INTERFACES** This appendix contains signal description and sequencing information for models 810 through 990 input/output channel interfaces. The following interfaces are available. - External interface, 12-bit - Maintenance channel interface - Two-port multiplexer interface #### **TWELVE-BIT EXTERNAL INTERFACE** The 12-bit external interface uses bidirectional, synchronous communication to transmit data between bits 52 through 63 of the channel data register and a number of CDC CYBER 170 external devices. The transmission is over separate input and output coaxial cables using an AC transmission scheme. In addition to 13 data signals (12 data, 1 parity), the cables also transmit eight control signals from a PP to an external device, and four from an external device to a PP. Maximum cable length between repeaters is 21 meters (70 feet). ## MAINTENANCE CHANNEL INTERFACE The maintenance channel interface (channel 178) uses unidirectional, asynchronous communication. It transmits only 9 data bits (8 data, 1 parity) in each direction. The data transfers between bits 56 through 63 of the channel data register and the external device. #### TWO-PORT MULTIPLEXER INTERFACE The two-port multiplexer interface is an EIA standard RS-232 serial interface. Refer to this standard for more information. 60458890 B # **SIGNALS** The following signals are described below. # **TWELVE-BIT CHANNEL CONTROL SIGNALS** The 12-bit channel uses the following control signals: | <u>Signal</u> | Description | |-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Active Pulse | Sent by a data sending device to a data receiving device to begin a data transmission. Normally sent by a PP to an external device. An external device can send this signal to a PP only on the 12-bit channel. | | Inactive Pulse | Sent from either a data sending or data receiving device to signify end of a data transmission; clears active and full flags. | | Full Pulse | Sent from a data sending device to a data receiving device with transmitted data. The full pulse directs the receiving device to sample the data signals. | | Empty Pulse | Sent by a data receiving device to a data sending device to acknowledge receipt of a full pulse and associated data. This pulse signals the sender to transmit more data. | | Function Pulse | Sent by IOU to an external device to indicate that the associated data signals are control signals. | | Master Clear | Sent by IOU to all external devices on the $\rm I/O$ channel. It indicates to those devices that all activity is to cease and initial conditions are to be restored. | | 10-Megahertz<br>Clock | Consists of a pulse sent every 100 nanoseconds. This clock synchronizes all external devices to IOU. | | 1-Megahertz<br>Clock | A pulse every 1 microsecond; sent by the IOU to an external device. | # **MAINTENANCE CHANNEL SIGNALS** The maintenance channel uses the following control signals. # **Control Signals** | Signal | Description | | |----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Active | Sent from IOU to external device to indicate start of data transmission. | | | Inactive | Sent from either data sending or data receiving device to indicate end of transmission. | | | Ready | Sent from data sending device to data receiving device with transmitted data; instructs receiving device to sample the data lines. The receiving device then sends a ready pulse back to acknowledge receipt of the data and to indicate it is ready for more data. | | | Function | Sent only to an external device to indicate that signals on data lines are control signals. | | | Error | Sent by external device to IOU to indicate that the device detected an error. | | # Signals and Cables Table II-C-1 lists the signals used by the maintenance channel interface. Table II-C-1. Maintenance Channel Signals (Sheet 1 of 2) | Signal Name | Connector Pins | |----------------------------------------------|----------------| | Data out bit 20 (unidirectional) | A1/A2 | | Data out bit $2^1$ (unidirectional) | A3/A4 | | Data out bit $2^2$ (unidirectional) | A5/A6 | | Data out bit $2^3$ (unidirectional) | A7/A8 | | Data out bit $2^4$ (unidirectional) | A9/A10 | | Data out bit $2^5$ (unidirectional) | B1/B2 | | Data out bit 26 (unidirectional) | в3/в4 | | Data out bit 2 <sup>7</sup> (unidirectional) | в5/в6 | | Data out parity (unidirectional) | в7/в8 | Table II-C-1. Maintenance Channel Signals (Sheet 2 of 2) | Signal Name | Connector Pins | |---------------------------------------------|----------------| | Data in bit 20 (unidirectional) | C1/C2 | | Data in bit $2^{1}$ (unidirectional) | C3/C4 | | Data in bit 2 <sup>2</sup> (unidirectional) | C5/C6 | | Data in bit 2 <sup>3</sup> (unidirectional) | C7/C8 | | Data in bit 2 <sup>4</sup> (unidirectional) | C9/C10 | | Data in bit 2 <sup>5</sup> (unidirectional) | D1/D2 | | Data in bit 26 (unidirectional) | D3/D4 | | Data in bit 2 <sup>7</sup> (unidirectional) | D5/D6 | | Data in parity (unidirectional) | D7/D8 | | Function out | E1/E2 | | Ready out | E3/E4 | | Spare | E5/E6 | | Active out | E7/E8 | | Inactive out | E9/E10 | | Ready in | F1/F2 | | Spare | F3/F4 | | Inactive in | F5/F6 | | Summary status in | F7/F8 | | Exchange accept in | D9/D10 | | Error in | в9/в10 | #### **DATA SIGNALS** A data sending device transmits the data signals to a data receiving device along with the associated full pulses. The IOU also transmits a function code over the data lines to an external device, with a function pulse. ### PP AND CHANNEL INTERACTION Channel transmissions are controlled by the active and full flags. When a PP executes an I/O instruction, the state of these flags is altered and control signal(s) sent to the external devices. When the devices send control signals to the IOU, the state of these flags is again altered. #### **ACTIVE FLAG** When the PP sets the active bit with a 00740 or 00741 instruction, the IOU sends an active pulse on the external channel. The IOU sends an inactive pulse when the PP clears the active bit. An active pulse sent by an external device sets the active bit; an inactive pulse sent by an external device clears the active bit. #### **FULL FLAG** When a PP sets the full bit using a 00720, 00721, 0073, or 1073 instruction, the IOU sends a full pulse and data pulses for the data contained in the channel data register to an external device. When a PP clears the full bit with a 00700, 00701, or 1071 instruction, the system sends an empty pulse. When an external device sends a full pulse, the associated data pulses set the channel data register, and the system sets the full bit. When an external device sends an empty pulse, the IOU clears the full bit. #### **FUNCTION INSTRUCTIONS** When a function instruction (00760, 00761, 00770, 00771) executes, the IOU sets active and full bits, writes a word into the channel data register, and transmits the word from the data register to an external device. The IOU transmits a function pulse to the external device to indicate that the word is a control signal rather than data. The external device sends an inactive pulse to acknowledge the receipt of the function, thereby setting the active bit and the full bit to zero. #### **EXTERNAL CHANNEL INPUT/OUTPUT SEQUENCES** Tables II-C-2 (Data Input Sequence), and II-C-3 (Data Output Sequence) show the sequences followed by the channels during data input and output over an external interface. Similarily, tables II-C-4 (MCH Input Sequence), and II-C-5 (MCH Output Sequence) show input and output sequences for the maintenance channel $(17_8)$ . Data Sequences Timing is shown in figure II-C-1. Table II-C-2. Data Input Sequence \*The inactive signal is normally sent from the external device to the IOU. However, in certain cases the IOU may deactivate the channel. This is determined by the external device and the function being executed. #### Key: - A, F, E are the active, full and error flags - 1. PP executes a function instruction which sets the active and full flags in the internal interface, places a word in the channel register, and sends a function pulse. - The external device acknowledges the acceptance of the function by sending an inactive signal which clears the active flag, the full flag, and the channel register. - 3. PP sets the active flag to indicate that data flow may start. - 4. The external device sends a 12-bit word (plus parity) to the channel register, with a full signal which sets the full flag. - 5. PP stores the data word in PPM and clears the full flag which, in turn, sends an empty signal to the external device. - 6. Steps 4 and 5 repeat until the device completes the data transfer. Then the external device clears its active condition and sends an inactive signal to the PP, which clears the channel active flag. Table II-C-3. Data Output Sequence #### Key: - A, F, E are the active, full, and error flags. - PP executes a function instruction which sets the active and full bits in the internal interface, places a word into the channel register, and sends the function pulse. - The external device acknowledges the acceptance of the function by sending an inactive signal. This, in turn, clears the active flag, the full flag, and the channel register. - 3. PP sets the active flag to indicate that data flow is about to start. - 4. PP places a 12-bit data word (plus parity) into the channel register, which sets the full flag and sends the full signal. - 5. The external device accepts the data word and sends an empty signal which clears the channel register and the full flag. - 6. Steps 4 and 5 repeat until the PP has sent all the data to complete the data transfer. Then the PP clears the channel active flag, which turns off the external device with an inactive signal. 60458890 A External PP Device Flags 0 0 0 (1.)**Function Pulse** 0 0 **Inactive Signal** (2.)(3.)0 0 Active Signal 8 Bit Control Word Repeated twice (for 0 Ready Signal (4.)two control bytes) 0 Ready Signal (5.) 0 0 (6.) Inactive Signal 0 0 (7.) **Active Signal** 8 Data Bits Repeated (8.) 1 0 Ready Signal for each Ready Signal Inactive Signal Table II-C-4. MCH Input Sequence ## Key: A, F, E are the active, full and error flags. 0 0 0 0 (9.) (10.) - PP executes a function instruction which sets the active and full flags in the internal interface, places a word in the channel register and sends a function pulse. - The external device acknowledges the acceptance of the function by sending an inactive signal. This, in turn, clears the active flag, the full flag, and the channel register. - The PP sets the active flag to indicate that control word data flow is about to start. - 4. The PP places a control byte into the channel register, which sets the full flag and sends the ready signal. - 5. The external device accepts the control byte and sends the ready signal, which clears the channel register and the full flag. - 6. Steps 4 and 5 are repeated for a second control byte. The two control bytes contain the upper and lower portions of the address of the data to be read. - 7. The PP ensures that the channel is empty and then deactivates the channel, which clears the active flag. data byte - 8. The PP sets the active flag to indicate that data flow may start. - 9. The external device sends an 8-bit byte to the channel register with a ready signal which, in turn, sets the full flag. - 10. The PP stores the data word and clears the full flag which, in turn, sends the ready signal to the external device. - 11. Steps 8 and 9 repeat until the data transfer is complete. The PP deactivates the channel, which turns off the external device with an inactive signal. Table II-C-5. MCH Output Sequence #### Key: - A, F, E are the active, full and error flags. - PP executes a function instruction which sets the active and full bits in the internal interface, places a word in the channel register and sends the function pulse. - The external device acknowledges the acceptance of the function by sending an inactive signal. This, in turn, clears the active flag, the full flag, and the channel register. - The PP sets the active flag to indicate that control word data flow is about to start. - 4. The PP places a control byte into the channel register, which sets the ready flag and sends the full signal. - 5. The external device accepts the control byte and sends the ready signal which clears the channel register and the full flag. - 6. The PP ensures that the channel is empty and then deactivates the channel, which clears the active flag. - 7. The PP sets the active flag to indicate that data flow is about to start. - 8. The PP places an 8-bit byte into the channel register, which sets the full flag and sends the ready signal. - 9. The external device accepts the data byte and sends the ready signal, which clears the channel register and the full flag. - 10. Steps 8 and 9 repeat a sufficient number of times to complete the data transfers. The PP deactivates the channel, which turns off the external device with an inactive signal. Figure II-C-1. Data Sequences Timing This appendix lists the central processor and peripheral processor instructions, in both opcode and mnemonic sequences. #### CP INSTRUCTIONS - OPCODE SEQUENCE (Sheet 1 of 4) | Opcode | Mnemonic | Instruction | Page | |------------|----------|-------------------------------|---------------------| | 00 | HALT | Program error | 11-1-72 | | 01 | SYNC | Scope loop synchronization | II-1-73 | | 02 | EXCHANGE | Exchange | II-1-73 | | 03 | INTRUPT | Processor interrupt | II-1-84 | | 04 | RETURN | Return | II-1-74 | | 05 | PURGE | Purge buffer | II-1-86 | | 06 | POP | Pop | 11-1-75 | | 08 | CPYMX | Copy free running counter | II-1-76 | | 09 | CPYAA | Copy address, A to A | II-1-21 | | OA | CPYXA | Copy address, X to A | 11-1-2 | | ОВ | CPYAX | Copy address, A to X | 11-1-21 | | OC | CPYRR | Copy half-word | II-1-21 | | OD | CPYXX | Copy full-word | II-1-22 | | OE . | CPYSX | Copy from state register | 11-1-88 | | OF | CPYXS | Copy to state register | 11-1-88 | | 10 | INCX | Integer sum, immediate | 11-1-13 | | 11 | DECX | Integer difference, immediate | II-1-14 | | 14 | LBSET | Test and set bit | II-1-77 | | 16 | TPAGE | Test and set page | II-1-77 | | 17 | LPAGE | Load page table index | II-1-8 <sup>2</sup> | | 18 | IORX | Logical sum | II-1-28 | | 19 | XORX | Logical difference | 11-1-28 | | 1A | ANDX | Logical product | II-1-28 | | 1B | NOTX | Logical complement | 11-1-28 | | 1C | INHX | Logical inhibit | 11-1-29 | | 1E | MARK | Mark to Boolean | 11-1-30 | | 1 <b>F</b> | ENTZ | Enter zeros | 11-1-24 | | 1F | ENTO | Enter ones | II-1-24 | | 1 <b>F</b> | ENTS | Enter signs | II-1-24 | | 20 | ADDR | Half-word integer sum | II-1-12 | | 21 | SUBR | Half-word integer difference | 11-1-14 | | 22 | MULR | Half-word integer product | II-1-13 | | 23 | DIVR | Half-word integer quotient | 11-1-15 | | 24 | ADDX | Integer sum | II-1-13 | | 25 | SUBX | Integer difference | II-1-14 | II-D-1 ### CP INSTRUCTIONS - OPCODE SEQUENCE (Sheet 2 of 4) | Opcode | Mnemonic | Instruction | Page | |------------|---------------|---------------------------------------------------------|--------------------| | 26 | MULX | Integer product | II-1-15 | | 27 | DIVX | Integer quotient | 11-1-16 | | 28 | INCR | Half-word integer sum, immediate | II-1-12 | | 29 | DECR | Half-word integer difference, immediate | 11-1-14 | | 2A | ADDAX | Address increment, indexed | 11-1-22 | | 2C | CMPR | Half-word integer compare | 11-1-16 | | 2D | CMPX | Integer compare | II-1-16 | | 2E | BRREL | Branch relative | 11-1-17 | | 2F | BRDIR | Inter-segment branch | II-1-18 | | 30 | ADDF | FP sum | II <b>-1-</b> 55 | | 31 | SUBF | FP difference | 11-1-55 | | 32 | MULF | FP product | II-1-56 | | 33 | DIVF | FP quotient | II <b>-</b> 1-57 | | 34 | ADDD | Double-precision FP sum | II <b>-</b> 1-55 | | 35 | SUBD | Double-precision FP difference | II <b>-</b> 1-55 | | 36 | MULD | Double-precision FP product | 11-1-56 | | 37 | DIVD | Double-precision FP quotient | II-1-57 | | 39 | ENTX | Enter XI, immediate logical | 11-1-24 | | 3A | CONI | Convert from integer to FP | 11-1-53 | | 3в | CONF | Convert from FP to integer | 11-1-53 | | 3C | CMPF | FP compare | 11-1-60 | | 3D | ENTP | Enter immediate, positive | II-1-24 | | 3E | ENTN | Enter immediate, negative | 11-1-24 | | 3 <b>F</b> | ENTL | Enter immediate, logical | 11-1-24 | | 40 | ADDFV | FP vector sum | 11-1-65 | | 41 | SUBFV | FP vector difference | 11-1-65 | | 42 | MULFV | FP vector product | 11-1-65 | | 43 | DIVFV | FP vector quotient | 11-1-65 | | 44 | ADDXV | Integer vector sum | II-1-63 | | 45 | SUBXV | Integer vector difference | II-1-63 | | | | | TT 1 (/ | | 48<br>49 | IORV | Logical vector sum | II-1-64 | | | XORV | Logical vector difference | II-1-64 | | 4A<br>4B | ANDV<br>CNIFV | Logical vector product | II-1-64<br>II-1-64 | | | | Convert vector from integer to FP | | | 4C<br>4D | CNFIV<br>SHFV | Convert vector from FP to integer Shift vector circular | II-1-64<br>II-1-65 | | 50 | CHADRON. | • • • • • • • • • • • • • • • • • • • | TT 1 (2 | | 50<br>51 | CMPEQV | Integer vector compare, = | II-1-63 | | 51<br>52 | CMPLEV | Integer vector compare, $\frac{\langle}{\Sigma}$ | II-1-63<br>II-1-63 | | | CMPGEV | Integer vector compare, $\sum_{i=1}^{n}$ | | | 53 | CMPNEV | Integer vector compare, # | 11-1-63 | | 54<br>55 | MRGV | Merge vector | II-1-66<br>II-1-66 | | 56 | GTHV<br>SCTV | Gather vector | | | 57 | SUMFV | Scatter vector FP vector summation | II-1-68<br>II-1-70 | | 70 | ADDN | | | | 70 | אטעא | Decimal sum | 11-1-34 | # CP INSTRUCTIONS - OPCODE SEQUENCE (Sheet 3 of 4) | 0pcode | Mnemonic | Instruction | Page | |----------|----------------|------------------------------------------------------|------------------| | 71 | SUBN | Decimal difference | 11-1-34 | | 72 | MULN | Decimal product | 11-1-34 | | 73 | DIVN | Decimal quotient | II-1-34 | | 74 | CMPN | Decimal compare | II-1-35 | | 7.5 | MOVN | Numeric move | II-1-36 | | , , | 110 / 14 | Numeric move | 11-1-30 | | 76 | MOVB | Move bytes | 11-1-40 | | 77 | CMPB | Byte compare | II-1-39 | | 80 | LMULT | Load multiple | II-1 <b>-</b> 6 | | 81 | SMULT | Store multiple | II-1-6 | | 82 | LX | Load word | 11-1-7 | | 0.0 | av. | | | | 83 | SX | Store word | II-1-7 | | 84 | LA | Load address | 11-1-8 | | 85 | SA | Store address | II-1-8 | | 86 | LBYTP,j | Load bytes, relative | II-1-9 | | 87 | ENTC | Enter X1, signed immediate | 11-1-25 | | 88 | LBIT | Load bit | 11-1-10 | | 89 | SBIT | Store bit | II-1-10 | | 8A | ADDRQ | Half-word integer sum, signed immediate | II-1-13 | | 8B | ADDXQ | Integer sum, signed immediate | II-1-13 | | 8C | MULRQ | Half-word integer product, signed immediate | II-1-15 | | 8D | ENTE | Enter, signed immediate | II-1-25 | | 8E | ADDAQ | | | | 8F | ADDRQ | Address increment, signed immediate Address relative | II-1-23 | | 90 | • | | II-1-23 | | 91 | BRREQ<br>BRRNE | Branch on half-word equal | II-1-18 | | 91 | DKKNE | Branch on half-word not equal | 11-1-18 | | 92 | BRRGT | Branch on half-word greater than | II-1-18 | | 93 | BRRGE | Branch on half-word greater than or equal | II-1-18 | | 94 | BRXEQ | Branch on equal | II-1-19 | | 95 | BRXNE | Branch on not equal | II-1-19 | | 96 | BRXGT | Branch on greater than | II-1-19 | | | | _ | | | 97 | BRXGE | Branch on greater than or equal | II-1-19 | | 98 | BRFEQ | FP branch on equal | II-1-59 | | 99 | BRFNE | FP branch on not equal | II <b>-</b> 1-59 | | 9A | BRFGT | FP branch on greater than | II-1-59 | | 9B | BRFGE | FP branch on greater than or equal | 11-1-59 | | 9C | BRINC | Branch and increment | II-1-19 | | 9D | BRSEG | Branch on segments unequal | II-1-20 | | 9E | BROVR | FP branch on overflow | II-1-59 | | 9E | BRUND | FP branch on underflow | II-1-59 | | 9E | BRINF | FP branch on indefinite | 11-1-59 | | 9F | ₽D¢D | Dwarsh as condition was to | TT 1 00 | | AO | BRCR | Branch on condition register | II-1-88 | | AU<br>Al | LAI | Load address, indexed | II-1-8 | | | SAI | Store address, indexed | II-1-8 | | A2 | LXI | Load word, indexed | II-1-7 | | A3 | SXI | Store word, indexed | 11-1-7 | | | | | | # CP INSTRUCTIONS - OPCODE SEQUENCE (Sheet 4 of 4) | <u>Opcode</u> | Mnemonic | Instruction | Page | |---------------|------------|-----------------------------------|---------| | A4 | LBYT | Load bytes | II-1-9 | | A5 | SBYT | Store bytes | II-1-9 | | A7 | ADDAD | Address increment, modulo | II-1-23 | | <b>A8</b> | SHFC | Shift word, circular | II-1-26 | | A9 | SHFX | Shift word, end-off | II-1-27 | | AA | SHFR | Shift half-word, end-off | II-1-27 | | AC | ISOM | Isolate bit mask | 11-1-30 | | AD | ISOB | Isolate | II-1-30 | | AE | INSB | Insert | 11-1-30 | | во | CALLREL | Call relative | II-1-78 | | В2 | MULXQ | Integer product, signed immediate | II-1-15 | | в3 | ENTA | Enter XO, signed immediate | II-1-25 | | В4 | CMPPXA | Compare swap | II-1-80 | | В5 | CALLSEG | Call indirect | 11-1-81 | | BE | xxxx | Reserved for user | II-1-83 | | BF | xxxx | Reserved for user | 11-1-83 | | CO-7 | EXECUTE, S | Execute algorithm | II-1-83 | | DO-7 | LBYTS, S | Load bytes, immediate | II-1-9 | | D8-F | SBYTS,S | Store bytes, immediate | II-1-9 | | E4 | SCLN | Decimal scale | II-1-37 | | E5 | SCLR | Decimal scale, rounded | II-1-37 | | E9 | CMPC | Byte compare, collated | II-1-39 | | EB | TRANB | Byte translate | II-1-40 | | ED | EDIT | Edit | 11-1-41 | | F3 | SCNB | Byte scan while nonmember | II-1-48 | | F4 | CALDF | Calculate subscript and add | II-1-49 | | F9 | MCVI | Move immediate data | II-1-50 | | FA | CMPI | Compare immediate data | II-1-51 | | FB | ADDI | Add immediate data | II-1-52 | # CP INSTRUCTIONS - MNEMONIC SEQUENCE (Sheet 1 of 4) | Mnemonic | Opcode | Instruction | Page | |----------|------------|-------------------------------------------|--------------------| | ADDAD | A7 | Address increment, modulo | TT 1 22 | | ADDAQ | 8E | Address increment, signed immediate | II-1-23<br>II-1-23 | | ADDAX | 2 <b>A</b> | Address increment, indexed | | | ADDD | 34 | Double-precision FP sum | II-1-22<br>II-1-55 | | ADDF | 30 | FP sum | II-1-55 | | ADDFV | 40 | FP vector sum | 11-1-33 | | ADDI | FB | Add immediate data | 11-1-52 | | ADDN | 70 | Decimal sum | II-1-34 | | ADDPXQ | 8F | Address relative | II-1-23 | | ADDR | 20 | Half-word integer sum | II-1-12 | | ADDRQ | 8A. | Half-word integer sum, signed immediate | 11-1-13 | | ADDX | 24 | Integer sum | II-1-13 | | ADDXQ | 8B | Integer sum, signed immediate | II-1-13 | | ADDXV | 44 | Integer vector sum | | | ANDX | 1A | Logical product | II-1-28 | | ANDV | 4A | Logical vector product | | | BRCR | 9F | Branch on condition register | II-1-88 | | BRDIR | 2F | Inter-segment branch | II-1-18 | | BRFEQ | 98 | FP branch on equal | 11-1-59 | | BRFGE | 9B | FP branch on greater than or equal | II-1-59 | | BRFGT | 9A | FP branch on greater than | 11-1-59 | | BRFNE | 99 | FP branch on not equal | II-1-59 | | BRINC | 9C | Branch and increment | 11-1-19 | | BRINF | 9E | FP branch on indefinite | II-1-59 | | BROVR | 9E | FP branch on overflow | II-1-59 | | BRREL | 2E | Branch relative | II-1-17 | | BRREQ | 90 | Branch on half-word equal | II-1-18 | | BRRGE | 93 | Branch on half-word greater than or equal | II-1-18 | | BRRGT | 92 | Branch on half-word greater than | II-1-18 | | BRRNE | 91 | Branch on half-word not equal | II-1-18 | | BRSEG | 9D | Branch on segments unequal | II-1-20 | | BRUND | 9E | FP branch on underflow | II-1-59 | | BRXEQ | 94 | Branch on equal | 11-1-19 | | BRXGE | 97 | Branch on greater than or equal | 11-1-19 | | BRXGT | 96 | Branch on greater than | II-1-19 | | BRXNE | 95<br> | Branch on not equal | II-1-19 | | CALDF | F4 | Calculate subscript and add | II-1-49 | | CALLREL | В0 | Call relative | II-1-78 | | CALLSEG | B5 | Call indirect | 11-1-81 | | CMPB | 77 | Byte compare | II-1-39 | | CMPC | E9 | Byte compare, collated | II-1-39 | | CMPEQV | 50 | Integer vector compare, = | II-1-63 | | CMPF | 3C | FP compare | II-1-60 | | CMPGEV | 52 | Integer vector compare, > | II-1-63 | | CMPI | FA | Compare immediate data | II-1-51 | ### CP INSTRUCTIONS - MNEMONIC SEQUENCE (Sheet 2 of 4) | Mnemonic | Opcode | Instruction | Page | |---------------|--------|-----------------------------------------|------------------| | CMPLEV | 51 | Integer vector compare, ≤ | 11-1-63 | | CMPN | 74 | Decimal compare | 11-1-38 | | <b>CMPNEV</b> | 53 | Integer vector compare, ≠ | 11-1-63 | | CMPPXA | в4 | Compare swap | 11-1-80 | | CMPR | 2C | Half-word integer compare | 11-1-16 | | CMPX | 2D | Integer compare | 11-1-16 | | CNFIV | 4C | Convert vector from FP to integer | II-1-64 | | CNIFV | 4B | Convert vector from integer to FP | 11-1-64 | | CONF | 3B | Convert from FP to integer | 11-1-53 | | CONI | 3A | Convert from integer to FP | 11-1-53 | | CPYAA | 09 | Copy address, A to A | II-1-21 | | CPYAX | ОВ | Copy address, A to X | II-1-21 | | CPYMX | 08 | Copy free running counter | II-1-76 | | CPYRR | 0C | Copy half-word | 11-1-21 | | CPYSX | 0E | Copy from state register | 11-1-88 | | CPYXA | 0A | Copy address, X to A | II-1-21 | | CPYXS | OF | Copy to state register | 11-1-88 | | CPYXX | OD | Copy full-word | II-1-22 | | DECR | 29 | Half-word integer difference, immediate | II-1-14 | | DECX | 11 | Integer difference, immediate | 11-1-14 | | DIVD | 37 | Double-precision FP quotient | II-1-57 | | DIVF | 33 | FP quotient | II-1 <b>-</b> 57 | | DIVFV | 43 | FP vector quotient | II-1-65 | | DIVN | 73 | Decimal quotient | II-1-34 | | DIVR | 23 | Half-word integer quotient | II-1-15 | | DIVX | 27 | Integer quotient | 11-1-16 | | EDIT | ED | Edit | II-1-41 | | ENTA | В3 | Enter XO, signed immediate | II-1-25 | | ENTC | 87 | Enter X1, signed immediate | 11-1-25 | | ENTE | 8D | Enter signed immediate | 11-1-25 | | ENTL | 3F | Enter, immediate logical | II-1-24 | | ENTN | 3E | Enter, immediate negative | II-1-24 | | ENTO | 1F | Enter ones | 11-1-24 | | ENTP | 3D | Enter, immediate positive | II-1-24 | | ENTS | 1F | Enter signs | II-1-24 | | ENTX | 39 | Enter X1, immediate logical | II-1-24 | | ENTZ | 1F | Enter zeros | II-1-24 | | EXCHANGE | 02 | Exchange | II-1-73 | | EXECUTE, S | C0-7 | Execute alogrithm | II-1-83 | | GTHV | 55 | Gather vector | 11-1-66 | | HALT | 00 | Program error | II-1-72 | | INCR | 28 | Half-word integer sum, immediate | II-1-12 | | INCX | 10 | Integer sum, immediate | II-1-13 | | INHX | 1C | Logical inhibit | II-1-29 | | INSB | AE | Insert | II-1-30 | | INTRUPT | 03 | Processor interrupt | 11-1-84 | | | | • | | ## CP INSTRUCTIONS - MNEMONIC SEQUENCE (Sheet 3 of 4) | Mnemonic | Opcode | Instruction | Page | |----------|--------|---------------------------------------------|------------------| | IORV | 48 | Logical vector sum | 11-1-64 | | IORX | 18 | Logical sum | 11-1-28 | | ISOB | AD | Isolate | II-1-30 | | ISOM | AC | Isolate bit mask | 11-1-30 | | LA | 84 | Load address | 11-1-8 | | LAI | AO | Load address, indexed | II-1-8 | | LBIT | 88 | Load bit | II-1-10 | | LBSET | 14 | Test and set bit | II-1-77 | | LBYT | A4 | Load bytes | II-1-9 | | LBYTP,j | 86 | Load bytes, relative | II-1-9 | | LBYTS,S | DO-7 | Load bytes, immediate | 11-1-9 | | LMULT | 80 | Load multiple | II-1-6 | | LPAGE | 17 | Load page table index | II-1-84 | | LX | 82 | Load word | II-1-7 | | LXI | A2 | Load word, indexed | II-1-7 | | MARK | 1E | Mark to Boolean | 11-1-30 | | MCVI | F9 | Move immediate data | II-1-50 | | MOVB | 76 | Move bytes | 11-1-40 | | MOVN | 75 | Numeric move | II-1-36 | | MRGV | 54 | Merge vector | II-1 <b>-</b> 66 | | MULD | 36 | Double-precision FP product | II-1-56 | | MULF | 32 | FP product | 11-1-56 | | MULFV | 42 | FP vector product | II-1-65 | | MULN | 72 | Decimal product | II-1-34 | | MULR | 22 | Half-word integer product | II-1-13 | | MULRQ | 8C | Half-word integer product, signed immediate | II-1-15 | | MULX | 26 | Integer product | 11-1-15 | | MULXQ | В2 | Integer product, signed immediate | II-1-15 | | NOTX | 1B | Logical complement | II-1-28 | | POP | 06 | Pop | II-1-75 | | PURGE | 05 | Purge buffer | II-1-86 | | RETURN | 04 | Return | II-1-74 | | SA | 85 | Store address | 11-1-8 | | SAI | A1 | Store address, indexed | 11-1-10 | | SBIT | 89 | Store bit | II-1-11 | | SBYT | A5 | Store bytes | II-1-9 | | SBYTS,S | D8-F | Store bytes, immediate | 11-1-9 | | SCLN | E4 | Decimal scale | II-1-37 | | SCLR | E5 | Decimal scale rounded | II-1-37 | | SCNB | F3 | Byte scan while nonmember | II-1-48 | | SCTV | 56 | Scatter vector | II-1-68 | | SHFC | A8 | Shift word, circular | II-1-26 | | SHFR | AA | Shift half-word, end-off | II-1-27 | | | | | | # CP INSTRUCTIONS - MNEMONIC SEQUENCE (Sheet 4 of 4) | Mnemonic | Opcode | Instruction | Page | |----------|--------|--------------------------------|------------------| | SHFV | 4D | Shift vector circular | 11-1-65 | | SHFX | A9 | Shift word, end-off | 11-1-27 | | SMULT | 81 | Store multiple | 11-1-6 | | SUBD | 35 | Double-precision FP difference | 11-1-55 | | SUBF | 31 | FP difference | II <b>-</b> 1-55 | | SUBFV | 41 | FP vector difference | 11-1-65 | | SUBN | 71 | Decimal difference | 11-1-34 | | SUBR | 21 | Half-word integer difference | 11-1-14 | | SUBX | 25 | Integer difference | 11-1-14 | | SUBFV | 45 | Integer vector difference | 11-1-63 | | SUMFV | 57 | FP vector summation | 11-1-70 | | SX | 83 | Store word | 11-1-7 | | SXI | A3 | Store word, indexed | 11-1-7 | | SYNC | 01 | Scope loop synchronization | 11-1-73 | | TPAGE | 16 | Test and set page | II-1-77 | | TRANB | EB | Byte translate | 11-1-40 | | XORV | 49 | Logical vector difference | 11-1-64 | | XORX | 19 | Logical difference | 11-1-28 | | xxxx | BE | Reserved for user | 11-1-83 | | xxxx | BF | Reserved for user | II-1-83 | # PP INSTRUCTIONS - OPCODE SEQUENCE (Sheet 1 of 4) | Opcode | Mnemonic | Instruction | Page | |--------|----------|--------------------------|------------------| | 0000 | _ | Pass | II-1-135 | | 0001dm | LJM m,d | Long jump to m+(d) | II-1-113 | | 0002dm | RJM m, d | Return jump to m+(d) | II-1-114 | | 0003d | UJN d' | Unconditional jump d | II-1-114 | | 0004d | ZJN d | Zero jump d | 11-1-114 | | 0005a | NJN d | Nonzero jump d | II-1-115 | | 0006d | PJN d | Plus jump d | II-1-115 | | 0007d | MJN d | Minus jump d | II-1-115 | | 0010d | SHN d | Shift A by d | II-1-104 | | 0011d | LMN d | Logical difference d | II-1-104 | | 0012d | LPN d | Logical product d | 11-1-104 | | 0013d | SCN d | Selective clear d | 11-1-105 | | 0014d | LDN d | Load d | II-1-94 | | 0015d | LCH d | Load complement d | II-1 <b>-</b> 94 | | 0016d | ADN d | Add d | 11-1-98 | | 0017d | SBN d | Subtract d | II-1-98 | | 0020dm | LDC m,d | Load dm | 11-1-94 | | 0021dm | ADC m,d | Add dm | II-1-99 | | 0022dm | LPC m.d | Logical product dm | II-1-105 | | 0023dm | LMC m, d | Logical difference dm | II-1-105 | | 002400 | PSN | Pass | 11-1-135 | | 0024d | LRD d | Load R | II-1-117 | | 002500 | - | Pass | II-1-135 | | 0025d | SRD d | Store R | II-1-117 | | 00260X | EXN | Exchange jump | 11-1-136 | | 00261X | MXN | Monitor exchange jump | II-1-136 | | 00262X | MAN | Monitor exchange jump MA | II-1-136 | | 0027X | KPT | Keypoint | II-1-135 | | 0030d | LDD d | Load (d) | II-1-94 | | 00314 | ADD d | Add (d) | II-1-99 | | 0032d | SBD d | Subtract (d) | II-1-99 | | 0033d | TWD q | Logical difference (d) | II-1-106 | | 0034d | STD d | Store (d) | II-1-95 | | 0035d | RAD d | Replace add (d) | II-1-109 | | 0036d | AOD d | Replace add one (d) | II-1-109 | | 0037d | SOD d | Replace subtract one (d) | II-1-109 | | 0040d | LDI d | Load ((d)) | II-1-95 | | 0041d | ADI d | Add ((d)) | II-1-100 | | 0042d | SBI d | Subtract ((d)) | II-1-100 | | 0043d | LMI d | Logical difference ((d)) | 11-1-107 | ### PP INSTRUCTIONS - OPCODE SEQUENCE (Sheet 2 of 4) | Opcode | Mnemonic | Instruction | | Page | |-----------------------|--------------------|------------------------------------------------------------------|---|----------------------| | 0044d | STI d | Store ((d)) | | 11-1-96 | | 0045d | RAI d | Replace add ((d)) | | II-1-110 | | 0046d | AOI d | Replace add one ((d)) | | II-1-110 | | 0047d | SOI d | Replace subtract one ((d)) | | II-1-111 | | 0050dm | LDM m,d | Load (m+(d)) | | 11-1-96 | | | • | | | | | 0051dm | ADM m,d | Add $(m+(d))$ | | 11-1-101 | | 0052dm | SBM m,d | Subtract (m+(d)) | | 11-1-102 | | 0053dm | LMM m,d | Logical difference (m+(d)) | | 11-1-107 | | 0054dm | STM m,d | Store (m+(d)) | | 11-1-96 | | 0055dm | RAM m,d | Replace add (m+(d)) | | 11-1-111 | | 0056dm | اد س ۸OM | Ponless add one (mt/d)) | | II-1-112 | | 0057dm | AOM m,d<br>SOM m,d | Replace add one (m+(d)) Replace subtact one (m+(d)) | | 11-1-112 | | 00604 | CRD d | Central read from (A) to d | | II-1-118 | | 0061dm | | Central read (d) words from (A) to m | | II-1-119 | | 0061dm | CRM m,d<br>CWD d | Central read (d) words from (A) to m Central write to (A) from d | | 11-1-119 | | 00020 | CMD G | Central write to (A) from d | | 11 1 120 | | 0063dm | CWM m,d | Central write (d) words to (A) from m | | 11-1-122 | | 00640cm | AJM m,c | Jump to m if channel C active | | II-1-125 | | 00641cm | SCF m,c | Test to m and set channel C flag | | II-1-125 | | 00650cm | IJM m,c | Jump to m if channel C inactive | | II-1-126 | | 00651cm | CCF c | Clear channel C flag | | 11-1-126 | | | | | | | | $00660_{\mathtt{cm}}$ | FJM m,c | Jump to m if channel C full | | II-1-127 | | 00661cm | SFM m,c | Jump to m if channel C error flag set | | II-1-127 | | 00670cm | EJM m,c | Jump to m if channel C empty | | II-1-127 | | 00671cm | CFM m,c | Jump to m if channel C error flag clear | | II-1-127 | | 00700c | IAN c | Input to A from channel C when active | | 11-1-128 | | 00701c | IAN 40B+c | Input to A from channel C if active | | II-1-128 | | 0071Xcm | IAM m,c | Input A words to m from channel C | | II-1-128 | | 00720c | OAN | Output from A on channel C when active | | II-1-130 | | 00721c | OAN 40B+c | Output from A on channel C if active | | II-1-131 | | 0073xcm | OAM m+c | Output A words from m on channel C | | 11-1-131 | | OO7 JACIII | OAT III'C | output A words from m on channel c | | 11 1 131 | | 00740c | ACN c | Activate channel C | | II-1-132 | | 00741c | ACN 40B+c | Unconditionally activate channel C | - | II-1-132 | | 00750c | DCN c | Deactivate channel C | | II-1-132 | | 00751c | DCN 40B+c | Unconditionally deactivate channel C | | II-1-133 | | 00760c | FAN c | Function a on channel C when inactive | | II-1-133 | | 00761c | FAN 40B+c | Function a on channel C if inactive | | 11-1-134 | | 00770cm | FNC m,c | Function m on channel C when inactive | | 11-1-134 | | 00771cm | FNC m, 40B+c | Function m on channel C if inactive | | II-1-134<br>II-1-135 | | 1000d | RDSL | Central read and set lock from d to (A) | | II-1-133 | | 1000d | RDCL | Central read and set lock from d to (A) | | II-1-123 | | 10010 | KDOD | ventral read and creat fock from d to (A) | | 11 1 123 | ### PP INSTRUCTIONS - OPCODE SEQUENCE (Sheet 3 of 4) | Opcode | Mnemonic | Instruction | Page | |--------------|-----------|---------------------------------|----------------------| | 1002 | _ | Pass | II-1-135 | | 1003 | - | Pass | 11-1-135 | | 1004 | _ | Pass | II-1-135 | | 1005 | _ | Pass | II-1-135 | | 1006 | _ | Pass | II-1-135 | | | | | | | 1007 | - | Pass | II-1-135 | | 1010 | - | Pass | II-1-135 | | 1011 | - | Pass | 11-1-135 | | 1012 | - | Pass | II-1-135 | | 1013 | - | Pass | 11-1-135 | | 1014 | | n. | TT 1 105 | | 1014<br>1015 | | Pass | II-1-135 | | 1015 | - | Pass<br>Pass | 11-1-135 | | 1017 | _ | rass<br>Pass | II-1-135<br>II-1-135 | | 1017 | _ | rass<br>Pass | II-1-135 | | 1020 | _ | rass | 11-1-133 | | 1021 | _ | Pass | 11-1-135 | | 1022d | LPDL d | Logical product (d) long | II-1-105 | | 1023d | LPIL d | Logical product ((d)) long | 11-1-106 | | 1024dm | LPML m,d | Logical product (m+(d) long | 11-1-106 | | 1025 | - m, u | Pass | 11-1-135 | | | | · | | | 1026d | INPN d | Interrupt processor | II-1-137 | | 1027 | · • | Pass | II <b>-</b> 1-135 | | 1030d | LDDL d | Load (d) long | II-1-95 | | 1031d | ADDL d | Add (d) long | II-1-99 | | 1032d | SBDL d | Subtract (d) long | 11-1-100 | | 10001 | 73477 4 | | 1 100 | | 1033d | LMDL d | Logical difference (d) long | 11-1-106 | | 1034d | STDL d | Store (d) long | II-1-95 | | 1035d | RADL d | Replace add (d) long | 11-1-109 | | 1036d | AODL d | Replace add one (d) long | II-1-109 | | 1037d | SODL d | Replace subtract one (d) long | 11-1-110 | | 1040d | LDIL d | Load ((d)) long | 11-1-96 | | 1041d | ADIL d | Add ((d)) long | II-1-100 | | 1042d | SBIL d | Subtract ((d)) long | II-1-101 | | 1043d | LMIL d | Logical difference ((d)) long | II-1-107 | | 1044d | STIL d | Store ((d)) long | II-1-96 | | | | | | | 1045d | RAIL d | Replace add ((d)) long | 11-1-110 | | 1046d | AOIL d | Replace add one ((d)) long | II-1-110 | | 1047d | SOIL d | Replace subtract one ((d)) long | II-1-111 | | 1050dm | LDML m,d | Load (m+(d)) long | II-1-97 | | 1051dm | ADML m, d | Add (m+(d)) long | 11-1-101 | | | | - | | # PP INSTRUCTIONS - OPCODE SEQUENCE (Sheet 4 of 4) | emonic | Instruction | Page | |---------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | L m.d | Subtract (m+(d)) long | 11-1-102 | | | | II <b>-</b> 1-107 | | • | | II-1-97 | | | | II-1-111 | | L m, d | Replace add one (m+(d)) long | II-1-112 | | L m.d 1 | Replace subtract one (m+(d)) long | 11-1-112 | | | | II-1-118 | | | | II-1-120 | | | | II-1-121 | | | | 11-1-122 | | JM m.c | Jump if channel C flag set | 11-1-126 | | • | • | II-1-126 | | • | • | II-1-135 | | - | Pass | II-1-135 | | | | 11-1-135 | | PM m c | Input A words to m from channel C packed | 11-1-129 | | | | 11-1-135 | | | | II-1-132 | | | | II-1-135 | | | - <del></del> | 11-1-135 | | | Pass | II <b>-1-</b> 135 | | | | 11-1-135 | | | IL m,d m,c IM m,c IM m,c | AL m,d Subtract (m+(d)) long AL m,d Logical difference (m+(d)) long AL m,d Store (m+(d)) long AL m,d Replace add (m+(d)) long AL m,d Replace add one (m+(d)) long AL m,d Replace subtract one (m+(d)) long AL m,d Central read from (A) to d long AL m,d Central read (d) words from (A) to m long AL m,d Central write to (A) from d long AL m,d Central write (d) words to (A) from m long AL m,c Jump if channel C flag set AL m,c Jump if channel C flag clear Pass Pass Pass Pass Pass Pass Pass P | # PP INSTRUCTIONS - MNEMONIC SEQUENCE (Sheet 1 of 4) | Mnemonic | <u>Opcode</u> | Instruction | Page | |------------|---------------|------------------------------------|-------------------| | - | 0000 | Pass | 11-1-135 | | - | 002500 | Pass | II-1-135 | | - | 1002 | Pass | II-1-135 | | - | 1003 | Pass | II-1-135 | | <b>-</b> ' | 1004 | Pass | 11-1-135 | | _ | 1005 | Pass | II <b>-</b> 1-135 | | - | 1006 | Pass | II-1-135 | | _ | 1007 | Pass | II-1-135 | | - | 1010 | Pass | II-1-135 | | | 1011 | Pass | 11-1-135 | | _ | 1012 | Pass | 11-1-135 | | - | 1013 | Pass | 11-1-135 | | - | 1014 | Pass | II <b>-</b> 1-135 | | | 1015 | Pass | II-1-135 | | - | 1016 | Pass | 11-1-135 | | - | 1017 | Pass | II-1-135 | | - | 1020 | Pass | II-1-135 | | - | 1021 | Pass | II-1-135 | | - | 1025 | Pass | II-1-135 | | - | 1027 | Pass | 11-1-135 | | - | 1066 | Pass | II-1-135 | | - | 1067 | Pass | II <b>-</b> 1-135 | | - | 1070 | Pass | II-1-135 | | - | 1072 | Pass | II-1-135 | | - | 1074 | Pass | 11-1-135 | | _ | 1075 | Pass | II-1-135 | | - | 1076 | Pass | II-1-135 | | - | 1077 | Pass | II-1-135 | | ACN 40B+c | 00741c | Unconditionally activate channel C | II-1-132 | | ACN c | 00740c | Activate channel C | II-1-132 | | ADC m,d | 0021dm | Add dm | 11-1-99 | | ADD d | 0031d | Add (d) | II-1-99 | | ADDL d | 1031d | Add (d) long | II-1-99 | | ADI d | 0041d | Add ((d)) | II-1-100 | | ADIL d | 1041d | Add ((d)) long | 11-1-100 | | ADM m,d | 0051dm | Add (m+(d)) | II-1-101 | | AOM m,d | 0056dm | Replace add one $(m+(d))$ | II-1-112 | | ADML m, d | 1051dm | Add (m+(d)) long | II-1-100 | | AOML m,d | 1056dm | Replace add one (m+(d)) long | II-1-112 | | LCN d | 0015d | Load complement d | II-1-94 | | | | | | 60458890 A ### PP INSTRUCTIONS - MNEMONIC SEQUENCE (Sheet 2 of 4) | Mnemonic | Opcode | Instruction | Page | |--------------|---------|--------------------------------------------|-------------------| | ADN d | 0016a | Add d | 11-1-98 | | AJM m,c | 00640cm | Jump to m if channel C active | II-1-125 | | AOD d | 00364 | Replace add one (d) | II-1-109 | | AODL d | 1036d | Replace add one (d) long | II-1-109 | | AOI d | 0046d | Replace add one ((d)) long | 11-1-110 | | AOIL d | 1046d | Replace add one ((d)) long | 11-1-110 | | CCF c | 00651cm | Clear channel C flag | II-1-126 | | CFM m,c | 00671cm | Jump to m if channel C error flag clear | II-1-127 | | CRD d | ь0900 | Central read from (A) to d | II-1-118 | | CRDL d | 1060d | Central read from (A) to d long | 11-1-118 | | CRM m,d | 0061dm | Central read (d) words from (A) to m | II-1-119 | | CRML m,d | 1061dm | Central read (d) words from (A) to m long | II-1-120 | | CWD d | 0062d | Central write to (A) from d | II-1-120 | | CWDL d | 1062d | Central write to (A) from d long | 11-1-121 | | CWM m,d | 0063dm | Central write (d) words to (A) from m | II-1-122 | | CWML m,d | 1063dm | Central write (d) words to (A) from m long | II-1-122 | | DCN 40B+c | 00751c | Unconditionally deactivate channel C | II-1-133 | | DCN c | 00750c | Deactivate channel C | II-1-132 | | EJM m,c | 00670cm | Jump if channel C empty | II-1-127 | | EXN | 00260X | Exchange jump | 11-1-136 | | FAN 40B+c | 00761c | Function A on channel C if inactive | 11-1-134 | | FAN c | 00760c | Function A on channel C when inactive | II-1-133 | | FCJM m,c | 1065xcm | Jump if channel C flag clear | II-1-126 | | FJM m,c | 00660cm | Jump if channel C full | II-1-127 | | FNC m, 40B+c | 00771cm | Function m on channel C if inactive | 11-1-135 | | FNC m,c | 00770cm | Function m on to channel C when active | 11-1-134 | | IAM m,c | 0071Xcm | Input A words from channel C to m | II-1-128 | | IAN 40B+c | 00701c | Input To A from channel C if active | II-1-128 | | IAN c | 00700c | Input To A from channel C when active | II-1-128 | | IAPM m,c | 1071xcm | Input A words to m from channel C packed | 11-1-129 | | IJM m,c | 00650cm | Jump if channel C inactive | II-1-126 | | KPT | 0027X | Keypoint | II <b>-</b> 1-135 | | LDC m,d | 0020dm | Load dm | II-1-94 | | LDD d | 0030d | Load (d) | II-1-94 | | LDDL d | 1030d | Load (d) long | 11-1-95 | | LDI d | 0040d | Load ((d)) | II-1-95 | | LDIL d | 1040d | Load ((d)) long | 11-1-95 | #### PP INSTRUCTIONS - MNEMONIC SEQUENCE (Sheet 3 of 4) | Mnemonic | <u>Opcode</u> | Instruction | Page | |-----------|---------------|-------------------------------------------|-------------------| | LDM m,d | 0050dm | Load (m+(d)) | II-1-96 | | LDML m,d | 1050dm | Load (m+(d)) long | II-1-97 | | LDN d | 0014d | Load d | II-1-94 | | LJM m,d | 0001dm | Long jump to m+(d) | II-1-113 | | LMD d | 0033d | Logical difference (d) | II-1-106 | | TWDT q | 1033d | Logical difference (d) long | II-1-106 | | LMI d | 0043d | Logical difference ((d)) | II-1-107 | | LMIL d | 1043d | Logical difference ((d)) long | II-1-107 | | LMM m,d | 0053dm | Logical difference (m+(d)) | II-1-107 | | LMML m,d | 1053dm | Logical difference (m+(d)) long | 11-1-107 | | LMN d | 0011d | Logical difference d | II-1-104 | | LPC m,d | 0022dm | Logical product dm | 11-1-105 | | LPDL d | 1022d | Logical product (d) long | II-1-105 | | LPIL d | 1023d | Logical product ((d)) long | II-1-106 | | LPML m,d | 1024dm | Logical product (m+(d)) long | II-1-106 | | LPN d | 0012d | Logical product d | II-1-104 | | LRN d | 0024d | Load R | II-1-117 | | MAN | 00262X | Monitor exchange jump MA | II-1-136 | | MJN d | 0007d | Minus jump d | II-1-115 | | MXN | 00261X | Monitor exchange jump | II-1-136 | | NJN d | 0005d | Nonzero jump d | II-1-115 | | OAM m+c | 0073xcm | Output (A) words from m on channel C | II-1-131 | | OAN | 00720c | Output from (A) on channel C when active | II-1-130 | | OAN 40B+c | 00721c | Output from A on channel C if active | II-1-131 | | OAPM m,c | 1073xcm | Output A words from m on channel C packed | II-1-132 | | PJN d | 0006d | Plus jump d | II-1-115 | | LMC m,d | 0023dm | Logical difference dm | II-1-105 | | PSN | 002400 | Pass | II-1-135 | | RAD d | 0035d | Replace add (d) | II-1-109 | | RADL d | 1035d | Replace add (d) long | 11-1-109 | | RAI d | 0045d | Replace add ((d)) | II-1-110 | | RAIL d | 1045d | Replace add ((d)) long | II-1-110 | | RAM m,d | 0055dm | Replace add (m+(d)) | II-1-111 | | RAML m,d | 1055dm | Replace add (m+(d)) long | II-1-111 | | RDCL | 1001d | Central read and clear lock from d to (A) | II-1-123 | | RDSL | 1000d | Central read and set lock from d to (A) | II-1-123 | | RJM m,d | 0002dm | Return jump m+(d) | II-1-114 | | SBD d | 0032d | Subtract (d) | II-1-99 | | SBI d | 0042d | Subtract ((d)) | II-1-100 | | SBDL d | 1032d | Subtract (d) long | II <b>-</b> 1-100 | ## PP INSTRUCTIONS - MNEMONIC SEQUENCE (Sheet 4 of 4) | Mnemonic | Opcode | Instruction | Page | |-----------|---------|---------------------------------------|----------| | SBIL d | 1042d | Subtract ((d)) long | 11-1-101 | | SBM m,d | 0052dm | Subtract (m+(d)) | 11-1-102 | | SBML m.d | 1052dm | Subtract (m+(d)) long | 11-1-102 | | SBN d | 0017a | Subtract d | 11-1-98 | | SCF m,c | 00641cm | Test and set channel C flag | II-1-125 | | SFM m,c | 00661cm | Jump to m if channel C error flag set | II-1-127 | | SOD d | 0037a | Replace subtract one (d) | 11-1-109 | | SODL d | 1037d | Replace subtract one (d) long | II-1-110 | | SOI d | 0047a | Replace subtract one ((d)) | 11-1-111 | | SOIL d | 1047d | Replace subtract one ((d)) long | II-1-111 | | SOM m,d | 0057dm | Replace subtract one (m+(d)) | 11-1-112 | | SOML m, d | 1057dm | Replace subtract one (m+(d)) long | II-1-112 | | SRD d | 0025d | Store R | 11-1-117 | | STD d | 0034d | Store (d) | 11-1-95 | | STDL d | 1034d | Store (d) long | II-1-95 | | STI d | 0044d | Store ((d)) | II-1-96 | | STIL d | 1044d | Store ((d)) long | 11-1-96 | | STM m,d | 0054dm | Store (m+(d)) | 11-1-96 | | STML m,d | 1054dm | Store (m+(d)) long | 11-1-97 | | TSJM m,c | 1064cm | Jump if channel C flag set | II-1-126 | | UJN d | 0003d | Unconditional jump d | II-1-114 | | ZJN d | 0004a | Zero jump d | 11-1-114 | # **INDEX** | Address arithmetic instructions, CP II-1-22 | Byte instructions, BDP II-1-38 | |-------------------------------------------------------------------|-----------------------------------------------------------------------------| | Address translation, see Virtual and Central Memory Programming | Central memory access instructions, PP II-1-116 | | Arithmetic instructions, floating- | Central memory programming, see Virtual and | | point II-1-54 | Central Memory Programming | | Arithmetic instructions, PP II-1-97 | Character data word, display | | . * | station II-2-133 | | | Character mode word, display | | | station II-2-130 | | | Clock, real-time, programming II-2-136 | | BDP byte instructions II-1-38 | CM registers | | BDP data descriptors II-2-40 | Corrected error log (CEL) II-2-16 | | BDP data types | Element identifier (EID) II-2-17 | | Slack digit II-2-45 | Environment control (EC) II-2-17 | | Type 0: packed decimal, | Free-running counter II-2-17 | | unsigned II-2-42 | Options installed (OI) II-2-17 | | Type 1: packed decimal, unsigned slack digit II-2-42 | Port bounds II-2-17 | | 0 | Status summary (SS) II-2-17 | | Type 10: binary, unsigned II-2-45 Type 11: binary, signed II-2-45 | Uncorrectable error log (UEL) II-2-18 | | Type 2: packed decimal, signed II-2-43 | Codes, display station II-2-133<br>Condition and mask registers, CP II-2-20 | | Type 3: packed decimal, signed, slack | Conversion instructions, floating- | | digit II-2-43 | point II-1-53 | | Type 4: unpacked decimal, | • | | unsigned II-2-43 | Coordinate data word, display station II-2-133 | | Type 5: unpacked decimal, trailing sign | Copy instructions, CP II-1-20 | | combined Hollerith II-2-44 | CP address arithmetic instructions II-1-22 | | Type 6: unpacked decimal, trailing sign | CP branch instructions II-1-17 | | separate II-2-44 | CP condition and mask registers II-2-20 | | Type 7: unpacked decimal, leading sign | CP condition register bit grouping II-2-23 | | combined Hollerith II-2-44 | CP copy instructions II-1-20 | | Type 8: unpacked decimal, leading sign | CP exchange operations II-2-1 | | separate II-2-44 | CP general instructions II-1-4 | | Type 9: alphanumeric II-2-45 | CP instruction description | | BDP instruction descriptions II-1-31 | nomenclature II-1-2 | | BDP instruction nomenclature II-1-32 | CP instruction formats II-1-1 | | BDP numeric instructions II-1-32 | CP instruction index | | BDP operand types and field lengths II-2-42 | Mnemonic sequence II-D-5 | | BDP subscript and immediate data | Opcode sequence II-D-1 | | instructions II-1-48 | CP integer arithmetic instructions II-1-11 | | BDP undefined results | CP interrupts II-1-3 | | Invalid data II-2-45 | Exchange II-2-25 | | Overlap II-2-45 | Trap II-2-25 | | Branch instructions, CP II-1-17 | Conditions, see Interrupt Conditions | | Branch instructions, floating-point II-1-58 | CP load and store instructions II-1-5 | | Branch instructions, PP II-1-113 | CP logical instructions II-1-27 | | Business data processing (BDP) | CP mark to Boolean instruction II-1-30 | | programming II-2-40 | CP register bit string instructions II-1-29 | | | | 60458890 B Index-1 | CP | registers | Data sequences timing II-C-11 | |-----|---------------------------------------------------------------------|----------------------------------------------------------------------------| | | Address A II-2-6 | Data types, BDP, see BDP data types | | | Base constant (BC) II-2-6 | Debug, see Program Monitoring | | | Cache/map corrected error log | Dedicated channels, IOU II-2-136 | | | (CCEL/MCEL) II-2-14 | Difference, FP II-2-52 | | | Debug index (DI) II-2-6 | Display station programming | | | Debug list pointer (DLP) II-2-6 | Character data word II-2-133 | | | Debug mask (DM) II-2-7 | Character mode II-2-130 | | | Dependent environment control | Codes II-2-133 | | | (DEC) II-2-14 | Coordinate data word II-2-133 | | | Element identifier (EID) II-2-14 | Data display II-2-130 Display character codes II-2-132 | | | Flag register Critical-frame flag (CFF) II-2-8 | Display character codes II-2-132 Display station output function | | | On-condition flag (OCF) II-2-8 | code II-2-133 | | | Process-not-damaged (PND) | Dot mode II-2-130 | | | flag II-2-8 | Keyboard II-2-130 | | | Job process state (JPS) II-2-14 | Keyboard character codes II-2-131 | | | Largest ring number (LRN) II-2-8 | Program timing consideration II-2-134 | | | Last processor identification | Programming example II-2-134 | | | (LPID) II-2-8 | Receive and display program | | | Model dependent word (MDW) II-2-14 | flowchart II-2-135 | | | Monitor condition (MCR) II-2-8 | Divide, FP II-2-53 | | | Monitor mask (MMR) II-2-8 | Double-precision nonstandard FP | | | Monitor process state (MPS) II-2-15 | numbers II-2-51 | | | Operand X II-2-9 | Double-precision register | | | Options installed (OI) II-2-13 | designators II-1-53 | | | Page size mask (PSM) II-2-13 | | | | Page table address (PTA) II-2-13 | | | | Page table length (PTL) II-2-13 Process interval timer (PIT) II-2-9 | | | | Processor fault status (PFS) II-2-13 | Edit examples | | | Processor identifier (PID) II-2-13 | Using edit masks 1 through 8 II-B-2 | | | Processor test mode (PTM) II-2-13 | Using edit masks 17 through 25 II-B-4 | | | Program address (P) II-2-9 | Using edit masks 9 through 16 II-B-3 | | | Segment table address (STA) II-2-10 | Edit mask 26 II-B-5 | | | Segment table length (STL) II-2-10 | Edit masks 1 through 25 II-B-1 | | | Status summary (SS) II-2-13 | End cases, floating-point, see | | | System interval timer (SIT) II-2-15 | Floating-Point End Cases | | | Top-of-stack (TOS) pointer II-2-10 | Exceptions during stack operations II-2-40 | | | Trap enable (TE) | Exchange interrupt II-2-25 | | | Trap-enable delay flip-flop | Exchange jumps II-1-136 | | | (TEF) II-2-10 | Exchange operations, CP II-2-1 | | | Trap-enable flip-flop (TEF) II-2-10 | Exchange packages II-2-3 | | | Trap pointer (TP) II-2-10 | CYBER 170 State exchange | | | Untranslatable pointer (UTP) II-2-11 | package II-2-113 | | | Untranslatable virtual machine identifier (UVMID) II-2-11 | Interstate exchange package II-2-108 Virtual State exchange package II-2-5 | | | | Virtual State exchange package II-2-5 Exponent arithmetic, FP II-2-51 | | | User condition (UCR) II-2-11 User mask (UMR) II-2-11 | Exponent arithmetic, Fr 11-2-31 | | | Virtual machine capability list | | | | (VMCL) II-2-15 | | | | Virtual machine identifier | Flags II-2-35 | | | (VMID) II-2-12 | Floating-point arithmetic | | CP | shift instructions II-1-26 | instructions II-1-54 | | | BER 170 State exchange package II-2-113 | Floating-point branch instructions II-1-58 | | | | Floating-point conversion | | | | instructions II-1-53 | | )at | a descriptors, BDP II-2-40 | Floating-point (FP) end cases | | | a format, PP II-1-90 | FP compare results II-2-55 | | )at | a formats, FP II-2-49 | FP difference results, UM clear II-2-58 | Index-2 | FP difference results, UM set II-2-59 | Instruction descriptions, peripheral | |---------------------------------------------------------------------|--------------------------------------------------------------------------------| | FP product results, UM clear II-2-60 | processor II-1-90 | | FP product results, UM set II-2-61 | Instruction descriptions, system II-1-71 | | FP quotient results, UM clear II-2-62 | Instruction descriptions, vector II-1-60 | | FP quotient results, UM set II-2-63 | Instruction format, vector II-1-61 | | FP sum results, UM clear II-2-56 | Instruction formats, PP II-1-90 | | FP sum results, UM set II-2-57 | Instruction index | | Floating-point (FP) programming | CP instructions - mnemonic | | Exponent arithmetic II-2-51 | sequence II-D-5 | | FP data formats II-2-49 | CP instructions - opcode | | FP divide II-2-53 | sequence II-D-1 | | FP double-precision nonstandard | PP instructions - mnemonic | | numbers II-2-51 | sequence II-D-13 | | FP indefinite numbers II-2-51 | PP instructions - opcode | | FP infinite numbers II-2-50 | sequence II-D-9 | | FP multiply II-2-53 | Instruction nomenclature, BDP II-1-32 | | FP nonzero numbers II-2-50 | Instructions, mixed mode II-1-86 | | FP standard and nonstandard | Instructions, monitor mode II-1-85 | | numbers II-2-50 | Integer arithmetic instructions, CP II-1-11 | | FP sum and difference II-2-52 | Integer format II-1-12 | | FP zero numbers II-2-50 | Interface information | | Normalization II-2-51 | Active flag II-C-5 | | Representation II-2-50 | Control signals II-C-3 | | Floating-point instruction | Data input sequences II-C-6 | | descriptions II-1-52 | Data output sequences II-C-7 | | Format | Data sequences timing II-C-11 | | BDP data descriptor II-2-41 | Data signals II-C-5 | | FP data II-2-49 | External channel I/O sequences II-C-5 | | Integer II-1-12 | Full flag II-C-5 | | Of XO for call instructions II-2-37 | Function instructions II-C-5 | | Page table entry II-2-89 | Interfaces II-C-1 | | PP data II-1-90 | Maintenance channel interface II-C-l | | PP instructions II-1-90 | | | PP relocation register II-1-91 | Maintenance channel signals II-C-3 MCH input sequence II-C-8 | | Process virtual address (PVA) II-2-78 | MCH output sequence II-C-9 | | Real memory address (RMA) II-2-81 | PP and channel interaction II-C-5 | | Segment/page identifier (SPID) II-2-80 | Signals II-C-2 | | System virtual address (SVA) II-2-79 | • | | Vector instruction II-1-61 | Signals and cables II-C-3 Two-port multiplexer interface II-C-1 | | vector instruction it-1-01 | Two-port multiplexer interface II-C-1<br>12-bit channel control signals II-C-2 | | | 12-bit external interface II-C-1 | | | Interrupt conditions | | General instructions, CP II-1-4 | Access violation (MCR 54) II-2-26 | | Global privileged system | | | instructions II-1-84 | Address specification error (MCR 52) II-2-27 | | Glossary II-A-1 | | | Glossary II-A-1 | Arithmetic loss of significance (UCR 62) II-2-27 | | | · · · · · · · · · · · · · · · · · · · | | | Arithmetic overflow (UCR 57) II-2-27<br>Critical frame flag (UCR 53) II-2-28 | | Immediate data instruction, BDP II-1-48 | | | Indefinite numbers, FP II-2-51 | CYBER 170 State exchange request (MCR 53) II-2-32 | | | | | Infinite numbers, FP II-2-50 Input/output instructions, PP II-1-124 | Debug (UCR 56) II-2-28 | | | Detected uncorrectable error | | Instruction description nomenclature, | (MCR 48) II-2-32 | | CP II-1-2 | Divide fault (UCR 55) II-2-28 | | Instruction descriptions, BDP II-1-31 | Environment specification error | | Instruction descriptions, floating- | (MCR 55) II-2-28 Expenses exerties (MCR 58) II-2-30 | | noin (1-1-7/ | Hypopont oxortlow (HCD EQ) TT9.90 | 60458890 B Index-3 | Exponent underflow (UCR 59) II-2-29 | Interstate exchange package II-2-107 | |---------------------------------------------------------------------------|------------------------------------------------------------------| | External interrupt (MCR 56) II-2-29 | Interstate stack frame save area | | FP indefinite (UCR 61) II-2-29 | (SFSA) II-2-113 | | FP loss of significance | Memory addressing in CYBER 170 | | (UCR 60) II-2-30 | State II-2-103 | | Free flag (UCR 50) II-2-30 | Operation in CYBER 170 State II-2-102 | | Instruction specification error | Return from Virtual State to CYBER 170 | | (MCR 51) II-2-30 | State II-2-105 | | Inter-ring pop (UCR 52) II-2-31 | Software exception conditions II-2-115 | | Invalid BDP data (UCR 63) II-2-31 | State-switching operations II-2-104 | | Invalid segment/ring number zero | Trap interrupt from CYBER 170 State to | | (MCR 60) II-2-31 | Virtual State II-2-105 | | Multiple II-2-33 | Virtual State monitor mode-to-CYBER 170 | | Not assigned (MCR 49) II-2-31 | State exchange II-2-104 | | Outward call/inward return | IOU dedicated channels II-2-136 | | (MCR 61) II-2-31 | IOU pass instructions II-1-135 | | Page table search without find | IOU peripheral processor (PP) programming | | (MCR 57) II-2-32 | Absolute and relocation | | Privileged instruction fault | addressing II-2-121 | | (UCR 48) II-2-32 | Cache invalidation II-2-127 | | Process interval time (UCR 51) II-2-32 | Central memory addressing by PPs II-2-121 | | Short warning (MCR 50) II-2-32 | PPs II-2-121 Channel active flag II-2-124 | | Soft error log (MCR 62) II-2-33<br>System interval timer (MCR 59) II-2-33 | Channel flags II-2-124 | | Trap exception (MCR 63) II-2-33 | Channel input/output (I/O) | | Unimplemented instruction | operations II-2-124 | | (UCR 49) II-2-33 | Channel marker flag II-2-125 | | Interrupt flowchart II-2-34 | Channel parity errors II-2-128 | | Interrupts, CP II-1-3; II-2-25 | Direct 12-bit address II-2-123 | | Interrupts, multiple II-2-33 | Direct 18-bit operand II-2-123 | | Interstate exchange package II-2-108 | Direct 6-bit address II-2-123 | | Interstate programming | Direct 6-bit operand II-2-123 | | Address errors II-2-119 | Error detection and recovery II-2-128 | | Cache invalidation in CYBER 170 | Error flag II-2-125 | | State II-2-103 | Indexed 12-bit address II-2-123 | | Call from Virtual State to CYBER 170 | Indirect 6-bit address II-2-123 | | State II-2-105 | Initialization II-2-129 | | Calls, returns, and interrupts II-2-106 | Inter-PP communications II-2-126 | | Code modification in CYBER 170 | Operating system (OS) bounds | | State II-2-115 | test II-2-122 | | CYBER 170 State exchange | Parity errors on input data II-2-129 | | package II-2-112 | Parity errors on output data II-2-128 | | CYBER 170 State-to-Virtual State monitor | PP central memory read II-2-122 | | mode exchange II-2-104 | PP central memory write II-2-122 | | Debug/performance monitoring II-2-115 | PP hardware errors II-2-128 PP memory addressing by PPs II-2-123 | | Exception handling in CYBER 170 | , , , | | State II-2-115 | PP program timing | | Exchange packages used in CYBER 170 | consideration II-2-127 Programming for channel input/ | | State II-2-107 | output II-2-125 | | Exchanges within CYBER 170 State II-2-104 | Register-full flag II-2-124 | | State II-2-104<br>Extended memory transfer | Timeout II-2-129 | | exceptions II-2-120 | IOU registers | | Hardware exceptions in CYBER 170 | Element identifier (EID) II-2-19 | | State II-2-121 | Environment control (EC) II-2-19 | | Illegal instructions II-2-120 | Fault status (FS) II-2-19 | | Interstate calls, returns, and | Fault status mask II-2-19 | | interrupts II-2-106 | Operating system (OS) bounds II-2-19 | | | | Options installed (OI) II-2-19 Status summary (SS) II-2-20 Test mode (TM) II-2-20 Job-to-monitor exchange operations, Virtual State II-2-3 Keyboard character codes, display station II-2-131 Keyboard, display station II-2-130 Load and store instructions, CP II-1-5 Load and store instructions, PP II-1-93 Local privileged system instructions II-1-83 Logical instructions, CP II-1-27 Logical instructions, PP II-1-103 Maintenance channel programming For halt/stop (opcode 0/1) II-2-146 For master clear/clear errors (opcode 6/7) II-2-146 For read IOU summary status (opcode C, IOU only) II-2-147 For read/write (opcode 4/5) II-2-146 MCH control words II-2-146 MCH function word bit assignments II-2-147 MCH functions words II-2-144 Maintenance registers CM II-2-16 II-2-18 Mark to Boolean instruction, CP Mixed mode instructions II-1-86 Monitor condition/mask register bit assignments II-2-21 Monitor mode instructions TT-1-85 Monitor-to-job exchange operations, Virtual II-2-3 State Multiple interrupt conditions II-2-34 Multiply, FP 11-2-53 Nonprivileged system instructions II-1-72 Nonstandard numbers, FP II-2-50 Nonzero numbers, FP Normalization, FP II-2-51 Numeric instructions, BDP II-1-32 Page table entry format II-2-89 Page table search, start RMA formation II-2-87 Page, virtual memory, see Virtual and Central Memory Programming Pass instructions, IOU II-1-135 Peripheral processor instruction descriptions II-1-90 PP arithmetic instructions II-1-97 PP branch instructions II-1-113 PP central memory access instructions II-1-116 PP data format II-1-90 PP input/output instructions II-1-124 PP instruction formats II-1-90 PP instruction index Mnemonic sequence II-D-13 II-D-9 Opcode sequence PP load and store instructions PP logical instructions II-1-103 PP relocation register format PP replace instructions II-1-108 Process state registers, CP II-2-6 Processor state registers, CP Process virtual address (PVA) format II-2-78 Program monitoring Debug II**-**2-64 Debug condition select II-2-67 Debug conditions II-2-72 Debug index register Debug list II-2-64 Debug list entry II-2-66 Debug list pointer register 11-2-65 Debug mask register II-2-66 Debug scan operation II-2-68 Debug-software interaction, debug disabled II-2-70 Debug-software interaction, debug II-2-70 enabled Enabling debug II-2-68 Interrupts during debug scan TT-2-69 Programming information Real-time clock programming II-2-136 Real memory address (RMA) format Register bit string instructions, CP II-1-29 Register designators, doubleprecision II-1-53 Registers CM, see CM Registers CP, see CP Registers IOU, see IOU Registers Stack operations, see Stack Operations, Assigned Registers Relocation register format, PP II-1-91 Replace instructions, PP II-1-108 60458890 B | Segment/page identifier (SPID) | Undefined results, BDP II-2-45 | |-------------------------------------------------------|---------------------------------------------| | format II-2-80 | User condition/mask register bit | | SFSA descriptor II-2-38 | assignments II-2-22 | | SFSA descriptor field II-2-37 | User mask/condition and monitor condition | | Shift instructions, CP II-1-26 | fields II-2-39 | | Stack frame save area (SFSA) format II-2-36 | | | Stack frames and save areas II-2-36 | | | Stack manipulating operations II-2-36 | | | Stack operations, assigned registers | Vector instruction descriptions II-1-60 | | Argument pointer (A4) II-2-40 | Vector instruction format II-1-61 | | Binding section pointer (A3) II-2-40 | Vector operations II-2-47 | | Current stack frame pointer | Vector programming | | (A1) II-2-39 | Vector broadcast II-2-48 | | Dynamic space pointer (AO) II-2-39 | Vector interrupts II-2-48 | | Previous save area pointer (A2) II-2-39 | Vector length (number of | | Top-of-stack pointers II-2-39 | operations) II-2-47 | | Stack operations, exceptions during II-2-40 | Vector overlap II-2-48 | | Standard numbers, FP II-2-50 | Vector page size II-2-48 | | Subscript and immediate data instructions, | Virtual and central memory programming | | BDP II-1-48 | Access protection II-2-91 | | Sum, FP II-2-52 | Address tables II-2-83 | | System instruction descriptions II-1-71 | BN-to-page number/page offset | | System instruction privilege and | conversion II-2-82 | | mode II-2-99 | Call indirect access | | System instructions, global | requirements II-2-101 | | privileged II-1-84 | CM addressing from CP II-2-77 | | System instructions, local | Code base pointer format II-2-91 | | privileged II-1-83 | Effect of RN violations II-2-98 | | System instructions, nonprivileged II-1-72 | Effect of RN = $0$ II-2-96 | | System publication index 7/8 | Execute access privilege/mode II-2-98 | | System virtual address (SVA) II-2-79 | Keys/locks II-2-99 | | | Listing of pages in page table II-2-90 | | | Page table entries (PTE) II-2-87 | | | Page table entry format II-2-89 | | m | Page table search II-2-86 | | Trap interrupt II-2-25 | Page table search, start RMA | | Two-port multiplexer programming | formation II-2-87 | | Calendar clock/auto dial-out | Process binding section II-2-90 | | (1XXX) II-2-140 | Process virtual address (PVA) | | Data input II-2-144 | format II-2-78 | | Data output II-2-143 | Process virtual memory II-2-78 | | Function words II-2-139 | PTE control fields II-2-88 | | Master clear (07XX) II-2-143 | PTE page frame RMA field II-2-89 | | PP read terminal data (O1XX) II-2-141 | PTE segment/page identifier | | PP write output buffer (02XX) II-2-142 | field II-2-88 | | Programming considerations II-2-143 | PVA-to-RMA conversion II-2-83 | | Read status summary (00XX) II-2-141 | PVA-to-SVA conversion, execute II-2-94 | | Set/clear data terminal ready | PVA-to-SVA conversion, read/ | | (DTR) (04XX) II-2-143 Set/clear request to cond (PTS) | write II-2-93 | | Set/clear request to send (RTS) (05XX) II-2-143 | Real memory II-2-79 | | Set operation mode to terminal | Real memory address (RMA)<br>format II-2-81 | | oce obergerou mode to ferminat | TOT MAC 11-5-01 | Index-6 (03XX) II-2-142 Terminal deselect (6XXX) II-2-139 Terminal select (7XXX) II-2-139 11-2-97 Ring structure II-2-95 RN effect on pop instruction Ring voting II-2-95 RN for execute access II-2-96 RN for read/write access II-2-96 Segment descriptor table entry format II-2-85 Segment descriptor table (SDT) II-2-84 Segment/page identifier (SPID) format II-2-80 System instruction privilege and mode II-2-99 System page table (SPT) II-2-86 System virtual address (SVA) format II-2-79 System virtual memory II-2-78 Virtual machine identifier (VMID) field II-2-38 Virtual State exchange package II-2-5 Virtual State job-to-monitor exchange operations II-2-3 Virtual State monitor-to-job exchange operations II-2-3 #### **COMMENT SHEET** CDC CYBER 170 Computer Systems Models 815, 825, 835, 845, and 855; CDC CYBER 180 Computer Systems Models 810, 830, 835, 840, 845, 850, 855, 860, and 990 Virtual State Volume II Hardware Reference Manual MANUAL TITLE: | his form is not intend<br>nis manual. Please in<br>nclude page number | ded to be used as an order<br>ndicate any errors, suggeste<br>references). | blank. Control Data<br>ed additions or deleti | Corporation we<br>ons, or general | lcomes your evaluation c<br>comments below (please | |-----------------------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------|-----------------------------------|----------------------------------------------------| | CITY: | | STATE: | ZIP CODE | l: | | TREET ADDRESS: | | | | | | COMPANY: | | | | | | IAME: | | | | | | UBLICATION NO.: | 60458890 | REV | ISION: C | | FOLD FOLD NECESSARY IF MAILED IN THE UNITED STATES NO POSTAGE #### **BUSINESS REPLY MAIL** FIRST CLASS **PERMIT NO. 8241** MINNEAPOLIS, MINN. POSTAGE WILL BE PAID BY #### **CONTROL DATA CORPORATION** Publications and Graphics Division ARH219 4201 North Lexington Avenue Saint Paul, Minnesota 55112 FOLD FOLD U O O $\bigcap$ **GD** CONTROL DATA 0