# **MODEL 3210 PROCESSOR** **USER'S MANUAL** # PERKIN-ELMER Computer Systems Division 2 Crescent Place Oceanport. N. J. 07757 The information in this document is subject to change without notice and should not be construed as a commitment by The Perkin-Elmer Corporation. The Perkin-Elmer Corporation assumes no responsibility for any errors that may appear in this document. The software described in this document is furnished under a license, and it can be used or copied only in a manner permitted by that license. Any copy of the described software must include the Perkin-Elmer copyright notice. Title to and ownership of the described software and any copies thereof shall remain in The Perkin-Elmer Corporation. The Perkin-Elmer Corporation assumes no responsibility for the use or reliability of its software on equipment that is not supplied by Perkin-Elmer. The Perkin-Elmer Corporation, Computer Systems Division 2 Crescent Place, Oceanport, New Jersey 07757 © 1980 by The Perkin-Elmer Corporation Printed in the United States of America # TABLE OF CONTENTS | PREI | FACE | | xiii | |------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | СНАІ | PTERS | | | | 1 | SYSTEM D | ESCRIPTION | | | | 1.1 | INTRODUCTION | 1-1 | | | 1.2.1<br>1.2.1.1<br>1.2.1.2<br>1.2.1.3 | PROCESSOR Program Status Word (PSW) Register Set Select (R) Condition Code (C,V,G,L) Location Counter General Registers | 1-4<br>1-4<br>1-5<br>1-5<br>1-6<br>1-5 | | | | Floating-Point Registers | 1-6 | | | 1.3 | PROCESSOR INTERRUPTS | 1-7 | | | 1.4 | RESERVED MEMORY LOCATIONS | 1-7 | | | 1.5.1<br>1.5.2<br>1.5.3<br>1.5.4 | DATA FORMATS Fixed-Point Data Floating-Point Data Logical Data Decimal String Data Alphanumeric String Data | 1-8<br>1-8<br>1-9<br>1-9<br>1-9 | | | 1.6 | DATA ALIGNMENT | 1-10 | | | 1.7 | INSTRUCTION ALIGNMENT | 1-10 | | | 1.8 | INSTRUCTION FORMATS | 1-11 | | | 1.8.1<br>1.8.2<br>1.8.2<br>1.8.4<br>1.8.5<br>1.8.6<br>1.8.7 | Introduction Branch Instruction Formats Programming Examples Register-to-Register (RR) Format Short Form (SF) Format Register and Indexed Storage One (RX1) Format Register and Indexed Storage Two (RX2) Format Register and Indexed Storage Three (RX3) Format | 1-11<br>1-13<br>1-13<br>1-14<br>1-14<br>1-15<br>1-16 | | | 1.8.9 | Register and Immediate Storage One (RI1) Format | 1-18<br>1-20 | 29-747 R00 4/81 i | Format 1.8.11 Register and Indexed Storage/Register Indexed Storage (RXRX) Format 2 SYSTEM CONTROL | 1-22<br>and<br>1-24<br>2-1<br>2-1 | |------------------------------------------------------------------------------------------------------|-----------------------------------| | | 2-1 | | 2 SYSTEM CONTROL | | | | | | 2.1 INTRODUCTION | 2-1 | | 2.2 CONFIGURATION | | | 2.3 SYSTEM CONTROL PANEL SWITCHES and INDI | | | 2.3.1 Key-Operated Security Lock | 2-3 | | 2.3.2 Control Switches | 2-4 | | 2.4 OPERATING INSTRUCTIONS | 2-5 | | 2.4.1 Power-Up | <b>2-</b> 5 | | 2.4.2 Entering Console Service | <b>2-</b> 5 | | 2.4.3 Initial Program Load (IPL) | <b>2-</b> 5 | | 2.5 SYSTEM TERMINAL COMMANDS | 2-6 | | 2.5.1 Select an Address and Examine "0" | 2-6 | | 2.5.2 Increment and Examine Next Location "+ | -" 2-6 | | 2.5.3 Decrement and Examine Prior Location | 2-7 | | | 2-7 | | | 2-7<br>2 <b>-</b> 7 | | 2.5.5 Examine General Register "R" | | | 2.5.6 Modify General Register "=" | 2-7 | | 2.5.7 Examine Single-Precision Floating-Poir Register "F" | 1t<br>2-8 | | 2.5.8 Modify Single-Precision Floating-Point | | | Register "=" | 2-8 | | | | | | | | Register "D" | 2-8 | | 2.5.10 Modify Double-Precision Floating-Point Register "=" | :<br>2 <b>-</b> 9 | | 2.5.11 Examine Program Status Word "P" | 2-9 | | 2.5.12 Modify Program Status Word "=" | 2-9 | | 2.5.12 Hoully Flogiam Status word = 2.5.13 Execute Single Instruction ">" | 2-9<br>2-9 | | | | | 2.5.14 Enter Run Mode "<" | <b>2-</b> 9 | | 2.6 MEMORY INITIALIZATION | 2-10 | | 2.7 SYSTEM TERMINAL PROGRAMMING INSTRUCTION | ONS 2-11/2-12 | | 3 LOGICAL OPERATIONS | | | 3.1 INTRODUCTION | 3-1 | | 3.2 LOGICAL DATA FORMATS | 3-1 | | 3.3 OPERATIONS | <b>3-</b> 2 | ii 29-747 R00 4/81 | 3.3.1 | Boolean Operations | 3-2 | |--------|------------------------------------------------------------------------------------------------|--------------| | 3.3.2 | Translation | 3-2 | | 3.3.3 | List Processing | 3-3 | | 3.4 | LOGICAL INSTRUCTION FORMATS | <b>3-</b> 5 | | 3.5 | LOGICAL INSTRUCTIONS | 3-5 | | 3.5.1 | • • • | 3-7 | | 3.5.2 | Load Immediate Short (LIS) | 3-8 | | 3.5.3 | Load Complement Short (LCS) | <b>3-</b> 9 | | 3.5.4 | Load Halfword (LH, LHI) | 3-10 | | 3.5.5 | Load Address (LA) | 3-11 | | 3.5.6 | Load Real Address (LRA) | 3-12 | | 3.5.7 | Load Halfword Logical (LHL) | 3-16 | | 3.5.8 | | 3-17 | | 3.5.9 | Load Byte (LB, LBR) | 3-18 | | 3.5.10 | Exchange Halfword Register (EXHR) | 3-19 | | 3.5.11 | Load Byte (LB, LBR) Exchange Halfword Register (EXHR) Exchange Byte Register (EXBR) Store (ST) | 3-20 | | 3.5.12 | Store (ST) | 3-21 | | 3.5.13 | Store Halfword (STH) | 3-21 | | 3.5.14 | Store Multiple (STM) | 3-22 | | 3.5.15 | Store Byte (STB, STBR) | 3-23 | | 3.5.16 | Compare Logical (CL, CLR, CLI) | 3-24 | | 3.5.17 | Compare Logical Halfword (CLH, CLHI) | 3-25 | | 3.5.18 | Compare Logical Byte (CLB) | 3-26 | | 3.5.19 | AND (N, NR, NI) | 3-27 | | 3.5.20 | AND Halfword (NH, NHI) | 3-28 | | 3.5.21 | OR (O, OR, OI) | 3-29 | | 3.5.22 | OR Halfword (OH, OHI) | <b>3-</b> 30 | | 3.5.23 | Exclusive OR (X, XR, XI) | 3-31 | | 3.5.24 | Exclusive OR Halfword (XH, XHI) | 3-32 | | 3.5.25 | Test Immediate (TI) | 3-33 | | 3.5.26 | Test Halfword Immediate (THI) | 3-34 | | 3.5.27 | Shift Left Logical (SLL, SLLS) | 3-35 | | 3.5.28 | Shift Right Logical (SRL, SRLS) | 3-36 | | 3.5.29 | Shift Left Halfword Logical (SLHL, SLHLS) | 3-37 | | 3.5.30 | Shift Right Halfword Logical (SRHL, SRHLS) | 3-38 | | | Rotate Left Logical (RLL) | <b>3-</b> 39 | | 3.5.32 | Rotate Right Logical (RRL) | 3-40 | | 3.5.33 | Test and Set (TS) | 3-41 | | 3.5.34 | Test Bit (TBT) | 3-42 | | 3.5.35 | Set Bit (SBT) | 3-43 | | 3.5.36 | Reset Bit (RBT) | 3-44 | | 3.5.37 | Complement Bit (CBT) | 3-45 | | 3.5.38 | Cyclic Redundancy Check (CRC12, CRC16) | 3-46 | | 3.5.39 | Translate (TLATE) | 3-48 | | 3.5.40 | Add To List (ATL, ABL) | 3-51 | | 3.5.41 | Remove From List (RTL, RBL) | 3-53 | # 4 BRANCHING | 4.1 | INTRODUCTION | 11 _ 4 | |-------|--------------|-------------| | 4 . 1 | INTRODUCTION | <b>4-</b> 7 | 29-747 R00 4/81 | | 4.2 | OPERATIONS | 4-1 | |-----|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------| | | 4.2.1 | Decision Making | 4-1 | | | 4.2.2 | Subroutine Linkage | 4-2 | | | 4.3 | BRANCH INSTRUCTION FORMATS | 4-2 | | | 4.4 | BRANCH INSTRUCTIONS | 4-2 | | | 4.4.1 | Branch on True (BTC, BTCR, BTBS, BTFS) | 4-3 | | | 4.4.2 | Branch on False (BFC, BFCR, BFBS, BFFS) | 4-4 | | | 4.4.3 | Branch and Link (BAL, BALR) | 4-5 | | | 4.4.4 | Branch on Index Low or Equal (BXLE) | 4-7 | | | 4.4.5 | Branch on Index High (BXH) | 4-9 | | | 4.5 | EXTENDED BRANCH MNEMONICS | 4-11 | | | 4.5.1 | Branch on Carry (BC, BCR, BCS) | 4-13 | | | | Branch on No Carry (BNC, BNCR, BNCS) | 4-14 | | | | Branch on Equal (BE, BER, BES) | 4-15 | | | | Branch on Not Equal (BNE, BNER, BNES) | 4-16 | | | | Branch on Low (BL, BLR, BLS) | 4-17 | | | | Branch on Not Low (BNL, BNLR, BNLS) | 4-18 | | | | Branch on Minus (BM, BMR, BMS) | 4-19 | | | | Branch on Not Minus (BNM, BNMR, BNMS) | | | | 4.5.9 | | 4-21 | | | 4.5.10 | | 4-22 | | | 4.5.11 | Branch on Overflow (BO, BOR, BOS) | 4-23 | | | 4.5.12 | | | | | 4.5.13 | Branch on Zero (BZ, BZR, BZS) | 4-25 | | | 4.5.14 | Branch on Not Zero (BNZ, BNZR, BNZS) | 4-25 | | | | Branch (Unconditional) (B, BR, BS) | 4-27 | | | 4.5.16 | No Operation (NOP, NOPR) | 4-28 | | 5 - | FIXED-PO | DINT ARITHMETIC | | | | 5.1 | INTRODUCTION | 5-1 | | | 5.2 | FIXED-POINT DATA FORMATS | 5-1 | | | 5.3 | FIXED-POINT NUMBER RANGE | 5-2 | | | 5 • 4 | OPERATIONS | 5-2 | | | 5.5 | CONDITION CODE | 5-3 | | | 5.6 | FIXED-POINT INSTRUCTION FORMATS | 5-3 | | | 5.7.1<br>5.7.2<br>5.7.3<br>5.7.4<br>5.7.5 | FIXED-POINT INSTRUCTIONS Add (A, AR, AI, AIS) Add Halfword (AH, AHI) Add to Memory (AM) Add Halfword to Memory (AHM) Subtract (S, SR, SI, SIS), Subtract Halfword (SH, SHI) | 5-4<br>5-5<br>5-7<br>5-9<br>5-11<br>5-13 | | | · <b></b> | | J 13 | | | 5.7.7<br>5.7.8<br>5.7.9<br>5.7.10<br>5.7.12<br>5.7.13<br>5.7.14<br>5.7.15<br>5.7.16 | Compare Halfword (CH, CHI) Multiply (M, MR) Multiply Halfword (MH, MHR) Divide (D, DR) Divide Halfword (DH, DHR) Shift Left Arithmetic (SLA) Shift Left Halfword Arithmetic (SLHA) Shift Right Arithmetic (SRA) Shift Right Halfword Arithmetic (SRHA) | 5-17<br>5-18<br>5-20<br>5-20<br>5-20<br>5-20<br>5-30<br>5-30<br>5-30 | |---|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------| | 6 | FLOATING | G-POINT ARITHMETIC (OPTIONAL) | | | | 6.1 | INTRODUCTION | 6-1 | | | 6.2 | FLOATING-POINT DATA FORMATS | 6-2 | | | 6.3<br>6.3.1<br>6.3.2 | FLOATING-POINT NUMBER Floating-Point Number Range Normalization | 6-3<br>6-4 | | | 6.3.3<br>6.3.4 | Equalization<br>True Zero | 6-5<br>6-5<br>6-6 | | | 6.3.5<br>6.3.6<br>6.3.7 | Exponent Overflow Exponent Underflow Guard Digits and R*-Rounding | 6-7<br>6-7 | | | 6.3.8 | Conversion from Decimal | 6-8<br>6-9 | | | 6.4 | CONDITION CODE | 6-10 | | | 6.5<br>6.5.1 | FLOATING-POINT INSTRUCTIONS | 6-10 | | | 6.5.3 | | 6-12<br>6-14 | | | 6.5.4<br>6.5.5 | Load Multiple Floating-Point (LME)<br>Load General Register from Floating-Point | 6-15<br>6-16 | | | 6.5.6<br>6.5.7 | Register (LGER)<br>Store Floating-Point (STE)<br>Store Multiple Floating-Point (STME) | 6-16<br>6-17<br>6-17 | | | 6.5.8<br>6.5.9<br>6.5.10 | Add Floating-Point (AE, AER) Subtract Floating-Point (SE, SER) | 6-18<br>6-20 | | | 6.5.11<br>6.5.12 | Compare Floating-Point (CE, CER) Multiply Floating-Point (ME, MER) Divide Floating-Point (DE, DER) | 6-22<br>6-23<br>6-25 | | | 6.5.13<br>6.5.14<br>6.5.15 | Fix Register (FXR) Float Register (FLR) | 6-27<br>6-29 | | | 6.5.16 | Load Double-Precision Floating-Point (LD, LDR, LDGR) Load Positive Double-Precision Register | 6-30 | | | | (LPDR) | 6-31 | 29-747 R00 4/81 | | 6.5.17 | Load Complement Double-Precision Register | | |----|-----------|------------------------------------------------|---------------| | | | (LCDR) | 6-32 | | | 6.5.18 | Load Multiple Double-Precision Floating- | | | | | Point (LMD) | 6-33 | | | 6.5.19 | Load General Registers from Double-Precision | | | | | Floating-Point Register (LGDR) | 6-34 | | | 6.5.20 | Store Double-Precision Floating-Point (STD) | 6-35 | | | 6.5.21 | Store Multiple Double-Precision Floating- | | | | | Point (STMD) | 6 <b>-</b> 35 | | | 6.5.22 | Add Double-Precision Floating-Point (AD, ADR) | 6-36 | | | 6.5.23 | Subtract Double-Precision Floating-Point (SD, | | | | | SDR) | 6-38 | | | 6.5.24 | Compare Double-Precision Floating-Point (CD, | | | | | CDR) | 6-40 | | | 6.5.25 | Multiply Double-Precision Floating-Point (MD, | | | | | M DR) | 6-41 | | | 6.5.26 | Divide Double-Precision Floating-Point (DD, | | | | | DDR) | 6-43 | | | 6.5.27 | Fix Register Double-Precision (FXDR) | 6-45 | | | 6.5.28 | Float Register Double-Precision (FLDR) | 6-46 | | | 6.5.29 | Load Single-Precision Floating-Point | | | | | Register from Double (LED, LEDR) | 6-47 | | | 6.5.30 | Load Double-Precision Floating-Point Register | | | | | from Single (LDE, LDER) | 6-48 | | | 6.5.31 | Store Double-Precision Floating-Point Register | | | | | in Single-Precision Memory (STDE) | 6-49/6-50 | | | | | | | -, | CMDTNC | OPERAMIONO | | | 7 | STRING | OPERATIONS | | | | 7.1 | INTRODUCTION | 7-1 | | | 7 • 1 | ININODUCTION | • | | | 7.2 | DECIMAL DATA FORMAT DEFINITIONS | 7-1 | | | 7.2.1 | Packed Decimal | 7-i | | | 7.2.2 | Unpacked (Zoned) Decimal | 7-2 | | | 7.2.2 | onpuoned (Boned) becamal | . 2 | | | 7.3 | DECIMAL AND ALPHANUMERIC STRING INSTRUCTION | | | | 7 • 3 | FORMATS | 7-3 | | | | TORINIS | , , | | | 7.4 | STRING INSTRUCTIONS | 7-3 | | | 7.4.1 | | 7-4 | | | 7.4.2 | Store Binary as Packed Decimal String (STBP) | 7-5 | | | 7.4.3 | Move Translated Until (MVTU) | 7-6 | | | 7.4.4 | • • • • • • • • • • • • • • • • • • • • | 7-8 | | | 7.4.5 | | 7-10 | | | 7.4.6 | | 7-12 | | | 7.4.7 | · | 7-14 | | | , • ~ • , | onguon and note (only only) | , 17 | | | | | | | 8 | HIGH SP | PEED DATA HANDLING INSTRUCTIONS (OPTIONAL) | | | | | | | | | 8.1 | INTRODUCTION | 8 – 1 | | | | | | | | | · · | | |---|-----------|--------------------------------------------------------------------------------------------------------------|--------------| | | 8.2 | DATA HANDLING INSTRUCTION FORMATS | 8-1 | | | 8.3 | DATA HANDLING INSTRUCTIONS | 8-1 | | | | Process Byte (PB) | 8-2 | | | 0 - 3 - 1 | Process Byte Register (PBR) | 8-4 | | | 0.3.2 | Process byte Register (PDR) | 0-4 | | 9 | INPUT/OU: | TPUT OPERATIONS | | | | 9.1 | INTRODUCTION AND CONFIGURATION OF I/O SYSTEM | 9-1 | | | 9.2 | DEVICE CONTROLLERS | 9-1 | | | 9.2.1 | Function | 9-1 | | | 9.2.2 | Device Addressing | 9-2 | | | 9.2.3 | Function Device Addressing Processor/Controller Communication Device Priorities - External Interrupt Levels; | 9-2 | | | 9.2.4 | Device Priorities - External Interrupt Levels; | | | | | Interrupt Queuing | 9-2 | | | 9.3 | INTERRUPT SERVICE POINTER TABLE | 9-3 | | | 0 4 | COMMENT OF TAX ORDERTONS | o | | | 9.4 | CONTROL OF I/O OPERATIONS | 9-4 | | | 9.5 | STATUS MONITORING I/O | 9-4 | | | 9.6 | INTERRUPT DRIVEN I/O | 9-5 | | | | SELECTOR CHANNEL I/O | 9-6 | | | | Introduction | 9-6 | | | | Selector Channel Devices | 9-7 | | | | Selector Channel Operation | 9-7 | | | 9.7.4 | Selector Channel Programming | 9-3 | | | 9.8 | I/O INSTRUCTION FORMATS | 9-9 | | | | I/O INSTRUCTIONS | 9-9 | | | 9.9.1 | Output Command (OC, OCR) | 9-10 | | | 9.9.2 | Sense Status (SS, SSR) | 9-11 | | | | Read Data (RD, RDR) | 9-12 | | | | Read Halfword (RH, RHR) | 9-13 | | | | Write Data (WD, WDR) | 9-14 | | | | Write Halfword (WH, WHR) | 9-15 | | | | Autoload (AL) | 9-16 | | | 9.9.8 | Simulate Channel Program (SCP) | 9-18 | | | 9.10 | AUTO DRIVER CHANNEL | <b>9-1</b> 9 | | | 9.11 | CHANNEL COMMAND BLOCK | 9-19 | | | | Introduction | 9-19 | | | 9.11.2 | Subroutine Address | 9-20 | | | 9.11.3 | | 9-21 | | | | Translation | 9-21 | | | 9.11.5 | Check Word | 9-22 | | | 9.11.6 | Channel Command Word | 9-23 | 29-747 R00 4/81 vii | | | Valid Channel Command Codes<br>General Auto Driver Channel Programming | 9-25 | |----|------------|------------------------------------------------------------------------|----------------| | | 301100 | Procedure | 9-26 | | 10 | STATUS | SWITCHING AND INTERRUPTS | | | | 10.1 | INTRODUCTION | 10-1 | | | 10.2 | PROGRAM STATUS WORD (PSW) AND RESERVED | | | | 1002 | MEMORY LOCATIONS | 10-2 | | | 10.2.1 | Program Status Word | 10-3 | | | | Memory Access Level Field (LVL) | 10-3 | | | 10.2.1.2 | Floating-Point Masked Mode (FLM) | 10-3 | | | 10.2.1.3 | Interruptible Instruction in Progress (IIP) | 10-3 | | | 10.2.1.4 | Wait State (W) | 10-4 | | | | I/O Interrupt Mask (I) | 10-4 | | | | Machine Malfunction Interrupt Enable (M) | 10-5 | | | 10.2.1.7 | Floating-Point Underflow Interrupt Enable | | | | | (FLU) | 10-5 | | | | Relocation/Protection Enable (R/P) | 10-6 | | | | System Queue Service Interrupt Enable (Q) | 10-6 | | | | O Protect Mode Enable (P) | 10-6 | | | | 1 Register Set Select Field (R) | 10-7 | | | | 2 Condition Code (C, V, G, L) | 10-8 | | | | PSW Location Counter (LOC) | 10-8<br>10-9 | | | 10 • 2 • 3 | Reserved Memory Locations | 10-9 | | | 10.3 | INTERRUPT TIMING AND PRIORITY | 10-10 | | | 10.3.1 | Maskable and Nonmaskable Interrupts | 10-10 | | | 10.3.2 | Interrupt Timing | 10-12 | | | 10.3.3 | Interrupt Precedence | 10-13 | | | 10.3.4 | Interruptible Instructions | 10-14 | | | | | | | | | PROCESSOR MODES | 10-15 | | | 10.4.1 | Console Mode | 10-15 | | | 10.4.2 | Run Mode | 10-16 | | | 10.4.3 | Single-Step Mode | 10-17 | | | 10 5 | STATUS SWITCHING | 40-40 | | | | Illegal Instruction Interrupt | 10-18<br>10-19 | | | | Data Format Fault Interrupt | 10-19 | | | | Alignment Faults | 10-19 | | | | Invalid Digit Faults | 10-21 | | | | Relocation/Protection (MAT) Fault Interrupt | 10-21 | | | | Machine Malfunction Interrupt | 10-22 | | | | Early Power Fail Detect and Automatic | | | | | Shutdown | 10-24 | | | 10.5.4.2 | Power Restore | 10-25 | | | | •1 If the LSU is Disabled | 10-25 | | | | •2 If the LSU is Enabled | 10-26 | | | 10.5.4.3 | Noncorrectable Memory Error | 10-26 | | | 10.5.4.4 | Nonconfigured Memory Address | 10-28 | viii 29-747 R00 4/81 | | 10.5.4.5 | Shared Memory Power Fail Detect (Optional) | 10-29 | |----|-----------|----------------------------------------------|--------------| | | 10.5.5 | Input/Output Device (I/O) Interrupts | 10-30 | | | 10.5.5.1 | Priority Levels | 10-30 | | | 10.5.5.2 | Immediate Interrupt-Auto Driver Channel | | | | | Operation | 10-31 | | | 10.5.6 | Simulated Interrupt | 10-34 | | | 10.5.7 | | 10-35 | | | 10.5.8 | Supervisor Call (SVC) Interrupt | 10-36 | | | | System Breakpoint Interrupt | 10-37 | | | | Arithmetic Fault Interrupt | 10-37 | | | 1013113 | nii die independent | 10 37 | | | 10.6 | STATUS SWITCHING INSTRUCTIONS | 10-38 | | | 10.6.1 | Load Program Status Word (LPSW) | 10-39 | | | 10.6.2 | | 10-40 | | | | Exchange Program Status Register (EPSR) | 10-41 | | | 10.6.4 | | 10-42 | | | | Supervisor Call (SVC) | 10-43 | | | | System Breakpoint (BRK) | 10-44 | | | | Privileged System Function (PSF) | 10-44 | | | | Read Error Logger (REL) | 10-45 | | | | Load Process Segment Table Descriptor | 10-46 | | | | (LPSTD) | 10-50 | | | | Load Shared Segment Table Descriptor (LSSID) | 10-51 | | | | Store Process State (STPS) | 10-52 | | | | Load Process State (LDPS) | 10-53 | | | | Save Interruptible State (ISSV) | 10-55 | | | | Restore Interruptible State (ISRSI) | 10-55 | | | | Store Byte, No ECC (XSTB) | 10-56 | | | | Reset Memory Voltage Failure (RMVF) | 10-57 | | | 10.0.7.5 | Reset Remory Voltage Fallule (RMVF) | 10-56 | | 11 | MEMORY M | ANAGEMENT | | | | | TVDD05447704 | | | | 11.1 | INTRODUCTION | 11-1 | | | 11.2 | ADDRESS SPACE | 11-3 | | | 11.2.1 | Physical Address Space | 11-3 | | | 11.2.2 | Program Address Space | 11-3 | | | | Segment Field | 11-4 | | | | Offset Field | 11-4 | | | 11.2.3 | | 11-4 | | | 11.2.3 | Selection of Program of Physical Addressing | 11-5 | | | 11.3 | TRANSLATION FROM PROGRAM TO PHYSICAL | | | | * * * * * | ADDRESS SPACE | <b>11-</b> 5 | | | 11.3.1 | | 11-6 | | | | Segment Table Descriptors and Their Use | 11-6 | | | | Format of a Segment Table Descriptor | 11-7 | | | | Setting the Program Address Space Size | 11-7 | | | 11.3.3 | | 11-8 | | | | Segment Table Entry Size | 11-8 | | | | Hardware Segment Table Entry | 11-8 | | | | Software Segment Table Entry | 11-12 | | | | | | 29-747 R00 4/81 ix | 11.4 | MEMORY ADDRESS TRANSLATOR FAULTS | 11-16 | |----------|-----------------------------------------------|-------------| | 11.4.1 | Conditions that Cause MAT Faults | 11-16 | | 11.4.1.1 | PST or SST Size Exceeded Fault | 11-16 | | 11.4.1.2 | Nonpresence Fault | 11-17 | | 11.4.1.3 | Access Level Fault | 11-17 | | 11.4.1.4 | Access Mode Faults | 11-17 | | 11.4.1.5 | Segment Limit Fault | 11-17 | | 11.4.2 | Fault Precedence | 11-18 | | 11.4.3 | MAT Fault Handling Routine | 11-18 | | 11.4.4 | Reexecution of Faulting Instructions | 11-19 | | 11.4.5 | Effect of System Initialization on the MAT | 11-19 | | 11.5 | MEMORY MANAGEMENT INSTRUCTIONS | 11-20 | | 11.5.1 | Load Process Segment Table Descriptor (LPSTD) | 11-20 | | 11.5.2 | Ioad Shared Segment Table Descriptor (LSSTD) | 11-21/11-22 | # APPENDIXES | A | OP-CODE MAP | |---|------------------------------------------------| | В | INSTRUCTION SUMMARY - ALPHABETICAL BY MNEMONIC | | С | INSTRUCTION SUMMARY - NUMERICAL | | D | ARITHMETIC REFERENCES | | E | I/O REFERENCES | | F | CCNSCLE SERVICE ROUTINE FLCWCHART | # FIGURES | 1-1<br>1-2<br>1-3<br>1-4<br>1-5<br>1-6 | Model 3210 Processor Block Diagram Program Status Word Register Set Numbering Instruction Formats Sample Program RXRX Formats | 1-2<br>1-4<br>1-5<br>1-12<br>1-13<br>1-25 | |----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------| | 2-1<br>2-2 | System Control Panel<br>Model 550 Keyboard Layout | 2-1<br>2-3 | | 3-1<br>3-2<br>3-3<br>3-4<br>3-5 | Logical Data Translation Table Entry Circular List Definition Circular List LRA Example | 3-1<br>3-2<br>3-3<br>3-4<br>3-15 | # FIGURES (Continued) | 3-6<br>3-7 | Flowchart for CRC Generation List Processing Instructions | 3-47<br>3-54 | |--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------| | 5-1 | Fixed-Point Data Formats | 5 <b>-1</b> | | 6-1<br>6-2 | Exponent Overflow Exponent Underflow | 6-7<br>6-7 | | 7-1<br>7-2 | Packed Decimal Format<br>Unpacked Decimal Format | 7-1<br>7-2 | | 9-1<br>9-2<br>9-3 | Channel Command Block<br>Channel Command Word<br>Auto Driver Channel Flowchart | 9-20<br>9-23<br>9-27 | | 10-1<br>10-2<br>10-3 | Program Status Word (PSW)<br>Reserved Memory Locations<br>Schematic Diagram of Interrupt System | 10-2<br>10-9 | | 10-4<br>11-1<br>11-2<br>11-3<br>11-4 | Architecture Machine Malfunction Status Word (MMSW) Memory Address Translation Program Address Segment Table Descriptor Segment Table Entry | 10-11<br>10-23<br>11-2<br>11-4<br>11-7<br>11-9 | | TABLES | | | | 2-1 | SYSTEM TERMINAL SUPPORT COMMAND SUMMARY | 2-2 | | 5-1<br>6-1 | FIXED-POINT FORMAT RELATIONS FLOATING/FIXED-POINT RANGES | 5-2<br>6-4 | | 10-1 | INTERRUPT PRIORITY LEVEL/REGISTER SET SUMMARY SUMMARY | 10-32<br>10-32 | | 11-1 | SEGMENT ACCESS FIELD SETTINGS | 11-10 | | INDEX | | Index-1 | 29-747 R00 4/81 xi #### PREFACE The Model 3210 Processor User's Manual provides programming and operating information for the System. The programmer is provided with information on the 32-bit system architecture and the unique memory management scheme, as well as a description of each instruction in the repertoire. The instruction descriptions include valuable system-related information presented in the form of programming notes and instruction examples. Information pertaining to the system control terminal is given to facilitate program preparation and execution for the system programmer and operator. # CHAPTER 1 SYSTEM DESCRIPTION #### 1.1 INTRODUCTION The Mcdel 3210 processor is designed to meet the needs for high performance and reliability in a 32-bit minicomputer. The architecture has improved error recovery capabilities for those applications where fault tolerance is a necessity, and allows direct addressing of up to 4 megabytes of memory implemented in MOS with Error-Correction Code (ECC). Through the use of 32-bit general registers and a comprehensive instruction set, the Model 3210 processor provides fullword data processing power and direct memory addressing up to a limit of 8 megabytes. The system is shown in block diagram form in Figure 1-1. The instruction set includes: - halfword and fullword arithmetic and logical operations - optional single-precision and double-precision floating-point - list processing - cyclic redundancy checking - bit and byte manipulations - alrhanumeric and decimal character string processing - decimal/binary conversions - instructions designed to improve operating system performance With this enriched repertcire and direct memory addressing, coding and debugging time is reduced to a minimum. Eight sets of 16 32-bit general registers are provided. Register set selection is controlled by bits in the Program Status Word (PSW). Register-to-register instructions permit operations between any of the 16 registers in the current set, eliminating redundant loads and stores. The multiple register set organization eliminates the overhead incurred in saving and restoring registers when responding to interrupts. The Memory Address Translator (MAT) provides automatic program segmentation, relocation, and protection. The protect mode enables detection of privileged instructions. These two features are invaluable in process control, data communication, and time-sharing operations because they prevent a running program from interfering with the system integrity. Figure 1-1 Model 3210 Processor Block Diagram The Model 3210 supports up to 4 Mb of directly addressable MOS memory. Error correction is standard and is performed across every 32-bit fullword in memory using a 7-bit modified Error-Correcting Code (ECC). All single-bit errors are detected and corrected; all double-bit errors and most multiple-bit errors are detected. The memory error logger identifies the memory module reporting a fault and indicates the location of the faulty memory chip. In addition to conventional means of programmed I/O, the processor automatically acknowledges all I/O interrupts and performs much of the required overhead before activating an interrupt service routine. The auto driver channel can perform data transfers with character translation, longitudinal or cyclic redundancy checking, and data buffer chaining without interrupting the running program. Refer to the following manuals for further information: Common Assembly Language (CAL) User's Manual, Publication Number 29-640 ESELCH Programming Manual, Publication Number 29-529 FDMA Bus Universal Interface Instruction Manual, Publication Number 29-423 Mcdel 3210 Maintenance Manual, Publication Number 47-022 #### 1.2 PROCESSOR The Central Processing Unit (CPU), or processor, controls activities in the system. (See Figure 1-1.) It executes instructions in a specific sequence and performs arithmetic and logical functions. Included in the processor's components are the following: - Program status word register - General registers - Hardware multiply and divide ### 1.2.1 Program Status Word (PSW) The 64-bit Program Status Word (PSW) defines the state of the processor at any given time. (See Figure 1-2.) Figure 1-2 Frogram Status Word Bits 0:31 are reserved for status information and interrupt masks. Bits 32:63 contain the location counter. Unassigned PSW bits must not be used and must always be zero. Status information and interrupt mask bits are defined as follows: | | | Reserved<br>LVL | Must be zero Memory access level | |------|-------|-----------------|------------------------------------------| | Bit | | Reserved | Must be zero | | Bit | 13 | FLM | Floating-point arithmetic masked mode | | Bit | 14 | IIP | Interruptible instruction in progress | | Bit | 15 | Reserved | Must be zero | | Bit | 16 | W | Wait state | | Bit | 17 | I | I/O interrupt mask | | Bit | 18 | M | Machine malfunction interrupt mask | | Bit | 19 | FLU | Floating-point arithmetic underflow mask | | Bit | 20 | I | I/O interrupt mask | | Bit | 21 | R/P | Relocation/protection interrupt mask | | Bit | 22 | Ç | System queue interrupt mask | | Bit | 23 | P | Protect mode | | Bits | 24:27 | R | Register set select bits | | Bits | 28:31 | C, V, G, L | Condition code | | Bits | 32:39 | Reserved | Must be zero | | Bits | 40:63 | | Program address (location counter) | Refer to Chapter 10 for details on the interrupt mask bits. ### 1.2.1.1 Register Set Select (R) Bits 24:27 of the PSW are used to designate the current register set. Register sets are numbered 0 through 15. The processor has eight sets of general registers. (See Figure 1-3.) 558 | REGISTER<br>SET<br>NUMBER | DESIGNATION | |-------------------------------------|--------------------------------------------------------| | 0<br>1<br>2<br>3 | RESERVED FOR INTERRUPTS | | 4<br>5<br>6 | MAY BE ALLOCATED BY THE OS<br>FOR GENERAL PURPOSE USE. | | 7<br>8<br>9<br>10<br>11<br>12<br>13 | UNIMPLEMENTED<br>SETS | | 15 | GENERAL PURPOSE | Figure 1-3 Register Set Numbering #### 1.2.1.2 Condition Code (C, V, G, L) Bits 28:31 of the PSW contain the condition code. As part of the execution of certain instructions, the state of the condition code may be changed to indicate the nature of the result. Not all instructions affect the condition code. The state of the condition code may conditional branch be tested with instructions. Each bit in the condition code is set if the corresponding condition occurred as a result of the instruction that affected the condition code. The normal interpretation of these bits is: | С | V | G | L | |---|---|---|---| | 1 | 0 | 0 | 0 | | 0 | 1 | 0 | 0 | | 0 | 0 | 1 | 0 | | 0 | 0 | 0 | 1 | Arithmetic carry, borrow, or shifted carry Arithmetic overflow Greater than zero Less than zero #### 1.2.1.3 Location Counter The location counter contains the address of the instruction currently being executed by the processor, and points to that instruction until it has successfully completed execution. Once this execution is completed, the location counter is incremented by 2, 4, 6, 8, 10, or 12 (depending upon the instruction executed), and the next instruction is fetched. In the case of a branch instruction, the location counter is loaded with the address to which control is being transferred, and the next instruction is fetched from that address. If an instruction is not successfully completed due to a fault or other interrupting condition, the location counter contains the address of the faulting or interrupted instruction. When a program interruption is due to an incorrect branch address, the location counter contains the branch address and not the location of the branch instruction. #### 1.2.2 General Registers The processor has eight register sets, numbered 0 through 6, and 15 (see Figure 1-3). There are 16 registers in each set and each register is 32 bits wide. Register set selection is determined by the state of bits 24:27 of the current PSW. Registers 1 through 15 of any set may be used as index registers. When an interrupt occurs, the processor loads pertinent information into preselected registers of the register set selected by the new PSW. For details of this operation, refer to Chapter 10. #### 1.2.3 Floating-Point Registers There are eight optional single-precision floating-point registers, each 32 bits wide. These registers are identified by the even numbers 0 through 14. There are eight optional double-precision floating-point registers, each 64 bits wide. These registers are also identified by the even numbers 0 through 14 and are separate from the single-precision floating-point registers. Floating-point operations must always specify the registers with even numbers. #### 1.3 PROCESSOR INTERRUPTS The PSW that is loaded in the processor at any point in time is called the current PSW. If either the status word or both the location counter and status word are changed, a status switch is said to have occurred. This status switch can be caused explicitly by executing special instructions, or it can be forced to occur by an interrupt or fault. At the time of a status switch, the current PSW that is saved is called the old PSW. The PSW that replaces the current PSW is called the new PSW. Interrupt conditions cause the entire PSW to be replaced by a new PSW, thus breaking the usual sequential flow of instruction execution. When an interrupt condition occurs, the processor saves its current PSW either in memory or in a pair of general registers belonging to the register set selected by the new PSW. It loads information related to the interrupt condition in other registers of this same set. A new PSW is loaded from a memory location reserved for the specific interrupt condition. The immediate interrupt is an exception to the rule. In this case, the status portion of the new PSW, bits 0:31, is forced to a preset value, and the location counter is loaded from a memory location reserved for that interrupting device. Refer to Chapter 10 for details of interrupt processing. #### 1.4 RESERVED MEMORY LOCATIONS Physical memory locations $X^0^-X^2CF^0$ are called reserved memory locations. These locations contain the various new PSWs and other information needed to handle interrupts. | X * 000000 * - X * 00001F * | Reserved; must be zero | |------------------------------|----------------------------------------| | X * 000020 * - X * 000027 * | Machine malfunction interrupt old PSW | | X*000028*-X*00002B* | Used by console service microcode | | X * 00002C * - X * 00002F * | Machine malfunction LM block start | | | address | | X*000030*-X*000037* | Illegal instruction interrupt new PSW | | X * 000038 * - X * 00003F * | Machine malfunction interrupt new PSW | | X • 000040 • - X • 000043 • | Machine malfunction status word | | X • 000044 • - X • 000047 • | Machine malfunction virtual (program) | | | address | | X • 000048 • - X • 00004 F • | Arithmetic fault interrupt new PSW | | X * 000050 * - X * 00007F * | Boctstrap loader and device definition | | | table | | X.000080X.000083. | System queue pointer | | X * 000084 * - X * 000087 * | Power fail save area pointer | | X.000088X.00008E. | System queue service interrupt new PSW | Relocation/Protection interrupt new PSW X'000090'-X'000097' Surervisor call new PSW status X'000098'-X'00009B' Surervisor call new PSW location X.00006C.-X.0000BB. counter values (16 halfwords) X'0000BC'-X'0000BF' Reserved; must be zero X'0000C0'-X'0000C7' Reserved; must be zero X \* 0000C8 \* - X \* 0000CF \* Data format fault new PSW X'0000D0'-X'0002CF' Interrupt service pointer table X \* 0002D0 \* - X \* 0004CF \* Expanded interrupt service pointer table. X \* 0004D0 \* - X \* 0008CF \* Expanded interrupt service pointer table These reserved locations play an important role in both interrupt and input/output processing. (Refer to Chapters 9 and 10.) All location counter values are subject to MAT relocation if the new PSW enables the MAT (bit 21=1). All other pointers contain absolute addresses not subject to MAT relocation. #### 1.5 DATA FORMATS The processor performs logical and arithmetic operations on single bits, 8-bit bytes, 16-bit halfwords, 32-bit fullwords, and 64-bit doublewords. This data may represent a fixed-point number, a floating-point number, logical information, a bit or byte array, or a decimal or alphanumeric byte string. #### 1.5.1 Fixed-Point Data Fixed-point arithmetic operands may be either 16-bit halfwords or 32-bit fullwords. In fullword multiply and divide operations, 64-bit operands are manipulated. Fixed-point data is treated as 15-bit signed integers in the halfword format. Positive numbers are expressed in true binary form with a sign bit of zero. Negative numbers are represented in two's complement form with a sign bit of one. The numerical value of zero is represented with all bits zero. Refer to Chapter 5 for details of fixed-point data representation. In fixed-point arithmetic and logical operations between a fullword register and a halfword operand, the halfword operand is expanded to a fullword by propagating the most significant bit into the high order bits before the operation is started. This permits the use of halfword to fullword operations with consistent results and provides space economy, since small values do not require fullword locations. Arithmetic operations on fixed-point halfword quantities may produce results not entirely consistent with those obtained in a 16-bit processor. If this problem exists, the Convert to Halfword Value Register (CHVR) instruction may be used to adjust the result and the condition code, making them consistent with the same operations in a 16-bit processor. ### 1.5.2 Floating-Point Data A floating-point number consists of a 7-bit exponent in excess-64 notation and a signed fraction. The quantity expressed by this number is the product of the fraction and the number 16 raised to the power represented by the exponent. Each floating-point value requires a 32-bit fullword or a 64-bit doubleword, of which eight bits are used for the sign and exponent. The remaining bits are used for the fraction. Refer to Chapter 6 for details of floating-point data representation. Floating-point operations take place between the contents of a floating-point register and another floating-point register, a floating-point operand contained in a fullword or doubleword in memory, or a general register or pair of general registers. #### 1.5.3 Logical Data Logical operations manipulate 8-bit bytes, 16-bit halfwords, and 32-bit fullwords. In addition, it is possible to perform logical operations on single bits located in bit arrays. Refer to Chapter 3 for details of logical data representation. ### 1.5.4 Decimal String Data Decimal strings are strings of consecutive bytes in memory that begin and end on byte boundaries. Information contained in a decimal string may represent packed or unpacked decimal data. Refer to Chapter 7 for details of decimal data formats and operations. #### 1.5.5 Alphanumeric String Data Alphanumeric strings are strings of consecutive bytes in memory that begin and end on byte boundaries. Information contained in an alphanumeric string may represent any character stream including decimal string data. Refer to Chapter 7 for details of alphanumeric string data format and operations. #### 1.6 DATA ALIGNMENT The following discussion is unique to the Model 3210 implementation and is presented for information only. Any program that misuses a processor feature by taking advantage of a peculiarity of one implementation may not work on a different implementation. Locations in main memory are numbered consecutively, beginning at address '000000'. Although memory is addressable and alterable to the byte level, machine accesses to memory involve only halfwords or fullwords. Those instructions requiring a single byte access actually access a halfword and then manipulate the appropriate byte within the halfword. Memory can be accessed only to the halfword level; therefore, bit 31 of the address is truncated at the memory. A halfword fetch at address '000051' and a fetch at address X'000050' produce the same halfword. There is no warning mechanism telling the program that it is fetching halfwords on the odd byte boundary. The CAL Assembler generates an error flag if it sees halfword operations directed to an odd byte address or if it sees fullword operations directed to other than a fullword address. Pytes of information are addressed by their specific hexadecimal address. Two bytes form a halfword. Halfwords have an even address, the address of the left-most byte in the pair. Two halfwords comprise a fullword. A fullword address is a multiple of four (4 bytes) and is the address of the left-most halfword in the pair. The hardware actually truncates the least significant two address bits on fullword accesses, forcing proper alignment. A data format fault is generated if a fullword access is directed to an address that has bit 30 or 31 set; or if a halfword store is directed to an address that has bit 31 set. #### 1.7 INSTRUCTION ALIGNMENT User-level instructions are always aligned on halfword boundaries. Any halfword address is valid regardless of the length of the instruction word. The CAL assembler generates boundary errors if the assembled location counter for an instruction becomes odd. At the machine level, an attempt to make the instruction location counter odd by branching or causing a status switch is ignored by the hardware. In the Model 3210, location counter bit 31 is not implemented and is therefore always zero. Thus, a branch to address X'000051' causes the location counter to be set to X'000050'. # 1.8 INSTRUCTION FORMATS # 1.8.1 Introduction Instruction formats provide a concise method of representing required operations for easy interpretation by the processor. Figure 1-4 shows the eight basic formats. The following is a list of abbreviations and their meanings as used in Figure 1-4. | OP | Operation code | |-------|--------------------------------------------| | R 1 | First operand register | | R 2 | Second operand register | | N | A 4-bit immediate value | | X 2 | Second operand single index register | | D2 | Second operand displacement | | FX2 | Second operand first index register | | SX2 | Second operand second index register | | A 2 | Second operand direct address | | I2 | Second operand immediate value | | L1 | Specifies the length of the first operand | | L2 | Specifies the length of the second operand | | CPMOD | Specifies a particular instruction within | | | the class specified by OP | | ADD1 | The effective first operand address | | ADD2 | The effective second operand address | | | | Many instructions may be expressed in two or more formats. This feature provides flexibility in data organization and instruction sequencing. When working with the Common Assembly Language (CAL) assembler, it is unnecessary to specify the instruction format. The assembler selects the most economical format and supplies the required bits in the machine code. When double indexing is required, the assembler always chooses the RX3 format. (Refer to the Common Assembly Language (CAL) Manual, Publication Number 29-640.) 29-747 R00 4/81 Figure 1-4 Instruction Formats #### 1.8.2 Branch Instruction Formats Branch instructions use the RR, SF, and all variations of the RX formats. In the conditional branch instructions, however, the R1 field does not specify a register; instead, it contains a mask value (labeled M1 in the instruction descriptions). This mask value is tested with the condition code. The CAL assembler provides a series of extended branch mnemonics, which makes it possible to specify a conditional branch without specifying the mask value explicitly. ### 1.8.3 Programming Examples Each of the following examples refers to the sample assembly language program shown in Figure 1-5. Note the use of symbolic equates for general registers. Machine code generated and the result of each instruction are dependent upon the physical and logical placement of the instructions, respectively. | PROG= S | 3200 | AS | SEMBLED RY | CAL | 03 | -066R05-0 | 1 (3 | 2-811) | | |---------|---------|--------------|------------------|-----|-------|----------------|---------------|--------------------------|-----------------------------| | | | | | | 1 2 3 | \$3200 | PROG<br>CROSS | SERIES 3200 INSTRU | CTION FORMAT EXAMPLES | | | | | • | | , | | NOR X3 | | • | | | 0000 | 0005 | | | 5 | R 5 | EQU | 5 | GENERAL REGISTER 5 | | | | 0006 | | | 6 | ₹6 | EQU | 6 | GENERAL REGISTER 6 | | | | 0007 | | | 7 | R 7 | EQU | 7 | GENERAL REGISTER 7 | | | | 0008 | | | 8 | R8 | EGU | 8 | GENERAL REGISTER 8 | | | | 0009 | | | 9 | 39 | EQU | 9 | GENERAL REGISTER 9 | | | | 000A | | _ | .0 | R10 | EOU | 10 | GENERAL REGISTER 10 | | | 0000 | 0000 | | | 1 | R11 | EQU | 11 | GENERAL REGISTER 11 | | 0000001 | 245E | | | 1 | . 3 | SF | LIS | R5+14 | (R5) = *0000000E* | | 0000021 | 0865 | | | 1 | 5 | RR | LR | R6+R5 | (R6) = "0000000E" | | 0000041 | 4050 | 1000 | | 1 | . 7 | RX1.EX1 | STH | R5+X*1000* | (X*1000*) = X*000E* | | 0000081 | 4056 | OFF2 | | 1 | 9 | <b>RX1.EX2</b> | STH | R5.X*0FF2*(R6) | (x • 1000 • ) = x • 000 E • | | 00000C1 | | | =0000141 | | 1 | RX2.EX1 | STH | R5+L0C1 | (LOC1) = X+000E+ | | 0000101 | | 0000 | =0000181 | | 2 | 1.001 | 8 | RI1.EX1<br>F*9* | THE HALFWOODS OF STOR | | 0000171 | | 0000 | | 2 | 3 | LOC1 | DC | F-01- | TWO HALFWORDS OF STOR | | 0000181 | C890 | 8000 | | 2 | 5 | R I 1 • E X 1 | LHI: | R9.X*8000* | (R9) = Y*FFFF8000* | | 00001C1 | C895 | 8000 | | 2 | 7 | RI1.EX2 | LHI | R9+X+8000+(R5) | (R9) = Y*FFFF800F* | | 0000201 | F8A0 | 0000 | 8000 | 2 | 9 | R12.EX1 | LI | R10+X*8000* | (910) = Y*00008000* | | 0000261 | F8BA | 0001 | 7FFE | 3 | 1 | R12.EX2 | LI | R11.Y*17FFE*(R10) | (R11) = Y*0001FFFE* | | 00002C1 | 4050 | FFE4 | =0000141 | 3 | 3 | RX2.EX2 | STH | R5+LOC1 | (LOC1) = X*000E* | | 0000301 | 4056 | FFD2 | =000006I | 3 | 5 | R X 2 • E X 3 | STH | R5+L0C1-14(R6) | (LOC1) = X * 000E * | | 0000341 | 5870 | 4001 | 0000 | 3 | 7 | RX3.EX1 | L | R7.Y.10000. | (R7) = (Y*010000*) | | 00003A1 | | 4601<br>FFBC | FFE4<br>=0000001 | - | 9 | <b>9X3.EX2</b> | L<br>B | R8.Y*20000*-29(R5.<br>SF | R6) (R8) = (Y*020000*) | | 0000441 | ı | | | . 4 | 2 . | | END | | | | ~ | | | | _ | ~ | | ~ | <u> </u> | | | LOCATIO | N OB.TE | CT IN | FORMATION | | 1 | LABEL | 1 | OPERANDS | COMMENTS | Figure 1-5 Sample Program # 1.8.4 Register-to-Register (RR) Format | 561 | 0 7 | .8 11 | 12 15 | |-----|-----|-------|-------| | | OP | R1 | R2 | In this 16-bit format, bits 0:7 contain the operation code; bits 8:11 contain the R1 field; and bits 12:15 contain the R2 field. In most RR instructions, the register specified by R1 contains the first operand, and the register specified by R2 contains the second operand. For example: 1.8.5 Short Form (SF) Format This 16-bit format provides space economy when working with small values. Bits 0:7 contain the operation code; bits 8:11 contain the R1 field; and bits 12:15 contain the N field. In arithmetic and logical operations, the register specified by R1 contains the first operand. The N field contains a 4-bit immediate value (12:15) used as the second operand. For example: | Machine Code | <u>Label</u> | Assembler N | otation | |--------------|---------------------|---------------------|---------| | 245E | SF | LIS R5,14 | | | | Second operand | | | | | First operand | | | | I | Load Immediate Shor | t (LIS) instruction | op-code | 563 | , | 0 7 | 8 11 | 12 15 | 16 1 | 7 | 18 31 | |---|-----|------|-------|------|---|-------| | | ОР | R1 | X2 | 0 | 0 | D2 | This is a 32-bit format in which bits 0:7 contain the operation code; bits 8:11 contain the R1 field; bits 12:15 contain the X2 field; bits 16 and 17 must be zero; and bits 18:31 contain the D2 field. In general, the register specified by R1 contains the first operand. The second operand is located in memory at the address obtained by adding the contents of the second operand index register (specified by X2) and the 14-bit absolute address contained in the D2 field. For example: The second operand address is calculated as follows: No indexing is specified; therefore, the second operand address is $X^{\circ}1000^{\circ}$ . The second operand address is calculated as follows: ### Second Operand Address - = contents of D2 field + contents of index register 6 (see Figure 1-5) - = X\*OFF2\* + Y\*000000E\* - = Y \* 00001000\* #### 1.8.7 Register and Indexed Storage Two (RX2) Format | 566 | 0 7 | 8 11 | 12 15 | 16 | 17 | 31, | |-----|-----|------|-------|----|----|-----| | | ОР | R1 | X2 | 1 | D2 | | This format provides relative addressing capability in a 32-bit instruction word. Bits 0:7 contain the operand code; bits 8:11 contain the R1 specification; bits 12:15 contain the X2 specification; bit 16 must always be one; and bits 17:31 contain the relative displacement, D2. In the RX2 format, the register specified by R1 contains the first operand. The address of the second operand, in memory, is calculated by adding the value contained in the incremented location counter (the address of the next sequential instruction) and the sum of (1) the 32-bit representation of the 15-bit signed number contained in the D2 field, and (2) the contents of the index register specified by X2. Negative numbers in the D2 field are expressed in two's complement notation. For example: The second operand address is calculated as follows: #### Second Operand Address - = 32-bit expansion of contents of D2 field + contents of incremented location counter (see Figure 1-5) - = Y'00000004 + Y'00000010 - = Y'0000014' The second operand address is calculated as follows: #### Second Operand Address - = 32-bit expansion of contents of D2 field + contents of incremented location counter (see Figure 1-5). - = Y'FFFFFFE4' + Y'00000030' - = Y'00000014' The second operand address is calculated as follows: Second Operand Address - = 32-bit expansion of D2 field + contents of incremented location counter + contents of index register 6 (see Figure 1-5) - = Y'FFFFFFD2' + Y'00000034' + Y'0000000E' - = Y'00000014' 1.8.8 Register and Indexed Storage Three (RX3) Format This is a 48-bit format in which double indexing is permitted. Bits 0:7 contain the operation code; bits 8:11 contain the R1 specification; bits 12:15 contain the first index specification, FX2; bit 16 must be zero; bit 17 must be one; bits 18:19 must be zero; bits 20:23 contain the second index specification, SX2; and bits 24:47 contain a 24-bit address, A2. Second level indexing is allowed even if first level indexing is not specified. In general, the first operand is contained in the register specified by R1. The second operand is located in memory. Its memory address is obtained by adding the contents of the first index register and the contents of the second index register, and then adding to this result the contents of the A2 field. For example: The second operand address is calculated as follows: Second Operand Address - = contents of A2 field - = Y \* 000 10000 \* #### Machine Code ### Labe1 #### Assembler Notation The second operand address is calculated as follows: 572-1 Second Operand Address - = contents of A2 field + contents of index register 6 + contents of index register 5 (see Figure 1-5) - = Y'0001FFE4" + Y'0000000E" + Y'0000000E" - = Y'00020000' #### 1.8.9 Register and Immediate Storage One (RI1) Format This format represents a 32-bit instruction word. Bits 0:7 contain the operand code; bits 8:11 contain the R1 specification; and bits 16:31 contain the 16-bit immediate value, I2. In this format, the register specified by R1 contains the first operand. The 32-bit effective second operand is obtained by adding together the 32-bit representation of the signed 16-bit value contained in the I2 field, and the contents of the register specified by X2. For example: The second operand is calculated as follows: #### Second Operand - = 32-bit representation of X'8000' - = Y FFFF8000 • The second operand is calculated as follows: 16 20 24 28 31 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 #### Second Operand - = 32-bit representation of X'8000' + the contents of the index register 5 (see Figure 1-5) - = Y'FFFF8000' + Y'0000000E' - $= Y \cdot FFFF800F \cdot$ 1.8.10 Register and Immediate Storage Two (RI2) Format This is a 48-bit instruction format. Bits 0:7 contain the operation code; bits 8:11 contain the R1 specification; bits 12:15 contain the X2 specification; and bits 16:47 contain the 32-bit immediate value, I2. The first operand is contained in the register specified by R1. The second operand is obtained by adding the contents of the index register, specified by X2, and the 32-bit immediate value contained in the I2 field. For example: The second operand is calculated as follows: #### Second Operand - = contents of I2 field - = Y .00080000. The second operand is calculated as follows: #### Second Operand - = contents of I2 field + contents of index register 10 (see Figure 1-5) - = Y'00017FFE' + Y'00008000' - = Y \* 000 1 F F F E \* 1.8.11 Register and Indexed Storage/Register and Indexed Storage (RXRX) Format (See Figures 1-4 and 1-6) The RXRX format resembles a pair of adjacent RX format instructions, but represents only one instruction. Each member of the instruction pair may have any one of the standard RX formats. For example, the first member might be RX1 and the second member might be RX3, resulting in a 10-byte instruction. The particular RX format chosen by the assembler for one member is independent of that chosen for the other; thus, the instruction can require 8, 10, or 12 bytes. OP contains the operation code that defines the RXRX instruction class. The actual operation to be performed is defined by the OPMOD field. The L1 field specifies the length of the first operand string. If bit 0 of OPMOD is set, L1 is the length with a maximum value of 15. If bit 0 of OPMOD is zero, the general register specified by L1 contains the length. The L2 field specifies the length of the second operand string. If bit 1 of OPMOD is set, this field contains the length with a maximum value of 15. If bit 1 of OPMOD is zero, the general register specified by L2 contains the length. The effective address calculated for the first member is the address of the left-most (lowest-address) byte of the first operand string. The effective address calculated for the second member is the address of the left-most byte of the second operand string. An RX2 displacement calculated for either member is with respect to the incremented location counter for that member. In this example both members of the RXRX instruction use the RX1 format. No indexing is specified for either member so the first operand address is $X^*1000^{\circ}$ , and the second operand address is $X^*0FFC^{\circ}$ . Figure 1-6 RXRX Formats In this example, both members of the RXRX instruction use the RX3 format. Double indexing is specified for the first member and no indexing is specified for the second member. The first operand address is X°1FFE4° plus the contents of index registers 6 and 5. The second operand address is X°28000°. The length of the first operand is 10 bytes and the second operand is 6 bytes. #### CHAPTER 2 SYSTEM CONTROL #### 2.1 INTRODUCTION Operator control is provided by the system control panel and the System Terminal, a microcode-supported device interfaced to the system by an asynchronous line controller. The System Terminal may be used as the operating system's console device, and may be a visual display unit or a printing terminal. The asynchronous interface must be strapped as device numbers X'10' and X'11'. #### 2.2 CONFIGURATION The system control panel, shown in Figure 2-1, controls power to the system and Initial Program Loading (IPL). It also provides controls for system initialization, processor halt/run, and single step. Light Emitting Diodes (LEDs) on the system console indicate current system state. Figure 2-1 System Control Panel Keyboard commands through the System Terminal allow the operator to examine and modify processor registers and main memory (Refer to Figure locations and then begin program execution. Hexadecimal characters and a number of special characters 2-2.) the System Terminal support microcode. are recognized by characters accepted and their meanings are shown in Table 2-1. other characters are accepted and cause a question mark (?) use for When not in to be written to the System Terminal. the System Terminal is available to a running operator control, program for use as an I/O device. See Appendix F for a flowchart of the console service routine. TABLE 2-1 SYSTEM TERMINAL SUPPORT COMMAND SUMMARY 581-1 | 581-1 | | | |----------------------------|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | KEY<br>COMMAND<br>SEQUENCE | MEANING | SYSTEM TERMINAL DISPLAY | | <b>ðnnnnn</b> CR | Select memory address<br>and display halfword<br>contents | <∂nnnnn<br>nnnnn YYYY<br>≤ | | RNCR | Select general register and display contents | ≤Rn<br>YYYYYYYY<br>≤ | | FnCR | Select single-precision floating-point register and display contents* | <pre>≤Fn</pre> | | Dncr | Select double-precision floating-point register and display contents* | <pre>≤Dn YYYYYYY YYYYYYYY ≤</pre> | | PCR | Select program status word and display contents | <u>₹</u><br><u>₹</u><br><u>₹</u> | | + | Increment memory location counter to display next sequential halfword | <pre>&lt;+ nnnnn YYYY ≤</pre> | | - | Decrement memory location counter to display previous halfword | <pre></pre> | | =YXYYCR | Replace contents of currently selected memory location or register with new data | <pre>&lt;=YYYY for memory </pre> <pre>&lt;=YYYYYYYY for register </pre> | | < | Begin program execution at current memory location | <b>≤&lt;</b> | | # | Delete command | <a>2010#</a> ≤ <a>2010#</a> <a>3010#</a> <a>3010#<a>3010#</a> <a>3010#</a> <a>3010#</a> <a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a>3010#<a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a></a> | | > | Single-step instruction at current memory location | <≥ | <sup>\*</sup>Floating-point is optional in this processor. #### Notes: - 1. Characters in boxes indicate operational key strokes required for commands. - 2. Character symbol cf lower case n used to indicate hexadecimal address of memory or register. - 3. Character symbol of upper case Y used to indicate hexadecimal contents of memory or register. - 4. Underlined characters are those output from the system. Characters not underlined are those typed by the operator. - 5. A back arrow, or underline (X°5F°), or a back space (X°08°) character may be used to delete the previously input hexadecimal character. - 6. Space characters may be entered as desired. They are ignored by the processor. Figure 2-2 Model 550 Keyboard Layout # 2.3 SYSTEM CONTROL PANEL SWITCHES AND INDICATORS ## 2.3.1 Key-Operated Security Lock This is a 3-position (STANDEY-ON-LOCK) key-operated switch that controls primary power to the system. It can also disable (LOCK) the initialize and console switches, thereby preventing any accidental manual input to the system. The power indicator lamp (POWER) is on when the security lock is in the ON or LOCK position. ## 2.3.2 Control Switches All the control switches, with the exception of the Initial Program Load (IPL) switch, are enabled only when the key-operated security lock is in the CN position, and primary AC power is applied. #### HALT/RUN HALT/RUN This momentary contact switch causes program execution to be halted if the system was running, or resumed if the system was halted. When halted, control is given to the System Terminal support routine through which the memory or registers can be examined or modified and program execution restarted. If the processor was already in the System Terminal support routine, program execution is started. This switch is disabled if the security lock is in the LOCK position. #### SINGLE STEP SINGLE When in the UP position, control is automatically given to the System Terminal support routine at the conclusion of each user level instruction. The program status word is displayed, including the address of the next sequential instruction (location counter). Execution of the next instruction is caused by pressing the HALT/RUN switch or by typing a less than (<) character on the System Terminal. To resume normal run mode execution, return the SINGLE STEP switch to the DOWN position and begin execution by pressing the HALT/RUN switch or by typing the less than (<) character on the System Terminal. The SINGLE STEP switch is disabled when the security lock is in Attempts to single step LOCK position. through instructions that do I/O to the System Terminal do not produce meaningful results. #### IPL ENABLE This switch is not disabled by the security lock. When in the ENABLE position, an Initial Program Load (IPL) from the Loader Storage Unit (LSU) is performed after any of the following steps: DISABLE - turning the security lock from the STANDBY to 1. ON position - depression of the Initialize (INIT) switch 2. - 3. return of AC power to the system #### INITIALIZE INIT This momentary contact switch causes the system to be initialized. The initialization sequence clears all device controllers on the I/O bus and resets certain functions in the processor. The fault lamp (FAULT) comes on when the switch is depressed and is extinguished with the completion of the initialization sequence. ### 2.4 OPERATING INSTRUCTIONS #### 2.4.1 Power-Up To prevent Initial Program Load (IPL) on power-up, place the IPL switch in the DISABLE position. To power-up the system, turn the key-operated security lock clockwise from the STANDBY to the ON position. The power lamp (POWER) lights, and power is provided The fault lamp (FAULT) on the system control to the system. panel also lights, and the microdiagnostic routine is entered. This routine exercises internal data paths and registers. If main memory power has fallen out of regulation since the system locations X'000000' to X'03FFFF' running, last initialized. The diagnostic routine tests the lowest 256 kbytes memory before extinguishing the FAULT lamp. This diagnostic of limited in scope, serving only to indicate a go/no-go is an error is detected in any portion of the Ιf condition. microdiagnostic, the microccde loops indefinitely, and the FAULT lamp remains on. If no errors are detected, the FAULT lamp is turned off. ### 2.4.2 Entering Console Service If power was lost while the microcode was in the console service routine, control is returned to the console when the power-up sequence is complete, provided that IPL is not enabled. If the system was executing a program when power was lost, execution resumes when power returns, provided that IPL is not enabled. To enter console service in this case, depress the HALT/RUN switch. ## 2.4.3 Initial Program Load (IPL) To perform Initial Program Load (IPL), place the IPL switch in the ENABLE position; then initialize the system by depressing the INIT switch momentarily. A power down/power up sequence is emulated, and diagnostics are performed. At the successful completion of the microdiagnostic sequence, an IPL from the LSU is performed. Control is transferred to the newly-loaded program. ## 2.5 SYSTEM TERMINAL COMMANDS When the System Terminal support routine is entered from power-up or initialize, a carriage return and line feed sequence are output. The current value of the PSW status and location counter are output, followed by another carriage return and line feed sequence. Finally, the less than (<) operator prompt character is output to indicate that the system is ready to receive operator commands. If memory power was lost, the location counter is set to X'003FFFFE', and the PSW is set to X'00008000'. In this case, the first 256 kbytes of memory are written during power-up to establish the error correcting code bits. Space characters may be used as desired in any of the described System Terminal commands. Spaces are ignored by the console routine. ## 2.5.1 Select an Address and Examine "@" The commercial "at" sign (a) places the System Terminal support routine in the address mode. This character may be followed by up to six hexadecimal digits of address. Leading zeros are not required. If more than six digits are input, only the least significant six are used. A carriage return is used to signal the end of the address; the address input is then copied into the location counter. A carriage return and line feed sequence are output, followed by the new value of the location counter and the halfword contents of that location. Note that the data fetch is subject to memory relocation if enabled by the current PSW. After this display, a carriage return and line feed sequence are output, followed by a new operator prompt. If an invalid character is input by the operator, the system responds by outputting a question mark (?), a carriage return, a line feed, and an operator prompt. ## 2.5.2 Increment and Examine Next Location "+" After examining a memory location, the plus character (+) can be used to advance the location counter by two. No other operator input is required. A carriage return and line feed are output, followed by the new location counter value and the halfword contents of that location. This memory access is subject to the relocation defined by the current PSW. After outputting another carriage return and line feed, the operator prompt character is output. This procedure may be repeated to examine sequential memory locations. ## 2.5.3 Decrement and Examine Frior Location "-" After examining a memory location, the minus character (-) can be used to decrement the location counter by two. No other operation is required. A carriage return and line feed are output, followed by the new location counter value and the halfword contents of that location. This memory access is subject to the relocation defined by the current PSW. After outputting another carriage return and line feed, the operator prompt character is output. This procedure may be repeated to examine sequential memory locations. ## 2.5.4 Modify Current Location "=" After examining a memory location, the equal sign (=) can be used to put the System Terminal support routine in the memory write mode. This character may be followed by up to four hexadecimal digits of data to be written. Leading zeros are not required. If more than four digits are input, only the least significant four are used. A carriage return is used to signal the end of the data. At that time, the accumulated data is written into the memory location currently addressed by the location counter. This memory write is subject to the relocation defined by the current PSW. The current location counter is incremented by two and a carriage return, line feed, and operator prompt are output. This procedure may be repeated to modify sequential memory locations. ## 2.5.5 Examine General Register "R" The character (R) causes the System Terminal support routine to interpret subsequent hexadecimal input as the number of a general register (in the set selected by the current PSW) to be displayed. A carriage return is used to signal the end of hexadecimal input. At that time, the least significant four bits of the accumulated hexadecimal data are taken as the desired register number. The fullword contents of that register are output followed by a carriage return, line feed, and operator prompt. Plus and minus commands are invalid for general registers. ## 2.5.6 Modify General Register "=" Immediately after examining a general register, the equal sign (=) can be used to change the contents of the currently selected register. The equal sign can be followed by up to eight hexadecimal digits of data. Leading zeros are not required. If more than eight digits are input, only the least significant eight are used. A carriage return is used to signal the end of the data input. At that time, the accumulated data is copied into the currently selected general register. A carriage return, line feed, and operator prompt are then output. # 2.5.7 Examine Single-Precision Floating-Point Register "F" The character (F) causes the System Terminal support routine to interpret subsequent hexadecimal input as the number of a single-precision floating-point register to be displayed. If the processor does not have single-precision floating-point, this command character causes a question mark sequence to be output. A carriage return is used to signal the end of hexadecimal input. At that time, the least significant four bits of the accumulated hexadecimal data are taken as the desired register number. If necessary, this number is rounded to the next lowest even number. The fullword contents of that register are output followed by a carriage return, line feed, and operator prompt. Plus and minus commands are invalid for floating-point registers. ## 2.5.8 Modify Single-Precision Floating-Point Register "=" Immediately after examining a single-precision floating-point register, that register is available for modification. Type an equal sign (=) followed by up to eight hexadecimal digits of data. Leading zeros are not required. If more than eight digits are input, only the least significant eight are used. A carriage return is used to signal the end of the data input. At that time, the accumulated data is copied into the currently selected single-precision floating-point register. This data is not tested for normalization; therefore, an unnormalized floating-point number can be manually placed in the register. The system outputs a carriage return, line feed, and operator prompt. ## 2.5.9 Examine Double-Precision Floating-Point Register "D" The character (D) causes the System Terminal support routine to interpret subsequent hexadecimal input as the number of a double-precision floating-point register to be displayed. If the processor does not have double-precision floating-point, this command character causes a question mark sequence to be output. A carriage return is used to signal the end of hexadecimal input. At that time, the least significant four bits of the accumulated hexadecimal data are taken as the desired register number. If necessary, this number is rounded to the next lowest even number. The doubleword contents of that register are output, followed by a carriage return, line feed, and operator prompt. Plus and minus commands are invalid for floating-point registers. #### 2.5.10 Modify Double-Precision Floating-Point Register "=" Immediately after examining a double-precision floating-point register, that register is available for modification. Type an equal sign (=) followed by up to 16 hexadecimal digits. Leading zeros are not required. If more than 16 digits are input, only the last 16 digits are used. A carriage return is used to signal the end of the data input. At that time, the accumulated data is copied into the currently selected double-precision register. The data is not tested for normalization; therefore, an unnormalized floating-point number can be manually placed in a double-precision register. The system outputs a carriage return, line feed, and operator prompt. #### 2.5.11 Examine Program Status Word "P" The character (P) puts the System Terminal support routine into the PSW display mode. A carriage return is required to complete this command input. Upon receipt of the carriage return, the contents of the PSW are output followed by a carriage return, line feed, and operator prompt. The plus and minus commands are invalid for the PSW. #### 2.5.12 Modify Program Status Word "=" Immediately after examining the PSW, the equal sign (=) can be used to change the contents of the PSW status field. The equal sign can be followed by up to six hexadecimal digits of data. Leading zeros are not required. If more than six digits are input, only the least significant six are used. A carriage return is used to signal the end of the data input. At that time, the accumulated data is copied into the PSW, which is then displayed. A carriage return, line feed, and operator prompt are then output. ### 2.5.13 Execute Single Instruction ">" Entering the character (>) causes the processor to execute the instruction indicated by the location counter, in single-step mode. If the instruction is an interruptible instruction, only one phase or iteration of the instruction may be performed. After this execution, the console service routine displays the PSW and location counter, followed by a carriage return, line feed, and operator prompt. #### 2.5.14 Enter Run Mode "<" Entering the character (<) causes the processor to begin program execution, starting with the instruction indicated by the location counter. # 2.6 MEMORY INITIALIZATION The following example shows how to set up dedicated low memory for loading the 32-bit relocating loader from magnetic tape. | < a 3 0 cr | Select address '30' | |-------------------|----------------------------------------------------------------------| | 000030 0000 | Location '30' already = '0000' | | ≤ + | Advance to address '32' | | 000032 8000 | Location '32' already = '8000' | | ≤ + | Advance to address '34' | | 000034 0000 | Location '34' already = '0000' | | ≤ + | Advance to address '36' | | 000036 1536 | location '36' contains '1536' | | < = 5 0 cr | Change contents of '36' to '0050 | | 000038 0000 | Location '38' contains '0000' | | <b>≤ a 5 o cr</b> | Select address '50' | | 000050 D500 | <pre>Location '50' already = 'D500', the auto-load instruction</pre> | | ≤ + | Advance to address '52' | | 000052 00CF | Location '52' already = '00CF', the usual ending address | | ≤ + | Advance to address •54• | | 000054 4300 | Location '54' already = '4300' a branch instruction | | ≤ + | Advance to address *56* | | 000056 0080 | Location '56' already = '0080' the usual branch address | | <b>≤ a 7 8 cr</b> | Select address '78' | | 000078 C186 | Location '78' contains 'C186' | | | | | ≤ = 8 5 A 1 cr | Change '78' to '85A1', the device<br>number and command byte for<br>magnetic tape | |----------------|-----------------------------------------------------------------------------------| | 00007A 0000 | Location '7A' contains '0000' | | <b>≤ +</b> | Advance to address '7C' | | 00007C 0000 | Location '7C' contains '0000' | | < a 3 0 cr | Select starting address '30' | | 000030 0000 | | | < < | Start program execution | After loading, the relocating loader places the processor in the wait state. The wait lamp on the consolette is on. Depress the HALT/RUN switch to regain control at the System Terminal. The terminal response, for example is: 008000 03FB00 < which shows the PSW and the LCC pointing at the loader start address of '3FB00'. Type the less than (<) character to begin execution of the relocating loader. #### 2.7 SYSTEM TERMINAL PROGRAMMING INSTRUCTIONS The System Terminal (ST) uses either a 2-line asynchronous communication multiplexor or an 8-line asynchronous communication multiplexor interface. Since the microprogram of the processor must communicate with the ST, the device address is fixed at X'010' and X'011'. The interface must be strapped for full duplex operation. Refer to the appropriate instruction manual for complete programming information. The microprogram programs the ST for highest clock rate, two stop bits per character, seven data bits, and even parity. Echoplex is not turned on. # CHAPTER 3 LOGICAL OPERATIONS #### 3.1 INTRODUCTION The set of logical instructions provides a means for the manipulation of binary data. Many of the instructions grouped with the logical set may also be used in arithmetic and other operations. These instructions include loads, stores, compares, shifts, list processing, translation, and cyclic redundancy checks. #### 3.2 LOGICAL DATA FORMATS Logical data may be organized as bytes, halfwords, fullwords, or bit arrays of up to $2^{27}$ bits as shown in Figure 3-1. | 5 | | | | |----------|-----------|---------------------------------------|----| | <u>0</u> | BYTE 7 | | | | | | | | | | | | | | | | | | | 0 | HALFWORD | 15 | | | | | | | | <b>L</b> | | · · · · · · · · · · · · · · · · · · · | | | | | | | | 0 | FULLWORD | | 31 | | | | | | | <b>L</b> | | | | | | | | | | 0 | BIT ARRAY | | N | | | | , , | | | L | | | | Figure 3-1 Logical Data #### 3.3 OPERATIONS In logical operations between the contents of a general register and a halfword operand, the halfword operand is expanded to a fullword before the operation starts. The halfword is expanded by propagating the most significant bits through bits 0:15 of the fullword. For example, the halfword 'A000' is expanded to 'FFFFA000' before participating in the operation. ### 3.3.1 Boolean Operations The Boolean operators AND, OR, and Exclusive OR (XOR) operate on halfword and fullword quantities. All bits in both operands participate individually. The Boolean functions are defined as follows: ``` O AND 0 = 0 O AND 1 = 0 1 AND 0 = 0 1 AND 1 = 1 O CR 0 = 0 O OR 1 = 1 1 OR 0 = 1 1 OR 1 = 1 C XCR 0 = 0 O XOR 1 = 1 1 XOR 0 = 1 1 XOR 0 = 1 1 XOR 0 = 1 1 XOR 0 = 1 1 XOR 1 = 0 ``` #### 3.3.2 Translation The Translate (TLATE) instruction is used to translate a character directly, or to effect an unconditional branch to a special translate subroutine. Associated with the translate instruction is a translation table. The entries in the table are halfwords, as shown in Figure 3-2. Figure 3-2 Translation Table Entry The character to be translated is a byte of logical data. This unsigned quantity is doubled and used as an index into the translation table. If the corresponding table entry has a one in bit position zero, then bits 8:15 contain the character to be substituted for the data character. If there is a zero in bit position zero, bits 1:15 contain the address, divided by two, of the translation routine. When the translate instruction results in a branch, this value is doubled to produce the address of the routine. Because this result is a 16-bit address, the software routine must be located in the first 64 kb of the program address The program may reside anywhere in memory if it is space. relocated by the Memory Address Translator (MAT). translation table may contain up to 256 entries. However, if the data characters are always less than eight bits, fewer entries are required. #### 3.3.3 List Processing The list processing instructions manipulate a circular list as defined in Figure 3-3. Figure 3-3 Circular List Definition The first four halfwords, called the list header, contain the list parameters. Immediately following the header is the list itself. The first fullword in the list is designated Slot 0. The remaining slots are designated 1, 2, 3, etc., up to a maximum slot number, which is equal to the number in the list minus one. An absolute maximum of 65,535 fullword slots may be specified. (Slots are designated 0 through X°FFFE°.) The first halfword of the header indicates the number of slots (fullwords) in the entire list. The second halfword indicates the current number of slots being used. When this halfword equals zero, the list is empty. When this halfword equals the number of slots in the list, the list is full. Once initialized, this halfword is maintained automatically. It is incremented when elements are added to the list and decremented when elements are removed. The third and fourth halfwords of the list header specify the current top of the list and the next bottom of the list, respectively. These pointers are also updated automatically. (See Figure 3-4.) Figure 3-4 Circular List ### 3.4 LOGICAL INSTRUCTION FORMATS The logical instructions use the Register to Register (RR), the Short Form (SF), the Register and Indexed Storage (RX), and the Register and Immediate Storage (RI) instruction formats. ### 3.5 LOGICAL INSTRUCTIONS The instructions described in this section are: ``` Load L Load Register LR Load Immediate LI Load Immediate Short LIS Load Complement Short LCS Load Halfword LH Load Halfword Immediate LHI Load Address LA Load Real Address LRA Load Halfword Logical LHL Load Multiple LM Load Byte LB Load Byte Register LBR Exchange Halfword Register EXHR Exchange Byte Register FXBR Store ST Store Halfword STH Store Multiple STM Store Byte STB Store Byte Register STBR Compare Logical C L Compare Logical Register CLR Compare Logical Immediate CLI Compare Logical Halfword CLH Compare Logical Halfword Immediate CLHI Compare Logical Byte CLB AND N AND Register NR AND Immediate ΝI AND Halfword NΗ AND Halfword Immediate NHI OR 0 OR Register OR OR Immediate OI OR Halfword OH OR Halfword Immediate OHI Exclusive OR X Exclusive OR Register XR Exclusive OR Immediate XI Exclusive OR Halfword XΗ Exclusive OR Halfword Immediate XHI Test Immediate ΤI Test Halfword Immediate THI ``` ``` Shift Left Logical SLL Shift Left Logical Short SLLS Shift Right Logical SRL Shift Right Logical Short SRLS Shift Left Halfword Logical SLHL Shift Left Halfword Logical Short SLHLS Shift Right Halfword Logical SRHL Shift Right Halfword Logical Short SRHLS Rotate Left Logical RLL Rotate Right Logical RRL Test and Set TS Test Bit TBT Set Bit SBT Complement Bit CBT Reset Bit RBT Cyclic Redundancy Check Modulo 12 CRC12 Cyclic Redundancy Check Modulo 16 CRC16 TLATE Translate Add to Top of List ATL Add to Bottom of List ABL Remove from Top of List RTL Remove from Bottom of List RBL ``` ## 3.5.1 Load (L, LR, LI) Load (L) Load Register (LR) Load Immediate (LI) | Ass | embler Notation | Op-Code | <b>Format</b> | | |-----|------------------|------------|---------------|--| | L | R1,D2(X2) | 58 | RX1,RX2 | | | T. | R1, A2(FX2, SX2) | 58 | RХЗ | | | LR | R1,R2 | 0.8 | RR | | | LI | R1,I2(X2) | <b>F</b> 8 | RI2 | | #### Cperation The second operand replaces the contents of the register specified in R1. #### Condition Code | С | V | G | L | | | |---|---|---|-------------|----------|----------| | 0 | 0 | 0 | 0 | Value is | zero | | 0 | 0 | 0 | 1 | Value is | not zero | | 0 | 0 | 1 | 0<br>1<br>0 | Value is | not zero | #### Programming Notes When the Load instructions operate on fixed-point data, the condition code indicates zero (no flags), negative (L flag), or positive (G flag) value. In the RR format, if R1 equals R2, the Load instruction functions as a test on the contents of the register. In the RX formats, the second operand must be located on a fullword boundary. ### 3.5.2 Load Immediate Short (IIS) | Assen | bler Notation | Op-Code | <b>Format</b> | |-------|---------------|---------|---------------| | LIS | R1,N | 24 | SF | #### Operation The 4-bit second operand is expanded to a 32-bit fullword with high order bits forced to zero. This fullword replaces the contents of the register specified by R1. #### Condition Code | | С | V | G | L | | |---|---|---|---|---|----------------------| | Ì | 0 | 0 | 0 | 0 | <b>Value is zero</b> | | | 0 | 0 | 0 | 0 | Value is not zero | #### Programming Note When this instruction operates on fixed-point data, the condition code indicates zero (no flags), or positive (G flag) value. Example: LIS | Assem | bler Notation | Machine Code | Comments | |-------|---------------|--------------|-------------------| | LIS | REG4, 15 | 244F | LOAD 15 INTO REG4 | Result of LIS Instruction (REG4) = 0000000F Condition Code = 0010 (G=2) ### 3.5.3 Load Complement Short (LCS) | Assem | bler Notation | Op-Code | Format | |-------|---------------|---------|--------| | LCS | R1, N | 25 | SF | #### Operation The 4-bit second operand is expanded to a 32-bit fullword with high order bits forced to zero. The two's complement value of this fullword then replaces the contents of the register specified by R1. #### Condition Code | C | V | G | L | | |---|---|-------|---|-------------------| | 0 | 0 | 0 | 0 | Value is zero | | 0 | 0 | G O O | 1 | Value is not zero | #### Programming Note When this instruction operates on fixed-point data, the condition code indicates zero (no flags), or negative (L flag) value. Example: LCS | Asser | bler Notation | Machine Code | Comments | |-------|---------------|--------------|-------------------| | LCS | REG8,7 | 2587 | LCAD -7 INTO REG8 | Result of ICS Instruction (REG8) = FFFF FFF9 Condition Code = 0001 (L=1) 3.5.4 Load Halfword (LH, LHI) Load Halfword (LH) Load Halfword Immediate (LHI) | Asse | mbler Notation | Op-Code | Format | |------|------------------|---------|---------| | LH | R1,D2(X2) | 48 | RX1,RX2 | | LH | R1, A2(FX2, SX2) | 48 | RX3 | | LHI | R1,I2(X2) | C8 | RI1 | #### Operation The halfword second operand is expanded to a fullword by propagating the most significant bit through bits 0:15. This fullword replaces the contents of the register specified by R1. #### Condition Code | | | | | L | | |---|---|---|---|-------------|-------------------| | | 0 | 0 | 0 | 0 | Value is zero | | į | 0 | 0 | 0 | 1 | Value is not zero | | | 0 | 0 | 1 | 0<br>1<br>0 | Value is not zero | #### Programming Notes When the Load Halfword instructions operate on fixed-point data, the condition code indicates zero (no flags), negative (L flag), or positive (G flag) value. In the RX formats, the second operand must be located on a halfword boundary. In the RI1 format, the 16-bit I2 field is extended to a fullword by propagating the sign bit through bits 0:15. The contents of the index register specified by X2 are then added to form the fullword second operand. #### 3.5.5 Load Address (LA) | Asse | embler Notation | Op-Code | Format | | |------|------------------|---------|---------|--| | LA | R1,D2(X2) | E 6 | RX1,RX2 | | | LA | R1, A2(FX2, SX2) | E 6 | RX3 | | #### Operation The effective address of the second operand (24 bits) replaces bits 8:31 of the register specified by R1. Bits 0:7 of the register specified by R1 are forced to zero. Condition Code Unchanged #### Programming Note The length of the address quantity depends on the internal structure of the particular machine; thus, in this processor, with a maximum address length of 24 bits, the calculated address replaces bits 8:31 of the register specified by R1, and bits 0:7 are replaced by zero. In a processor with a maximum address length of 20 bits, the calculated address replaces bits 12:31 of the register specified by R1, and bits 0:11 are forced to zero. #### 3.5.6 Load Real Address (LRA) | Assem | bler Notation | Op-Code | <b>Format</b> | |-------|------------------|---------|---------------| | LRA | R1,D2(X2) | 63 | RX1,RX2 | | LRA | R1, A2(FX2, SX2) | 63 | RX3 | #### Operation This instruction simulates the operation of the Memory Address Translator. The register specified by R1 contains a program address (not relocated). The second operand address points to a relocation/protection module parameter block, in the format shown: | BYTE<br>OFFSET | 0 1 | 14 | 15 3° | l . | |----------------|----------|------------------|-----------------------------|--------| | +0 | $\times$ | (PST ENTRIES) -1 | A(PROCESS SEGMENT TABLE)/12 | 8 PSTD | | +4 | $\geq$ | (SST ENTRIES) -1 | A(SHARED SEGMENT TABLE)/128 | SSTD | The address contained in the register specified by R1 is relocated, using the appropriate parameters. The relocated address replaces the contents of the register specified by R1. #### Condition Code | С | V | G | L | | |---|---|---|---|------------------------------------| | 1 | 0 | 0 | 0 | Segment not mapped | | 0 | 1 | 0 | 0 | Nonpresent segment | | 0 | 0 | 1 | X | Write-protected segment | | 0 | 0 | X | 1 | Read- or Execute-protected segment | | 0 | 0 | 0 | 0 | No restrictions | The condition code is determined on a priority basis with segment table size exceeded checked first, nonpresent segment second, segment limit exceeded third, and all protect keys (as a group) last. #### Programming Notes Segment tables must conform to the rules given in the section on Memory Management; otherwise, the results of the LRA instruction are undefined. If the address is not mapped or not present, the register specified by R1 is unchanged. Segment table size exceeded or segment limit exceeded results in condition code 1000 (unmapped). The second operand location must be on a fullword boundary. Example: LRA This example performs an address translation in the same manner as the Memory Address Translator (MAT). The steps shown are not optimal, and do not reflect the actual operation of the MAT, which is a high-speed device capable of performing several of the steps simultaneously. To set up for this example, register R1 contains X'053147', the program address to be translated. RELOCBLK is the address of a relocation/protection module parameter block. This block contains two fullwords. The first of these is the Process Segment Table Descriptor (PSTL), with the value X'000E06BF'. The second is the Shared Segment Table Descriptor (SSTD), with the value X'000C06C0'. Memory location X'035FA8' contains the Process Segment Table Entry (PSTE) to be used, with the value X'588A0028'. Memory location X'036028' contains the Shared Segment Table Entry (SSTE) to be used, with the value X'58126880'. The instruction proceeds as follows: LRA F1, RELOCBLK TRANSLATE ADDRESS IN R1 - 1. The PSTD is fetched from RELOCBLK, and ANDed with X'FFFE0000' to extract the segment table size field. The result, X'000E0000', is shifted right 17 bit positions, yielding X'00000007'. This value is the number of entries in the Process Segment Table (PST), minus one. Therefore, the PST has entries for segments 0 through 7. - The program address from register R1, X\*053147\*, is shifted right 16 bit positions to yield the specified segment number, X\*00000005\*. The segment number is compared with the FST size. If the PST size were less than the segment number, this would mean that no entry existed in the PST for the specified segment, and that the segment was unmapped (condition code = 8). However, such is not the case, and the instruction proceeds. - 3. The PSTD is ANDed with X'0001FFFF' to extract the segment table address field. The result, X'000006BF', is shifted left seven bit positions, to multiply it by 128. This yields the address of the PST, X'35F90'. - 4. The segment number specified by the program address in R1 (X'053147') is used as an index into the PST. Because each Segment Table Entry (STE) requires eight bytes, the segment number, X'00000005', is shifted left three bit positions, to multiply it by eight. The result, X'00000028', and the address of the PST, X'035F80', are added. The result is the address X'035FA8', and the PSTE at that address is fetched. This PSTE has the value X'588A0028'. The PSTE is ANDed with the value X'40000000' to test the Presence bit in the STE. If the bit were zero, this would mean the segment was not present (condition code = 4). But such is not the case, and the instruction proceeds. 5. The PSTE is then ANDed with X'00800000', to test the Shared Segment bit. If the bit were zero, the LRA instruction would use the data in the PSTE as data in the SSTE also, and perform the operations in step 9 below; but such is not the case. The Shared Segment bit in the PSTE is set, which means that an entry from the Shared Segment Table (SST) must also be used in translating the program address. The SSTD (X°000C06C0°) is ANDed with X°FFFE0000° to extract the segment table size field. The result, X°000C0000°, is shifted right 14 bit positions to yield X°00000030°. This value is the maximum SST offset, the offset in bytes from the start of the SST to the beginning of the last entry. - 6. The SSTD is ANDed with X'0001FFFF' to extract the segment table address field. The result, X'000006C0', is shifted left seven bit positions to yield the address of the Shared Segment Table (SST), X'036000'. - 7. The PSTE is now ANDed with X'0001FFFF' to extract the Segment Relocation Field (SRF). This field has the value X'00000028'. If this value exceeded the maximum SST offset, this would mean that no entry existed in the SST for the specified segment, and that the segment was unmapped (condition code = 8); but such is not the case, and the instruction proceeds. The SRF is added with the PST address, X'036000'. The Shared Segment Table Entry (SSTE) pointed to by the PSTE is located at the resulting address, X'036028'. - 8. The SSTE is fetched, and its value found to be X°58126880°. This value is ANDed with X°40000000° to test the STE Presence bit. If the bit were zero, this would mean the segment was not present (condition code = 4); but such is not the case, and the instruction proceeds. - The SSTE, with a value X°58126880°, is ANDed with the value X°003E0000° to extract the Segment Limit Field (SLF). The resulting value, X°00120000°, is shifted right six bit positions, yielding an SLF value of X°00004800°. The program address from R1, X°053147°, is ANDed with X°0000F800°. The resulting value, X°00003000°, is compared to the SLF value, X°00004800°. If the SLF value were the lesser of the two values, this would indicate that the program address was in an unreachable part of the segment (segment limit violation), and thus unmapped (condition code = 8); but such is not the case, and the instruction proceeds. 10. At this point, address translation can be performed. The SSTE, with value X'58126880', is ANDed with the value X'0001FFFF' to extract the SRF. This field has the value X'00006880'. The SRF is shifted left seven bit positions, giving the relocation value X'00344400'. The program address from R1, X°053147°, is ANDed with the value X°0000FFFF°, giving the value X°00003147°. To this value is added the relocation value, X°00344000°. The result is the translated program address, X°347147°, which replaces the contents of register R1. 11. The PSTE, with value X'588A0028', and the SSTE. value X°58126880°, are ANDed, yielding the value X'58020000'. This value contains the combined segment access keys. If ANDing the keys with X'08000000' yielded a zero result, the G flag would be set in condition code to indicate a write-protected segment. If ANDing the keys with X'10000000' yielded a zero result, the L flag would be set in the condition code to indicate a read-protected segment; but neither is the case. ANDing the keys with X°04000000° does vield a zero result, and the L flag is set in the condition code to indicate that the segment is execute-protected. The LRA instruction terminates once these tests have been performed. (See Figure 3-5.) Figure 3-5 LRA Example ### 3.5.7 Load Halfword Logical (LHL) | Asser | mbler Notation | <u>Op-Code</u> | Format | |-------|------------------|----------------|---------| | LHL | R1,D2(X2) | 73 | RX1,RX2 | | LHL | R1, A2(FX2, SX2) | 73 | RX3 | #### Operation The halfword second operand replaces bits 16:31 of the register specified by R1. Bits 0:15 of the register specified by R1 are replaced by zero. #### Condition Code | j | С | V | G | L | | | |---|---|---|---|---|----------|----------| | | 0 | 0 | 0 | 0 | Value is | zero | | | 0 | 0 | 0 | 0 | Value is | not zero | #### Programming Note The second operand must be located on a halfword boundary. #### 3.5.8 Load Multiple (LM) | Asse | embler Notation | <u>Op-Code</u> | <u>Format</u> | | |------|-----------------|----------------|---------------|--| | LM | R1,D2(X2) | <b>D</b> 1 | RX1,RX2 | | | LM | R1,A2(FX2,SX2) | D 1 | RX3 | | #### Operation Successive registers, starting with the register specified by R1, are loaded from successive memory locations, starting with the location specified as the effective address of the second operand. Each register is loaded with a fullword from memory. The process stops when register 15 has been loaded. Condition Code Unchanged Programming Notes The second operand must be located on a fullword boundary. The second operand address is formed before any registers are loaded; therefore, X2, FX2, and SX2 can be among the registers loaded. In the event of a machine malfunction due to a noncorrectable memory error, or due to a MAT fault, the effective address calculated at the beginning of the instruction is available, should a retry be desired. For details, refer to Chapter 10 and Chapter 12. 3.5.9 Load Byte (LB, LBR) Load Byte (LB) Load Byte Register (LBR) | Asse | mbler Notation | Op-Code | <b>Format</b> | |------|----------------|---------|---------------| | LB | R1,D2(X2) | D3 | RX1,RX2 | | LB | R1,A2(FX2,SX2) | D3 | RX3 | | LBR | R1,R2 | 93 | RR | #### Operation The 8-bit second operand replaces the least significant bits (bits 24:31) of the register specified by R1. Bits 0:23 of the register are forced to zero. Condition Code Unchanged ## Programming Note In the Load Byte Register instruction, the second operand is taken from the least significant eight bits (bits 24:31) of the register specified by R2. #### 3.5.10 Exchange Halfword Register (EXHR) | Assemi | oler Notation | Op-Code | <b>Format</b> | |--------|---------------|---------|---------------| | EXHR | R1,R2 | 34 | RR | #### Operation Bits 0:15 of the register specified by R2 replace bits 16:31 of the register specified by R1. Bits 16:31 of the register specified by R2 replace bits 0:15 of the register specified by R1. Condition Code Unchanged #### Programming Note If R1 equals R2, the two halfwords contained within the register are exchanged. If R1 does not equal R2, the contents of R2 are unchanged. ### Example: EXHR | Assemi | bler Notation | Machine Code | Comments | | | |------------------|---------------------------------------------------|------------------------------------------|----------------------------------------|--|--| | LI<br>LI<br>EXHR | REG5,Y'OABCDEF9'<br>REG7,Y'12345678'<br>REG5,REG7 | F850 OABC DEF9<br>F870 1234 5678<br>3457 | (REG5) = OABCDEF9<br>(REG7) = 12345678 | | | #### Result of EXHR Instruction (REG5) = 56781234(REG7) = 12345678 Condition Code unchanged #### 3.5.11 Exchange Byte Register (EXBR) | Assembler Notation | | <u>Op-Code</u> | Format | |--------------------|-------|----------------|--------| | EXBR | R1,R2 | 94 | RR | #### Operation The two 8-bit bytes contained in bits 16:31 of the register specified by R2 are exchanged and loaded into bits 16:31 of the register specified by R1. Bits 0:15 of the register specified by R1 are unchanged. The register specified by R2 is unchanged. Condition Code Unchanged #### Programming Note R1 and R2 may specify the same register. In this case, the two bytes in bits 16:31 of the register specified by R2 are exchanged. Example: EXBR | Assemi | bler Notation | Machine | Code | <u>C</u> | omments | |--------|---------------------|-----------|------|----------|------------| | LI | REG7, X . 5A6B3C4D. | F870 5A6B | 3C4D | (REG7) | = 5A6B3C4D | | LI | REG3,Y'98761234' | F830 9876 | 1234 | (REG3) | = 98761234 | | EXBR | REG7, REG3 | 9473 | | | | #### Result of EXBR Instruction (REG7) = 5A6B3412(REG3) = 98761234 Condition Code unchanged #### 3.5.12 Store (ST) | Ass | embler Notation | Op-Code | Format | |-----|------------------|---------|---------| | ST | R1,D2(X2) | 50 | RX1,RX2 | | ST | R1, A2(FX2, SX2) | 50 | RX3 | #### Operation The 32-bit contents of the register specified by R1 replace the contents of the fullword memory location specified by the effective address of the second operand. #### Condition Code Unchanged #### Programming Note The second operand location must be on a fullword boundary. #### 3.5.13 Store Halfword (STH) | Assembler Notation | | Op-Code | <b>Format</b> | |--------------------|------------------|---------|---------------| | STH | R1,D2(X2) | 40 | RX1,RX2 | | STH | R1, A2(FX2, SX2) | 40 | RX3 | #### Operation Bits 16:31 of the register specified by R1 replace the contents of the halfword memory location specified by the effective address of the second operand. #### Condition Code Unchanged #### Programming Note The second operand location must be on a halfword boundary. # 3.5.14 Store Multiple (STM) | Assem | bler Notation | Op-Code | <b>Format</b> | |-------|------------------|---------|---------------| | STM | R1,D2(X2) | DO | RX1,RX2 | | STM | R1, A2(FX2, SX2) | DO | RX3 | # Operation The fullword contents of registers, starting with the register specified by R1, replace the contents of successive fullword memory locations, starting with the location specified by the effective address of the second operand. The process stops when register 15 has been stored. Condition Code Unchanged Programming Note The second operand location must be on a fullword boundary. 3.5.15 Store Byte (STB, STBR) Store Byte (STB) Store Byte Register (STBR) | Assem | bler Notation | Op-Code | Format | |-------|------------------|---------|---------| | STB | R1,D2(X2) | D2 | RX1,RX2 | | STB | R1, A2(FX2, SX2) | D2 | RX3 | | STBR | R1,R2 | 92 | ŔR | ## Operation The least significant eight bits (bits 24:31) of the register specified by R1 are stored in the byte second operand location. Condition Code Unchanged ## Programming Note In the Store Byte Register instruction, the 8-bit quantity is stored in bits 24:31 of the register specified by R2. Bits 0:23 of the register are unchanged. # Example: STBR | Assembler Notation | Machine Code | Comments | | |--------------------------------------------|----------------------------------|----------------------------------------|--| | LI PEG4,Y'13577531'<br>LI REG3,Y'24688642' | F840 1357 7531<br>F830 2468 8642 | (REG4) = 13577531<br>(REG3) = 24688642 | | | • | | | | | STBR REG4, REG3 | 9243 | | | Result of STBR Instruction (REG4) = 13577531(REG3) = 24688631 Condition Code unchanged # 3.5.16 Compare Logical (CL, CLR, CLI) Compare Logical (CL) Compare Logical Register (CLR) Compare Logical Immediate (CLI) | Asser | nbler Notation | Op-Code | Format | |-------|------------------|---------|---------| | CL | R1,D2(X2) | 55 | RX1,RX2 | | CL | R1, A2(FX2, SX2) | 55 | RX3 | | CLR | R1,R2 | 05 | RR | | CLI | R1, I2(X2) | F5 | RI2 | # Operation The first operand, the contents of the register specified by R1, is compared logically to the second operand. The result is indicated by the condition code setting. Neither operand is changed. #### Condition Code | C | V | G | L | | |---|---|---|---|-----------------------------------| | 0 | X | 0 | 0 | First operand equal to second | | 1 | Х | 0 | 1 | First operand less than second | | 1 | X | 1 | 0 | First operand less than second | | 0 | Х | 0 | 1 | First operand greater than second | | 0 | X | 1 | 0 | First operand greater than second | # Programming Notes In the RX formats, the second operand must be located on a fullword boundary. The state of the V flag is undefined. If the second operand is zero, the C flag cannot set. It is meaningful to check the following condition code mask (M1) after a logical comparison: | Mask | True/False* | Inference | |------|-------------|------------------------------------------| | 3 | False | First crerand equal to second | | 3 | True | First cperand not equal to second | | 8 | False | First operand greater than or equal to | | 8 | True | second<br>First cperand less than second | <sup>\*</sup>Pefer to Chapter 4 for True/False concept in branch instructions. #### 3.5.17 Compare Logical Halfword (CLH, CLHI) Compare Logical Halfword (CLH) Compare Logical Halfword Immediate (CLHI) | Assem | oler Notation | Op-Code | Format | | |-------|------------------|---------|---------|--| | CLH | R1,D2(X2) | 45 | RX1,RX2 | | | CLH | R1, A2(FX2, SX2) | 45 | RX 3 | | | CLHI | R1,I2(X2) | C5 | RI1 | | #### Operation The halfword second operand is expanded to a fullword by propagating the most significant bit through bits 0:15. The first operand, the contents of the register specified by R1, is compared to this fullword. The result is indicated by the condition code setting. Neither operand is changed. #### Condition Code | C | ٧ | G | L | | |---|---|---|---|----------------------------------| | 0 | X | 0 | 0 | First operand equal to second | | 1 | Х | 0 | 1 | First operand less than second | | 1 | X | 1 | 0 | First operand less than second | | 0 | X | 0 | 1 | First operand greater than secon | | 0 | Х | 1 | 0 | First operand greater than secon | #### Programming Notes In the RX formats, the second operand must be located on a halfword boundary. In the RI1 format, the 16-bit I2 field is extended to a fullword by propagating the sign bit through bits 0:15. The contents of the index register specified by X2 are then added to form the fullword second operand. The state of the V flag is undefined. If the second operand is zero, the C flag cannot set. It is meaningful to check the following condition code mask (M1) after a logical comparison: | <u>Mask</u> | True/False* | Inference | |-------------|-------------|-----------------------------------| | 3 | False | First operand equal to second | | 3 | True | First operand not equal to second | | 8 | False | First operand greater than or | | | | equal to second | | 8 | True | First operand less than second | <sup>\*</sup>Refer to Chapter 4 for True/False concept in branch instructions. #### 3.5.18 Compare Logical Byte (CLB) | Assen | bler Notation | Op-Code | Format | |-------|-----------------|---------|---------| | CLB | R1,D2(X2) | D4 | RX1,RX2 | | CLB | R1, A2(FX2,SX2) | D 4 | RX3 | #### Operation The byte quantity, contained in bits 24:31 of the register specified by R1, is compared with the 8-bit second operand. The result is indicated by the condition code setting. Neither operand is changed. #### Condition Code | | С | | | | | |---|-------------|---|---|---|-----------------------------------| | | 0 | X | 0 | 0 | First operand equal to second | | į | 1 | X | 0 | 1 | First operand less than second | | | 0<br>1<br>0 | X | 1 | 0 | First operand greater than second | # Programming Notes Both operands are treated as unsigned quantities. If the second operand is zero, the C flag cannot set. It is meaningful to check the following condition code mask (M1) after a logical comparison: | Mask | True/False* | Inference | | | |------|--------------|---------------------------------------------------|--|--| | 2 | False | First operand not greater than second | | | | 2 | True | First operand greater than second | | | | 3 | False | First operand equal to second | | | | 3 | True | First operand not equal to second | | | | 8 | <b>False</b> | First operand greater than or | | | | 8 | True | equal to second<br>First operand less than second | | | <sup>\*</sup>Refer to Chapter 4 for True/False concept in branch instructions. 3.5.19 AND (N, NR, NI) AND (N) AND Register (NR) AND Immediate (NI) | Ass | embler Notation | Op-Code | Format | | |-----|------------------|---------|---------|--| | N | R1,D2(X2) | 54 | RX1,RX2 | | | N | R1, A2(FX2, SX2) | 54 | RX3 | | | NR | R1,R2 | 04 | RR | | | ΝI | R1,12(X2) | F 4 | RI2 | | # Operation The logical product of the 32-bit second operand and the contents of the register specified by R1 replace the contents of the register specified by R1. The 32-bit logical product is formed on a bit-by-bit basis. # Condition Code | _ | • | - | L | | |---|---|---|-------|--------------------| | 0 | 0 | 0 | 0 | Result is zero | | 0 | 0 | 0 | 1 | Result is not zero | | 0 | 0 | 1 | 0 1 0 | Result is not zero | # Programming Notes In the RX formats, the second operand must be located on a fullword boundary. # 3.5.20 AND Halfword (NH, NHI) AND Halfword (NH) AND Halfword Immediate (NHI) | Asse | mbler Notation | <u>Op-Code</u> | Format | | |------|----------------|----------------|---------|--| | N H | R1,D2(X2) | 44 | RX1,RX2 | | | NH | R1,A2(FX2,SX2) | 44 | RX3 | | | NHI | R1, I2(X2) | C 4 | RI1 | | ## Operation The halfword second operand is expanded to a fullword by propagating the most significant bit through bits 0:15. The logical product of this 32-bit quantity and the contents of the register specified by R1 replace the contents of the register specified by R1. The 32-bit logical product is formed on a bit-by-bit basis. #### Condition Code | | | G | | | |---|---|-------------|---|--------------------| | 0 | 0 | 0<br>0<br>1 | 0 | Result is zero | | 0 | 0 | 0 | 1 | Result is not zero | | 0 | 0 | 1 | 0 | Result is not zero | #### Programming Notes In the RX formats, the second operand must be located on a halfword boundary. In the RI1 format, the 16-bit I2 field is extended to a fullword by propagating the sign bit through bits 0:15. The contents of the index register specified by X2 are then added to form the fullword second operand. 3.5.21 OR (0, OR, OI) OR (O) OR Register (OR) OR Immediate (OI) | Ass | embler Notation | Op-Code | Format | | |-----|-----------------|---------|---------|--| | 0 | R1,D2(X2) | 56 | RX1,RX2 | | | 0 | R1, A2(FX2,SX2) | 56 | RX3 | | | OR | R1,R2 | 06 | RR | | | OI | R1,I2(X2) | F6 | RI2 | | #### Operation The logical sum of the 32-bit second operand and the contents of the register specified by R1 replace the contents of the register specified by R1. The 32-bit logical sum is formed on a bit-by-bit basis. # Condition Code | С | V | G | L | • | |---|---|-------------|---|--------------------| | 0 | 0 | 0 | 0 | Result is zero | | 0 | 0 | 0 | 1 | Result is not zero | | 0 | 0 | 0<br>0<br>1 | 0 | Result is not zero | # Programming Notes In the RX formats, the second operand must be located on a fullword boundary. 3.5.22 OR Halfword (OH, OHI) OR Halfword (OH) OR Halfword Immediate (OHI) | Asse | mbler Notation | Op-Code | <b>Format</b> | | |------|------------------|---------|---------------|--| | ОН | R1,D2(X2) | 46 | RX1,RX2 | | | ОН | R1, A2(FX2, SX2) | 46 | RX3 | | | OHI | R1,I2(X2) | C6 | RI1 | | #### Operation The halfword second operand is expanded to a fullword by propagating the most significant bit through bits 0:15. The logical sum of this 32-bit quantity and the contents of the register specified by R1 replace the contents of the register specified by R1. The 32-bit logical sum is formed on a bit-by-bit basis. #### Condition Code | С | V | G | L | | |---|---|-------|---|--------------------| | 0 | 0 | 0 0 1 | 0 | Result is zero | | 0 | 0 | 0 | 1 | Result is not zero | | 0 | 0 | 1 | 0 | Result is not zero | ## Programming Notes In the RX formats, the second operand must be located on a halfword boundary. In the RI1 format, the 16-bit I2 field is extended to a fullword by propagating the sign bit through bits 0:15. The contents of the index register specified by X2 are then added to form the fullword second operand. # 3.5.23 Exclusive OR (X, XR, XI) Exclusive OR (X) Exclusive OR Register (XR) Exclusive OR Immediate (XI) | Ass | embler Notation | Op-Code | Format | |-----|------------------|---------|---------| | X | R1,D2(X2) | 57 | RX1,RX2 | | X | R1, A2(FX2, SX2) | 57 | RX 3 | | ΧR | R1,R2 | 07 | RR | | XΙ | R1,I2(X2) | F7 | RI2 | # Operation The logical difference of the 32-bit second operand and the contents of the register specified by R1 replace the contents of the register specified by R1. The 32-bit logical difference is formed on a bit-by-bit basis. # Condition Code | C | | | | | |-------|---|---|---|--------------------| | 0 | 0 | 0 | 0 | Result is zero | | 0 0 0 | 0 | 0 | 1 | Result is not zero | | 0 | 0 | 1 | 0 | Result is not zero | # Programming Notes In the RX formats, the second operand must be located on a fullword boundary. # 3.5.24 Exclusive OR Halfword (XH, XHI) Exclusive OR Halfword (XH) Exclusive OR Halfword Immediate (XHI) | Asset | mbler Notation | Op-Code | <b>Format</b> | | |-------|------------------|---------|---------------|--| | XН | R1,D2(X2) | 47 | RX1,RX2 | | | ХН | R1, A2(FX2, SX2) | 47 | R X 3 | | | XHI | R1, I2(X2) | C7 | RT1 | | ## Operation The halfword second operand is expanded to a fullword by propagating the most significant bit through bits 0:15. The logical difference of this 32-bit quantity and the contents of the register specified by R1 replace the contents of the register specified by R1. The 32-bit logical difference is formed on a bit-by-bit basis. # Condition Code | С | | | | | |-----|---|---|---|--------------------| | 0 | 0 | 0 | 0 | Result is zero | | 000 | 0 | 0 | 1 | Result is not zero | | 0 | 0 | 1 | 0 | Result is not zero | #### Programming Notes In the RX formats, the second operand must be located on a halfword boundary. In the RI1 format, the 16-bit I2 field is extended to a fullword by propagating the sign bit through bits 0:15. The contents of the index register specified by X2 are then added to form the fullword second operand. # 3.5.25 Test Immediate (TI) | Asse | embler Notation | Op-Code | Format | |------|-----------------|---------|--------| | TI | R1,I2(X2) | ĖЗ | RI2 | #### Operation Each bit of the second operand is logically ANDed with the corresponding bit in the register specified by R1. Neither operand is changed. # Condition Code | | | | | L | | | | | |---|---|---|---|-------|--------|----|------|------| | I | 0 | 0 | 0 | 0 | Result | is | zero | ) | | l | 0 | 0 | 0 | 1 | Result | is | not | zero | | I | 0 | 0 | 1 | 0 1 0 | Result | is | not | zero | ## Programming Notes When operating on fixed-point data, the condition code indicates zero (no flags), negative (L flag), or positive (G flag) result. This instruction works the same as the AND Immediate instruction (NI) except that the first operand is not changed. # Example: TI This example tests if bit 16 of register 9 is set. (REG9) = 7EFBC230 # Assembler Notation # Comments TI REG9,Y°00008000° BNZ LABEL Test bit 16 Branch if bit is set # Result of TI Instruction (REG9) Unchanged Condition Code = 0010 (G=1) The conditional branch is taken. ## 3.5.26 Test Halfword Immediate (THI) | Assem | bler Notation | Op-Code | <b>Format</b> | | |-------|---------------|---------|---------------|--| | THI | R1,I2(X2) | СЗ | RI1 | | #### Operation The halfword second operand is expanded to a fullword by propagating the most significant bit through bits 0:15. Each bit in this quantity is logically ANDed with the corresponding bit contained in the register specified by R1. Neither operand is changed. #### Condition Code | С | l V | G | L | | | | | |-----|-----|---|---|--------|----|------|------| | 0 | 0 | 0 | 0 | Result | is | zero | • | | 0 | 0 | 0 | 1 | Result | is | not | zero | | 0 0 | 0 | 1 | 0 | Result | is | not | zerc | #### Programming Notes When operating on fixed-point data, the condition code indicates zero (no flags), negative (I flag), or positive (G flag) result. In the RI1 format, the 16-bit I2 field is extended to a fullword by propagating the sign bit through bits 0:15. The contents of the index register specified by X2 are then added to form the fullword second operand. This instruction works the same as the AND Halfword Immediate instruction (NHI) except that the first operand is not changed. Example: THI This example tests if any of bits 0:16 of register 9 is set. (REG9) = 80800000 | Assembler Nota | tion | Comments | |----------------|------|----------| | | | | THI REG9, X°8000° Test bits 0:16 BNZ LABEL Branch if any set Result of THI Instruction (REG9) Unchanged Condition Code = 0001 (L=1) The conditional branch is taken. 3.5.27 Shift Left Logical (SLL, SLLS) Shift Left Logical (SLL) Shift Left Logical Short (SLLS) | Assemi | bler Notation | Op-Code | Format | | |--------|---------------|---------|--------|--| | SLL | R1,I2(X2) | ED | RI1 | | | SLLS | R1, N | 11 | SF | | #### Operation The first operand, the contents of the register specified by R1, is shifted left the number of places specified by the second operand. Bits shifted out of position 0 are shifted through the carry flag of the condition code and then lost. The last bit shifted remains in the carry flag. Zeros are shifted into position 31. # Condition Code | С | V | G | L | | |---|---|---|---|--------------------| | X | 0 | 0 | 0 | Result is zero | | X | 0 | 0 | 1 | Result is not zero | | Х | 0 | 1 | 0 | Result is not zero | | 1 | 0 | X | X | Carry | #### Programming Notes In the RI1 format, the shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31. In the SF format, the maximum shift count is 15. The state of the C flag indicates the state of the last bit shifted out of position 0. If the second operand specifies a shift of zero places, the condition code is set in accordance with the value contained in the register. The C flag is zero in this case. When the register specified by R1 contains fixed-point data, the L flag set indicates a negative result; the G flag set indicates a positive result. # 3.5.28 Shift Right Logical (SRL, SRLS) Shift Right Logical (SRL) Shift Right Logical Short (SRLS) | Asseml | bler Notation | Op-Code | <u>Format</u> | | |--------|---------------|---------|---------------|--| | SRL | R1,I2(X2) | EC | RI1 | | | SRLS | R1, N | 10 | SF | | #### Operation The first operand, the contents of the register specified by R1, is shifted right the number of places specified by the second operand. Bits shifted out of position 31 are shifted through the carry flag of the condition code and then lost. The last bit shifted remains in the carry flag. Zeros are shifted into position 0. #### Condition Code | С | V | G | L | | |---|---|-------------|---|--------------------| | X | 0 | 0 | 0 | Result is zero | | X | 0 | 0 | 1 | Result is not zero | | X | 0 | 1 | 0 | Result is not zero | | 1 | 0 | 0<br>1<br>X | Х | Carry | ## Programming Notes In the RI1 format, the shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31. In the SF format, the maximum shift count is 15. The state of the C flag indicates the state of the last bit shifted out of position 31. When the register specified by R1 contains fixed-point data, the L flag set indicates a negative result; the G flag set indicates a positive result. If the second operand specifies a shift of zero places, the condition code is set in accordance with the value contained in the register. The C flag is zero in this case. # 3.5.29 Shift Left Halfword Lcgical (SLHL, SLHLS) Shift Left Halfword Logical (SLHL) Shift Left Halfword Logical Short (SLHLS) | Assemb | ler Notation | Op-Code | Format | | |--------|--------------|---------|--------|--| | SLHL | R1,I2(X2) | CD | RI1 | | | SLHLS | R1,N | 91 | SF | | #### Operation Bits 16:31 of the register specified by R1 are shifted left the number of places specified by the second operand. Bits shifted out of position 16 are shifted through the carry flag and lost. The last bit shifted remains in the carry flag. Zeros are shifted into position 31. Bits 0:15 of the first operand remain unchanged. #### Condition Code | L | С | V | G | L | | | | |---|---|---|---|---|--------|----|----------| | | X | 0 | 0 | 0 | Result | is | zero | | I | X | 0 | 0 | 1 | Result | is | not zero | | 1 | X | 0 | 1 | 0 | | | not zero | | L | 1 | 0 | X | X | Carry | | | ## Programming Notes The condition code setting is based on the halfword (bits 16:31) result. In the RI1 format, the shift count is specified by the least significant four bits of the second operand. The maximum shift count is 15. In the SF format, the maximum shift count is 15. The state of the C flag indicates the state of the last bit shifted out of position 16. When the register specified by R1 contains fixed-point data, the L flag set indicates a negative result; the G flag set indicates a positive result. If the second operand specifies a shift of zero places, the condition code is set in accordance with the value contained in bits 16:31 of the register. The C flag is zero in this case. 3.5.30 Shift Right Halfword Logical (SRHL, SRHLS) Shift Right Halfword Logical (SRHL) Shift Right Halfword Logical Short (SRHLS) | Assemb | ler Notation | Op-Code | <b>Format</b> | | |--------|--------------|---------|---------------|--| | SRHL | R1,I2(X2) | СС | RI1 | | | SRHLS | R1,N | 90 | SF | | ## Operation Bits 16:31 of the register specified by R1 are shifted right the number of places specified by the second operand. Bits shifted out of position 31 are shifted through the carry flag and lost. The last bit shifted remains in the carry flag. Zeros are shifted into position 16. Bits 0:15 of the first operand remain unchanged. #### Condition Code | ſ | С | ٧ | G | L | | |---|---|---|---|---|--------------------| | ſ | X | 0 | 0 | 0 | Result is zero | | ١ | X | 0 | 0 | 1 | Result is not zero | | ļ | X | 0 | 1 | 0 | Result is not zero | | ١ | 1 | 0 | X | X | Carry | #### Programming Notes The condition code setting is based on the halfword (bits 16:31) result. In the RI1 format, the shift count is specified by the least significant four bits of the second operand. The maximum shift count is 15. In the SF format, the maximum shift count is 15. The state of the C flag indicates the state of the last bit shifted out of position 31. When the register specified by R1 contains fixed-point data, the L flag set indicates a negative result; the G flag set indicates a positive result. If the second operand specifies a shift of zero places, the condition code is set in accordance with the halfword value contained in bits 16:31 of the register. The C flag is zero in this case. # 3.5.31 Rotate Left Logical (RLL) | Assem | bler | Notation | Op-Code | <b>Format</b> | |-------|------|----------|---------|---------------| | RLL | R 1 | ,I2(X2) | EB | RI1 | #### Operation The 32-bit first operand, contained in the register specified by R1, is shifted left, end around, the number of positions specified by the second operand. Bits shifted out of position 0 are shifted into position 31. #### Condition Code | С | V | G | L | | | | | |---|---|---|-------------|--------|----|------|------| | 0 | 0 | 0 | 0 | Result | is | zero | ) | | 0 | 0 | 0 | 1 | Result | is | not | zero | | 0 | 0 | 1 | 0<br>1<br>0 | Result | is | not | zero | # Programming Notes The shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31. When the register specified by R1 contains fixed-point data, the L flag set indicates a negative result; the G flag set indicates a positive result. If the second operand specifies a shift of zero places, the condition code is set in accordance with the value contained in the register specified by R1. #### Example: RLL | 1. | Asse | embler Notation | Mach: | ine Code | Comments | | | |----|------|------------------------------------------|-------|----------|-----------------|--|--| | | | REG9, Y • 56789ABC •<br>REG9, X • 0004 • | | 56789ABC | (REG9)=56789ABC | | | #### Result of RLL Instruction (REG9) = 6789ABC5 Condition Code = 0010 (G=1) | 2• | Asse | mbler Notation | Machine Code | Comments | |----|-----------|------------------|-----------------------------|-----------------| | | LI<br>RLL | REG9,Y'88880000' | F890 8888 0000<br>EB90 0003 | (REG9)=88880000 | #### Result of RLL Instruction (REG9) = 44400004 Condition Code = 0010 (G=1) # 3.5.32 Rotate Right Logical (RRL) | Assen | bler Notation | Op-Code | Format | |-------|---------------|---------|--------| | RRL | R1,I2(X2) | E A | RI1 | #### Operation The 32-bit first operand, contained in the register specified by R1, is shifted right, end around, the number of positions specified by the second operand. Bits shifted out of position 31 are shifted into position 0. ## Condition Code | _ | V | _ | . – | | | | | |---|-----|---|-----|--------|----|-----|----------| | 0 | 0 | 0 | 0 | Result | is | zer | <b>o</b> | | 0 | 000 | 0 | 1 | Result | is | not | zero | | 0 | 0 | 1 | 0 | Result | is | not | zero | # Programming Notes The shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31. When the register specified by R1 contains fixed-point data, the L flag set indicates a negative result; the G flag set indicates a positive result. If the second operand specifies a shift of zero places, the condition code is set in accordance with the value contained in the register specified by R1. ## Example: RRL | 1. | Asse | mbler Notation | Machine Code | | | Comments | | | |----|------|--------------------------------|--------------|--------------|------|----------|---|----------| | | | REG4,Y°12345678°<br>REG4,X°04° | | 1234<br>0004 | 5678 | (REG4) | = | 12345678 | #### Result of RRL Instruction (REG4) = 81234567Condition Code = 0001 (L=1) | 2. | Assembler Notation | | Machine | Code | <u>Comments</u> | | | |----|--------------------|-----------------------------|------------------------|------|-----------------|------------|--| | | LI | REG4,Y'00001111' REG4,X'01' | F840 0000<br>EA40 0001 | | (REG4) = | = 00001111 | | ## Result of RRL Operation (REG4) = '800000888' Condition Code = 0001 (L=1) # 3.5.33 Test and Set (TS) | Asse | mbler Notation | Op-Code | Format | |------|----------------|---------|---------| | TS | D2(X2) | - EO | RX1,RX2 | | TS | A2(FX2,SX2) | ΕO | RX3 | #### Operation The halfword operand is read from memory and, on the same cycle, written back with the most significant bit set. The other bits in the halfword are unchanged. On the read cycle, the most significant bit of the operand is tested. The condition code reflects the state of this bit at the time of the memory read. ## Condition Code | С | V | G | L | | | | | |---|---|---|--------|------------------|-----|----|------| | X | X | X | 0<br>1 | Most significant | bit | is | zero | | X | X | X | 1 | Most significant | bit | is | set | #### Programming Notes The second operand must be located on a halfword boundary. The TS instruction provides a mechanism for software synchronization and can be used in a single processor environment as follows: Two or more user tasks running under an operating system share a halfword. This halfword is located in a memory area referred to as Task Common. Each task can access the halfword using the TS instruction. The synchronization sequence may be as follows: - TASK 1 Sets the most significant bit using the TS instruction. - TASK 2 Senses the most significant bit using the TS instruction, sees that it is set, performs the necessary software synchronization, and then zeros the most significant bit of the halfword. The TS instruction can be used in a multiprocessor system as follows: two or more processors share a halfword. This halfword is located in a memory area referred to as Shared Memory. Each processor can access the halfword using the TS instruction. The synchronization sequence can be as explained for user tasks with the following slight difference: whereas TASK 1 and TASK 2 cannot access the halfword at the same (real) time, two processors can. The access is granted according to the relative priority of the two processors. The hardware ensures that no other accesses to the halfword are made during the execution of the TS instruction. # 3.5.34 Test Bit (TBT) | Assen | bler Notation | Op-Code | <b>Format</b> | |-------|------------------|---------|---------------| | TBT | R1,D2(X2) | 74 | RX1,RX2 | | TBT | R1, A2(FX2, SX2) | 74 | RX 3 | #### Operation The second operand address points to a bit array starting on a byte boundary. The value contained in the register specified by R1 is the bit displacement into the array. Bits in the array are counted from left to right starting with bit 0. The argument bit is located and tested. The test does not change the bit. #### Condition Code | С | V | G | L | | | | | |---|---|---|-----|--------|-----|----|------| | 0 | 0 | 0 | 0 0 | Tested | bit | is | zero | | 0 | 0 | 1 | 0 | Tested | bit | is | one | ## Programming Note For software compatibility with other processors, the bit array should start on a halfword boundary. # Example: TBT | Assem | bler Notation | Machine Code | Comments | |-------|---------------|--------------|--------------------------------------------------------------------------------------------| | LIS | REG8,3 | 2483 | <pre>(REG8) = 3 LABEL = halfword in memory at location X*OBC4*. It contains X*B34A*.</pre> | | TBT | REG8,LABEL | 7480 OBC4 | | # Result of TBT Instruction Memory Location X'BC4' unchanged (REG8) unchanged Condition Code = 0010 (G=1)...Bit 3 of location X'BC4' is set. # 3.5.35 Set Bit (SBT) | Assemb | 1er Notation | Op-Code | Format | |--------|----------------|---------|---------| | SBT | R1,D2(X2) | 75 | RX1,RX2 | | SBT | R1,A2(FX2,SX2) | 75 | RX3 | # Operation The second operand address points to a bit array starting on a byte boundary. The value contained in the register specified by R1 is the bit displacement into the array. Bits in the array are counted from left to right starting with bit 0. The argument bit is located and set to one. #### Condition Code | j | С | V | G | L | | | | | | | |---|---|---|---|---|----------|-------|----|-----|-----|------| | | 0 | 0 | 0 | 0 | Previcus | state | of | bit | was | zero | | | 0 | 0 | 1 | 0 | Previous | state | of | bit | was | one | # Programming Note For software compatibility with other processors, the bit array should start on a halfword boundary. # Example: SBT | Assem | bler Notation | Machine Code | <u>Comments</u> | | | |-------|---------------|--------------|-----------------------------------------------------------|--|--| | LIS | REG5,8 | 2458 | (REG5) = 8 LABEL located at X'1520'. It contains X'2134'. | | | | SBT | REG5,LABEL | 7550 1520 | | | | # Result of SBT Instruction Contents of LABEL = 21B4 (REG5) unchanged Condition Code = 0000 (G=0) #### 3.5.36 Reset Bit (RBT) | Assem | bler Notation | Op-Code | <b>Format</b> | |-------|-------------------|---------|---------------| | RBT | R1,D2(X2) | 76 | RX1,RX2 | | RBT | R1, A2 (FX2, SX2) | 76 | RX3 | # Operation The second operand address points to a bit array starting on a byte boundary. The value contained in the register specified by R1 is the bit displacement into the array. Bits in the array are counted from left to right starting with bit zero. The argument bit is located and forced to zero (reset). # Condition Code | С | V | G | L | | | | | | | |---|---|---|---|----------|-------|----|-----|-----|------| | 0 | 0 | 0 | 0 | Previcus | state | of | bit | was | zero | | 0 | 0 | 0 | 0 | Previcus | state | of | bit | was | one | #### Programming Note For software compatibility with other processors, the bit array should start on a halfword boundary. #### Example: RBT | Assem | bler Notation | Machine Code | Comments | | |-------|---------------|--------------|--------------------------------------------|--| | LIS | REG2,3 | 2423 | (REG2) = 3 | | | RBT | REG2, LABEL | 7620 1A42 | LABEL located at X'1A42' contains X'3143'. | | ## Result of RBT Instruction Contents of LABEL = 2143 (REG2) unchanged Condition Code = 0010 (G=1) # 3.5.37 Complement Bit (CBT) | Assem | bler Notation | Op-Code | Format | |-------|------------------|---------|---------| | CBT | R1,D2(X2) | 77 | RX1,RX2 | | CBT | R1, A2(FX2, SX2) | 77 | RX3 | #### Operation The second operand address points to a bit array starting on a byte boundary. The value contained in the register specified by R1 is the bit displacement into the array. Bits in the array are counted from left to right starting with bit 0. The argument bit is located and complemented. ## Condition Code | С | V | G | L | | |---|---|---|---|--------------------------------| | 0 | 0 | 0 | 0 | Previous state of bit was zero | | 0 | 0 | 1 | 0 | Previous state of bit was one | #### Programming Note For software compatibility with other processors, the bit array should start on a halfword boundary. ## Example: CBT | Assem | bler Notation | Machine Code | <u>Comments</u> | | | |-------|----------------------|-------------------|----------------------------------------------------------|--|--| | LIS | REG9,3<br>REG9,LABEL | 2493<br>7790 OC4A | (REG9) = 3 LABEL located at X'C4A'. It contains X'2813'. | | | # Result of CBT Instruction Contents of LABEL = 3813 (REG9) unchanged Condition Code = 0000 (G=0) ## 3.5.38 Cyclic Redundancy Check Cyclic Redundancy Check Modulo 12 (CRC12) Cyclic Redundancy Check Modulo 16 (CRC16) | Assemb1 | er Notation | Op-Code | <b>Format</b> | |---------|------------------|------------|---------------| | CRC12 | R1, D2(X2) | 5 E | RX1,RX2 | | CRC12 | R1, A2(FX2, SX2) | 5 E | RX3 | | CRC16 | R1,D2(X2) | 5 <b>F</b> | RX1,RX2 | | CRC16 | R1, A2(FX2, SX2) | 5 <b>F</b> | RX3 | #### Operation These instructions are used to generate either a 12-bit or a 16-bit Cyclic Redundancy Check (CRC) residual halfword. The register specified by R1 contains, in bits 24:31, the data character to be included in the CRC residual. The second operand is the accumulated (old) CRC residual. The polynomial used for the 12-bit CRC generation is: $$X^{12} + X^{11} + X^3 + X^2 + X + 1$$ The polynomial used for the 16-bit CRC generation is: $$X^{16} + X^{15} + X^{2} + 1$$ The halfword second operand is replaced by the generated CRC residual. Condition Code Unchanged Programming Notes The register specified by R1 remains unchanged. The second operand must be located on a halfword boundary. Figure 3-6 illustrates a flowchart for CRC generation. # **CRC12 ALGORITHM SHOWN** FOR CRC 16 ALGORITHM, USE: R1 24:31 INSTEAD OF R126:31 IN STEP 1 8 INSTEAD OF 6 IN STEP 2 X'A001' INSTEAD OF X'0F01' IN STEP 4 Figure 3-6 Flowchart for CRC Generation # 3.5.39 Translate (TLATE) | Assemb1 | er Notation | Op-Code | <u>Format</u> | | |---------|------------------|------------|---------------|--| | TLATE | R1,D2(X2) | E7 | RX1,RX2 | | | TLATE | R1, A2(FX2, SX2) | E <b>7</b> | RX3 | | # Operation The least significant eight bits (bits 24:31) of the register specified by R1 contain the character to be translated. The fullword location specified by the second operand address contains the address of a translation table. The table is made up of 256 halfwords. The character contained in the register specified by R1 is used as an index into the table. If bit 0 of the table entry corresponding to the index character is one, bits 8:15 of the table entry replace the index character, and the next sequential instruction is executed. If bit 0 of the table entry is zero, bits 1:15 of the table entry contain the address, divided by two, of a special character handling routine. In this case, no translation takes place. The address contained in bits 1:15 is shifted left by one (multiplied by two). This address replaces the current location counter, thereby effecting an unconditional branch to the special character handling routine. Translation of character string data may also be performed using the MVTU instruction. (See Chapter 7.) Condition Code Unchanged #### Programming Notes The second operand address must be located on a fullword boundary. | 0 | 7 | . 8 | 15 | | | |---|----------------|------------|------------|--|--| | | | TRANSLATED | | | | | 1 | | CHARI | CTER | | | | | <b>L</b> | | | | | | 0 | (CHAR.HANDLING | ROUTINE | ADDRESS)/2 | | | #### Example: TLATE This example illustrates the use of the TLATE instruction. The translation table must either be initialized or assembled to contain up to a total of 256 halfword entries. In this example, the table contains 2 entries: | <u>Label</u> | Assem | bler Notation | Comments | | | | |--------------|---------------------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|--|--|--| | | LHI<br>STH<br>LA<br>SRLS<br>STH | REG5, Xº8052º<br>REG5, TABLE<br>REG7, TRANLAB<br>REG7, 1<br>REG7, TABLE+4 | LOAD TABLE ENTRY INTO REGS PUT ENTRY INTO TABLE LOAD ANOTHER TABLE ENTRY DIVIDE BY 2 PUT ENTRY INTO TABLE | | | | | TABADR | DC | A(TABLE) | | | | | Alternatively, this table may be assembled with the proper constant values. The T type constant may be used to assemble subroutine addresses in the proper format. For example: | | ALIGN | 2 | |-------|-------|------------| | TABLE | EQU | * | | | DO | 256 | | | DC | H • O • | | | ORG | TABLE+4 | | | DC | T(TRANLAB) | | | ORG | TABLE+512 | Since a program is normally assembled as a relocatable program, the address of TRANLAB is not known, but for illustrative purposes assume the address of TRANLAB is X'864°. | | 0 | | | 15 | |----------------------|---|-----------|--------------|----| | TABLE+0<br>TABLE+2 | | T | T | | | TABLE+4 | 8 | 0 | 5 | 2 | | TABLE+6 TABLE+8 | | | <del> </del> | | | TABLE+10<br>TABLE+12 | 0 | 4 | 3 | 2 | | TABLE+508 | 7 | <br> <br> | | | At TABLE+10 is the address of TRANLAB divided by 2 (X\*864\*/2) Using this table, this example translates the character in register 2. | <u>Label</u> | Assemb1 | Comments | | | | | |--------------|--------------|-----------------------|--------|---|------|------| | | LIS<br>TLATE | REG2,2<br>REG2,TABADR | (REG2) | = | 0000 | 0002 | #### Result of TLATE Instruction (REG2) = 0000 0052 Condition Code unchanged The entry used = data at address of (2 times contents of REG2) + TABLE = data at address TABLE + 4 = X\*8052\* Since the first bit of the entry is 1, direct translation is used and the contents of REG2 are replaced by X'0000 0052'. 2. Using the table, the following example shows how the TLATE instruction can be used to branch to a special character handling routine: | <u>Label</u> | Ass | emble: | Notation | Comments | |--------------|------------|--------|-----------------------|--------------------| | | LIS<br>TLA | ΓE | REG5,5<br>REG5,TABADR | (REG5) = 0000 0005 | | | • | | | | | | • | | | | | | • | | | | | | • | | | | | | • | | | | | TRANLAB | LR | R6,E | ₹5 | THESE INSTRUCTIONS | | | LB | R3,0 | (R6) | OPERATE ON THE | | | • | | | SPECIAL CHARACTER. | | | • | | | | | | • | | | | | | | | | | | | • | | | | | | • | | | | | | • | | | | | | | | | | Result of TLATE Instruction (continued) (REG5) = 0000 0005 Condition Code unchanged Control is transferred to the subroutine at address TRANLAB (X°864°). The entry used = data at address of (2 times contents of REG5) + TABLE = data at address TABLE + A = X\*0432\* Since the first bit of the entry is 0, the entry is multiplied by 2, a transfer occurs to TRANLAB (at address X'864'), and the processor executes instructions from the new address. 3.5.40 Add To List (ATL, ABL) Add to Top of List (ATL) Add to Bottom of List (ABL) | Assem | bler Notation | Op-Code | Format | |-------|------------------|---------|---------| | ATL | R1,D2(X2) | 64 | RX1,RX2 | | ATL | R1, A2(FX2, SX2) | 64 | RX3 | | ABL | R1,D2(X2) | 65 | RX1.RX2 | | ABL | R1,A2(FX2,SX2) | 65 | RX3 | #### Operation The register specified by R1 contains the fullword element to be added to the list, which is located in memory at the address of the second operand. The number of slots used tally is compared with the number of slots in the list. If the number of slots used equals the number of slots in the list, an overflow condition exists. The element is not added to the list and the overflow flag in the condition code is set. If the number of slots used tally is less than the number of slots in the list, it is incremented by one, the appropriate pointer is changed, and the element is added to the list. (Refer to Figure 3-4.) #### Condition Code | С | V | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 1 | 0 | 0 | Element added successfully List overflow ## Programming Notes These instructions manipulate circular lists as described in the introduction to this chapter. The second operand location must be on a fullword boundary. The ATL instruction manipulates the current top pointer in the list. If no overflow occurs, the current top pointer, which points to the last element added to the top of the list, is decremented by one. The element is inserted in the slot pointed to by the new current top pointer. If the current top pointer was zero on entering this instruction, the current top pointer is set to the maximum slot number in the list. This condition is referred to as list wrap. The ABL instruction manipulates the next bottom pointer. If no overflow occurs, the element is inserted in the slot pointed to by the next bottom pointer, and the next bottom pointer is incremented by one. If the incremented next bottom pointer is greater than the maximum slot number in the list, the next bottom pointer is set to zero. This condition is referred to as list wrap. For the nonoverflow situation, pointer halfwords in the list header are not manipulated until after the element has been successfully added. This facilitates error recovery in the event of a memory fault. See examples in the next section. # 3.5.41 Remove From List (RTL, RBL) Remove from Top of List (RTL) Remove from Bottom of List (RBL) | Assem | bler Notation | Op-Code | Format | |-------|------------------|---------|---------| | RTL | R1,D2(X2) | 66 | RX1,RX2 | | RTL | R1, A2(FX2,SX2) | 66 | RX3 | | RBL | R1,D2(X2) | 67 | RX1,RX2 | | RBL | R1, A2(FX2, SX2) | 67 | RX3 | #### Operation The element removed from the list replaces the contents of the register specified by R1. The list is located at the address of the second operand. If, at the start of the instruction execution, the number of slots used tally is zero, then the list is already empty and the instruction terminates with the overflow flag set in the condition code. This condition is referred to as list underflow; in this case, R1 is undefined. If underflow does not occur, the appropriate pointer is changed, the element is extracted and placed in the register specified by R1, and the number of slots used tally is decremented by one. #### Condition Code | C | V | G | L | | |-------|---|---|---|------------------------| | 0 | 0 | 0 | 0 | List now empty | | 0 | 0 | 1 | 0 | List is not yet empty | | 0 0 0 | 1 | 0 | 0 | List was already empty | #### Programming Notes These instructions manipulate circular lists as described in the introduction to this chapter. The second operand location must be on a fullword boundary. In the case of list underflow, the contents of the register specified by R1 are unchanged. The RTL instruction manipulates the current top pointer. If no underflow occurs, the current top pointer points to the element to be extracted. The element is extracted and placed in the register specified by R1. The current top pointer is incremented by one and compared to the maximum slot number. If the current top pointer is greater than the maximum slot number, the current top pointer is set to zero. This condition is referred to as list wrap. The RBL instruction manipulates the next bottom pointer. If no underflow occurs, and the next bottom pointer is zero, it is set to the maximum slot number (list wrap); otherwise, it is decremented by one, and the element now pointed to is extracted and placed in the register specified by R1. For the nonunderflow situation, pointer halfwords in the list header are not manipulated until after the element has been successfully removed. The register specified by R1 is not modified until the header has been updated. This facilitates error recovery in the event of a memory fault. Examples: List Instructions (ATL, ABL, RTL, RBL) The following are examples of the use of the four list processing instructions. The original list is normally set up as shown in Figure 3-7. | 590 | | | 1 | | | | |--------|------|-------|-----|-----------|-----|---------------------| | LIST | 0005 | 0000 | WH | HERE HALF | WOR | DS AT | | | 0000 | 0000 | LIS | ST : | = | MAXIMUM # OF SLOTS | | SLOT 0 | UNDE | FINED | | : | = | 5 (IN THIS EXAMPLE) | | SLOT 1 | UNDE | FINED | LI | ST + 2 | = | # OF ENTRIES USED | | SLOT 2 | UNDE | FINED | | : | = | 0 | | SLOT 3 | UNDE | FINED | LI | ST + 4 | = | CURRENT TOP OF LIST | | SLOT 4 | UNDE | FINED | · | : | = | SLOT 0 | | | | | LI | ST + 6 | = | NEXT BOTTOM OF LIST | | | | | • | : | = | SLOT 0 | Figure 3-7 List Processing Instructions | Asser | mbler Notation | Results and Comments | |-------|----------------|----------------------------------------| | LIS | REGO,O | | | STH | REGO, LIST+2 | INITIALIZE NUMBER OF ENTRIES USED TO 0 | | ST | REGO, LIST+4 | INITIALIZE POINTERS TO O | | LIS | REG1,1 | REGISTERS 1 THROUGH 6 CONTAIN | | LIS | REG2,2 | 1 THROUGH 6 RESPECTIVELY | | LIS | REG3,3 | | | LIS | REG4,4 | | | LIS | REG5,5 | | | LIS | REG6,6 | | | STH | REG5, LIST | TOTAL NUMBER OF ENTRIES = 5 | | REF1 | ATL REG1, LIST | LIST | 0005 0001 | |------|----------------|------------|---------------------------------------------------------| | | | | 0004 0000 (List Wrap) | | | | SLOT 0 | UNDEFINED | | | | SLOT 1 | UNDEFINED | | | | SLOT 2 | UNDEFINED | | | | SLOT 3 | UNDEFINED | | | | SLOT 4 | 0000 0001 | | | | Current To | Code = 0000<br>p Pointer = Slot 4<br>m Pointer = Slot 0 | | REF2 | ATL REG2, LIST | LIST | 0005 0002 | | | | e e | 0003 0000 | | | | SLOT 0 | UNDEFINED | | | | SLOT 1 | UNDEFINED | | | | SLOT 2 | UNDEFINED | | | | SLOT 3 | 0000 0002 | | | | SLOT 4 | 0000 0001 | | | | Condition | Code = 0000 | | REF3 | ATL REG3, LIST | LIST | 0005 0003 | | |------|----------------|--------|-----------|--| | | | | 0002 0000 | | | | | SLOT 0 | UNDEFINED | | | | | SLOT 1 | UNDEFINED | | | | | SLOT 2 | 0000 0003 | | | | | SLOT 3 | 0000 0002 | | | | | SLOT 4 | 0000 0001 | | Condition Code = 0000 Current Top Pointer = Slot 2 Next Bottom Pointer = Slot 0 | REF4 | ABL | REG4, LIST | LIS | ST | 0005 | 0004 | |------|-----|------------|------|----|------|-------| | | | | | | 0002 | 0001 | | | | | SLOT | 0 | 0000 | 0004 | | | | | SLOT | 1 | UNDE | FINED | | | | | SLOT | 2 | 0000 | 0003 | | | | | SLOT | 3 | 0000 | 0002 | | | | | SLOT | 4 | 0000 | 0001 | Condition Code = 0000 Current Top Pointer = Slot 2 Next Bottom Pointer = Slot 1 | REF5 | ABL | REG5, LIST | LIS | ST | 0005 | 0005 | |------|-----|------------|------|----|-------|------| | | | | | | 0002 | 0002 | | | | | SLOT | 0 | 0000 | 0004 | | | | | SLOT | 1 | 0000 | 0005 | | | | | SLOT | 2 | 0000 | 0003 | | | | , | SLOT | 3 | 00.00 | 0002 | | | | | SLOT | 4 | 0000 | 0001 | | | | | | | | | Condition Code = 0000 Current Top Pointer = Slot 2 Next Bottom Pointer = Slot 2 | REF6 | ABL | REG6, LIST | LIST | 0005 | 0005 | |------|-----|------------|--------|------|------| | | | | | 0002 | 0002 | | | | | SLOT 0 | 0000 | 0004 | | | | | SLOT 1 | 0000 | 0005 | | | | | SLOT 2 | 0000 | 0003 | | | | | SLOT 3 | 0000 | 0002 | | | | | SLOT 4 | 0000 | 0001 | Condition Code = 0100 (List overflow) Current Top Pointer = Slot 2 Next Bottom Pointer = Slot 2 | REF7 | RTL REG7, LIST | LIST | 0005 | 0004 | |------|----------------|----------|------|-------| | | | | 0003 | 0002 | | | | SLOT 0 | 0000 | 0004 | | | | SLOT 1 | 0000 | 0005 | | | | SLOT 2 X | 0000 | 0003. | | | | SLOT 3 | 0000 | 0002 | | | | SLOT 4 | 0000 | 0001 | (REG7) = 0000 0003 Condition Code = 0010 Current Top Pointer = Slot 3 Next Bottom Pointer = Slot 2 | REF8 | RBL | REG8, LIST | LIS | ST | | 0005 | 0003 | |------|-----|------------|------|----|---|------|------| | | | | | | | 0003 | 0001 | | | | | SLOT | 0 | | 0000 | 0004 | | | | | SLOT | 1 | X | 0000 | 0005 | | | | | SLOT | 2 | X | 0000 | 0003 | | | | | SLOT | 3 | | 0000 | 0002 | | | | | SLOT | 4 | | 0000 | 0001 | (REG8) = 0000 0005 Condition Code = 0010 Current Top Pointer = Slot 3 Next Bottom Pointer = Slot 1 ### NOTE X equals entry removed from list, and is not accessible through further manipulation by list instructions. | REF9 | RTL | REG9, LIST | LIS | T | | 0005 | 0002 | |------|-----|------------|------|---|---|------|------| | | | | | | | 0004 | 0001 | | | | | SLOT | 0 | | 0000 | 0004 | | | | | SLOT | 1 | X | 0000 | 0005 | | | | | SLOT | 2 | X | 0000 | 0003 | | | | | SLOT | 3 | X | 0000 | 0002 | | | | | SLOT | 4 | | 0000 | 0001 | (REG9) = 0000 0002 Condition Code = 0010 Current Top Pointer = Slot 4 Next Bottom Pointer = Slot 1 | REF 10 | RBL | REG10,LIST | LIS | ST | | 0005 | 0001 | |--------|-----|------------|------|----|---|------|------| | | | | | | | 0004 | 0000 | | | | | SLOT | 0 | X | 0000 | 0004 | | • | | | SLOT | 1 | X | 0000 | 0005 | | | | | SLOT | 2 | X | 0000 | 0003 | | | | | SLOT | 3 | X | 0000 | 0002 | | | | | SLOT | 4 | | 0000 | 0001 | (REG10) = 0000 0004 Condition Code = 0010 Current Top Pointer = 4 Next Bottom Pointer = 0 ### NOTE X equals entry removed from list, and is not accessible through further manipulation by list instructions. | REF11 | RTL | REG11,LIST | LIS | ST | | 0005 | 0000 | |-------|-----|------------|------|----|---|------|------| | | | | | | | 0000 | 0000 | | | | | SLOT | 0 | X | 0000 | 0004 | | | | | SLOT | 1 | X | 0000 | 0005 | | | | | SLOT | 2 | X | 0000 | 0003 | | | | | SLOT | 3 | X | 0000 | 0002 | | | | | SLOT | 4 | X | 0000 | 0001 | (REG11) = 0000 0001 Condition Code = 0000 (List is now empty) Current Top Pointer = 0 Next Bottom Pointer = 0 | REF12 | RTL | REG12, LIST | LIS | ST | | 0005 | 0000 | | |-------|-----|-------------|------|----|---|------|-------|--| | | | | | | | 0000 | 0000 | | | | | | SLOT | 0 | X | 0000 | 0004 | | | | | | SLOT | 1 | X | 0000 | 0005 | | | | | | SLOT | 2 | X | 0000 | 0003 | | | | | | SLOT | 3 | X | 0000 | 0.002 | | | | | | SLOT | 4 | X | 0000 | 0001 | | (REG12) = UNDEFINED Condition Code = 0100 (List was Current Top Pointer = 0 already empty) Next Bottom Pointer = 0 # NOTE X equals entry removed from list, and is not accessible through further manipulation by list instructions. ### CHAPTER 4 BRANCHING #### 4.1 INTRODUCTION In normal operations, the processor executes instructions in sequential order. The branch instructions allow this sequential mode of operation to be varied, so that programs can loop, transfer control to subroutines, or make decisions based on the results of previous operations. ### 4.2 OPERATIONS The second operand of a branch instruction is the address of the memory location to which control is transferred. The address may be contained in a register or it may be specified in the instruction as the second operand address or as a displacement. ### 4.2.1 Decision Making The conditional branch instructions permit the program to make decisions based on some result. In these instructions, the R1 field contains a 4-bit mask, M1, which is tested by ANDing it with the condition code. The result of the test determines whether the branch is taken, or the next sequential instruction is executed. The following examples show previous condition code, mask specified in a branch instruction, and the result of the test on which the branch or no branch decision is made. | Condition<br>Code | Mask(M1) | Result<br>of Test | (True/<br>False) | Branch<br>True<br>Taken | Branch<br>False<br>Taken | |-------------------|----------|-------------------|------------------|-------------------------|--------------------------| | 0000 | 0010 | 0000 | (False) | No | Yes | | 0001 | 1010 | 0000 | (False) | No | Yes | | 1001 | 1000 | 1000 | (True) | Yes | No | | 0100 | 0100 | 0100 | (True) | Yes | No | | 1010 | 0010 | 0010 | (True) | Yes | No | | 0010 | 0011 | 0010 | (True) | Yes | No | | 0010 | 0000 | 0000 | (False) | No | Yes | ### 4.2.2 Subroutine Linkage The branch and link instructions allow branching to subroutines in such a way that a return address is passed to the subroutine. For these instructions, the address of the memory location immediately following the branch instruction is saved in the register specified by R1. # 4.3 BRANCH INSTRUCTION FORMATS The branch instructions use the Register-to-Register (RR), the Short Form (SF), and the Register and Indexed Storage (RX) formats. # 4.4 BRANCH INSTRUCTIONS The instructions described in this section are: | BFC Bran | ch on Fals | se Condition | | |-----------|------------|----------------------------|---| | BFCR Bran | ch on Fals | se Condition Register | | | | ch on Fals | se Condition Backward Shor | t | | BFFS Bran | ch on Fals | se Condition Forward Short | | | | ch on True | e Condition | | | BTCR Bran | ch on True | Condition Register | | | | ch on True | Condition Backward Short | | | BTFS Bran | ch on True | Condition Forward Short | | | BAL Bran | ch and Lin | ık | | | BALR Bran | ch and Lin | k Register | | | BXLE Bran | ch on Inde | x Low or Equal | | | BXH Bran | ch on Inde | x High | | 4.4.1 Branch on True (BTC, BTCR, BTBS, BTFS) Branch on True Condition (BTC) Branch on True Condition Register (BTCR) Branch on True Condition Backward Short (BTBS) Branch on True Condition Forward Short (BTFS) | Assem | bler Notation | Op-Code | Format | |-------|-----------------|---------|---------| | ВТС | M1,D2(X2) | 42 | RX1,RX2 | | BTC | M1, A2(FX2,SX2) | 42 | RX3 | | BTCR | M1,R2 | 02 | RR | | BTBS | M 1 , N | 20 | SF | | BTFS | M 1 , N | 21 | SF | ### Operation The condition code of the Program Status Word (PSW) is tested for the conditions specified by the mask field, M1. If any conditions tested are found to be true, a branch is taken to the second operand location. If none of the conditions tested is found to be true, the next sequential instruction is executed. Condition Code Unchanged ### Programming Notes In the RR format, the branch address is contained in the register specified by R2. In the SF format, the N field contains the number of halfwords to be added to or subtracted from the current location counter to obtain the branch address. In the RR and RX formats, the branch address must be located on a halfword boundary. Example: BTC | Asser | Assembler Notation Machine Code | | Comments | | | |-------|---------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | LH | R1,X'100' | 4810 0100 | Load halfword (X°1234°) located at X'100°. Condition code is set to CVGL = 0010. Mask is 3, i.e., M1=0011. Perform logical AND between CVGL and M1, i.e., 0010 AND 0011. The result is 0010, i.e., true; therefore, a branch is taken to LOC. | | | | BTC | 3,LOC | 4230 ABCO | | | | 4.4.2 Branch on False (BFC, BFCR, BFBS, BFFS) Branch on False Condition (BFC) Branch on False Condition Register (BFCR) Branch on False Condition Backward Short (BFBS) Branch on False Condition Forward Short (BFFS) | Asseml | bler Notation | Op-Code | <b>Format</b> | |--------|------------------|---------|---------------| | BFC | M1,D2(X2) | 43 | RX1,RX2 | | BFC | M1, A2(FX2, SX2) | 43 | RX3 | | BFCR | M1,R2 | 03 | RR | | BFBS | M 1 , N | 22 | SF | | BFFS | M1,N | 23 | SF | ### Operation The condition code of the PSW is tested for the conditions specified in the mask field, M1. If all conditions tested are found to be false, a branch is taken to the second operand location. If any of the conditions tested is found to be true, the next sequential instruction is executed. Condition Code Unchanged ### Programming Notes In the RR format, the branch address is contained in the register specified by R2. In the SF format, the N field contains the number of halfwords to be added to or subtracted from the current location counter to obtain the branch address. In the RR and RX formats, the branch address must be located on a halfword boundary. Example: BFC | Assembler Notation | Machine Code | Comments | |-----------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LCS R1,2<br>BFC 9,LOC | 2512<br>4390 AECO | (R1) = FFFFFFFE. Condition code, CVGL = 0001 mask is 1001. Perform logical AND between mask and CVGL, i.e., 1001 AND 0001. The result is 0001, i.e., true; therefore, a branch is not taken to LOC. | # 4.4.3 Branch and Link (BAL, BALR) Branch and Link (BAL) Branch and Link Register (BALR) | Assemi | bler Notation | Op-Code | Format | |--------|-------------------|---------|---------| | BAL | R1,D2(X2) | 41 | RX1,RX2 | | BAL | R1, A2 (FX2, SX2) | 41 | RX3 | | BALR | R1,R2 | 01 | RR | ### Operation The address of the next sequential instruction is saved in the register specified by R1, and a branch is taken to the second operand address. Condition Code Unchanged ### Programming Notes The second operand location must be on a halfword boundary. The branch address is calculated before the register specified by R1 is changed. R1 may specify the same register as X2, FX2, SX2, or R2. ### Example: BAL The following example illustrates the use of the BAL instruction. This instruction causes control to be transferred to a subroutine called SUBROUT. After completion of the subroutine, the linking register is used to branch back to the next sequential instruction after the BAL; i.e., the instruction labeled RETURN. | | <u>Label</u> | Assembler Notation | Comments | |--------------|--------------|--------------------|-------------------------------------------------| | | BEGIN | BAL REG4, SUBROUT | TRANSFER TO SUBROUT | | MAIN | RETURN | XR R6,R6 | | | PROG | | STH R6, LAB+4 | | | | SUBROUT | LHL R8,LCC | THE RETURN ADDRESS OF THE SUBROUTINE IS IN REG4 | | SUBROUTINE - | | AHI R8,10 | | | | RTNEND | BR REG4 | RETURN TO XR INST. | # NOTE The linking register (REG4 in the example) should not be used within the subroutine. Result of BAL Instruction (REG4) = Address of instruction at SUBROUT Condition Code unchanged # 4.4.4 Branch on Index Low or Equal (BXLE) | Assemb | ler Notation | Op-Code | <b>Format</b> | | |--------|------------------|---------|---------------|--| | BXLE | R1,D2(X2) | C1 | RX1,RX2 | | | BXLE | R1, A2(FX2, SX2) | C1 | RX3 | | ### Set Up | • | 3 | 1 | |------|----------------------|---| | R 1 | Starting index value | 7 | | R1+1 | Increment value | ٦ | | R1+2 | Limit or final value | 7 | Before execution of this instruction, the register specified by R1 must contain a starting index value. The register specified by R1+1 must contain an increment value. The register specified by R1+2 must contain a comparand (limit or final value). All values may be signed. ### Operation Execution of this instruction causes the increment value to be added to the index value, creating a new index value. The result is compared logically to the limit or final value. If the new index value is less than or equal to the limit value, a branch is taken to the second operand location. If the new index value is greater than the limit value, the next sequential instruction is executed. Condition Code Unchanged #### Programming Notes The incremented index value replaces the contents of the register specified by R1. Any three consecutive registers of the same set may be used by this instruction as specified by R1. These registers may be 6, 7, 8; or 14, 15, 0; or 15, 0, 1, etc. The second operand location must be on a halfword boundary. The branch address is calculated before incrementing the starting index value contained in the register specified by R1. R1 may specify the same register as X2, FX2 or SX2. Example: BXLE Transfer 10 bytes in memory starting at the memory location labeled BUFO to the memory location labeled BUFO. | <u>Label</u> | Assembler Notation | | Comments | | |--------------|--------------------|----------------|-------------------------------|--| | | LIS | REG3,0 | (REG3)=STARTING INDEX VALUE=0 | | | | LIS | REG4,1 | (REG4)=INCREMENT VALUE | | | | LIS | R5,9 | (REG5)=FINAL VALUE=9 | | | AGAIN | LB | REGO, BUFO(R3) | (REGO)=1 BYTE FROM BUFO | | | | STB | REGO, BUF1(R1) | COPY 1 BYTE TO BUF1 | | | LABEL | BXLE | R3, AGAIN | IF (REG3)>(REG5), DONE | | | | • | | | | | | • | | | | | | • | | | | | BUFO | DS | 10 | | | | BUF1 | DS | 10 | | | Result of BXLE Instruction Code between the instructions labeled AGAIN and LABEL is executed ten times. Condition Code unchanged by BXLE instruction (REG3) = 0000000A (REG4) = 00000001 (REG5) = 00000009 ### 4.4.5 Branch on Index High (EXH) | Assem | bler Notation | Op-Code | Format | |-------|-----------------|---------|---------| | вхн | R1, D2(X2) | CO | RX1,RX2 | | BXH | R1, A2(FX2,SX2) | CO | RX 3 | #### Set Up | O | 31 | |------|----------------------| | R1 | Starting index value | | R1+1 | Increment value | | R1+2 | Limit or final value | Before execution of this instruction, the register specified by R1 must contain a starting index value. The register specified by R1+1 must contain an increment value. The register specified by R1+2 must contain a comparand (limit or final value). All values may be signed. ### Operation Execution of this instruction causes the increment value to be added to the index value, creating a new index value. The result is logically compared to the limit or final value. If the new index value is greater than the limit value, a branch is taken to the second operand location. If the new index value is less than or equal to the limit value, the next sequential instruction is executed. Condition Code Unchanged ### Programming Notes The incremented index value replaces the contents of the register specified by R1. Any three consecutive registers of the same set may be used by this instruction as specified by R1. These registers may be 6, 7, 8; 14, 15, 0; or 15, 0, 1, etc. The second operand location must be on a halfword boundary. The branch address is calculated before incrementing the starting index value contained in the register specified by R1. R1 may specify the same register as X2, FX2 or SX2. Example: BXH The following example shows how to set up a counter (1-9) using the BXH instruction: | <u>Label</u> | Assembler Notation | | Comment | | |--------------|-------------------------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--| | BEGIN | LIS<br>LIS<br>BXH<br>LH | REG1,1<br>REG2,1<br>REG3,9<br>REG1,LABEL<br>R6,CCUNT | (REG1)=0000 0001 (INDEX) (REG2)=0000 0001 (INCREMENT) (REG3)=0000 0009 (COMPARAND) COMPARE INDEX WITH COMPARAND | | | LABEL | •<br>B<br>LA<br>ST | BEGIN<br>R8,RTN<br>R8,MEM | BRANCH TO BXH INSTRUCTION EXIT FROM BXH | | Result of BXH Instruction Code between the instructions labeled BEGIN and LABEL is executed nine times. Condition Code Unchanged by BXH instruction (REG1) = 0000 000A (REG2) = 0000 0001 (REG3) = 0000 0009 # 4.5 EXTENDED BRANCH MNEMONICS The CAL assembler supports 47 extended branch mnemonics that generate the branch op-code (true or false conditional) and the condition code mask required. The programmer must supply the second operand address (symbolic or absolute). In the case of Short Format (SF) branch instructions, the second operand branch address must be within 15 halfwords of the current location counter. The CAL assembler determines the backward or forward relationship of the second operand address and generates the appropriate operation code. ### The instructions described in this section are: ``` BC Branch on Carry BCR Branch on Carry Register BCS Branch on Carry Short BNC Branch on No Carry BNCR Branch on No Carry Register BNCS Branch on No Carry Short BE Branch on Equal BER Branch on Equal Register BFS Branch on Equal Short BNE Branch on Not Equal BNER Branch on Not Equal Register BNES Branch on Not Equal Short B L Branch on Low BLR Branch on Low Register BLS Branch on Low Short BNL Branch on Not Low Branch on Not Low Register BNLR BNLS Branch on Not Low Short BM Branch on Minus BMR Branch on Minus Register BMS Branch on Minus Short BNM Branch on Not Minus Branch on Not Minus Register BNMR BNMS Branch on Not Minus Short BP Branch on Plus BPR Branch on Plus Register BPS Branch on Plus Short Branch on Not Plus BNP BNPR Branch on Not Plus Register BNPS Branch on Not Plus Short ``` 29-747 ROO 4/81 | BO | Branch on Overflow | |---------------|-------------------------------------------------------------------------------------| | BCR | Branch on Overflow Register | | BOS | Branch on Overflow Short | | BNO | Branch on No Overflow | | BNOR | Branch on No Overflow Register | | BNOS | Branch on No Overflow Short | | BZ | Branch on Zero | | BZR | Branch on Zero Register | | BZS | Branch on Zero Short | | BNZ | Branch on Not Zero | | BNZR | Branch on Not Zero Register | | BNZS | Branch on Not Zero Short | | B<br>BR<br>BS | Branch (Unconditional) Branch Register (Unconditional) Branch Short (Unconditional) | | NOP | No Operation | | NOPR | No Operation Register | # 4.5.1 Branch on Carry (BC, BCR, BCS) Branch on Carry (BC) Branch on Carry Register (BCR) Branch on Carry Short (BCS) | Assembler Notation | | Op-Code+M1 | <b>Format</b> | |--------------------|-------------|---------------|---------------| | ВС | D2(X2) | 428 | RX1,RX2 | | BC | A2(FX2,SX2) | 428 | RX3 | | BCR | R2 | 028 | RR | | BCS | λ | 208(Backward) | SF | | | | 218 (Forward) | | # Operation If the Carry (C) flag in the condition code is set, a branch is taken to the second operand location. If the C flag is zero, the next sequential instruction is executed. Condition Code Unchanged # Programming Notes The branch address must be located on a halfword boundary. In the RR format, the branch address is contained in the register specified by R2. Example: BCS | Assembler Notation | | Machine Code | Comments | | |--------------------|------|--------------|----------|------------------------------------------| | SHIFT | SLLS | R9,1 | 1191 | Register 9 is shifted | | | ECS | SHIFT | 2081 | left until the first zero bit is shifted | | | | | | out of position 0. | # 4.5.2 Branch on No Carry (BNC, BNCR, BNCS) Branch on No Carry (BNC) Branch on No Carry Register (ENCR) Branch on No Carry Short (BNCS) | Assembler Notation | | Op-Code+M1 | | Format | |--------------------|-------------|------------|------------|---------| | BNC | D2(X2) | 438 | | RX1,RX2 | | BNC | A2(FX2,SX2) | 438 | | RX3 | | BNCR | R2 | 038 | | RR | | BNCS | λ | 228 | (Backward) | SF | | | | 238 | (Forward) | | # Operation If the Carry (C) flag in the condition code is zero, a branch is taken to the second operand location. If the C flag is set, the next sequential instruction is executed. Condition Code Unchanged # Programming Notes The branch address must be located on a halfword boundary. # 4.5.3 Branch on Equal (BE, BER, BES) Branch on Equal (BE) Branch on Equal Register (BER) Branch on Equal Short (BES) | Assembler Notation | | Op-Code+M1 | Format | |--------------------|-------------|----------------|---------| | BE | D2(X2) | 433 | RX1,RX2 | | BE | A2(FX2,SX2) | 433 | RX3 | | BER | R2 | 033 | RR | | BES | λ | 223 (Backward) | SF | | | | 233 (Forward) | | ### Operation If the G flag and the L flag are both zero in the condition code, a branch is taken to the second operand location. If either flag is set, the next sequential instruction is executed. Condition Code Unchanged ### Programming Notes The branch address must be located on a halfword boundary. In the RR format, the branch address is contained in the register specified by R2. ### Example: BE | Assembler Notation | Machine Code | Comments | |---------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------| | CLHI R4,X°23°<br>BE CPTIN | C540 0023<br>4330 0A00 | If R4 contains X°23°, a branch is taken to location X°A00°. Otherwise, the next sequential instruction is executed. | # 4.5.4 Branch on Not Equal (BNE, BNER, BNES) Branch on Not Equal (BNE) Branch on Not Equal Register (BNER) Branch on Not Equal Short (ENES) | Assem | bler Notation | Op-Code+M1 | Format | |-------|---------------|----------------|---------| | BNE | D2(X2) | 423 | RX1,RX2 | | BNE | A2(FX2,SX2) | 423 | RX3 | | BNER | R2 | 023 | RR | | BNES | λ | 203 (Backward) | SF | | | | 213 (Forward) | | ### Operation If the G flag or the L flag is set in the condition code, a branch is taken to the second operand location. If both flags are zero, the next sequential instruction is executed. Condition Code Unchanged Programming Notes The branch address must be located on a halfword boundary. # 4.5.5 Branch on Low (BL, BLR, BLS) Branch on Low (BL) Branch on Low Register (BLR) Branch on Low Short (BLS) | Assembler Notation | | Op-Code+M1 | Format | |--------------------|-------------|----------------|---------| | BL | D2(X2) | 428 | RX1,RX2 | | BL | A2(FX2,SX2) | 428 | RX3 | | BLR | R2 | 028 | RR | | BLS | A | 208 (Backward) | SF | | | | 218 (Forward) | | ### Operation If the Carry (C) flag in the condition code is set, a branch is taken to the second operand address. If the C flag is zero, the next sequential instruction is executed. Condition Code Unchanged ### Programming Notes The branch address must be located on a halfword boundary. In the RR format, the branch address is contained in the register specified by R2. ### Example: BL | Assemb: | ler Notation | Machine Code | <u>Comments</u> | |---------|--------------|--------------|----------------------------------------------------------------------------------------------------------| | CLHI | R1,X'FF' | C510 00FF | (R1) is compared to X'00FF'. If (R1) is less than X'00FF', a branch is taken to memory location X'0A00'. | | BL | RESTART | 4280 0A00 | | 4.5.6 Branch on Not Low (BNL, BNLR, BNLS) Branch on Not Low (BNL) Branch on Not Low Register (BNLR) Branch on Not Low Short (BNLS) | Assembler Notation | | Op-Code+M1 | Format | | |--------------------|-------------|----------------|----------|--| | BNL | D2(X2) | 438 | RX1, RX2 | | | BNL | A2(FX2,SX2) | 438 | RX3 | | | BNLR | R2 | 0 38 | RR | | | BNLS | A | 228 (Backward) | SF | | | | | 238 (Forward) | | | ### Operation If the Carry (C) flag in the condition code is zero, a branch is taken to the second operand address. If the C flag is set, the next sequential instruction is executed. Condition Code Unchanged Programming Notes The branch address must be located on a halfword boundary. 4.5.7 Branch on Minus (BM, BMR, BMS) Branch on Minus (BM) Branch on Minus Register (BMR) Branch on Minus Short (BMS) | Assembler Notation | | Op-Code+M1 | <b>Format</b> | |--------------------|-------------|----------------|---------------| | BM | D2(X2) | 421 | RX1,RX2 | | BM | A2(FX2,SX2) | 421 | RX3 | | BMR | R 2 | 021 | RR | | BMS | λ | 201 (Backward) | SF | | | | 211 (Forward) | | ### Operation If the Less Than (L) flag in the condition code is set, a branch is taken to the second operand location. If the L flag is zero, the next sequential instruction is executed. Condition Code Unchanged Programming Notes The branch address must be located on a halfword boundary. In the RR format, the branch address is contained in the register specified by R2. Example: BM | Assembler Notation | | Machine Code | Comments | | |--------------------|----------|--------------|-----------------------------------------------------------------------------|--| | SIS | R3,1 | 2631 | If (R3) is less than 0 after the subtraction, a branch is taken to X'10A0'. | | | BM | CONTINUE | 4210 10A0 | | | # 4.5.8 Branch on Not Minus (BNM, BNMR, BNMS) Branch on Not Minus (BNM) Branch on Not Minus Register (BNMR) Branch on Not Minus Short (BNMS) | Assembler Notation | | Op-Code+M1 | Format | |--------------------|-------------|---------------------------------|---------| | BNM | D2(X2) | 431 | RX1,RX2 | | BNM | A2(FX2,SX2) | 431 | RX3 | | BNMR | R 2 | 031 | RR | | BNMS | λ | 221 (Packward)<br>231 (Forward) | SF | ### Operation If the Less Than (L) flag in the condition code is zero, a branch is taken to the second operand location. If the L flag is set, the next sequential instruction is executed. Condition Code Unchanged ### Programming Notes The branch address must be located on a halfword boundary. # 4.5.9 Branch on Plus (BP, BPR, BPS) Branch on Plus (BP) Branch on Plus Register (BPR) Branch on Plus Short (BPS) | Assembler Notation | | Op-Code+M1 | Format | |--------------------|-------------|----------------|---------| | BP | D2(X2) | 422 | RX1,RX2 | | ВP | A2(FX2,SX2) | 422 | RX3 | | BPR | R 2 | 022 | RR | | BPS | A | 202 (Backward) | SF | | | | 212 (Forward) | | ### Operation If the Greater Than (G) flag in the condition code is set, a branch is taken to the second operand location. If the G flag is zero, the next sequential instruction is executed. Condition Code Unchanged ### Programming Notes The branch address must be located on a halfword boundary. # 4.5.10 Branch on Not Plus (BNP, BNPR, BNPS) Branch on Not Plus (BNP) Branch on Not Plus Register (BNPR) Branch on Not Plus Short (BNPS) | Assembler Notation | | Op-Code+M1 | <b>Format</b> | | |----------------------------|-------------------------|-------------------------------------|----------------------------|--| | BNP<br>BNP<br>BNPR<br>BNPS | D2(X2) A2(FX2,SX2) R2 A | 432<br>432<br>032<br>222 (Backward) | RX1,RX2<br>RX3<br>RR<br>SF | | | | R 2<br>A | | ) | | ### Operation If the Greater Than (G) flag in the condition code is zero, a branch is taken to the second operand location. If the G flag is set, the next sequential instruction is executed. Condition Code Unchanged ### Programming Notes The branch address must be located on a halfword boundary. # 4.5.11 Branch on Overflow (BO, BOR, BOS) Branch on Overflow (BO) Branch on Overflow Register (ECR) Branch on Overflow Short (BOS) | Assembler Notation | | Op-Code+M1 | Format | |--------------------|-----------------------|---------------------------------|----------------| | BO<br>BO | D2(X2)<br>A2(FX2,SX2) | 424<br>424 | RX1,RX2<br>RX3 | | BOR | R2 | 024 | RR | | BOS | A | 204 (Backward)<br>214 (Forward) | SF | ### Operation If the Overflow (V) flag in the condition code is set, a branch is taken to the second operand location. If the V flag is zero, the next sequential instruction is executed. Condition Code Unchanged Programming Notes The branch address must be located on a halfword boundary. # 4.5.12 Branch on No Overflow (BNO, BNOR, BNOS) Branch on No Overflow (BNO) Branch on No Overflow Register (BNOR) Branch on No Overflow Short (BNOS) | Assembler Notation | | Op-Code+M1 | <b>Format</b> | | |--------------------|-----------------------|---------------------------------|----------------|--| | BNO<br>BNO | D2(X2)<br>A2(FX2,SX2) | 434<br>434 | RX1,RX2<br>RX3 | | | BNOR | R2 | 034 | RR | | | BNOS | λ | 224 (Backward)<br>234 (Forward) | SF | | #### Operation If the Overflow (V) flag in the condition code is zero, a branch is taken to the second operand location. If the V flag is set, the next sequential instruction is executed. Condition Code Unchanged ### Programming Notes The branch address must be located on a halfword boundary. 4.5.13 Branch on Zero (BZ, BZR, BZS) Branch on Zero (BZ) Branch on Zero Register (BZR) Branch on Zero Short (BZS) | Asse | mbler Notation | Op-Code+M1 | Format | |------------|----------------|----------------|---------| | B <b>Z</b> | D2(X2) | 433 | RX1,RX2 | | ΒZ | A2(FX2,SX2) | 433 | RX3 | | BZR | R2 | 033 | RR | | BZS | A | 223 (Packward) | SF | | | | 233 (Forward) | | ### Operation If the G and L flags are both zero in the condition code, a branch is taken to the second operand location. If the G or L flag is set, the next sequential instruction is executed. Condition Code Unchanged Programming Notes The branch address must be located on a halfword boundary. # 4.5.14 Branch on Not Zero (BNZ, BNZR, BNZS) Branch on Not Zero (BNZ) Branch on Not Zero Register (BNZR) Branch on Not Zero Short (BNZS) | Assembler Notation | | Op-Code+M1 | Format | |--------------------|-------------|----------------|---------| | BNZ | D2(X2) | 423 | RX1,RX2 | | BNZ | A2(FX2,SX2) | 423 | RX3 | | BNZR | R 2 | 023 | RR | | BNZS | A | 203 (Fackward) | SF | | | | 213 (Forward) | | # Operation If the G or L flag in the condition code is set, a branch is taken to the second operand address. If the G and L flags are both zero, the next sequential instruction is executed. ### Condition Code Unchanged # Programming Notes The branch address must be located on a halfword boundary. 4.5.15 Branch (Unconditional) (B, BR, BS) Branch (Unconditional) (B) Branch Register (Unconditional) (BR) Branch Short (Unconditional) (BS) | Assembler Notation | Op-Code+M1 | <b>Format</b> | | |-----------------------------------|------------------------------------------------------|----------------------------|--| | B D2(X2) B A2(FX2,SX2) BR R2 BS A | 430<br>430<br>030<br>220 (Backward)<br>230 (Forward) | RX1,RX2<br>RX3<br>RR<br>SF | | ### Operation A branch is unconditionally taken to the second operand address. Condition Code Unchanged Programming Notes The branch address must be located on a halfword boundary. In the RR format, the branch address is contained in the register specified by $\ensuremath{\text{R2}}_{\:\raisebox{1pt}{\text{\circle*{1.5}}}}$ This instruction is assembled as a Branch on False Condition instruction, with no condition specified (M1=0). Therefore, the branch test is always false and the branch is always taken. ### Example: B | Ass | embler Notation | Machine Code | Comments | |-----|-----------------|--------------|-------------------------------------------------------| | В | CFTIN | 4300 0100 | An unconditional branch is taken to location X'0A00'. | 4.5.16 No Operation (NOP, NOPR) No Operation (NOP) No Operation Register (NOPR) | Assembler Notation | | Op-Code+M1 | Format | |--------------------|-------------|------------|---------| | NOP | D2(X2) | 420 | RX1,RX2 | | NOP | A2(FX2,SX2) | 42C | RX3 | | NOPR | R 2 | 020 | RR | Operation The next sequential instruction is executed. Condition Code Unchanged Programming Notes D2(X2) or A2(FX2,SX2) and R2 are ignored and usually equal zero (0). This instruction is assembled as a Branch on True Condition instruction with no condition specified (M1=0); therefore, no branch is taken and the next instruction is fetched and executed. Example: NOP, NOPR | Assemble | r Notation | Machi | ine Co | <u>ode</u> | <u> </u> | Comments | |-----------|------------|----------------------|--------------|------------|----------|-------------------------------| | NOP ONOPR | (0,0) | 4200<br>4200<br>0200 | 4000<br>0000 | 0000 | No | operation operation operation | # CHAPTER 5 FIXED-POINT ARITHMETIC ### 5.1 INTRODUCTION Fixed-point arithmetic instructions provide a complete set of operations for calculating addresses and indices, for counting, and for general purpose fixed-point arithmetic. ### 5.2 FIXED-POINT DATA FORMATS There are three formats for fixed-point data: the halfword, the fullword, and the doubleword. In each of these formats, the most significant bit (bit 0) is the sign bit. The remaining 15, 31 or 63 bits represent the magnitude. (See Figure 5-1.) Figure 5-1 Fixed-Point Data Formats Positive values are represented in true binary form with a sign bit of zero. Negative values are represented in two's complement form with a sign bit of one. To change the sign of a number, the two's complement of the number may be produced by subtracting the number from zero. Another way would be to: - 1. Change all zeros to cnes, and all ones to zeros. - 2. Add one. ### 5.3 FIXED-POINT NUMBER RANGE Fixed-point numbers represent integers. Table 5-1 shows relations between different fcrmats, along with decimal values. TABLE 5-1 FIXED-POINT FORMAT RELATIONS 600 | DOUBLE WORD | FULLWORD | HALFWORD | DECIMAL | |----------------------------------------|-----------------------------|-----------------------|----------------------------| | 800000000000000<br>(MOST NEGATIVE) | | | -9 223 372 036 854 775 808 | | | 80000000<br>(MOST NEGATIVE) | | -2 147 483 648 | | | | 8000 (MOST NEGATIVE) | -32 768 | | FFFFFFFFFFFFF | FFFFFFF | FFFF (LEAST NEGATIVE) | <b>–1</b> | | 000000000000000 | 00000000 | 0000 | 0 | | 000000000000001 | 00000001 | 0001 (LEAST POSITIVE) | 1 | | | | 7FFF (MOST POSITIVE) | 32 767 | | · | 7FFFFFFF<br>(MOST POSITIVE) | | 2 147 483 647 | | 7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF | | | 9 223 372 036 854 775 807 | #### 5.4 OPERATIONS Fixed-point instructions include both fullword and halfword operations. Fullword operations take place (a) between the contents of two general registers; (b) between the contents of a general register and a fullword stored in memory; or (c) between the contents of a general register and a fullword obtained from the instruction stream. Fullword multiply produces a doubleword result which is contained in two adjacent registers. Fullword divide operates on doubleword data contained in two adjacent registers. Halfword operations take place between a fullword contained in one of the general registers and a halfword contained in memory. Before the operation is started, the halfword in memory is expanded to a fullword by propagating the most significant bit (sign bit) into the high order bits of the fullword. The halfword multiply and divide instructions are exceptions to this rule. #### 5.5 CONDITION CODE All fixed-point arithmetic instructions, except multiply and divide, affect the condition code to indicate the outcome of the operation on the 32-bit result. In fixed-point add and subtract operations, the arguments are represented in two's complement form; therefore, all bits, including sign, participate in forming the result. Consequently, the occurrence of a carry or borrow has no real arithmetic significance. For example, an add operation between a minus one (FFFF FFFF) and a plus two (0000 0002) produces the correct result of plus one (0000 0001) and a carry. The condition code is set to 1010 (C = 1 and G = 1). Carry means that the complete result, which in this case would have been 1 0000 0001, would not fit in 32 bits. An overflow occurs when the result does not fit in 31 bits. Note that bit zero must be reserved for the sign of the result. For example, adding one to the largest positive fixed-point value produces an overflow: 7FFF FFFF +0000 0001 =8000 0000 The resulting condition code is 0101 (V=1 and L=1). The result, 8000 0000, is logically correct, but because the sign bit is negative when the result should be positive, the overflow condition exists. The columns of the condition code table given for each instruction description show the state of the C, V, G and L flags for the possible results. An 'X' in a condition code column means that the particular flag is not defined, and may be either 0 or 1. Hence, no inference should be drawn by testing that particular flag. ### 5.6 FIXED-POINT INSTRUCTION FORMATS The fixed-point instructions use the Register to Register (RR), the Short Form (SF), the Register and Indexed Storage (RX), and the Register and Immediate (RI) instruction formats. # 5.7 FIXED-PCINT INSTRUCTIONS The fixed-point instructions described in this section are: ``` A Add AR Add Register AΙ Add Immediate AIS Add Immediate Short AΗ Add Halfword Add Halfword Immediate AHI Add to Memory A M AHM Add Halfword to Memory S Subtract SR Subtract Register Subtract Immediate SI Subtract Immediate Short SIS SH Subtract Halfword SHI Subtract Halfword Immediate С Compare CR Compare Register CI Compare Immediate CH Compare Halfword CHI Compare Halfword Immediate M Multiply MR Multiply Register ΜH Multiply Halfword MHR Multiply Halfword Register Divide DR Divide Register DH Divide Halfword DHR Divide Halfword Register SLA Shift Left Arithmetic Shift Left Halfword Arithmetic SLHA SRA Shift Right Arithmetic SRHA Shift Right Halfword Arithmetic CHVR Convert to Halfword Value Register ``` 5-4 5.7.1 Add (A, AR, AI, AIS) Add (A) Add Register (AR) Add Immediate (AI) Add Immediate Short (AIS) | Asse | mbler Notation | Op-Code | Format | |------|-----------------|---------|---------| | A | R1,D2(X2) | 5 A | RX1,RX2 | | A | R1, A2(FX2,SX2) | 5 À | RX3 | | AR | R1,R2 | OA | RR | | ΑI | R1,I2(X2) | FA | RI2 | | AIS | R 1 , N | 26 | SF | #### Operation The second operand is added algebraically to the contents of the register specified by R1. The result of this 32-bit addition replaces the contents of the register specified by R1. #### Condition Code | | С | V | G | L | | |---|---|---|---|---|-----------------------------| | i | X | 0 | 0 | 0 | Result is zero | | | X | 0 | 0 | 1 | Result is less than zero | | į | X | 0 | 1 | 0 | Result is greater than zero | | | X | 1 | X | X | Arithmetic overflow | | | 1 | X | X | X | Carry | #### Programming Notes The second operand for the AIS instruction is obtained by expanding the 4-bit data field, N, to a 32-bit fullword by forcing the high order bits to zero. In the RI2 format, the contents of the index register specified by X2 are added to the 32-bit I2 field to form the fullword second operand. In the RX formats the second operand must be located on a fullword boundary. Example: A Add contents of memory location labeled LAB to the contents of REG4. 1. REG4 contains X'7F341234' Fullword in memory at LAB contains X'7F124321' Assembler Notation Comments A REG4, LAB ADD (LAB) TO (REG4) Result of A Instruction (REG4) = X°FE465555° (LAB) unchanged by this instruction Condition Code = 0101 (V=1, L=1) 2. REG5 contains X'8000 0001' Fullword in memory at LAB contains X'80000002' Assembler Notation Comments A REG5, LAB ADD (LAE) TO (REG5) Result of A Instruction (REG5) = X°00000003° (LAB) unchanged by this instruction Condition Code = 1110 (C=1, V=1, G=1) ## 5.7.2 Add Halfword (AH, AHI) Add Halfword (AH) Add Halfword Immediate (AHI) | Asse | mbler Notation | Op-Code | Format | |------------|-----------------------------|------------|----------------| | A H<br>A H | R1,D2(X2)<br>R1,A2(FX2,SX2) | 4 A<br>4 A | RX1,RX2<br>RX3 | | AHI | R1,I2(X2) | CA | RI1 | #### Operation The 16-bit second operand is expanded to a 32-bit fullword by propagating the most significant bit through bits 0:15 of the fullword. The fullword operand is added to the fullword contents of the register specified by R1. The result replaces the contents of the register specified by R1. #### Condition Code | L | С | V | G | L | | |---|---|---|---|---|-----------------------------| | | X | 0 | 0 | 0 | Result is zero | | 1 | X | 0 | 0 | 1 | Result is less than zero | | 1 | X | 0 | 1 | 0 | Result is greater than zero | | | X | 1 | X | X | Arithmetic overflow | | L | 1 | X | X | X | Carry | #### Programming Notes In the RX formats, the second operand must be located on a halfword boundary. In the RI1 format, the 16-bit I2 field is extended to a fullword by propagating the sign bit through bits 0:15. The contents of the index register specified by X2 are then added to form the fullword second operand. Example: AH This example adds the halfword at memory location labeled LAB to the contents of register 4. 1. REG4 contains X°00230002° Halfword at memory location LAB contains X°FFFF° Assembler Notation Comments AH REG4, LAB ADD (LAB) TO (REG4) Result of AH Instruction (REG4) = X'00230001' (LAB) unchanged by this instruction Condition Code = 1010 (C=1, G=1) 2. REG5 contains X'FFFF FFF5' LAB contains X'FFF2' Assembler Notation Comments AH REG5, LAB ADD (LAB) TO (REG5) Result of AH Instruction (REG5) = 'FFFF FFE7' (LAB) unchanged by this instruction Condition Code = 1001 (C=1, L=1) ## 5.7.3 Add to Memory (AM) | Asse | embler Notation | Op-Code | Format | | |------|-----------------|---------|---------|--| | A M | R1,D2(X2) | 51 | RX1,RX2 | | | A M | R1,A2(FX2,SX2) | 51 | RX3 | | #### Operation The first operand contained in the register specified by R1 is added algebraically to the fullword second operand. The result replaces the fullword second operand in memory. The contents of the register specified by R1 are not changed. ## Condition Code | С | V | G | L | |---|---|---|--------| | X | 0 | 0 | 0 | | X | 0 | 0 | 1 | | X | 0 | 1 | 0<br>X | | Х | 1 | X | X | | 1 | X | X | X | Result is zero Result is less than zero Result is greater than zero Arithmetic overflow Carry #### Programming Note The second operand must be located on a fullword boundary. #### Example: AM 1. Add contents of register 8 to memory location labeled LOC: RFG8 contains X.00000008. Fullword in memory at LOC contains X.034289AB. | Asse | mbler Notation | Comments | | |------|----------------|--------------------|---| | A M | REG8, LOC | ADD (REG8) TO (LOC | ) | #### Result of AM Instruction (REG8) unchanged by this instruction (ICC) = X\*034289B3\* Condition Code = 0010 (G=1) 2. Add contents of register 7 to memory location labeled LOC: REG7 contains X'7F341234' Fullword in memory at LOC contains X'7F124321' Assembler Notation Comments AM REG7, LCC ADD (REG7) TO (LOC) #### Result of AM Instruction (REG7) unchanged by this instruction (LCC) = X°FE465555° Condition Code = 0101 (V=1, L=1) ## 5.7.4 Add Halfword to Memory (AHM) | Asser | mbler Notation | Op-Code | Format | | |-------|----------------|---------|---------|--| | AHM | R1,D2(X2) | 61 | RX1,RX2 | | | AHM | R1,A2(FX2,SX2) | 61 | RX3 | | #### Operation The halfword second operand is added algebraically to the least significant 16 bits (bits 16:31) of the register specified by R1. The 16-bit result replaces the contents of the memory location specified by the effective address of the second operand. The contents of the register specified by R1 are not changed. #### Condition Code | į | С | V | G | L | |---|--------|----|---|---------------| | | X | 0 | 0 | 0 | | i | X | 00 | 0 | 1 | | | X<br>X | 0 | 1 | 0<br><b>X</b> | | | X | 1 | X | X | | | 1 | X | X | X | Result is zero Result is less than zero Result is greater than zero Arithmetic overflow Carry #### Programming Notes The second operand must be located on a halfword boundary. The condition code settings are based on the halfword result. ## Example: AHM This example adds the contents of register 5 to the contents of memory location LAB. 1. RFG5 contains X\*00230002\* Halfword in memory at LAB contains X\*FFFF\* | Asser | mbler Notation | Comments | |-------|----------------|---------------------| | AHM | REG5, LAB | ADD (REG5) TO (LAB) | #### Result of AHM Instruction (REG5) unchanged by this instruction (LAB) = 0001 Condition Code = 1010 (C=1, G=1) 2. REG6 contains X°FFFF FFF5° LAB contains X°FFF2° Assembler Notation Comments AHM REG6, LAB ADD (REG6) TO (LAB) #### Result of AHM Instruction (REG6) unchanged by this instruction (LAB) = FFE7 Condition Code = 1001 (C=1, L=1) ## 5.7.5 Subtract (S, SR, SI, SIS) Subtract (S) Subtract Register (SR) Subtract Immediate (SI) Subtract Immediate Short (SIS) | Asse | mbler Notation | Op-Code | Format | |------|------------------|------------|---------| | S | R1,D2(X2) | 5 B | RX1,RX2 | | S | R1, A2(FX2, SX2) | 5B | RX3 | | SR | R1,R2 | OB | RR | | SI | R1,I2(X2) | FE | RI2 | | SIS | R1,N | 2 <b>7</b> | SF | #### Operation The fullword second operand is subtracted algebraically from the contents of the register specified by R1. The result replaces the contents of the register specified by R1. #### Condition Code | | С | V | G | L | | |---|---|---|---|---|-----------------------------| | 1 | X | 0 | 0 | 0 | Result is zero | | ı | X | 0 | 0 | 1 | Result is less than zero | | 1 | X | 0 | 1 | 0 | Result is greater than zero | | | X | 1 | X | X | Arithmetic overflow | | | 1 | X | X | X | Borrow | #### Programming Notes The second operand for the SIS instruction is obtained by expanding the 4-bit data field, N, to a 32-bit fullword by forcing the high order bits to zero. In the RI2 format, the contents of the index register specified by X2 are added to the 32-bit I2 field to form the fullword second operand. In the RX formats, the second operand must be located on a fullword boundary. #### Examples: This example subtracts the fullword at memory location LOC from the contents of register 9. REG9 contains X'444444444 LCC contains X'444444444 Assembler Notation Comments S REG9, LOC SUBTRACT (LOC) FROM (REG9) Result of S Instruction (REG9) = 0 (ICC) unchanged by this instruction Condition Code = 0000 2. REG9 contains X'23456789' LCC contains X'FFFF4321' Assembler Notation Comments S REG9, LOC SUBTRACT (LOC) FROM (REG9) Result of S Instruction (REG9) = 23462368 (LOC) unchanged by this instruction Condition Code = 1010 (C=1, G=1) ## 5.7.6 Subtract Halfword (SH, SHI) Subtract Halfword (SH) Subtract Halfword Immediate (SHI) | Assembler Notation | | Op-Code | <b>Format</b> | |--------------------|----------------|---------|---------------| | SH | R1,D2(X2) | 4B | RX1,RX2 | | SH | R1,A2(FX2,SX2) | 4 E | RX3 | | SHI | R1,I2(X2) | CB | RI1 | #### Operation The 16-bit second operand is expanded to a 32-bit fullword by propagating the most significant bit through bits 0:15. This fullword is subtracted from the contents of the register specified by R1. The result replaces the contents of the register specified by R1. #### Condition Code | С | V | G | L | |---|---|---|--------| | X | 0 | 0 | 0 | | X | 0 | 0 | 1 | | X | 0 | 1 | 0 | | X | 1 | X | 0<br>X | | 1 | X | X | X | Result is zero Result is less than zero Result is greater than zero Arithmetic overflow Borrow #### Programming Notes In the RX formats, the second operand must be located on a halfword boundary. In the RI1 format, the 16-bit I2 field is extended to a fullword by propagating the sign bit through bits 0:15. The contents of the index register specified by X2 are then added to form the fullword second operand. Example: SH This example subtracts the halfword at memory location LOC from the contents of register 9. 1. REG9 contains X'00123456' LOC contains X'FFF4' Assembler Notation Comments SH REG9, LCC SUBTRACT (LOC) FROM (REG9) Result of SH Instruction (REG9) = 00123462 (LOC) unchanged by this instruction Condition Code = 1010 2. REG9 contains X'FFFF4567' LCC contains X'2345' Assembler Notation Comments SH REG9, LCC SUBTRACT (LOC) FROM (REG9) Result of SH Instruction (REG9) = FFFF2222 (LOC) unchanged by this instruction Condition Code = 0001 #### 5.7.7 Compare (C, CR, CI) Compare (C) Compare Regis Compare Register (CR) Compare Immediate (CI) | Assembler Notation | | Op-Code | Format | |--------------------|------------------|---------|---------| | С | R1,D2(X2) | 59 | RX1,RX2 | | С | R1, A2(FX2, SX2) | 59 | RX3 | | CR | R1,R2 | 09 | RR | | CI | R1,I2(X2) | F9 | RI2 | #### Operation The first operand contained in the register specified by R1 is compared algebraically to the 32-bit second operand. The result is indicated by the condition code setting. Neither operand is changed. #### Condition Code | С | V | G | L | |---|---|---|---| | 0 | X | 0 | 0 | | 1 | X | 0 | 1 | | 0 | X | 1 | 0 | First operand is equal to second operand First operand is less than second operand First operand is greater than second operand #### Programming Notes In the RX formats, the second operand must be located on a fullword boundary. The state of the V flag is undefined. Example: C This example compares the contents of register 3 to the contents of the fullword in memory location LAB. REG3 contains X°44567894° Fullword at LAB contains X°04321243° #### #### Result of C Instruction (REG3) unchanged by this instruction (LAB) unchanged by this instruction Condition Code = 0010 (G=1) #### 5.7.8 Compare Halfword (CH, CHI) Compare Halfword (CH) Compare Halfword Immediate (CHI) | Assembler Notation | | Op-Code | <b>Format</b> | |--------------------|------------------|---------|---------------| | СН | R1,D2(X2) | 49 | RX1,RX2 | | CH | R1, A2(FX2, SX2) | 49 | RX 3 | | CHI | R1,I2(X2) | C9 | RI 1 | #### Operation The halfword second operand is expanded to a fullword by propagating the most significant bit through bits 0:15. The first operand, the contents of the register specified by R1, is compared algebraically to the effective second operand. The result is indicated by the condition code setting. Neither operand is changed. #### Condition Code | C | V | G | L | |---|---|---|---| | 0 | X | 0 | 0 | | 1 | X | 0 | 1 | | 0 | X | 1 | 0 | First operand is equal to second operand First operand is less than second operand First operand is greater than second operand #### Programming Notes In the RX formats, the second operand must be located on a halfword boundary. In the RI1 format, the 16-bit I2 field is extended to a fullword by propagating the sign bit through bits 0:15. The contents of the index register specified by X2 are then added to form the fullword second operand. Condition code settings are based on the fullword comparison. The state of the V flag is undefined. Example: CH This example compares the contents of register 8 to the halfword at LAP. REG8 contains X°F4567891° Halfword at LAB contains X°3123° Assembler Notation Comments CH REG8, LAB CCMFARE (REG8) TO (LAB) Result of CH Instruction (REG8) unchanged by this instruction (LAB) unchanged by this instruction Condition Code = 1001 (C=1, V=1) 5.7.9 Multiply (M, MR) Multiply (M) Multiply Register (MR) | Assembler Notation | | <u>Op-Code</u> | <b>Format</b> | |--------------------|------------------|----------------|---------------| | M | R1,D2(X2) | 5C | RX1,RX2 | | M | R1, A2(FX2, SX2) | 5C | RX3 | | MR | R1,R2 | 1C | RR | #### Operation The fullword first operand contained in the register specified by R1+1 is multiplied by the fullword second operand. The 64-bit result is stored in the registers specified by R1 and R1 + 1. The sign of the result is determined by the rules of algebra. Condition Code Unchanged Programming Notes The R1 field of these instructions must specify an even numbered register. If the R1 field of these instructions is odd, the result is undefined. In the RX formats, the second operand must be located on a fullword boundary. The most significant bits of the result are placed in the register specified by R1; the least significant bits are placed in the register by R1+1. Example: M This example multiplies the contents of register 9 by the contents of memory location LOC and places the result in registers 8 and 9 (64 bits). REG8 contains unknown data REG9 contains X'00002431' Fullword at location LOC contains X'43120000' #### Assembler Notation #### Comments M REG8, LOC MULTIPLY (REG9) BY (LOC) Result of M Instruction REG8 and REG9 together contain the result (REG8, REG9) = 0000 097B, 5E72 0000 (LOC) unchanged by this instruction Condition Code unchanged by this instruction Example: MR This example multiplies the contents of register 9 by the contents of register 8 and places the result in registers 8 and 9 (64 bits). REG8 contains X'00010000' REG9 contains X'12345678' ## Assembler Notation Comments MR REG8, REG8 MULTIPLY (REG9) BY (REG8) Result of MR Instruction REG8 and REG9 together contain the result (REG8, REG9) = 0000 1234, 5678 0000 Condition Code unchanged by this instruction #### 5.7.10 Multiply Halfword (MH, MHR) Multiply Halfword (MH) Multiply Halfword Register (MHR) | Assembler Notation | | Op-Code | Format | | |--------------------|------------------|---------|---------|--| | MH | R1,D2(X2) | 4C | RX1,RX2 | | | MH | R1, A2(FX2, SX2) | 4 C | RX3 | | | MHR | R1,R2 | 0 C | RR | | #### Operation The first operand, contained in bits 16:31 of the register specified by R1, is multiplied by the 16-bit second operand, taken from memory or from bits 16:31 of the register specified by R2. Both operands are 16-bit signed two's complement values. The 32-bit result replaces the contents of the register specified by R1. The sign of the result is determined by the rules of algebra. Condition Code Unchanged #### Programming Note In the RX formats, the second operand must be located on a halfword boundary. #### Example: MH This example multiplies the halfword contents of register 8 by the halfword in memory location LAB. REG8 contains X'ABCD 0045' Halfword at memory location LAB contains X'8674' #### Assembler Notation #### Comments MH REG8, LAB MULTIPLY LEAST SIGNIFICANT HALF OF (REG8) BY (LAB) Result of MH Instruction (REG8) = FFDF3D44 (LAB) unchanged by this instruction Condition Code unchanged by this instruction Example: MHR This example multiplies the halfword contents of register 11 by the halfword contents of register 4. REG11 contains X°37210004° REG4 contains X°FFFF0307° #### Assembler Notation Comments MHR REG11, REG4 MULTIPLY LS HALF OF (REG11) BY LS HALF OF (REG4) Result of MHR Instruction (REG11) = 00000C1C (REG4) unchanged by this instruction Condition Code unchanged by this instruction 5.7.11 Divide (D, DR) Divide (D) Divide Register (DR) | Assembler Notation | | Op-Code | <b>Format</b> | |--------------------|------------------|---------|---------------| | D | R1,D2(X2) | 5 D | RX1,RX2 | | D | R1, A2(FX2, SX2) | 5 D | RX3 | | DR | R1,R2 | 1 D | RR | #### Operation The 64-bit signed dividend contained in the two registers specified by R1 and R1+1 is divided by the signed fullword second operand. The 32-bit signed remainder replaces the contents of the register specified by R1. The signed 32-bit quotient replaces the contents of the register specified by R1+1. The sign of the quotient is determined by the rules of algebra. The sign of the remainder is the same as the sign of the dividend. Condition Code Unchanged #### Programming Notes The R1 field of these instructions must specify an even numbered register. If the R1 field of these instructions is odd, the result is undefined. The most significant bits of the dividend must be contained in the register specified by R1. The least significant bits of the dividend must be contained in the register specified by R1+1. In the RX formats, the second operand must be located on a fullword boundary. If the divisor is equal to zero, the instruction is not executed, the operand registers remain unchanged, and the arithmetic fault interrupt is taken. If the value of the quotient is more positive than X'7FFFFFFF' or more negative than X'80000000', quotient overflow is said to occur. If quotient overflow occurs, the operand registers remain unchanged, and the arithmetic fault interrupt is taken. #### Example: D This example divides the contents of registers 8 and 9 by the fullword contents of memory 1ccation LOC. 1. REG8 contains X\*12345678\* = Most significant half of dividend REG9 contains X\*98765432\* = Least significant half of dividend LOC contains X\*34343434\* = Divisor #### Assembler Notation #### Comments D REG8, LOC DIVIDE (REG8,9) BY (LOC) ## Result of D Instruction (REG8) = 1E1E1E1E = Remainder (REG9) = 59455459 = Quotient (LOC) unchanged by this instruction Condition Code unchanged by this instruction 2. REG8 contains X°FFFF1234° = Most significant half of dividend REG9 contains X°00000000° = Least significant half of dividend LCC contains X°12345678° = Divisor ## Assembler Notation #### Comments D REG8, LOC DIVIDE (REG8,9) BY (LOC) ## Result of D Instruction (REG8) = F250D9E0 = Remainder (REG9) = FFF2EFFC = Quotient LCC unchanged by this instruction Condition Code unchanged by this instruction 3. REG8 contains X'43657898' = Most significant half of dividend REG9 contains X'12123456' = Least significant half of dividend LOC contains X'00000000 = Divisor #### Assembler Notation #### Comments D REG8, LOC DIVIDE (REG8,9) BY (LOC) #### Result of D Instruction Division by zero causes arithmetic fault to be taken. Operands and condition code remain unchanged by this instruction. 4. REG8 contains X'80000000' = Most significant half of dividend REG9 contains X'00000001' = Least significant half of dividend LCC contains X'00000001' = Divisor ## Assembler Notation #### Comments D REG8, LOC DIVIDE (REG8,9) BY (LOC) #### Result of D Instruction Quotient overflow causes arithmetic fault to be taken. Operands and condition code remain unchanged by this instruction. Example: DR This example divides the contents of registers 8 and 9 by the contents of register 2. REG8 contains X'FFFFFFFF' = Most significant half of dividend REG9 contains X'FFFFFFFD' = Least significant half of dividend REG2 contains X'FFFFFFFE' = Divisor #### Assembler Notation #### Comments DR REG8, REG2 DIVIDE (REG8,9) BY (REG2) Result of DR instruction (REG8) = FFFFFFFF = Remainder (REG9) = 00000001 = Quotient (REG2) unchanged by this instruction Condition Code unchanged by this instruction 5.7.12 Divide Halfword (DH, DHR) Divide Halfword (DH) Divide Halfword Register (DHR) | Assembler Notation | | Op-Code | Format | | |--------------------|-----------------------------|------------|----------------|--| | DH<br>DH | R1,D2(X2)<br>R1,A2(FX2,SX2) | 4 D<br>4 D | RX1,RX2<br>RX3 | | | DHR | R1,R2 | O D | RR | | #### Operation The 32-bit signed dividend contained in the register specified by R1 is divided by the 16-bit signed second operand. The 16-bit signed remainder is copied to R1 (bits 16:31) and the halfword value is converted to a fullword value. The 16-bit signed quotient is copied to the register specified by R1 + 1 after conversion to a fullword value. The sign of the quotient is determined by the rules of algebra. The sign of the remainder is the same as the sign of the dividend. Condition Code Unchanged #### Programming Notes In the RX formats, the second operand must be located on a halfword boundary. In the RR format, the second operand is taken from bits 16:31 of the register specified by R2. If the divisor is equal to zero, the instruction is not executed, the operand registers remain unchanged, and the arithmetic fault interrupt is taken. If the value of the quotient is more positive than X°7FFF° or more negative than X°8000°, quotient overflow is said to occur. If quotient overflow occurs, the operand registers remain unchanged, and the arithmetic fault interrupt is taken. Example: DH This example divides the contents of register 7 by the halfword contents of memory location LCC. 1. REG7 contains X'0000 0054' = Dividend LOC contains X'0008' = Divisor ## Assembler Notation Comments DH REG7.LOC DIVIDE (REG7) BY (LOC) Result of DH Instruction (REG7) = 0000 0004 = Remainder (REG8) = 0000 000Å = Quetient (IOC) unchanged by this instruction Condition Code unchanged by this instruction 2. REG7 contains X'1234 5678' = Dividend LOC contains X'0000' = Divisor ## Assembler Notation Comments DH REG7, LOC DIVIDE (REG7) BY (LOC) Result of DH Instruction Division by zero causes arithmetic fault to be taken. Operands and condition code remain unchanged by this instruction. 3. REG7 contains X'8000 0002' = Dividend LOC contains X'0001' ## Assembler Notation Comments DH REG7, LCC DIVIDE (REG7) BY (LOC) Result of DH Instruction Quotient overflow causes arithmetic fault to be taken. Operands and condition code remain unchanged by this instruction. ## 5.7.13 Shift Left Arithmetic (SLA) | Asser | mbler Notation | Op-Code | Format | |-------|----------------|---------|--------| | SLA | R1,I2(X2) | EF | RI1 | #### Operation Bits 1:31 of the first operand, contained in the register specified by R1, are shifted left the number of places specified by the second operand. The sign bit (bit 0) remains unchanged. Bits shifted out of position 1 are shifted through the carry flag and then lost. The last bit shifted remains in the carry flag. Zeros are shifted into position 31. #### Condition Code | C | V | G | L | | |---|---|---|---|--| | X | 0 | 0 | 0 | | | X | 0 | 0 | 1 | | | X | 0 | 1 | 0 | | Result is zero Result is less than zero Result is greater than zero #### Programming Notes The state of the C flag indicates the state of the last bit shifted. The shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31. A shift of zero places causes the condition code to be set in accordance with the value contained in the register specified by R1. The C flag is zero in this case. #### Example: SLA This example shifts the bits in register 5 left by the number specified by the second operand. REG5 contains X 80005647 Assembler Notation Comments SLA REG5,4 SHIFT (REG5) LEFT 4 PLACES Result of SLA Instruction (REG5) = 80056470 Condition Code = 0001 (L=1) #### 5.7.14 Shift Left Halfword Arithmetic (SLHA) | Assem | bler Notation | Op-Code | Format | |-------|---------------|---------|--------| | SLHA | R1,I2(X2) | CF | RI1 | #### Operation Bits 17:31 of the register specified by R1 are shifted left the number of places specified by the second operand. Bit 16 of the register, the halfword sign bit, remains unchanged. Bits shifted out of position 17 are shifted through the C flag and then lost. The last bit shifted remains in the C flag. Zeros are shifted into position 31. Bits 0:15 of the first operand register remain unchanged. #### Condition Code | C | V | G | L | |---|---|---|---| | X | 0 | 0 | 0 | | X | 0 | 0 | 1 | | X | 0 | 1 | 0 | Result is zero Result is less than zero Result is greater than zero #### Programming Notes The condition code settings are based on the halfword (bits 16:31) result. The state of the C flag indicates the state of the last bit shifted. The shift count is specified by the least significant four bits of the second operand. The maximum shift count is 15. A shift of zero places causes the condition code to be set in accordance with the halfword value contained in bits 16:31 of the register specified by R1. The C flag is zero in this case. ## 5.7.15. Shift Right Arithmetic (SRA) | Asser | mbler Notation | Op-Code | Format | |-------|----------------|---------|--------| | SRA | R1,I2(X2) | EE | RI1 | #### Operation Bits 1:31 of the first operand, contained in the register specified by R1, are shifted right the number of places specified by the second operand. The sign bit (bit 0) remains unchanged and is propagated right as many positions as specified by the second operand. Bits shifted out of position 31 are shifted through the C flag and lost. The last bit shifted remains in the C flag. #### Condition Code | C | V | G | L | |---|---|---|---| | X | 0 | 0 | 0 | | X | 0 | 0 | 1 | | X | 0 | 1 | 0 | Result is zero Result is less than zero Result is greater than zero #### Programming Notes The state of the C flag indicates the state of the last bit shifted. The shift count is specified by the least significant five bits of the second operand. The maximum shift count is 31. A shift of zero places causes the condition code to be set in accordance with the value contained in the register specified by R1. The C flag is zero in this case. #### Example: SRA This example shifts the contents of register 9 right the number of places specified by the second operand. REG9 contains X'800004256' Assembler Notation Comments SRA REG9.8 SHIFT (REG9) RIGHT 8 PLACES Result of SRA Instruction (REG9) = X°FF800042° Condition Code = 0001 (L=1) #### 5.7.16 Shift Right Halfword Arithmetic (SRHA) | <u> Assem</u> | bler Notation | Op-Code | <b>Format</b> | |---------------|---------------|---------|---------------| | SRHA | R1,I2 (X2) | CE | RI1 | #### Operation Bits 17:31 of the register specified by R1 are shifted right the number of places specified by the second operand. Bit 16 of the register, the halfword sign bit, remains unchanged and is propagated right the number of positions specified by the second operand. Bits shifted out of position 31 are shifted through the C flag and lost. The last bit shifted remains in the C flag. Bits 0:15 of the first operand register remain unchanged. #### Condition Code | | | V | | | | |---|---|---|---|-----|-----------------------------| | Ì | χ | 0 | 0 | 0 | Result is zero | | | X | 0 | 0 | 1 | Result is less than zero | | | X | 0 | 1 | 010 | Result is greater than zero | #### Programming Notes The condition code settings are based on the halfword (bits 16:31) result. The state of the C flag indicates the state of the last bit shifted. The shift count is specified by the least significant four bits of the second operand. The maximum shift count is 15. A shift of zero places causes the condition code to be set in accordance with the halfword value contained in bits 16:31 of the register specified by R1. The C flag is zero in this case. # 5.7.17 Convert to Halfword Value Register (CHVR) | Assembler Notation | | <u>Op-Code</u> | Format | | |--------------------|-------|----------------|--------|--| | CHVR | R1,R2 | 12 | RR | | #### Cperation The halfword second operand, bits 16:31 of the register specified by R2, is expanded to a fullword by propagating the most significant bit (bit 16) through bits 0:15. This fullword replaces the contents of the register specified by R1. #### Condition Code | U | V | G | L | |---|---|-------------|---| | X | X | 0 | 0 | | X | X | 0<br>0<br>1 | 1 | | X | X | | 0 | | X | 1 | X | X | | 1 | х | x | X | | 0 | X | X | X | Result is zero Result is less than zero Result is greater than zero Source operand cannot be represented by a 16-bit signed number Carry flag was set in previous condition code Carry flag was zero in previous condition code #### Programming Notes The V flag is set when bit 15 of the second operand is not the same as bit 16 of the second operand. The G and L flags reflect the algebraic value of bits 16:31 of the second operand. Execution of this instruction following halfword operations guarantees the same results as those obtained if the program were run on a 16-bit machine. For example, if location A in memory contains the halfword value of X°7FFF° (decimal 32767) then, | LH | R1,A | R 1 | contains | X * 00007FFF * | |-----|------|-----|----------|----------------| | AIS | R1,1 | | | X.00008000. | Following the add operation, the condition code is: | С | V | G | L | |---|---|---|---| | 0 | 0 | 1 | 0 | indicating a result greater than zero, which is correct for fullword operations. If the same sequence were executed on a 16-bit processor, as: LH R1, A R1 contains X'7FFF' AIS R1,1 R1 contains X'8000' Following this, the condition code in the halfword processor is: | С | V | G | L | |---|---|---|---| | 0 | 1 | 0 | 1 | indicating overflow and a negative result. Going back to the original sequence and adding the Convert to Halfword Value Register instruction produces the following: LH R1,A R1 contains X'00007FFF' AIS R1,1 R1 contains X'00008000' CHVR R1,R1 R1 contains X'FFFF8000' Following this sequence, the condition code is: | С | V | G | L | |---|---|---|---| | 0 | 1 | 0 | 1 | which is identical to that of the 16-bit processor, and can be tested in the same manner. # CHAPTER 6 FLOATING-POINT ARITHMETIC (OPTIONAL) #### 6.1 INTRODUCTION Floating-point arithmetic instructions provide a means for rapid handling of scientific data expressed as floating-point numbers. Single-precision and double-precision floating-point instructions, as well as mixed mode floating-point instructions, are described in this chapter. The comprehensive set of instructions includes load and store floating-point numbers; add, subtract, multiply, divide and compare two floating-point numbers; convert fixed-point to floating-point and vice versa; and mixed mode operations that translate single-precision to double-precision and vice versa. Floating-point is a means of representing a quantity in any numbering system. For example, the decimal number 123 (base = 10), can be represented in the following forms: | 123.0 | X | 10 <sup>0</sup> | |--------|---|-----------------| | 1.23 | x | 10 <sup>2</sup> | | 0.123 | X | 10 <sup>3</sup> | | 0.0123 | x | 104 | In this example, the decimal point moved; this is called a floating-point. In actual floating-point representation, the significant digits are always fractional and are collectively referred to as fractions. The power to which the base number is raised is called the exponent. For example, in the number .45678 $\times$ 10<sup>2</sup>, 45678 is the fraction and 2 is the exponent. Both the fraction and the exponent can be signed. If we have a floating-point representation such as, (sign of fraction) (exponent) (fraction) the following representation applies: Number | N Q III D C L | r roa crity portit | | | | | | |------------------|--------------------------|---|----|-------|--|--| | +32.94 | $= +.3294 \times 10^{2}$ | + | +2 | 3294 | | | | -23760000.0 | $=2376 \times 10^8$ | - | +8 | 2376 | | | | +0.000059 | $= +.59 \times 10^{-4}$ | + | -4 | 59 | | | | -0.0000000092073 | $=92073 \times 10^{-8}$ | - | -8 | 92073 | | | Large or small numbers can be easily expressed in floating-point, making it ideally suitable for scientific computation. Note the compactness of floating-point notation in the above examples. Floating-point representation in the processor is similar to the above representation. The differences are: - Hexadecimal, instead of decimal, numbering system is used. - 2. Physical size of the number is limited, therefore the magnitude and precision are limited. #### 6.2 FLCATING-PCINT DATA FCRMATS Floating-point numbers occur in one of two formats: single-precision and double-precision. The single-precision format requires a fullword (32 bits). When such a value is contained in memory, it must exist on a fullword address boundary. The sign (S), exponent (X), and fraction (consisting of the digits F1, F2, F3, F4, F5, and F6) fields are designated as follows: | 602 | .0 | 7 | 8 11 | 12 15 | 16 19 | 20 23 | 24 27 | 28 31 | |-----|----|---|------|-------|-------|-------|-------|-------| | | s | х | F1 | F2 | F3 | F4 | F5 | F6 | The dcuble-precision format requires a doubleword (64 bits). When two general registers hold a double-precision value, an even/odd pair of general registers must be used. The even-numbered register contains the most significant 32 bits, and the next sequential odd register contains the least significant 32 bits. The sign (S), exponent (X), and fraction (consisting of digits F1 through F14) fields are designated as follows: | 32 | 35 | 36 | 39 | 40 | 43 | 44 | 47 | 48 | 51 | <b>,</b> 52 | 55 | 56 | 59 | 60 | 63 | |----|----|----|----|----|----|----|-----|----|-----|-------------|-----|----|-----|----|-----| | F7 | | | F8 | | F9 | | F10 | | F11 | | F12 | | F13 | | F14 | #### 6.3 FLCATING-FCINT NUMBER In the processor, a floating-point number is represented in the following form: | Sign | Exponent | Fraction | |------|----------|----------| Sign The most significant bit of a floating-point number is the sign bit. The sign bit is zero for positive numbers and one for negative numbers. The floating-point value of zero always has a positive sign. Exponent The 7-bit field, bits 1:7, is designated as the exponent field. The exponent is expressed in excess-64 notation. The number in this field contains the true value of the exponent plus X°40° (decimal 64). This helps to represent very small magnitudes between 0 and 1. Some of the exponent values are as fcllcws: | Exponent in Excess-64 notation | True<br>exponent in<br>hexadecimal | True<br>exponent in<br>decimal | Multiply<br>fraction by | |--------------------------------|------------------------------------|--------------------------------|-------------------------| | 00 | -40 | -64 | 16 | | 3 <b>F</b> | -1 | -1 | 16 | | 40 | 0 | 0 | 16 | | 41 | 1 | 1 | 16 | | 7 F | 3 F | 63 | 16 | The exponent field for true zero is always 00. Fraction The fraction field is 6 hexadecimal digits for single-precision floating-point numbers (thus limiting the precision), and 14 hexadecimal digits for double-precision floating-point numbers. any other fraction, the floating-point fraction is expressed with most precision when the most significant hexadecimal digit (not necessarily the most significant bit) is nonzero. The floating-point number with such a fraction is called a normalized floating-point number. In the 3200 processors, normalized numbers are always used to obtain the maximum possible precision. For hexadecimal fraction conversion, refer to Appendix D. Examples: The following examples illustrate the sign, exponent, and fraction concept of a floating-point number: | Numbers in Hexa-<br>decimal integer-<br>fraction notation | | frac | n-exponent-<br>cticn shown<br>clarity | Single-precision<br>floating-point numbers | | | | |--------------------------------------------------------------------------------------|-------|----------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------|--|--|--| | | s | E | F | | | | | | +1.3A25678<br>-6.89F2C<br>+1A.C39D21<br>-3C1DF.82A3<br>+ABCDEF12.9AC<br>+0.0032A9CF2 | 0 1 0 | 41<br>42<br>45<br>48 | 13A25678<br>689F2C<br>1AC39021<br>3C1DF82A3<br>ABCDEF129AC<br>32A9CF2 | 4113A256<br>C1689F2C<br>421AC39D<br>C53C1DF8<br>48ABCDEF<br>3E32A9CF | | | | | +0.0032A9CF2<br>-0.000002C7B5 | - | _ | 32A9CF2<br>2C7B5 | | | | | #### 6.3.1 Floating-Point Number Range The range of magnitude (M) of a normalized floating-point number is as follows: | Single precision: | 16 <sup>-65</sup> | < M | ≤ | (1 - | 16 <sup>-6</sup> ) * 16 <sup>63</sup> | |-------------------------|-------------------|-------|-----|------|---------------------------------------| | Double precision: | 16 <sup>-65</sup> | < M | < | (1 - | $16^{-14}$ ) * $16^{63}$ | | Approximately for both: | 5.4 * | 10-79 | 9 _ | < M | < 7.2 * 10 <sup>79</sup> | Table 6-1 shows the floating-point range in relation to the fixed-point range along with the decimal values. TABLE 6-1 FLOATING/FIXED-POINT RANGES | 606-1 | 1 | |-------|---| |-------|---| | FLOATING-POINT<br>NUMBERS | | | | FI | DECIMAL<br>NUMBERS | | | |---------------------------------|------|----------------------|------|------|-------------------------------------|--------------------------------------------|-----| | (most negative) | FFFF | FFFF | | | | -7.2* 10 <sup>75</sup> | | | | | 0000 | | | (most negative)<br>(least negative) | -2 147 483<br>-1 | 648 | | (least negative)<br>(true zero) | | | 0000 | 0000 | | -5.4*10 <sup>-79</sup> | | | (least positive) | 4110 | 0000<br>0000<br>FFFF | | | (least positive) (most positive) | +5.4*10 <sup>-79</sup><br>+1<br>+2 147 483 | 647 | | (most positive) | 7FFF | FFFF | | | <u>-</u> | +7.2*10 <sup>75</sup> | | #### 6.3.2 Normalization Normalization is a process of making nonzero the most significant digit (F1) of the fraction of a floating-point number. In the normalization process, the floating-point fraction is shifted left hexadecimally (i.e., four bits at a time), and its exponent is decremented by one for each hexadecimal shift until the most significant digit (not necessarily the most significant bit) of the fraction is nonzero. Except for the load instructions, all floating-point operations assume and require normalized operands for consistent results. The load instructions normalize an unnormalized operand. #### Example: | | Operands | After normalization | |----|----------|-------------------------------| | 1. | 42012345 | 41123450 | | 2. | 21000ABC | 1EAEC000 | | з. | C900FE12 | C7FF1200 | | 4. | 6C000000 | 00000000 (true zero) | | 5. | 82000A67 | 00000000 (exponent underflow) | In Example 4, the fraction of the operand is zero. During the normalization process, such a fraction is detected, and the floating-point number is set to true zero. In Example 5, the exponent of the operand is very small. During the normalization process, the exponent is decremented from 00 to 7F. Such a transition results in exponent underflow, and the floating-point number is set to true zero. Normalized results are always produced in floating-point operations, assuming the operands are normalized. Results of operations between unnormalized numbers are undefined. #### 6.3.3 Equalization Equalization is a process of equalizing exponents of two floating-point numbers. The fraction of the floating-point number with the smaller exponent is shifted right hexadecimally, i.e., four bits at a time, and its exponent is incremented by one for each hexadecimal shift until the two exponents are equal. # S EXPONENT F1 F2 F3 F4 F5 F6 During floating-point addition and subtraction, the two floating-point operands are equalized. **FRACTION** #### Example: | | Floating-point operands | After equalization | |----|-------------------------|----------------------| | 1. | 43123456<br>3F789ABC | 43123456<br>43000078 | | 2. | C7FE1234<br>4956789A | C900FE12<br>4956789A | In this example, normalized floating-point numbers are shown because addition and subtraction require normalization. If the exponents differ by more than 6 for single-precision or more than 14 for double-precision, the representable significance of the lower exponent floating-point number is lost in the process of equalization. Digits shifted out are shifted through the guard digits and may still have an effect on the result, sum, or difference. #### 6.3.4 True Zero A floating-point number is true zero when the exponent and the fraction fields are all zeros; therefore, all data bits must be zero. A zero value always has a positive sign. In general, zero values participate as normal operands in all floating-point operations. A true zero may be used as an operand. It may also result from an arithmetic operation that caused an exponent underflow, in which case the entire number may be forced to true zero. If an arithmetic operation produces a result whose fraction digits are all zeros (sometimes referred to as loss of significance), the entire number is forced to true zero. ## Examples: | Numbers | Operation | Result | Reason | |----------------------|-----------|-----------|-----------------------| | 030000 <b>A</b> B | Normalize | 0000 0000 | exponent<br>underflow | | 41ABCDEF<br>41ABCDEF | Subtract | 0000 0000 | loss of significance | # 6.3.5 Exponent Overflow In floating-point operations, exponent overflow occurs when a resulting exponent is greater than +63. If overflow occurs, the result register is unchanged. The condition code is set to reflect the overflow situation and the resulting sign. Figure 6-1 illustrates exponent overflow using a line representation of numbers. Figure 6-1 Exponent Overflow If overflow occurs, the V flag in the condition code is set, and an arithmetic fault interrupt is taken. Exponent overflow interrupts cannot be disabled. # 6.3.6 Exponent Underflow The normalization process, during a floating-point operation, may produce an exponent underflow. This underflow occurs when a result exponent is less than -64. Figure 6-2 illustrates exponent underflow using a line representation of numbers. Figure 6-2 Exponent Underflow If underflow occurs, an arithmetic fault interrupt is taken, if enabled by the current PSW. Both operands remain unchanged. If underflow is disabled by the current PSW, the result is forced to zero (the closest possible answer), the V flag in the condition code is set, and the next sequential instruction is executed. # 6.3.7 Guard Digits and R\*-Rounding When an intermediate floating-point result has been formed, it consists of a sign, an exponent, and a fraction field. The fraction field is extended by a number of guard digits containing the least significant fraction digits of the intermediate result. Before the result is copied to a destination, it is rounded to compensate for the loss in the final result of the guard digits. The rules for the R\*-Rounding scheme are: - If the most significant guard digit is hexadecimal 7 or less, no rounding is performed. (See Example 1.) - If the most significant guard digit is hexadecimal 8, and all other guard digits are 0, the least significant bit of the final result is forced to 1. (See Example 2.) - If the most significant guard digit is hexadecimal 8, and another guard digit is nonzero, or if the most significant guard digit is hexadecimal 9 or greater, 1 is added to the fraction field of the final result. (See Example 3.) If this addition produces a carry out of the fraction field (i.e., fraction field was all 1s), the result exponent is incremented by 1, the most significant fraction digit (F1) is set to hexadecimal 1, and all other fraction digits are set to 0. (See Example 4.) Note that exponent overflow could occur as the result of rounding. Examples of R\*-Rounding INTERMEDIATE RESULT FINAL SINGLE-PRECISION RESULT Guard Data Digits | 1. | 42ABCD12 | | 42ABCD12 | |----|----------|----------|----------| | 2. | C1183756 | 80000000 | C1183757 | | З. | 3E265739 | 80100C0C | 3E26573A | | 4. | 41FFFFFF | F0000000 | 42100000 | # 6.3.8 Conversion from Decimal To convert a decimal number into the excess-64 notation used internally by the processor, the following steps must be taken: 1. Separate the decimal integer from the decimal fraction: $$182.375_{10} = (182 + .375)_{10}$$ 2. Convert each part to hexadecimal by referring to the integer conversion table and the fraction conversion table in Appendix D. $$182_{10} = B6_{16}$$ $\cdot 375_{10} = \cdot 6_{16}$ 3. Combine the hexadecimal integer and fraction: $$B6.6_{16} = (B6.6 \times 16^{\circ})_{16}$$ 4. Shift the radix point: $$(B6.6X16^{\circ})_{16} = (.B66X16^{\circ})_{16}$$ 5. Add 64 (X'40') to the exponent: $$40_{16} + 2_{16} = 42_{16}$$ 6. Convert the exponent field and fractions to binary allowing 1 bit for the sign, 7 bits for exponent field, and 24 or 56 bits for the fraction. ## 6.4 CONDITION CODE Most floating-point operations affect the condition code. For each instruction description, the possible condition code settings are shown. # 6.5 FLOATING-POINT INSTRUCTIONS All floating-point instructions are illegal when PSW bit 13 (FLM) is set. Floating-point instructions cannot be executed when the processor is in the Floating-Point Masked (FLM) mode. Floating-point instructions use the Register to Register (RR), and the Register and Indexed Storage (RX) instruction formats. In all of the RR formats, except for fix and float, the R1 and R2 fields specify one of the floating-point registers. There are eight single-precision floating-point registers and eight double-precision floating-point registers numbered 0, 2, 4, 6, 8, 10, 12, and 14. Floating-point instructions must specify even-numbered floating-point registers, or the results of the instructions are undefined. Except for the FXR, FXDR, LGER, and LGDR instructions, the R1 field always specifies a floating-point register. Floating-point arithmetic operations, excluding loads and stores, require normalized operands to ensure correct results. If the operands are not normalized, the results of these operations are undefined. Floating-point results are normalized. The floating-point load instructions normalize the floating-point data presented as the second operand. The single-precision floating-point instructions described in this section are: ``` LE Load Floating-Point LER Load Floating-Point Register LEGR Load Floating-Point from General Register LPER Load Positive Floating-Point Register LCER Load Complement Floating-Point Register Load Floating-Point Multiple LME LGER Load General Register from Floating-Point Register STE Store Floating-Point STME Store Floating-Point Multiple AE Add Floating-Point AER Add Floating-Point Register SE Subtract Floating-Point SER Subtract Floating-Point Register CE Compare Floating-Point CER Compare Floating-Point Register ΜE Multiply Floating-Point Multiply Floating-Point Register MER DΕ Divide Floating-Point DER Divide Floating-Point Register FXR Fix Register FLR Float Register ``` The double-precision floating-point instructions described in this section are: ``` Load DPFP LD LDR Load Register DPFP Load DPFP from General Registers LDGR Load Positive Register DPFP LPDR Load Complement Register DPFP LCDR Load DPFP Multiple LMD Load General Register from DPFP register LGDR STD Store DPFP STMD Store Multiple DPFP Add DPFP A D ADR Add Register DPFP SD Subtract DPFP SDR Subtract Register DFFF Compare DPFP CD CDR Compare Register DPFP MD Multiply DPFP Multiply Register DPFP MDR DD Divide DPFP DDR Divide Register DPFP FXDR Fix Register DPFP FLDR Float Register DPFP ``` The mixed mode floating-point instructions described in this section are: | LED | Load SPFP from DPFP | |------|------------------------------| | LEDR | Load Register SPFP from DPFP | | LDE | Load DPFP from SPFP | | LDER | Load Register DPFP from SPFP | | STDE | Store DPFP in SPFP | # 6.5.1 Load Floating-Point (LE, LER, LEGR) Load Floating-Point (LE) Load Floating-Point Register (LER) Load Floating-Point from General Register (LEGR) | Asset | mbler Notation | Op-Code | Format | |-------|------------------|---------|---------| | LE | R1,D2(X2) | 68 | RX1,RX2 | | LE | R1, A2(FX2, SX2) | 68 | RХЗ | | LER | R1, R2 | 28 | RR | | LEGR | R1,R2 | A 5 | RR | # Operation The floating-point second operand is normalized, if necessary, and placed in the single-precision floating-point register specified by R1. ## Condition Code | C | ٧ | G | L | | |-------|---|---|---|--------------------------------------------| | 0 | 0 | 0 | 0 | Floating-roint result is zero | | 0 | 0 | 0 | 1 | Floating-point result is less than zero | | 0 | 0 | 1 | 0 | Floating-point result is greater than zero | | 0 0 0 | 1 | 0 | 0 | Exponent underflow | # Programming Notes If the argument fraction is zero, the entire result is forced to zero, $X^{\bullet}0000\ 0000^{\bullet}$ . Normalization can produce exponent underflow. If PSW bit 19 is set, an arithmetic fault interrupt is taken, and the register specified by R1 is unchanged. If an exponent underflow occurs, and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. In the RX formats, the second operand must be located on a fullword boundary. Example: LE This example normalizes the fullword at memory location LOC and places it in floating-point register 8. Floating-point REG8 contains unknown data LOC contains X°4200 1000° Assembler Notation Comments LE REG8, LOC LOAD FROM LOC AND NORMALIZE Result of LE Instruction: (REG8) = X°4010 0000° (LOC) unchanged by this instruction Condition Code = 0010 # 6.5.2 Load Positive Floating-Point Register (LPER) | Assem | bler Notation | Op-code | Format | |-------|---------------|---------|--------| | LPER | R1,R2 | 13 | RR | #### Operation The floating-point second operand specified by R2 is forced positive, normalized if necessary, and placed in the single-precision floating-point register specified by R1. #### Condition Code | С | V | G | L | | |---|---|---|---|--| | 0 | 0 | 0 | 0 | | | 0 | 0 | 1 | 0 | | | 0 | 1 | 0 | 0 | | Floating-roint result is zero Floating-point result is greater than zero Exponent underflow #### Programming Notes If the argument fraction is zero, the entire result is forced to zero, X'0000 0000'. Normalization can produce exponent underflow. If PSW bit 19 is set, an arithmetic fault interrupt is taken, and the register specified by R1 is unchanged. If an exponent underflow occurs, and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. # Example: Floating-point REG6 contains unknown data Floating-point REG8 contains X°C11921FB° # Assembler Notation Comments LPER REG6, REG8 LCAD REG6 WITH POSITIVE OF (REG8) Result of LPER Instruction: (REG6) = X°411921FB° (REG8) unchanged by this instruction Condition Code = 0010 # 6.5.3 Load Complement Floating-Point Register (LCER) | Assemi | oler Notation | Op-Code | <b>Format</b> | |--------|---------------|---------|---------------| | LCER | R1,R2 | 17 | RR | #### Operation The sign of the floating-point second operand specified by R2 is complemented. The resulting floating-point number is normalized, if necessary, and placed in the single-precision floating-point register specified by R1. # Condition Code | С | V | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | | 0 | 0 | 1 | 0 | | 0 | 1 | 0 | 0 | Floating-point result is zero Floating-point result is less than zero Floating-point result is greater than zero Exponent underflow # Programming Notes If the argument fraction is zero, the entire result is forced to zero, X'0000 0000'. Normalization can produce exponent underflow. If PSW bit 19 is set, an arithmetic fault interrupt is taken, and the register specified by R1 is unchanged. If an exponent underflow occurs, and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. # 6.5.4 Load Multiple Floating-Point (LME) | Asser | mbler Notation | Op-Code | Format | |-------|------------------|---------|---------| | LME | R1,D2(X2) | 72 | RX2,RX2 | | LME | R1, A2(FX2, SX2) | 72 | RX 3 | #### Operation Successive single-precision floating-point registers, starting with the register specified by R1, are loaded from successive fullword memory locations starting with the address of the second operand. The process stops when floating-point register 14 has been loaded. Condition Code Unchanged # Programming Notes Values loaded into the floating-point registers are assumed to be normalized, and no test or adjustment is performed. The second operand must be located on a fullword boundary. ## 6.5.5 Load General Register from Floating-Point Register (LGER) | Assem | bler Notation | Op-Code | <u>Format</u> | | |-------|---------------|---------|---------------|--| | LGER | R1,R2 | 15 | RR | | # Operation The floating-point second operand, contained in the single-precision floating-point register specified by R2, is placed in the general register specified by R1. The second operand is unchanged. ## Condition Code | | | | | L | | |---|---|---|---|-------------|-----------------------------| | | 0 | 0 | 0 | 0 | Result is zero | | | 0 | 0 | 0 | 0<br>1<br>0 | Result is less than zero | | i | 0 | 0 | 1 | 0 | Result is greater than zero | # 6.5.6 Store Floating-Point (STE) | Asser | mbler Notation | Op-Code | Format | |-------|------------------|---------|---------| | STE | R1,D2(X2) | 60 | RX1,RX2 | | STE | R1, A2(FX2, SX2) | 60 | RX3 | #### Operation The floating-point first operand, contained in the single-precision floating-point register specified by R1, is placed in the fullword memory location specified by the second operand address. The first operand is unchanged. Condition Code Unchanged Programming Note The second operand must be located on a fullword boundary. # 6.5.7 Store Multiple Floating-Point (STME) | Assem | bler Notation | <u>Op-Code</u> | Format | |-------|------------------|----------------|---------| | STME | R1,D2(X2) | 71 | RX1,RX2 | | STME | R1, A2(FX2, SX2) | 71 | RX3 | # Operation The contents of successive single-precision floating-point registers, starting with the even numbered register specified by R1, are stored in successive fullword memory locations, starting with the address of the second operand. The operation stops when the contents of floating-point register 14 have been stored. Condition Code Unchanged Programming Note The second operand must be located on a fullword boundary. # 6.5.8 Add Floating-Point (AE, AER) Add Floating-Point (AE) Add Floating-Point Register (AER) | Asser | mbler Notation | Op-Code | <b>Format</b> | |-------|------------------|---------|---------------| | ΑE | R1,D2(X2) | 6 A | RX1,RX2 | | AΕ | R1, A2(FX2, SX2) | 6 A | RX3 | | AER | R1,R2 | 21 | RR | #### Operation The two operand exponents are compared. If the exponents differ, the fraction with the smaller exponent is shifted right hexadecimally (four bits at a time), and its exponent is incremented by one for each hexadecimal shift, until the two exponents are equal. The hexadecimal digits (of four bits each) are shifted through the guard digits for additional precision. If no equalizing shifts are required, the guard digits remain zero. The fractions are then algebraically added. The guard digits participate in this addition. If the addition of fractions produces a carry, the exponent of the result is incremented by one, and the fraction of the result is shifted right one hexadecimal digit. The carry bit is shifted back into the most significant hexadecimal digit of the fraction, producing a normalized result. This result is then R\*-rounded and replaces the contents of the single-precision floating-point register specified by R1. If the addition of fractions does not produce a carry, the result is normalized, if necessary, and R\*-rounded. This result replaces the contents of the single-precision floating-point register specified by R1. ## Condition Code | C | ٧ | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | | 0 | 0 | 1 | 0 | | 0 | 1 | 0 | 1 | | 0 | 1 | 1 | 0 | | 0 | 1 | 0 | 0 | Floating-point result is zero Floating-point result is less than zero Floating-point result is greater than zero Exponent overflow, result is less than zero Exponent cverflow, result is greater than zero Exponent underflow Programming Notes When the addition of the fractions produces a carry, incrementing the exponent of the result by one can produce exponent overflow. In this case, the arithmetic fault interrupt is taken and the contents of the register specified by R1 remain unchanged. Normalization of the result can produce exponent underflow. If PSW bit 19 is set, an arithmetic fault interrupt is taken, and the register specified by R1 is unchanged. If exponent underflow occurs and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. In the RX formats, the second operand must be located on a fullword boundary. Fastest results occur when the first operand is larger than the second operand. Example: AE This example adds the contents of LOC to the contents of floating-point register 8 and places the result in floating-point register 8. Floating-point REG8 contains X°7EFF FFFF'. LOC contains X°7EFF FFFF' Assembler Notation Comments AE REG8, LCC ADD (LOC) TO (REG8) Result of AE Instruction (Floating-point REG8) = 7F1F FFFF (LOC) unchanged by this instruction Condition Code = 0010 # 6.5.9 Subtract Floating-Point (SE, SER) Subtract Floating-Point (SE) Subtract Floating-Point Register (SER) | Asse | mbler Notation | Op-Code | Format | |------|------------------|---------|---------| | SE | R1,D2(X2) | 6B | RX1,RX2 | | SE | R1, A2(FX2, SX2) | 6 P | RX3 | | SER | R1,R2 | 2B | RR | #### Operation The two operand exponents are compared. If the exponents differ, the fraction with the smaller exponent is shifted right hexadecimally (four bits at a time), and its exponent is incremented by one for each hexadecimal shift, until the two exponents are equal. The hexadecimal digits (of four bits each) are shifted through the guard digits for additional precision. If no equalizing shifts are required, the guard digits remain zero. The second operand fraction is then subtracted algebraically from the first operand fraction. The guard digits participate in this subtraction. If the subtraction of fractions produces a carry, the exponent of the result is incremented by one, and the fraction of the result is shifted right one hexadecimal digit. The carry bit is shifted back into the most significant hexadecimal digit of the fraction, producing a normalized result. This result is then R\*-rounded and replaces the contents of the single-precision floating-point register specified by R1. If the subtraction of fractions does not produce a carry, the result is normalized, if necessary, then R\*-rounded. This result replaces the contents of the single-precision floating-point register specified by R1. #### Condition Code | С | V | G | L | |-------|---|-------|---| | 0 | 0 | 0 | 0 | | 00000 | 0 | 0 0 1 | 1 | | 0 | 0 | ' ' | 0 | | 0 | 1 | 0 | 1 | | 0 | 1 | 1 | 0 | | C | 1 | 0 | 0 | Floating-point result is zero Floating-point result is less than zero Floating-point result is greater than zero Exponent overflow, result is less than zero Exponent cverflow, result is greater than zero Exponent underflow Programming Notes When the subtraction of the fractions produces a carry, incrementing the exponent of the result by one can produce exponent overflow. In this case, the arithmetic fault interrupt is taken, and the contents of R1 remain unchanged. Normalization of the result can produce exponent underflow. If PSW bit 19 is set, an arithmetic fault interrupt is taken, and the register specified by R1 is unchanged. If exponent underflow occurs and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. In the RX formats, the second operand must be located on a fullword boundary. Fastest results occur when the first operand is larger than the second operand. Example: SE This example subtracts the contents of LOC from the contents of floating-point register 8 and places the result in floating-point register 8. Floating-point RFG8 contains X'7EFF FFFF' LOC centains X'7A10 0000' # Assembler Notation Comments SE REG8, LOC SUBTRACT (LOC) FROM (REG8) Result of SE Instruction (Floating-point REG8) = 7EFF FFEF (LOC) unchanged by this instruction Condition Code = 0010 # 6.5.10 Compare Floating-Point (CE, CER) Compare Floating-Point (CE) Compare Floating-Point Register (CER) | Asser | nbler Notation | Op-Code | Format | |-------|----------------|---------|---------| | CE | R1,D2(X2) | 69 | RX1,RX2 | | CE | P1,D2(FX2,SX2) | 69 | RX3 | | CER | R1,R2 | 29 | RR | #### Operation The first and second operands are compared. Comparison is algebraic, and the sign, fraction, and exponent of each number must be considered. The result is indicated by the condition code setting. Neither operand is changed. # Condition Code | C | V | G | L | |---|---|---|---| | 0 | X | 0 | 0 | | 1 | X | 0 | 1 | | 0 | X | 1 | 0 | First operand is equal to second operand First operand is less than second operand First operand is greater than second operand # Programming Notes The state of the V flag is undefined. In the RX formats, the second operand must be located on a fullword boundary. 6.5.11 Multiply Floating-Point (ME, MER) Multiply Floating-Point (ME) Multiply Floating-Point Register (MER) | Assembler Notation | | Op-Code | Format | |--------------------|-----------------|---------|---------| | ME | R1,D2(X2) | 6C | RX1,RX2 | | ΜE | R1, A2(FX2,SX2) | 6C | RX3 | | MER | R1,R2 | 2C | RR | #### Operation The exponents of each operand, as derived from the excess-64 notation used in floating-roint representation, are added to produce the exponent of the result. This exponent is converted back to excess-64 notation, and the fractions are then multiplied. If the product is zero, the entire floating-point value is forced to zero, X\*0000 0000\*. If the product is not zero, the result is normalized. The sign of the result is determined by the rules of algebra. The R\*-rounded result replaces the contents of the single-precision floating-point register specified by R1. # Condition Code | | C | V | G | L | |---|-----|-----|---|---| | | 0 | 0 | 0 | 0 | | į | 000 | 000 | 0 | 1 | | | | | 1 | 0 | | | 0 | 1 | 0 | 1 | | | 0 | 1 | 1 | 0 | | | 0 | 1 | 0 | 0 | Floating-point result is zero Floating-point result is less than zero Floating-point result is greater than zero Exponent overflow, result is less than zero Exponent overflow, result is greater than zero Exponent underflow ## Programming Notes Multiplication of two 6-hexadecimal-digit fractions effectively produces a result of six hexadecimal digits and a number of guard digits. The guard digits participate in the R\*-rounding of the final result. The addition of exponents can produce exponent overflow. In this case, an arithmetic fault interrupt is taken, and both operands remain unchanged. The addition of exponents or the normalization process can produce exponent underflow. If PSW bit 19 is set, an arithmetic fault interrupt is taken and the register specified by R1 is unchanged. If exponent underflow occurs and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. In the RX formats, the second operand must be located on a fullword boundary. Fastest results occur when the second operand multiplier contains sets of four or more contiguous ones cr zeros. Example: ME This example multiplies the contents of floating-point register 8 by the contents of memory location LOC and places the result in floating-point register 8. Floating-point REG8 contains X°5FFF FFFF° LOC contains X°60FF FFFF° # Assembler Notation Comments ME REG8, LOC MULTIPLY (REG8) BY (LOC) Result of ME Instruction (Floating-point REG8) = 7FFF FFFE (LOC) unchanged by this instruction Condition Code = 0010 6.5.12 Divide Floating-Point (DE, DER) Divide Floating-Point (DE) Divide Floating-Point Register (DER) | Asse | mbler Notation | Op-Code | <b>Format</b> | |------|-----------------|---------|---------------| | DE | R1, D2 (X2) | 6 D | RX1,RX2 | | DΕ | R1,A2 (FX2,SX2) | 6 D | RX3 | | DER | R1, R2 | 2 D | RR | #### Operation The exponents of each operand, as derived from the excess-64 notation used in floating-point representation, are subtracted to produce the exponent of the result. This exponent is converted back to excess-64 notation. The first operand fraction is then divided by the second operand fraction. Division continues until the quotient is normalized, adjusting the exponent for each additional division required. No remainder is returned. The sign of the quotient is determined by the rules of algebra. The R\*-rounded quotient replaces the contents of the single-precision floating-point register specified by R1. # Condition Code | С | V | G | L | | |---|---|---|---|---------------------------------------------| | 0 | 0 | 0 | 0 | Floating-roint result is zero | | 0 | 0 | 0 | 1 | Floating-point result is less than zero | | 0 | 0 | 1 | 0 | Floating-point result is greater than zero | | 0 | 1 | 0 | 1 | Exponent cverflow, result is less than zero | | 0 | 1 | 1 | 0 | Exponent overflow, result is greater than | | | | | | zero | | 0 | 1 | 0 | 0 | Exponent underflow | | 1 | 1 | 0 | 0 | Divisor equal to zero | ## Programming Notes Before starting the divide operation, the divisor is checked. If it is equal to zero, the operation is aborted, and the arithmetic fault interrupt is taken. Neither operand is changed. Subtraction of exponents may produce exponent overflow. In this case, an arithmetic fault interrupt is taken, and both operands remain unchanged. The subtraction of exponents or the division process can produce exponent underflow; normalization of the result can produce exponent underflow. If PSW bit 19 is set, an arithmetic fault interrupt is taken, and the register specified by R1 is unchanged. If exponent underflow occurs and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. The 6-hexadecimal digit first operand fraction is divided by the 6-hexadecimal digit second operand, effectively producing the 6-hexadecimal digit quotient along with a number of guard digits. The guard digits participate in the R\*-rounding of the final result. In the RX formats, the second operand must be located on a fullword boundary. Example: DE This example divides the contents of floating-point register 4 by the contents of memory location LOC and places the result in floating-point register 4. Floating-point REG4 contains X'44FF FFFF' = dividend LOC contains X'0611 1111' = divisor # Assembler Notation Comments DE REG4, LCC DIVIDE (REG4) BY (LOC) Result of DE Instruction: (Floating-point REG4) = 7FF0 0000 (LOC) unchanged by this instruction Condition Code = 0010 # 6.5.13 Fix Register (FXR) | Assen | nbler Notation | Op-Code | Format | |-------|----------------|---------|--------| | FXR | R1,R2 | 2 E | RR | #### Operation R1 and R2 specify a general-purpose register and a floating-point register respectively. The normalized floating-point number contained in the floating-point register is converted to a two's complement notation integer value by shifting and truncating. The result is stored in the general register specified by R1. # Condition Code | | C | V | G | L | | |---|---|---|---|---|---------------------------------------| | | X | 0 | 0 | 0 | Result is zero or underflow | | | X | 0 | 0 | 1 | Result is less than zero | | | X | 0 | 1 | 0 | Result is greater than zero | | | X | 1 | 0 | 1 | Overflow, result is less than zero | | 1 | X | 1 | 1 | 0 | Overflow, result is greater than zero | # Programming Notes The range of floating-point magnitudes (M) that produces a nonzero integral result is: $+X^4880\ 0000^{\circ} M \ge +X^4110\ 0000^{\circ}$ Floating-point magnitudes greater than $+ X^{\circ}487F$ FFFF' or $- X^{\circ}4880$ 0000° cause overflow. The result is forced to $X^{\circ}7FFF$ FFFF' if positive, or to $X^{\circ}8000$ 0000° if negative. The V flag is set in the condition code along with either the G or L flag, depending on the sign of the result. Floating-point magnitudes less than +X'41100000' cause underflow, and the result is forced to zero. In the event of overflow or underflow, no arithmetic fault interrupt is taken, even if enabled in the current PSW. Example: FXR This example converts the contents of floating-point register 8 to a fixed-point number and places it in register 3. Floating-point REG8 contains X°46FF FF00° REG3 contains unknown data Assembler Notation Comments FXR REG3, REG8 CONVERT (REG8) TO FIXED-POINT Result of FXR Instruction (REG3) = 00FFFF00 (Floating-point REG8) unchanged by this instruction Condition Code = 0010 # 6.5.14 Float Register (FLR) | Asser | mbler Notation | Op-Code | Format | | |-------|----------------|---------|--------|--| | FLR | R1,R2 | 2 F | RR | | #### Operation R1 and R2 specify a floating-point register and a general-purpose register, respectively. The integer value contained in the general register specified by R2 is converted to a floating-point number and stored in the single-precision floating-point register specified by R1. ## Condition Code | C | V | G | L | |---|---|---|---| | X | 0 | 0 | 0 | | X | 0 | 0 | 1 | | X | 0 | 1 | 0 | Floating-point result is zero Floating-point result is less than zero Floating-point result is greater than zero # Programming Note The full range of fixed-point integer values can be converted to floating-point. The fixed-point value X'7FFF FFFF', the largest positive integer, converts to the floating-point value X'487F FFFF'. The fixed-point value X'8000 0000', the most negative integer, converts to the floating-point value X'C880 0000'. The result in R1 is normalized and truncated, if necessary, to fit in the six fraction digits. Example: FLP This example converts the fixed-point contents of Register 4 to a floating-point number and places it in floating-point register 8. REG4 contains X°7FFF FFF0° Floating-point REG8 contains unknown data # Assembler Notation Comments FLR REG8, REG4 CONVERT (REG4) TO FLOATING-POINT Result of FLR Instruction: (Floating-point REG8) = 487FFFFF (REG4) unchanged by this instruction Condition Code = 0010 # 6.5.15 Load Double-Precision Floating-Point (LD, LDR, LDGR) Load Couble-Precision Floating-Point (LD) Load Register Double-Precision Floating-Point (LDR) Load Couble-Precision Floating-Point Registers from General Registers (LDGR) | Assem | bler Notation | Op-Code | Format | |-------|------------------|---------|---------| | LD | R1,D2(X2) | 78 | RX1,RX2 | | LD | R1, A2(FX2, SX2) | 78 | RX3 | | LDR | R1,R2 | 38 | RR | | LDGR | R1,R2 | A 6 | RR | #### Operation The floating-point second operand is normalized, if necessary, and placed in the double-precision floating-point register specified by R1. # Condition Code | С | V | G | L | | |---|---|---|---|----------------------------------------------| | 0 | 0 | 0 | 0 | Double-precision result is zero | | 0 | 0 | 0 | 1 | Double-precision result is less than zero | | 0 | 0 | 1 | 0 | Double-precision result is greater than zero | | О | 1 | 0 | 0 | Exponent underflow | ## Programming Notes If the argument fraction is zero, the entire result is forced to zero, X°0000 0000 0000 0000°. Normalization can produce exponent underflow. If PSW bit 19 is set, the arithmetic fault interrupt is taken, and the register specified by R1 remains unchanged. If exponent underflow occurs, and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. In the RX formats, the second operand must be located on a fullword boundary. The R2 field for LDGR must specify the even member of an even/odd pair of general registers. The register specified by R2 contains the most significant 32 bits, and R2+1 contains the least significant 32 bits. If R2 is not an even numbered register, unpredictable results occur. # 6.5.16 Load Positive Double-Frecision Register (LPDR) | Assem | bler Notation | <u>op-Code</u> | Format | |-------|---------------|----------------|--------| | LPDR | R1,R2 | 33 | RR | # Operation The double-precision floating-point second operand contained in the double-precision floating-point register specified by R2 is forced positive. The result is normalized if necessary and placed in the double-precision floating-point register specified by R1. # Condition Code | С | V | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 0 | 1 | 0 | | 0 | 1 | 0 | 0 | Double-precision result is zero Double-precision result is greater than zero Exponent underflow # Programming Notes If the argument fraction is zero, the entire result is forced to zero, X°0000 0000 0000 0000°. Normalization of the result can produce exponent underflow. If PSW bit 19 is set, the arithmetic fault interrupt is taken, and the register specified by R1 remains unchanged. If exponent underflow occurs, and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. # 6.5.17 Load Complement Double-Precision Register (LCDR) | Assembler Notation | <u>Op-Code</u> | <b>Format</b> | |--------------------|----------------|---------------| | LCDR R1,R2 | 37 | RR | # Cperation The sign of the double-precision floating-point second operand contained in the double-precision floating-point register specified by R2 is complemented. The result is normalized if necessary and placed in the double-precision floating-point register specified by R1. #### Condition Code | С | V | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | | 0 | 0 | 1 | 0 | | 0 | 1 | 0 | 0 | Double-precision result is zero Double-precision result is less than zero Double-precision result is greater than zero Exponent underflow #### Programming Notes If the argument fraction is zero, the entire result is forced to zero, X°0000 0000 0000 0000°. Normalization may produce exponent underflow. If PSW bit 19 is set, the arithmetic fault interrupt is taken and the register specified by R1 remains unchanged. If an exponent underflow occurs and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1 in this case. # 6.5.18 Load Multiple Double-Precision Floating-Point (LMD) | Asse | mbler Notation | <u>Op-Code</u> | Format | | |------|-----------------|----------------|---------|--| | LMD | F1,D2(X2) | 7 F | RX1,RX2 | | | LMD | R1, A2(FX2,SX2) | 7 F | RX3 | | ## Operation Successive double-precision floating-point registers, starting with the register specified by R1, are loaded from successive fullword memory location pairs, starting with the address of the second operand. The process stops when double-precision floating-point register 14 has been loaded. Condition Code Unchanged Programming Notes Values loaded into the double-precision floating-point registers are assumed to be normalized, and no test or adjustment is performed. The second operand must be located on a fullword boundary. # 6.5.19 Load General Registers from Double-Precision Floating-Point Register (LGDR) | Assembler Notation | <u>Op-Code</u> | <u>Format</u> | |--------------------|----------------|---------------| | LGDR R1,R2 | 16 | RR | #### Operation The double-precision floating-point second operand, contained in the double-precision register specified by R2, is placed in the general register pair specified by R1. The second operand is unchanged. ## Condition Code | | | V | | | | |---|---|-----|---|---|-----------------------------| | 1 | 0 | 0 | 0 | 0 | Result is zero | | | 0 | 0 | 0 | 1 | Result is less than zero | | | 0 | 000 | 1 | 0 | Result is greater than zero | # Programming Notes The R1 field must specify the even member of the even/odd pair of general registers receiving the result. The even numbered register receives the most significant 32 bits while the next sequential odd numbered register receives the least significant 32 bits. If P1 and R2 do not specify even numbered registers, unpredictable results occur. ## 6.5.20 Store Double-Precision Floating-Point (STD) | Assembler Notation | | <u>Op-Code</u> | <b>Format</b> | |--------------------|-----------------|----------------|---------------| | STD | R1,D2(X2) | 70 | RX1,RX2 | | STD | R1, A2(FX2,SX2) | 70 | RX3 | # Operation The floating-point first operand, contained in the double-precision floating-point register specified by R1, is placed in the double word memory location specified by the second operand address. The first operand is unchanged. Condition Code Unchanged Programming Note The second operand must be located on a fullword boundary. # 6.5.21 Store Multiple Double-Precision Floating-Point (STMD) | Assemb | 1er Notation | <u>Op-Code</u> | <b>Format</b> | |--------|------------------|----------------|---------------| | STMD | R1,D2(X2) | 7 E | RX1,RX2 | | STMD | R1, A2(FX2, SX2) | 7 E | RX3 | ## Operation The contents of successive double-precision floating-point registers, starting with the even numbered register specified by R1, are stored in successive fullword memory location pairs, starting with the address of the second operand. The operation stops when the contents of double-precision floating-point register 14 have been stored. Condition Code Unchanged Programming Note The second operand must be located on a fullword boundary. 6.5.22 Add Double-Precision Floating-Point (AD, ADR) Add Double-Precision Floating-Point (AD) Add Register Double-Precision Floating-Point (ADR) | Asse | mbler Notation | Op-Code | Format | | |------|------------------|---------|---------|--| | A D | R1,D2(X2) | 7 A | RX1,RX2 | | | AD | R1, A2(FX2, SX2) | 7 A | RX3 | | | ADR | R1,R2 | 3 A | RR | | #### Operation The two operand exponents are compared. If the exponents differ, the fraction with the smaller exponent is shifted right hexadecimally (four bits at a time), and its exponent is incremented by one for each hexadecimal shift until the two exponents are equal. Hexadecimal digits are shifted through the guard digits to retain precision. The fractions are then added algebraically. If the addition of fractions produces a carry, the exponent of the result is incremented by one and the fraction of the result is shifted right one hexadecimal position. The carry bit is shifted back into the most significant hexadecimal digit of the fraction, producing a normalized result. This result is $R^*$ -rounded and replaces the contents of the double-precision floating-point register specified by R1. If the addition of fractions does not produce a carry, the result is normalized, if necessary, and placed in the double-precision floating-point register specified by R1. #### Condition Code | С | V | G | L | |------|-----|---|---| | C | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | | 0000 | 0 0 | 1 | 0 | | 0 | 1 | 0 | 1 | | 0 | 1 | 1 | 0 | | | | | | | 0 | 1 | 0 | 0 | Double-precision result is zero Double-precision result is less than zero Double-precision result is greater than zero Exponent cverflow, result is less than zero Exponent cverflow, result is greater than zero Exponent underflow Programming Notes When the addition of fractions produces a carry, incrementing the exponent of the result by one may produce exponent overflow. In this case, the arithmetic fault interrupt is taken and both operands remain unchanged. Normalization of the result can produce exponent underflow. If PSW bit 19 is set, an arithmetic fault interrupt is taken, and the register specified by R1 is unchanged. If exponent underflow occurs and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. Fastest results occur when the first operand is larger than the second operand. In the RX formats, the second operand must be located on a fullword boundary. # 6.5.23 Subtract Double-Precision Floating-Point (SD, SDR) Subtract Double-Precision Floating-Point (SD) Subtract Register Double-Precision Floating-Point (SDR) | Asser | mbler Notation | Op-Code | Format | | |-------|----------------|------------|---------|--| | SD | R1,D2(X2) | <b>7</b> B | RX1,RX2 | | | SD | R1,A2(FX2,SX2) | <b>7</b> B | RX.3 | | | SDR | R1,R2 | 3 B | RR | | # Cperation The two operand exponents are compared. If the exponents differ, the fraction with the smaller exponent is shifted right hexadecimally (four bits at a time), and its exponent is incremented by one for each hexadecimal shift, until the two exponents are equal. Hexadecimal digits are shifted through the guard digits to retain precision. The second operand fraction is then subtracted algebraically from the first operand fraction. If the subtraction of fractions produces a carry, the exponent of the result is incremented by one and the fraction of the result is shifted right one hexadecimal position. The carry bit is shifted back into the most significant hexadecimal digit of the fraction producing a normalized result. This result is R\*-rounded and replaces the contents of the double-precision floating-point register specified by R1. If the subtraction of fractions does not produce a carry, the result is normalized, if necessary, then R\*-rounded and placed in the double-precision floating-point register specified by R1. ## Condition Code | C | γ | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | | 0 | 0 | 1 | 0 | | 0 | 1 | 0 | 1 | | 0 | 1 | 1 | 0 | | 1 | | | | | 0 | 1 | 0 | 0 | Double-precision result is zero Double-precision result is less than zero Double-precision result is greater than zero Exponent overflow, result is less than zero Exponent overflow, result is greater than zero Exponent underflow # Programming Notes When the subtraction of fractions produces a carry, incrementing the exponent of the result by one may produce exponent overflow. In this case, the arithmetic fault interrupt is taken and the contents of R1 remain unchanged. Normalization of the result can produce exponent underflow. If PSW bit 19 is set, an arithmetic fault interrupt is taken, and the register specified by R1 is unchanged. If exponent underflow occurs and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. Fastest results occur when the first operand is larger than the second operand. In the RX formats, the second operand must be located on a fullword boundary. 6.5.24 Compare Double-Precision Floating-Point (CD, CDR) Compare Double-Precision Floating-Point (CD) Compare Register Double-Precision Floating-Point (CDR) | Asse | mbler Notation | Op-Code | Format | | |------|------------------|---------|---------|--| | CD | R1,D2(X2) | 79 | RX1,RX2 | | | CD | R1, A2(FX2, SX2) | 79 | RX3 | | | CDR | R1,R2 | 39 | RR | | # Operation The first and second operands are compared. Comparison is algebraic, taking into account the sign, exponent and fraction of each number. The result is indicated by the condition code setting. Neither operand is changed. # Condition Code | | С | V | G | L | | |---|---|---|---|-------|----------------------------------------------| | | 0 | X | 0 | 0 1 0 | First operand is equal to second operand | | I | 1 | X | 0 | 1 | First operand is less than second operand | | l | 0 | X | 1 | 0 | First operand is greater than second operand | # Programming Notes The state of the overflow flag is undefined. In the RX formats, the second operand must be located on a fullword boundary. 6.5.25 Multiply Double-Precision Floating-Point (MD, MDR) Multiply Double-Precision Floating-Point (MD) Multiply Register Double-Precision Floating-Point (MDR) | Asser | bler Notation | Op-Code | Format | | |-------|------------------|---------|---------|--| | MD | R1,D2(X2) | 7 C | RX1,RX2 | | | MD | R1, A2(FX2, SX2) | 7C | RX3 | | | MDR | R1,R2 | 3C | RR | | #### Operation The exponents of the two operands, as derived from the excess-64 notation used in floating-point representation, are added to produce the exponent of the result. This exponent is converted back to excess-64 notation. The fractions are then multiplied. If the product is zero, the entire double-precision value is forced to zero, X°0000 0000 0000 0000°. If the product is not zero, the result is normalized, if necessary. The sign of the result is determined by the rules of algebra. The R\*-rounded result replaces the contents of the double-precision floating-point register specified by R1. #### Condition Code | | С | V | G | L | | |---|-------|------|-------|---|--| | i | 0 | 0 | 0 | 0 | | | | 0 | 0 | 0 0 1 | 1 | | | | 0 | 0001 | 1 | 0 | | | i | 00000 | 1 | 0 | | | | | 0 | 1 | 1 | 0 | | | | | | | | | | | 0 | 1 | 0 | 0 | | Double-precision result is zero Double-precision result is less than zero Double-precision result is greater than zero Exponent overflow, result is less than zero Exponent overflow, result is greater than zero Exponent underflow #### Programming Notes Multiplication of two 14-hexadecimal-digit fractions effectively produces a result of 14 hexadecimal digits and a number of guard digits. The guard digits participate in the R\*-rounding of the final result. The addition of exponents may produce exponent overflow. In this case, an arithmetic fault interrupt is taken and both operands remain unchanged. Normalization of the result can produce exponent underflow. If PSW bit 19 is set, an arithmetic fault interrupt is taken, and the register specified by R1 is unchanged. If exponent underflow occurs and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. In the RX formats, the second operand must be located on a fullword boundary. Fastest results occur when the second operand multiplier contains sets of 4 or more contiguous ones or zeros. 6.5.26 Divide Double-Precision Floating-Point (DD, DDR) Divide Double-Precision Floating-Point (DD) Divide Register Double-Precision Floating-Point (DDR) | Asset | mbler Notation | Op-Code | Format | | | |-------|----------------|------------|---------|--|--| | DD | R1,D2(X2) | 7 E | RX1,RX2 | | | | DD | R1,A2(FX2,SX2) | <b>7</b> D | RX3 | | | | DDR | R1,R2 | 3D - | RR | | | #### Operation The exponents of the two operands, as derived from the excess-64 notation used in floating-point representation, are subtracted to produce the exponent of the result. This exponent is converted back to excess-64 notation. The first operand fraction is then divided by the second operand fraction. Division continues until the quotient is normalized, adjusting the exponent for each additional division required. No remainder is returned. The sign of the result is determined by the rules of algebra. The R\*-rounded quotient replaces the contents of the double-precision floating-point register specified by R1. #### Condition Code | | С | V | G | L | | |---|---|---|---|---|----------------------------------------------| | ı | 0 | 0 | 0 | 0 | Double-precision result is zero | | I | 0 | 0 | 0 | 1 | Double-precision result is less than zero | | | 0 | 0 | 1 | 0 | Double-precision result is greater than zero | | | 0 | 1 | 0 | 1 | Exponent cverflow, result is less than zero | | | 0 | 1 | 1 | 0 | Exponent overflow, result is greater than | | | | | | | zero | | | 0 | 1 | 0 | 0 | Exponent underflow | | | 1 | 1 | 0 | 0 | Divisor equal to zero | | | | L | L | | | #### Programming Notes Before starting the divide operation, the divisor is checked. If it is equal to zero, the operation is aborted, and the arithmetic fault interrupt is taken. Neither operand is changed. The subtraction of exponents may produce exponent overflow. In this case, an arithmetic fault interrupt is taken and both operands remain unchanged. Subtraction of exponents or the division process can produce exponent underflow. Normalization of the result can produce exponent underflow. If PSW bit 19 is set, an arithmetic fault interrupt is taken, and the register specified by R1 is unchanged. If exponent underflow occurs and bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. The 14-hexadecimal-digit first operand fraction is divided by the 14-hexadecimal-digit second operand fraction, effectively producing the 14-hexadecimal-digit quotient along with a number of guard digits. The guard digits participate in the R\*-rounding of the final result. In the RX formats, the second operand must be located on a fullword boundary. #### 6.5.27 Fix Register Double-Precision (FXDR) | Assemb | ler Notation | Op-Code | Format | |--------|--------------|---------|--------| | FXDR | R1,R2 | 3E | RR | #### Operation R1 and R2 specify a general purpose register and a double-precision floating-point register, respectively. The normalized floating-point number contained in the floating-point register is converted to an integer value by shifting and truncating. The result is placed in the general register specified by R1. #### Condition Code | С | V | G | L | |---|---|---|---| | X | 0 | 0 | 0 | | X | 0 | 0 | 1 | | X | 0 | 1 | 0 | | X | 1 | 0 | 1 | | X | 1 | 1 | 0 | Result is zero or underflow Result is less than zero Result is greater than zero Overflow, result is less than zero Overflow, result is greater than zero #### Programming Notes The range of the floating-point magnitude (M) that produces a nonzero integral result is: + X°4880 0000 0000 0000° ≥ M ≥ + X°4110 0000 0000 0000° Double-precision floating-point magnitudes greater than +X°487F FFFF FFFF or -X°4880 0000 0000 0000° cause overflow. The result is forced to X°7FFF FFFF° if positive or to X°8000 0000° if negative. The V flag is set in the condition code along with either the G or L flag, depending on the sign of the result. Double-precision floating-point magnitudes less than $+X^{\circ}4110~0000~0000^{\circ}$ cause underflow, and the result is forced to zero. In the event of overflow or underflow, no arithmetic fault interrupt is taken even if enabled in the current PSW. ### 6.5.28 Float Register Double-Precision (FLDR) | Assemb | ler Notation | Op-Code | Format | | |--------|--------------|---------|--------|--| | FLDR | R1,R2 | 3F | RR | | #### Operation R1 and R2 specify a double-precision floating-point register and a general purpose register, respectively. The integer value contained in the general register specified by R2 is converted to a floating-point number and placed in the double-precision floating-point register specified by R1. #### Condition Code | C | ٧ | G | L | |---|---|---|---| | X | 0 | 0 | 0 | | X | 0 | 0 | 1 | | X | 0 | 1 | 0 | Double-precision result is zero Double-precision result is less than zero Double-precision result is greater than zero #### Programming Notes The full range of fixed-point integer values may be converted to double-precision floating-point. The fixed-point value X°7FFF FFFF, the largest positive integer, converts to a double-precision floating-point value of X°487F FFFF FF00 0000°. The fixed-point value X°8000 0000°, the most negative integer, converts to a double-precision floating-point value of X°C880 0000 0000 0000°. The result in R1 is normalized. 6.5.29 Load Single-Precision Floating-Point Register From Double (LED, LEDR) Load Single-Precision Floating-Point Register from Double-Precision Memory (LED) Load Single-Precision Floating-Point Register from Double-Precision Register (LEDR) | Assemb | oler Notation | Op-Code | <b>Format</b> | |--------|-------------------|---------|---------------| | LED | R1,D2(X2) | 84 | RX1,RX2 | | LED | R1, A2 (FX2, SX2) | 8 4 | RX3 | | LEDR | R1,R2 | A 4 | RR | #### Operation Double-precision floating-point data from the second operand location is R\*-rounded to single-precision accuracy, and placed in the single-precision floating-point register specified by R1. #### Condition Code | С | V | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | | 0 | 0 | 1 | 0 | | 0 | 1 | 0 | 0 | | 0 | 1 | 0 | 1 | | 0 | 1 | 1 | 0 | Floating-point result is zero Floating-point result is less than zero Floating-point result is greater than zero Exponent underflow Exponent overflow, result is less than zero Exponent overflow, result is greater than zero #### Programming Notes R1 and R2 must specify even-numbered registers. Rounding of the result may cause exponent overflow. In this case, the register specified by R1 is unchanged, and the arithmetic fault interrupt is taken. Normalization of the result may produce exponent underflow. If enabled by PSW bit 19, the arithmetic fault interrupt is taken, and the register specified by R1 remains unchanged. If bit 19 of the current PSW is zero, zeros replace the contents of the register specified by R1. In the RX formats, the second operand must be located on a fullword boundary. 6.5.30 Load Double-Precision Floating-Point Register From Single (LDE, LDER) Load Double-Precision Floating-Point Register from Single-Precision Memory (LDE) Load Double-Precision Floating-Point Register from Single-Precision Register (LDER) | Assem | bler Notation | Op-Code | <u>Format</u> | | | |-------|------------------|-----------|---------------|--|--| | LDE | R1,D2(X2) | 87 | RX1,RX2 | | | | LDE | R1, A2(FX2, SX2) | 87 | RX3 | | | | LDER | R1,R2 | <b>A7</b> | RR | | | #### Operation Single-precision floating-point data from the second operand location is converted to double-precision data by appending trailing zeros. The result replaces the contents of the double-precision floating-point register specified by R1. #### Condition Code | C | V | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | | 0 | 0 | 1 | 0 | | 0 | 1 | 0 | 0 | Double-precision result is zero Double-precision result is less than zero Double-precision result is greater than zero Exponent underflow ## Programming Notes The registers specified by R1 and R2 must be even-numbered registers. Normalization of the result may produce exponent underflow. If enabled by PSW bit 19, the arithmetic fault interrupt is taken, and the register specified by R1 remains unchanged. If bit 19 of the current PSW is zero, no arithmetic fault occurs. Zeros replace the contents of the register specified by R1. In the RX formats, the second operand must be located on a fullword boundary. ## 6.5.31 Store Double-Precision Floating-Point Register in Single-Precision Memory (STDE) | Assem | bler Notation | Op-Code | Format | | | |-------|----------------|---------|---------|--|--| | STDE | R1,D2(X2) | 82 | RX1,RX2 | | | | STDE | R1,A2(FX2,SX2) | 82 | RX3 | | | #### Operation Data from the double-precision floating-point register specified by R1 is R\*-rounded to single-precision accuracy, and stored in the fullword second operand location. Condition Code Unchanged Programming Notes The register specified by R1 must be an even-numbered register. Normalization of the rounded result may produce exponent underflow. In this case, zero, X'0000 0000', replaces the contents of the second operand location. Rounding of the result may cause exponent overflow. In this case, the contents of the second operand location remain unchanged, and the arithmetic fault interrupt is taken. The second operand must be located on a fullword boundary. # CHAPTER 7 STRING OPERATIONS #### 7.1 INTRODUCTION String operations deal with operands that are strings of consecutive bytes in memory beginning and ending on byte boundaries. Information contained in such a string may represent packed decimal data or ASCII character information including unpacked decimal data. #### 7.2 DECIMAL DATA FORMAT DEFINITIONS Decimal operands can be in either packed or unpacked (zoned) format. The decimal operands are considered as right-aligned integers. The address of a decimal operand specifies the address of the left-most or most significant byte of the operand. #### 7.2.1 Packed Decimal A number represented in packed decimal format is a fixed-point, signed integer, and consists of from 1 to 16 consecutive bytes. (See Figure 7-1.) Each byte is divided into two digit fields; thus each byte, except for the right-most in the string, contains two decimal digits represented in binary code. The only values allowed in a decimal digit field are 0 through 9. The right-most byte in the string contains the least significant decimal digit and the sign digit. $$D_1, D_2, D_3, \dots D_{30}, D_{31} = DECIMAL DIGITS$$ S = SIGN DIGIT Figure 7-1 Packed Decimal Format There are two standard values for the sign S: hexadecimal C for plus and hexadecimal D for minus. However, the hexadecimal values 3, A, E, and F are also recognized for plus, and hexadecimal B is recognized for minus. Other values, O through 2 and 4 through 9, are illegal in the S position. A packed decimal number contains an odd number of decimal digits. The most significant digit (zero or nonzero) of the number is in bit positions 0-3 of the left-most byte. The least significant digit occupies bit positions 0-3 of the right-most byte of the string, immediately preceding the sign digit, S. Any unused digit at the beginning of the string is filled with a leading zero. ## 7.2.2 Unpacked (Zoned) Decimal A number represented in unpacked decimal format is a fixed-point signed integer, and consists of from 1 to 31 consecutive bytes. (See Figure 7-2.) Each byte, with the exception of the right-most byte, is assumed to contain the 7-bit ASCII equivalent of a decimal digit. Thus, the top four bits contain zone information and the bottom four bits in each byte contain the binary equivalent of a decimal digit from 0 through 9. When the processor generates an unpacked decimal byte string, the zone digit is always '3'. However, any zone value is accepted in an unpacked decimal operand, since the zone has no effect on the operation of the instructions and is not examined. In the right-most byte of the string, S is the sign digit. Acceptable values for the sign digit are the same as those defined for packed decimal data. | 612 | BYTE 1 | | BYTE | 2 | ВҮТ | E 3 | 1,, | BYTE | 29 | BYTE | 30 | BYTE | ≣31 <b> </b> | |-----|-------------------------------------------|----------------|---------------------|-------------------|------|----------------|--------------------|-------|-----------------|------|-----------------|------|-----------------| | | ZONE | D <sub>1</sub> | ZONE | D <sub>2</sub> | ZONE | D <sub>3</sub> | Γ', | ZONE | D <sub>29</sub> | ZONE | D <sub>30</sub> | S | D <sub>31</sub> | | | | | | | | | <del></del> /) | | | | | | | | | ZONE<br>D <sub>1</sub> ,D <sub>2</sub> ,D | | ے,,D <sub>2</sub> ر | .,D <sub>2.</sub> | = | | IE DIGIT<br>IMAL D | | | | | | | | | s 1,52,53. | | | 3 30 | J 31 | = | | DIGIT | | | | | | Figure 7-2 Unpacked Decimal Format The most significant digit of an unpacked decimal number occupies the left-most byte of the string. The least significant digit occupies the right-most byte of the string. #### 7.3 DECIMAL AND ALPHANUMERIC STRING INSTRUCTION FORMATS The two binary/decimal conversion instructions use the standard RX format. The remaining string operations use the RXRX format. In the instruction descriptions, the RXRX format is diagrammed as follows: OP $$\begin{cases} R1 \\ =L1 \end{cases}$$ , $\begin{cases} D2 (X2) \\ A2 (FX2,SX2) \end{cases}$ , $\begin{cases} R1 \\ =L2 \end{cases}$ , $\begin{cases} L2 (X2) \\ A2 (FX2,SX2) \end{cases}$ where any field may have either one of the options shown in the braces. R1/=L1 refers to the first operand length and R2/=L2 refers to the second operand length. Length of operand strings is always expressed as a number of bytes. These can vary from 0 to 15 for immediate length formats, and from 0 to maximum memory for register length. See Section 1.8.11 for further details of the RXRX instruction format. #### 7.4 STRING INSTRUCTIONS The string instructions are interruptible, and use the scratchpad registers. If an interrupt occurs during the execution of a string instruction, bit 14 (IIP) is set by the processor in the old PSW to indicate that the scratchpad registers contain information pertinent to the interrupted instruction. See Section 10.3.4 for further information. The instructions described in this section are: LPB Load Packed Decimal String as Binary (convert from decimal to binary) STBP Store Binary as Packed Decimal String (convert from binary to decimal) MVTU Move Translated Until MOVE Move and Pad MOVEP Move and Pad with Default Pad CPAN Compare Alphanumeric CPANP Compare Alphanumeric with Default Pad PMV Pack and Move (convert unpacked decimal string to packed decimal string) PMVA Pack and Move Absolute (force positive result) UMV Unpack and Move (convert packed decimal string to unpacked decimal string) UMVA Unpack and Move Absolute (force positive result) # 7.4.1 Load Packed Decimal String as Binary (LPB) | Asse | mbler Notation | Op-Code | Format | |------|------------------|---------|---------| | | R1,D2(X2) | 6 F | RX1,RX2 | | TAR | R1, A2(FX2, SX2) | 6 F | RX3 | #### Operation The second operand address points to the left-most byte of a packed decimal string of length sixteen bytes (31 packed decimal digits plus sign). Digits of the operand are checked for validity as the operand is converted to a 64-bit, two's complement binary number. The result replaces the contents of the even/odd general register pair specified by R1 and R1+1. #### Condition Code | C | V | G | L | | |---|---|---|---|-----------------------------| | 0 | 0 | 0 | 0 | Result is zero | | 0 | 0 | 0 | 1 | Result is less than zero | | 0 | 0 | 1 | 0 | Result is greater than zero | | 0 | 1 | 0 | 0 | Overflow | ## Programming Notes This instruction is interruptible. R1 must specify an even-numbered register. If not, unpredictable results occur. If an illegal decimal digit or sign digit is detected during conversion, the registers specified by R1 and R1+1 remain unchanged, and a data format fault interrupt is taken. The largest positive number that can be processed without overflow is 9,223,372,036,854,775,807. ## 7.4.2 Store Binary As Packed Decimal String (STBP) | Assem | bler Notation | <u>Op-Code</u> | Format | |-------|------------------|----------------|---------| | STBP | R1,D2(X2) | 6 E | RX1,RX2 | | | R1, A2(FX2, SX2) | 6 E | RX3 | #### Operation The contents of the even/odd general register pair specified by R1 and R1+1 are converted and stored in memory as a packed decimal string of length 16 bytes (31 packed decimal digits plus sign). The left-most byte is stored at the address specified by the second operand. ## Condition Code | С | ٧ | G | L | | |-----|---|---|---|-----------------------------| | 0 | 0 | 0 | 0 | Result is zero | | 0 0 | 0 | 0 | 1 | Result is less than zero | | 0 | 0 | 1 | 0 | Result is greater than zero | ### Programming Notes This instruction is interruptible. R1 must specify an even-numbered register. If not, unpredictable results occur. ## 7.4.3 Move Translated Until (MVTU) | Assembler Notation | | Function<br>Code | Format | |--------------------|-----|------------------|--------| | | 8 C | 00 | RXRX | #### Operation General register 0 contains the escape character whose occurrence causes the instruction to terminate. General register 2 contains the address of a translation table. This translation table is a simple list of 256 single byte entries, not to be confused with the table used by the translate instruction. The first operand string begins at the address specified by the first operand address. The length of this string is equal to either the contents of the register specified by R1, or the value of L1. The second operand string begins at the address specified by the second operand address. The length of this string is equal to either the contents of the register specified by R1, or the value of L2. Successive bytes from the second operand string are moved to the first operand string, as follows: - 1. A byte is fetched from the second operand string (this is the argument byte). The contents of general register 2 are tested. If general register 2 contains zero, no translation occurs. If general register 2 does not contain zero, it contains the address of a translation table of maximum size 256 bytes. In this case, the argument byte fetched from the second operand string is used as an index into the translation table, and the byte at the resulting address is fetched and used as the argument byte. - 2. The argument byte is compared with the escape character contained in bits 24:31 of general register 0. If the bytes are the same, the C flag is set in the condition code, and the instruction terminates. Otherwise, the argument byte is stored in the first operand string, and the next successive byte is processed. This operation is repeated until either the escape character is encountered, the first operand string has been filled, or the second operand string has been exhausted. - 3. When the instruction terminates, the address of the next byte to be moved from the second operand string is returned in general register 1. #### Condition Code | ſ | С | V | G | L | |---|---|---|---|---| | Γ | 0 | 0 | 0 | 0 | | 1 | 0 | 1 | 0 | 0 | | ١ | | | | | | ı | 1 | 0 | 0 | 0 | Entire string moved First operand filled before entire string moved Escape character encountered ## Programming Notes This instruction is interruptible. The contents of general register 1 may change during instruction execution, but are not valid until instruction termination. Bytes are moved from the second operand string to the first operand string in a left-to-right sequence. If the strings overlap, such that the source is to the left of the destination, unpredictable results occur. ## 7.4.4 Move (MOVE, MOVEP) Move and Pad (MOVE) Move and Pad with Default Pad (MOVEP) | | Assembler Notation | | Function Code | Format | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------|--------| | MOVE | $ \begin{cases} R1 \\ =L1 \end{cases}, \begin{cases} D2(X2) \\ A2(FX2,SX2) \end{cases}, \begin{cases} R2 \\ =L2 \end{cases}, \begin{cases} D2(X2) \\ A2(FX2,SX2) \end{cases} $ | ) 8C | 01 | RXRX | | MOVEP | $ \begin{cases} R1 \\ =L1 \end{cases}, \begin{pmatrix} D2(X2) \\ A2(FX2,SX2) \end{pmatrix}, \begin{pmatrix} R2 \\ =L2 \end{pmatrix}, \begin{pmatrix} D2(X2) \\ A2(FX2,SX2) \end{pmatrix} $ | ) 8C | 21 | RXRX | ## Operation The first operand string begins at the address specified by the first operand address and has a length equal either to the contents of the register specified by R1, or to the value of L1. The second operand string begins at the address specified by the second operand address and has a length equal either to the contents of the register specified by R2, or to the value of L2. Successive bytes from the second operand string are moved to the first operand string. If the second operand string is exhausted before the first operand string is filled, the remaining bytes in the first operand string are filled using the pad character. If MOVE is specified, the pad character is contained in bits 24:31 of general register 0. If MOVEP is specified, the remainder of the first operand is filled with ASCII space characters (X°20°). If the first operand string is filled before the second operand string is exhausted, overflow results, and the operation is terminated. When the instruction terminates, the address of the next byte to be moved from the second operand string is returned in general register 1. #### Condition Code | С | ٧ | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 1 | 0 | 0 | Entire string moved First operand filled before entire string moved #### Programming Notes These instructions are interruptible. The contents of general register 1 may change during instruction execution, but are not valid until instruction termination. If MCVEP is specified, the contents of general register 0 are ignored. Bytes are moved from the second operand string to the first operand string in a left-to-right sequence. If the strings overlap such that the source is to the left of the destination, unpredictable results occur. ## 7.4.5 Compare (CPAN, CPANP) Compare Alphanumeric (CPAN) Compare Alphanumeric with Default Pad (CPANP) | - | Assembler Notation | | Function<br>Code | Format | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------|--------| | CPÀN | $ \begin{cases} R1 \\ =L1 \end{cases} \begin{pmatrix} D2(X2) \\ A2(FX2,SX2) \end{pmatrix} , \begin{pmatrix} R2 \\ =L2 \end{pmatrix} \begin{pmatrix} D2(X2) \\ A2(FX2,SX2) \end{pmatrix} $ | 8C | 02 | RXRX | | CPANP | $ \begin{cases} R1 \\ =L1 \end{cases}, \begin{cases} D2(X2) \\ A2(FX2,SX2) \end{cases}, \begin{cases} R2 \\ =L2 \end{cases}, \begin{cases} D2(X2) \\ A2(FX2,SX2) \end{cases} $ | 8 C | 22 | RXRX | ### Operation The first operand string begins at the address specified by the first operand address and has a length equal either to the contents of the register specified by R1, or to the value of L1. The second operand string begins at the address specified by the second operand address and has a length equal either to the contents of the register specified by R2, or to the value of L2. The two strings are compared a byte at a time until the first unequal byte pair is found, or until the length of both strings is exhausted. If the strings are of unequal length, the shorter string is logically extended to the length of the longer string. If CPAN is specified, this is done by using the pad character contained in bits 24:31 of general register 0. If CPANP is specified, the ASCII space character (X°20°) is used as the default pad character. Upon termination, general register 1 is set equal to one less than the number of second operand bytes that successfully matched corresponding bytes in the first operand string. This count (or offset) includes pad characters if the second operand string was longer than the first. For example, a first operand string of length three bytes contains the characters ABC. A second operand string of length six bytes contains the characters ABCDDD. A CPANP instruction returns a condition code of 0001 (first operand string less than second operand string) and general register 1 is set equal to 2. The first nonmatching character was the character 'D' in the second operand string. Given the same operand strings, a CPAN instruction with general register 0 set equal to a pad character of 'D' returns a condition code of 0000 (strings are equal including pad characters) and general register 1 is set equal to 5. #### Condition Code | Γ | С | ٧ | G | L | |---|---|---|-----|---| | Γ | 0 | 0 | 0 1 | 0 | | | 0 | 0 | 1 | 0 | | | | | | | | | 1 | 0 | 0 | 1 | Strings are equal First operand string greater than second operand string First operand string less than second operand string #### Programming Notes If CPANP is specified, the contents of general register 0 are ignored. If CPAN is specified, bits 0:23 of general register 0 are ignored. These instructions are interruptible. ## 7.4.6 Pack and Move (PMV, PMVA) Pack and Move (PMV) Pack and Move Absolute (PMVA) | Assem | bler Notation | | Function<br>Code | Format | |-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------------------|--------| | PMV | $ \begin{cases} R1 \\ =L1 \end{cases}, \begin{pmatrix} D2(X2) \\ A2(FX2,SX2) \end{pmatrix}, \begin{pmatrix} R2 \\ =L2 \end{pmatrix}, \begin{pmatrix} D2(X2) \\ A2(FX2,SX2) \end{pmatrix} $ | )} 8C | 03 | RXRX | | PMVA | $ \begin{cases} R1 \\ =L1 \end{cases}, \begin{cases} D2(X2) \\ A2(FX2,SX2) \end{cases}, \begin{cases} R2 \\ =L2 \end{cases}, \begin{cases} D2(X2) \\ A2(FX2,SX2) \end{cases} $ | ) 8C | 23 | RXRX | #### Operation The first operand string begins at the address specified by the first operand address. The length of this string in bytes is one greater than either the contents of the register specified by R1, or the value of L1. The second operand string begins at the address specified by the second operand address. The length of this string in bytes is one greater than either the contents of the register specified by R1, or the value of L2. The second operand string consists of unpacked decimal data digits with a sign digit. Data in this string is packed and replaces the first operand string. Leading zeros are supplied as required to fill the higher-order positions of the first operand string. #### Condition Code | С | V | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | X | 0 | 1 | | 0 | X | 1 | 0 | | 0 | 1 | X | X | | 1 | X | X | X | Result is zero Result is less than zero Result is greater than zero Overflow Invalid digit in second operand string Programming Notes PMVA causes the sign digit of the first operand string to be forced positive. Overflow occurs if the length of the first operand string is not sufficient to contain the packed representation of the second operand string. The V flag is set in the condition code, and the specified number of digits in the first operand string receive packed data from the second operand string. Higher-order digits of packed data are lost in this case. Leading zero digits do not cause overflow. They are truncated if necessary. These instructions are interruptible instructions. Since packing is done conceptually from right to left with any overlapping allowed, the instruction PMV can be used to check the validity of decimal data. If the destination string is to the left of the source string, such that the signed byte of the destination string is taken as data from the source string, the sign digit is found to be an illegal data digit, and the C flag is set at completion of the instruction. ## 7.4.7 Unpack and Move (UMV, UMVA) Unpack and Move (UMV) Unpack and Move Absolute (UMVA) | | Assembler Notation | | Function Code | Format | |------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------------|--------| | UM V | ${R1 \atop =L1}, {D2(X2) \atop A2(FX2,SX2)}, {R2 \atop =L2}, {D2(X2) \atop A2(FX2,SX2)}$ | 8C | 04 | RXRX | | UMVA | $ \begin{cases} R1 \\ = L1 \end{cases} \begin{cases} D2(X2) \\ A2(FX2,SX2) \end{cases} \begin{cases} R2 \\ = L2 \end{cases} \begin{cases} D2(X2) \\ A2(FX2,SX2) \end{cases} $ | 8 C | 24 | RXRX | #### Operation The first operand string begins at the address specified by the first operand address. The length of this string in bytes is one greater than either the contents of the register specified by R1, or the value of L1. The second operand string begins at the address specified by the second operand address. The length of this string in bytes is one greater than either the contents of the register specified by R2, or the value of L2. The second operand string consists of packed decimal data digits with a sign digit. Data in this string is unpacked and replaces the first operand string. Leading zeros are supplied as required to fill the higher-order positions of the first operand string. #### Condition Code | С | V | G | L | | |---|---|---|---|----------------------------------------| | 0 | 0 | 0 | 0 | Result is zero | | 0 | X | 0 | 1 | Result is less than zero | | 0 | X | 1 | 0 | Result is greater than zero | | 0 | 1 | X | X | Overflow | | 1 | X | Х | X | Invalid digit in second operand string | #### Programming Notes UMVA causes the sign digit of the first operand string to be forced positive. Overflow occurs if the length of the first operand string is not sufficient to contain the unpacked representation of the second operand string. The V flag is set in the condition code, and the specified number of digits in the first operand string receive unpacked data from the second operand string. Higher-order digits of unpacked data are lost in this case. Leading zero digits do not cause overflow. They are truncated if necessary. These instructions are interruptible instructions. Since unpacking is done conceptually from right to left with any overlapping allowed, the instruction UMV can be used to check the validity of decimal data. If the destination string is to the left of the source string, such that the signed byte of the destination string is taken as data from the source string, the sign digit is found to be an illegal data digit, and the C flag is set at the completion of the instruction. # CHAPTER 8 HIGH SPEED DATA HANDLING INSTRUCTIONS (OPTIONAL) #### 8.1 INTRODUCTION The data handling instructions are used to compute polynomial error check redundancy characters, as used by most data communications protocols. Communications protocols supported by this option include, but are not limited to, the following: - 1. Binary Synchronous Communications (BISYNC or BSC) IBM's widely accepted half-duplex protocol uses the CRC BISYNC error check polynomial ( $x^{16} + x^{15} + x^2 + 1$ ). - 2. Synchronous Data Link Control (SDLC) IBM's new full-duplex protocol uses the CRC SDLC error check polynomial ( $x^{16} + x^{12} + x^{13} x^{$ - 3. Advanced Data Communications Control Procedure (ADCCP) ANSI's proposed National Standard full-duplex protocol uses CRC SDLC. - 4. High Level Data Link Control (HDLC) The International Standard Organizations full-duplex protocol uses CRC SDLC. #### 8.2 DATA HANDLING INSTRUCTION FORMATS The optional data handling instructions use the Register to Register (RR), and the Register and Indexed Storage (RX) formats. #### 8.3 DATA HANDLING INSTRUCTIONS PB Process Byte PBR Process Byte Register ## 8.3.1 Process Byte (PB) | Asse | mbler Notation | Op-Code | Format | |------|----------------|---------|----------| | PB | R1,D2(X2) | 62 | RX1, RX2 | | PB | R1,A2(FX2,SX2) | 62 | RX3 | Set-Up | 615 | 0 7 | 8 15 | 16 23 | 24 31 | |-----|-----|------------|-------|-----------| | R1 | X | CHECK CODE | X | DATA BYTE | Bits 24:31 of the register specified by R1 contain the data byte to be processed. Bits 8:15 of the register specified by R1 contain a check code to indicate the type of processing. This byte is interpreted as follows: X'00' Cumulative check zerc (CRC BISYNC) X'01' Cumulative check one (CRC SDLC) X°02° Cumulative check two (LRC) The second operand address points to a halfword residual checksum to be included in the cumulative check. ### Operation If CRC BISYNC is specified, the data byte and the old residual checksum participate in the generation of a new residual checksum based on the evaluation of the polynomial ( $x^{16} + x^{15} + x^2 + 1$ ). If CRC SDLC is specified, a similar operation is performed, using the polynomial $(x^{16} + x^{12} + x^5 + 1)$ . In both of these cases, the new residual checksum replaces the old residual checksum at the second operand location. If LRC is specified, the Exclusive-OR of the data byte with the old residual checksum replaces the old residual checksum at the second operand location. Condition Code Unchanged Programming Notes Bits 0:7 and 16:23 of the register specified by R1 are ignored. The register specified by R1 remains unchanged. The second operand must be located on a halfword boundary. Undefined check codes should not be used. If they are, the results are undefined. Example: PB This example performs a Process Byte instruction and stores the residue in RESIDUE. Register 1 contains X'0001007A' where: 01 = CRC SDLC 7A = DATA BYTE RESIDUE contains X'DO53' = old residue Assembler Notation Comments PB R1, RESIDUE RESIDUE on halfword boundary Result of PB Instruction (R1) unchanged by this instruction (RESIDUE) = X'BC13' = new residue Condition Code unchanged by this instruction ## 8.3.2 Process Byte Register (PBR) | - | Assembler Notation | | Op-Code Form | | nat | | | |-----|--------------------|---|--------------|----|----------|-----------|----| | | PBR R1,R2 | | 32 R | | RE | ₹ | | | 616 | Set-Up | | | | | | | | 1 | 0 7 | 8 | 15 | 16 | 23 | 24 | 31 | | R1 | х | | CHECK CODE | х | | DATA BYTE | | | R2 | 0 | | | RE | SIDUAL C | HECKSUM | | Bits 24:31 of the register specified by R1 contain the data byte to be processed. Bits 8:15 of the register specified by R1 contain a check code indicating the type of processing. This byte is interpreted as follows: X'00' Cumulative check zero (CRC BISYNC) Cumulative check one (CRC SDLC) X'02' Cumulative check two (LRC) The second operand is a fullword contained in the register specified by R2. Bits 16:31 of the second operand contain the residual checksum to be included in the processing. ### Operation If CRC BISYNC is specified, the data byte and the old residual checksum participate in the generation of a new residual checksum, based on the evaluation of the polynomial ( $x^{16} + x^{15} + x^2 + 1$ ). If CRC SDLC is specified, a similar operation is performed, using the polynomial ( $x^{16} + x^{12} + x^5 + 1$ ). In both these cases, the new residual checksum replaces the contents of bits 16:31 of register specified by R2. If LRC is specified, the Exclusive-OR of the data byte with the old residual checksum replaces the old residual checksum in the second operand. #### Condition Code #### Unchanged #### Programming Notes Bits 0:7 and 16:23 of the register specified by R1 are ignored. The register specified by R1 remains unchanged. Bits 0:15 of the register specified by R2 are not used and must be zero. Undefined check codes should not be used. If they are, the results are undefined. # CHAPTER 9 INPUT/OUTPUT OPERATIONS ## 9.1 INTRODUCTION AND CONFIGURATION OF I/O SYSTEM Input/Output (I/O) operations, as defined for the processor, provide a versatile means for the exchange of information between the processor, memory, and external devices. Communication between the processor and external devices is accomplished over the I/O bus. Data transfers over the I/O bus require processor intervention, either programmed or automatic, for each item transferred. Direct data transfers between external devices and memory are accomplished over the DMA Bus, and proceed independently of the processor so other program processing can proceed simultaneously. #### 9.2 DEVICE CONTROLLERS #### 9.2.1 Function The basic function of a device controller is: - 1. To provide synchronization with the processor - 2. To provide device address recognition - 3. To transmit operational commands from the processor to the device - 4. To translate device status into meaningful information for the processor - 5. To request processor attention when required In addition, a controller may generate parity; convert serial data to parallel; buffer incoming or outgoing data; or perform other device-dependent functions. # 9.2.2 Device Addressing The system design allows as many as 1,023 external devices. Each device must have its own address or device number, ranging from X°001° through X°3FF°. (Device number X°000° is not assigned.) The minimum system provides for 255 device numbers. Larger systems may have either 511 or 1,023. # 9.2.3 Processor/Controller Communication Device controllers may communicate with the processor either directly, using the I/O bus, or indirectly through a selector channel. Communication between the processor and controller is a bidirectional, request/response operation. The processor can initiate communication by sending the device number out onto the I/O bus. When a controller recognizes that number as its address, it returns a synchronization signal to the processor and remains ready to accept commands from the processor. The processor waits up to 40 microseconds for the synchronization signal. If no signal is received within this period, the processor aborts the operation and notifies the controlling program. In this case, the status returned is $X\cdot O4\cdot K$ known as False Sync. The condition code in the PSW is also set to $X\cdot 4\cdot (V \text{ flag=1})$ . Controller malfunction and software failure (incorrect device address) are the most common causes of this type of time-out. A controller can initiate communication with the processor by generating an attention signal. If the processor is in an interruptible state as defined by bits 17 and 20 of the PSW, this signal causes the processor to temporarily suspend the normal "fetch instruction/execute/fetch next instruction" operation at the end of the execute phase, and to transmit an acknowledge signal over the I/O bus. The controller requesting attention responds with a synchronization signal and transmits its device number to the processor. 9.2.4 Device Friorities - External Interrupt Levels; Interrupt Queuing ## External Interrupt Levels The system architecture provides four external interrupt levels. PSW bits 17 and 20 define the external interrupt enable status of the processor. When interrupt requests occur on more than one interrupt level, the request on the highest priority interrupt level is acknowledged first. Level 0 is the highest; level 3 is the lowest in priority. ## Interrupt Queuing Any device controller attempting to interrupt the processor activates one of the four attention lines sensed by the processor and holds that line active until the processor acknowledges the interrupt. Requests for attention are asynchronous; therefore more than one request may be rending at any time on any interrupt The system resolves these conflicts according to device level. priority, determined by the physical placement of the device controller on the I/O bus. When two or more device controllers on the same interrupt level request attention at the same time, the controller nearest to the processor in the RACKO/TACKO priority wiring pattern captures the acknowledge signal from the and is serviced first. All other interrupting processor controllers of lower priority must wait for the next acknowledge signal from the processor. ## 9.3 INTERRUPT SERVICE POINTER TABLE Device requests for service may result in either an immediate interrupt or an auto driver channel operation. The processor chooses one of these options according to information contained in the interrupt service pointer table. The interrupt service pointer table is an ordered list containing one entry for each possible device number in the system. The table starts at memory location X'0000D0' and contains a halfword entry for each device number in the system. For a minimum system (255 device numbers), the table extends through memory location X'0002CF'; for a maximum system (1023 device numbers), the table extends through memory location X'0008CF'. The software controlling I/C operations must set up the table. When the processor receives the device address after acknowledging a request for service, it adds twice the device address to X°0000D0°. The result is the address, within the table, of the entry reserved for the device requesting attention. If the entry in the table is even (bit 15 equals 0), the processor takes an immediate interrupt and transfers control to the software interrupt service routine at the address contained in the table. If the entry in the table is odd (bit 15 equals 1), the processor transfers control to the auto driver channel, without interrupting the currently running program. At the time the processor transfers control to the software interrupt service routine, the old FSW (current at the time of the device request) has been saved in registers 0 and 1 of the new register set. The device number is saved in register 2 and the status in register 3. The status portion of the current PSW has been replaced by the value X'000028nX', where n is the new register set number equal to the device interrupt level, and X is the least significant 4 bits of the device status. Machine malfunction interrupts and higher level I/O interrupts are enabled and all other interrupts are disabled. The entry in the interrupt service pointer table is now the new location counter. ## 9.4 CONTROL OF I/O OPERATIONS The 32-bit I/O structure allows several data transfers depending on the particular application and on the characteristics of the external devices. Primary methods of data transfer between the processor and external devices are: - One byte or one halfword to or from any of the general registers - On∈ byte or one halfword tc or from memory - A block of data to or from memory under control of a selector channel or DMA universal interface - Multiplexed blocks of data to or from memory under control of the auto driver channel Standard device controllers require a predetermined sequence of commands to effect data transfers. These commands address the device, put it in the correct mode, and cause data to be transferred. Because all I/O instructions are privileged operations, I/O control programs must run in the supervisor mode, i.e., with bit 23 of the current PSW zero. I/O control programs should disable immediate interrupts or enable only higher level interrupts, as controlled by PSW bits 17 and 20. ## 9.5 STATUS MONITORING I/O The simplest form of I/O programming is status monitoring I/O. In this mode of operation, only one device is handled at a time, and the processor cannot overlap other operations with the data transfer. The sequence of operations in this type of programming is: - 1. Address the device and set the proper mode (output command instruction). - 2. Test the device status (sense status instruction). - 3. Loop back to the sense status instruction until the status byte indicates that the device is ready (conditional branch instruction). - 4. When the device is ready, transfer the data (read or write instruction). - 5. If the transfer is not complete, branch back to the sense status instruction. If it is complete, terminate. #### 9.6 INTERRUPT DRIVEN I/O Interrupt driven I/O allows the processor to take advantage of the disparity in speed between itself and the external devices being controlled. With status monitoring, the processor spends time waiting for the device. With interrupt driven programming, the processor can use this time performing other functions. This kind of programming establishes at least two levels of operation. On one level are the interrupt service programs. On the other level are interruptible programs that run with the immediate interrupt enabled. Before starting interrupt driven operations, the interrupt service pointer table must be set up. This table starts at memory location X'0000D0' and must contain a halfword address entry for every possible device. The table is ordered according to device addresses in such a way that X'0000D0' plus two times the device address equals the memory address of the table entry reserved for that device. The value placed in the location reserved for a device is the address of the interrupt service routine for the device. For example, if a terminal is connected at an address of $X^{\circ}02^{\circ}$ and the interrupt routine resides in memory at address $X^{\circ}3000^{\circ}$ , the setup involves writing $X^{\circ}3000^{\circ}$ at memory location $X^{\circ}D4^{\circ}$ . Note that $X^{\circ}D4^{\circ}=X^{\circ}D0^{\circ}+2$ times the terminal address. Although there may be gaps in device address assignments, the interrupt service pointer table should be completely filled. Entries for nonexistent devices should point to an error recovery routine. This precaution prevents system failure in the event of spurious interrupts caused by hardware malfunction or by improper use of the simulate interrupt instruction. The next step is to prepare the device for the transfer, preferably with the immediate interrupts disabled. Once the table pointer has been set up and the device prepared, the processor can move on to an interruptible program. The sequence of operation in this type of program is: - 1. Set up the interrupt service pointer table to vector to error addresses for undefined devices. - 2. Store the address of the software interrupt service routine at two times the device number plus X\*DO\* (X\*DO\* is starting address of service pointer table). - 3. Set up the software interrupt service routine. - 4. Set up the device and enable device interrupts. - 5. Enable I/O interrupts in the PSW. When the device signals a need for service, the processor saves its current state and transfers control to the interrupt service routine at the location specified in the interrupt service pointer table. At this time, the current PSW has a status that indicates running state, machine malfunction interrupt enabled, higher level I/O interrupts enabled, and all other interrupts disabled. The condition code contains bits 4:7 of the device status. Registers O and 1 of the new set contain the old PSW, indicating the status and location of the interrupted program. Register 2 of that set contains the device address. Register 3 contains the device status. # The interrupt service routine should: - check the device status in Register 3, and if satisfactory, - 2. make the transfer, and - 3. return to the interrupted program by reloading the old PSW from registers 0 and 1 (LPSWR R0). The interrupt service routine should not enable immediate interrupts on its own interrupt level. This would allow other interrupt requests to be acknowledged, and the contents of registers 0:4 could be lost. If it is necessary to enable immediate interrupts on the same level, the routine should save the register set, switch to a different register set, save it if necessary, and then enable immediate interrupts. ## 9.7 SELECTOR CHANNEL I/O ## 9.7.1 Introduction The selector channel controls the transfer of data directly between high speed devices and memory. As many as 16 devices may be attached to the selector channel, only one of which may be operating at any one time. The advantage in using the selector channel is that other program processing may proceed simultaneously with the transfer of data between the external device and memory. This is possible because the selector channel accesses memory on a cycle stealing basis, permitting the processor and the channel to share memory. In some cases, execution time of the program in progress may be affected, while in others, the effect is negligible. This depends upon the rate at which the selector channel and processor compete for memory cycles. The selector channel is linked to the processor over the I/O bus. It has its own unique device number which it recognizes when addressed by the processor. Like other device controllers, it can request processor attention through the immediate interrupt. #### 9.7.2 Selector Channel Devices The selector channel has a private bus similar to the processor's I/O bus. Controllers for the devices associated with the selector channel are attached to this bus. When the selector channel is idle, its private bus is connected directly to the I/O bus. If this condition exists, the processor can address, command, and accept interrupt requests from the devices attached to the selector channel. When the selector channel is busy, this connection is broken. All communication between the processor and devices on the selector channel is cut off. Any attempt by the processor to address a device on the channel when the channel is busy results in instruction time-out. #### 9.7.3 Selector Channel Operation Two registers in the selector channel hold the current memory address and the final memory address. With the use of write instructions, the control software places the address of the first byte of the data buffer into the current address register and the address of the last byte into the final address register. This is done before starting a selector channel operation. During the data transfer, the channel increments the current address register by one for each byte transferred. When the current address equals the final address, the last byte has been transferred, and the channel terminates. The selector channel accesses memory a minimum of one halfword at a time; therefore, the transfer must always involve an integral number of halfwords. The starting address of the data buffer must always be on an even byte (halfword) boundary. The final address must always be on an odd byte boundary. The starting address must be less than the final address. Upon termination, the software should read back from the selector channel the address contained in the current address register. If this address is not equal to the final address specified for the transfer, and if the buffer limits were properly checked before the transfer, this condition indicates a device malfunction or an unusual condition within the device. For example, crossing a cylinder boundary on a disc is an abnormal termination. The reason for the termination is indicated in the selector channel status or the device status. # 9.7.4 Selector Channel Programming The usual method of programming with the selector channel uses the immediate interrupt. The first step in the operation is to check the status of the selector channel. If the selector channel is not busy, the address of the termination interrupt service routine is placed in the location within the interrupt service pointer table reserved for the selector channel. The program should then proceed as follows: - 1. Give the selector channel a command to stop. This command initializes the selector channel registers and assures the idle condition with the private bus connected to the I/O bus, so that the device may be set up for data transfer. - 2. Give the selector channel the starting and final addresses. - 3. Prepare the device for the transfer with the required commands and information. - 4. Give the selector channel the command to start. With the start command, the selector channel breaks the connection between its private bus and the processor's I/O bus, and provides a direct path between memory and the last device addressed over its bus. When the device becomes ready, the channel starts the transfer, which proceeds to completion without further processor intervention. Once the start command has been given, the processor can be directed to the execution of concurrent programs. Upon termination, the channel signals the processor that it requires service. The processor subsequently takes an immediate interrupt, transferring control to the selector channel interrupt service routine. At this time, registers 0:3 of the new set are set up as for any other immediate interrupt. If a power fail/restore sequence occurs while using the selector channel, the contents of the selector channel's internal registers are undefined. #### 9.8 I/O INSTRUCTION FORMATS I/O instructions use the Register to Register (RR) and the Register and Indexed Storage (RX) instruction formats. #### 9.9 I/O INSTRUCTIONS Following most I/O instructions, the V flag in the condition code indicates instruction time-out. This means that the operation was not completed, either because the device did not respond at all, or because it responded incorrectly. In the Sense Status and Autoload instructions, the V flag can also mean examine status. To distinguish between these two conditions, the program should test bits 0:3 of the device status byte. If all of these bits are zero, device time-out has occurred. The instructions described in this section are: - SS Sense Status - SSR Sense Status Register - OC Output Command - CCR Cutput Command Register - RD Read Data - RDR Read Data Register - RH Read Halfword - RHR Read Halfword Register - WD Write Data - WDR Write Data Register - WH Write Halfword - WHR Write Halfword Register - AL Autoload - SCP Simulate Channel Program ## 9.9.1 Output Command (OC, OCR) Output Command (OC) Output Command Register (OCR) | Asser | mbler Notation | Op-Code | Format | |-------|------------------|---------|---------| | OC | R1,D2(X2) | CE | RX1,RX2 | | oc | R1, A2(FX2, SX2) | DE | RX3 | | OCR | R1, R2 | 9 E | RR | #### Operation Bits 22:31 of the register specified by R1 contain the 10-bit device address. The processor addresses the device and transfers an 8-bit command byte from the second operand location to the device. Neither operand is changed. ## Condition Code | С | ٧ | G | L | |---|---|---|---| | C | 0 | 0 | 0 | | 0 | 1 | 0 | 0 | Operation successful Instruction time-out (FALSE SYNC) ## Programming Notes In the RR format, bits 24:31 cf the register specified by R2 contain the device command. These instructions are privileged operations. 9.9.2 Sense Status (SS, SSR) Sense Status (SS) Sense Status Register (SSR) | Asser | mbler Notation | Op-Code | Format | |----------|-----------------------------|------------|----------------| | SS<br>SS | R1,D2(X2)<br>R1,A2(FX2,SX2) | D D<br>D D | RX1,RX2<br>RX3 | | SSR | R1,R2 | 9 D | RR | ### Operation Bits 22:31 of the register specified by R1 contain the 10-bit device address. The device is addressed and the 8-bit device status is transferred to the second operand location. The condition code is set equal to the least significant four bits of the device status byte. The first operand is unchanged. ### Condition Code Bits 4:7 of the device status byte are copied into the condition code. See the appropriate device manual for a description of this status. If the device is not in the system, the condition code is set to 0100 (false sync). In this case, the status byte returned is $X^{\circ}04^{\circ}$ . ### Programming Notes In the RR format, the device status byte replaces bits 24:31 of the register specified by R2. Bits 0:23 are forced to zero. These instructions are privileged operations. ## 9.9.3 Read Data (RD, RDR) Read Data (RD) Read Data Register (RDR) | Asser | nbler Notation | Or-Code | Format | |-------|------------------|---------|---------| | RD | R1,D2(X2) | DB | RX1,RX2 | | RD | R1, A2(FX2, SX2) | DB | RX3 | | RDR | R1,R2 | 9B | RR | ### Operation Bits 22:31 of the register specified by R1 contain the 10-bit device address. The processor addresses the device and transfers an 8-bit data byte from the device to the second operand location. ## Condition Code | | | G | | | | | |---|---|---|---|----------------------|--------|-------| | С | 0 | 0 | 0 | Operation successful | | | | 0 | 1 | 0 | 0 | Instruction time-out | (FALSE | SYNC) | ### Programming Notes In the RR format, the 8-bit data byte replaces bits 24:31 of the register specified by R2. Eits 0:23 of the register are forced to zero. These instructions are privileged operations. Instruction time-out does not prevent the second operand location from being modified. # 9.9.4 Read Halfword (RH, RHR) Read Halfword (RH) Read Halfword Register (RHR) | Asset | mbler Notation | Or-Code | <b>Format</b> | |-------|------------------|-----------|---------------| | RH | R1,D2(X2) | D9 | RX1,RX2 | | RH | R1, A2(FX2, SX2) | <b>D9</b> | RX3 | | RHR | R1,R2 | 99 | RR | ## Operation Bits 22:31 of the register specified by R1 contain the 10-bit device address. The processor addresses the device. If the device is halfword-oriented, the processor transfers 16 bits of data from the device to the second operand location. If the device is byte-oriented, the processor transfers two 8-bit bytes in successive operations. ### Condition Code | С | V | G | L | | | | |----|---|---|---|----------------------|--------|-------| | 00 | 0 | 0 | 0 | Operation successful | | | | 0 | 1 | 0 | 0 | Instruction time-out | (FALSE | SYNC) | ### Programming Notes If the device is byte-oriented, it must be capable of supplying both bytes without intervening status checks. This instruction does not perform status checking between the two byte transfers. In the RR format, the data transferred from a halfword device replaces bits 16:31 of the register specified by R2. Bits 0:15 are forced to zero. The first byte of data from a byte device replaces bits 16:23 of the register specified by R2 and the second byte replaces bits 24:31. Bits 0:15 of the register specified by R2 are forced to zero. In the RX format, the second operand must be located on a halfword boundary. The first byte of data from a byte device replaces bits 0:7 of the halfword operand in memory and the second byte replaces bits 8:15. These instructions are privileged operations. Instruction time-out does not prevent the second operand location from being modified. 9.9.5 Write Data (WD, WDR) Write Data (WD) Write Data Register (WDR) | Asse | mbler Notation | Op-Code | Format | |------|------------------|---------|---------| | WD | R1,D2(X2) | DA | RX1,RX2 | | WD | R1, A2(FX2, SX2) | DA | RX3 | | WDR | R1,R2 | 9 A | RR | ## Operation Bits 22:31 of the register specified by R1 contain the 10-bit device address. The processor addresses the device and transfers an 8-bit data byte from the second operand location to the device. Neither operand is changed. # Condition Code | С | V | G | L | | |----|---|---|---|-----------------------------------| | 00 | 0 | 0 | 0 | Operation successful | | 0 | 1 | 0 | 0 | Instruction time-out (FALSE SYNC) | Programming Notes In the RR format, the 8-bit data byte is transferred from bits 24:31 of the register specified by R2. These instructions are privileged operations. ## 9.9.6 Write Halfword (WH, WHR) Write Halfword (WH) Write Halfword Register (WHR) | Asse | mbler Notation | Op-Code | Format | | |------|------------------|---------|---------|--| | WH | R1,D2(X2) | D8 | RX1,RX2 | | | WH | R1, A2(FX2, SX2) | D8 | RX3 | | | WHR | R1,R2 | 98 | RR | | ### Operation Bits 22:31 of the register specified by R1 contain the 10-bit device address. The processor addresses the device. If the device is halfword-oriented, the processor transfers 16 bits of data from the second operand location to the device. If the device is byte-oriented, the processor transfers two 8-bit data bytes in successive operations. ### Condition Code | С | V | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 1 | 0 | 0 | Operation successful Instruction time-out (FALSE SYNC) ## Programming Notes If the device is byte-oriented, it must be capable of accepting both bytes without intervening status checks. This instruction does not perform status checking between the two byte transfers. In the RR format, data is transferred to a halfword device from bits 16:31 of the register specified by R2. The first byte of data is transferred to a byte device from bits 16:23 of the register specified by R2; the second byte comes from bits 24:31. In the RX format, the second operand must be located on a halfword boundary. The first byte of data is transferred to a byte device from bits 0:7 of the halfword operand in memory and the second byte is transferred from bits 8:15. These instructions are privileged operations. ## 9.9.7 Autoload (AL) | Asse | mbler Notation | <u>Op-Code</u> | Format | |------|------------------|----------------|---------| | AL | D2(X2) | D5 | RX1,RX2 | | AL | R1,D2(X2) | <b>D</b> 5 | RX1,RX2 | | AL | A2(FX2,SX2) | D 5 | RX3 | | AL | R1, A2(FX2, SX2) | D5 | RX3 | ### Operation The AL instruction loads memory with a block of data from an input device. The 8-bit input device address is specified by memory location X'000078'. The device command byte is specified by memory location X'000079'. If the R1 field of this instruction is not specified, or contains zero, the default value X°000080° is used for the start address of the data block in memory and the second operand address is used for the end of the data block. If the R1 field of this instruction contains a value other than zero, then the contents of the general registers specified by R1 and R1+1 are used for the start and end of the data block, respectively. If the start address is greater than the end address, the instruction is aborted. The address of a selector channel is specified by memory location X'00007D'. If the byte at this location contains zero, the selector channel is not used by this instruction. In this case, data is transferred a byte at a time from the input device to successive memory locations, beginning with the specified block start address. If any blank or zero bytes are input before the first nonzero byte, these bytes are considered to be leader and are ignored. All other zero bytes are stored as data. When a data byte has been stored at the specified block end address, the instruction terminates. If the selector channel address specified by memory location X'00007D' is not zero, the selector channel is used to transfer data from the input device to successive memory locations, beginning with the specified block start address. All data bytes are transferred; no checking for leading zero bytes can be made. The instruction terminates when data has been stored at the specified block end address. ## Condition Code | | С | V | G | L | |---|---|---|---|---| | Γ | 0 | 0 | 0 | 0 | | l | X | 1 | X | X | | ı | X | X | 1 | X | | | X | X | Х | 1 | Operation successful or aborted Examine status or time out End of medium Device unavailable ### Programming Notes This instruction may be used only with devices whose addresses are less than, or equal to, X'FF'. This instruction is a privileged operation. Bad status termination results if any of the least significant three bits of the device status are set. If the selector channel is not used, the starting and ending addresses for this instruction are relocatable. Address translation should be disabled before attempting to use this instruction in this case. If the selector channel is used, the data block must begin on a halfword boundary and end on an odd byte boundary. The block may be loaded anywhere in memory. Software must issue a stop command to the selector channel following this instruction. A selector channel interrupt may be queued by this instruction. If the R1 field of this instruction is used, it must specify the even member of an even/odd register pair. ## 9.9.8 Simulate Channel Program (SCP) | Assem | bler Notation | Or-Code | Format | |-------|------------------|---------|---------| | SCP | R1,D2(X2) | E 3 | RX1,RX2 | | SCP | R1, A2(FX2, SX2) | E3 | RX3 | ### Operation The second operand address is the address of a Channel Command Block (CCB). The buffer switch bit of the Channel Command Word (CCW) specifies the buffer to be used for the data transfer. If this bit is set, buffer 1 is used. If it is zero, buffer 0 is used. If the byte count field of the current buffer is greater than zero, the V flag in the condition code is set, and the next sequential instruction is executed. If the byte count field is not greater than zero, the following data transfer operation is performed. If the CCW specifies read, a byte of data is moved from bits 24:31 of the register specified by R1 to the appropriate buffer location. If the CCW specifies write, a byte of data is moved from the appropriate buffer location to bits 24:31 of the register specified by R1. Bits 0:23 are forced to zero. After a byte has been transferred, the count field of the appropriate buffer is incremented by one. If the count field is now greater than zero, and if the fast bit of the CCW is zero, the buffer switch bit of the CCW is complemented. ### Condition Code | | | | G | | | |---|---|---|---|------------------|--------------------------------------| | | 0 | 0 | 0 | 0 | Count field is now zero | | | 0 | 0 | 0 | 1 | Count field is now less than zero | | | 0 | 0 | 1 | 0 | Count field is now greater than zero | | | 0 | 1 | 0 | 0<br>1<br>0<br>0 | Count field was greater than zero | | • | | | | | | ## Programming Notes If the CCW specifies fast mode, buffer 1 may be used, but the buffer bit is not switched when the count field becomes greater than zero. The second operand must be located on a fullword boundary. This instruction is a privileged operation. ### 9.10 AUTO DRIVER CHANNEL The auto driver channel provides a means for multiplexing block data transfers between memory and low or medium speed I/O devices. The channel operation is similar, in some respects, to interrupt driven I/O. The channel is activated as a result of a service request from a device on the I/O bus. Upon receipt of such a request, the processor uses the device number to index into the interrupt service pointer table. If the value contained in the table is even, the processor transfers control to the interrupt service routine. If the value is odd, it transfers control to the auto driver channel. To the auto driver channel, the address in the interrupt service pointer table is the address plus one (making it odd) of a Channel Command Block (CCB). The channel command block is a channel program consisting of a description of the operation to be performed, and a list of parameters associated with the operation. In addition to the functions of read and write, the channel can also: - 1. translate characters - 2. test device status - 3. chain buffers - 4. calculate longitudinal and cyclic redundancy check values - 5. transfer control to software routines to take care of unusual situations ### 9.11 CHANNEL COMMAND BLOCK ## 9.11.1 Introduction The Channel Command Block (CCE), as shown in Figure 9-1, consists of a channel command word (16 bits) that describes the function; count fields (16 bits each) for two buffers; final addresses (32 bits each) for two buffers; a check word (16 bits) for the longitudinal or cyclic redundancy check; the address (32 bits) of a translation table; and the address (16 bits) of a software routine. The CCB requires 22 bytes of memory. Many interrupt service routines may be available at any time to service device requests. There may also be many channel command blocks in the system ready to handle data transfers as required. Each channel command block must be aligned on a fullword boundary. The channel command block address, plus one, must be placed in the interrupt service pointer table location for the device involved in the transfer. | 617 | 0 | . 15 | |-----|-------------------------------|----------| | 0 | CHANNEL COMMAND WORD (HA | ALFWORD) | | 2 | BUFFER BYTE COUNT (HA | ALFWORD) | | 4 | BUFFER 0 END ADDRESS (FU | JLLWORD) | | 8 | CHECK WORD (HA | ALFWORD) | | 10 | BUFFER 1 BYTE COUNT (HA | ALFWORD) | | 12 | BUFFER 1 END ADDRESS (FU | JLLWORD) | | 16 | TRANSLATION TABLE ADDRESS (FL | JLLWORD) | | 20 | SUBROUTINE ADDRESS (HA | ALFWORD) | Figure 9-1 Channel Command Block # 9.11.2 Subroutine Address To handle special situations, channel control is transferred to the software subroutine, whose address is contained in the channel command block. When this occurs, registers 0:4 of the appropriate set have already been set up by the processor to contain the old PSW, the device number, the device status, and the address of the channel command block. The current PSW status specifies run state, machine malfunction interrupt enabled, higher level I/O interrupts enabled, and all other interrupts disabled. The channel transfers control to the subroutine either unconditionally (controlled by a bit in the channel command word), because of bad device status, because of special character translation, or because it has reached the limit of a buffer. It indicates its reason for transferring control by adjusting the condition code as follows: | C | V | G | L | |---|---|---|---| | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | | 0 | 0 | 1 | 0 | Unconditional transfer or special character Bad status Buffer limit The subroutine address in the CCB is a 16-bit physical address. For this reason, the subroutine at that address, or at least the first instruction of the subroutine, must reside in the 64 kb of memory. ### 9.11.3 Buffers There is a space in the CCB to describe two data buffer areas. The data areas may be located anywhere in memory. The limits of each data area are described by an address field and a count field. The address field contains the physical address of the last byte in the data area. This address is right justified in the fullword provided. If the device being controlled is a halfword-oriented device, the final address must be odd. If the device is a byte-oriented device, the address may be either odd or even. The active buffer is selected by a bit in the channel command word. When one buffer has been exhausted, the channel may reverse the state of this bit and thus switch to the alternate buffer. Automatic buffer switching is available only for byte-oriented devices and if the Fast bit of the CCW is zero. If the Fast bit is set, buffer 0 is always used. The count field, in most operations, contains a negative number whose absolute value is equal to one less than the number of bytes to be transferred. The one exception is the case of a single data transfer, for which the count field contains zero. During data transfers, the channel adds the value contained in the count field to the final address in order to obtain the current address. It makes the transfer, using the current address, then increments the value in the count field by one for a byte device or by two for a halfword device. When the count field becomes greater than zero, the channel sets the G flag in the condition code and transfers control to the specified software subroutine. If the count field is greater than zero upon channel activation, the channel makes no transfer and relinquishes control of the processor. ### 9.11.4 Translation The translation feature is available only for byte-oriented devices and if the Fast (F) bit in the CCW is zero. If translation is specified, the fullword provided in the channel command block must contain the address, right justified, of a translation table. This table, which must be aligned to a halfword boundary, can contain up to 256 halfword entries. The format of this table is identical to that used by the Translate (TLATE) instruction (see Section 3.3.2). During data transfers, the channel multiplies the data byte by two and adds this value to the translation table address. The result is the address within the translation table cf the halfword entry corresponding to the data byte. The channel tests this entry, and, if bit 0 of the halfword is set, it substitutes bits 8:15 of the halfword for the data byte and proceeds with the operation. If bit 0 of the halfword is a zero, the channel: - does not increment the byte count for the appropriate buffer. - puts the data byte, untranslated, in bits 24:31 of register 3, of the appropriate set, and forces bits 0:23 of register 3 to zero. - multiplies the value contained in the translation table by two, and transfers control to the software special character translation routine located at the resulting address. Upon transfer to the translation subroutine, registers 0 and 1 contain the old PSW; register 2 contains the device number; register 3 contains the untranslated character; and register 4 contains the address of the channel command block. The current PSW indicates run state, machine malfunction interrupt enabled, higher level I/O interrupts enabled and all other interrupts disabled. The condition code is zero. ## 9.11.5 Check Word The check word in the channel command block contains the accumulated residual for longitudinal or cyclic redundancy checking. The initial value for the check word is usually zero. (There are data dependent exceptions, e.g., where initial characters are not to be included in the check.) The longitudinal check is an exclusive OR of the character with the check word. The cyclic check uses the fcrmula for CRC 16: $$X^{16} + X^{15} + X^{2} + 1$$ If the data communication ortion is equipped, the cyclic check may ortionally use the formula for CRC SDLC: $$X^{16} + X^{12} + X^{5} + 1$$ On input, if both redundancy checking and translation are required, the character is translated first; then the cyclic redundancy check is done using the original character input rather than the translated character. On output, the translated character participates in the redundancy check. Redundancy checking may be used only with byte devices, and is only performed if the Fast bit (F) of the CCW is zero. ### 9.11.6 Channel Command Word The Channel Command Word (CCW), as shown in Figure 9-2, consists of two parts. Bits 0:7 contain a status mask. Bits 8:15 describe the channel operation. Figure 9-2 Channel Command Word ## Status Mask On every channel operation, if the Execute (E) bit is set, the status mask is ANDed with the device status. This operation does not change the status mask. If the result is zero, the channel proceeds with the operation. If the result is nonzero, the channel sets the L flag in the condition code, and transfers control to the specified software subroutine. ### Execute Bit (E) If this bit is zero, the channel unconditionally transfers control to the specified subroutine, without taking any other action. The condition code is zero. If this bit is set, the channel continues with the operation as specified in the channel command word. ### Fast Bit (F) If this bit is set, the channel performs the I/O transfer in the fast mode. In this mode, buffer switching, redundancy checking, and translation are not allowed. This bit must be set for halfword devices. If this bit is set, buffer 0 is always used. ## Read/Write Bit (R/W) This bit indicates the type of operation. If this bit is zero, a byte or a halfword is input from the device. If this bit is set, a byte or a halfword is cutput to the device. # Translate Bit (T) If this bit is set, and the Fast bit is zero, the channel translates the data byte, using the translation table defined in the CCB. # Redundancy Check Type Bits (RC) These two encoded bits specify the type of redundancy check required. No check is performed if the Fast bit is set. CRC SDLC may be performed only if the data communication option is installed. If the option is not installed, CRC BISYNC (CRC 16) is performed when SDLC is specified. The following table contains the valid types of checks: | Bit<br>10 | Bit<br>11 | Redundancy Check Type | |-----------|-----------|---------------------------------------------| | • | | | | 0 | 0 | LRC | | 0 | 1 | CRC BISYNC | | 1 | 0 | Reserved - must not be specified | | 1 | 1 | CRC SDLC - Should only be specified if | | | | the data communication option is installed. | # Buffer Switch Bit (B) When zero, this bit specifies that buffer 0 is to be used for the transfer. If it is set, buffer 1 is used. The channel chains buffers, when the count field becomes greater than zero, by complementing the buffer switch bit before transferring control to the specified software routine. Buffer 0 is always used if the Fast bit in the CCW is set. # 9.11.7 Valid Channel Command Codes The following is a list of valid codes for the channel command word. Note that only the first three may be used with halfword devices. # CHANNEL CCMMAND WORD 8:15 | <b>HEXADECIMAL</b> | BINARY | MEANING | |--------------------|----------|------------------------------------------------------------| | 00 | 0000000 | Transfer to subroutine | | 81 | 10000001 | Read fast mode | | 85 | 10000101 | Write fast mode | | 80 | 10000000 | LRC, Buffer O, read | | 8 2 | 10000010 | LRC, Buffer O, read, translate | | 8 4 | 10000010 | LRC, Buffer O, write | | 86 | 10000110 | LRC, Buffer O, write, translate | | ጸጸ | 10001000 | LRC, Buffer 1, read | | 8 A | 10001010 | LRC, Buffer 1, read, translate | | 8 C | 10001100 | LRC, Buffer 1, write | | 8 E | 10001110 | LRC, Buffer 1, write, translate | | 90 | 10010000 | LRC, Buffer 1, write, translate CRC BISYNC, Buffer 0, read | | 92 | 10010010 | CRC BISYNC, Buffer O, read, | | | | translate | | 94 | 10010100 | CRC BISYNC, Buffer 0, write | | 96 | 10010110 | CRC BISYNC, Buffer O, write, | | | | translate | | 98 | 10011000 | CRC BISYNC, Buffer 1, read | | 9 A | 10011010 | CRC BISYNC, Buffer 1, read, | | | | translate | | 9 C | 10011100 | CRC BISYNC, Buffer 1, write | | 9 E | 10011110 | CRC BISYNC, Buffer 1, write, | | | | translate | | ВО | 10110000 | CRC SDLC, Buffer O, read | | B2 | 10110010 | CRC SDLC, Buffer O, read, | | | | translate | | B4 | 10110100 | CRC SDLC, Buffer 0, write | | B6 | 10110110 | CRC SDLC, Buffer O, write, | | | | translate | | B8 | 10111000 | CRC SDLC, Buffer 1, read | | BA | 10111010 | CRC SDLC, Buffer 1, read, | | | | translate | | | 10111100 | CRC SDLC, Buffer 1, write | | BE | 10111110 | CRC SDLC, Buffer 1, write, | | | | translate | - 9.11.8 General Auto Driver Channel Programming Procedure (See Figure 9-3) - 1. Set up interrupt service pointer table to vector to error routines for undefined devices. - 2. Set up address of channel command word + 1 (odd) in table at 2 times device number plus X'DO' (start of interrupt service pointer table). - 3. Set up complete channel command block. - 4. Set up device and enable device interrupt. - 5. Enable I/C interrupts in PSW (auto driver channel performs I/O operation). - 6. Check for good termination of auto driver channel operation when the subroutine defined in the CCB is entered. Figure 9-3 Auto Driver Channel Flowchart Figure 9-3 Auto Driver Channel Flowchart (Continued) # CHAPTER 10 STATUS SWITCHING AND INTERRUPTS #### 10.1 INTRODUCTION The processor's interrupt system provides a mechanism for escape from the normal processing sequence to handle external and internal events. The software routine that is executed in response to an interrupt is called an interrupt service routine. Before transferring control to a service routine, the current state of the processor is preserved so that, upon completion of the service routine, the execution of an interrupted program may be resumed. Interrupts may be classified as being synchronous or asynchronous, depending on whether they occur in fixed relationship to the execution of instructions, or whether they occur at random times due to events external to the processor. Examples of asynchronous interrupts include power fail, console attention, and peripheral device interrupts. Synchronous interrupts occur due to fault conditions, or in the case of software interrupts, may be programmed to occur. Examples of fault conditions which cause synchronous interrupts include noncorrectable memory errors, illegal instructions, and arithmetic faults. Software interrupts occur when the Supervisor Call (SVC) or Simulate Interrupt (SINT) instructions are executed, or as a result of adding an entry to the system queue. The Breakpoint (BRK) instruction causes program execution to be suspended so that the system console terminal may be activated. See the chapter on the System Console Terminal. Each interrupt condition is reset when the corresponding interrupt is serviced by the processor. # 10.2 PROGRAM STATUS WORD (PSW) AND RESERVED MEMORY LOCATIONS The Program Status Word (PSW), shown in Figure 10-1, is a 64-bit quantity that controls the operation of the processor. The PSW provides information about various states and conditions affecting the operation of the processor. The PSW is composed of two fullwords: bits 0:31 are the status word, and bits 32:63 are the location counter. The various PSW fields are described below: Figure 10-1 Program Status Word (PSW) | Bits | 0-9 | | Unused, must be zero | |------|---------|---------|---------------------------------------| | Bits | 10-11 | LAL | Memory access level | | Bit | 12 | | Unused, must be zero | | Bit | | FLM | Floating-point masked mode | | Bit | | IIP | Interruptible instruction in progress | | Bit | | | Unused, must be zero | | Bit | | W | Wait state | | Bit | | I | I/O interrupt mask | | Bit | | M | Machine malfunction interrupt mask | | Bit | | FLU | Floating-point underflow mask | | Bit | | I | I/O interrupt mask | | Bit | | R/P | Relocation/protection mask | | Bit | | Q | System queue service interrupt mask | | Bit | 23 | P | Protect mode | | | 24 - 27 | | Register set select field | | | 28 - 31 | C,V,G,L | Condition code | | _ | 32 - 39 | | Unused, must be zero | | Bits | 40 - 63 | | Location counter | ## 10.2.1 Program Status Word (PSW) Bits 0:31 of the PSW are called the status word. This word controls interrupts, defines the status of the processor, and contains the condition code. The following sections provide detailed definitions of various states of the processor and how the status word controls them. Unused bits of the status word must always be zero. ## 10.2.1.1 Memory Access Level Field (LVL) When PSW bit 21 (R/P) is set, PSW bits 10 and 11 participate in an access level check for any memory access attempted by the current program. The LVL field of PSW is compared numerically to the access level field of the appropriate segment table entry. If the LVL field contains a lesser value than the access level field, a Memory Address Translator (MAT) fault interrupt occurs. When PSW bit 21 is zero, PSW bits 10 and 11 are ignored, and no access level check is performed. # 10.2.1.2 Floating-Point Masked Mode (FLM) On processors with the floating-point option, when bit 13 of the current PSW is zero, a program may execute any legal floating-point instruction. When bit 13 of the current PSW is set, the processor is in the Floating-Point Masked (FLM) mcde. A program running in this mode is not allowed to execute floating-point arithmetic instructions. If execution of any floating-point arithmetic instruction is attempted in FLM mode, an illegal instruction interrupt occurs. If the processor is in FLM mcde when a context switch is made by the system program and the processor state must be saved, the contents of the floating-point registers need not be saved. This results in a faster context switch. ## 10.2.1.3 Interruptible Instruction in Progress (IIP) PSW bit 14 is set by the processor while an interruptible instruction is in progress, and is zero when the interruptible instruction terminates. This bit is set by the processor to indicate that the scratchpad registers contain valid parameters for the interruptible instruction and that these parameters need not be recalculated before resuming the interrupted instruction. If bit 14 of the current PSW is set when the processor transfers control to a software interrupt service routine, that routine must not allow the contents of the scratchpad registers to be modified before the interruptible instruction is resumed. The STPS, LDPS, ISSV, and ISRST instructions provide the means for saving and restoring these registers if they must be used by the interrupt service routine. ## 10.2.1.4 Wait State (W) When PSW bit 16 is set, the processor is in the wait state. In the wait state, the normal fetch instruction/execute instruction/fetch next instruction sequence is suspended. While in the wait state, the processor is responsive to console attention interrupts and primary power fail, as well as any interrupts specifically enabled by the current PSW. PSW bit 16 is zero when the processor is executing instructions. This bit is forced to zero whenever the single-step, run switch, or system console terminal is used to initiate instruction execution. This bit is not forced set by entry to the console mode. If an interrupt occurs, PSW bit 16 is set according to the new PSW defined for servicing the interrupt. Bit 16 of the new PSW for any I/O interrupt is zero. Except for an I/O interrupt, the state of bit 16 of the new PSW is tested as the PSW is loaded. If bit 16 of the newly loaded PSW is set, the processor enters the wait state, provided that no interrupt is still pending. All pending interrupts are serviced before the processor enters the wait state. ### 10.2.1.5 I/O Interrupt Mask (I) PSW bits 17 and 20 are used together to enable or disable recognition of interrupt requests generated by peripheral devices on any of the four interrupt levels, as detailed below: | BIT 17 | BIT 20 | MEANING | |--------|--------|-----------------------------------| | 0 | 0 | All levels disabled | | 0 | 1 | Higher levels enabled | | 1 | 0 | All levels enabled | | 1 | 1 | Current and higher levels enabled | The interrupt levels are numbered from 0 to 3, with level 0 being the highest priority interrupt level and level 3 being the lowest priority interrupt level. An I/C interrupt request is queued until the processor acknowledges the interrupt unless the request is programmed reset, or power fail occurs. The state of PSW bits 17 and 20 is ignored by the Simulate Interrupt (SINT) instruction. ## 10.2.1.6 Machine Malfunction Interrupt Enable (M) PSW bit 18 is used to enable and disable detection of various malfunction conditions within the processor and the resulting machine malfunction interrupt. When this bit is set, any of the following conditions results in a machine malfunction interrupt. - early power failure - power restore - noncorrectable memory data error - nonconfigured memory address - shared memory power failure The processor is designed with the concept that all software must enable the machine malfunction interrupt for maximum data integrity. Unlike other processors, this does not require that this interrupt ever be disabled. The processor resets each detected interrupt condition as it occurs. While performing a machine malfunction interrupt PSW swap, the processor sets PSW bit 18 tc allow error detection for the new PSW data fetched from memory. If the new PSW cannot be fetched correctly, the processor effectively stops by entering the console mode. This prevents a runaway situation in the event of a double fault. If PSW bit 18 is zero, any noncorrectable memory data error is logged by the optional error logger. Cache accesses to memory using a nonconfigured memory address result in undefined data being loaded into the optional high-speed cache, with no error indication. (Subsequent access to the same area of cache results in another memory fetch, as cache data is invalidated.) No machine malfunction interrupt occurs for any of the reasons given above. A machine malfunction due to early power failure or shared memory power failure is queued until PSW bit 18 is set by software, or until automatic shutdown occurs. The interrupt is not queued for any other reason. ## 10.2.1.7 Floating-Point Underflow Interrupt Enable (FLU) PSW bit 19 controls response of the processor to an arithmetic underflow resulting from a single- or double-precision floating-point arithmetic operation. If this bit is set when the underflow occurs, an arithmetic fault interrupt occurs, and the participating floating-point registers remain unchanged. If this bit is zero when the underflow occurs, the result of the operation is replaced by zero, and the condition code is set to 0100 (V-flag only), as defined in the description of the specific floating-point instruction. # 10.2.1.8 Relocation/Protection Enable (R/P) PSW bit 21 is used to enable and disable the relocation and protection programmed into the Memory Address Translator (MAT). When this bit is set, relocation, protection, and the MAT fault interrupt are enabled. When this bit is zero, relocation, protection, and the MAT fault interrupt are disabled. # 10.2.1.9 System Queue Service Interrupt Enable (Q) If bit 22 of the new PSW loaded by any of the instructions listed below is set, the state of the system queue is tested. If the system queue is not empty, a System Queue Service (SQS) interrupt occurs. If the system queue is empty, the next instruction is fetched and executed, according to the newly-loaded PSW. If bit 22 of the newly-loaded FSW is zero, the SQS interrupt is disabled. The following instructions test the state of the system queue: | MNEMONIC | MEANING | | | |----------|-----------------------------------|--|--| | EPSR | Exchange Program Status Register | | | | LDPS | Load Process State | | | | LPSW | Load Program Status Word | | | | LPSWR | Load Program Status Word Register | | | # 10.2.1.10 Protect Mode Enable (P) When PSW bit 23 is set, the processor is in the protect mode. Any attempt by a program running in this mode to execute a privileged instruction causes an illegal instruction interrupt to occur. The processor does not attempt to execute the offending instruction. The Breakpoint (BRK) instruction is a privileged instruction. When PSW bit 23 is zero, the processor is in privileged mode. A program running in privileged mode may execute any legal instruction, within the constraints imposed by the system configuration and the state of PSW bit 13 (FLM). 10.2.1.11 Register Set Select Field (R) Bits 24, 25, 26, and 27 of the current PSW select the active general register set. Although 16 different sets may be specified by using the four bits of this field, only eight sets of general registers are implemented in this processor. The implemented sets are numbered 0, 1, 2, 3, 4, 5, 6, and 15. Set 0, 1, 2, or 3 is automatically selected by the processor in handling an I/O interrupt on the corresponding interrupt level. Registers 0 through 4 of that set are used to maintain information pertaining to an I/O interrupt request which is acknowledged on the I/O interrupt level corresponding to the selected register set. Therefore, sets 0, 1, 2, and 3 should not be used for general purpose processing. These sets may, however, be used for processing internal interrupts, which use registers 11 through 15 of the selected set to maintain information pertaining to the interrupt. Sets 4, 5, 6, and 15 may be allocated according to processing needs, without special consideration. Sets 7 through 14 are not implemented. An attempt to select a set which is not implemented may result in the selection of any set, without any special indication of the error. When a new PSW is loaded, the specified register set becomes the active set for the next instruction executed. | | PSW B | IT | | SELECTED REGISTER SET | |----|-------|----|----|-----------------------| | 24 | 25 | 26 | 27 | | | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 1 | 1 | | 0 | 0 | 1 | 0 | 2 | | 0 | 0 | 1 | 1 | 3 | | 0 | 1 | .0 | 0 | 4 | | 0 | 1 | 0 | 1 | 5 | | 0 | 1 | 1 | 0 | 6 | | 1 | 1 | 1 | 1 | 15 | 10.2.1.12 Condition Code (C, V, G, L) PSW bits 28:31 contain the condition code. As part of the execution of certain instructions, the state of the condition code may be updated to reflect the nature of the result. Not all instructions affect the condition code. For most interrupts, bits 28:31 of the new PSW are simply copied to the condition code. For immediate interrupts, the least significant four bits of the status byte for the interrupting device are copied to the condition code after the new PSW has been loaded. No restrictions are imposed on the condition code field of a new PSW contained in a memory location or register. Any condition code value may be specified. The condition code of the current PSW may be tested by the conditional branch instructions described in Chapter 4. # 10.2.2 PSW Location Counter (LOC) PSW bits 32:63 comprise the location counter, which contains the address of the instruction currently being executed by the processor. When the current instruction is successfully completed, the value contained in the location counter is incremented by the length of the instruction in bytes, and the instruction at the resulting address is fetched. An instruction which results in a branch being taken causes the contents of the location counter to be replaced with the effective branch address; i.e., with the address of the instruction to which control is to be transferred. The instruction at the new address is the next instruction to be fetched and executed. When an interrupt occurs, the entire FSW, bits 0:63, is replaced. If bit 16 of the new PSW (the wait bit) is set, the instruction indicated by the new contents of the location counter is not fetched. Manual intervention is required to cause the wait bit to be zero, and the instruction to be fetched and executed. If an interrupt causes the PSW with the wait bit set to be replaced by another new PSW that has the wait bit zero, the instruction indicated by the location counter of that new PSW is fetched and executed. If an instruction has not been successfully completed when an interrupt PSW swap occurs, the 64-bit PSW, in effect for the instruction being executed at the time of the interrupt, is saved before the interrupt handler is entered. The location counter in the saved PSW points to the instruction being executed at the time the interrupt occurred. If the interrupt occurs after the successful completion of one instruction and before beginning another, the location counter in the saved PSW points to the next instruction to be executed. See Section 10.5, Status Switching, for an explanation of old, current, and new PSW, and of the use of these PSWs by the processor in scheduling interrupt service routines. ## 10.2.3 Reserved Memory Locations Physical memory locations X'000000' - X'0002CF' are reserved memory locations. For systems with expanded I/O interrupt service pointer tables, physical memory locations X'0002DO' - X'0004CF' or X'0002DO' - X'0008CF' are also reserved memory locations. These locations contain assorted information used in servicing interrupts, as shown in Figure 10-2. Use of data in these locations as the result of an interrupt is detailed in the section describing the interrupt. ``` X'000000' - X'00001F' Reserved, must be zero X'000020' - X'000027' Machine malfunction interrupt old PSW X * 000028 * - X * 00002B * Used by console service microcode X'00002C' - X'00002F' LM effective address word X'000030' - X'000037' Illegal instruction interrupt new PSW X * 000038 * - X * 00003F * Machine malfunction interrupt new PSW X*000040* - X*000043* Machine malfunction status word X.000044. - X.000047. Machine malfunction virtual (program) address word X * 000048 * - X * 00004F * Arithmetic fault interrupt new PSW X'000050' - X'00007F' Bootstrap loader and device definition table X.000080. - X.000083. System queue pointer X*000084* - X*000087* Power fail save area pointer X * 000088 * - X * 00008F * System queue service interrupt new PSW X'000090' - X'000097' Relocation/Protection (MAT fault) new PSW X.000038, - X.00003B. Supervisor call new PSW status word X.00006c. - X.0000BB. Supervisor call new PSW location ccunter values X'0000BC' - X'0000C7' Reserved, must be zero X.0000C8. - X.0000CE. Data format fault new PSW X * 0000D0 * - X * 0002CF * Interrupt service pointer table X * 000 2 DO * - X * 000 4 CF * Expanded interrupt service pointer table X*0004D0* - X*0008CF* Expanded interrupt service pointer table ``` Figure 10-2 Reserved Memory Locations ### 10.3 INTERRUPT TIMING AND FRICRITY ## 10.3.1 Maskable and Nonmaskable Interrupts Maskable interrupt conditions are controlled by bits in the PSW. When a request to interrupt due to a maskable condition occurs, the corresponding control bit in the PSW is examined. If the control bit indicates that the interrupt is enabled, an interrupt is taken and control is transferred to the appropriate service routine. The paragraph describing each interrupt provides details about the control bit(s), how the interrupt is enabled or disabled, and the effects of enabling or disabling an interrupt. Nonmaskable interrupts are those which have no corresponding control bits in the PSW. Examples of nonmaskable interrupts are SVC, SINT, Illegal Instruction, and Console Attention. Sections describing each interrupt provide further details. Figure 10-3 shows the various maskable and nonmaskable interrupts. Figure 10-3 Schematic Diagram of Interrupt System Architecture # 10.3.2 Interrupt Timing Asynchronous interrupts are normally permitted to occur only after execution of an instruction has been completed, and before execution of the next instruction begins. However, asynchronous interrupts are permitted to occur at the end of any iteration, while an interruptible instruction is being executed. A synchronous interrupt is permitted to occur at the time the condition causing the interrupt is detected. The SQS interrupt, which occurs at some indefinite time following addition of an entry to the system queue, is called a deferred synchronous interrupt. A synchronous interrupt due to a fault causes the offending instruction to be aborted with no modification of the contents of registers or memory locations generally resulting from execution of that instruction. Fixed—and floating—point Load/Store Multiple, and Store Double—Precision are exceptions to this rule. In the case of an interruptible instruction, the current iteration of the instruction is aborted by such an interrupt without modification of the contents of registers or memory as a result of the faulted iteration. For all interrupts, the old PSW location counter presented to the interrupt handler points to the next logically-executed instruction in the interrupted program. If the interrupt is caused by a fault, the instruction causing the fault was not completed and is logically the next instruction to be executed. The old PSW location counter presented to the fault interrupt service routine, therefore, always points to the instruction which caused the fault. Multiple memory accesses are required for the manipulation of a circular list structure using the ATL, ABL, RTL, or RBL instruction. For each of these instructions, the list header is not updated until the body of the list has been successfully accessed. For the RTL and RBL instructions, no registers are modified unless the list element has been successfully accessed, and the list header has been successfully updated. 10-12 ### 10.3.3 Interrupt Precedence Considering the instant of instruction fetch request as the time of reference, interrupts have the following precedence (highest to lowest): ## INTERRUPT FRECEDENCE TABLE Synchronous Interrupts Fault interrupts System queue service Asynchronous Interrupts Primary power fail/restore Console attention Early power fail Shared memory power fail I/O interrupts Fault interrupts are caused by various conditions that have the following logical precedence in descending priority order. - Relocation/protection fault on an instruction fetch - Machine malfunction fault due to memory malfunction on an instruction fetch - Illegal instruction fault - Illegal subfunction fault - Data format fault due to alignment error on a data read/write operation - Relocation/protection fault on a data read/write operation - Machine malfunction fault due to memory malfunction on a data read/write operation - Data format fault for other than boundary alignment error - Arithmetic fault For a memory malfunction, a nonconfigured memory address fault takes precedence over a noncorrectable memory data fault. Since any fault interrupt causes execution of an instruction to be aborted at the point of the fault interrupt condition, no more than one fault interrupt condition can occur at a time. However, other interrupts in the synchronous and asynchronous interrupt classes given in the preceding Interrupt Precedence Table can occur simultaneously. In such a case, the order given in the table above governs the servicing sequence for the interrupts. ## 10.3.4 Interruptible Instructions For any interruptible instruction, execution consists of the following phases: instruction fetch, instruction decode, an iterative loop, and termination. An interrupt during any phase of an interruptible instruction does not affect the operation of the instruction. It may simply be reexecuted once the interrupt has been serviced. An interrupt during the iterative phase of the instruction causes the processor to resume the iterative phase when the instruction is reexecuted, as though the interrupt never occurred. If the interrupt was caused by a fault, the iteration which resulted in the interrupt is repeated when the instruction is reexecuted. To abort an interruptible instruction when it is interrupted, PSW bit 14 must be forced to zero before any subsequent interruptible instruction (excep6t RDCS or WDCS) is attempted. ### CAUTION SOFTWARE MUST NEVER SET PSW BIT 14 UNLESS RESUMING EXECUTION OF THE INTERRUPTIBLE INSTRUCTION THAT CAUSED BIT 14 OF THE PSW TO BE SET. RESUMPTION OF ANY INTERRUPTIBLE INSTRUCTION MUST NEVER BE ATTEMPTED IF THE CONTENTS OF THE SCRATCHPAC REGISTERS ARE NOT KNOWN TO HAVE BEEN PRESERVED BETWEEN INSTRUCTION INTERRUPTION AND RESUMPTION. # 10.4 PROCESSOR MODES At any given time, the processor may be in the console mode or run mode. The single-step mode provides a means for alternating between the console and run modes. Wait and run states only have meaning for the run mode. ### 10.4.1 Console Mode While the processor is dedicated to communicating with the system console terminal, it is said to be in the console mode. In this mode, program execution is suspended so that the user may examine and modify the data contained in certain registers and memory locations. Appendix F provides a flowchart for the console service routine. The console mode may be entered in any of the following ways: - The Breakpoint (BRK) instruction is executed by a running program when PSW bit 23 is zero. - 2. Execution of an instruction is completed while in the single-step mode. - 3. The HALT/RUN switch or the SINGLE switch is depressed momentarily while the processor is in the run mode. - 4. Following a system initialization sequence, backup power to memory is found not to have been maintained within regulation, and the ISU is not enabled when the sequence is complete. - 5. Following a system initialization sequence, if backup power to memory was maintained within regulation, but the LSU is not enabled and the contents of physical memory location X°000028° indicate that the processor was in the console mode when system initialization occurred. - 6. An attempt to fetch a machine malfunction interrupt new PSW results in a non-correctable memory error. In this case, the error code for the initial malfunction is stored in the machine malfunction status word at X'000040', and LOC is loaded with the address of the status word before the console mode is entered. - 7. If control has been passed to uninitialized Writable Control Store or an errant WCS microprogram, control can be regained at the system console by enabling the single-step mode via the SINGLE switch, and depressing the HALT/RUN switch. Note that system initialization occurs when the power supply detects that AC line voltage is failing; when the Initialize (INIT) switch on the consolette is momentarily depressed; or when the key-operated LOCK/ON/STANDBY switch is moved to the STANDBY position. The initialization sequence completes when power is restored to the processor. System initialization resets all pending interrupts for the system console and other I/O devices in the system. DMA operations are also terminated. While the processor is in the console mode, interrupt conditions are not handled in the same manner as they are if detected during execution of a program. Interrupt requests for the system console terminal and all other I/O devices remain queued until the run mode is entered. DMA operations are not affected by changing processor modes. PSW bit 16 is always forced to zero before the run mode is entered from the console mode. Fault conditions caused by memory accesses while in the console mode are reset when they occur, and do not cause interrupts when the run mode is entered. If a fault condition occurs while attempting to modify a memory location, that location may not be changed. If a fault occurs while attempting to examine a memory location, the console service routine is aborted and restarted. System initialization, while in the console mode, results in automatic shutdown, with no machine malfunction interrupt due to power failure. # 10.4.2 Run Mode When the processor is not dedicated to communicating with the system console terminal, it is in the run mode. In this mode, program execution is controlled by the contents of the 64-bit Program Status Word (PSW). While the processor is in the run mode, it may be in either the wait state (PSW bit 16 is set), or the run state (PSW bit 16 is zero). In the run state, the processor performs a repetitive fetch instruction/execute instruction/fetch next instruction sequence. In the wait state, this sequence is suspended. The run mode may be entered in any of the following ways: - The 'less than' prompt character (<) is entered from the system console terminal when the processor is in the console mode. - 2. The HALT/RUN switch is depressed momentarily while the processor is in the console mode. - 3. The LSU is installed and enabled when a system initialization sequence is completed. In this case, the program loaded from the LSU is given control of the processor. - 4. The 'greater than' single-step character (>) is entered from the system console terminal when the processor is in the console mode. This causes the instruction to be executed in single-step mode, regardless of the position of the SINGLE switch. Interrupt conditions cannot cause the processor to enter the run mode from the console mode, with the following two exceptions: - 1. An initialization sequence performed while the processor is in the console mode causes a program to be loaded from the enabled LSU. Control of the processor is given to that program. - 2. The HALT/RUN switch is depressed momentarily while the processor is in the console mode. ### 10.4.3 Single-Step Mode When the SINGLE switch is in the SINGLE position, the processor is in the single-step mode. In this mode, whenever execution of an instruction is completed, the processor leaves the run mode and enters the console mode. Manual intervention is normally required to execute the next instruction. Interrupts are handled according to the methods detailed in the previous paragraphs. If the processor is in the single-step mode and the run state when an interrupt request occurs, the processor completes the current instruction (or iteration) and then performs the interrupt PSW swap. The first instruction of the interrupt service routine is not executed. If system initialization occurs while in the single-step mode, any instruction in progress (or the current iteration of an interruptible instruction) completes. When the initialization sequence is complete, a maximum of one instruction is executed before the processor again enters the console mode. If the processor is in the run state when the SINGLE switch is placed in the SINGLE position, the console mode is entered. Note that in the single-step mode, PSW bit 16 is always forced to zero before entering the run mode to fetch a user instruction. ### NOTE If interrupts are enabled at the system control terminal interface by software, entering the console mode causes interrupts to be queued from device X°011' (the write side). Depression of any key at the console may cause an interrupt to be queued from device X°010' (the read side). ## 10.5 STATUS SWITCHING The PSW that is loaded in the processor, at any given time, is called the current PSW. The register set selected by this PSW, the data contained in the general, floating-point, or scratchpad registers accessible by the user program, and the machine status defined by the PSW collectively constitute the "process state". If the status word or both the location counter and status word are changed, a status switch has occurred. A status switch can be caused explicitly by executing a status switching instruction or may be forced to occur by an interrupt. When the value of the PSW that was current at the time of a status switch is saved, that value is called the old FSW. The scheduling of interrupt service routines is based upon the concerts of old PSW, current FSW, and new PSW. When an interrupt occurs, the following status switch takes place: the current PSW becomes the old PSW; the new PSW defined for the interrupt is loaded, and becomes the current PSW. For a status switch resulting from an interrupt, the old PSW is stored in dedicated registers of the set specified by the new PSW defined for the interrupt. The machine malfunction interrupt is the exception to this rule; for this interrupt, the old PSW is stored in dedicated memory locations. For meaningful processor response to multiple interrupts, it is important that the new PSW defined for a particular interrupt class does not enable interrupts of the same class. The various interrupts which may occur, and the response of the processor to each interrupt, are described in the following sections. # 10.5.1 Illegal Instruction Interrupt The illegal instruction interrupt occurs if an attempt is made to execute an instruction whose operation code is not one of those permitted by the system. This interrupt may occur for any of the following reasons: - The operation code is undefined for the system, or optional equipment necessary to execute the instruction is not present in the system. - 2. The operation code has several possible subfunction specifications, and the subfunction specified is undefined. - 3. The instruction is a privileged instruction, and PSW bit 23 is set. - 4. The instruction is a floating-point instruction, and PSW bit 13 is set. The illegal instruction interrupt cannot be disabled. The floating-point instructions, high speed data handling instructions, and writable control store instructions require optional equipment, and are therefore optionally illegal. No attempt is made by the processor to execute an illegal instruction. When an illegal instruction interrupt occurs, the following actions are taken: - 1. The current PSW is stored in registers 14 and 15 of the set selected by the illegal instruction interrupt new PSW found in memory at physical address X'000030'. - The illegal instruction interrupt new PSW becomes the current PSW. The old PSW location counter presented to the interrupt service routine in register 15 points to the illegal instruction. #### 10.5.2 Data Format Fault Interrupt The data format fault interrupt occurs if the required halfword or fullword alignments are viclated for memory accesses, or if it is otherwise determined that data is not properly aligned to the specified fields. Halfword alignment violations are not detected by the processor on memory read. The data format fault interrupt cannot be disabled. When a data format fault interrupt occurs, the following actions are taken: - 1. The current PSW is stored in registers 14 and 15 of the set selected by the data format fault new PSW found in memory at physical address X'0000C8'. - Register 13 of the selected set is loaded with a code to indicate the reason for the interrupt, as shown in the following list: # CCDE REASON FOR INTERRUPT - O Reserved code - 1 Reserved code - 2 Invalid sign digit, packed data - 3 Invalid data digit, packed data - 4 Reserved code - 5 Reserved code - 6 Fullword or Halfword alignment fault - 3. If the interrupt was caused by a halfword or fullword alignment fault, register 12 of the selected set is loaded with the nonaligned virtual address causing the fault. - 4. The data format fault interrupt new PSW becomes the current PSW. The old PSW location counter presented to the interrupt service routine in register 15 points to the instruction being executed when the fault occurred. A data format fault causes the current instruction, or the current iteration of an interruptible instruction, to be aborted immediately. #### 10.5.2.1 Alignment Faults An attempt to fetch a fullword of data from memory, or to write a fullword of data to memory, using a program address which does not have zeros as its two least significant bits, causes a fullword alignment fault. An attempt to write a halfword of data to memory, using a program address which does not have zero as its least significant bit, causes a halfword alignment fault. The processor does not distinguish between fullword and halfword alignment faults. An alignment fault cannot occur during an instruction fetch on this processor. If an alignment fault occurs while attempting to write to memory, the fullword or halfword at the next lower aligned address may be modified. ### 10.5.2.2 Invalid Digit Faults If an invalid sign or data digit is encountered while processing numeric string data, it is presumed that the data is not aligned to the specified fields. Additional information may be found in the description of the instruction used to process the numeric string. ### 10.5.3 Relocation/Protection (MAT) Fault Interrupt This fault interrupt occurs if an executing program violates any of the relocation and protection conditions programmed into the Memory Address Translator (MAT). MAT error checking and the MAT fault interrupt are enabled when PSW bit 21 is set. MAT faults are not gueued. When a MAT fault interrupt occurs, the following actions are taken: - 1. The current PSW is stored in registers 14 and 15 of the set selected by the MAT fault interrupt new PSW found in memory at physical address X'000090'. - 2. Register 13 of the selected set is loaded with a code to indicate the reason for the interrupt. This code is copied from the MAT status register while simultaneously resetting the fault. | CODE | REASON FOR INTERRUPT | |------|----------------------------------------| | 0 . | Reserved code | | 1 | Execute protect violation | | 2 | Write protect violation | | 3 | Read protect violation | | 4 | Access level fault | | 5 | Segment limit fault | | 6 | <ul> <li>Nonpresent segment</li> </ul> | | 7 | SST size exceeded | | 8 | PST size exceeded | - 3. Register 12 of the selected set is loaded with the program address which caused the fault. - 4. If the fault occurred on a data fetch while attempting to load the general registers using the Load Multiple (LM) instruction, register 11 of the selected set is loaded with the effective second operand address calculated at the start of the LM instruction. - 5. The MAT fault interrupt new PSW becomes the current PSW. The old PSW location counter presented to the interrupt service routine in register 15 points to the instruction being executed when the fault occurred. Further information on memory management may be found in Chapter 12. #### 10.5.4 Machine Malfunction Interrupt The machine malfunction interrupt occurs when any of the following conditions are detected: - Early power fail - Power restore - Noncorrectable memory data error - Nonconfigured memory address - Shared memory power fail Detection of the listed conditions and the machine malfunction interrupt are enabled when FSW bit 18 is set. Early power fail and shared memory power fail detects are queued until primary power fail occurs if PSW bit 18 is zero. All other malfunction conditions are ignored, and the interrupts are lost. When a machine malfunction interrupt occurs, the following actions are taken: - 1. The current PSW is stored in memory beginning at physical address X'000020'. - 2. The Machine Malfunction Status Word (MMSW) at physical address X'000040' is loaded with a code to indicate the reason for the interrupt. Only one bit is set in this code: | BIT | | |--------|------------------------------------------------------------------------------| | NUMBER | REASON FOR INTERRUPT | | 0 | PF - Power failure | | 1 | PR - Fower restoration | | 2 | NCD - Noncorrectable memory error<br>during data fetch | | 3 | NCI - Noncorrectable memory error during instruction fetch | | 4 | NCA - Noncorrectable memory error<br>during auto driver channel<br>operation | | 5 | NVD - Nonconfigured memory address during data fetch | | 6 | NVI - Nonconfigured memory address during instruction fetch | | 7 | NVA - Nonconfigured memory address during auto driver channel operation | | 30 | SMP - Shared memory power failure | - 3. If the interrupt was caused by a noncorrectable memory error, or nonconfigured memory address, the virtual address used for the memory access is stored in the machine malfunction virtual address word at physical address X\*000044\*. Ctherwise, the contents of this word are undefined. - 4. If the interrupt was caused by a noncorrectable memory error, or nonconfigured memory address, and the fault occurred on a data fetch while attempting to load the general registers using the LM instruction, the effective second operand address calculated at the start of that instruction is stored in the LM effective address word at physical address X'00002C'. Otherwise, the contents of this word are undefined. - 5. The machine malfunction interrupt new PSW found at physical address X'000038' becomes the new PSW. If the interrupt was caused by executing an instruction, the old PSW location counter presented to the interrupt service routine points to the offending instruction. Otherwise, the old PSW location counter presented to the interrupt service routine points to the instruction to be executed once the interrupt has been serviced. If the interrupt was caused by executing the LM instruction, bits 2 and 5 of the Machine Malfunction Status Word (MMSW), may be used to determine if any registers were modified before the interrupt occurred. If the old PSW location counter points to an LM instruction, and if bits 2 and 5 of the MMSW are both zero, no registers were mcdified. If bit 2 or bit 5 of the MMSW is set, then: - 1. If the data stored at physical addresses X'000044' and X'00002C' are equal to one another, no registers were modified by the instruction before the fault occurred. - 2. If the data stored at physical addresses X'000044' and X'00002C' are not equal to one another, at least one register was modified by the instruction before the fault occurred. The number of registers modified may be determined by taking the difference of the data stored at physical addresses X'000044' and X'00002C', and dividing the result by four. Figure 10-4 Machine Malfunction Status Word (MMSW) ### 10.5.4.1 Early Power Fail Detect and Automatic Shutdown Early power fail detect occurs when the primary power failure sensor detects a low voltage; when the power switch is turned from the ON to STANDBY position; or when the INIT switch is depressed. At the end of execution of the current instruction or the current iteration of the current interruptible instruction, a machine malfunction interrupt is taken if PSW bit 18 is set. Following early power fail detect, software has one millisecond before the automatic shutdown procedure of the processor takes control as a result of Primary Power Fail. During this procedure, the following actions occur: - 1. The fullword power fail save area pointer is fetched from location X'000084'. - 2. The following information is saved by firmware in the power fail save area: | DATA | OFFSET IN SAVE<br>AREA (IN BYTES) | |---------------------------------------------------------|-----------------------------------| | Current PSW | 0-7 | | The eight general register sets (in order, 0 through F) | 8-519 | | Interruptible instruction state (scratchpad registers) | 520-583 | | Optional floating-point registers, single and double | 584-679 | 3. The processor waits for power restore. #### NOTES - 1. If the processor is not equipped with the optional floating-point registers, the area between offsets 584 and 679 is not used. - 2. If the pointer found in location X'000084' does not specify a save area aligned to a fullword boundary, the processor forces correct alignment by replacing the two least significant bits of the pointer with zeros. - 3. The floating-point masked mode bit in the PSW has no effect on the saving of the floating-point registers. - 4. The IIP bit in the PSW has no effect on the saving of the scratchpad registers. #### 10.5.4.2 Power Restore When power restore occurs, a simple go/no-go self-test of various internal buses and registers is performed. If the back-up supply voltages to memory were not maintained within margins between shutdown and power restore, the first 256 kbytes of memory are filled with a data pattern to prevent spurious noncorrectable memory error indications, and the general registers, scratchpad registers, and floating-point registers are loaded with predetermined data. The first 256 kbytes of memory are then tested to see if data can be held. This test does not modify the data contained in memory. Failure of self-test or the memory test causes that test to loop, as long as the failure persists. During the test, the processor is responsive only to a primary power fail which results in an automatic shutdown, and the FAULT lamp on the consolette switch panel is on. When memory testing is complete, the FAULT lamp is turned off, and the state of the optional Loader Storage Unit (LSU) is tested. If the LSU is not equipped, it is presumed to be disabled. In all cases, bit 1 of the machine malfunction status word at physical address X°000040° is set to indicate power restore. # 10.5.4.2.1 If the LSU is Disabled If the back-up voltages to memory were not maintained within margins between shutdown and power restore, then memory is assumed not to contain valid data. In this case, a PSW status of '00008000' (wait bit only) and location counter of '00FFFFFE' are loaded and displayed on the system console terminal. Manual intervention is required to restart the processor. The Memory Voltage Failure (MVF) indication is reset in this case. MVF is discussed under the section "If the LSU is Enabled." If the back-up voltages to memory were maintained, the data saved in the power fail save area by the automatic shutdown procedure is reloaded. If the data in memory at physical address X'000028' indicates that the processor was in console mode when power failed, the reloaded PSW is displayed, and communication with the system console terminal resumes. 29-747 R00 4/81 10-25 If the processor was not in console mode when power failed, bit 18 of the reloaded PSW is tested. If the bit is set, a machine malfunction interrupt occurs. If bit 18 of the reloaded PSW is zero, program execution is resumed using the reloaded PSW. Note that the state of the wait bit (bit 16) of the PSW is tested before executing any instruction. #### NOTE Data in the Memory Address Translator and Selector Channel control registers and Writable Control Store is volatile, and must be considered invalid following any power fail/restore sequence. #### 10.5.4.2.2 If the LSU is Enabled After the FAULT lamp is turned off, the program in the LSU is loaded, and control is transferred to it, using the PSW specified in the program. If the memory start address is greater than the memory end address specified for the LSU program, the program is not loaded, and the console mcde is entered. A Memory Voltage Failure (MVF) indication is available to the processor if memory voltages are not maintained within margins between shutdown and power restore. MVF is reset when the console mode is entered, or is reset when the Reset Memory Voltage Failure (RMVF) instruction is executed. If MVF is indicated following power restore, it is assumed that memory does not contain an executable program. The MVF indication is retained until reset as described above, even if multiple shutdown/power restore sequences occur. Software loaded via the optional LSU should execute the RMVF instruction once the load is complete and all interrupt new PSWs have been established. Proper use of the RMVF instruction prevents a potential runaway condition in the event of multiple power failures. #### 10.5.4.3 Noncorrectable Memory Error During write operations to memory, an Error Correcting Code (ECC) is generated. This code enables the memory system to correct any single bit error detected on a subsequent read operation in each fullword of memory. If the operation is only a byte or halfword write to memory, the memory system reads and updates the error correcting code for the fullword of memory that contains the byte or halfword that is being written. Each time data is read from memory, the error correcting code is re-created and compared to the code generated when data was last written to any part of the fullword memory location. If a data error is detected, and the error is a single bit error, it is corrected transparent to the processor. If, however, a multiple bit error is detected, a memory malfunction fault is generated, since multiple bit errors cannot be corrected. Note that data with three or more bits in error may not result in a fault. Detection of any error causes a bit to be set in the optional error logger for subsequent readout using the REL instruction. If PSW bit 18 is zero when the error occurs, the error is ignored, but is logged in the optional error logger. If PSW bit 18 is set, occurrence of a noncorrectable memory error causes the current instruction (or the current iteration of an interruptible instruction) to be aborted immediately, and a machine malfunction interrupt occurs. Bit 2, 3, or 4 of the machine malfunction status word at physical address X'000040' is set to indicate the reason for the interrupt. The program address used for the memory access is stored in the machine malfunction address word at physical address X'000044'. If the error occurs on a data fetch while attempting to load the general registers using the LM instruction, the effective second operand address calculated at the start of the LM instruction is stored in the LM effective address word at physical address $\chi^00002C^0$ . This data allows the instruction to be simulated in the event specified index registers were modified. If the error occurs while fetching an instruction, the old PSW location counter, presented to the interrupt service routine, points to the first halfword of the instruction being fetched. If the error occurs during an auto driver channel operation, registers 0 and 1 of the set indicated by the old PSW presented to the interrupt service routine contain the PSW for the instruction interrupted by the I/O interrupt that activated the channel. Register 4 of the set indicated contains the address of the CCB that was being executed when the error occurred. Since the error correcting code is maintained on a fullword basis, if a multiple bit error is detected when a halfword or byte of a fullword is read, it is not possible to determine which bits are in error. Therefore, a reference to any portion of a fullword that contains multiple bit errors may cause a memory malfunction, even though the incorrect bits might not be in the portion of the fullword being accessed. (References to memory made by look-ahead buffers or caches do not cause memory malfunction interrupts until the fullword that is in error is actually used by the currently executing instruction.) # 10.5.4.4 Nonconfigured Memory Address The processor tests the physical address used for each memory access, if PSW bit 18 is set. When access to memory assigned to a memory controller physically not in the system is attempted, a machine malfunction interrupt occurs. The current instruction (or the current iteration of an interruptible instruction) is immediately aborted. Bit 5, 6, or 7 of the machine malfunction status word at physical address X'000040' is set to indicate the reason for the interrupt. The program address used for the memory access is stored in the machine malfunction address word at physical address X'000044'. If the error occurs on a data fetch while attempting to load the general registers using the LM instruction, the effective second operand address calculated at the start of the LM instruction is stored in the LM effective address word at physical address X'00002C'. This data allows the instruction to be simulated in the event specified index registers were modified. If the error occurs while fetching an instruction, the old PSW location counter, presented to the interrupt service routine, points to the first halfword cf the instruction being fetched. If the error occurs during an auto driver channel operation, registers 0 and 1 of the set indicated by the old PSW presented to the interrupt service routine contain the PSW for the instruction interrupted by the I/O interrupt that activated the channel. Register 4 of the indicated set contains the address of the CCB that was being executed when the error occurred. 10.5.4.5 Shared Memory Power Fail Detect (Optional) This interrupt can occur only if the processor is equipped with the MOS shared memory option. Shared memory power fail detect occurs when the early power failure sensor in the shared memory power supply detects a low voltage. Each processor attached to the shared memory system is interrupted. At the end of execution of the current instruction or the current iteration of the current interruptible instruction, a machine malfunction interrupt is taken if PSW bit 18 is set. Following shared memory power fail detect, software has one millisecond before the MOS shared memory system enters a power-down or stand-by mode. During this time, any necessary housekeeping functions may be performed by system software. There is no mechanism to indicate to the processor that shared memory power has been restored; however, the following sequence may be performed to test for shared memory power: - Store a fullword data pattern in a fullword location in shared memory. This pattern may be any data other than all zeros or all ones. - 2. Store a different data pattern in the next-higher-addressed fullword location in shared memory. - 3. Compare the contents of the first fullword location with the data pattern stored by step 1. If no error is indicated and the patterns are equal, power is applied to the shared memory system. Note that if the MOS shared memory back-up supply voltages are maintained within margins between power fail and power restore, data in the shared memory is retained during the power fail/restore sequence. This can be determined by software means. There is no mechanism, however, to indicate this fact to the processor. If the stand-by voltages were not maintained within margins, the data is lost. In this case, software in the master processor must store a fullword data pattern in each fullword of shared memory, initializing the ECC bits to prevent subsequent spurious noncorrectable memory error indications. An attempt to fetch an instruction or data from shared memory, while the memory is in a power-down or stand-by state, results in a noncorrectable memory error or nonconfigured memory address fault. # 10.5.5 Input/Cutput Device (I/O) Interrupts # 10.5.5.1 Priority Levels Interrupt requests from I/O devices may occur on any of four priority levels. Level 0 is the highest priority level; level 3 is the lowest priority level. Acknowledgement of interrupt requests on the various priority levels is enabled by PSW bits 17 and 20, as shown in the following table: | PSW BIT 17 | PSW BIT 20 | MEANING | |------------------|------------------|---------------------------------------------------------------------------------------------------------------------------| | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | All levels disabled Higher priority levels enabled All priority levels enabled Current and higher priority levels enabled | A unique register set is selected for I/O interrupt requests acknowledged on each priority level. For example, when an interrupt request is acknowledged at priority level 3, register set 3 is selected by the processor for handling the interrupt request. If the request results in entry to a software interrupt service routine, register set 3 is selected by the PSW in effect at the time the routine is entered, and information pertaining to the interrupt is contained in registers 0 to 3 or 0 to 4 of that set. The current priority level is determined by bits 24:27 (the register select field) of the current PSW. For example, if set 3 is currently selected, levels 2, 1, and 0 are higher priority levels, and level 3 is the current priority level. If PSW bit 17 is zero and PSW bit 20 is set, an I/O interrupt request occurring on level 2, 1, or 0 is acknowledged, but a request occurring on level 3 is not acknowledged. In this example, if PSW bits 17 and 20 are both set (the PSW status is X'4830'), the interrupt request on level 3 is also acknowledged. If a register set other than 0, 1, 2, or 3 is selected by the current PSW, all I/O interrupt requests are considered to be higher-priority requests, and will be acknowledged if either PSW bit 17 or bit 20 is set. If the current PSW selects register set 4, 5, 6, or 15, all interrupt levels are considered to be higher priority levels. Enabling of interrupts on the various levels is shown in detail in Table 10-1. When an interrupt request occurs, but is not acknowledged by the processor, the request remains queued until one of the following occurs: - 1. The interrupt request is acknowledged by the processor when enabled by the current PSW. when enabled by the current PSW. - 2. The interrupt request is programmed reset by the software. - 3. System initialization occurs. When the processor acknowledges an I/O interrupt request, the result may be either an auto driver channel operation, or an immediate interrupt. In either case, the register set associated with the priority level, on which the interrupt is acknowledged, is used in processing the interrupt. For further information on programming a device interrupt request reset, refer to the programming manual for the specific device. This feature is not available for all I/O devices. # 10.5.5.2 Immediate Interrupt - Auto Driver Channel Operation An interrupt request by an I/O device at one of the four interrupt priority levels is acknowledged only when interrupts are enabled for that level, as defined by the status of PSW bits 17 and 20, and the selected register set. TABLE 10-1 INTERRUPT PRICRITY LEVEL/REGISTER SET SUMMARY PSW CURRENT BITS REGISTER SET EXTERNAL INTERRUPT LEVEL ENABLED 17 20 LEVEL O LEVEL 1 LEVEL 2 LEVEL 3 0 0 ANY SET NO NC NO NO 0 1 0 NO NO NO NO 0 1 1 YES NC NO NO 0 1 2 YES YES NO NO 0 1 3 YES YES YES NO 0 1 4 YES YES YES YES 0 1 5 YES YES YES YES 0 6 YES YES YES YES 0 F YES YES YES YES 1 0 ANY SET YES YES YES YES 1 1 0 YES NC NO NO 1 1 1 YES YES NO NO 1 1 2 YES YES YES NO 1 1 3 YES YES YES YES 1 1 4 YES YES YES YES 1 1 5 YES YES YES YES 1 1 6 YES YES YES YES 1 1 F YES YES YES YES The processor recognizes I/C interrupts between the execution of instructions, or at the end of an iteration of an interruptible instruction. When an I/O interrupt is recognized, the following actions occur: - 1. The current PSW is saved in registers 0 and 1 of the new set selected by the interrupt level. (PSW bits 0:31 are saved in register 0 and bits 32:63 in register 1.) - 2. The PSW status word is loaded with the value Y'000028NO', where N specifies the new register set. This status enables higher level I/O interrupts and machine malfunction interrupts. Also note that memory address translation is disabled. - The I/O interrupt request is acknowledged and reset. The address of the interrupting device is placed in register 2 of the selected set. The status byte from the interrupting device replaces the contents of register 3. The device number and status are placed in the least significant bit positions in the register; the most significant bits are forced to zero. The four least significant bits of the status of the interrupting device are placed in the condition code. - 4. The device number is added twice to X'0000D0' (the start of the interrupt service pointer table) to obtain the address within the table that corresponds to the interrupting device. The contents of this halfword of memory are fetched and examined to see if the interrupt is to be treated as an immediate interrupt or as an auto driver channel operation. If bit 15 of the halfword is zero, an immediate interrupt is required. If bit 15 of the halfword is one (the halfword is odd), an auto driver channel operation is required. If the interrupt is an immediate interrupt, the value in the table becomes the location counter portion of the current PSW. If the interrupt is an auto driver channel operation, then the least significant bit of the halfword is replaced by zero and the resulting value is placed in register 4 of the selected set. The auto driver channel is then activated. ### 10.5.6 Simulated Interrupt The simulated interrupt results from executing a Simulate Interrupt (SINT) instruction when PSW bit 23 is zero. SINT is a privileged instruction, and may not be executed when PSW bit 23 is set. Execution of the SINT instruction causes the processor to simulate acknowledgement of an enabled I/O interrupt request from an external device. The device address and interrupt level for the simulated interrupt are specified by the operands of the SINT instruction. The states of PSW bits 17 and 20, normally used to enable and disable the various I/O interrupt levels, are ignored by the SINT instruction. For purposes of the simulated interrupt, I/O interrupts at all priority levels are assumed to be enabled. No pending device interrupt request is actually acknowledged by the processor as a result of executing the SINT instruction. With the exception of the differences described here, the simulated interrupt request is handled as detailed in Section 10.5.5. #### CAUTION DUE TO THE FACT THAT THE SINT INSTRUCTION IGNORES THE STATES OF PSW BITS 17 AND 20, IT SHOULD BE USED CAREFULLY BY PROGRAMS WHICH RUN IN REGISTER SETS 0, 1, 2, OR 3. EXAMPLE, IF A PROGRAM EXECUTING IN REGISTER SET 2 ENABLES ONLY HIGHER-LEVEL INTERRUPTS, DATA IN THE REGISTERS OF SET 2 ARE NOT NORMALLY SUBJECT TO CHANGE AS A RESULT OF 1/0 INTERRUPT. HOWEVER, IF THE PROGRAM EXECUTING IN REGISTER SET 2 DOES CAUSING INTERRUPT LEVEL 3 (AND REGISTER SET 3) TO BE SELECTED, THE NEW PSW LOADED BY THE PROCESSOR CAUSES INTERRUPTS AT LEVELS 2, 1, AND O TO BE ENABLED. IF AN I/O INTERRUPT REQUEST AT LEVEL 2 OCCURRED, IT WOULD BE HONORED, CAUSING REGISTERS 0, 1, 2, AND 3 (AND FERHAPS 4) OF SET 2 TO BE OVERWRITTEN. IF THESE REGISTERS ARE NOT STORED BEFORE THE SINT INSTRUCTION IS EXECUTED, DATA IN THE REGISTERS IS LOST, AND SYSTEM SOFTWARE COULD BE LEFT IN AN INDETERMINATE STATE. The simulated interrupt is a software interrupt. # 10.5.7 System Queue Service (SQS) Interrupt When any of the instructions listed below is executed, as the instruction completes, bit 22 of the new PSW loaded by the instruction is tested. If the bit is zero, the SQS interrupt is disabled, and program execution continues according to the new PSW loaded. | MNEMONIC | MEANING | | | |----------|-----------------------------------|--|--| | EPSR | Exchange Program Status Register | | | | LDPS | Load Process State | | | | LPSW | Load Program Status Word | | | | LPSWR | Load Program Status Word Register | | | If bit 22 of the new PSW loaded by any of these instructions is set, the state of the system queue (whose physical address is found at physical location X'000080') is tested. The system queue is assumed to be maintained according to the circular list format. The number used field is fetched from the list header. If this field contains zero, the system queue is assumed to be empty, and program execution continues according to the new PSW loaded. If the number used field for the system queue is not zero when it is tested, the following actions are taken to cause an SQS interrupt: - 1. The current PSW, which was loaded by execution of one of the listed instructions, is stored in registers 14 and 15 of the set selected by the SQS interrupt new PSW found in memory at physical address X°000088°. - 2. Register 13 of the selected set is loaded with the address of the system queue. - 3. The SQS interrupt new PSW becomes the current PSW. If the SQS interrupt occurs as a result of executing an EPSR instruction, the old PSW location counter presented to the interrupt service routine in register 15 points to the instruction following the FPSR instruction. If the interrupt occurs as a result of executing any of the other listed instructions, the old PSW location counter contains the value loaded by the instruction causing the interrupt. Items may be added to the system queue while the SQS interrupt is enabled or disabled. The Add to Top of List (ATL) and Add to Bottom of List (ABL) instructions are normally used for this purpose. The fact that the items have been added to the system queue is recorded in the list header. Only when a new PSW is loaded which enables the SQS interrupt, is the state of the queue tested, and an interrupt allowed. The system queue has a maximum size, as determined by the list header established by system software. If an attempt is made to add an item to the queue when it is already full, the data may be lost. This could result in system software being left in an indeterminate state. Note that the address of the system queue contained in the system queue pointer must be aligned to a fullword boundary. See Section 10.6 on Status Switching Instructions for a description of the EPSR, LDPS, LPSW, and LPSWR instructions. The SQS interrupt is a deferred synchronous software interrupt. # 10.5.8 Supervisor Call (SVC) Interrupt The Supervisor Call (SVC) interrupt occurs when the SVC instruction is executed. This instruction and the resulting interrupt provide a means for any program to communicate with system software. When the SVC instruction is executed, the processor takes the following actions: - 1. The current PSW is saved in registers 14 and 15 of the set selected by the SVC interrupt new PSW found in memory at physical address X\*000098\*. - Register 13 of the selected set is loaded with the effective second operand address calculated for the SVC instruction executed. This is normally the address of an SVC parameter block, aligned to a fullword boundary. - 3. The SVC interrupt new PSW becomes the current PSW, with a new location counter value chosen from the ordered list of halfwords at physical location X°9C°. The old PSW location counter presented to the interrupt service routine in register 15 points to the instruction following the SVC instruction. The SVC interrupt is a software interrupt and cannot be disabled. ## 10.5.9 System Breakpoint Interrupt A system breakpoint results if a Breakpoint (BRK) instruction is executed when PSW bit 23 is zero. BRK is a privileged instruction, and may not be executed when PSW bit 23 is set. Execution of the BRK instruction causes the processor to enter the console mode. In this mode, the processor is dedicated to communication with the system console terminal. Various registers and memory locations may be examined or modified by the user from the system console terminal while in this mode. When the BRK instruction is executed, no registers or memory locations are modified. The FSW status and location counter are not modified by the BRK instruction. The location counter, at entry to the console mode, points to the BRK instruction. When the run mode is entered from the console mode, PSW bit 16 is forced to zero, so that an instruction is fetched and executed. If the run mode is entered immediately after a BRK instruction is executed, the same BRK instruction results in another system breakpoint. The system breakpoint interrupt is a software interrupt. ### 10.5.10 Arithmetic Fault Interrupt The arithmetic fault interrupt results from either a fixed-point or a floating-point arithmetic operation, when the magnitude of the result is too large to be represented within the required number of bits. Division by zero is a special case and always results in an arithmetic fault interrupt. Interrupts for any of these reasons cannot be disabled. Floating-point underflow occurs when the normalized result of a floating-point load, conversion, or other arithmetic operation is not zero, but is so small that it cannot be represented within the floating-point number system defined for the processor. If PSW bit 19 is zero when floating-point underflow occurs, no arithmetic fault interrupt results. In this case, the result of the operation is set to "true zero". This means that every bit of the result is forced to zero as the result is copied to its destination. If PSW bit 19 is set when floating-point underflow occurs, an arithmetic fault interrupt does occur. When an arithmetic fault interrupt occurs, the following actions are taken: - 1. The instruction causing the interrupt is aborted before the data in any register or memory location is modified. - 2. The current PSW is stored in registers 14 and 15 of the set selected by the arithmetic fault interrupt new PSW found in memory at physical address X\*000048\*. - 3. Register 13 of the selected set is loaded with a code to indicate the reason for the interrupt: | CODE | PEASON FOR INTERRUPT | |------|-----------------------------------| | 0 | Fixed-point division by zero | | 1 | Fixed-point quotient overflow | | 2 | Floating-point division by zero | | 3 | Floating-point exponent underflow | | 4 | Floating-point exponent overflow | - 4. Register 12 of the selected set is loaded with the address of the instruction following the instruction causing the interrupt. - 5. The arithmetic fault interrupt new PSW becomes the current PSW. The old PSW location counter presented to the interrupt service routine in register 15 points to the instruction that caused the interrupt. # 10.6 STATUS SWITCHING INSTRUCTIONS Status switching instructions provide for software control of the system's interrupt structure. They also allow user-level programs to communicate efficiently with control software. All status switching instructions, except the supervisor call instruction, are privileged operations; therefore, all interrupt handling routines must run in the supervisor mode. The status switching instructions described in this section are: | 10.6.1 | LPSW | Load Program Status Word | |--------|-------|-----------------------------------| | 10.6.2 | LPSWR | Load Program Status Word Register | | 10.6.3 | EPSR | Exchange Program Status Register | | 10.6.4 | SINT | Simulate Interrupt | | 10.6.5 | SVC | Supervisor Call | | 10.6.6 | BRK | System Breakpoint | | 10.6.7 | PSF | Privileged System Function | # 10.6.1 Load Program Status Word (LPSW) | Assembler Notation | | Or-Code | <b>Format</b> | |--------------------|-------------|---------|---------------| | LPSW | D2(X2) | C2 | RX1,RX2 | | LPSW | A2(FX2,SX2) | C2 | RX3 | ### Operation The 64-bit second operand replaces the current PSW. #### Condition Code Determined by the new PSW (bits 28:31). ### Programming Notes The R1 field of this instruction must be zero. The second operand must be aligned to a fullword boundary. This instruction is a privileged operation. This instruction may be used to change register sets. The new set becomes active for execution of the next instruction. If bit 22 of the new PSW is set, the state of the system queue is tested. If the queue is nonempty, a System Queue Service (SQS) interrupt occurs. In this case, the newly loaded PSW is saved as the old PSW when the SQS interrupt occurs. # 10.6.2 Load Program Status Word Register (LPSWR) | Assemb1 | er Notation | Op-Code | <u>Format</u> | |---------|-------------|---------|---------------| | LPSWR | R 2R 2 | 18 | RR | ### Operation The contents of the register specified by R2 replace bits 0:31 of the current PSW. The contents of the register specified by R2+1 replace bits 32:63 of the current PSW. Condition Code Determined by the new PSW (bits 28:31). Programming Notes The R1 field of this instruction must be zero. The R2 field of this instruction must specify an even-numbered register. This instruction may be used to change register sets. The new set becomes active for execution of the next instruction. This instruction is a privileged operation. If bit 22 of the new PSW is set, the state of the system queue is tested. If the queue is nonempty, a System Queue Service (SQS) interrupt occurs. In this case, the newly loaded PSW is saved as the old PSW when the SQS interrupt occurs. ### 10.6.3 Exchange Program Status Register (EPSR) | Assemb | ler Notation | Op-Code | <u>Format</u> | |--------|--------------|---------|---------------| | EPSR | R1,R2 | 95 | RR | #### Cperation Bits 0:31 of the current PSW replace the contents of the register specified by R1. The contents of the register specified by R2 then replace bits 0:31 of the current PSW. #### Condition Code Determined by the new PSW (bits 28:31). #### Programming Notes R1 and R2 may specify any general-purpose registers. If R1 and R2 specify the same register, bits 0:31 of the current PSW are copied into the register specified by R2, but otherwise remain unchanged. This instruction may be used to change register sets. The new set becomes active for execution of the next instruction. This instruction is a privileged operation. If bit 22 of the new PSW is set, the state of the system queue is tested. If the queue is nonempty, a System Queue Service (SQS) interrupt occurs. In this case, the newly loaded PSW is saved as the old PSW when the SQS interrupt occurs. # 10.6.4 Simulate Interrupt (SINT) | Assembler Notation | | <u>Op-Code</u> | Format | |--------------------|-----------|----------------|--------| | SINT | I2(X2) | <b>E</b> 2 | RI1 | | SINT | R1,I2(X2) | E 2 | RI1 | #### Operation The least significant 10 bits of the second operand are presented to the interrupt handler as a device number. The device number is used to index into the interrupt service pointer table, simulating an interrupt request from an external device. The result is either an immediate interrupt or an auto driver channel operation. #### Condition Code Determined by the status of the addressed device, in the case of the immediate interrupt, or set by the auto driver channel at termination. ## Programming Notes If the R1 field of this instruction is not specified or contains zero, it is assumed that an interrupt from level 0 is required, and register set 0 is selected. If the R1 field of the instruction is nonzero, the least significant 4 bits of the register specified by R1 designate the new register set, and consequently the new interrrupt level. This instruction is a privileged operation. This instruction causes the processor to load registers 0 through 3, or 0 through 4, of the new set as for a real interrupt request. During the execution of this instruction, the device is addressed and the status byte is returned in register 3 of the new set. If the specified device does not respond to the status request, register 3 of the new set contains X'00000004' due to time-out. If an immediate interrupt is being simulated, the V flag is also set in the condition code as a result of the time-out. The SINT instruction does not cause any pending interrupt to be acknowledged. #### 10.6.5 Supervisor Call (SVC) | Assembler Notation | | Or-Code | Format | | |--------------------|-----------------|---------|----------|--| | SVC | N,D2(X2) | E 1 | RX1, RX2 | | | SVC | N, A2(FX2, SX2) | E 1 | RX3 | | #### Operation The second operand (normally the program address of an SVC parameter block) replaces bits 8:31 of register 13 of the set designated by the supervisor call new PSW status. Bits 0:7 of this register are forced to zero. The current PSW replaces the contents of registers 14 and 15 of that set. The fullword quantity located at X'000098' in memory replaces bits 0:31 of the current PSW. The 4-bit N field is doubled and added with X'00009C'. The halfword quantity located at the resultant address becomes the current location counter. #### Condition Code Determined by the new PSW (bits 28:31). ### Programming Note This instruction provides a means to switch from the protect mode to the supervisor mode. It is used by a program running under an operating system to initiate certain functions in the supervisor program. The second operand address is normally a pointer to the memory location of parameters needed by the supervisor program to perform the specified function. Such a pointer must indicate a parameter block aligned to a fullword boundary. The type of supervisor call is specified in the N field of the instruction. Sixteen different calls are provided for. Return from the supervisor is made by executing an LPSWR instruction specifying the stored old PSW in registers 14 and 15 of the set selected by the Supervisor Call interrupt new PSW (LPSWR R14). # 10.6.6 System Breakpoint (ERK) Assembler Notation Op-Code Format BRK 88 SF Operation The BRK instruction causes the processor to enter the console mode. Programming Notes The location counter is not incremented. This instruction is a privileged instruction. # 10.6.7 Privileged System Function (PSF) | Assembler Notation | | Op-Code | Format | |--------------------|-----------------|-----------|---------| | PSF | N,D2(X2) | DF | RX1,RX2 | | PSF | N, A2(FX2, SX2) | <b>LF</b> | RX3 | ### Operation The PSF instruction may perform any one of 16 functions, as specified by the value contained in the N field. The assembler recognizes extended mnemonics which cause the proper value to be specified in the N field of this instruction. The nature of the specified function may vary from processor to processor. The following paragraphs detail PSF operations performed by this processor. | VALUE OF N | EXTENDED<br>PSF<br>MNEMONIC | MEANING | |------------|-----------------------------|---------------------------------------| | 0 | REL | Read Error Logger | | 1 | LPSTD | Load Process Segment Table Descriptor | | 2 | LSSTD | Load Shared Segment Table Descriptor | | 3 | STPS | Store Process State | | 4 | LDPS | Lcad Process State | | 5 | ISSV | Save Interruptible State | | 6 | ISRST | Restore Interruptible State | | 7 | XSTB | Store Byte, no ECC | | 8 | RMVF | Reset Memory Voltage Failure | #### Programming Notes This instruction is a privileged instruction. PSF functions selected by values of N other than those listed above are undefined for this processor and result in an illegal instruction interrupt. # 10.6.7.1 Read Error Logger (REL) Assembler Notation Op-Code Format REL R2 DFO RX1 (see programming notes) ### Operation The register specified by R2 contains an error logger address as shown below. If bit 19 of the specified error logger address is zero, the 16 error logger bits at this address are read. These bits correspond to memory data errors detected since the error logger bits at that address were last read. If bit 19 of the error logger address is set, the error logger status register is read. Bit 16 of this data is one if errors were detected since the status was last read; otherwise, bit 16 of this data is zero. Data read from the error logger replaces the contents of the register specified by R2+1. Bit 16 of the data is copied to the L flag in the condition code. Once the data has been read from the error logger location, data at that location is set to zero. | 624 | 0 7 | 8 9 | 10 13 | 14 15 | 16 18 | 19 | 20 31 | • | |-----|----------|-----|-------|-------|-------|----|----------|---| | | RESERVED | В | М | С | S | х | RESERVED | | | BITS | MNEMONIC | USE | |-------|----------|---------------------------------------------------------------------------------------------------------------------------| | 00:07 | Reserved | Must be zero. | | 08:13 | M | Selects one 256 kb memory array. | | 14:15 | С | Selects one of the four columns within the memory array. | | 16:18 | S | A syndrome code, modulo 8. The 16 error logger bits at a corresponding syndrome address are read if the X bit is zero. | | 19 | X | If this bit is set in the error logger address, error logger status is read. The C and S fields are ignored in this case. | | 20:31 | Reserved | Must be zero. | The format of the data read from the error logger is shown below. S(n) is the bit in the error logger at the address corresponding to the specified syndrome ccde plus $n_{\bullet}$ There may be multiple error loggers in the system, each uniquely accessible via the M field of the REL error logger address. The following paragraphs describe the relationship between an area of memory and the associated error logger. There is an error logger for each memory bank. The bank also consists of a bank controller and at least one main memory storage module (STM). For this processor, there is only one bank within a given memory block. The memory block is noninterleaved. The lowest-addressed byte within a memory block is located on a 1-megabyte boundary. There may be more than one memory block within the system. The primary (lowest-addressed) memory block is labeled Block 0. Memory within the block is configurable in minimum increments of 256 kb. In a system with both local and shared memory, local memory occupies low address space. Local memory cannot occupy the same memory block as shared memory. Condition Code (after reading error logger status) | С | V | G | L | |---|---|---|---| | X | X | X | 0 | | Х | X | X | 1 | No new error bits in selected bank At least one new error bit in selected bank Programming Notes This instruction is a privileged instruction. The R2 field of this instruction must specify an even-numbered register. Reading error logger status sets the error bit to zero, but does not necessarily zero the error logger bits at any syndrome address. REL is assembled as an RX1 format instruction, in which the displacement field is always zero. REL is an extended PSF mnemonic. If the error logger is not equipped, undefined data is returned by this instruction. Refer to the Processor Maintenance Manual for further details of error logger operation. ## PROGRAMMING EXAMPLE: REL In order to determine the number and location of error loggers in the system, it is first necessary to zero the error bit in each possible error logger status register. The following sequence requires that location MEMTOP contain the address of the last byte in memory. For the example, MEMTOP contains Y.003FFFFF. for a 4 Mb memory configuration. | Location | Contains | Assembler Notation | Comments | |------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1000<br>1004<br>1008<br>100C<br>100E<br>1012<br>1014<br>1018<br>101A<br>101E | C820 0010<br>C800 1000<br>DF00 0000<br>OA02<br>DF00 0000<br>OA02<br>DF00 0000<br>FA00 000F FFD0<br>5500 1090<br>4280 1008 | CL RO, MEMTOP | BANK INCREMENT X BIT, LOGGER O BANK O READ BANK O STATUS REG ADVANCE TO BANK 1 READ BANK 1 STATUS REG ADVANCE TO BANK 2 READ BANK 2 STATUS REG ADVANCE TO BANK 3 READ BANK 3 STATUS REG ADVANCE TO NEXT 1 MB BOUNDARY, & BANK O PAST TOP OF PHYS MEMORY ? | | 1020 | 4200 1008 | BL LAB1 | BRANCH: NO | At this time, the error logger error status bits are zero for all loggers associated with memory from address X°000000° through the address value contained in MEMTOP. The following example shows how to create a new error indication in an error logger. On entry, R6 contains the running PSW, with bit 18 forced to zero. This FSW is used to allow errors to be logged without causing a machine malfunction interrupt. | Location | Contains | Assembler Notation | <u>Comments</u> | |------------------------------|---------------------------------------------|-------------------------------------------------------|------------------------------------------------------------------------------------------------------| | 1200<br>1204<br>1206<br>120Å | 5821 0000<br>0802<br>C700 0001<br>DF71 0003 | L R2,0(R1) LR R0,R2 XHI R0,1 XSTE 3(R1) | GET MEMORY DATA FULLWORD COPY FOR XSTB CHANGE LS BIT STORE LS BYTE OF FULLWORD WITH SINGLE-BIT ERROR | | 120E<br>1210<br>1214<br>1216 | 9556<br>5831 0000<br>9565<br>5020 0000 | EPSR R5,R6<br>L R3,0(R1)<br>EPSR R6,R5<br>ST R2,0(R1) | ZERO PSW BIT 18 (MMF) READ, CREATE ERROR RESTORE ENTRY PSW RESTORE MEMORY DATA | If the preceding sequence is used with a program address corresponding to Bank O of the memory block under test, and if the error is shown also in Bank 3, the block is not interleaved. If the error is not shown in Eank 3, but is shown in Bank 1, then the block is 2-way interleaved; otherwise, the block is 4-way interleaved. Note that once the error logger status is read and the error is shown to have been detected, the status bit is set to zero. This requires that the error be re-created before continuing the sequence. A similar technique may be used to determine the amount of memory in each bank of an error logger. The error is created at the lowest 1 Mb boundary in the bank. The next 1 Mb boundary of the bank is tested for the error. If the error bit is set, that address space belongs to the error logger being interrogated. When the error disappears, a new memory block may have been entered. Note that "address wrap" may occur if an address larger than the configured memory size is used. This may be detected by interrogating the logger at the same bank of Block 0. # 10.6.7.2 Load Process Segment Table Descriptor (LPSTD) | Assembler Notation | | Or-Code | Format | |--------------------|-------------|---------|---------| | LPSTD | D2(X2) | DF1 | RX1,RX2 | | LPSTD | A2(FX2,SX2) | | RX3 | #### Operation The second operand address points to a fullword Process Segment Table Descriptor (PSTD), which has the following format: 2231 | 0 1 2 | 14 | 15 31 | |-------|--------------------|-----------------------| | | SEGMENT TABLE SIZE | SEGMENT TABLE ADDRESS | Bits 0:1 Are reserved, and must be zero. Bits 2:14 Contain the number of doubleword entries in the Process Segment Table, minus one. This number defines the Maximum Valid Program Address (MVPA) for the executing program (process). Bits 15:31 Contain the absolute address of the Process Segment Table in main memory, divided by 128. The data in the Process Segment Table is used in translation of program addresses from program to physical address space when PSW bit 21 is set. Condition Code Unchanged ## Programming Notes The operand address must be aligned to a fullword boundary. The LPSTD instruction may be executed regardless of the state of PSW bit 21. The new Process Segment Table is available for execution of the next instruction which is executed with PSW bit 21 set. This instruction is a privileged instruction. LPSTD is an extended PSF mnemonic. # 10.6.7.3 Load Shared Segment Table Descriptor (LSSTD) | Assembler Notation | | Or-Code | <u>Format</u> | |--------------------|-------------|---------|---------------| | LSSTD | D2(X2) | DF2 | RX1,RX2 | | LSSTD | A2(FX2,SX2) | DF2 | RX3 | #### Operation The second operand address points to a fullword Shared Segment Table Descriptor (SSTD), which has the following format: | 2231 | | | | | |-------|--------------------|------|-----------------------|----| | 0 1,2 | ·1 | 4,15 | | 31 | | | SEGMENT TABLE SIZE | | SEGMENT TABLE ADDRESS | | Bits 0:1 Are reserved, and must be zero. Bits 2:14 Contain the number of doubleword entries in the Shared Segment Table, minus one. Bits 15:31 Contain the absolute address of the Shared Segment Table in main memory, divided by 128. The data in the Shared Segment Table is used in translation of program addresses from program to physical address space when PSW bit 21 is set, if the Process Segment Table entry specifies that the segment is shared. Condition Code Unchanged Programming Notes The operand address must be aligned to a fullword boundary. The LSSTD instruction may be executed regardless of the state of PSW bit 21. The new Shared Segment Table is available for execution of the next instruction which is executed with PSW bit 21 set. Following an LSSTD instruction, the Process Segment Table Descriptor must be loaded, using the LPSTD or LDPS instruction, before attempting MAT translation with the newly defined shared segment table. This instruction is a privileged instruction. LSSTD is an extended PSF mnemcnic. # 10.6.7.4 Store Process State (STPS) | Assembler Notation | Or-Code | Format | |---------------------------------|---------|----------------| | STPS D2(X2)<br>STPS A2(FX2,SX2) | DF3 | RX1,RX2<br>RX3 | #### Operation The process state, defined by the old PSW in registers 14 and 15 of the current set, is saved in the area of memory whose starting address is specified by the operand. The area has the following format: | NORMAL OFFSET (BYTES) | STORED DATA | |-----------------------|-------------------------------------------------------| | 0-7 | Process PSW | | 8-11 | Reserved - not used | | 12-75 | Process general registers | | 76-139 | Process interruptible state | | 140-235 | Single- and double-precision floating-point registers | Condition Code Unchanged # Programming Notes The operand address must be aligned to a fullword boundary. This instruction is a privileged instruction. STPS is an extended PSF mnemonic. The process general register set is specified by the old PSW in register 14 when this instruction is executed. If bit 14 of the process PSW in register 14 is zero, the process interruptible state is not saved, and the save area is compacted accordingly. In this case, the process' floating-point registers are saved beginning at an offset of 76 bytes from the specified operand address. If bit 13 of the process PSW in register 14 is set, or if the processor is not equipped with floating-point registers, then floating-point registers are not saved, and the save area is compacted accordingly. ### 10.6.7.5 Load Process State (LDPS) | Assembler Notation | | Or-Code | Format | |--------------------|-------------|---------|---------| | LDPS | D2(X2) | DF4 | RX1,RX2 | | LDPS | A2(FX2,SX2) | DF4 | RX3 | #### Operation Data from the area of memory specified by the operand replaces the current process state. The area has the following format: | NORMAL OFFSET (BYTES) | STORED DATA | |-----------------------|---------------------------------------------------------------------------------------------------------| | 0-7 | Process PSW | | 8-11 | Process segment table descriptor | | 12-75 | Process general registers | | 76-139 | Process interruptible state (if bit 14 in saved PSW is set) | | 140-235 | Process single-precision and double-precision floating-point registers (if bit 13 in saved PSW is zero) | The new PSW at the operand address specifies the general register set which is loaded from the save area. If bit 14 of the new PSW is set, the interruptible state is loaded from the save area. If bit 13 of the new PSW is zero, and the processor is equipped with floating-point registers, then the single- and double-precision floating-point registers are loaded from the save area. If bit 21 of the new PSW is set, the Process Segment Table Descriptor is loaded. Finally, the new PSW at the operand address becomes the current PSW. #### Programming Notes The operand address must be aligned to a fullword boundary. This instruction is a privileged instruction. LDPS is an extended PSF mnemonic. If bit 14 of the new PSW is zero, the process interruptible state is not loaded, and the save area is assumed to be compacted accordingly. In this case, the process floating-point registers are loaded from memory beginning at an offset of 76 bytes from the specified operand address. If bit 13 of the new PSW is set, or if the processor is not equipped with floating-point registers, the process' floating-point registers are not loaded, and the save area is assumed to be compacted accordingly. If bit 22 of the new PSW is set, the state of the system queue is tested before testing the wait bit (bit 16). If the queue is nonempty, a System Queue Service (SQS) interrupt occurs. In this case, the newlyloaded PSW is saved as the old PSW when the SQS interrupt occurs. The state of the wait bit (PSW bit 16) is tested before the next instruction is executed. The process register set is selected in order to load the process general registers. All data is fetched from the save area before the process PSW is loaded. If a fault occurs during the execution of this instruction, one or more of the specified registers may have been modified. The old PSW presented to the fault interrupt service routine in register 14 may select the general register set specified by the process PSW in the save area, but is otherwise the same as the PSW in effect when this instruction is fetched and executed. The old PSW location counter presented to the interrupt service routine in register 15 points to the LDPS instruction. ### 10.6.7.6 Save Interruptible State (ISSV) | Assemb | ler Notation | <u>Op-Code</u> | Format | | | |--------|--------------|----------------|---------|--|--| | ISSV | D2(X2) | DF5 | RX1,RX2 | | | | ISSV | A2(FX2,SX2) | DF5 | RX3 | | | #### Operation The contents of the interruptible instruction scratchpad registers are stored in the 16 fullwords of memory starting at the address specified by the operand. Condition Code Unchanged Programming Notes The operand address must be aligned to a fullword boundary. This instruction is a privileged instruction. ISSV is an extended PSF mnemonic. # 10.6.7.7 Restore Interruptible State (ISRST) | Assembl | ler Notation | Or-Code | Format | | |---------|--------------|---------|---------|--| | ISRST | D2(X2) | DF6 | RX1,RX2 | | | ISRST | A2(FX2,SX2) | | RX3 | | #### Operation The interruptible instruction scratchpad registers are loaded from the 16 fullwords in memory starting at the address specified by the operand. Condition Code Unchanged Programming Notes The operand address must be aligned to a fullword boundary. This instruction is a privileged instruction. ISRST is an extended PSF mnemcnic. # 10.6.7.8 Store Byte, No ECC (XSTB) | Assemb | ler Notation | Or-Code | <b>Format</b> | | |--------|--------------|---------|---------------|--| | XSTB | C2(X2) | DF7 | RX1,RX2 | | | XSTB | A2(FX2,SX2) | CF7 | RX3 | | #### Operation The contents of bits 24:31 of general register 0 are stored in memory at the address specified by the operand, without changing the error correction code bits for the specified memory location. Condition Code Unchanged Programming Notes This instruction is a privileged instruction. XSTB is an extended PSF mnemonic. This instruction may be used in conjunction with the read error logger instruction to test the operation of the Error Correction Codes (ECC). #### 10.6.7.9 Reset Memory Voltage Failure (RMVF) Assembler Notation Op-Code Format RMVF DF8 RX1 (See programming notes) #### Operation The processor's internal Memory Voltage Failure (MVF) indication is reset. The MVF indication is set only as a result of the voltages to main memory not being maintained within acceptable margins during a power fail/restore sequence. Condition Code Unchanged #### Programming Notes This instruction should be executed by software loaded via the optional LSU, after all interrupt new PSWs have been established. Proper use of this instruction prevents a potential runaway condition in the event of multiple power fail/restore sequences. MVF is reset by the processor when the console mode is entered. This instruction is a privileged instruction. RMVF is an extended PSF mnemonic. RMVF generates an RX1 format instruction, in which the displacement field is always zero. # CHAPTER 11 MEMCRY MANAGEMENT #### 11.1 INTRODUCTION The Memory Address Translator (MAT) supports: 2<sup>24</sup> byte (16 Mbyte) physical address space 2<sup>24</sup> byte (16 Mbyte) program address space Segmentation Shared segments Read, write, and execute protection 4 levels of hardware controlled access to segments Figure 11-1 provides a block diagram of the data structures required for various types of translation from program to physical address space. Program address space consists of all memory addresses which may be specified by the executing program. Physical address space consists of all addresses resulting from translation of program addresses to addresses corresponding to actual memory locations. The Memory Address Translator (MAT) performs the translation as detailed in Figure 11-1 and in the following paragraphs. The segment number field of the program address is used as an index into the process segment table to select a segment table entry. The segment table entry points either to a segment or the shared segment table. (See Figure 11-1.) If the segment table entry points to the segment, then the offset selects the desired address relative to the beginning of the segment. If the segment table entry points to a shared segment table, the value is used as an index relative to the beginning of the shared segment table where a segment table entry for the segment can be found. The segment table entry in the shared segment table cannot point to a shared segment table. Figure 11-1 Memcry Address Translation #### 11.2 ADDRESS SPACE This processor supports management of a 2<sup>24</sup> byte physical or program address space. When physical or program addresses are manipulated, they are treated as 24-bit quantities. In general, 32-bit quantities are available to the processor for address calculation. When intermediate calculations are complete, bits 0 through 7 of the 32-bit effective result are forced to zero or discarded, giving a calculated address 24 bits in length, which occupies bits 8 through 31 of the 32-bit effective result. In some instances, an address consisting of less than 24 bits may be used by the processor. Such an address is extended to 24 bits in length by forcing the higher-order bits to zero. #### 11.2.1 Physical Address Space The Memory Address Translator (MAT) is disabled when PSW bit 21 is zero. When the MAT is disabled, any of the $2^{24}$ byte maximum available memory may be directly accessed. In those cases where less than $2^{24}$ bytes of memory are configured, a machine malfunction fault condition is likely to occur as a result of attempting to access memory outside the available limits. #### 11.2.2 Program Address Space The Memory Address Translator (MAT) is disabled when PSW bit 21 is zero. When enabled or disabled, the MAT may be programmed so that when translation is enabled, it is possible for a program to run in a maximum program address space of $2^{24}$ bytes. Program addresses generated during the execution of such a program are translated to physical addresses used in accessing memory by the MAT. If a program address space of less than $2^{24}$ bytes has been created, and a program address is generated which is outside the limits of the program address space, a Memory Address Translator fault occurs. The MAT, when properly programmed, allows simultaneous execution of concurrent processes while protecting each process from interference by the other processes in the system. Violation of any of the enabled protection mechanisms causes a Memory Address Translator fault to occur. A description of such faults may be found in the section on Memory Address Translator Faults in this chapter. If a physical address space of less than 2<sup>24</sup> bytes exists, and program address translation by the MAT results in a physical address which is outside the limits of physical address space, a machine malfunction fault condition is likely to occur. Proper programming of the MAT causes a program address which would result in such a physical address to be intercepted before reaching the memory system. Figure 11-2 shows a 24-bit program address as it would be contained in a 32-bit general register or memory location. The program address is comprised of two fields: SEGMENT and OFFSET. The significance of each field is described in the following paragraphs. **FULLWORD** Figure 11-2 Program Address ## 11.2.2.1 Segment Field The maximum program address space of $2^{24}$ bytes is divided into $2^8$ (256) segments of $2^{16}$ (65536) bytes each. A particular 64 kbyte segment is selected by the most significant 8 bits of the program address (this is shown graphically in Figure 11-2 as bits 0 through 7 of the program address, or bits 8 through 15 of the fullword containing the address). For example, program addresses in the range Y'000000' - Y'00FFFF' select segment 0, as the most significant 8 bits of each address are zero. Program addresses in the range Y'4F0000' - Y'4FFFFF' select segment $4F_{16}$ (7910), as the most significant 8 bits of the address are $4F_{16}$ . ### 11.2.2.2 Offset Field The offset field is comprised of the least significant 16 bits of the program address (this is shown graphically in Figure 11-2 as bits 8 through 23 of the program address, or bits 16 through 31 of the fullword containing the address). The value contained in this field is used as a byte offset into the selected segment. For example, program address Y'09F001' specifies byte F001 of segment 9. The offset field of the program address has no special significance to the MAT, except with respect to segment limit checking (see Section 11.3.3.2). ## 11.2.3 Selection of Program or Physical Addressing PSW bit 21, the relocation/protection bit, controls selection of program or physical addressing. When bit 21 is zero, the Memory Address Translator (MAT) is disabled. In this mode, all addresses generated are physical addresses. No segment table is used; hence, no level checking, access mode checking, etc., is performed. Bits 10 and 11 cf the PSW (the access level bits) are ignored in the physical mode. The user of the physical mode must take care when modifying memory. The fact that a data area has been modified is not recorded by hardware. If it is desired to reflect the modification information in the segment tables, this must be done explicitly by the program running in the physical mode. When PSW bit 21 is set, the MAT is enabled. All addresses generated are program addresses which are translated to physical addresses using the segment tables. System software must ensure that segment table addresses have been specified via the LPSTD and LSSTD instructions (as in the section on Setting of the Program Address Space Size in this chapter) before the MAT is enabled. When the MAT is enabled, bits 10 and 11 of the PSW indicate the level at which the program is running. When a program address is generated, the access level specified in the STE is compared against the contents of bits 10 and 11 of the PSW. If the contents of bits 10 and 11 are greater than or equal to the access level specified in the STE, then access to the segment is permitted; otherwise, a MAT fault occurs. System software should set bits 10 and 11 of the PSW according to the level at which the process is running to insure protection of segments. # 11.3 TRANSLATION FROM PROGRAM TO PHYSICAL ADDRESS SPACE The mapping of program address space to physical address space is accomplished using information supplied in a segment table. A segment table contains one doubleword entry, called a Segment Table Entry (STE), per segment in the program address space created. The segment number field of the program address is used as an index into the segment table for selection of an STE. A segment table must be aligned to a $2^7$ (128) byte boundary in physical memory. The table may contain from 1 to 256 doubleword entries. # 11.3.1 Shared and Private Segments There may be a number of processes resident in the system at any given time. Each of these processes has its own program address space requirements, reflected in the process segment table associated with that process. Consequently, there may be several Process Segment Tables (PSTs) in memory concurrently, although only one, the segment table for the active process, may be known to the MAT at any given time. Section 11.3.2 contains details on how the active Process Segment Table is specified. Segments of the program address space of a process which are used only by that process are called private segments. Other segments of the program address space may exist that are shared with other processes; these segments are consequently called shared segments. Although the STE describing a shared segment may be replicated in the segment tables associated with each process using the segment, it is preferable to maintain a separate Shared Segment Table (SST). For a shared segment, the process STE has an indication that the segment's description is not found in the Process Segment Table (PST), but is instead found in the Shared Segment Table. A detailed explanation of this is found in the section on Hardware Segment Table Entry. The data contained in a segment must be stored in contiguous locations in physical memory. This is called Unpaged Allocation. For unpaged allocation, each segment must be aligned to a 2 (2048) byte boundary in physical memory. # 11.3.2 Segment Table Descriptors and Their Use The Memory Address Translator is enabled only when PSW bit 21 is set. Prior to enabling the MAT, the locations and sizes of the Process Segment Table and Shared Segment Table to be used must be identified to the system by loading the appropriate descriptor registers. These registers can be changed while MAT is enabled. To specify the address of the Process Segment Table to the system, a Load Process Segment Table Descriptor (LPSTD) instruction is used; to specify the address of the shared segment table, the Load Shared Segment Table Descriptor (LSSTD) instruction is used. The STDs are volatile quantities. This means that in the event of a power fail, the values lcaded must be assumed to have been destroyed. The power restore routine must reload the SSTD and PSTD before enabling the MAT. #### 11.3.2.1 Format of a Segment Table Descriptor A Segment Table Descriptor (STD) is a fullword quantity, as shown in Figure 11-3. Bits 0 and 1 of the STD are reserved and must always be zero. Bits 2 through 14 specify the segment table size, minus 1. For example, if the segment table size were 4, this field would have a value of 3. For a process STD (PSTD), this field has a maximum value of 255 (Y°FF°). For a shared STD (SSTD), this field has a maximum value of 8191 (Y°1FFF°). Bits 15 through 31 of the STD specify the segment table physical address, divided by $2^7$ (128). A segment table must be aligned to a $2^7$ byte boundary in physical memory. For example, if a segment table starts at location Y°035F80°, then bits 15:31 of the STD contain Y°06BF° (Y°035F80°; divided by $2^7$ ). The value of 0 for this field is a reserved value and, therefore, no segment table can start at physical address 0. Figure 11-3 Segment Table Descriptor #### 11.3.2.2 Setting the Program Address Space Size When a PSTD is loaded, its segment table size field determines the maximum valid program address. The maximum valid program address (MVPA) is defined by the following formula: MVPA = (number of segment table entries)\*(Y'10000') + X'FFFF' The MVPA includes address space for the zeroth Segment Table Entry (STE). For example, if the specified segment table size in the STD is 5, (requiring 6 segment table entries) then program addresses in the range Y'000000'-Y'05FFFF' are considered valid. If a program address is generated which is greater than the MVPA, a MAT fault occurs. (See Section 11.4 cn MAT Faults.) Within the valid program address space, there may be segments which are not used. For example, a program address space of a process uses segments 0, 1, 2, and 5 while segments 3 and 4 are unused in that process. In this case, the segment table must contain entries for segments 3 and 4. To indicate that each of these segments is unused, its STE indicates that it is nonpresent and unused. (See Section 11.3.3.3 on Software Segment Table Entry). #### 11.3.3 Segment Table Entries Figure 11-4 represents a segment table entry. Entries in the shared segment table and process segment table have the same format, with minor differences which are detailed in the following text. # 11.3.3.1 Segment Table Entry Size An STE is a 64-bit quantity. Bits 0:31 are the hardware STE and bits 32:63 are the software STE. The hardware STE contains the necessary information to enable hardware to perform program to physical address translation. The software STE contains information used by system software to manage the process address space and keep track of segment history. # 11.3.3.2 Hardware Segment Table Entry The hardware portion of the STE (HSTE) is contained in bits 0:31 of the STE. The HSTE is comprised of several fields as shown in Figure 11-4. Reserved fields of the HSTE must always contain zero. | 0 | 1 | 2 | 3 | 5 | 6 7 | 8 | 9 | 10 | | 14 | 15 31 | |----|------|----|----|-------|-----|---|-----------|----|-----|----|-------| | R | Р | D | | Α | L | S | Um<2mm2m2 | | SLF | | SRF | | | HSTE | | | | | | | | | | | | 32 | 33 | 34 | 35 | 36 37 | 38 | | | 43 | 44 | | 63 | | | | | | R | | | | | | | | U H E PUN RSN V E D SSTE Figure 11-4 Segment Table Entry - R Reference Bit Bit 0 of the HSTE is called the reference (R) bit. This bit of the HSTE is set by the hardware when the segment is referenced by software. A segment is said to be referenced when an attempt is made to read, write, or execute the contents of the segment. DMA I/O does not set the reference bit for the participating segment. - P Presence Bit Bit 1 of the HSTE is the presence (P) bit. The presence bit is set when the segment described by the STE is in memory; it is zero when the segment is not present in memory. A segment is said to be present when any portion of the segment is in memory. When P=0, hardware ignores the contents of the rest of the HSTE (Bits 2 through 31), but the R bit is set as a result of the attempted access. Referencing a segment that is not present (P=0) causes a fault. (See Section 11.4.1.2 on Nonpresence Fault.) - D Dirty Bit Bit 2 of the HSTE is called the dirty (D) bit. This bit of the HSTE is set by the hardware when a program modifies (writes into) a segment. This bit is not set by DMA I/O operations that modify the segment. If P=O, attempts to modify the segment do not affect the dirty bit. If the PST STE indicates that the segment is shared, the D bit is set in both the SST STE, and in the PST STE, for a write. A - Access Mode Bits - Bits 3 through 5 of the HSTE are called the access mode (A) bits. These bits determine the allowed modes of access to the segment. The three modes of access to a segment are: read access, write access, and execute access. If an attempt is made to access a segment in a manner not permitted by the setting of the access mode bits, a MAT fault occurs. For example, instructions cannot be fetched from a segment unless execute access is enabled. Section 11.4 contains a detailed definition of all MAT faults. Table 11-1 defines access field settings and the types of access that are enabled. TABLE 11-1 SEGMENT ACCESS FIELD SETTINGS | SETTING | READ ENABLED | WRITE ENABLED | EXECUTE ENABLED | | |---------|--------------|---------------|-----------------|--| | 000 | No | No | No | | | 001 | No | No | Yes | | | 010 | No | Yes | No | | | 011 | No | Yes | Yes | | | 100 | Yes | No | No | | | 101 | Yes | No | Yes | | | 110 | Yes | Yes | No | | | 111 | Yes | Yes | Yes | | L - Access Level Bits - Bits 6-7 of the HSTE are called the access level (L) bits. The L field is used in conjunction with bits 10 and 11 of the Program Status Word (PSW) to determine if a program can access a segment. If the contents of PSW bits 10 and 11 are greater than or equal to the L bits, then access to the selected segment is allowed; if the value of PSW bits 10 and 11 is less than L, then a fault occurs. The L bits are checked before the A bits. See Section 11.4 for a detailed description of MAT faults. S - Shared Segment Bit - Bit 8 of the HSTE is called the Shared Segment (S) bit. If this bit is zero, the MAT performs protection and relocation functions as defined for a private segment. The S bit must be zero for all STEs in the SST. If the S bit is set in a Process Segment Table entry, the selected segment is a shared segment. In this case, the SRF field of the PST STE is used as a byte offset into the SST. The SST STE found at the resulting address is used by the MAT in performing protection and relocation functions, as follows: The values of the A fields in the PST STE and the SST STE are ANDed to determine the allowed access modes. All other MAT protection and relocation functions are performed using data from the SST STE. SLF - Segment Limit Field - Bits 10 through 14 of the HSTE are called the Segment Limit Field (SLF). The SLF is used to indicate the size of a segment. The SLF contents are determined according to the following formula: SLF = (size of segment) divided by $(2^{11})$ -1 For example, for a segment of size 2<sup>11</sup> bytes, the SLF would contain 0. When a program address is generated, the contents of bits 8:12 of the program address is compared to the SLF. If the SLF is less than this number, a MAT fault occurs (see Section 11.4). The granularity of memory allocation is $2^{11}$ (2,048) bytes. This means that memory must be allocated in $2^{11}$ byte units. For example, if a segment requires Y'3542' bytes, 14 kbytes of memory must be allocated, though only part of the last 2,048 bytes is used. SRF - Segment Relocation Field - Bits 15 through 31 of the HSTE are called the Segment Relocation Field (SRF). The interpretation of the SRF depends upon the setting of the S bit. If S is set in the PST, the PST SRF field contains a byte offset into the SST at which the STE for the segment can be found. If the value contained in the PST SRF field is greater than the size in bytes of the SST, a MAT fault occurs. See Section 11.4 for a detailed description of MAT faults. If S is zero in the PST, the SRF contains the physical address of the segment in memory, divided by $2^7$ . For example, if the segment starts at physical address Y'146800', the SRF field of the HSTE should contain X'28D0'. Note that for a shared segment, the least significant 3 bits of the SRF field in a PST HSTE must be zero, as the indicated SST HSTE is aligned to a doubleword boundary. The least significant 4 bits must be zero for the SRF field in all other cases, as the SRF is the address of a segment aligned to a 2<sup>11</sup> byte boundary, divided by 2<sup>7</sup>. If the MAT attempts to use an SRF field which has a one in any of these trailing bits, the results are undefined. ### 11.3.3.3 Software Segment Table Entry Bits 32-63 of the segment table entry are called the Software Segment Table Entry (SSTE). These bits are used by software in managing the program address space, and have no hardware significance to the processor. The information presented in this section details one possible scheme for software management of memory. The fullword SSTE is available for any software memory management scheme. The OS/32 MT operating system software does not manage memory as suggested in this section. a. Usage Mode Bits - Bits 0 and 1 of the SSTE (bits 32 and 33 of the STE) are called the usage mode (U) bits. In conjunction with the P bit in the HSTE, these bits indicate the state of each segment. Possible states of a segment are: | State | <u>P</u> | $\bar{\mathbf{n}}$ | |----------------|----------|--------------------| | Unused | 0 | 00 | | Used | 0 | 01 | | Loading | 0 | 10 | | Unloading | 0 | 11 | | Active | 1 | 00 | | I/O Ongoing | 1 | 01 | | Unload Pending | 1 | 10 | - 1. Unused State If a segment is logically an invalid portion of the program address space of a process, then it is said to be in the unused state. For example, if a process has data in segments 0, 1, 2, and 5, but has no data in segments 3 and 4, references to segments 3 and 4 are invalid. Since segments 3 and 4 must each have an STE, the fact that these segments represent an invalid portion of the program address space of the process is indicated by setting P=0 and U=0 for the unused state. Since P=0 in the HSTE, any references to such a segment cause a MAT fault. The fault handler, using the U field, may determine that the fault was caused by a reference to an invalid portion of the process program address space and can take appropriate action. - 2. Used State If a segment is logically a valid part of the process program address space, but is not physically present in memory, that segment is said to be in the used state. When a reference is made to such a segment, a MAT fault occurs since P=0 in the HSTE. The fault handler, using the U field, may determine that the fault was caused by a reference to a used segment, and then take action to load the segment. When a used segment is to be loaded, the segment state is changed by scftware from used to loading as explained in the next paragraph. 3. Loading State - If a segment that is logically part of the program address space of the process is being moved from backing store into physical memory, it is said to be in the loading state. If a reference is made to a segment that is in the loading state, a fault occurs since P=O in the HSTE. The fault handler normally places the process that made the reference into a wait state, pending completion of the loading operation. When a segment has successfully been loaded, software normally changes its state from loading to active. At this point, any process that faulted because it referenced the segment in the loading state, and was consequently put into a wait state, may resume execution. 4. Unloading State - When a segment that is logically part of the program address space of the process is being temporarily removed from physical memory and copied to back-up store, it is said to be in the unloading state. Any references to such a segment cause a MAT fault, because P=O in the HSTE. When a MAT fault occurs and the U field indicates that it was caused by a segment in an unloading state, the fault handler has a choice of actions it can take. For example, if the segment was being unloaded to make physical memory space available, the process that made the reference can be put into a wait state. When the unload completes, the physical memory that the segment occupies may be retained and the segment put into an active state. If it is desired to give the physical memory that the segment occupied to another segment, then the unloaded segment should be put into the used state and the fault should be treated in the same manner as faults that occur in a used state. In some systems, a segment may be unloaded because it is being removed not only from physical memory but is also being removed logically from the program address space of the process. A dynamically attached and detached buffer segment is an example of such a segment. If a segment in an unloading state is being logically removed from the program address of the process, the segment goes into an unused state at the completion of the unloading operation. Faults generated by references to such segments are normally errors. - 5. Active State When a segment is logically in the program address space of a process, physically resident in memory, and free to be used by the process within the restrictions placed by the A and L fields, it is said to be in the active state. The active state is the normal state for a segment that is being used by a process. - 6. I/O Ongoing State When I/O operations are being performed upon the contents of an active segment, the segment is put into the I/O ongoing state. The physical memory being occupied by the segment may not be deallocated and reassigned to another segment. The segment should not be unloaded until all I/O operations terminate. A segment should be in I/O ongoing state until all I/O operations being performed upon the contents of the segment have been completed. At this point, the segment may be returned to the active state. - 7. Unload Pending State If it is determined that a segment is to be unloaded and the segment is in the I/O ongoing state, the segment must be placed in an unload pending state which indicates that it is to be unloaded when all I/O operations terminate. When the last I/O operation completes, the segment may be placed in an unloading state and may then be unloaded. If the decision to unload the segment is changed while the segment is in an unload pending state, the state should be changed back to either I/O ongoing, if there are still outstanding I/O operations, or active, if all I/O operations have completed. - b. Reference History Bits Bits 34 and 35 of the STE (bits 2 and 3 of the SSTE) are called the reference history (R) bits. The H field is used to manage replacement algorithms. At given intervals, the state of the R and D bits in the HSTE are recorded in the H field and are reset in the HSTE. The state of the R bit is retained only between intervals. For example, if the R bit is reset at the time it is examined, the H field will indicate that the last state of the R bit was reset (0). In contrast to this, once D has been set in the HSTE, that fact is retained in the H field until the segment is either unloaded or a copy of the modified state of the segment is made. The H field is composed of 2 bits. The most significant bit of the H field will always be set equal to the value of R at the time the HSTE was last scanned and reset. The least significant bit of the H field will be an OR of its previous contents and the setting of D in the HSTE the last time D was scanned. This results in four possible values for the H field: - segment unreferenced in last interval, unmodified (H=00) - 2. segment referenced in last interval, unmodified (H=10) - 3. segment referenced in last interval, modified (H=11) - 4. segment unreferenced in last interval, modified (at some previous time) (H=01) - c. Reserved Field Bits 36 and 37 of the STE (bits 4 and 5 of the SSTE) are reserved. These bits must be set to 0. - d. Disk Address Bits 38 through 63 of the STE (bits 6 through 31 of the SSTE) contain the Disk Address (DA) field. This field contains two subfields: the Paging Unit Number (PUN) which is contained in bits 38 through 43 of the STE (bits 6 through 11 of the SSTE) and the Relative Sector Number (RSN) which is contained in bits 44 through 63 of the STE (bits 12 through 31 of the SSTE). A paging unit is a randomly accessible device which may be read from or written to. This unit is used to load and unload segments. The PUN is used as an index into a Page Device Table (PDT) which is used to translate the PUN into a physical device. The PDT entry contains a physical device address and a device starting sector. The RSN in the SSTE is added to the starting sector specified in the PDT entry to compute the actual sector number at which segment can be found. There may be up to 32 paging units used in a system at any given time. The PDT allows independence of the logical paging unit from the physical paging unit. For example, a given physical device could be divided into multiple paging units or several physical devices could be combined to be a single paging unit. # 11.4 MEMORY ADDRESS TRANSLATOR FAULTS Previous sections of this manual have stated that certain conditions result in MAT faults. A fault is an indication that some exception condition has occurred and that system software should take some action in response. Some faults (such as access violation) are indicative of error, while other faults (such as presence fault) may be used for management of the software system. ## 11.4.1 Conditions that Cause MAT Faults The conditions that cause MAT faults to occur are described in the following sections. # 11.4.1.1 PST or SST Size Exceeded Fault The LPSTD or LDPS instruction defines the MVPA (as in Section 11.3.2.2). If an address is generated that is greater than the MVPA, a FST size exceeded fault occurs. The LSSTD instruction defines a size for the SST. If an STE in the PST specifies an SST offset greater than the size of the SST, an SST size exceeded fault occurs. If the MVPA is exceeded for the PST, then no reference to memory is made. If the fault is caused by exceeding the valid size of the SST, then only the Process Segment Table will have been referenced. ## 11.4.1.2 Nonpresence Fault The nonpresence fault occurs when an STE which has its presence bit reset (0) is referenced. The program address that caused the fault is returned to systems software. The R bit of the referenced STE is set; but the contents of the segment and the D bit in the STE are not modified as a result of a reference to a nonpresent segment. If the nonpresent segment can be loaded, the instruction that caused the fault may be reexecuted after the segment is loaded. For certain instructions, software intervention may be required to allow correct reexecution. Section 11.4.4 contains a detailed description of how to recover from a nonpresence fault. # 11.4.1.3 Access Level Fault An access level fault occurs when the access level specified by bits 10 and 11 of the PSW is less than the access level specified in an STE that is referenced. The R bit of the referenced STE is set: the contents of the segment and the D bit in the STE are not modified as a result of a reference for the segment which causes an access level fault. If system software can correct the fault, the faulting instruction may be reexecuted with certain restrictions. See Section 11.4.4 for details. # 11.4.1.4 Access Mode Faults There are three access mode faults: read access fault, write access fault, and execute access fault. Each fault occurs when a mode of access is attempted for a segment that does not allow that mode of access. The R bit of the referenced STE is set; but the contents of the segment and the D bit in the STE are not modified as the result of an attempted access resulting in the access mode fault. If system software can correct the fault, the instruction may be reexecuted with certain restrictions. See Section 11.4.4 for details. # 11.4.1.5 Segment Limit Fault A segment limit fault occurs when the value contained in bits 8:12 of a program address is greater than the value specified in the SLF field of the HSTE. The R bit of the referenced STE is set; but the contents of the segment and the D bit in the STE are not modified as the result of an attempted access resulting in a segment limit fault. If the system software can correct the fault, then the instruction that caused the fault may be reexecuted with certain restrictions. See Section 11.4.4 for details. #### 11.4.2 Fault Precedence While some faults may physically be checked for in parallel by the hardware, there is a logical priority in which faults are checked: - 1. Segment table size exceeded - 2. Nonpresent segment - 3. Segment limit violation - 4. Access level violation - 5. Access mode violation Detection of any of the listed MAT faults causes the user instruction to be aborted immediately. The reason for the abort is reported to system software as detailed in Section 11.4.3. Only one MAT fault can occur for a single memory operation. #### 11.4.3 MAT Fault Handling Routine When a MAT fault occurs, the MAT fault handling routine pointed to by the MAT fault handler new PSW is entered. The MAT fault interrupt new PSW is contained in physical location X'000090'. The PSW in effect at the time the fault occurs is placed in registers 14 and 15 of the set selected by the MAT fault handler new PSW. The location counter of the old PSW (register 15) contains the address of the instruction that caused the fault. Register 13 of the selected set is loaded with a value to indicate the reason for the fault. The possible values are: | VALUE | MEANING | |-------|---------------------------------------| | 0 | Reserved code | | 1 | Access mode fault - execute protected | | 2 | Access mode fault - write protected | | 3 | Access mode fault - read protected | | 4 | Access level fault | | 5 | Segment limit fault | | 6 | Nonpresent segment fault | | 7 | SST size exceeded | | 8 | PST size exceeded | Register 12 of the selected set is loaded with the program address that caused the fault. If the fault occurred during execution of the LM instruction, the calculated address of the start of the data block is placed in register 11 of the selected set. # 11.4.4 Reexecution of Faulting Instructions In general, an instruction that caused a correctable MAT fault can simply be reexecuted after the fault is corrected. The Load Multiple (LM) instruction in some cases cannot simply be reexecuted, but must be simulated. When a Load Multiple instruction faults, register 11 of the set specified by the MAT interrupt new PSW is loaded with the program address calculated by the hardware as the effective second operand address of the instruction. If that address is the same as the program address which caused the fault (contained in register 12), then the instruction may be reexecuted once the fault has been corrected; no registers were modified by the LM instruction. If the addresses in register 11 and register 12 are not equal, at least one register was modified by the LM instruction. Once the fault has been corrected, system software should build and execute an instruction sequence to load the required registers, using the calculated program address in register 11. If the addresses are not equal, then the difference in the addresses, D, should be computed. The last register modified, M=(D/4)-1+R1, should be calculated. If M is less than the X2 field in an RX1 or RX2, or is less than both the FX2 and SX2 fields in an RX3, the instruction may be reexecuted. If this is not the case, then system software must build an instruction sequence to load the remaining registers from the appropriate memory locations. The location portion of the old PSW should then be incremented by the length of the faulted instruction. At this point, normal execution can be resumed by loading the old PSW. # 11.4.5 Effect of System Initialization on the MAT When the Initialize switch (INIT) on the display panel is depressed, or the processor is powered up, all segmentation, relocation, protection, and MAT interrupts are disabled regardless of the state of bit 21 in the current PSW. The contents of the Shared Segment Table and Process Segment Table descriptor registers must be restored by software after power fail. The MAT remains disabled until an LPSTD instruction is issued. At this time, the MAT is enabled or remains disabled, according to the state of bit 21 of the current PSW. #### 11.5 MEMORY MANAGEMENT INSTRUCTIONS Instructions are provided to control the MAT. These instructions are: LPSTD Load Process Segment Table Descriptor LSSTD Load Shared Segment Table Descriptor ## 11.5.1 Load Process Segment Table Descriptor (LPSTD) | Assembl | er Notation | <u>Op-Code</u> | <b>Format</b> | | |---------|-------------|----------------|---------------|--| | LPSTD | D2(X2) | DF1 | RX3 | | | LPSTD | A2(FX2,SX2) | DF1 | RX3 | | #### Operation The operand specifies the address of the fullword Process Segment Table Descriptor. This descriptor is loaded and its contents define the Process Segment Table to be used in program to physical address translation when bit 21 of the PSW is set. Condition Code Unchanged Programming Notes This instruction is a privileged instruction. The address specified by the operand must be on a fullword boundary. A Process Segment Table Descriptor may be loaded while PSW bit 21 is set or zero. LPSTD is an extended PSF mnemonic. # 11.5.2 Load Shared Segment Table Descriptor (LSSTD) | Assemb] | ler Notation | <u>Op-Code</u> | Format | | |---------|--------------|----------------|---------|--| | LSSTD | D2(X2) | DF2 | RX1,RX2 | | | LSSTD | A2(FX2,SX2) | DF2 | RX3 | | #### Operation The operand specifies the address of the fullword Shared Segment Table Descriptor. This descriptor is loaded and its contents define the Shared Segment Table to be used in program to physical address translation when bit 21 of the PSW is set. Condition Code Unchanged Programming Notes This instruction is a privileged instruction. The address specified by the operand must be on a fullword boundary. A Process Segment Table Descriptor may be loaded while PSW bit 21 is set or zero. LSSTD is an extended PSF mnemcnic. Following an LSSTD instruction, the Process Segment Table Descriptor must be loaded, using the LPSTD or LDPS instruction, before attempting MAT translation with the newly defined shared segment table. ## APPENDIX A CP-CODE MAP 635-1 MSD --- | BTBS BTFS BFBS BFFS | PBR 1 | 4 | ST 3 | 1<br>4<br>AHM | 7<br>STD 3<br>1<br>3<br>STME | 8 | 9<br>SRHLS<br>SLHLS | A | В | C<br>BXH | STM <sup>3</sup> | E<br>TS | F | |------------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------|---------|----------------------|------------------------------|---------------|---------------------|-----------|-----|----------------|------------------|------------|-----| | BTFS<br>BFBS | PBR 1 | STH 4 BAL 4 | ST 3 | STE<br>1<br>4<br>AHM | STD 1 | | | | | | | | | | BFBS | PBR 2 | BAL<br>4 | | АНМ | | | 61 111 6 | į | | | | | | | | PBR<br>1 | | | | | | 3EIIE3 | | | BXLE | LM S | svc 3 | | | BFFS | | | | 2 PB 4 | 3<br>LME<br>1 | STDE<br>1 | STBR | | | 3<br>LPSW<br>* | sтв | SINT | | | | LPDR | 4<br>BFC | | 3<br>LRA | 4<br>LHL | | LBR | | | тні | LB | SCP | ті | | LIS | EXHR | 4<br>NH | 3<br>N | 3<br>ATL | твт | 3<br>LED<br>1 | EXBR | LEDR<br>1 | | NHI | CLB | | NI | | LCS | | 4<br>CLH | 3<br>CL | 3<br>ABL | SBT | | EPSR | LEGR<br>1 | | CLHI | AL<br>* | | CLI | | AIS | | 4<br>OH | o 3 | RTL 3 | RBT | | | LDGR<br>1 | | оні | | LA | оі | | sis | LCDR | 4<br>XH | x 3 | RBL 3 | СВТ | 3<br>LDE<br>1 | | LDER<br>1 | | хні | | 3<br>TLATE | ХI | | LER 1 | LDR 1 | 4<br>LH | 3<br>L | 3<br>LE 1 | LD | BRK | WHR | | | LHI | 4<br>WH | | LI | | CER | CDR | CH 4 | С 3 | CE | CD | | RHR<br>* | | | сні | 4<br>RH<br>* | | СІ | | AER | ADR | AH 4 | A 3 | AE 3 | AD 3 | 1 | WDR | | | АНІ | WD<br>* | RRL | AI | | SER | SDR | 4<br>SH | 3<br>S | SE | SD | | RDR | | | sнı | RD<br>* | RLL | SI | | MER | MDR | MH 4 | м 3 | ME 3 | MD | RXRX | | | | SRHL | | SRL | | | DER | DDR | DH 4 | D 3 | DE 3 | DD 3 | 3 | SSR<br>* | | | SLHL | SS<br>* | SLL | | | FXR | FXDR | | | | STMD | 3 | OCR | | | SRHA | oc<br>• | SRA | | | FLR | FLDR | | 1 | l l | 5<br>LMD | 3 | | | | SLHA | PSF | SLA | | | | LCS AIS SIS LER 1 CER 1 SER MER DER | LCS AIS SIS LCDR 1 LER 1 1 CER 1 1 AER 1 ADR 1 SER 1 SDR 1 MER 1 MDR 1 DER 1 DDR 1 FXR 1 FXDR 1 | LCS OPTIONAL FLOATING-POINT INSTRUCTION OPTIONAL HIGH-SPEED DATA HANDLING INSTRUCTION SECOND OPERAND ADDRESS MUST BE FULLWORD ALIGNED. SECOND OPERAND ADDRESS MUST BE HALFWORD ALIGNED. USE SCRATCHPAD REGISTERS. PRIVILEGED INSTRUCTION 636-1 #### RXRX SUB FUNCTIONS | ٨ | MSD | • | | | | |---------------|------|---|-------|---|---------------------------------| | | 0 | 1 | 2 | 3 | | | | 4 | 5 | 6 | 7 | IMMEDIATE LENGTH SECOND OPERAND | | | 8 | 9 | Α | В | IMMEDIATE LENGTH FIRST OPERAND | | | С | D | E | F | IMMEDIATE LENGTH BOTH OPERANDS | | LSD<br>0 | M∨TU | | | | | | 9 1<br>000 | MOVE | | MOVEP | | | | FUNCTION CODE | CPAN | , | CPANP | | USE SCRATCHPAD REGISTERS | | NO 3 | PMV | | PMVA | | | | 4 | UMV | | UMVA | | | #### PRIVILEGED SYSTEM FUNCTIONS (PSF) | OP-CODE | MNEMONIC | MEANING | |---------|----------|---------------------------------------| | DF0 | REL | READ ERROR LOGGER | | DF1 | LPSTD | LOAD PROCESS SEGMENT TABLE DESCRIPTOR | | DF2 | LSSTD | LOAD SHARED SEGMENT TABLE DESCRIPTOR | | DF3 | STPS | SAVE PROCESS STATE | | DF4 | LDPS | LOAD PROCESS STATE | | DF5 | ISSV | SAVE INTERRUPTIBLE STATE | | DF6 | ISRST | RESTORE INTERRUPTIBLE STATE | | DF7 | XSTB | STORE BYTE WITHOUT ECC | | DF8 | RMVF | RESET MEMORY VOLTAGE FAILURE | # APPENDIX B INSTRUCTION SUMMARY - ALPHABETICAL BY MNEMONIC | A | MNEMCNIC | OF-CODE | INSTRUCTION | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|-----------------------------------------| | ABL 65 Add to Bottom of List AD 7A Add IFFP ADR 3A Add IFFP. Register AE 6A Add SPFP Register AE 2A Add SPFP Register AH 4A Add Halfword AHI CA Add Halfword Immediate AHM 61 Add Halfword to Memory AI FA Add Immediate AIS 26 Add Immediate Short AL D5 Autoload AM 51 Add to Memory AR 0A Add Register ATL 64 Add to Top of List B 430 Branch Unconditional BAL 41 Branch and Link Register BC 428 Branch on Carry Register BC 428 Branch on Carry Register BC 208 Branch on Carry Short (Backward) BCS 218 Branch on Carry Short (Forward) BE 433 Branch on Equal Short (Forward) BE 333 Branch on Equal Short (Backward) BES 223 Branch on Equal Short (Forward) BES 233 Branch on False Condition Backward Short BFFC 43 Branch on False Condition Register Forward Short BFFC 03 Branch on False Condition Forward Short BFFC 03 Branch on False Condition Forward Short BFFC 03 Branch on False Condition Forward Short BFFC 03 Branch on Low Register BFFC 23 Branch on Low Short (Backward) BLR 028 Branch on Low Short (Backward) BLR 028 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | 1 | 5 A | Add | | ADD 7A Add EFFP ADDR 3A Add IPFP Register AE 6A Add SPFP AER 2A Add SPFP Register AH 4A Add Halfword Immediate AHM 61 Add Halfword to Memory AI FA Add Immediate Short AI D5 Autoload AM 51 Add to Memory AR 0A Add to Memory AR 0A Add to Top of List B 430 Branch Unconditional BAL 41 Branch and Link BALR 01 Branch and Link BALR 01 Branch on Carry Register BC 428 Branch on Carry Short (Backward) BCS 208 Branch on Carry Short (Forward) BEF 433 Branch on Equal BER 033 Branch on Equal BER 033 Branch on Equal BES 223 Branch on Equal Short (Forward) BES 223 Branch on False Condition Backward Short BFFS 23 Branch on False Condition Register BFFC 43 Branch on False Condition Register BFFC 03 Branch on False Condition Register BFFC 03 Branch on False Condition Register BFFC 03 Branch on False Condition Forward Short BFFC 03 Branch on False Condition Forward Short BFFC 03 Branch on False Condition Forward Short BFFC 03 Branch on Low Register BFFS 23 Branch on Low Register BFFS 24 Branch on Low Register BFFS 25 Branch on Low Register BFFS 26 Branch on Low Register BFFS 27 Branch on Low Register BFFS 28 Branch on Low Register BLS 208 Branch on Low Short (Forward) BLS 218 Branch on Low Short (Forward) BMS 211 Branch on Minus Short (Forward) BMS 211 Branch on Minus Short (Forward) | | | | | ADR AE AE AE AE AE AA AC | | | | | AER 2A Add SPFP AER 2A Add SPFP Register AH 4A Add Halfword AHI CA Add Halfword Immediate AHM 61 Add Halfword to Memory AI FA Add Immediate AIS 26 Add Immediate Short AL D5 Autoload AM 51 Add to Memory AR 0A Add Register ATL 64 Add to Top of List B 430 Branch Unconditional BAL 41 Branch and Link BALR 01 Branch and Link BALR 01 Branch on Carry BCR 028 Branch on Carry Register BCS 208 Branch on Carry Short (Backward) BCS 218 Branch on Equal BER 033 Branch on Equal BER 033 Branch on Equal BER 033 Branch on Equal Short (Forward) BES 223 Branch on Equal Short (Forward) BES 233 Branch on Equal Short (Forward) BFFS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition Register BFFC 43 Branch on False Condition Register BFFC 43 Branch on False Condition Register BFFC 43 Branch on False Condition Register BFFC 43 Branch on False Condition Forward Short BFC 43 Branch on False Condition Forward Short BFF 23 Branch on Low Short (Backward) BFFS 23 Branch on False Condition Forward Short BFF 43 Branch on False Condition Forward Short BFF 23 Branch on Low Short (Forward) BFFS 23 Branch on Low Short (Forward) BFFS 24 Branch on Low Short (Forward) BFF 25 Branch on Low Short (Forward) BFF 26 Branch on Minus Short (Backward) BFF 27 Branch on Minus Short (Forward) BMS 201 Branch on Minus Short (Forward) | | | Add IPFP Register | | AER AH AH AA Add Halfword AHI CA Add Halfword Immediate AHM 61 Add Halfword to Memory AI FA Add Immediate AIS 26 Add Immediate AIS 26 Add Immediate Short AL D5 Autoload AM 51 Add to Memory AR AR OA ADD ADD ADD ADD ADD ADD ADD ADD ADD | | | | | AH AHI CA Add Halfword Immediate AHM 61 Add Halfword Immediate AIS 26 Add Immediate AIS 26 Add Immediate Short AL D5 Autoload AM 51 Add to Memory AR AR OA Add Register ATL 64 Add to Top of List B BAL BAL BAL O1 Branch and Link BALR O1 Branch and Link Register BC BC 428 Branch on Carry BCS 208 Branch on Carry Short (Backward) BCS 218 Branch on Equal BER O33 Branch on Equal BER O33 Branch on Equal Short (Forward) BES 223 Branch on False Condition BFBS 22 Branch on False Condition BFFC O3 BFAC O3 BFAC O3 BFAC O3 BFAC O3 BFAC O3 BFAC O4 BFAC O3 BFAC O4 BFAC O3 BFAC O5 O6 BFAC O7 BF | | • | Add SPFP Register | | AHI CA Add Halfword Immediate AHM 61 Add Halfword to Memory AI FA Add Immediate AIS 26 Add Immediate Short AL D5 Autoload AM 51 Add to Memory AR OA Add Register ATL 64 Add to Top of List B 430 Branch Unconditional BALR 01 Branch and Link BALR 01 Branch and Link Register BC 428 Branch on Carry BCR 028 Branch on Carry Short (Backward) BCS 208 Branch on Carry Short (Forward) BCS 218 Branch on Carry Short (Forward) BER 033 Branch on Equal BER 033 Branch on Equal BER 033 Branch on Equal Short (Backward) BES 223 Branch on Equal Short (Forward) BFBS 22 Branch on False Condition BFBS 22 Branch on False Condition Backward Short BFC 03 Branch on False Condition Forward Short BFC 03 Branch on False Condition Forward Short BFFS 23 Branch on False Condition Forward Short BFFS 23 Branch on False Condition Forward Short BFFS 23 Branch on Iow Register BFFS 24 Branch on Low BLR 028 Branch on Low BLR 028 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Backward) BM 421 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Add Halfword | | AHM 61 Add Halfword to Memory AI FA Add Immediate AIS 26 Add Immediate Short AL D5 Autoload AM 51 Add to Memory AR 0A Add Register ATL 64 Add to Top of List B 430 Branch Unconditional BAL 41 Branch and Link Register BC 428 Branch on Carry BCR 028 Branch on Carry Register BCS 208 Branch on Carry Short (Forward) BES 218 Branch on Equal BER 033 Branch on Equal BER 033 Branch on Equal Register BES 223 Branch on Equal Short (Forward) BES 233 Branch on Equal Short (Forward) BES 233 Branch on False Condition Backward Short BFC 43 Branch on False Condition Register BFC 03 Branch on False Condition Register BFFS 23 Branch on False Condition Register BFFS 23 Branch on False Condition Register BFFS 24 Branch on Low BLL 428 Branch on Low BLL 428 Branch on Low BLL 428 Branch on Low BFR 028 Branch on Low Register BFFS 23 Branch on Low Register BFFS 24 Branch on Low Short (Backward) BL 428 Branch on Low Short (Backward) BL 428 Branch on Low Short (Forward) BL 428 Branch on Low Short (Forward) BL 428 Branch on Low Short (Backward) BL 428 Branch on Low Short (Forward) BL 428 Branch on Minus Short (Backward) BL 428 Branch on Minus Short (Backward) BL 508 Branch on Minus Short (Forward) BL 508 Branch on Minus Short (Forward) BMM 421 Branch on Minus Short (Forward) | | CA | Add Halfword Immediate | | AI FA Add Immediate AIS 26 Add Immediate Short AL D5 Autoload AM 51 Add to Memory AR OA Add Register ATL 64 Add to Top of List B 430 Branch Unconditional BAL 41 Branch and Link BALR O1 Branch and Link Register BC 426 Branch on Carry BCR 028 Branch on Carry Register BCS 208 Branch on Carry Short (Backward) BCS 218 Branch on Equal BER 033 Branch on Equal BER 033 Branch on Equal BES 223 Branch on Equal Short (Forward) BES 223 Branch on Equal Short (Forward) BFES 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition Backward Short BFC 03 Branch on False Condition Register BFFS 23 Branch on False Condition Register BFFS 24 Branch on Low Register BFFS 25 Branch on Low Register BFFS 26 Branch on Low Register BFFS 27 Branch on Low Register BFFS 28 Branch on Low Short (Backward) BL 428 Branch on Low Register BFFS 29 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BLS 218 Branch on Low Short (Forward) BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Forward) BMS 201 Branch on Minus Short (Forward) | | 61 | | | AIS AL D5 Autoload AM 51 AM 51 Add to Memory AR OA AR OA Add Register ATL 64 Add to Top of List B BAL BAL BAL BAL BAL BC | | F A | | | AL D5 Add to Memory AR OA Add Register ATL 64 Add to Top of List B 430 Branch Unconditional BAL 41 Branch and Link BALR O1 Branch and Link Register BC 428 Branch on Carry BCR 028 Branch on Carry Short (Backward) BCS 208 Branch on Carry Short (Forward) BE 433 Branch on Equal BER 033 Branch on Equal BER 033 Branch on Equal Short (Backward) BES 223 Branch on Equal Short (Forward) BES 233 Branch on Equal Short (Forward) BFBS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition BFCR 03 Branch on False Condition Register BFFS 23 Branch on False Condition Register BFFS 24 Branch on Iow BFCR 03 Branch on Iow BFCR 04 Branch on Low BFCR 05 Branch on Low BFCR 06 Branch on Low BFCR 08 Branch on Low BFFS 29 Branch on Low BFFS 208 Branch on Low BFFS 208 Branch on Low Short (Backward) BBS 218 Branch on Low Short (Forward) BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Forward) BMS 201 Branch on Minus Short (Forward) | | 26 | | | AM 51 Add to Memory AR 0A Add Register ATL 64 Add to Top of List B 430 Branch Unconditional BAL 41 Branch and Link BALR 01 Branch and Link Register BC 428 Branch on Carry BCR 028 Branch on Carry Short (Backward) BCS 208 Branch on Carry Short (Forward) BE 433 Branch on Equal BER 033 Branch on Equal BER 033 Branch on Equal Short (Backward) BES 223 Branch on Equal Short (Forward) BES 223 Branch on Equal Short (Forward) BFS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition Register BFC 03 Branch on False Condition Register BFFS 23 Branch on False Condition Register BFFS 24 Branch on Low BLR 028 Branch on Low Register BLR 028 Branch on Low Short (Backward) BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Low Short (Forward) BM 421 Branch on Minus Register BMS 201 Branch on Minus Short (Forward) BMS 201 Branch on Minus Short (Forward) | | <b>D</b> 5 | | | B 430 Branch Unconditional BAL 41 Branch and Link BALR 01 Branch on Carry BCR 028 Branch on Carry Register BCS 208 Branch on Carry Short (Backward) BCS 218 Branch on Carry Short (Forward) BEF 433 Branch on Equal BER 033 Branch on Equal BER 033 Branch on Equal Register BES 223 Branch on Equal Short (Forward) BES 223 Branch on Equal Short (Forward) BES 233 Branch on Equal Short (Forward) BFBS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition Register BFC 03 Branch on False Condition Register BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low BLR 028 Branch on Low Short (Backward) BLS 208 Branch on Low Short (Forward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus Register BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | A M | 51 | | | B 430 Branch Unconditional BAL 41 Branch and Link BALR 01 Branch and Link Register BC 428 Branch on Carry BCR 028 Branch on Carry Register BCS 208 Branch on Carry Short (Backward) BCS 218 Branch on Carry Short (Forward) BE 433 Branch on Equal BER 033 Branch on Equal Register BES 223 Branch on Equal Short (Backward) BES 223 Branch on Equal Short (Forward) BES 233 Branch on Equal Short (Forward) BFBS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition Register BFC 03 Branch on False Condition Register BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low BLR 028 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus Register BMS 201 Branch on Minus Register BMS 201 Branch on Minus Short (Forward) BMS 211 Branch on Minus Short (Forward) | AR | | | | BAL 41 Branch and Link BALR 01 Branch and Link Register BC 428 Branch on Carry BCR 028 Branch on Carry Register BCS 208 Branch on Carry Short (Backward) BCS 218 Branch on Carry Short (Forward) BE 433 Branch on Equal BER 033 Branch on Equal Register BES 223 Branch on Equal Short (Backward) BES 233 Branch on Equal Short (Forward) BES 233 Branch on Equal Short (Forward) BFBS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition Backward Short BFC 03 Branch on False Condition Register BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low BLR 028 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BLS 218 Branch on Minus Register BMS 021 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | ATL | 64 | Add to Top of List | | BALR 01 Branch and Link Register BC 428 Branch on Carry BCR 028 Branch on Carry Register BCS 208 Branch on Carry Short (Backward) BCS 218 Branch on Carry Short (Forward) BE 433 Branch on Equal BER 033 Branch on Equal Register BES 223 Branch on Equal Short (Backward) BES 233 Branch on Equal Short (Forward) BFBS 22 Branch on Equal Short (Forward) BFBS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition Register BFC 03 Branch on False Condition Register BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low Register BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Short (Backward) BMS 201 Branch on Minus Short (Forward) BMS 201 Branch on Minus Short (Forward) | В | | | | BC 428 Branch on Carry BCR 028 Branch on Carry Register BCS 208 Branch on Carry Short (Backward) BCS 218 Branch on Carry Short (Forward) BE 433 Branch on Equal BER 033 Branch on Equal BES 223 Branch on Equal Short (Backward) BES 233 Branch on Equal Short (Forward) BFBS 22 Branch on Equal Short (Forward) BFBS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition BFCR 03 Branch on False Condition Register BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low BLR 028 Branch on Low Short (Backward) BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | BAL | | Branch and Link | | BCR 028 Branch on Carry Register BCS 208 Branch on Carry Short (Backward) BCS 218 Branch on Carry Short (Forward) BE 433 Branch on Equal BER 033 Branch on Equal BES 223 Branch on Equal Short (Backward) BES 233 Branch on Equal Short (Forward) BFBS 22 Branch on Equal Short (Forward) BFBS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition BFCR 03 Branch on False Condition Register BFFS 23 Branch on Equal Short BFFS 24 Branch on False Condition BFCR 05 Branch on False Condition BFFS 26 Branch on Low BFFS 27 Branch on Low BFFS 28 Branch on Low BFFS 29 Branch on Low Register BFFS 208 Branch on Low Short (Backward) BFFS 218 Branch on Minus BFFS 218 Branch on Minus BFFS 218 Branch on Minus BFFS 218 Branch on Minus BFFS 218 Branch on Minus BFFS 218 Branch on Minus Short (Backward) BFFS 219 BFFS BFFS CONSTRUCTOR BFFS BFFS BFFS BFFS BFFS BFFS BFFS BFF | | | | | BCS 218 Branch on Carry Short (Backward) BCS 218 Branch on Carry Short (Forward) BE 433 Branch on Equal BER 033 Branch on Equal Register BES 223 Branch on Equal Short (Backward) BES 233 Branch on Equal Short (Forward) BES 234 Branch on Equal Short (Forward) BES 255 Branch on Equal Short (Forward) BES 266 Branch on False Condition Backward Short BEC 478 Branch on False Condition Register BEC 479 Branch on False Condition Register BEC 479 Branch on Equal Short (Forward Short BEC 479 Branch on False Condition Forward Short BEC 479 Branch on Low Branch on Low Branch on Low Short (Backward) BEC 479 Branch on Minus BEC 479 Branch on Minus Register BEC 479 Branch on Minus Register BEC 479 Branch on Minus Register BEC 479 Branch on Minus Short (Backward) BEC 479 Branch on Minus Short (Backward) BEC 479 Branch on Minus Short (Forward) | BC | | Branch on Carry | | BCS 218 Branch on Carry Short (Forward) BE 433 Branch on Equal BER 033 Branch on Equal Register BES 223 Branch on Equal Short (Backward) BES 233 Branch on Equal Short (Forward) BES 22 Branch on Equal Short (Forward) BFBS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition Register BFC 03 Branch on False Condition Register BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low Register BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on Carry Register | | BE 433 Branch on Equal BER 033 Branch on Equal Register BES 223 Branch on Equal Short (Backward) BES 233 Branch on Equal Short (Forward) BES 233 Branch on Equal Short (Forward) BFBS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition BFCR 03 Branch on False Condition Register BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low Register BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on Carry Short (Backwald) | | BER 033 Branch on Equal Register BES 223 Branch on Equal Short (Backward) BES 233 Branch on Equal Short (Forward) BES 233 Branch on Equal Short (Forward) BEBS 22 Branch on False Condition Backward Short BEC 43 Branch on False Condition Register BECR 03 Branch on False Condition Register BEFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low Register BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | | | BES 233 Branch on Equal Short (Backward) BES 233 Branch on Equal Short (Forward) BFBS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition BFCR 03 Branch on False Condition Register BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low Register BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on Equal Posistor | | BES BFBS 22 Branch on Equal Short (Forward) BFBS BFC 43 Branch on False Condition BFCR BFCR BFFS 23 Branch on False Condition Register BFFS BL 428 Branch on False Condition Forward Short BL BL BL BL BR 028 Branch on Low BLR BLS BR 1028 Branch on Low Short (Backward) BLS BR BR 1218 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BRS 211 Branch on Minus Short (Backward) Branch on Minus Short (Forward) BRS CONTROL BRANCH | | | Branch on Equal Register (Backward) | | BFBS 22 Branch on False Condition Backward Short BFC 43 Branch on False Condition BFCR 03 Branch on False Condition Register BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low Register BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on Equal Short (Forward) | | BFC 43 Branch on False Condition BFCR 03 Branch on False Condition Register BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low Register BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on Equal Short (Forward) | | BFCR 03 Branch on False Condition Register BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low Register BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on False Condition | | BFFS 23 Branch on False Condition Forward Short BL 428 Branch on Low BLR 028 Branch on Low Register BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on False Condition Register | | BL 428 Branch on Low BLR 028 Branch on Low Register BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on False Condition Forward Short | | BLR 028 Branch on Low Register BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | | | BLS 208 Branch on Low Short (Backward) BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | | | BLS 218 Branch on Low Short (Forward) BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on Low Short (Backward) | | BM 421 Branch on Minus BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on Low Short (Forward) | | BMR 021 Branch on Minus Register BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on Minus | | BMS 201 Branch on Minus Short (Backward) BMS 211 Branch on Minus Short (Forward) | | | Branch on Minus Register | | BMS 211 Branch on Minus Short (Forward) | | | Branch on Minus Short (Backward) | | m I - C-mm | | | Branch on Minus Short (Forward) | | | | | Branch on No Carry | # APPENDIX B (Continued) | MNEMONIC | OF-CODE | INSTRUCTION | |-----------|------------|------------------------------------------------------------------------| | BNCR | 038 | Branch on No Carry Register | | BNCS | 228 | Branch on No Carry Short (Backward) | | BNCS | 238 | Branch on No Carry Short (Forward) | | BNE | 423 | Branch on Not Equal | | BNER | 023 | Branch on Not Equal Register | | BNES | 203 | Branch on Not Equal Short (Backward) | | BNES | 213 | Branch on Not Equal Short (Forward) | | BNL | 438 | Branch on Not Low | | BNLR | 038 | Branch on Not Low Register | | BNLS | 228 | Branch on Not Low Short (Backward) | | BNLS | 238 | Branch on Not Low Short (Forward) | | BNM | 431 | Branch on Not Minus | | BNMR | 031 | Branch on Not Minus Register | | BNMS | 221 | Branch on Not Minus Short (Backward) | | BNMS | 231 | Branch on Nct Minus Short (Forward) | | BNO | 434 | Branch on No Overflow | | BNOR | 034 | Branch on No Overflow Register | | BNOS | 224 | Branch on No Overflow Short (Backward) | | BNOS | 234 | Branch on No Overflow Short (Forward) | | BNP | 432 | Branch on Not Plus | | BNPR | 032 | Branch on Nct Plus Register | | BNPS | 222 | Branch on Nct Plus Short (Backward) | | BNPS | 232 | Branch on Not Plus Short (Forward) | | BNZ | 423 | Branch on Not Zero | | BNZR | 023 | Branch on Not Zero Register | | BNZS | 203 | Branch on Not Zero Short (Backward) | | BNZS | 213 | Branch on Not Zero Short (Forward) | | BO | 424 | Branch on Overflow | | BOR | 024 | Branch on Overflow Register Branch on Overflow Short (Backward) | | BOS | 204 | Branch on Overflow Short (Backward) Branch on Overflow Short (Forward) | | BOS | 214 | Branch on Plus | | BP | 422 | Branch on Plus Register | | BPR | 022 | Branch on Plus Short (Backward) | | BPS | 202<br>212 | Branch on Plus Short (Forward) | | BPS | 030 | Branch Unconditional Register | | BR<br>BRK | 88 | Breakpoint | | BS | 220 | Branch Unconditional Short (Backward) | | BS | 230 | Branch Unconditional Short (Forward) | | BTBS | 20 | Branch on True Condition Backward Short | | BTC | 42 | Branch on True Condition | | BTCR | 02 | Branch on True Condition Register | | BTFS | 21 | Branch on True Condition Forward Short | | BXH | Č O | Branch on Index High | | BXLE | C1 | Branch on Index Low or Equal | | BZ | 433 | Branch on Zero | | BZR | 033 | Branch on Zero Register | | BZS | 223 | Branch on Zero Short (Backward) | | BZS | 233 | Branch on Zero Short (Forward) | | | | | # APPENDIX B (Continued) | MNEMONIC | OP-CODE | INSTRUCTION | |----------|------------|------------------------------------------| | С | 59 | Compare | | CBT | 77 | Complement Bit | | | 7 <i>7</i> | Compare Double Floating-Point | | CD | | Compare Double Floating Foint Register | | CDR | 39 | | | CE | 69 | Compare Floating-Point | | CER | 29 | Compare Floating-Point Register | | CH | 49 | Compare Halfword | | CHI | C 9 | Compare Halfword Immediate | | CHVR | 12 | Convert Halfword Value Register | | CI | F 9 | Compare Immediate | | CL | 55 | Compare Lcgical | | CLB | D 4 | Compare Logical Byte | | CLH | 45 | Compare Logical Halfword | | CLHI | <b>C</b> 5 | Compare Logical Halfword Immediate | | | F 5 | Compare Logical Immediate | | CLI | | | | CLR | 05 | Compare Logical Register | | CPAN | 8C/02 | Compare Alphanumeric | | CPANP | 8C/22 | Compare Alphanumeric and Pad | | CR | 09 | Compare Register | | CRC12 | 5 E | Cyclic Redundancy Check Modulo 12 | | CRC16 | 5 F | Cyclic Redundancy Check Modulo 16 | | D | 5 D | Divide - | | DD | <b>7</b> D | Divide Double-Precision Floating-Point | | DDR | 3 D | Divide Double Floating-Point Register | | DE | 6 D | Divide Floating-Point | | DER | 2 D | Divide Floating-Point Register | | DH | 4 D | Divide Halfword | | | 0 D | Divide Halfword Register | | DHR | | <del>-</del> | | DR | <b>1</b> D | Divide Register | | EPSR | 95 | Exchange Program Status Register | | EXBR | 94 | Exchange Byte Register | | EXHR | 34 | Exchange Halfword Register | | 2211111 | • | <b></b> | | FLR | 2 F | Float Register | | FLDR | 3F | Float Register Double Precision | | FXDR | 3 E | Fix Register Double-Precision Floating | | FADE | J.E. | Point | | EVD | O.F. | | | FXR | 2 E | Fix Register | | ISRST | DF6 | Interruptible State Restore | | ISSV | DF5 | Interruptible State Save | | 2201 | | | | L | 58 | Load | | LA | E 6 | Lcad Address | | LB | D3 | Load Byte | | | | Load Byte Register | | LBR | 93 | Load Complement Double Floating Register | | LCDR | 37 | road combiement nogpie troating rediscer | # APPENDIX E (Continued) | MNEMONIC | OP-CODE | INSTRUCTION | |----------|------------|-----------------------------------------------| | LCER | 17 | Load Complement Floating-Point Register | | LCS | 25 | Load Complement Short | | LD | 78 | Load Couble-Precision Floating-Point | | LDE | 87 | Load Double Floating-Point From Single | | LDER | λ7 | Load Couble From Single Register | | LDGR | <b>A</b> 6 | Load Double From General Register | | LDPS | DF4 | Load Frocess State | | LDR | 38 | Load Couble-Precision Register | | LE | 68 | Load Floating-Point | | LED | 8 4 | Load Floating From Double Precision | | LEDR | <b>A</b> 4 | Load Floating From Double Register | | LEGR | <b>A</b> 5 | Load Floating From General Register | | LER | 28 | Load Floating-Point Register | | LH | 48 | Load Halfword | | LHI | C 8 | Load Halfword Immediate | | LHL | 73 | Load Halfword Logical | | LI | F 8 | Load Immediate | | LIS | 24 | Load Immediate Short | | LM | D 1 | Load Multiple | | LMD | <b>7</b> F | Load Multiple Double-Precision Floating Point | | LME | 72 | Load Multiple Floating-Point | | LPB | 6 F | Load Facked Binary | | LPDR | 33 | Load Positive Double Floating Register | | LPER | 13 | Load Positive Floating Register | | LPSTD | DF1 | Load Frocess Segment Table Description | | LPSW | C2 | Load Frogram Status Word | | LPSWR | 18 | Load Program Status Word Register | | LR | 0.8 | Load Register | | LRA | 63 | Load Real Address | | LSSTD | DF2 | Load Shared Segment Table Descriptor | | M | 5 C | Multiply | | MD | 7 C | Multiply Double Floating-Point | | MDR | 3C | Multiply Double Floating Register | | ME | 6 C | Multiply Floating-Point | | MER | 2 C | Multiply Floating-Point Register | | MR | 4 C | Multiply Halfword | | MHR | 0 C | Multiply Halfword Register | | MOVE | 8C/01 | Move | | MOVEP | 8C/21 | Move and Pad | | MR | <b>1</b> C | Multiply Register | | N | 54 | AND | | NH | 44 | AND Halfword | | NHI | Сu | AND Halfword Immediate | | NI | F 4 | AND Immediate | | NOP | 420 | No Operation | | NCPR | 020 | No Operation Register | | NR | 04 | AND Register | # APPENDIX B (Continued) | W N TWO N T C | OP-CODE | INSTRUCTION | |---------------|------------|---------------------------------------------| | MNEMONIC | OF CODE | | | 0 | 56 | CR | | oc | DE | Output Command | | OCR | 9 E | Cutrut Command Register | | OH | 46 | CR Halfword | | OHI | C6 | OR Halfword Immediate | | OI | F 6 | OR Immediate | | OR | 06 | CR Register | | . 010 | • | | | PВ | 62 | Process Byte | | PBR | 32 | Frccess Byte Register | | PMV | 8C/03 | Fack and Move | | PMVA | 8C/23 | Pack and Move Absolute | | 2 | | a matter of list | | RBL | 67 | Remove from Bottom of List | | RET | 76 | Reset_Bit | | RD | DВ | Read Data | | RDR | <b>9</b> B | Read Data Register | | REL | DFO | Read Error Logger | | RH | D 9 | Read Halfword<br>Read Halfword Register | | RHR | 99 | | | RLL | EB | Rotate Left Logical | | RMVF | DF8 | Reset Memory Voltage Fault | | RRL | EA | Rotate Right Logical | | RTL | 66 | Remove from Top of List | | | | a a kina ak | | S | 5 B | Subtract | | SBT | 75 | Set Bit<br>Simulate Channel Program | | SCP | E 3 | Subtract Double-Precision Floating | | SD | <b>7</b> B | | | | _ | Pcint<br>Subtract Register Double-Precision | | SDR | <b>3</b> B | Floating-Point | | | | Subtract Floating-Point | | SE | 6 B | Subtract Floating-Point Register | | SER | 2B | Subtract Halfword | | SH | 4 B | Subtract Halfword Immediate | | SHI | CB | Subtract Immediate | | SI | FB | Simulate Interrupt | | SINT | E2 | Subtract Immediate Short | | SIS | 27 | shift Left Arithmetic | | SLA | EF | Shift Left Halfword Arithmetic | | SLHA | C F<br>C D | chiff Taff Halfword Logical | | SLHL | | Shift Left Halfword Logical Short | | SLHLS | 91 | | | | ΕD | Shift Left Logical | | SIL | 11 | Shift Left Logical Short | | SLLS | 1 1 | <del></del> | # APPENDIX B (Continued) | MNEMONIC | OP-CODE | INSTRUCTION | |----------|------------|------------------------------------------------| | SR | OB | Subtract Register | | SRA | EE | Shift Right Arithmetic | | SRHA | CE | Shift Right Halfword Arithmetic | | SRHL | CC | Shift Right Halfword Logical | | SRHLS | 90 | Shift Right Halfword Logical Short | | SRL | EC | Shift Right Logical | | SRLS | 10 | Shift Right Logical Short | | SS | DD | Sense Status | | SSR | 9 D | Sense Status Register | | ST | 50 | Store | | STB | D 2 | Store Byte | | STBP | 6 E | Store Binary as Packed | | STBR | 92 | Store Byte Register | | STD | 70 | Store Double-Precision Floating-Point | | STDE | 82 | Store Double-Precision in Single-Precision | | STE | 60 | Store Floating-Point | | STH | 40 | Store Halfword | | STM | DO | Store Multiple | | STMC | <b>7</b> E | Store Multiple Double-Precision Floating-Point | | STME | 71 | Store Multiple Floating-Point | | STPS | DF3 | Save Frocess State | | SVC | E 1 | Supervisor Call | | TBT | 74 | Test Bit | | THI | C3 | Test Halfword Immediate | | TI | F 3 | Test Immediate | | TLATE | E 7 | Translate | | TS | ΕO | Test and Set | | UMV | 8C/04 | Unpack and Move | | AVMU | 8C/24 | Unpack and Move Absolute | | WD | D A | Write Data | | WDR | 9 A | Write Data Register | | WH | B <b>T</b> | Write Halfword | | WHR | 98 | Write Halfword Register | | X | 57 | Exclusive OR | | ХH | 47 | Exclusive OR Halfword | | XHI | C7 | Exclusive OR Halfword Immediate | | ХI | F7 | Exclusive OR Immediate | | XR | 07 | Exclusive OR Register | | XSTE | DF7 | Store Byte, No ECC | ### APPENDIX C INSTRUCTION SUMMARY - NUMERICAL | OP-CODE | MNEMONIC | INSTRUCTION | |----------------|----------|------------------------------------------| | 01* | BALR | Branch and Link Register | | 02* | BTCR | Branch on True Condition Register | | 03* | BFCR | Branch on False Condition Register | | 04 | NR | AND Register | | 05 | CLR | Compare Logical Register | | 06 | OR | OR Register | | 07 | XR | Exclusive OR Register | | 0.8 | LR | Load Register | | 09 | CR | Compare Register | | OA | AR | Add Register | | CB | SR | Subtract Register | | OC* | MHR | Multiply Halfword Register | | OD* | DH R | Divide Halfword Register | | 10 | SRLS | Shift Right Logical Short | | 11 | SLLS | Shift Left Logical Short | | 12 | CHVR | Convert to Halfword Value Register | | 13+ | LPER | Load Positive Floating-Point | | 15+ | LGER | Load General Register from Floating | | 16+ | LGDR | Load General from Double Floating | | 17+ | LCER | Load Complement Floating Register | | 18 | LPSWR | Load Program Status Word Register | | 1C* | MR | Multiply Register | | 1D* | DR | Divide Register | | 20* | BTBS | Branch on True Condition Backward Short | | 21* | BTFS | Branch on True Condition Forward Short | | 22* | BF BS | Branch on False Condition Backward Short | | 23* | BFFS | Branch on False Condition Forward Short | | - <del>-</del> | | | <sup>\*</sup>Condition code not changed +Optional instruction # APPENDIX C (Continued) | OP-CODE | MNEMONIC | INSTRUCTION | |-------------------|----------|---------------------------------------------------| | 24 | LIS | Load Immediate Short | | 25 | LCS | Lcad Complement Short | | 26 | AIS | Add Immediate Short | | 27 | SIS | Subtract Immediate Short | | 28+ | LER | Lcad | | 29+ | CER | Compare Floating-Point | | 21+ | AER | Add Floating-Point Register | | 2B+ | SER | Subtract Floating-Point Register | | 2C+ | MER | Multiply Floating-Point Register | | 2D+ | DER | Divide Floating-Point Register | | 2 E+ | FXR | Fix Register | | 2F+ | FLR | Float Register | | 32*+ | PBR | Process Byte Register | | 33+ | LPDR | Lcad Positive Double Register | | 34* | EXHR | Exchange Halfword Register | | 37+ | LCDR | Lcad Complement Double Register | | 38+ | LDR | Lcad Register Double-Precision | | | | Floating-Point | | 39+ | CDR | Compare Register Double-Precision Floating-Point | | 3 <b>A</b> + | ADR | Add Register Double-Precision | | _ | | Floating-Point | | 3B+ | SDR | Subtract Register Double-Precision Floating-Point | | 3C+ | MDR | Multiply Register Double-Precision | | 3 <sup>'</sup> D+ | 222 | Floating-Point | | 304 | DDR | Divide Register Double-Precision Floating-Point | | 3 E+ | FXDR | Fix Register Double-Precision Floating-Point | | 3F+ | FLDR | Float Register Double-Precision<br>Floating-Point | | 40* | STH | Store Halfword | <sup>\*</sup>Condition code not changed <sup>+</sup>Optional instruction # APPENDIX C (Continued) | OP-CODE | MNEMONIC | INSTRUCTION | |---------|----------|-----------------------------------| | 41* | BAL | Branch and Link | | 42* | BTC | Branch on True Condition | | 43* | BFC | Branch on False Condition | | 44 | NH | AND Halfword | | 45 | CLH | Compare Logical Halfword | | 46 | ОН | OR Halfword | | 47 | ХH | Exclusive OR Halfword | | 48 | LH | Load Halfword | | 49 | СН | Compare Halfword | | 4 A | AH | Add Halfword | | 4B | SH | Subtract Halfword | | 4C* | MH | Multiply Halfword | | 4 D* | DH | Divide Halfword | | 50* | ST | Store | | 51 | AM | Add to Memory | | 54 | N | AND | | 55 | CL | Compare Logical | | 56 | О | CR | | 57 | X | Exclusive OR | | 58 | L | Load | | 59 | С | Compare | | 5 A | A | Add | | 5 B | S | Subtract | | 5C* | M | Multiply | | 5D* | D | Divide | | 5E* | CRC12 | Cyclic Redundancy Check Modulo 12 | | 5F* | CRC16 | Cyclic Redundancy Check Modulo 16 | | 60*+ | STE | Store Floating-Point | | 61 | AHM | Add Halfword to Memory | | 62*+ | PB | Frocess Byte | | 63 | LRA | Load Read Address | | 64 | ATL | Add to Top of List | | 65 | ABL | Add to Bottom of List | | | | | <sup>\*</sup>Condition code not changed <sup>+</sup>Optional instruction | CP-CCDE | MNEMONIC | INSTRUCTION | |--------------|----------|------------------------------------------------| | 66 | RTL | Remove from Top of List | | 67 | RBL | Remove from Bottom of List | | 68+ | LE | Lcad Floating-Point | | 69+ | CE | Compare Floating-Point | | 6 <b>X</b> + | AE | Add Floating-Point | | 6B+ | SE | Subtract Floating-Point | | 6C+ | ME | Multiply Floating-Point | | 6 D+ | DE | Divide Floating-Point | | 6 E | STBP | Store Binary as Packed | | 6 F | LPB | Lcad Packed Binary | | 70*+ | STD | Store Double-Precision Floating-Point | | 71*+ | STME | Store Floating-Point Multiple | | 72*+ | LME | Load Floating-Point Multiple | | 73 | LHL | Load Halfword Logical | | 74 | TBT | Test Bit | | 75 | SBT | Set Bit | | 76 | RBT | Reset Bit | | 77 | CBT | Complement Bit | | 78+ | LD | Load Double-Precision Floating-Point | | 79+ | CD | Compare Double-Precision Floating-Point | | 7 A+ | A D | Add Double-Precision Floating-Point | | 7B+ | SD | Subtract Double-Precision Floating-Point | | 7C+ | MD | Multiply Double-Precision Floating-Point | | 7D+ | DD | Divide Double-Precision Floating-Point | | 7E*+ | STMD | Store Multiple Double-Precision Floating-Foint | | 7 F* + | LMD | Load Multiple Double-Precision Floating Pcint | | 82*+ | STDE | Store Double Precision in Single | | 84+ | LED | Load Floating from Double Precision | | 87+ | LDE | Load Double from Floating-Point | | 88* | BRK | Breakpoint | <sup>\*</sup>Condition code not changed <sup>+</sup>Optional instruction | OP-CODE | MNEMONIC | INSTRUCTION | |------------|----------|-------------------------------------| | 0.0 | (RXRX) | RXRX Class designator | | 8 C | MVTU | Move Translated Until | | 8C/00 | MOVE | Mcve | | 8C/01 | CPAN | Compare Alphanumeric | | 8C/02 | PMV | Pack and Move | | 8C/03 | | Unpack and Move | | 8C/04 | UMV | Move and Pad | | 8C/21 | MOVEP | Compare Alphanumeric and Pad | | 8C/22 | CPANP | Pack and Move Absolute | | 8C/23 | PMVA | Unpack and Move Absolute | | 8C/24 | U M V Å | Unpack and hove absolute | | | an 117 C | Shift Right Halfword Logical Short | | 90 | SRHLS | Shift Left Halfword Logical Short | | 91 | SLHLS | Store Byte Register | | 92* | STBR | Lcad Byte Register | | 93* | LBR | TCSG Bice Wedtroot | | | ממעה | Exchange Byte Register | | 94* | EXBR | Exchange Program Status Word | | 95 | EPSR | EXCHANGE 22090 | | | WHR | Write Halfword Register | | 98 | RHR | Read Halfword Register | | 99 | ипи | | | 9 <b>λ</b> | WDR | Write Data Register | | 9B | RDR | Read Data Register | | 90 | 2.2 4. | | | 9 D | SSR | Sense Status Register | | 9 E | OCR | Output Command Register | | 72 | | s - Double Pegister | | A 4+ | LEDR | Load Floating from Double Register | | A 5+ | LEGR | Load Floating from General Register | | A6+ | LDGR | Load Double from General Register | | A7+ | LDER | Load Double from Floating Register | | | | | | C0* | BXH | Branch on Index High | | C1* | BXLE | Branch on Index Low or Equal | | <b>V</b> 1 | | at the Hand | | C2 | LPSW | Load Program Status Word | | | | | | C3 | THI | Test Halfword Immediate | | | | AND Halfword Immediate | | C4 | NHI | Compare Logical Halfword Immediate | | C5 | CLHI | Compare noarcar management | | | | | <sup>\*</sup>Condition code not changed +Optional instruction | OP-CODE | MNEMONIC | INSTRUCTION | |--------------------------------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | C6<br>C7 | OHI<br>XHI | OR Halfword Immediate Exclusive OR Halfword Immediate | | C8 | LHI | Lcad Halfword Immediate | | C9 | CHI | Compare Halfword Immediate | | C A<br>C B | AHI<br>SHI | Add Halfword Immediate<br>Subtract Halfword Immediate | | CC<br>CD<br>CE<br>CF | SRHL<br>SLHL<br>SRHA<br>SLHA | Shift Right Halfword Logical<br>Shift Left Halfword Logical<br>Shift Right Halfword Arithmetic<br>Shift Left Halfword Arithmetic | | DO*<br>D1*<br>D2*<br>D3*<br>D4 | STM<br>LM<br>STB<br>LB<br>CLB | Store Multiple Load Multiple Store Byte Load Byte Compare Logical Byte | | D5 | AL | Autoload | | D8<br>D9 | WH<br>RH | Write Halfword<br>Read Halfword | | DA<br>DB | WD<br>RD | Write Data<br>Read Data | | DD<br>DE<br>DF | SS<br>OC<br>(PSF) | Sense Status<br>Output Command<br>PSF Class Designator | | DF0 DF1* DF2* DF3* DF4 DF5* DF6* DF7* DF8* | PEL LPSTD LSSTD STPS LDPS ISSV ISRST XSTB RMVF | Read Error Logger Load Process Segment Table Descriptor Load Shared Segment Table Descriptor Save Process State Load Process State Interruptible State Save Interruptible State Restore Store Byte, No ECC Reset Memory Voltage Fault | <sup>\*</sup>Condition code not changed <sup>+</sup>Optional instruction | OP-CODE | MNEMONIC | INSTRUCTION | |----------|-------------|-------------------------------------------------| | EO | TS | Test and Set | | E 1 | SVC | Supervisor Call | | E2<br>E3 | SINT<br>SCP | Simulate Interrupt<br>Simulate Channel Program | | E6* | LA | Load Address | | E7* | TLATE | Translate | | EA<br>EB | RRL<br>RLL | Rotate Right Logical<br>Rotate Left Logical | | EC<br>ED | SRL<br>SLL | Shift Right Logical Shift Left Logical | | EE<br>EF | SRA<br>Sla | Shift Right Arithmetic<br>Shift Left Arithmetic | | F3 | TI | Test Immediate | | F4<br>F5 | NI | AND Immediate<br>Compare Logical Immediate | | F6<br>F7 | XI | CR Immediate<br>Exclusive OR Immediate | | F8<br>F9 | LI | load Immediate<br>Compare Immediate | | FA<br>FB | AI<br>SI | Add Immediate<br>Subtract Immediate | <sup>\*</sup>Condition code not changed <sup>+</sup>Optional instruction ### APFENDIX D ARITHMETIC REFERENCES 637-1 ### TABLE OF POWERS OF TWO ``` 2<sup>-n</sup> 2<sup>n</sup> n 0 1.0 2 0.5 0.25 2 8 3 0.125 0.062 16 4 0.031 25 32 5 64 6 0.015 625 812 5 128 7 0.007 8 0.003 906 25 256 953 125 9 0.001 512 024 10 0.000 976 562 5 048 11 0.000 488 281 25 140 625 12 0.000 244 096 0.000 122 070 312 5 192 13 8 25 061 035 156 16 384 14 0.000 32 768 15 0.000 030 517 578 125 015 258 789 062 5 536 16 0.000 65 25 007 629 394 531 131 072 17 0.000 265 625 262 144 18 0.000 003 814 697 812 5 524 288 19 0.000 001 907 348 632 316 406 25 0.000 000 953 674 048 576 20 2 097 152 21 0.000 000 476 837 158 203 125 0.000 000 238 418 579 101 562 5 304 22 194 289 550 781 25 608 23 0.000 000 119 209 8 388 775 390 625 000 059 604 644 16 777 216 24 0.000 432 25 0.000 000 029 802 322 387 695 312 5 554 33 901 000 014 161 193 847 656 25 26 0.000 67 108 864 580 596 923 828 125 0.000 000 007 450 134 217 728 27 0.000 000 003 725 290 298 461 914 062 5 268 435 456 28 230 957 031 25 862 645 149 000 001 536 870 912 29 0.000 478 625 30 0.000 000 000 931 322 574 615 515 073 741 824 257 812 5 000 465 661 287 307 739 147 483 648 31 0.000 000 628 906 25 000 000 232 830 643 653 869 967 296 32 0.000 4 294 592 0.000 000 000 116 415 321 826 934 814 453 125 589 934 33 8 5 207 660 913 467 407 226 562 000 058 17 179 869 184 34 0.000 000 25 733 703 613 281 368 35 0.000 000 000 029 103 830 456 359 738 34 000 000 014 551 915 228 366 851 806 640 625 68 719 476 736 36 0.000 312 5 275 183 425 903 320 137 438 953 472 37 0.000 000 000 007 957 614 807 091 712 951 660 156 25 0.000 000 000 003 637 978 944 38 274 877 906 856 475 830 078 989 403 545 888 0.000 000 000 001 818 549 755 813 39 000 000 000 909 494 701 772 928 237 915 039 062 5 1 099 511 627 776 40 0.000 ``` 638 TABLE OF POWERS OF SIXTEEN | | | | | | 16 <sup>n</sup> | | | | |---|---|-----|-----|-----|-----------------|-----|-----|-----| | | | | | | | | 1 | 0 | | | | | | | | | 16 | ] 1 | | | | | | | | | 256 | 2 | | | | | | | | 4 | 096 | 3. | | | | | | | | 65 | 536 | 4 | | | | | | | 1 | 048 | 576 | 5 | | | | | | | 16 | 777 | 216 | 6 | | | | | | | 268 | 435 | 456 | 7 | | | | | | 4 | 294 | 967 | 296 | 8 | | | | | | 68 | 719 | 476 | 736 | 9 | | | | | 1 | 099 | 511 | 627 | 776 | 10 | | | | | 17 | 592 | 186 | 044 | 416 | 11 | | | | | 281 | 474 | 976 | 710 | 656 | 12 | | | | 4 | 503 | 599 | 627 | 370 | 496 | 13 | | | | 72 | 057 | 594 | 037 | 927 | 936 | 14 | | ı | 1 | 152 | 921 | 504 | 606 | 846 | 976 | 15 | DECIMAL VALUES 639 # HEXADECIMAL ADDITION AND SUBTRACTION TABLE EXAMPLES: 5 + A = F; 18 - D = B; A + B = 15 | 1 | | | | | | | | | | | | | | | | | |---|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---| | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Ε | F | | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | ·A | В | С | D | Е | F | 10 | 1 | | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | U | D | E | F | 10 | 11 | 2 | | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Ε | F | 10 | 11 | 12 | 3 | | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | 10 | 11 | 12 | 13 | 4 | | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | 10 | 11 | 12 | 13 | 14 | 5 | | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 6 | | 7 | 8 | 9 | Α | В | С | D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 7 | | 8 | 9 | Α | В | С | D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 8 | | 9 | Α | В | С | D | Ε | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 9 | | Α | В | С | D | E | ·F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | Α | | В | С | D | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1A | В | | С | D | Е | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1A | 1B | С | | D | Е | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1A | 1B | 1C | D | | E | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1A | 1B | 1C | 1D | E | | F | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 1A | 1B | 1C | 1D | 1E | F | | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | | 640 # HEXADECIMAL MULTIPLICATION AND DIVISION TABLE EXAMPLES: $5 \times 6 = 1E$ ; $75 \div D = 9$ ; $58 \div 8 = B$ ; $9 \times C = 6C$ | | | | | | | | | | | | | — т | —т | —т | | | |---|---|-----|----|----|----|----|----|----|----|----|----|-----|----|----|----|---| | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | | | 1 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | 1 | | 2 | 2 | 4 | 6 | 8 | Α | С | E | 10 | 12 | 14 | 16 | 18 | 1A | 1C | 1E | 2 | | 3 | 3 | 6 | 9 | С | F | 12 | 15 | 18 | 1B | 1E | 21 | 24 | 27 | 2A | 2D | 3 | | 4 | 4 | 8 | С | 10 | 14 | 18 | 1C | 20 | 24 | 28 | 2C | 30 | 34 | 38 | зс | 4 | | 5 | 5 | Α | F | 14 | 19 | 1E | 23 | 28 | 2D | 32 | 37 | 3C | 41 | 46 | 4B | 5 | | 6 | 6 | С | 12 | 18 | 1E | 24 | 2A | 30 | 36 | 3C | 42 | 48 | 4E | 54 | 5A | 6 | | 7 | 7 | E | 15 | 1C | 23 | 2A | 31 | 38 | 3F | 46 | 4D | 54 | 5B | 62 | 69 | 7 | | 8 | 8 | 10 | 18 | 20 | 28 | 30 | 38 | 40 | 48 | 50 | 58 | 60 | 68 | 70 | 78 | 8 | | 9 | 9 | 12 | 1B | 24 | 2D | 36 | 3F | 48 | 51 | 5A | 63 | 6C | 75 | 7E | 87 | 9 | | A | A | 14 | 1E | 28 | 32 | 3C | 46 | 50 | 5A | 64 | 6E | 78 | 82 | 8C | 96 | Α | | В | В | 16 | 21 | 2C | 37 | 42 | 4D | 58 | 63 | 6E | 79 | 84 | 8F | 9A | A5 | В | | С | С | 18 | 24 | 30 | 3C | 48 | 54 | 60 | 6C | 78 | 84 | 90 | 9C | A8 | В4 | С | | D | D | 1A | 27 | 34 | 41 | 4E | 5B | 68 | 75 | 82 | 8F | 9C | A9 | В6 | СЗ | D | | E | E | 1C | 2A | 38 | 46 | 54 | 62 | 70 | 7E | 8C | 9A | A8 | В6 | C4 | D2 | E | | F | F | 1:E | 2D | 3C | 4B | 5A | 69 | 78 | 87 | 96 | A5 | В4 | СЗ | D2 | E1 | F | | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | А | В | С | D | E | F | | 641 ### TABLE OF MATHEMATICAL CONSTANTS | CONSTANT | D | ECIMAL | VALUE | | HEXADECIMAL<br>VALUE | FLOA | TING PO | DINT VA | ALUE | |---------------------|----------|--------|-------|-------|---------------------------------------|--------|---------|---------------|------| | | | | | | | DO | OUBLE F | PRECISION | ON . | | | | | | | | SINGLE | PRECIS | SION | | | π | 3.14159 | 26535 | 89793 | 23846 | 3.243F 6A88 | 4132 | 43F6 | A888 | 5A31 | | π-1 | 0.31830 | 98861 | 83790 | 67154 | 85A3 08D3<br>0.517C C1B7 | 4051 | 7CC1 | B727 | 220B | | $\int \pi$ | 1.77245 | 38509 | 05516 | 02730 | 2722 0A95<br>1.C5BF 891B | 411C | 5BF8 | 9184 | EF6B | | Ln π | 1.14472 | 98858 | 49400 | 17414 | 4EF6 AA7A<br>1.250D 048E | 4112 | B67A | E858 | 4CAA | | √3 | 1.73205 | 08075 | 68871 | 29353 | 7A1B D0BD<br>1.BB67 AE85 | 411B | 6/AE | 8584 | CAA7 | | е | 2.71828 | 18284 | 59045 | 23536 | 84CA A/3B<br>2.B7E1 5162 | 412B | 7E15 | 1628 | AED3 | | e -1 | 0.36787 | 94411 | 71442 | 32160 | 8AED 2A6B<br>0.5E2D 58D8<br>B3BC DF1B | 405E | 2D58 | D <b>8B3</b> | BCDF | | √e | 1.64872 | 12707 | 00128 | 14683 | 1.A612 98E1<br>E069 BC97 | 411A | 6129 | 8E1E | 069C | | log <sub>10</sub> e | 0.43429 | 44819 | 03251 | 82765 | 0.6F2D EC54<br>9B94 38CB | 406F | 2DEC | 5 <b>A</b> 9B | 9439 | | log <sub>2</sub> e | 1.44269 | 50408 | 88963 | 40736 | 1.7154 7652<br>B82F E177 | 4117 | 1547 | 652B | 82FE | | γ | 0.57721 | 56649 | 01532 | 86061 | 0.93C4 67E3<br>7DB0 C7A5 | 4093 | C467 | E37D | B0C8 | | Ln γ | -0.54953 | 93129 | 81644 | 82234 | -0.8CAE 9BC1<br>1F5A 5FF4 | C08C | AE9B | C11F | 5A60 | | √2 | 1.41421 | 35623 | 73095 | 04880 | 1.6A09 E667<br>F3BC C909 | 4116 | A09E | 667F | 3BCD | | Ln2 | 0.69314 | 71805 | 59945 | 30942 | 0.B172 17F7<br>D1CF 79AC | 40B1 | 7217 | F7D1 | CF7A | | log <sub>10</sub> 2 | 0.30102 | 99956 | 63981 | 19521 | 0.4D10 4D42<br>7DE7 FBCC | 404D | 104D | 427D | E7FC | | √10 | 3.16227 | 76601 | 68379 | 33199 | 3.298B 075B<br>4B6A 5240 | 4132 | 9880 | 75B4 | B6A5 | | Ln10 | 2.30258 | 50929 | 94045 | 68402 | 2.4D76 3776<br>AAA2 BO5C | 4124 | D763 | 776A | AA2B | ### FRACTION CONVERSION TABLE ### 642 ### Hexadecimal and Decimal Fraction Conversion Table | | | | | | | | HALFWORD | ) | | | | | | | |------|---------|------|--------|------|------|-----------|----------|------|--------|--------|--------|-----------|------|--| | | | BYTE | | | | | | | BYTE | | | | | | | BITS | 0123 | | 456 | 57 | | 0123 4567 | | | | | | | | | | Hex | Decimal | Hex | Deci | mal | Hex | | Decimal | | Hex | | Decima | Equivalen | t | | | .0 | .0000 | .00 | .0000 | 0000 | .000 | .0000 | 0000 | 0000 | .0000 | .0000 | 0000 | 0000 | 0000 | | | .1 | .0625 | .01 | .0039 | 0625 | .001 | .0002 | 4414 | 0625 | .0001 | .0000 | 1525 | 8789 | 0625 | | | .2 | .1250 | .02 | .0078 | 1250 | .002 | .0004 | 8828 | 1250 | .0002 | .0000 | 3051 | 7578 | 1250 | | | .3 | .1875 | .03 | .0117 | 1875 | .003 | .0007 | 3242 | 1875 | .0003 | .0000 | 4577 | 6367 | 1875 | | | .4 | .2500 | .04 | .0156 | 2500 | .004 | .0009 | 7656 | 2500 | .0004 | .0000 | 6103 | 5156 | 2500 | | | .5 | .3125 | .05 | .0195 | 3125 | .005 | .0012 | 2070 | 3125 | .0005 | .0000 | 7629 | 3945 | 3125 | | | .6 | .3750 | .06 | .0234 | 3750 | .006 | .0014 | 6484 | 3750 | .0006 | .0000 | 9155 | 2734 | 3750 | | | .7 | .4375 | .07 | .0273 | 4375 | .007 | .0017 | 0898 | 4375 | .0007 | .0001 | 0681 | 1523 | 4375 | | | .8 | .5000 | .08 | .0312 | 5000 | .008 | .0019 | 5312 | 5000 | .0008 | .0001 | 2207 | 0312 | 5000 | | | .9 | .5625 | .09 | .0351 | 5625 | .009 | .0021 | 9726 | 5625 | .0009 | .0001 | 3732 | 9101 | 5625 | | | .A | .6250 | .OA | .0390 | 6250 | .00A | .0024 | 4140 | 6250 | .000A | .0001 | 5258 | 7890 | 6250 | | | . В | .6875 | .08 | .0429 | 6875 | .00B | .0026 | 8554 | 6875 | . 000В | .0001 | 6784 | 6679 | 6875 | | | .c | .7500 | .0C | .0468 | 7500 | .00C | .0029 | 2968 | 7500 | .000C | .0001 | 8310 | 5468 | 7500 | | | .D | .8125 | .00 | . 0507 | 8125 | .00D | .0031 | 7382 | 8125 | .000D | .0001 | 9836 | 4257 | 8125 | | | .E | .8750 | .OE | .0546 | 8750 | .00E | .0034 | 1796 | 8750 | .000E | .0002 | 1362 | 3046 | 8750 | | | .F | .9375 | .OF | . 0585 | 9375 | .00F | .0036 | 6210 | 9375 | .000F | . 0002 | 2888 | 1835 | 9375 | | | | ! | | 2 | | | | 3 | | | | 4 | | | | ### TO CONVERT , ABC HEXADECIMAL TO DECIMAL Find .A in position 1 .6250 Find .08 in position 2 .0429 6875 Find .00C in position 3 .0029 2968 7500 .ABC Hex is equal to .6708 9843 7500 ### TO CONVERT . 13 DECIMAL TO HEXADECIMAL | next lowest to | .1300 | | | | | | |---------------------|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|------|---------------------------|----------| | subtract | 1250 | | | | == | .2 Hex | | 0625 next lowest to | .0050 | 0000 | | | | | | | 0039 | 0625 | | | EE | .01 | | 7656 2500 | .0010 | 9375 | 0000 | | | | | • | 0009 | 7656 | 2500 | | == | .004 | | 0681 1523 4375 | .0001 | 1718 | 7500 | 0000 | | | | | 0001 | 0681 | 1523 | 4375 | := | .0007 | | | .0000 | 1037 | 5976 | 5625 | :8 | ,2147 He | | | | | | | | <b>A</b> | | | Subtract<br>0625 next lowest to<br>7656 2500<br>0681 1523 4375 | 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 0050 | 0625 next lowest to .0050 0000 .0039 0625 .0010 9375 .0000 7656 .0011 1523 4375 .0001 1718 .0001 0681 .0000 1037 | | 0625 next lowest to 1250 | 1250 | To convert fractions beyond the capacity of table, use techniques below: ### HEXADECIMAL FRACTION TO DECIMAL Convert the hexadecimal fraction to its decimal equivalent using the same technique as for integer numbers. Divide the results by 16<sup>n</sup> (n is the number of fraction positions). Example: .8A7 = .540771<sub>10</sub> $$8A7_{16} = 2215_{10}$$ .540771 $16^3 = 4096$ 4096[2215.000000] ### DECIMAL FRACTION TO HEXADECIMAL Collect integer parts of product in the order of calculation. ### INTEGER CONVERSION TABLE 643 Hexadecimal and Decimal Integer Conversion Table | | | | HALFW | ORD | | HALFWORD | | | | | | | | | | |----------------|--------------------------------|--------------------------------------------------|-------------|------------|------------|----------|--------------------|-----------|---------|-----|---------|------|---------|-----|----------------| | | BY | TE | | | BYT | E | | BYTE BYTE | | | | | | | | | BITS: | 0123 | | 4567 | | 0123 | | 4567 | | 0123 | | 4567 | 0123 | | T | 4567 | | Hex | Decimal Decima | | 0 | 0 | 0_ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 1 | 268,435,456 | 1 | 16,777,216 | 1 | 1,048,576 | 1 | 65,536 | 1 | 4,096 | i | 256 | i | 16 | 1 | 1 <del>1</del> | | 2 | 536,870,912 | 2 | 33,554,432 | 2 | 2,097,152 | 2 | 131,072 | 2 | 8,192 | 2 | 512 | 2 | 32 | 2 | 2 | | 3 | 605,306,368 | 3 | 50,331,648 | 3 | 3,145,728 | 3 | 196,608 | 3 | 12,288 | 3 | 768 | 3 | 48 | 3 | 3 | | • | 1,073,741,824 | 4 | 67,108,864 | _4 | 4,194,304 | 4 | 262,144 | 4 | 16,384 | 4 | 1,024 | 4 | 64 | 4 | 4 | | 7 | 1,342,177,280 | 3 | 83,886,080 | 5 | 5,242,880 | 5 | 327,680 | 5 | 20,480 | 5 | 1,280 | 5 | 80 | 5 | 5 | | ÷ | 1,610,612,736 | • | 100,663,296 | 6 | 6,291,456 | 6 | 393,216 | 6 | 24,576 | 6 | 1,536 | 6 | 96 | 6 | 6 | | <del>-</del> | 1,879,048,192 | <del>/</del> | 117,440,512 | _7 | 7,340,032 | 7 | 458,752 | 7 | 28,672 | 7 | 1,792 | 7 | 112 | 7 | 7 | | 8 | 2,147,483,648 | <u> </u> | 134,217,728 | 8 | 8,388,608 | 8 | 524,288 | 8 | 32,768 | 8 | 2,048 | 8 | 128 | 8 | 8 | | <del>' </del> | 2,415,919,104 | <del></del> | 150,994,944 | 9 | 9,437,184 | 9 | 589,824 | 9 | 36,864 | 9 | 2,304 | 9 | 144 | 9 | 9 | | _ | 2,684,354,560<br>2,952,790,016 | <del>- </del> | 167,772,160 | _ <u> </u> | 10,485,760 | <u> </u> | 655,360 | _ A | 40,960 | A | 2,560 | A | 160 | A | 10 | | 2 | 3,221,225,472 | <del>-</del> - | 184,549,376 | - B | 11,534,336 | В | 720,896 | <u>B</u> | 45,056 | В | 2,816 | В | 176 | В | 11 | | <del> </del> | 3,489,660,928 | <u>D</u> | 218,103,808 | 6 | 12,582,912 | <u> </u> | 786,432 | <u></u> | 49, 152 | С | 3,072 | С | 192 | С | 12 | | | 3,758,096,384 | F | 234,881,024 | Ē | 13,631,488 | D | 851,968 | <u>D</u> | 53,248 | D | 3,328 | D | 208 | D | 13 | | F | 4,026,531,840 | Ē | 251,658,240 | È | 15,728,640 | E | 917,504<br>983,040 | E E | 57,344 | E | 3,584 | E | 224 | E | 14 | | | .,, | · · · · · · | ,,240 | ' | 15,728,640 | <u></u> | | r | 61,440 | F | 3,840 | F | 240 | F | 15 | | | 5 | | 7 | | 6 | | 5 | | 4 | | 3 | | 2 | | 1 | ### TO CONVERT HEXADECIMAL TO DECIMAL - Locate the column of decimal numbers corresponding to the left-most digit or letter of the hexadecimal; select from this column and record the number that corresponds to the position of the hexadecimal digit or letter. - 2. Repeat step 1 for the next (second from the left) position. - 3. Repeat step 1 for the units (third from the left) position. - Add the numbers selected from the table to form the decimal number. | EXAMPLE | | | | | | | | | | | |----------------------------------------|------|--|--|--|--|--|--|--|--|--| | Conversion of<br>Hexadecimal Value D34 | | | | | | | | | | | | 1. D | 3328 | | | | | | | | | | | 2. 3 | 48 | | | | | | | | | | | 3. 4 | 4 | | | | | | | | | | | 4. Decimal | 3380 | | | | | | | | | | To convert integer numbers greater than the capacity of table, use the techniques below: ### HEXADECIMAL TO DECIMAL Successive cumulative multiplication from left to right, adding units position. Example: D34 $$_{16}$$ = 3380 $_{10}$ D = 13 $\frac{\times 16}{208}$ 3 = $\frac{+3}{211}$ $\frac{\times 16}{3376}$ 4 = $\frac{+4}{4}$ ### TO CONVERT DECIMAL TO HEXADECIMAL - (a) Select from the table the highest decimal number that is equal to or less than the number to be converted. - (b) Record the hexadecimal of the column containing the selected number. - (c) Subtract the selected decimal from the number to be converted. - Using the remainder from step 1(c) repeat all of step 1 to develop the second position of the hexadecimal (and a remainder). - Using the remainder from step 2 repeat all of step 1 to develop the units position of the hexadecimal. - 4. Combine terms to form the hexadecimal number. | EXAMPLE | | | | | | | | |--------------------------------|--------------------|--|--|--|--|--|--| | Conversion of<br>Decimal Value | 3380 | | | | | | | | 1. D | <u>-3328</u><br>52 | | | | | | | | 2. 3 | <del>-48</del> | | | | | | | | 3. 4 | 4 | | | | | | | | 4. Hexadecimal | D34 | | | | | | | ### DECIMAL TO HEXADECIMAL Divide and collect the remainder in reverse order. # APPENDIX E I/C REFERENCES ### ASCII/HEX CONVERSION TABLE 644-1 | | BITS | | <sup>b</sup> 6 <sub>b5</sub> <sub>b4</sub> | 000 | 0<br>0<br>1 | 0<br>1<br>0 | 0<br>1<br>1 | 1<br>0<br>0 | 1<br>0<br>1 | 1<br>1<br>0 | 1<br>1<br>1 | | |------------|---------------------|------------------|--------------------------------------------|------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------| | <b>b</b> 3 | b <sub>2</sub><br>↓ | b <sub>1</sub> ↓ | <b>∳</b> | MSD<br>LSD | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | 0 | 0 | 0 | 0 | 0 | NUL | DLE | SP | 0 | @ | Р | `` | р | | 0 | 0 | 0 | 1 | 1 | SOH | DC1 | ! | 1 | Α | Q | а | q | | 0 | 0 | 1 | 0 | 2 | STX | DC2 | " | 2 | В | R | b | r | | 0 | 0 | 1 | 1 | 3 | ETX | DC3 | # | 3 | С | S | С | S | | 0 | 1 | 0 | 0 | 4 | EOT | DC4 | \$ | 4 | D | Т | d | t | | 0 | 1 | 0 | 1 | 5 | ENQ | NAK | % | 5 | E | U | е | u | | 0 | 1 | 1 | 0 | 6 | ACK | SYN | & | 6 | F | V | f | V | | 0 | 1 | 1 | 1 | 7 | BEL | ETB | , | 7 | G | W | g | w | | 1 | 0 | 0 | 0 | 8 | BS | CAN | ( | 8 | Н | X | h | x | | 1 | 0 | 0 | 1 | 9 | HT | EM | ) | 9 | ı | Y | i | У | | 1 | 0 | 1 | 0 | Α | LF | SUB | * | : | J | Z | j | z | | 1 | 0 | 1 | 1 | В | VT | ESC | + | ; | K | [ | k | { | | 1 | 1 | 0 | 0 | С | FF | FS | , | < | L | \ | 1 | !<br> | | 1 | 1 | 0 | 1 | D | CR | GS | - | = | М | ] | m | } | | 1 | 1 | 1 | 0 | E | SO | RS | | > | N | ^ | n | ~ | | 1 | 1 | 1 | 1 | F | SI | US | / | ? | 0 | | 0 | DEL | | NUL | Null | DLE | Data link escape | |-----|-----------------------|-------|---------------------------| | SOH | Start of heading | DC1-4 | Device control | | STX | Start of text | NAK | Negative acknowledge | | ETX | End of text | SYN | Synchronous idle | | EOT | End of transmission | ETB | End of transmission block | | ENQ | Enquiry | CAN | Cancel | | ACK | Acknowledge | EM | End of medium | | BEL | Audible signal | SUB | Start of special sequence | | BS | Backspace | ESC | Escape | | HT | Horizontal tabulation | FS | File separator | | LF | Line feed | GS | Group separator | | VT | Vertical tabulation | RS | Record separator | | FF | Form feed | US | Unit separator | | CR | Carrier return | SP | Space | | SO | Shift out | DEL | Delete/Idle | | SI | Shift in | | | ### ASCII/CARD CODE CONVERSION TABLE 645-I | GRAPHIC | 7-BIT<br>ASCII<br>CODE | CARD<br>CODE | GRAPHIC | 7-BIT<br>ASCII<br>CODE | CARD<br>CODE | |-----------------------------------------|------------------------|--------------|----------|------------------------|--------------| | SPACE | 20 | BLANK | @ | 40 | 8-4 | | ! | 21 | 11-8-2 | Ā | 41 | 12-1 | | · , , , , , , , , , , , , , , , , , , , | 22 | 8-7 | В | 42 | 12-2 | | # | 23 | 8-3 | C | 43 | 12-3 | | #<br>\$<br>% | 24 | 11-8-3 | D | 44 | 12-4 | | % | 25 | 0-8-4 | E | 45 | 12-5 | | & | 26 | 12 | F | 46 | 12-6 | | t | 27 | 8-5 | G | 47 | 12-7 | | ( | 28 | 12-8-5 | H | 48 | 12-8 | | j | 29 | 11-8-5 | 1 | 49 | 12-9 | | * | 2A | 11-8-4 | J | 4A | 11-1 | | + | 2B | 12-8-6 | K | 4B | 11-2 | | | 2C | 0-8-3 | L | 4C | 11-3 | | -<br>- | 2D | 11 | М | 4D | 11-4 | | • | 2E | 12-8-3 | N | 4E | 11-5 | | / | 2F | 0-1 | О | 4F | 11-6 | | 0 | 30 | 0 | Р | 50 | 11-7 | | 1 | 31 | 1 | Q | 51 | 11-8 | | | 32 | 2 | R | 52 | 11-9 | | 3 | 33 | 2<br>3 | S | 53 | 0-2 | | 2<br>3<br>4<br>5<br>6<br>7 | 34 | 4 | Т | 54 | 0-3 | | 5 | 35 | 5 | U | 55 | 0-4 | | 6 | 36 | 5<br>6 | V | 56 | 0-5 | | 7 | 37 | 7 | w | 57 | 0-6 | | 8 | 38 | 8 | X | 58 | 0-7 | | 8<br>9 | 39 | 9 | Υ | 59 | 0-8 | | : | 3A | 8-2 | Z | 5A | 0-9 | | ; | 3B | 11-8-6 | [ | 5B | 12-8-2 | | < | 3C | 12-8-4 | \ | 5C | 0-8-2 | | = | 3D | 8-6 | ] | 5D | 12-8-7 | | > | 3E | 0-8-6 | <u>†</u> | 5E | 11-8-7 | | ><br>? | 3F | 0-8-7 | + | 5F | 0-8-5 | 646-1 # STANDARD-PREFERRED ADDRESS TABLE AIC = ANALOG INPUT CONTROLLER AOC = ANALOG OUTPUT CONTROLLER DIO = DIGITAL I/O CONTROLLER QSA = QUAD SYNCHRONOUS ADAPTER ULI = UNIVERSAL LOGIC INTERFACE MDIO = MEMORY DISPATCHED I/O ### APPENDIX F CONSOLE SERVICE ROUTINE FLOWCHART ### NOTES: - 1. ALL RECEIVED CHARACTERS ECHOED BY PROCESSOR. 2. LOWER-CASE CHARACTERS INTERPRETED AS UPPER-CASE. 3. SPACE CHARACTERS IGNORED. 4. BACKSPACE, UNDERLINE, DELETE CAUSE PREVIOUS NUMERIC CHARACTER TO BE IGNORED. 5. IF HARDWARE FLOATING POINT IS NOT AVAILABLE, DISPLAYS ALL "F"s AS CONTENTS. ### INDEX ``` Access level fault, 11-17 Access mode faults, 11-17 Add (A, AR, AI, AIS), 5-5 double-precision floating-point (AD, ADR), 6-36 floating-point (AE, AER), 6-18 halfword (AH, AHI), 5-7 halfword to memory (AHM), 5-11 to list (ATL, ABL), 3-51 to memory (AM), 5-9 Address space, 11-3 Alphanumeric string data, 1-9 Alignment faults, 10-20 AND (N, NR, NI), 3-27 AND halfword (NH, NHI), 3-28 Arithmetic fault interrupt, 10-37 Arithmetic references, D-1 Auto driver channel, 9-19 buffers, 9-21 channel command block, 9-19, 9-20 channel command word, 9-23 checkword, 9-22 general programming procedure for, 9-26 subroutine address, 9-20 translation by, 9-21 valid command codes, 9-25 Auto driver channel flowchart, 9-27 Autolcad (AL), 9-16 Block diagram, processor, 1-2 Boolean operations, 3-2 Branching, 4-1 Branch instructions, 4-2 Branch and link (BAL, BALR), 4-5 on carry (BC, BCR, BCS), 4-13 cn equal (BE, BER, BES), 4-15 on false (BFC, BFCR, BFBS, BFFS), 4-4 on index high (BXH), 4-9 on index low or equal (BXLE), 4-7 on low (BL, BLR, BLS), 4-17 on minus (BM, BMR, BMS), 4-19 cn no carry (BNC, BNCR, ENCS), 4-14 on no overflow (BNO, BNCR, BNOS), 4-24 on not equal (BNE, BNER, BNES), 4-16 on not low (BNL, BNLR, BNLS), 4-18 on not minus (BNM, BNMR, BNMS), 4-20 ``` ``` Branch on not plus (BNP, BNPR, BNFS), 4-22 on not zero (BNZ, BNZR, ENZS), 4-26 on overflow (BO, BOR, BOS), 4-23 cn plus (BP, BPR, BPS), 4-21 on true (BTC, BTCR, BTBS, BTFS), 4-3 on zero (BZ,BZR,BZS), 4-25 unconditional (B, BR, BS), 4-27 Buffers, 9-21 Buffer switch bit, (B), 9-24 Channel, see Auto Driver Channel Check word, 9-22 Circular list, 3-4 Circular list definition, 3-3 Compare, 3-24, 5-17, 7-10 alphanumeric (CPAN, CPANP), 7-10 alphanumeric with default pad (CPANP), 7-10 arithmetic (C,CR,CI), 5-17 double-precision floating-point (CD,CDR), 6-40 floating-point (CE, CER), 6-22 halfword (CH, CHI), 5-18 logical (CL, CLR, CLI), 3-24 logical byte (CLB), 3-26 logical halfword (CLH, CLHI), 3-25 Complement bit (CBT), 3-45 Condition code, 1-5, 6-10, 10-8 Conditions that cause MAT faults, 11-16 Configuration, system control, 2-1 Console mode, 10-15 Console service routine flowchart, F-1 Control of I/O operations, 9-4 Control switches, 2-4 Convert to halfword value register (CHVR), 5-33 Conversion from decimal, 6-9 CRC generation flowchart, 3-47 Cyclic redundancy check (CRC12, CRC16), 3-46 by auto-driver channel, 9-22 Data alignment, 1-10 Data formats, 1-8 decimal data, 7-1 fixed-point data, 5-1 floating-point data, 6-2 logical data, 3-1 Data format fault interrupt, 10-19 Data handling instructions, 8-1 Data handling instruction formats, 8-1 Decimal string data, 1-9, 7-1 Decision making, 4-1 Decrement and examine prior 1ccation "-", 2-7 Device addressing, 9-2 Device controllers, 9-1 Device priorities, 9-2 ``` ``` Divide (D, DR), 5-24 double-precision floating-point (DD, DDR), 6-43 floating-point (DE, DER), 6-25 halfword (DH, DHR), 5-27 Early power fail detect and automatic shutdown, 10-24 Entering console service, 2-5 Equalization, 6-5 Examine (see also Modify) double-precision floating-point register "D", 2-8 general register "R", 2-7 program status word "P", 2-9 single-precision floating-point register "F", 2-8 Examples of R*-rounding, 6-8 Exchange byte register (EXBR), 3-20 Exchange halfword register (EXHR), 3-19 Exchange program status register (EPSR), 10-41 Exclusive-OR (X,XR,XI), 3-31 Exclusive-OR halfword (XH,XHI), 3-32 Execute bit (E), 9-23 Exponent overflow, 6-7 Exponent underflow, 6-7 Extended branch mnemonics, 4-11 Fast bit (F), 9-23 Fault precedence, 11-18 Faults alignment, 10-20 data format, 10-19 illegal instruction, 10-19 machine malfunction, 10-22 memory address translator (MAT), 11-18 Fix register (FXR), 6-27 Fix register double-precision (FXDR), 6-45 Fixed-point arithmetic, 5-1 data, 1-8 data formats, 5-1 instructions, 5-4 instruction formats, 5-3 number range, 5-2 operations, 5-2 Float register (FLR), 6-29 Float register double-precision (FLDR), 6-46 Floating/fixed point ranges, 6-4 Floating-Point arithmetic, 6-1 data formats, 1-9, 6-2 instructions, 6-10 masked mode (FLM), 10-3 number, 6-3 number range, 6-4 registers, 1-6 underflow interrupt enable (FLU), 10-5 Flowchart, console service routine, F-1 Format of a segment table descriptor, 11-7 ``` ``` General auto driver channel programming procedure, 9-26 General registers, 1-6 Guard digits and R*-rounding, 6-8 Hardware segment table entry, 11-8 High speed data handling instructions, 8-1 Illegal digit cases (pack and move), 7-12 Illegal digit cases (unpack and move), 7-14 Illegal instruction interrupt, 10-19 Immediate interrupt - auto driver channel, 10-31 Increment and examine next location "+", 2-6 Initial program load, 2-5 Input/output operations, 9-1 Instruction alignment, 1-10 Instruction formats, 1-11 branch instructions, 4-2 decimal and alphanumeric string, 7-3 fixed-point instructions, 5-3 floating-point instructions, 6-4 I/O instructions, 9-9 logical instructions, 3-5 Instruction summary - alphabetical by mnemonic, B-1 Instruction summary - numerical, C-1 driven I/0, 9-5 precedence, 10-13 priority level/register set summary, 10-32 queuing, 9-3 service pointer table, 9-3 system architecture - schematic diagram, 10-11 timing and priority, 10-10, 10-12 Interrupts, processor, 1-7 Interruptible instructions, 10-14 Interruptible instruction in progress (IIP), 10-3 Interruptible state instructions using, 7-3, 10-55, 10-56 saving on power fail, 10-29 Invalid digit faults, 10-21 I/0 device interrupts, 10-30 instruction format, 9-9 instructions, 9-9 interrupt mask (I), 10-4 references, E-1 system configuration, 9-1 Key operated security lock, 2-3 List processing, 3-3 List processing instructions, 3-54 Load (L,LR,LI), 3-7 address (LA), 3-11 byte (LB, LBR), 3-18 complement double-precision register (LCDR), 6-32 complement floating-point register (LCER), 6-15 ``` ``` Load (continued) complement short (LCS), 3-9 double-precision floating-point (LD, LDR, LDGR), 6-30 dcuble-precision floating-point register from single (LDE,LDER), 6-48 floating-point (LE, LER, LEGR), 6-12 general registers from double-precision floating-point register (LGDR), 6-34 general register from floating-point register (LGER), 6-16 halfword (LH, LHI), 3-10 halfword logical (LHL), 3-16 immediate short, 3-8 multiple (LM), 3-17 multiple double-precision floating-point (LMD), 6-33 multiple floating-point (LME), 6-16 packed decimal string as binary (LPB), 7-4 positive double-precision register (LPDR), 6-31 positive floating-point register (LPER), 6-14 process segment table descriptor (LPSTD), 10-50, 11-20 process state (LDPS), 10-53 program status word (LPSW), 10-39 program status word register (LPSWR), 10-40 real address (LRA), 3-12 shared segment table descriptor (LSSTD), 10-51, 11-21 single-precision floating-point register from double (LED, LEDR), 6-47 Location counter, 1-6 Logical data, 1-9, 3-1 instructions, 3-5 instruction formats, 3-5 cperations, 3-1 Machine malfunction interrupt, 10-22 early power fail (EPF), 10-22 nonconfigured memory address, 10-28 noncorrectable memory error, 10-26 power restore, 10-25 shared memory power fail, 10-29 Machine malfunction interrupt enable, 10-5 Machine malfunction status word (MMSW), 10-23 Maskable and nonmaskable interrupts, 10-10 MAT fault handling routine, 11-18 Memory access level field (IVI), 10-3 Memory address translation, 11-2 Memory address translator faults, 11-16 access level fault, 11-17 access mode violation - execute, 11-17 access mode violation - read, 11-17 access mode violation - write, 11-17 nonpresent segment fault, 11-17 PST size exceeded, 11-16 SST size exceeded, 11-16 segment limit violation, 11-17 Memory initialization, 2-10 Memory management, 11-1 ``` ``` Memory management instructions, 11-20 Modify current location "=", 2-7 double-precision floating-point register "=", 2-9 general register "=", 2-7 program status word "=", 2-9 single-precision floating-point register "=", 2-8 Move, 7-8 and pad (MOVE), 7-8 and pad with default pad (MOVEP), 7-8 translated until (MVTU), 7-6 Multiply (M,MR), 5-20 double-precision floating-point (MD, MDR), 6-41 floating-point (ME, MER), 6-23 halfword (MH, MHR), 5-22 MVTU instruction, 7-6 Nonpresence fault, 11-17 Normalization, 6-5 No operation (NCP, NCPR), 4-28 Offset field, 11-4 Op-code map, A-1 Operating instructions, 2-5 OR (C, CR, OI), 3-29 OR halfword (OH, OHI), 3-30 Output command (OC, OCR), 9-10 Pack and move (PMV), 7-12 Pack and move absolute (MPVA), 7-12 Packed decimal, 7-1 Packed decimal format, 7-1 Physical address space, 11-3 Power fail early, 10-24 shared memory, 10-29 Power restore, 10-25 Power-up, 2-5 Priority levels, 10-30 Privileged system function (PSF), 10-45 Process byte (PB), 8-2 Process byte register (PBR), 8-4 Processor, 1-4 Processor/controller communication, 9-2 Processor interrupts, 1-7 Processor modes, 10-15 Program address space, 11-3 Programming examples, 1-13 Programming instructions, system terminal, 2-11/2-12 Program status word (PSW), 1-4, 10-2, 10-3 Protect mode enable (P), 10-6 PST size exceeded fault, 11-16 PSW location counter (LOC), 10-8 PSW status word, 10-3 ``` ``` Read data (RD, RDR), 9-12 error logger (REL), 10-46 halfword (RH,RHR), 9-13 Read/write bit (R/W), 9-23 Redundancy check type bits (RC), 9-24 Reexecution of faulting instructions after a MAT interrupt, 11-19 after a machine malfunction interrupt, 10-29 Register and immediate storage formats RI1, 1-20 RI2, 1-22 Register and indexed storage formats RX1, 1-15 RX2, 1-16 RX3, 1-18 RXRX, 1-24 Register set numbering, 1-5 select, 1-5 select field (P), 10-7 Register-to-register format (RR), 1-14 Relocation/protection enable (R/P), 10-6 Relocation/protection (MAT) fault interrupt, 10-21 Remove from list (RTL, RBL), 3-53 Reserved memory locations, 1-7, 10-9 Reset bit (RBT), 3-44 Peset memory voltage failure (RMVF), 10-58 Restore interruptible state (ISRST), 10-56 Rotate left logical (RLL), 3-39 Rotate right logical (RRL), 3-40 Run mode, 10-16 RXRX formats, See Register and indexed storage formats Sample program, 1-13 Save interruptible state (ISSV), 10-55 Schematic diagram - interrupt system architecture, 10-11 Segment field, 11-4 access field settings, 11-10 limit fault, 11-17 table descriptors and their use, 11-6 table entries, 11-8 table entry size, 11-8 Select an address and examine "a", 2-6 Selection of program or physical addressing, 11-5 Selector channel I/0, 9-6 devices, 9-7 operation, 9-7 programming, 9-8 Sense status (SS, SSR), 9-11 Set bit (SBT), 3-43 Setting the program address space size, 11-7 Shared and private segments, 11-6 Shared memory power fail, 10-29 ``` ``` Shift left arithmetic (SLA), 5-29 left halfword arithmetic (SLHA), 5-30 left halfword logical (SLHL, SLHLS), 3-37 1eft logical (SLL, SLLS), 3-35 right arithmetic (SRA), 5-31 right halfword arithmetic (SRHA), 5-32 right halfword logical (SRHL, SRHLS), 3-38 right logical (SRL, SRLS), 3-36 Short form format (SF), 1-14 Simulate channel program (SCP), 9-18 Simulate interrupt (SINT), 10-42 Simulated interrupt, 10-34 Single step mode, 10-17 Software segment table entry, 11-12 SST size exceeded fault, 11-16 Status mask, 9-23 monitoring I/O, 9-4 switching, 10-18 switching and interrupts, 10-1 switching instructions, 10-38 Store (ST), 3-21 binary as packed decimal string (STBP), 7-5 byte (STB, STBR), 3-23 byte, no ECC (XSTB), 10-57 double-precision floating-point (STD), 6-35 double-precision floating-point register in single- precision memory (STDE), 6-49/6-50 floating-point (STE), 6-17 halfword (STH), 3-21 multiple (STM), 3-22 multiple floating-point (STME), 6-17 multiple double-precision floating-point (STMD), 6-35 process state (STPS), 10-52 String instructions, 7-3 String operations, 7-1 Subroutine address, 9-20 Subroutine linkage, 4-2 Subtract (S,SR,SI,SIS), 5-13 double-precision floating-point (SD,SDR), 6-38 floating-point (SE, SER), 6-20 halfword (SH, SHI), 5-15 Supervisor call (SVC), 10-43 Supervisor call (SVC) interrupt, 10-36 System breakpoint (BRK), 10-44 breakpoint interrupt, 10-37 control, 2-1 control panel, 2-1 control panel switches and indicators, 2-3 description, 1-1 queue service (SQS) interrupt, 10-35 ``` System (continued) queue service interrupt enable (Q), 10-6 terminal commands, 2-6 terminal support command summary, 2-2 Test and set (TS), 3-41 Test bit (TBT), 3-42 Test halfword immediate (THI), 3-34 Test immediate (TI), 3-33 TLATE instruction, 3-2, 3-48 Translate (TLATE), 3-48 Translate bit, 9-24 Translation, 3-2, 3-48, 7-6, 9-21 Translation from program to physical address space, 11-5 Translation table entry, 3-2 True zero, 6-6 Unpack and move (UMV), 7-14 Unpack and move absolute (UMVA), 7-14 Unpacked decimal format, 7-2 Unpacked (zoned) decimal, 7-2 Valid channel command codes, 9-25 Wait state (W), 10-4 Write data (WD, WDR), 9-14 Write halfword (WH, WHR), 9-15 550 Keyboard layout, 2-3 Model 3210 block diagram, 1-2 Op-code map, A-1 ### **PUBLICATION COMMENT FORM** Please use this postage-paid form to make any comments, suggestions, criticisms, etc. concerning this publication. From \_\_\_\_\_ Date \_\_\_\_ Title \_\_\_\_\_\_ Publication Title \_\_\_\_\_ Company\_\_\_\_\_\_Publication Number \_\_\_\_\_ Address \_\_\_\_\_ **FOLD FOLD** Check the appropriate item. Page No. \_\_\_\_\_ Drawing No. \_\_\_\_\_ Error Drawing No. Addition Page No. Page No. \_\_\_\_\_ Drawing No. \_\_\_\_\_ CUT ALONG LINE Other Explanation: **FOLD** FOLD FOLD FOLD ### **BUSINESS REPLY MAIL** FIRST CLASS PERMIT NO. 22 OCEANPORT, N.J. POSTAGE WILL BE PAID BY ADDRESSEE ## PERKIN-ELMER Computer Systems Division 2 Crescent Place Oceanport, NJ 07757 NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES **TECH PUBLICATIONS DEPT. MS 322A** FOLD FOLD