# **GD** CONTROL DATA CDC® CYBER 170 COMPUTER SYSTEMS MODELS 835, 845, AND 855 CDC ° CYBER 180 COMPUTER SYSTEMS MODELS 835, 840, 845, 850, 855, 860, AND 990 **CYBER 170 STATE** Central Processor Instruction Index | Cod | Code | | | |-----------|----------------|--------------|--| | Mnemonic | Mnemonic Octal | | | | AX | 21 | 4-8 | | | AX | 23 | 4-9 | | | BX | 10-17 | 4-6 | | | CC | 466 | 4-16 | | | CR | 660 | 4-19 | | | CW | 467<br>670 | 4-17<br>4-19 | | | CX | 47 | 4-17 | | | DF | 036 | 4-5 | | | DM | 465 | 4-16 | | | DX | 32 | 4-12 | | | DX | 33 | 4-12 | | | DX | 42 | 4-14 | | | EQ | 04 | 4-6 | | | FX | 30 | 4-11 | | | FX | 31 | 4-11 | | | FX | 40 | 4-13 | | | FX | 44 | 4-14 | | | - <b></b> | , , | • • • | | | Co | Code | | | |-------------------------------------------|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--| | Mnemonic | 0ctal | Page | | | GE ID IM IR IX IX JP LT LX LX MX NE NG NO | 06<br>037<br>464<br>034<br>36<br>37<br>02<br>07<br>20<br>22<br>43<br>05<br>033<br>460-463 | 4-6<br>4-6<br>4-16<br>4-5<br>4-13<br>4-13<br>4-4<br>4-6<br>4-8<br>4-14<br>4-6<br>4-5<br>4-15 | | | NX<br>NZ<br>OR<br>PL | 24<br>031<br>035<br>032 | 4-9<br>4-5<br>4-5<br>4-5 | | | Cod | | | |----------|-------|------| | Mnemonic | Octal | Page | | PS | 00 | 4-2 | | PX | 27 | 4-11 | | RC | 016 | 4-4 | | RE | 011 | 4-3 | | R.J | 010 | 4-2 | | RX | 014 | 4-4 | | RX | 34 | 4-12 | | RX | 35 | 4-12 | | RX | 41 | 4-13 | | RX | 45 | 4-15 | | SA | 50-57 | 4-17 | | SB | 60-67 | 4-18 | | SX | 70-77 | 4-19 | | UX | 26 | 4-10 | | WX | 015 | 4-4 | | WE | 012 | 4-3 | | X.J | 013 | 4-4 | | ZR | 030 | 4-4 | | ZX | 25 | 4-10 | Peripheral Processor Instruction Index | Cod | | | |--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | Mnemonic | Octal | Page | | ACN ADC ADD ADI ADM ADN AJM AOD AOI AOM CCF CFM CRD CRM CWD CWM DCN EJM EXN FAN FAN FINC IAM IAN | 74 21 31 41 51 16 640 36 46 56 651 671 60 61 62 63 75 670 260 76 660 77 71 | 4-38<br>4-32<br>4-33<br>4-34<br>4-35<br>4-37<br>4-34<br>4-35<br>4-37<br>4-36<br>4-36<br>4-36<br>4-36<br>4-36<br>4-39<br>4-37<br>4-39<br>4-37<br>4-39<br>4-38 | | Cod | | | |-------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Mnemonic | Octal | Page | | IJM KPT LCN LDC LDD LDI LDI LDM LJM LJM LMC LMD LMI LMM LMN LMN LMN LMN LPC LPN LRD MAN MJN MXN NJN OAM OAN | 650<br>27<br>15<br>20<br>30<br>40<br>50<br>14<br>01<br>23<br>33<br>43<br>53<br>11<br>22<br>12<br>24<br>262<br>07<br>261<br>05<br>73 | 4-37<br>4-33<br>4-32<br>4-32<br>4-33<br>4-34<br>4-35<br>4-32<br>4-31<br>4-33<br>4-34<br>4-34<br>4-35<br>4-32<br>4-32<br>4-32<br>4-32<br>4-33<br>4-31<br>4-33<br>4-31<br>4-38<br>4-38 | | Code | | | |-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | Mnemonic | 0ctal | Page | | PJN PSN RAD RAI RAM RJM SBD SBI SBM SBN SCF SCN SFM SHN SOD SOI SOM SRD STD STD STD STM UJN ZJN | 06<br>00<br>35<br>45<br>55<br>02<br>32<br>42<br>52<br>17<br>641<br>13<br>661<br>10<br>37<br>47<br>57<br>25<br>34<br>44<br>54 | 4-31<br>4-34<br>4-34<br>4-35<br>4-31<br>4-33<br>4-34<br>4-35<br>4-37<br>4-32<br>4-37<br>4-32<br>4-37<br>4-32<br>4-34<br>4-35<br>4-35<br>4-35<br>4-31<br>4-31 | # **GD** CONTROL DATA CDC® CYBER 170 COMPUTER SYSTEMS MODELS 835, 845, AND 855 CDC ° CYBER 180 COMPUTER SYSTEMS MODELS 835, 840, 845, 850, 855, 860, AND 990 **CYBER 170 STATE** ## **REVISION RECORD** | REVISION | DESCRIPTION | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 01<br>(05-15-81) | Preliminary issue. | | A<br>(04-23-82) | Manual revised to add support of model 855. | | B<br>(12-30-83) | Manual revised; includes Engineering Change Order 44612/PD03024 and Comment Sheets 2924, 2745, and 3068. Also adds model 845 information to manual. This edition obsoletes all previous editions. | | C<br>(04-28-84) | Manual revised to add support of CYBER 180 Models 835, 845, 855, and 990. | | D<br>(11-02-84) | Manual revised; includes Engineering Change Order 46271. Adds support of CYBER 180 Models 840, 850, and 860. | | E<br>(05-14-85) | Manual revised; includes Engineering Change Order 46744. Front Cover, 2 through 9, 1-1 through 1-11, 2-1, 2-4, 2-7 through 2-10, 2-14, 2-15, 3-1 through 3-7, 4-20, 4-31, 5-1, 5-7, 5-8, 5-21, 5-22, 5-25 through 5-30, and Index-5 are revised. Pages 2-16, 2-17, 3-8 through 3-14, 5-31, and 5-32 are added. | | | | | | | | | | | | | | | | | · | | | | | | ! | | | | | | | | | | | | Publication No. | | ## REVISION LETTERS I, O, Q, S, X AND Z ARE NOT USED. © 1981, 1982, 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 | - | 4-7 | A | 5-24 | A | | | | | | Inside Front | | 4-8 | В | 5-25 | E | İ | 1 1 | | | | Cover | В | 4-9 | В | 5-26 | E | | 1 1 | ì | | | Title Page | - | 4-10 | В | 5-27 | E | | 1 1 | | | | 2 | E | 4-11 | В | 5-28 | E | | 1 1 | | l i | | 3/4 | E | 4-12 | A | 5-29 | E | | 1 . 1 | | | | 5 | E | 4-13 | A | 5-30 | E | | 1 1 | 1 | | | 6 | E | 4-14 | A | 5-31 | E | | 1 1 | | | | 7 | E | 4-15 | A | 5-32 | E | | 1 1 | | | | 8 | E | 4-16 | В | A-1 | A | | 1 1 | | 1 1 | | 9 | E | 4-17 | В | Index-1 | С | | 1 1 | | | | 1-1 | E | 4-18 | В | Index-2 | C | | 1 | | | | 1-2 | E | 4-19 | В | Index-3 | C | | 1 1 | | l f | | 1-3 | E | 4-20 | E | Index-4 | c | | 1 1 | 1 | i I | | 1-4 | E | 4-21 | В | Index-5 | E | | 1 1 | i . | | | 1-5 | E | 4-22 | В | Index-6 | l c l | | 1 1 | <b>j</b> | 1 | | 1-6 | E | 4-23 | В | Index-7 | C | | 1 1 | | | | 1-7 | E | 4-24 | В | Comment Sheet | E | | | | | | 1-8 | E | 4-25 | В | Back Cover | - | <b>]</b> | | | | | 1-9 | E | 4-26 | В | | | | 1 1 | | l 1 | | 1-10 | E | 4-27 | В | | l 1 | | 1 1 | | | | 1-11 | E | 4-28 | В | | i I | | 1 1 | | | | 2-1 | E | 4-29 | В | | | | 1 1 | | | | 2-2 | С | 4-30 | В | | i | | 1 1 | | 1 | | 2-3 | C | 4-31 | E | | 1 1 | | | | | | 2-4 | E | 4-32 | В | | | | 1 1 | | | | 2-5 | C | 4-33 | D | | | | 1 1 | | | | 2-6 | C | 4-34 | D | | | | 1 1 | | | | 2-7 | E | 4-35 | D | | | | 1 1 | | l 1 | | 2-8 | E | 4-36 | D | | | | 1 1 | 1 | 1 1 | | 2 <del>-9</del> | E | 4-37 | D | 1 | | | 1 1 | 1 | | | 2-10 | E | 4-38 | D | | | | 1 1 | | 1 | | 2-11 | D | 4-39 | В | | i l | | | Ì. | | | 2-12 | D | 4-40 | В | | 1 | | 1 1 | | 1 1 | | 2-13 | D | 4-41 | В | | 1 1 | 1 | | | i i | | 2-14 | E | 4-42 | В | • | | | i ! | | 1 | | 2-15 | E | 5-1 | E | | | | 1 | | 1 1 | | 2-16 | E | 5-2 | A | | | l | 1 1 | | i | | 2-17 | E | 5-3 | A | | | · | | | | | 3-1 | E | 5-4 | A | | | • | | | | | 3-2 | E | 5-5 | В | | 1 1 | | | | | | 3-3 | E | 56 | A | | | | | | 1 | | 3-4 | E | 5-7 | E | | 1 | | 1 1 | | | | 3-5 | l e i | 5-8 | E | | 1 | | | | | | 3-6 | E. | 5-9 | E | | | · . | 1 1 | | | | 3-7 | E | 5-10 | A | | | <b>.</b> | 1 | | | | 3-8 | E | 5-11 | A | ] | 1 | i I | 1 1 | 1 | | | 3-9 | E | 5-12 | A | | 1 | | 1 1 | | | | 3-10 | E | 5-13 | A | | | | 1 1 | | 1 | | 3-11 | E | 5-14 | A | | | 1 | 1 1 | | 1 | | 3-12 | E | 5-15 | A | | 1 | 1 [ | | | į l | | 3-13 | E | 5-16 | A | 11 | | | | | | | 3-14 | E | 5-17 | A | | 1 | | 1 1 | | 1 | | 4-1 | A | 5-18 | A | | 1 | ' | | 1 | | | 4-2 | В | 5-19 | A | | 1 | | | 1 | | | 4-3 | В | 5-20 | A | | | | | | | | 4-4 | В | 5-21 | E | | | | | | | | 4-5 | В | 5-22 | E | | | | | | | | 4-6 | В | 5-23 | A | , | | | | | | | | 1 - | B 1 | | l 1 | I | 11 | 1 1 | I | ı | ## **PREFACE** This manual contains hardware reference information for the CDC® CYBER 170 Models 835, 845, and 855 Computer Systems and the CYBER 180 Models 835, 840, 845, 850, 855, 860, and 990 Computer Systems. The manual describes the functional, operational, and programming characteristics of the computer system hardware. Additional hardware reference information is available in the publications listed in the system publication index on the following page. This manual is for use by customer, marketing, training, programming, and Engineering Services personnel who operate, program, and maintain the computer systems. There are two methods used within this manual to designate bit numbers. In the majority of the manual, bits are numbered 59 through 0 reading from left to right. | 59 | | | |----|---|--| | | | | | | ÷ | | | | | | However, in the context of the two-port multiplexer and maintenance registers, bits are numbered 0 through 63 from left to right. | 0 | 63 | |---|----| | | | | | | | Ł | | Other manuals that are applicable to the CYBER 170 and CYBER 180 computer systems but not listed in the following index are: | Control Data Publication | Publication<br>Number | |--------------------------------------------------------------------|-----------------------| | NOS Version 2 Operator/Analyst<br>Handbook | 60459310 | | NOS Version 2 Systems<br>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<br>Reference Manual, Volume 1 | 60458480 | | NOS/BE Version 1 System Programmer's Reference Manual, Volume 2 | 60458490 | | Maintenance Register Codes Booklet | 60458110 | | Codes Booklet | 60458100 | | CYBER Initialization Package (CIP)<br>User's Handbook | 60457180 | Publication ordering information and latest revision levels are available from the Literature Distribution Services catalog, publication number 90310500. ### 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. It has been tested and found to comply with the limits for a 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 when operated in a commercial environment. 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. SYSTNDEX BIO # **CONTENTS** | 1. SYSTEM DESCRIPTION | 1-1 | Models 845 and 855, without the Memory Upgrade Option | 2-9 | |--------------------------------------------------|------------|-------------------------------------------------------|------------| | Introduction | 1-1 | Models 845 and 855, with the Memory | | | Physical Characteristics | 1-1 | Upgrade Option, and models 840, | | | Functional Characteristics (Models 835, 840, | | 850, and 860 | 2-9 | | 845, 850, 855, and 860) | 1-4 | Model 990 | 2-9 | | Model 835 Characteristics | 1-4 | CM Ports and Priorities | 2-9 | | Central Processor | 1-4 | SECDED | 2-9 | | Central Memory | 1-4 | CM Layout | 2-10 | | Input/Output Unit | 1-5 | CM Bounds Register | 2-10 | | Models 840, 845, 850, 855, and 860 | | Central Memory Reconfiguration | 2-10 | | Characteristics | 1-5 | Input/Output Unit | 2-14 | | Central Processor | 1-5 | Peripheral Processor | 2-14 | | Central Memory | 1-5 | • | 2-14 | | Input/Output Unit | 1-6 | Deadstart<br>Barrel and Slot | 2-14 | | Functional Characteristics (Model 990) | - : | | 2-14 | | Model 990 Characteristics (Model 990) | 1-6 | PP Registers | | | | 1-6 | PP Numbering | 2-16 | | Central Processor | 1-6 | PP Memory | 2-16 | | Central Memory | 1-6 | I/O Channels | 2-16 | | Input/Output Unit | 1-7 | Real-Time Clock | 2-16 | | Major System Component Descriptions | 1-7 | Two-Port Multiplexer | 2-16 | | Central Processor | 1-7 | Maintenance Channel | 2-17 | | Instruction Section | 1-7 | Central Memory Access | 2-17 | | Registers | 1-7 | | | | Execution Section | 1-7 | | | | Cache Memory | 1-7 | 3. OPERATING INSTRUCTIONS | 3-1 | | Addressing Section | 1-7 | | | | Central Memory Control | | Controls and Indicators | 3-1 | | (Models 840 through 990) | 1-8 | Deadstart Panel Controls/Indicators | | | Central Memory | 1-8 | (Models 835, 840, 845, 850, 855, and 860) | 3-1 | | Input/Output Unit | 1-8 | Deadstart Display/Controls (Model 990) | 3-3 | | System Console | 1-8 | Central Memory Controls | 3-3 | | | | Power-On and Power-Off Procedures | 3-11 | | | | Operating Procedures (all models except 990) | 3-11 | | | | Control Checks | 3-11 | | 2. FUNCTIONAL DESCRIPTIONS | 2-1 | Deadstart Sequences | 3-11 | | | | Operating Procedures (Model 990) | 3-12 | | Central Processor | 2-1 | Control Checks | 3-12 | | Instruction Section | 2-1 | Deadstart Sequences | 3-12 | | Model 835 Instruction Lookahead | 2-1 | IOU Reconfiguration (all models | | | Models 840, 845, and 850 | | except 990) | 3-12 | | Instruction Lookahead | 2-1 | IOU Reconfiguration (Model 990) | 3-12 | | Models 855 and 860 Instruction | | 100 Reconfiguration (model 990) | J 12 | | Lookahead | 2-1 | | | | Model 990 Instruction Lookahead | 2-1 | 4. INSTRUCTION DESCRIPTIONS | 4-1 | | Maintenance Access Control | 2-2 | | | | Instruction Control Sequences | 2-2 | CP Instructions | 4-1 | | Registers | 2-4 | CP Instruction Formats | 4-1 | | Operating Registers | 2-5 | CP Operating Modes | 4-2 | | Support Registers | 2-5 | CP Instruction Descriptions | 4-2 | | Execution Section | 2-7 | Instruction Execution Timing | 4-20 | | Cache Memory | 2-7 | PP Instruction Descriptions | 4-30 | | Addressing Section | 2-7 | PP Instruction Formats | 4-30 | | Central Memory Control | | PP Data Format | 4-30 | | (Models 840 through 990) | 2-7 | PP Relocation Register Format | 4-30 | | Central Memory | 2-7 | PP Instruction Descriptions | 4-31 | | Address Format (Models 835, 845, and 855 | | Instruction Execution Timing | 4-39 | | without the Memory Upgrade Option) | 2-7 | Thousand the training | , | | Address Format (Models 845 and 855, with | | | | | the Memory Upgrade Option, and models | 2-0 | 5. PROGRAMMING INFORMATION | 5-1 | | 840, 850, and 860)<br>Address Format (Model 990) | 2-8 | CD. Dwo gwowyt - w | ٠. | | CM Access and Cycle Times | 2-8<br>2-8 | CYPER 170 Frohence Lune | 5-1 | | Model 835 | 2-8 | CYBER 170 Exchange Jump | 5-1<br>5-2 | | | | | | 60469290 E | Floating-Point Arithmetic | 5-2 | Channel (Marker) Flag Instructions | | |----------------------------------------|------------------|--------------------------------------|--------------| | Format | 5-2 | (641, 651) | 5-16 | | Packing | 5-2 | Error Flag Instructions (661, 671) | 5-16 | | Overflow | 5-3 | Channel Transfer Timing | 5-16 | | Underflow | 5-3 | Input/Output Transfers | 5-18 | | Indefinite | 5-3 | Data Input Sequence | 5-18 | | Nonstandard Operands | 5-4 | Data Output Sequence | 5-18 | | Normalized Numbers | 5-4 | System Console Programming | 5-16<br>5-21 | | Rounding | 5-4 | Keyboard | 5-21 | | Double-Precision Results | 5-4 | Data Display | 5-21 | | Fixed-Point Arithmetic | 5-4 | Character Mode | 5-21<br>5-21 | | Integer Arithmetic | 5-6 | Dot Mode | 5-21 | | Compare/Move Arithmetic | 5-6 | Codes | 5-21<br>5-22 | | Instruction Lookahead Purge Control | 5-6 | Programming Example | 5-22<br>5-22 | | Model 835 Purge Control | 5 <b>-</b> 6 | Programming Timing Considerations | | | Models 840, 845, 850, 855, and 860 | 3 0 | Real-Time Clock Programming | 5-22<br>5-23 | | Purge Control | 5-7 | Two-Port Multiplexer Programming | 5-23 | | Model 990 Purge Control | 5-7 | Two-Port Multiplexer Operation | 5-23 | | Error Response | 5-7 | Terminal Select (7XXX) | 5-23 | | Illegal Instructions | 5 <del>-</del> 7 | Terminal Deselect (6XXX) | 5-23 | | Hardware Errors | 5–7 | Read Status Summary (00XX) | 5-23 | | Conditional Software Errors | 5-12 | PP Read Terminal Data (01XX) | 5-23 | | Memory Programming | 5-12 | PP Write Output Buffer (02XX) | 5-24 | | Addressing Modes | 5-12 | Set Operation Mode to the | J-24 | | Direct Read/Write Instructions (014, | , 1 <b>2</b> | Terminal (03XX) | 5-24 | | 015, 660, 670) | 5-12 | Set/Clear Data Terminal Ready (04XX) | 5-24<br>5-24 | | Block Copy Instructions (011, 012) | 5-12 | Set/Clear Request to Send (05XX) | 5-24<br>5-24 | | PP Programming | 5-14 | Master Clear (07XX) | 5-24 | | Central Memory Addressing by PPs | 5-14 | Programming Considerations | 5-24 | | PP Memory Addressing by PPs | 5-14 | Output Data | 5-25 | | Direct 6-Bit Operand | 5-14 | Input Data | 5-25 | | Direct 18-Bit Operand | 5-14 | Request to Send and Data Terminal | , 2, | | Direct 6-Bit Address | 5-14 | Ready | 5-25 | | Direct 12-Bit Address | 5-14 | Maintenance Channel Programming | 5-25 | | Indexed 12-Bit Address | 5-14 | Maintenance Channel | 5-25 | | Indirect 6-Bit Address | 5-14 | MCH Function Words | 5-27 | | Central Memory Read/Write Instructions | 5-14 | MCH Control Words | 5-27 | | PP Central Memory Read | | MCH Programming for Halt/Start | , 21 | | Instructions (60, 61) | 5-14 | (Opcode 0/1) | 5-27 | | PP Central Memory Write | | MCH Clear LED (Opcode 3) | 5-27 | | Instructions (62, 63) | 5-15 | MCH Programming for Read/Write | 3 21 | | Input/Output Channel Communications | 5-15 | (Opcode 4/5) | 5-28 | | Inter-PP Communications | 5-15 | MCH Programming for Master Clear/ | J 20 | | PP Program Timing Considerations | 5-16 | Clear Errors (Opcode 6/7) | 5-28 | | Channel Operation | 5-16 | MCH Echo (Opcode 8) | 5-28 | | Channel Control Flags | 5-16 | MCH Programming for Read IOU Status | J 20 | | Channel Active/Inactive Flag | 5-16 | Summary (Opcode C, IOU Only) | 5-28 | | Register Full/Empty Flag | 5-16 | , | 0 | | | | | | ## **APPENDIX** ## A. GLOSSARY A-1 ## **INDEX** ## **FIGURES** | 1-1 | Models 835, 845, and 855 Computer Systems | | 1-6 | Models 840, 850, and 860 Chassis | | |-----|-------------------------------------------|-----|-------|------------------------------------|------| | | (without the Memory Upgrade Option) | 1-1 | | Configuration, Single CP | | | | Model 990 Computer System | 1-2 | | (Top Cutaway View) | 1-3 | | 1-3 | Model 835 Chassis Configuration (Top | | 1-7 | Model 860 Chassis Configuration, | | | | Cutaway View) | 1-2 | | Dual CP (Top Cutaway View) | 1-3 | | 1-4 | Models 845 and 855 (without the Memory | | 1-8 - | Model 990 Chassis Configuration | - 3 | | | Upgrade Option) Chassis Configuration | | | (Top Cutaway View) | 1-4 | | | (Top Cutaway View) | 1-3 | 1-9 | Model 835 Computer System | 1-9 | | 1-5 | Models 845 and 855 (with the Memory | | 1-10 | Models 840, 845, 850, 855, and 860 | | | | Upgrade Option) Chassis Configuration | | | Computer System | 1-10 | | | and Optional Dual CP (Top Cutaway View) | 1-3 | 1-11 | Model 990 Computer System | 1-11 | | | | | | | | | 12-1 | CYBER 170 Exchange Package | 2-5 | 4-2 | PP Instruction Formats | 4-30 | |------------|-------------------------------------------------------------------------------|------|------|----------------------------------------------------------|--------------| | 2-2 | Address Format (Models 835, 845, and | | 4-3 | PP Data Format | 4-30 | | | 855 without the Memory Upgrade Option) | 2-7 | 4-4 | PP Relocation (R) Register Format | 4-31 | | 2-3 | Address Format (Models 840, 850, | | 5-1 | CYBER 170 Exchange Package | 5-1 | | | and 860) | 2-8 | 5-2 | Floating-Point Format | 5-2 | | 2-4 | Address Format (Model 990) | 2-8 | 5-3 | Floating-Add Result Format | 5-4 | | 2-5 | CM Layout | 2-10 | 5-4 | Multiply Result Format | 5-4 | | 2-6 | Barrel and Slot | 2-15 | 5-5 | Format of Exit Condition Register | | | 2-7 | Formation of Absolute CM Address | 2-15 | | at (RAC) | 5-7 | | 3-1 | Deadstart Panel (all models except 990) | 3-1 | 5-6 | Memory Map | 5-13 | | 3-2 | Deadstart Options Display (Model 990) | 3-4 | 5-7 | Channel Transfer Timing | 5-17 | | 3-3 | Initial Deadstart Display (Model 990) | 3-4 | 5-8 | Data Input Sequence Timing | 5-19 | | 3-4 | CM Configuration Switches | 3-5 | 5-9 | Data Output Sequence Timing | 5-20 | | 3-5 | Reconfiguration Examples (Models 845 | | 5-10 | Display Station Output Function Code | 5-22 | | | and 855 with the Memory Upgrade | | 5-11 | Coordinate Data Word | 5-22 | | | Option and models 840, 850, and 860 | 3-10 | 5-12 | Character Data Word | 5-22 | | 4-1 | CP Instruction Parcel Arrangement | 4-1 | 5-13 | Receive and Display Program Flowchart | 5-22 | | | | | | | | | | | TAB | LES | | | | 2-1 | Port Priority | 2-9 | 5-1 | Bits 58 and 59 Configurations | 5-2 | | 2-2 | Model 835 SECDED Syndrome Codes/ | | 5-2 | Xj Plus Xk (30, 32, 34 Instructions) | 5-5 | | | Corrected Bits | 2-11 | 5-3 | Xj Minus Xk (31, 33, 35 Instructions) | 5-5 | | 2-3 | Models 840, 845, 850, 855, and 860 SECDED | | 5-4 | Xj Multiplied by Xk (40, 41, 42 | | | | Syndrome Codes/Corrected Bits | 2-12 | | Instructions) | 5-5 | | 2-4 | Model 990 SECDED Syndrome Codes/ | | 5-5 | Xj Divided by Xk (44, 45 Instructions) | 5-5 | | | Corrected Bits | 2-13 | 5-6 | Contents of Exit Condition Register | | | 3-1 | Deadstart Panel Controls/Indicators, all | | | at (RAC) | 5-7 | | | models except 990 | 3-2 | 5-7 | Error Exits in CYBER 170 Monitor | - 0 | | 3-2 | • • • | 3-6 | | Mode (MF=1) | 5-8 | | 3-3 | Deadstart Display Operator Entries and | | 5–8 | Error Exits in CYBER 170 Job Mode | E 10 | | | Functions | 3–6 | | (MF=0) | 5-10 | | 3–4 | Central Memory Reconfiguration (Models | | 5-9 | Keyboard Character Codes | 5-21 | | | 835, 845, and 855 without the Memory | 2 7 | 5-10 | • • | 5-21<br>5-26 | | ۰. | Upgrade Option) | 3-7 | 5-11 | <del>-</del> | 3-20 | | 3-3 | Central Memory Reconfiguration (Models | | 5-12 | MCH Function Word Bit Assignments, all models except 990 | 5-27 | | | 845 and 855 with the Memory Upgrade | 3-8 | 5_12 | MCH Function Word Bit Assignments, | , 21 | | 2 -6 | Option and models 840, 850, and 860) | 7 2 | J-13 | Model 990 | 5-27 | | 3-0<br>3-7 | Central Memory Reconfiguration (Model 990) Barrel Numbering Table (all models | 3-7 | 5-14 | Model 835 CP Internal Address | , 2, | | 3-7 | except 990) | 3-13 | J-14 | Assignments | 5-29 | | 2_0 | PP and Barrel Reconfiguration Example, | J13 | 5-15 | Model 835 CM Internal Address | , <u>.</u> , | | 3-0 | RP=0 (Model 990) | 3-13 | , 1, | Assignments | 5-29 | | 3-9 | | J 13 | 5-16 | | J . 2. | | 3.7 | RP=2 (Model 990) | 3-14 | 3 10 | CP Internal Address Assignments | 5-30 | | 4-1 | Central Processor Instruction Designators | 4-2 | 5-17 | | • | | | Collate Table | 4-16 | 2 | Assignments | 5-30 | | 4-3 | | 4-20 | 5-18 | — — — — — — — — — — — — — — — — — — — | | | | Model 845 CP Instruction Timing | 4-23 | | Internal Address Assignments | 5-31 | | 4-5 | | 4-27 | 5-19 | Model 990 CM Internal Address | | | | PP Nomenclature | 4-30 | | Assignments | 5-31 | | | DD Instruction Timing | 4-40 | 5-20 | TON Internal Address Assignments | 5-33 | 9 This section introduces the CYBER 170 Models 835, 845, 855, and the CYBER 180 Models 835, 840, 845, 850, 855, 860, and 990 Computer Systems, identifies their physical and functional characteristics, and provides descriptions of major system components. ## INTRODUCTION Models 835, 845, and 855 without the Memory Upgrade Option (figure 1-1), models 845 and 855 with the Memory Upgrade Option and models 840, 850, and 860 (not shown), and model 990 (figure 1-2) are high-speed computer systems for both business and scientific applications. The systems include the following components. - Central processor (CP). - Central memory (CM). - Input/output unit (IOU). ## PHYSICAL CHARACTERISTICS The mainframe configuration for model 835 (figure 1-3), and models 845 and 855 without the Memory Upgrade Option (figure 1-4) include a three-section cabinet for the CP, CM, and IOU. (The system console is also required for system operation.) Each cabinet section contains a logic chassis with plug-in circuit boards. The logic chassis in the IOU also contains a deadstart panel with initialization and maintenance controls and displays. Each cabinet section also contains a self-contained cooling unit to cool the logic chassis, at ac/dc control section with voltage margin testing facilities, and dc power supplies. For additional cooling or power information, refer to the cooling system and power system manuals listed in the system publication index. Figure 1-1. Models 835, 845, and 855 Computer Systems (Without the Memory Upgrade Option) Figure 1-2. Model 990 Computer System The mainframe configuration for models 845 and 855 with the Memory Upgrade Option (figure 1-5) and models 840, 850, and the single-CP 860 (figure 1-6) include an interconnected three-section cabinet for the CP, CM, and IOU. (The system console is also required for system operation.) The model 855, with the Memory Upgrade Option, and model 860 (figure 1-7) also support an optional second CP, which is contained in an additional one-bay section. (The model 855 second CP does not support CYBER 170 State operation.) Each cabinet section contains a logic chassis with plug-in circuit boards. The CP cabinet section comprises three attached subsections, each with separate power and cooling facilities. A stand-alone cooling unit provides cooling for the CP subsections and CM. The IOU cabinet section has a self-contained cooling unit to cool the IOU logic chassis. Each cabinet section also contains an ac/dc control section with voltage margin testing facilities and dc power supplies. For additional cooling or power information, refer to the cooling system and power system manuals listed in the system publication index. Figure 1-3. Model 835 Chassis Configuration (Top Cutaway View) Figure 1-4. Models 845 and 855 (without the Memory Upgrade Option) Chassis Configuration (Top Cutaway View) Figure 1-5. Models 845 and 855 (with the Memory Upgrade Option) Chassis Configuration and Model 855 Optional Dual CP (Top Cutaway View) The mainframe configuration for model 990 (figure 1-7) includes interconnected CP, CM, and IOU cabinet sections that compose the system cabinet. (The system console is also required for system operation.) Each cabinet section contains a logic chassis with plug-in circuit boards. The CP consists of 10 sections, plus a single section for central memory control (CMC). With the dual-CP option, an additional, identical cabinet contains the second CP. (The second CP does not support CYBER 170 State operation.) The CM consists of one section with four memory cages. The IOU consists of two sections and performs initialization and maintenance functions. The CP, CM, and IOU sections each contain an ac/dc control section with voltage margin testing facilities and dc power supplies. A stand-alone cooling unit provides cooling for the CP and CM logic chassis, while the IOU has a built-in cooling unit. Figure 1-6. Models 840, 850, and 860 Chassis Configuration, Single CP (Top Cutaway View) Figure 1-7. Model 860 Chassis Configuration, Dual CP (Top Cutaway View) Figure 1-8. Model 990 Chassis Configuration (Top Cutaway View) # FUNCTIONAL CHARACTERISTICS (MODELS 835,840,845,850,855, AND 860) To achieve high computation speeds, the model 835 uses emitter-coupled logic (ECL); models 840, 845, 850, 855, and 860 use ECL and large-scale integration (LSI) logic. High speed is also the objective of the CP design, which is based on the assumption that both data and instructions are, in most cases, accessed from successive memory locations. Accordingly, the CP prefetches both instructions and data expected to be used next while the current instruction is being processed. The semiconductor central memory is divided into eight independent banks. These banks may all be simultaneously in the process of completing read/write requests which are queued and distributed at ECL speeds. System input/output speeds are determined by the capabilities of existing external devices. ## **MODEL 835 CHARACTERISTICS** #### Central Processor The model 835 CP hs the following characteristics: - 60-bit internal word. - Eight 60-bit operand (X) registers. - Eight 18-bit address (A) registers. - Eight 18-bit index (B) registers. - Two registers that isolate each user's central memory space (RAC, FLC). - Two registers that isolate each user's extended memory space (RAE, FLE). - Register exchange instructions (exchange jumps) for interrupting programs. - Floating-point arithmetic (10-bit exponent plus sign bit, 48-bit coefficient plus sign bit). Some FP instructions use 96-bit (double-precision) coefficients. - Integer arithmetic (60/18-bit operands). - Character string compare/move facilities (6-bit characters). - Packed instructions (15/30/60-bit instructions in 60-bit words). - Synchronous internal logic. - 56-nanosecond clock period. - 2048-word cache buffer memory, option available for 4096-word cache. - Instruction and branch instruction lookahead. - Microcode control. - Parity checking of all major data and address paths. - Maintenance channel to IOU. ## **Central Memory** The model $835\ \text{CM}$ has the following characteristics: - 72-bit data word (60 data bits, 8 singleerror correction double-error detection bits, and 4 unused bits). - 524K words of refresh-type semiconductor memory, options available to 2097K words. - Organization of eight independent banks. - Two memory ports. - Bounds register to limit write access. - 56-nanosecond clock period. - Maximum data transfer rate of one word every 56 nanoseconds. - 672-nanosecond read access time. - 448-nanosecond read/write cycle time. - 896-nanosecond partial write cycle time. - Read and write data queuing capability. - Single-error correction double-error detection (SECDED) on stored data. - Parity checking of all major data, address and control paths. - Unified extended memory (UEM) which serves as extended memory within CM. #### Input/Output Unit The model 835 IOU has the following characteristics: - Ten peripheral processors (PPs), 15-PP/20-PP options available. Each PP has 4K independent memory (PPM) comprised of 16-bit words with the upper 4 bits zero. - Port to central memory. - Bounds register to limit writes to central memory. - Twelve 12-bit CYBER 170 channels to external devices, 24 channel option available. - Real-time clock (channel 148). - Display controller (CYBER 170 channel 108). - Two-port multiplexer (channel 15g). - Maintenance channel (channel 178). - Parity checking on all major data and address paths. - Operating speed of 250 nanoseconds and a minor cycle of 50 nanoseconds. # MODELS 840,845,850,855, AND 860 CHARACTERISTICS ### **Central Processor** The models 840, 845, 850, 855, and 860 CP have the following characteristics: - 60-bit internal word. - Eight 60-bit operand (X) registers. - Eight 18-bit address (A) registers. - Eight 18-bit index (B) registers. - Two registers that isolate each user's central memory space (RAC, FLC). - Two registers that isolate each user's extended memory space (RAE, FLE). - Register exchange instructions (exchange jumps) for interrupting programs. - Floating-point arithmetic (10-bit exponent plus sign bit, 48-bit coefficient plus sign bit). Some FP instructions use 96-bit (double-precision) coefficients. - Integer arithmetic (60/18-bit operands). - Character string compare/move facilities (6-bit characters). - Packed instructions (15/30/60-bit instructions in 60-bit words). - Synchronous internal logic. - 64-nanosecond clock period. - 2048-word cache buffer memory, option available for 4096-word cache. - Instruction and branch instruction lookahead. - Microcode control. - Parity checking of all major data and address paths. - Maintenance channel to IOU. ## **Central Memory** The models 845 and 855 CM without the Memory Upgrade Option, has the following characteristics: Timing references are from CMC/CPU interface. - 72-bit data word (60 data bits, 8 single-error correction double-error detection bits, and 4 unused bits). - 524K words of refresh-type semiconductor memory, options available to 4192K words. - Organization of eight independent banks. - Two memory ports (located in the central processor cabinet). - Bounds register to limit write access. - 64-nanosecond clock period. - Maximum data transfer rate of one word every 64 nanoseconds. - 528-nanosecond read access time. - 448-nanosecond read/write cycle time. - 896-nanosecond partial write cycle time. - Read and write data queuing capability. - Single-error correction double-error detection (SECDED) on stored data. - Parity checking of all major data, address and control paths. - Unified extended memory (UEM) which serves as extended memory within CM. The models 845 and 855, with the Memory Upgrade Option, and the models 840, 850, and 860 CM have the following characteristics: Timing references are from CMC/CPU interface. - 72-bit data word (60 data bits, 8 singleerror correction double-error detection bits, and 4 unused bits). - 2097K words (16 Megabytes) of dynamic random access memory, options available to 16 776K words (128 Megabytes). - Organization of eight independent banks. - Two memory ports (located in the central processor cabinet). - Bounds register to limit write access. - 64-nanosecond clock period. - Maximum data transfer rate of one word every 32 nanoseconds. - 464 nanosecond read access time. - 384 nanosecond read/write cycle time. - 768 nanosecond partial write cycle time. - Read and write data queuing capability. - Single-error correction double-error detection (SECDED) on stored data. - Parity checking of all major data, address and control paths. - Unified extended memory (UEM) which serves as extended memory within CM. ## Input/Output Unit The models 840, 845, 850, 855, and 860 IOU is the same as that of the model 835. Refer to the description of the IOU under Model 835 Characteristics. ## **FUNCTIONAL CHARACTERISTICS (MODEL 990)** To achieve high computation speeds, the model 990 uses emitter-coupled logic (ECL) and large-scale integration (LSI) logic. High speed is also the objective of the CP design, which is based on the capability to execute many operations concurrently. The bipolar central memory is divided into 32 independent banks to minimize conflicts between central memory requests. System input/output speeds are determined by the capabilities of existing external devices. ## **MODEL 990 CHARACTERISTICS** #### **Central Processor** The model 990 CP has the following characteristics: - 60-bit internal word. - Eight 60-bit operand (X) registers. - Eight 18-bit address (A) registers. - Eight 18-bit index (B) registers. - Two registers that isolate each user's extended memory space (RAC, FLC). - Two registers that isolate each user's extended memory space (RAE, FLE). - Register exchange instructions (exchange jumps) for interrupting programs. - Floating-point arithmetic (10-bit exponent plus sign bit, 48-bit coefficient plus sign bit). Some FP instructions use 96-bit (double-precision coefficients). - Integer arithmetic (60/18-bit operands). - Character string compare/move facilities (6-bit characters). - Packed instructions (15/30/60-bit instructions in 60-bit words). - Synchronous internal logic. - 16-nanosecond clock period. - 4096-word cache buffer memory. - Instruction and branch instruction lookahead. - Microcode control. - Parity checking of selected data and address paths. - Maintenance channel to IOU. #### **Central Memory** The model 990 CM has the following characteristics: - 72-bit data word (60 data bits, 8 singleerror correction and double-error detection bits, and 4 unused bits). - 1048K words of bipolar memory, options available to 4192K words in 1048K-word increments. - Organization of 32 independent banks. - Memory ports (located in the central processor cabinet). - Bounds register to limit write access. - 64-nanosecond clock period. - Maximum data transfer rate of four words every 16 nanoseconds. - 80-nanosecond read access time. - 64-nanosecond read/write cycle time. - 192-nanosecond partial-write cycle time. - Read and write data queuing capability. - Single-error correction double-error detection (SECDED) on stored data. - Parity checking of all major data, address and control paths. - Unified extended memory (UEM) which serves as extended memory within CM. #### Input/Output Unit The model 990 IOU is the same as that of the model 835 except that each PP has 4K or 8K independent memory (PPM) comprised of 16-bit words with the upper 4 bits zero. Refer to the description of the IOU under Model 835 Characteristics. ## MAJOR SYSTEM COMPONENT DESCRIPTIONS ## **CENTRAL PROCESSOR** The CP hardware (figures 1-9, 1-10, and 1-11) consists of the following: - Instruction section. - Registers. - Execution section. - Cache memory. - Addressing section. - Central memory control (models 840 through 990). The CP is isolated from the IOU and is thus able to carry on computation or character manipulation unencumbered by I/O requirements. ## **Instruction Section** The instruction section directs the arithmetic and manipulative functions for instruction execution. The instruction section prefetches instruction words from memory and disassembles them into instructions. #### Registers Operating registers reduce storage accesses for operands used during the execution of an instruction. These registers are: - Eight 60-bit X registers (XO through X7) which hold operands used for computation. - Eight 18-bit A registers (A0 through A7) which use A0 primarily for indexing and A1 through A7 for CM operand addressing. - Eight 18-bit B registers (B0 through B7) which are primarily indexing registers to control program execution. The B0 register always contains all zeros. Eight support registers support the operating registers during program execution. These registers are: - 18-bit program address (P) register. - 21-bit reference address for CM (RAC) register. This is a program's lower bound. - 21-bit field length for CM (FLC) register. This is a program's upper bound. - 6-bit exit mode (EM) register. - 6-bit flag register. - 21-bit reference address for UEM (RAE) register. - 24-bit field length for UEM (FLE) register. - 18-bit monitor address (MA) register. The registers store data and control information, present operands to the execution section, and store results. For the models 845 and 855, the operating and support registers reside in the operand issue section. For the model 990, the operating and support registers reside in the register unit and process state registers section. #### **Execution Section** The execution section combines the operands to achieve the result. #### **Cache Memory** The cache memory for models 835, 845, and 855 consists of two sets of fast bipolar memory, capable of storing 2048 60-bit words. It can be expanded to four sets with a capacity of 4096 words. The cache memory for model 990 consists of 4096 words. The memory addressing sections determine whether a requested word is in the cache memory. If it is not, they read four consecutive words from central memory into the cache memory. ## **Addressing Section** The addressing section checks memory addresses against the CP registers RAC, FLC, RAE, and FLE to ensure isolation of user memory space. ## Central Memory Control (Models 840 through 990) On models 840 through 990, central memory control (CMC) is integrated within the CP. CMC controls the flow of data between CM and requesting system components. ## CENTRAL MEMORY The CM (figures 1-9, 1-10, and 1-11) consists of the following: - Eight memory banks (models 835 through 860) or 32 memory banks (model 990). - Memory ports. - Distributor. - The CM for the models 835, 845, and 855, without the Memory Upgrade Option, is a refresh-type metal oxide semiconductor (MOS) memory organized into eight independent banks. The CM for the models 845 and 855, with the Memory Upgrade Option, and the models 840, 850, and 860 is a dynamic random access memory organized into eight independent banks. The model 990 CM is a bipolar memory organized into 32 independent banks. A portion of CM can be reserved for use as extended memory. It is called unified extended memory (UEM), and is referenced by the RAE and FLE registers. On the models 835 and 990, UEM operates in 24-bit format standard addressing mode. On models 840, 845, 850, 855, and 860 it can operate in either 24-bit format standard addressing mode or 30-bit format expanded addressing mode. On the model 835, each memory port has queuing buffers. On the models 840, 845, 850, 855, and 860, one port has a queuing buffer. On the model 990, all ports have queuing buffers. The models 840 through 990 have ports located in the central processor cabinet. The distributor resolves port conflicts and multiplexes data from ports to the storage unit. It includes the error correction code (ECC) generator, SECDED, and partial-write logic. On models 840 through 990, the distributor is located in the central processor cabinet. ## INPUT/OUTPUT UNIT The IOU (figures 1-9, 1-10, and 1-11) consists of the following: - Ten logically independent peripheral processors (PPs). Options are available to increase total to 15 or 20 PPs. - Internal interface to 12 I/O channels. 24-channel option is available. - External interfaces to I/O channels - 11 or 23 CYBER 170 channel interfaces. - Display controller interface (CYBER 170 channel 10g). - Real-time clock interface (channel 148). - Two-port multiplexer interface (channel 158). - Maintenance channel interface (channel 178). - Interface to central memory. - Bounds register to limit writes to CM. - On the model 835, cache invalidation bus interface to CP. The PPs are organized in groups of five, called barrels. The PPs in a barrel time-share common hardware. Each PP has its own independent memory, and communicates with all I/O channels and with central memory. ## SYSTEM CONSOLE The system console, required for system operation, provides a visual, alphanumeric readout for the computer. The receipt of symbol and position information from the computer enables displaying program information on a cathode-ray tube (CRT). The station also contains an alphanumeric keyboard which enables an operator to send data to the computer. The keyboard and CRT combination permits the computer operator to monitor and control system operation. Except for programming information in section 5, refer to the system console manual listed in the system publication index in the preface of this manual for further system console information. Figure 1-9. Model 835 Computer System Figure 1-10. Models 840, 845, 850, 855, and 860 Computer System Figure 1-11. Model 990 Computer System This section provides functional descriptions of the central processor (CP), central memory (CM), and input/output unit (IOU) as shown in the block diagrams in section 1. Functional descriptions for the system display station and the cooling system are in their respective manuals listed in the system publication index in the preface of this manual. #### CENTRAL PROCESSOR The CP consists of the instruction section, registers, the execution section, cache memory, and the addressing section. The models 845 through 990 CP also include central memory control. ## **INSTRUCTION SECTION** The instruction section consists of logic for instruction control. ## Model 835 Instruction Lookahead The model 835 instruction lookahead hardware (ILH) prefetches instruction words to make the next instruction immediately available when the execution of the previous instruction is complete; for example, during conditional branch instructions. To accomplish this, ILH reads instructions from cache/CM into a three-word, first-in, first-out buffer. When ILH detects a conditional branch, it reads two instruction words from cache/CM, starting at the target address, into a branch buffer, and holds them until the branch is resolved. If the branch takes place, the branch buffer contains the next two executable instruction words; if not, ILH purges the branch buffer and processing continues with the next instruction in the three-word buffer. ## Models 840, 845, and 850 Instruction Lookahead The models 840, 845, and 850 instruction lookahead hardware (ILH) prefetches a maximum of 12 instructions to make the next instruction immediately available when the execution of the previous instruction is complete. This is accomplished by reading instructions from cache/CM into a series of buffer ranks. The model 845 responds to both negative and positive resolution of a conditional branch by purging the buffer ranks and reinitializing the Instruction Fetch Unit. Models 855 and 860 Instruction Lookahead The model 855 and 860 instruction lookahead hardware (ILH) prefetches a maximum of 12 instructions to make the next instruction immediately available when the execution of the previous instruction is complete. This is accomplished by reading instructions from cache/CM into a series of buffer ranks. When ILH detects a conditional branch, it assumes that the branch condition will be met. ILH computes the branch target address and reads instructions from cache/CM starting at the target address. If the branch is taken, the buffer ranks contain the next executable instruction words. If the branch is not taken, the hardware purges the buffer ranks and resumes prefetching at the instruction word following the unsatisfied branch instruction. #### Model 990 Instruction Lookahead The model 990 instruction lookahead hardware (ILH) speeds up instruction processing by stacking prefetched instructions to make them immediately available for execution. It also accurately predicts program branching based on the recent history of each conditional branch. To maintain a continuous flow of instructions, the instruction section prefetches instruction words ahead of the instruction being read and stores them in the 64-word instruction buffer stack (IBS). This high-speed buffer is set in the instruction stream between CM and the CP execution section. When an instruction is requested for execution, IBS checks whether that instruction is in the stack. If in the stack, the instruction proceeds to instruction decode and initiation. If not in the stack, the instruction is fetched from CM and placed in the IBS. A least-recently-used replacement algorithm determines the new instruction's position in the IBS. If the instruction issued is a conditional branch, the instruction section predicts the branch taken or not taken based on the recent history of the branch. It then prefetches instructions along that path before the branch outcome is known. The actual result of the branch determines whether the conditionally issued instructions may execute to completion. If a branch prediction is correct, the instruction section enables the modifying of registers and CM from issued instructions. If a branch prediction is incorrect, hardware purges the issued instructions along the incorrect branch and issues instructions along the correct branch. In this case, registers and CM appear as if no instructions were issued after the incorrectly predicted branch. As a precaution to incorrect branch prediction, the instruction section will not issue subsequent branch instructions until the prior branch instruction is resolved. 2-1 #### Maintenance Access Control The maintenance access control performs initialization and maintenance operations in the CP. ## **Instruction Control Sequences** The instruction control section performs instruction translation and control sequences. Each control sequence obtains the necessary instruction operands from the operating registers and provides the control signals for execution. Instructions read from CM are 60-bit instruction words that are in four 15-bit groups, two 30-bit groups, or a combination of 15-bit and 30-bit groups. The 15-bit groups are termed parcels with the first parcel (parcel 0) being the highest-order 15 bits of a 60-bit CM word. Second, third, and fourth parcels (parcels 1, 2, and 3) follow in order. The 30-bit groups contain two 15-bit parcels. The instruction control sequences control the execution of one or more instructions of a common type. These sequences and associated instructions are briefly described in this section. For further information, refer to CP Instruction Descriptions in section 4. ## Boolean Sequence The Boolean sequence controls instructions that require bit-by-bit data manipulation. This includes both the logical and transmissive operations. The instructions requiring logical operations are: 11 Tordeel madust (VI) and (VI) 17 Logical difference of (Xj) with complement of (Xk) to Xi | 11 | to Xi | BX1 XJ * Xk | |----|-------------------------------------------------------|--------------| | 12 | Logical sum of (Xj) and (Xk) to Xi | BXi Xj + Xk | | 13 | Logical difference of (Xj) and (Xk) to Xi | BXi Xj - Xk | | 15 | Logical product of (Xj) with complement of (Xk) to Xi | BXi -Xk * Xj | | 16 | Logical sum of (Xj) with complement of (Xk) to Xi | BXi -Xk + Xj | The instructions requiring transmissive operations are: BXi -Xk - Xj | 10 | Transmit (Xj) to Xi | BXi Xj | |----|-----------------------------------|---------| | 14 | Transmit complement of (Xk) to Xi | BXi -Xk | ## Shift Sequence The shift sequence controls instructions that require shifting the 60-bit field of data within the operand word. The shift instructions are: | 20 | Left shift (Xi) by jk | LXi jk | |----|------------------------|--------| | 21 | Right shift (Xi) by jk | AXi jk | | 22 | Left shift (Xk) nominally | LXi Bj, Xk | |----|---------------------------|------------| | | (Bi) places to Xi | | | 23 | Right shift | (Xk) nominally | AXi | Вj, | Χk | |----|-------------|----------------|-----|-----|----| | | (Bi) places | to Xi | | | | The shift sequence also controls the pack and unpack instructions. In the packed floating format, the coefficient is contained in the lower 48 bits. The sign and biased exponents are contained in the upper 12 bits. The unpack instruction obtains the packed word from the Xk register, delivers the coefficient to the Xi register, and delivers the exponent to the Bj register. The unpack and pack instructions are: | 26 | Unpack | (Xk) | to | Χi | and | Вj | UXi | Вj, | Χk | |----|--------|------|----|----|-----|----|-----|-----|----| |----|--------|------|----|----|-----|----|-----|-----|----| The shift sequence also controls the normalize operations. The coefficient portion of the operand is repositioned, and the exponent is adjusted so that the most significant bit of the coefficient is in the highest-order bit position of the coefficient, and the exponent is decreased by the number of bit positions shifted. The normalize instructions are: | 24 | Normalize | (Xk) | to | Χí | and | Вi | NXi | Вj, | Χk | |----|-----------|------|----|----|-----|----|-----|-----|----| | | | | | | | | | | | | 25 | Round normalize | (Xk) to | Xi ZXi | Вj, | Χk | |----|-----------------|---------|--------|-----|----| | | and Bj | | | | | #### Floating-Add Sequence The floating-add sequence controls the operations necessary to form the 48-bit floating sum with a 12-bit exponent of the floating-point sum or difference of two floating-point operands. The floating-add instructions are: | 30 | Floating | sum | of | (Xj) | and | (Xk) | FXi | Хj | + | Χk | |----|----------|-----|----|------|-----|------|-----|----|---|----| | | to Xi | | | | | | | | | | | 31 | Floating | difference | of | (Xj) | FXi | Xj - | · Xk | |----|----------|------------|----|------|-----|------|------| | | and (Xk) | to Xi . | | | | | | ## Floating-Multiply and Floating-Divide Sequence The floating-multiply and floating-divide sequence controls the operation of floating-multiply, floating-divide, and population-count instructions. The multiply instructions are: | 40 | Floating | product | of | (Xj) | FXi | Хj | * | Χk | |----|----------|---------|----|------|-----|----|---|----| | | and (Xk) | to Xi | | | | | | | | | 41 | Round floating product of (Xj) and (Xk) to Xi | RXi Xj * Xk | | Set Xi to (Aj) + (Bk) | SXi Aj + Bk | |-----|-----|-----------------------------------------------|--------------|--------|------------------------------------|-------------| | 4 | 42 | Floating double-precision | DXi Xj * Xk | 75 | Set Xi to (Aj) - (Bk) | SXi Aj - Bk | | | 72 | product of (Xj) and (Xk) to Xi | DAI AJ ~ AK | 76 | Set Xi to (Bj) + (Bk) | SXi Bj + Bk | | The | div | ide instructions are: | | 77 | Set Xi to (Bj) - (Bk) | SXi Bj - Bk | | | 44 | Floating divide (Xj) by (Xk) to Xi | FXi Xj/Xk | he lon | ng-add instructions are: | | | | 45 | Round floating divide (Xj) by (Xk) to Xi | RXi Xj/Xk | 36 | Integer sum of (Xj) and (Xk) to Xi | IXi Xj + Xk | | The | poj | pulation-count instruction count | s the number | 37 | Integer difference of (Xi) | IXi Xi - Xk | The population-count instruction counts the number of one bits in a 60-bit operand. The instruction is: 47 Population count of (Xk) to Xi CXi Xk ## Increment Sequence The increment sequence controls the one's complement addition and subtraction of 18-bit fixed-point operands for increment instructions 50 through 77. The sequence also controls the 60-bit one's complement sum and difference values for long-add instructions 36 and 37. The increment instructions are: | 50 | Set Ai to (Aj) + K | SAi Aj + K | |-----|-----------------------|-------------| | 51 | Set Ai to (Bj) + K | SAi Bj + K | | 52 | Set Ai to (Xj) + K | SAi Xj + K | | 53 | Set Ai to (Xj) + (Bk) | SAi Xj + Bk | | 54 | Set Ai to (Aj) + (Bk) | SAi Aj + Bk | | 55 | Set Ai to (Aj) - (Bk) | SAi Aj - Bk | | 56 | Set Ai to (Bj) + (Bk) | SAi Bj + Bk | | 57 | Set Ai to (Bj) - (Bk) | SAi Bj - Bk | | 60 | Set Bi to (Aj) + K | SBi Aj + K | | 61 | Set Bi to (Bj) + K | SBi Bj + K | | 6.2 | Set Bi to (Xj) + K | SBi Xj + K | | 63 | Set Bi to (Xj) + (Bk) | SBi Xj + Bk | | 64 | Set Bi to (Aj) + (Bk) | SBi Aj + Bk | | 65 | Set Bi to (Aj) - (Bk) | SBi Aj - Bk | | 66 | Set Bi to (Bj) + (Bk) | SBi Bj + Bk | | 67 | Set Bi to (Bj) - (Bk) | SBi Bj - Bk | | 70 | Set Xi to (Aj) + K | SXi Aj + K | | 71 | Set Xi to (Bj) + K | SXi Bj + K | | 72 | Set Xi to (Xj) + K | SXi Xj + K | | 73 | Set Xi to (Xj) + (Bk) | SXi Xj + Bk | | | | | ## Compare/Move Sequence and (Xk) to Xi The compare/move sequence controls data manipulation on a character basis. The compare/move instructions (also referred to as CMU instructions) are 60-bit instructions that use six support registers for source and result field CM addresses and character position offsets. The support registers load from the 60-bit instruction word. The compare/move instructions are: | 464 | Move indirect (Bj) + K | IM Bj + K | |-----|------------------------|-----------| | 465 | Move direct | DM | | 466 | Compare collated | CC | | 467 | Compare uncollated | CU | ## The support registers are: - An 18-bit Kl register that specifies which relative CM address word contains the first character of the source data field. - An 18-bit K2 register that specifies which relative CM address word contains the first character of the result field. - A 4-bit Cl register that specifies the character position or offset of the first CM word of the source field. - A 4-bit C2 register that specifies the character position or offset of the first CM word of the result field. - Two 16-bit L registers (LA and LC) that specify the number of characters in the data field. The LA register is associated with K1, and the LC register is associated with K2. Instruction 464 uses 14 register bits. Instructions 465, 466, and 467 use only the lower eight register bits. ## NOTE CMU instructions are provided for compatibility with previous systems. For better performance, recompile jobs to avoid use of CMU instructions. #### CYBER 170 Exchange Sequence The CYBER 170 exchange sequence is the method used to swap jobs in and out of execution. When a CYBER 170 exchange jump instruction occurs, the CYBER 170 exchange sequence writes the contents of the current job's CP registers (described later in this section) into an area of central memory called a CYBER 170 exchange package. A CYBER 170 exchange package is associated with each job. It contains sufficient information to restart a job if the job is interrupted during execution and swapped out by a CYBER 170 exchange jump. To complete the sequence, CP registers for another job are read from its CYBER 170 exchange package and that job begins or resumes execution. For further information, refer to CYBER 170 Exchange Jump in section 5. ## **Block Copy Sequence** The block copy sequence controls the transfer of data between CM and UEM. The number of words to be transferred is determined by the addition of K to the contents of Bj. The starting address for CM is formed by adding either the AO register or certain bits of the XO register to the RAC reference address. The starting address for UEM is formed by adding certain bits of the XO register to the RAE reference address. The block copy instructions are: | 011 | Block copy Bj + K words | RE Bj + K | |-----|-------------------------|-----------| | | from UEM to CM | • | 012 Block copy Bj + K words from CM to UEM WE Bj + K ## Direct Read/Write Sequence Instructions 014 and 015 perform single word direct read and write operations for UEM, and instructions 660 and 670 perform single word direct read and write operations for central memory. | 014 | Read one word from UEM at (Xk + RAE) into Xj | RXj Xk | |-----|----------------------------------------------|---------| | 015 | Write one word from Xj to UEM at (Xk + RAE) | WXj Xk | | 660 | Read central memory at (Xk) to Xj | CRXj Xk | | 670 | Write Xj into central memory at (Xk) | CWXj Xk | #### Normal Jump Sequence The normal jump sequence controls the execution of branch instructions 02 through 07. The 02 instruction performs an unconditional jump to the Bi register address plus K. The branch address is K when 1 equals 0. The 02 instruction is: 02 Jump to $$(Bi) + K$$ JP $Bi + K$ The conditional jump instructions 03 through 07 branch to address K if the jump condition is met. #### These instructions are: | 030 | Branch to K if $(Xj) = 0$ | ZR Xj, K | |-----|-------------------------------------|--------------| | 031 | Branch to K if $(Xj) \neq 0$ | NZ Xj, K | | 032 | Branch to K if (Xj) is positive | PL Xj, K | | 033 | Branch to K if (Xj) is negative | NG Xj, K | | 034 | Branch to K if (Xj) is in range | IR Xj, K | | 035 | Branch to K if (Xj) is out of range | OR Xj, K | | 036 | Branch to K if (Xj) is definite | DF Xj, K | | 037 | Branch to K if (Xj) is indefinite | ID Xj, K | | 04 | Branch to K if (Bi) = (Bj) | EQ Bi, Bj, K | | 05 | Branch to K if (Bi) # (Bj) | NE Bi, Bj, K | | 06 | Branch to K if (Bi) $\geq$ (Bj) | GE Bi, Bj, K | | 07 | Branch to K if (Bi) < (Bj) | LT Bi, Bj, K | ## Return Jump Sequence The return jump sequence controls the execution of three instructions. | 00 | Error exit to MA or program stop | PS | |-----|------------------------------------------------------------------------|-----------| | 010 | Return jump to K | rj k | | 013 | Central exchange jump<br>to (Bj) + K or monitor<br>exchange jump to MA | XI Ri + K | ## REGISTERS The CP contains the operating and support registers described in the following paragraphs. For the model 835, these registers are located in the registers section (refer to figure 1-9). For the models 840, 845, 850, 855, and 860, these registers are located in the operand issue section (refer to figure 1-10). For the model 990, these registers are located in the register unit and process state registers sections (refer to figure 1-11). The contents of these registers can be written into memory and reloaded from memory as a CYBER 170 exchange package by a single CP instruction (CYBER 170 exchange jump). Figure 2-1 shows the CYBER 170 exchange package. The time a CYBER 170 exchange package resides in CP hardware is called an execution interval. During this interval, the contents of X, A, B, and P registers can be changed by CP instructions. The contents of other support registers change only as a result of a CYBER 170 exchange jump. For further information, refer to CYBER 170 Exchange Jump in section 5. ## **Operating Registers** The operating registers consist of operand (X), address (A), and index (B) registers. These registers minimize memory references for arithmetic operands and results. ## X Registers The CP contains eight 60-bit X registers, X0 through X7. The X0 register is used in the compare instructions to indicate if two fields of characters are equal. Also, the X0 register provides the relative UEM starting address in a block copy operation. The XI through X7 registers are primarily data handling registers for computation. XI through X5 are used to input data from CM and X6 and X7 are used to transmit data to CM. Operands and results transfer between CM and the X registers as a result of placing CM addresses into corresponding A registers. #### A Registers The CP contains eight 18-bit A registers, A0 through A7. The A0 register serves as an intermediate register for the user's discretion. The A0 register is used in the compare collate instruction for the collate table address. Also, the A0 register provides the relative CM starting address in a block copy operation. The Al through A7 registers are essentially CM operand address registers associated one-for-one with the X registers. Placing a quantity into an address register (Al through A5) causes a CM read reference to that address and transmits the CM word to the corresponding X register (Xl through X5). Similarly, placing a quantity into the A6 or A7 register causes the word in the corresponding X6 or X7 register to be written into that relative address of CM. #### B Registers The CP contains eight 18-bit B registers, BO through B7. These registers are primarily indexing registers to control program execution. Program loop counts may also be incremented or decremented in these registers. Program addresses may be modified on the way to an A register by adding or subtracting B register quantities. The B registers also hold shift counts for the nominal Bj shifts, the resultant exponent for the unpack, the operand exponent for the pack, and the resultant shift count from a normalize. The BO register always contains positive zero which can be used as an operand. This register cannot hold results from instructions. #### **Support Registers** Eight support registers assist the operating registers during the execution of programs. The contents of the support registers are stored in CM, and their new contents are loaded from CM during a CYBER 170 exchange sequence. With the exception of the P register, the contents of the support Figure 2-1. CYBER 170 Exchange Package registers cannot be altered during the execution interval of a CYBER 170 exchange package. When the execution interval completes, the data in the support registers is sent back to CM through a CYBER 170 exchange jump. ## P Register The 18-bit program address (P) register loads from CM during the first word of a CYBER 170 exchange sequence and contains the current program execution address. The register serves as a program address counter and holds the relative CM address for each program step. ## **RAC Register** The 21-bit CM reference address (RAC) register loads from CM during the second word of a CYBER 170 exchange sequence. An absolute CM address forms by adding RAC to a relative address determined by the instruction. The content of the P register is added to RAC to form the program address in CM. A P-equal-to-zero condition specifies relative address zero and, therefore, (RAC). This CM location is reserved for recording error exit conditions and should not be used to store data or instructions. #### FLC Register The 21-bit CM field length (FLC) register loads from CM during the third word of a CYBER 170 exchange sequence. The FLC register defines the size of the field of the program in execution. Relative CM addresses are compared with FLC to check that the program is not going out of its allocated memory range. #### EM Register The 6-bit exit mode (EM) register loads from CM during the fourth word of a CYBER 170 exchange sequence. The EM register holds 6 exit mode selection bits that control individual error conditions for a program. Selected EM register bits cause the CP to error exit when the corresponding conditions occur. Any or all of the 6 bits can be set at one time. Clear EM register bits allow the CP to continue, without error processing, when most of the corresponding conditions occur. Refer to the error exit tables under Error Response in section 5 for specific cases. The exit mode selection bits appear in the exchange package as bits 48 through 50, and 57 through 59. The bits and their corresponding conditions are: | Mode<br>Selection | 01-151 | |-------------------|----------------------| | Bit | Significance | | 48 | Address out of range | | 49 | Infinite operand | | 50 | Indefinite operand | | Mode<br>Selection<br>Bit | Significance | |--------------------------|----------------| | 57 | Hardware error | | 58 | Hardware error | | 59 | Hardware error | #### Flag Register The 6-bit flag register loads from CM during the fourth word of a CYBER 170 exchange sequence. The flag register holds 6 bits that function as control flags. | -6 | | |------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bits | Condition | | 51 | Hardware error bit. | | 52 | Instruction stack (lookahead) purge flag. It set, extended purging of instruction lookahead registers is enabled. For further information, refer to Instruction Lookahead Purge Control under CP Programming in section 5. | | 53 | CMU interrupted flag. If set, one of instructions 464 through 467 has been interrupted. The information necessary to resume operation has been saved. | | 54 | Block copy flag. If set, block copy instructions (011, 012) use bits 30 through 50 of XO rather than AO to determine the CM address. For further information, refer to the descriptions of the block copy instructions in section 4. | | 55 | Expanded addressing select flag. If set, UEM is operating in expanded addressing mode; if clear, UEM is operating in 24-bit standard addressing mode. This bit must be clear on the model 835. For further information, refer to Addressing Modes under Memory Programming in section 5. | | 56 | UEM enable flag. If set, UEM is available. This flag must be set to allow 011, 012, 014, and 015 instructions to access UEM. | ## RAE Register The 21-bit UEM reference address (RAE) register loads from CM during the fifth word of a CYBER 170 exchange sequence. The lower 6 bits of this register are always zero. An absolute UEM address forms by adding RAE to the relative address which is determined by the instruction. #### FLE Register The 24-bit UEM field length (FLE) register loads from CM during the sixth word of a CYBER 170 exchange sequence. The lower 6 bits of this register are always zero. The FLE register defines the size of the field in UEM for the program in execution. Relative UEM addresses are compared with FLE. #### MA Register The 18-bit monitor address (MA) register loads from CM during the seventh word of a CYBER 170 exchange sequence. The MA register contains the absolute starting address of an exchange package which is used when executing a central exchange jump (013) instruction with the CYBER 170 monitor flag clear, or when honoring a monitor exchange jump to MA (262x) instruction with the CYBER 170 monitor flag clear. For further information, refer to CYBER 170 Exchange Jump in section 5. #### **EXECUTION SECTION** The execution section combines the operands into results, providing additional sequencing control where necessary. ## CACHE MEMORY Cache memory is a high-speed buffer memory which is transparent to the user. It reduces effective ${\tt CM}$ access time by eliminating unnecessary references. When the CP first reads CM, a block of four words from CM (containing the requested word) is read rapidly into cache memory. For model's 835 through 860, these words may be instructions or data. For model 990, these words include all data except instructions. On subsequent reading of any of these words, CM need not be accessed when these words are in cache memory. Often this is the case because the same data is read more than once, or because a loop of instructions is repeatedly executed. Cache memory for the models 835 through 860 is 2048 words or, optionally, 4096 words. Cache memory for the model 990 is 4096 words. #### ADDRESSING SECTION An address adder calculates memory addresses for data and unconditional jump instructions. Memory management hardware verifies that memory addresses are to access permitted memory areas. If this is the case, this hardware accesses cache memory and, if necessary, central memory. ## **CENTRAL MEMORY CONTROL (MODELS 840 THROUGH 990)** Central memory control (CMC) provides an interface to CM for the CP and IOU. On models 840 through 990, it is physically located in the CP cabinet. CMC includes: - Ports and distributor. - SECDED logic. - Partial-write logic. - Memory control logic. - Maintenance registers. ## **CENTRAL MEMORY** The CM performs the following functions. - For the models 835, 845, and 855, without the Memory Upgrade Option, eight memory banks store from 524K to 2097K of 64-bit words (the leftmost 4 bits are undefined) and an 8-bit SECDED code. - For the models 845 and 855, with the Memory Upgrade Option, and the models 840, 850, and 860, eight memory banks store from 2097K to 16 776K of 64-bit words (the leftmost 4 bits are undefined) and an 8-bit SECDED code. - For the model 990, 32 memory banks store from 1048K to 4192K of 64-bit words (the leftmost 4 bits are undefined) and an 8-bit SECDED code. - The two ports make CM accessible to the CP and every PP. - A bounds register limits access to CM from either or both ports. - The SECDED generators generate the SECDED code bits stored with each word. SECDED checks circuits, corrects single-bit errors, and detects double-bit errors. - The maintenance channel interface gives a PP in the IOU access to the CM maintenance registers for system initialization, corrective action, error reporting and diagnostics, and for setting the port bounds register. # ADDRESS FORMAT (MODELS 835, 845, AND 855 WITHOUT THE MEMORY UPGRADE OPTION) Figure 2-2 illustrates the address format for the models 835, 845, and 855 (without the Memory Upgrade Option). Figure 2-2. Address Format (Models 835, 845, and 855 without the Memory Upgrade Option) The following list defines the address fields for figure 2-2. - Bank select specifies one of eight banks. Since the bank address is the lowest order 3 bits of the storage address, sequential addressing results in a phased-bank operation which allows a maximum data transfer rate of one word each clock period. - Chip address specifies the address of one word in 16K MOS memory chips for the selected bank. - Row select selects one of four word rows in a quadrant. - Quadrant select selects one of four quadrants. It is used only for storage units larger than 524K. # ADDRESS FORMAT (MODELS 845 AND 855, WITH THE MEMORY UPGRADE OPTION, AND MODELS 840, 850, AND 860) Figure 2-3 illustrates the address format for the models 850 and 860. Figure 2-3. Address Format (Models 840, 850, and 860) The following list defines the address fields for figure 2-3. - Quadrant select specifies one of four quadrants (array packs) within a bank. - Chip select, if set, enables the row address select to the upper half (720) of the 144 chips on memory boards in all eight memory banks. If clear, enables the lower half of the 144 chips on memory boards in all eight banks. - Chip address, which comprises column address select and row address select, specifies the address of one word on a chip for the selected bank and quadrant. - Row address select specifies the row-select portion of the chip address on a chip. - Column address select specifies the columnselect portion of the chip address on a chip. - Bank select specifies one of eight banks. #### **ADDRESS FORMAT (MODEL 990)** Figure 2-4 illustrates the address format for the model 990. Figure 2-4. Address Format (Model 990) The following list defines the address fields for figure 2-4. - Column select specifies one of two columns. - Row select specifies one of four word rows in a bank. (Each word row corresponds to a set of chips in a bank.) - Chip address specifies the address of one word in 16K bipolar memory chips for the selected bank. - Bank select specifies one of eight banks in a cage. - Cage select specifies one of four cages in a column. (The cage number in a column corresponds to the distributor number in central memory control.) ## **CM ACCESS AND CYCLE TIMES** The following paragraphs list CM access and cycle times for models 835 through 990. The models 835, 845, and 855 CM, without the Memory Upgrade Option, operate on an internal clock period of 64 nanoseconds (major cycle). The models 845 and 855, with the Memory Upgrade Option, and the models 840, 850, and 860 CM operate on an internal clock period of 32 nanoseconds (minor cycle). The model 990 CM operates on an internal clock period of 16 nanoseconds. #### Model 835 The CM access time for a read operation is 672 nanoseconds. One bank cycle is 8 clock periods (448 nanoseconds). Cycle time for a read or write operation is 448 nanoseconds (8 clock periods). Cycle time for a partial write (read/modify/write) is 896 nanoseconds (16 clock periods). The CM access time for a read operation is 384 nanoseconds (6 clock periods or major cycles). One bank cycle for a read or write operation is 448 nanoseconds (7 clock periods or major cycles). Cycle time for a partial write (read/modify/write) is 896 nanoseconds (14 clock periods or major cycles). # Models 845 and 855, With the Memory Upgrade Option, and Models 840, 850, and 860 The CM access time for a read operation is 320 nanoseconds (10 minor clock periods or 5 major cycles). One bank cycle for a read or write operation is 384 nanoseconds (12 minor clock periods or 6 major cycles). Cycle time for a partial write (read/modify/write) is 768 nanoseconds (24 minor clock periods or 12 major cycles). #### Model 990 The CM access time for a single-word read operation is 208 nanoseconds (13 clock periods). The CM access time for a four-word block read is 256 nanoseconds (10 clock periods). Cycle time for a normal read or write operation is 64 nanoseconds (4 clock periods). Cycle time for a partial write, read/set/clear/lock, and exchange is 192 nanoseconds (12 clock periods). ## **CM PORTS AND PRIORITIES** A priority network resolves access conflicts on a rotating basis, preventing long-term lockout of any port. In case of simultaneous requests, the CP has priority. The models 835, 840, 845, 850, 855, and 860 CM also have a refresh mechanism which may consume a maximum of 6 percent (model 835), 7 percent (models 845 and 855, without the Memory Upgrade Option), and 4 percent (models 845 and 855, with the Memory Upgrade Option, and models 845 and 855, and 860) of memory time. Refresh requests have priority over port requests. Refer to table 2-1 for maximum request lockout time. | Maximum Request Lockout Time in Bank Cycles | | | | | | | | | | | | |---------------------------------------------|------------------------|--|--|--|--|--|--|--|--|--|--| | Port | Read or Write Requests | | | | | | | | | | | | Refresh<br>Port O | 1<br>4 | | | | | | | | | | | | Port 1 | 5 | | | | | | | | | | | NOTE: For a model 835, 1 bank cycle equals 8 clock periods which equals 448 nanoseconds. For models 845 and 855, without the Memory Upgrade Option, 1 bank cycle equals 7 clock periods which equals 448 nanoseconds. For models 845 and 855, with the Memory Upgrade Option, and models 840, 850, and 860, 1 bank cycle equals 5 clock periods which equals 384 nanoseconds. For the model 990, 1 bank cycle equals 4 clock periods which equals 64 nanoseconds. ## **SECDED** The SECDED logic corrects single-bit errors during a CM read, permitting unimpeded computer operation. The SECDED logic prepares for the error correction by generating error correction code (ECC) bits for each data word, and by storing these ECC bits in CM with the data word during the CM write. Tables 2-2 (model 835), 2-3 (models 840 and 860), and 2-4 (model 990) list the hexadecimal codes for all the combinations of syndrome bits with the number of the data bit assigned each code or a note categorizing the code. Then, during a CM read, CM performs the following SECDED sequence. - Read one CM word and generate new ECC bits for data portion of CM word. - 2. Compare new ECC bits with CM word ECC bits. - If old and new ECC bits match, no error exists. Send data to requesting unit. - If bits do not match, generate syndrome bits from result of ECC compare. - Decode syndrome bits to determine if single or multiple bit failure. - If single bit failure, correct by inverting failing bit in data word. Send corrected word to requesting unit. - 7. If multiple bit or other uncorrectable error, send uncorrectable error response code to CP or IOU. A PP in the IOU may then analyze the syndrome bits using the maintenance channel. #### **CM LAYOUT** Central memory contains an area that is reserved for special software called Virtual State software. Along with the hardware and microcode, this software handles the operations of Virtual State as described in section 5. Virtual State software is located at the higher end of memory. The remaining memory is available to the CYBER 170 State and may be allocated as central memory (accessible via RAC and FLC) or as unified extended memory (accessible via RAE, FLE, and the 011, 012, 014, and 015 instructions). Refer to figure 2-5. Figure 2-5. CM Layout ## **CM BOUNDS REGISTER** The CM bounds register limits the write access to CM from specified ports. The ports are limited to the area between an upper and lower bound as specified in the CM bounds register. Bits in byte 0 specify the port(s) from which the write access is limited. The CM bounds register is set through the maintenance channel. For further information, refer to Maintenance Channel Programming in section 5. #### **CENTRAL MEMORY RECONFIGURATION** Central memory reconfiguration is a manually performed function that permits the computer operator to restructure the CM addresses so that a failing part of CM can be quickly locked out to provide a continuous block of usable CM. CM reconfiguration is accomplished by setting the switches on the memory unit to manipulate the upper address bits. When a configuration switch is set forcing a CM address bit to a zero/one, the address range corresponding to the original installed memory accesses some parts of the reconfigured memory more than once. Addresses up to the rightmost forced bit, and half the addresses using the rightmost forced bit, cover a contiguous address space from location zero, which is the reconfigured memory. For further information, refer to section 3. Table 2-2. Model 835 SECDED Syndrome Codes/Corrected Bits | Code | Bit | |------|-------------|------|------|------|------------|------------|---------------|------|--------|------|-----------|-----------|-----------|------|-------|------| | 00 | 7 | 20 | 66 ② | 40 | 65② | 60 | (3 | 80 | 64② | A0 | 3 | CO | 0/1 6 | EO | 32 | 1 | | 01 | 71 ② | 21 | 3 | 41 | 3 | 61 | 4 | 81 | 3 | A1 | 4 | C1 | <b>(</b> | El | 32 | (3) | | 02 | 70 ② | 22 | 3 | 42 | 3 | 62 | 4 | 82 | 3 | A2 | 4 | C2 | 4 | E2 | 36 | (3) | | 03 | 6/76 | 23 | 4 | 43 | 4 | 63 | 3 | 83 | 4 | A3 | 3 | С3 | 3 | E3 | 36 | 1 | | 04 | 69 ② | 24 | 3 | 44 | 3 | 64 | 4 | 84 | 3 | A4 | 4 | C4 | 4 | E4 | 34 | (3) | | 05 | 3 | 25 | 4 | 45 | 4 | 65 | 3 | 85 | 4 | A5 | 3 | C5 | 3 | E5 | 34 | 1 | | 06 | 3 | 26 | 4 | 46 | 4 | 66 | 3 | 86 | 4 | A6 | 3 | С6 | 3 | E6 | 38 | 1 | | 07 | 24 ① | 27 | 28 ③ | 47 | 26⑤ | 67 | 30 (1 | 87 | 25 (5) | A7 | 29 ① | C7 | 27 ① | E7 | 31/38 | (3) | | 08 | 68 ② | 28 | 3 | 48 | 3 | 68 | 4 | 88 | 3 | A8 | 4 | C8 | 4 | E8 | 33 | ③ | | 09 | 3 | 29 | 4 | 49 | 4 | 69 | 3 | 89 | 4 | A9 | 3 | C9 | 3 | E9 | 33 | 1 | | OA. | .3 | 2A | 4 | 4A | 4 | . 6A | 3 | 8A | 4 | AA | 3 | CA | 3 | EA | 37 | ① | | ОВ | 16 <b>①</b> | 2В | 20 ③ | 4B | 18(5) | 6В | 22 (1 | 8в | 17 (5) | AB | 21 ① | СВ | 19 ① | ЕВ | 23/37 | (3) | | oc | 4/5⑥ | 2C | 4 | 4C | 4 | 6C | 3 | 8C | 4 | AC | 3 | ·cc | 3 | EC | 35 | 1 | | OD | 8 ① | 2D | 12 ③ | 4D | 10 (5) | 6D | 14 (1 | 8D | 9 (5) | AD | 13 (Î) | CD | 11 ① | ED | 15/35 | ·(S) | | 0E | 0 (L) | 2E | 4 ⑤ | 4E | 2 (5) | 6E | 6 (1 | 8E | 1 (5) | AE | 5 ① | CE | 3 ① | EE | 7/39 | ③ | | OF | 3 | 2F | 4 | 4F | 4 | 6F | 3 | 8F | 4 | AF | 3 | CF | 3 | EF | 39 | ① | | 10 | 67 ② | 30 | 2/36 | 50 | 3 | 70 | 56 ① | 90 | 3 | во | 48 ① | DO . | 40 ① | FO - | | 3 | | 11 | 3 | 31 | 4 | 51 | 4 | 71 | 56 (5 | 91 | 4 | B1 | 48 ⑤ | D1 | 40 ⑤ | F1 | | 4 | | 12 | 3 | 32 | 4 | 52 | <b>(4)</b> | 72 | 60 <u>(</u> 5 | 92 | (4) | В2 | 52 ⑤ | D2 | 44 ⑤ | F2 | | 4 | | 13 | 4 | 33 | 3 | 53 | 3 | 73 | 60 (I | H . | 3 | В3 | 52 ① | D3 | 44 ① | F3 | | 3 | | 14 | 3 | 34 | 4 | 54 | 4 | 74 | 58 (5 | 94. | 4 | В4 | 50 ③ | D4 | 42 ③ | F4 | | 4 | | 15 | 4 | 35 | 3 | 55 | 3 | 75 | 58 (1 | 95 | 3 | В5 | 50 ① | D5 | 42 ① | F5 | | 3 | | 16 | 4 | 36 | 3 | 56 | 3 | 7,6 | 62 (1 | 96 | 3 | В6 | 54 ① | D6 | 46 (I) | F6 | | 3 | | 17 | 24 ⑤ | 37 | 28 ① | 57 | 26① | 77 | 30/62(5 | 97 . | 25 ① | В7 | 29/54 (5) | D7 | 27/46 (5) | F7 | | 3 | | 18 | 3 | 38 | 4 | 58 | 4 | 78 | 57 (3 | 98 | 4 | В8 | 49 ③ | D8 | 41 (5) | F8 | | 4 | | 19 | 4 | 39 | 3 | 59 | 3 | 79 | 57 ① | 99 | 3 | В9 | 49 ① | D9 | 41 ① | F9 | | 3 | | 1A | 4 | - 3A | 3 | 5A | 3 | 7A | 61 (1 | 9A | 3 | ВА | 53 ① | DA | 45 ① | FA | | 3 | | 1B | 16 ⑤ | 3В | 20 ① | | 18① | 7B | 22/61 (5 | 1 | 17 ① | ВВ | 21/534 | i | 19/45 (5) | FB | 23 | 1 | | 10 | 4 | 3C | 3 | | 3 | 7C | 59 (1 | 1 | 3 | ВС | 51 ① | 4 | 43 ① | 1 | | 3 | | 1D | 8 ⑤ | 3D | 12 ① | 1 | 10 ① | 7D | 14/59(5 | 1 | 9 ① | BD | 13/51 (5) | <b>!!</b> | 11/43(5) | ii . | 15 | 1 | | 1E | 0 ③ | 3E | 4 ① | 5E | 2 ① | 7E | 6/63 (5 | 1 | 1 (1) | ВЕ | 5/55 ③ | 1 | 3/47 (5) | FE | 7 | 1 | | 1F | 4 | 3F | 3 | 5F | 3 | 7 <b>F</b> | 63 <u>(</u> | 9F | 3 | BF | 55 ① | DF | 47 ① | FF | | 3 | ## Notes: - Corrected single-bit error. Syndrome code bit failed (single code bit set). Double error or multiple error (even number of code bits set). Multiple error reported as a single error. Double error or multiple error with indicated bit(s) inverted. Double error or multiple error or forced double error due to a partial write parity error on one of the two buts. the two bytes. - 7 No error detected. Table 2-3. Models 840, 845, 850, 855, and 860 SECDED Syndrome Codes/Corrected Bits | Code | Bit | Code | Bit | Code | Bit | Code | В | it | Code | Bit | Code | В | it | Code | В | it | Code Bit | | it | |------|------------|----------|---------------|----------|------------|----------|----|------------|----------|-------------------------------|------------|------------|--------|----------|-----|----------|----------|----|--------------| | 00 | 6 | 20 | 66 ② | 40 | 65② | 60 | | 3 | 80 | 64② | <b>A</b> 0 | | 3 | C0 | 0/1 | (3) | E0 | 32 | 1 | | 01 | 71 ② | 21 | 3 | 41 | 3 | 61 | | 4 | 81 | 3 | Al | | 4 | Cl | | 4 | El | | (5) | | 02 | 70 ② | 22 | 3 | 42 | 3 | 62 | | 4 | 82 | 3 | A2 | | 4 | C2 | | 4 | E2 | | (5) | | 03 | 6/7 ⑤ | 23 | 4 | 43 | 4 | 63 | | 3 | 83 | 4 | A3 | | 3 | СЗ | | 3 | E3 | 36 | 1 | | 04 | 69 ② | 24 | 3 | 44 | 3 | 64 | | 4 | 84 | 3 | A4 | | 4 | C4 | | 4 | . E4 | | (5) | | 05 | 3 | 25 | 4 | 45 | 4 | 65 | | 3 | 85 | <b>④</b> | <b>A</b> 5 | | 3 | C5 | | 3 | E5 | 34 | 1 | | 06 | 3 | 26 | 4 | 46 | 4 | 66 | | 3 | 86 | 4 | A6 | | 3 | С6 | | 3 | E6 | 38 | 1 | | 07 | 24 ① | 27 | 3 | 47 | 3 | 67 | 30 | 1 | 87 | ⑤ | A7 | 29 | 1 | C7 | 27 | 1 | E7 | | (5) | | 08 | 68 ② | 28 | 3 | 48 | 3 | 68 | | 4 | 88 | 3 | A8 | | 4 | С8 | | 4 | E8 | | (3) | | 09 | 3 | 29 | 4 | 49 | 4 | 69 | | 3 | 89 | 4 | А9 | | 3 | С9 | | 3 | E9 | 33 | 1 | | 0A | 3 | 2A | 4 | 4A | 4 | 6A | | 3 | 8A | 4 | AA | | 3 | CA | | 3 | EA | 37 | 1 | | 0в | 16 ① | 2В | (3) | 4B | (3) | 6В | 22 | 1 | 8в | (5) | AB | 21 | 1 | СВ | 19 | 1 | ЕВ | | (3) | | 0C | 4/5③ | 2C | (4) | 4C | 4 | 6C | | 3 | 8C | 4 | AC | | 3 | cc | | 3 | EC | 35 | 1 | | OD | 8 ① | 2D | 3 | 4D | 10③ | 6D | 14 | 0 | 8D | (3) | AD | 13 | 1 | СД | 11 | 1 | ED | | <b>⑤</b> | | 0E | 0 (1) | 2E | 4 ③ | 4E | 3 | 6E | 6 | ① | 8E | (5) | AE | 5 | 0 | CE | 3 | 1 | EE | | <b>③</b> | | OF | 3 | 2F | 4 | 4F | <b>④</b> | 6F | | 3 | 8F | <b>④</b> | AF | | 3 | CF | | 3 | EF | 39 | ① | | 10 | 67 ② | 30 | 2/3⑤ | 50 | 3 | 70 | 56 | ① | 90 | 3 | В0 | 48 | 1 | DO | 40 | 1 | F0 | | 3 | | 11 | 3 | 31 | <b>④</b> | 51 | <b>(4)</b> | 71 | | (5) | 91 | <b>(4)</b> | Bl | | (3) | D1 | | (3) | F1 | | <b>4</b> | | 12 | 3 | 32 | <b>④</b> | 52 | (4) | 72 | | (3) | 92 | <b>(4)</b> | B2 | | (3) | D2 | ,, | (S) | F2 | | <b>4</b> | | 13 | <b>(4)</b> | 33 | 3 | 53 | 3 | 73 | 60 | ① | 93 | 3 | B3 | 52 | 1 | D3 | 44 | 1 | F3 | | 3 | | 14 | ③<br>④ | 34<br>35 | <b>④</b> | 54 | <b>4</b> | 74 | 58 | (S) | 94<br>95 | <ul><li>4</li><li>3</li></ul> | B4<br>B5 | 50 | (3) | D4<br>D5 | 42 | (3) | F4 | | <b>4</b> | | 16 | 4 | 36 | ③<br>③ | 55<br>56 | 3 | 75<br>76 | 62 | ①<br>① | 96 | 3 | В6 | 54 | ① | D6 | 46 | 1 | F5 | | 3 | | 17 | (5) | 37 | 28 ① | 57 | 26① | 76<br>77 | 02 | (1)<br>(3) | 96 | 25 ① | В7 | <i>)</i> 4 | ①<br>⑤ | D7 | 40 | (I) | F6<br>F7 | 31 | ③<br>① | | 18 | 3 | 38 | 28 (J)<br>(4) | 58 | 4 | 78 | | 3 | 98 | 4 | B8 | | 3 | D8 | | 3 | F8 | 71 | ( <u>1</u> ) | | 19 | 4 | 39 | 3 | 59 | 3 | 79 | 57 | 1 | 99 | 3 | В9 | 49 | 1 | D9 | 41 | 1 | F9 | | 3 | | 1A | 4 | 3A | 3 | 5A | 3 | 7A | 61 | 1 | 9A | 3 | BA | 53 | 1 | DA | 45 | 1 | FA | | 3 | | 1В | <u>⑤</u> | 3B | 20 ① | 5B | 18① | 7B | | (5) | 9B | 17 ① | ВВ | | (3) | DB | | (3) | FB | 23 | 1 | | 1C | <b>4</b> | 3C | 3 | 5C | 3 | 7C | 59 | 1 | 9C | 3 | вс | 51 | 1 | DC | 43 | 1 | FC | | 3 | | 1D | <u> </u> | 3D | 12 ① | 5D | 10① | 7D | | 3 | 9D | 9 (Î) | BD | | 3 | DD | _ | <b>⑤</b> | FD | 15 | 1 | | 1E | <u> </u> | 3E | 4 ① | 5E | 2 ① | 7E | | 3 | 9E | 1 (1) | BE | | 3 | DE | | 3 | FE | 7 | ① | | 1F | <u>(4)</u> | 3F | 3 | 5F | 3 | 7F | 63 | 1 | 9F | 3 | BF | . 55 | 1 | DF | 47 | 1 | FF | | 3 | | i | | | | | | | | | | Ĭ | | | | | | Ĭ | | | | ## Notes: - Syndrome code bit failed (single code bit set). - Double error or multiple error (even number of code bits set). - (1) Corrected single-bit error. (2) Syndrome code bit failed (si (3) Double error or multiple err (4) Multiple error reported as a (5) Double error or multiple error Multiple error reported as a single error. Double error or multiple error or forced double error due to a partial write parity error on one of the two bytes indicated. - 6 No error detected. Table 2-4. Model 990 SECDED Syndrome Codes/Corrected Bits | | Code | Bit | Code | Bit | Code | Bit | Code | Bi | t | Code | Bit | Code | Bit | | Code | Bi | t | Code | Bit | | |----------|------|-------------|------|----------------|------------|-------------|------|----|------------|------|----------|---------|----------|------------|------|-----|------------|---------|-----|------------| | | 00 | (3) | 20 | 66 <b>①</b> | 40 | 65 <b>①</b> | 60 | | 2 | 80 | 64 ① | A0 | 1 | 2 | CO | 0/1 | (4) | EO | 32 | ⊗ | | | 01 | 71 ① | 21 | 2 | 41 | 0 | 61 | | 3 | 81 | 2 | Al | | <b>9</b> | Cl | | 3 | El | | 4 | | | 02 | 70 <b>①</b> | 22 | 2 | 42 | 2 | 62 | | 3 | 82 | 2 | A2 | | 9 | C2 | | 3 | E2 | | 4 | | | 03 | 6/7 4 | 23 | 3 | 43 | 3 | 63 | | 0 | 83 | 3 | A3 | ( | | C3 | | 2 | E3 | 36 | ⊗. | | | 04 | 69 <b>(</b> | 24 | 2 | 44 | 2 | 64 | | 3 | 84 | 2 | A4 | | <b>9</b> | C4 | | 3 | E4 | | 4 | | | 05 | 2 | 25 | 3 | 45 | 3 | 65 | | 2 | 85 | 3 | A5 | | | C5 | | 2 | E5 | 34 | ⊗ | | | 06 | 2 | 26 | 3 | 46 | 3 | 66 | | @ | 86 | 3 | A6 | ( | ) C | C6 | | 2 | E6 | 38 | ⊗ | | | 07 | 24 🔇 | 27 | (4) | 47 | • | 67 | 30 | (8) | 87 | <b>(</b> | A7 | 29 ( | 0 | C7 | 27 | <b>(X)</b> | E7 | | <b>@</b> | | | 08 | 68 <b>①</b> | 28 | 2 | 48 | 2 | 68 | | 3 | 88 | 2 | A8 | . ( | )<br> | C8 | | 3 | E8 | | 4 | | | 09 | 2 | 29 | 3 | 49 | 3 | 69 | | @ | 89 | 3 | А9 | | | С9 | | 2 | E9 | 33 | ⊗ | | | 0A | 2 | 2A | 3 | 4A | 3 | 6A | | @ | 8A | 3 | AA | ( | | CA | | @ | EA | 37 | ⊗ | | | ОВ | 16 🕱 | 2В | 4 | 4B | 4 | 6В | 22 | (X) | 8в | <b>④</b> | АВ | 21 ( | 0 | СВ | 19 | (X) | ЕВ | | 4 | | | 0С | 4/54 | 2C | 3 | 4C | 3 | 6C | | 2 | 8C | 3 | AC | ( | 2 | СС | | 2 | EC | 35 | ⊗ | | | OD | 8 🕸 | 2D | (4) | 4D | 10 4 | 6D | 14 | ⊗ | 8D | 4 | AD | 13 ( | 0 | CD | 11 | (X) | ED | | 4 | | | 0E | 0 ⊗ | 2E | (4) | 4E | <b>(</b> | 6E | 6 | <b>(X)</b> | 8E | 4 | AE | 5 ( | <b>D</b> | CE | 3 | (X) | EE | | 4 | | | OF | 2 | 2F | 3 | 4F | 3 | 6F | | 2 | 8F | 3 | AF | ( | <b>⊅</b> ∥ | CF | | 2 | EF | 39 | ⊗ | | | 10 | 67 <b>①</b> | 30 | 2/34 | 50 | 2 | 70 | 56 | ⊗ | 90 | 2 | ВQ | 48 ( | 0 | DO | 40 | (X) | F0 | | 2 | | | 11 | 2 | 31 | 3 | 51 | 3 | 71 | | 4 | 91 | 3 | В1 | | Ð | D1 | | 4 | Fl | | 3 | | | 12 | 2 | 32 | 3 | 52 | 3 | 72 | | 4 | 92 | 3 | В2 | | Ð | D2 | | 4 | F2 | | 3 | | | 13 | 3 | 33 | 2 | 53 | 2 | 73 | 60 | ⊗ | 93 | 2 | В3 | 52 ( | 0 | D3 | 44 | <b>(X)</b> | F3 | | 2 | | | 14 | 2 | 34 | 3 | 54 | 3 | 74 | | 4 | 94 | 3 | В4 | ( | Ð | D4 | | 4 | F4 | | 3 | | | 15 | 3 | 35 | 2 | 55 | 2 | 75 | 58 | <b>(X)</b> | 95 | 2 | В5 | 50 ( | 0 | D5 | 42 | <b>(X)</b> | F5 | | 2 | | | 16 | 3 | 36 | 2 | 56 | 2 | 76 | 62 | <b>®</b> | 96 | 2 | В6 | 54 ( | ١٥ | D6 | 46 | (X) | F6 | | 2 | | | 17 | 4 | 37 | 28 X | 57 | 26 🛞 | 77 | | 4 | 97 | 25 🛞 | В7 | ( | ୬∥ | D7 | | 4 | F7 | 31 | <b>(X)</b> | | ; | 18 | 2 | 38 | 3 | 58 | 3 | 78 | | 4 | 98 | 3 | В8 | ( | 0 | D8 | | 4 | F8 | | ③ | | | 19 | 3 | 39 | 2 | 59 | 2 | 79 | 57 | ⊗ | 99 | 2 | В9 | 49 ( | <b>∂</b> | D9 | 41 | (X) | F9 | | 2 | | | 1A | 3 | 3A | 2 | 5A | 2 | 7A | 61 | <b>(X)</b> | 9A | 2 | ВА | 53 ( | 0 | DA | 45 | (X) | FA | | 2 | | | 18 | 4 | 3в | 20 🕸 | 5В | 18 🕱 | 7B | | <b>(4)</b> | 9В | 17 🕲 | ВВ | ( | Ð | DB | *. | 4 | FB | 23 | <b>(X)</b> | | | 10 | 3 | 3C | 2 | 5C | 2 | 7C | 59 | ⊗ | 9C | 2 | вс | 51 ( | <b>∑</b> | DC | 43 | (X) | FC | | 2 | | | 1 D | <b>(</b> | 3D | 12 <b>(X</b> ) | 5D | 10 🕱 | 7 D | | 4 | 9D | 9 🕉 | BD | ( | Ð | DD | | 4 | FD | 15 | <b>(X)</b> | | | 1 E | 4 | 3E | 4 <b>(X</b> ) | 5E | 2 🕱 | 7E | | 4 | 9E | 1 🕸 | ВЕ | ( | Ð | DE | | 4 | FE | 7 | <b>(X)</b> | | | 1 F | 3 | 3F | 2 | 5 <b>F</b> | 2 | 7F | 63 | (X) | 9F | 2 | BF | 55 ( | D | DF | 47 | (X) | FF | | 2 | | $\vdash$ | | L | • | <u> </u> | | | • | · | | · | · | <b></b> | <b>L</b> | | | | | <b></b> | | | ## Notes: - © Corrected single-bit error. ① Syndrome code bit failed (single code bit set). ② Double error or multiple error (even number of code bits set). ③ Multiple error reported as a single error. ④ Double error or multiple error or forced double error due to a partial write parity error on one of the 2 bytes indicated. - 5 No error detected. ## INPUT/OUTPUT UNIT The input/output unit (IOU) performs the functions required to locate, select, and initialize the external devices connected to the system, and controls the transfer of data between a selected device and CM. The IOU also performs system maintenance functions. The IOU contains the following functional areas. - Peripheral processor (PP). - I/O channels. - Real-time clock. - Two-port multiplexer. - Maintenance channel. - CM access. #### **PERIPHERAL PROCESSOR** The basic IOU contains 10 PPs and can be expanded to 20 PPs in 5-PP increments. Each PP is a logically independent computer with its own memory. Each 5-PP group is organized into a multiplexing system which allows the PPs to share common hardware for arithmetic, logical, and I/O operations without losing independence. This multiplexing system comprises five ranks of registers termed a barrel. Each rank contains information related to the instruction being executed by one PP. Each PP can communicate with the CP by issuing a CYBER 170 exchange request to a specific CYBER 170 exchange package associated with the issuing PP. In addition, a PP can also communicate with the CP via CM read and write operations. PPs can communicate with each other over the I/O channels and through CM. Each PP executes programs alone or with other PPs to control data transfers between external devices and CM. These programs are comprised of instructions from the IOU instruction set and respond to requests issued through CM by the operating system. The programs translate generalized operating system requests into control functions for accessing the external devices and may also perform device scheduling and optimization. The programs use PP memory as a buffer for the data transfer between external devices and CM to isolate IOU data transfer from variations in CM transfer rate. ## Deadstart A deadstart sequence allows the IOU to initialize itself. This deadstart sequence is initiated by the DEAD START switch on the deadstart panel (all models except 990) or the DEAD START switch on the system console (model 990, CC634 system console, uses Control G Control R to initiate the deadstart sequence). The panel includes controls for assigning any PPM to PPO. For further information, refer to section 3. #### **Barrel and Slot** The barrel consists of the R, A, P, Q, and K registers, each one of which has five ranks 0 through 4. (Refer to figure 2-6.) Information in these registers moves from one rank to the next at a uniform 20-megahertz rate, providing a multiplexed system of five PPs, each operating at a 4-megahertz rate. The registers are stationary while the PPs rotate. For example, rank 4 registers contain PPO, PP1, PP2, PP3, and PP4 in succession, each consuming 50 nanoseconds of the total cycle time of 250 nanoseconds. Since PP memories operate at a slower rate, independent memory with its own address and data registers is provided for each PP. Each time data enters the slot, a portion of the instruction for that data is executed. The slot performs tasks such as arithmetic and logic operations and program address manipulation. Complete execution of an instruction may require the R, A, P, Q, and K register quantities to go more than one trip around the barrel and through the slot. The PPM may be referenced once each time the PP passes around the barrel and through the slot. During its slot time, the PP may also communicate with CM or with any of the I/O channels. #### **PP Registers** #### R Register The 28-bit R register, in conjunction with the A register, forms an absolute CM address for CM read/write instructions. When bit 17 of the A register is set, the absolute CM address is formed by appending six zeros to the lower end of the contents of the R register and adding to the result bits 0 through 16 of the contents of the A register (refer to figure 2-7). ## A Register The 18-bit A register holds one operand for arithmetic, logic, or selected I/O operations. The content of A may be an arithmetic operand, CM address, I/O function, or I/O data word. Various instructions operate on 6, 12, 16, or 18 bits of the A register. When the A register is used as the CM address, parity is generated for transmission with the address to memory control. At deadstart, the A register is set to 10000 (octal). When bit 17 of the A register is clear, the A register is used as the CM address; however, when bit 17 is set, the R register is added to the A register (as described in the R register description) to obtain the absolute CM address for CM read/write instructions. Figure 2-6. Barrel and Slot Figure 2-7. Formation of Absolute CM Address #### P Register (All Models Except 990) The 12-bit P register is the program address register, except during the execution of instructions 61, 63, 71, and 73. For these instructions, the P register contains the PPM address of the data transfer. At deadstart, the P register is set to zero. ## P Register (Model 990) The P register operates in two different modes. In 4K PPM mode, P is a 12-bit register and in 8K PPM mode, P is a 16-bit register. In 8K mode, the PP memory uses only the least significant 13 bits. The P register is the program address register, except during the execution of instructions 61, 63, 71, and 73. For these instructions, the P register contains the PPM address of the data transfer. At deadstart, the P register is set to zero. #### Q Register (All Models Except 990) The 12-bit Q register holds data for several functions such as the address of the operand during direct addressing and indirect addressing, peripheral address of data used during one-word central read or write instructions, upper 6 bits during constant mode instructions, channel number on all I/O and channel instructions, shift count, and relative jump designator. At deadstart, each rank of the Q register is set to a corresponding PP number. Rank O is set to PPO, rank 2 is set to PP2, and so on. ## Q Register (Model 990) The Q register operates in two different modes. In 4K PPM mode, Q is a 12-bit register and in 8K PPM mode, Q is a 16-bit register. In 8K mode, the PP memory uses only the least significant 13 bits. The Q register holds data for several functions such as the address of the operand during direct addressing and indirect addressing, peripheral address of data used during one-word central read or write instructions, upper 6 bits during constant mode instructions, channel number on all I/O and channel instructions, shift count, and relative jump designator. At deadstart, each rank of the Q register is set to a corresponding PP number. Rank O is set to PPO, rank 2 is set to PP2, and so on. #### K Register The 12-bit K-register is visible to the programmer through the maintenance channel only. This register holds the operation code field of an instruction for display on the IOU deadstart panel and for deadstart panel interrogation. When a PP is halted (idled), this register contains all ones. #### PP Numbering PPs are numbered as follows: | Barrel | PPs | |--------|------------------| | 0 | 00 to 04 | | 1 | 05 to 11 (octal) | | 2 | 20 to 24 (octal) | | 3 | 25 to 31 (octal) | The deadstart sequence is used to determine PP numbering within a barrel. The sequence assigns barrel numbers according to the switch settings and, during the first minor cycle after deadstart, loads a zero into the Q register in barrel 0. This defines all the data in that rank of the barrel as belonging to PPO and since Q is the channel selector, assigns PPO to channel 0. During the next minor cycle, Q loads with a 1. This defines PPI and assigns it to channel 1. This process occurs in parallel in all barrels until the IOU assigns each rank of each barrel with a PP number and a channel number. Reassignment can be done only during a deadstart. #### **PP Memory** Each PP has an independent 4K word memory (all models except 990), or 4K or 8K word memory (model 990); each word contains 16 data bits with the upper 4 bits set to zero, and 1 parity bit. PPO executes the deadstart program from the deadstart panel (all models except 990), or from the system console (model 990) during the deadstart operation. Therefore, PP memory 0 must be operational. A PP memory reconfiguration feature allows the user to restore IOU operation if the IOU detects a fault in the PP memory normally assigned to PPO. To reconfigure, the operator assigns a good PP memory to PPO and the operating system removes the failing PP memory. Computer operation can continue without the failing PP memory, and repairs can be made during scheduled maintenance. The system must be deadstarted to reconfigure PPMs. #### I/O CHANNELS The I/O channels are comprised of an internal interface that allows common hardware and software to control the external devices, and an external interface that allows the IOU to communicate with the external devices using 12-bit data channels. The internal interface can transfer 16-bit data words between two PPs, or between a PP and an external device at a maximum rate of one word every 250 nanoseconds. This rate can be sustained for the maximum practical channel transfer (4096 words). During transfers between PPs, if the PPs are in the slot at the same time, the transfer rate is 500 nanoseconds. Any PP can access any of the CYBER 170 bidirectional I/O channels. All PPs communicate with external devices through the independent I/O channels. Each channel may be connected to one or more pieces of external equipment, but only one piece of equipment can use a channel at one time. All channels can be active simultaneously. The display station controller (DSC) is attached to CYBER 170 channel 10g. The DSC is the IOU interface between the PPs and the system console, servicing both the keyboard and the cathode-ray tube (CRT). It transmits function words and digital symbol size/position data to the system console, and receives digital character codes from the keyboard. It also receives digital symbol codes from the PPs and converts these to analog signals to the CRT. #### **REAL-TIME CLOCK** The real-time clock is a l2-bit free-running counter, incrementing at a l-megahertz rate. It is permanently attached to channel 148. This channel may be read at any time as its active and full flags are always set. ## TWO-PORT MULTIPLEXER The two-port multiplexer provides communication capability between a PP and two attached terminals. One port is reserved for maintenance purposes and the other port is reserved for future use. The two-port multiplexer is permanently attached to channel 158. #### **MAINTENANCE CHANNEL** The maintenance channel is used for initialization of the CP and CM maintenance registers and monitoring of error status. The maintenance channel consists of the maintenance channel interface on channel 178, a maintenance access control in each system element, and a set of interconnecting cables. #### **CENTRAL MEMORY ACCESS** Any PP can access CM. During a write from the IOU to CM, the IOU assembles five successive 12-bit PP words into a 64-bit CM word with the leftmost four bits undefined. During a CM read, the IOU disassembles the rightmost 60 bits of the 64-bit CM word into five PP words. To find the CM address, a PP reads the A register. If bit 17 of the A register is clear, the PP uses the contents of the A register for the CM address. If bit 17 of the A register is set, the PP adds the relocation address from the R register to the A register to form the CM A maximum of 20 PPs in various stages of assembly/disassembly can simultaneously read CM words, and five PPs can write CM words. This section describes mainframe controls and indicators and the operating procedures which are hardware-dependent. Software-dependent procedures are in system software reference manuals listed in the preface. ## **CONTROLS AND INDICATORS** This section describes IOU deadstart controls and indicators and CM configuration switches used by the system operator. Other controls used by maintenance personnel are described in the hardware operator's guide and the hardware maintenance manuals of the power distribution and warning system, the cooling system, and the system console listed in the system publication index. ## **DEADSTART PANEL CONTROLS/INDICATORS (MODELS 835, 840, 845, 850, 855, AND 860)** The deadstart panel (figure 3-1) is in the IOU. It contains PP register selection and display facilities, deadstart controls, error indicators, and a switch matrix, which is the source for a short PP program for initialization or troubleshooting. The switches, indicators, and their functions are listed in table 3-1. Figure 3-1. Deadstart Panel (All Models Except 990) Table 3-1. Deadstart Panel Controls/Indicators, All Models Except 990 (Sheet 1 of 2) | Panel Nomenclature | Description | Function | |----------------------------------|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 20 through 215 by 1 through 2088 | Toggle switch matrix (two-<br>position switches) | Provides a 16-word deadstart program for PPO. Switches 20 through 211 set 12 bits for each of the program words, labeled 1 through 20 (octal). Switches 212 through 215 are set to zero. | | | | Up position sets bit. Down position clears bit. | | PP NO | Octal display | Shows the PP selected by PP SELECT switches. | | DATA | Octal display | Shows the content of the register selected by REGISTER SELECT switches. | | PP SELECT | Toggle switches (two-position) | Selects the PP whose register is to be displayed. | | REGISTER SELECT | Toggle switches (two-position) | Selects the register to be displayed (00 = $P$ , 01= $Q$ , 10 = $K$ , 11 = $A$ ). | | A, K, Q, P | Indicators | One of these lights to indicate which register is selected by REGISTER SELECT switches. | | LAMP TEST | Toggle switch (two-position) | Lights all indicators and display segments. | | CLEAR AUTO | Toggle switch (two-position) | Allows manual clearing of auto mode bit (bit 34 of the environment control register) to override possible auto mode selection. This allows the selection of the PP and register from the deadstart panel if bit 34 is set. | | FREQ MARGIN | Toggle switch (three-position) | Determines the frequency margin selected (FAST/NORMAL/SLOW). The setting of this switch is sensed only at deadstart time. | | RECONFIGURATION, BARREL | Toggle switches (two-position) | Selects the physical barrel which is logical barrel 0. All the other logical barrels are numbered from the selected physical barrel circularly. (If physical barrel l is selected by the switches, physical barrel 2 is logical barrel 1, and so on.) | | RECONFIGURATION, PPM | Toggle switches (two-position) | Selects the physical PP memory which is logical PPMO. All the other PPMs in all barrels are numbered from the selected physical PPM circularly. If the switches are set to a value greater than four, no reconfiguration takes place. | | LONG/SHORT DEAD START SEQUENCE | Toggle switch (two-position) | Selects the LONG/SHORT deadstart sequence. The setting of this switch is sensed only at deadstart. | Table 3-1. Deadstart Panel Controls/Indicators, All Models Except 990 (Sheet 2 of 2) | Panel Nomenclature | Description | Function | |--------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DEAD START | Toggle switch (three-position, center is off) | Selects the fast or slow repetitive deadstart, which generates a master clear pulse every 250 or 4000 microseconds respectively. Up position selects fast deadstart; down position selects slow deadstart. (The single deadstart control pushbutton is on the system console.) | | L.D.S. ERROR-A | Indicator | Remains lit when long deadstart branch tests are not completed within 10.25 microseconds. | | L.D.S. ERROR-B | Indicator | Remains lit when a long deadstart sequence does not go to completion. | | DEAD START ERROR | Indicator | Lights in case of long deadstart ROM address/data parity error. | | M, CH, A, PQ, I, C | Indicators | Lights in case of hardware failures as follows: | | | | M: PP memory failure | | | | CH: I/O channel failure | | | | A: A barrel failure | | | | PQ: P or Q barrel failure | | | | I: Firmware or control failure | | | | C: 12/16 conversion failure | ## **DEADSTART DISPLAYS/CONTROLS (MODEL 990)** Pressing the deadstart pushbutton on the CC545 system console or pressing the CTRL G key on the CC634B system console initiates deadstart and an initial deadstart display appears on the screen of the system console. It is created by an independent microcomputer in the mainframe and does not rely on any program being operational in the PP's. The initial deadstart display is used to select a 16-word deadstart program for PPO and to initiate the deadstart sequence for PPO. It is also used to reconfigure PPMs and barrels, and to display error status and maintenance information. The format of the deadstart options display is shown in figure 3-2 and the deadstart display is shown in figure 3-3. Table 3-2 describes the two operator-selectable options and table 3-3 describes the operator entries and functions for the deadstart display. Other deadstart displays are available for maintenance use. Refer to the Cyber Instruction Package (CIP) listed in the preface for additional information. ## **CENTRAL MEMORY CONTROLS** The CM for models 835, 845, and 855, without the Memory Upgrade Option, contains four three-position configuration switches (figure 3-4). The CM for models 845, and 855, with the Memory Upgrade Option, and models 840, 850, and 860 contains six twoposition configuration switches (figure 3-4). The CM for model 990 contains three-position configuration switches (figure 3-4). On the model 835, these switches are located along the edge of a printed circuit board located just to the right of the center post in the middle section of the memory cabinet (location DO1). On models 845 and 855, without the Memory Upgrade Option, these switches are located along the edge of a printed circuit board located just to the right of the center post in the lower section of the memory cabinet (location F04). On models 845 and 855, with the Memory Upgrade Option, and on models 840, 850, and 860 these switches are located along the address interface pak switch in the A section of the memory cabinet. On model 990, these switches are located on a switch box attached to the underside of the top panel over the CMC section. ``` DEADSTART OPTIONS S SYSTEM LOAD OPTIONS M MAINTENANCE OPTIONS (CR) SYSTEM LOAD OPTIONS PROGRAM N SELECTED ``` Figure 3-2. Deadstart Options Display (Model 990) ``` DEADSTART - REV. 01 XX YYYYYY=CHANGE DS PRG PPM CONF = 00 XX+YYYYYY=CHANGE DS PRG INC NIO BRL CONF = 0 S=SHORT DS DLY LOOP = 0 L=LONG DS LDS ADDR = 6000 H=HELP CLK FREQ = NORMAL PROGRAM 1 01 001402 02 007306 03 000017 04 007546 05 007706 06 000120 07 007406 007106 10 11 007301 12 000710 000000 13 14 000000 000000 15 000000 16 17 000000 20 007112 ``` Figure 3-3. Initial Deadstart Display (Model 990) The switches are used to eliminate CM sections with malfunctions. For models 835, 845, and 855, without the Memory Upgrade Option, each switch, SW3 through SW6, forces one corresponding CM address bit, 23 through 20, either to a zero (switch down) or to a one (switch up). Refer to table 3-4. For models 845 and 855, with the Memory Upgrade Option, and models 840, 850, and 860 each switch, SW0 through SW5 inverts the corresponding CM address bit 37 through 42. The inversion effectively moves blocks of bad memory to the highest memory block and moves blocks of good memory down, thereby providing a sequentially addressable block of error-free memory. Refer to table 3-5. For the model 990, each switch, SW2 through SW4, forces one corresponding CM address bit, 39 through 41, either to a zero (switch down) or to a one (switch up). Refer to table 3-6. In case of CM malfunctions, the remaining good memory can be reconfigured so it is accessible by contiguous addresses from zero to the maximum remaining address. This is accomplished by setting configuration switches (figure 3-4) as listed in tables 3-4, 3-5, and 3-6. Refer to the hardware operator's guide listed in the system publication index for further information. Figure 3-4. CM Configuration Switches Table 3-2. Deadstart Options Display (Model 990) | Option | Description | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | S | Selects a short deadstart sequence using the deadstart program identified at the bottom of the display. Upon completion of the deadstart sequence a display for loading system software appears. | | м | Causes the deadstart display to appear on the screen. | Table 3-3. Deadstart Display Operator Entries and Functions | Operator Entry | Function | | | | | |----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | хх уууууу | Enters a single word in the deadstart program at xx to a new value yyyyyy (octal). | | | | | | жж+уууууу | Changes words in the deadstart program in sequence starting at xx. | | | | | | s | Selects a short deadstart sequence. | | | | | | L | Selects a long deadstart sequence. | | | | | | H | Brings up a display that lists and explains all available commands.<br>Refer to the Hardware Operator's Guide for detailed information about these commands. | | | | | Table 3-4. Central Memory Reconfiguration (Models 835, 845, and 855, Without the Memory Upgrade Option) | Original CM | | | Reconfigured CM | | | | | | | | |-----------------|---------------|----------------|-----------------|-----------|-----------|-----------|-------|---------|---------|------| | Size | | Size | Loca | tion of | Failin | g CM | Recon | figurat | ion Set | ting | | Words<br>(MB) | Address Range | Words | Bit<br>23 | Bit<br>22 | Bit<br>21 | Bit<br>20 | SW3 | SW4 | SW5 | SW6 | | 524K<br>(4MB) | 0-1 777 777 | 262K<br>(2MB) | | | 0 | х | _ | _ | U | - | | | | 262K<br>(2MB) | | | 1 | x | - | _ | D | - | | 1049K<br>(8MB) | 0-3 777 777 | 524K<br>(4MB) | | 0 | Х | х | _ | ט | - | - | | | | 524K<br>(4MB) | | 1 | х | x | _ | D | - | - | | 1573K<br>(12MB) | 0-5 777 777 | 524K<br>(4MB) | 0 | 0 | X | х | _ | ט | _ | - | | | | 524K<br>(4MB) | 0 | 1 | X · | x | _ | D | _ | - | | | | 1049K<br>(8MB) | 1 | 0 | x | х | D | _ | - | - | | 2097K<br>(16MB) | 0-7 777 777 | 1049K<br>(8MB) | 0 | X | Х | x | U | _ | - | - | | | | 1049K<br>(8MB) | 1 | X | X | x | D | - | - | - | | | | | • | (1) | | • | | (2 | ) | | - 1. CM remaining can be further reconfigured by setting additional configuration switches. - 2. U equals up, D equals down, and dash (-) equals center position. Table 3-5. Central Memory Reconfiguration (Models 845 and 855 with the Memory Upgrade Option and Models 840, 850, and 860) | | Original CM | | | Reconfigured CM | | | | | | |---------------------|---------------|-------------------|--------------------------|-----------------|----------------|----------------|----------------|----------------|--| | Size | | Error-Free | Reconfiguration Settings | | | ngs | | | | | Words<br>(MB) | Address Range | Size | SWO<br>ADRS 37 | SW1<br>ADRS 38 | SW2<br>ADRS 39 | SW3<br>ADRS 40 | SW4<br>ADRS 41 | SW5<br>ADRS 42 | | | 2097 K<br>(16 MB) | 0-7 777 777 | 1049 K<br>(8 MB) | D | ם | D | U | D | D | | | 4195 K<br>(32 MB) | 0-17 777 777 | 2097 K<br>(16 MB) | D | D | ט | D | D | D | | | 8390 K<br>(64 MB) | 0-37 777 777 | 4195 K<br>(32 MB) | D | υ | D<br>· | D | D | D | | | 16780 K<br>(128 MB) | 0-77 777 777 | 8390 K<br>(64 MB) | <b>"</b> | D | D | D | D | D | | - 1. CM remaining can be further reconfigured to obtain larger contiguous blocks of error free memory by setting additional configuration switches. See examples shown in figure 3-5. - 2. U equals up, D equals down. Normal setting of all switches is down. Table 3-6. Central Memory Reconfiguration (Model 990) | . ( | Original CM | | | Ro | econfigured | CM | | | |-----------------|---------------|-----------------|-----------------------------|---------|---------------|-------------------------|-----|----------| | Size | | Size | Size Location of Failing CM | | | Reconfiguration Setting | | | | Words<br>(MB) | Address Range | Words | RMA Bit<br>39 | RMA Bit | RMA Bit<br>41 | SW2 | SW3 | SW4 | | 1049K<br>(8MB) | 0-3 777 777 | 524K<br>(4MB) | х | х | 0 | _ | _ | U | | | | 524K<br>(4MB) | x | x | 1 | . – | _ | D | | 2097K<br>(16MB) | 0-7 777 777 | 1049K<br>(8MB) | x | 0 | <b>x</b> , | <u>-</u> | U | _ | | | | 1049K<br>(8MB) | x | 1 | x | - | D | - | | 3146K<br>(24MB) | 0-13 777 777 | 1049K<br>(8MB) | Ò | 0 | х | _ | Ū | _ | | | | 1049K<br>(8MB) | 0 | 1 | x | _ | D | - | | | | 2097K<br>(16MB) | 1 | 0 | x | D | - | _ | | 4195K<br>(32MB) | 0-17 777 777 | 2097K<br>(16MB) | 0 | х | X | Ŭ | _ | _ | | | , | 2097K<br>(16MB) | 1 | x | х | D | _ | <u>-</u> | | | | | (1 | ) | . " | | (2) | | - 1. CM remaining can be further reconfigured by setting additional configuration switches. - 2. U equals up, D equals down, and dash (-) equals center position. Set SWO up to move block of memory containing error to upper half of memory. Error in lower 64 MB block of 128 MB memory. Set SWl up to move 32 MB block containing error to next higher 32 MB. Then set SWO up to move block containing error to highest block of memory. Error in lowest 32 MB block of 128 MB memory. Set SW2 up to move 16 MB block containing error to next higher block. Then set SW1 up to move 32 MB block containing error to highest block of memory. Error in lowest 16 MB block of upper half of 128 MB memory. Figure 3-5. Reconfiguration Examples (Models 845 and 855 with the Memory Upgrade Option and Models 840, 850, and 860) ### POWER-ON AND POWER-OFF PROCEDURES In case of an emergency, use the system EMERGENCY OFF switch. The power-on and power-off procedures are described in the hardware operator's guide listed in the system publication index. #### CAUTION Improper application or removal of power may damage system circuits and/ or air conditioning system. Power must be turned on/off by designated personnel only, except for the system EMERGENCY OFF switch. Use only for extreme emergency, not for normal shutdown. # **OPERATING PROCEDURES**(ALL MODELS EXCEPT 990) Refer to the hardware operator's guide listed in the system publication index. The system is initialized by setting its control switches, and then by running either a long or short deadstart sequence (defined later in this section). After initialization, the keyboard is used to instruct the system further, under program control. #### **CONTROL CHECKS** Before activating a long or short deadstart sequence, check the positions of deadstart panel switches against their intended use. These checks can be made by using table 3-1. The normal settings of these switches is as follows: | Switch | Position | |-----------------------------------|----------------------------------------| | CLEAR AUTO | Down | | FREQ MARGIN | Center | | RECONFIGURATION | All down | | LONG/SHORT DEAD START<br>SEQUENCE | Down for a short<br>deadstart sequence | | DEAD START | Center | | All error lights | Not lit | #### **Deadstart Sequences** In response to a deadstart signal from either the deadstart pushbutton on the system console, or from the DEAD START switch on the deadstart panel, circuits in the IOU perform a deadstart sequence. Depending on the setting of the LONG/SHORT DEAD START SEQUENCE switch on the deadstart panel, either the long or the short deadstart sequence is performed. The short deadstart sequence is used when hardware integrity verification is not required. The long deadstart sequence performs all the tasks performed by the short deadstart sequence and some additional tasks. The main additional task is the running of a diagnostic program, from a read-only Memory (ROM) in the IOU, on logical PPO. The diagnostic program takes approximately one minute to run. Both deadstart sequences begin with a master clear which sets up all PPs, except logical PPO, for a 4096-word block input starting at PP location 0. The input into each PP is from the channel with the same number as the logical number of the PP concerned. The master clear also resets all external devices and sets maintenance channel connect code bit 52. The individual channels and registers are set as follows: | Channe1 | Active/<br>Inactive<br>Flag | Full/<br>Empty<br>Flag | Channel<br>Flag | Channel<br>Error<br>Flag | |---------------------------------|-----------------------------|------------------------|-----------------|--------------------------| | 0 | Inactive | Empty | Clear | Clear | | 10 (display controller) | Active | Enpty | Clear | Clear | | <pre>14 (real-time clock)</pre> | Active | Ful1 | Set | Set | | 15 (two-port mux) | Active | Empty | Clear | Clear | | 17 (maintenance) | Active | Empty | Clear | Clear | | Other installed channels | Active | Empty | Clear | Clear | | Noninstalled channels | Inactive | Empty | Clear | Clear | The flags of channel 14 and of noninstalled channels are fixed by hardware and cannot be changed. | Register | Initialization | Description | |----------|----------------|-------------------------------------------------| | K | 0071008† | Instruction display on deadstart panel | | P | 0077778 | Causes block input to start from location 0 | | A | 10,0008 | Count of 4096 words | | Q | 0, 1, 2 | I/O channel numbers (PPO: O, PPI: 1, and so on) | All registers in all barrels are set to these values, except the registers of PPO. If the long deadstart sequence is being performed, hardware clears location 77778 in all PP memories and sets the P register of PPO to 60008. PPO starts performing a test program from a read-only memory in IOU and lights the deadstart panel L.D.S. ERRO-A and L.D.S. ERRO-B indicators. Indicator A remains lit unless the test program reaches location 62008 within 10.25 microseconds. Indicator B remains lit until the test program reaches location 77768. When this happens, the unique part of the long deadstart sequence ends with a master clear. Next, both deadstart sequences clear PPO location 0, write the settings of the deadstart panel matrix switches into PPO memory locations 1 to $20_8$ , and clear PPO location $21_8$ . PPO then starts executing the program entered from the matrix switches, which is normally a bootstrap program to input more data from an assigned external device. The short deadstart sequence does not disturb PP memory other than PPO locations 0 to 218. Both deadstart sequences leave all PPs, except PPO, waiting for a block input, or for action through the maintenance channel. After the block input is complete, each PP starts executing the program entered from whatever address was entered into location 0 of that PP. <sup>†</sup> Leading zeros are not displayed on deadstart panel. ## **OPERATING PROCEDURES (MODEL 990)** Refer to the Hardware Operator's Guide. The system is initialized by setting its deadstart display control parameters, and then by running either a long or short deadstart sequence (defined later in this section). After initialization, the keyboard is used to instruct the system further, under program control. #### **CONTROL CHECKS** Before activating a long or short deadstart sequence, check the deadstart display parameters against their intended use. The normal settings of these parameters are as follows: | Parameter | <u>Value</u> | |----------------|--------------| | PPM CONF | 00 | | BRL CONF | 0 | | LDS ADDR | 6000 | | Error messages | none | #### **Deadstart Sequences** In response to a keyboard command (L or S) to the deadstart display, the IOU performs a deadstart sequence. Depending on the command (L or S), either the long or the short deadstart sequence is performed. The short deadstart sequence is used when hardware integrity verification is not required. The long deadstart sequence performs all the tasks performed by the short deadstart sequence and some additional tasks. The main additional task is the running of a diagnostic program, from a read-only memory (ROM) in the IOU, on logical PPO. The diagnostic program takes approximately 15 seconds to run. Both deadstart sequences begin with a master clear which sets up all PPs, except logical PPO, for a 4096-word block input starting at PP location 0. The input into each PP is from the channel with the same number as the logical number of the PP concerned. The master clear also resets all external devices and sets maintenance channel connect code bit 52. The individual registers are set as follows: | Register | Initialization | Description | | | | | |----------|----------------|-------------------------------------------------|--|--|--|--| | К | 0071008 | Instruction display | | | | | | P | 0077778 | Causes block input to start from location 0 | | | | | | A | 10,0008 | Count of 4096 words | | | | | | Q | 0, 1, 2 | I/O channel numbers (PPO: 0, PPI: 1, and so on) | | | | | All registers in both barrels are set to these values, except the registers of $\ensuremath{\mathsf{PP0}}$ . If the long deadstart sequence is being performed, hardware clears location 77778 in all PP memories and sets the P register of PPO to the value indicated by the parameter LDS ADDR = XXXX (normally 60008). PPO starts performing a test program from a read-only memory in IOU. Hardware errors cause the LDS program to hang before completion. In the absence of errors, execution proceeds until the test program reaches location 77768. When this happens, the unique part of the long deadstart sequence ends with a master clear. Next both deadstart sequences clear PPO location 0, write the deadstart program on the display into PPO memory locations 1 to 20g, and clears PPO location 21g. PPO then starts executing the program entered from the deadstart display, (which is normally a bootstrap program to input more data from an assigned external device). The short deadstart sequence does not disturb PP memory other than PPO locations 0 to 218. Both deadstart sequences leave all PPs, except PPO, waiting for a block input, or for action through the maintenance channel. After the block input is complete, each PP starts executing the program entered from whatever address was entered into location 0 of that PP. ## IOU RECONFIGURATION (ALL MODELS EXCEPT 990) The logical PP numbers and hardware are assigned to physical PPs circularly from the settings of IOU deadstart panel RECONFIGURATION switches, which specify which physical barrel and PPM is PPO. If the PPM section of these switches is set to a value greater than four, the value zero is substituted. If the BARREL section of these switches is set to a value greater than the number of installed barrels, the value zero is substituted. Thus, possible barrel numbering is as described in table 3-7. NOTE The minimum system option is 10 PPs. ## **IOU RECONFIGURATION (MODEL 990)** The logical PP numbers and hardware are assigned to physical PPs circularly from the settings of IOU deadstart display PPM CONF and BRL CONF parameters, specifying which physical barrel and PPM is PPO. Maximum values for these parameters depend on the number of PPs installed. Illegal values entered in RB X and RP XX commands are rejected by the deadstart display, and cause error messages to appear on the screen (refer to the Hardware Operator's Guide). Reconfiguration is discussed in detail in the Hardware Operator's Guide; allowable values for the PPM CONF and BRL CONF parameters and reconfiguration examples are shown in tables 3-8 and 3-9. Table 3-7. Barrel Numbering Table (All Models Except 990) | Barrels Installed | Physical Barrel | Logical PPs in Physical Barrel with<br>BARREL RECONFIGURATION Switch Values | | | | | | | |--------------------|-----------------|-----------------------------------------------------------------------------|-------|--------|---------|--|--|--| | | | 0 | 1 | 2 | 3 | | | | | 4 Barrels (20 PPs) | 0 | 0-4 | 25-31 | 20-24 | 5-11 | | | | | | 1 | 5-11 | 0-4 | 25-31 | 20-24 | | | | | | 2 | 20-24 | 5-11 | 0-4 | 25-31 | | | | | | 3 | 25-31 | 20-24 | 5-11 | 0-4 | | | | | 3 Barrels (15 PPs) | 0 | 0-4 | 20-24 | 5-11 | (0-4) | | | | | | 1 | 5-11 | 0-4 | 20-24 | (5-11) | | | | | | 2 | 20-24 | 5-11 | 0-4 | (20-24) | | | | | 2 Barrels (10 PPs) | 0 | 0-4 | 5-11 | (0-4) | (0-4) | | | | | | 1 | 5-11 | 0-4 | (5-11) | (5-11) | | | | | l Barrel (5 PPs) | 0 | 0-4 | (0-4) | (0-4) | (0-4) | | | | Table 3-8. PP and Barrel Reconfiguration Example, RP=0 (Model 990) | No. | Physical | ysical Logical PP | | | | | Logical PP | | | Logical PP | | | | Logical PP | | | | |-----|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------| | of | in each | | | | | RB=1 | | | RB=2 | | | RB=3 | | | | | | | PPs | Barre1 | BAR0 | BAR1 | BAR2 | BAR3 | BAR0 | BAR1 | BAR2 | BAR3 | BAR0 | BAR1 | BAR2 | BAR3 | BARO | BAR1 | BAR2 | BAR3 | | 10 | 00<br>01<br>02<br>03<br>04 | 00<br>01<br>02<br>03<br>04 | 05<br>06<br>07<br>10<br>11 | х | x | 05<br>06<br>07<br>10<br>11 | 00<br>01<br>02<br>03<br>04 | x | x | х | x | x | x | x | х | x | Х | | 15 | 00<br>01<br>02<br>03<br>04 | 00<br>01<br>02<br>03<br>04 | 05<br>06<br>07<br>10 | 20<br>21<br>22<br>23<br>24 | x | 20<br>21<br>22<br>23<br>24 | 00<br>01<br>02<br>03<br>04 | 05<br>06<br>07<br>10<br>11 | x | 05<br>06<br>07<br>10<br>11 | 20<br>21<br>22<br>23<br>24 | 00<br>01<br>02<br>03<br>04 | х | x | х | X | х | | 20 | 00<br>01<br>02<br>03<br>04 | 00<br>01<br>02<br>03<br>04 | 05<br>06<br>07<br>10 | 20<br>21<br>22<br>23<br>24 | 25<br>26<br>27<br>30<br>31 | 25<br>26<br>27<br>30<br>31 | 00<br>01<br>02<br>03<br>04 | 05<br>06<br>07<br>10<br>11 | 20<br>21<br>22<br>23<br>24 | 20<br>21<br>22<br>23<br>24 | 25<br>26<br>27<br>30<br>31 | 00<br>01<br>02<br>03<br>04 | 05<br>06<br>07<br>10<br>11 | 05<br>06<br>07<br>10<br>11 | 20<br>21<br>22<br>23<br>24 | 25<br>26<br>27<br>30<br>31 | 00<br>01<br>02<br>03<br>04 | - 1. X = not applicable, results in message "Error BRL not installed". - 2. RP = PP Configuration. - 3. RB = NIO Barrel Configuration only. - 4. BAR 0-3 are the physical barrels. Table 3-9. PP and Barrel Reconfiguration Example, RP=2 (Model 990) | | Physical | | | | | | Logical PP | | | | Logical PP | | | | | | | |-----------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------| | No.<br>of | PPMs<br>in each<br>Barrel | RB=0 | | | | RB=1 | | | RB=2 | | | | RB=3 | | | | | | PPs | | BARO | BAR1 | BAR2 | BAR3 | BAR0 | BAR1 | BAR2 | BAR3 | BARO | BAR1 | BAR2 | BAR3 | BAR0 | BAR1 | BAR2 | BAR3 | | 10 | 00<br>01<br>02<br>03<br>04 | 03<br>04<br>00<br>01<br>02 | 10<br>11<br>05<br>06<br>07 | x | x | 10<br>11<br>05<br>06<br>07 | 03<br>04<br>00<br>01<br>02 | X | x | x | x | x | х | x | x | x | x | | 15 | 00<br>01<br>02<br>03<br>04 | 03<br>04<br>00<br>01<br>02 | 10<br>11<br>05<br>06<br>07 | 23<br>24<br>20<br>21<br>22 | х | 23<br>24<br>20<br>21<br>22 | 03<br>04<br>00<br>01<br>02 | 10<br>11<br>05<br>06<br>07 | х | 10<br>11<br>05<br>06<br>07 | 23<br>24<br>20<br>21<br>22 | 03<br>04<br>00<br>01<br>02 | х | x | x | x | x | | 20 | 00<br>01<br>02<br>03<br>04 | 03<br>04<br>00<br>01<br>02 | 10<br>11<br>05<br>06<br>07 | 23<br>24<br>20<br>21<br>22 | 30<br>31<br>25<br>26<br>27 | 30<br>31<br>25<br>26<br>27 | 03<br>04<br>00<br>01<br>02 | 10<br>11<br>05<br>06<br>07 | 23<br>24<br>20<br>21<br>22 | 23<br>24<br>20<br>21<br>22 | 30<br>31<br>25<br>26<br>27 | 03<br>04<br>00<br>01<br>02 | 10<br>11<br>05<br>06<br>07 | 10<br>11<br>05<br>06<br>07 | 23<br>24<br>20<br>21<br>22 | 30<br>31<br>25<br>26<br>27 | 03<br>04<br>00<br>01<br>02 | - 1. X = not applicable, results in message "Error BRL not installed". - 2. RP = PP Configuration. - 3. RB = NIO Barrel Configuration only. - 4. BAR 0-3 are the physical barrels. #### **CP INSTRUCTIONS** #### **CP INSTRUCTION FORMATS** ## NOTE CYBER 170 CP instructions use the rightmost 60 bits in the 64-bit word. The leftmost 4 bits are undefined. For these instructions, the most significant bit is bit 59 and the least significant bit is bit 0. Program instruction words are divided into 15-bit fields called parcels. The first parcel (parcel 0) is the highest-order 15 bits of the 60-bit word. The second, third, and fourth parcels (parcels 1, 2, and 3) follow in order. Figure 4-1 shows possible parcel arrangements for instructions within a program instruction word. An instruction may occupy one, two, or four parcels. This arrangement depends upon the instruction format. When an instruction occupies two parcels, it must occupy two parcels within the same program word. A program word may be filled with a oneparcel pass instruction or an instruction acting as a two-parcel pass instruction. These instructions are used to fill a program word when necessary to place a particular instruction in the first parcel of a program word or to avoid starting a two-parcel instruction in the fourth parcel of a program word. Pass instructions may also be used for branch entry points because a branch instruction destination address must begin with a new word. One-parcel pass instructions are 460xx through 463xx. Instructions 60xxx through 62xxx may be used as two-parcel pass instructions by setting the i instruction designator to zero. Refer to table 4-1 for CP instruction designators. CP instructions 011 and 012 have special properties. They are 60-bit double instructions which must start at parcel 0. The programmer has the option of providing a branch instruction at parcels Figure 4-1. CP Instruction Parcel Arrangement 2 and 3 in the same instruction word (to an error handling software routine), or filling this space with pass instructions. Refer to instructions 011 and 012. Table 4-1. Central Processor Instruction Designators | Designator | Use | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Opcode | 6-bit/9-bit field specifying instruction operation code. | | i | 3-bit code specifying one of eight registers. | | j | 3-bit code specifying one of eight registers. | | jk | 6-bit code specifying amount of shift or mask. | | k | 3-bit code specifying one of eight registers. | | ĸ | 18-bit operand or address. | | x | Unused designator. | | A | One of eight 18-bit address registers. | | В | One of eight 18-bit index registers;<br>BO is fixed and equal to zero. | | x | One of eight 60-bit operand registers. | | () | Content of the word at a CM address. | | ci † | Offset (character address) of the first character in the first word of the source field. | | G2 .† | Character address of the first character in the first word of the result field. | | KI † | 18-bit address indicating the CM location of the first (leftmost) character of the source field. | | к2 † | 18-bit address indicating the CM location of the first (leftmost) character of the result field. | | IL † | Lower 4 bits of the field length (character count) for a move or compare instruction; used with LU to specify field length. | | w † | Upper 9 bits of the field length (character count) for indirect move instruction or the upper 3 bits for direct instructions; used with LL to specify field length. | | | | Applicable to compare/move instructions only. Instructions 013 and 464 through 467 are 60-bit instructions which must start at parcel 0. They ignore any information in parcels 2 and 3; however, these parcels are normally set to all zeros. #### **CP OPERATING MODES** The CP executes instructions in CYBER 170 job mode, CYBER 170 monitor mode, and executive state. Changes between CYBER 170 job mode and CYBER 170 monitor mode are caused by CYBER 170 exchange jumps (CP instruction 013 and PP instructions 2600, 2610, and 2620). A hardware flag called the CYBER 170 monitor flag (MF) indicates whether the CP is in CYBER 170 job mode (flag is clear) or in CYBER 170 monitor mode (flag is set). Executive state is invisible to the applications programmer. It sets up the CYBER 170 environment during initialization, executes certain instructions, and handles hardware-detected error conditions. Hardware-caused exchanges are called error exits; most of these can be enabled or disabled by setting or clearing bits in the CYBER 170 exchange package. For further information on CP operating modes, refer to CYBER 170 Exchange Jump, Executive State, and Error Response in section 5. #### **CP INSTRUCTION DESCRIPTIONS** The instruction descriptions are in numerical order. The shaded areas, like those in the following 00xxx and 010xK instruction formats, indicate unused bits. The unused bits are ignored by the CP. 00xxx Error Exit to MA when CYBER 17 PS MF Clear Interrupt to Executive Mode when CYBER 170 MF Set This instruction causes an illegal instruction error exit. CYBER 170 MF is the hardware monitor flag. Refer to Illegal Instructions, section 5. 010xK Return Jump to K RJ K This two-parcel instruction uses the lower-order 18 bits as operand K. This instruction writes a special word into CM at relative address K. The current program sequence then terminates by a jump to address K plus 1. The word stored in memory contains a jump instruction which causes an unconditional jump to the address of this return jump instruction plus 1. This instruction calls a subroutine and inserts execution of the subroutine between execution of this instruction word and the following instruction word. Instructions appearing after the return jump instruction in the instruction word are not executed. The called subroutine exit must be at address K. The called subroutine entrance address must be K plus 1. This instruction stores a 60-bit word at address K in memory. The upper half of this word contains an unconditional jump (0400) instruction with an address which is equal to the current program address plus 1. The lower half of the stored word is all zeros. The octal digits in the stored word then appear as illustrated with the x field indicating the location of the current program address plus 1. K 0400x xxxxx 00000 00000 Subroutine exit K + 1 yyyyy yyyyy yyyyy yyyyy Subroutine entrance OlljK Block Copy Bj + K Words from RE Bj + K UEM to CM | 59 | 51 | | 47 | 30 290 | | | | | | |----|----|---|----|--------|---------|---------|------|--|--| | Г | OH | j | к | | INST. F | OR HALF | EXIT | | | This instruction copies a block of Bj plus K consecutive words from unified extended memory (UEM) to CM. The source UEM address is XO plus RAE where the bits used depend on the setting of the expanded addressing select flag in the CYBER 170 exchange package. If the flag is clear (UEM is in standard addressing mode), the UEM address is calculated using bits 0 through 22 of XO; bits 24 through 59 are ignored. If the flag is set (UEM is in expanded addressing mode), the UEM address is calculated using bits 0 through 28 of XO; bits 30 through 59 are ignored. The destination CM address is either AO plus RAC or XO plus RAC depending on the setting of the block copy flag in the CYBER 170 exchange package. When the block copy flag is clear, the CM address is AO plus RAC. When the block copy flag is set, the CM address is calculated using bits 30 through 50 of XO. Bits 51 through 59 must be set to zero; results are undefined if these bits are not zero. The operation leaves Bj, XO, and AO unchanged. Bj and K are both signed 18-bit one's complement numbers, making it possible to transfer a maximum of 131,071 60-bit words. If Bj plus K is zero, the instruction acts as a 60-bit pass instruction. If bit 21 or 22 of the result of XO plus RAE is a one, zeros are transferred and the next instruction is taken from parcel 2 of the same instruction word. If this is not the case, the next instruction is taken from parcel 0 of the next instruction word. If execution of the OlljK instruction is interrupted, it is restarted from the beginning. This instruction is illegal if it does not start in parcel 0 or the UEM enable flag in the CYBER 170 exchange package is clear. In standard addressing mode, 24 bits of XO are checked against 23 bits of FLE with bit 23 of FLE equal to zero. In expanded addressing mode, 30 bits of XO are checked against 29 bits of FLE with bit 29 equal to zero. If the XO bits are greater than or equal to FLE, an address out of range is detected. If Bj plus K is negative, an address range error exit takes place. If the source field and the destination field overlap in physical memory, the final contents of the destination field are undefined. For further information, refer to Block Copy Instructions in section 5. O12jK Block Copy Bj + K Words from WE Bj + K CM to UEM | 59 5 | il | 47 | 30 29 | 0 | |------|----|----|---------------------|---| | 012 | j | К | INST. FOR HALF EXIT | | This instruction copies a block of Bj plus K consecutive words from CM to UEM. The source CM address is either AO plus RAC or XO plus RAC depending on the setting of the block copy flag in the CYBER 170 exchange package. When the block copy flag is clear, the CM address is AO plus RAC. When the block copy flag is set, the CM address is calculated using bits 30 through 50 of XO. Bits 51 through 59 must be set to zero; results are undefined if these bits are not zero. The destination UEM address is XO plus RAE where the bits used depend on the setting of the expanded addressing select flag in the CYBER 170 exchange package. If the flag is clear (UEM is in standard addressing mode), the UEM address is calculated using bits 0 through 22 of XO; bits 24 through 59 are ignored. If the flag is set (UEM is in expanded addressing mode), the UEM address is calculated using bits 0 through 28 of XO; bits 30 through 59 are ignored. The operation leaves Bj, XO, and AO unchanged. Bj and K are both signed 18-bit one's complement numbers, making it possible to transfer a maximum of 131,071 60-bit words. If Bj plus K is zero, the instruction acts as a 60-bit pass instruction. If bit 21 or 22 of the result of XO plus RAE is a one, zeros are transferred and the next instruction is taken from parcel 2 of the same instruction word. If this is not the case, the next instruction is taken from parcel O of the next instruction word. If execution of the 012jK instruction is interrupted, it is restarted from the beginning. This instruction is illegal if it does not start in parcel 0 or the UEM enable flag in the CYBER 170 exchange package is clear. In standard addressing mode, 24 bits of XO are checked against 23 bits of FLE with bit 23 of FLE equal to zero. In expanded addressing mode, 30 bits of XO are checked against 29 bits of FLE with bit 29 equal to zero. If the XO bits are greater than or equal to FLE, an address out of range is detected. If Bj plus K is negative, an address range error exit takes place. If the source field and the destination field overlap in physical memory, the final contents of the destination field are undefined. For further information, refer to Block Copy Instructions in section 5. 013jK Central Exchange Jump to XJ Bj + K Bj + K when CYBER 170 MF Set 013xx Monitor Exchange Jump to MA when CYBER 170 MF Clear This instruction must start at parcel 0. Also, a CYBER 170 exchange package must be ready at address Bj plus K or at address MA. This instruction stores P plus 1 into the outgoing CYBER 170 exchange package in hardware and then exchanges this CYBER 170 exchange package with the CYBER 170 exchange package stored in memory. If, at the beginning of the instruction, the CYBER 170 MF is set, then the incoming CYBER 170 exchange package starts at absolute address Bj plus K. If, at the beginning, the CYBER 170 MF is clear, then the j and K fields of the instruction are ignored, and the incoming CYBER 170 exchange package starts at absolute address MA which is obtained from the outgoing CYBER 170 exchange package. In either case, the CYBER 170 MF is toggled and the outgoing CYBER 170 exchange package is stored beginning at the same CM address from where the incoming CYBER 170 exchange package is obtained. Also, the jump is always to relative address P, parcel 0, from the new CYBER 170 exchange package. Refer to CYBER 170 Exchange Jump, section 5. This instruction is illegal if the UEM enable flag in the CYBER 170 exchange package is clear. This instruction reads the 60-bit word from UEM location Xk plus RAE into Xj. Xk is less than FLE. The number of bits checked for an address out of range condition varies depending on the addressing mode of UEM. In standard addressing mode, 24 bits of Xk are checked against 23 bits of FLE with bit 23 of FLE equal to zero. In expanded addressing mode, 30 bits of Xk are checked against 29 bits of FLE with bit 29 of FLE equal to zero. If Xk is greater than or equal to FLE, an address out of range is detected. This instruction is illegal if the UEM enable flag in the CYBER 170 exchange package is clear. This instruction writes the 60-bit word from Xj into the UEM location Xk plus RAE. Xk is less than FLE. The number of bits checked for an address out of range condition varies depending on the addressing mode of UEM. In standard addressing mode, 24 bits of Xk are checked against 23 bits of FLE with bit 23 of FLE equal to zero. In expanded addressing mode, 30 bits of Xk are checked against 29 bits of FLE with bit 29 of FLE equal to zero. If Xk is greater than or equal to FLE, an address out of range is detected. 016jk Read Free Running Counter ХJ WXj Xk RC Xi JP Bi + K | 14 | 6 | <u> 5</u> | 2 0 | |-----|---|-----------|-----| | 016 | | j | k | This instruction transfers the current contents of the 48-bit free running counter to the Xj register. The leftmost twelve bits of Xj are set to zero. The k field is ignored. This instruction is a single parcel instruction that can be located in any parcel. 017jk Illegal Instruction Jump to (Bi) + K 021xK Refer to Illegal Instructions, section 5. This two-parcel instruction uses the lower-order 18 bits as operand K. The instruction causes the current program sequence to terminate with a jump to address Bi plus K in CM. This instruction allows computed branch point destinations. This is the only instruction in which a computed parameter can specify a program branch destination address. All other jump instructions have preassigned destination addresses. The quantities in Bi and operand K are added in an 18-bit one's complement mode. The result is treated as an 18-bit positive integer which specifies the beginning address in CM for the new program sequence. The remaining instructions, if any, in the instruction word do not execute. 030jK Branch to K if (Xj) = 0 ZR Xi, K This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon the content of Xj. The branch to address K occurs only on the following conditions. The current program sequence continues for all other cases. This instruction branches on a zero result from either a fixed-point or a floating-point operation. 031jK Branch to K if $(Xj) \neq 0$ NZ Xj, K PL Xj, K | 29 2 | 1 20 18 | 17 0 | |------|---------|------| | 031 | j | К | This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon the content of Xj. The program sequence continues only on the following conditions. The branch to address K occurs for all other cases. This instruction branches on a nonzero result from either a fixed-point or a floating-point operation. 032jK Branch to K if (Xj) is Positive | 1 | 29 2 | 1 20 18 | 17 | · O | |---|------|---------|----|-----| | | 032 | j | | К | This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon the content of Xj. The branch decision for this instruction is based on the value of the sign bit in Xj. This instruction branches on a positive result from either a fixed-point or a floating-point operation. 033jK Branch to K if (Xj) is Negative NG Xj, K | 29 | 21 | 20 18 | 17 | | 0 | |----|-----|-------|----|---|---| | | 033 | j | | K | | This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon the content of Xj. The branch decision for this instruction is based on the value of the sign bit in Xj. This instruction branches on a negative result from either a fixed-point or a floating-point operation. 034jK Branch to K if (Xj) is in Range IR Xj, K | 29 | 21 | 20 18 | 117 0 | |-----|----|-------|-------| | 034 | 4 | j | K | This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon the content of Xj. The program sequence continues only on the following conditions. The branch to address K occurs for all other cases. This instruction branches on a floating-point quantity within the floating-point range. The value of the coefficient is ignored in making this branch test. An underflow quantity is considered in range for purposes of this test. 035jK Branch to K if (Xj) is Out of Range OR Xj, K | 29 | 2 | 120 18 | 17 0 | |----|-----|--------|------| | | 035 | j | К | This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon the content of Xj. The branch to address K occurs only on the following conditions. The current program sequence continues for all other cases. 036jK Branch to K if (Xj) is Definite DF Xj, K This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon the content of Xj. The program sequence continues only on the following conditions. The branch to address K occurs for all other cases. This instruction branches on a floating-point quantity which may be out of range but is still defined. The value of the coefficient is ignored in making this branch test. An overflow quantity or an underflow quantity is considered defined for purposes of this test. 037 jK Branch to K if (Xj) is Indefinite ID Xj, K | 29 | 21 | 20 18 | 17 | | ) | |----|-----|-------|----|-----|---| | | 037 | j | | Κ , | l | This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon the content of the Kj register. The branch to address K occurs only on the following conditions. The current program sequence continues for all other cases. This instruction branches on a floating-point quantity which is not defined. The value of the coefficient is ignored in making this branch test. An overflow quantity or an underflow quantity is considered defined for purposes of this test. 04ijK Branch to K if (Bi) = (Bj) EQ Bi, Bj, K | <u> 29 24</u> | 23 2 | 20 18 | 17 0 | |---------------|------|-------|------| | 04 | i | j | К | This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon a comparison of the contents of the Bi and Bj registers. The branch to address K occurs only if the two quantities are identical on a bit-by-bit comparison basis. The current program sequence continues for all other cases. This instruction branches on an index equality test. A quantity consisting of all zeros and a quantity consisting of all ones are not equal for this test. 05ijK Branch to K if (Bi) # (Bj) NE Bi, Bj, K | 29 24 | 23 21 | 20 18 | 17 | 0 | |-------|-------|-------|----|---| | 05 | i | j | K. | 7 | This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon a comparison of the contents of the Bi and Bj registers. The program sequence continues only if the two quantities are identical on a bit-by-bit comparison basis. The branch to address K occurs for all other cases. This instruction branches on an index inequality test. A quantity consisting of all zeros and a quantity consisting of all ones are not equal for this test. 06ijK Branch to K if (Bi) $\geq$ (Bj) GE Bi, Bj, K | 29 24 | 23 21 | 20 18 | <u> </u> | |-------|-------|-------|----------| | 06 | ^ i | j | K | This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon a comparison of the contents of Bi and Bj. Both quantities are treated as signed integers. The branch to address K occurs if the content of Bi is greater than or equal to the content of Bj. The current program sequence continues if the content of Bi is less than Bj. This instruction branches on an index threshold test. A positive zero quantity is considered greater than a negative zero quantity. 07ijK Branch to K if (Bi) < (Bj) LT Bi, Bj, K | 3 | 29 24 | 23 21 | 20 18 | 17 0 | |---|-------|-------|-------|------| | | 07 | i | j | К | This two-parcel instruction uses the lower-order 18 bits as operand K. Execution of this instruction causes the program sequence to terminate with a jump to address K in CM or to continue with the current program sequence, depending upon a comparison of the contents of Bi and Bj. Both quantities are treated as signed integers. The branch to address K occurs if the content of Bi is less than the content of Bj. The current program sequence continues if the content of Bi is greater than or equal to the content of Bj. This instruction branches on an index threshold test. A positive zero quantity is considered greater than a negative zero quantity. 10ijx Transmit (Xj) to Xi BXi Xj This instruction transfers a 60-bit word from Xj into Xi. This instruction moves data from one X register to another X register. No logical function is performed on the data. llijk Logical Product of (Xj) and (Xk) to Xi BXi Xj \* Xk This instruction reads operands from two X registers, operates upon them to form a result, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. The result delivered to Xi is the bit-by-bit logical product of the two operands. Each of the 60 bits in Xj is compared with the corresponding bit in Xk to form a single bit in Xi. A sample computation is listed in octal notation to illustrate the operation performed and includes the four possible bit combinations that may occur. - (Xj) = 7777 7000 0123 4567 1010 - (Xk) = 0123 4567 0077 7700 1100 - (Xi) = 0123 4000 0023 4500 1000 This instruction extracts portions of a 60-bit word during data processing. 12ijk Logical Sum of (Xj) and (Xk) to Xi BXi Xj + Xk This instruction reads operands from two X registers, operates upon them to form a result, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. The result delivered to Xi is the bit-by-bit logical sum of the two operands. Each of the 60 bits in Xj is compared with the corresponding bit in Xk to form a single bit in Xi. A sample computation is listed in octal notation to illustrate the operation performed and includes the four possible bit combinations that may occur. - $(X_j) = 0000 7777 0123 4567 1010$ - (Xk) = 0123 4567 7777 0000 1100 - (Xi) = 0123 7777 7777 4567 1110 This instruction merges portions of a 60-bit word into a composite word during data processing. 13ijk Logical Difference of (Xj) BXi Xj -Xk and (Xk) to Xi This instruction reads operands from two X registers, operates upon them to form a result, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. The result delivered to Xi is the bit-by-bit logical difference of the two operands. Each of the 60 bits in Xj is compared with the corresponding bit in Xk to form a single bit in Xi. A sample computation is listed in octal notation to illustrate the operation performed and includes the four possible bit combinations that may occur. - (Xj) = 0123 7777 0123 4567 1010 - (Xk) = 0123 4567 7777 3210 1100 - (Xi) = 0000 3210 7654 7777 0110 This instruction compares bit patterns or complements bit patterns during data processing. 14ixk Transmit Complement of (Xk) to Xi BXi -Xk This instruction reads a 60-bit word from Xk, complements the word, and writes the result into Xi. This instruction changes the sign of a fixed-point or floating-point quantity. The instruction also inverts an entire 60-bit field during data processing. 15ijk Logical Product of (Xj) with BXi -Xk \* Xj Complement of (Xk) to Xi | 14 | | 9 | 8 6 | 5 3 | 2 0 | |----|----|---|-----|-----|-----| | | 15 | | ï | j | k | This instruction reads operands from two X registers, operates upon them to form a result, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. The result delivered to Xi is the bit-by-bit logical product of the value in Xj and the complement of the value in Xk. Each of the 60 bits in Xj is compared with the corresponding bit in Xk to form a single bit in Xi. A sample computation is listed in octal notation to illustrate the operation performed and includes the four possible bit combinations that may occur. - $(X_1) = 7777 7000 0123 4567 1010$ - (Xk) = 0123 4567 0007 7700 1100 - (Xi) = 7654 3000 0120 0067 0010 This instruction extracts portions of a 60-bit word during data processing. l6ijk Logical Sum of (Xj) with BXi -Xk + Xj Complement of (Xk) to Xi | 14 | 98 | 65 | 3 | 20 | |----|----|----|---|----| | 16 | li | | j | k | This instruction reads operands from two X registers, operates upon them to form a result, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. The result delivered to Xi is the bit-by-bit logical sum of the value in Xj and the complement of the value in Xk. Each of the 60 bits in Xj is compared with the corresponding bit in Xk to form a single bit in Xi. A sample computation is listed in octal notation to illustrate the operation performed and includes the four possible bit combinations that may occur. - (Xj) = 0000 7777 0123 4567 1010 - (Xk) = 0123 4567 7777 0000 1100 - (Xi) = 7654 7777 0123 7777 7677 This instruction merges portions of a 60-bit word into a composite word during data processing. 17ijk Logical Difference of (Xj) BXi -Xk - Xj with Complement of (Xk) to Xi | 14 | | 9 | 8 6 | 5 3 | 2 0 | |----|----|---|-----|-----|-----| | | 17 | | i | j | k | This instruction reads operands from two X registers, operates upon them to form a result, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. The result delivered to Xi is the bit-by-bit logical difference of the value in Xj and the complement of the value in Xk. Each of the 60 bits in Xj is compared with the corresponding bit in Xk to form a single bit in Xi. A sample computation is listed in octal notation to illustrate the operation performed and includes the four possible combinations that may occur. - (Xj) = 0123 7777 0123 4567 1010 - (Xk) = 0123 4567 7777 3210 1100 - (X1) = 7777 4567 0123 0000 7667 This instruction compares bit patterns or complements bit patterns during data processing. 20ijk Left Shift (Xi) by jk LXi jk | 14 | 9 | 8 6 | 5 5 | 0 | |----|---|-----|-----|----| | 20 | | i | | jk | This instruction reads one operand from Xi, shifts the 60-bit word left circularly by jk bit positions, and writes the resulting 60-bit word back into the same Xi register. The j and k designators are treated as a single 6-bit positive integer operand in this instruction. A left-circular shift implies that the bit pattern in the 60-bit word is displaced towards the highest-order bit positions. The bits shifted off the upper end of the 60-bit word are inserted in the lowest-order bit positions in the same sequence. The resulting 60-bit word has the same quantity of bits with values of one and zero as in the original operand. A sample computation is listed in octal notation to illustrate the operation performed. Initial (Xi) = 2323 6600 0000 0000 0111 $$jk = 12 (octal)$$ This instruction, together with instruction 21, may be used whenever a data word is to be shifted by a predetermined amount. If the amount of shift is derived in the execution of the program, instruction 22 or 23 should be used. 21ijk Right Shift (Xi) by jk AXi ik | <u>14</u> | 98 | 6 | 5 | 0 | |-----------|----|---|---|----| | 21 | | i | | jk | This instruction reads one operand from Xi, shifts the 60-bit word right with sign extension by jk bit positions, and writes the resulting 60-bit word back into the same Xi register. The j and k designators are treated as a single 6-bit positive integer operand in this instruction. A right shift with sign extension implies that the bit pattern in the 60-bit word is displaced toward the lowest-order bit positions. The bits shifted off the lower end of the word are discarded. The highest-order bit positions are filled with copies of the original sign bit. Two sample computations are listed in octal notation to illustrate the operation performed. The first example contains a positive operand, and the second example contains a negative operand. Initial (Xi) = 2004 7655 0002 3400 0004 jk = 30 (octal) Final (Xi) = 0000 0000 2004 7655 0002 Initial (Xi) = 6000 4420 2222 0000 5643 jk = 10 (octal) Final (Xi) = 7774 0011 0404 4440 0013 This instruction, together with instruction 20, may be used whenever a data word is to be shifted by a predetermined amount. If the amount of shift is derived in the execution of the program, instruction 22 or 23 should be used. 22ijk Left Shift (Xk) Nominally (Bj) Places to Xi LXi Bj, Xk | 14 | 98 | 6 | 5 3 | 2 0 | |----|----|---|-----|-----| | 22 | | i | j | k | This instruction reads a 60-bit operand from Xk, shifts the data either left or right as specified by Bj, and writes the resulting 60-bit word into Xi. If the value in Bj is positive, the data is left shifted circularly the number of bit positions designated by the value in Bj. If the value in Bj is negative, the data is right shifted with sign extension the number of bit positions designated by the value in Bj. The sign of Bj is determined by Bj bit 17. A left circular shift implies that the bit pattern in the 60-bit word is displaced towards the highest-order bit positions. The bits shifted off the upper end are inserted in the lowest-order bit positions in the same sequence. The resulting 60-bit word has the same quantity of bits with values of one and zero as in the original operand. A right shift with sign extension implies that the bit pattern in the 60-bit word is displaced towards the lowest-order positions. The bits shifted off the lower end are discarded. The highest-order bit positions are filled with copies of the original sign bit. Two sample computations are listed in octal notation to illustrate the operation performed. The first example contains a positive shift count resulting in a left circular shift, and the second example illustrates the right shift with sign extension. - (Xk) = 2323 6600 0000 0000 0111 - (Bj) = 00 0012 - (Xi) = 7540 0000 0000 0022 2464 - (Xk) = 1327 6000 0000 3333 2422 - $(B_1) = 77 7771$ - (Xi) = 0013 2760 0000 0033 3324 If Bj bits 6 through 10 are different from Bj bit 17 and Bj bit 17 is set, the shift count is greater than 63 (decimal) places right, and a result of positive zero is returned to Xi. Bj bits 11 through 16 are not tested by this instruction. This instruction is used when the amount of shift is derived in the computation. The instruction is also used for correcting the coefficient of a floating-point number when the exponent has been unpacked into a B register. 23ijk Right Shift (Xk) Nominally (Bj) Places to Xi AXi Bj, Xk | 14 | 9 | 8 6 | 5 3 | 2 0 | |----|---|-----|-----|-----| | 23 | | i | j | k | This instruction reads a 60-bit operand from Xk, shifts the data either left or right as specified by the content of Bj, and writes the resulting 60-bit word into Xi. If the value in Bj is positive, the data is right shifted with sign extension the number of bit positions designated by the value in Bj. If the value in Bj is negative, the data is left shifted circularly the number of bit positions designated by the value in Bj. The sign of Bj is determined by Bj bit 17. A left circular shift implies that the bit pattern in the 60-bit word is displaced towards the highest-order bit positions. The bits shifted off the upper end are inserted in the lowest-order bit positions in the same sequence. The resulting 60-bit word has the same quantity of bits with values of one and zero as in the original operand. A right shift with sign extension implies that the bit pattern in the 60-bit words is displaced towards the lowest-order bit positions. The bits shifted off the lower end of the word are discarded. The highest-order bit positions are filled with copies of the original sign bit. Two sample computations are listed in octal notation to illustrate the operation performed. The first example contains a positive shift count resulting in a right shift with sign extension, and the second example contains a negative shift count resulting in a left circular shift. - (Xk) = 1327 6000 0000 3333 2422 - $(B_1) = 00 0006$ - (Xi) = 0013 2760 0000 0033 3324 - (Xk) = 2323 6600 0000 0000 0111 - (Bj) = 77 7765 - $(Xi) = 7540\ 0000\ 0000\ 0022\ 2464$ If Bj bits 6 through 10 are different from Bj bit 17 and Bj bit 17 is clear, the shift count is greater than 63 (decimal) places right, and a result of positive zero is returned to Xi. Bj bits 11 through 16 are not tested by this instruction. This instruction is used when the amount of shift is derived in the computation. The instruction is also used for correcting the coefficient of a floating-point number when the exponent has been unpacked into a B register. 24ijk Normalize (Xk) to Xi and Bj NXi Bj, Xk | ŀ | 4 | 9 | 8 6 | 5 3 | 2 0 | |---|----|-----|-----|-----|-----| | | 24 | > - | ï | j | k | | • | | | | | | This instruction reads one operand from Xk, performs a normalizing operation on this word in floating-point format, and delivers the normalized result to Xi. In addition, a positive integer shift count is sent to Bj. This shift count is the number of bit positions of shift required to normalize the original operand coefficient. The normalizing operation consists of repositioning the coefficient portion of the operand and then adjusting the exponent portion of the operand to leave the value of the result unaltered. The coefficient is shifted towards the higher-order bit positions of the word. The coefficient is shifted the minimum number of bit positions required to make bit 47 different from sign bit 59. This places the most significant bit of the coefficient in the highest-order position. The exponent is then decreased by the number of bit positions shifted. Two sample computations are listed in octal notation to illustrate the operation performed. The first example involves a positive floating-point number, and the second example involves a negative number. $(Xk) = 2034 \ 0047 \ 6500 \ 0000 \ 2262$ (Xi) = 2026 4765 0000 0022 6200 (Bj) = 00 0006 (Xk) = 5743 7730 1277 7777 5515 (Xi) = 5751 3012 7777 7755 1577 (Bj) = 00 0006 Normalizing a number with either a positive or negative zero coefficient sets a shift count in Bj to 48 (decimal) and enters Xi with positive zero. If Xk contains an infinite quantity (3777xxx...x or 4000xxx...x) or an indefinite quantity (1777xxx...x or 6000xxx...x), no shift takes place. The content of Xk is copied to Xi, and Bj is set to zero. Corresponding infinite and indefinite exit conditions are also set in the CP for exit mode action. If the exponent is less than negative 1777 with a zero coefficient, the contents of Xi and Bj are set to zero. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 25ijk Round Normalize (Xk) to Xi and Bj ZXi Bj, Xk | 14 | 9 | 8 6 | 5 3 | 3 2 | 0 | |----|---|-----|-----|-----|---| | 25 | | i | j | | k | This instruction reads one operand from Xk, performs a rounding and then a normalizing operation in floating-point format, and delivers the round normalized result to Xi. In addition, a positive integer shift count is sent to Bj. This shift count is the number of bit positions of shift required to normalize the original operand coefficient. The rounding operation consists of adding a bit to the coefficient portion of the operand in a bit position immediately below the least significant bit position. This round bit has a value equal to the complement of the operand sign bit. The result increases the magnitude of the coefficient by one-half the value of the least significant bit. The normalizing operation consists of repositioning the coefficient and adjusting the exponent to leave the value of the resulting floating-point quantity unaltered. The coefficient is shifted towards the higher-order bit positions. The round bit is shifted along with the coefficient. The displacement is the minimum number of bit positions required to make bit 47 different from sign bit 59. This places the most significant bit of the coefficient in the highest-order bit position. The exponent is decreased by the number of bit positions shifted. Two sample computations are listed in octal notation to illustrate the normalizing operation performed. The first example involves a positive floating-point number, and the second example involves a negative number. (Xk) = 2034 0047 6500 0000 2262 (Xi) = 2026 4765 0000 0022 6420 (Bj) = 00 0006 (Xk) = 5743 7730 1277 7777 5515 (Xi) = 5751 3012 7777 7755 1537 (Bj) = 00 0006 If Xk contains either an infinite quantity (3777xxx...x or 4000xxx...x) or an indefinite quantity (1777xxx...x or 6000xxx...x), no shift takes place. The content of Xk is copied to Xi, and Bj is set to zero. Corresponding infinite and indefinite exit conditions are also set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 26ijk Unpack (Xk) to Xi and Bj UXi Bj, Xk | 14 | 98 | <u>6:</u> | <u> 5</u> | <u> 20</u> | |----|----|-----------|-----------|------------| | 26 | | i | Ĺ | k | This instruction reads one operand from Xk, unpacks this word from floating-point format, and delivers the coefficient and exponents to Xi and Bj, respectively. The 60-bit word delivered to Xi consists of the lowest 48 bits unaltered from the original operand plus the upper 12 bits, each equal to the original sign bit. This is a signed integer equal to the value of the coefficient in the original operand. The 18-bit quantity delivered to Bj is a signed integer equal to the value of the exponent in the original operand. The 11-bit exponent field in the operand is altered to remove the bias and then sign extended to fill out the 18-bit quantity. The sign of the coefficient is removed in this process. Four sample sets of operands and unpacked results are listed in octal notation to illustrate the operation performed. These examples contain the four combinations of coefficient sign and exponent sign. (Xk) = 2034 4500 3333 2000 0077 (Xi) = 0000 4500 3333 2000 0077 (Bj) = 00 0034 (Xk) = 1743 4500 3333 2000 0077 (Xi) = 0000 4500 3333 2000 0077 (Bj) = 77 7743 (Xk) = 5743 3277 4444 5777 7700 (Xi) = 7777 3277 4444 5777 7700 - (Xk) = 6034 3277 4444 5777 7700 - (Xi) = 7777 3277 4444 5777 7700 - (Bj) = 77 7743 This instruction converts a number from floating-point format to fixed-point format. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 27ijk Pack (Xk) and (Bj) to Xi PXi Bj, Xk | 14 | | 9 | 8 | 6 | 5 | 32 | 0 | |----|----|---|---|---|---|----|---| | | 27 | | i | | j | Ι | k | This instruction reads the contents of Xk and Bj, packs them into a single word in floating-point format, and delivers this result to Xi. The coefficient for the value in Xi is obtained from the content of Xk, which is treated as a signed integer. The exponent for the value in Xi is obtained from the content of Bj, which is treated as a signed integer. The lowest-order 48 bits in Xi are copied directly from the lowest-order 48 bits in Xk. The sign bit in Xi is copied directly from the sign bit in Xk. The exponent field in Xi is derived from the value in Bj by extracting the lowest-order 11 bits in Bj and modifying this quantity for exponent bias and coefficient sign. Four sample sets of operands and packed results are listed in octal notation to illustrate the operation performed. These examples contain the four combinations of coefficient sign and exponent sign. - (Xk) = 0000 4500 3333 2000 0077 - (Bj) = 00 0034 - (Xi) = 2034 4500 3333 2000 0077 - (Xk) = 0000 4500 3333 2000 0077 - (Bj) = 77 7743 - (Xi) = 1743 4500 3333 2000 0077 - (Xk) = 7777 3277 4444 5777 7700 - (Bj) = 00 0034 - (Xi) = 5743 3277 4444 5777 7700 - (Xk) = 7777 3277 4444 5777 7700 - (Bj) = 77 7743 - (Xi) = 6034 3277 4444 5777 7700 This instruction converts a number in fixed-point format to floating-point format. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. | 14 | . 9 | 8 6 | 5 3 | 2 0 | |----|-----|-----|-----|-----| | | 30 | i | j | k | This instruction reads operands from two X registers, operates upon them to form a floating-point sum, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are in floating-point format and are not necessarily normalized. The sum of the quantities in Xj and Xk is delivered to Xi in floating-point format and is not necessarily normalized. The two operands are unpacked from floating-point format, and the exponents are compared. The coefficient with the smaller exponent is right shifted by the difference of the two exponents such that both coefficients are the same significance. The two coefficients are then added to form a 96-bit result. The upper half of the result is then selected as a coefficient and packed along with the larger exponent to form the result sent to Xi. If coefficient overflow occurs, the sum is right shifted one place, and the exponent is increased by one. If the two operands have unlike signs, the result coefficient may have leading zeros. No normalize operation is built into this instruction to correct this situation. A separate normalize instruction must be programmed if the result is to be kept in a normalized form. When the difference between the exponents is greater than 128 (decimal), the shifted sign bit is extended to the entire shifted operand. Infinite (3777xxx...x or 4000xxx...x) or indefinite (1777xxx...x or 6000xxx...x) operands cause corresponding exit conditions to set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 31ijk Floating Difference of (Xj) and (Xk) to Xi | 14 | 9 | 8 6 | 5 3 | 2 0 | | |----|---|-----|-----|-----|---| | 31 | | - | j | k | l | This instruction reads operands from two X registers, operates upon them to form a floating-point difference, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are in floating-point format and are not necessarily normalized. The result of subtracting the quantity in Xk from the quantity in Xj is delivered to Xi in floating-point format and is not necessarily normalized. The two operands are unpacked from floating-point format, and the exponents are compared. The coefficient with the smaller exponent is right shifted by the difference of the two exponents such that both coefficients are the same significance. The Xk coefficient is then subtracted from the Xj coefficient to form a 96-bit result. The upper half of the result is then selected and packed along with the larger exponent to form the result sent to Xi. If coefficient overflow occurs, the result is right FXi Xj - Xk shifted one place, and the exponent is increased by If the two operands have like signs, the result coefficient may have leading zeros. No normalize operation is built into this instruction to correct this situation. A separate normalize instruction must be programmed if the result is to be kept in a normalized form. Infinite (3777xxx...x 4000xxx...x) or indefinite (1777xxx...x or 6000xxx...x) operands cause corresponding exit conditions to set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 32ijk Floating Double-Precision Sum DXi Xj + Xk of (Xj) and (Xk) to Xi | 14 | | 9 | 8 | 6 | 5 | 3 | 2 | ( | ) | |----|----|---|---|---|---|---|---|---|---| | | 32 | | i | | j | | | k | 1 | This instruction reads operands from two X registers, operates upon them to form a double-precision floating-point sum, and delivers the lower half of this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are in floating-point format and are not necessarily normalized. The sum of the quantities in Xj and Xk is delivered to Xi in floating-point format and is not necessarily normalized. The two operands are unpacked from floating-point format, and the exponents are compared. The coefficient with the smaller exponent is right shifted by the difference of the two exponents such that both coefficients are the same significance. The two coefficients are then added to form a 96-bit result. The lower half of the result is then selected and packed along with the larger exponent minus 48 (decimal) to form the result sent to Xi. If coefficient overflow occurs, the result is right shifted by one place, and the exponent is increased by one. Infinite (3777xxx...x or 4000xxx...x) or indefinite (1777xxx...x or 6000xxx...x) operands cause corresponding exit conditions to set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 33ijk Floating Double-Precision DXi Xj - Xk Difference of (Xj) and (Xk) to Xi | 14 | 98 | 6 5 | 3 | 2 0 | |----|----|-----|---|-----| | 33 | | i | j | k | This instruction reads operands from two X registers, operates upon them to form a double-precision floating-point difference, and delivers the lower half of this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are in floating-point format and are not necessarily normalized. The result of subtracting the quantity in Xk from the quantity in Xj is delivered to Xi in floating-point format and is not necessarily normalized. The two operands are unpacked from floating-point format, and the exponents are compared. The coefficient with the smaller exponent is right shifted by the difference of the two exponents such that both coefficients are the same significance. The Xk coefficient is then subtracted from the Xj coefficient to form a 96-bit result. The lower half of the result is then selected and packed along with the larger exponent minus 48 (decimal) to form the result sent to Xi. If coefficient overflow occurs, the result is right shifted one place, and the exponent is increased by one. Infinite (3777xxx...x or 4000xxx...x) or indefinite (1777xxx...x or 6000xxx...x) operands cause corresponding exit conditions to set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 34ijk Round Floating Sum of (Xj) RXi Xj + Xk and (Xk) to Xi | 14 | 9 | 8 | 6 | 5 | 32 | 0 | |----|---|---|---|---|----|---| | 34 | | i | | j | | k | This instruction reads operands from two X registers, operates upon them to form a rounded floating-point sum, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are in floating-point format and are not necessarily normalized. The result is delivered to Xi in floating-point format and is not necessarily normalized. The round floating-point sum is a single-precision floating-point sum with a round bit (or bits) inserted before the add operation takes place. A round bit is always inserted in the coefficient with the larger exponent. If the two exponents are equal, the round bit is inserted in the coefficient for Xk. The round bit is equal to the complement of the sign bit and is inserted immediately to the right of the lowest-order bit in the coefficient. This has the effect of increasing the magnitude of the coefficient by one-half of the least significant bit. A second round bit is inserted in a corresponding manner to the other coefficient if both operands are normalized or have unlike signs. The second round bit is inserted before the coefficient has been shifted by the difference of the exponents. Infinite (3777xxx...x or 4000xxx...x) or indefinite (1777xxx...x or 6000xxx...x) operands cause corresponding exit conditions to set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 35ijk Round Floating Difference RXi Xj - Xk of (Xj) and (Xk) to Xi | 14 | 9 | 8 6 | 5 3 | 2 0 | |----|---|-----|-----|-----| | 35 | | i | j | k | This instruction reads operands from two X registers, operates upon them to form a rounded floating-point difference, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are in floating-point format and are not necessarily normalized. The result of subtracting the quantity in Xk from the quantity in Xj is delivered to Xi in floating-point format and is not necessarily normalized. The round floating-point difference is single-precision floating-point difference with a round bit (or bits) inserted before the subtract operation takes place. A round bit is always inserted in the coefficient with the larger exponent. If the two exponents are equal, the round bit is added to the coefficient for Xk. The round bit is equal to the complement of the sign bit and is inserted immediately to the right of the lowest-order bit in the coefficient. This has the effect of increasing the magnitude of the coefficient by one-half of the least significant bit. A second round bit is inserted in a corresponding manner to the other coefficient if both operands are normalized or have like signs. The second round bit is inserted before the coefficient has been shifted by the difference of the exponents. Infinite 4000xxx...x) or indefinite (3777xxx...x or (1777xxx...x or 6000xxx...x) operands cause corresponding exit conditions to set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 36ijk Integer Sum of (Xj) and (Xk) to Xi IXi Xj + Xk This instruction reads operands from two X registers, operates upon them to form a 60-bit integer sum, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are signed integers. The resulting integer sum is delivered to Xi. Overflow is not detected. This instruction adds integers too large for handling by 50 through 77 instructions. The instruction also merges and compares data fields during data processing. For further information, refer to Integer Arithmetic under CP Programming in section 5. 37ijk Integer Difference of (Xj) IXi Xj - Xk and (Xk) to Xi 14 98 65 32 0 37 | i | j | k This instruction reads operands from two X registers, operates upon them to form a 60-bit integer difference, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are signed integers. The result of subtracting the quantity in Xk from the quantity in Xj is delivered to Xi. Overflow is not detected. This instruction subtracts integers too large for handling by 50 through 77 instructions. The instruction also compares data fields during data processing. For further information, refer to Integer Arithmetic under CP Programming in section 5. 40ijk Floating Product of (Xj) and FXi Xj \* Xk (Xk) to Xi | 14 | 9 | 8 6 | 5 3 | 2 0 | |----|----|-----|-----|-----| | | 40 | - | j | k | This instruction reads operands from two X registers, operates upon them to form a floating-point product, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are in floating-point format and are not necessarily normalized. The result is delivered to Xi in floating-point format. If both operands are normalized, the result is also normalized. If both operands are not normalized, the result is not normalized. The two operands are unpacked from floating-point format. The exponents are added with a correction factor to determine the exponent for the result. The coefficients are multiplied as signed integers to form a 96-bit integer product. The upper half of this product is extracted to form the coefficient for the result. If the original operands are normalized and the product has only 95 significant bits, a 1-bit left shift to normalize the result coefficient is done. The resulting exponent is reduced by one count in this case. If both operands are not normalized, the resulting double-precision product has less than 96 significant bits. No test is made for the position of the most significant bit. The upper 48 bits are read from the double-precision product register. Leading zeros occur in this result coefficient. This instruction is used in floating-point calculations where rounding of operands is not desired, such as in multiple-precision arithmetic and in calculations involving error analysis. Infinite (3777xxx...x or 4000xxx...x) or indefinite (1777xxx...x or 6000xxx...x) operands cause corresponding exit conditions to set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 4lijk Round Floating Product of RXi Xj \* Xk (Xj) and (Xk) to Xi | 14 9 | 8 | 65 | 32 | 0 | |------|---|----|----|---| | 41 | 1 | | j | k | This instruction reads operands from two X registers, operates upon them to form a rounded floating-point product, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are in floating-point format and are not necessarily normalized. The result is delivered to Xi in floating-point format. If both operands are normalized, the result is also normalized. If both operands are not normalized, the result is not normalized. The two operands are unpacked from floating-point format. The exponents are added with a correction factor to determine the exponent for the result. The coefficients are multiplied as signed integers to form a 96-bit integer product. A rounding bit is added to bit position 46 of this product. The upper half of this product is extracted to form the coefficient for the result. If the original operands are normalized and the product has only 95 significant bits, a 1-bit left shift to normalize the result coefficient is done. The resulting exponent is reduced by one count in this case. If both operands are not normalized, the resulting double-precision product has less than 96 significant bits. No test is made for the position of the most significant bit. The upper 48 bits are read from the double-precision product register. Leading zeros occur in this result coefficient. This instruction is used in single-precision floating-point calculations. For multiple-precision calculations, the 40 and 42 instructions must be used. Infinite (3777xxx...x or 4000xxx...x) or indefinite (1777xxx...x or 6000xxx...x) operands cause corresponding exit conditions to set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 42ijk Floating Double-Precision DXi Xj \* Xk Product of (Xj) and (Xk) to Xi | ŀ | 4 | 9 | 8 | 6 | 5 | 3 | 2 | 0 | |---|----|---|---|---|----|---|---|---| | ſ | 42 | | ī | | Π. | j | k | ٦ | This instruction reads operands from two X registers, operates upon them to form a double-precision floating-point product, and delivers the lower half of this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are in floating-point format and are not necessarily normalized. The lower half of the double-precision product is delivered to Xi in floating-point format and is not necessarily normalized. The operands are not rounded in this operation. The two operands are unpacked from floating-point format. The exponents are added to determine the exponent for the result. The result exponent is exactly 48 less than the exponent for a 40 instruction. The coefficients are multiplied as signed integers to form a 96-bit integer product. The lower half of this product is extracted to form the coefficient for the result. If the original operands are normalized and the double-precision product has only 95 significant bits, a 1-bit left shift to normalize the result coefficient is done. The resulting exponent is reduced by one count in this case. If both operands are not normalized, the resulting double-precision product has less than 96 significant bits. No test is made for the position of the most significant bit. The lower 48 bits are always read from the 96-bit product register. This instruction is used in multiple-precision floating-point calculations. This instruction also provides for integer multiplication capabilities where both operands have an exponent value of plus or minus zero, and neither coefficient has been normalized. The integer result sent to Xi is 48 bits with 60-bit sign extension. If the result exceeds 48 bits, the hardware does not detect an overflow. An overflow check can be made by executing a 40 instruction using the same two operands. If the result is nonzero, overflow is then indicated. An integer multiply operation is not intended to be used with normalized operands. Infinite (3777xxx...x and 4000xxx...x) or indefinite (1777xxx...x or 6000xxx...x) operands cause corresponding exit conditions to set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 43ijk Form Mask of jk Bits to Xi MXi jk | 14 | 9 8 | 3 | 6 | 5 | 3 | 2 | 0 | |----|-----|---|---|---|---|---|---| | 43 | T | i | | j | | k | | This instruction generates a masking word using the j and k designators as parameters. No operands are read from operating registers. The j and k designators are treated as a single 6-bit octal quantity to designate the width of the masking field. A field of ones, beginning at the highest-order end of the word, is extended downward on a background of zeros. The completed masking word consists of one bits in the highest-order jk bit positions and zero bits in the remainder of the word. This masking word is then delivered to Xi. The following are sample parameters. $$j = 2$$ k = 4 Xi = 7777 7760 0000 0000 0000 This instruction generates variable width masks for logical operations. This instruction, together with a shift instruction, generally creates an arbitrary field mask faster than reading a pregenerated mask from CM. 44ijk Floating Divide (Xj) by (Xk) to Xi FXi Xj/Xk This instruction reads operands from two X registers, operates upon them to form a floating-point quotient, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are in floating-point format. The result of dividing the content of Xj by the content of Xk is delivered to Xi. If both operands are normalized, the quotient is also normalized. The remainder from the division process is discarded. The two operands are unpacked from floating-point format. The exponents are subtracted with a correction factor to determine the exponent for the result. The coefficient from Xj is positioned in a dividend register. The coefficient from Xk is trial-subtracted repeatedly from the dividend. The quotient bits are assembled in a quotient register. When 48 bits of the quotient are assembled, they are packed with the result exponent into floating-point format and delivered to Xi. If the exponent subtraction causes an underflow or overflow, an underflow or overflow result is returned even with the occurrence of a divide fault. If the dividend is not normalized, the quotient cannot be normalized. However, the quotient is correct even though there may be leading zeros in the coefficient. If the divisor is not normalized, the quotient may be incorrect. If the coefficient for the content of Xj is larger than the coefficient for the content of Xk by a factor of two or more, a divide fault causes an indefinite result to be returned to Xi. This instruction is used in floating-point calculations where rounding of operands is not desired. In multiple-precision division, this instruction must be followed by a multiplication of the quotient by the divisor and subtracted from the dividend to reconstruct the remainder. If infinite (3777xxx...x or 4000xxx...x) or indefinite (1777xxx...x or 6000xxx...x) operands are used, corresponding exit conditions are set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 45ijk Round Floating Divide (Xj) by (Xk) to Xi RXi Xj/Xk | 14 | 9 | 8 6 | 5 3 | 2 0 | |----|----|-----|-----|-----| | | 45 | i | j | k | This instruction reads operands from two X registers, operates upon them to form a rounded floating-point quotient, and delivers this result to a third X register. The operands for this instruction are in Xj and Xk. These operands are in floating-point format. The result of dividing the content of Xj by the content of Xk is delivered to Xi. If both operands are normalized, the quotient is also normalized. The remainder from the division process is discarded. The two operands are unpacked from floating-point format in this operation. The exponents are subtracted with a correction factor to determine the exponent for the result. The coefficient from Xj is positioned in a dividend register. The Xj quantity is modified by inserting a 2525...25 round pattern below the lowest-order bit of the dividend coefficient. The coefficient from Xk is trialsubtracted repeatedly from the dividend. The quotient bits are assembled in a quotient register. When 48 bits of the quotient are assembled, they are packed with the result exponent into floating-point format and delivered to Xi. If the dividend is not normalized, the quotient cannot be normalized. However, the quotient is correct even though there may be leading zeros in the coefficient. If the divisor is not normalized, the quotient may be incorrect. If the coefficient for the content of Xj is larger than the coefficient for the content of Xk by a factor of two or more, a divide fault occurs. A divide fault causes an indefinite result to be returned to Xi. This instruction is used in single-precision floating-point calculations where rounding of operands is desired to reduce truncation errors. If infinite (3777xxx...x or 4000xxx...x) or indefinite (1777xxx...x or 6000xxx...x) operands are used, corresponding exit conditions are set in the CP for exit mode action. For further information, refer to Floating-Point Arithmetic under CP Programming in section 5. 460xx through 463xx Pass NO These instructions fill program instruction words where necessary to match jump destinations with word boundaries. The j and k designators are ignored, and a nonzero value has no effect in this instruction. 464 through 467 Compare/Move The compare/move instructions (also referred to as CMU instructions) are provided for compatibility with previous systems. For better performance, recompile jobs to avoid use of CMU instructions. $\mbox{CMU}$ instructions must appear in parcel 0 or they are treated as illegal instructions. Data fields consisting of 6-bit characters may start or end with any character position (offset) of the 10 6-bit positions in each word. The character positions are designated as follows: For move instructions, a Kl designator specifies which CM word contains the first character of the source data field, and a Cl designator specifies the character position (offset) of the first character. The K2 designator specifies the CM location in which the first character of the result data field is placed, and the C2 designator specifies the first character position. For compare instructions, both data field addresses specify source fields. ## Example: If the instruction is K1=1000 and C1=3, the first character of the source field is in position 3 of location 1000. Therefore, the first character of the source field is 71. An address is out of range if Cl or C2 is greater than 9, Kl plus Nl is greater than the program field length for CM (FLC), or K2 plus N2 is greater than FLC. Nl equals the number of CM references made to the source data field starting at Kl, and N2 equals the number of CM references made to the result data field starting at K2. When an address-out-of-range condition occurs, the CMU instruction is not executed. LL is the lower 4 bits, and LU is the upper 9 bits of the field length designator in numbers of characters. The maximum length of the data fields for the move direct and the compare instructions is 127 (1778) characters. The maximum data field length for the move indirect instruction is 8191 (177778) characters. If L (LU and LL combined) is zero, the instruction becomes a pass. For overlapping move instructions, the address of the source field (specified by K1) must be greater than the address of the result field (specified by K2) to provide proper field overlap. If K1 is less than K2, part of the source field is changed during execution, with the amount of change determined by the number of CM conflicts encountered. Overlapping fields should not contain more than 377 (octal) characters, because an exchange jump interrupts any compare/move operation having a decremented field length greater than 377 (octal). 464 jK Move Indirect IM Bj + K | 59 5150 48 | 3 4 7 | 30 29 | . 0 | |------------|-------|-------|-----| | 464 j | к | | | Any instructions located in the lower two parcels of the instruction word do not execute. Bj plus K specifies a relative address in CM for the following descriptor word. | <u>59 57 56 48</u> | 47 3 | 50 29 26 | 25 22 | 21 18 | 17 0 | |--------------------|------|----------|-------|-------|------| | LU | KI | L | CI | C2 | K2 | The descriptor word specifies the movement of the source field to the result field. The movement is from left to right through the field. Register XO clears at the end of the execution. 465 Move Direct DM | 59 51 | 5048 | 47 3 | 302926 | 25 22 | 21 18 | 17 0 | |-------|------|------|--------|-------|-------|------| | 465 | LU | KI | LL | CI | C2 | K2 | This instruction moves the source field to the result field as specified by the 60-bit instruction word. The field length is limited to a 7-bit count. 466 Compare Collated CC | 59 5150 48 47 | | | 302926252221 1817 | | | | | 0 | | |---------------|----|----|-------------------|--|----|----|----|----|---| | 46 | 56 | LU | KI | | LL | CI | C2 | K2 | 7 | This instruction compares the field designated by Kl,Cl with the field designated by K2,C2 as specified by the 60-bit instruction word. The compare is from left to right through the fields until two unequal characters are found. These two characters are then collated and referenced in the collate table beginning at address AO (table 4-2). If the table values found for the two unequal characters are equal, the compare continues until another pair of characters is unequal or until the field length is exhausted. If the table values found for the two unequal characters are unequal, XO is set prior to instruction termination as follows: If field Kl is greater than field K2, set X0 to 0000 0000 0000 0000 0xxx. If field Kl is equal to field K2, set XO to 0000 0000 0000 0000 0000. If field Kl is less than field K2, set XO to 7777 7777 7777 7777 7yyy where yyy is the complement of xxx. The value of the three octal numbers xxx, stored in XO, is determined by the equation L minus N equals xxx (L is the length of the field, and N is the number of pairs of characters that were collated equal prior to instruction termination). In other words, xxx is the number of pairs of characters not yet compared plus one. The AO register contains the starting word address of an 8-word, 64-character collate table (table 4-2). This table must have been previously stored in consecutive CM locations. The collated value of a character is found by examining the collate table. The upper 3 bits of the character to be collated are added to AO to obtain the relative address of the word containing the collated value. The lower 3 bits of the character to be collated specify the character address of the collated value. ## Example: Suppose the character under examination is an octal 63. The 6 is added to the AO to form the word address. The 3 is used to pick the correct character from that word. The value of 63 is 63 in the collate table. Table 4-2. Collate Table | | Address | | C | olla | ting | Cha | ract | er L | ocat | ions | | |---|------------|----|----|------|------|-----|------|------|------|------|----| | | <b>A</b> 0 | 00 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | хx | хх | | | A0+1 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | хx | хx | | I | A0+2 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | хх | хx | | | A0+3 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | хx | хx | | | A0+4 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | хх | хx | | | A0+5 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | хx | хх | | l | A0+6 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | хх | жх | | | A0+7 | 70 | 71 | 72 | 73 | 74 | 75 | 76 | 77 | хх | жх | | 59 51504847 | | | 47 | 302926252221 1817 | | | | | | |-------------|-----|----|----|-------------------|----|----|----|---|--| | | 467 | LU | KI | LL | CI | C2 | K2 | ٦ | | This instruction is similar to the 466 instruction except that the collate table is not used. The XO register is set when the first pair of unequal characters is encountered or when the field length is exhausted. 47ixk Population Count of (Xk) to Xi CXi Xk CU - This instruction reads one operand from Xk, counts the number of one bits in the operand, and stores the count in Xi. The count delivered to Xi is a positive integer. If the operand is all ones, a count of 60 (decimal) is delivered to Xi. If operand is all zeros, a zero word is delivered to Xi. 50ijK Set Ai to (Aj) + K SAi Aj + K | <u>29</u> | 24 | 23 21 | 20 18 | 317 | 0 | |-----------|----|-------|-------|-----|---| | | 50 | i | j | K . | ٦ | This two-parcel instruction uses the lower-order 18 bits as operand K. This instruction reads an operand from Aj, forms the sum of the operand plus K, and delivers the result to Ai. If the i designator is nonzero, a reference is made to CM using the result as the relative address. The type of reference is a function of the i designator value. i = 0 No CM reference i = 1, 2, 3, 4, 5 Read from CM to Xi i = 6,7 Write into CM from Xi This instruction obtains operands from CM for computation and delivers the result back into CM. 5lijK Set Ai to (Bj) + K SAi Bj + K This two-parcel instruction uses the lower-order 18 bits as operand K. This instruction reads an operand from Bj, forms the sum of the operand plus K, and delivers the result to Ai. If the i designator is nonzero, a reference is made to CM using the result as the relative address. The type of reference is a function of the i designator value. i = 0 No CM reference i = 1,2,3,4,5 Read from CM to Xi i = 6,7 Write into CM from Xi This instruction obtains operands from CM for computation and delivers the result back into CM. 29 2423 2120 1817 0 52 i j K This two-parcel instruction uses the lower-order 18 bits as operand K. This instruction reads an operand from Kj, forms the sum of the operand plus K, and delivers the result to Ai. If the i designator is nonzero, a reference is made to CM using the result as the relative address. The type of reference is a function of the i designator value. i = 0 No CM reference i = 1, 2, 3, 4, 5 Read from CM to Xi i = 6.7 Write into CM from Xi This instruction obtains operands from CM for computation and delivers the result back into CM. 53ijk Set Ai to (Xj) + (Bk) SAi Xj + Bk | 14 | 9 | 8 6 | 5 3 | 2 | _0 | |----|---|-----|-----|---|----| | 53 | | i | j | Π | k | This instruction reads operands from Xj and Bk, forms the sum of the operands, and delivers the result to Ai. If the i designator is nonzero, a reference is made to CM using the result as the relative address. The type of reference is a function of the i designator value. i = 0 No CM reference i = 1,2,3,4,5 Read from CM to Xi i = 6.7 Write into CM from Xi This instruction obtains operands from CM for computation and delivers the result back into CM. 54ijk Set Ai to (Aj) + (Bk) SAi Aj + Bk 14 98 65 32 0 54 | i | j | k This instruction reads operands from Aj and Bk, forms the sum of the operands, and delivers the result to Ai. If the i designator is nonzero, a reference is made to CM using the result as the relative address. The type of reference is a function of the i designator value. i = 0 No CM reference i = 1, 2, 3, 4, 5 Read from CM to Xi i = 6,7 Write into CM from Xi This instruction obtains operands from CM for computation and delivers the result back into CM. SAi Aj - Bk 60ijK Set Bi to (Aj) + K | - | 4 | 9 | 8 | 6 | 5 3 | 2 0 | ) | |---|----|---|---|---|-----|-----|---| | | 55 | | i | | j | k | l | This instruction reads operands from Aj and Bk, subtracts the Bk operand from the Aj operand, and delivers the result to Ai. If the i designator is nonzero, a reference is made to CM using the result as the relative address. The type of reference is a function of the i designator value. i = 0 No CM reference i = 1, 2, 3, 4, 5 Read from CM to Xi i = 6.7 Write into CM from Xi This instruction obtains operands from CM for computation and delivers the results back into CM. 56i jk Set Ai to (Bj) + (Bk) SAi Bj + Bk | 14 | 98 | 65 | 32 | 0 | |----|----|-----|----|---| | 56 | | i j | | k | This instruction reads operands from Bj and Bk, forms the sum of the operands, and delivers the result to Ai. If the i designator is nonzero, a reference is made to CM using the result as the relative address. The type of reference is a function of the i designator value. i = 0 No CM reference i = 1,2,3,4,5 Read from CM to Xi i = 6,7 Write into CM from Xi This instruction obtains operands from CM for computation and delivers the results back into CM. 57ijk Set Ai to (Bj) - (Bk) SAi Bj - Bk | 14 | 98 | 65 | 32 | 0 | |----|----|----|----|---| | 57 | i | j | k | | This instruction reads operands from Bj and Bk, subtracts the Bk operand from the Bj operand, and delivers the result to Ai. If the i designator is nonzero, a reference is made to CM using the result as the relative address. The type of reference is a function of the i designator value. i = 0 - No CM reference i = 1, 2, 3, 4, 5 Read from CM to Xi i = 6,7 Write into CM from Xi This instruction obtains operands from CM for computation and delivers the result back into CM. | 29 24 23 2120 1817 | | | | 17 | 0 | | | |--------------------|----|---|---|----|---|--|--| | Г | 60 | i | j | | K | | | This two-parcel instruction uses the lower-order 18 bits as operand K. This instruction reads an operand from Aj, forms the sum of the operand plus K and delivers the result to Bi. The sum is formed in an 18-bit one's complement mode. This instruction is for address modification in the increment registers. 6lijK Set Bi to (Bj) + K SBi Bj + K | 29 | 24 | 23 21 | 20 18 | 0 | |----|----|-------|-------|---| | | 61 | i | j | K | This two-parcel instruction uses the lower-order 18 bits as operand K. This instruction reads an operand from Bj, forms the sum of the operand plus K, and delivers the result to Bi. The sum is formed in an 18-bit one's complement mode. 62ijK Set Bi to (Xj) + K SBi Xj + K | 29 24 | 23 21 | 20 18 | 0 | |-------|-------|-------|---| | 62 | i | j | К | This two-parcel instruction uses the lower-order 18 bits as operand K. This instruction reads an operand from Xj, forms the sum of the operand plus K, and delivers the result to Bi. The sum is formed in an 18-bit one's complement mode. 63ijk Set Bi to (Xj) + (Bk) SBi Xj + Bk | 14 | 98 | 65 | 32 | 0 | |----|----|----|----|---| | 63 | | | j | k | This instruction reads operands from Xj and Bk, adds the operands, and delivers the result to Bi. The sum is formed in an 18-bit one's complement mode. 64ijk Set Bi to (Aj) + (Bk) SBi Aj + Bk | 14 | 98 | 65 | 32 | 0 | |----|----|----|----|---| | 64 | | | j | k | This instruction reads operands from Aj and Bk, adds the operands, and delivers the result to Bi. The sum is formed in an 18-bit one's complement mode. 65ijk Set Bi to (Aj) - (Bk) SBi Aj - Bk This instruction reads operands from Aj and Bk, subtracts the Bk operand from the Aj operand, and delivers the result to Bi. The difference is formed in an 18-bit one's complement mode. If the i designator is zero, this becomes a pass instruction. 660 jk Read Central Memory at (Xk) to Xj | 4 | | 6 | 5 3 | 2 ( | ) | |---|-----|---|-----|-----|---| | | 660 | | j | k | I | This instruction loads into Xj the word at location (Xk), where Xk is a right-justified 21-bit relative word address. Bits 21 through 59 of Xk are ignored. If the 21 bits of Xk are greater than or equal to FLC, an address out of range is detected. 66ijk Set Bi to (Bj) + (Bk) SBi Bj + Bk CR Xj, Xk | 14 | | 98 | 65 | 3 | 2 ( | ) | |----|----|----|----|---|-----|---| | | 66 | | | j | k | ] | This instruction reads operands from Bj and Bk, adds the operands, and delivers the result to Bi. The sum is formed in an 18-bit one's complement mode. If the i designator is zero, this becomes a read central memory instruction. 670jk Write Xj into Central Memory at (Xk) CW Xj, Xk | 14 | 6 | 5 | 32 | 0 | |-----|---|---|----|---| | 670 | | j | | k | This instruction stores Xj in location (Xk) where Xk is a 21-bit relative word address. Bits 21 through 59 of Xk are ignored. If the 21 bits of Xk are greater than or equal to FLC, an address out of range is detected. 67ijk Set Bi to (Bj) - (Bk) SBi Bj - Bk | 14 | 98 | 65 | 32 | 0 | |----|----|----|----|---| | 67 | | | j | k | This instruction reads operands from Bj and Bk, subtracts the Bk operand from the Bj operand, and delivers the result to Bi. The difference is formed in an 18-bit one's complement mode. If the i designator is zero, this becomes a write central memory instruction. 70ijK Set Xi to (Aj) + K SXi Aj + K | 29 | 24 | 23 2 | 20 18 | 17 | | 0 | |----|----|------|-------|----|---|---| | 70 | 0 | i | j | | К | | This two-parcel instruction uses the lower-order 18 bits as operand K. This instruction reads an operand from Aj, forms the sum of the operand plus K, and delivers the result to Xi. The sum is formed in an 18-bit one's complement mode. The 18-bit result is sign-extended by copying the highest-order bit of the result into the upper 42 bit positions in Xi. 7lijK Set Xi to (Bj) + K SXi Bj + K | 1 | 29 | 242 | 3 21 | 20 18 | 17 | | | C | ) | |---|----|-----|------|-------|----|---|---|---|---| | ļ | 71 | | i | j | | - | K | | l | This two-parcel instruction uses the lower-order 18 bits as operand K. This instruction reads an operand from Bj, forms the sum of the operand plus K, and delivers the result to Xi. The sum is formed in an 18-bit one's complement mode. The 18-bit result is sign-extended by copying the highest-order bit of the result into the upper 42 bit positions in Xi. 72ijK Set Xi to (Xj) + K SXi Xj + K | 29 2 | 423 2 | 20 18 | 0 | |------|-------|-------|---| | 72 | i | j · | К | This two-parcel instruction uses the lower-order 18 bits as operand K. This instruction reads an operand from Xj, forms the sum of the operand plus K, and delivers the result to Xi. The sum is formed in an 18-bit one's complement mode. The 18-bit result is sign-extended by copying the highest-order bit of the result into the upper 42 bit positions in Xi. 73ijk Set Xi to (Xj) + (Bk) SXi Xj + Bk | 14 | 98 | 6 5 | 3 | 2 | 0 | |-----|----|-----|---|---|---| | 7.3 | | i | j | k | | This instruction reads operands from Xj and Bk, adds the operands, and delivers the result to Xi. The sum is formed in an 18-bit one's complement mode. The 18-bit result is sign-extended by copying the highest-order bit of the result into the upper 42 bit positions in Xi. 74ijk Set Xi to (Aj) + (Bk) SXi Aj + Bk | 14 | 98 | <u>65</u> | 3 | 2 0 | |----|----|-----------|---|-----| | 74 | | i | j | k | This instruction reads operands from Aj and Bk, adds the operands, and delivers the result to Xi. The sum is formed in an 18-bit one's complement mode. The 18-bit result is sign-extended by copying the highest-order bit of the result into the upper 42 bit positions in Xi. 75ijk Set Xi to (Aj) - (Bk) SXi Aj - Bk | 14 | 98 | <u>65</u> | <u> </u> | 2 0 | |----|----|-----------|----------|-----| | 75 | | i . ] | j | k | This instruction reads operands from Aj and Bk, subtracts the Bk operand from the Aj operand, and delivers the result to Xi. The difference is formed in an 18-bit one's complement mode. The 18-bit result is sign-extended by copying the highest-order bit of the result into the upper 42 bit positions in Xi. 76ijk Set Xi to (Bj) + (Bk) SXi Bj + Bk This instruction reads operands from Bj and Bk, adds the operands, and delivers the result to Xi. The sum is formed in an 18-bit one's complement mode. The 18-bit result is sign-extended by copying the highest-order bit of the result into the upper 42 bit positions in Xi. SXi Bj - Bk This instruction reads operands from Bj and Bk, subtracts the Bk operand from the Bj operand, and delivers the result to Xi. The difference is formed in an 18-bit one's complement mode. The 18-bit result is sign-extended by copying the highest-order bit of the result into the upper 42 bit positions in Xi. #### INSTRUCTION EXECUTION TIMING Approximate execution times for models 835, and 845 and 855, without the Memory Upgrade Option, CP instructions are listed in tables 4-3, 4-4, and 4-5. (Execution times for models 845 and 855, with the Memory Upgrade Options, models 840, 850, 860, and 990 will be available at a later date.) These times are listed with the assumption that no conflicts occur. Execution delays result unless all the conditions listed in the timing notes column exist for the particular instruction. The numbers in the timing notes column refer to notes listed at the end of the table. # NOTE These execution times are approximations only and subject to change without notice. Accurate timings can come only from benchmark tests. Control Data Corporation is not responsible for assumptions made based on the times listed here. Table 4-3. Model 835 CP Instruction Timing (Sheet 1 of 4) | Instruction<br>Code | Description | Execution<br>Time in<br>56-ns Cycles | Timing<br>Notes | |---------------------|--------------------------------------------------------------|--------------------------------------|-----------------| | 00xxx | Error exit to MA or interrupt to executive mode | - | _ | | 010 xK | Return jump to K | 11-14 | _ | | 011 <b>j</b> K | Block copy Bj + K words from UEM to CM | - | 2 | | 012 <b>j</b> K | Block copy Bj + K words from CM to UEM | - | 3 | | 013 <b>j</b> K | Central exchange jump to Bj + K (CYBER 170 monitor flag set) | 175-185 | - | | 013 <b>xx</b> | Monitor exchange jump to MA (CYBER 170 monitor flag clear) | 175–185 | - | | 014jk | Read one word from UEM to Xj | 15-19 | - | | 015 <b>j</b> k | Write one word from Xj to UEM | 15-19 | - | | 016jk | Read free running counter | - | - | | 017 <b>j</b> k | Illegal instruction | 80-120 | _ | | O2ixK | Jump to (Bi) + K | 11-14 | _ | | 030јк | Branch to K if (Xj) = 0 | 4 or 11-14 | 1 | | 031 јк | Branch to K if (Xj) # 0 | 4 or 11-14 | 1 | | 032 јк | Branch to K if (Xj) is positive | 2 or 7-10 | 1 | | 033jK | Branch to K if (Xj) is negative | 2 or 7-10 | 1 | - 1. First time shown if branch was not taken; second time shown if branch was taken. - Execution time varies depending on the number of words transferred. Execution time in 56-ns cycles is: 64 + 190 (x/32). x=number of words transferred. Cache hit rate of 75% is assumed. - 3. Execution time varies depending on the number of words transferred. Execution time in 56-ns cycles is: 34 + 190 (x/32). x=number of words transferred. Cache hit rate of 75% is assumed. Table 4-3. Model 835 CP Instruction Timing (Sheet 2 of 4) | Instruction<br>Code | Description | Execution Time in 56-ns Cycles | Timing<br>Notes | |---------------------|-------------------------------------------------------------|--------------------------------|-----------------| | | | <u> </u> | | | 034 jK | Branch to K if (Xj) is in range | 4 or 11-14 | 1 | | 035 jK | Branch to K if (Kj) is out of range | 4 or 11-14 | 1 | | 036 jK | Branch to K if (Xj) is definite | 4 or 11-14 | . 1 | | 037 jK | Branch to K if (Kj) is indefinite | 4 or 11-14 | 1 | | 041 jK | Branch to K if (Bi) = (Bj) | 6 or 11-14 | 1 | | 05 <b>i</b> jK | Branch to K if (Bi) # (Bj) | 6 or 11-14 | 1 | | 061 jK | Branch to K if (Bi) $\geq$ (Bj) | 6 or 11-14 | 1 | | 07i <b>j</b> K | Branch to K if (Bi) < (Bj) | 6 or 11-14 | 1 | | 10i jx | Transmit (Xj) to Xi | 2 | - | | llijk | Logical product of (Xj) and (Xk) to Xi | 2 | - | | 12ijk | Logical sum of (Xj) and (Xk) to Xi | 2 | - | | 13 <b>i</b> jk | Logical difference of (Xj) and (Xk) to Xi | 2 | - | | 14ixk | Transmit complement of (Xk) to Xi | 2 | - | | 15ijk | Logical product of (Xj) with complement of (Xk) to Xi | . 4 | - | | 161 jk | Logical sum of (Xj) with complement of (Xk) to Xi | 4 | - | | 17ijk | Logical difference of (Xj) with complement of (Xk) to Xi | 4 | _ | | 20 <b>i j</b> k | Left shift (Xi) by jk | 2 | _ | | 21 <b>i j</b> k | Right shift (Xi) by jk | 2 | _ | | 221 jk | Left shift (Xk) nominally (Bj) places to Xi | 6 or 7-10 | 2 | | 23 <b>i j</b> k | Right shift (Xk) nominally (Bj) places to Xi | 6 or 7-10 | 2 | | 241 jk | Normalize (Xk) to Xi and Bj | 6 | _ | | 25 <b>i</b> jk | Round normalize (Xk) to Xi and Bj | 11-14 | _ | | 261 jk | Unpack (Xk) to Xi and Bj | 7–10 | _ | | 27ijk | Pack (Xk) and (Bj) to Xi | 5 | _ | | 30 i jk | Floating sum of (Xj) and (Xk) to Xi | 4 | - | | 311jk | Floating difference of (Xj) and (Xk) to Xi | 4 | _ | | 32 <b>i</b> jk | Floating double-precision sum of (Xj) and (Xk) to Xi | 40-60 | | | 33i jk | Floating double-precision difference of (Xj) and (Xk) to Xi | 40-60 | - | | 341 jk | Round floating sum of (Xj) and (Xk) to Xi | 7–10 | - | | 351 jk | Round floating difference of (Xj) and (Xk) to Xi | 7–10 | _ | - 1. First time shown if branch was not taken; second time shown if branch was taken. - 2. First time shown if left shift; second time shown if right shift. Type of shift depends on the sign. Table 4-3. Model 835 CP Instruction Timing (Sheet 3 of 4) | Instruction<br>Code | Description | Execution<br>Time in<br>56-ns Cycles | Timing<br>Notes | |---------------------|----------------------------------------------------------|--------------------------------------|-----------------| | 36i jk | Integer sum of (Xj) and (Xk) to Xi | 2 | _ | | 37ijk | Integer difference of (Xj) and (Xk) to Xi | 2 | _ | | 40i jk | Floating product of (Xj) and (Xk) to Xi | 11-14 | - | | 41i jk | Round floating product of (Xj) and (Xk) to Xi | 11–14 | - | | 421 <b>j</b> k | Floating double-precision product of (Xj) and (Xk) to Xi | 11-14 | - | | 431 jk | Form mask of jk bits to Xi | 4 | - | | 441 jk | Floating divide (Xj) by (Xk) to Xi | 40-60 | - | | 451 jk | Round floating divide (Xj) by (Xk) to Xi | 40–60 | _ | | 460xx-<br>463xx | Pass | 2 | - | | 464 jK | Move indirect | - | 3 | | 465 | Move direct | - | 3 | | 466 | Compare collated | - | 3 | | 467 | Compare uncollated | - | 3 | | 47ixk | Population count of (Xk) to Xi | 20-25 | 4 | | 501 jK | Set Ai to (Aj) + K | 3, 7-10,<br>or 20-25 | 5 | | 51 <b>i j</b> K | Set Ai to (Bj) + K | 3, 7-10, or<br>20-25 | 5 | | 521 jK | Set Ai to (Xj) + K | 3, 7-10, or<br>20-25 | 5 | | 53 <b>i</b> jk | Set Ai to (Xj) + (Bk) | 3, 7-10, or<br>20-25 | 5 | | 541 jk | Set Ai to (Aj) + (Bk) | 3, 7-10, or 20-25 | 5 | | 55 <b>i</b> jk | Set Ai to (Aj) - (Bk) | 3, 7-10, or 20-25 | 5 | | 561 jk | Set Ai to (Bj) + (Bk) | 3, 7-10, or 20-25 | 6 | | 57 <b>i</b> jk | Set Ai to (Bj) - (Bk) | 3, 7-10, or 20-25 | 6 | | 60i jK | Set Bi to (Aj) + K | 3 | - | | 61 <b>ij</b> K | Set Bi to (Bj) + K | 3 | - | - 3. CMU instructions are simulated. For best results, recompile to avoid use of these instructions. - 4. P equals the number of bits. - 5. 3 cycles when i equals 0; 7-10 cycles when i equals 6 or 7; 20-25 cycles when i equals 1 through 5. Cache hit rate of 75% is assumed. - 6. 3 cycles when i equals 0; 7-10 cycles when i equals 6 or 7; 20-25 cycles when i equals 1 through 5. Table 4-3. Model 835 CP Instruction Timing (Sheet 4 of 4) | Instruction<br>Code | Description | Execution<br>Time in<br>56-ns Cycles | Timing<br>Notes | |---------------------|--------------------------|--------------------------------------|-----------------| | 62i jK | Set Bi to (Xj) + K | 3 | - | | 631 jk | Set Bi to (Xj) + (Bk) | 3 | _ | | 64i jk | Set Bi to (Aj) + (Bk) | 3 | - | | 651 jk | Set Bi to (Aj) - (Bk) | 3 | _ | | 660 jk | Read CM at (Xk) to Xj | 4. | 7 | | 661 jk | Set Bi to (Bj) + (Bk) | 3 | - | | 670 jk | Write Xj into CM at (Xk) | 4 | - | | 671 jk | Set Bi to (Bj) - (Bk) | 3 | - | | 701 jK | Set Xi to (Aj) + K | 5 | - | | 711 <del>j</del> k | Set Xi to (Bj) + K | 5 | - | | 72 <b>i j</b> K | Set Xi to (Xj) + K | 5 | - | | 73i jk | Set Xi to (Xj) + (Bk) | 5 | - | | 74 <b>i j</b> k | Set Xi to (Aj) + (Bk) | 5 | _ | | 751 jk | Set Xi to (Aj) - (Bk) | 5 | - | | 761 jk | Set Xi to (Bj) + (Bk) | 5 | - | | 77 i jk | Set Xi to (Bj) - (Bk) | 5 | <u>-</u> | 7. Cache hit rate of 75% is assumed. Table 4-4. Model 845 CP Instruction Timing (Sheet 1 of 4) | Instruction<br>Code | Description | Execution<br>Time in<br>64-ns Cycles | Timing<br>Notes | |---------------------|--------------------------------------------------------------|--------------------------------------|-----------------| | 00xxx | Error exit to MA or interrupt to executive mode | - | - | | 010xK | Return jump to K | 10-20 | - | | 011 jK | Block copy Bj + K words from UEM to CM | - · | 1 | | 012 <b>j</b> K | Block copy Bj + K words from CM to UEM | _ | 1 | | 013 јк | Central exchange jump to Bj + K (CYBER 170 monitor flag set) | 125 | | Timing Notes: Execution time varies depending on number of words and number of 16-word blocks. Execution time in major cycles is: 39 + 3\* (number of words) + 7\* (number of 16-word blocks). Cache hit rate of 75% is assumed. Table 4-4. Model 845 CP Instruction Timing (Sheet 2 of 4) | Instruction<br>Code | Description | Execution<br>Time in<br>64-ns Cycles | Timing<br>Notes | |---------------------|------------------------------------------------------------|--------------------------------------|-----------------| | 013xx | Monitor exchange jump to MA (CYBER 170 monitor flag clear) | 125 | _ | | 014 <b>j</b> k | Read one word from UEM to Xj | 10-20 | _ | | 015 <b>j</b> k | Write one word from Xj to UEM | 10-20 | - | | 016 <b>j</b> k | Read free running counter | 10-20 | - | | 017 <b>j</b> k | Illegal instruction | 75–80 | - | | 02ixK | Jump to (Bi) + K | 8 | - | | 030 jK | Branch to K if (Xj) = 0 | 8 or 6 | 2 | | 031 <del>j</del> K | Branch to K if (Xj) ≠ 0 | 8 or 6 | 2 | | 032 <del>j</del> K | Branch to K if (Xj) is positive | 8 or 6 | 2 | | 033 <del>j</del> K | Branch to K if (Xj) is negative | 8 or 6 | 2 | | 034 jK | Branch to K if (Kj) is in range | 8 or 6 | 2 | | 035 <del>j</del> K | Branch to K if (Xj) is out of range | 8 or 6 | 2 | | 036 jK | Branch to K if (Kj) is definite | 8 or 6 | 2 | | 037 <del>j</del> K | Branch to K if (Xj) is indefinite | 8 or 6 | 2 | | 04i jK | Branch to K if (Bi) = (Bj) | 8 or 6 | 2 | | 05i <b>j</b> K | Branch to K if (Bi) ≠ (Bj) | 8 or 6 | 2 | | 06ijK | Branch to K if (Bi) $\geq$ (Bj) | 8 or 6 | 2 | | 07ijK | Branch to K if (Bi) < (Bj) | 8 or 6 | 2 | | 10 i jx | Transmit (Xj) to Xi | 1 | - | | lli <b>j</b> k | Logical product of (Xj) and (Xk) to Xi | 1 | _ | | 121 <b>j</b> k | Logical sum of (Xj) and (Xk) to Xi | 1 | _ | | 1 <b>3</b> 1 jk | Logical difference of (Xj) and (Xk) to Xi | 1 | - | | 14i <b>xk</b> | Transmit complement of (Xk) to Xi | 1 | - | | 15 <b>i j</b> k | Logical product of (Xj) with complement of (Xk) to Xi | 1 | - | | 161 <b>j</b> k | Logical sum of (Xj) with complement of (Xk) to Xi | · 1 | - | | 17 <b>i j</b> k | Logical difference of (Xj) with complement of (Xk) to Xi | 1 | _ | | 20 i jk | Left shift (Xi) by jk | 8 | - | | 21 i <b>j</b> k | Right shift (Xi) by jk | 1 | _ | <sup>2.</sup> First time shown if branch was taken; second time shown if branch was not taken. Table 4-4. Model 845 CP Instruction Timing (Sheet 3 of 4) | Instruction<br>Code | Description | Execution<br>Time in<br>64-ns Cycles | Timing<br>Notes | |---------------------|-------------------------------------------------------------|--------------------------------------|-----------------| | 221 jk | Left shift (Xk) nominally (Bj) places to Xi | 4 | - | | 23 <b>i</b> jk | Right shift (Xk) nominally (Bj) places to Xi | 4 | - | | 24i jk | Normalize (Xk) to Xi and Bj | 3 | _ | | 25i jk | Round normalize (Xk) to Xi and Bj | 2 | _ | | 26i jk | Unpack (Xk) to Xi and Bj | 2 | - | | 27i jk | Pack (Xk) and (Bj) to Xi | 1 | - | | 30i jk | Floating sum of $(Xj)$ and $(Xk)$ to $Xi$ | 2 | - | | 31i jk | Floating difference of (Xj) and (Xk) to Xi | 2 | _ | | 32i jk | Floating double-precision sum of (Xj) and (Xk) to Xi | 2 | _ | | 33i jk | Floating double-precision difference of (Xj) and (Xk) to Xi | 2 | - | | 34 <b>i</b> jk | Round floating sum of (Xj) and (Xk) to Xi | 2 | | | 35i jk | Round floating difference of $(Xj)$ and $(Xk)$ to $Xi$ | 2 | - | | 36ijk | Integer sum of (Xj) and (Xk) to Xi | 1 | - , | | 37i jk | Integer difference of (Xj) and (Xk) to Xi | 1 | - | | 40i jk | Floating product of (Xj) and (Xk) to Xi | 3 | - ` | | 4lijk | Round floating product of (Xj) and (Xk) to Xi | 3 | - | | 42 <b>i</b> jk | Floating double-precision product of (Xj) and (Xk) to Xi | 3 | - | | 43i jk | Form mask of jk bits to Xi | 4 | - | | 441 jk | Floating divide (Xj) by (Xk) to Xi | 14 | - | | 45i jk | Round floating divide (Xj) by (Xk) to Xi | 14 | _ | | 460xx-<br>463xx | Pass | 1 | - | | 464 jK | Move indirect | <u>.</u> | 3 | | 465 | Move direct | _ | 3 | | 466 | Compare collated | - | 3 | | 467 | 467 Compare uncollated | | 3 | | 47ixk | Population count of (Xk) to Xi | 17 | - | | 501 jK | Set Ai to (Aj) + K | 1, 2, or 4-5 | 4 | <sup>3.</sup> CMU instructions are simulated. For best results, recompile to avoid use of these instructions. 4. The first value for i=0, second for i=6 or 7, and the third for i=1-5. Table 4-4. Model 845 CP Instruction Timing (Sheet 4 of 4) | Instruction<br>Code | Description | Execution<br>Time in<br>64-ns Cycles | Timing<br>Notes | |---------------------|--------------------------|--------------------------------------|-----------------| | 51 <b>i j</b> K | Set Ai to (Bj) + K | 1, 2, or 5-6 | 4 | | 52 <b>ij</b> K | Set Ai to (Xj) + K | 1, 2, or 4-5 | 4 | | 53i jk | Set Ai to (Xj) + (Bk) | 1, 2, or 4-5 | 4 | | 54 <b>i</b> jk | Set Ai to (Aj) + (Bk) | 1, 3, or 7-8 | 4 | | 55 <b>i j</b> k | Set Ai to (Aj) - (Bk) | 1, 3, or 5-6 | 4 | | 561 jk | Set Ai to (Bj) + (Bk) | 1, 2, or 5-6 | 4 | | 57 <b>i j</b> k | Set Ai to (Bj) - (Bk) | 1, 2, or 4-5 | 4 | | 60i jK | Set Bi to (Aj) + K | 1 | - | | 611 jK | Set Bi to (Bj) + K | 1 | <b>-</b> . | | 621 jK · | Set Bi to (Xj) + K | 1 | - | | 631 <b>j</b> k | Set Bi to (Xj) + (Bk) | 1 | - | | 641 jk | Set Bi to (Aj) + (Bk) | 1 | _ | | 651 <b>j</b> k | Set Bi to (Aj) - (Bk) | 1 | - | | 660 jk | Read CM at (Xk) to Xj | 4-5 | 4 | | 661 <b>j</b> k | Set Bi to (Bj) + (Bk) | 1 | 5 | | 670 jk | Write Xj into CM at (Xk) | 1 | | | 67i <b>j</b> k | Set Bi to (Bj) - (Bk) | 1 | - | | 701 <b>j</b> K | Set Xi to (Aj) + K | 1 . | - | | 71 <u>i j</u> K | Set Xi to (Bj) + K | 1 | - | | 721 jK | Set Xi to (Xj) + K | 1 | - | | 73i jk | Set Xi to (Xj) + (Bk) | 1 | - | | 74i <b>j</b> k | Set Xi to (Aj) + (Bk) | 1 | - | | 75 <b>i j</b> k | Set Xi to (Aj) - (Bk) | 1 | - | | 761 jk | Set Xi to (Bj) + (Bk) | 1 | - | | 77 <b>i j</b> k | Set Xi to (Bj) - (Bk) | 1 | - | <sup>4.</sup> The first value for i=0, second for i=6 or 7, and the third for i=1-5. $i\neq 0$ . Table 4-5. Model 855 CP Instruction Timing (Sheet 1 of 3) | Instruction<br>Code | Description | Execution<br>Time in<br>64-ns Cycles | Timing<br>Notes | |---------------------|--------------------------------------------------------------|--------------------------------------|-----------------| | 00xxx | Error exit to MA or interrupt to executive mode | _ | <del>-</del> | | 010xK | Return jump to K | 10-20 | <b>-</b> | | 011 jK | Block copy Bj + K words from UEM to CM | - | 1 | | 012 jK | Block copy Bj + K words from CM to UEM | - | 1 | | 013јк | Central exchange jump to Bj + K (CYBER 170 monitor flag set) | 125 | - | | 013xx | Monitor exchange jump to MA (CYBER 170 monitor flag clear) | 125 | - | | 014 jk | Read one word from UEM to Xj | 10-20 | - | | 015 <del>j</del> k | Write one word from Xj to UEM | 10-20 | <del>-</del> | | 016 <b>j</b> k | Read free running counter | 10-20 | - | | 017 <del>j</del> k | Illegal instruction | 75-80 | - | | 02ixK | Jump to (Bi) + K | 8 | - | | 030 jk | Branch to K if (Xj) = 0 | 1 or 6 | 2 | | 031 jK | Branch to K if $(Xj) \neq 0$ | 1 or 6 | 2 | | 032 <del>ј</del> К | Branch to K if (Xj) is positive | 1 or 6 | 2 | | 033 <u>J</u> K | Branch to K if (Xj) is negative | 1 or 6 | 2 | | 034 jK | Branch to K if (Xj) is in range | 1 or 6 | 2 | | 035 <u>1</u> K | Branch to K if (Xj) is out of range | 1 or 6 | 2 | | 036 јк | Branch to K if (Xj) is definite | l or 6 | 2 | | 037 jK | Branch to K if (Xj) is indefinite | 1 or 6 | 2 | | 041 jK | Branch to K if (Bi) = (Bj) | 1 or 6 | 2 | | 051 jK | Branch to K if (Bi) # (Bj) | 1 or 6 | 2 | | 061 jK | Branch to K if (Bi) $\geq$ (Bj) | lor 6 | 2 | | 071 jK | Branch to K if (Bi) < (Bj) | 1 or 6 | 2 | | 10i jx | Transmit (Xj) to Xi | 1 | - | | lli jk | Logical product of (Xj) and (Xk) to Xi | 1 | <del>.</del> | | 121 jk | Logical sum of (Xj) and (Xk) to Xi | 1 | - | | 131 jk | Logical difference of (Xj) and (Xk) to Xi | 1 . | - | | 14ixk | Transmit complement of (Xk) to Xi | 1 | - | | 15 <b>i j</b> k | Logical product of (Xj) with complement of (Xk) to Xi | 1 | - | <sup>1.</sup> Execution time varies depending on number of words and number of 16-word blocks. Execution time in major cycles is: 39 + 3\* (number of words) + 7\* (number of 16-word blocks). Cache hit rate of 75% is assumed. <sup>2.</sup> First time shown if branch was taken; second time shown if branch was not taken. Table 4-5. Model 855 CP Instruction Timing (Sheet 2 of 3) | Instruction<br>Code | Description | Execution<br>Time in<br>64-ns Cycles | Timing<br>Notes | |---------------------|-------------------------------------------------------------|--------------------------------------|-----------------| | 16 <b>i j</b> k | Logical sum of (Xj) with complement of (Xk) to Xi | 1 | _ | | 17 <b>i j</b> k | Logical difference of (Xj) with complement of (Xk) to Xi | 1 | _ | | 201 jk | Left shift (Xi) by jk | 4 | - | | 21 <b>i</b> jk | Right shift (Xi) by jk | 1 | - | | 221 jk | Left shift (Xk) nominally (Bj) places to Xi | 4 | - | | 231 jk | Right shift (Xk) nominally (Bj) places to Xi | 4 | _ | | 241 jk | Normalize (Xk) to Xi and Bj | 2 | - | | 25i jk | Round normalize (Xk) to Xi and Bj | 2 | - | | 261 jk | Unpack (Xk) to Xi and Bj | 2 | _ | | 271 jk | Pack (Xk) and (Bj) to Xi | 1 | _ | | 30i jk | Floating sum of (Xj) and (Xk) to Xi | 2 | _ | | 31ijk | Floating difference of (Xj) and (Xk) to Xi | 2 | _ | | 32 <b>i</b> jk | Floating double-precision sum of (Xj) and (Xk) to Xi | 2 | _ | | 331 jk | Floating double-precision difference of (Xj) and (Xk) to Xi | 2 | - | | 341 jk | Round floating sum of (Xj) and (Xk) to Xi | 2 | <b>-</b> . | | 351 jk | Round floating difference of ( $Xj$ ) and ( $Xk$ ) to $Xi$ | 2 | - | | 361 jk | Integer sum of (Xj) and (Xk) to Xi | 1 | - | | 37 <b>i</b> jk | Integer difference of (Xj) and (Xk) to Xi | 1 | - | | 401 jk | Floating product of (Xj) and (Xk) to Xi | 3 | - | | 4lijk | Round floating product of (Xj) and (Xk) to Xi | 3 | =' | | 421 jk | Floating double-precision product of (Xj) and (Xk) to Xi | 3 | - | | 43i jk | Form mask of jk bits to Xi | 2 | - | | 44 <b>i j</b> k | Floating divide (Xj) by (Xk) to Xi | 14 | - | | 45i jk | Round floating divide (Xj) by (Xk) to Xi | 14 | - | | 460xx-<br>463xx | Pass | 1 | - | | 464 jK | Move indirect | - | 3 | | 465 | Move direct | _ | 3 | | 466 | Compare collated | _ | 3 | | 467 | Compare uncollated | - | 3 | | 47ixk | Population count of (Xk) to Xi | 17 | <u>-</u> | <sup>3.</sup> CMU instructions are simulated. For best results, recompile to avoid use of these instructions. Table 4-5. Model 855 CP Instruction Timing (Sheet 3 of 3) | Instruction<br>Code | Description | Execution<br>Time in<br>64-ns Cycles | Timing<br>Notes | |---------------------|--------------------------|--------------------------------------|-----------------| | 501 jK | Set Ai to (Aj) + K | 1, 2, or 4-5 | 4 | | 51ijK | Set Ai to (Bj) + K | 1, 2, or 4-5 | 4 | | 52i jK | Set Ai to (Xj) + K | 1, 2, or 4-5 | 4 | | 53 <b>i</b> jk | Set Ai to (Xj) + (Bk) | 1, 2, or 4-5 | 4 | | 54i jk | Set Ai to (Aj) + (Bk) | 1, 3, or 5-6 | 4 | | 55 <b>i</b> jk | Set Ai to (Aj) - (Bk) | 1, 3, or 5-6 | 4 | | 56 <b>i</b> jk | Set Ai to (Bj) + (Bk) | 1, 2, or 4-5 | 4 | | 57ijk | Set Ai to (Bj) - (Bk) | 1, 2, or 4-5 | 4 | | 60i jK | Set Bi to (Aj) + K | 1 | - | | 61i jK | Set Bi to (Bj) + K | 1 | - | | 62i jK | Set Bi to (Xj) + K | 1 | <del>-</del> | | 63ijk | Set Bi to (Xj) + (Bk) | 1 | - | | 641 jk | Set Bi to (Aj) + (Bk) | 1 | - | | 65 <b>i</b> jk | Set Bi to (Aj) - (Bk) | 1 | <u>-</u> · | | 660 jk | Read CM at (Xk) to Xj | 4-5 | 4 | | 66i jk | Set Bi to (Bj) + (Bk) | 1 | 5 | | 670 jk | Write Xj into CM at (Xk) | 1 | <del>-</del> | | 67ijk | Set Bi to (Bj) - (Bk) | , 1 | _ | | 70 <b>i j</b> K | Set Xi to (Aj) + K | 1 | - : | | 71 <b>i j</b> K | Set Xi to (Bj) + K | 1 | <b>-</b> . | | 72i jK | Set Xi to (Xj) + K | 1 | - | | 731 jk | Set Xi to (Xj) + (Bk) | 1 . | - | | 74i jk | Set Xi to (Aj) + (Bk) | 1 | - | | 751 jk | Set Xi to (Aj) - (Bk) | 1 | - | | 76i jk | Set Xi to (Bj) + (Bk) | 1 | - | | 771 jk | Set Xi to (Bj) - (Bk) | 1 | - | <sup>4.</sup> The first value for i=0, second for i=6 or 7, and the third for i=1-5. Cache hit rate of 75% is assumed. <sup>5.</sup> **i**≠0. ## **PP INSTRUCTIONS** ### PP: INSTRUCTION FORMATS Figure 4-2 shows PP instruction formats. PP instructions are 16 or 32 bits long. In instruction descriptions, the operation code is given either by two or three octal digits. The third digit, when used, indicates the state of the s-bit (zero or one) in I/O instructions (refer to table 4-6). The upper 4 bits of the PP instructions must be zero to ensure that the instructions operate as defined in this section. Table 4-6. PP Nomenclature | | <del></del> | |-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Term | Description | | 0pcode | Specifies instruction operation code. | | s | Specifies I/O instruction subcode. | | С | Specifies channel number. | | A | Refers to the A register (arithmetic register) or the content of the A register. | | (A) | Refers to the content of the word at the CM address specified by the A register. | | P | Refers to the P register or to the content of the P register (program address register). | | R | Refers to the R register or to the content of the R register (relocation register). | | (d) | Refers to the content of the word at the PP memory address specified by the d field (direct mode). | | ((d)) | Refers to the content of the word at<br>the PP memory address specified by the<br>content of the word at the PP memory<br>address specified by the d field<br>(indirect mode). | | m + (d) | Refers to the PP memory address specified by the m field indexed by the content of the word at the PP memory addressed specified by the d field. | | (m + (d)) | Refers to the content of the word at<br>the PP memory address specified by the<br>m field indexed by the content of the<br>word at the PP memory address<br>specified by the d field (memory mode). | Figure 4-2. PP Instruction Formats #### PP DATA FORMAT Figure 4-3 shows PP data format and how 12-bit data is packed into 64-bit CM words or unpacked from 64-bit CM words. Figure 4-3. PP Data Format # PP RELOCATION REGISTER FORMAT Figure 4-4 shows PP relocation (R) register format. This register is loaded-from/stored-into PP memory by instructions 24 and 25 (load/store R register). Figure 4-4. PP Relocation (R) Register Format #### PP INSTRUCTION DESCRIPTIONS PP instruction descriptions are in numerical order. Refer to section 5, Programming Information. 00xx Pass PSN This instruction specifies that no operation is to be performed. The instruction provides a means of padding out a program. 01dm Long jump to m + (d) LJM m,d This instruction jumps to the address given by m plus the content of location d. If d equals zero, m is not modified. 02dm Return Jump to m + (d) RJM m,d This instruction jumps to the address given by m plus the content of location d. If d equals zero, m is not modified. The current program address (P) plus 2 is stored at the jump address. The next instruction starts at the jump address plus 1. The subprogram exits with a long jump or normal sequencing to the jump address minus 1, which in turn contains a long jump, 0100. This returns the original program address plus 2 to the P register. 03d Unconditional Jump d 15 12 11 65 0 This instruction provides an unconditional jump to any address up to 31 (decimal) locations forward or backward from the current program address. The value of d is added to the current program address. If d is positive (01 through 37), 0001 through 0037 is added, and the jump is forward. If d is negative (40 through 76), 7740 through 7776 is added, and the jump is backward. When d equals 00 or 77, the PP hangs; a deadstart is required to restart the PP. 04d Zero Jump d ZJN d UJN d | 15 12 | 11 | 65 | 0 | |-------|----|----|---| | 00 | 04 | 0. | i | This instruction provides a conditional jump to any address up to 31 (decimal) locations forward or backward from the current program address. If the content of the A register is zero, the jump is taken. If the content of A is nonzero, the next instruction executes from P plus 1. Negative zero (777777) is treated as nonzero. For interpretation of d, refer to the 03 instruction. 05d Nonzero Jump d NJN d | 15 12 | 11 | 6 | 5 0 | |-------|----|---|-----| | 00 | 05 | | d | This instruction provides a conditional jump to any address up to 31 (decimal) locations forward or backward from the current program address. If the content of the A register is nonzero, the jump is taken. If the content of A is zero, the next instruction executes from P plus 1. Negative zero (777777) is treated as nonzero. For interpretation of d, refer to the 03 instruction. 06d Plus Jump d PJN d This instruction provides a conditional jump to any address up to 31 (decimal) locations forward or backward from the current program address. If the sign of the A register is positive, the jump is taken. If the sign of A is negative, the next instruction executes from P plus 1. Positive zero is treated as a positive quantity. Negative zero is treated as a negative quantity. For interpretation of d, refer to the 03 instruction. 07d Minus Jump d MJN d This instruction provides a conditional jump to any address up to 31 (decimal) locations forward or backward from the current program address. If the content of the A register is negative, the jump is taken. If the content of A is positive, the next instruction executes from P plus 1. Positive zero is treated as a positive quantity. Negative zero is treated as a negative quantity. For interpretation of d, refer to the 03 instruction. 10d Shift d SHN d This instruction shifts the content of the A register right or left d places. If d is positive (00 through 37), the shift is left circular. If d is negative (40 through 77), the shift is right (end-off with no sign extension). Thus, d equal to 06 requires a left shift of six places; d equal to 71 requires a right shift of six places. lld Logical Difference d LMN d | <u> 15 12</u> | 11 6 | 5 0 | |-----------------|------|-----| | 00 | 11 👉 | d | This instruction forms the bit-by-bit logical difference of d and the lower 6 bits of A in the register in A. This is equivalent to complementing individual bits of A that correspond to bits of d that are one. The upper 12 bits of A are not altered. 12d Logical Product d LPN d | <u>15 12</u> | . 11 | 65 | 0 | |--------------|------|----|---| | 00 | 12 | | d | This instruction forms the bit-by-bit logical product of d and the lower 6 bits of the A register and leaves this quantity in the lower 6 bits of A. The upper 12 bits of A are zero. 13d Selective Clear d SCN d This instruction clears any of the lower 6 bits of the A register where corresponding bits of d are one. The upper 12 bits of A are not altered. 14d Load d LDN d This instruction clears the A register and loads d. The upper 12 bits of A are zero. 15d Load Complement d LCN d | 15 12 | 11 6 | 5 | 0 | |-------|------|---|---| | 00 | 15 | d | | This instruction clears the A register and loads the complement of $d_{\,\bullet\,}$ The upper 12 bits of A are one. 16d Add d ADN d This instruction adds d (treated as a 6-bit positive quantity) to the content of the $\mbox{\mbox{\sc A}}$ register. 17d Subtract d SRN d | 15 12 | <u> </u> | ( | <u> 65</u> | 0 | |-------|----------|----|------------|---| | 00 | | 17 | | d | This instruction subtracts d (treated as a 6-bit positive quantity) from the content of the A register. 20dm Load dm LDC dm This instruction clears the A register and loads an 18-bit quantity consisting of d as the upper 6 bits and m as the lower 12 bits. The content of the location (P plus 1) which follows the present program address (P) is read to provide m. 21dm Add dm ADC dm This instruction adds to the A register the 18-bit quantity consisting of d as the upper 6 bits and m as the lower 12 bits. The content of the location (P plus 1) which follows the present program address (P) is read to provide m. 22dm Logical Product dm LPC dm This instruction forms the bit-by-bit logical product of the content of the A register and the 18-bit quantity dm in A. The upper 6 bits of this quantity consist of d, and the lower 12 bits are the content of the location (P plus 1), which follows the present program address (P). 23dm Logical Difference dm LMC dm This instruction forms the bit-by-bit logical difference of the content of the A register and the 18-bit quantity dm in A. This is equivalent to complementing individual bits of A which correspond to bits of dm that are one. The upper 6 bits of the quantity consist of d, and the lower 12 bits are the content of the location (P plus 1), which follows the present program address (P). 24d Load R Register LRD d | 15 12 | 11 6 | 5 0 | |-------|------|-----| | 00 | 24 | d | Figure 4-4 shows R register format. If d is not equal to 0, this instruction loads the upper 10 bits of the R register (bits 18-27) from the rightmost 10 bits of PP memory location d. The 12 bits contained in PP memory location d plus 1 are loaded into the next 12 bits of the R register (bits 6-17). If d equals 0, the instruction is a pass. 25d Store R Register SRD d Figure 4-4 shows R register format. If d is not equal to 0, this instruction stores the upper 10 bits of the R register (bits 18 through 27) into the rightmost 10 bits of PP memory location d. The 12 bits contained in PP memory location d plus 1 are stored into the next 12 bits of the R register (bits 6 through 17). If d equals 0, the instruction is a pass. 2600 Exchange Jump EXN This instruction causes an unconditional exchange jump in the CP, leaving the CP CYBER 170 monitor flag unaltered. The new CYBER 170 exchange package begins at central memory location R plus A when the leftmost bit in A is set. When this bit is clear, A specifies the address. The PP waits until the exchange has been completed before proceeding with the next instruction. 2610 Monitor Exchange Jump | 15 12 | 11 6 | 5 0 | |-------|------|-----| | 00 | 26 | 10 | If the CP is in the CYBER 170 monitor mode, this instruction is a pass. If the CP is in the CYBER 170 job mode, it causes a CYBER 170 exchange jump in the CP, switching the CP to the CYBER 170 monitor mode (MF equals 1). The new CYBER 170 exchange package begins at central memory location R plus A when the leftmost bit in A is set. When this bit is clear, A specifies the address. The PP waits until the exchange has been completed before proceeding with the next instruction. 2620 Monitor Exchange Jump to MA MAN | 15 12 | 11 6 | 5 0 | |-------|------|-----| | 00 | 26 | 20 | If the CP is in CYBER 170 monitor mode, this instruction is a pass. If the CP is in CYBER 170 job mode, it causes a CYBER 170 exchange jump in the CP, switching the CP to CYBER 170 monitor mode (MF equals 1). The new CYBER 170 exchange package begins at the absolute address given in the MA field of the outgoing CYBER 170 exchange package. The PP waits until the exchange has been completed before proceeding with the next instruction. 27d Pass KPT d | 15 12 | 11 6 | 5 0 | |-------|------|-----| | 00 | 27 | d | This instruction is no operation. However, it generates a pulse to a testpoint (keypoint) for optional monitoring by external equipment. 30d Load (d) LDD d | 15 | 12 | H | 6 | 5 | 0 | |----|----|---|----|---|---| | Г | 00 | | 30 | | d | This instruction clears the A register and loads the content at location $d_{\bullet}$ . The upper 6 bits of A are zero. 31d Add (d) ADD d This instruction adds the content at location d (treated as a 12-bit positive quantity) to the A register. | 15 12 | 11 | 65 | 0 | |-------|----|----|---| | 00 | 32 | | q | This instruction subtracts the content at location d (treated as a 12-bit positive quantity) from the A register. 33d Logical Difference (d) LMD d | 15 | 12 | 11 ( | 6 5 | 0 | |----|----|------|-----|---| | 0 | Ö | 33 | | ď | This instruction forms in the A register the bit-by-bit logical difference of the lower 12 bits of the A register and the content at location d. This is equivalent to complementing individual bits of A which correspond to bits in location d that are ones. The upper 6 bits are not altered. 34d Store (d) STD d This instruction stores the lower 12 bits of the A register at location d. 35d Replace Add (d) RAD d This instruction adds the quantity at location d to the content of the A register and stores the lower 12 bits of the result at location d. The result remains in A at the end of the operation and the original content of A is destroyed. 36d Replace Add One (d) AOD d | 15 12 | 2 11 | 6 | 5 0 | |-------|------|----|-----| | . 00 | | 36 | d | This instruction replaces the quantity at location d with its original value plus 1. The result remains in the A register at the end of the operation, and the original content of A is destroyed. 37d Replace Subtract One (d) Subtract One (d) SOD d | 15 12 | 11 6 | 5 0 | |-------|------|-----| | 00 | 37 | d | This instruction replaces the quantity at location d with its original value minus 1. The result remains in the A register at the end of the operation, and the original content of A is destroyed. | I5 I2 | 11 | 65 | 0 | |-------|----|----|---| | 00 | 40 | | d | This instruction clears the A register and loads a 12-bit quantity that is obtained by indirect addressing. The upper 6 bits of A are zero. Location d is read from PPM, and the word read is used as the operand address. 41d Add ((d)) ADI d | <u>15</u> 12 | 11 6 | 5 0 | |--------------|------|-----| | 00 | 41 | d | This instruction adds to the content of the A register a 12-bit operand (treated as a positive quantity) obtained by indirect addressing. Location d is read from PPM, and the word read is used as the operand address. 42d Subtract ((d)) SBI d | 15 12 | 11 | 65 | 0 | |-------|----|-----|---| | 00 | 42 | : [ | d | This instruction subtracts from the A register a 12-bit operand (treated as a positive quantity) obtained by indirect addressing. Location d is read from PPM, and the word read is used as the operand address. 43d Logical Difference ((d)) LMI d | 15 12 | П | 6 | 5 | 0 | |-------|---|----|---|---| | 00 | | 43 | d | | This instruction forms in the A register the bit-by-bit logical difference of the lower 12 bits of the A register and the 12-bit operand read by indirect addressing. Location d is read from PPM, and the word read is used as the operand address. The upper 6 bits of A are not altered. 44d Store ((d)) STI d | <u>15 12</u> | 11 6 | 5 0 | |--------------|------|-----| | 00 | 44 | q | This instruction stores the lower 12 bits of the A register at the location specified by the content of location $d_{\,\bullet}$ 45d Replace Add ((d)) RAI d | 15 12 | 11 | 65 | 0 | |-------|----|----|---| | 00 | 45 | | d | This instruction adds the operand, which is obtained from the location specified by the content at location d, to the content of the A register. The lower 12 bits of the sum replace the original operand. The result remains in A at the end of the operation. | 15 | 12 | 11 € | 5 5 | . 0 | |----|----|------|-----|-----| | | 00 | 46 | | | This instruction replaces the operand, which is obtained from the location specified by the content at location d, by its original value plus 1. The result remains in the A register at the end of the operation, and the original content of A is destroyed. 47d Replace Subtract One ((d)) SOI d AOI d | 15 12 | 11 | 6 5 | 0 | |-------|----|-----|---| | 00 | 47 | | d | This instruction replaces the operand, which is obtained from the location specified by the content at location d, by its original value minus 1. The result remains in the A register at the end of the operation, and the original content of A is destroyed. 50dm Load (m + (d)) LDM m,d This instruction clears the A register and loads a 12-bit quantity. The upper 6 bits of A are zeros. The 12-bit operand is obtained by indexed direct addressing. The quantity m, read from PPM location P plus 1, serves as the base operand address to which the content of d is added. If d equals 0, the operand address is m, but if d is not equal to 0, m plus the content in d is the operand address. Thus, location d may be used as an index quantity to modify operand addresses. 51dm Add (m + (d)) ADM m,d This instruction adds the 12-bit operand (treated as a positive quantity) read by indexed direct addressing (refer to 50 instruction) to the A register. 52dm Subtract (m + (d)) SBM m,d This instruction subtracts the 12-bit operand (treated as a positive quantity) read by indexed direct addressing (refer to the 50 instruction) from the A register. This instruction forms the bit-by-bit logical difference of the lower 12 bits of the A register and a 12-bit operand obtained by indexed direct addressing (refer to the 50 instruction) in A. The upper 6 bits of A are not altered. 54dm Store (m + (d)) STM m,d This instruction stores the lower 12 bits of the A register in the location determined by indexed direct addressing (refer to 50 instruction). 55dm Replace Add (m + (d)) RAM m,d This instruction adds the operand, which is obtained from the location determined by indexed direct addressing (refer to the 50 instruction), to the A register. The lower 12 bits of the sum replace the original operand in PPM. The result remains in A at the end of the operation, and the original content of A is destroyed. 56dm Replace Add One (m + (d)) AOM m,d This instruction replaces the operand, which is obtained from the location determined by indexed direct addressing (refer to the 50 instruction), by its original value plus 1. The result remains in the A register at the end of the operation, and the original content of A is destroyed. 57dm Replace Subtract One (m + (d)) 31 28 27 22 21 16 15 12 11 O 00 57 d 00 m SOM m,d This instruction replaces the operand, which is obtained from the location determined by indexed direct addressing (refer to the 50 instruction), by its original value minus 1. The result remains in the A register at the end of the operation, and the original content of A is destroyed. 60d Central Read from (A) to d CRD d This instruction disassembles one 60-bit word from central memory into five 12-bit words and stores these in five consecutive PP memory locations, beginning with the leftmost 12 bits of the 60-bit word. The parameters of the transfer are as follows: If bit 17 of A is zero, A bits 0 through 16 contain the absolute address of the 60-bit word transferred. If bit 17 of A is one, hardware adds relocation register R to zero-extended A bits 0 through 16 to obtain the absolute address of the 60-bit word transferred. For further information, refer to R Register under Input/Output Unit in section 2, and PP Relocation Register Format at the beginning of this section on PP Instructions. Field gives the PP location which receives the first 12-bit word transferred. PP memory addressing is cyclic and location 0000 follows location 7777. 61dm Central Read (d) Words from CRM d,m (A) to m PP location 0000 is used by hardware. This instruction disassembles 60-bit words from central memory into 12-bit words, and places these in consecutive PP memory locations, beginning with the leftmost 12 bits of the first 60-bit word. The parameters of the transfer are as follows: If bit 17 of A is zero, A bits 0 through 16 contain the absolute address of the first 60-bit word transferred. If bit 17 of A is one, hardware adds relocation register R to zero-extended A bits 0 through 16 to obtain the absolute address of the first 60-bit word transferred. For further information, refer to R Register under Input/Output Unit in section 2, and PP Relocation Register Format at the beginning of this section on PP Instructions. PP location d must contain the number of 60-bit words transferred. Field m gives the PP location into which the first 12-bit word is placed. This instruction stores P plus l into PP location 0000 before beginning the transfer. After the transfer is completed, the next instruction is taken from one plus whatever address is stored in location 0000. If the transfer overwrites location 0000, execution resumes at the location specified by (0000) plus l and results are undefined. (PP memory addressing is cyclic and location 0000 follows location 7777.) The A register is incremented by one after each 60-bit word is read from central memory. If the incrementing changes A bit 17, the central memory addressing is switched between direct address and relocation address modes. Refer to Central Memory Addressing by PPs, section 5. After the transfer is completed, the A register contains either the address of the last word transferred plus one (direct addressing) or the same address less the contents of the relocation address register (relocation addressing), except as follows: If the last word transferred is from a relative address 3777768 and relocation is in effect, then the A register is cleared, and the value returned in A may not point to the last word transferred plus one. 62d Central Write to (A) from d CWD d | 15 12 | 11 6 | 5 0 | |-------|------|-----| | 00 | 62 | d | This instruction assembles five 12-bit words from consecutive PP memory locations into one 60-bit word and stores the 60-bit word in central memory. The first 12-bit word is stored in the leftmost 12 bits of the 60-bit word. (PP memory addressing is cyclic and location 0000 follows location 7777.) The parameters of the transfer are as follows: If bit 17 of A is zero, A bits 0 through 16 contain the absolute address of the 60-bit word stored. If bit 17 of A is one, hardware adds relocation register R to zero-extended A bits 0 through 16 to obtain the absolute address of the 60-bit word stored. For further information, refer to R Register under Input/Output Unit in section 2, and PP Relocation Register Format at the beginning of this section on PP Instructions. Field d gives the PP location of the first 12-bit word transferred. The transfer is subject to the CM bounds test. 63dm Central Write (d) Words to CWM m,d (A) from m PP location 0000 is used by hardware. This instruction assembles 12-bit words from consecutive PP memory locations into 60-bit words and stores these in central memory. The first 12-bit word is stored in the leftmost 12 bits of the 60-bit word. (PP memory addressing is cyclic and location 0000 follows location 7777.) The parameters of the transfer are as follows: If bit 17 of A is zero, A bits 0 through 16 contain the absolute address of the first 60-bit word transferred. If bit 17 of A is one, hardware adds relocation register R to zero-extended A bits 0 through 16 to obtain the absolute address of the first 60-bit word transferred. For further information, refer to R Register under Input/Output Unit in section 2, and in PP Relocation Register Format at the beginning of this section on PP Instructions. PP location d must contain the number of 60-bit words transferred. Field m gives the PP location from where the first 12-bit word is obtained. The transfer is subject to the CM bounds test. This instruction stores P plus 1 into PP location 0000 before beginning the transfer. After the transfer is completed, the next instruction is taken from one plus whatever address is stored in location 0000. The A register is incremented by one after each 60-bit word is written into central memory. If the incrementing changes A bit 17, the central memory addressing is switched between direct address and relocation address modes. Refer to Central Memory Addressing by PPs, section 5. After the transfer is completed, the A register contains either the address of the last word transferred plus one (direct addressing), or the same address less the contents of the relocation address register (relocation addressing), except as follows: If the last word transferred is from a relative address 3777768 and relocation is in effect, then the A register is cleared, and the value returned in A may not point to the last word transferred plus one. 640cm Jump to m if Channel c Active AJM m,c If channel c is active this instruction causes a jump to m. Otherwise, it is a pass. 641cm Test and Set Channel c Flag SCF m,c If the channel c flag is set, this instruction causes a jump to m. If the channel c flag is clear, it sets this flag and continues with the next instruction. When m is set to P plus 2, the channel flag is unconditionally set when the program reaches P plus 2. If two or more PPs simultaneously issue this instruction for the same channel, the conflict is resolved as follows: If one of the competing channels is channel 17 (maintenance channel), the PP in the lowest physical level sees the true condition of the flag; the other conflicting PPs see the flag set (and hence take a jump). If the competing channel is any other channel, software must resolve the conflict. Any five consecutively numbered PPs (in the same barrel) issue instructions at different times. 650cm Jump to m if Channel c Inactive IJM m,c This instruction provides a conditional jump to a new address specified by m. The jump is taken if the channel specified by c is inactive. The next instruction is at P plus 2 if the channel is active. This instruction clears the channel c flag. The m field is required but not used. This instruction provides a conditional jump to a new address specified by m. The jump is taken if the channel designated by c is full. The next instruction is at P plus 2 if the channel is empty. An input channel is full when the input equipment places a word in the channel and that word has not been accepted by a PP. The channel is empty when a word has been accepted. An output channel is full when a PP places a word on the channel. The channel is empty when the output equipment accepts the word. 661cm Jump to m if Channel c Error SFM m,c Flag Set If the channel c error flag is set, this instruction clears the error flag and causes a jump to m. If this error flag is clear, the instruction is a pass. When m is set to P plus 2, the channel error flag is unconditionally cleared when the program reaches P plus 2. 670cm Jump to m if Channel c Empty EJM m,c This instruction provides a conditional jump to a new address specified by m. The jump is taken if the channel specified by c is empty. The next instruction is at P plus 2 if the channel is full. Refer to 660 instruction for explanation of full and empty. 60469290 D If the channel c error flag is clear, this instruction causes a jump to m. If this error flag is set, the instruction clears the error flag and proceeds with the next instruction. When m is set to P plus 2, the channel error flag is unconditionally cleared when the program reaches P plus 2. 70d Input to A from Channel d IAN d | <u>15</u> 12 | 11 6 | 5 | 0 | |--------------|------|---|---| | 00 | - 70 | d | | This instruction transfers a word from input channel d to the lower 12 bits of the A register. The upper 6 bits of A are cleared to zero. ## NOTE If bit 5 of d is clear and the channel is inactive, this instruction hangs the PP, waiting for the channel to go active and full, if executed. If bit 5 of d is set and the channel is inactive or is deactivated before a full is received, the instruction exits. The word is not accepted, and the A register clears. 71dm Input A Words to m from Channel d IAM m,d This instruction transfers a block of 12-bit words from input channel d to PPM. The first word goes to the PPM address specified by m. The A register holds the block length. A reduces by one as each word is read. The input operation completes when A equals zero or the data channel becomes inactive. If the operation terminates by the channel becoming inactive, the next storage location in PPM is set to zero. However, the word count is not affected by this empty word. Therefore, A holds the block length minus the number of real data words read. During this instruction, address 0000 temporarily holds P while m is held in the P register. P advances by one to hold the address for the next word as each word is stored. #### NOTE If this instruction executes when the data channel is inactive, no input operation is accomplished, and the program continues at P plus 2. However, the location specified by m is set to zero. 72d Output from A on Channel d | 15 12 | II ( | 6.5 | 0 | |-------|------|-----|---| | 00 | 72 | d | 1 | This instruction transfers a word from the A register (lower 12 bits) to output channel d. # NOTE If bit 5 of d is clear and the channel is inactive, this instruction hangs the PP, waiting for the channel to go active and full, if executed. If bit 5 of d is set and the channel is inactive, the program continues at P plus 1. The word is not transferred. 73dm Output A Words from m on Channel d OAM m,d OAN d This instruction transfers a block of words from PPM to channel d. The first word is read from the address specified by m. The A register holds the number of words to be sent. A reduces by one as each word is read. The output operation completes when A equals zero or the channel becomes inactive. During this instruction, address 0000 temporarily holds P while m is held in the P register. P advances by one to give the address of the next word as each word is read from the PPM. # NOTE If this instruction executes when the data channel is inactive, no output operation is accomplished, and the program continues at P plus 2. 74d Activate Channel d ACN d This instruction activates the channel specified by d and sends the active signal on the channel to equipment connected to the channel. Activating a channel, which must precede a 70 through 73 instruction, prepares I/O equipment for the exchange of data. NOTE If this instruction executes when the data channel is already active and if bit 5 of d is set, the program continues at P plus 1. Otherwise, activating an already active channel causes the PP to wait until the channel goes inactive. The PP hangs if the channel does not go inactive. 75d Deactivate Channel d DCN d This instruction deactivates the channel specified by d. As a result, the I/O data transfer stops. # NOTE If this instruction executes when the data channel is already inactive and bit 5 of d is set, the program continues at P plus 1. The channel remains inactive, and no inactive signal is sent to the I/O equipment. Deactivating an already inactive channel causes the PP to hang until the channel becomes active. If an output instruction is followed by a disconnect instruction without first establishing that the information has been accepted by the input device (check for channel empty), the last word transmitted may be lost. Do not deactivate a channel before putting a useful program in the associated PP. PPs other than 0 are hung on an input instruction (71) Deactivating a after deadstart. channel after deadstart causes an exit to the address specified by the content of location 0000 plus 1 and execution of that program. If the channel is deactivated without a valid program in that PP, the PP executes whatever program was left in PPM. Therefore, the PP could run wild. 76d Function A on Channel d FAN d | 15 12 | 11 6 | 5 0 | |-------|------|-----| | 00 | 76 | d | This instruction sends the external function code in the lower 12 bits of the A register on channel d. ## NOTE If this instruction executes with bit 5 of d clear and the channel active, PP execution stops until a deadstart or another PP causes the channel to become inactive. If bit 5 of d is set and the channel is active, the program continues at P plus 1. Neither the function signal nor the function word transmits. The channel remains active, and execution continues. 77dm Function m on Channel d FNC m,d This instruction sends the external function code specified by m on channel d. #### NOTE If this instruction executes with bit 5 of d clear and the channel active, PP execution stops until a deadstart or another PP causes the channel to become inactive. If bit 5 of d is set and the channel is active, the program continues at P plus 2. Neither the function signal nor the function word transmits. The channel remains active, and execution continues. ## INSTRUCTION EXECUTION TIMING Approximate execution times for the PP instructions are listed in table 4-7. These times are listed with the assumption that no conflicts occur. The numbers in the timing notes column refer to the notes at the end of the table. Execution times are given in 250-nanosecond major cycles. # NOTE These execution times are approximations only and subject to change without notice. Accurate timings can come only from benchmark tests. Control Data Corporation is not responsible for assumptions made based on the times listed here. Table 4-7. PP Instruction Timing (Sheet 1 of 3) | Instruction<br>Code | Description | Execution<br>Time in<br>250-ns Cycles | Timing<br>Notes | |---------------------|-----------------------------------------|---------------------------------------|-----------------| | 00xx | Pass | 1 | _ | | 01dm | Long jump to m + (d) | 3 | - | | 02dm | Return jump to $m + (d)$ | 4 | _ | | 03 <b>d</b> | Unconditional jump d | 1 | _ | | 04d | Zero jump d | 1 | - | | 05a | Nonzero jump d | 1 | _ | | 06 <b>a</b> | Plus jump d | 1 | _ | | 07 d | Minus jump d | 1 | - | | 10 <b>d</b> | Shift d | 1 | - | | 11 <b>d</b> | Logical difference d | 1 | _ | | 12d | Logical product d | 1 | _ | | 13 <b>d</b> | Selective clear d | 1 | - | | 14d | Load d | 1 | _ | | 15d | Load complement d | 1 | _ | | 16d | Add d | 1 | _ | | 17d | Subtract d | 1 | _ | | 20dm | Load dm | 2 | _ | | 21dm | Add dm | 2 | _ | | 22dm | Logical product dm | 2 | - | | 23dm | Logical difference dm | 2 | _ | | 24d | Load R register from (d) and (d) $+ 1$ | 3 | _ | | 25d | Store R register at $(d)$ and $(d) + 1$ | 4 | _ | | 260x | Exchange jump | 2 | 1 | | 261x | Monitor exchange jump | 2 | 1 | | 262x | Monitor exchange jump to MA | 2 | 1 | | 27d | Pass | 1 | _ | | 30d | Load (d) | 2 | _ | | 31d | Add (d) | 2 | _ | | 32d | Subtract (d) | 2 | _ | | 33d | Logical difference (d) | 2 | _ | | 34d | Store (d) | 2 | _ | | 35d | Replace add (d) | 4 | _ | <sup>1.</sup> No assembly-disassembly unit (ADU) conflicts and no outstanding CYBER 170 exchange jump request in the ADU. Table 4-7. PP Instruction Timing (Sheet 2 of 3) | Instruction<br>Code | Description | Execution<br>Time in<br>250-ns Cycles | Timing<br>Notes | |---------------------|---------------------------------------|---------------------------------------|-----------------| | 36d | Replace add one (d) | 5 | <u>-</u> | | 37d | Replace subtract one (d) | 5 | - | | 40d | Load ((d)) | 3 | - | | 41d | Add ((d)) | 3 | - | | 42d | Subtract ((d)) | 3 | - | | 43d | Logical difference ((d)) | 3 | - | | 44d | Store ((d)) | 3 | - | | 45d | Replace add ((d)) | 5 | - | | 46d | Replace add one ((d)) | 6 | _ | | 47 d | Replace subtract one ((d)) | 6 | - | | 50 dm | Load (m + (d)) | 4 | - | | 51 dm | Add (m + (d)) | 4 | - | | 52 dm | Subtract (m + (d)) | 4 | _ | | 53dm | Logical difference (m + (d)) | 4 | - | | 54dm | Store (m + (d)) | 4 | - | | 55dm | Replace add (m + d)) | 6 | _ | | 56 dm | Replace add one (m + (d)) | 7 | - | | 57dm | Replace subtract one (m + (d)) | 7. | - | | 60d | Central read from (A) to d | 12 | 2 | | 61dm | Central read (d) words from (A) to m | - | 2,3 | | 62d | Central write to (A) from d | 6 | 2 | | 63dm | Central write (d) words to (A) from m | <u>-</u> | 2,4 | | 640cm | Jump to m if channel c active | 2 | _ | | 641cm | Test and set channel c flag | 2 | _ | | 650cm | Jump to m if channel c inactive | 2 | -<br>- | | 651cm | Clear channel c flag | 2 | | | 660cm | Jump to m if channel c full | 2 | <del>-</del> | | 661cm | Jump to m if channel c error flag set | 2 | _ | - 2. No ADU conflicts. No central memory conflicts. Add a possible trip due to resynchronization (CM read instructions only). - 3. 7 major cycles for instruction set-up and instruction exit. 5 major cycles for every CM word. - 4. 6 major cycles for instruction set-up and instruction exit. 5 major cycles for every CM word. Table 4-7. PP Instruction Timing (Sheet 3 of 3) | Instruction<br>Code | Description | Execution<br>Time in<br>250-ns Cycles | Timing<br>Notes | |---------------------|-----------------------------------------|---------------------------------------|-----------------| | 670cm | Jump to m if channel c empty | 2 | - | | 671cm | Jump to m if channel c error flag clear | 2 | _ | | 70d | Input to A from channel d | 2 | - | | 71dm | Input A words to m from channel d | - | 5 | | 72d | Output from A on channel d | 2 | - | | 73dm | Output (A) words from m on channel d | - | 5 | | 74d | Activate channel d | 2 | - | | 75d | Deactivate channel d | 2 | - | | 76d | Function A on channel d | 2 | , <b>-</b> | | 77dm | Function m on channel d | 2 | _ | 5. 5 major cycles for instruction set-up and exit. 1 major cycle per word (nonconflict case) or 2 major cycles per word (conflict case). Nonconflict case is when two PPs communicating to each other are not in the slot at the same time. Conflict case is when two PPs communicating with each other are in the slot at the same time. This section contains special programming information about the CP, CM, PPs, system console, real-time clock, two-port multiplexer, and maintenance channel. # **CP PROGRAMMING** #### **CYBER 170 EXCHANGE JUMP** The CP operates in either CYBER 170 job mode, which can be interrupted, or CYBER 170 monitor mode, which cannot be interrupted. A hardware flag called the CYBER 170 monitor flag (MF) indicates the mode in which the CP is executing a job. The CP uses a CYBER 170 exchange jump operation to switch from CYBER 170 job mode to CYBER 170 monitor mode and back again. The execution of a CYBER 170 exchange jump permits the CP to send pertinent information from the operating and control registers to CM and permits CM to send new information to the same registers. The information that flows from and into the operating and control registers during a CYBER 170 exchange jump is called a CYBER 170 exchange package (figure 5-1). A CYBER 170 exchange jump operation is initiated by the CP 013 instruction and the PP 2600, 2610, and 2620 instructions. A CYBER 170 exchange jump instruction starts or interrupts the CP and provides CM with the first address of a 16-word exchange package. For the 013 instruction with MF set (CP in monitor mode) the starting address of the CYBER 170 exchange package is Bj plus K. With MF clear (CP in job mode), the address is the monitor address (MA). For the 2600 instruction, the CYBER 170 exchange package address is A plus R when bit 17 of the A register is set. When this bit is clear, the address is A. For the 2610 instruction with MF set, the instruction is a pass. With MF clear, the CYBER 170 exchange package address is A plus R when bit 17 of the A register is set. When this bit is clear, the address is A. For the 2620 instruction with MF set, the instruction is a pass. With MF clear, the CYBER 170 exchange package address is MA of the outgoing CYBER 170 exchange package. The CYBER 170 exchange package contains the following registers which provide information for program execution. - 18-bit program address (P) register. - 21-bit reference address for CM (RAC) register. - 21-bit field length for CM (FLC) register. Figure 5-1. CYBER 170 Exchange Package - 6-bit exit mode (EM) register. - 6-bit flag register. - 21- or 24-bit reference address for UEM (RAE); 21 bits with lower 6 bits assumed to be zero in standard addressing mode; 24 bits right-shifted with 6 assumed zeros in expanded addressing mode. - 21- or 24-bit field length for UEM (FLE); 21 bits in standard addressing mode and 24 bits in expanded addressing mode; lower 6 bits are assumed to be zero. - 18-bit monitor address (MA) register. - Initial contents of eight 60-bit X registers. - Initial contents of eight 18-bit A registers. - Initial contents of 18-bit B registers B1 through B7, B0 contains constant 0. The time that a particular CYBER 170 exchange package resides in the CP hardware registers is the execution interval. The execution interval begins with a CYBER 170 exchange jump that swaps the CYBER 170 exchange package information in CM with the information contained in the CP registers. The execution interval ends with the next CYBER 170 exchange jump. #### **EXECUTIVE STATE** The executive state uses a combination of hardware, software, and microcode to handle the following: - System initialization. - Compare/move instructions. - Software errors and unimplemented instructions that occur in CYBER 170 monitor mode. - Processor-detected hardware errors. - Hardware integrity verification (diagnostics). In general, executive state determines the cause of an interrupt and decides whether to return the CP to the interrupted mode, to halt the CP, or to simulate a CYBER 170 exchange and return control to CYBER 170 monitor mode. Refer to Error Response, this section. #### FLOATING-POINT ARITHMETIC ### Format Floating-point arithmetic expresses a number in the form $kB^{\mathbf{n}_{\bullet}}$ - k Coefficient (WNTISSA) - B Base number - n Exponent or power to which the base number is raised B is assumed to be 2 for binary-coded quantities. In the 60-bit floating-point format (figure 5-2), the binary point is considered to be to the right of the coefficient. The lower 48 bits express the integer coefficient, which is the equivalent of 15 decimal digits. The sign of the coefficient is separated from the rest of the coefficient and appears in the highest-order bit of the packed word. Negative numbers are represented in one's complement notation. The exponent is biased by complementing the exponent sign bit. Figure 5-2. Floating-Point Format Table 5-1 summarizes the configurations of bits 58 and 59 and the implications regarding signs of the possible combinations. Table 5-1. Bits 58 and 59 Configurations | Bit 59 | Bit 58 | Coefficient Sign | Exponent Sign | |--------|--------|------------------|---------------| | 0 | 1 | Positive | Positive | | 0 | 0 | Positive | Negative | | 1 | 0 | Negative | Positive | | 1 | 1 | Negative | Negative | #### **Packing** Packing refers to the conversion of numbers in the form kBn to floating-point format. A shortcut method of packing exponents can be derived by considering the representation of negative and positive zero exponents. Assuming a positive coefficient, zero exponents are packed as follows: Positive zero exponent 2000x,...,x Negative zero exponent 1777x,...,x Since positive exponents are expressed in true form, begin with a bias of 2000 (positive zero) and add the magnitude of the exponent. The range of positive exponents is 0000 through 1777. In packed form, the range is 2000 through 3777. When the coefficient is negative, the packed positive exponent is complemented to become 5777 through 4000. Negative exponents are expressed in complement form by beginning with a bias of 1777 (negative zero) and then subtracting the magnitude of the exponent. The range of negative exponents is negative 0000 through negative 1777. In packed form, the range is 1777 through 0000. When the coefficient is negative, the packed negative exponent is complemented to become 6000 through 7777. Examples of packed and unpacked floating-point numbers are shown in octal notation to illustrate the packing process. Examples 1 and 2 are different forms of the integer positive 1. Example 3 is positive 100 (decimal), and example 4 is negative 100 (decimal). Examples 5 and 6 are large and small positive numbers. The unpacked values are shown as they might appear in the X and B registers prior to a pack operation. The packed negative zero exponent is not used for normal operation. Instead, 1777 is used to indicate the special error condition of indefinite. | | 1. | Unpacked<br>coefficient | 0000 | 0000 | 0000 | 0000 | 0001 | |---------|----|-------------------------|------|-------------|------|------|------| | +1 | | Unpacked<br>exponent | 00 | 0000 | (18) | | | | 1 > | | Packed<br>format | 2000 | 0000 | 0000 | 0000 | 0001 | | | 2. | Unpacked<br>coefficient | 0000 | 4000 | 0000 | 0000 | 0000 | | + 1 | | Unpacked exponent | 77 | 7720<br>\oo | | | | | | | Packed<br>format | 1720 | 4000 | 0000 | 0000 | 0000 | | | 3. | Unpacked<br>coefficient | 0000 | 6200 | 0000 | 0000 | 0000 | | x100 | | Unpacked<br>exponent | 77 | 7726 | | | | | | | Packed<br>format | 1726 | 6200 | 0000 | 0000 | 0000 | | | 4. | Unpacked<br>coefficient | 7777 | 1577 | 7777 | 7777 | 7777 | | /00 | | Unpacked exponent | 77 | 7726 | | | | | | | Packed<br>format | 6051 | 1577 | 7777 | 7777 | 7777 | | | 5• | Unpacked coefficient | 0000 | 4771 | 3000 | 0044 | 7021 | | + LAFGE | / | Unpacked exponent | 00 | 1363 | | | | | • | | Packed<br>format | 3363 | 4771 | 3000 | 0044 | 7021 | | 6. | Unpacked coefficient | 0000 | 6301 | 0277 | 4315 | 6033 | |--------|----------------------|------|------|------|------|------| | ISMALL | Unpacked exponent | 77 | 6210 | | | | | | Packed<br>format | 0210 | 6301 | 0277 | 4315 | 6033 | #### Overflow Overflow of the floating-point range is indicated by an exponent value of positive 1777 (3777 or 4000 in packed form). This is the largest exponent value that can be represented in the floating-point format. This exponent value may result from the calculation in which this exponent value, together with the computed coefficient value, is a correct representation of the result. This situation is called a partial overflow. However, further computation using this result generates an overflow. A complete overflow occurs whenever a result requires an exponent larger than positive 1777. In this case, a complete overflow value results. This result has a positive 1777 exponent and a zero coefficient. The sign of the coefficient is the same as that which generates if the result had not overflowed the floating-point range. #### Underflow Underflow of the floating-point range is indicated by an exponent value of negative 1777 (0000 or 7777 in packed form). This is the smallest exponent value that can be represented in the floating-point format. This exponent value may result from the calculation in which this exponent value, together with the computed coefficient value, is a correct representation of the result. This situation is called a partial underflow. Further computation using this result may be detected as an underflow. A complete underflow occurs whenever a result requires an exponent smaller than negative 1777. In this case, a complete underflow value results. This result has a negative 1777 exponent and a zero coefficient. The complete underflow indicator is a word of all zeros, and it is the same as a zero word in integer format. ## Indefinite An indefinite result indicator generates whenever the calculation cannot be resolved. An example is division when the divisor is 0 and the dividend is also 0. Another example is multiplication of an overflow number times an underflow number. The indefinite result indicator is a value that cannot occur in normal floating-point calculations. This indicator corresponds to a negative 0 exponent and a 0 coefficient (177770,...,0 in packed form). Any indefinite indicator used as an operand generates an indefinite result no matter what the other operand value is. Although indefinite indicators always generate with a positive sign, they may occur as operands with a negative sign. ## **Nonstandard Operands** In summary, the special operand forms in octal are: Positive overflow (+ @ ) 3777x,...,x Negative overflow (- @ ) 4000x,...,x Positive indefinite (+IND) 1777x,...,x Negative indefinite (-IND) 6000x,...,x Positive underflow (+0) 0000x,...,x Negative underflow (-0) 7777x,...,x Tables 5-2 through 5-5 indicate the resulting forms when various combinations of underflow, overflow, and indefinite forms are used in floating-point operations. The designations W and N are defined as follows: - W Any word except + OO and + IND - N Any word except $+ \infty$ , + IND, and + 0 ### **Normalized Number** A normalized floating-point number has as large a coefficient and as small an exponent as possible. A floating-point number in packed format is normalized if the coefficient sign bit is different from bit 47. This condition indicates that the coefficient has been left shifted until bit 47 contains the most significant bit in the coefficient; therefore, the floating-point number has no leading sign bits in the coefficient. The normalized instructions perform the coefficient shift. The floating-multiply and floating-divide instructions deliver normalized results when provided with normalized operands. The floating-add instructions may deliver unnormalized results even when both operands are normalized. Therefore, it is necessary to perform the normalize operation after each sequence of floating-add or floating-subtract operations if the result is to be kept in a normalized form. #### Rounding Floating-point instructions round the results in single-precision computation. These instructions execute in the same amount of time as the unrounded versions. The operands are modified to accomplish the rounding function. The amount of bias introduced by the rounding operation varies and is affected by the coefficient value in the operands. The descriptions of the round instructions define the effects of rounding in detail. ## **Double-Precision Results** The floating-point arithmetic instructions generate double-precision results. Use of unrounded instructions allows separate recovery of upper and lower half results with proper exponents. Rounded instructions allow only upper half results to be obtained. Two instructions, one single-precision and one double-precision, are required to retrieve an entire double-precision result. To add or subtract two floating-point numbers, the coefficient having the smaller exponent enters the upper half of an accumulator and is right shifted by the difference of the exponents. The other coefficient is then added into the upper half of the accumulator. The result is a double-length register with the format shown in figure 5-3. Figure 5-3. Floating-Add Result Format If single precision is selected, the upper 48 bits of the 96-bit result and the larger exponent are returned as the result. Selecting double precision causes only the lower 48 bits of the 96-bit result and the larger exponent minus 60 (octal) to be returned as the result. The subtraction of 60 (octal) is necessary because the binary point is effectively moved from the right of bit 48 to the right of bit 0. A 96-bit product generates from two 48-bit coefficients. The result of a multiply is a double-length register with the format shown in figure 5-4. Figure 5-4. Multiply Result Format If single precision is selected, the upper 48 bits of the product and the sum of the exponents plus 60 (octal) are returned as the result. The addition of 60 (octal) is necessary because the binary point effectively moves from the right of bit 0 to the right of bit 48 when the upper half of the 96-bit result is selected. If double precision is selected, the result is the lower 48 bits of the product and the sum of the exponents. ### **FIXED-POINT ARITHMETIC** Fixed-point addition and subtraction of 60-bit numbers are handled by the long-add instructions (36 and 37). Negative numbers are represented in one's complement notation, and overflows are ignored. The sign bit is in the high-order bit position (bit 59), and the binary point is to the right of the low-order bit position (bit 0). Fixed-point addition and subtraction of 18-bit numbers are handled by the increment instructions (50 through 77). Negative numbers are represented in one's complement notation, and overflows are ignored. The sign bit is in the high-order bit position (bit 17), and the binary point is to the right of the low-order position (bit 0). | | i | · · · · · · · · · · · · · · · · · · · | | | | |----|-------|---------------------------------------|------|------|-------| | | | | X | k | | | | | W | +∞ | - 00 | + IND | | | W | | +∞ | -∞ | IND | | v: | +∞ | + ∞ | + 00 | IND | IND | | Xj | - ∞ | -8 | IND | - ∞ | IND | | | ± IND | IND | IND | IND | IND | | | | Xk | | | | | | |----|-------|-----|-----|-----|-------|--|--| | | | w | +ω | -8 | + IND | | | | | W | | -8 | +∞ | IND | | | | | + ω | +∞ | IND | + Φ | IND | | | | Xj | - ∞ | -ω | - ∞ | IND | IND | | | | | ± IND | IND | IND | IND | IND | | | Table 5-4. Xj Multiplied by Xk (40, 41, 42 Instructions) | | | | Xk | | | | | | |----|-------|-----|-----|-----------|-----------------|------|------|-------| | - | | +N | -N | +0 | -0 | + 00 | -00 | + IND | | | +N | | | 0 | 0 | +∞ | - ∞ | IND | | | -N | | | 0 | 0 | - 00 | +∞ | IND | | | +0 | 0 | . 0 | Integer t | | IND | IND | IND | | Хj | -0 | 0 | 0 | mui | eger†<br>Itiply | IND | IND | IND | | | +ω | +∞ | - ω | IND | IND | + 00 | - 00 | IND | | | -ω | | +∞ | IND | IND | -ω | +∞ | IND | | | ± IND | $<sup>\</sup>ensuremath{^{\dagger}}$ If both operands used in the integer multiply are normalized, an underflow results. Table 5-5. Xj Divided by Xk (44, 45 Instructions) | | | | | | VI. | | | | |----|--------------|-----|-----|-----|-----|-----|-----|-------| | | | • | 4 | · | Xk | | | | | | | +N | √-N | +0 | -0 | + Φ | - ω | + IND | | | +N | | | +∞ | -ω | .0 | 0 | IND | | ; | -N | | | -ω | +∞ | 0 | 0 | IND | | | +0 | 0 | 0 | IND | IND | 0 | 0 | IND | | Хj | -0 | 0 | 0 . | IND | IND | 0 | 0 | IND | | | +∞ | +∞ | -ω | +ω | - ∞ | IND | IND | IND | | | - & | -ω | +ω | - ω | +ω | IND | IND | IND | | - | <u>+</u> IND | Integer multiplication is handled as a subset operation of the floating-multiply (42) instruction. The integer multiply requires that both 47-bit integer operands have zero exponents and are not normalized. The result is 48 bits with sign extension. Normalized operands cause underflow results to be reported. If the results exceed 48 bits, overflow is not detected. An integer divide takes several steps. For example, an integer quotient X1 equal to X2/X3 is produced by the following steps. | | Instructions | Remarks | |----|--------------------------------------|---------------------------| | 1. | Pack X2 from X2<br>and B0 | Pack X2 | | 2. | Pack X3 from X3 and B0 | Pack X3 | | 3. | Normalize X3 in X0 and B0 | Normalize X3 (divisor) | | 4. | Normalize X2 in X2 and B0 | Normalize X2 (dividend) | | 5. | Floating quotient of X2 and X0 to Xi | Divide | | 6. | Unpack X1 to X1 and B7 | Unpack quotient | | 7. | Shift X1 nominally<br>left B7 places | Shift to integer position | The divide requires that both integer ( $2^{47}$ maximum) operands be in floating-point format, and the dividend coefficient must be less than two times the divisor coefficient. The normalize X3 instruction ensures this condition. The normalize X3 instruction left shifts the divisor n places $(n\geq 0)$ , providing a divisor exponent of negative n. The quotient exponent is then 0 minus (-n) minus 48 equals n minus 48<0. After unpacking and left shifting nominally, the negative (or zero) value in B7 right shifts the quotient 48 minus n places, producing an integer quotient in X1. A remainder may be obtained by an integer multiply of X1 and X3 and subtracting the result from X2. #### INTEGER ARITHMETIC Integer divide packs the integers into floating-point format using the pack instruction with a zero-exponent value. In integer multiplication, a 48-bit product can be formed by using the double-precision multiply instruction. Both operands must have an exponent value of $\pm 0$ , and the coefficients cannot both be normalized. The result is sign-extended to 60 bits and sent to an X register. In integer division, the divisor must be normalized but the dividend need not be normalized. The resulting quotient must be unpacked and the coefficient shifted by the amount of the unpacked exponent using the left shift (22) instruction to obtain the integer quotient. #### COMPARE/MOVE ARITHMETIC The compare/move arithmetic provides multiple character manipulation. The characters are 6 bits long. Characters can be moved from one CM location to another, and fields of characters can be compared either directly or through a collate table. The move direct instruction moves a field of up to 127 characters from one location to another location as specified in the instruction. The move indirect instruction performs the same kind of move, but a CM reference is used to obtain the parameters. The move indirect instruction moves a field of up to 8181 characters. The compare collated instruction compares two fields of up to 127 characters. When two characters are unequal, the characters are referenced in a collate table, and the values are compared. If those values are unequal, the field with the larger character is indicated. The compare uncollated instruction compares two fields of up to 127 characters and indicates the larger of the first character pair that is found to be unequal. CMU instructions are provided for compatibility with previous systems. For better performance, recompile jobs to avoid use of CMU instructions. #### INSTRUCTION LOOKAHEAD PURGE CONTROL Prefetching of instructions at a branch target address by instruction lookahead hardware can lead to program failures if a program modifies its own code dynamically. Under normal conditions, the lookahead registers are purged by execution of a return jump instruction (010), UEM read instruction (011), exchange jump instruction (013), or unconditional branch instruction (02). These conditions can be extended by selecting extended purge control. When extended purge control is in effect, lookahead registers are also purged by execution of any conditional jump instruction (03 through 07) or any CM store instruction (50 through 57 when i equals 6 or 7). To enable extended purge control, the system sets bit 52 of the flag register in the CYBER 170 exchange package. self-modifying code is present, it may be helpful to set extended purge control; however, the additional purging does cause a degradation in execution and does not cover all cases of code modification. # Model 835 Purge Control If normal purge conditions are in effect, a store instruction that modifies a sequential instruction must modify at least P plus five words ahead to ensure execution of the modified code. A store instruction followed by a branch to a modified instruction will execute the modified code only if that code is at least at the branch's target address plus two words, or the branch is at least at P plus four words following the store instruction. If the extended purge option is selected, a store instruction can modify the next sequential instruction and be assured of executing the modified instruction. Likewise, a store instruction followed by a branch to a modified instruction always executes the modified code. If normal purge conditions are in effect, a store instruction that modifies a sequential instruction must modify at least P plus six words ahead to ensure execution of the modified code. In addition, a store instruction followed by a branch to a modified instruction will execute the modified code only if there are at least 12 executed instructions between the store and the modified code. If the extended purge option is selected, a store instruction can modify the next sequential instruction and be assured of executing the modified instruction. Likewise, a store instruction followed by a branch to a modified instruction always executes the modified code. # **Model 990 Purge Control** If normal purge conditions are in effect, a store instruction that modifies a sequential instruction must modify at least P plus 64 words ahead to ensure execution of the modified code. In addition, a store instruction followed by a branch to a modified instruction will execute the modified code only if there are at least 64 executed instructions between the store and the modified code and only if there are four branch instructions to four different 16-word blocks of instructions between the store and the modified code (the modified code must not reside in one of the blocks jumped to). If the extended purge option is selected, a store instruction can modify the next sequential instruction and be assured of executing the modified instruction. Likewise, a store instruction followed by a branch to a modified instruction always executes the modified code. #### **ERROR RESPONSE** When the CP detects or is informed of an error, it records the error. Depending upon the type of error and the exit mode selection bits set in the EM register, the program in execution may be interrupted. If the error is an illegal instruction or an addressrange error on an RNI or branch, the program interruption is unconditional. For other types of errors, the exit mode selection bits determine whether or not the program is interrupted. If the exit mode selection bit is set and the corresponding condition is detected, the program is interrupted. The exit mode selection bits are contained in word N plus 3 of the exchange package. Figure 5-5 shows the format of the exit condition register at (RAC). Table 5-6 describes the possible contents of the register. Tables 5-7 and 5-8 list CP error responses. The CP has the following error conditions: illegal instructions, hardware errors, and conditional software errors. ### **Illegal Instructions** An instruction is illegal when it has an illegal operating code, an illegal operating parameter, or when it is positioned so that it begins in one instruction word and extends into the next instruction word. In the CYBER 170 job mode, illegal instructions cause an exchange to the CYBER 170 monitor mode. In the CYBER 170 monitor mode, they cause a jump to executive state; the CP stops. CP illegal instructions are: - 017. - 011, 012, 013, 464, 465, 466, 467 if they do not begin at parcel 0. - 011, 012, 014, 015 if the UEM enable flag in the flag register of the CYBER 170 exchange package is clear. - Any 30-bit instruction which begins at parcel 3. Figure 5-5. Format of Exit Condition Register at (RAC) Table 5-6. Contents of Exit Condition Register at (RAC) | Field | Description | | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | ec | 6-bit exit condition code | | | | Code Condition | | | | 00 <sub>8</sub> Illegal instruction<br>01 <sub>8</sub> Address-range error (bit 48)<br>02 <sub>8</sub> Floating-point infinite<br>(bit 49) | | | | 04 <sub>8</sub> Floating-point indefinite<br>(bit 50) | | | | 20g Processor-detected malfunction | | | | 67 <sub>8</sub> Hardware malfunction | | | P | When an error exit occurs, the content of the P register may not correspond to the address of the instruction that caused the error exit. The P register may have been incremented prior to the execution of the instruction. | | | ERROR<br>STATUS | Nonzero information in bits 0 through 29 is error status for customer engineering and maintenance. | | ### **Hardware Errors** CP/CM hardware errors are: data parity errors, address parity errors, and double bit errors. If the CP is in CYBER 170 job mode, a hardware error causes a jump to executive state which returns to CYBER 170 monitor mode. If the CP is in CYBER 170 monitor mode, a hardware error causes a jump to executive state; the CP halts. The instruction being executed when such a fault is detected is not necessarily connected with the fault. Table 5-7. Error Exits in CYBER 170 Monitor Mode (MF=1) (Sheet 1 of 2) | | Error Response | | | |---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|--| | Error Condition | Exit Mode Selected | Exit Mode Not Selected | | | Illegal instruction or 00 instruction. | 1. The instruction is not executed. | 1. N/A (exit mode is always selected). | | | | <ol> <li>Store P and exit condition<br/>bits (00) at location RAC. P equals<br/>address of illegal instruction.</li> </ol> | | | | | 3. Interrupt to executive state. | | | | | 4. CP stops in executive state. | | | | Exit condition bit 48 set by an incremental read with an | 1. The X register is unchanged. | 1. Inhibit read, X unchanged. | | | address out of range (AOR). | <ol><li>The A register contains the AOR address.</li></ol> | 2. Continue execution. | | | | <ol> <li>Store P and exit condition bits<br/>(01) at location RAC. P equals<br/>address of increment instruction<br/>or address of instruction following<br/>the increment.</li> </ol> | | | | | 4. Interrupt to executive state. | | | | | 5. CP stops in executive state. | | | | Exit condition bit 48 set by an incremental write with an address out of range (AOR). | <ol> <li>Block write operation; content of<br/>CM is unchanged.</li> </ol> | 1. Inhibit write, CM unchanged. | | | address out of range (AOK). | <ol><li>The A register contains the AOR address.</li></ol> | 2. Continue execution. | | | | <ol> <li>Store P and exit condition bits<br/>(01) at location RAC. P equals<br/>address of instruction or address<br/>of instruction following the<br/>increment.</li> </ol> | | | | | 4. Interrupt to executive state. | | | | | 5. CP stops in executive state. | | | | Exit condition bit 48 set by an RNI or branch address | 1. Inhibit execution. | N/A (exit mode is always selected regardless of status | | | out of range. | <ol> <li>Store P and exit condition bits<br/>(01) at location RAC. P equals<br/>address of instruction required<br/>by RNI or address of branch<br/>destination instruction.</li> </ol> | of EM register bit 48). | | | | 3. Interrupt to executive state. | | | | | 4. CP stops in executive state. | | | Table 5-7. Error Exits in CYBER 170 Monitor Mode (MF=1) (Sheet 2 of 2) | | Error Response | | | |-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--| | Error Condition | Exit Mode Selected | Exit Mode Not Selected | | | Exit condition bit 48 set on CMU instruction. | <ol> <li>Detected by executive state during<br/>the execution of compare/move<br/>instruction.</li> </ol> | <ol> <li>Detected by executive state<br/>during the execution of compare/<br/>move instruction.</li> </ol> | | | <ol> <li>C1 or C2 greater than 9.</li> <li>K1 or K2 address out of range.</li> </ol> | <ol> <li>Condition 1 omits reading/writing;</li> <li>CM is unchanged. Condition 2 causes the instruction to go unexecuted.</li> </ol> | 2. Condition 1 omits reading/writ-<br>ing; CM is unchanged. Condition<br>2 causes the instruction to go<br>unexecuted. | | | | <ol><li>Store P and exit bits (01) at<br/>RAC.</li></ol> | 3. Continue with next instruction. | | | | 4. CP stops in executive state. | | | | Exit condition bit 48 set by<br>a UEM address range check | 1. Execute instruction as a pass. | 1. Execute instruction as a pass. | | | for instructions 011 and 012. | 2. Store P and exit bits (01) at RAC. | 2. Exit to next 60-bit word and continue execution. | | | | 3. Interrupt to executive state. | | | | | 4. CP stops in executive state. | | | | Exit condition bit 48 set by a UEM address range check | 1. Execute instruction as a pass. | 1. Execute instruction as a pass. | | | for instructions 014 and 015. | <ol> <li>Store P and exit condition bits (01)<br/>at RAC. P equals address of follow-<br/>ing instruction.</li> </ol> | 2. Exit to next parcel and continue execution. | | | | 3. Interrupt to executive state. | | | | | 4. CP stops in executive state. | | | | Exit condition bit 49 set by infinite condition, or bit 50 set by indefinite condition. | <ol> <li>Store P and exit condition bits (02<br/>for infinite or 04 for indefinite).<br/>P equals address of arithmetic<br/>instruction or address of instruc-<br/>tion following.</li> </ol> | 1. Continue execution. | | | | 2. Interrupt to executive state. | | | | | 3. CP stops in executive state. | | | | Any hardware parity error or double SECDED error. | 1. Interrupt to executive state. | 1. Interrupt to executive state. | | | COURT DEPART CATOLO | <ol><li>Executive state stores P and exit<br/>condition bits (20) at RAC.</li></ol> | 2. Executive state stores P and exit condition bits (20) at RAC. | | | | 3. CP stops in executive state. | 3. CP stops in executive state. | | Table 5-8. Error Exits in CYBER 170 Job Mode (MF=0) (Sheet 1 of 2) | | Error Response | | |-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------| | Error Condition | Exit Mode Selected | Exit Mode Not Selected | | Illegal instruction or 00 instruction. | 1. The instruction is not executed. | 1. N/A (exit mode is always selected). | | | <ol> <li>Store P and exit condition bits<br/>(00) at location RAC. P equals<br/>address of illegal instruction.</li> </ol> | | | | 3. Exchange jump to MA and set CYBER 170 MF. | | | Exit condition bit 48 set by an incremental read with an | 1. The X register is unchanged. | 1. Inhibit read, X unchanged. | | address out of range (AOR). | <ol><li>The A register contains the AOR address.</li></ol> | 2. Continue execution. | | | 3. Store P and exit condition bits (01) at location RAC. P equals address of increment instruction or address of instruction following the increment. | | | | <ol> <li>Exchange jump to MA and set CYBER<br/>170 MF.</li> </ol> | | | Exit condition bit 48 set by an incremental write with an | <ol> <li>Block write operation; content of<br/>CM is unchanged.</li> </ol> | 1. Inhibit write, CM unchanged. | | address out of range (AOR). | <ol><li>The A register contains the AOR address.</li></ol> | 2. Continue execution. | | | <ol> <li>Store P and exit condition bits<br/>(01) at location RAC. P equals<br/>address of instruction or address<br/>of instruction following the<br/>increment.</li> </ol> | | | | 4. Exchange jump to MA and set CYBER 170 MF. | | | Exit condition bit 48 set by an RNI or branch address | 1. Inhibit execution. | N/A (exit mode is always selected regardless of status | | out of range. | <ol> <li>Store P and exit condition bits (01) at location RAC. P equals address of instruction required by RNI or address of branch destination instruction.</li> </ol> | of EM register bit 48). | | | <ol> <li>Exchange jump to MA and set<br/>CYBER 170 MF.</li> </ol> | | Table 5-8. Error Exits in CYBER 170 Job Mode (MF=0) (Sheet 2 of 2) | | Error Response | | | |-----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--| | Error Condition | Exit Mode Selected | Exit Mode Not Selected | | | Exit condition bit 48 set on CMU instruction. | 1. Detected by executive state during the execution of compare/move instruction. | <ol> <li>Detected by executive state<br/>during the execution of compare/<br/>move instruction.</li> </ol> | | | <ol> <li>C1 or C2 greater than 9.</li> <li>K1 or K2 address out of range.</li> </ol> | <ol> <li>Condition 1 omits reading/writing;</li> <li>CM is unchanged. Condition 2 causes the instruction to go unexecuted.</li> </ol> | <ol> <li>Condition 1 omits reading/writ-<br/>ing; CM is unchanged. Condition<br/>2 causes the instruction to go<br/>unexecuted.</li> </ol> | | | | 3. Store P and exit bits (01) at RAC. | 3. Continue with next instruction. | | | | 4. Exchange jump to MA and set CYBER 170 MF. | | | | Exit condition bit 48 set by a UEM address range check | 1. Execute instruction as a pass. | l. Execute instruction as a pass. | | | for instructions 011 and 012. | 2. Store P and exit bits (01) at RAC. | <ol> <li>Exit to next 60-bit word and<br/>continue execution.</li> </ol> | | | | <ol> <li>Exchange jump to MA and set CYBER<br/>170 MF.</li> </ol> | | | | Exit condition bit 48 set by a UEM address range check for | 1. Execute instruction as a pass. | 1. Execute instruction as a pass. | | | instructions 014 and 015. | 2. Stop CP. | <ol><li>Exit to next parcel and<br/>continue execution.</li></ol> | | | | 3. Store P and exit condition bits (01) at location RAC. | | | | | <ol> <li>Exchange jump to MA and set CYBER<br/>170 MF.</li> </ol> | | | | Exit condition bit 49 set by infinite condition, or bit 50 set by indefinite condition. | <ol> <li>Store P and exit condition bits<br/>(02 for infinite or 04 for indefi-<br/>nite). P equals address of arith-<br/>metic instruction or address of<br/>instruction following.</li> </ol> | 1. Continue execution. | | | | <ol><li>Exchange jump to MA and set CYBER<br/>170 MF.</li></ol> | | | | Any hardware parity error | 1. Interrupt to executive state. | 1. Interrupt to executive state. | | | or double SECDED error. | <ol><li>Executive state stores P and exit<br/>condition bits (20) at RAC.</li></ol> | 2. Executive state stores P and exit condition bits (20) at RAC. | | | | <ol><li>Exchange jump to MA and set CYBER<br/>170 MF.</li></ol> | 3. Exchange jump to MA and set<br>CYBER 170 MF. | | ### Conditional Software Errors Conditional software errors are caused by address-range errors, and floating-point infinite/indefinite operands or results. A conditional software error causes action depending on bits set in the EM field in the current CYBER 170 exchange package. If the bit reserved for use with the specific type of error is clear, the error is ignored in both CYBER 170 job and CYBER 170 monitor modes. If the bit is set and the error occurs in the CYBER 170 job mode, it causes an exchange to the CYBER 170 monitor mode. If the bit is set and the error occurs in the CYBER 170 monitor mode, it causes an interrupt to executive state. # **MEMORY PROGRAMMING** All references to CM by the CP for instructions or read/write data are made relative to RAC. The RAC defines the lower limit of the addresses of a program in CM. The upper limit of the program addresses is defined by FLC added to RAC. All references to UEM by the CP for instructions or read/write data are made relative to RAE. The RAE defines the lower limit of the addresses of a program/data in UEM. The upper limit of the addresses is defined by FLE added to RAE. The field length is a number of 60-bit words established by the operating system prior to program execution. All references to CM or UEM for a program/data must be within the field established for that program. During a CYBER 170 exchange jump, RAC and FLC are loaded into respective registers to define the CM limits of the program that is initiated by the CYBER 170 exchange jump. RAE and FLE are loaded to define the UEM limits of a program. Figure 5-6 shows the absolute and relative memory addresses, RAC, FLC, RAE, and FLE register relationships. For a program to operate within the established limits, the following conditions must exist. For absolute memory addresses: $RAC \leq (RAC + P) < (RAC + FLC)$ For relative memory addresses: 0 < P < FLC #### **ADDRESSING MODES** UEM can be used in either of two addressing modes: standard or expanded. Standard addressing mode provides addressing up to 21 bits in a 24-bit format. Expanded addressing mode provides addressing up to 24 bits in a 30-bit format. Addressing mode is determined by the expanded addressing select flag, bit 55 of word 3 in the CYBER 170 exchange package. ## DIRECT READ/WRITE INSTRUCTIONS (014, 015, 660, 670) These instructions transfer one 60-bit word between the selected X register and a memory location, using a 21-bit relative address. Instructions 660 and 670 use the memory address Xk (21 bits) plus RAC (21 bits) to address CM. Instructions 014 and 015 use the memory address Xk (21 bits) plus RAE (21 bits) to address UEM. ### **BLOCK COPY INSTRUCTIONS (011, 012)** These instructions transfer up to 131 071 60-bit words between fields in CM and UEM. The UEM address is XO plus RAE (bits 0 through 22 in standard addressing mode; bits 0 through 28 in expanded addressing mode). The CM address is AO plus RAC (if the block copy flag is clear in the CYBER 170 exchange package) or XO, bits 30 through 50, plus RAC (if the block copy flag is set). The transfers occur in blocks of up to 64 words, during which other CP activities are suspended. These instructions are 30-bit instructions which must start at parcel 0. If the UEM address has bit 21 or bit 22 set in standard addressing mode (bit 28 if in expanded addressing mode), zeros are transferred to CM and the next instruction is taken from parcel 2 of the same instruction word. If this is not the case on a block read, the next instruction is taken from parcel 0 of the next instruction word. A transfer of all zeros can be made to central memory using the 011 instruction and setting bit 21 or 22 (or bit 28) of the address (XO + RAE) when FLE is sufficiently large. Figure 5-6. Memory Map #### PP PROGRAMMING The PPs have access to all CM storage locations. One 64-bit word or a block of 64-bit words can be transferred from a peripheral processor memory (PPM) to CM or from CM to PPM. (Five 12-bit PP words equal one 64-bit CM word, with the leftmost 4 bits undefined.) Data from external devices is read into a PPM, and with additional instructions, is transferred to CM. Conversely, data is transferred from CM to a PPM and is then transferred by additional instructions to external devices. Addresses sent to CM from PPs are absolute or relocation addresses. #### **CENTRAL MEMORY ADDRESSING BY PPs** PPs address central memory using either absolute or relocation addressing. Every PP can read all central memory locations without restriction. Every PP has write access to central memory. The bounds register in central memory may also be set to limit write access from the IOU. Instructions 24/25 load/store the relocation (R) register. If bit 17 of the A register is zero, bits 0 through 16 of A specify an absolute central memory address 0 through 377 7778. If bit 17 of A is one, bits 0 through 16 of A are added to the 28-bit R register to specify an absolute central memory address 0 through 0 007 777 7778. If bit 17 of A changes during a transfer, the addressing mode also changes accordingly. The leftmost 7 bits of R represent extra addressing capacity which is unused. The rightmost 6 bits of R are appended zeros. Instruction 24 loads R from two consecutive PP memory locations. Instruction 25 stores R into two PP memory locations. Figure 4-4 shows how R is stored in PP memory. #### PP MEMORY ADDRESSING BY PPs PP instructions use 6-bit or 18-bit direct operands, or access PP memory through direct, indirect, or indexed addressing. #### **Direct 6-Bit Operand** PP instructions in this category are no-address instructions. They have the format OPCODEd. The d field is used as a 6-bit direct operand, zero-extended to 18 bits in calculations. #### Direct 18-Bit Operand PP instructions in this category are constant address instructions. They have the format OPCODEdm. The combined d and m fields are used as an 18-bit operand. #### Direct 6-Bit Address PP instructions in this category are direct address instructions. They have the format OPCODEd. The d field is used as a 6-bit direct address, accessing PP memory locations 0 to 778. #### **Direct 12-Bit Address** PP instructions in this category are indexed direct address instructions, with zero index. They have the format OPCODEdm, d equals 0. The m field is used as a 12-bit direct address, accessing PP memory locations 0 through 77778. #### **Indexed 12-Bit Address** PP instructions in this category are indexed direct address instructions. They have the format OPCODEdm, d equals 0. The m field is used as a 12-bit direct address (base address). The d field specifies a PP memory location from 1 to 778, the contents of which is a 12-bit one's complement number index. The indexed direct address is formed by adding the index to the base address as signed one's complement numbers, ignoring overflow. When m plus (d) equals 7777, the result is set to 0000, except as follows: adding 7777 plus 7777 equals 7777. In general, adding 0000 or 7777 leaves the other number unchanged, except when the other number is also 0000 or 7777. #### **Indirect 6-Bit Address** PP instructions in this category are indirect address instructions. They have the format OPCODEd. The 6-bit d field is used to read a 12-bit number from PP locations 0 through 778; this number is used as a 12-bit address to access PP memory locations 0 through 77778. #### **CENTRAL MEMORY READ/WRITE INSTRUCTIONS** PP instructions can read and write to central memory either single words or blocks of words. #### PP Central Memory Read Instructions (60, 61) Instruction 60 transfers one CM word into five 12-bit PP memory words. Instruction 61 transfers a block of 1 through 811 CM words into 5 through 4095 12-bit PP words; it is possible to transfer up to 4096 CM words overwriting PP memory cyclically; location 0, however, has special properties. Refer to instruction 61. #### PP Central Memory Write Instructions (62, 63) Instruction 62 transfers five 12-bit PP memory words into one CM word. Instruction 63 transfers 5 through 4095 PP memory words into 1 through 811 CM words. It is possible to transfer up to 20 480 PP memory words, repeating information from PP memory cyclically. #### INPUT/OUTPUT CHANNEL COMMUNICATIONS Data transfers to and from external devices are controlled by PP instructions 64 through 77. The assignment of PPs, transfer priorities and resolution of conflicts are software responsibilities. Channel parity and reservation must be provided for, using the channel marker flag and/or software interlocks in central memory. After any conflicts have been resolved, proceed as follows: | | Action | Typical Instruction | |----|-------------------------------------|-----------------------------------------------| | 1. | Clear error flag. | Jump if error flag set, and clear flag (661). | | 2. | Verify inactive status. | Jump if active (640). | | 3. | Verify read status. | | | | Prepare for reading summary status. | Function m (77). | | | Verify that the device responded. | Jump if active (640). | | | Activate channel. | Activate (74). | | | Read summary status. | Input to A (70). | | | Verify error flag clear. | Jump if error flag set (661). | | | Analyze summary status. | Logical product (12).<br>Zero jump (04). | | 4. | Enter number of words to A. | Load d (14). | | 5. | Prepare for input/output. | | responded. 6. Read/write data. Verify that the device | Activate channel. | Activate (74). | | |-----------------------------|-------------------------------|--| | Read/write data. | Input/output A words (71/73). | | | If write, loop until empty. | Jump if full (660). | | | Disconnect channel. | Deactivate (75). | | | Verify inactive status. | Jump if active (640). | | Verify inactive status. Jump if active (640). Jump if active (640). Prepare for read/write. Function m (77). #### Action #### Typical Instruction 7. Verify transfer integrity. | Verify A words | were | |-----------------|------| | transferred (re | fer | | to note). | | Nonzero jump (05). Verify error flag Jump if error flag set clear. ( (661). Verify inactive status. Jump if active (640). Prepare for reading device status. Function m (77). Verify that the device Jump if active (640). responded. Activate channel. Activate (74). Read device status. Input to A (70). Verify error flag clear. Jump if error flag set (661). (001). Analyze device status. Logical product (12). Nonzero jump (05). Disconnect channel. Deactivate (75). #### NOTE If A equals the original value, no words were transferred. If A is not equal to 0, the device or another PP ended the 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 the external devices of that channel for a data transfer. Both single word and block transfers can be used. Either the sending or the receiving PP can activate the channel used, after which the sending PP outputs data into the channel register of the channel concerned 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 in the same time slot. In such a case the transfer rate is one word every 500 nanoseconds. PPs which use the same time slots are as follows: | Slot | PP Number | | | |------|---------------|--|--| | 1 | 0, 5, 20, 25 | | | | 2 | 1, 6, 21, 26 | | | | 3 | 2, 7, 22, 27 | | | | 4 | 3, 10, 23, 30 | | | | 5 | 4, 11, 24, 31 | | | Software resolves priority and reservation problems arising in inter-PP communications by interlocks stored in CM or by other means. #### PP PROGRAM TIMING CONSIDERATIONS Some external equipment may require timing considerations in issuing function, activate, and input instructions. Refer to the applicable external equipment reference manual. Such timing considerations may, for example, be required to ensure that the equipment attains a proper speed before data is sent (required by some magnetic tape equipment). Also, equipment which terminates a data transfer by resetting the active flag to inactive often requires timing considerations in issuing the next function instruction. #### **CHANNEL OPERATION** #### **Channel Control Flags** Channel operation is affected by the channel active/inactive and full/empty flags and, depending on the status of these two flags, the channel is said to be active, inactive, full, or empty. Each channel also has a marker flag for software use, and an error flag for indicating transmission parity errors. #### Channel Active/Inactive Flag A channel is normally activated by a function (76 or 77) instruction or by an activate channel (74) instruction. The channel can also be activated by an external device. A function instruction conditions the external device for a coming data or status information transfer. The instruction places a 12-bit function word plus parity in the channel register and sets the active and full flags. The function word and a function signal are sent to the external device. No active or full signals are sent during a function instruction. The external device accepts the function word and sends an inactive signal which clears the channel active and full flags, clearing the channel register. An activate channel instruction prepares a channel for data transfer and sends an active signal to the external device. Subsequent input or output instructions transfer data. A disconnect channel (75) instruction after a data transfer returns the channel to an inactive state, and an inactive signal is sent to the external device. #### Register Full/Empty Flag A register is full when it contains a function or data word for an external device or contains a word received from the external device. The register is empty when the flag clears. The flag is turned on or off as the register changes state. A channel can only be full when it is active. On data output, the processor places a word in the channel register (the channel should be active and empty) and sets a full flag. The data word plus parity and a full signal are sent to the external device. The external device accepts the word and sends an empty signal to the channel which clears the full flag, clearing the channel register. The active and empty status of the channel signals the PP to send the next word to the register. On data input, the external device sends a word and a full signal to the data channel. The word is placed in the channel register, and the full flag sets. The PP stores the word and clears the full flag, clearing the data register. An empty signal is sent to the external device signaling it to send #### Channel (Marker) Flag Instructions (641, 651) This flag is used by software as a marker and does not affect hardware operation. When PPs in the same time slot use this flag, priority conflicts exist. For channel 17g (maintenance channel) marker flag, priority problems are resolved by hardware. For other channels, such conflicts must be resolved by software. Any five consecutively numbered PPs are not in the same time slot. #### Error Flag Instructions (661, 671) This flag indicates an input data parity error on the specific channel being tested. It also indicates an output data parity error on channels which have the capability of sending an error signal to the IOU in case of such an error. The status register of the device concerned must be read to verify output data integrity. #### **Channel Transfer Timing** Figure 5-7 shows channel transfer timing. All signal pulses are $25\pm5$ nanoseconds in width and occur $25\pm5$ nanoseconds following the 10-megahertz clock. To maintain the fastest possible cycle time (250 nanoseconds), a function/full/empty pulse from the PP must be answered with an inactive/empty/full pulse, respectively, within 310+35 nanoseconds. If the maximum speed is not required, this response time may be increased by multiples of 100 nanoseconds. The PP master clock frequency can be varied by $\pm 2$ percent. The peripheral devices used must tolerate this frequency variation. Figure 5-7. Channel Transfer Timing #### **INPUT/OUTPUT TRANSFERS** #### **Data Input Sequence** The external device sends data (figure 5-8) to the PP via the controller as follows: - 1. The PP places a function word in the channel register and sets the full flag and the channel active flag. At the same time, the PP sends the first of a group of words and function signals to all controllers. The function signals cause all controllers to sample the words and identify the words as function codes rather than data words. Connect codes select controllers and modes of operation and clear nonselected controllers. Only selected controllers are connected. - 2. The controller sends an inactive signal to the PP, indicating acceptance of the function code. The signal drops the channel active flag, which in turn drops the full flag and clears the channel register. - 3. The PP sets the channel active flag and sends an active signal to the controller which signals the input equipment to start sending data. - 4. The input equipment reads a 12-bit data word plus one parity bit and then sends the word with parity to the channel register with a full signal which sets the channel full flag (10 to 15 nanoseconds after the data arrives). - 5. The PP stores the word, drops the full flag, and returns an empty signal, indicating acceptance of the word. The input equipment clears its data register and prepares to send the next word. - Steps 4 and 5 repeat for each word transferred. - 7. At the end of the transfer, the controller clears its active condition and sends an inactive signal to the PP to indicate the end of the data. The signal clears the channel active flag to disconnect the controller and the PP from the channel. 8. As an alternative, the PP may choose to disconnect from the channel before the input equipment has sent all its data. The PP does this by dropping the active flag and sending an inactive signal to the controller which immediately clears its active condition and sends no more data, although the input equipment may continue to the end of its record or cycle (for example, a magnetic tape unit would continue to end-of-record and stop in the record gap). #### **Data Output Sequence** The PP sends data (figure 5-9) to the external device as follows: - 1. The PP places a function word in the channel register and sets the full flag and the channel active flag. The function signal causes all controllers to sample the word and identify the word as a function code rather than a data word. Connect codes select controllers and modes of operation and clear nonselected controllers. Only selected controllers are connected. - 2. The controller sends an inactive signal to the PP, indicating acceptance of the function code. The signal drops the channel active flag, which in turn drops the full flag and clears the channel register. - 3. The PP sets the channel active flag and sends an active signal to the controller which signals the output equipment that data flow is starting. - 4. The PP places a 12-bit data word plus one parity bit in the channel register and sets the full flag. Coincidently, the PP sends a word with parity and a full signal to the controller. - 5. The controller accepts the word and sends an empty signal to the PP where the signal clears the channel register and drops the full flag. - Steps 4 and 5 repeat for each PP word. - 7. After the last word is transferred and acknowledged by the controller empty signal, the PP drops the channel active flag and turns off the controller with an inactive signal. Figure 5-8. Data Input Sequence Timing Figure 5-9. Data Output Sequence Timing ## SYSTEM CONSOLE PROGRAMMING #### KEYBOARD A PP transmits function code 70208 to request data from the keyboard of the system console. The PP then activates the input channel and inputs one character from the keyboard. This character enters as the lower 6 bits of the word; the upper bits are cleared. There is no status report by the keyboard. Table 5-9 lists the keyboard character codes. Table 5-9. Keyboard Character Codes | Cl. | 0-1- | 01 | <b>6.1</b> | |-----------|------|-----------------|------------| | 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 | | н | 10 | 8 | 43 | | I | 11 | 9 | 44 | | J | 12 | + | 45 | | K | 13 | _ | 46 | | L | 14 | * | 47 | | м | 15 | 1 | 50 | | N | 16 | ( | 51 | | 0 | 17 | ) | 52 | | · P | 20 | Left blank key | 53 | | Q | 21 | = | 54 | | R | 22 | Right blank key | 55 | | s | 23 | <b>)</b> | 56 | | т | 24 | | 57 | | U. | 25 | Carriage return | 60 | | V | 26 | Backspace | 61 | | W | 27 | Space | 62 | | x | 30 | | | | Y Y | 31 | | | | Z | 32 | | | #### DATA DISPLAY Data is displayed within an 8- by 11-inch area of a cathode-ray tube (CRT). The display can be in character mode (alphanumeric) and/or dot mode (graphic). Two presentation areas (left and right) are displayed. Each is made up of 262 144 dot locations arranged in a 512-by-512 dot 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. #### Character Mode In character mode, three sizes are provided. 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 5-10 lists the display character codes. Table 5-10. Display Character Codes | | [ | | | |-----------|------|-----------|------| | Character | Code | Character | Code | | Space | 00 | o | 33 | | A | 01 | 1 | 34 | | В | 02 | . 2 | 35 | | c | 03 | 3 | 36 | | D | 04 | 4 | 37 | | E | 05 | 5 | 40 | | F | 06 | 6 | 41 | | G . | 07 | 7 | 42 | | н | 10 | 8 | 43 | | ı | 11 | 9 | 44 | | J | 12 | + | 45 | | K | 13 | - | 46 | | L | 14 | * | 47 | | м | 15 | / | 50 | | N | 16 | ( | 51 | | 0 | 17 | ) | 52 | | P | 20 | Space | 53 | | Q | 21 | = | 54 | | R | 22 | Space | 55 | | S | 23 | , | 56 | | Т | 24 | • | 57 | | U | 25 | | | | v | 26 | | | | w. | 27 | | 1 | | x | 30 | | | | Y | 31 | | | | z | 32 | | | #### 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 are formed by a series of X and Y coordinates. Vertical lines are formed by a single X coordinate and a series of Y coordinates. #### Codes A single function word is transmitted to select the presentation, mode, and character size (character mode only). Figure 5-10 illustrates the function word format. The word following the function word specifies the starting coordinates for the display (for either mode). Figure 5-11 illustrates the coordinate data word. In character mode, the words that follow are display character codes. Figure 5-12 illustrates the character data word. Figure 5-10. Display Station Output Function Code Figure 5-11. Coordinate Data Word Figure 5-12. Character Data Word When the display operation has started, the controller regulates character spacing on the line. A new coordinate data word must be sent to start each line. If new coordinates are not specified, data is written on the line specified by the active 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 5-13) requests an input of one line of data from the system console and displays this data on the CRT as it is being typed. Figure 5-13. Receive and Display Program Flowchart #### PROGRAMMING TIMING CONSIDERATIONS When performing an output operation, the computer must wait at the end of the output for a channel empty condition to prevent a loss of coordinates or data. A full jump at the end of the output ensures that the channel is empty and the display controller accepts the last word of the output before disconnecting from the channel. #### **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 through $4095_{10}$ . #### TWO-PORT MULTIPLEXER PROGRAMMING NOTE For two-port multiplexer programming, bit numbering within words is 0 through 63 from left to right. Channel 158 is reserved for communications with one or two external devices through the two-port multiplexer. One port is reserved for maintenance purposes and the other is reserved for future use. The two-port multiplexer can communicate with all external devices which use EIA standard RS-232C serial interface. The multiplexer 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 rate is switch selectable for each channel for operation between 110 and 9600 baud. These switches are located internally on the two-port multiplexer. #### TWO-PORT MULTIPLEXER OPERATION The two-port multiplexer uses the rightmost 12 bits on channel $15_8$ . A 12-bit (octal) function word from the PP is translated to specify the following operating conditions. | Code | <u>Function</u> | |--------------|--------------------------------------------------------------| | 7xxx | Terminal select | | 6XXX | Terminal deselect | | 00XX | Read status summary | | 01XX | Read terminal data | | 02XX | Write output buffer | | 03XX | Set operation mode to terminal | | 04XX | Set/clear terminal control signal, data terminal ready (DTR) | | 05 <b>XX</b> | Set/clear terminal control signal, request to send (RTS) | | 06XX | Not used | | 07XX | Master clear selected port | #### Terminal Select (7XXX) The PP sends this select code to specify the terminal to which the function codes and data transmissions apply. Code 7000 selects port 0 (for future use) and code 7001 selects port 1 (maintenance console). #### Terminal Deselect (6XXX) The PP sends this code which deselects the two-port multiplexer from channel $15_8$ so the 16-bit channel is available for inter-PP communications. #### Read Status Summary (00XX) This code permits the PP to input status from the selected terminal. One-word input must follow to read the status response. The response is 12 bits. | Bit | Status | |-------|-----------------------------------| | 52-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 permits the PP to input the terminal data from the selected terminal. Channel $15_8$ must be activated and a one-word input must follow to read in the terminal data. The data word is 12 bits. | Bit | Status | | | | |-------|------------------------------------------|--|--|--| | 52 | Data set ready | | | | | 53 | Data set ready and data carrier detector | | | | | 54 | Over run | | | | | 55 | Framing or parity error | | | | | 56-63 | 8-bit data | | | | #### Data Set Ready (Bit 52) When the data set ready signal is active, this bit sets. # Data Set Ready (DSR) and Data Carrier Detector (DCD) (Bit 53) When both data set ready and data carrier detector signals are active, this bit sets. #### Over Run (Bit 54) When the previously received character is not read by the PP before the present character is transferred to the data holding register, the over run bit sets. #### Framing or Parity Error (Bit 55) When the received character does not have a valid stop bit (framing error), or when this bit sets, the received character parity does not agree with the select parity (parity error). #### Data Character (Bits 56 through 63) The lower 8 bits of the input word form the data character. The multiplexer forms this character directly from the Universal Asynchronous Receiver and Transmitter (UART). #### PP Write Output Buffer (02XX) This code prepares the multiplexer for an output operation to the 64-character output buffer memory. Before an output operation can proceed, channel 15g must be activated. The output operation is terminated when the multiplexer receives an inactive signal from the PP, or when no more locations are available in the output buffer. In the latter case, an inactive (instead of empty) signal is sent back to the channel, which in turn will terminate the output operations. #### Set Operation Mode to the Terminal (03XX) This code permits the PP to set the terminal operation mode register. A 12-bit function code word from the PP specifies the operation of the terminal. This word is decoded in the function register. Segments of the word define the mode as follows: | 58 | Not used | |----|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 59 | No parity | | | When this bit is set, it eliminates the parity bit from the transmitted and received characters. The stop bit(s) immediately follow the last data bit. | Status | Bit | Status | |-----|--------| | | 0,000 | 60 Number of stop bits This bit selects the number of stop bits, 1 or 2, to be appended immediately after the parity bit. When this bit is clear, it inserts 1 stop bit and when set, it inserts 2 stop bits. 61-62 Number of bits per character These 2 bits are internally decoded to select 5, 6, 7, or 8 data bits per character. | Bit 61 | Bit 62 | Bits per | Character | |--------|--------|----------|-----------| | 0 | 0 | 5 | | | 0 | 1 | 6 | | | 1 | 0 | 7 | | | 1 | 1 | 8 | | 63 Odd/even parity select This bit selects the type of parity which will be appended immediately after the data bits. It also determines the parity that will be checked on read data. #### Set/Clear Data Terminal Ready (04XX) This code permits the PP to set or clear the terminal control signal, data terminal ready (DTR). When bit 63 is set, DTR is active, and when bit 63 is clear, DTR is inactive. #### Set/Clear Request to Send (05XX) This code permits the PP to set or clear the terminal control signal, request to send (RTS). When bit 63 is set, RTS is active, and when bit 63 is clear, RTS is inactive. #### Master Clear (07XX) This code permits the PP to master clear the selected port including its output buffer memory and UART. The terminal operation mode register and terminal control signals are not cleared. #### **PROGRAMMING CONSIDERATIONS** Channel 15<sub>8</sub> communicates with the terminals connected to the external interface, one at a time. To establish communications between a PP and the terminal, the PP issues a function for select. The function word for select is formed by the least significant 12 bits, sent to channel 15<sub>8</sub>, and specifies the following information. Bit - A select code to select the multiplexer (7XXX). - The terminal with which the PP would like to establish communication (7XXX). When the connect is established, the two-port multiplexer routes all data to the terminal designated by the select code. The multiplexer responds with the inactive signal to acknowledge the receipt of the function code of 7XXX for select, 6XXX for deselect, and 0XXX for operation. Otherwise, the function is ignored by the multiplexer. #### **Output Data** The multiplexer accepts a maximum data block length of 64 characters per terminal. During the block data transfer, the multiplexer terminates the output operation either when it receives an inactive signal from the channel or when the output buffer is full. When the output buffer is full, the multiplexer sends back an inactive signal instead of an empty signal to the channel on the last output word. The signal indicates the output buffer accepts the last output word and it cannot receive anymore data from the PP. Output to a full buffer is not allowed by the multiplexer. The multiplexer sends back an inactive signal to deactivate channel 15g after the multiplexer decodes the previous function code which is O2XX (PP write output buffer), and receives an activate signal from the PP. #### **Input Data** The multiplexer does not store the input data from the terminal. A lost data condition exists if the PP does not input the previous data before the new data arrives from the terminal. The multiplexer allows input from an empty input buffer. #### Request to Send and Data Terminal Ready Request to send and data terminal ready are brought up automatically by the hardware under the following conditions regardless of the software RTS and DTR bits. - Data in the UART output register. - Data in the FIFO output register. When no data is in the FIFO or UART, the software bit determines RTS and DTR. #### MAINTENANCE CHANNEL PROGRAMMING NOTE Maintenance registers are numbered 0 through 63 from left to right. #### MAINTENANCE CHANNEL A PP in the IOU can perform any or all of the following operations through the maintenance channel (MCH) to each system element, such as the CP, IOU, and CM. - Initializing registers, controls, and memories. - Monitoring and recording error information. - Verifying error detection and correction hardware. The maintenance channel consists of the maintenance channel interface on channel $17_8$ , a maintenance channel interface in each system element, and a set of interconnecting cables. The IOU maintenance channel interface contains a selector that connects to one of up to seven system elements. The IOU is element 0 and its maintenance access control is internally connected to the selector. All other system elements are assigned arbitrary element numbers. Each maintenance access control is connected to the selector by a single cable. This arrangement results in a radial connection that allows any system element to be shut down or removed without affecting communication with the other elements. #### MCH FUNCTION WORDS The MCH function word consists of the connect, opcode, and type fields which are used as described in the next three paragraphs and tables 5-11, 5-12, and 5-13. The connect field specifies the unit to which the MCH is connected (CP, CM, or IOU), controlling selection within the IOU only. The unit remains connected until another connect code selects a different unit. Connect codes 10g to 17g leave the MCH unconnected; in this state the interface can be used for PP to PP communications. 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. When the CP is the connected unit, type codes 1 through A<sub>16</sub> (model 835) or 1 through 7 (models 840, 845, 850, 855, and 860) specify the data type in the operation to be performed. Also, for the CP, type code O specifies that the internal address of the CP register to be connected is specified in a control word which is sent as two data words immediately following the function word. When IOU is the connected unit, type codes 0 through 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 zeros. The exceptions are reading the options installed and element identifier registers. On the model 835, CM ignores the type code. On models 840, 845, 850, 855, and 860, CM uses A<sub>16</sub> to access maintenance registers. Table 5-11. MCH Function Word Bit Assignments | Field | | Description | |---------------------|---------------------------------------------------|------------------------------------------------------------------------------------| | | | MCH Function Word to Model 835 CP | | CONNECT (bits 8-11) | Code 2 <sub>16</sub> = | Connect CP maintenance registers | | OPCODE (bits 4-7) | Code $0_{16} =$ | Halt processor | | | <sup>1</sup> 16 = | Start processor | | | 416 =<br>5 <sub>16</sub> = | Prepare for read (control word required) Prepare for write (control word required) | | | 6 <sub>16</sub> = 7 <sub>16</sub> = | Master clear | | | 7 <sub>16</sub> = | Clear errors | | TYPE (bits 0-3) | Code 0 <sub>16</sub> = | Control word required | | | | MCH Function Word to Model 835 CM | | CONNECT (bits 8-11) | Code 1 <sub>16</sub> = | Connect CM maintenance registers | | OPCODE (bits 4-7) | Code $4_{16} =$ | Prepare for read (control word required) | | | <sup>5</sup> 16 = | Prepare for write (control word required) | | | 6 <sub>16</sub> = 7 <sub>16</sub> = | Master clear<br>Clear fault status register | | | · · · · · · · · · · · · · · · · · · · | MCH Function Word to Models 840, 845, 850, 855, | | | | 860, and 990 CP and CM | | CONNECT (bits 8-11) | Code 1 <sub>16</sub> = | Required for models 845 and 855 CP and CM | | TYPE (bits 0-3) | Code $0_{16}$ = | CP and CP registers | | OPCODE (bits 4-7) | Code $0_{16} =$ | Halt processor | | | <sup>1</sup> 16 = | Start processor | | | <sup>4</sup> 16 <del>=</del><br><sup>5</sup> 16 = | Prepare for read Prepare for write | | | 616 = | Master clear | | | <sup>7</sup> 16 = | Clear errors | | TYPE (bits 0-3) | Code 1 <sub>16</sub> = | Control store memory | | OPCODE (bits 4-7) | Code 4 <sub>16</sub> = | Prepare for read | | 010000 (0103 4 7) | 5 <sub>16</sub> = | Prepare for write | | TYPE (bits 0-3) | Code 3-7 <sub>16</sub> = | Internal memories (all models areast 990) | | III (UIFO O_1) | 3 <sub>16</sub> = | Internal memories (all models except 990) Unused (Model 990) | | | <sup>4</sup> 16 = | ACU Control Memories (Model 990) | | | <sup>5</sup> 16 = 616 = 616 | BP3 Decode Memories (Model 990) Operand Cache (OCA) (Model 990) | | | 616 = 7 <sub>16</sub> = | Register File (RGU) (Model 990) | | | 8 <sub>16</sub> = | Load and Store Section (LSU) Control Memories (Model 990) | | | <sup>9</sup> 16 = | Error Processing Network (EPN) (Model 990) | | OPCODE (bits 4-7) | Code 4 <sub>16</sub> = | Prepare for read | | | 516 = | Prepare to write | | TYPE (bits 0-3) | Code A <sub>16</sub> = | CM and CM registers | | OPCODE (bits 4-7) | Code 4 <sub>16</sub> = | Prepare for read | | | <sup>5</sup> 16 = | Prepare for write | | | 6 <sub>16</sub> = | Master clear | | | <sup>7</sup> 16 = | Clear errors | Table 5-12. MCH Function Word Bit Assignments, All Models Except 990 | Field | | Description | |---------------------|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | MCH Function Word to IOU | | CONNECT (bits 8-11) | Code 0 <sub>16</sub> = | Connect IOU maintenance registers | | OPCODE (bits 4-7) | Code 4 <sub>16</sub> = 5 <sub>16</sub> = 6 <sub>16</sub> = 7 <sub>16</sub> = C <sub>16</sub> = | Prepare for read (control word required) Prepare for write (control word required) Master clear Clear fault status registers Read IOU status summary (reads one byte, control word not required) | | TYPE (bits 0-3) | Codes 0-7 <sub>16</sub> = | IOU registers are read circularly (byte 0 follows byte 7) from the byte specified by the TYPE field | Table 5-13. MCH Function Word Bit Assignments, Model 990 | Field | | | Description | | |---------------------|------|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--| | | | | MCH Function Word to IOU | | | CONNECT (bits 8-11) | Code | 0 <sub>16</sub> = | Connect IOU maintenance registers | | | OPCODE (bits 4-7) | | 316 =<br>416 =<br>516 =<br>616 =<br>716 =<br>816 =<br>C16 = | Clear LED Read Write Master Clear ADU/CMI Clear Fault Status Register Echo Request Summary Status Byte | | | TYPE (bits 0-3) | | | Type code must equal 0 | | #### MCH CONTROL WORDS Some function words must be followed by two 8-bit control words which specify the internal address of the register to be accessed. This is accomplished by transmitting two PP words where the rightmost 8 bits in each word are used. Control words are required for the following: - Function words to a model 835 CP with opcodes 4/5 (read/write) and type code 0. - Function words to models 840, 845, 850, 855, 860, and 990 CP with opcodes 4/5. - Function words to CM and IOU with opcodes 4/5. - Function words to CP, CM, and IOU with opcode 8 (echo). Refer to tables 5-14 through 5-20 for CP, CM, and IOU internal address assignments. ## MCH Programming for Halt/Start (Opcode 0/1) These operations consist of the output of a function word. A halt opcode halts the processor without damaging the process being executed, including the integrity of the interunit communication of the halted processor such as CDC CYBER 170 exchange request communication, central memory communications, and the process state. If the process is subsequently restarted without performing any other MCH operations, or after performing read/write with certain precautions as described in Operating Systems Manual, the process continues without damage. #### 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 first control word. - 3. Verify error flag clear. - 4. Output second 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/write as 64-bit (eight-byte) registers, requiring the input/output of eight MCH data words. Most registers which are physically smaller than eight bytes are right-justified with zero-fill. Exceptions are as follows: - Reading a status summary register repeats the status information in each byte. - The IOU may disconnect the MCH without affecting subsequent MCH operations in the following cases: - After reading one to eight bytes from any maintenance register. - After writing one byte to a corrected error log register. - After writing one byte to an uncorrected error log register. The following MCH operations on CP registers can be performed with the CP running or halted. - Read CP status summary register. - Read CP fault status register. - Read CP corrected error log registers. - Read CP options installed registers. - Read CP element identifier 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 these registers are accessed by microcode. Refer to the Maintenance Register Codes Booklet listed in the preface for register bit assignments. #### MCH Programming for Master Clear/Clear Errors (Opcode 6/7) These operations consist of the output of a single function word. The master clear immediately and arbitrarily clears the connected unit, without regard to possible information loss. Clear errors clears the error indicators in the connected unit; to avoid loss of error information while the errors are cleared, the unit concerned should be halted. #### 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 Status Summary (Opcode C, IOU Only) This operation is an alternative, faster means of reading the IOU status summary register. - 1. Issue function with opcode C. - 2. Input status summary byte. Table 5-14. Model 835 CP Internal Address Assignments | Internal | Address (1) | | | | |----------|-------------|-----|-----------|----------------------------------------| | Hex | 0ctal | (2) | pe<br>(3) | Description | | 00 | 000 | R | A | Status summary register | | 10 | 020 | R | A | Element identifier register | | 30 | 060 | R | A | Dependent environment control register | | 42 | 082 | R | M | Monitor condition register | | 80 | 200 | R | A | Processor fault status register | | 81 | 201 | R | A | Control store errors register | | 90 | 220 | R | A | Retry corrected error log register | | 92 | 222 | R | A | Cache corrected error log register | | 93 | 223 | R | A | Map corrected error log register | | | | | | | - (1) The internal address is the second byte of two 8-bit control words which must be supplied after a function word output with OPCODE = 4/5. The first byte is discarded. - (2) R = read, W = write - (3) A = always accessible, M = microcode accessible Table 5-15. Model 835 CM Internal Address Assignments | | | Internal Address (1) | | |---------------------------------|----------|----------------------|-----| | Description | Type (2) | Octal | Hex | | Status summary register | R | 000 | 00 | | Element identifier register | R | 020 | 10 | | Options installed register | R | 022 | 12 | | Corrected error log register | R/W | 240 | AO | | Uncorrected error log 1 registe | R/W | 244 | A4 | | Uncorrected error log 2 registe | R/W | 250 | A8 | - (1) The internal address is the second byte of two 8-bit control words which must be issued after a function word output with OPCODE = 4/5. The first byte is discarded. - (2) R = read, W = write Table 5-16. Models 840, 845, 850, 855, and 860 CP Internal Address Assignments | Internal | Address (1) | | | | | |----------|-------------|---|------------|----------------------------------------------|--| | Hex | Octal | | rpe<br>(3) | Description | | | 00 | 000 | R | A | Status summary register | | | 10 | 020 | R | A | Element identifier register | | | 30 | 060 | R | A | Dependent environment control register | | | 42 | 082 | R | M | Monitor condition register | | | 80-89 | 200-211 | R | A | Processor fault status registers 1 through 9 | | - (1) The internal address is the second byte of two 8-bit control words which must be supplied after a function word output with OPCODE = 4/5. The first byte is discarded. - (2) R = read, W = write - (3) A = always accessible, M = microcode accessible Table 5-17. Model 990 CP Internal Address Assignments | | | Ту | pe | | |-------|---------|-----|-----|----------------------------------------| | Hex | Octal | (2) | (3) | Description | | 00 | 000 | R | A | Status summary register | | 10 | 020 | R | A | Element identifier register | | 11 | 021 | R | A | Processor ID | | 12 | 022 | R | A | Options install | | 30 | 060 | R | A | Dependent environment control register | | 31 | 061 | R | A | Control store address | | 32 | 062 | R | A | Control store breakpoint | | 80-8F | 200-217 | R | A | Processor fault | - The internal address is the second byte of two 8-bit control words which must be supplied after a function word output with OPCODE = 4/5. The first byte is discarded. - 2. R = read, W = write - 3. A = always accessible, M = microcode accessible Table 5-18. Models 840, 845, 850, 855, and 860 CM Internal Address Assignments | Internal | Internal Address (1) | | | |------------|----------------------|----------|----------------------------------| | Hex | Octal | Type (2) | Description | | 00 | 000 | R | Status summary register | | 10 | 020 | R | Element identifier register | | 12 | 022 | R | Options installed register | | <b>A</b> 0 | 240 | R/W | Corrected error log register | | <b>A</b> 4 | 244 | R/W | Uncorrected error log 1 register | | A8 | 250 | R/W | Uncorrected error log 2 register | | | | | | - (1) The internal address is the second byte of two 8-bit control words which must be issued after a function word output with OPCODE = 4/5. The first byte is discarded. - (2) R = read, W = write Table 5-19. Model 990 CM Internal Address Assignments | Octal | Type (2) Descr | Description | |---------|-------------------------------------|---------------------------------------| | 000 | R | Status summary register | | 020 | R | Element identifier register | | 022 | R | Options install | | 040 | R/W | Environmental control | | 240-243 | R/W | Corrected error log | | 244-247 | R/W | Uncorrected error log | | - | 000<br>020<br>022<br>040<br>240–243 | 000 R 020 R 022 R 040 R/W 240-243 R/W | - The internal address is the second byte of two 8-bit control words which must be issued after a function word output with OPCODE = 4/5. The first byte is discarded. - 2. R = read, W = write Table 5-20. IOU Internal Address Assignments | Internal | Address (1) | | | |----------|-------------|----------|-----------------------------| | Hex | 0ctal | Type (2) | Description | | 00 | 000 | R | Status summary register | | 10 | 020 | R | Element identifier register | | 12 | 022 | R | Options installed register | | 18 | 030 | R/W | Fault status mask register | | 40 | 100 | R | Status register | | 80 | 200 | R/W | Fault status l register | | 81 | 201 | R/W | Fault status 2 register | | AO | 240 | R/W | Test mode | | | | | • | - The internal address is the second byte of two 8-bit control words which must be issued after a function word output with OPCODE = 4/5. The first byte is discarded. - 2. R = read, W = write # **GLOSSARY** | | | • | | |---------|---------------------------------------------------|--------|------------------------------------------------| | ADU | Assembly-disassembly unit | 1/0 | Input/output | | AOR | Address out of range | IOU | Input/output unit | | CEL | Corrected error log | MA | Monitor address | | CIF | CMU interrupted flag | МСН | Maintenance channel | | CM | Central memory | MF | Monitor flag | | CMU | Compare/move unit | MOS | Metal oxide semiconductor | | CP | Central processor | MUX | Multiplexer, selector | | CRT | Cathode-ray tube | OS | Operating system | | CTI | Common Test and Initialization | PE | Parity error | | DSC | Display station | PP | Peripheral processor | | DTR | Data terminal ready | PPM | Peripheral processor memory | | ECC | Error correction code | RAC | Reference address, central memory | | ECL | Emitter-coupled logic | RAE | Reference address, extended memory | | EDS | Extended deadstart | RAM | Random access (read-write) memory | | EIA | Electronic Industries Association | RNI | Read next instruction | | EM, EMS | Exit mode selection | ROM | Read-only memory | | EC | Exit condition code field at (RAC) | RTS | Request to send | | FIFO | First in, first out | SECDED | Single-error correction double-error detection | | FLC | Field length, central memory | UART | Universal Asynchronous Receiver and | | FLE | Field length, extended memory | OAKI | Transmitter | | HIVS | Hardware Initialization and Verification Software | UEM | Unified extended memory | | ILH | Instruction lookahead hardware | | | 60469290 A # **INDEX** | • | | |--------------------------------------------|---------------------------------------------------------| | A barrel failure 3-3 | Branch target address 2-1 | | A register, PP 2-13 | Buffers, queuing 1-6 | | Set instructions 2-2 | buffers, queuing 1-0 | | A registers, CP 1-6; 2-5 | | | | Casha sammantal among lan mandatan 5-22 | | Set instructions 4-17,18 | Cache corrected error log register 5-32 | | Absolute CM address formation 2-7,14; 5-12 | Cache invalidation bus interface 1-6 | | Absolute UEM address formation 2-9 | Cache memory 1-6; 2-7 | | Access, CM 2-8,15 | Cathode ray tube, see CRT | | Activate channel 4-38; 5-16 | Central exchange jump instruction 4-4 | | Active channel 5-16 | Central memory control (CMC) 1-6; 2-7 | | Add instructions 4-32,33,34,35 | Central memory, see CM | | Address designator 4-2 | Central processor, see CP | | Address format, CM 2-7 | Central read instruction 4-36 | | Address out of range error 2-6; 5-8,10 | Central write instruction 4-36 | | Address registers, see A registers | Channel active flag 5-16 | | Addressing | Channel control flag 5-16 | | Absolute address formation 2-7,14; 5-12 | Channel error flag 5-16 | | By PPs 5-14 | Channel flag instruction 5-16 | | CM 5-14 | Channel, I/O, see I/O channels | | CM by PPs 5-14 | Channel, maintenance, see maintenance channel | | PPM by PPs 5-14 | Channel marker flag 5-16 | | Relative address formation 5-12 | Channel transfer timing 5-16,17 | | Section in CP 1-6; 2-7 | Character address designator 4-2 | | Addressing mode | Character codes 5-21 | | Expanded 1-6; 2-7; 5-2,12 | Character manipulation 5-6 | | Standard 1-6; 2-7; 5-2,12 | Character mode 5-21,22 | | Alphanumeric characters 5-21 | Character size 5-21 | | Assembly/disassembly 2-15 | Characteristics, | | Auto mode bit 3-2 | Functional 1-3 | | | Physical 1-1 | | | Chassis configuration | | | Model 835 1-2 | | B registers 1-6; 2-5 | Models 845 and 855 1-3 | | Set instructions 2-4; 4-18 | Model 990 1-3 | | Bank cycle times 2-8 | Chip address field 2-7 | | Bank select field 2-8 | | | Banks, CM 1-6; 2-8 | CIF (CMU interrupted flag) 2-6<br>CLEAR AUTO switch 3-2 | | Barrel and slot 2-13 | | | Barrels 1-6; 2-13 | Clear channel error flag instruction 4-37 | | | Clear channel flag instruction 4-37 | | Logical barrel 0 selection 3-2 | CM | | Reconfiguration 3-2 | Access 2-15 | | Bit numbering 5; 4-1 | Access time, model 835 2-8 | | Block copy flag 2-6 | Access time, models 845 and 855 2-8 | | Block copy from CM instruction 4-3; 5-12 | Access time, model 990 2-8 | | Block copy from UEM instruction 4-3; 5-12 | Address format, models 835, 845, and 855 2-7 | | Block copy instruction sequence 2-3 | Address format, model 990 2-8 | | Block copy instructions 2-6 | Address formation 2-6,13 | | Boolean instruction sequence 2-2 | Addressing by PPs 5-14 | | Bounds register 1-6; 2-8 | Banks 1-3,4,5; 2-7 | | Branch destination address 4-4 | Block copy instructions 5-12 | | Branch instructions 2-4 | Bounds register 1-6; 2-9 | | Definite 4-5 | Configuration switches 3-3 | | Equal to zero 4-4 | Controls 3-1 | | In range 4-5 | Cycle times, model 835 2-8 | | Indefinite 4-6 | Cycle times, models 845 and 855 2-8 | | Negative 4-5 | Cycle times, model 990 2-8 | | Not equal to zero 4-5 | Description 1-6 | | Out of range 4-5 | Distributor 1-6 | | Positive 4-5 | Extended, see UEM | | Register greater than or equal 4-6 | Field length register, see FLC register | | Register less than 4-6 | Functional characteristics, model 835 1-3 | | Register less than 4-6 Registers equal 4-6 | • | | Registers equal 4-6 | Functional characteristics, models 845 and 855 1-4 | | "Procero not eduar 4-0 | 4-1 CCO DIIA | 60469290 C | Functional characteristics, model 990 1-5 | Cycle times, CM | |-----------------------------------------------------------------------------|--------------------------------------------------------| | Functional description 2-7 | Model 835 2-8 | | Layout 2-9 | Models 845 and 855 2-8 | | Map 5-13 | Model 990 2-8 | | MCH function word 5-25 | | | Port priority 2-8 | • | | Ports 1-6; 2-7,8 | | | Programming 5-12 | Data carrier detector (DCD) 5-24 | | Read word from 4-19; 5-12 | Data character 5-24 | | Reconfiguration 2-9; 3-1,5 | Data display 5-21 | | Reconfiguration switches 3-1 | Data formats 4-1 | | Reference address register, see RAC register | PP 4-30 | | Word 4-1 | Data input sequence 5-18,19 | | Write word to 4-19; 5-12 | Data output sequence 5-18,20 | | CMC 1-6; 2-7 | Data parity error 5-16 | | CMU error exit 5-9,11,13 | Data set ready (DSR) 5-23 | | CMU instructions, see Compare/move instructions | DATA switch 3-2 | | CMU interrupted flag 2-6 Codes, display station 5-22 | Data terminal ready (DTR) 5-24,25 | | Codes, display station 5-22 Collate table for compare/move instruction 4-16 | DCD, see Data carrier detector Deactivate channel 4-39 | | Compare collated instruction 4-16; 5-6 | DEAD START ERROR indicator 3-3 | | Compare/move arithmetic 5-6 | DEAD START SWITCH 2-11; 3-3 | | Compare/move instruction sequence 2-3 | Deadstart | | Compare/move instructions 2-3; 4-15 | Controls 3-1,2 | | Compare collated 5-6 | Indicators 3-1,2 | | Compare uncollated 5-6 | Matrix 3-2 | | Designators within instructions 4-2 | Panel 2-13; 3-1 | | Move direct 5-6 | Program 3-2,5 | | Move indirect 5-6 | Sequence 2-13; 3-4 | | Support registers 2-3 | Switches 3-1,2 | | Compare uncollated instruction 4-17; 5-6 | Description, system 1-1 | | Complement, instructions using 4-7,8 | Direct address instructions 5-14 | | Conditional software errors 5-12 | Direct read/write instruction sequence 2-3 | | Configuration, mainframe 1-1 | Direct read/write instructions, | | Configuration switches, CM 3-1,3 | CM 2-3; 5-12 | | Constant address instructions 5-14 | UEM 2-3; 5-12 | | Control checks 3-4 | Direct 6-bit address 5-14 | | Control failure 3-3 | Direct 6-bit operand 5-14 | | Control flags 2-6; 5-16 | Direct 12-bit address 5-14 | | Control words, maintenance channel 5-27 | Direct 18-bit operand 5-14 | | Controls 3-1,2 | Display character codes 5-21 | | Conversion | Display controller interface 1-6 | | Fixed-point to floating-point 4-11 | Display station 1-7 | | Floating-point to fixed-point 4-10 | Character codes 5-21<br>Character sizes 5-21 | | Coordinates, display station 5-21,22 | Codes 5-22 | | Counter, running 4-4<br>CP | Codes 3-22<br>Controller 2-13 | | | | | Addressing section 1-6; 2-7 Cache memory 1-6; 2-7 | Coordinates 5-21,22<br>Keyboard 5-21 | | Description 1-5 | Mode 5-21,22 | | Execution section 1-6; 2-7 | Output function code 5-22 | | Functional characteristics, model 835 1-3 | Presentation 5-22 | | Functional characteristics, models 845 | Programming 5-21 | | and 855 1-4 | Timing considerations 5-22 | | Functional characteristics, model 990 1-5 | Distributor, CM 1-4 | | Functional description 2-1 | Dot mode 5-21 | | Instruction descriptions 4-1 | Double-bit errors 2-7; 5-9,11 | | Instruction designators 4-2 | Double-precision results 5-4 | | Instruction section 1-5; 2-1 | DSC, see Display station controller | | MCH function word 5-25 | DSR, see Data set ready | | Operating modes 4-2 | DTR, see Data terminal ready | | Programming 5-1 | | | Registers 1-6; 2-4 | | | CRT 1-7; 5-21 | | | CYBER 170 exchange jump 2-3,11; 4-2,4; 5-1 | ECL, see Emitter-coupled logic | | CYBER 170 exchange package 2-3,4; 4-4; 5-1 | EM register 2-6 | | Contents 5-1 | EMC, see Exit mode conditions | | CYBER 170 exchange sequence 2-3 | EMERGENCY OFF switch 3-4 | | CYBER 170 job mode 4-2; 5-1 | Emitter-coupled logic (ECL) 1-2 | | Error exits 5-10 | Empty register 5-16 | | CYBER 170 monitor flag 2-7; 4-2; 5-1 | EMS bits, see Exit mode selection bits | | CYBER 170 monitor mode 4-2; 5-1 | Environment control register | | Error exits 5-8 | IOU 3-2 | Index-2 60469290 C | Error conditions 2-6 Error correction code bits 2-8; 5-7 | FS register, see fault status register<br>Full register flag 5-16 | |------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------| | Error exit 4-2<br>Error exit condition codes 2-6; 5-7 | Function instruction 5-16<br>Function on channel instruction 4-39 | | Error exit to MA instruction 4-2 Error exits 5-7 | Function words, maintenance channel 5-27 Functional characteristics | | In CYBER 170 job mode 5-10<br>In CYBER 170 monitor mode 5-8 | Model 835 1-3<br>Models 845 and 855 1-4 | | Error flag 5-16 Error flag instruction 5-16 | Model 990 1-5 Functional description | | Error handling 5-7 Error processing 2-6; 5-7 | CM 2-7<br>CP 2-1 | | Error response 5-7 Exchange jump instruction 4-33 | IOU 2-13 | | Exchange jump, see CYBER 170 exchange jump | | | Exchange package, see CYBER 170 exchange package | 01 4 1 | | Exchange sequence, see CYBER 170 exchange sequence Execution interval 2-4; 5-2 | Glossary A-1 Graphic mode 5-21 | | Execution section 1-6; 2-7 | oraphize mode 5 21 | | Execution times | | | Model 835 CP 4-20<br>Model 845 CP 4-23 | H-14 OD 5 07 | | Model 855 CP 4-27 | Halt CP 5-27<br>Hardware errors 5-7,9,11 | | PP 4-39 | nardware errors 3-7,5,11 | | Exit condition codes 5-7 | | | Exit condition register 5-7 Exit mode conditions 5-7 | I/O channel failure 3-3 | | Exit mode conditions 5-7 Exit mode register, see EM register | I/O channels 2-13,15 Activate 5-16 | | Exit mode selection bits 2-6; 5-7 | Active/inactive 5-16 | | Expanded addressing mode 1-6; 2-7; 5-2,12 | Communications 5-15 | | Expanded addressing select flag 2-6 | External interface 1-6; 2-15 | | Extended purge control, see instruction lookahead purge control | Initial state 3-5 Internal interface 1-6; 2-15 | | External interface, IOU 1-6; 2-15 | Internal interface 1-6; 2-15 Operation 5-16 | | • | Parity 5-15 | | | Reservation 5-15 | | Fast deadstart 3-3 | I/O transfers 5-16,18 | | Field length for CM register, see FLC register Field length for UEM register, see FLE register | ILH, see Instruction lookahead Illegal instructions 4-2,4; 5-7,8 | | Firmware or control failure 3-3 | Inactive channel 5-16 | | Fixed-point arithmetic 5-4 | Increment instruction sequence 2-2 | | Normalized numbers 5-6 | Indefinite error 5-9,11 | | Overflow 5-4 | Indefinite, floating-point 5-3 | | Fixed-point to floating-point conversion 4-11<br>Flag register 2-6 | Indefinite operand error 2-6 Index registers, see B registers | | FLC register 2-6 | Indexed direct address instructions 5-14 | | FLE register 2-6 | Indexed 12-bit address 5-14 | | Floating-add instruction sequence 2-2 | Indicators 3-1,2 | | Floating divide instruction 4-14 Floating-divide instruction sequence 2-2 | Indirect address instructions 5-14 | | Floating-divide instruction sequence 2-2 Floating double-precision difference | Indirect 6-bit address 5-14 Infinite operand error 2-6; 5-9,11 | | instruction 4-12 | Initialization | | Floating double-precision product instruction 4-14 | IOU 2-13; 3-4 | | Floating double-precision sum instruction 4-12<br>Floating-multiply instruction sequence 2-2 | Input data parity error 5-16 | | Floating-multiply instruction sequence 2-2 Floating-point arithmetic 5-2 | Input from channel instruction 4-38 Input/output channel, see I/O channel | | Double-precision 5-4 | Input/output unit, see IOU | | Format 5-2 | Input sequence 5-18,19 | | Indefinite 5-3 | Instruction control sequences 2-1 | | Nonstandard operands 5-4<br>Normalized numbers 5-4 | Block copy sequence 2-3 Boolean sequence 2-1 | | Overflow 5-3 | Boolean sequence 2-1<br>Compare/move sequence 2-3 | | Packing 5-2 | CYBER 170 exchange sequence 2-3 | | Rounding 5-4 | Direct read/write sequence 2-3 | | Underflow 5-3 | Floating-add sequence 2-2 | | Floating-point difference instruction 4-11 Floating-point sum instruction 4-11 | Floating-divide sequence 2-2 Foating-multiply sequence 2-2 | | Floating-point to fixed-point conversion 4-10 | Increment sequence 2-2 | | Floating product instruction 4-13 | Normal jump sequence 2-4 | | Form mask instruction 4-14 | Return jump sequence 2-4 | | Framing error 5-24 | Shift sequence 2-2 | | Free running counter 4-4 FREQ MARGIN switch 3-2 | Instruction descriptions 4-1<br>CP 4-1 | | Frequency margin 3-2 | PP 4-30 | | <del>-</del> | | 60469290 C Index-3 | Instruction designators | Unpack 4-10 | |---------------------------------------------------------------------------|----------------------------------------------------------------------------| | CP 4-2 | Write one word to UEM 4-4 | | PP 4-30 | Write word to CM 4-19; 5-12 | | Instruction execution times | Instructions, PP (see also inside | | Model 835 CP 4-20<br>Model 845 CP 4-23 | front cover) 4-30 | | Model 855 CP 4-27 | Activate channel 4-38 Add 4-32,33,34,35 | | PP 4-39 , | Central read 4-36 | | Instruction lookahead 2-1 | Central read 4 30<br>Central write 4-36 | | Purge control 5-6 | Channel flag 5-16 | | Instruction lookahead purge control 2-6 | Clear channel error flag 4-37 | | Instruction lookahead purge flag 2-6 | Clear channel flag 4-37 | | Instruction prefetch, see Instruction lookahead | CM read 5-14 | | Instruction purge flag 2-6 | CM write 5-15 | | Instruction section 1-5; 2-1 | Deactivate channel 4-39 | | Instruction word designators | Error flag 5-16 | | CP 4-2 | Exchange jump 4-33 | | PP 4-30 | Function on channel 4-39 | | Instruction word format CP 4-1 | Input from channel 4-38 | | Instructions, CP (see also inside front cover) | Jump if channel active 4-37 | | Block copy from CM 4-3; 5-12 | Jump if channel empty 4-37 Jump if channel error flag clear 4-37 | | Block copy from UEM 4-3; 5-12 | Jump if channel error flag clear 4-37 Jump if channel error flag set 4-37 | | Branch 4-4,5,6 | Jump if channel full 4-37 | | Central exchange jump 4-4 | Jump if channel inactive 4-37 | | Compare collated 4-16; 5-6 | Load 4-32,33,34,35 | | Compare/move 4-15 | Load complement 4-32 | | Compare uncollated 4-17; 5-6 | Load/store R register 4-33; 5-14 | | Complement 4-7,8 | Logical difference 4-32,33,34,35 | | Direct read/write of CM 5-12 | Logical product 4-32 | | Direct read/write of UEM 5-12 | Long jump 4-31 | | Error exit to MA 4-2 | Minus jump 4-31 | | Floating 4-11,12,13,14 | Monitor exchange jump 4-33 | | Floating divide 4-14 | Monitor exchange jump to MA 4-33 | | Floating double-precision difference 4-12 | Nonzero jump 4-31 | | Floating double-precision product 4-14 Floating double-precision sum 4-12 | Output on channel 4-38 | | Floating-point difference 4-11 | Pass 4-31,33<br>Plus jump 4-31 | | Floating-point sum 4-11 | Replace add 4-34,35 | | Floating product 4-13 | Replace add one 4-34,35 | | Form mask 4-14 | Replace subtract one 4-34,35 | | Illegal 4-2,4; 5-7,8 | Return jump 4-31 | | Integer difference 4-13 | Selective clear 4-32 | | Integer sum 4-13 | Shift 4-32 | | Interrupt to executive mode 4-2 | Store 4-34,35 | | Jump 4-2,4 | Store R register 4-33; 5-14 | | Left shift 4-8 | Subtract 4-32,33,34 | | Logical difference 4-7 | Test and set channel flag 4-37 | | Logical product 4-7 | Unconditional jump 4-31 | | Logical sum 4-7<br>Monitor exchange jump 4-4 | Zero jump 4-31 Integer arithmetic 5-6 | | Move direct 4-16; 5-6 | Integer difference instruction 4-13 | | Move indirect 4-16; 5-6 | Integer sum instruction 4-13 | | Normalize 4-9.10 | Inter-PP communications 5-15 | | Pack 4-11 | Internal addresses, maintenance registers | | Pass 4-15 | 5-28,29,30 | | Population count 4-17 | Internal interface, IOU 1-6; 2-15 | | Read free running counter 4-4 | Interrupt to executive mode instruction 4-2 | | Read word from CM 4-19; 5-12 | IOU | | Read word from UEM 4-4 | Barrel and slot 2-13 | | Return jump 4-2 | Deadstart 2-13 | | Right shift 4-8,9 | Description 1-6 | | Round floating difference 4-12 | Environmental control register 3-2 | | Round floating divide 4-15 | External interface 1-6 | | Round floating product 4-13 Round floating sum 4-12 | Functional characteristics 1-4,5 | | Round floating sum 4-12 Round normalize 4-10 | Functional description 2-13 I/O channels 1-6 | | Set Ai 4-17,18 | I/O channels 1-6 Initialization 2-13; 3-4,5 | | Set Bi 4-18,19 | Internal interface 1-5 | | Set Xi 4-19,20 | Maintenance registers 5-30,42 | | Transfer word register to register 4-6 | MCH function word 5-25,27 | | Transmit complement 4-7 | Peripheral processors, see PPs | | Transmit word 4-6 | PPs 1-6; 2-13 | | Unconditional jump 4-2,4 | Reconfiguration 3-6 | | | | Index-4 | Joh mode soo CYPER 170 tob mode | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Makal and da nambasadasakan manana asa 1600 | | Job mode, see CYBER 170 job mode | Metal oxide semiconductor memory, see MOS | | Jump if channel active instruction 4-37 | MF, see CYBER 170 monitor flag | | Jump if channel empty instruction 4-37 | Microcode 5-2 | | | | | Jump if channel error flag clear instruction 4-37 | Minus jump instruction 4-31 | | Jump if channel error flag set instruction 4-37 | Mode selection bits 5-7 | | Jump if channel full instruction 4-37 | Modes of operation 4-2 | | | | | Jump if channel inactive 4-37 | Monitor address register, see MA register | | Jump instructions 4-2,4 | Monitor exchange jump instruction 4-4,33 | | | | | | Monitor flag, see CYBER 170 monitor flag | | | Monitor mode, see CYBER 170 monitor mode | | | MOS 1-4 | | K register, PP 2-15 | | | | Most insignificant bit 4-1 | | Keyboard character codes 5-21 | Move direct instruction 4-16; 5-6 | | | Move indirect instruction 4-16; 5-6 | | | 11010 111011001 111011011 1 10, 5 | | | | | | | | L. D. S. ERROR-A indicator 3-3 | | | | N 11 | | | No-address instructions 5-14 | | LAMP TEST switch 3-2 | Nonstandard operands 5-4 | | Large scale integration (LSI) logic 1-2 | Nonzero jump instruction 4-31 | | | _ · · | | Least significant bit 4-1 | Normal jump instruction sequence 2-4 | | Left circular shift 4-8,9 | Normalize instruction 4-9,10 | | Left shift instruction 4-8 | Normalize operations 2-2; 4-9; 5-4 | | | | | Load complement instruction 4-32 | Normalized numbers | | Load instruction 4-32,33,34,35 | Fixed-point 5-6 | | Load R register 4-33; 5-14 | Floating-point 5-4 | | · · | rioacing-point 3-4 | | Lockout time, maximum request 2-9 | | | Logical difference instruction 4-7,8,32,33,34,35 | | | Logical product instruction 4-7,32 | | | | | | Logical sum instruction 4-7 | Offset designator for compare/move 4-2,15 | | Long-add instructions 2-3 | One's complement addition/subtraction 2-2 | | Long jump instruction 4-31 | Opcode designator 4-2 | | | . • | | Long/short deadstart sequence 3-3,5 | Operand designator 4-2 | | LONG/SHORT DEAD START SEQUENCE switch 3-3 | Operand registers, see X registers | | Lookahead | | | | Operating instructions/procedures 3-1,4 | | Purge control 5-6 | Operating modes, CP 4-2 | | Lookahead, instruction 2-1 | Operating registers 1-6; 2-5 | | Lookahead purge control 2-6 | | | | Operation code 4-2 | | Lookahead purge flag 2-6 | Output data parity error 5-16 | | LSI logic 1-2 | Output on channel instruction 4-38 | | | | | | | | | Output sequence 5-18,20 | | | Overflow | | | Overflow | | MA register 2-7 | Overflow Fixed-point 5-4 | | MA register 2-7 | Overflow Fixed-point 5-4 Floating-point 5-3 | | MAC, see Maintenance access control | Overflow Fixed-point 5-4 | | <u> </u> | Overflow Fixed-point 5-4 Floating-point 5-3 | | MAC, see Maintenance access control Mainframe configuration 1-1 | Overflow Fixed-point 5-4 Floating-point 5-3 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 | Overflow Fixed-point 5-4 Floating-point 5-3 | | MAC, see Maintenance access control Mainframe configuration 1-1 | Overflow Fixed-point 5-4 Floating-point 5-3 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration 3-6 | P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 | P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration 3-6 | P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 Programming 5-12 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 Plus jump instruction 4-31 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 Programming 5-12 Reconfiguration switches 2-9 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Partial processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 Plus jump instruction 4-31 Population-count instructions 2-2; 4-17 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 Programming 5-12 Reconfiguration switches 2-9 Memory see also CM | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 Plus jump instruction 4-31 Population-count instructions 2-2; 4-17 Port bounds register, see CM bounds register | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 Programming 5-12 Reconfiguration switches 2-9 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 Plus jump instruction 4-31 Population-count instructions 2-2; 4-17 Port bounds register, see CM bounds register Port priority 2-8 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 Programming 5-12 Reconfiguration switches 2-9 Memory see also CM CM reconfiguration 2-9; 3-1,4 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 Plus jump instruction 4-31 Population-count instructions 2-2; 4-17 Port bounds register, see CM bounds register Port priority 2-8 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 Programming 5-12 Reconfiguration switches 2-9 Memory see also CM CM reconfiguration 2-9; 3-1,4 CM reconfiguration switches 3-1,5 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 Plus jump instruction 4-31 Population-count instructions 2-2; 4-17 Port bounds register, see CM bounds register Port priority 2-8 Ports, CM 1-6; 2-7,8 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 Programming 5-12 Reconfiguration switches 2-9 Memory see also CM CM reconfiguration switches 3-1,5 Map 5-13 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 Plus jump instruction 4-31 Population-count instructions 2-2; 4-17 Port bounds register, see CM bounds register Port priority 2-8 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 Programming 5-12 Reconfiguration switches 2-9 Memory see also CM CM reconfiguration 2-9; 3-1,4 CM reconfiguration switches 3-1,5 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 Plus jump instruction 4-31 Population-count instructions 2-2; 4-17 Port bounds register, see CM bounds register Port priority 2-8 Ports, CM 1-6; 2-7,8 Power-off procedures 3-4 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 Programming 5-12 Reconfiguration switches 2-9 Memory see also CM CM reconfiguration switches 3-1,5 Map 5-13 PP 2-13 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 Plus jump instruction 4-31 Population-count instructions 2-2; 4-17 Port bounds register, see CM bounds register Port priority 2-8 Ports, CM 1-6; 2-7,8 Power-off procedures 3-4 Power-on procedures 3-4 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 Programming 5-12 Reconfiguration switches 2-9 Memory see also CM CM reconfiguration switches 3-1,5 Map 5-13 PP 2-13 PP reconfiguration 2-15; 3-6 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 Plus jump instruction 4-31 Population-count instructions 2-2; 4-17 Port bounds register, see CM bounds register Port priority 2-8 Ports, CM 1-6; 2-7,8 Power-off procedures 3-4 PP NO switch 3-2 | | MAC, see Maintenance access control Mainframe configuration 1-1 Maintenance access control 2-2,16 Maintenance channel 2-16; 5-25 Master clear 5-28 Programming 5-25 Maintenance channel interface 1-5; 2-7,13; 5-25 Control words 5-27 Function words 5-25,26,27 Marker flag, channel 5-16 Mask designator 4-2 Masking word 4-14 Master clear 3-5 Maintenance channel 5-28 Two-port multiplexer 5-24 MCH, see Maintenance channel CM reconfiguration 3-1,4 CM reconfiguration switches 3-1,5 PP reconfiguration switches 3-2,6 Programming 5-12 Reconfiguration switches 2-9 Memory see also CM CM reconfiguration switches 3-1,5 Map 5-13 PP 2-13 | Overflow Fixed-point 5-4 Floating-point 5-3 Overrun 5-24 P or Q barrel failure 3-3 P register, CP 2-6 P register, PP 2-13 Pack instruction 4-11 Pack/unpack instructions 2-2; 4-10 Packing numbers 5-2 Panel, deadstart 3-1 Parcels 2-1; 4-1 Parity, channel 5-15 Parity errors 5-9,11,16,24 Partial overflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Partial underflow 5-3 Pass instruction 4-15,31,33 Peripheral processors, see PPs Phased-bank operation 2-7 Physical characteristics 1-1 Plus jump instruction 4-31 Population-count instructions 2-2; 4-17 Port bounds register, see CM bounds register Port priority 2-8 Ports, CM 1-6; 2-7,8 Power-off procedures 3-4 Power-on procedures 3-4 | | PPs 1-6 | RECONFIGURATION, BARREL switch 3-2 | |---------------------------------------------------------------------------|--------------------------------------------------------------------| | Access to CM 2-15 | RECONFIGURATION, PPM switch 3-2 | | Addressing 5-14 | Reconfiguration switches | | Barrels 1-6; 2-13 | CM 2-9; 3-1,3 | | Communications 2-13; 5-15 | PP 3-2,6 | | CM read instructions 5-14 | Reference address for CM register, see RAC register | | CM write instructions 5-15 | Reference address for UEM register, see RAE register | | Data format 4-30 Description 2-13 | Register designator 4-2 | | Description 2-13<br>Initialization 3-5 | Register display, PP 3-2<br>Register empty 5-16 | | Instruction designators 4-30 | Register formats 4-1 | | Instruction execution times 4-39 | Register full flag 5-16 | | Instruction word format 4-30 | REGISTER SELECT switch 3-2 | | Instructions 4-30 | Registers, 2-4 | | Memory failure 3-3 | A, CP 1-6; 2-4; 4-17,18 | | Memory (PPM) 2-15 | A, PP 2-13 | | Numbering 2-15 | B 1-6; 2-4; 4-18,19 | | Program timing considerations 5-16 | Compare/move support 2-3 | | Programming 5-14 | CP 1-6; 2-4 | | Reconfiguration 2-15; 3-2,6 | EM 2-6 | | Reconfiguration switches 3-2,6 | Exit mode, see EM register | | Registers 2-13; 3-5 | Field length, see FLC and FLE registers | | Relocation register format 4-30 Selection switches 3-2 | Flag 2-6 | | To PP communications 5-15 | FLC 2-6<br>FLE 2-6 | | Write output buffer function 5-24 | General description 1-6 | | Prefetch of instructions, see Instruction lookahead | K 2-15 | | Programming | MA 2-7 | | CM 5-12 | Monitor address register, see MA register | | CP 5-1 | Operating 1-6; 2-5 | | Display station 5-21 | P, CP 2-6 | | Maintenance channel 5-25 | P, PP 2-13 | | PP 5-14 | PP 2-13 | | Real-time clock 5-23 | Program address, see P register | | Two-port multiplexer 5-23 | Q 2-13 | | Program address register, see P register Program mode 4-2 | R 2-13; 5-14 | | Program timing considerations, PP 5-16 | RAC 2-6<br>RAE 2-6 | | Program word format 4-1 | Reference address, see RAC and RAE registers | | Programming information 5-1 | Support 1-6; 2-5 | | Publication index 6 | X 1-6; 2-4; 4-19,20 | | Purge control | Relative address 5-12 | | Model 835 5-6 | Relocation register, see R register | | Models 845 and 855 5-7 | Replace add instruction 4-34,35 | | | Replace add one instruction 4-34,35 | | | Replace subtract one instruction 4-34,35 | | | Request lockout time, maximum 2-9 | | Q barrel failure 3-3 | Request to send 5-24,25 | | Q register, PP 2-13 Ouadrant select field 2-7 | Reservation, channel 5-15 | | | Return jump instruction 4-2,31 | | Queuing buffers 1-6 | Return jump instruction sequence 2-4 Right shift instruction 4-8,9 | | | ROM 3-5 | | | Round floating difference instruction 4-12 | | R register 2-13; 4-30,33 | Round floating divide instruction 4-15 | | Load instruction 5-14 | Round floating product instruction 4-13 | | Store instruction 5-14 | Round floating sum instruction 4-12 | | RAC 5-7 | Round normalize instruction 4-10 | | RAC register 2-6 | Rounding, floating-point 5-4 | | RAE register 2-6 | Rounding operation 4-10; 5-4 | | Ranks 2-13 | Row select field 2-7,8 | | Read free running counter instruction 4-4 Read maintenance registers 5-27 | RTS, see Request to send | | Read-only memory 3-5 | Running counter 4-4 | | Read status summary 5-28 | | | Read status summary function 5-23 | | | Read terminal data function 5-23 | S register, see Status register | | Read word from CM instruction 4-19; 5-12 | SECDED 2-8 | | Read word from UEM instruction 4-4 | SECDED code bits | | Real-time clock interface 1-6; 2-15 | Description 2-8 | | Programming 5-23 | Model 835 2-10 | | Reconfiguration, | Models 845 and 855 2-11 | | CM 2-9; 3-1,4 | Model 990 2-12 | | PPs 2-15; 3-2,6 | SECDED errors 5-9,11 | | Selective clear instructions 4-32 Selector 5-25 Set A register instructions 2-2 Set Ai instructions 4-17,18 Set B register instructions 2-3 Set Bi instructions 4-18,19 Set X register instructions 2-3 | Two-port multiplexer interface 1-6; 2-15 Input data 5-25 Operation 5-23 Output data 5-25 Programming 5-23 | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------| | Set Xi instructions 4-19,20 | | | Shift designator 4-2 | UART 5-24 | | Shift instruction 4-32 | UEL register, see Uncorrected error log register | | Shift instruction sequence 2-2 | UEM | | Short deadstart sequence 3-3,5<br>Single-bit errors 2-8 | Block copy instructions 2-3; 5-12 | | Single error correction/double error detection, see | Description 1-6 Direct read/write instructions 5-12 | | SECDED | Enable flag 2-6 | | Single-precision 5-4 | Field length register, see FLE register | | Slot, see Barrel and slot | Instructions 2-3 | | Slow deadstart 3-3 | Read one word from 5-12 | | Software errors, 5-12 | Reference address register, see RAE register | | SS register, see Status summary register | Write one word to 5-12 | | Stack 2-1 | Unconditional jump instruction 4-2,4,31 | | Standard addressing mode 1-6; 2-6; 5-2,12 | Underflow, floating-point 5-3 | | Start CP 5-27 | Unified extended memory, see UEM | | Store Instruction 4-34,35<br>Store R register 4-33; 5-14 | Universal Asynchronous Receiver and Transmitter 5-24 | | Subtract instruction 4-32,33,34,35 | Unpack instruction 4-10 | | Support registers 1-6; 2-5 | Unpack instructions 2-2 | | Compare/move 2-3 | onpack Institutions 2 2 | | Switches, | | | CM reconfiguration 2-9; 3-1,3 | | | PP reconfiguration 3-2,6 | Virtual State 2-8; 4-2; 5-2 | | Syndrome codes 2-8 | | | Model 835 2-10 | | | Models 845 and 855 2-11 | | | Model 990 2-12 | Word | | System description 1-1 System publication index 6 | Bit numbering 5 | | System publication index o | Instruction 4-1 Write maintenance registers 5-27 | | | Write maintenance registers 5-27 Write output buffer 5-24 | | | Write word to CM instruction 4-19; 5-12 | | Target address 2-1 | Write word to UEM instruction 4-4 | | Terminal deselect function 5-23 | | | Terminal operation mode function 5-24 | | | Terminal select function 5-23 | | | Test and set channel flag instruction 4-37 | X registers 1-6 | | Timing considerations | Set instructions 2-3; 4-19,20 | | Channel 5-16 | | | Display station 5-22<br>PP 5-16 | | | PP 5-16 Transfer blocks 5-12 | 7 | | Transfer single words 5-12 | Zero jump instruction 4-31 | | Transfer timing 5-16,17 | | | Transfer word register to register 4-6 | | | Transfers, I/O 5-16 | 00 instruction | | Transmit complement instruction 4-7 | Error exit 5-8,10 | | Transmit word instruction 4-6 | 12/16 conversion failure 3-3 | 60569290 C Index-7 # CUT ALONG LINE ## **COMMENT SHEET** | MANUAL TITLE: | 180 Comp | R 170 Co<br>uter Sys<br>O State | tems Mo | dels | 835, | 840, | 845, | | | | | |-------------------------------------------------------------|----------------|---------------------------------|---------|------|----------|---------|---------|-----|----------------------|-------------|--| | PUBLICATION NO | | | | | | ISION: | | | | | | | NAME: | | | | | <u> </u> | | | | | | | | COMPANY: | | | | | | | | | <br> | _ | | | STREET ADDRESS | | | , | | | | | - | <br>· · · <u>-</u> · | | | | CITY: | | | STATE | E: | | | ZIP COD | )E: | <i>3</i> | <del></del> | | | This form is not i<br>this manual. Plea<br>include page num | ise indicate a | ny errors, su | | | | | | | | | | | | | ☐ Please R | leply | | o Reply | y Neces | sary | | | | | NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES # **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