TEXAS INSTRUMENTS Equipment Group P. O. Box 2909 Austin, Texas 78767 S1005P 1 March 1972 ## TEXAS INSTRUMENTS | ### CONTROL OF THE PROPERTY | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | AND THE PROPERTY OF PROPER | | ************************************** | | | | | | ###################################### | | AND THE PROPERTY OF PROPER | | APPROXIMATION OF THE PROXIMATION | | ************************************** | | | | | | | | ************************************** | | | | THE STATE OF THE PARTY P | | | | | | | ## © Texas Instruments Incorporated 1972 All Rights Reserved The information and/or drawings set forth in this document and all rights in and to inventions disclosed herein and patents which might be granted thereon disclosing or employing the materials, methods, techniques or apparatus described herein are the exclusive property of Texas Instruments Incorporated. No disclosure of the information or drawings shall be made to any other person or organization without the prior consent of Texas Instruments Incorporated. ## TABLE OF CONTENTS | Section | | | Page | |---------|------|-----------------------------------------------------|-------| | I | GENE | RAL DESCRIPTION | | | | 1-1 | The Central Processor | 1-1 | | | 1-2 | Central Processor-Peripheral Processor Relationship | 1 - 1 | | | 1-3 | Central Processor Resources | 1-1 | | | 1-8 | The Assembler | 1-2 | | | 1-9 | Coding Media | 1-3 | | | 1-10 | Punched Card | 1-10 | | | 1-11 | Coding Form | 1-11 | | II . | LANG | UAGE ELEMENTS | | | | 2-1 | Character Set for the ASC | 2-1 | | | 2-2 | Printable Characters | 2-1 | | | 2-3 | Special Characters | 2-1 | | | 2-4 | Items | 2-1 | | | 2-5 | Symbol | 2-3 | | | 2-6 | Character String | 2-3 | | | 2-7 | Decimal Integer | 2-3 | | | 2-8 | Hexadecimal Integer | 2-4 | | | 2-9 | Floating Point Item | 2-4 | | | 2-10 | Fixed Point Decimal Item | 2-5 | | | 2-11 | Location Counter | 2-6 | | | 2-12 | Literal | 2-6 | | | 2-13 | Intrinsic Function | 2-6 | | Section | | | Page | |---------|--------------|------------------------------------------------|------| | | 2-14 | Operators | 2-7 | | | 2-15 | Operator Types | 2-7 | | | 2-16 | Expressions | 2-7 | | | 2-17 | Subexpressions | 2-10 | | | 2-18 | Assumed Parentheses | 2-11 | | | 2-19 | Literals | 2-12 | | • | 2-20 | Lists | 2-13 | | | 2-21 | Intrinsic Functions | 2-14 | | | 2-22 | Global Attribute Functions | 2-14 | | | 2-26 | Location Counter | 2-16 | | | 2-27 | Program Sections | 2-16 | | | 2-28 | Relocation | 2-17 | | | 2-29 | Constants | 2-17 | | | 2-32 | Location Counter | 2-17 | | | 2-33 | Relocatability of Symbols | 2-18 | | | 2-34 | Relocatability of Expressions | 2-18 | | III | LANG | UAGE STRUCTURE | | | | 3-1 | Statement Format | 3-1 | | | 3-2 | Conventions for Describing Language Statements | 3-2 | | | 3-3 | Continuation Lines | 3-2 | | | 3-4 | Label Field | 3-3 | | | 3-6 | Command Field | 3-3 | | | 3 <b>-</b> 7 | Operand Field | | | | 3-8 | | | | | 3-8 | Remark Field | 3 - | | Section | | | Page | |---------|-------|--------------------------------------|--------------| | | 3-9 | Comment Lines | 3 <b>-</b> 5 | | | 3-10 | Blank Lines | 3 <b>-</b> 5 | | IV | DIREC | CTIVES | | | | 4-1 | Introduction | 4-1 | | | 4-2 | Definition Directives | 4-1 | | | 4-3 | Equate Directive (EQU) | 4-1 | | | 4-4 | Set Directive (SET) | 4-2 | | | 4-5 | External Name Directive (EXTRN) | 4-3 | | | 4-6 | Entry Name Directive (ENTRY) | 4-4 | | | 4-7 | Data Directive (DATA) | 4-5 | | | 4-8 | Format Directive (FORM) | 4-6 | | | 4-9 | Using Directive (USING) | 4-7 | | | 4-10 | Drop Directive (DROP) | 4-8 | | | 4-11 | Origin Directive (ORG) | 4-8 | | | 4-12 | Control Directives | 4-9 | | | 4-13 | Literal Origin Directive (LITORG) | 4-9 | | | 4-14 | End Assembly Directive (END) | 4-10 | | | 4-15 | Section Directive (SEC) | 4-11 | | | 4-16 | Common Module Directive (COM) | 4-12 | | | 4-17 | Dummy Section Directive (DUM) | 4-13 | | | 4-18 | Dummy Common Module Directive (COMD) | 4-14 | | | 4-19 | Copy Directive (COPY) | 4-15 | | | 4-20 | Reserve Directive (RES) | 4-16 | | | 4-21 | Align Directive (ALIGN) | 4-16 | | • | 4-22 | Do Directive (DO) | 4-17 | | | 4-23 | Pseudo Directives | 4-21 | | Section | | | Page | |---------|-------|-------------------------------------------|--------------| | | 4-24 | Indirect Address Constant Directive (IND) | 4-21 | | | 4-25 | Data Halfword Directive (DATAH) | 4-22 | | | 4-26 | Listing Directives | 4-22 | | | 4-27 | Skip Directive (SKIP) | 4-22 | | | 4-28 | List Directive (LIST) | 4-23 | | | 4-29 | Nolist Directive (NOLIST) | 4-24 | | v | ASSEI | MBLER OUTPUT | | | | 5-1 | Assembler Output | 5-1 | | | 5-2 | Source Program Listing | 5 - 1 | | | 5-3 | Messages | 5-3 | | | 5-5 | Cross-Reference Listing | 5 <b>-</b> 5 | | VI | ASSE | MBLER-CENTRAL PROCESSOR INTERFACE | | | | 6-1 | Introduction | 6-1 | | | 6-2 | Instruction Formats | 6-1 | | | 6-3 | Label | 6-3 | | | 6-4 | Command | 6-3 | | | 6-5 | Operands | 6-3 | | · | 6-6 | R, N, X Operand List | 6-3 | | | 6-10 | R, R, N Operand List | 6-7 | | | 6-11 | Register Addressing | 6-8 | | | 6-12 | Register Operand-R Field Addresses | 6-8 | | | 6-13 | Address Operand Register Addresses | 6-11 | | | 6-14 | Address Development | 6-12 | | Section | | | Page | |---------|---------------|-----------------------------------------------|--------------| | | 6-15 | Assembler Translation | 6-12 | | | 6-18 | Machine Translation | 6-15 | | | 6-29 | Immediate Operands | 6-31 | | | 6-30 | Assembler Translation | 6-31 | | | 6-33 | Machine Translation | 6-32 | | | 6-40 | Branch Address Development | 6-36 | | | 6-41 | Assembler Translation | 6-37 | | | 6-47 | Machine Translation | 6-39 | | | 6-51 | Data Formats | 6-43 | | | 6-52 | Fixed Point Data | 6-44 | | | 6-53 | Floating Point Data | 6-44 | | | 6-56 | Program Status Doubleword | 6-49 | | | 6-57 | Branch or Skip Register | 6-50 | | | 6 <b>-</b> 58 | Compare Code | 6-50 | | | 6 <b>-</b> 59 | Result Code | 6-51 | | | 6-60 | Arithmetic Exception Condition Code | 6-51 | | | 6-62 | Arithmetic Exception Mask | 6-53 | | | 6-64 | Program Counter | 6-54 | | VII | THE S | SCALAR INSTRUCTIONS FOR THE CENTRAL PROCESSOR | | | | 7-1 | Introduction | 7-1 | | | 7-2 | Load Register Instructions | 7-2 | | | 7-3 | Load, Word (L) | 7-3 | | | 7-4 | Load, Halfword (LH) | 7-4 | | | 7 <b>-</b> 5 | Load, Right Halfword From Right (LR) | 7 <b>-</b> 5 | | | 7 <b>-</b> 6 | Load, Left Halfword From Right (LL) | 7-6 | | Section | | | Page | |---------|--------------|------------------------------------------------------------|--------------| | | 7-7 | Load, Doubleword (LD) | 7-7 | | | 7 <b>-</b> 8 | Load Immediate, Word (LI) | 7-8 | | | 7-9 | Load Immediate, Halfword (LIH) | 7-9 | | | 7-10 | Load Negative, Fixed Point Word (LN) | 7-10 | | | 7-11 | Load Negative, Fixed Point Halfword (LNH) | 7-11 | | | 7-12 | Load Negative, Floating Point Word (LNF) | 7-12 | | | 7-13 | Load Negative, Floating Point Doubleword (LND) | 7-13 | | • | 7-14 | Load Magnitude, Fixed Point Word (LM) | 7-14 | | | 7-15 | Load Magnitude, Fixed Point Halfword (LMH) | <b>7-</b> 15 | | | 7-16 | Load Magnitude, Floating Point Word (LMF) | 7-16 | | | 7-17 | Load Magnitude, Floating Point Doubleword (LMD) . | 7-17 | | | 7-18 | Load Negative Magnitude, Fixed Point Word (LNM). | 7-18 | | | 7-19 | Load Negative Magnitude, Fixed Point Halfword (LNMH) | 7-19 | | | 7-20 | Load Negative Magnitude, Floating Point Word (LNMF) | 7-20 | | | 7-21 | Load Negative Magnitude, Floating Point Double-word (LNMD) | 7-21 | | | 7-22 | Load One's Complement, Word (LD) | 7-22 | | | 7-23 | Load Register File (LF) | 7-23 | | | 7-24 | Load Register Files, Multiple (LFM) | 7-24 | | | 7-25 | Store Instructions | 7-25 | | | 7-26 | Store Word (ST) | 7-26 | | | 7-27 | Store Halfword (STH) | 7-27 | | | 7-28 | Store Right Halfword Into Right (STR) | 7-28 | | | 7-29 | Store Left Halfword Into Right (STL) | 7-29 | | | 7-30 | Store Doubleword (STD) | 7-30 | | | 7-31 | Store Zero, Word (STZ) | 7-31 | | Section | | Page | |--------------|----------------------------------------------------|---------------| | 7-3 | Store Zero, Halfword (STZH) | 7-32 | | 7-3 | Store Zero, Doubleword (STZD) | 7-33 | | 7-3 | Store Negative, Fixed Point Word (STN) | 7-34 | | 7-3 | 5 Store Negative, Fixed Point Halfword (STNH) | 7-35 | | 7-3 | 6 Store Negative, Floating Point Word (STNF) | 7-36 | | 7-3 | 7 Store Negative, Floating Point Doubleword (STND) | 7-37 | | 7-3 | Store One's Complement, Word (STO) | 7-38 | | 7-3 | Store One's Complement, Halfword (STDH) | 7-39 | | 7-4 | O Store Register File (STF) | 7-40 | | 7-4 | Store Register Files, Multiple (STFM) | 7-41 | | 7-4 | 2 Arithmetic Instructions | 7-42 | | 7-4 | Add, Fixed Point Word (A) | 7-43 | | 7-4 | Add, Fixed Point Halfword (AH) | 7-44 | | 7-4 | Add, Floating Point Word (AF) | <b>7-4</b> 5 | | 7-4 | Add, Floating Point Doubleword (AFD) | 7-46 | | 7-4 | Add Immediate, Fixed Point Word (AI) | 7-47 | | 7-4 | 8 Add Immediate, Fixed Point Halfword (AIH) | 7-48 | | 7-4 | Add Magnitude, Fixed Point Word (AM) | 7-49 | | 7 <b>-</b> 5 | Add Magnitude, Fixed Point Halfword (AMH) | 7-50 | | 7-5 | Add Magnitude, Floating Point Word (AMF) | 7 <b>-</b> 51 | | 7 <b>-</b> 5 | Add Magnitude, Floating Point Doubleword (AMFD) | 7-52 | | 7 <b>-</b> 5 | | 7-53 | | 7 <b>-</b> 5 | | 7-54 | | 7 <b>-</b> 5 | | 7 <b>-</b> 55 | | 7 <b>-</b> 5 | | 7-56 | | 7-5 | | 7 <b>-</b> 57 | | 7-5 | | 7 <b>-</b> 58 | | Section | | | Page | |---------|-----------------|------------------------------------------------------|--------------| | | 7-59 | Subtract Magnitude, Fixed Point Word (SM) | <b>7-</b> 59 | | | 7-60 | Subtract Magnitude, Fixed Point Halfword (SMH) | 7-60 | | | 7-61 | Subtract Magnitude, Floating Point Word (SMF) | 7-61 | | | 7-62 | Subtract Magnitude, Floating Point Doubleword (SMFD) | 7-62 | | | 7-63 | Multiply, Fixed Point Word (M) | 7-63 | | | 7-64 | Multiply, Fixed Point Halfword (MH) | 7-64 | | | 7-65 | Multiply, Floating Point Word (MF) | 7-65 | | | 7-66 | Multiply, Floating Point Doubleword (MFD) | 7-66 | | | 7-67 | Multiply Immediate, Fixed Point Word (MI) | 7-67 | | | 7-68 | Multiply Immediate, Fixed Point Halfword (MIH) | 7-68 | | | 7-69 | Divide, Fixed Point Word (D) | 7-69 | | | 7-70 | Divide, Fixed Point Halfword (DH) | 7-70 | | | 7-71 | Divide, Floating Point Word (DF) | 7-71 | | | 7-72 | Divide, Floating Point Doubleword (DFD) | 7-72 | | | 7-73 | Divide Immediate, Fixed Point Word (DI) | 7-73 | | | 7-74 | Divide Immediate, Fixed Point Halfword (DIH) | 7-74 | | | 7 <b>-</b> 75 I | Logical Instructions | 7-75 | | | 7-76 | AND, Word (AND) | 7-76 | | | 7-77 | AND, Doubleword (ANDD) | 7-77 | | | 7-78 | AND Immediate, Word (ANDI) | 7-78 | | | 7-79 | OR, Word (OR) | 7-79 | | | 7-80 | OR, Doubleword (ORD) | 7-80 | | | 7-81 | OR Immediate, Word (ORI) | 7-81 | | | 7-82 | Exclusive OR, Word (XOR) | 7-82 | | | 7-83 | Exclusive OR, Doubleword (XORD) | 7-83 | | | 7-84 | Exclusive OR Immediate, Word (XORI) | 7-84 | | | 7-85 | Equivalence, Word (EQC) | 7-85 | | Section | | | Page | |---------|---------------|-----------------------------------------------|-------| | | 7-86 | Equivalence, Doubleword (EQCD) | 7-86 | | | 7-87 | Equivalence Immediate, Word (EQCI) | 7-87 | | | 7-88 | Shift Instructions | 7-88 | | | 7 <b>-</b> 89 | Arithmetic Shifts | 7-89 | | | 7-90 | Logical Shifts | 7-89 | | | 7-91 | Circular Shifts | 7-90 | | | 7-92 | Algorithm for Bit Reversal | 7-91 | | | 7-93 | Arithmetic Shift, Word (SA) | 7-92 | | | 7-94 | Arithmetic Shift, Halfword (SAH) | 7-93 | | | 7 <b>-</b> 95 | Arithmetic Shift, Doubleword (SAD) | 7-94 | | | 7 <b>-</b> 96 | Logical Shift, Word (SL) | 7-95 | | | 7-97 | Logical Shift, Halfword (SLH) | 7-96 | | | 7 <b>-</b> 98 | Logical Shift, Doubleword (SLD) | 7-97 | | | 7-99 | Circular Shift, Word (SC) | 7-98 | | | 7-100 | Circular Shift, Halfword (SCH) | 7-99 | | | 7-101 | Circular Shift, Doubleword (SCD) | 7-100 | | | 7-102 | Bit Reversal, Word (RVS) | 7-101 | | | 7-103 | Compare Instructions | 7-102 | | | 7-104 | Compare, Fixed Point Word (C) | 7-103 | | | 7-105 | Compare, Fixed Point Halfword (CH) | 7-104 | | | 7-106 | Compare, Floating Point Word (CF) | 7-105 | | | 7-107 | Compare, Floating Point Doubleword (CFD) | 7-106 | | | 7-108 | Compare Immediate, Fixed Point Word (CI) | 7-107 | | | 7-109 | Compare Immediate, Fixed Point Halfword (CIH) | 7-108 | | | 7-110 | Compare Logical AND, Word (CAND) | 7-109 | | | 7-111 | Compare Logical AND, Doubleword (CANDD) | 7-110 | | | 7-112 | Compare Logical AND Immediate, Word (CANDI) | 7-111 | | Section | | | Page | |---------|-------|----------------------------------------------------------|-------| | | 7-113 | Compare Logical OR, Word (COR) | 7-112 | | | 7-114 | Compare Logical OR, Doubleword (CORD) | 7-113 | | | 7-115 | Compare Logical OR Immediate, Word (CORI) | 7-114 | | | 7-116 | Increment or Decrement, Test and Skip Instructions | 7-115 | | | 7-117 | Increment, Test and Skip on Equal (ISE) | 7-116 | | | 7-118 | Increment, Test and Skip on Not Equal (ISNE) | 7-117 | | • | 7-119 | Decrement, Test and Skip on Equal (DSE) | 7-118 | | | 7-120 | Decrement, Test and Skip on Not Equal (DSNE) | 7-119 | | | 7-121 | Increment or Decrement, Test and Branch Instructions | 7-120 | | | 7-122 | Increment, Test and Branch on Zero (IBZ) | 7-121 | | | 7-123 | Increment, Test and Branch on Not Zero (IBNZ) | 7-122 | | | 7-124 | Decrement, Test and Branch on Zero (DBZ) | 7-123 | | | 7-125 | Decrement, Test and Branch on Not Zero (DBNZ) | 7-124 | | | 7-126 | Index, Test and Branch Instructions | 7-125 | | | 7-127 | Algorithm for Index Test and Branch | 7-126 | | | 7-128 | Branch on Less Than or Equal (BCLE) | 7-127 | | | 7-129 | Branch on Greater Than (BCG) | 7-128 | | | 7-130 | Conditional Branch Instructions | 7-129 | | | 7-131 | Condition Algorithms for Conditional Branches | 7-132 | | | 7-132 | Branch on Comparison Code True (BCC) | 7-133 | | | 7-133 | Branch on Result Code True (BRC) | 7-135 | | | 7-134 | Branch on Arithmetic Exception (BAE) | 7-137 | | | 7-135 | Branch on Execute Branch Condition True (BXEC) | 7-140 | | | 7-136 | Unconditional Branch Instructions | 7-141 | | | 7-137 | Branch and Load Base Register With Program Counter (BLB) | 7-142 | | Section | | | Page | |---------|-------|---------------------------------------------------------------------|---------------| | | 7-138 | Branch and Load Index or Vector Register With Program Counter (BLX) | 7-143 | | | 7-139 | Stack Instructions | 7-144 | | | 7-140 | Stack Instruction Definition | 7-145 | | | 7-141 | Push Word Into Last-In-First-Out Stack (PSH) | 7-146 | | | 7-142 | Pull Word From Last-In-First-Out Stack (PUL) | 7-147 | | | 7-143 | Modify Stack Parameter Doubleword (MOD) | 7-148 | | | 7-144 | Conversion and Normalization Instructions | 7-150 | | | 7-145 | Algorithm for Floating Point to Fixed Point Conversions | <b>7-</b> 151 | | | 7-146 | Algorithm for Fixed Point to Floating Point Conversions | 7-152 | | | 7-147 | Fixed Point Normalization | 7-154 | | | 7-148 | Convert Floating Point Word to Fixed Point Word (FLFX) | 7-155 | | | 7-149 | Convert Floating Point Word to Fixed Point Half-word (FLFH) | 7-156 | | | 7-150 | Convert Floating Point Doubleword to Fixed Point Word (FDFX) | 7-157 | | | 7-151 | Convert Fixed Point Word to Floating Point Word (FXFL) | 7-158 | | | 7-152 | Convert Fixed Point Halfword to Floating Point Word (FHFL) | <b>7-</b> 159 | | | 7-153 | Convert Fixed Point Word to Floating Point Double-word (FXFD) | 7-160 | | | 7-154 | Convert Fixed Point Halfword to Floating Point Doubleword (FHFD) | 7-160 | | | 7-155 | Normalize Fixed Point Word (NFX) | 7-162 | | | 7-156 | Normalize Fixed Point Halfword (NFH) | 7-163 | | | 7-157 | Miscellaneous Instructions | 7-164 | | Section | | | Page | |---------|-------|-----------------------------------------------------------|---------------| | | 7-158 | Exchange Words (XCH) | 7-165 | | | 7-159 | Load Look Ahead (LLA) | 7-166 | | | 7-160 | Load Effective Address (LEA) | 7-168 | | | 7-161 | Execute (XEC) | 7-169 | | | 7-162 | Interpret (INT) | 7-170 | | | 7-163 | Monitor Call and Proceed (MCP) | 7-171 | | | 7-164 | Monitor Call and Wait (MCW) | 7-172 | | • | 7-165 | Program Status Instructions | 7-173 | | | 7-166 | Load Arithmetic Exception Mask (LAM) | 7-174 | | | 7-167 | Load Arithmetic Exception Condition (LAC) | <b>7-</b> 175 | | | 7-168 | Store Program Status Word (SPS) | 7-176 | | VIII | THE V | ECTOR INSTRUCTIONS FOR THE CENTRAL PROCESSOR | | | | 8-1 | Introduction | 8-1 | | | 8-2 | Definition | 8-1 | | | 8-3 | Execute Vector Parameter File Instructions | 8-4 | | | 8-4 | Vector Load and Execute (VECTL) | 8-4 | | | 8-5 | Vector Execute (VECT) | 8-5 | | | 8-6 | The Vector Parameter File | 8-6 | | | 8-7 | Vector Operation Specification | 8-6 | | | 8-8 | Arithmetic and Logical Comparison Condition Specification | 8-6 | | | 8-9 | Vector Length (Self Loop Count) Specification | 8-8 | | | 8-10 | Single-Valued Vector and Word Size Specification | 8-8 | | | 8-13 | Vector Address Development | 8-14 | | | 8-15 | Halfword Index Start Specification | 8-15 | | | 8-16 | Self Loop Increment Direction | 8-16 | | Section | | | Page | |---------|------|--------------------------------------------------|---------------| | • | 8-17 | Inner Loop Specification | 8-18 | | | 8-20 | Outer Loop Specification | 8-19 | | | 8-23 | Program Interrupts | 8-19 | | | 8-24 | Vector Hazard | 8-20 | | | 8-25 | Vector Arithmetic Instructions | 8-20 | | | 8-26 | Vector Add Instructions | 8-2] | | | 8-27 | Vector Add Magnitude Instructions | 8-22 | | | 8-28 | Vector Subtract Instructions | 8-23 | | | 8-29 | Vector Subtract Magnitude Instructions | 8-24 | | | 8-30 | Vector Multiply Instructions | 8-25 | | | 8-31 | Vector Dot Product Instructions | 8-26 | | | 8-32 | Vector Divide Instructions | 8-28 | | | 8-33 | Vector Logical Instructions | 8-30 | | | 8-34 | Vector Shift Instructions | 8-31 | | | 8-35 | Vector Merge Instructions | 8-33 | | | 8-36 | Vector Order Instructions | 8-34 | | | 8-37 | Vector Compare Instructions | 8 <b>-</b> 36 | | | 8-38 | Vector Compare Arithmetic Instructions | 8-38 | | | 8-39 | Vector Compare Logical Instructions | 8-38 | | | 8-40 | Vector Peak Picking Instructions | 8-39 | | | 8-41 | Vector Search Instructions | 8-40 | | | 8-42 | Vector Search for Largest Element Instructions | 8-41 | | | 8-43 | Vector Search for Largest Magnitude Instructions | 8-41 | | | 8-44 | Vector Search for Smallest Element Instructions | 8-42 | | Section | | I | Page | |---------|------|-------------------------------------------------------------|-------------| | | 8-45 | Vector Search for Smallest Magnitude Instructions | 8-42 | | | 8-46 | Vector Conversion Instructions | 8-43 | | | 8-47 | Convert Floating Point Elements to Fixed Point Elements | 8-43 | | | 8-48 | Convert Fixed Point Elements to Floating Point Elements | 8-44 | | | 8-49 | Vector Normalize Instructions | 8-45 | | | | APPENDICES | | | Append | ix | | | | A | | SCALAR INSTRUCTIONS BY LOGICAL GROUPING | <b>A-</b> 1 | | В | | SCALAR INSTRUCTIONS IN ALPHABETICAL ORDER BY ASSEMBLER CODE | B-1 | | С | | SCALAR INSTRUCTIONS IN NUMERIC ORDER BY MACHINE CODE | C-1 | | D | | VECTOR INSTRUCTIONS BY LOGICAL GROUPING | D-1 | | E | | VECTOR INSTRUCTIONS IN ALPHABETICAL ORDER BY ASSEMBLER CODE | E-1 | | F | | VECTOR INSTRUCTIONS IN NUMERIC ORDER BY MACHINE CODE | F-1 | | G | | SCALAR INSTRUCTION TIME REQUIREMENTS | G-1 | | | | G-1 Scalar Instruction Timing Groups | G-1 | | Н | | VECTOR INSTRUCTION TIME REQUIREMENTS | H- 1 | | | | H-1 Time Requirements for Complete Vector Operation | H-1 | #### LIST OF ILLUSTRATIONS | Figure | $\operatorname{Title}$ | Page | |--------|--------------------------------------------------------|--------------| | 1-1 | Coding Form | 1-4 | | 5-1 | Sample Source Program Listing | 5-2 | | 5-2 | Cross-Reference Listing Example | 5 <b>-</b> 6 | | 6-1 | Assembler Statement Translations into Machine Code | 6-2 | | 6-2 | Register File Specifications | 6-9 | | 6-3 | Development of Singleword Effective Addresses | 6-17 | | 6-4 | Development of Halfword Effective Addresses | 6-20 | | 6-5 | Development of Doubleword Effective Addresses | 6-23 | | 6-6 | Indirect Address Cell Format | 6-28 | | 6-7 | Development of Singleword Effective Immediate Operands | 6-33 | | 6-8 | Development of Halfword Effective Immediate Operands | 6-34 | | 6-9 | Development of Singleword Logical Immediate Operands | 6-36 | | 6-10 | Program Counter Relative Branch Address Development | 6-40 | | 6-11 | Development of Base Relative Branch Addresses | 6-42 | | 6-12 | Algebraic Data Formats | 6-43 | | 8-1 | The Vector Parameter File | 8-3 | | 8-2 | Flow of Execution of a Vector Parameter File | 8-7 | | 8-3 | Flow of Execution with B Single-valved | 8-10 | | 8-4 | Flow of Execution with B Single-valved | 8-13 | #### LIST OF TABLES | Table | Title | Page | |-------|------------------------------------------------------------------------|------| | 2-1 | Printable Characters | 2-2 | | 2-2 | Special Characters | 2-2 | | 2-3 | Operator Hierarchies and Descriptions | 2-8 | | 2-4 | Use of Operators | 2-9 | | 2-5 | Results of Operations on Absolute and Relocatable Items in Expressions | 2-19 | | 5-1. | Assembler Generated Messages | 5-4 | | 5-2 | Procedure Processing Message Symbols | 5-5 | | 6-1 | General Forms and Variations of the Operand Lists | 6-4 | | 6-2 | Register Addressing Symbols | 6-10 | | 6-3 | Development of Singleword Addresses (Direct) | 6-18 | | 6-4 | Development of Branch Addresses (Direct) | 6-41 | | 6-5 | Value Ranges of Fixed Point Data | 6-44 | | 6-6 | Specifications for Arithmetic Exception Mask Data Constants | 6-54 | | 8-1 | Specifications of the SV Field | 8-9 | | 8-2 | Specifications of the HS Field Valves | 8-17 | | 8-3 | Specifications of the VI Field Valves | 8-17 | | 8-4 | Specifications of the VI, HS, and ALCT Fields | 8-37 | | 8-5 | Specifications of the ALCT Valves | 8-37 | | H-1 | Vector Execution Rates in Clocks/Element | H-1 | ## SECTION I GENERAL DESCRIPTION #### 1-1. THE CENTRAL PROCESSOR The Central Processor is that unit of the ASC dedicated to processing the user's raw data. It is particularly oriented toward the processing of numerical data that is typical of scientific data processing. #### 1-2. CENTRAL PROCESSOR-PERIPHERAL PROCESSOR RELATIONSHIP The Central Processor operates under control of the Peripheral Processor in which the operating system resides. The resources of the Central Processor are time-shared among users through this system which can cause a current program's status to be saved, the program to be removed from the Central Processor, and another program to be given control of the Central Processor. All communication, either to or from the Central Processor, takes place through the Peripheral Processor. #### 1-3. CENTRAL PROCESSOR RESOURCES Once a program is given control of the Central Processor, both program and data are streamed directly from central memory to the Central Processor and results streamed back. Streaming is accomplished by double buffering of both program and data. #### 1-4. Pipeline Instruction Processing The instructions fetched from memory are decoded in a pipeline mode of four levels. This method permits four instructions to be in the process of decoding at any given time, and, unless a branch instruction requires the discard of some of the instructions, each instruction is ready for execution in the arithmetic unit as soon as its resources are available. #### 1-5. Vector Operations The Central Processor performs operations on ordered sets of data without requiring additional instruction decoding. Once a vector operation has been initiated, the data upon which it operates is streamed directly to the arithmetic unit from central memory, and the results streamed back to central memory. #### 1-6. <u>Instruction Set</u> The Central Processor has 177 scalar instructions and 70 vector instructions that provide a large range of programming ploys. #### 1-7. Data Formats The Central Processor performs operations on fixed point, floating point, or binary logical data. Fixed point data may be either 32-bit singlewords or 16-bit halfwords, and in either case the values are represented with negative numbers in two's complement notation. Floating point data may be either 32-bit singlewords or 64-bit doublewords. In either case, the biased hexadecimal exponent method of representation is used. #### 1-8. THE ASSEMBLER The assembler as implemented for the Central Processor provides for symbolic coding of programs to be executed in the Central Processor. There are directives which are commands to the assembler itself. These directives are used to inform the assembler of conditions to be expected at assembly time, of conditions to be expected at object program execution time, and of the nature of the symbols used by the programmer. The assembler mnemonics for actual machine codes are the names of procedures built into the assembler. These procedures translate the mnemonics and the operands associated with them into object code that the machine can execute. There are also procedures built into the assembler which translate data that is in a form more convenient to the programmer into the object data forms usable by the machine. #### 1-9. CODING MEDIA A source program is a sequence of source statements that are punched into cards and entered into the computer by a card reader. #### 1-10. PUNCHED CARD The card format is a standard 80-column punched card. #### 1-11. CODING FORM Assembler source statements may be written on the standard coding form, shown in Figure 1-1. One line of code on the form is punched into one card; vertical columns on the form correspond to card columns. Space is provided for program identification and for instructions to keypunch operators. The body of the coding form consists of the statement field, columns 1 through 72, and the identification sequence field, columns 73 through 80. PROGRAMMER'S GUIDE TO THE CENTRAL PROCESSOR Figure 1-1. Coding Form ## SECTION II LANGUAGE ELEMENTS ## 2-1. CHARACTER SET FOR THE ASC The ASC Assembler recognizes the EBCDIC character set as standard notation. That is, characters are interpreted as punched on the IBM 029 keypunch. References in this manual are made to alphabetic characters (A through Z), numeric characters (0 through 9), and special characters (all the rest). All characters except the double quotation mark (") and the semicolon (;) may be used in character strings, and these also may be used freely in the remark field and in comments. The period (or decimal point), dollar sign (\$), and question mark (?) may be used in symbols along with alphabetic and numeric characters. Most of the special characters have unique meanings to the assembler. The double quotation mark (") inside a character string will terminate the string. The semicolon (;) when used inside character strings will terminate the card image, and the string will be continued on the next line beginning with the first non-blank character. #### 2-2. PRINTABLE CHARACTERS Table 2-1 contains a list of the non-alphanumeric printable characters and their names without regard to their special meanings to the assembler. #### 2-3. SPECIAL CHARACTERS Table 2-2 lists the special characters which have unique meaning to the ASC Assembler. #### 2-4. ITEMS Any item consists of a combination of one or more characters. An item may be a symbol, decimal integer, character string, hexadecimal integer, location counter, floating point item, fixed point item, literal, or intrinsic function. Table 2-1. Printable Characters | CHAR-<br>ACTER | NAME | CARD<br>CODE | CHAR-<br>ACTER | NAME | CARD<br>CODE | |----------------|----------------------|--------------|----------------|--------------------------|--------------| | | blank | blank | - | hyphen, or<br>minus sign | 11 | | ¢ | cent sign | 12-8-2 | / | slash (virgule) | 0-1 | | • | period | 12-8-3 | , | comma | 0-8-3 | | < | less than | 12-8-4 | % | percent sign | 0-8-4 | | ( | left<br>parenthesis | 12-8-5 | - | horizontal<br>bar | 0-8-5 | | + | plus sign | 12-8-6 | > | greater than | 0-8-6 | | | vertical bar | 12-8-7 | ? | question mark | 0-8-7 | | & | ampersand | 12 | <b>†</b> | vertical arrow | 8-1 | | ! | exclamation | 11-8-2 | : | colon | 8-2 | | | point | | # | number | 8-3 | | \$ | dollar sign | 11-8-3 | @ | at | 8-4 | | * | asterisk | 11-8-4 | t | apostrophe | 8-5 | | ) | right<br>parenthesis | 11-8-5 | = | equals | 8-6 | | ; | semicolon | 11-8-6 | 11 | quotation<br>marks | 8-7 | | | not sign | 11-8-7 | | 11101110 | | Table 2-2. Special Characters | CHARACTER | MEANING | CHARACTER | MEANING | |-----------|-------------------------|-----------|-------------------------| | # . | hexadecimal | ) | right parenthesis | | @ | indirect addressing | ¢ | augment indicator | | , | separator | > | greater than | | \$ | location counter | ; | continuation | | * | multiply and comments | | not | | • | period or decimal point | 11 | EBCDIC string indicator | | < | less than | = | equals or literal | | - | subtract | | indicator | | / | divide | ( | left parenthesis | | + | add | blank | separator or space | 2-5. SYMBOL A symbol is represented as a string of from one to eight EBCDIC characters, the first of which must be alphabetic. The remaining characters may be alphabetic, numeric, . , \$ , # , or any other special characters not used by the Assembler for unique purposes. (See Table 2-2 for characters having unique meaning to the Assembler.) VALUE: The value of a symbol is a name assigned to another item or other value. Examples: AABBCCDD Q. J\$P? 2-6. CHARACTER STRING A character string is any string of characters surrounded by double quotation marks (not to be confused with two single quotation marks). Semicolons (;) or double quotation marks ('') cannot be parts of a character string because they operate on the string. Character strings which are assigned to symbols as values cannot exceed 8 characters in length. Other character strings are restricted to 256 characters. <u>VALUE</u>: The value of a character string is the EBCDIC representation of the characters found between the quotation marks. Each character string is converted into an even multiple of 4 characters (32 bits). Strings which do not contain a multiple of 4 characters are filled to the right with blanks. Example: ''AB\*C'' 2-7. DECIMAL INTEGER A decimal integer is a string of unsigned decimal digits (0 through 9). <u>VALUE</u>: The value of a decimal integer is the 32-bit (binary representation) base 10 value of the string of digits. Examples: 19 5440 #### 2-8. HEXADECIMAL INTEGER A hexadecimal integer is a string of unsigned hexadecimal digits (0 through F) preceded by a #. The maximum number of characters after the # is 16. <u>VALUE</u>: The value of a hexadecimal integer is the 32 or 64-bit (binary representation) base 16 value of the string of digits. Example: #3B8FE5 #### 2-9. FLOATING POINT ITEM A floating point item is a string of decimal digits with a decimal point and optionally followed by a decimal exponent. The exponent is written as the letter E or the letter D followed by an integer constant. The item may be positive, zero, or negative. If either the initial string of decimal digits or the integral exponent are unsigned, the assembler assumes the respective part to be positive. If a decimal exponent is given, the decimal point is not required in the initial string of digits. The item may assume one of three forms: - A string of decimal digits with a decimal point, and without an exponent. This form is assumed by the assembler, to be single precision representation. - 2. A string of decimal digits, optionally with a decimal point, followed by the letter E and an integral decimal exponent. The E specifies single precision representation. - 3. A string of decimal digits, optionally with a decimal point, followed by the letter D and an integral decimal exponent. The D specifies double precision representation. For both single and double precision representation, the value of the exponent, n, has the range: $-64 \le n \le +63$ . The range of values M, a floating point item, may have is: (1) in single precision (32-bit representation), $16^{-65} \le M \le (1 - 16^{-6}) \times 16^{63}$ and true zero; and (2) in double precision (64-bit representation), $16^{-65} \le M \le (1 - 16^{-14}) \times 16^{63}$ and true zero; or, approximately, $5.4 \times 10^{-79} \le M \le 7.2 \times 10^{75}$ . The number of bits used in the representation of the fractional part of a floating point item does not significantly affect its range of values, but affects the precision of the values that may be represented. If the maximum exponent value is exceeded, a syntax error is returned; but, if the significance is exceeded, truncation of the least significant bits occurs and no error message is returned. <u>VALUE</u>: The value of a floating point item is the 32 or 64-bit binary representation of the string of digits with 8 bits reserved for the exponent and with the remaining 24 or 56 bits left for the fraction. The exponent is represented in excess 64 notation. The fraction is normalized in its area. Examples: 5. 5.321E+6 6D-26 5.3 -5.2E6 2.718 #### 2-10. FIXED POINT DECIMAL ITEM A fixed point decimal item is a string of decimal digits, which may have a decimal point, followed by (1) a B or a BB, and by (2) a binary scale factor. The item may be positive, zero, or negative. If either the initial string of decimal digits or the binary scale factor is unsigned, the assembler assumes the respective part to be positive. A positive binary scale factor shifts the binary representation of the quantity to the left by the specified number of binary units, and a negative binary scale factor shifts the binary representation of the quantity to the right by the specified number of binary units. Any part of the decimal numeral which would result in a binary fraction, when converted to binary and scaled, will be truncated. A single B specifies single precision, and a double B (i.e., BB) specifies double precision. The range of values of a fixed point item, F, is restricted to: -2, 147, 483, $648 \le F \le +2$ , 147, 483, 647 (i.e., $-2^{31} \le F \le 2^{31}$ - 1). VALUE: The value of a fixed point decimal item is the 32 or 64-bit binary representation of the string of digits with the representation determined by converting integer and fraction portions of the string separately and placing the result in either 32 or 64 bits as determined by the precision designator, B or BB, respectively. Examples: 3.21B+5 3.21BB+5 6B2 6BB2 #### 2-11. LOCATION COUNTER The coding symbol for the value of the location counter is \$. . VALUE: The value of \$ is the 32-bit current value at assembly time of the location counter. Example: \$+6 #### 2-12. LITERAL A literal is a constant which is the relative location of the start of one or more words of data. A literal is expressed in the form of an equals sign followed by the data to be contained in the relative location (see Topic 2-19). VALUE: The value of a literal is the location of a constant. Examples: =A =6 =A+6 ## 2-13. INTRINSIC FUNCTION An intrinsic function is an item used to produce substitution of another item, expression, or list in its place. See Topic 2-21. VALUE: The value of an intrinsic function is the identity of the particular parameter operated on by the function, or is the value assigned to the condition of the parameter operated on by the function. Example: T(RHO) #### 2-14. OPERATORS Items may be combined using the special character operators defined in Table 2-3. The table also gives hierarchy numbers for determining the sequence in which the value of an expression is computed. Operations with higher hierarchies are performed before operations having lower hierarchies. Operations with the same hierarchy are performed from left to right. #### 2-15. OPERATOR TYPES Each operator falls under two type classifications: every operator is either a unary operator or a binary operator, and every operator is one of the following: an arithmetic operator, a relational operator, or a logical operator. See Tables 2-3 and 2-4 for the operator symbols and their uses. UNARY OPERATION: A unary operation is one that involves only one operand. BINARY OPERATION: A binary operation is one that involves two operands. ARITHMETIC OPERATION: An arithmetic operation is one that yields algebraic quantities. RELATIONAL OPERATION: A relational operation is one that yields a "TRUE" or "FALSE" quantity; i.e., 1 or 0, respectively. LOGICAL OPERATION: A logical operation is one that yields a Boolean quantity. #### 2-16. EXPRESSIONS An expression is an item, or it is a series of items, connected by operators. The sequence of operations performed in evaluating an expression is determined by the hierarchy of the operators in the expression. The hierarchy of operators is shown in Table 2-3. Operations with higher hierarchy numbers are performed first; operations with the same hierarchy are performed from left to right. Table 2-3. Operator Hierarchies and Descriptions | HIER-<br>ARCHY | SYMBOL | TYPE | DESCRIPTION | |----------------|--------|-------------------|-----------------------------------| | 7 | + | Unary Arithmetic | Plus | | 7 | - | Unary Arithmetic | Minus (two's complement) | | 7 | - | Unary Arithmetic | Not (one's complement) | | 6 | // | Binary Logical | Logical Binary Operator | | 5 | * | Binary Arithmetic | Arithmetic Product | | 5 | / | Binary Arithmetic | Arithmetic Quotient | | 4 | + | Binary Arithmetic | Arithmetic Sum | | 4 | - | Binary Arithmetic | Arithmetic Difference | | 3 | < | Binary Relational | Arithmetic Less Than | | 3 | 一< | Binary Relational | Not Less Than | | 3 | = | Binary Relational | Arithmetic Equals | | 3 | 一 = | Binary Relational | Not Equals | | 3 | <= | Binary Relational | Less Than or Equal | | 3 | > | Binary Relational | Arithmetic Greater Than | | 3 | ¬> | Binary Relational | Not Greater Than | | 3 | >= | Binary Relational | Greater Than or Equal | | 2 | ** | Binary Logical | Logical Product (AND) | | 1 | ++ . | Binary Logical | Logical Sum (OR) | | 1 . | | Binary Logical | Logical Difference (Exclusive OR) | | 1 | == | Binary Logical | Logical Equivalence | The length of an expression is limited by the number of continuation lines over which the statement may extend. The value of an arithmetic expression, E, is restricted to the range: -2, 147, 483, 648 $\leq$ E $\leq$ +2, 147, 483, 647 (-2<sup>31</sup> $\leq$ E $\leq$ 2<sup>31</sup> - 1). The value of an expression, E, containing an external symbol or symbols is restricted to the range: -8, 388, 608 $\leq$ E $\leq$ +8, 388, 617, (-2<sup>23</sup> $\leq$ E $\leq$ 2<sup>3</sup> - 1). Floating point numbers are not valid in expressions which contain more than one item. That is, floating point arithmetic will not be performed at assembly Table 2-4. Use of Operators | SYMBOL | GENERAL<br>FORM | WHERE | RESULTS | |---------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------| | + | +a | a is an algebraic expression | a | | - | -a | a is an algebraic expression | two's complement of a | | 7 | —7 a | a is an algebraic or logical expression | one's complement of a | | // | a//i | a is a logical expression; i is an integer expression | shift a left i binary digits if i<br>is positive; shift a right i bi-<br>nary digits if i is negative | | 7/4 | a*b | a and b are algebraic expressions | the product of a and b | | / | a/b | the numerator a is an algebraic expression; the denominator b is an algebraic expression | the quotient of a divided by b | | + | a+b | a and b are algebraic expressions | the sum of a and b | | - | a-b | a and b are algebraic expressions | the difference of a and b | | < | a <b< td=""><td>a and b are algebraic expressions</td><td>true if a is less than b</td></b<> | a and b are algebraic expressions | true if a is less than b | | ¬< | a¬ <b< td=""><td>a and b are algebraic expressions</td><td>true if a is not less than b</td></b<> | a and b are algebraic expressions | true if a is not less than b | | = | a=b | a and b are algebraic expressions | true if a is equal to b | | ¬ ₌ | a 🦳 =b | a and b are algebraic expressions | true if a is not equal to b | | <= | <b>a</b> <=b | a and b are algebraic expressions | true if a is less than or equal to b | | > | a>b | a and b are algebraic expressions | true if a is greater than b | | 7 > | a¬>b | a and b are algebraic<br>expressions | true if a is not greater than b | | >= | a>=b | a and b are algebraic<br>expressions | true if a is greater than or equal to b | | স্ব স্থ | a**b | a and b are logical expres-<br>sions | logical product of a and b (AND) | | ++ | a++b | a and b are logical expres-<br>sions | logical sum of a and b (OR) | | | ab | a and b are logical expressions | logical difference of a and b (exclusive OR) | | == | a==b | a and b are logical expres-<br>sions | logical equivalence of a and b | time. The assembler will denote as an error any attempts to do arithmetic operations on double length floating point numbers in expressions, or on character strings longer than four characters. Certain logical operations (\*\*, ++, --, and ==) and all relational operations may be performed on values that require more than four characters (32 bits) to represent them. ## 2-17. SUBEXPRESSIONS An expression may contain subexpressions, and subexpressions may contain other subexpressions. A subexpression is an expression enclosed in parentheses, and it may appear wherever an item is valid. Subexpressions are evaluated before other items in an expression, and the innermost subexpression is evaluated first. The value of an item or expression is right-justified in its generated result field, and unspecified leading bit positions will contain zeros; character strings are left-justified with blanks filled to the right in the last word for unjustified characters. <u>Note</u>: Character strings used in immediate operands (see Topic 6-32) are not left-justified in a fullword, but justified in the 16-bit N field. Thus, a character string immediate operand has a maximum of two characteriers, and the rightmost byte is blank filled if there is only one character in the string. The value of the part of the expression or subexpression containing and affected by a relational operator (e.g., >, <, or =) is equated to one if the relation is true and equated to zero if the relation is false. For example, if E is an expression of the form: X > Y then, E is evaluated as a one (1) if the relation is true, or zero (0) if the relation is false. Also, if the assigned section of expression X is not the same as the assigned section of expression Y, then the expression E cannot be completed and is evaluated as false (zero). #### Examples: 1. The following expression is evaluated as zero if R is a relocatable item: R - 4 > 37 2. The following expression is evaluated as zero if the subexpression (X>Y) is false and equal to A if the subexpression (X>Y) is true: A\*(X>Y) ## 2-18. ASSUMED PARENTHESES The following examples denote how parentheses are assumed, the results being governed by the hierarchies in Table 2-3. Expression: -A//-I\*2 Method: 1. Two's complement A 2. Two's complement I 3. Shift two's complement of A by value of two's complement of I 4. Multiply result by two Assumes: ((-A)//(-I))\*2 Expression: -A//(-I\*2) Method: 1. Two's complement I 2. Multiply result of two's complement of I by two 3. Two's complement A 4. Shift result of two's complement of A by result obtained in step 2 Assumes: (-A)//((-I)\*2) Expression: -A//-(I\*2) Method: 1. Multiply I by two 2. Two's complement A 3. Two's complement the result of I multiplied by two 4. Shift the result of the two's complement of A by the result obtained in step 3. Assumes: (-A)//(-(I\*2)) #### 2-19. LITERALS A literal is a constant. The constant is the relative location of the start of one or more words of data. The relative location is reserved by the assembler, and the contents of the location are set to the value of the expression which specifies the data. An expression which is to be a literal is identified by being preceded by an equal sign (=). The assembler reserves sufficient contiguous words to contain the value of the expression. The number of words reserved for expressions which do not contain forward references is determined by the number of bit positions required to specify the value. Expressions that contain forward references are assumed to require no more than one word to specify their respective values. Literals which have the same value are stored only once, whenever possible. Reaching the end of an assembly or using the LITORG directive (see Topic 4-13) causes all literals identified, since the last LITORG directive or since the start of the assembly, to be assigned locations and to be output. Literals appearing after a LITORG directive that are duplicates of values occurring before that LITORG directive will be assigned at least two separate locations. Further duplication will occur if the expression composing the literal is not a single item and all of the quantities composing the expression are not defined prior to their appearance in the expression. The literal table is adjusted so that multiple-word literals are output first. <u>Limitations and Restrictions</u>: The initial literal location assignment occurring after a LITORG directive or at the end of an assembly will always start at an even-word boundary (a location whose value is a multiple of two). Multiple word literal values will be assigned locations beginning on even-word boundaries. Words that are skipped to achieve even-word alignment will not be cleared. The value of an expression that identifies a literal is restricted to 28 characters in length. Subexpressions and lists (see Topic 2-20) will not be made into literals. <u>Creation of Address Constants</u>: Address constants will be placed in the literal table when symbols with relocatable values are used as literals. See Topics 2-27 and 2-28. #### Examples: | LITERAL | VALUE | |---------------|---------------------------------------------------------------| | =ETA | Address of a word that contains the address of symbol ETA, | | | if ETA is relocatable; address of a word that contains the | | | value of ETA, if ETA is absolute | | =50 | Address of a word that contains the absolute value 50 | | =ETA+50 | Address of a word that contains the value of the expression | | | ETA+50. If this literal is used before ETA is defined, more | | | than one constant with this value will be allocated. | | =TAU+50=RHO | Address of a constant that contains zero or one (the value of | | | the expression TAU+50=RHO) | | NU+=PI | Error | | =(MU, NU, XI) | Error | #### 2-20. LISTS A list is a set of items, expressions, or sublists separated by commas. In the most trivial case a list may be a single item. A sublist is a list enclosed in parentheses. Lists are used in the operand field of a statement. If a list of parameters is enclosed by a single set of parentheses, these parameters are considered to be second level parameters. In the list A, (B, C), D B and C are second level parameters, whereas A and D are first level. Parameter 2 (at first level) is a sublist. Restrictions: The maximum number of expressions in a list at one level is 15. The maximum number of levels of parentheses in a list is five. The value of a parameter which is nonexistent or uncoded is always zero; e.g., for a general list: expa,(expd, expb), expx that is coded: Al, (A4,) the expb and expx would both be evaluated as zero. # 2-21. INTRINSIC FUNCTIONS An intrinsic function is an operation performed on or applied to an expression or a list. Some intrinsic functions (global intrinsic functions) may be used outside or inside procedures, whereas others (local intrinsic functions) may be used only in procedures. (This manual does not include procedure programming.) Intrinsic function usages may be nested. #### 2-22. GLOBAL ATTRIBUTE FUNCTIONS A global intrinsic function is one that may be used either outside or inside procedures. An attribute of a parameter is the characteristic, or the value of the characteristic of the parameter; e.g., the fact that the parameter is a literal is a characteristic, or the value of the base of the parameter is the value of a characteristic. An attribute function either determines the value of the characteristic of a specified parameter or determines on a true or false basis whether a specified parameter has a certain characteristic. Some attribute functions are global and others are local. All global functions are also attribute functions. A global attribute function is one that may be used either inside or outside procedure definitions and that determines the value of some characteristic of the specified parameter. #### 2-23. Base Function - B(exp) The base intrinsic function, B(exp), is replaced by the number of the base which yields the smallest non-negative result (displacement) when the value of that base is subtracted from the value of the expression, exp. If two or more bases yield the same least result, the highest numbered base is selected to replace B(exp). See Topic 6-15. <u>Limits and Restrictions:</u> If all bases yield a displacement greater than 4095, an error message is generated by the assembler. The base function is replaced by: | Expression (exp) | B(exp) | |--------------------|--------------------------------------| | external reference | error message generated by assembler | | absolute | zero | | relocatable | absolute | Example: RSRU ST B(TOTAL), BSV, X2 # 2-24. Displacement Function-D(exp) The displacement intrinsic function, D(exp), is replaced by the displacement value of the expression, exp. The displacement value of exp is the smallest non-negative difference between the value of the expression and the values of the bases (if any) in the table of applicable bases. See Topic 6-15. If all bases have a value of zero, the displacement of the expression is the displacement of the expression relative to the beginning of the control section. <u>Limits and Restrictions</u>: If a displacement is greater than 4095, an error message is generated by the assembler. The displacement function is replaced by: | Expression (exp) | D(exp) | |--------------------|--------------------------------------| | external reference | error message generated by assembler | | absolute | zero | | relocatable | absolute | Example: INX L X2, D(RHO) # 2-25. Section Function-T(exp) The section intrinsic function is replaced by the section number of symbol exp, if a section number is valid. See Topic 2-27. <u>Limits and Restrictions</u>: If exp is an external reference, T(exp) is greater than 256 and the value of T(exp) is the sum of 256 plus the external symbol number. See Topic 4-5. If (exp) is absolute, T(exp) is replaced by zero. T(exp) is replaced by an absolute value. If (exp) is in a dummy section (see Topic 4-17), T(exp) is replaced by the negative of the dummy section number. When using an assembler directive that produces multiple code (e.g., the DO directive), the argument(exp) of the intrinsic function cannot be a forward reference. #### 2-26. LOCATION COUNTER The location counter symbol, \$, when it is processed during evaluation of expressions, causes the current relative location in the assembly of the instruction procedure call to be inserted in place of the symbol. In this sense, it acts somewhat like an intrinsic function. #### 2-27. PROGRAM SECTIONS An assembly may be divided into logical subdivisions called sections. Each section has a protection key for use in regrouping the various sections of an assembly at object time. A section is defined by the SEC directive; see Topic 4-15. Sections provide the basis for addressing memory locations during an assembly. Memory locations are identified in the assembler as relative locations from the start of the section. Section numbers are assigned to each section by the assembler. Section numbers 1 through 63 may be assigned in one assembly; i.e., any given assembly may have a maximum of 63 sections. ### 2-28. RELOCATION Since the assembler does not actually place object statements in fixed Central Memory locations, the relative locations assigned by the assembler must be relocatable to available memory locations. Thus the relative location of a statement within a section is a relocatable value, and the value of a symbol, or an expression that refers to a relative location, is a section identification and the relative location within that section. #### 2-29. CONSTANTS Two types of constants are identifiable during an assembly: (1) the actual value of a numeral, and (2) the relative location of a symbol within its section. The relative location of a symbol in its section is referred to as an <u>address constant</u>. # 2-30. Address Constants There are two classifications of address constants: (1) an address constant that is an internally relocatable value; i.e., a value whose section and relative location within its section is defined in the current assembly; and (2) an address constant that is an externally relocatable value; i.e., a value whose section and whose relative location within that section is defined in another assembly. # 2-31. Numeral Constants The value of a numeral is not relocatable. An absolute value cannot be defined as belonging to a section or to a relative location within a section. An absolute value may result from the use of relocatable items in an expression which produces loss of identity of the items within their sections (see Table 2-5). # 2-32. LOCATION COUNTER The location counter is a relocatable variable whose value is the current section number and current relative location within that section. The value of the location counter is positioned at the statement being assembled. The character, \$, represents the value of the location counter symbolically. Use of \$ in the operand of various control directives (see Topic 4-12) permits the value of the location counter to be changed so that assembly control may be changed to different sections or to other positions within the same section. #### 2-33. RELOCATABILITY OF SYMBOLS The section to which a symbol belongs is determined by either of the following: (1) the symbol may be equated to a procedure reference statement, or, (2) it may be equated to the value in the location counter. Such symbols are relocatable since the statement's location will be relocated with the section itself. Symbols defined in other assemblies and identified by use of the EXTRN directive (see Topic 4-5) are relocatable. Symbols which are equated to absolute expressions or items are absolute. Symbols equated to the T(a) intrinsic function are absolute. # 2-34. RELOCATABILITY OF EXPRESSIONS Expressions, because they contain symbols, may be evaluated as absolute or relocatable. An expression that would be relocatable to more than one section because the symbols in the expression are defined in different sections is illegal; e.g., A+B where A and B are relocatable and belong to separate sections. Table 2-5 shows, for each type of operator, the relocatability of the result. The result may be relocatable, absolute, or illegal. If the result is relocatable, its section is the section of the relocatable item or items. # 2-35. Effect of Relational Operators The effect of relational operations (i.e., initiated by the operators: $<, \neg <, =, \neg =, <=, >, \neg >, >=$ ) is as follows: | A | В | A REL B | |-------|-------|--------------------------------------| | ABS | ABS | will compare, if same length | | ABS | RELOC | will not compare, evaluated as false | | RELOC | ABS | will not compare, evaluated as false | | RELOC | RELOC | will compare if in same section | Note: Since the result of a relational operation is always zero (false) or one (true), the result is always absolute. Table 2-5. Results of Operations on Absolute and Relocatable Items in Expressions | A | В | A+B | A-B | A*B | A/B | |-------|-------|---------|---------|---------|----------| | ABS | ABS | ABS | ABS | ABS | ABS(B#0) | | ABS | RELOC | RELOC | illegal | Notel | illegal | | RELOC | ABS | RELOC | RELOC | Note2 | Note3 | | RELOC | RELOC | illegal | Note4 | illegal | illegal | | A | В | A++B | AB | <b>A</b> **B | A==B | |-------|-------|---------|---------|--------------|---------| | ABS | ABS | ABS | ABS | ABS | ABS | | ABS | RELOC | illegal | illegal | illegal | illegal | | RELOC | ABS | illegal | illegal | illegal | illegal | | RELOC | RELOC | illegal | illegal | illegal | illegal | Note 1: Illegal unless A equals zero or one. If A is one, the result is relocatable; if A is zero the result is an absolute zero. Note 2: Illegal unless B equals zero or one. If B is one, the result is relocatable; if B is zero, the result is an absolute zero. Note 3: Illegal unless B equals one. If B equals one, the result is relocatable. Note 4: Illegal unless A and B are in the same section. If A and B are in the same section, the result is absolute. # SECTION III LANGUAGE STRUCTURE # 3-1. STATEMENT FORMAT A program consists of a sequence of coded lines, each line containing from I to 80 characters. However, only the first 72 characters of a line are processed by the assembler. A line may contain a statement or a comment. Statement columns 73 through 80 can be used for program identification or for sequencing. A statement generally consists of three coding fields: a label field, a command field, and an operand field. These three fields are of variable length and are terminated by one or more blanks; i.e., no embedded blanks are permitted in these fields. Any statement columns to the right of the operand field may be used as a remark field which contains text. GENERAL FORM: The general form of an assembler statement is: | LABEL | | COMMAND | OPERANDS | REMARKS | |----------|----|---------|-----------------------|---------| | [symbol] | 18 | symbol | [expl[,exp2[,,expn]]] | [text] | | TEST | - | SEC | 0 | | | START | | LF | #10, INIT, X1 | | #### 3-2. CONVENTIONS FOR DESCRIBING LANGUAGE STATEMENTS The following conventions are used to illustrate the language statements: - 1. Upper case letters and punctuation marks (except those explained in items 3 and 4 below) represent information that must be coded exactly as shown. - 2. Lower case letters and words are generic terms that represent information that must be supplied; i. e., a substitution must be made when coding a parameter or option so represented. - 3. Information within brackets [] is optional. It may be included or omitted entirely, depending upon program requirements. - 4. When several choices are enclosed in braces { }, one of the enclosed alternatives must be selected by the programmer. If one of the alternatives is underlined, the parameter may be omitted and the system assumes the underlined alternative. - 5. Mandatory blanks are represented by a slashed, lower-case letter "b" (b). This symbol is not used to represent permissible blanks. #### 3-3. CONTINUATION LINES A semicolon (;) appearing in the operand field is a line terminator which signals that the following line is to be treated as a continuation of the current one. That is, the semicolon is considered to be followed immediately by the first non-blank on the following line, and the information following a semicolon on the line on which the semicolon appeared is ignored. Restrictions: No more than two continuation lines are permitted for each statement. A semicolon (;) cannot be used to terminate an item; such usage will be treated as an error. Character strings and intrinsic functions are the only types of items that can be divided by a semicolon. Character strings can be divided anywhere within the string, but leading blanks on the continuation line are not treated as part of the character string. Intrinsic functions can be divided by a semicolon only after the open parenthesis. Examples: The following lines of code illustrate use of continuation lines: CMPREG L (A1\*(SUM1=SUM2))++(A2\*(SUM1>SUM2))++(A3\*(SUM1<SUM2)), (D(; SUM1), B2), X5 COMPUTE REGISTER TO LOAD MSSG DATA "THIS COMPUTATION EXTENDS INTO AN UN; DEFINED REGION." #### 3-4. LABEL FIELD A statement may be given a name by the programmer to permit references to be made to the statement from other points within the program. The use of a name is normally optional, but some directives do require a symbol in the label field. The label must start in column 1. If no label is used, column 1 must be blank. The symbol is normally equated to the current value of the Assembler's location counter. Examples: The following are valid labels: A\$QED **BCD345** AABBCCDD Y #### 3-5. Reserved Symbols The following symbols are reserved and may not be used as labels: - 1. Symbolic register names; viz., B0 through B15, A0 through A15, X0 through X7, and V0 through V7. - 2. The names of any of the directives; e.g., DATA, FORM, etc. - 3. The names of any of the built-in procedures for the machine instructions, i. e., the assembler mnemonics for the machine operations. WARNING: Because the Simulator's reserved symbol table contains both Peripheral Processor and Central Processor reserved symbols (such as register labels), use of a Peripheral Processor register symbol that would normally be legitimate in Central Processor programs will cause an error message to be issued if this symbol is encountered in a debugging action for the Central Processor. Therefore, it is advisable to avoid use of these symbols as labels. #### 3-6. COMMAND FIELD Each statement has a command. The command begins with the first non-blank following the label field and is terminated by one or more blanks. The command must be a symbol. The command field dictates the operation to be performed and may call an assembler directive or a previously defined or built-in procedure. Thus the command field contains a mnemonic which is the name of a directive or a label of a procedure. New operations may be introduced by defining new procedures. (The ASC Central Processor instruction set is represented by built-in procedures.) Any error occurring in the command field will result in an illegal instruction. The assembler will generate one word of zeros (absolute) of loader text and will process the operand field for general syntax errors only. Examples: DATA, SET, LR, and BLB are representative commands. #### 3-7. OPERAND FIELD Most commands require operands. If a line is to include operands, the operand field begins with the first non-blank following the command field. The operand field is composed of a list of elements. Elements are composed of one or more expressions (often referred to as parameters). The last element in the operand list is terminated by a blank; all other elements in lists are terminated by a comma. Sublists, which are elements in the form of lists enclosed in parentheses, may exist. Intrinsic functions may also be elements in an operand. Elements omitted from the right end of an operand list are assumed to have a value of zero, (0, 0, 0 may be written as 0). If the operand field is left vacant, the remark field must also be left vacant (blank). The number of blanks between fields is not limited. The assembler will check each expression in the operand field for valid syntax. If a syntax error is found, the assembler will print a diagnostic flag and supply zero in place of the expression found to be in error. The object code generated for the remainder of the statement depends upon the use of the expression; i.e., the command produced may or may not be correct. In some cases, a word of zeros is generated. #### 3-8. REMARK FIELD The optional remark field is allowed as a convenience for documentation and has no effect upon the nature of the assembled object code. A remark must be isolated from the end of the operand field by at least one blank. The remark field may not be continued to the next line. #### 3-9. COMMENT LINES A line (which is not a statement continuation line) whose first column contains an asterisk (\*) is treated as entirely commentary. No loader text is generated. The line will be listed in context. #### 3-10. BLANK LINES A line consisting of only spaces (blanks) in character positions 1 through 71 is treated as commentary. A blank line will be printed on the assembly listing as a result. # SECTION IV DIRECTIVES ### 4-1. INTRODUCTION Assembler directives supply special types of information to the assembler. A reference to any symbolic item in an expression on a directive line must have previously appeared as a label; e.g., it must be possible to immediately evaluate the expression(s) in the operand field of the directive. If the operand expression can not be evaluated, it will be assigned a value of zero, and an error message will be printed. Exceptions to this rule are the symbols in the operands of the EXTRN, the ENTRY, the DATA, and the USING directives, symbols which may be forward references. The SET directive has conditional exceptions. All forward references may be satisfied with values which do not exceed one word. The value of a forward reference may be relocatable or absolute, and, if n is the value, $-2^{31} \le n < 2^{31}$ . Note: In the general forms of the directive statements, items enclosed in brackets are optional. #### 4-2. DEFINITION DIRECTIVES #### 4-3. EQUATE DIRECTIVE (EQU) The EQU directive is used to assign a permanent value to its symbolic label. #### GENERAL FORM: | LABEL | | COMMAND | | OPERANDS | |--------|---|---------|---|----------| | symbol | R | EQU | R | exp | The symbolic label is defined to have the value of the expression, exp. The value of exp may be absolute or relocatable, positive or negative, and is expanded to an integral multiple of fullwords. Restrictions: An EQU statement must have a label. Symbols in the expression must be defined prior to their use in the EQU directive; i.e., the expression cannot be a forward reference. Symbols defined in the label of this directive cannot be redefined. <u>Limitations</u>: The maximum number of characters in a character string named by an EQU statement is 28. # Examples: | LABEL | K COMMAND | Ø OPERANDS | | |-------|-----------|-------------------|--| | ALPHA | EQU | \$ <del>+</del> 3 | | | BETA | EQU | ALPHA | | | NO | EQU | 0 | | #### 4-4. SET DIRECTIVE (SET) The SET directive is used to assign a temporary value to its symbolic label. #### GENERAL FORM: | LABEL | COMMAND | OPERANDS | |--------|---------|----------| | symbol | SET | g exp | The symbolic label is defined to have the value of the expression, exp. The value of the symbol can be changed by redefining it as the label of another SET directive. The value of exp which may be absolute or relocatable, positive or negative, is expanded to an integral multiple of fullwords, and the expression may contain a symbol that is a forward reference. Restrictions: A SET statement must have a label. If the value of the symbolic label is changed by being used as the label of another SET directive, no subsequent values can exceed the length of the first. <u>Limitations</u>: If exp contains a forward reference, n, the value of n is within the range: $-2^{31} \le n < 2^{31}$ -1. The maximum number of characters in a character string named by a SET statement is 28. ### Examples: | LABEL | COMMAND | OPERANDS | | |-------|---------|------------|--| | ALPHA | SET | 3 | | | YES | SET | BETA-ALPHA | | | BETA | SET | \$ | | # 4-5. EXTERNAL NAME DIRECTIVE (EXTRN) The EXTRN directive is used to identify every symbol that is used but not defined in the current assembly. #### GENERAL FORM: | LABEL | | COMMAND | l | OPERANDS | |-------|---|---------|---|--------------------| | blank | R | EXTRN | R | symbol[,[,symbol]] | Each name appearing in the operand field of the EXTRN directive will be output to the Link Editor, provided that reference to that name is within the current assembly. Any declared external names to which references are not made will not be output to the Link Editor. Reference to an external name requires the use of an address constant. <u>WARNING</u>: Any reference within the current assembly to an external name not declared by an EXTRN directive will be treated as being undefined and an error flag will appear on the assembly listing. Restrictions: An EXTRN statement cannot have a label. Limitations: A limit of 255 external symbols may be declared for a module. A limit of 15 external symbols may be listed in the operand field of one EXTRN statement. # Examples: | LABEL | K COMMAND | OPERANDS | | |-------|-----------|-----------|--| | | EXTRN | ALPHA | | | | EXTRN | SQRT, SIN | | # 4-6. ENTRY NAME DIRECTIVE (ENTRY) The ENTRY directive is used to establish linkages between programs that have been assembled separately but that are to be loaded and executed together. ### GENERAL FORM: | LABEL | | COMMAND | OPERANDS | |-------|---|---------|---------------------| | blank | R | ENTRY | symbol[,[, symbol]] | Each name appearing in the operand field of the ENTRY directive declares an entry point into the current assembly to which external programs may refer. Any name declared to be an entry point that is not defined within the assembly will cause an error message to be output in the assembly listing. Control section names can be used as entry points. Entry points are generated automatically for them. Restrictions: An ENTRY statement cannot have a label. Each name appearing in the operand field of the ENTRY directive must also appear as the label of a statement in the body of the assembly and must have a relocatable value defined in a control section. Limitations: A limit of 255 entry names may be declared for a module. A limit of 15 entry names may be listed in the operand field of one ENTRY statement. ### Examples: | LABEL | الا | COMMAND | אלן | OPERANDS | | |-------|-----|---------|-----|-----------|--| | | | ENTRY | | ALPHA | | | | | ENTRY | | SQRT, SIN | | #### 4-7. DATA DIRECTIVE (DATA) The DATA directive generates enough fullword data units to contain the information in the operand field. #### GENERAL FORM: | LABEL | COMMAND | OPERANDS | |----------|---------|-----------------| | [symbol] | DATA | b exp[,[,exp]] | The label symbol is the location of the first expression in the operand list. The symbol is given the current value of the location counter. Each expression is expanded to a multiple of fullword units. An address constant is generated for any expression that is not absolute. If a generated address constant refers to an external symbol, the output module indicates that the value of the external is to be added, at link edit (or simulation) time, to the constant displacement derived from the expression in which the external symbol is used; e.g., for the statement: DATA EXTERN1 + 10, EXTRN2+ $$(T < S)$$ in which EXTRN1 and EXTRN2 are the first and second external symbols defined in the assembly, ten will be added to the location of EXTRN1 at link edit time, and either zero or one will be added to the location of EXTRN2, depending upon whether (T < S) is false or true, respectively. <u>Limitations</u>: A limit of 15 expressions may be listed in the operand field of one DATA statement. A symbol in the operand field of the data statement that is defined by an EQU or SET statement is assumed to have a singleword value. If a symbol is set (EQU or SET) to a value (e.g., a character string) greater than one word in length, only the rightmost word of the value will be generated as data. #### Examples: | LABEL | COMMAND | OPERANDS | |--------|---------|-----------| | | DATA | BETA | | ALPHA | DATA | 0 | | FLTPNT | DATA | 1.0,2.0 | | | DATA | "LITERAL" | | | DATA | 1.0D0 | # 4-8. FORMAT DIRECTIVE (FORM) The FORM directive is used to specify arbitrary data formats. #### GENERAL FORM: | LABEL | <br> <br> | COMMAND | | OPERANDS | |--------|-------------|---------|---|-------------------------------| | symbol | R | FORM | R | expl, exp2[, exp3, ···, expn] | The values of the absolute expressions in the operand field of the FORM directive give the bit lengths of successive fields in the resultant data word. Reference may be made to a format definition by using its label as the command in any succeeding statement with an operand field composed of values to be placed in the object word fields defined in the FORM statement. Restrictions: A FORM statement must have a label. The sum of the values of the expressions must be a multiple of fullword (32-bit) units. <u>Limitations</u>: A limit of 15 fields may be defined in the operand list of a FORM statement. Restrictions: Access to indirect address constants are execute requests; therefore, indirect address constants must be in control sections with execute permitted. Examples: | LABEL | COMMAND | OPERANDS | · | |--------|---------|----------------|---| | FSTART | FORM | 8, 4, 4, 4, 12 | | | | FSTART | #C4,2,8,#E,31 | | produces the hexadecimal code: # 4-9. USING DIRECTIVE (USING) The USING directive indicates to the assembler that the specified base register contains the value of the relocatable expression. #### GENERAL FORM: | LABEL | | COMMAND | | OPERANDS | |-------|---|---------|---|---------------| | blank | R | USING | R | exp, register | The assembler will select a base and compute a displacement from the specified base value for each relocatable expression that follows the USING statement. The base selected will be that base (for the section) which produces the smallest displacement. <u>WARNING</u>: Failure to specify a base register or registers for each section of an assembly will result in addressability errors. Restrictions: A USING statement cannot have a label. Base register zero (symbol, B0) cannot be specified as the register operand of the USING directive. The USING directive does not produce code to place the value of exp in the base register. The programmer must include code to actually place the value in the base register. Note: Refer to Topics 2-23, 2-24, and 6-16. #### Examples: | LABEL | COMMAND | OPERANDS | | |-------|---------|-----------|--| | | USING | ALPHA, B2 | | | | USING | \$+1,B14 | | #### 4-10. DROP DIRECTIVE (DROP) The DROP directive indicates to the assembler that the specified base register is no longer available for base selection. The base will not be considered available until another USING directive declares it to be available. #### GENERAL FORM: | LABEL | <br> <br> | COMMAND | <br> <br> - | OPERANDS | |-------|-------------|---------|-------------|----------| | blank | R | DROP | R | register | Restrictions: A DROP statement cannot have a label. #### Examples: | L | ABEL | R | COMMAND | R | OPERANDS | | |---|------|---|---------|---|----------|--| | | W | | DROP | | B14 | | #### 4-11. ORIGIN DIRECTIVE (ORG) The ORG directive is used to set or reset the location of the origin for all or a portion of the section being assembled. #### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | |---|----------|---|---------|---|----------| | f | [symbol] | R | ORG | R | exp | The location counter is set to the value of the expression, exp. All code generated following the ORG directive will begin at the location whose value is that of the expression. If the expression is blank, it directs the assembler to use the highest value previously assigned to the location counter of the section being assembled as the present value of the location counter. The label, if present, is assigned the value of the location counter before the location counter is reset. <u>Restrictions</u>: The expression must have a relocatable value and must be within the same control section as the ORG statement. #### Examples: | LABEL | X COMMAND | OPERANDS | | |-------|-------------|----------|--| | ALPHA | ORG | \$+50 | | | | ORG | ALPHA | | #### 4-12. CONTROL DIRECTIVES # 4-13. LITERAL ORIGIN DIRECTIVE (LITORG) The LITORG directive sets the location of the origin for all literals (regardless of the referring section) defined since the previous LITORG directive and places the locations of the literals in their respective object code statements. #### GENERAL FORM: | LABEL | COMMAND | OPERANDS | |----------|---------|----------| | [symbol] | LITORG | [exp] | The origin is determined by incrementing the value of the expression, if necessary, to a doubleword boundary. The literals will be generated beginning at the aligned location. The label, if present, is assigned the value of the location counter before the location counter is reset. After the literals have been generated, the location counter will remain set to the first location following the last generated literal. If the expression is blank, the current location counter value becomes the literal origin before alignment. <u>Restrictions</u>: The expression must have a relocatable value and must be within the same control section as the LITORG statement. #### Examples: | LABEL | K COMMAND | OPERANDS | | |-------|-----------|----------|--| | ALPHA | LITORG | \$+10 | | | | LITORG | | | #### 4-14. END ASSEMBLY DIRECTIVE (END) The END directive signals termination of the assembly. #### GENERAL FORM: | LABEL | | COMMAND | <br> <br> | OPERANDS | |-------|---|---------|-------------|----------| | blank | R | END | R | [exp] | The value of the expression represents the beginning execution address of the assembly when it is loaded and run (unless otherwise overridden). If the operand field is blank, no address for beginning execution of the program is output to the loader. Whenever an END statement is encountered, it will be recognized as the end of the assembly. Restrictions: An END statement cannot have a label. The END directive cannot be used in a procedure. The expression, exp, must be relocatable. #### Examples: | LABEL | R COMMAND | אן | OPERANDS | | |-------|-----------|----|----------|--| | | END | | FIRST | | | | END | | • | | #### 4-15. SECTION DIRECTIVE (SEC) The SEC directive defines a control section and asserts assembly control to that section for the generation of any subsequent code that is to have the same protection conditions. #### GENERAL FORM: | LABEL | COMMAND | OPERANDS | |--------------|---------|---------------------------------| | [symbol] b | SEC | <pre> [exp1][, exp2] </pre> | The label is the symbolic name applied to the control section. Subsequent uses of a SEC statement with the same label will return control to the section at the location immediately following the highest location count used previously within the section. Sections may be resumed as desired. The assembler assigns a control section number to the section when the defining statement is used for the first time. Section numbers are assigned sequentially. Initially, the location counter is set to zero. An ORG directive (see Topic 4-11) may be used to adjust the location counter values. The first operand expression, expl, specifies the hardware protection of all code generated under control of the defined section. Expression 1 need not be used in subsequent returns to a defined section; the original protection will be assumed. Expression 1 must be absolute with a value of 0, 1, 2, or 3. An expl value of 0 specifies read, write, or execute (i.e., no protection); an expl value of 1 specifies read only; an expl value of 2 specifies read or write; and an expl value of 3 specifies execute only. If expl is blank, the value 0 is assumed. The second operand expression, exp2, specifies the memory alignment for the beginning of the section. Expression2 must be absolute and the value is considered to be an exponent of 2, i.e., 2 exp2. If exp2 is not present, a value of 3 is assumed, and, thus, the section will be aligned on an octet boundary. The assembler will assign a control section to the module name if no SEC directive is used. No protection (i.e., read, write, or execute) will be assumed for such a section. Restrictions: Both expressions must be absolute. The protection condition cannot be changed after the initial defining SEC statement; i.e., a given section has only one protection condition. Limitations: Only one unlabeled SEC statement is allowed. <u>WARNING</u>: The assembler will create absolute literals in a section with execute only protection even though they cannot be read and, therefore, cannot be used. #### Examples: | LABEL | COMMAND | OPERANDS | | |-------|---------|----------|--| | ALPHA | SEC | 1,2 | | | BETA | SEC | 0 | | | | SEC | 3,3 | | #### 4-16. COMMON MODULE DIRECTIVE (COM) The COM directive defines a common module. #### GENERAL FORM: | LABEL | COMMAND | OPERANDS | |----------|---------|----------------| | [symbol] | СОМ | [exp1][, exp2] | The label is the symbolic name applied to the common section. Subsequent uses of a COM statement with the same label will return control to the common section at the location immediately following the highest location count used previously within the section. Common sections may be resumed as desired. If no label is present, "blank" common is defined; i.e., it is an unlabeled common section. The protection condition of the common section is specified by expl. The absolute value of expl may be 0, 1, 2, or 3 with the same protection interpretation as for the SEC directive; viz., no protection, read only, read or write only, and execute only, respectively. If expl is blank, zero is assumed. The beginning boundary alignment is specified by exp2 where exp2 is an exponent of 2; i.e., the alignment will be $2^{\exp 2}$ . If exp2 is blank, three (an octet boundary) is assumed. The module definition output generated for a COM statement has the same format as that for a SEC statement; the setting of a reserved bit within the format distinguishes the defined module as a common module. Restrictions: Both expressions must be absolute. The protection condition cannot be changed after the initial defining COM statement. # Examples: | LABEL | K COMMAND | OPERANDS | | |-------|-----------|----------|--| | ALPHA | СОМ | 0,3 | | | BETA | COM | | | | | СОМ | 1 | | #### 4-17. DUMMY SECTION DIRECTIVE (DUM) The DUM directive defines an absolute dummy section. #### GENERAL FORM: | LABEL | <br> <br> | COMMAND | | OPERANDS | | |----------|-------------|---------|---|---------------|---| | [symbol] | R | DUM | R | [expl][,exp2] | 7 | Any reference to the absolute dummy section name or to any symbol defined within the dummy section is treated as an absolute reference to a section. The symbolic name has a value of zero since it is the first location in the dummy section. The values of any other symbols defined (as labels of statements) within the section have the values of their respective displacements from the beginning of the dummy section. A dummy section produces no object text output and no evidence will exist in the object ''deck'' that the DUM statement appeared in the source file. The operand expressions have no significance other than as a comment for the protection and boundary conditions of the actual section for which the dummy section substitutes. #### Examples: | LABEL | COMMAND | OPERANDS | | |-------|---------|----------|--| | ALPHA | DUM | 2,3 | | | BETA | DUM | 0,0 | | | | DUM | | | #### 4-18. DUMMY COMMON MODULE DIRECTIVE (COMD) The COMD directive defines a relocatable dummy section. #### GENERAL FORM: | LABEL | COMMAND | OPERANDS | |--------|---------|---------------| | symbol | COMD | [expl][,exp2] | Any reference to the dummy common module name or to any symbol defined within the dummy common section is treated as a relocatable value to which the value of the symbolic label is to be added at link-edit time. At assembly time the symbolic label has the value of relative zero and symbols defined (as labels of statements) within the dummy common section have values that are the relocatable displacements relative to the beginning of the module. The symbolic label is assumed to be the name of a common section. A dummy common module produces no object text output. The operand expressions have no significance other than as a comment for the protection and boundary conditions of the actual common section for which the dummy common section substitutes. Restrictions: A COMD statement must have a label. #### Examples: | LABEL | COMMAND | OPERANDS | | |-------|---------|----------|--| | ALPHA | COMD | 0,3 | | | BETA | COMD | 1,1 | | #### 4-19. COPY DIRECTIVE (COPY) The COPY directive causes the specified file, "sourcefilename," to be copied inline as source text to the assembler. #### GENERAL FORM: | LABEL | <br> | COMMAND | | OPERANDS | |-------|------|---------|---|----------------| | blank | R | COPY | R | sourcefilename | The source statements from the file, sourcefilename, are merged into the assembly after the COPY statement and before any later source statements in the assembly. The file may exist on an indicated user library or on the system procedure library. The COPY function is processed during PASS 1 of the Assembler without regard to level of assembly. Restrictions: A COPY statement cannot have a label. The occurrence of an END statement in the copied file will cause termination of the assembly. <u>Limitations</u>: The COPY function cannot be used to copy part of a source file; all card images in the file will be copied. #### Examples: | LABEL | [X] | COMMAND | JR | OPERANDS · | |-------|-----|---------|----|------------| | | | COPY | | SOURCE | | | | COPY | | PROC1 | # 4-20. RESERVE DIRECTIVE (RES) The RES directive is used to reserve space within the assembly. #### GENERAL FORM: | LABEL | COMMAND | <br> | OPERANDS | |----------|---------|------|----------| | [symbol] | RES | R | exp | The present value of the current location counter is modified by the value of the expression, exp. The expression may be positive or negative, but must be absolute. The value of the symbolic label is the value of the current location counter before it is modified. Restrictions: The expression, exp, must be absolute. Limitations: The maximum value of exp is 65536. #### Examples: | LABEL | COMMAND | OPERANDS | |-------|---------|----------| | ALPHA | RES | 10 | | BETA | RES | #16 | | | RES | 100 | #### 4-21. ALIGN DIRECTIVE (ALIGN) The ALIGN directive causes the location counter value to be incremented, if necessary, to place the next statement on a specified word boundary. # GENERAL FORM: | LABEL | <br> | COMMAND | | OPERANDS | | |-------|------|---------|---|------------|--| | blank | R | ALIGN | R | expl, exp2 | | The second operand expression, exp2, specifies a basic boundary alignment and the first operand specifies a number of words past that basic alignment; e.g., ALIGN 2, 8 would specify the second word past an octet boundary. If the current value of the location counter is not on a word boundary as specified by exp2 and exp1, the location counter value will be incremented by the least value sufficient to place the new location count on the specified boundary. The contents of any locations skipped are not modified. Mathematically, the location count must meet the criterion: $C \equiv x \mod (y)$ , where C is the location count, x is the value of expl, and y is the value of exp2. Illustratively, this means that ALIGN 2, 8 will force the location counter value to a member of the set $\{2, 10, 18, 26, \dots\}$ . Restrictions: An ALIGN statement cannot have a label. The expressions, expl and exp2, must be absolute. Expl must be less than exp2. #### Examples: | LABEL & C | OMMAND & | OPERANDS · | |-----------|----------|------------| | A | LIGN | 0,8 | | A. | LIGN | 1,2 | | A | LIGN | 0,16 | #### 4-22. DO DIRECTIVE (DO) The DO directive provides control of assembly by including, excluding, or repeating a variable number of statements. The result in the assembly is the same as if the "DO-controlled" statements had been included, excluded or repeated in the source input stream. #### GENERAL FORM: | LABEL | COMMAND | OPERANDS | |----------|---------|--------------------------| | [symbol] | DO | [exp1][,[exp2][,[exp3]]] | ACTION SUMMARY: The DO directive is restricted in its interpretation when used outside of procedures. It does, however, have limited use. Letting the DO parameters, expl, exp2, exp3, be represented by x, y, and z, respectively, the action of the DO directive outside of procedures may be summarized as: - 1. If x > 1, assemble the next statement x times; ignore y and z. - 2. If x = 1, assemble the next y statements once, and skip z statements. - 3. If x < 1, skip the next y statements; ignore z. Note: See <u>PROGRAMMERS' GUIDE TO PROCEDURE PROGRAMMING</u> for the interpretation of the DO directive when it is used within procedures. Restrictions: Of the intrinsic functions only B(exp), D(exp), and T(exp) are valid as parameters of a DO statement used outside of a procedure. Outside of procedures, DO directives can be nested only to exclude the nested DO statement; they cannot be used to cause repetition of the nested DO statement's control range. Outside of procedures, no statements within the range of a given DO statement other than a nested DO statement or a SET statement may have labels. <u>Default Values for Parameters:</u> The following table illustrates the Assembler's interpretation of the DO parameters for the various cases of coding: | | expl < l | expl = 1 | expl >1 | | |------------|------------|------------|------------|--| | CODED | ASSUMES | ASSUMES | ASSUMES | | | DO x | DO x, 1, 0 | DO 1, 1, 0 | DO x, 1, 0 | | | DO x, | DO x, 1, 0 | DO 1, 1, 0 | DO x, 1, 0 | | | DO x,, | DO x, 0, 0 | DO 1,0,0 | DO x, 1, 0 | | | DO x,, z | DO x, 0, 0 | DO 1,0,z | DO x, 1, 0 | | | DO x, y | DO x, y, 0 | DO 1, y, 0 | DO x, 1, 0 | | | DO x, y, | DO x, y, 0 | DO 1, y, 0 | DO x, 1, 0 | | | DO x, y, z | DO x, y, 0 | DO 1, y, z | DO x, 1, 0 | | Note: If expl is defaulted, it will be assumed to be zero. ITERATION GROUP: The value of exp2 specifies the number of statements to be assembled as a group. This group, called the iteration group, begins with the statement immediately following the DO statement. Restrictions: Outside of procedures, if expl is greater than one, exp2 defaults to one. Note: Commentary lines are not statements and are, therefore, ignored in DO directive iterations. ITERATION COUNT: The value of expl specifies the number of times the iteration group is to be assembled. This value is called the iteration count. An expl value of less than one causes the iteration group to be skipped without action. An expl value of n, where n is greater than or equal to one, causes the iteration group to be assembled n consecutive times. Restrictions: Outside of procedures, if expl is greater than one, exp2 defaults to one; if expl is equal to or less than one, exp2 may be greater than one. <u>Limitations</u>: The effective value of expl is limited to the range: $0 \le \exp l \le 255$ . SKIP COUNT: The value of exp3 specifies the number of contiguous statements in the source stream that are to be excluded when the iterations are complete. This value is called the skip count. The statements skipped are those that immediately follow the last statement iterated. If expl is less than one, the DO execution is complete after the iteration group is skipped and exp3 is ignored; i.e., only the number of statements equal to exp2 will be skipped. Restrictions: Outside of procedures, exp3 is defaulted to zero for all cases other than those in which expl is equal to one. SATISFACTION OF PARAMETERS: When a number of statements equal to (or greater than) the value of exp2 have been assembled in one iteration, exp2 is said to be satisfied for that iteration. When a number of iterations equal to the value of expl has been completed, expl is said to be satisfied for that DO statement. The DO directive is said to be satisfied when the iterations and/or skips specified by all three parameters have been completed. <u>DO LABEL</u>: A label on the DO directive provides symbolic access to the number of the iteration the DO directive is performing (or has performed) at the time reference is made to the label. When the DO statement has been encountered in the source stream, the label is initially given a value of one; thus, if the DO label is used as one of the parameters of its own DO statement, that parameter will always be evaluated as one. This initial assignment of the label value overrides any previous assignment of a value to that symbol by a previous SET or DO statement. The value of the DO label is incremented at the beginning of each iteration of the DO directive; thus, the value of the label is always the number of the iteration being performed, or is the number of the last iteration performed once the DO directive is satisfied. Any attempts to modify the value of the DO label by a SET statement or as the label of a nested DO statement within the range of the DO directive will cause an anomalous assembly. In summary, if a DO statement has an iteration count, (value of expl) of n and has a label, the value of the label will be incremented through the series $\{1, 2, 3, \ldots, n\}$ in successive iterations. If the value of expl is less than one, the label will always have the value of one. Once the DO directive is satisfied, the label retains its last value unless or until its value is modified by a SET statement or it is used as the label of another DO statement, or the DO statement is reaccessed. Such modifications must occur outside the range of the subject DO directive. Restrictions: The value of a DO label cannot be preset to a value other than one. The value of a DO label cannot be modified within the range of the subject DO directive, other than by its own iteration incrementation. NESTED DO DIRECTIVES: A DO directive is said to be nested when it is one of the statements included in the iteration group of another DO directive which is called the parent DO directive. DO directives may be nested up to 32 levels. Restrictions: An error message will be returned if the range of a nested DO directive exceeds the range of its parent DO directive even through the resultant assembly may be the desired result. Outside of procedures, a DO directive may be nested only to permit its exclusion from the assembly. The nested DO directive will not repeat statements within its range; neither will the parent DO directive cause the nested DO directive to repeat its action. #### 4-23. PSEUDO DIRECTIVES #### 4-24. INDIRECT ADDRESS CONSTANT DIRECTIVE (IND) The IND directive is used to generate an indirect address constant. #### GENERAL FORM: | LABEL | <br> <br> | COMMAND | | OPERANDS | |----------|-------------|---------|---|-------------| | [symbol] | K | IND | R | expl[,exp2] | Expression1 represents the address value and expression2 represents the second level index. Expression1 may be preceded by an at sign (@) to indicate another level of indirectness. #### Examples: | LABEL | אַן | COMMAND | אן | OPERANDS | | |-------|----------|---------|----|----------|--| | GAMMA | <u> </u> | IND | | @BETA | | | | | IND | | SIGMA | | <u>Restrictions</u>: Access to indirect address constants are execute requests; therefore, indirect address constants must be in control sections with execute permitted protection codes. # 4-25. DATA HALFWORD DIRECTIVE (DATAH) The DATAH directive will place the values of expression1 and expression2 into the left and right halves, respectively, of the word generated by the statement. Both expressions must be absolute. #### GENERAL FORM: | LABEL | COMMAND | | OPERANDS | |----------|---------|---|------------| | [symbol] | DATAH | R | expl, exp2 | #### Examples: | LABEL | K COMMAND | OPERANDS | | |-------|-----------|----------|--| | ALPHA | DATAH | 0,1 | | | | DATAH | -3,2 | | # 4-26. <u>LISTING DIRECTIVES</u> #### 4-27. SKIP DIRECTIVE (SKIP) The SKIP directive permits control of the assembly listing. This directive causes the assembler to skip print lines or to eject the page of the assembly listing. The contents of the operand field also control the printing of the heading at the top of the new page. The directive itself is not printed on the listing. #### GENERAL FORM: | LABEL | <br> <br> <br> | COMMAND | | OPERANDS | |-------|----------------|---------|---|---------------------------| | blank | R | SKIP | R | [exp[, character string]] | If the expression is zero or blank, the page will be ejected. Otherwise, a number of print lines equal to the value of the expression will be skipped. The expression must be absolute. SKIP directives are ignored if the NOLIST directive is used. The operand field of the SKIP directive may have any of the following formats: | FORMAT | FUNCTION | |-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SKIP | Eject the page; new page number equals old page number plus one; print previous title. | | SKIP n | Skip n lines; if this causes page ejection, start at top of page as in previous format. | | SKIP 0, "TITLE" | Eject the old page; new page number equals old page number plus one; new title is the character string, TITLE. | | SKIP n, "TITLE" | Skip n lines; this causes page ejection, start at top of new page; new title for the next page is the character string, TITLE, regardless of whether page is ejected now; new page number equals old page number plus one. | Restrictions: No label is allowed with the SKIP directive. The expression must be absolute. Limitations: The character string may not exceed 100 positions. # Examples: | LABEL | COMMAND | OPERANDS | |-------|---------|-----------| | | SKIP | 3 | | | SKIP | | | | SKIP | 0,"TITLE" | | | SKIP | 6,"TITLE" | # 4-28. LIST DIRECTIVE (LIST) The LIST directive is used to cause the object code listing to resume. #### GENERAL FORM: | LABEL | | COMMAND | <br> | OPERANDS | | |-------|---|---------|------|----------|--| | blank | R | LIST | R | blank | | The combination of NOLIST and LIST directives can be used when only a portion of the assembly listing is desired. The directive is not printed on the listing. Restrictions: No label is allowed with the LIST directive. #### Example: | L. | ABEL | אן | COMMAND | )X | OPERANDS | |----|------|----|---------|----|----------| | | | | LIST | | | # 4-29. NOLIST DIRECTIVE (NOLIST) The NOLIST directive is used to suppress the listing. #### GENERAL FORM: | LABEL | <br> <br> | COMMAND | | OPERANDS | |-------|-------------|---------|---|----------| | blank | R | NOLIST | R | blank | When the assembler encounters this directive, it stops the listing. The directive is not printed on the listing. Restrictions: No label is allowed with the NOLIST directive. # Example: | LABEL | K | COMMAND | K | OPERANDS | | |--------|---|---------|---|----------|--| | NOLIST | | | | | | #### SECTION V #### ASSEMBLER OUTPUT #### 5-1. ASSEMBLER OUTPUT The Assembler output consists of object modules and a listing with messages. #### 5-2. SOURCE PROGRAM LISTING An assembly listing will be output in the format shown in Figure 5-1. A double space listing may be requested by control card option, or listing may be suppressed by control card option. Columns with headings are provided for error flags, the location of each statement, the object text generated, the statement number, and each source statement. If program sequencing has been requested, an unheaded column of sequence numbers will be printed. Error Column (ERRORS): The ERROR column contains the flags for assembler error messages and procedure processing error messages. These error flags and their meanings are described in the section on Messages. Statement Location Column (LOCATION): The LOCATION column contains the location (in hexadecimal numerals) relative to the beginning of its section for each source statement. Object Code Column (OBJECT TEXT GENERATED): The OBJECT TEXT GENER-ATED column contains the hexadecimal object code generated by each statement in the source program. Statement Number Column (STMT): The STMT column contains decimal statement numbers for each source statement in an assembly. Note: The user should note that the Central Processor Procedure Library statements which precede each program are not listed; therefore, statement numbers begin at some number greater than zero. PROGRAMMER'S GUIDE TO THE CENTRAL PR OCESSOR Figure 5-1. Example Source Program Listing Source Statement Column (SOURCE STATEMENT): The SOURCE STATEMENT column contains each symbolic source statement in the assembly input. SUMMARY OF SPECIAL LISTS: Following the listing of source statements for an assembly is a summary of special lists and the number of statements in error for each section. The format is as follows: LITERALS ASSIGNED TO SECTION hh location counter value literal ENTRY NAMES entry name location counter value EXTERNAL NAMES external name ASSEMBLY COMPLETE xxxx STATEMENTS IN ERROR. ### 5-3. MESSAGES An assembly listing line consists of the hexadecimal representation of the location counter and machine language instruction followed by the number and image of the original source statement. Message flags are indicated to the left of the location counter value. For each line upon which an error condition is discovered (which results in a message flag being listed) a word containing an error count will be incremented by one. At the end of the assembly run, this count is set in the specified word on the listing. A maximum of six flags will appear on the listing for each line of generated listing. Table 5-1. Assembler Generated Messages | FLAG | ERROR CONDITION | |------|-----------------------------------------------------------------| | A | Addressability Error | | В | Invalid Use of Base Intrinsic | | С | Too Many Continuation Cards | | D | Duplicate Label Assignment | | E | General Syntax Error | | F | Intrinsic Function Invalidly Used | | G | Invalid Use of a List | | H. | Invalid Use of a Directive | | I | Undefined Instruction | | J | Invalid Use of Displacement Intrinsic | | K | Invalid Use of Control Section Intrinsic | | L | Error in the Label Field | | M | Magnitude Error | | N | No END Card on Deck | | 0 | Too Many Operands on Statement | | P | Parentheses Are Unbalanced | | Q | Invalid Arithmetic Operation | | R | Relocation Error | | S | Truncation Has Occurred | | Т | Assembler Table Overflow | | Ŭ | Undefined Symbol | | V | Invalid Forward Reference | | W | Warning, Possible Error | | X | Reserved for Future Use | | Y | Reserved for Future Use | | Z | Disagreement in Location Counter between Pass One and Pass Two. | ### 5-4. Procedure Processing Generated Messages The message flags following are generated by the Central Processor and the Peripheral Processor procedures that the assembler processes. FLAG ERROR CONDITION 1 Invalid use of a register, or insufficient number of parameters. 2 Questionable use of a register, or insufficient number of parameters. 3 Invalid use of a literal for the ASC. 4 Invalid use of an @ for the ASC. 5 Invalid use of a ¢ for the ASC. Table 5-2. Procedure Processing Message Symbols #### 5-5. CROSS-REFERENCE LISTING A cross-reference listing will be output in the format appearing in Figure 5-2. The cross-reference listing can be suppressed by control card option. Each new symbol encountered is entered in the SYMBOL column and its definition and/or cross-references are listed to the right through the TYPE, SEC, VALUE, DEFN, and REFERENCES columns. Each new symbol will have a SYMBOL and TYPE entry in the cross-reference listing. If the symbol is defined, the SEC, VALUE, and DEFN fields will be filled; if the symbol is not defined, these three fields will contain hyphens. A series of hyphens in any field indicates that, for that symbol, the field is not applicable, not available, or not known. Symbol Column (SYMBOL): The SYMBOL column contains the symbol whose cross-references are listed in the succeeding columns and lines of the listing format. All entries prior to the next entry in the SYMBOL column refer to the given symbol. ASSEMBLER OUTPUT ``` PAGE CROSS-REFERENCE LISTING 02/05/70 REFERENCES DEFN - SYMBOL TYPE SEC VALUE 673 675 -- 00000011 -- 00000012 29 30 A2 673 33 00000015 A5 674 34 00000016 VAR 681 671 672 01 00000000 670 BRCHTST ENT 671 -- 00000001 VAR 273 276 ISN 678 01 00000A10 680 674 01 0000000F 676 01 000008A0 REL TOTAL 674 -- 00000021 VAR -- 00000025 DATE-02/05/70 EXECUTION TIME-OOHRS COMINS 52.67SECS STEP-ASMC ``` Figure 5-2. Cross-Reference Listing Example Type Column (TYPE): The TYPE column contains an abbreviation specifying the type of the symbol being cross-referenced. The meanings of the abbreviations in the TYPE column are as follows: | ABBREVIATION | MEANING | |--------------|----------------------------------------------------------------------------------| | REL | internally relocatable | | ABS | absolute | | EXT | external | | ENT | entry point | | VAR | variable, section and value may change; the first section and value is displayed | The VAR type symbol results from the definition of a SET or a DO directive outside of all procedures. Symbols defined by SET and DO directives inside a procedure have definition information only. Section Column (SEC): The SEC column contains the number of the section to which the symbol belongs and in which it is defined. Value Column (VALUE): The VALUE column contains the value assigned to or the evaluation of the symbol being cross-referenced. Depending upon the type of the symbol, its value may be an address constant, a value set by the programmer, or the evaluation of the symbol via operations. If the VALUE column contains eight asterisks, the value of the symbol cannot be represented in eight hexadecimal digits. <u>Definition Column (DEFN)</u>: The DEFN column contains the number of the statement in which the symbol is defined. References Column (REFERENCES): The REFERENCES column contains a complete listing of the statement numbers of all the statements in which the symbol being cross-referenced appears. This will not include its definition statement number that appears in the DEFN column. #### SECTION VI #### ASSEMBLER-CENTRAL PROCESSOR INTERFACE # 6-1. INTRODUCTION The assembler produces machine code statements by interpretation of symbolic coding through procedures that are defined in the assembler. The names by which the procedures may be called (i.e., the assembler mnemonics for the central processor instructions) are described in Sections VII and VIII of this manual. This section of the manual describes the modes of interpretation of symbolic code into machine code for scalar instructions. Since the vector operations have special characteristics, both in the assembler procedures and in the machine, they are described in Section VIII, which is devoted entirely to the vector operations. ### 6-2. INSTRUCTION FORMATS The machine instruction has an eight-bit operation code field, a four-bit R field which either specifies a register whose contents are used or altered in the operation or is a condition mask for the operation, a four-bit T field whose most significant bit specifies indirect addressing and whose other three bits specify an index register, a four-bit M field which specifies the base register to be used in address development, and a 12-bit N field which specifies the displacement to be used in address development. For instructions which use immediate operands, the M and N fields compose a 16-bit immediate operand field. For index, test, and branch instructions, the T field addresses arithmetic registers. All three machine formats are illustrated in Figure 6-1. The assembler statement of a scalar instruction may have a label, must have a command, and may have from one to three operands. In general: | LABEL | COMMAND | | OPERANDS | |----------|----------|---|----------------------------------| | [symbol] | mnemonic | R | [operand1, ]operand2[, operand3] | Figure 6-1. Assembler Statement Translations into Machine Code ### 6-3. LABEL A label on an assembler instruction is optional. When it is present, it is a symbol (see Topic 2-5) and it is assigned a relocatable value which is its relative position in the assembly. If a label is not present, its field must be represented by one or more blanks. The label is not interpreted into any part of the machine instruction. ### 6-4. COMMAND The command in the assembler instruction is mandatory. The command is one of the mnemonics defined by procedures in the assembler. This mnemonic, in conjunction with information from the operands, determines the operation code field of the machine code instruction (see Figure 6-1). Note that the machine operation code may not be determined from the command mnemonic alone; e.g., the mnemonic L for load instructions may be translated into any one of three machine codes depending upon the register operand included in the statement. #### 6-5. OPERANDS The operand list varies in number of operands and in operand interpretation from instruction to instruction, but there are only two basically different operand lists. They may be called the R, N, X list and the R, R, N list, respectively. Table 6-1 is a definitive list of all operand combinations. ### 6-6. R, N, X OPERAND LIST The R, N, X operand list is basic to all except two of the scalar instructions. ### 6-7. First Operand The first operand is that operand which is translated into the R field of the machine instruction and also helps determine the operation code for some instructions. See Figure 6-1. Table 6-1. General Forms and Variations of the Operand Lists | GENERAL | Γ | | | | |------------------|----------|---------|--------------|----------------------------| | FORMS | SYMBOI | LIC N | EXPLICIT BAS | SE AND DISP | | R, N, X Lists: | | | | | | r, [@] [=]n[, x] | r,@=n, x | r,@=n | | | | | r,@n, x | r,@n | r,@(d, b), x | <b>r</b> ,@( <b>d</b> , b) | | | r, =n, x | r,=n | | | | | r, n, x | r, n | r, (d, b), x | <b>r</b> , (d, b) | | r, [@[=]]n[, x] | r,@=n, x | r,@=n | | | | | r,@n, x | r,@n | r,@(d, b), x | <b>r,</b> @(d, b) | | | r, n, x | r,n | r, (d, b), x | r, (d, b) | | r, [@]n[, x] | r,@n, x | r,@n | r,@(d, b), x | r,@(d,b) | | | r, n, x | r,n | r, (d, b), x | r, (d, b) | | m, [@[=]n[, x] | m,@=n, x | m,@=n | | | | | m,@n, x | m,@n | m,@(d, b), x | m,@(d, b) | | | m, n, x | m, n | m, (d, b), x | m, (d, b) | | m, [@]n[, x] | m,@n, x | m,@n | m,@(d, b), x | m,@(d, b) | | | m, n, x | m, n | m, (d, b), x | m, (d, b) | | [@[=]]n[x,] | @=n, x | @=n | | | | | @ n, x | @ n | @(d, b), x | @(d, b) | | | n, x | n | (d, b), x | (d, b) | | [@]n[, x] | @ n, x | @ n | @(d, b), x | @(d, b) | | | n, x | n | (d, b), x | (d, b) | | r, i[, x] | r, i, x | r, i | _ | | | i[,x] | i, x | i | _ | | | i | *** | i | _ | _ | | R, R, N Lists: | | | | | | r, r, n | | r, r, n | | r, r, (d, b) | The first operand may be a register symbol or value, a mask, or supplied by the assembler. For those instructions where the assembler supplies the R field of the object instruction, no "first" operand is coded; therefore, it is convenient to refer to it as the register operand or the mask operand, as appropriate. GENERAL FORM SYMBOLS: In general forms, the first operand, when present, will be represented by symbols as follows: | SYMBOL | MEANING | |---------|--------------------------------------------------------------| | r | replace r with a register symbol or register value | | m | replace m with an absolute expression | | neither | no "first" operand, the R field is supplied by the assembler | ### 6-8. Second Operand The second operand is that operand which is translated into the M and N fields of the machine instruction and, also, specifies whether the most significant bit of the T field is to be set to one or zero (i.e., indicates whether to use indirect addressing.) See Figure 6-1. The second operand may be a relocatable expression, a sublist specifying base and displacement, or an absolute expression which is an immediate operand. Instructions which use relocatable symbols also permit base and displacement sublists and vice versa, but absolute expressions and relocatable values are not interchangeable. Since the "first" operand is not always coded, it is convenient to refer to the "second" operand as the address operand (when a relocatable symbol or a base and displacement sublist) or as the immediate operand (when an absolute expression). An address operand may be preceded by an @ sign to indicate indirect addressing (see Topic 6-27), and its presence causes the most significant bit of the T field of the object instruction to be set to one. BASE AND DISPLACEMENT SUBLIST: When a relocatable expression is coded in the second operand, it is provided by the assembler with a base and displacement. When it is desired to code the base and displacement explicitly, the address operand is coded as a sublist (i.e., a list enclosed in parentheses) with the displacement first, a comma, and then the base register symbol or value. The displacement is translated into the N field and the base into the M field of the object instruction. See Figure 6-1. Both the displacement and the base must be absolute expressions. RESTRICTIONS ON LITERALS: In all instructions in which the data flow is from the location specified by the address operand, a literal may be used as an address operand since it is given a relocatable value. In those instructions in which the data flow or the flow of control (i.e., a branch) is to the location specified by the address operand, use of a literal is restricted and may be prohibited. For some branch instructions a literal which will create an indirect address is permitted in conjunction with the indirect address symbol. Note that, in any case where a literal is conjuncted with indirect addressing, the literal must be assembled into an indirect address. A base and displacement sublist, since it is a list, cannot be a literal. GENERAL FORM SYMBOLS: In general forms, the second operand will be represented by symbols as follows: | SYMBOL | MEANING | |--------------|-----------------------------------------------------------------------------------------------------| | n | replace n with a relocatable expression or a base and displacement sublist (d, b) | | @ <b>n</b> | use the indirect address cell at location n + index to develop a terminal effective address | | =n | assembler give =n a relocatable value and store the value of n at that location (n may be absolute) | | @ n | assembler give =n a relocatable value and store the indirect address, n, at that location | | (d, b) | explicit base and displacement address (Continued) | | SYMBOL | MEANING | |--------|------------------------------------------------------------------------------| | d | replace d with a positive absolute expression, or a register symbol or value | | b | replace b with an absolute expression, or a base register symbol or value | | i | replace i with an absolute expression | ### 6-9. Third Operand The third operand is that operand which is translated into the three least significant bits of the T field of the object instruction. See Figure 6-1. The third operand will always be an index register symbol or value. It is convenient to refer to it as the index operand. In general forms, the index operand will be represented by the symbol x. It is always optional to leave off the index operand, but there is one instruction, LLA, in which an index operand is prohibited. ### 6-10. R, R, N OPERAND LIST There are only two instructions, BCLE and BCG, which use the R, R, N operand list. It differs from the R, N, X list in that it is the second operand that is translated into the T field of the object instruction. See Figure 6-1. The first operand is always an arithmetic register symbol or value, the second operand is always an even arithmetic register symbol or value, and the third operand is always a relocatable address (branch) symbol. The third operand does not permit use of indirect addressing or literals. The algorithm of these two instructions is discussed in Topic 7-127. For convenience, the first operand may be called the register operand, the second operand may be called the test operand, and the third operand may be called the address operand. ### 6-11. REGISTER ADDRESSING The bank of 48 registers in the Central Processor are separated into six eightword files: the two base register files, A and B, the two arithmetic files, C and D, the index register file, X, and the vector register file, V. Symbolic addressing of the registers may be performed by their reserved symbols built into the assembler procedures, by their decimal positions in the register bank, by their hexadecimal positions in the register bank, or by any absolute expression which is equated to any of the previous addresses. Figure 6-2 illustrates the division of the register bank into files, and Table 6-2 lists the symbols by which the individual registers may be addressed. Note that all register addressing modes are absolute values. ### 6-12. REGISTER OPERAND - R FIELD ADDRESSES Register operands are translated by the assembler into the R field of the object code. Since there are 48 registers but only four bits in the R field, the translation is performed modulo 16. For those assembly instructions which may refer to any register in the bank (e.g., L), the modulus number (i.e., first 16, second 16, third 16) or the symbol letter (i.e., Bx, Ax, Xx, or Vx) determines which object operation code is selected. In the object code, it is the operation code that specifies which group of 16 registers is accessed, whereas in the assembler code the register operand specifies which operation code to select. Note that the index and vector register files are accessed in the same modulus, and, therefore, instructions whose names specify an index register in the R field also may use vector registers. | SYMBOLIC | DECIMAL | HEXADECIMAL | REGISTER BANK | FILE | | |----------|---------|-------------|---------------|------|-----------------------------------------| | ADDRESS | ADDRESS | ADDR ESS | | | | | В0 | 0 | #0 | WIRED TO ZERO | 1 1 | | | Bl | 1 | #1 | | ) | | | | : | | | A - | | | В7 | 7 | #1 | | ) ( | BASE<br>REGISTERS | | В8 | 8 | #8 | | ) ( | (BR) | | : | | <u>:</u> | | В | | | B15 | 15 | #F | | ) / | | | A0 | 16 | #10 | | ) ( | | | : | : | : | | C | | | A7 | 23 | #17 | | ) ( | ARITHMETIC | | A8 | 24 | #18 | | ) ( | REGISTERS<br>(AR) | | : | •<br>• | | | D | , , | | A15 | 31 | #1 <b>F</b> | | ) / | | | . X0 | 32 | #20 | | ) \ | | | : | • | : | | X | INDEX<br>REGISTERS<br>(XR) | | X7 | 39 | #27 | | ) ( | | | V0 | 40 | #28 | | ) ( | VECTOR | | : | | i i | | v V | VECTOR<br>REGISTERS<br>(VR) | | V7 | 47 | #2F | | 1 / | , , , , , , , , , , , , , , , , , , , , | Figure 6-2. Register File Specifications | Table 6-2. | Register | Addressing | Symbols | |------------|----------|------------|---------| |------------|----------|------------|---------| | SYMBOLIC | NUMER | IC ADDRESS | SYMBOLIC | NUMER | IC ADDRESS | |----------|---------|-------------|------------------------|-------|-------------| | ADDRESS | DECIMAL | HEXADECIMAL | AL ADDRESS DECIMAL HEX | | HEXADECIMAL | | B0* | 0 | # 0 | A8 | 24 | # 18 | | В1 | 1 | # 1 | A9 | 25 | # 19 | | В2 | 2 | # 2 | A10 | 26 | # 1A | | В3 | 3 | # 3 | A11 | 27 | # 1B | | В4 | 4 | # 4 | A12 | 28 | # 1C | | B5 | 5 | # 5 | A13 | 29 | # 1D | | В6 | 6 | # 6 | A14 | 30 | # 1E | | В7 | 7 | . # 7 | A15 | 31 | # 1F | | В8 | 8 | # 8 | X0** | 32 | # 20 | | В9 | 9 | # 9 | X1 | 33 | # 21 | | В10 | 10 | # A | X2 | 34 | # 22 | | B11 | 11 | # B | Х3 | 35 | # 23 | | B12 | 12 | # C | X4 | 36 | # 24 | | В13 | 13 | # D | X5 | 37 | # 25 | | B14 | 14 | # E | X6 | 38 | # 26 | | B15 | 15 | # F | X7 | 39 | # 27 | | A0 | 16 | # 10 | V0 | 40 | # 28 | | A1 | 17 | # 11 | V1 | 41 | # 29 | | A2 | 18 | # 12 | V2 | 42 | # 2A | | A3 | 19 | # 13 | V3 | 43 | # 2B | | A4 | 20 | # 14 | V4 | 44 | # 2C | | A5 | 21 | # 15 | V5 | 45 | # 2D | | A6 | 22 | # 16 | V6 | 46 | # 2E | | A7 | 23 | # 17 | V7 | 47 | # 2F | <sup>\*</sup>When these values are used in the b parameter of the explicit address sublist, (d, b), they specify that there is no base. <sup>\*\*</sup>When these values are used in the index operand, they specify that there is no index. Examples: The following assembler statements would translate into the illustrated hexadecimal object code: | LABEL CMMND | ₿ OPERANDS | OP b | I R | b T | b M | p | |-----------------|-----------------------|----------|-----|--------|-----|------------| | L<br>L | B2,(X1),X2<br>A3,(A4) | 18<br>14 | 2 3 | 2<br>0 | 0 | 021<br>014 | | ${ t L}$ | #13,(20) | 14 | 3 | 0 | 0 | 014 | | L | X2,(X3) | 1C | 2 | 0 | 0 | 023 | | L | V3,(X1) | 1C | В | 0 | 0 | 021 | ### 6-13. ADDRESS OPERAND REGISTER ADDRESSES Registers may be addressed in the address operand (N field) of most instructions by coding a base and displacement sublist with base register specification of zero (implied or explicit). Since the N field is 12 bits, references to registers in the N field are by their hexadecimal positions from the beginning of the register bank. Refer to the example in Topic 6-12. Indexing address operand register references may produce effective addresses in virtual memory since the index word sets are greater than 48 words. Refer to Topic 6-23. Illustratively, the index word set for a register origin, x, is: Note: VM = Virtual Memory ### 6-14. ADDRESS DEVELOPMENT From the viewpoint of the user, address development occurs in two phases: (1) the assembler's interpretation of symbolic addresses into object code, and (2) the machine's interpretation of object code. The user must be able to anticipate the final result of his coding. Table 6-3 gives the specifications for direct singleword addresses. ### 6-15. ASSEMBLER TRANSLATION The general translation of an assembler statement into an object statement is described in Topics 6-6 through 6-10. Translation of an address operand into the base and displacement fields is discussed in greater detail in the following topics. ### 6-16. Symbolic Addresses Since Central Processor instructions use base and displacement addressing (M and N fields), the programmer must provide the assembler with information about the use of base registers. This is accomplished with the USING directive, Topic 4-9. In developing the base and displacement fields for a symbolic address, the assembler determines which base registers are in use, and selects that base register whose contents when subtracted from the program counter relative displacement of the symbol will give the smallest N field displacement. Then that base register's object address is assembled into the M field of the object instruction, and the derived N displacement is assembled into the N field of the object instruction. Limitations: The N displacement must be within the range: $0 \le N \le 4095$ . The N displacement is translated into the 12-bit N field as a positive number. <u>Default</u>: The base register addressed in the M field will be base register zero if no base registers are specified by the USING directive to be in use. This produces program counter relative displacements, and for $0 \le N \le 47$ produces register addressing in the address operand. Note: Note that there are three distinct displacements involved in programming the Central Processor in assembler language. First, there is the displacement of a symbolic location from the beginning of the program (section) in which it is named; this is called program counter relative displacement. Second, there is the displacement of a symbolic location from some specified base position within the program in which it is named; this, for convenience, will be called the N displacement. Third, there is the index displacement specified by the contents of an index register addressed in the index operand. Example: The following assembler code would produce the illustrated object code (note that SUM is addressed by base register 2 because a smaller displacement is possible) and results on execution: | LABEL | CMMND | OPERANDS | COUNT | OP | b R | l p l I | 1 16 1 1 | M¦k | S N | |-------|-----------|--------------|-------|----|-----|---------|----------|--------------|-----| | EXAMP | SEC | 0 | | | | | | | | | | USING | EXAMP, B1 | | | | | | | | | | USING | EXAMP+50, B2 | | | | | | | | | | BLB | B1,\$+1 | 0 | 98 | 1 | 0 | | 0 | 001 | | | AI | B1,-1 | 1 | 70 | 1 | 0 | | $\mathbf{F}$ | FFF | | | LI | X1,50 | 2 | 5C | 1 | 0 | | 0 | 032 | | | L | B2, (X1) | 3 | 18 | 2 | 0 | | 0 | 021 | | | : | : | • | | | | | | | | | | • | | | | | | | | | | LI | X1,2 | (6) | 5C | 1 | 0 | | 0 | 002 | | | • | • | | | | | | | | | | •<br>C.M. | | | | | | | | | | | ST | A3, SUM, X1 | (F) | 24 | 3 | 1 | | 2 | 00A | | | • | : | : | | | | | | | | SUM | • | • | (0.5) | | | | | | | | SUM | DATA | 0,0,0,0,0 | (3C) | 00 | 0 | 0 | | 0 | 000 | | | | | (3D) | 00 | 0 | 0 | | 0 | 000 | | | | | (3E) | 00 | 0 | 0 | | 0 | 000 | | | | | (3F) | 00 | 0 | 0 | | 0 | 000 | | | | | (40) | 00 | 0 | 0 | | 0 | 000 | ### On execution: | COUNT | REGISTER CONTENTS | | | 'S | VIRTUAL MEMORY CONTENTS | | | | | | |-------|-------------------|------|------|----|-------------------------|--|--|--|--|--| | 0 | В1 | 0000 | 0001 | | | | | | | | | 1 | В1 | 0000 | 0000 | | | | | | | | | 2 | X1 | 0000 | 0032 | | | | | | | | | 3 | В2 | 0000 | 0032 | - | + | | | | | | | 6 | X1 | 0000 | 0002 | | | | | | | | | F | A3 | 40E0 | 0000 | | 3E 40E0 0000 | | | | | | # 6-17. Explicit Base and Displacement Addresses Explicit base and displacement address interpretation is described in Topic 6-8. Base and displacement as calculated by the assembler can be avoided, whenever desirable, by explicit base and displacement addressing in the address operand. Use of explicit base and displacement requires that the programmer know both the contents of the base register he specifies and the exact displacement from that base location. The principal use of the base and displacement sublist in the address operand is to develop a register address in the M and N fields of the object code. <u>Limitations</u>: Any expression used as the d parameter must have a value within the range: $0 \le d \le 4095$ . Any expression used as the b parameter must have a value within the range: $0 \le b \le 15$ . Note: As within any list, an empty paramter is provided, by the assembler, with the value of zero; thus, if (d, b) is coded (A2), the result is an M field of zero and an N field of 12 (base 16). Example: The following assembler code would translate into the illustrated hexadecimal object code: | LABEL CMMND | OPERANDS | OP | 16 | R | βİ | Т | 15 H | M | N N | |-----------------|--------------|----|----|---|----|---|------|---|-----| | L | X5,(#7F,B1) | 1C | | 5 | | 0 | | 1 | 07F | | AF | A3, (A8), X5 | 42 | | 3 | | 5 | | 0 | 018 | ### 6-18. MACHINE TRANSLATION There are four factors that determine the mode by which the Central Processor develops the effective address: first, the operation code specifies whether the effective address is that of a singleword, halfword or doubleword; second, the indirect (most significant) bit of the T field specifies whether the address is to be obtained directly or indirectly; third the M field specifies whether a base value is to be added to the N field displacement; and fourth, the three least significant bits of the T field specify whether the address is to be modified by an index value. ### 6-19. <u>Direct Address Development</u> Direct addresses are those that are developed from the N field, the contents of the base register addressed by the M field, and the contents of the index register addressed by the T field. Restrictions: An M field of zero specifies no base value and any effective address obtained that is within the range: $0 \le EA \le 47$ , will be the address of a register. If the M field is any value other than zero, effective addresses within the range $0 \le EA \le 47$ will address low virtual momory even though the contents of the base register addressed might be zero. The first index register (index register 0, X0) cannot be used for indexing. It can be addressed in any other field of an instruction, but a value of zero in the T field specifies no indexing. ### 6-20. Singleword Addresses Singleword addressing is specified by the operation code (assembler mnemonic) and the addresses are developed as follows: - 1. Consider the 12-bit N field to be the positive N displacement. - 2. Examine the M field and. - a. if it is not zero, find the base register it addresses and add the least significant 24 bits of the contents (as a positive value) to the N deplacement, or - b. if it is zero, treat an effective address within the range of the register bank addresses as an indexable register address. - 3. Examine the three least significant bits of the T field and. - a. if it is not zero, find the index register it addresses and add the least significant 24 bits of the contents (as a two's complement value) to the result of step 2, or - b. if it is zero, ignore the index unit. - 4. Use the result of step 3 as the effective address of the instruction. Figure 6-3 illustrates the full process, and Table 6-3 gives the full specification for singleword addressing. Note: This development takes place in the arithmetic unit; neither the instruction nor the contents of the base and index registers are altered. Figure 6-3. Development of Singleword Effective Addresses Table 6-3. Development of Singleword Addresses (Direct) | ADDRESS AND | 0 : | $\leq N \leq 2^{12}$ . | - 1 | | | EFFECTIVE | | |-------------|--------------------|-----------------------------------------------------------------------------------|-------|--------|--------------------------------------------------|-----------|---------| | SYMBOLIC | EXPLICIT | M FIELD | (M)+N | ORIGIN | T FIELD | (M)+N+(T) | ADDRESS | | expr | (expa, expa) | M=0 | N≤47 | REG | T=0 | N/A | REG | | | | | N<47 | VM | T=0 | N/A | VM | | | | 0 <m≤15< td=""><td>≥0</td><td>VM</td><td>T=0</td><td>≥0</td><td>VM</td></m≤15<> | ≥0 | VM | T=0 | ≥0 | VM | | expr, expa | (expa, expa), expa | M=0 | N≤47 | REG | T=0 | N/A | R EG | | | | | | | 0 <t≤7< td=""><td>EA≤47</td><td>R EG</td></t≤7<> | EA≤47 | R EG | | | | | | | | EA>47 | VM | | | , | , | N>47 | VM | T=0 | N/A | VM | | | | | | | 0 <t≤7< td=""><td>EA≤47</td><td>REG</td></t≤7<> | EA≤47 | REG | | : | | _ | | | | EA>47 | VM | | | | 0 <m≤15< td=""><td>≥0</td><td>VM</td><td>0≤T≤7</td><td>≥0</td><td>VM</td></m≤15<> | ≥0 | VM | 0≤T≤7 | ≥0 | VM | | | (expa) | M=0 | N≤47 | REG | T=0 | N/A | REG | | | | · | N>47 | VM | T=0 | N/A | VM | | | (expa), expa | M=0 | N≤47 | REG | T=0 | N/A | REG | | | | | | | 0 <t≤7< td=""><td>EA≤47</td><td>R EG</td></t≤7<> | EA≤47 | R EG | | | | | | | | EA>47 | VM | | | | | N>47 | VM | T=0 | N/A | VM | | | | | | | .0 <t≤7< td=""><td>EA≤47</td><td>REG</td></t≤7<> | EA≤47 | REG | | | | | | | | EA>47 | VM | Where expr is a relocatable expression (symbol), expa is an absolute expression (symbol), (M) is the content of the base register, (T) is the content of the index register, REG is a register, and VM is a virtual memory location. Examples: Given that the assembler statement: L A4, SUM, X5 translates into object code: 14 4 5 1 0FF, that B1 contains: 0000 1000, and X5 contains: 0000 000A; then the address will be developed as: Given that the assembler statement: A X4, (#A, B2) translates into object code: 62 4 0 2 00A, and that B2 contains: 0000 2000; the address will be developed as: #### 6-21. Halfword Addresses Halfword addressing is specified by the operation code (assembler mnemonic), and the halfword specified may be either the left or the right halfword of a single-word depending upon the code. In either case, the addresses are developed as follows: - 1. Consider the 12-bit N field to be the positive N displacement. - 2. Examine the M Field and, - a. if it is not zero, find the base register it addresses and add the least significant 24 bits of the contents (as a positive value) to the N displacement, or - b. if it is zero, treat any effective address within the range of the register bank addresses as an indexable register address. - 3. Examine the three least significant bits of the T field and, - a. if it is not zero, find the index register it addresses and, - (1) displace its 25 least significant bits to the right by one bit and, - (2) add the value as a two's complement signed number to the result of step 2, or - b. if it is zero, ignore the index unit. - 4. Use the result of step 3 as the effective address of the instruction. Figure 6-4 illustrates the full process. Figure 6-4. Development of Halfword Effective Addresses Restrictions: The address developed from steps 1 and 2 is actually a word address; it is the operation code that specifies the use of a halfword. Note then that any symbolic address is a word address; e.g., in the following instructions LH X1, IMMOD and LR X1, IMMOD is the same word, but one instruction accesses the left half and the other accesses the right half. It is only the index parameter that produces halfword displacements. See Topic 6-25, for a description of halfword index word sets. Note: This development takes place in the arithmetic unit; neither the instruction nor the contents of the base and index registers are altered. Note: Table 6-3 is valid for halfword addressing up to determination of the origin, but when indexing is specified, the singleword displacement is only one-half the index value; e.g., in an instruction with base register 0, an N displacement of 48 would be the first virtual memory address; but with an N displacement of 0 it would require an index value of 96 to exit from the register bank (for H halfword operations). The register exit point for base register 0 addresses will be: exit = N + X, where the index value X = 2(47-N) + 2 for "H" halfword instructions and X = 2(47-N) + 1 for "L" or "R" halfword instructions. Examples: Given that the assembler statement: LH A4, (#B, B2), X1 translates into: 15 4 1 2 00B, and that B2 contains: 0000 0000, and X1 contains: 0000 000B; then the address will be developed as: and the contents of the right half of virtual memory location #10 would be loaded into the left half of A4. Given that the assembler statement: LH A4, (A6), X1 translates into: 15 4 1 0 016, and that X1 contains: 0000 0004; then the address will be developed as: and the contents of the left half of A8 will be loaded into the left half of A4. #### 6-22. Doubleword Addresses Doubleword addressing is specified by the operation code (assembler mnemonic) and the addresses are developed as follows: - 1. Consider the 12-bit N field to be the positive N displacement. - 2. Examine the M field and, - a. if it is not zero, find the base register it addresses and add the least significant 24 bits of the contents (as a positive value) to the N displacement, or - b. if it is zero, treat any effective address within the range of the register bank addresses as an indexable register address. - 3. Examine the three least significant bits of the T field and, - a. if it is not zero, find the index register it addresses and, - (1) displace its 23 least significant bits to the left by one bit and, - (2) add the value as a two's complement signed number to the result of step 2, or - b. if it is zero, ignore the index unit. - 4. Use the result of step 3 as the effective address of the instruction. Figure 6-5 illustrates the full process. Figure 6-5. Development of Doubleword Effective Addresses Restrictions: The address developed from steps 1 and 2 must be an even number so that the least significant bit will be zero; otherwise, the bit is zeroed automatically. No doubleword instruction will accept as its first word of data an odd word location; i.e., doubleword addressing is by even-odd word pairs only. The index parameter, due to the register shift, produces automatic doubleword displacements. See Topic 6-26. Note: This development takes place in the arithmetic unit; neither the instruction nor the contents of the base and index registers are altered. Note: Table 6-3 is valid for doubleword addressing up to determination of the origin, but when indexing is specified, the singleword displacement is twice the index value; e.g., in an instruction with base register 0, an N displacement of 48 would be the first virtual memory address, but with an N displacement of 0 it would require only an index value of 24 to exit from the register bank. The register exit point for base register 0 addresses will be: exit = N + X, where the index value X = 1/2 (48-N) and N must be even. Example: Given that Assembler statement: LD A6, SUMD, X1 translates into 176110F0, and that B1 contains: 0000 0000, and X1 contains: 0000 0004; then the address will be developed as: and the contents of the virtual memory location F8 and F9 will be loaded into registers A6 and A7. ### 6-23. Index Word Sets Symbolic addresses are all effectively singleword addresses as can be seen from Topics 6-16 and 6-19 through 6-22. The index value is displaced left or right or not at all to produce the proper index displacement units; viz., singleword units, halfword units, and doubleword units. This produces a set of units which can be accessed by a single symbol plus an index value; for convenience they are called index word sets. ### 6-24. Singleword Index Word Sets Singleword index word sets are straightforward; all addressable locations within the set fall within the interval: location $-(2^{23})$ , location $+(2^{23}-1)$ . Illustratively <u>Limitations</u>: The index values (i.e., contents of the index register addressed by the index operand) must be within the range: $-2^{23} \le x \le 2^{23}-1$ ### 6-25. Halfword Index Word Sets There are two types of halfword index word sets: those with left halfword origins and those with right halfword origins. Those halfword instructions whose assembler mnemonics end with the letter "H" (e.g., LH, STH) all access, without index, the left half of the location addressed; i.e., they set left halfword origins. Even index values access left halfwords, and odd index values access right halfwords. Those halfword instructions whose assembler mnemonics end with the letter "L" or the letter "R" (e.g., LL, LR) all access, without index, the right half of the location addressed; i.e., they set right halfword origins. Even index values access right halfwords, and odd index values access left halfwords. <u>Limitations</u>: The index values (i.e., contents of the index register addressed by the index operand) must be within the range: $-2^{24} \le x \le 2^{24} - 1$ . The fullword interval spanned by a left index word set is: location $-(2^{23})$ , location $+(2^{23}-1)$ . Note that the fullword interval of the set is the same as that for the singleword index word set, but that there are twice as many addressable units. The fullword interval spanned by a right halfword index word set is: location $-(2^{23})$ , location $+(2^{23}-1)$ . The right half displacement extends it one word farther than any of the other index word sets. Illustratively: #### 6.26. Doubleword Index Word Sets Doubleword index word sets originate at an even-odd doubleword location and are indexed by doubleword incremental units. Restrictions: The location name in the address operand must be the name of an even numbered location. <u>Limitations</u>: The index values (i.e., contents of the index register addressed by the index operand) must be within the range: $-2^{22} \le x \le 2^{22} - 1$ . The singleword interval spanned by a doubleword index word set is: location $-(2^{23})$ , location $+(2^{23}-1)$ . Note that the singleword interval of the set is the same as for the singleword index word set, but there are only half as many addressable units. Illustratively: ### 6-27. Indirect Address Development Indirect addresses are those that are developed from indirect address cells which are originally addressed by the T, M, and N fields of the instruction. The indirect address cells may or may not specify additional indirection and/or indexing. Figure 6-6 illustrates the indirect address cell format. Figure 6-6. Indirect Address Cell Format The indirect addresses are developed as follows: 100957 - 1. Examine the most significant bit of the T field and, - a. if it is not set to one, this is not an indirect address; develop the appropriate direct address (Topic 6-19 through 6-22). - b. if it is set to one, proceed to step 2. - 2. Develop a singleword address (Topic 6-20). - 3. Examine the indirect address cell in the location found in step 2 and, - a. if the most significant bit (bit 4) of its T field is set to one, - (1) develop an address from its address field (a full 24-bit virtual memory address) and the contents of the index register specified (if any) in its T field, and - (2) use the contents of the location obtained to repeat step 3. - b. if the most significant bit of its T field is zero, develop an appropriate 24-bit singleword, halfword, or doubleword virtual memory address. - 4. Use the terminal address obtained as the location from which or to which data is to be moved. Restrictions: All initial addresses in the T, M, and N fields (address and index operands) will be developed as singleword addresses. Only the first level of indirection can refer to a register; there is no M field in an indirect address cell and all addresses refer to virtual memory. The terminal address index increment will always be appropriate to the word size specified by the operation code. Indirect address development is in the execute mode; indirect address cells must be in execution permitted control sections. <u>Program Interruptions</u>: If any intermediately accessed location contains a one in any bit position zero through three, an illegal operation interrupt will occur. Note: Indirect addressing will not be inadvertently introduced into immediate operand instructions by introduction of a one into the most significant bit of the T field because those instructions do not examine the indirect bit. Note: Table 6-3 is valid for development of the first level of indirect address development. The table need only be altered by coding the operands with an @ sign on the left as they are expressed in the table. The T field values would then always be either: T = 8, or $8 < T \le 15$ in place of T = 0 and $0 < T \le 7$ , respectively. Example: Given that base register B1 is in use with contents of: 0000 0000, and registers X1, X2, X3, X4, X5, X6, and X7 each contains: 0000 0000, and the following assembler code transtated as illustrated: | LABEL 16 | CMMND | ₿ OPERANDS | COUNT | OP & R & T & M & N | |----------|--------|---------------|-------|---------------------| | | :<br>L | A2 ONODELA MA | : | _ | | | L | A2,@NODE10,X1 | F | 14 2 1 1 OFF | | | : | | : | - 16 T 16 ADDRESS | | NODE10 | IND | @NODE11, X2 | FF | 0 A 0001FE | | | IND | @NODE12, X3 | 100 | 0 B 0002FD | | | : | | | | | NODE11 | IND | D111, X4 | 1FE | 0 4 0003FC | | | IND | D112, X5 | lFF | 0 5 0004FB | | | • | | • | | | NODE12 | IND | D121, X6 | 2FD | 0 6 0005 <b>FA</b> | | | IND | D122, X7 | 2FE | 0 7 0006F9 | | | : | | | WORD 1 WORD 2 | | D1111 | DATA | 2,4 | 3FC | 0000 0002 0000 0004 | | | • | | | | | D112 | DATA | 3,5 | 4FB | 0000 0003 0000 0005 | | | : | | : | | | D121 | DATA | 2,3 | 5FA | 0000 0002 0000 0003 | | | : | | | | | D122 | DATA | 4,5 | 6F9 | 0000 0004 0000 0005 | then on execution of instruction F the address will be developed as: and 0000 0005 will be loaded into A2. ### 6-28. Creating Indirect Address Cells Indirect address cells with the full power of indirect addressing are normally programmed with the IND directive (see Topic 4-24). This directive provides for building T fields in the indirect address cells. This produces indirect address indexing which is convenient for the creation of tree structures of addresses. The load effective address instruction also creates effective address cells (in the base, index or vector registers), but these cells will have no T field and, thus, no intermediate or terminal indexing. Refer to the example in Topic 6-27. #### 6-29. IMMEDIATE OPERANDS If the "second" operand of an instruction is specified by the instruction to be an immediate operand, it is developed by the assembler into a 16-bit absolute value that occupies the M and N fields of the object instruction. See Figure 6-1. All assembler mnemonics for instructions which treat the M-N field as immediate data end with the letter "I", e.g., LI, AI, SI. #### 6-30. ASSEMBLER TRANSLATION The assembler will translate either numeric expressions or character strings into immediate M-N fields. #### 6-31. Numeric Immediate Operands Numeric immediate operands are right-justified in the right half of the instruction word and unspecified bit positions are filled with zeros. Negative numbers are expressed in two's complement form with the sign bit in bit 16 of the instruction word. <u>Limitations</u>: The value of an expression used as an immediate operand must be within the range: -32, $768 \le i \le +32$ , $767 (-2^{15} \le i \le 2^{15}-1)$ . ### 6-32. Character String Immediate Operands Character strings used as immediate operands are left justified in the right half of the instruction word and unspecified bit positions are filled with zeros. Restrictions: Since EBCDIC character representation is used in the ASC and EBCDIC representation requires one byte per character, a character string immediate operand is restricted to two characters in length. A single character operand will have a blank represented in the right byte. #### 6-33. MACHINE TRANSLATION The Central Processor processes the object code representation of an immediate operand as a numeric or as a logical value, depending upon the operation code, and modifies the 16-bit immediate value by the appropriate index value, depending upon the operation code and the presence of an index operand. ## 6-34. Numeric Immediate Development Numeric immediate operands are developed as signed numbers with negative values represented in two's complement form and may, if so specified or permitted, be modified by an index value. The effective immediate operand will be of the word size appropriate the operation code, i.e., will be a singleword or a halfword. #### 6-35. Singleword Numeric Immediates Singleword immediates are specified by the operation code and the effective immediate is developed as follows: - 1. Extend the sign of the 16-bit value in the M-N field to the left to produce a full 32-bit signed value. - 2. Examine the T field of the instruction (ignoring the indirect bit) and, - a. if it is zero, ignore the index unit, or - b. if it is greater than zero, - (1) add the 24-bit signed value in the index register addressed to the value obtained in step 1 (the index unit is only 24 bits in length), and - (2) extend the sign of the result to a full 32-bit singleword. - 3. Use the full singleword result as the effective immediate operand. Figure 6-7 illustrates the full process. <u>Limitations</u>: The index value in the index register addressed, if any, must be within the range: $-2^{23} \le X \le 2^{23}-1$ . The effective immediate operand produced will be within the range: $-2^{23} \le ei \le 2^{23} - 1$ . Figure 6-7. Development of Singleword Effective Immediate Operands Note: The load look ahead (LLA) instruction does not permit modification of its immediate operand, and the shift instructions place closer limitations on the possible values of the effective immediate operand. These instructions are described in Section VII. Note: The development of an effective immediate operand takes place in the arithmetic unit; the original instruction word is not modified. #### 6-36. Halfword Numeric Immediates Halfword immediates are specified by the operation code and the effective halfword immediate value is developed as follows: - 1. Consider the data in the M-N field to be a 16-bit signed value with negative numbers in two's complement form. - 2. Examine the T field of the instruction (ignoring the indirect bit) and, - a. if it is zero, ignore the index unit, or - b. if it is greater than zero, - (1) extract the 16-bit signed value from the right half of the index register addressed, and - (2) add it to the value obtained in step 1. - 3. Use the value obtained in step 2 as an effective halfword immediate operand. Figure 6-8 illustrates the full process. Figure 6-8. Development of Halfword Effective Immediate Operands Restrictions: Only the right half of an index register is accessed by the index operand (T field). <u>Limitations</u>: The index value in the right half of the index register addressed, if any, will be within the range: $-2^{15} \le X \le 2^{15}-1$ . The effective immediate operand produced will be within the range: $-2^{15} \le ei \le 2^{15}-1$ . # 6-37. Logical Immediate Development Logical immediate operands are developed as pure binary values and may, if so specified, be modified by an index value. The effective immediate operand will be of the word size appropriate to the instruction; i.e., will be a singleword or halfword. # 6-38. Singleword Logical Immediates Singleword immediates are specified by the operation code and the effective immediate is developed as follows: - Extend zeros into the left of the logical value in the M-N field to produce a full 32-bit logical value. - Examine the T field of the instruction (ignoring the indirect bit) and, - if it is zero, ignore the index unit, or - if it is greater than zero, - (1) add the 24-bit logical value in the index register addressed to the value obtained in step 1 (the index unit is only 24 bits in length), and - (2) extend zeros to the left to produce a full 32-bit logical value. - Use the full singleword result as the effective immediate operand. Figure 6-9 illustrates the process. Restrictions: Index modification is by one's complement addition only; there is no overflow into the eight most significant bits of the singleword and no end-aroundcarry. Figure 6-9. Development of Singleword Logical Immediate Operands #### 6-39. Halfword Logical Immediates Halfword immediates are specified by the operation code and are developed under the same restrictions as singleword logical immediates; i.e., index modification is by one's complement addition only. Halfword logical immediates are developed under the additional restraints that index modification is restricted to the 16 bits of the right half of the index register, and that the result is restricted to a 16-bit logical value. No extension of zeros is required. #### 6-40. BRANCH ADDRESS DEVELOPMENT Branch addresses may be either program counter relative or base relative. The branch addresses developed are always singleword addresses. Table 6-4 gives the specifications for direct branch addresses. ### 6-41. ASSEMBLER TRANSLATION The assembler translates all symbolic addresses into program counter relative branches if possible. Base relative branches can be forced by coding the address operand as an explicit base and displacement sublist. #### 6-42. Symbolic Branch Addresses A symbolic address, which in other types of instructions would be translated into base and displacement fields, is translated into program counter relative branches if the displacement from the current location counter is within the interval: location -2048, location +2047. For those branches which fall outside the program counter relative interval, the assembler produces the typical base and displacement values on the basis of the information supplied by the USING directive (see Topic 4-9). Restrictions: Branch addresses will be program counter relative whenever possible. Branch addresses never refer to the register bank. <u>Limitations</u>: For branch addresses to be program counter relative, their displacement from the current location must be within the range: $-2048 \le d \le 2047$ (i.e., $-2^{12} \le d \le 2^{12}$ -1). Example: Given that base register Bl is in use with contents of: 0000 0000, and the following assembler statements translated as illustrated. | LABEL | ⊭ CMMND | OPERANDS | COUNT | OP | b R | N T | M | 1 1/5 | N | |-------|---------------------|-------------|--------------|------|------|--------|-------|---------|--------------| | | • | | • | | | | | | | | SUM | AF | A1,(A5) | $\mathbf{F}$ | 42 | 1 | 0 | 0 | ( | 015 | | | BCLE | X1, A6, SUM | 10 | 86 | 1 | 6 | 0 | - | FFF | | | CF | A1, (A2) | 11 | CA | 1 | 0 | 0 | ( | 012 | | | BG | TOTAL | 12 | 91 | 2 | 0 | 1 | { | 3 <b>A</b> 0 | | | : | | • | | | | | | | | TOTAL | $\operatorname{ST}$ | A1, OUT, X5 | 8A0 | 24 | 1 | 5 | 1 | 1 | 410 | | | • | | : | | | | | | | | OUT | RES | 5 | A10 | five | word | ls res | serve | d | | the BCLE branch is program counter relative with a negative displacement because the location to which it branches, SUM, is within -2048 words of its own location, whereas the BG branch is base relative because the location to which it branches is greater than 2047 words from its own location (viz., 8A0 = 2208 base 10, 12=18 base 10, and 2208 - 18 = 2190). # 6-43. Explicit Base and Displacement Branch Address Either program counter relative or base relative branches can be coded explicitly with a base and displacement sublist as the address operand. ## 6-44. Program Counter Relative Branch Since a base register specification of zero specifies a program counter relative branch, the sublist can be used to produce an explicit branch displacement by coding a displacement only. This requires that the precise displacement be known. <u>Limitations:</u> For an explicit program counter relative branch, the expression used as the d parameter must have a value within the range: $-2048 \le d \le 2047$ . If the b parameter is coded, the expression used must have a value of zero: b = 0. ### 6-45. Base Relative Branch When a branch address is coded explicitly with a base register other than zero, the branch will be base relative. The contents of the base register and the precise displacement from that base location must be known. The displacement in such an instruction is always positive. <u>Limitations</u>: To produce an explicit base relative branch, the expression used as the d parameter must have a value within the range: $0 \le d \le 4095$ (i.e., $0 \le d \le 2^{12}$ -1), and the expression used as the b parameter must have a value within the range: $0 < b \le 15$ . # 6-46. Indirect Branch Addresses When the assembler statement specifies that the branch address is to be developed by indirect addressing, the address of the first level indirect address cell is obtained by the standard direct address development as described in Topics 6-16, 6-20, and 6-24. The indirect address cell format is the same as that for non-branch instructions; i.e., the terminal branch address will always be an absolute virtual memory address and never program counter relative. Refer to Topic 6-27. Restrictions: The first level of indirection cannot access the register bank; branch address development, regardless of the T and M fields, will never address a register. #### 6-47. MACHINE TRANSLATION There are three factors that determine the mode by which the Central Processor develops the effective branch address: first, the indirect (most significant) bit of the T field specifies whether the branch address is to be developed directly or indirectly; second, the M field specifies whether a direct branch address is to be program counter or base relative; and third, the three least significant bits of the T field specify whether the address is to be modified by an index value. # 6-48. Program Counter Relative Branch AddressDevelopment Direct program counter relative branch addresses are developed when the indirect bit of the T field and the M field are both zero. The address is developed by the following procedure: - 1. Consider the 12-bit N field to be a signed value with negative numbers in two's complement form. - 2. Add the value from step 1 to the current value of the program counter. - 3. Examine the three least significant bits of the T field and, - a. if they are zero, ignore the index unit, or - b. if they are greater than zero, add the 24-bit signed value in the index register addressed to the value obtained in step 2. - 4. If the branch condition is true or if the instruction is an unconditional branch, enter the result into the program counter; otherwise, go to the next instruction. Figure 6-10 illustrates the process and Table 6-4 gives the specifications for branch addressing. Figure 6-10. Program Counter Relative Branch Address Development ### 6-49. Base Relative Branch Address Development Direct base relative branch addresses are developed when the indirect bit of the T field is zero and the M field is not zero. The effective address is developed by the following procedure: - 1. Consider the 12-bit N field to be a positive value. - 2. Add the value from step 1 to the positive 24-bit value in the base register addressed by the M field - 3. Examine the three least significant bits of the T field and, - a. if they are zero, ignore the index unit, or - b. if they are not zero, add the signed 24-bit value in the index register addressed by the T field to the value from step 2. | : | Table 6-4. Development of Branch Addresses (Direct) | | | | | |------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------|--------------------------------|------------------------------------------|-------------| | ADDRESS & | ADDRESS & INDEX OPERANDS | | | | | | SYMBOLIC | EXPLICIT | M FIELD | N FIELD | T FIELD | DEVELOPMENT | | expr | (expa, expa) | M=0 | $-2^{11} \le N \le 2^{11} - 1$ | T=0 | (PC)+N | | * | | 0 <m≤15< td=""><td><math>0 \le N \le 2^{12} - 1</math></td><td>T=0</td><td>N+(M)</td></m≤15<> | $0 \le N \le 2^{12} - 1$ | T=0 | N+(M) | | expr, expa | (expa, expa), expa | M=0 | $-2^{11} \le N \le 2^{11} - 1$ | T=0 | (PC)+N | | | | | | 0 <t≤7< td=""><td>(PC)+N+(T)</td></t≤7<> | (PC)+N+(T) | | * | | 0 <m≤15< td=""><td>0≤N≤2<sup>12</sup>-1</td><td>T=0</td><td>N+(M)</td></m≤15<> | 0≤N≤2 <sup>12</sup> -1 | T=0 | N+(M) | | | | | | 0 <t≤7< td=""><td>N+(M)+(T)</td></t≤7<> | N+(M)+(T) | | | (expa) | M=0 | $-2^{11} \le N \le 2^{11} - 1$ | T=0 | (PC)+N | | | (expa), expa | M=0 | $-2^{11} \le N \le 2^{11} - 1$ | T = 0 | (PC)+N | | | | <del>.</del><br> | | 0 <t≤7< td=""><td>(PC)+N+(T)</td></t≤7<> | (PC)+N+(T) | | | | 0 <m≤15< td=""><td>0≤N≤2<sup>12</sup>-1</td><td>T=0</td><td>N+(M)</td></m≤15<> | 0≤N≤2 <sup>12</sup> -1 | T=0 | N+(M) | | | | | | 0 <t≤7< td=""><td>N+(M)+(T)</td></t≤7<> | N+(M)+(T) | Where expr is a relocatable expression (symbol), expa is an absolute expression (symbol), (PC) is the present value of the program counter, (M) is the content of the base register, and (T) is the content of the index register. <sup>\*</sup>expr will not be translated with M > 0 unless the value of N would fall outside the range: $\leq N \leq 2^{11} - 1.$ 4. If the branch condition is true or if the instruction is an unconditional branch, enter the result into the program counter; otherwise go to the next instruction. Figure 6-11 illustrates the process. Figure 6-11. Development of Base Relative Branch Addresses ### 6-50. Indirect Branch Address Development If the most significant bit of the T field is set to a one, the effective branch address will be developed indirectly. Indirect branch address development proceeds the same as that for other instructions with the exception that an M field of zero at the first level will not produce a reference to a register when $0 \le N \le 47$ . Branch address development never accesses the register bank. See Topic 6-27 for a description of the development process. # 6-51. DATA FORMATS The ASC uses two algebraic data formats: fixed point with two's complement representation for negative numbers, and floating point with excess 64 (biased) exponent representation. Fixed point values may occur in either singleword or halfword lengths. Floating point values may occur in either singleword or doubleword lengths. Figure 6-12 illustrates the machine formats of these data forms. Figure 6-12. Algebraic Data Formats #### 6-52. FIXED POINT DATA The assembler format for fixed point data is described in Topic 2-10. The range of values that any given fixed point data constant may have depends upon its proposed usage. Table 6-5 lists the ranges for some typical uses: | PURPOSE | VALUE RANGE | |----------------------------------------------|-------------------------------------------------------------------------------------------------| | GENERAL ALGEBRAIC:<br>Singleword<br>Halfword | $-2^{31} \le fx \le 2^{31} - 1$ $-2^{15} \le fx \le 2^{15} - 1$ | | INDEXES: Singleword Halfword Doubleword | $-2^{23} \le fx \le 2^{23} - 1$ $-2^{24} \le fx \le 2^{24} - 1$ $-2^{22} \le fx \le 2^{22} - 1$ | | BASES:<br>Singleword | $0 \le fx \le 2^{24} - 1$ | Table 6-5. Value Ranges of Fixed Point Data ### 6-53. FLOATING POINT DATA The assembler format for floating point data is described in Topic 2-9. #### 6-54. Normalized Floating Point Values A normalized floating point value is one in which at least one of the four most significant bits of the fraction is set to one. All floating point data created by the assembler is normalized as is required by many floating point instructions. WARNING: Although all floating point data constants created by the assembler will be normalized, there is no guarantee that all input data will be normalized. # 6-55. Infinite and Indefinite Floating Point Values Infinite $(+\infty \text{ or } -\infty)$ floating point values are output from the arithmetic unit when a floating point operation would have a resultant value that, if normalized, would require a biased exponent greater than 127. Such operations produce a floating point overflow condition (see Topic 6-60), and attempts to use these values in subsequent operations other than division will also cause the overflow condition. Indefinite floating point values are output from the arithmetic unit when input to the unit is either an indefinite form or a "dirty zero". A "dirty zero" is a floating point value with a zero fraction, but a non-zero exponent. Overflow also occurs whenever an indefinite value is input to the arithmetic unit for any operation. The hexadecimal representations of the infinite and indefinite forms are as follows: | VALUE | HEXADI | ECIMAL FORM | |------------|------------|---------------------| | V11202 | SINGLEWORD | DOUBLEWORD | | +∞ | 7FFF FFFF | 7FFF FFFF FFFF FFFF | | <b>-</b> ω | FFFF FFFF | FFFF FFFF FFFF FFFF | | IND | 7F00 0000 | 7F00 0000 0000 0000 | #### DATA FORMS | INFINITE FORMS AND INDE | FINITE FORMS: | FLOATING<br>POINT | |----------------------------------|---------------|-------------------| | FLOATING ADD | OUTPUT | OVERFLOW | | (+ \infty) + (+ \infty) | + ∞ | Yes | | (+ \infty ) + (- \infty ) | IND | Yes | | (- \infty) + (+ \infty) | IND | Yes | | (- \omega ) + (- \omega ) | <b>-</b> ∞ | Yes | | $(+ \infty) + (\underline{+} N)$ | + ∞ | Yes | | $(-\infty) + (\pm N)$ | <b>-</b> ∞ | Yes | | $(DZ) + (\underline{+} N)$ | IND | Yes | | $(DZ) + (\pm \infty)$ | IND | Yes | ### FLOATING POINT SINGLE LENGTH FORMS ARE: | + ∞ | 7FFF | FFFF | Positive infinite form. | |------------|------|------|-------------------------| | <b>-</b> & | FFFF | FFFF | Negative infinite form. | | IND | 7F00 | 0000 | Indefinite form. | #### FLOATING POINT DOUBLE LENGTH FORMS ARE: | + ∞ | 7FFF | FFFF | FFFF | FFFF | |------------|------|------|------|------| | <b>-</b> ® | FFFF | FFFF | FFFF | FFFF | | IND | 7F00 | 0000 | 0000 | 0000 | The indefinite form, 7F00 ... 00, is generated by the Arithmetic Unit when an indefinite form or a "dirty zero" appears as input to the Arithmetic Unit during a floating point arithmetic operation. A "dirty zero" is a floating point form consisting of a zero mantissa and a non-zero exponent. It has the form XX00 ... 00, where at least one X is not equal to zero. | FLOATING ADD MAGNITUDE | OUTPUT | FLOATING<br>POINT<br>OVER FLOW | |------------------------------------------------|------------|--------------------------------| | $(+ \infty) + (\pm \infty)$ | + ∞ | Yes | | $(-\infty) + (\pm \infty) $ | IND | Yes | | $(+ \infty) + (\underline{+} N)$ | + ∞ | Yes | | $(-\infty) + (\underline{+} N)$ | <b>-</b> ω | Yes | | $(\underline{+} N) + (\underline{+} \infty) $ | + ∞ | Yes | | $(DZ) + (\underline{+}N) $ | IND | Yes | | $(DZ) + (\underline{+} \infty)$ | IND | Yes | | $(\underline{+} N) + (DZ) $ | IND | Yes | | $(\underline{+} \infty) + (DZ) $ | IND | Yes | | | | FLOATING<br>POINT | |---------------------------------|----------------|-------------------| | FLOATING SUBTRACT | OUTPUT | OVERFLOW | | (+ \infty ) - (+ \infty ) | IND | Yes | | (+ ∞ ) - (- ∞ ) | + ∞ | Yes | | (-∞) - (+∞) | <b>-</b> ∞ | Yes | | (- \infty ) - (- \infty) | IND | Yes | | (+∞ ) - ( <u>+</u> N) | + ∞ | Yes | | (-∞)-( <u>+</u> N) | <b>-</b> ω | Yes | | $(\pm N) - (+ \infty)$ | <b>-</b> ∞ | Yes | | ( <u>+</u> N) - (- ∞) | + ∞ | Yes | | (DZ ) - ( <u>+</u> N) | IND | Yes | | (DZ) - $(\pm \infty)$ | IND | Yes | | $(\pm N)$ - (DZ) | IND | Yes | | $(\pm \infty)$ - (DZ) | IND | Yes | | | | | | | | FLOATING | | FLOATING<br>SUBTRACT MAGNITUDE | OUTPUT | POINT<br>OVERFLOW | | | | | | $(+\infty) - (\pm \infty)$ | IND | Yes | | $(-\infty)-(+\infty)$ | <b>-</b> ω | Yes | | $(+\infty) - (+ N)$ | + ∞ | Yes | | (-∞)- ( <u>+</u> N) | <b>-</b> ∞ | Yes | | $(+ N) - (+ \infty)$ | <del>-</del> ∞ | Yes | | (DZ ) - ( <u>+</u> N) | IND | Yes | | $(DZ) - (\underline{+} \infty)$ | IND | Yes | | $(\underline{+} N) - (DZ) $ | IND | Yes | | $(+\infty)$ - $(DZ)$ | IND | Yes | | FLOATING MULTIPLY OR FLOATING VECTOR DOT PRODUCT | OUTE | PUT | FLOATING<br>POINT<br>OVER FLOW | |--------------------------------------------------|------------|-------------------------------|--------------------------------| | (+ \infty ) \cdot (+ \infty ) | + ∞ | | Yes | | (+ \omega ) · (- \omega ) | <b>-</b> ∞ | | Yes | | (- ∞ ) · (+ ∞ ) | <b>-</b> ω | ı | Yes | | (- ω ) · (- ω ) | + ∞ | ı | Yes | | $(+ \infty) \cdot (\overline{+} N)$ | <u>+</u> ∞ | | Yes | | (- ω) · ( <u>+</u> N) | <u>+</u> ∞ | | Yes | | ( <u>+</u> ∞ ) · ( 0 ) | INI | ) | Yes | | (+N). $(0)$ | 0 | | No | | (0) (0) | 0 | | No | | (DZ) $\cdot (+ \infty)$ | INI | ) | Yes | | (DZ) · ( <u>+</u> N) | INI | ) | Yes | | (DZ)·(0) | INI | ) | Yes | | FLOATING DIVIDE | OUTPUT | FLOATING<br>POINT<br>OVERFLOW | DI VIDE<br>CHECK | | $(+ \infty) \div (+ \infty)$ | IND | Yes | No | | (+∞) ÷ (N) | + ∞ | Yes | No | | $(+\infty) \div (-N)$ | <b>-</b> ω | Yes | No | | $(-\infty) \div (N)$ | <b>-</b> ω | Yes | No | | $(-\infty) \div (-N)$ | + ∞ | Yes | No | | $(\underline{+} \infty) \div (0)$ | <u>+</u> ∞ | Yes | Yes | | $(\underline{+} N) \div (\underline{+} \infty)$ | 0 | No | No | | $(0) \div (\underline{+} \infty)$ | 0 | No | No | | $(0) \div (\pm N)$ | 0 | No | No | | ( 0 ) ÷ ( 0 ) | IND | Yes | Yes | | ( N)÷(0) | + ∞ | Yes | Yes | | (-N)÷(0) | <b>-</b> ∞ | Yes | Yes | | | | | | | FLOATING DIVIDE | OUTPUT | FLOATING<br>POINT<br>OVERFLOW | DIVIDE<br>CHECK | |------------------------------------|--------|-------------------------------|-----------------| | $(DZ) \div (\underline{+} \infty)$ | IND | Yes | No | | $(DZ) \div (\underline{+} N)$ | IND | Yes | No | | $(DZ) \div (0)$ | IND | Yes | Yes | | $(\underline{+} \infty) \div (DZ)$ | IND | Yes | No | | $(\underline{+} N) \div (DZ)$ | IND | Yes | No | | $(0) \div (DZ)$ | IND | Yes | No | ## 6-56. PROGRAM STATUS DOUBLEWORD The program status doubleword is a set of controls and registers internal to the Central Processor. They are accessible only in part to the programmer through the branch and load instructions, BLB and BLX, and the program status instructions, LAM, LAC, and SPS. For access purposes, the program status doubleword may be said to have the following format: The control state and Central Processor memory usage fields are of no interest to the Central Processor programmer, but rather to the system programmer. All the other fields are affected by and/or affect the result of one or more Central Processor instructions. #### 6-57. BRANCH OR SKIP REGISTER The branch or skip register is a four-bit field in which only the two least significant bits are used. The least significant bit is set (to one) or reset (to zero) depending upon whether, when an execute instruction, XEC, executes a branch or skip instruction, the condition for branching or skipping is true or false, respectively. See Topic 7-161. The setting of this bit is used by the branch on execute condition instruction, BXEC. The BXEC can be coded to branch on either condition true or condition false. See Topics 7-135 and 7-131. #### 6-58. COMPARE CODE The compare code is a four-bit field that is set upon execution of an arithmetic or a logical compare instruction to indicate the nature of the comparison result. Only the three least significant bits of the field are used. The compare code is used by the branch on compare code true instructions to determine whether a previously executed comparison meets the condition for branching. The specifications of the lists are as follows: | ARITHMETIC<br>COMPARISON<br>RESULT | | COMPARE<br>CODE<br>0 1cl 1cg 1ce | |------------------------------------|-------------------------|----------------------------------| | x< y | mixed ones and<br>zeros | 0,1,0,0 | | x>y | all bits ones | 0,0,1,0 | | <b>x</b> =y | all bits zeros | 0,0,0,1 | #### 6-59. RESULT CODE The result code is a four-bit field that is set according to the arithmetic or logical properties of a result emerging from the arithmetic unit to be entered into a register. The setting is changed only when a new result emerges from the arithmetic unit; thus, the result code reflects the properties of the data in the most recently modified register. Only the three least significant bits of the field are used. The result code is used by the branch on result code true instructions to determine whether the properties of the most recently acquired datum meets the condition for branching. The specifications of the bits are as follows: | ARITHMETIC<br>RESULT | LOGICAL<br>RESULT | RESULT<br>CODE<br>0 rl rg re | |----------------------|-------------------------|----------------------------------| | <b>x</b> <0 | mixed ones and<br>zeros | 0,1,0,0 | | x>0 | all bits are ones | 0,0,1,0 | | <b>x</b> =0 | all bits are zero | 0,0,0,1 | #### 6-60. ARITHMETIC EXCEPTION CONDITION CODE The arithmetic exception condition code is a four-bit field whose bits are set whenever the arithmetic unit detects one of the arithmetic exceptions: divide check, fixed point overflow, floating point exponent underflow, or floating point exponent overflow. See Topic 6-62. Illustratively: ARITHMETIC EXCEPTION CONDITION CODE D X O U <u>Divide Check</u>, <u>D</u>: The divide check bit, D, is set to one when the arithmetic unit encounters an attempt to divide by zero in either fixed or floating point operations. Fixed Point Overflow, X: The fixed point overflow bit, X, is set to one when a fixed point arithmetic or arithmetic shift operation produces a result in which a high order bit or bits would be lost (i.e., move out the left end of the data word). The operation will be completed by ignoring the lost bits. Floating Point Exponent Overflow, O: The floating point exponent overflow bit, O, will be set to one when a floating point operation produces a result in which the biased exponent would exceed 127. The operation is completed by entering a result of $+\infty$ for positive values and $-\infty$ for negative values. Floating Point Exponent Underflow, U: The floating point exponent underflow bit, U, is set to one when a floating point operation produces a result in which the biased exponent would be less than zero. The operation is completed by entering a result of true zero. # 6-61. Resetting the Arithmetic Exception Code All bits set by detection of an arithmetic exception condition remain set until reset by the execution of a branch on arithmetic exception condition (BAE) instruction in which the corresponding bit of the R field (mask operand) of the instruction contains a one. Thus, a branch on arithmetic exception of divide check will not remove the record of a previous fixed point overflow, and so on. #### Illustratively: Refer to Topics 7-131 and 7-134. The arithmetic exception condition code can be reset in its entirety by the LAC instruction, Topic 7-167. #### 6-62. ARITHMETIC EXCEPTION MASK The arithmetic exception mask is a four-bit field that is used to specify whether detection of any given arithmetic exception (or combination of exceptions) is to cause a program interruption. When a given bit is set to a zero, detection of an arithmetic exception condition corresponding to that bit will not cause program interruption; when the bit is set to one, detection of the corresponding arithmetic exception will cause program interruption. The bits of the arithmetic exception mask correspond on a one-to-one basis with those of the arithmetic exception condition code; illustratively: The arithmetic exception condition code and the arithmetic exception mask are continuously compared (within the arithmetic unit), and, at any time a bit setting of one occurs in both corresponding bits, a program interrupt signal is issued to the peripheral processor for system action. # 6-63. Setting the Arithmetic Exception Mask The arithmetic exception mask is set by the load arithmetic exception mask (LAM) instruction. Refer to Topic 7-166. Since only bits four through seven of the word accessed by the LAM instruction are loaded and all other bits of the word are ignored, the data constant which specifies the desired interrupt conditions can be built as either a fullword or a left halfword. Illustratively, the singleword accessed by LAM appears as if it were: Table 6-6. Specifications for Arithmetic Exception Mask Data Constants | INTERRUPTS | HEXADECIMAL | INTERRUPTS | HEXADECIMAL | |------------|-------------|---------------|-------------| | none | #0000 0000 | D | #0800 0000 | | · U | #0100 0000 | D or U | #0900 0000 | | 0 | #0200 0000 | D or O | #0A00 0000 | | O or U | #0300 0000 | D, O, or U | #0B00 0000 | | X | #0400 0000 | D or X. | #0C00 0000 | | X or U | #0500 0000 | D, X, or U | #0D00 0000 | | X or O | #0600 0000 | D, X, or O | #0E00 0000 | | X, O, or U | #0700 0000 | D, X, O, or U | #0F00 0000 | #### 6-64. PROGRAM COUNTER The program counter is a 24-bit field which contains the current instruction address. The value in this field informs the Central Processor which instruction in the program to begin processing when the signal from the Peripheral Processor (system) starts processing. The capability of the Central Processor to store the program status doubleword and then reinstate it (both on signal from the Peripheral Processor) enables program interruptions by the system without destruction of the currently executing program. #### SECTION VII ### THE SCALAR INSTRUCTIONS FOR THE CENTRAL PROCESSOR # 7-1. INTRODUCTION This section describes the scalar instructions implemented in the Central Processor. The assembler mnemonic for each instruction is given with the instruction name, and then a description of the instruction with its operands, restrictions, limitations, and other programming information follows. # 7-2. LOAD REGISTER INSTRUCTIONS Table 7-1 lists the load register instructions discussed on the following pages. Table 7-1. Load Register Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|----------------------------------------------------|-------| | L | Load, Word | 7-3 | | LH | Load, Halfword | 7-4 | | LR | Load, Right Halfword from Right | 7-5 | | LL | Load, Left Halfword from Right | 7-6 | | LD | Load, Doubleword | 7-7 | | LI | Load Immediate, Word | 7-8 | | LIH | Load Immediate, Halfword | 7-9 | | LN | Load Negative, Fixed Point Word | 7-10 | | LNH | Load Negative, Fixed Point Halfword | 7-11 | | LNF | Load Negative, Floating Point Word | 7-12 | | LND | Load Negative, Floating Point Doubleword | | | LM | Load Magnitude, Fixed Point Word | | | LMH | Load Magnitude, Fixed Point Halfword | | | LMF | Load Magnitude, Floating Point Word | | | LMD | Load Magnitude, Floating Point Doubleword | | | LNM | Load Negative Magnitude, Fixed Point Word | 7-18 | | LNMH | Load Negative Magnitude, Fixed Point Halfword | 7-19 | | LNMF | Load Negative Magnitude, Floating Point Word | 7-20 | | LNMD | Load Negative Magnitude, Floating Point Doubleword | 7-21 | | LO | Load Ones Complement, Word | 7-22 | | LF . | Load Register File | 7-23 | | LFM | Load Register Files, Multiple | 7-24 | ### 7-3. LOAD, WORD (L) The instruction L causes the data in the effective address to replace the contents of the register addressed by the register operand. ### GENERAL FORM: | | LABEL | COMMAND | 1 1<br>1 1 | OPERANDS | | |-----------|----------|---------|------------|---------------|--| | | [symbol] | 6 L | R | r,[@][=]n[,x] | | | Examples: | | L | | B2, (A3) | | | | | L | | X1,@NUM, X3 | | # Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |-------------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | BR, AR, XR, | BR, AR, XR, | zero or | BR, AR, XR, VR, | | or VR | VR, or CM | XR | or CM | ### Program Status: | PROGRAM INTERRUPTIONS | |-----------------------| | none | | | | | | | | | | - | Note: If base register zero (B0) is addressed by the register operand, the result code is set according to the algebraic value in the effective address although base register zero remains set to zero. ### 7-4. LOAD, HALFWORD (LH) The instruction LH causes the data in the effective halfword address to replace the contents of the left half of the arithmetic register addressed by the register operand. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. ## GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|---------------| | | [symbol] | TH R | r,[@][=]n[,x] | | Examples: | | LH | A1,=#12F3 | | | | LH | A2, NUM, X3 | | | | | | # Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |-----------------------|---------------------------------------|------------------|----------------|----------------------------------------| | left half of AR, only | left half<br>of BR, AR,<br>XR, VR, or | zero<br>XR | n/a<br>even | left half of BR,<br>AR, XR, VR, or CM | | | СМ | | odd | right half of BR,<br>AR, XR, VR, or CM | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | | | | | | | | | | | Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. # 7-5. LOAD, RIGHT HALFWORD FROM RIGHT (LR) The instruction LR causes the data in the effective halfword address to replace the contents of the right half of the arithmetic register addressed by the register operand. Terminal index displacement is by halfword increments beginning from the initial right halfword of the index word set. ### GENERAL FORM: | Examp | ples: | |-------|-------| | LABEL | COMMAND | <br> <br> | OPERANDS | |----------|---------|-------------|---------------| | [symbol] | LR | R | r,[@][=]n[,x] | | | LR | | A1, WORD | | LR | | | A1,@WORD,X1 | | İ | | | | # Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|-------------------------|------------------|----------------|---------------------------------------| | right | right half | zero | n/a | right half of BR, | | half of AR, only | of BR, AR<br>XR, VR, or | XR | even | AR, XR, VR, or CM | | | СМ | | odd | left half of BR,<br>AR, XR, VR, or CM | # Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | | | | | | | | | | | Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. # 7-6. LOAD, LEFT HALFWORD FROM RIGHT (LL) The instruction LL causes the data in the effective halfword address to replace the contents of the left half of the arithmetic register addressed by the register operand. Terminal index displacement is by halfword increments beginning from the initial right halfword of the index word set. ## GENERAL FORM: | | LABEL | | COMMAND | 1 1 | OPERANDS | | |-----------|----------|---|---------|-----|---------------|--| | | [symbol] | R | LL | R | r,[@][=]n[,x] | | | Examples: | | | LL | | Al, WORD | | | | | | LL | | Al,@WORD,Xl | | | | | | | | | | ## Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |-----------------------------|----------------------------------------|------------------|----------------|----------------------------------------| | left<br>half of<br>AR, only | right half<br>of BR, AR,<br>XR, VR, or | zero<br>XR | n/a<br>even | right half of BR,<br>AR, XR, VR, or CM | | · | СМ | | odd | left half of BR,<br>AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | | | | | | | | Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. ### 7-7. LOAD, DOUBLEWORD (LD) The instruction LD causes the data in the effective doubleword address to replace the contents of the even-odd arithmetic register pair addressed by the register operand. Terminal index displacement is by doubleword increments of even-odd word pairs. #### GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | |-----------|----------|---------|---|---------------| | | [symbol] | LD | R | r,[@][=]n[,x] | | Examples: | | LD | | A2, ADDR | | | | LD | | A2,@ADDR, X3 | | | | | | | ## Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | ## Program Status: | PROGRAM INTERRUPTIONS | |----------------------------------| | specification error if AR is odd | | | | | | | Restrictions: Both register and effective addresses must be even valued. Note: Indirect address indexing is by singleword increments although the terminal indexing is by doubleword increments. # 7-8. LOAD IMMEDIATE, WORD (LI) The instruction LI causes the effective immediate operand to replace the contents of the register addressed by the register operand. # GENERAL FORM: | | LABEL | COMMAND | <br> | OPERANDS | | |-----------|----------|---------|------|-------------|--| | | [symbol] | R LI | R | r, i[, x] | | | Examples: | | LI | | X2,123 | | | | | LI | | V1,#3CF9,X1 | | | | | | | | | # Addressing: | REGISTER | INDEX | IMMEDIATE | |---------------|------------|-------------------------------------| | OPERAND | OPERAND | MODIFIER | | AR, XR, or VR | zero<br>XR | none $-2^{23} \le m \le 2^{23} - 1$ | # Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | | | | | | | | | | | | | | | | | | | | | | | # 7-9. LOAD IMMEDIATE, HALFWORD (LIH) The instruction LIH causes the effective immediate operand to replace the contents of the left half of the arithmetic register addressed by the register operand. # GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | |-----------|----------|---|---------|--|--------------| | | [symbol] | R | LIH | | r, i[, x] | | Examples: | | | LIH | | A2,#36C9 | | | | | LIH | | A1, 1236, X4 | | | | | | | | # Addressing: | REGISTER | INDEX | IMMEDIATE | |-----------------------|--------------------------|-------------------------------------| | OPERAND | OPERAND | MODIFIER | | left half of AR, only | zero<br>XR right<br>half | none $-2^{15} \le m \le 2^{15} - 1$ | # Program Status: | PROGRAM INTERRUPTIONS | |-----------------------| | none | | • . | | | | , | | | | | | | | | | | # 7-10. LOAD NEGATIVE, FIXED POINT WORD (LN) The instruction LN causes the algebraic negative (twos complement) of the value in the effective address to replace the contents of the arithmetic register addressed by the register operand. # GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | |---------------|----------|---------|---|---------------| | Examples: | [symbol] | k LN | R | r,[@][=]n[,x] | | Examples: | | LN | | A1, RSLT | | | | LN | | A1,@ADDR,X1 | | | | | | | | ) Addrossing. | | | | | Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | Note: Fixed point overflow and failure to change from negative to positive occur for the case of the algebraically largest negative number; i.e., the two complement of 8000 0000 (base 16) is 8000 0000. #### 7-11. LOAD NEGATIVE, FIXED POINT HALFWORD (LNH) The instruction LNH causes the algebraic negative (two's complement) of the value in the effective halfword address to replace the contents of the left half of the arithmetic register addressed by the register operand. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. #### GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | |-----------|----------|---------|---|---------------| | | [symbol] | LNH | R | R,[@][=]n[,x] | | Examples: | | LNH | | Al, RSLT | | | | LNH | | A1,@ADDR, X1 | | | | | | | # Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|--------------------------|------------------|----------------|----------------------------------------| | left | left half | zero | n/a | left half of BR, | | half of AR, only | of BR, AR,<br>XR, VR, or | XR | even | AR, XR, VR, or CM | | ,, | СМ | | odd | right half of BR,<br>AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or _ | fixed point overflow | | | | | | | | | | | | | Note: Fixed point overflow and failure to change from negative to positive occur for the case of the algebraically largest negative number; i.e., the two complement of 8000 (base 16) is 8000. # 7-12. LOAD NEGATIVE, FLOATING POINT WORD (LNF) The instruction LNF causes the algebraic negative (sign change only) of the value in the effective address to replace the contents of the arithmetic register addressed by the register operand. # GENERAL FORM: | | LABEL | COMMAND | <br> | |-----------|----------|---------|--------------| | | [symbol] | LNF | | | Examples: | | LNF | A1, FLOAT | | | | LNF | A1,(A2) | | | | LNF | A1,@(A3), X2 | | | | | | # Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | ### Program Status: | PROGRAM INTERRUPTIONS | |-----------------------| | none | | | | | | | | | | | | | | | | | ## 7-13. LOAD NEGATIVE, FLOATING POINT DOUBLEWORD (LND) The instruction LND causes the algebraic negative (sign change only) of the value in the effective doubleword address to replace the contents of the even-odd arithmetic register pair addressed by the register operand. Terminal index displacement is by doubleword increments of even-odd word pairs. #### GENERAL FORM: | Examples: | | |-----------|--| | LABEL | <br> <br> <u> </u> | COMMAND | ND OPERANDS | | |----------|-----------------------|---------|---------------|---------------| | [symbol] | R | LND | R | r,[@][=]n[,x] | | LND | | | A2, (A4) | | | LND | | | A2,@ADDR,X1 | | | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|----------------------------------| | +, 0, or - | specification error if AR is odd | Restrictions: Both register and effective addresses must be even valued. Note: Indirect address indexing is by singleword increments although the terminal indexing is by doubleword increments. ### 7-14. LOAD MAGNITUDE, FIXED POINT WORD (LM) The instruction LM causes the absolute value of the data in the effective address to replace the contents of the arithmetic register addressed by the register operand. #### GENERAL FORM: | | LABEL | COMMAND | <br> <br> | OPERANDS | |-----------|----------|---------|-------------|---------------| | | [symbol] | LM | R | r,[@][=]n[,x] | | Examples: | | LM | | A1, WORD | | | | LM | | A1,@ADDR,X1 | | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | ### Program Status: | xed point overflow | |--------------------| | , | | | | | | | | | Note: A result code of negative and fixed point overflow are possible only for the case of the algebraically largest negative number, i.e., 8000 0000 (base 16). #### 7-15. LOAD MAGNITUDE, FIXED POINT HALFWORD (LMH) The instruction LMH causes the absolute value of the data in the effective half-word address to replace the contents of the left half of the arithmetic register addressed by the register operand. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. #### GENERAL FORM: | Examp | les: | |-------|------| | LABEL | | COMMAND | | OPERANDS | |----------|---|---------|--------------|---------------| | [symbol] | R | LMH | R | r,[@][=]n[,x] | | LMH | | | A1, WORD | | | LMH | | | A1,@ADDR, X2 | | | İ | | | | | #### Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |-----------------------|---------------------------------------|------------------|----------------|----------------------------------------| | left half of AR, only | left half<br>of BR, AR,<br>XR, VR, or | zero<br>XR | n/a<br>even | left half of BR,<br>AR, XR, VR, or CM | | | СМ | | odd | right half of BR,<br>AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | | | | | | | | Note: A result code of negative and fixed point overflow are possible only for the case of the algebraically largest negative number, i.e., 8000 (base 16). Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. #### 7-16. LOAD MAGNITUDE, FLOATING POINT WORD (LMF) The instruction LMF causes the absolute value of the data in the effective address to replace the contents of the arithmetic register addressed by the register operand. #### GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | |-----------|----------|---------|---|---------------| | | [symbol] | K LMF | R | r,[@][=]n[,x] | | Examples: | | LMF | | A1, RSLT | | | | LMF | | A1,@ADDR,X3 | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | + or 0 | none | | | | | | | | | | | | | | | | Note: A negative result is not possible. ### 7-17. LOAD MAGNITUDE, FLOATING POINT DOUBLEWORD (LMD) The instruction LMD causes the absolute value of the data in the effective double-word address to replace the contents of the even-odd arithmetic register pair addressed by the register operand. Terminal index displacement is by doubleword increments of even-odd word pairs. #### GENERAL FORM: | | LABEL | | COMMAND | | Í | OPERANDS | | |-----------|----------|---|---------|--|---|---------------|--| | | [symbol] | R | LMD | | R | r,[@][=]n[,x] | | | Examples: | | | LMD | | | A2, RSLT | | | | | | LMD | | | A4, @ADDR, X1 | | | | | | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|----------------------------------| | + or 0 | specification error if AR is odd | | | | | | | | | | Restrictions: Both register and effective addresses must be even valued. Note: Indirect address indexing is by singleword increments although the terminal indexing is by doubleword increments. #### 7-18. LOAD NEGATIVE MAGNITUDE, FIXED POINT WORD (LNM) The instruction LNM causes the negative (two's complement) of the absolute value of the data in the effective address to replace the contents of the arithmetic register addressed by the register operand. #### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|------------|---------|--------------| | | [symbol] & | LNM | | | Examples: | | LNM | A1, (A2) | | | | LNM | A1,@ADDR, X2 | | A 44 | | | | Addressing. | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | 0 or - | none | | | | | | | | | | | | - | | | | Note: A positive result is not possible. ### 7-19. LOAD NEGATIVE MAGNITUDE, FIXED POINT HALFWORD (LNMH) The instruction LNMH causes the negative (two's complement) of the absolute value of the data in the effective halfword address to replace the contents of the left half of the arithmetic register addressed by the register operand. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. #### GENERAL FORM: | • | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|---------------| | | [symbol] | LNMH | r,[@][=]n[,x] | | Examples: | | LNMH | Al, RSLT | | | | LNMH | A1,@ADDR,X1 | | | | | | #### Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |-----------------------|---------------------------------------|------------------|----------------|----------------------------------------| | left half of AR, only | left half<br>of BR, AR,<br>XR, VR, or | zero<br>XR | n/a<br>even | left half of BR,<br>AR, XR, VR, or CM | | | CM | | odd | right half of BR,<br>AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | 0 or - | none | | | | | | | | | | Note: A positive result is not possible. Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. ### 7-20. LOAD NEGATIVE MAGNITUDE, FLOATING POINT WORD (LNMF) The instruction LNMF causes the negative (sign change only) of the absolute value of the data in the effective address to replace the contents of the arithmetic register addressed by the register operand. #### GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | | |-----------|----------|---------|----|---------------|--| | | [symbol] | LNMF | 18 | r,[@][=]n[,x] | | | Examples: | | LNMF | | A1,(A2) | | | | | LNMF | | Al,@ADDR,X3 | | | | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | 0 or - | none | | | · | | | | | | | | | | | | | Note: A positive result is not possible. ### 7-21. LOAD NEGATIVE MAGNITUDE, FLOATING POINT DOUBLEWORD (LNMD) The instruction LNMD causes the negative (sign change only) of the absolute value of the data in the effective doubleword address to replace the contents of the even-odd arithmetic register pair addressed by the register operand. Terminal index displaced is by doubleword increments of even-odd word pairs. #### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|--------------| | | [symbol] | LNMD | | | Examples: | | LNMD | A2, RSLT | | | | LNMD | A4,@(A3), X1 | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-----------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|----------------------------------| | 0 or - | specification error if AR is odd | Restrictions: Both register and effective addresses must be even valued. Note: A positive result is not possible. Note: Indirect address indexing is by singleword increments although the terminal indexing is by doubleword increments. ### 7-22. LOAD ONE'S COMPLEMENT, WORD (LO) The instruction LO causes the one's complement of the data in the effective address to replace the contents of the arithmetic register addressed by the register operand. #### GENERAL FORM: | | LABEL | COMMAND | <br> <br> - | OPERANDS | |-----------|----------|---------|-----------------|---------------| | | [symbol] | LO | R | r,[@][=]n[,x] | | Examples: | | LO | | A1,(A1) | | | | LO | | A1,@ADDR,X1 | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR VR, | | | VR, or CM | XR | or CM | | PROGRAM INTERRUPTIONS | |-----------------------| | none | | | | | | | | | | | | | | | | | #### 7-23. LOAD REGISTER FILE (LF) The instruction LF causes the contents of the word octet beginning at the effective address to replace the contents of the eight-word register file addressed by the mask operand. #### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | |-----------|----------|---|---------|---|---------------| | | [symbol] | R | LF | R | m,[@]n[,x] | | Examples: | | | LF | | 1,BASEREG, X2 | | | | | LF | | 4,@VECTR,X3 | | | | | *** | | | #### Addressing: | MASK<br>VALUE | REGISTER FILE<br>LOADED | ADDRESS<br>OPERAND | INDEX<br>OPERAND | EFFECTIVE<br>ADDRESS | | |----------------------------|----------------------------------------------|-----------------------------|------------------|------------------------------------------------------------------|--| | 0<br>1<br>2<br>3<br>4<br>5 | BR-A<br>BR-B<br>AR-C<br>AR-D<br>XR-X<br>VR-V | BR, AR,<br>XR, VR,<br>or CM | zero<br>or<br>XR | register file BR-A, BR-B, AR-C, AR-D, XR-X, or VR-V, or CM octet | | | 6 | no operation, take next instruction | | | | | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | Restrictions: The effective address will be forced to a multiple of eight, i.e., to an octet boundary. Note: With a mask value of six, all parts of this instruction are assembled and it can be made operative by programmed alteration of the R field. Note: Base register zero is wired to zero and will not be altered if file A is loaded. ### 7-24. LOAD REGISTER FILES, MULTIPLE (LFM) The instruction LFM causes the contents of the six central memory octets that begin at the effective address to replace the contents of the six eight-word register files. #### GENERAL FORM: | | LABEL | <br> <br> | COMMAND | | OPERANDS | |-----------|----------|-----------|---------|---|-----------| | | [symbol] | R | LFM | R | [@]n[,x] | | Examples: | | | LFM | | SAVEREG | | | | | LFM | | @ADDR, X1 | | | | | | | | #### Addressing: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | |-----------------|---------------|-------------------| | CM only | zero or XR | CM only | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-------------------------------------------------------------------| | not affected | specification error if effective<br>address is a register address | Restrictions: The effective address must refer to central memory and will be forced to a multiple of eight, i.e., to an octet boundary. Note: Base register zero will not be altered since it is wired to zero. ### 7-25. STORE INSTRUCTIONS Table 7-2 lists the store instructions discussed on the following pages. Table 7-2. Store Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|-------------------------------------------|-------| | ST | Store Word | 7-26 | | STH | Store Halfword | 7-27 | | STR | Store Right Halfword Into Right | 7-28 | | STL | Store Left Halfword Into Right | 7-29 | | STD | Store Doubleword | 7-30 | | STZ | Store Zero, Word | 7-31 | | STZH | Store Zero, Halfword | 7-32 | | STZD | Store Zero, Doubleword | 7-33 | | STN | Store Negative, Fixed Point Word | 7-34 | | STNH | Store Negative, Fixed Point Halfword | 7-35 | | STNF | Store Negative, Floating Point Word | 7-36 | | STND | Store Negative, Floating Point Doubleword | 7-37 | | STO | Store Ones Complement, Word | 7-38 | | STOH | Store Ones Complement, Halfword | 7-39 | | STF | Store Register File | 7-40 | | STFM | Store Register Files, Multiple | 7-41 | # 7-26. STORE WORD (ST) The instruction ST causes the data in the register addressed by the register operand to replace the contents of the effective address. ### **GENERAL FORM:** | Exam | ples | : | |------|------|---| | LABEL | | COMMAND | <br> !<br> 1 | OPERANDS | |----------|---|---------|-----------------|------------| | [symbol] | R | ST | | r,[@]n[,x] | | | | ST | | B1, RSLT | | ST | | | X2, SAVEREG, X1 | | | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |-------------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | BR, AR, XR, | BR, AR, XR, | zero or | BR, AR, XR, VR, | | or VR | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | · | | | | | | | | | | | | | | | | | | | | | | ### 7-27. STORE HALFWORD (STH) The instruction STH causes the data in the left half of the arithmetic register addressed by the register operand to replace the contents of the effective halfword address. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. #### GENERAL FORM: | • | LABEL | I<br>I<br> | COMMAND | 1 1 | OPERANDS | | |-----------|----------|------------|---------|-----|-------------|--| | · | [symbol] | R | STH | R | r,[@]n[,x] | | | Examples: | | - | STH | | Al,STORE | | | | | | STH | | A2,@ADDR,X1 | | | | | | | | • | | #### Addressing: | | REGISTER | ADDRESS | INDEX | INDEX | EFFECTIVE | |---|----------------------------|---------------------------------------------|------------|--------------------|------------------------------------------------------------------------| | | OPERAND | OPERAND | OPERAND | VALUE | ADDRESS | | 1 | eft<br>nalf of<br>AR, only | left half<br>of BR, AR,<br>XR, VR, or<br>CM | zero<br>XR | n/a<br>even<br>odd | left half of BR, AR, XR, VR, or CM right half of BR, AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | | | | | | | | Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. ### 7-28. STORE RIGHT HALFWORD INTO RIGHT (STR) The instruction STR causes the data in the right half of the arithmetic register addressed by the register operand to replace the contents of the effective halfword address. Terminal index displacement is by halfword increment beginning from the initial right halfword of the index word set. #### GENERAL FORM: | • | LABEL | COMMAND | | OPERANDS | | |-----------|----------|---------|---|--------------|--| | | [symbol] | STR | R | r,[@]n[,x] | | | Examples: | | STR | | A3, RSLT | | | | | STR | | A2,@RSLT, X1 | | | : | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | INDEX | EFFECTIVE | |------------------------|----------------------------------------------|------------|--------------------|---------------------------------------------------------------------------------| | OPERAND | OPERAND | OPERAND | VALUE | ADDRESS | | right half of AR, only | right half<br>of BR, AR,<br>XR, VR, or<br>CM | zero<br>XR | n/a<br>even<br>odd | right half of BR,<br>AR, XR, VR, or CM<br>left half of BR,<br>AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | | | | | Note: Indirect address indexing by singleword increments although the terminal indexing is by halfword increments. #### 7-29. STORE LEFT HALFWORD INTO RIGHT (STL) The instruction STL causes the data in the left half of the arithmetic register addressed by the register operand to replace the contents of the effective halfword address. Terminal index displacement is by halfword increments beginning from the initial right halfword of the index word set. #### GENERAL FORM: | Evamples | | |-----------|----------| | Examples. | xamples: | | LABEL | <br> | COMMAND | | OPERANDS | |----------|------|---------|--------------|------------| | [symbol] | R | STL | R | r,[@]n[,x] | | | | STL | | A1, (A2) | | STL | | | A2,@RSLT, X1 | | | | | | | | #### Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |-----------------------|----------------------------------------|------------------|----------------|----------------------------------------| | left half of AR, only | right half<br>of BR, AR,<br>XR, VR, or | zero<br>XR | n/a<br>even | right half of BR,<br>AR, XR, VR, or CM | | | СМ | | odd | left half of BR,<br>AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | | | | | | | | | | | Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. #### 7-30. STORE DOUBLEWORD (STD) The instruction STD causes the data in the even-odd arithmetic register pair addressed by the register operand to replace the contents of the effective doubleword address. Terminal index displacement is by doubleword increments of even-odd word pairs. #### GENERAL FORM: | | LABEL | COMMAND | 1 1 | OPERANDS | | |-----------|----------|---------|-----|---------------|---| | | [symbol] | STD | R | r,[@]n[,x] | | | Examples: | | STD | | A2, RSLT | | | | | STD | | A2, @ADDR, X2 | | | | | | | | j | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|----------------------------------| | +, 0, or - | specification error if AR is odd | Restrictions: Both register and effective addresses must be even valued. Note: Indirect address indexing is by singleword increments although the terminal indexing is by doubleword increments. #### 7-31. STORE ZERO, WORD (STZ) The instruction STZ causes a word of zeros to be stored into the effective address. #### GENERAL FORM: | | LABEL | COMMAND | [ | OPERANDS | |-----------|----------|---------|---|-----------| | Examples: | [symbol] | STZ | R | [@]n[,x] | | Examples: | | STZ | | RSLT | | | | STZ | | @(A1), X1 | | A 11 | | | | | ### Addressing: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | |-----------------------|---------------|-----------------------| | BR, AR, XR, VR, or CM | zero or XR | BR, AR, XR, VR, or CM | | | | | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | zero | none | | | | | | | | | | | | | | | | | | | | | | | | | #### 7-32. STORE ZERO, HALFWORD (STZH) The instruction STZH causes a halfword of zeros to be stored into effective halfword address. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. #### GENERAL FORM: | | LABEL | | COMMAND | l<br>L | OPERANDS | |-----------|----------|---|---------|--------|-----------| | _ | [symbol] | R | STZH | R | [@]n[,x] | | Examples: | | | STZH | | RSLT | | | | | STZH | | @(A1), X1 | | | | | | | | #### Addressing: | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------------------------|------------------|----------------|----------------------------------------| | left half<br>of BR, AR,<br>XR, VR, or | zero<br>XR | n/a<br>even | left half of BR,<br>AR, XR, VR, or CM | | СМ | | odd | right half of BR,<br>AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | zero | none | | | | | | | | | | | | | Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. #### 7-33. STORE ZERO, DOUBLEWORD (STZD) The instruction STZD causes a doubleword of zeros to be stored into the effective doubleword address. Terminal index displacement is by doubleword increments of even-odd word pairs. #### GENERAL FORM: | | LABEL | I | COMMAND | | OPERANDS | |-----------|----------|---|---------|---|-----------| | | [symbol] | R | STZD | R | [@]n[,x] | | Examples: | | | STZD | | RSLT | | | | | STZD | | @(A3), X1 | | | | | | | | #### Addressing: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | |-----------------------|---------------|----------------------------------------| | BR, AR, XR, VR, or CM | zero or XR | BR, AR, XR, VR, or<br>CM even-odd pair | #### Program Status: | PROGRAM INTERRUPTIONS | |-----------------------| | none | | | | | | | | | Restrictions: The effective doubleword address must be even valued. Note: Indirect address indexing is by singleword increments although the terminal indexing is by doubleword increments. ### 7-34. STORE NEGATIVE, FIXED POINT WORD (STN) The instruction STN causes the algebraic negative (two's complement) of the value in the arithmetic register addressed by the register operand to be stored into the effective address. #### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | | |-----------|----------|---|---------|---|-------------|---| | | [symbol] | R | STN | R | r,[@]n[,x] | - | | Examples: | | | STN | | A1, (A1) | | | | | | STN | | A1,@ADDR,X1 | | | | | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | | | | | | | | <u>Note</u>: Fixed point overflow is possible only for the algebraically largest negative value and the value stored is the same as the value in the register; i. e., the two's complement of 8000 0000 (base 16) is 8000 0000. #### 7-35. STORE NEGATIVE, FIXED POINT HALFWORD (STNH) The instruction STNH causes the algebraic negative (two's complement) of the value in the left half of the arithmetic register addressed by the register operand to be stored into the effective halfword address. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. #### GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | |-----------|----------|---------|---|-------------| | | [symbol] | STNH | R | r,[@]n[,x] | | Examples: | | STNH | | A1, RSLT | | | | STNH | | A1,@ADDR,X1 | | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | INDEX | EFFECTIVE | |----------|---------------------------------------------|------------|--------------------|------------------------------------------------------------------------| | OPERAND | OPERAND | OPERAND | VALUE | ADDRESS | | 1 | left half<br>of BR, AR,<br>XR, VR, or<br>CM | zero<br>XR | n/a<br>even<br>odd | left half of BR, AR, XR, VR, or CM right half of BR, AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | | | | | Note: Fixed point overflow is possible only for the algebraically largest negative value and the value stored is the same as the value in the register; i.e., the two's complement of 8000 (base 16) is 8000. Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. ## 7-36. STORE NEGATIVE, FLOATING POINT WORD (STNF) The instruction STNF causes the algebraic negative (sign change only) of the value in the arithmetic register addressed by the register operand to be stored into the effective address. #### GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | |-----------|------------|---------|---|-------------| | | [symbol] 🎉 | STNF | R | r,[@]n[,x] | | Examples: | | STNF | | A1, FLOAT | | | | STNF | | A1,@ADDR,X1 | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | | | · | | | | | | | | | | | | | | | | | | | | #### 7-37. STORE NEGATIVE, FLOATING POINT DOUBLEWORD (STND) The instruction STND causes the algebraic negative (sign change only) of the value in the even-odd arithmetic register pair addressed by the register operand to be stored into the effective doubleword address. Terminal index displacement is by doubleword increments of even-odd word pairs. #### GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | | |-----------|----------|---------|---|-------------|--| | | [symbol] | STND | R | r,[@]n[,x] | | | Examples: | - | STND | | A2, FLOAT | | | | | STND | | A2,@ADDR,X2 | | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|----------------------------------| | +, 0, or - | specification error if AR is odd | | | | | | | | | | | | | Restrictions: Both register and effective addresses must be even valued. Note: Indirect address indexing is by singleword increments although the terminal indexing is by doubleword increments. # 7-38. STORE ONE'S COMPLEMENT, WORD (STO) The instruction STO causes the one's complement of the data in the arithmetic register addressed by the register operand to be stored into the effective address. ### GENERAL FORM: | · | LABEL | COMMAND | | OPERANDS | |-----------|----------|---------|---|--------------| | | [symbol] | K STO | R | r,[@]n[,x] | | Examples: | | STO | | A1, NEG | | | | STO | | Al,@ADDR, X2 | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | | | | · | | | | | | | | | | | | | | | | # 7-39. STORE ONE'S COMPLEMENT, HALFWORD (STOH) The instruction STOH causes the one's complement of the data in the left half of the arithmetic register addressed by the register operand to be stored into the effective halfword address. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. #### GENERAL FORM: | 1 | LABEL | | COMMAND | <br> <br> 1 | <br> | OPERANDS | |-----------|----------|---|---------|-------------|-----------|-------------| | | [symbol] | R | STOH | 18 | <br> <br> | r,[@]n[,x] | | | | | STOH | | | A1, RSLT | | Examples: | | | STOH | | | Al,@ADDR,X1 | | | | | | | | | | | | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | INDEX | EFFECTIVE | |----------|---------------------------------------------|------------|--------------------|------------------------------------------------------------------------| | OPERAND | OPERAND | OPERAND | VALUE | ADDRESS | | | left half<br>of BR, AR,<br>XR, VR, or<br>CM | zero<br>XR | n/a<br>even<br>odd | left half of BR, AR, XR, VR, or CM right half of BR, AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | | | | | | | | Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. #### 7-40. STORE REGISTER FILE (STF) The instruction STF causes the contents of the eight-word register file addressed by the mask operand to be stored into the word octet beginning at the effective address. #### GENERAL FORM: | | LABEL | COMMAND | D OPERANDS | | |-----------|----------|---------|--------------|--| | | [symbol] | 8TF | m,[@]n[,x] | | | Examples: | | STF | 7, SAVEREG | | | • | | STF | 5,@ADDR,X1 | | | | | | | | ### Addressing: | MASK<br>VALUE | REGISTER FILE<br>STORED | ADDRESS<br>OPERAND | INDEX<br>OPERAND | EFFECTIVE<br>ADDRESS | | | |----------------------------|----------------------------------------------|-----------------------------|------------------|----------------------------------------------------------------|--|--| | 0<br>1<br>2<br>3<br>4<br>5 | BR-A<br>BR-B<br>AR-C<br>AR-D<br>XR-X<br>VR-V | BR, AR,<br>XR, VR,<br>or CM | zero<br>or<br>XR | register file BR-A, BR-B AR-C, AR-D XR-X, or VR-V, or CM octet | | | | 6 | word octet of zeros stored | | | | | | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | Restrictions: The effective address will be forced to a multiple of eight, i.e., to an octet boundary. ### 7-41. STORE REGISTER FILES, MULTIPLE (STFM) The instruction STFM causes the contents of the six eight-word register files to be stored into the six central memory word octets that begin at the effective address. ### GENERAL FORM: | | LABEL | <br> <br> <br> | COMMAND | | OPERANDS | |-----------|----------|----------------|---------|---|-----------| | | [symbol] | R | STFM | R | [@]n[,x] | | Examples: | | | STFM | | SAVEREG | | | | | STFM | | @ADDR, X1 | | | | | | | | #### Addressing: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | | |-----------------|---------------|-------------------|--| | CM only | zero or XR | CM only | | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-------------------------------------------------------------------| | not affected | specification error if effective<br>address is a register address | Restrictions: The effective address must refer to central memory and will be forced to a multiple of eight, i.e., to an octet boundary. ### 7-42. ARITHMETIC INSTRUCTIONS Table 7-3 lists the arithmetic instructions discussed on the following pages. Table 7-3. Arithmetic Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|-----------------------------------------------|-------| | A | Add, Fixed Point Word | 7-43 | | AH | Add, Fixed Point Halfword | 7-44 | | AF | Add, Floating Point Word | 7-45 | | AFD , | Add, Floating Point Doubleword | 7-46 | | AI | Add, Immediate, Fixed Point Word | 7-47 | | AIH | Add Immediate, Fixed Point Halfword | 7-48 | | AM | Add Magnitude, Fixed Point Word | 7-49 | | АМН | Add Magnitude, Fixed Point Halfword | 7-50 | | AMF | Add Magnitude, Floating Point Word | 7-51 | | AMFD | Add Magnitude, Floating Point Doubleword | 7-52 | | s | Subtract, Fixed Point Word | 7-53 | | SH | Subtract, Fixed Point Halfword | 7-54 | | SF | Subtract, Floating Point Word | 7-55 | | SFD | Subtract, Floating Point Doubleword | 7-56 | | SI | Subtract Immediate, Fixed Point Word | 7-57 | | SIH | Subtract Immediate, Fixed Point Halfword | 7-58 | | SM | Subtract Magnitude, Fixed Point Word | 7-59 | | SMH | Subtract Magnitude, Fixed Point Halfword | 7-60 | | SMF | Subtract Magnitude, Floating Point Word | 7-61 | | SMFD | Subtract Magnitude, Floating Point Doubleword | 7-62 | | M | Multiply, Fixed Point Word | 7-63 | | MH | Multiply, Fixed Point Halfword | 7-64 | | MF | Multiply, Floating Point Word | 7-65 | | MFD | Multiply, Floating Point Doubleword | 7-66 | | MI | Multiply, Immediate, Fixed Point Word | 7-67 | | мін | Multiply Immediate, Fixed Point Halfword | 7-68 | | D | Divide, Fixed Point Word | 7-69 | | DH | Divide, Fixed Point Halfword | 7-70 | | DF | Divide, Floating Point Word | 7-71 | | DFD | Divide, Floating Point Doubleword | 7-72 | | DI | Divide Immediate, Fixed Point Word | 7-73 | | DIH | Divide Immediate, Fixed Point Halfword | 7-74 | #### 7-43. ADD, FIXED POINT WORD (A) The instruction A causes the value in the effective address to be added to the value in the register addressed by the register operand, and causes the sum to be loaded into the register. #### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|-------------------| | | [symbol] | A | b r,[@][=]n[,x] | | Examples: | | A | B1,=#100 | | | | Α | X1,@ADDR, X2 | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |-------------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | BR, AR, XR, | BR, AR, XR, | zero or | BR, AR, XR, VR, | | or VR | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | · | | | | | | | | | | | | | | | | | | | | | | | | · | #### 7-44. ADD, FIXED POINT HALFWORD (AH) The instruction AH causes the value in the effective halfword address to be added to the value in the left half of the arithmetic register addressed by the register operand, and causes the sum to be loaded into the left half of the register. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. #### GENERAL FORM: | | LABEL | ]<br> <br> | COMMAND | | OPERANDS | |-----------|----------|------------|---------|-------|---------------| | | [symbol] | R | AH | . R | r,[@][=]n[,x] | | Examples: | | | AH | | A1,=#FFF | | | | | AH | | A1,@ADD,X1 | | | | | | | | #### Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |-----------------------|---------------------------------------|------------------|----------------|----------------------------------------| | left half of AR, only | left half<br>of BR, AR,<br>XR, VR, or | zero<br>XR | n/a<br>even | left half of BR,<br>AR, XR, VR, or CM | | | СМ | | odd | right half of BR,<br>AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | | | | · | | | | | | | Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. #### 7-45. ADD, FLOATING POINT WORD (AF) The instruction AF causes the value in the effective address to be added to the value in the arithmetic register addressed by the register operand, and causes the sum to be loaded into the register. #### GENERAL FORM: | | LABEL | <br> | COMMAND | <br> <br> | OPERANDS | | |-----------|----------|------|---------|-----------|---------------|--| | | [symbol] | R | AF | R | r,[@][=]n[,x] | | | Examples: | | | AF | | A1, (A2) | | | | | | AF | | Al, RSLT, Xl | | | , | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------------------| | +, 0, or - | floating point exponent overflow | | | floating point exponent underflow | | | | | | | | | | | | | | | | | | | | | | # 7-46. ADD, FLOATING POINT DOUBLEWORD (AFD) The instruction AFD causes the value in the effective doubleword address to be added to the value in the even-odd arithmetic register pair addressed by the register operand, and causes the sum to be loaded into the register pair. Terminal index displacement is by doubleword increments of even-odd word pairs. #### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | | |-----------|-------------|---|---------|----------|---------------|--| | | [symbol] | R | AFD | R | r,[@][=]n[,x] | | | Examples: | AFD | | | A2, (A4) | ╗ | | | | | | AFD | | A2, RSLT, X1 | | | ı | <del></del> | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|--------------------------------------------------------------------| | +, 0, or - | floating point exponent overflow floating point exponent underflow | | | specification error if AR is odd | Restrictions: Both register and effective addresses must be even valued. Note: Indirect address indexing is by singleword increments although the terminal indexing is doubleword increments. ### 7-47. ADD IMMEDIATE, FIXED POINT WORD (AI) The instruction AI causes the effective immediate operand to be added to the value in the register addressed by the register operand, and causes the sum to be loaded into the register. #### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|----------| | | [symbol] | R VI | | | Examples: | | AI | A1,13 | | · | | AI | B1,15,X1 | | | | | | Addressing: | REGISTER | INDEX | IMMEDIATE | |----------------------|------------|-------------------------------------| | OPERAND | OPERAND | MODIFIER | | BR, AR, XR,<br>or VR | zero<br>XR | none $-2^{23} \le m \le 2^{23} - 1$ | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | | | | | | | | | | | | | | | | | | | | | | | #### 7-48. ADD IMMEDIATE, FIXED POINT HALFWORD (AIH) The instruction AIH causes the effective immediate operand to be added to the value in the left half of the arithmetic register addressed by the register operand, and causes the sum to be loaded into the left half of the register. #### GENERAL FORM: | Examples: | | |-----------|--| | LABEL | 1 <br> | COMMAND | | OPERANDS | |----------|---------|---------|---------|-----------| | [symbol] | R | AIH | R | r, i[, x] | | | | AIH | | A2, 3 | | AIH | | | A2,5,X1 | | | | | | | | #### Addressing: | REGISTER | INDEX | IMMEDIATE | |--------------------------|--------------------------|-------------------------------------| | OPERAND | OPERAND | MODIFIER | | left half of<br>AR, only | zero<br>XR right<br>half | none $-2^{15} \le m \le 2^{15} - 1$ | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | | | | | | | | | | | | | | | | | | | | | | | ### 7-49. ADD MAGNITUDE, FIXED POINT WORD (AM) The instruction AM causes the absolute value of the data in the effective address to be added to the value in the arithmetic register addressed by the register operand, and causes the sum to be loaded into the register. #### GENERAL FORM: | | LABEL | I<br>I | COMMAND | | <br> <br> | OPERANDS | | |-----------|----------|--------|---------|---|-----------|---------------|---| | | [symbol] | R | AM | R | | r,[@][=]n[,x] | | | Examples: | | | AM | | | A1, ABS, X1 | | | | | | AM | | | Al,@ADDR,Xl | - | | | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | ### Program Status: | PROGRAM INTERRUPTIONS | |-----------------------| | fixed point overflow | | | | | | | <u>Note</u>: Fixed point overflow is possible when the value in the arithmetic register is positive; it will occur when the value in the effective address is the algebraically largest negative number (8000 0000, base 16) and the register contents are zero or positive. ## 7-50. ADD MAGNITUDE, FIXED POINT HALFWORD (AMH) The instruction AMH causes the absolute value of the data in the effective halfword address to be added to the value in the left half of the register addressed by the register operand, and causes the sum to be loaded into the left half of the register. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. ### GENERAL FORM: | | LABEL | | COMMAND | 1 | OPERANDS | |-----------|----------|---|---------|---|---------------| | | [symbol] | R | АМН | R | r,[@][=]n[,x] | | Examples: | | | АМН | | A3, RSLT | | | | | AMH | | A3,@ADDR,X1 | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | INDEX | EFFECTIVE | |-----------------------------|---------------------------------------------|------------|--------------------|------------------------------------------------------------------------| | OPERAND | OPERAND | OPERAND | VALUE | ADDRESS | | left<br>half of<br>AR, only | left half<br>of BR, AR,<br>XR, VR, or<br>CM | zero<br>XR | n/a<br>even<br>odd | left half of BR, AR, XR, VR, or CM right half of BR, AR, XR, VR, or CM | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | | | | |----------------------|-----------------------|--|--|--| | +, 0, or - | fixed point overflow | | | | Note: Fixed point overflow is possible when the value in the register halfword is positive; it will occur when the value in the effective halfword is the algebraically largest negative number (8000, base 16) and the register halfword contents are zero or positive. <u>Note:</u> Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. ### 7-51. ADD MAGNITUDE, FLOATING POINT WORD (AMF) The instruction AMF causes the absolute value of the data in the effective address to be added to the value in the arithmetic register addressed by the register operand, and causes the sum to be loaded into the register. ### GENERAL FORM: | LABEL | COMMAND | OPERANDS | |----------|---------|----------------| | [symbol] | AMF | r,[@][=]n[,x] | | | AMF | Al, ABS | | | AMF | A1,@ADDR, X1 | | | | [symbol] AMF | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|----------------------------------| | +, 0, or - | floating point exponent overflow | | , , | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 7-52. ADD MAGNITUDE, FLOATING POINT DOUBLEWORD (AMFD) The instruction AMFD causes the absolute value of the data in the effective doubleword address to be added to the value in the even-odd arithmetic register pair addressed by the register operand, and causes the sum to be loaded into the register pair. Terminal index displacement is by doubleword increments of even-odd word pairs. ### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | |-----------|----------|---|---------|---|---------------| | _ | [symbol] | R | AMFD | R | r,[@][=]n[,x] | | Examples: | | | AMFD | | A2, ADD | | | | | AMFD | | A2,@ADDR,X1 | | Į | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-------------------------------------------------------------------| | +, 0, or - | floating point exponent overflow specification error if AR is odd | Restrictions: Both register and effective addresses must be even-valued.. Note: Indirect address indexing is by singleword increments although terminal indexing is by doubleword increments. ### 7-53. SUBTRACT, FIXED POINT WORD (S) The instruction S causes the value in the effective address to be subtracted from the value in the arithmetic register addressed by the register operand, and causes the difference to be loaded into the register. ### GENERAL FORM: | | LABEL | l I | COMMAND | | OPERANDS | |--------------|----------|-----|---------|----|---------------| | Erroman logo | [symbol] | R | S | 12 | r,[@][=]n[,x] | | Examples: | | | S | | B1,=#100 | | | | | S | | X1,@ADDR, X2 | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | | | | | | | | | | | | | | | | | | | | | | | #### 7-54. SUBTRACT, FIXED POINT HALFWORD (SH) The instruction SH causes the value in the effective halfword address to be subtracted from the value in the left half of the arithmetic register addressed by the register operand, and causes the difference to be loaded into the left half of the register. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. #### GENERAL FORM: | Examples | : | |----------|---| | LABEL | <br> <br> _ | COMMAND | | OPERANDS | |----------|----------------|---------|------------|---------------| | [symbol] | R | SH | R | r,[@][=]n[,x] | | | | SH | | A1,=#FFFF | | SH | | | A1,@SUB,X1 | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | INDEX | EFFECTIVE | |----------|---------------------------------------------|------------|--------------------|---------------------------------------------------------------------------------| | OPERAND | OPERAND | OPERAND | VALUE | ADDRESS | | half of | left half<br>of BR, AR,<br>XR, VR, or<br>CM | zero<br>XR | n/a<br>even<br>odd | left half of BR,<br>AR, XR, VR, or CM<br>right half of BR,<br>AR, XR, VR, or CM | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | | | | | | | | Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. ### 7-55. SUBTRACT, FLOATING POINT WORD (SF) The instruction SF causes the value in the effective address to be subtracted from the value in the arithmetic register addressed by the register operand, and causes the difference to be loaded into the register. ### GENERAL FORM: | | LABEL | COMMAND | <br> ! | OPERANDS | |-----------|----------|---------|---------|---------------| | | [symbol] | SF | R | r,[@][=]n[,x] | | Examples: | | SF | | A1, (A2) | | · | | SF | | A1, RSLT, X1 | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|--------------------------------------------------------------------| | +, 0, or - | floating point exponent overflow floating point exponent underflow | | | | ## 7-56. SUBTRACT, FLOATING POINT DOUBLEWORD (SFD) The instruction SFD causes the value in the effective doubleword address to be subtracted from the value in the even-odd arithmetic register pair addressed by the register operand, and causes the difference to be loaded into the register pair. Terminal index displacement is by doubleword increments of even-odd word pairs. ### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|---------------| | | [symbol] | SFD | r,[@][=]n[,x] | | Examples: | | SFD | A2, (A4) | | | · | SFD | A2, RSLT, X1 | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------------------------------------------------------------------------------------| | +, 0, or - | floating point exponent overflow floating point exponent underflow specification error if AR is odd | Restrictions: Both register and effective addresses must be even valued. Note: Indirect address indexing is by singleword increments although terminal indexing is by doubleword increments. ## 7-57. SUBTRACT IMMEDIATE, FIXED POINT WORD (SI) The instruction SI causes the effective immediate operand to be subtracted from the value in the arithmetic register addressed by the register operand, and causes the difference to be loaded into the register. ### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-------------|----------|---------|----------| | | [symbol] | ß SI | | | Examples: | | SI | A1,13 | | · | | SI | A1,15,X1 | | Addrossing. | | | | Addressing: | REGISTER | INDEX | IMMEDIATE | |----------|------------|-------------------------------------| | OPERAND | OPERAND | MODIFIER | | AR | zero<br>XR | none $-2^{23} \le m \le 2^{23} - 1$ | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | | | | | | | | | | | | | | | | | | | | ### 7-58. SUBTRACT IMMEDIATE, FIXED POINT HALFWORD (SIH) The instruction SIH causes the effective immediate operand to be subtracted from the value in the left half of the arithmetic register addressed by the register operand, and causes the difference to be loaded into the left half of the register. ### GENERAL FORM: | Examp | oles | : | |-------|------|---| | LABEL | | COMMAND | | OPERANDS | |----------|-----|---------|---|-----------| | [symbol] | R | SIH | R | r, i[, x] | | | SIH | | | A2, 3 | | | | SIH | | A2, 5, x1 | | | | | | | ## Addressing: | REGISTER | INDEX | IMMEDIATE | |-----------------------|--------------------------|-------------------------------------| | OPERAND | OPERAND | MODIFIER | | left half of AR, only | zero<br>XR right<br>half | none $-2^{15} \le m \le 2^{15} - 1$ | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | | | | | | | , | | | | | | | | | | | | | | | | ### 7-59. SUBTRACT MAGNITUDE, FIXED POINT WORD (SM) The instruction SM causes the absolute value of the data in the effective address to be subtracted from the value in the arithmetic register addressed by the register operand, and causes the difference to be loaded into the register. #### GENERAL FORM: | | LABEL | İ | COMMAND | | OPERANDS | | |-----------|----------|---|---------|---|---------------|---| | | [symbol] | R | SM | R | r,[@][=]n[,x] | | | Examples: | | | SM | | A1, ABS, X1 | ٦ | | | | | SM | | Al,@ADDR,Xl | | | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | | | · . | | | | Note: Fixed point overflow is possible when the value in the arithmetic register is negative; it will occur when the value in the effective address is the algebraically largest negative number (8000 0000, base 16) and the contents of the arithmetic register are negative. ## 7-60. SUBTRACT MAGNITUDE, FIXED POINT HALFWORD (SMH) The instruction SMH causes the absolute value of the data in the effective halfword address to be subtracted from the value in the left half of the arithmetic register addressed by the register operand, and causes the difference to be loaded into the left half of the register. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. ### GENERAL FORM: | | LABEL | | COMMAND | | T | OPERANDS | |-----------|----------|---|---------|---|---|---------------| | | [symbol] | R | SMH | R | | r,[@][=]n[,x] | | Examples: | | | SMH | | | A3, RSLT | | | | | SMH | | | A3,@ADDR, X1 | | | | | | | | | ### Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|--------------------------|------------------|----------------|----------------------------------------| | left | left half | zero | n/a | left half of BR, | | | of BR, AR,<br>XR, VR, or | XR | even | AR, XR, VR, or CM | | | CM | | odd | right half of BR,<br>AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | Note: Indirect address indexing is by singleword increments although terminal indexing is by halfword increments. ### 7-61. SUBTRACT MAGNITUDE, FLOATING POINT WORD (SMF) The instruction SMF causes the absolute value of the data in the effective address to be subtracted from the value in the arithmetic register addressed by the register operand, and causes the difference to be loaded into the register. ### GENERAL FORM: | | LABEL | | COMMAND | | | OPERANDS | | |-----------|----------|---|---------|---|---|---------------|--| | | [symbol] | R | SMF | k | 8 | r,[@][=]n[,x] | | | Examples: | | | SMF | | | Al, ABS | | | | | | SMF | | | Al,@ADDR,Xl | | | , | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------------------| | +, 0, or - | floating point exponent underflow | | | | | | | | | | | | | | | | | | | | | | ## 7-62. SUBTRACT MAGNITUDE, FLOATING POINT DOUBLEWORD (SMFD) The instruction SMFD causes the absolute value of the data in the effective doubleword address to be subtracted from the value in the even-odd arithmetic register pair addressed by the register operand, and causes the difference to be loaded into the register pair. Terminal index displacement is by doubleword increments of even-odd word pairs. ### GENERAL FORM: | Exa | mn | 165 | | |-----|----|-----|--| | LABEL | | COMMAND | <br> <br> | OPERANDS | |----------|---|---------|-------------|---------------| | [symbol] | R | SMFD | R | r,[@][=]n[,x] | | | | SMFD | | A2, SUB | | | | SMFD | | A2,@SUB, X1 | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|--------------------------------------------------------------------| | +, 0, or - | floating point exponent underflow specification error if AR is odd | Restrictions: Both register and effective addresses must be even valued. Note: Indirect address indexing is by singleword increments although the terminal indexing is by doubleword increments. #### 7-63. MULTIPLY, FIXED POINT WORD (M) The instruction M causes the value in the effective address to be multiplied by the value in the register addressed by the register operand, and causes the product to be loaded into the register or registers. The full doubleword integer product is loaded into an even-odd register pair if the register operand addresses an even arithmetic register; but only the least significant half of the integer product is saved and loaded if the register operand addresses an odd arithmetic register or a register from any other register file. #### GENERAL FORM: | · | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|--------------| | | [symbol] | M | | | Examples: | | М | A1, (A2) | | | | M | A2, RSLT, X1 | | | | | | ### Addressing: | REGISTER | DESTINATION OF | ADDRESS | INDEX | EFFECTIVE | |------------------------------|-------------------------------------------------------------|-----------------------------|------------------|-------------------------------------------| | OPERAND | RESULT | OPERAND | OPERAND | ADDRESS | | even AR odd AR BR, XR, or VR | AR even-odd pair odd AR singleword BR, XR, or VR singleword | BR, AR,<br>XR, VR,<br>or CM | zero<br>or<br>XR | BR, AR,<br>XR, VR,<br>or CM<br>singleword | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | Limitations: Where only a singleword product is saved, the product, p, must have a value within the range: $-2^{31} \le p \le 2^{31}-1$ ; otherwise, a fixed point overflow occurs. Restrictions: When an even arithmetic register is addressed in the register operand, the data in the succeeding odd arithmetic register will be replaced by the result of this instruction. 7-63 ### 7-64. MULTIPLY, FIXED POINT HALFWORD (MH) The instruction MH causes the value in the effective halfword address to be multiplied by the value in the left half of the arithmetic register addressed by the register operand, and causes the fullword product (32 bits) to be loaded into the register. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. #### GENERAL FORM: | • | LABEL | COMMAND | | OPERANDS | |-----------|----------|---------|--|---------------| | • | [symbol] | MH | | r,[@][=]n[,x] | | Examples: | | МН | | A1, RSLT | | | | MH | | A1,@ADDR,X1 | | | | | | | ### Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|---------------------------------------|------------------|----------------|----------------------------------------| | 1 ' | left half<br>of BR, AR,<br>XR, VR, or | zero<br>XR | n/a<br>even | left half of BR,<br>AR, XR, VR, or CM | | fullword<br>product | СМ | | odd | right half of BR,<br>AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | | | | | | | | Restrictions: Any data in the right half of the arithmetic register will be replaced by the result of this operation. Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. ### 7-65. MULTIPLY, FLOATING POINT WORD (MF) The instruction MF causes the value in the effective address to be multiplied by the value in the arithmetic register addressed by the register operand, and causes the product to be loaded into the register. ### GENERAL FORM: | | LABEL | COMMAND | <br> | OPERANDS | | |-----------|----------|---------|------|---------------|--| | | [symbol] | MF | R | r,[@][=]n[,x] | | | Examples: | | MF | | A1, (A2) | | | · | | MF | | Al, MULT, Xl | | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|--------------------------------------------------------------------| | +, 0, or - | floating point exponent overflow floating point exponent underflow | | | | ### 7-66. MULTIPLY, FLOATING POINT DOUBLEWORD (MFD) The instruction MFD causes the value in the effective doubleword address to be multiplied by the value in the even-odd arithmetic register pair addressed by the register operand, and causes the product to be loaded into the register pair. Terminal indexing is by doubleword increments of even-odd word pairs. ### GENERAL FORM: | | LABEL | <br> <br> | COMMAND | 1 | OPERANDS | | |-----------|----------|-------------|---------|---|---------------|--| | _ | [symbol] | R | MFD | R | r,[@][=]n[,x] | | | Examples: | | | MFD | | A2, (A4) | | | | | | MFD | | A2, RSLT, X1 | | | | | | | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------------------------------------------------------------------------------------| | +, 0, or - | floating point exponent overflow floating point exponent underflow specification error if AR is odd | Restrictions: Both register and effective addresses must be even valued. Note: Indirect address indexing is by singleword increments although the terminal indexing is by doubleword increments. #### 7-67. MULTIPLY IMMEDIATE, FIXED POINT WORD (MI) The instruction MI causes the effective immediate operand to be multiplied by the value in the register addressed by the register operand, and causes the product to be loaded into the register or registers. The full doubleword integer product is loaded into an even-odd register pair if the register operand addresses an even arithmetic register; but only the least significant half of the integer product is saved and loaded if the register operand addresses an odd arithmetic register or a register from any other register file. #### GENERAL FORM: | Examples | : | |----------|---| | LABEL | <br> | COMMAND | | OPERANDS | |----------|------|---------|----|-------------| | [symbol] | R | MI | 18 | r, i, [, x] | | | | MI | | B2,#FFCF | | | | MI | | V1,3,X3 | | | | | | | #### Addressing: | REGISTER | DESTINATION OF | INDEX | IMMEDIATE | |------------------------------|----------------------------------------------------------------------|------------|------------------------------------| | OPERAND | RESULT | OPERAND | MODIFIER | | even AR odd AR BR, XR, or VR | AR even-odd pair<br>odd AR singleword<br>BR, XR, or VR<br>singleword | zero<br>XR | none $-2^{23} \le m \le 2^{23} -1$ | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | fixed point overflow | <u>Limitations</u>: When only a singleword product is saved, the product, p, must have a value within the range; $-2^{31} \le p \le 2^{31}-1$ ; otherwise, a fixed point overflow occurs. Restrictions: When an even arithmetic register is addressed in the register operand, the data in the succeeding odd arithmetic register will be replaced by the result of this instruction. ## 7-68. MULTIPLY IMMEDIATE, FIXED POINT HALFWORD (MIH) The instruction MIH causes the effective immediate operand to be multiplied by the value in the left half of the arithmetic register addressed by the register operand, and causes the fullword product (32 bits) to be loaded into the register. #### GENERAL FORM: | Examples: | | |-----------|--| | LABEL | <br> | COMMAND | | OPERANDS | | |----------|------|---------|---|-----------|--| | [symbol] | R | MIH | R | r, i[, x] | | | | | MIH | | A1,3 | | | | | MIH | | A1,5,X1 | | | | | | | | | ### Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | |-------------------------------|------------------|--------------------------------| | AR; left half | zero | none | | for data,<br>fullword product | XR right<br>half | $-2^{15} \le m \le 2^{15} - 1$ | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | | | · | | | | Restrictions: Any data in the right half of the arithmetic register will be replaced by the result of this operation. #### 7-69. DIVIDE, FIXED POINT WORD (D) The instruction D causes the value in the effective address to be divided into the value in the even-odd arithmetic register pair or in the odd arithmetic register addressed by the register operand, and causes the quotient to be loaded into the single register addressed by the operand. #### GENERAL FORM: | | LABEL | <br> <br> | COMMAND | <br> <br> | OPERANDS | |-----|----------|------------|---------|-----------|---------------| | | [symbol] | R | D | R | r,[@][=]n[,x] | | es: | | | D | | A1, (A2) | | | | | D | | A2, RSLT, X1 | | | | | | | | ### Addressing: Exampl | REGISTER<br>OPERAND | DIVIDEND | RESULT | ADDRESS<br>OPERAND | INDEX<br>OPERAND | EFFECTIVE<br>ADDRESS | | |---------------------|----------------------|-----------------------|--------------------|------------------|----------------------|--| | even AR | AR even-<br>odd pair | AR even<br>singleword | BR, AR,<br>XR, VR, | zero<br>or | BR, AR,<br>XR, VR, | | | odd AR | AR odd<br>singleword | AR odd<br>singleword | or CM | XR | or CM<br>singleword | | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|--------------------------------------| | +, 0, or - | fixed point overflow<br>divide check | <u>Limitations</u>: When a quotient is derived from a doubleword dividend, the quotient, q, must have a value within the range: $-2^{31} \le q \le 2^{31}-1$ ; otherwise, a fixed point overflow will occur. Note: When a doubleword dividend is selected (by addressing an even arithmetic register), the second word of the dividend is not altered when the quotient is loaded into the even singleword arithmetic register. ### 7-70. DIVIDE, FIXED POINT HALFWORD (DH) The instruction DH causes the value in the effective halfword address to be divided into the value in the arithmetic register (fullword) addressed by the register operand, and causes the quotient to be loaded into the left half of the register. Terminal index displacement is by halfword increments beginning from the initial left halfword of the index word set. ### GENERAL FORM: | | LABEL | <br> | COMMAND | | OPERANDS | |-----------|----------|------|---------|----|---------------| | · | [symbol] | R | DH | 18 | r,[@][=]n[,x] | | Examples: | | | DH | | A1, RSLT | | | | | DH | | A2,@RSLT, X1 | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | INDEX | EFFECTIVE | |-----------------------------------------------------|---------------------------------------------|------------|--------------------|------------------------------------------------------------------------| | OPERAND | OPERAND | OPERAND | VALUE | ADDRESS | | AR;<br>fullword<br>of data,<br>halfword<br>quotient | left half<br>of BR, AR,<br>XR, VR, or<br>CM | zero<br>XR | n/a<br>even<br>odd | left half of BR, AR, XR, VR, or CM right half of BR, AR, XR, VR, or CM | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|--------------------------------------| | +, 0, or - | fixed point overflow<br>divide check | Limitations: The quotient, q, must have a value within the range: $-2^{15} \le q \le 2^{15}-1$ ; otherwise, a fixed point overflow will occur. Note: The right halfword of the dividend is not altered when the halfword quotient is loaded. Note: Indirect address indexing is by singleword increments although the terminal indexing is by halfword increments. ### 7-71. DIVIDE, FLOATING POINT WORD (DF) The instruction DF causes the value in the effective address to be divided into the value in the arithmetic register addressed by the register operand, and causes the quotient to be loaded into the register. ### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|-------------| | | [symbol2 | DF | | | Examples: | | DF | Al, RSLT | | | | DF | A1,@RSLT,X1 | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRIPTIONS | |----------------------|---------------------------------------------------------------------------------| | +, 0, or - | floating point exponent overflow floating point exponent underflow divide check | ### 7-72. DIVIDE, FLOATING POINT DOUBLEWORD (DFD) The instruction DFD causes the value in the effective doubleword address to be divided into the value in the even-odd arithmetic register pair addressed by the register operand, and causes the quotient to be loaded into the even odd register pair. Terminal index displacement is by doubleword increments of even-odd word pairs. #### GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | | |-----------|----------|---------|---|---------------|--| | ·<br> | [symbol] | DFD | R | r,[@][=]n[,x] | | | Examples: | | DFD | | A2, (A4) | | | | | DFD | | A2,@RSLT,X1 | | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|------------------------------------------------------------------------------------------------------------------| | +, 0, or - | floating point exponent overflow floating point exponent underflow divide check specification error if AR is odd | Restrictions: Both register and effective addresses must be even-valued. Note: Indirect address indexing is by singleword increments although the terminal indexing is by doubleword increments. ## 7-73. DIVIDE IMMEDIATE, FIXED POINT WORD (DI) The instruction DI causes the effective immediate operand to be divided into the value in the arithmetic register addressed by the register operand, and causes the quotient to be loaded into the single register addressed by the operand. ### GENERAL FORM: | | LABEL | <br> l | COMMAND | <u> </u> | OPERANDS | |-----------|----------|--------|---------|----------|-------------| | Examples: | [symbol] | R | DI | R | r, i[, x] | | | | | DI | | A1,3 | | | | | DI | • | A1, #FF, X1 | | | | | | | | ### Addressing: | REGISTER<br>OPERAND | DIVIDEND | QUOTIENT | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | |---------------------|------------|------------|------------------|--------------------------------| | even AR | AR | AR | zero | none | | | singleword | singleword | XR | $-2^{23} \le m \le 2^{23} - 1$ | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | divide check | #### 7-74. DIVIDE IMMEDIATE, FIXED POINT HALFWORD (DIH) The instruction DIH causes the effective immediate operand to be divided into the value in the arithmetic register (fullword) addressed by the register operand, and causes the quotient to be loaded into the left half of the register. ### GENERAL FORM: | LABEL | COMMAND | OPERANDS | |----------|---------|------------------| | [symbol] | R DIH | b r, i[, x] | | | DIH | A3,1 | | | DIH | A3, #C, X3 | | | | [symbol] DIH | ### Addressing: | REGISTER | INDEX | IMMEDIATE | |-----------------------------------------------|--------------------------|-------------------------------------| | OPERAND | OPERAND | MODIFIER | | AR; fullword dividend, left halfword quotient | zero<br>XR right<br>half | none $-2^{15} \le m \le 2^{15} - 1$ | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|--------------------------------------| | +, 0, or - | fixed point overflow<br>divide check | <u>Limitations</u>: The quotient, q, must have a value within the range: $-2^{15} \le q \le 2^{15}-1$ ; otherwise, a fixed point overflow will occur. Note: The right halfword of the dividend is not altered when the halfword quotient is loaded. # 7-75. LOGICAL INSTRUCTIONS Table 7-4 lists the logical instructions discussed on the following pages. Table 7-4. Logical Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|------------------------------|-------| | AND | AND, Word | 7-76 | | ANDD | AND, Doubleword | 7-77 | | ANDI | AND Immediate, Word | 7-78 | | OR | OR, Word | 7-79 | | ORD | OR, Doubleword | 7-80 | | ORI | OR Immediate, Word | 7-81 | | XOR | Exclusive OR, Word | 7-82 | | XORD | Exclusive OR, Doubleword | 7-83 | | XORI | Exclusive OR Immediate, Word | 7-84 | | EQC | Equivalence, Word | 7-85 | | EQCD | Equivalence, Doubleword | 7-86 | | EQCI | Equivalence Immediate, Word | 7-87 | ### 7-76. AND, WORD (AND) The instruction AND causes the data in the effective address to be ANDed, bit by corresponding bit, with the data in the arithmetic register addressed by the register operand, and causes the result to be loaded into the register. ### GENERAL FORM: | • | LABEL | | COMMAND | <br> | OPERANDS | | |-----------|----------|---|---------|------|---------------|---| | | [symbol] | R | AND | R | r,[@][=]n[,x] | | | Examples: | | | AND | | A1,@(A3), X1 | | | | | | AND | | A1, RSLT, X2 | · | | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | PROGRAM INTERRUPTIONS | |-----------------------| | none | | | | | | | | | | | | | | | | | ### 7-77. AND, DOUBLEWORD (ANDD) The instruction ANDD causes the data in the effective doubleword address to be ANDed, bit by corresponsing bit, with the data in the even-odd arithmetic register pair addressed by the register operand, and causes the result to be loaded into the register pair. Terminal index displacement is by doubleword increments of even-odd word pairs. ### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | |-----------|----------|---|---------|---|---------------| | · | [symbol] | R | ANDD | R | r,[@][=]n[,x] | | Examples: | | | ANDD | | A2, (A4) | | | | • | ANDD | | A2,@RSLT,X1 | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|----------------------------------| | ones, zeros, or mixed | specification error if AR is odd | | | | | | | | | | | | | | | | | | | #### 7-78. AND IMMEDIATE, WORD (ANDI) The instruction ANDI causes the effective immediate operand to be ANDed, bit by corresponding bit, with the data in the arithmetic register addressed by the register operand, and causes the result to be loaded into the register. #### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | |-----------|----------|---|---------|---|-------------| | | [symbol] | R | ANDI | R | r, i[, x] | | Examples: | | | ANDI | | A1,#FFCD | | | | | ANDI | | A1,#FF39,X1 | | | | | | | | ### Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | |---------------------|------------------|--------------------------| | AR | zero | none | | | XR | $0 \le m \le 2^{23} - 1$ | | | | | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | | · | | | | Restrictions: Modification of the immediate operand by an index value is by one's complement addition only; i.e., there is no sign extension from the 24-bit index and no end-around-carry to the least significant bit. ### 7-79. OR, WORD (OR) The instruction OR causes the data in the effective address to be ORed, bit by corresponding bit, with the data in the arithmetic register addressed by the register operand, and causes the result to be loaded into the register. ### GENERAL FORM: | Examples | : | |----------|---| | LABEL | | COMMAND | | OPERANDS | | |----------|---|---------|-------------|---------------|--| | [symbol] | K | OR | R | r,[@][=]n[,x] | | | | | OR | | A1, (A4) | | | OR | | | Al,@WORD,Xl | | | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | | • . | | | | | | | | | | | | | | | | | | | | | | ### 7-80. OR, DOUBLEWORD (ORD) The instruction ORD causes the data in the effective doubleword address to be ORed, bit by corresponding bit, with the data in the even-odd arithmetic register pair addressed by the register operand, and causes the result to be loaded into the register pair. Terminal index displacement is by doubleword increments of even-odd word pairs. #### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|-------------------| | | [symbol] | ⊌ ORD | b r, [@][=]n[, x] | | Examples: | | ORD | A2, RSLT | | • | · | ORD | A4,@RSLT,X1 | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|----------------------------------| | ones, zeros, or mixed | specification error if AR is odd | | | | | | | | | | | | | | | | | | | ### 7-81. OR IMMEDIATE, WORD (ORI) The instruction ORI causes the effective immediate operand to be ORed, bit by corresponding bit, with the data in the arithmetic register addressed by the register operand, and causes the result to be loaded into the register. ### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS · | | |-----------|----------|---|---------|---|-------------|--| | | [symbol] | R | ORI | R | r, i[, x] | | | Examples: | | | ORI | | A1,3 | | | | | | ORI | | A1, #FF, X1 | | | | | | | | | | ### Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | |---------------------|------------------|--------------------------| | AR | zero | none | | | | $0 \le m \le 2^{23} - 1$ | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | <u>Restrictions</u>: Modification of the immediate operand by an index value is by one's complement addition only; i.e., there is no sign extension from the 24-bit index and no end-around-carry to the least significant bit. ### 7-82. EXCLUSIVE OR, WORD (XOR) The instruction XOR causes the data in the effective address to be exclusive ORed, bit by corresponding bit, with the data in the arithmetic register addressed by the register operand, and causes the result to be loaded into the register. ### GENERAL FORM: | | LABEL | COMMAND | OPERANDS · | |-----------|----------|---------|---------------| | | [symbol] | XOR | r,[@][=]n[,x] | | Examples: | | XOR | A1, (A1) | | | | XOR | Al,@RSLT,Xl | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | none or | BR, AR, XR, | | | VR, or CM | XR | VR, or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | | | | | | | | | | | | | | | | | | | | | | | | ### 7-83. EXCLUSIVE OR, DOUBLEWORD (XORD) The instruction XORD causes the data in the effective doubleword address to be exclusive ORed, bit by corresponding bit, with the data in the even-odd arithmetic register pair addressed by the register operand, and causes the result to be loaded into the register pair. Terminal index displacement is by doubleword increments of even-odd word pairs. ### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS ' | | |-----------|----------|---|---------|---|---------------|--| | ,<br>, | [symbol] | R | XORD | R | r,[@][=]n[,x] | | | Examples: | | | XORD | | A2, RSLT | | | | | | XORD | | A2, RSLT, X1 | | | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-----------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|----------------------------------| | ones, zeros, or mixed | specification error if AR is odd | | | | | | | | | | | | | | | | | | | | | | # 7-84. EXCLUSIVE OR IMMEDIATE, WORD (XORI) The instruction XORI causes the effective immediate operand to be exclusive ORed, bit by corresponding bit, with the data in the arithmetic register addressed by the register operand, and causes the result to be loaded into the register. ### GENERAL FORM: | Examples: | | |-----------|--| | LABEL | | COMMAND | | OPERANDS | | |----------|---|---------|---|-------------|--| | [symbol] | R | XORI | R | r, i[, x] | | | | | XORI | | A1,3 | | | | | XORI | | A1, #00, X1 | | ### Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | |---------------------|------------------|--------------------------| | AR | none | none | | | XR | $0 \le x \le 2^{23} - 1$ | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | | | Note: Modification of the immediate operand by an index value is by one's complement addition only. # 7-85. EQUIVALENCE, WORD (EQC) The instruction EQC causes the data in the effective address to be equivalenced, bit by corresponding bit, with the data in the arithmetic register addressed by the register operand, and causes the result to be loaded into the register. ## GENERAL FORM: | | LABEL | i <br> | COMMAND | | OPERANDS · | | |-------------|----------|---------|---------|---|---------------|--| | Transplace. | [symbol] | R | EQC | R | r,[@][=]n[,x] | | | Examples: | | | EQC | | A1, (A2) | | | | | | EQC | | Al,@RSLT,X1 | | | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | none or | BR, AR, XR, | | | VR, or CM | XR | VR, or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | | | | | | | | | | | · | | | | | | | | | | ### 7-86. EQUIVALENCE, DOUBLEWORD (EQCD) The instruction EQCD causes the data in the effective doubleword address to be equivalenced, bit by corresponding bit, with the data in the even-odd arithmetic register pair addressed by the register operand, and causes the result to be loaded into the register pair. Terminal index displacement is by doubleword increments of even-odd word pairs. ### GENERAL FORM: | | LABEL | COMMAND | OPERANDS . | |-----------|----------|---------|---------------| | | [symbol] | EQCD | r,[@][=]n[,x] | | Examples: | | EQCD | A2, (A4) | | | | EQCD | A2,@RSLT | | | | | | # Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|----------------------------------| | ones, zeros, or mixed | specification error if AR is odd | | | | | | | | | | | | | | · | | | | | | | | ## 7-87. EQUIVALENCE IMMEDIATE, WORD (EQCI) The instruction EQCI causes the effective immediate operand to be equivalenced, bit by corresponding bit, with the data in the arithmetic register addressed by the register operand, and causes the result to be loaded into the register. ### GENERAL FORM: | | LABEL | 1<br> <br> | COMMAND | | OPERANDS ' | | |--------------|----------|------------|---------|---|------------|--| | Erroman logo | [symbol] | R | EQCI | R | r, i[, x] | | | Examples: | | | EQCI | | Al,#FF | | | · | | | EQCI | | A1,#C1,X1 | | # Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | |---------------------|------------------|--------------------------| | AR | zero | none | | | XR | $0 \le x \le 2^{23} - 1$ | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | | • | | | | | | | Note: Modification of the immediate operand by an index value is by one's complement addition only. # 7-88. SHIFT INSTRUCTIONS Table 7-5 lists the shift instructions discussed on the following pages. Table 7-5. Shift Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|------------------------------|---------------| | SA | Arithmetic Shift, Word | 7-93 | | SAH | Arithmetic Shift, Halfword | 7-94 | | SAD | Arithmetic Shift, Doubleword | 7 <b>-</b> 95 | | SL | Logical Shift, Word | 7-96 | | SLH | Logical Shift, Halfword | 7-97 | | SLD | Logical Shift, Doubleword | 7 <b>-</b> 98 | | SC | Circular Shift, Word | 7-99 | | SCH | Circular Shift, Halfword | 7-100 | | SCD | Circular Shift, Doubleword | 7-101 | | RVS | Bit Reversal, Word | 7-102 | #### 7-89. ARITHMETIC SHIFTS Arithmetic shifts are implemented to preserve the sign of the shifted fixed point value and to detect fixed point overflow. An arithmetic right shift (negative shift count) causes the sign bit to be extended, unchanged, so that all replaced bits are ones for negative values and zeros for positive values. Bits shifted out the right end are lost. Illustratively: During an arithmetic left shift (positive shift count), the sign bit is continuously checked, and, if it changes, a fixed point overflow is indicated in the arithmetic exception condition register. The shift is completed regardless of this condition. Bits shifted through the sign bit are lost and zeros enter the low order bit positions. Illustratively: #### 7-90. LOGICAL SHIFTS Logical shifts preserve no arithmetic information. With either right or left shifts, zeros are entered into the vacated bit positions and bits shifted out the designated end are lost. There are no arithmetic exception conditions. #### 7-91. CIRCULAR SHIFTS In circular shifts, the bits shifted out the designated end are entered into the bit positions being vacated at the other end. A circular right shift (negative shift count) causes bits to be shifted out the right end of the word and to be reentered at the left end. Illustratively: A circular left shift (positive shift count) causes bits to be shifted out the left end of the word and to be reentered at the right end. Illustratively: The result code is set logically. Note: The 7-bit shift count is used for all word sizes. If the resulting shift count should exceed the word size of 32-bits for single word shift instructions, then the register result would appear as follows: Circular right shift - Right shift modulo 32 Circular left shift - Left shift modulo 32 The most significant bit of the T-field is not used, i.e., indirect shift counts are not possible. The M-field must be zero. #### 7-92. ALGORITHM FOR BIT REVERSAL Bit reversal is performed by the following steps: - 1. The word upon which reversal is to be performed is copied twice to produce a doubleword with two identical halves. - 2. A circular shift, according to the shift count, is performed on the left singleword. - 3. The bits of the right singleword are reversed. - 4. A circular shift opposite to that of step 2 is performed on the doubleword. - 5. The resultant left singleword is sent to the specified arithmetic register. This instruction reverses the rightmost bits of an arithmetic register. Other bits remain unchanged. Values greater than zero show results as indicated below. The initial bit assignment for register AR runs from 0 on the left to 31 on the right. Bit Reversal values of 0 and -1 leave register AR unchanged. Bit Reversal Output | Values of na | Contents of AR After<br>Bit Reversal Instruction | |--------------|--------------------------------------------------| | + 1 to +Max. | 000 0 | | 0 | 012 30 31 | | -1 | 012 30 31 | | -2 | 012 28 29 31 30 | | - 3 | 012 27 28 31 30 29 | | - 4 | 012 26 27 31 30 29 28 | | • | | | • | | | • | | | -29 | 0 1 2 31 30 29 5 4 3 | | -30 | 0 1 31 30 29 5 4 3 2 | | -31 | 0 31 30 29 5 4 3 2 1 | | - 32 | 31 30 29 5 4 3 2 1 0 | | -33 | 30 29 28 2 1 0 Ø | | -34 | 29 28 27 2 1 0 Ø Ø | | - 35 | 28 27 26 2 1 0 Ø Ø Ø | | • | | | • | | | • | | | -60 | 3 2 1 0 Ø Ø | | -61 | 2100 | | -62 | 100 | | <b>-</b> 63 | 0 Ø | | -64 to -Max. | Ø · · · · · · · · · · · · · · · · · | Where Ø represents a bit position that is zero. # 7-93. ARITHMETIC SHIFT, WORD (SA) The instruction SA causes the data in the arithmetic register addressed by the register operand to be arithmetically shifted left or right, the number of bits specified by the effective immediate operand. If the effective immediate operand is positive, the shift is to the left, and if it is negative, the shift is to the right. #### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|----------| | | [symbol] | ₿ SA | | | Examples: | | SA | A1,3,X1 | | | | | | | | | | | # Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | EFFECTIVE<br>IMMEDIATE | | |---------------------|------------------|-----------------------|------------------------|--| | AR | zero | none | -64≤i≤+63 | | | | XR | right half XR | | | # Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|---------------------------------------| | +, 0, or - | fixed point overflow, left shift only | Restrictions: Regardless of the index value, the effective immediate operand will be within the range: $-64 \le i \le +63$ . Index overflow is truncated, but not detected. Note: During left shifts any change of the sign bit causes a fixed point overflow. # 7-94. ARITHMETIC SHIFT, HALFWORD (SAH) The instruction SAH causes the data in the left half of the arithmetic register addressed by the register operand to be arithmetically shifted, left or right, the number of bits specified by the effective immediate operand. If the effective immediate operand is positive, the shift is to the left, and if it is negative, the shift is to the right. #### GENERAL FORM: | | LABEL | 1 <br> | COMMAND | | OPERANDS . | | |--------------|----------|---------|---------|---|------------|--| | Erroman log. | [symbol] | R | SAH | R | r, i[, x] | | | Examples: | | | SAH | | A3,6,X2 | | | | | | | | | | ## Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | EFFECTIVE<br>IMMEDIATE | |-----------------------|------------------|-----------------------|------------------------| | left half of AR, only | zero | none | | | AR, Only | XR | right half XR | -64≤ i ≤+ 63 | ## Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|---------------------------------------| | +, 0, or - | fixed point overflow, left shift only | Restrictions: Regardless of the index value, the effective immediate operand will be within the range: $-64 \le i \le +63$ . Index overflow is truncated, but not detected. Note: The contents of the right half of the register are not affected. Note: During left shifts any change of the sign bit causes a fixed point overflow, but the total shift is completed regardless of this condition. #### 7-95. ARITHMETIC SHIFT, DOUBLEWORD (SAD) The instruction SAD causes the data in the even-odd arithmetic register pair addressed by the register operand to be shifted arithmetically left or right, the number of bits specified by the effective immediate operand. If the effective immediate operand is positive, the shift is to the left, and if it is negative, the shift is to the right. ### GENERAL FORM: | | LABEL | I<br>I | COMMAND | | OPERANDS | | |-----------|----------|--------|---------|---|-----------|--| | | [symbol] | R | SAD | R | r, i[, x] | | | Examples: | | | SAD | | A2,10,X1 | | | | | | | | | | ## Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | EFFECTIVE<br>IMMEDIATE | |---------------------|------------------|-----------------------|------------------------| | AR; even-odd zero | | none | | | pair only | XR | right half XR | -64≤ i ≤+ 63 | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|---------------------------------------| | +, 0, or - | fixed point overflow, left shift only | | | specification error if AR is odd | Restrictions: Regardless of the index value, the effective immediate operand will be within the range: $-64 \le i \le +63$ . Index overflow is truncated, but not detected. Note: During left shifts any change of the sign bit causes a fixed point overflow, but the total shift is completed regardless of this condition. # 7-96. LOGICAL SHIFT, WORD (SL) The instruction SL causes the data in the arithmetic register addressed by the register operand to be shifted logically, left or right, the number of bits specified by the effective immediate operand. If the effective immediate operand is positive, the shift is to the left, and if it is negative, the shift is to the right. ## GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|-----------| | | [symbol] | SL | | | Examples: | | SL | A1,10, X1 | | | | | | ## Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | EFFECTIVE<br>IMMEDIATE | | |---------------------|------------------|-----------------------|------------------------|--| | AR | zero | none | -64≤ i ≤+ 63 | | | | XR | right half XR | | | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | Restrictions: Regardless of the index value, the effective immediate operand will be within the range: $-64 \le i \le +63$ . Index overflow is truncated, but not detected. ## 7-97. LOGICAL SHIFT, HALFWORD (SLH) The instruction SLH causes the data in the left half of the arithmetic register addressed by the register operand to be shifted logically, left or right, the number of bits specified by the effective immediate operand. If the effective immediate operand is positive, the shift is to the left, and if it is negative, the shift is to the right. ### GENERAL FORM: | | LABEL | COI | MMAND | | OPERANDS | |-----------|----------|-------|-------|---|-----------| | | [symbol] | ⊮¦ SI | LH | R | r, i[, x] | | Examples: | | SI | LH | | A1,10,X1 | | | | | | | | # Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | EFFECTIVE<br>IMMEDIATE | |---------------------|------------------|-----------------------|------------------------| | left half of | zero | none | -64≤ i≤+63 | | AR, only | XR | right half XR | | # Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | | | | | | Restrictions: Regardless of the index value, the effective immediate operand will be within the range: $-64 \le i \le +63$ . Index overflow is truncated, but not detected. Note: The contents of the right half of the register are not affected. ### 7-98. LOGICAL SHIFT, DOUBLEWORD (SLD) The instruction SLD causes the data in the even-odd arithmetic register pair addressed by the register operand to be shifted logically, left or right, the number of bits specified by the effective immediate operand. If the effective immediate operand is positive, the shift is to the left, and if it is negative, the shift is to the right. ## GENERAL FORM: | • | LABEL | COMMAND | OPERANDS | | |-----------|----------|---------|----------|--| | | [symbol] | SLD | r,i[,x] | | | Examples: | | SLD | A2,10,X1 | | | | | | | | | | | | | | ## Addressing: | REGISTER | INDEX | IMMEDIATE | EFFECTIVE | |--------------|---------|---------------|-----------| | OPERAND | OPERAND | MODIFIER | IMMEDIATE | | AR; even-odd | zero | none | -64≤i≤+63 | | pair only | XR | right half XR | | #### Program Status: | PROGRAM INTERRUPTIONS | |----------------------------------| | specification error if AR is odd | | | | | Restrictions: Regardless of the index value, the effective immediate operand will be within the range: $-64 \le i \le +63$ . Index overflow is truncated, but not detected. #### 7-99. CIRCULAR SHIFT, WORD (SC) The instruction SC causes the data in the arithmetic register addressed by the register operand to be shifted circularly, left or right, the number of bits specified by the effective immediate operand. If the effective immediate operand is positive, the shift is to the left, and if it is negative, the shift is to the right. #### GENERAL FORM: | _ | | |----------|---| | Examples | : | | | _ | | LABEL | <br> <br> | COMMAND | | OPERANDS | | |----------|-------------|---------|---|-----------|--| | [symbol] | R | SC | R | r, i[, x] | | | | | SC | | A1,10,X1 | | | | | | | | | #### Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | EFFECTIVE<br>IMMEDIATE | |---------------------|------------------|-----------------------|------------------------| | AR | zero | none | -64≤i≤+63 | | | XR | right half XR | | ### Program Status: | PROGRAM INTERRUPTIONS | |-----------------------| | none | | | | | | | Restrictions: Regardless of the index value, the effective immediate operand will be within the range: $-64 \le i \le +63$ . Index overflow is truncated, but not detected. Note: The shift count is performed modulo 32. # 7-100. CIRCULAR SHIFT, HALFWORD (SCH) The instruction SCH causes the data in the left half of the arithmetic register addressed by the register operand to be shifted circularly, left or right, the number of bits specified by the effective immediate operand. If the effective immediate operand is positive, the shift is to the left, and if it is negative, the shift is to the right. #### GENERAL FORM: | Examples | | |----------|--| | LABEL | <br> <br> <br> | COMMAND | | OPERANDS | · · · · · · · · · · · · · · · · · · · | |----------|----------------|---------|---|-----------|---------------------------------------| | [symbol] | R | SCH | R | r, i[, x] | | | | | SCH | | A1,3,X1 | | | | | | | | | ## Addressing: | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | EFFECTIVE<br>IMMEDIATE | |------------------|-----------------------|----------------------------| | zero | none | -64≤i≤+63 | | XR | right half XR | | | = | OPERAND<br>zero | OPERAND MODIFIER zero none | ## Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | · | | | | | Restrictions: Regardless of the index value, the effective immediate operand will be within the range: $-64 \le i \le +63$ . Index overflow is truncated, but not detected. Note: The contents of the right half of the register are not affected. Note: The shift count is performed modulo 16. ## 7-101. CIRCULAR SHIFT, DOUBLEWORD (SCD) The instruction SCD causes the data in the even-odd arithmetic register pair addressed by the register operand to be shifted circularly, left or right, the number of bits specified by the effective immediate operand. If the effective immediate operand is positive, the shift is to the left, and if it is negative, the shift is to the right. #### GENERAL FORM: | | LABEL | <br> <br>l_, | COMMAND | <br> <br> | OPERANDS | | |-----------|----------|--------------|---------|-----------|-----------|--| | | [symbol] | R | SCD | R | r, i[, x] | | | Examples: | | | SCD | | A2,16,X2 | | | | | | | | | | | | | | | | | | ## Addressing: | REGISTER | INDEX | IMMEDIA TE | EFFECTIVE | |---------------------------|------------|-----------------------|-----------| | OPERAND | OPERAND | MODIFIER | IMMEDIATE | | AR; even-odd<br>pair only | zero<br>XR | none<br>right half XR | | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|----------------------------------| | ones, zeros, or mixed | specification error if AR is odd | Restrictions: Regardless of the index value, the effective immediate operand will be within the range: $-64 \le i \le +63$ . Index overflow is truncated, but not detected. # 7-102. BIT REVERSAL, WORD (RVS) The instruction RVS causes the reversal of the rightmost or leftmost n bits, where n is the value of the effective immediate operand, of the data in the arithmetic register addressed by the register operand. The rightmost n bits are reversed if n is negative, and if n is positive, the register is cleared. The other bits of the register remain unchanged. #### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|------------| | Examples: | [symbol] | RVS | | | | | RVS | A1, -5, X1 | | | | | | # Addressing: | REGISTER | INDEX | IMMEDIATE | EFFECTIVE | |----------|------------|-----------------------|-------------| | OPERAND | OPERAND | MODIFIER | IMMEDIATE | | AR | zero<br>XR | none<br>right half XR | -64≤ i≤ +63 | ## Program Status: | PROGRAM INTERRUPTIONS | |-----------------------| | none | | | | | | | Restrictions: Regardless of the index value, the effective immediate operand will be within the range: $-64 \le i \le +63$ . Note: Although this operation uses a seven bit shift count, the reversal will be modulo 32; thus, operationally, the shift count is within the range: $-32 \le sc \le 32$ , and sc values 0 and -1 are effectively no operation. # 7-103. COMPARE INSTRUCTIONS Table 7-6 lists the shift instructions discussed on the following pages. Table 7-6. Compare Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|-----------------------------------------|-------| | С | Compare, Fixed Point Word | 7-104 | | СН | Compare, Fixed Point Halfword | 7-105 | | CF | Compare, Floating Point Word | 7-106 | | CFD | Compare, Floating Point Doubleword | 7-107 | | CI | Compare Immediate, Fixed Point Word | 7-108 | | CIH | Compare Immediate, Fixed Point Halfword | 7-109 | | CAND | Compare Logical AND, Word | 7-110 | | CANDD | Compare Logical AND, Doubleword | 7-111 | | CANDI | Compare Logical AND Immediate, Word | 7-112 | | COR | Compare Logical OR, Word | 7-113 | | CORD | Compare Logical OR, Doubleword | 7-114 | | CORI | Compare Logical OR Immediate, Word | 7-115 | # 7-104. COMPARE, FIXED POINT WORD (C) The instruction C causes the compare code to be set to reflect whether the value in the register addressed by the register operand is greater than, equal to, or less than the value in the effective address. The contents of both the register and the effective address are unchanged. # GENERAL FORM: | | LABEL | | COMMAND | | !<br>!<br>L | OPERANDS | | |-----------|----------|---|---------|---|-------------|---------------|--| | Examples: | [symbol] | R | С | k | <br> <br> | r,[@][=]n[,x] | | | Examples. | | | С | | | V1, (A1) | | | | | | С | | | A1,@RSLT,X1 | | | | | | | | | AT, GRODI, AI | | ## Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR, XR, | BR, AR, XR, | zero or | BR, AR, XR, VR, | | or VR | VR, or CM | XR | or CM | | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | >, =, or < | none | | RESULT CODE | | | not affected | | | | | #### 7-105. COMPARE FIXED POINT HALFWORD (CH) The instruction CH causes the compare code to be set to reflect whether the value in the left half of the arithmetic register addressed by the register operand is greater than, equal to, or less than the value in the effective halfword address. The contents of both the register and the effective address are unchanged. Terminal index displacement is by halfword increments beginning from the first left halfword of the index word set. ## GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | |-----------|----------|---------|----|---------------| | • | [symbol] | СН | 18 | r,[@][=]n[,x] | | Examples: | | СН | | A1, RSLT | | | СН | | | A1, RSLT, X1 | | | - | | | | # Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|--------------------------|------------------|----------------|----------------------------------------| | left | left half | zero | n/a | left half of BR, | | half of AR, only | of BR, AR,<br>XR, VR, or | XR | even | AR, XR, VR, or CM | | Ziit, Oniy | CM | | odd | right half of BR,<br>AR, XR, VR, or CM | | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | >, =, or < | none | | RESULT CODE | | | not affected | | | | | | | | # 7-106. COMPARE, FLOATING POINT WORD (CF) The instruction CF causes the compare code to be set to reflect whether the value in the arithmetic register addressed by the register operand is greater than, equal to, or less than the value in the effective address. The contents of both the register and the effective address are unchanged. #### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|-------------| | | [symbol] | ₽ CF | | | Examples: | | CF | A1, RSLT | | | | CF | Al,@RSLT,Xl | | | | | | ## Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|--------------------------|---------------|-----------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR, or CM | ### Program Status: | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | >, =, or < | none | | RESULT CODE | · | | not affected | | Note: The input floating point arguments must be hexadecimally normalized prior to use in a floating point compare instruction. ## 7-107. COMPARE, FLOATING POINT DOUBLEWORD (CFD) The instruction CFD causes the compare code to be set to reflect whether the value in the even-odd arithmetic register pair addressed by the register operand is greater than, equal to, or less than the value in the effective doubleword address. The contents of both the register and the effective doubleword are unchanged. Terminal index displacement is by doubleword increments of even-odd word pairs. ## GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | | |-----------|----------|---|---------|---|---------------|--| | , | [symbol] | R | CFD | R | r,[@][=]n[,x] | | | Examples: | | | CFD | | A2, (A4) | | | | | | CFD | | A2, RSLT, X1 | | | | | | | | | | ## Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | #### Program Status: | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|----------------------------------| | >, =, or < | specification error if AR is odd | | RESULT CODE | | | not affected | | Note: The input floating point arguments must be hexadecimally normalized prior to use in a floating point compare instruction. # 7-108. COMPARE IMMEDIATE, FIXED POINT WORD (CI) The instruction CI causes the compare code to be set to reflect whether the value in the register addressed by the register operand is greater than, equal to, or less than the value of the effective immediate operand. The contents of the register are unchanged. ### GENERAL FORM: | LABEL | | COMMAND | | OPERANDS | | |----------|---|---------|----|----------|--| | [symbol] | R | CI | 18 | r, i[,x] | | | | | CI | | Al,#FA | | | | | CI | | A1,#C,X2 | | | | | | | | | Example: ### Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | |---------------------|------------------|--------------------------------| | AR, XR, | zero | none | | or VR | XR | $-2^{23} \le x \le 2^{23} - 1$ | | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | >, =, or < | none | | RESULT CODE | | | not affected | | | | | | | | | | | | | | ## 7-109. COMPARE IMMEDIATE, FIXED POINT HALFWORD (CIH) The instruction CIH causes the compare code to be set to reflect whether the value in the left half of the arithmetic register addressed by the register operand is greater than, equal to, or less than the value of the effective immediate operand. The contents of the register are unchanged. ### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | |-----------|----------|---|---------|---|-----------| | | [symbol] | R | CIH | R | r, i[, x] | | Examples: | | | CIH | | A1,10,X1 | | i | | | | | | | | | | | | | Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | | |---------------------|------------------|-----------------------|--| | left half of | zero | none | | | AR, only | XR | right half XR | | | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | >, =, or < | none | | RESULT CODE | · | | not affected | | | | | | | | ### 7-110. COMPARE LOGICAL AND, WORD (CAND) The instruction CAND causes the compare code to be set to reflect whether the logical ANDing of the data in the arithmetic register addressed by the register operand with that in the effective address produces a result that is all ones, all zeros, or mixed. The contents of both the register and the effective address are unchanged. # GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | | |-----------|----------|---|---------|---|---------------|--| | Examples: | [symbol] | R | CAND | R | r,[@][=]n[,x] | | | | | | CAND | | A1,(A2) | | | | | | CAND | | A1, RSLT, X2 | | ## Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|--------------------------|---------------|-----------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR, or CM | | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | RESULT CODE | · | | not affected | | ## 7-111. COMPARE LOGICAL AND, DOUBLEWORD (CANDD) The instruction CANDD causes the compare code to be set to reflect whether the logical ANDing of the data in the even-odd arithmetic register pair addressed by the register operand with the data in the effective doubleword address produces a result that is all ones, all zeros, or mixed. The contents of both the register pair and the doubleword address are unchanged. Terminal index displacement is by doubleword increments of even-odd word pairs. #### GENERAL FORM: | · | LABEL | COMMAND | OPERANDS | | |-----------|------------|---------|-----------------|--| | | [symbol] & | CANDD | ß r,[@][=]n[,x] | | | Examples: | | CANDD | A2, (A4) | | | | | CANDD | A2, RSLT, X1 | | | | ; | | | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|----------------------------------| | ones, zeros, or mixed | specification error if AR is odd | | RESULT CODE | | | not affected | | ### 7-112. COMPARE LOGICAL AND IMMEDIATE, WORD (CANDI) The instruction CANDI causes the compare code to be set to reflect whether the logical ANDing of the data in the arithmetic register addressed by the register operand with the effective immediate operand produces a result that is all ones, all zeros, or mixed. The contents of the register are unchanged. ## GENERAL FORM: | • | LABEL | COMMAND | OPERANDS | |-----------|------------|---------|-----------| | | [symbol] 🖔 | CANDI | r, i[, x] | | Examples: | | CANDI | A1,#FFCD | | | | CANDI | A1,#0,X1 | | | | | | ## Addressing: | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | |------------------|-------------------------------| | zero<br>XR | none $0 \le x \le 2^{23} - 1$ | | - | zero | ### Program Status: | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | RESULT CODE | | | not affected | | Note: Modification of the immediate operand by an index value is by one's complement addition only. # 7-113. COMPARE LOGICAL OR, WORD (COR) The instruction COR causes the compare code to be set to reflect whether the logical ORing of the data in the arithmetic register addressed by the register operand with that in the effective address produces a result that is all ones, all zeros, or mixed. The contents of both the register and the effective address are unchanged. ### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | | |-----------|----------|---|---------|---|---------------|--| | Examples: | [symbol] | R | COR | R | r,[@][=]n[,x] | | | Examples. | | | COR | | A1, (A2) | | | | | | COR | | A1,@(A3), X1 | | | | | | | | | | # Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | RESULT CODE | · | | not affected | | ## 7-114. COMPARE LOGICAL OR, DOUBLEWORD (CORD) The instruction CORD causes the compare code to be set to reflect whether the logical ORing of the data in the even-odd arithmetic register pair addressed by the register operand with the data in the effective doubleword address produces a result that is all ones, all zeros, or mixed. The contents of both the register pair and the doubleword address are unchanged. Terminal index displacement is by doubleword increments of even-odd word pairs. # GENERAL FORM: | | LABEL | <br> <br> | COMMAND | | OPERANDS | | |-----------|----------|-------------|---------|---|---------------|--| | - 1 | [symbol] | R | CORD | R | r,[@][=]n[,x] | | | Examples: | | | CORD | | A2, (A4) | | | | | | CORD | | A2,@(A1),X1 | | | | | | | | | | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |---------------------------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd<br>pair only | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | | PROGRAM INTERRUPTIONS | |----------------------------------| | specification error if AR is odd | | • | | | | | | | | | #### 7-115. COMPARE LOGICAL OR IMMEDIATE, WORD (CORI) The instruction CORI causes the compare code to be set to reflect whether the logical ORing of the data in the arithmetic register addressed by the register operand with the effective immediate operand produces a result that is all ones, all zeros, or mixed. The contents of the register are unchanged. #### GENERAL FORM: | | LABEL | I | COMMAND | | OPERANDS | | |-----------|----------|---|---------|---|------------|--| | _ | [symbol] | R | CORI | R | r, i[, x] | | | Examples: | | | CORI | | A1,3 | | | | | | CORI | | A1, #F, X2 | | | | | | | | | | ## Addressing: | REGISTER<br>OPERAND | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | |---------------------|------------------|--------------------------| | AR | zero | none | | | XR | $0 \le x \le 2^{23} - 1$ | #### Program Status: | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | ones, zeros, or mixed | none | | RESULT CODE | | | not affected | | Note: Modification of the immediate operand by an index value is by one's complement addition only. # 7-116. INCREMENT OR DECREMENT, TEST AND SKIP INSTRUCTIONS Table 7-7 lists the increment or decrement, test and skip instructions discussed on the following pages. Table 7-7. Increment or Decrement, Test and Skip Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|---------------------------------------|-------| | ISE | Increment, Test and Skip on Equal | 7-117 | | ISNE | Increment, Test and Skip on Not Equal | 7-118 | | DSE | Decrement, Test and Skip on Equal | 7-119 | | DSNE | Decrement, Test and Skip on Not Equal | 7-120 | #### 7-117. INCREMENT, TEST AND SKIP ON EQUAL (ISE) The instruction ISE causes the fixed point value in the arithmetic register addressed by the register operand to be incremented by unity and the result to be stored in the register and causes this value to be arithmetically compared to the value in the effective address. If the two values are equal, the next instruction is skipped; if the two values are not equal, the next instruction is executed in turn. #### GENERAL FORM: | | LABEL | 1 | COMMAND | | OPERANDS | | |-----------|----------|---|---------|---|---------------|--| | | [symbol] | R | ISE | R | r,[@][=]n[,x] | | | Examples: | | | ISE | | A1,(X1) | | | | | | ISE | | A1,@(A2),X1 | | | | | | ISE | | A1,@SAVE,X2 | | ## Addressing: | <br>REGISTER | ADDRESS | INDEX | EFFECTIVE | |--------------|--------------------------|---------------|-----------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR,<br>VR, or CM | zero or<br>XR | | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTÉRRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | Note: If $\alpha \le 2F$ and M=0, where $\alpha$ is specified to be the same register address as defined by the R-field, then the next instruction is taken. # 7-118. INCREMENT, TEST AND SKIP ON NOT EQUAL (ISNE) The instruction ISNE causes the fixed point value in the arithmetic register addressed by the register operand to be incremented by unity and the result to be stored in the register and causes this value to be arithmetically compared to the value in the effective address. If the two values are not equal, the next instruction is skipped; if the two values are equal, the next instruction is executed in turn. # GENERAL FORM: | | LABEL | COMMAND | OPERANDS | | |-----------|-------------|---------|---------------|--| | Examples: | [symbol] 18 | ISNE | r,[@][=]n[,x] | | | | | ISNE | A1,(X1) | | | | | ISNE | A1,@(A2),X1 | | | | | ISNE | A1,@SAVE,X2 | | ## Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | | |----------|-------------|---------|-----------------|--| | OPERAND | OPERAND | OPERAND | ADDRESS | | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | | VR, or CM | XR | or CM | | ## Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | Note: If $\alpha \le 2F$ and M=0, where $\alpha$ is specified to be the same register address as defined by the R-field, then the next instruction is skipped. # 7-119. DECREMENT, TEST AND SKIP ON EQUAL (DSE) The instruction DSE causes the fixed point value in the arithmetic register addressed by the register operand to be decremented by unity and the result to be stored in the register, causes this value to be arithmetically compared to the value in the effective address, and, if the two values are equal, causes the next instruction to be skipped; if the two values are not equal, the next instruction is executed in turn. #### GENERAL FORM: | Examples: | LABEL | | COMMAND | | OPERANDS | | |-----------|----------|---|---------|---|---------------|--| | | [symbol] | R | DSE | R | r,[@][=]n[,x] | | | | | | DSE | | A1,(X1) | | | | | | DSE | | A1,@(A2),X1 | | | | | | DSE | | A1,@SAVE,X2 | | # Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | | |----------|-------------|---------|-----------------|--| | OPERAND | OPERAND | OPERAND | ADDRESS | | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | | VR, or CM | XR | or CM | | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | Note: If $\alpha \le 2F$ and M=0, where $\alpha$ is specified to be the same register address as defined by the R-field, then the next instruction is taken. ### 7-120. DECREMENT, TEST AND SKIP ON NOT EQUAL (DSNE) The instruction DSNE causes the fixed point value in the arithmetic register addressed by the register operand to be decremented by unity and the result to be stored in the register and causes this value to be arithmetically compared to the value in the effective address. If the two values are no equal, the next instruction is skipped; if the two values are equal, the next instruction is executed in turn. #### GENERAL FORM: | | LABEL | I<br>I<br>L | COMMAND | | OPERANDS | | |-----------|----------|-------------|-------------|---|---------------|--| | T | [symbol] | R | DSNE | R | r,[@][=]n[,x] | | | Examples: | | | DSNE | | A1,(X1) | | | | DSNE | | A1,@(A2),X1 | | | | | | | | DSNE | | A1,@SAVE,X2 | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | | |----------|-------------|---------|-----------------|--| | OPERAND | OPERAND | OPERAND | ADDRESS | | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | | VR, or CM | XR | or CM | | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | Note: If $\alpha \leq 2F$ and M=0, where $\alpha$ is specified to be the same register address as defined by the R-field, then the next instruction is skipped. # 7-121. INCREMENT OR DECREMENT, TEST AND BRANCH INSTRUCTIONS Table 7-8 lists the increment or decrement, test and branch instructions discussed on the following pages. Table 7-8. Increment or Decrement, Test and Branch Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|----------------------------------------|-------| | IBZ | Increment, Test and Branch on Zero | 7-122 | | IBNZ | Increment, Test and Branch on Not Zero | 7-123 | | DBZ | Decrement, Test and Branch on Zero | 7-124 | | DBNZ | Decrement, Test and Branch on Not Zero | 7-125 | ### 7-122. INCREMENT, TEST AND BRANCH ON ZERO (IBZ) The instruction IBZ causes the fixed point value in the register addressed by the register operand to be incremented by unity and the result stored in the register, and, if the new value is zero, causes a branch to the effective branch address; if the new value is not zero, the next instruction in sequence is executed in turn. #### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | | |-----------|----------|---|---------|----|---------------|--| | _ | [symbol] | R | IBZ | 18 | r,[@[=]]n[,x] | | | Examples: | | | IBZ | | Al,OUT | | | | | | IBZ | | X1,@SAVE,X2 | | | | | | | | | | ## Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |------------------|---------|---------------|-----------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR, XR,<br>or VR | CM only | zero or<br>XR | CM only | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | # 7-123. INCREMENT, TEST AND BRANCH ON NOT ZERO (IBNZ) The instruction IBNZ causes the fixed point value in the register addressed by the register operand to be incremented by unity and the result to be stored in the register, and, if the new value is not zero, causes a branch to the effective branch address; if the new value is zero, the next instruction in sequence is executed in turn. # GENERAL FORM: | Exam | ples | : | |------|------|---| | LABEL | | COMMAND | ]<br> <br> | OPERANDS | | |----------|---|---------|-------------|---------------|--| | [symbol] | R | IBNZ | R | r,[@[=]]n[,x] | | | IBNZ | | | Al,OUT | | | | IBNZ | | | X1,@SAVE,X2 | | | | | | | | | | # Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |------------------|---------|---------------|-----------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR, XR,<br>or VR | CM only | zero or<br>XR | CM only | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | # 7-124. DECREMENT, TEST AND BRANCH ON ZERO (DBZ) The instruction DBZ causes the fixed point value in the register addressed by the register operand to be decremented by unity and the result to be stored in the register, and, if the new value is zero, causes a branch to the effective branch address; if the new value is not zero, the next instruction in sequence is executed in turn. # GENERAL FORM: | • | LABEL | COMMAND | OPERANDS | |-----------|---------------------------------------|---------|---------------| | | [symbol] | ₿¦ DBZ | r,[@[=]]n[,x] | | Examples: | · · · · · · · · · · · · · · · · · · · | DBZ | Al,OUT | | | | DBZ | X1,@SAVE,X2 | | | | | | ## Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |------------------|---------|---------------|-----------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR, XR,<br>or VR | CM only | zero or<br>XR | CM only | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | ## 7-125. DECREMENT, TEST AND BRANCH ON NOT ZERO (DBNZ) The instruction DBNZ causes the fixed point value in the register addressed by the register operand to be decremented by unity and the result to be stored in the register, and, if the new value is not zero, causes a branch to the effective branch address; if the new value is zero, the next instruction in sequence is executed in turn. #### GENERAL FORM: | | LABEL | <br> <br> <br> | COMMAND | | OPERANDS | |-----------|----------|----------------|---------|---|---------------| | | [symbol] | R | DBNZ | R | r,[@[=]]n[,x] | | Examples: | | | DBNZ | | Al,OUT | | | | | DBNZ | | X1,@SAVE,X1 | | | | | | | | ## Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |------------------|---------|---------------|-----------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR, XR,<br>or VR | CM only | zero or<br>XR | CM only | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +, 0, or - | none | # 7-126. INDEX, TEST AND BRANCH INSTRUCTIONS Table 7-9 lists the test and branch instructions discussed on the following pages. Table 7-9. Index, Test and Branch Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|------------------------------|-------| | BCLE | Branch on Less Than or Equal | 7-128 | | BCG | Branch on Greater Than | 7-129 | #### 7-127. ALGORITHM FOR INDEX, TEST AND BRANCH An index, test and branch operation proceeds by the following steps: - 1. The value in the register addressed by the first operand is added to the value in the even register addressed by the second operand. - 2. The sum from step 1 is stored in the first operand register. - 3. The sum from step 1 is compared to the value in the odd register addressed by the second operand, and - a. if the comparison condition is true, a branch is taken to the branch address derived from the third operand, or - b. if the comparison condition is false, the instruction next in sequence is executed. Illustratively, for branch on greater than (BCG): | 1. | REG1 | value, v | | + REG2 | increment, i | |----|-----------|---------------|-------|----------|---------------| | | <b></b> | | • | | limit, t | | 2. | REG1 | value + incre | ement | | | | 3. | | | | REG2 | increment | | | R EG1 | value + incre | ement | <b>≟</b> | limit | | | a. if v + | i > t, PROGRA | AM CO | UNTER [ | operand three | | | b. if v + | i≯t, PROGR | AM CO | UNTER [ | \$+1 | # 7-128. BRANCH ON LESS THAN OR EQUAL (BCLE) The instruction BCLE causes the value in the register addressed by the first operand to be added to the increment value in the even-odd register pair addressed by the second operand, causes the result to be stored in the first operand register, causes the result to be arithmetically compared to the limit value in the second operand register pair, and, if the result is less than or equal to the limit, causes a branch to the branch address. If the result is greater than the limit, BCLE causes the instruction next in sequence to be executed. The increment value is the value in the first word of the even-odd arithmetic register pair addressed by the second operand, and the limit value is the value in the second word of the arithmetic register pair. The branch address is developed from the third operand. #### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | | |-------------------|----------|---|---------|---|-------------|--| | The second second | [symbol] | R | BCLE | R | r, r, n | | | Examples: | | | BCLE | | A1, A2, OUT | | | | | | BCLE | | X1,A2,LOOP | | | | | | | | | | ### Addressing: | FIRST REGISTER | SECOND REGISTER | BRANCH ADDRESS | | |----------------|--------------------------|----------------|--| | OPERAND | OPERAND | OPERAND | | | AR,XR, or VR | even-odd AR pair<br>only | CM only | | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-------------------------------------------------------| | | specification error if second register operand is odd | Restrictions: This instruction uses fixed point arithmetic only. Limitations: There is no index operand for address or value modification. # 7-129. BRANCH ON GREATER THAN (BCG) The instruction BCG causes the value in the register addressed by the first register operand to be added to the increment value in the even-odd arithmetic register pair addressed by the second operand, causes the result to be stored in the first operand register, causes the result to be arithmetically compared to the limit value in the second operand register pair, and, if the result is greater than the limit, causes a branch to the branch address. If the result is not greater than the limit, the instruction next in sequence to the BCG instruction is executed. The increment value is the value in the first word of the even-odd arithmetic register pair addressed by the second operand, and the limit value is the value in the second word of the arithmetic register pair. The branch address is developed from the third operand. #### GENERAL FORM: | Examples: | • | |-----------|---| | LABEL | <br> <br> | COMMAND | | OPERANDS | |----------|-------------|---------|----|--------------| | [symbol] | R | BCG | 18 | r, r, n | | | | BCG | | A1, A2, OUT | | | | BCG | | X1, A2, LOOP | #### Addressing: | FIRST REGISTER | SECOND REGISTER | BRANCH ADDRESS | | |----------------|--------------------------|----------------|--| | OPERAND | OPERAND | OPERAND | | | AR, XR, or VR | even-odd AR pair<br>only | CM only | | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-------------------------------------------------------| | +, 0, or - | specification error if second register operand is odd | Restrictions: This instruction uses fixed point arithmetic only. Limitations: There is no index operand for address or value modification. # 7-130. CONDITIONAL BRANCH INSTRUCTIONS Table 7-10 lists the branch instructions discussed on the following pages. Table 7-10. Conditional Branch Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|--------------------------------------------------------|-------| | BCC | Branch on Comparison Code True | 7-132 | | NOP | No operation | 7-132 | | В | Unconditional Branch | 7-132 | | BE | Branch on Compare Code of Equal | 7-132 | | BG | Branch on Compare Code of Greater Than | 7-132 | | BGE | Branch on Compare Code of Greater Than or Equal | 7-132 | | BL | Branch on Compare Code of Less Than | 7-132 | | BLE | Branch on Compare Code of Less Than or Equal | 7-132 | | BNE | Branch on Compare Code of Not Equal | 7-132 | | BCZ | Branch on Compare Code of All Bits Are Zero | 7-132 | | ВСО | Branch on Compare Code of All Bits Are One | 7-132 | | BCNM | Branch on Compare Code of Not Mixed | 7-132 | | ВСМ | Branch on Compare Code of Mixed Zeros and Ones | 7-132 | | BCNO | Branch on Compare Code of Not All Ones | 7-132 | | BCNZ | Branch on Compare Code of Not All Zeros | 7-132 | | BRC | Branch on Result Code True | 7-133 | | BZ | Branch on Result Code of Zero | 7-133 | | BPL | Branch on Result Code of Positive | 7-133 | | BZP | Branch on Result Code of Zero or Positive | 7-133 | | ВМІ | Branch on Result Code of Negative | 7-133 | | BZM | Branch on Result Code of Zero or Negative | 7-133 | | BNZ | Branch on Result Code of Not Zero | 7-133 | | BRZ | Branch on Result Code of All Bits Are Zero | 7-133 | | BRO | Branch on Result Code of All Bits Are One | 7-133 | | BRNM | Branch on Result Code of Bits Not Mixed Zeros and Ones | 7-133 | Table 7-10. Conditional Branch Instructions (Continued) | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|---------------------------------------------------------------------------------------------------------|-------| | BRM | Branch on Result Code of Bits Mixed Zeros . And Ones | 7-133 | | BRNO | Branch on Result Code of Not All Bits Ones | 7-133 | | BRNZ | Branch on Result Code of Not All Bits Zeros | 7-133 | | BAE | Branch on Arithmetic Exception | 7-134 | | BU | Branch on Floating Point Exponent Underflow | 7-134 | | ВО | Branch on Floating Point Exponent Overflow | 7-134 | | BUO | Branch on Floating Point Exponent Under-<br>flow or Overflow | 7-134 | | BX | Branch on Fixed Point Overflow | 7-134 | | BXU | Branch on Fixed Point Overflow or Floating Point Exponent Underflow | 7-134 | | вхо | Branch on Fixed Point Overflow or Floating Point Exponent Overflow | 7-134 | | вхио | Branch on Fixed Point Overflow or Floating Point Exponent Overflow or Underflow | 7-134 | | BD | Branch on Divide Check | 7-134 | | BDU | Branch on Divide Check or Floating Point Exponent Underflow | 7-134 | | BDO | Branch on Divide Check or Floating Point Exponent Overflow | 7-134 | | BDUO | Branch on Divide Check or Floating Point Exponent Overflow or Underflow | 7-134 | | BDX | Branch on Divide Check or Fixed Point Over-<br>flow | 7-134 | | BDXU | Branch on Divide Check or Fixed Point Over-<br>flow or Floating Point Exponent Underflow | 7-134 | | BDXO | Branch on Divide Check or Fixed Point Over-<br>flow or Floating Point Exponent Overflow | 7-134 | | BDXUO | Branch on Divide Check or Fixed Point Over-<br>flow or Floating Point Exponent Overflow<br>or Underflow | 7-134 | | BXEC | Branch on Execute Branch Condition True | 7-135 | # 7-131. CONDITION ALGORITHMS FOR CONDITIONAL BRANCHES The conditional branch instructions determine whether the branch path is to be taken according to whether the result is true for a logical operation between the bits in a program status field and the R field mask (mask operand) of the conditional branch instruction. The branch on comparison code true operation branches if, in the logical equation cond = $cl \cdot r_1 + cg \cdot r_2 + ce \cdot r_3$ , cond is true (one). Refer to Topic 6-58. The branch on result code true operation branches if, in the logical equation cond = $rl \cdot r_1 + rg \cdot r_2 + re \cdot r_3$ , cond is true (one). Refer to Topic 6-59. The branch on arithmetic exception operation branches if, in the logical equation cond = D $\cdot$ r<sub>0</sub> + X $\cdot$ r<sub>1</sub> + O $\cdot$ r<sub>2</sub> + U $\cdot$ r<sub>3</sub>, cond is true (one). The arithmetic exception mask is also reset, bit by bit, according to the logical equations: D = D - D $\cdot$ r<sub>0</sub>, X = X - X $\cdot$ r<sub>1</sub>, O = O - O $\cdot$ r<sub>2</sub>, and U = U - U $\cdot$ r<sub>3</sub>. Refer to Topic 6-60 and 6-61. The branch on execute branch condition operation branches if, in the logical equation cond = $c \cdot r_3$ , cond is true (one). Refer to Topic 6-57. Note: In the proceding equations, represents a logical AND, represents a logical OR, and represents a logical exclusive OR. Illustratively, these matching operations may be represented: 7-132 THE SCALAR INSTRUCTIONS FOR THE CENTRAL PROCESSOR ### 7-132. BRANCH ON COMPARISON CODE TRUE (BCC) The instruction BCC causes a branch to the effective branch address if the compare code reflects the condition(s) for branching specified by the mask operand; otherwise, the instruction next in sequence to the BCC instruction is executed in turn. This same machine instruction has an extended set of mnemonics within the assembler whereby the assembler provides the mask value for the desired branch conditions. In either method of coding, the compare code condition must have been set in the compare code field of the program status doubleword by the previous execution of an arithmetic or logical compare instruction. #### GENERAL FORMS: | Examples | : | |----------|---| | LABEL | <br> <br> | COMMAND | | OPERANDS | | |----------|---------------------------------------|---------------|-----------|---------------|--| | [symbol] | R | ВСС | R | m,[@[=]]n[,x] | | | [symbol] | 18 | code | k | [@[=]n[,x] | | | | | BCC | | LT, LSTHN, X1 | | | | · · · · · · · · · · · · · · · · · · · | NOP | | NONE, X1 | | | | | В | | ALWAYS | | | | | BE | | STOP, X2 | | | | | BG | | GO | | | | | BGE | | HERE, X4 | | | | | $\mathtt{BL}$ | THERE | | | | | | $_{ m BLE}$ | @GONE,X6 | | | | | | BNE | | NTEQUAL, X1 | | | | | BCZ | | HERE | | | | | BCO | THERE, X3 | | | | | | BCNM | GO | | | | | | BCM | OUT | | | | | | BCNO | | IN, X6 | | | | | BCNZ | | GOING, X7 | | EXTENDED CODE AND MASK DEFINITIONS: The masks for specifying branch conditions are defined in the following table with the assembler mnemonics that will provide the masks without coding them in the operand field: | MASK<br>VALUE | ARITH<br>CODE | DEFINITIONS | | | | | |---------------|---------------|------------------------------------------------------|--------------------------------------------|------|--|--| | 0 | NOP | no operation, take | no operation, take next instruction | | | | | | | | BRANCH IF COMPARE CODE<br>REFLECTS COMPARE | | | | | | | ARITHMETIC RESULT OF LOGICAL RESULT OF | | | | | | 1 | BE | equal | all zeros | BCZ | | | | 2 | ВG | greater than all ones | | всо | | | | 3 | BGE | greater than or equal not mixed ones and zeros | | BCNM | | | | 4 | ВL | less than mixed ones and zeros | | всм | | | | 5 | BLE | less than or equal not all ones | | BCNO | | | | 6 | BNE | not equal not all zeros | | BCNZ | | | | 7 | В | unconditional branch, go to effective branch address | | | | | ### Addressing: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | |-----------------|---------------|-------------------| | CM only | zero or XR | CM only | | COMPARE CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------|-----------------------| | not affected | none ` | | RESULT CODE | | | not affected | | # 7-133. BRANCH ON RESULT CODE TRUE (BRC) The instruction BRC causes a branch to the effective branch address if the result code reflects the condition(s) for branching specified by the mask operand; otherwise, the instruction next in sequence to the BRC instruction is executed in turn. This same machine instruction has an extended set of mnemonics within the assembler whereby the assembler provides the mask value for the desired branch conditions. In either method of coding, the result code condition must have been set in the result code field of the program status doubleword by the previous execution of an instruction which affects the result code. ### GENERAL FORMS: Examples: | LABEL | | COMMAND | | OPERANDS | |----------|---|----------------|-----------|-----------------| | [symbol] | R | BRC | 18 | m,[@[=]]n[,x] | | [symbol] | R | code | 18 | [@[=]]n[,x] | | | | BRC | | NEG, INCOMP, X3 | | | | BZ | | HERE, X2 | | | | $\mathtt{BPL}$ | | THERE, X3 | | | | BZP | | AGAIN, X3 | | | | BMI | | OUT, X5 | | | | BZM | | NOPE, X6 | | | | BNZ | | AROUND, X7 | | | | BRZ | | AGAIN, X2 | | | | BRO | | AROUND, X3 | | | | BRNM | | LOOP, X4 | | | | BRM | HERE, X5 | | | | | BRNO | THERE, X6 | | | | | BRNZ | | OUT, X7 | EXTENDED CODE AND MASK DEFINITIONS: The masks for specifying branch conditions are defined in the following table with the assembler mnemonics that will provide the masks without coding them in the operand field: | MASK<br>VALUE | ARITH<br>CODE | DEFINIT | LOGIC<br>CODE | | | | |---------------|---------------|------------------------------------------------------|----------------------------------------|-------|--|--| | 0 | | no operation, take | | | | | | | | BRANCH IF RESULT | BRANCH IF RESULT CODE REFLECTS | | | | | | | ARITHMETIC RESULT OF | ARITHMETIC RESULT OF LOGICAL RESULT OF | | | | | 1 | ВZ | zero all bits zero | | BRZ | | | | 2 | BPL | positive | all bits one | BRO | | | | 3 | BZP | zero or positive | not mixed | BRNM | | | | 4 | ВМІ | negative mixed zeros and ones | | BRM | | | | 5 | BZM | zero or negative not all ones | | B RNO | | | | 6 | BNZ | not zero not all zeros | | BRNZ | | | | 7 | | unconditional branch, go to effective branch address | | | | | # Addressing: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | |-----------------|---------------|-------------------| | CM only | zero or XR | CM only | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | Note: Although the mask values of zero and seven with the BRC instruction produce a no operation and an unconditional branch, respectively, there is no corresponding mnemonic such as NOP or B to produce those masks as there is for the BCC instruction. The assembler is implemented to produce a machine instruction with the operation code of 91 only for NOP and B. # 7-134. BRANCH ON ARITHMETIC EXCEPTION (BAE) The instruction BAE causes a branch to the effective branch address if the arithmetic exception code reflects the occurrence of the arithmetic exception(s) specified as the branch condition by the mask operand; otherwise, the instruction next in sequence to the BAE instruction is executed in turn. The conditions tested by the BAE instruction are reset to zero in the arithmetic exception code; those not tested are not reset thus permitting cumulative arithmetic exception detection. This same machine instruction has an extended set of mnemonics within the assembler whereby the assembler provides the mask value for the desired branch conditions. In either method of coding, the arithmetic exception code must have been set in the arithmetic exception code field of the program status doubleword by the previous execution of an instruction which affects the arithmetic exception code. ### GENERAL FORM: | | LABEL | 1 | COMMAND | | OPERANDS | |-----------|----------|---|----------------|---|---------------| | | [symbol] | R | BAE | R | m,[@[=]]n[,x] | | | [symbol] | β | code | B | [@[=]]n[,x] | | Examples: | | | BAE | | AEX, MESG, X4 | | | | | BU | | ERROR, X1 | | | | | ВО | | STOP, X2 | | | | | BUO | | END, X3 | | | | | BX | | AGAIN, X4 | | | | | BXU | | WHY, X5 | | | | | BXO | | @WHERE,X6 | | | | | BXUO | | HERE, X7 | | | | | BD | | THERE, X1 | | | | | $\mathtt{BDU}$ | | AROUND, X2 | | | | | BDO | | @LOOP, X3 | | | | | BDUO | | OUT, X4 | | | | | BDX | | GO, X5 | | | | | BĐXU | | GONE, X6 | | | | | BDXO | | GOING, X7 | | : | | | BDUXO | | ENOUGH, X1 | EXTENDED CODE AND MASK DEFINITIONS: The masks for specifying branch conditions are defined in the following table with the assembler mnemonics that will provide the masks without coding them in the operand field. | MASK<br>VALUE | BRANCH IF ARITHMETIC EXCEPTION CODE REFLECTS | CODE | |---------------|---------------------------------------------------------------------------------------|-------| | 0 | no operation, take next instruction | | | 1 | floating point exponent underflow | BU | | 2 | floating point exponent overflow | во | | 3 | floating point exponent underflow or overflow | BUO | | . 4 | fixed point overflow | BX | | 5 | fixed point overflow or floating point exponent underflow | BXU | | 6 | fixed point overflow or floating point exponent overflow | вхо | | 7 | fixed point overflow or floating point exponent underflow or overflow | BXUO | | 8 | divide check | BD | | 9 | divide check or floating point exponent underflow | BDU | | 10 | divide check or floating point exponent overflow | BDO | | 11 | divide check or floating point exponent underflow or overflow | BDUO | | 12 | divide check or fixed point overflow | BDX | | 13 | divide check or fixed point overflow or floating point exponent underflow | BDXU | | 14 | divide check or fixed point overflow or floating point exponent overflow | врхо | | 15 | divide check or fixed point overflow or floating point exponent underflow or overflow | BDXUO | # Addressing: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | |-----------------|---------------|-------------------| | CM only | zero or XR | CM only | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | | | | | | | # 7-135. BRANCH ON EXECUTE BRANCH CONDITION (BXEC) The instruction BXEC causes a branch to the effective branch address if the branch or skip register reflects the previous occurrence of an execute instruction (XEC) (see Topic 7-161) which caused execution of a conditional branch or skip instruction wherein the condition for branching or skipping was satisfied; otherwise, the instruction next in sequence to the BXEC instruction is executed in turn. The branch or skip condition bit of the branch or skip register in the program status doubleword is reset to zero whenever the BXEC instruction is executed. #### GENERAL FORM: | LABEL | <br> | COMMAND | | OPERANDS | | |----------|------|---------|---|-----------|----------------------------------------| | [symbol] | R | BXEC | R | [@]n[,x] | | | | | BXEC | | HERE, X1 | ······································ | | | | BXEC | | @SAVE, X2 | | # Addressing: Examples: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | |-----------------|---------------|-------------------| | CM only | zero or XR | CM only | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | # 7-136. UNCONDITIONAL BRANCH INSTRUCTIONS Table 7-11 lists the unconditional branch instructions discussed on the following pages. See the conditional branch instructions for unconditional branches and skips that may be derived from them. Table 7-11. Unconditional Branch Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|---------------------------------------------------------------|-------| | BLB | Branch and Load Base Register With Program<br>Counter | 7-137 | | BLX | Branch and Load Index or Vector Register With Program Counter | 7-138 | # 7-137. BRANCH AND LOAD BASE REGISTER WITH PROGRAM COUNTER (BLB) The instruction BLB causes the program counter value incremented by unity to be loaded into the base register addressed by the register operand, and causes an unconditional branch to the effective branch address. ### GENERAL FORM: | Examples | | |----------|--| | | | | LABEL | 1 | COMMAND | <br> <br> | OPERANDS | |----------|---|-------------|-------------|---------------| | [symbol] | R | BLB | R | r,[@[=]]n[,x] | | | | BLB | ,, <u>.</u> | B1,0 | | | | $_{ m BLB}$ | | B2,@SAVE,X2 | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|---------|---------------|-----------| | OPERAND | OPERAND | OPERAND | ADDRESS | | BR | CM only | zero or<br>XR | CM only | ## Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | Note: Since it is the second word of the program status doubleword that is being loaded into the base register, the register will contain in its eight most significant bits the arithmetic exception condition code and the arithmetic exception condition mask. See Topic 6-56 for details of the program status doubleword. This program status information can be reinstated by use of the LAM and LAC instructions. # 7-138. BRANCH AND LOAD INDEX OR VECTOR REGISTER WITH PROGRAM COUNTER (BLX) The instruction BLX causes the program counter value incremented by unity to be loaded into the index register or vector register addressed by the register operand, and causes an unconditional branch to the effective branch address. ### GENERAL FORM: | | LABEL | . <br> | COMMAND | | OPERANDS | |-----------|----------|---------|---------|---|---------------| | T3 1 | [symbol] | R | BLX | R | r,[@[=]]n[,x] | | Examples: | | | BLX | | X1,0 | | , | | | BLX | | V1,@SAVE,X1 | # Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|---------|---------------|-----------| | OPERAND | OPERAND | OPERAND | ADDRESS | | XR or VR | CM only | zero or<br>XR | CM only | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | | | | | |----------------------|-----------------------|--|--|--|--| | not affected | none | | | | | Note: Since it is the second word of the program status doubleword that is being loaded into the index or vector register, the register will contain in its eight most significant bits the arithmetic exception condition code and the arithmetic exception condition mask. See Topic 6-56 for details of the program status doubleword. This program status information can be reinstated by use of the LAM and LAC instructions. # 7-139. STACK INSTRUCTIONS Table 7-12 lists the stack instructions discussed on the following pages. See Topic 7-140 for the definition of a stack operation. Table 7-12. Stack Instructions | MNEMONIC | INSTRUCTION NAMES | TOPIC | |----------|----------------------------------------|-------| | PSH | Push Word Into Last-In-First-Out Stack | 7-141 | | PUL | Pull Word From Last-In-First-Out Stack | 7-142 | | MOD | Modify Stack Parameter Doubleword | 7-143 | #### 7-140. STACK INSTRUCTION DEFINITION The stack instructions are for use on push down stacks. They push, pull, and modify pointers on a stack by manipulating a pair of adjacent central memory words (called the stack parameter doubleword). The effective address of the instruction addresses the first word of the pair. The stack parameter doubleword has the following format: The word count (WC) is the number of words currently in the stack $(2^{15}-1)$ words maximum) and the space count (SC) is the count of unused words remaining in the stack $(2^{15}-1)$ words maximum). The stack pointer (SP) is the 24-bit central memory address of the next available location in the stack. Modification of the stack pointer is by full 32-bit two's complement addition. If the stack acted upon by the stack instruction permits the specified operation, the instruction next in sequence to the stack instruction is skipped; if the operation exceeds the stack parameters (i.e., the stack is already full for PSH, is already empty for PUL, or does not have enough entries or enough spaces for MOD), the next instruction is executed. Thus, the instruction following a stack instruction would be a pointer to a routine that handles the case of a full stack, of an empty stack, or of a stack with inadequate parameters for modification. Note: The programmer must provide the actual stack and the stack parameter doubleword. The stack parameter doubleword might, for example, be created by DATA directives or by store instructions. # 7-141. PUSH WORD INTO LAST-IN-FIRST-OUT STACK (PSH) The instruction PSH causes the data in the arithmetic register addressed by the register operand to be stored in the next available location in a stack and causes the stack parameter doubleword to be updated. The effective address specifies the address of the stack parameter doubleword that describes the stack. If the stack is already full (i.e., the space count is zero), the parameters are not changed and the instruction next in sequence to the PSH instruction is executed; otherwise, the next instruction is skipped. #### GENERAL FORM: | Example | s | • | |---------|---|---| | LABEL | <br> | COMMAND | <br> <br> | OPERANDS | | |----------|------|---------|-------------|-------------|--| | [symbol] | R | PSH | R | r,[@]n[,x] | | | | | PSH | | Al,STACK | | | | | PSH | | A1,@ADDR,X1 | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|--------------------------|---------------|-------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd<br>pair only | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | <u>Limitations</u>: The maximum number of stack entries addressable by this instruction is $2^{15}$ -1. <u>Note</u>: Updating the stack parameter doubleword includes incrementing the word count by unity, decrementing the space count by unity, and incrementing the stack pointer by unity. # 7-142. PULL WORD FROM LAST-IN-FIRST-OUT STACK (PUL) The instruction PUL causes the data in the last created entry in a stack to be loaded into the arithmetic register addressed by the register operand and causes the stack parameter doubleword to be updated. The effective address specifies the address of the stack parameter doubleword that describes the stack. If the stack is already empty (i.e., the word count is zero), the parameters are not changed and the instruction next in sequence to the PUL instruction is executed; otherwise, the next instruction is skipped. #### GENERAL FORM: | | LABEL | <br> <br> | COMMAND | | OPERANDS | | |-----------|----------|-------------|---------|---|-------------|--| | | [symbol] | R | PUL | R | r,[@]n[,x] | | | Examples: | | | PUL | | A1,STACK | | | | | | PUL | | A1,@ADDR,X1 | | # Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|--------------------------|---------------|--------------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR,<br>VR, or CM | zero or<br>XR | BR, AR, XR, VR,<br>or CM; even-odd'<br>pair only | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | <u>Limitations</u>: The maximum number of stack entries addressable by this instruction is $2^{15}$ -1. Note: Updating the stack parameter doubleword includes decrementing the word count by unity, incrementing the space count by unity, and decrementing the stack pointer by unity. # 7-143. MODIFY STACK PARAMETER DOUBLEWORD (MOD) The instruction MOD causes the stack parameter doubleword addressed by the effective address to be modified by the value in the left half of the arithmetic register addressed by the register operand. A negative (two's complement) modification value causes deletion of the most recent stack entries, and a positive modification value causes creation of a gap of unused stack locations. If the modification would cause either the word count (exceed the number of present entries for negative modification) or the space count (exceed the maximum table length for positive modification) to become negative, the stack parameter doubleword is not modified and the instruction next in sequence to the MOD instruction is executed; otherwise, the next instruction is skipped. ### GENERAL FORM: | Examples: | |-----------| | LABEL | | COMMAND | | OPERANDS | |----------|---|---------|---|-------------| | [symbol] | R | MOD | R | r,[@]n[,x] | | | | MOD | | A1,STACK | | | | MOD | | A1,@ADDR,X1 | ### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |--------------|-------------|---------|-------------------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | left half of | BR, AR, XR, | zero or | BR, AR, XR, VR, or CM; even-odd pair only | | AR, only | VR, or CM | XR | | # Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | <u>Limitations</u>: The modification value, x, is limited to the range: $-2^{15} \le x \le 2^{15} - 1$ . Note: Modification includes, if x is the modification value, the algebraic addition of x to the word count, algebraic subtraction of x from the space count, and algebraic addition of x to the stack pointer. Note: This instruction does not alter the stack; it alters the stack parameters and, therefore, the entry to which the stack parameter doubleword presently points. # 7-144. CONVERSION AND NORMALIZATION INSTRUCTIONS Table 7-13 lists the instructions for converting floating point numbers to fixed point numbers and vice versa, and the floating point normalization instructions that are discussed on the following pages. Table 7-13. Floating Point/Fixed Point Conversion Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|-----------------------------------------------------------|-------| | FLFX | Convert Floating Point Word to Fixed Point Word | 7-148 | | FLFH | Convert Floating Point Word to Fixed Point Halfword | 7-149 | | FDFX | Convert Floating Point Doubleword to Fixed Point Word | 7-150 | | FXFL | Convert Fixed Point Word to Floating Point Word | 7-151 | | FHFL | Convert Fixed Point Halfword to Floating Point Word | 7-152 | | FXFD | Convert Fixed Point Word to Floating Point Doubleword | 7-153 | | FHFD | Convert Fixed Point Halfword to Floating Point Doubleword | 7-154 | | NFX | Normalize Fixed Point Word | 7-155 | | NFH | Normalize Fixed Point Halfword | 7-156 | # 7-145. ALGORITHM FOR FLOATING POINT TO FIXED POINT CONVERSIONS The conversion of floating point values to fixed point values is performed by the following steps: - 1. Record the sign of the floating point fraction. - 2. Subtract 40 base 16 from the biased hexadecimal exponent to obtain the unbiased hexadecimal exponent. - 3. Multiply the unbiased hexadecimal exponent by 4 (shift left two bit positions) to obtain the equivalent binary exponent, be, (nine bits including sign). - 4. Align the most significant bit of the floating point fraction (bit position 8) into bit position 1 of the fixed point output register. - 5. Insert a zero into the sign bit (bit position 0) of the fixed point output register. - 6. Obtain the shift factor, h, for the value in the fixed point output register: - a. Add 31 to the scale factor, sf, (obtained from the effective halfword address), and - b. subtract the binary exponent (obtained in step 3), so that - c. h = 31 + sf be. - 7. Shift the contents of the fixed point output register: - a. right h bit positions if h is positive. - b. left h bit positions if h is negative, or - c. not at all if h is zero. - 8. If and only if the sign (recorded in step 1) was negative, take the two's complement of the number in the fixed point output register. - 9. Send the content of the fixed point output register to its single word or halfword, as appropriate, destination. #### 7-146. ALGORITHM FOR FIXED POINT TO FLOATING POINT CONVERSIONS The conversion of fixed point values to floating point values is performed by the following steps: - 1. Determine the sign of the fixed point integer to be converted, and - a. record the sign information, and - b. if and only if it is negative, take the two's complement of the fixed point number. - 2. Add 32 to the binary scale factor, sf, obtained from the effective halfword address (move the decimal from the right to the left end of the value). - 3. Perform a floating point normalization on the fixed point fraction by - a. shifting the fraction left a multiple of four-bit units until at least one of the four most significant bit positions contains a one, and - b. subtracting four from the binary exponent for each four-bit unit, h, shifted, so that: be = sf + 32 4h. - 4. Convert the binary exponent to a hexadecimal exponent by - a. shifting the fraction according to the two least significant bits of the binary exponent. [If these bits are (00) no shift occurs.] - (1) if no overflow would occur, shift left one bit for (01), two bits for (10), and three bits for (11), or - (2) if overflow would occur on left shift, add four to the binary exponent and shift the fraction right one bit for (11), two bits for (10), and three bits for (01); and - b. shifting the binary exponent right two bits (i.e., divide by four). - 5. Produce the biased hexadecimal exponent by adding 64 to the hexadecimal exponent modulo 128. - 6. Assemble the floating point number by - a. placing the normalized fraction in the fraction portion of the floating point output, - b. placing the biased hexadecimal exponent in the exponent portion of the floating point output, and - c. placing the sign information saved in step la in the most significant bit of the floating point output. - 7. Send the result to its singleword or doubleword, as appropriate, destination. Note: The operation of both conversion algorithms takes place in the arithmetic unit in registers that are not accessible to the programmer. # 7-147. FIXED POINT NORMALIZATION A fixed point number is said to be normalized when it differs in its two most significant bits, i.e., when the bit pattern is 01 or 10. A fixed point zero is considered to be normalized. A normalization instruction causes the fixed point value to be shifted left until the two most significant bits differ (unless the value was initially zero), counts the number of bit positions shifted, and stores the shift count as a negative number (two's complement) or zero. # 7-148. CONVERT FLOATING POINT WORD TO FIXED POINT WORD (FLFX) The instruction FLFX causes the floating point word in the arithmetic register addressed by the register operand to be converted to a fixed point word according to the scale factor in the effective halfword address and causes the result to be loaded into the arithmetic register. ### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|------------| | | [symbol] | FLFX | r,[@]n[,x] | | Examples: | | FLFX | Al, FACTOR | | | | FLFX | A1,@CM,X1 | ### Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|---------------------------------------|------------------|----------------|----------------------------------------| | AR,<br>fullword | left half<br>of BR, AR,<br>XR, VR, or | zero<br>XR | n/a<br>even | left half of BR,<br>AR, XR, VR, or CM | | | CM | | odd | right half of BR,<br>AR, XR, VR, or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | | | |----------------------|-----------------------|--|--| | +,0, or - | fixed point overflow | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### 7-149. CONVERT FLOATING POINT WORD TO FIXED POINT HALFWORD (FLFH) The instruction FLFH causes the floating point word in the arithmetic register addressed by the register operand to be converted to a fixed point halfword according to the scale factor in the effective halfword address and causes the result to be loaded into the left half of the arithmetic register. ### GENERAL FORM: | LABEL | COMMAND | OPERANDS | | |----------|---------|-------------|--| | [symbol] | K FLFH | r,[@]n[,x] | | | | FLFH | A1, FACTOR | | | | FLFH | A1,@WORD,X1 | | # Addressing: Examples: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|--------------------|------------------|---------------------------------------|---------------------------------------| | AR,<br>fullword | - | R, AR, | n/a<br>even | left half of BR,<br>AR, XR, VR, or CM | | CM | | odd | right half of BR, · AR, XR, VR, or CM | | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +,0,or - | fixed point overflow | | | | | | | | | | | | | | | | | | | | | | | | | # 7-150. CONVERT FLOATING POINT DOUBLEWORD TO FIXED POINT WORD (FDFX) The instruction FDFX causes the floating point doubleword in the even-odd arithmetic register pair addressed by the register operand to be converted to a fixed point word according to the scale factor in the effective halfword address and causes the result to be loaded into the even arithmetic register. #### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | | |-----------|----------|---|---------|---|-------------|---| | | [symbol] | R | FDFX | R | r,[@]n[,x] | | | Examples: | | | FDFX | | A2, FACTOR | | | | | | FDFX | | A4,@HERE,X1 | : | #### Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|--------------------------|------------------|----------------|----------------------------------------| | even-odd | left half | zero | n/a | left half of BR, | | AR pair | of BR, AR,<br>XR, VR, or | XR | even | AR, XR, VR, or CM | | | СМ | | odd | right half of BR,<br>AR, XR, VR, or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-------------------------------------------------------| | +,0,or - | fixed point overflow specification error if AR is odd | | | | # 7-151. CONVERT FIXED POINT WORD TO FLOATING POINT WORD (FXFL) The instruction FXFL causes the fixed point word in the arithmetic register addressed by the register operand to be converted to a floating point word according to the scale factor in the effective halfword address and causes the normalized result to be loaded into the arithmetic register. #### GENERAL FORM: | LABEL | | COMMAND | <br> 1<br> | OPERANDS | | |----------|---|---------|---------------|-------------|--| | [symbol] | R | FXFL | R | r,[@]n[,x] | | | | | FXFL | | Al, FACTOR | | | | | FXFL | | A1,@HERE,X1 | | # Addressing: Examples: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|--------------------------|------------------|----------------|----------------------------------------| | AR, | left half | zero | n/a | left half of BR, | | fullword | of BR, AR,<br>XR, VR, or | XR | even | AR, XR, VR, or CM | | | CM | | odd | right half of BR,<br>AR, XR, VR, or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|----------------------------------| | +,0,or - | floating point exponent overflow | | | | | | | | | | | | | | | | | | | | | | | | | # 7-152. CONVERT FIXED POINT HALFWORD TO FLOATING POINT WORD (FHFL) The instruction FHFL causes the fixed point halfword in the left half of the arithmetic register addressed by the register operand to be converted to a floating point singleword according to the scale factor in the effective halfword address and causes the normalized result to be loaded into the arithmetic register. ## GENERAL FORM: | Exampl | es: | |--------|-----| | LABEL | | COMMAND | | OPERANDS · | | |----------|---|-----------------|---|-------------|--| | [symbol] | R | FHFL | R | r,[@]n[,x] | | | | | FHFL | | Al, FACTOR | | | | | $\mathtt{FHFL}$ | | A1,@(A2),X1 | | | | | | | | | ### Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|-------------------------|------------------|----------------|----------------------------------------| | AR,<br>fullword | left half<br>of BR, AR, | zero | n/a | left half of BR,<br>AR, XR, VR, or CM | | lanword | XR, VR, or | XR | even | AIG XIG VIG OI CWI | | | CM | | odd | right half of BR,<br>AR, XR, VR, or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | | | |----------------------|----------------------------------|--|--| | +,0,or - | floating point exponent overflow | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 7-153. CONVERT FIXED POINT WORD TO FLOATING POINT DOUBLEWORD (FXFD) The instruction FXFD causes the fixed point word in the even arithmetic register of the even-odd pair addressed by the register operand to be converted to a floating point doubleword according to the scale factor in the effective half-word address and causes the normalized result to be loaded into the even-odd arithmetic register pair. #### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|-------------| | · | [symbol] | لا FXFD | r,[@]n[,x] | | Examples: | | FXFD | A2, FACTOR | | | | FXFD | A4,@HERE,X1 | #### Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|--------------------------|------------------|----------------|----------------------------------------| | even-odd | left half | zero | n/a | left half of BR, | | AR | of BR, AR,<br>XR, VR, or | XR | even | AR, XR, VR, or CM | | | CM | | odd | right half of BR,<br>AR, XR, VR, or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-------------------------------------------------------------------| | +,0,or - | floating point exponent overflow specification error if AR is odd | # 7-154. CONVERT FIXED POINT HALFWORD TO FLOATING POINT DOUBLE-WORD (FHFD) The instruction FHFD causes the fixed point halfword in the left half of the even register of the even-odd arithmetic register pair addressed by the register operand to be converted to a floating point doubleword according to the scale factor in the effective halfword address and causes the normalized result to be loaded into the even-odd arithmetic register pair. #### GENERAL FORM: | Exampl | 65 | | |--------|----|--| | LABEL | <br> <br> | COMMAND | | OPERANDS | | |----------|-------------|-----------------|----|-------------|--| | [symbol] | R | FHFD | 18 | r,[@]n[,x] | | | | | FHFD | | Al, FACTOR | | | | | $\mathtt{FHFD}$ | | A1,@HERE,X1 | | #### Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|--------------------------|------------------|----------------|----------------------------------------| | even-odd | left half | zero | n/a | left half of BR, | | AR pair | of BR, AR,<br>XR, VR, or | XR | even | AR, XR, VR, or CM | | | CM | | odd | right half of BR,<br>AR, XR, VR, or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-------------------------------------------------------------------| | +,0,or - | floating point exponent overflow specification error if AR is odd | | | | # 7-155. NORMALIZE FIXED POINT WORD (NFX) The instruction NFX causes the fixed point word in the effective address to be normalized and causes the normalized fixed point result to be loaded into the even register of the even-odd arithmetic register pair addressed by the register operand and the scale factor to be loaded into the right half of the odd register. The left half of the odd register is filled with zeros. #### GENERAL FORM: | LABEL | " | COMMAND | <br> | OPERANDS | | |----------|---|---------|------|-------------|--| | [symbol] | R | NFX | R | r,[@]n[,x] | | | | | NFX | | A2, PNPT | | | | | NFX | | A2,@INPT,X1 | | #### Addressing: Examples: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |--------------|-------------|---------|-----------------------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR; even-odd | BR, AR, XR, | zero or | BR, AR, XR, VR, or CM; singleword | | pair only | VR, or CM | XR | | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|----------------------------------| | +,0,or - | specification error if AR is odd | | | | | | | | | | | | | | | | | | | | | | | | | # 7-156. NORMALIZE FIXED POINT HALFWORD (NFH) The instruction NFH causes the fixed point halfword in the effective halfword address to be normalized and causes the normalized fixed point result to be loaded into the left half of the arithmetic register addressed by the register operand and the scale factor to be loaded into the right half of the register. #### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|--------------| | | [symbol] | NFH | 以 r,[@]n[,x] | | Examples: | | NFH | Al, INPTH | | | | NFH | A1,@INPTH,X1 | # Addressing: | REGISTER<br>OPERAND | ADDRESS<br>OPERAND | INDEX<br>OPERAND | INDEX<br>VALUE | EFFECTIVE<br>ADDRESS | |---------------------|--------------------------|------------------|----------------|----------------------------------------| | AR | left half | zero | i · | left half of BR, | | fullword | of BR, AR,<br>XR, VR, or | XR | even | AR, XR, VR, or CM | | | CM | | odd | right half of BR,<br>AR, XR, VR, or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | +,0,or - | none | | | | | | | | | | | | | | | | | | | # 7-157. MISCELLANEOUS INSTRUCTIONS Table 7-14 lists the miscellaneous instructions discussed on the following pages. Table 7-14. Miscellaneous Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|--------------------------|-------| | XCH | Exchange Words | | | LLA | Load Look Ahead | 7-159 | | LEA | Load Effective Address | 7-160 | | XEC | Execute | 7-161 | | INT | Interpret | 7-162 | | МСР | Monitor Call and Proceed | 7-163 | | MCW | Monitor Call and Wait | 7-164 | # 7-158. EXCHANGE WORDS (XCH) The instruction XCH causes the current data in the effective address to replace the data in the arithmetic register addressed by the register operand while the current data in the arithmetic register replaces the contents of the effective address; i.e., the current contents of the locations are exchanged. #### GENERAL FORM: | | LABEL | COMMAND | OPERANDS | : | |-----------|----------|---------|--------------|---| | | [symbol] | XCH | r,[@]n[,x] | | | Examples: | | XCH | Al, RSLT | | | | | XCH | A1, (A2), X1 | | #### Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |----------|-------------|---------|-----------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | VR, or CM | XR | or CM | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | # 7-159. LOAD LOOK AHEAD (LLA) The instruction LLA provides the lookahead unit in the Central Processor control hardware with information about a branch instruction that is to be executed and that will most frequently take the branch path. The instruction LLA does not influence the branch decision; it only increases the execution speed of a closed instruction loop. The value of the immediate operand i must be equal to the number of executable instructions from the instruction LLA through the branch instruction that is expedited; e.g., if LLA were in location 401 and the branch instruction were in location 429, the value of i would be 28. #### GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | | |-----------|----------|---------|---|----------|--| | | [symbol] | LLA لا | R | i | | | Examples: | | LLA | | 28 | | | | | LLA | | BRCH-\$ | | Addressing: This instruction permits no programmer addressing; the registers into which LLA enters values are internal to the Central Processor control hardware, and index modification of the immediate operand is not performed. | Program Status: RESULT CODE REFLECTS | | PROGRAM INTERRUPTIONS | |--------------------------------------|--------------|-----------------------| | | not affected | none | Restrictions: This instruction may have only an immediate operand without index modification. Limitations: The maximum applicable program loop size, including the LLA instruction, is 255 instructions, i.e., $0 < i \le 255$ . Note: The instruction LLA must be included within the program loop defined by the expedited branch instruction so that the branch counter and branch address registers (internal to the central processor) will be reinitialized each time the program reenters the loop. Note: If the execution of a branch instruction between the LLA and the expedited branch instruction results in its branch path being taken, the branch look ahead information is discarded; if the branch path is not taken, the look ahead information remains current for the intended branch instruction. Note: The execution of a skip instruction does not alter the number of executable instructions within the domain of the LLA instruction and its related branch instruction; i. e., the instruction immediately following the skip instruction must be counted regardless of whether execution results in the instruction's being skipped. #### 7-160. LOAD EFFECTIVE ADDRESS (LEA) The instruction LEA causes its own effective address (24 least significant bits) to be developed and causes that address to be loaded into the register addressed by the register operand. The eight most significant bits are zero. #### GENERAL FORM: | LABEL | | COMMAND | | OPERANDS | | |----------|---|---------|---|---------------|--| | [symbol] | R | LEA | R | r,[@][=]n[,x] | | | | | LEA | | X1,\$ | | | | | LEA | | V1,@HERE,X1 | | ### • Examples: | Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |-------------|----------|-------------|---------|-----------------| | | OPERAND | OPERAND | OPERAND | ADDRESS | | | BR, XR, | BR, AR, XR, | zero or | BR, AR, XR, VR, | | | or VR | VR, or CM | XR | or CM | ### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | Restrictions: When used to produce an indirect address constant, this instruction does not produce a T field and, thus, no terminal indexing. See Topic 6-27 for details of the indirect address word format. <u>Limitations</u>: When this instruction (operation code) is used as an address tracing element, the 24-bit address developed leaves no traces of its mode or path of development; therefore, it will not be possible to distinguish between low memory and registers when the effective address is less than of equal to 2F; neither will it give the correct terminal address if substituted for an indexed halfword or doubleword instruction since it is always indexed as a singleword instruction. #### 7-161. EXECUTE (XEC) The instruction XEC causes the instruction at the effective address to be executed and the program counter to be incremented by one; i.e., the next instruction executed is the one following the XEC instruction. If the instruction at the effective address is a branch or skip instruction and the condition(s) for branching or skipping are true, no actual branch or skip is executed but rather the branch or skip condition bit of the branch or skip register of the program status doubleword is set to one to indicate that the condition(s) were true. The next instruction executed is still the one following the XEC instruction. #### GENERAL FORM: | | LABEL | | COMMAND | <br> <br> | OPERANDS · | | |-----------|----------|---|---------|-------------|-------------|--| | Examples: | [symbol] | R | XEC | R | [@[=]]n[,x] | | | | | | XEC | | \$+1, X2 | | | | | | XEC | | @HERE, X1 | | #### Addressing: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | |-----------------------|---------------|-----------------------| | BR, AR, XR, VR, or CM | zero or XR | BR, AR, XR, VR, or CM | #### Program Status: | COMPARE CODE EFFECT | PROGRAM INTERRUPTIONS | |------------------------------|-------------------------------| | that of instruction executed | those of instruction executed | | RESULT CODE EFFECT | | | that of instruction executed | | Note: If the XEC instruction executes a branch on execute branch condition instruction (BXEC), the branch or skip condition bit of the branch or skip register of the program status doubleword will be reset to zero if it is presently true (one) and will remain zero if it is presently false (zero). #### 7-162. INTERPRET (INT) The instruction INT causes the operation code and register (R) field of the instruction in the effective address of this instruction to be loaded (right-justified) into the even arithmetic register of the even-odd arithmetic register pair addressed by the register operand of this instruction, and causes the index, base, and displacement (T, M, and N) fields of that instruction to be loaded (right-justified) into the odd arithmetic register of the even-odd register pair. See Topic 6-2 for a detailed description of the machine code format of instructions. #### GENERAL FORM: | Examples | : | |----------|---| | LABEL | | COMMAND | <br> | OPERANDS | | |----------|---|---------|------|---------------|--| | [symbol] | R | INT | 18 | r,[@][=]n[,x] | | | | | INT | | A4, BRANCH | | | | | INT | | A2,@=THERE,X1 | | # Addressing: | REGISTER | ADDRESS | INDEX | EFFECTIVE | |--------------|-------------|---------|-----------------------| | OPERAND | OPERAND | OPERAND | ADDRESS | | AR, even-odd | BR, AR, XR, | zero or | BR, AR, XR, VR, or CM | | pair only | VR, or CM | XR | | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|----------------------------------| | not affected | specification error if AR is odd | Note: The 20 most significant bits of the even register and the 12 most significant bits of the odd register are set to zero. #### 7-163. MONITOR CALL AND PROCEED (MCP) The instruction MCP causes a monitor service request signal to be issued to the Peripheral Processor (PP) via the Central Processor/Peripheral Processor communication link, causes the single length effective logical immediate operand to be stored in central memory location 07<sub>16</sub> when the availability signal is returned, and causes the Central Processor (CP) to proceed with execution of the next instruction when the storage is complete. #### GENERAL FORM: | | LABEL | COMMAND | | OPERANDS | | |-----------|----------|---------|----|----------|--| | | [symbol] | MCP | 18 | i[,x] | | | Examples: | | МСР | | #FFC,X1 | | # Addressing: | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | |------------------|--------------------------------| | zero | none | | XR | $-2^{23} \le x \le 2^{23} - 1$ | | RESULT CODE | PROGRAM INTERRUPTIONS | |--------------|-----------------------| | not affected | none | # 7-164. MONITOR CALL AND WAIT (MCW) The instruction MCW causes a monitor service request signal to be issued to the Peripheral Processor (PP) via the Central Processor/Peripheral Processor communication link, causes the single length effective logical immediate operand to be stored in central memory location 0716 when the availability signal is returned, and causes program execution to begin with the next instruction when the proper context switch returns the program to Central Processor (CP) control. #### GENERAL FORM: | | LABEL | | COMMAND | | OPERANDS | | |-----------|----------|---|---------|---|----------|--| | | [symbol] | R | MCW | R | i[,x] | | | Examples: | | | MCW | | #F, X2 | | #### Addressing: | INDEX<br>OPERAND | IMMEDIATE<br>MODIFIER | |------------------|--------------------------------| | zero | none | | XR | $-2^{23} \le x \le 2^{23} - 1$ | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | <u>Note</u>: There is no hardware protection to ensure that the program is not returned to the Central Processor before the monitor service is completed; this is a function of system programming. # 7-165. PROGRAM STATUS INSTRUCTIONS Table 7-15 list the program status instructions discussed on the following pages. Table 7-15. Program Status Instructions | MNEMONIC | INSTRUCTION NAME | TOPIC | |----------|-------------------------------------|-------| | LAM | Load Arithmetic Exception Mask | 7-166 | | LAC | Load Arithmetic Exception Condition | 7-167 | | SPS | Store Program Status Word | 7-168 | # 7-166. LOAD ARITHMETIC EXCEPTION MASK (LAM) The instruction LAM causes the contents of bits four through seven of the effective address to replace the contents of the arithmetic exception mask register (AEM) of the program status doubleword. The effect is to enable an interrupt signal from the Central Processor (CP) to the Peripheral Processor (PP) for any arithmetic exception condition detected whose corresponding bit is now set to one in the mask. A mask bit of zero disables the interrupt for the corresponding arithmetic exception. See Topics 6-60 through 6-63 for a more detailed description of maskable interrupts. #### GENERAL FORM: | • | LABEL | COMMAND | OPERANDS | |-----------|----------|---------|--------------| | | [symbol] | K LAM K | [@[=]]n[, x] | | Examples: | | LAM | (B1) | | | | LAM | RSLT, X1 | #### Addressing: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | |-----------------------|---------------|-----------------------| | BR, AR, XR, VR; or CM | zero or XR | BR, AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | Note: This instruction may be used to reinstate an arithmetic exception mask that was stored in a base, index, or vector register by a previously executed branch and load base register (BLB) or branch and load index register (BLX) instructions. See Topic 7-137, 7-138 and 6-63. #### 7-167. LOAD ARITHMETIC EXCEPTION CONDITION (LAC) The instruction LAC causes the contents of bits zero through three of the effective address to replace the contents of the arithmetic exception code register (AEC) of the program status doubleword. A bit setting of one in the corresponding bit of the code indicates that a specific arithmetic exception condition has been detected in the execution of an instruction, and a bit setting of zero indicates that no corresponding arithmetic exception has been detected. See Topic 6-60 for a more detailed discussion of the maskable interrupts. #### GENERAL FORM: | <del>(</del> | LABEL | COMMAND | OPERANDS | |--------------|------------|---------|-------------| | ` | [symbol] & | LAC | [@[=]]n[,x] | | Examples: | LAC | | (B1) | | | | LAC | RSLT, X1 | #### Addressing: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | |-----------------------|---------------|-----------------------| | BR, AR, XR, VR, or CM | zero or XR | BR, AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |----------------------|-----------------------| | not affected | none | Note: Since the arithmetic exception code (AEC) is changed by this instruction, record of any arithmetic exceptions prior to the execution will be lost unless the current arithmetic exception code is saved through execution of a branch and load base register (BLB) or, branch and load index register (BLX). The arithmetic exception condition code loaded by this instruction may be the reinstatement of such a previously stored arithmetic exception code. See Topics 7-137, 7-138, and 6-61. # 7-168. STORE PROGRAM STATUS WORD (SPS) The instruction SPS causes the second halfword of the program status doubleword to be stored into the effective address. The left half is loaded with zeros. Refer to Topic 6-56 for a more detailed discussion of the program status doubleword. #### GENERAL FORM: | Examples | | |----------|--| | LABEL | | COMMAND | | OPERANDS | , | |----------|---|---------|----|----------|---| | [symbol] | R | SPS | 18 | [@]n[,x] | | | | | SPS | | (A1) | | | | | SPS | | SAVE, X1 | | # Addressing: | ADDRESS OPERAND | INDEX OPERAND | EFFECTIVE ADDRESS | |-----------------------|---------------|-----------------------| | BR, AR, XR, VR, or CM | zero or XR | BR, AR, XR, VR, or CM | #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | | | | |----------------------|-----------------------|--|--|--| | not affected | none | | | | Note: The instruction SPS stores only the second halfword of the program status doubleword; the full program status doubleword is stored in central memory only on a special signal from the Peripheral Processor. The second word of the program status doubleword is loaded into a register by the branch and load base register (BLB) and branch and load index register (BLX) instructions. Refer to Topics 7-137 and 7-138. #### SECTION VIII #### THE VECTOR INSTRUCTIONS FOR THE CENTRAL PROCESSOR #### 8-1. INTRODUCTION Data for vector instructions may be organized into one, two, or three dimensional arrays. A one-dimensional array with one element is called a <u>scalar</u>. A <u>vector</u> is a sequence of elements (a one-dimensional array). A two-dimensional array is a matrix. All other dimensioned arrays are called n-arrays. The vector instructions cause specific operations which are performed on two series of input data and produce one series of output data. Data is structured as vectors in memory in order to utilize the vector instructions. The definition of a specific vector operation is contained in an octet of data called the Vector Parameter File. The set of instructions which define a vector parameter file are found in Figure 8-1. There are two means of executing the operation defined by the vector parameter file: (1) the file is loaded into the vector registers from memory and executed, (2) the file residing in the vector registers is executed. The vector parameter file is described in Figure 8-1 and should be referred to often during the study of the following sections. #### 8-2. DEFINITION AND FORMATS OF VECTOR INSTRUCTIONS The Vector instructions in the ASC Central Processor define vector operations on an ordered set of data. This data may be organized into one-, two-, or three-dimensional arrays. The execution of a vector instruction requires the building of a vector parameter file and the execution of a vector execute instruction. The vector operation, the argument vectors, and the resultant vector are described in the vector parameter file. In Figure 8-1, the contents of the vector registers are described. In vector operation on three dimensional arrays, the vector looping structure is somewhat analogous to a triple nested DO structure in FORTRAN. The self inner, and outer loops of the vector operation correspond to the innermost, middle and outermost loops of a triple nested FORTRAN DO. As in FORTRAN, the outer loop determines the number of iterations of the inner loop, and the inner loop determines the number of iterations of the self loop. The analogy to FORTRAN breaks down when discussing the increment values for each loop. The vector instructions provide more power by allowing variable, positive, or negative increments in the inner and outer loops. The self loop is analogous to a vector operation such as the operation: $$\overrightarrow{A} \circ \overrightarrow{B} \longrightarrow \overrightarrow{C}$$ where • is the operation to be performed between vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ . The resultant vector is $\overrightarrow{C}$ . In reference to the vector parameter file (Figure 8-1), the starting address of vectors $\overrightarrow{A}$ , $\overrightarrow{B}$ , and $\overrightarrow{C}$ are determined by SAA, SAB, and SAC respectively. Each vector in the self loop is a contiguous array. At the end of each self loop, for two- or three-dimensional arrays, SAA, SAB and SAC will have been incremented by the length of the self loop (LEN) -1. Also the increments DAI, DBI and DCI are added to SAA, SAB and SAC respectively. The inner loop count NI, is decremented. When the inner loop has been iterated NI times, for a three-dimensional array, the outer loop increments DAO, DBO, and DCO are added to SAA, SAB, and SAC respectively. The inner loop count (NI) is reset to the original value and the outer loop count (NO) is decremented. When the outer loop count (NO) becomes zero, the vector operation is terminated. After a vector operation is described in the vector parameter file, the vector operation is performed when the Vector Load and Execute Instruction (VECTL) or the Vector Execute Instruction (VECT) is executed. The instruction VECTL causes the vector parameter file to be loaded into the vector register file, and causes the vector parameter file to be executed. The instruction VECT causes the vector parameter file presently residing in the vector register file to be executed. | VECTOR | i | LEFT | HALF | | i | RIGH | THALF | | ASSEMBLER | | |----------|---------|------|-----------------------------|--------------------|-------|------|-------|------------|-----------|---------------| | REGISTER | BYT | E0 | BYT | BYTE'1 BYTE2 BYTE3 | | | | STATEMENTS | | | | REGIOIDI | HO | H1 | H2 H3 H4 H5 H6 H7 | | | | H6 | H7 | | | | V0 | OI | PR . | ALCT SV LEN | | | | EN . | | Operation | alct, len, sv | | V 1 | <b></b> | XA | SAA | | | | | | VCTRA | a, xa | | V2 | нѕ | хв | SAB | | | | | | VCTRA | b, xb, hs | | V3 | VI | хс | SAC | | | | | | VCTRA | c, xc, vi | | V 4 | | r | DAI | | | , | DBI | | DATAH | dai, dbi | | V5 | | C | ocı | | | | NI | | DATAH | dci, ni | | V 6 | DAO | | | DBO | | | | DATAH | dao, dbo | | | . V7 | | ī | oco . | | | | NO. | | DATAH | dco, no | | | | | Ol | oiect | t VPI | F | | | Code | ed VPF | | REGISTER | | | |----------|-------|-----------------------------------------------------------------------------------------------------| | NUMBER | FIELD | SPECIFIES | | 28 | OPR | type of vector operation | | | ALCT | arithmetic or logical comparison condition | | | sv | single-valued vector | | | LEN | vector length (self loop count) | | 29 | XA | vector $\overrightarrow{A}$ starting address index | | | SAA | starting address of vector $\overrightarrow{A}$ or immediate $\overrightarrow{A}$ | | 2A | HS | right or left halfword starting addresses | | | XВ | vector B starting address index . | | | SAB | starting address of vector $\overrightarrow{\mathtt{B}}$ or immediate $\overrightarrow{\mathtt{B}}$ | | 2B | VI | self loop increment directions | | | хc | vector $\overrightarrow{C}$ starting address index | | | SAC | starting address of vector $\overrightarrow{C}$ | | 2C | DAI | inner loop increment for vector A address | | | DBI | inner loop increment for vector B address | | 2D | DCI | inner loop increment for vector $\overrightarrow{C}$ address | | | NI | inner loop count | | 2 E | DAO | outer loop increment for vector A address | | | DBO | outer loop increment for vector B address | | 2F | DCO | outer loop increment for vector $\overrightarrow{C}$ address | | | NO | outer loop count | Figure 8-1. The Vector Parameter File # 8-3. EXECUTE VECTOR PARAMETER FILE INSTRUCTIONS The following instructions cause execution of a vector parameter file that exists in the program. Note that a vector parameter file is not executed from central memory, but must first be loaded into the vector register file. # 8-4. <u>VECTOR LOAD AND EXECUTE (VECTL)</u> The instruction VECTL causes the vector parameter file addressed by the effective octet address to be loaded into the vector register file, and causes the vector parameter file to be executed. #### GENERAL FORM: | Examples | | |----------|--| | LABEL | | COMMAND | | OPERANDS | |----------|---|---------|---|--------------------| | [symbol] | R | VECTL | R | [@]n[, x] [ n[, x] | | | | VECTL | | MATX | | | | VECTL | | @VADSET, X1 | | | | | | | | | | | | | # Addressing: | ADDRESS | INDEX | EFFECTIVE | | |--------------------------|------------|-----------------------|--| | OPERAND | OPERAND | ADDRESS | | | BR, AR, XR,<br>VR, or CM | Zero or XR | BR, AR, XR, VR, or CM | | | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | | | | |-----------------------------------|------------------------------------------|--|--|--| | not useful after vector operation | those of vector operation being executed | | | | Restrictions: The effective address vector parameter file must be an octet boundary; i.e., a multiple of eight. Note: The assembler places zero in the R field which specifies that the vector parameter file must be loaded to be executed. #### 8-5. VECTOR EXECUTE (VECT) The instruction VECT causes the vector parameter file presently residing in the vector register file to be executed. #### GENERAL FORM: Examples: | LABEL | COMMAND | OPERANDS | | |----------|---------|-------------|--| | [symbol] | VECT | [@]n[, x] | | | | VECT | MATX | | | | VECT | @VADSET, X1 | | | | | | | Addressing: Addresses are not used by this instruction. #### Program Status: | RESULT CODE REFLECTS | PROGRAM INTERRUPTIONS | |-----------------------------------|------------------------------------------| | not useful after vector operation | those of vector operation being executed | <u>Note</u>: Although the assembler generates the T, M, and N fields specified in the operand of the VECT instruction, these fields are ignored. The assembler also places one in the R field which specifies that the vector parameter file to be executed is already loaded. #### 8-6. THE VECTOR PARAMETER FILE The vector parameter file specifies a complete vector operation. When a vector parameter file is loaded into (or already exists in) the vector register file, an execute vector parameter file instruction (see Topic 8-3) will cause the specified vector operation to be executed. Figure 8-1 illustrates the vector parameter file and describes its fields as they exist in the vector register file. An example of one of the general assembler statement sets that would produce a vector parameter file is also included. <u>Note</u>: The command VCTRA is a CPU procedure designed to permit symbolic coding of the three vector words of the VPF. Figure 8-2 illustrates the flow of execution of a typical vector parameter file wherein neither of the argument vectors is single-valued. Note: As a convention, the vector addressed or contained in the second word of the vector parameter file will be called argument vector $\overrightarrow{A}$ , the vector addressed or contained in the third word of the vector parameter file will be called argument vector $\overrightarrow{B}$ , and the vector addressed in the fourth word of the vector parameter file will be called the resultant vector $\overrightarrow{C}$ . #### 8-7. VECTOR OPERATION SPECIFICATION The type of vector operation is specified by the assembler mnemonic in the first instruction of the vector parameter file. The various operations available are described in Topics 8-26 through 8-51. #### 8-8. ARITHMETIC AND LOGICAL COMPARISON CONDITION SPECIFICATION The ALCT field specifies the comparison condition to be used between elements of argument vectors and specifies when the vector operation is to terminate. Both the comparison condition and terminate condition are used in vector compare instructions. For vector peak picking instructions, only the terminate condition is Figure 8-2. Flow of Execution of a Vector Parameter File checked. The terminate condition specifies whether the operation is to stop at the first true condition or to record all true conditions found in all loops of the vector parameter file. See Table 8-6 of Topic 8-38 for a complete specification of the ALCT field. #### 8-9. VECTOR LENGTH SPECIFICATION (SELF LOOP COUNT) The LEN field specifies the number of times the self-loop operation of the vector parameter file is to be executed. A value of one for the LEN field effectively makes the self loop dimension a scalar operation. Given a self loop on a one-dimensional contiguous argument vector $\overrightarrow{A}$ with m elements, the value of the LEN field is m. Range: The value of the LEN field must be within the range: $0 \le \text{LEN} \le 2^{16} - 1$ . A zero value for LEN makes the vector parameter file a no operation; the inner and outer loop conditions will not be examined. #### 8-10. SINGLE-VALUED VECTOR AND WORD SIZE SPECIFICATION The SV field specifies the attributes of the input vectors, i.e., directly addressed, immediate, or directly addressed single-valued. For multiply and dot product operations with fixed point values as the argument vector elements, the SV field also specifies the element length of the elements of the resultant vector; for divide operations with fixed point values as the argument vector elements, the SV field specifies the length of the dividend elements of the input vector $\overrightarrow{A}$ . All other operations and all floating point products, dot products, and dividends contain the element length specification as an integral part of the instruction; e.g., the instruction VAH specifies fixed point halfword addition with fixed point halfword results and ignores any word size specification in the SV field. Table 8-1 contains the complete specifications of the SV field. #### 8-11. SINGLE-VALUED VECTORS A single-valued vector is effectively a scalar operand for the self loop. | SV FIELD | VECTOR TYPE | | YPE | | | | | |----------------------------------------------------|--------------------------------------------------------------------|---|-----|-----------------------------------------------------------------|--|--|--| | VALUE | $\overrightarrow{A} \circ \overrightarrow{B} = \overrightarrow{C}$ | | | LOOP USAGE | | | | | 0 <b>-</b> 3<br>8 <b>-</b> 11 | n | n | n | all loop increments active for all input<br>vectors | | | | | 4, 12 | k | n | n | self loop increment inactive for single-<br>valued input vector | | | | | 5, 13 | n | k | n | | | | | | 6, 14 | i | n | n | all loop increments inactive for imme- | | | | | 7, 15 | n | i | n | diate vector | | | | | n = a vector of any LEN k = a single-valued vector | | | | | | | | | i = immediate | | | | | | | | ELEMENT LENGTH OF RESULT | SV FIELD | DIVISOR OR MULTIPLICAND INPUT OF: | | | |------------------------------------|-----------------------------------|------------------------|--| | VALUE | SINGLEWORD | HALFWORD | | | $0 \le SV \le 7$ $8 \le SV \le 15$ | doubleword<br>singleword | singleword<br>halfword | | <u>Note</u>: These length options apply only to products, dot products, and dividends in fixed point operations; floating point operations do not change precision. Table 8-1. Specifications of the SV Field For purposes of execution of a vector parameter file, a single-valued vector is stored as a single-element vector, i.e., this vector address is not incremented during the self loop execution, but may be incremented by either or both the inner and outer loop increments in their turns. During the execution of the self loop, only one value will be acquired from central memory for the single-valued vector. The SV field specifies which argument vector is single-valued (see Table 8-1). Figure 8-3. Flow of Execution with B Single-Valued Example: Given $\overrightarrow{A} \circ \overrightarrow{B} = \overrightarrow{C}$ , $$\overrightarrow{A} = [a_1 \ a_2 \dots a_m] \text{ and } \overrightarrow{B} = [B_1 \ B_2 \dots B_r]$$ where each Bi is a single-valued vector with m elements. The LEN value in the vector parameter file is m to encompass $\overrightarrow{A}$ in the self loop. The SV value is five or thirteen to denote $\overrightarrow{B}$ as single-valued within the self loop only. The inner loop count is r to encompass $\overrightarrow{B}$ in the inner loop. The inner loop increment values are -m + 1 for $\overrightarrow{A}$ to reposition the counter for the next self loop, and positive unity for B and C to position to the next column. In performing an operation on $\overrightarrow{A}$ and $\overrightarrow{B}$ , $\overrightarrow{B}$ is treated as a vector having one element $b_i$ in any given self loop. However, on each successive inner loop $i=1,2,\ldots,r$ . Thus, a different $b_i$ is used only when the inner loop increment is used. #### 8-12. IMMEDIATE VECTORS An immediate single-valued vector is a single-valued vector that has the additional restriction that none of the loop increments are active. The vector value resides in the vector parameter file itself; thus, the immediate vector is obtained from the vector parameter file for all loops and never from central memory. The argument vector that is to be immediate is specified by the SV field (see Table 8-1). A halfword immediate vector is contained in the right half of the second or the third word, as specified. The value of such a vector is within the range: $-2^{15} \le i \le 2^{15} - 1.$ A singleword fixed point immediate vector occupies the entire vector parameter file word; i.e., the second or third word as specified. The value of such a vector is within the range: $-2^{31} < i < 2^{31} - 1$ . If the HS field is used to denote a starting address in the right halfword, then the single-valued vector must be $\overrightarrow{A}$ . A single-valued vector $\overrightarrow{B}$ would override the HS field. A floating point immediate vector occupies the entire vector parameter file word; i.e., the second or third word as specified. This applies to both singleword and doubleword operations; the second word of such a vector in a doubleword operation is treated as being filled with zeros. GENERAL FORMS: The general forms of the assembler coded vector parameter files for halfword immediate vectors are as follows: | LABEL | <br> <br> | COMMAND | <br> <br> | OPERAND | | |----------|-----------|----------|-----------|--------------------|--| | [symbol] | Þ | mnemonic | 1 16 | alct, len, sv | | | [symbol] | l js | VCTRA | 1 16 | a, xa or i | | | [symbol] | P, P, | VCTRA | ! 16<br>! | i, hs or b, xb, hs | | | [symbol] | R | VCTRA | ľЪ | c, xc, vi | | | [symbol] | R | DATAH | i þ | dai, dbi | | | [symbol] | R | DATAH | 1 16 | dci, ni | | | [symbol] | R | DATAH | 16 | dao, dbo | | | [symbol] | Þ | DATAH | 16 | deo, no | | For singleword and doubleword immediate vectors the general form is shown below. | LABEL | | COMMAND | | OPERAND | |----------|------------|------------------|-----------------|-------------------| | [symbol] | )¢ | mnemonic | 1 14 | alct, len, sv | | [symbol] | )5<br> | VCTRA or<br>DATA | <br> 16<br> | a, xa or<br>i | | [symbol] | <b>1</b> 8 | DATA or<br>VCTRA | <br> 16<br> | i or<br>b, xb, hs | | [symbol] | )¢ | VCTRA | !<br> ]6 | c, xc, vi | | [symbol] | )¢ | DATAH | 16 | dai, dbi | | [symbol] | 18 | DATAH | <i>b</i> | dci, ni | | [symbol] | )s | DATAH | <sub> </sub> 6 | dao, dbo | | [symbol] | <b>1</b> 8 | DATAH | <i>)</i> 5 | dco, no | Restrictions: Only one of the two argument vectors can be an immediate value. A doubleword immediate vector cannot be fully specified; only the first word is created and the other (least significant) word is treated as zero. Figure 8-4. Flow of Execution with B Single-Valued Immediate Immediate vector values cannot be modified by an index value. Example: Given an operation on argument vectors: $$\overrightarrow{A} \circ \overrightarrow{B} = \overrightarrow{C}$$ such that $a_{mgt} \overrightarrow{A}$ and $\overrightarrow{B}$ is an immediate vector then the vector parameter file is described as follows. The LEN field is m to denote the self loop. The SV field is seven or fifteen to specify that $\overrightarrow{B}$ is an immediate vector and no loops are active for $\overrightarrow{B}$ . The inner loop count is q+1, and the outer loop count is t. Assuming that all the elements are stored sequentially, both inner and outer loop increments for vectors $\overrightarrow{A}$ and $\overrightarrow{C}$ are positive unity. Note: A might be a 3-array, three vectors, or one vector with (m) (q) (t) elements. #### 8-13. VECTOR ADDRESS DEVELOPMENT The starting addresses of the argument vectors, A and B, and the resultant vector, C, and their index registers, if any, are specified in the second, third, and fourth words of the vector parameter file. Fields in the third and fourth words also specify left or right halfword index word sets and self loop address increment directions. #### 8-14. DIRECTLY ADDRESSED VECTORS Directly addressed vectors are those whose elements are acquired from central memory and whose element starting addresses are developed from the address fields and index register fields of the vector parameter file. The a, b, and c operands of the second, third, and fourth words, respectively, of the assembler coded vector parameter file are translated into the 24 bit address fields SAA, SAB, and SAC, respectively, of the object vector parameter file. The xa, xb, and xc operands of the assembler coded vector parameter file are translated into the address index fields XA, XB, and XC, respectively, of the object vector parameter file. These three fields address registers in the index register file (viz, registers X1 through X7). For any given vector $\overrightarrow{A}$ , $\overrightarrow{B}$ , or $\overrightarrow{C}$ , the address developed is the sum of the 24 bit address and the contents of the index register if one is specified. The index displacement produced is halfword, singleword, or doubleword as appropriate to the instruction (see Topics 6-19 and 6-23 for index displacement development). Halfword index word sets can be started from an initial left halfword or an initial right halfword by specifications of the hs operand (see Topic 8-5). <u>Restrictions</u>: No indirect addressing of vectors is permitted; thus, the most significant bits of the address index fields are ignored. The address increments of the vectors in the self loop are ±1 as specified in the VI field. The specification of positive or negative incremental direction is through the VI field described in Topic 8-17. The effective starting address of doubleword vectors must be in an even word boundary. <u>Note</u>: During execution of a vector parameter file, the addresses are not incremented in the vector registers. The current element address is contained in the hardware unit only. The current element addresses within the hardware unit are cumulative for all loops - self, inner, and outer. #### 8-15. HALFWORD INDEX START SPECIFICATION The HS field specifies in which halfword of a central memory word a vector(s) begins. Bits 1, 2, and 3 of the HS field refer to $\overrightarrow{A}$ , $\overrightarrow{B}$ , and $\overrightarrow{C}$ . A bit which is on indicates an initial right halfword address. A bit which is off indicates an initial left halfword address. For a halfword vector instruction, the contents of index registers are used to compute the starting addresses of the vectors. The indexed halfword starting addresses of vectors $\overrightarrow{A}$ , $\overrightarrow{B}$ , and $\overrightarrow{C}$ are developed as follows: $$IA = 2 \cdot SAA + (XA) + HSA$$ $$IB = 2 \cdot SAB + (XB) + HSB$$ $$IC = 2 \cdot SAC + (XC) + HSC$$ If the sum of the last two elements of the preceding equations is even, the vector begins in the left halfword. An odd sum specifies the right halfword. If an index register is not specified, that element is treated as 0. The final element of the equation is zero (left half) or one (right half). The most significant bit of the HS field is used to delete indices from the output array for the eight Vector Compare (VC) instructions and the four Vector Peak Pick (VPP) instructions. If this bit is off, the actual element index values are used for the output array. If this bit is on, the index values for the elements which satisfied the operation are suppressed. #### 8-16. SELF LOOP INCREMENT DIRECTION The VI field specifies which vector(s), $\overrightarrow{A}$ , $\overrightarrow{B}$ , or $\overrightarrow{C}$ , if any are arranged with their element addresses in decreasing order. Bits 1, 2, and 3 of the VI field correspond to vectors $\overrightarrow{A}$ , $\overrightarrow{B}$ , and $\overrightarrow{C}$ , respectively (bit 1 - $\overrightarrow{A}$ , etc.). An off bit indicates positive unity, and an on bit indicates negative unity. The most significant bit of the VI field refers to the count of the number of elements which satisfy the vector operation in process. If this bit is off, the output count is the total count for each self loop. If this bit is on, the output count is the total count for the vector operation. The MSB of the VI field is also used to compute the dot product involving non-contiguous input vectors. When this bit is on the dot product can be computed using non-contiguous elements in memory. The summation of the products is stored upon completion of each inner loop. <u>Restrictions</u>: The self loop element addresses are always incremented or decremented by unity where units are the word size specified by the instruction; i.e., halfword, singleword, or doubleword units. There is no provision in the self loop for variable increments. | HS<br>FIELD | VECTOR INDEX BEGINS<br>FROM HALFWORD | | | |-------------|--------------------------------------|---|---| | VALUE | Ā | B | Ċ | | 0 | L | L | L | | 1 | L | L | R | | 2 | L | R | L | | 3 | L | R | R | | 4 | R | L | L | | 5 | R | L | R | | 6 | R | R | L | | 7 | R | R | R | Where L indicates an initial left halfword and R indicates an initial right halfword for the index word set. Table 8-2. Specifications of the HS Field Values | VI<br>FIELD<br>VALUE | SELF LOOP ELEMENT ADDRESS INCREMENT A B C | | | |----------------------|-------------------------------------------|----|-----| | 0 | +1 | +1 | +1 | | 1 | +1 | +1 | - 1 | | 2 | +1 | -1 | +1 | | 3 | +1 | -1 | -1 | | 4 | -1 | +1 | +1 | | 5 | -1 | +1 | -1 | | 6 | -1 | -1 | +1 | | 7 | -1 | -1 | -1 | Table 8-3. Specifications of the VI Field Values ## 8-17. INNER LOOP SPECIFICATION All the inner loop specification fields are halfword fields and can be conveniently coded with DATAH directives. The DAI, DBI, DCI, and NI fields in the vector parameter file specify the inner loop conditions. #### 8-18. Inner Loop Vector Address Increments The DAI, DBI, and DCI fields specify the inner loop address increments of the vectors A, B, and C, respectively. They each are added to the current values of the respective vector element addresses at the completion of each but the last self loop within the inner loop. This addition occurs in the hardware; the addresses in the vector registers are not altered. Range: The increment values may be either positive or negative fixed point halfword values. The values of the DAI, DBI, and DCI fields must be within the range: $-2^{15} \le \text{DAI}$ , DBI, DCI $\le 2^{15} - 1$ . <u>Note</u>: A value of zero in an increment field will cause the first element of the next self loop to have the same address as the last element of the currently completed self loop. The addresses are not incremented after the last elementary operation of the self loop. #### 8-19. Inner Loop Count The NI field in the vector parameter file specifies the number of times the self loop is to be executed. Range: The inner loop count is treated as a positive value only, and must be within the range: $0 \le ni \le 2^{16} - 1$ . Note: A value of zero as the inner loop count causes termination of the vector operation. The outer loop specifications will not be examined. A value of one as the inner loop count causes the outer loop count to be checked for a value greater than one. The vector increments for the inner loop are not to be made. #### 8-20. OUTER LOOP SPECIFICATION The DAO, DBO, DCO, and NO fields in the vector parameter file specify the outer loop conditions. All the outer loop specification fields are halfword fields and can be conveniently coded with DATAH directives. ## 8-21. Outer loop Vector Address Increments The DAO, DBO, and DCO fields specify the outer loop address increments of the vectors A, B, and C, respectively. They each are added to the current values of the respective vector element addresses at the completion of each but the last inner loop within the outer loop. This addition occurs in the hardware; the addresses in the vector registers are not altered. Range: The increment values may be either positive or negative fixed point half-word values, and must be within the range: $-2^{15} \le DAO$ , DBO, DCO $\le 2^{15} - 1$ . Note: A value of zero in an increment field causes the first element of the next self loop to have the same address as the last element of the currently completed self loop. The addresses are not incremented by either the self loop increment or the inner loop increment after the last elementary operation of the self loop in any given loop phase. ## 8-22. Outer Loop Count The NO field in the vector parameter file specifies the number of times the inner loop is to be executed. Range: The outer loop count is treated as a positive value only, and must be within the range: $0 \le NO \le 2^{16} - 1$ . Note: A value of zero or one as the outer loop count terminates the vector operation. #### 8-23. PROGRAM INTERRUPTS The elementary operations between any two elements of the argument vectors are subject to the same program interrupts as their scalar counterparts. The maskable interrupts (the arithmetic exception conditions: fixed point over-flow, floating point exponent overflow, floating point exponent underflow, and divide check) when masked off permit the vector operation to run to completion; when masked on, the vector operation terminates on occurrence of the exception condition. See Topics 6-56 and 6-62 for a discussion of the program status double-word and the arithmetic exception condition mask. The unmaskable interrupts, such as specification errors for doubleword elements addressed on odd-even word boundaries, will cause termination of the vector operation whenever they are encountered. #### 8-24. VECTOR HAZARD Because of the buffering scheme used to implement the vector operations, a condition known as the vector hazard condition exists. Essentially, it involves those cases in which it is desired to have the elements of the resultant vector stored in the same locations as the elements of one of the argument vectors and immediately reusing the new data in the same vector operation. The Vector Hazard Rule may be stated: A Vector hazard condition exists when the addresses of the current octet of elements or the addresses of the next two octets of elements of argument vectors $\overrightarrow{A}$ or $\overrightarrow{B}$ are the same as the addresses of the current octet of elements or the addresses of the past three octets of elements of the resultant vector $\overrightarrow{C}$ . When the vector hazard condition occurs, the old data in the elements of $\overrightarrow{A}$ or $\overrightarrow{B}$ are used rather than the new (processed) data represented by the elements of the resultant vector $\overrightarrow{C}$ . # 8-25. <u>VECTOR ARITHMETIC INSTRUCTIONS</u> A vector arithmetic instruction causes the specified arithmetic operation to be performed on two correlated elements (one each from two argument vectors), and causes the result to be stored as the element of a resultant vector. The order in which the $\overrightarrow{A}$ and $\overrightarrow{B}$ elements are operated upon and the order in which the resulting values are stored are dependent upon the respective self, inner, and outer loop increments. The other parameters in the vector parameter field cause identical operations to be performed on specified elements of the vectors until the self, inner, and outer loops are satisfied. Note: In the following instruction descriptions, the following notation is used: $$\overline{A}$$ is a vector with elements $a_1, a_2, \ldots, a_n$ ; The elements appear sequentially in memory although not necessarily contiguously. The subscripts appear in sequence in the examples for convenience only. This is not required in the actual vector operation. Fortran instructions are used to describe more easily the vector operations. The resulting vector parameter file is also included. #### 8-26. VECTOR ADD INSTRUCTIONS A vector add instruction, with argument vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ , produces a self loop resultant vector $\overrightarrow{C}$ where $\overrightarrow{C} = \overrightarrow{A} + \overrightarrow{B}$ . The alignment of the various elements for addition in the inner and outer loops may be displaced by the inner and outer loop increments. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|------------------------------------------------| | VA | vector add, fixed point singleword elements | | VAH | vector add, fixed point halfword elements | | VAF | vector add, floating point singleword elements | | VAFD | vector add, floating point doubleword elements | ## Example: | | ION C(10, 20), A(10, 20), B(10, 20) <u>VECTOR PARAMETER FIL</u> | | |----------------------------------------------------------------|-----------------------------------------------------------------|-------| | $\overrightarrow{C} = \overrightarrow{A} + \overrightarrow{B}$ | VAF ( | ), 10 | | | VCTRA I | 3 | | | VCTRA A | A | | | VCTRA ( | C | | | DATAH 1 | 1,1 | | | DATAH 1 | 1,20 | | | DATAH ( | ), 0 | | | DATAH ( | ),0 | ## 8-27. VECTOR ADD MAGNITUDE INSTRUCTIONS A vector add magnitude instruction, with argument vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ produces a self loop resultant vector $\overrightarrow{C}$ , where $\overrightarrow{C} = \overrightarrow{A} + |\overrightarrow{B}|$ . The alignment of the various elements for addition in the inner and outer loops may be displaced by the inner and outer loop increments. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|----------------------------------------------------------| | VAM | vector add magnitude, fixed point singleword elements | | VAMH | vector add magnitude, fixed point halfword elements | | VAMF | vector add magnitude, floating point singleword elements | | VAMFD | vector add magnitude, floating point doubleword elements | # Example: | DIMENSION $C(10, 20)$ $A(10, 20)$ , $B(10, 20)$ | VECTOR PARAMETER FILE | | |----------------------------------------------------------------|-----------------------|------| | $\overrightarrow{C} = \overrightarrow{A} + \overrightarrow{B}$ | VSF | 0,10 | | | VCTRA | A | | | VCTRA | В | | | VCTRA | С | Example: (continued) # VECTOR PARAMETER FILE DATAH 1,1 DATAH 1,20 DATAH 0,0 DATAH 0,0 ## 8-28. VECTOR SUBTRACT INSTRUCTIONS A vector subtract instruction, with argument vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ , produces a self loop resultant vector $\overrightarrow{C}$ where $\overrightarrow{C} = \overrightarrow{A} - \overrightarrow{B}$ . The alignment of the various elements for subtraction in the inner and outer loops may be displaced by the inner and outer loop increments. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | | |-----------------------|-----------------------------------------------------|--| | VS | vector subtract, fixed point singleword elements | | | VSH | vector subtract, fixed point halfword elements | | | VSF | vector subtract, floating point singleword elements | | | VSFD | vector subtract, floating point doubleword elements | | #### Example: | DIMENSION C(10, 20), A(10, 20), B(10, 20) | VECTOR PARAMETER FILE | | |-------------------------------------------|-----------------------|-------| | C = A - B | VSF | 0, 10 | | | VCTRA | A | | | VCTRA | В | | | VCTRA | С | | | DATAH | 1, 1 | | | DATAH | 1, 20 | | | DATAH | 0, 0 | | | DATAH | 0, 0 | # 8-29. VECTOR SUBTRACT MAGNITUDE INSTRUCTIONS A vector subtract magnitude instruction with argument vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ , produces a self-loop resultant vector $\overrightarrow{C}$ where $\overrightarrow{C} = \overrightarrow{A} - |\overrightarrow{B}|$ . The alignment of the various elements for subtraction in the inner and outer loops may be displaced by the inner and outer loop increments. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|---------------------------------------------------------------| | VSM | vector subtract magnitude, fixed point singleword elements | | VSMH | vector subtract magnitude, fixed point halfword elements | | VSMF | vector subtract magnitude, floating point singleword elements | | VSMFD | vector subtract magnitude, floating point doubleword elements | # Example: | DIMENSION $C(10, 20)$ , $A(10, 20)$ , $B(10, 20)$ | VECTOR PARAMETER FILE | | |---------------------------------------------------|-----------------------|--| | C = A - B | VSMF 0,10 | | | | VCTRA A | | | | VCTRA B | | | | VCTRA C | | | | DATAH 1,1 | | | | DATAH 1,20 | | | | DATAH 0,0 | | DATAH 0,0 # 8-30. VECTOR MULTIPLY INSTRUCTIONS A vector multiply instruction, with argument vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ , produces a self loop resultant vector $\overrightarrow{C}$ where $\overrightarrow{C} = \overrightarrow{A} \times \overrightarrow{B}$ . The alignment of the various elements for multiplication in the inner and outer loops may be displaced by the inner and outer loop increments. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|-----------------------------------------------------------| | VM | vector multiply, fixed point singleword argument elements | | VMH | vector multiply, fixed point halfword argument elements | | VMF | vector multiply, floating point singleword elements | | VMFD | vector multiply, floating point doubleword elements | <u>Limitations</u>: The instructions VM and VMH do not specify the element length of the result elements. See Topic 8-10 for the method of specification. Note: The instruction VM causes 64 bit products to be generated in the arithmetic unit. If the MSB of the SV field is off, indexing on the resultant vector $\overrightarrow{C}$ is treated as a doubleword. If singleword results are specified (MSB of SV field is on), the least significant 32 bits of that product are stored in the resultant vector $\overrightarrow{C}$ . Overflow is detected. Note: The instruction VMH causes 32 bit products to be generated in the arithmetic unit. If the MSB of the SV field is off, indexing on the resultant vector $\overrightarrow{C}$ is treated as a fullword. If halfword results are specified (MSB of SV field is on), the least significant 16 bits of that product are stored in the resultant vector $\overrightarrow{C}$ . Overflow is detected. # Example: | DIMENSION C(10, 20), A(10, 20), B(10, 20) | VECTOR PARAMETER FILE | | |-------------------------------------------|-----------------------|------| | C = A * B | VMF | 0,10 | | | VCTRA | В | | | VCTRA | A | | | VCTRA | С | | | DATAH | 1,1 | | | DATAH | 1,20 | | | DATAH | 0,0 | | | DATAH | 0,0 | #### 8-31. VECTOR DOT PRODUCT INSTRUCTIONS The vector dot product operates on two vectors and produces a scalar output. The operation sums the products of the elements of $\overrightarrow{A}$ and $\overrightarrow{B}$ addressed in the self loop and stores the scalar result in the address designated by $\overrightarrow{C}$ . Following the execution of the self loop the $\overrightarrow{A}$ , $\overrightarrow{B}$ and $\overrightarrow{C}$ addresses are modified by the specified inner and outer loop increments. Since the self loop is used in the dot product, the elements of $\overrightarrow{A}$ and $\overrightarrow{B}$ must be contiguous. The self loop is never applied to $\overrightarrow{C}$ as $\overrightarrow{C}$ is single-valued. Algebraically, the dot product is: $$C_i = \sum_{j=1}^{m} a_j \cdot b_j$$ $C_i \in \overline{C}, i = 1, n$ where n and m are integers denoting the number of elements in the vectors. The <u>sparse dot product</u> is the dot product of non-contiguous elements of A and B. In order to obtain the sum of non-contiguous elements, the MSB of the VI field is set. This allows accumulation of the products over the whole vectors rather than storing the results at the completion of each self loop. This produces a scalar result and can never result in a vector. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|--------------------------------------------------------------| | VDP | vector dot product, fixed point singleword argument elements | | VDPH | vector dot product, fixed point halfword argument elements | | VDPF | vector dot product, floating point singleword elements | | VDPFD | vector dot product, floating point doubleword elements | <u>Limitations</u>: The instructions VDP and VDPH do not specify the element length of the result elements. See Topic 8-10 for the method of specification. Note: The instruction VDP causes 64 bit dot products to be generated in the arithmetic unit. If the MSB of the SV field is off, indexing on the resultant vector $\overrightarrow{C}$ is treated as a doubleword. If singleword results are specified (MSB of SV field is on), the least significant 32 bits of that dot product are stored in vector $\overrightarrow{C}$ . Overflow is detected. Note: The instruction VDPH causes 32 bit dot products to be generated in the arithmetic unit. If the MSB of the SV field is off, indexing on the resultant vector is treated as a fullword. If halfword results are specified (MSB of SV field is on), the least significant 16 bits of that dot product are stored in the resultant vector. Overflow is detected. Example 1: The following illustrates a dot product: | | DIMENSION $X(10)$ , $Y(10)$ | VECTOR PARAM | METER FILE | |----|-----------------------------|--------------|------------| | | DOTPR = 0 | VDPF | 0,10,8 | | | DO 10 I = 1,10 | | Υ | | 10 | DOTPR = DOTPR + X(I) * Y(I) | VCTRA | X | | | | VCTRA | DOTPR | | | | DATAH | 0,0 | | | | DATAH | 0,0 | | | | DATAH | 0,0 | | | | DATAH | 0,0 | Example 2: The following illustrates a spare dot product: | | DIMENSION X(10), Y(10) | VECTOR PARAM | METER FILE | |--------------------------------------------------|-----------------------------|--------------|------------| | | DOTPR = 0 | VDPF | 0, 1, 13 | | DO 30 I = 1,10,2 30 DOTPR = DOTPR + X(I) * Y(I) | DO 30 I = 1,10,2 | | Y | | | DOTPR = DOTPR + X(I) * Y(I) | | X | | | | VCTRA | DOTPR.,8 | | | | | 2,2 | | | | | 0,5 | | | | DATAH | • | | | | | 0,0 | | | | DATAH | 0,0 | #### MATRIX-MATRIX MULTIPLY | | DIMENSION $D(20, 20) A(10, 20) B(10, 20)$ | VECTOR PARAMETER FILE | |----|-------------------------------------------|-----------------------| | | DO 20 J = 1,20 | VDPF 0,10,8 | | | DO 20 I = 1,20 | VCTRA B | | | D(I, J) = 0 | VCTRA A | | 20 | DO 20, K = 1,10 | VCTRA D | | | D(I, J) = D(I, J) + A(K, J) * B(K, I) | DATAH 1,-9 | | | | DATAH 1,20 | | | | DATAH -199,1 | | | | DATAH 1,20 | ## 8-32. VECTOR DIVIDE INSTRUCTIONS A vector divide instruction, with argument vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ , produces a self loop resultant vector $\overrightarrow{C}$ where $\overrightarrow{C} = \overrightarrow{A}/\overrightarrow{B}$ . The alignment of the various elements for division in the inner and outer loops may be displaced by the inner and outer loop increments. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|---------------------------------------------------------| | VD | vector divide, fixed point singleword argument elements | | VDH | vector divide, fixed point halfword argument elements | | VDF | vector divide, floating point singleword elements | | VDFD | vector divide, floating point doubleword elements | <u>Limitations</u>: The instructions VD and VDH do not specify the element length of the dividend elements (vector $\overrightarrow{A}$ ). See Topic 8-10 for the method of specifications. Note: If the relative values of dividend and divisor are such that the quotient cannot be expressed in 32 bits, overflow occurs and the output result is unpredictable. Note: The instruction VDH causes 16 bit quotients to be generated from 16 bit divisors (vector B elements) and either 32 bit dividends (MSB of SV field is on) or 16 bit dividends (MSB of SV field is off). Indexing of the resultant vector is by fullwords if the MSB is on and by halfwords if the MSB is off. If the relative values of dividend and divisor are such that the quotient cannot be expressed in 16 bits, overflow occurs and the output result is unpredictable. #### Example: | DIMENSION C(10, 20), A(10, 20), B(10, 20) | VECTOR PARAMETER FILE | | |--------------------------------------------|-----------------------|--| | $\overline{C} = \overline{A}/\overline{B}$ | VDF 0,10,8 | | | | VCTRA A | | | | VCTRA B | | | | VCTRA C | | | | DATAH 1,1 | | | | DATAH 1,20 | | | | DATAH 0,0 | | | | DATAH 0,0 | | ## 8-33. VECTOR LOGICAL INSTRUCTIONS A vector logical instruction causes the specified logical operation to be performed on two correlated elements (one from each argument vectors), and causes the result to be stored as an element of a resultant vector. The other parameters in the vector parameter file cause identical operations to be performed on sequential elements of the vectors until the self, inner, and outer loops are satisfied. In terms of the self loop only, given argument vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ and a resultant vector $\overrightarrow{C}$ , where $\overrightarrow{C} = \overrightarrow{A}$ $| \widehat{\otimes} |$ $| \overrightarrow{B}$ . Any given elementary operation is defined the same as its scalar counterpart. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|------------------------------------------| | VAND | vector AND, singleword elements | | VANDD | vector AND, doubleword elements | | V.OR | vector OR, singleword elements | | VORD | vector OR, doubleword elements | | VXOR | vector exclusive OR, singleword elements | | VXORD | vector exclusive OR, doubleword elements | | VEQC | vector equivalence, singleword elements | | VEQCD | vector equivalence, doubleword elements | #### Example: | DIMENSION LC(10), LA(10), LB(10) | VECTOR PARAM | METER FILE | |----------------------------------|--------------|------------| | LC = AND (LA, LB) | VAND | 0,10,8 | | | VCTRA | LB | | | VCTRA | LA | | | VCTRA | LC | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | LC = OR (LA, LB) | VOR | 0,10,8 | |-------------------|-------|--------| | | VCTRA | LB | | | VCTRA | LA | | | VCTRA | LC | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | LC = XOR (LA, LB) | VXOR | 0,10,8 | | | VCTRA | LB | | | VCTRA | LA | | | VCTRA | LC | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | LC = EQU (LA, LB) | VEQC | 0,10,8 | | | VCTRA | LB | | | VCTRA | LA | | | VCTRA | LC | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | # 8-34. <u>VECTOR SHIFT INSTRUCTIONS</u> A vector shift instruction causes the elements of the argument vector $\overrightarrow{A}$ to be shifted left or right the number of bit positions specified in $\overrightarrow{B}$ and causes the results to be stored as elements of a resultant vector. Vector $\overrightarrow{B}$ can be an immediate value or a vector composed of halfwords containing the shift counts. In terms of the self loop only, given argument vector $\overrightarrow{A}$ and a shift count sc, where $-2^6 \le \text{sc} \le 2^6 - 1$ , $\overrightarrow{C} = \overrightarrow{A}$ where the elements of $\overrightarrow{A}$ are shifted sc positions to produce $\overrightarrow{C}$ . A negative shift count causes a right shift and a positive shift count causes a left shift. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|----------------------------------------------------------| | VSA | vector arithmetic shift, fixed point singleword elements | | VSAH | vector arithmetic shift, fixed point halfword elements | | VSAD | vector arithmetic shift, fixed point doubleword elements | | VSL | vector logical shift, singleword elements | | VSLH | vector logical shift, halfword elements | | VSLD | vector logical shift, doubleword elements | | VSC | vector circular shift, singleword elements | | VSCH | vector circular shift, halfword elements | | VSCD | vector circular shift, doubleword elements | # Example: | DIMENSION LC(10), LA(10), LB(10) | VECTOR PARAMETER FILE | | |----------------------------------|-----------------------|----------| | LC = ASHF (LA, -3) | VSA | 0,10,8 | | | VCTRA | LA | | | VCTRA | #FFFFFFD | | | VCTRA | LC | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | | VECTOR PAR | AMETER FILE | |--------------------|------------|-------------| | LC = LSHF (LB, 20) | VSL | 0,10,7 | | | VCTRA | LB | | | VCTRA | #0000014 | | | VCTRA | LC | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | | | | | LC = SLHF (LB, 10) | VSL | 0,10,7 | | | VCTRA | LB | | | VCTRA | #000000A | | | VCTRA | LC | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | ## 8-35. VECTOR MERGE INSTRUCTIONS A vector merge instruction causes elements to be acquired alternately from the two argument vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ , and causes them to be merged into a resultant vector $\overrightarrow{C}$ . In terms of the self loop only and given arguments vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ , with m and n elements, respectively, $\overrightarrow{C}$ = $(a_1, b_1, a_2, b_2, \ldots, a_m, b_n)$ Note: Use of a single-valued vector as either argument vector would produce alternate identical elements in the resultant vector; e.g., given $\overrightarrow{A}$ and single-valued $\overrightarrow{B}$ then $\overrightarrow{C}$ = $(a_1, b_2, a_2, b_1, \ldots, a_m b_1)$ . | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | | |-----------------------|-----------------------------------|--| | VMG | vector merge, singleword elements | | | VMGH | vector merge, halfword elements | | | VMGD | vector merge, doubleword elements | | # Example: | $\overrightarrow{C} = \overrightarrow{A} \circ \overrightarrow{B}$ | VECTOR PARA | VECTOR PARAMETER FILE | | |--------------------------------------------------------------------|-------------|-----------------------|--| | $\overrightarrow{A} = (0, 2, 4, 6, 8)$ | VMG | 0,5,0 | | | $\overrightarrow{B} = (1, 3, 5, 7, 9)$ | VCTRA | A | | | Then, | VCTRA | В | | | $\overrightarrow{C} = (0, 1, 2, 3, 4, 5, 6, 7, 8, 9)$ | VCTRA | С | | | | DATAH | 0,0 | | | | DATAH | 0,0 | | | | DATAH | 0,0 | | | | DATAH | 0,0 | | #### 8-36. VECTOR ORDER INSTRUCTIONS A vector order instruction performs an arithmetic comparison of the elements of vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ , such that the smaller element, whether from $\overrightarrow{A}$ or $\overrightarrow{B}$ , is the next element to be stored in the output vector $\overrightarrow{C}$ . If two equal values are compared from $\overrightarrow{A}$ and $\overrightarrow{B}$ , the value from $\overrightarrow{A}$ is stored in $\overrightarrow{C}$ and the value in $\overrightarrow{B}$ is retained for comparison with the next element of $\overrightarrow{A}$ . The input vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ must be of a special form, $(e_1, e_2, \ldots, e_n, \ell)$ where $e_i$ are the elements of the vector and $\ell$ is the boundary limit. The boundary limit is the largest positive number possible in the designated form (see following table). The boundary limits at the end of the argument vectors are necessary to prevent overrunning the end of the first vector exhausted. For vectors $\overrightarrow{A}$ with m elements and $\overrightarrow{B}$ with n elements, vector $\overrightarrow{C}$ contains m + n - 1 elements. Thus, LEN is m + n - 1. Note: The boundary limits for $\overline{A}$ and $\overline{B}$ are equal, thus only the boundary limit for $\overline{A}$ is stored in $\overline{C}$ which then contains one element less than the total of elements in $\overline{A}$ and $\overline{B}$ (i.e., m + n - 1). | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | BOUNDARY<br>LIMIT | |-----------------------|-------------------------------------------------------|-------------------| | VO | vector order, fixed point singleword elements | 7FFF FFFF | | VOH | vector order, fixed point halfword elements | 7FFF | | VOF | vector order, floating point singleword ele-<br>ments | 7FFF FFFF | | VOFD | vector order, floating point doubleword ele-<br>ments | FFFF FFFF | <u>Restriction</u>: The resultant vector must not be written over either argument vector; the restart condition for a vector order instruction begins from the initial argument elements. Floating point vectors A and B must be normalized prior to use in a vector order instruction. <u>Limitations</u>: Vector order instructions operate on only the self loop; values for the inner and outer loops are ignored. If the HS field is to be used and an immediate single-valued vector is used, the immediate vector must be vector $\overrightarrow{A}$ . ## Example: | $C = A \circ B$ | VECTOR PAR | AMETER FILE | |--------------------------------------|------------|-------------| | $A = (0, 3, 7, 2, 5, \ell)$ | vo | 0,10,0 | | $B = (2, 9, 1, 4, \ell)$ | VCTRA | A | | Then, | VCTRA | В | | · | VCTRA | С | | $C = (0, 2, 3, 7, 2, 5, 1, 4, \ell)$ | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | | | DATAH | 0,0 | Example: B is Immediate Single-Valued Vector | $\overrightarrow{C} = \overrightarrow{A} \circ \overrightarrow{B}$ | VECTOR PARAMETER FILE | | | |--------------------------------------------------------------------|-----------------------|--------|--| | $\overrightarrow{A} = (0, 1, 2, 3, 4, 5, 4, 7, 1, \ell)$ | VO | 0,9,15 | | | $\overrightarrow{B} = (5)$ | VCTRA | A | | | Then, | VCTRA | 5 | | | C = (0, 1, 2, 3, 4, 5, 4, 5, 5) | VCTRA | С . | | | | DATAH | 0,0 | | | | DATAH | 0,0 | | | • | DATAH | 0,0 | | | | DATAH | 0,0 | | Example: A is Immediate Single-Valued Vector $$\overrightarrow{C} = \overrightarrow{A} \circ \overrightarrow{B}$$ $\overrightarrow{A} = (5)$ $\overrightarrow{B} = (0, 1, 2, 3, 4, 5, 7, 1, \ell)$ $\overrightarrow{C} = (0, 1, 2, 3, 4, 5, 5, 5, 5, 5)$ If A is the single-valued vector, the element value (5) in B is continuously compared to the single-valued vector. #### 8-37. VECTOR COMPARE INSTRUCTIONS A vector compare instruction causes the specified comparison to be made between corresponding elements of two argument vectors, and causes the index numbers of the true comparisons to be stored as halfword elements of a resultant vector, beginning in the second halfword. At the completion of each self loop the count of the number of true conditions is stored in the first halfword of the resultant vector. Various information is obtained using the most significant bits of the ALCT, VI, and HS fields. The high order bit of ALCT field, if on, indicates that the vector operation is to terminate on the first true compare. The high order bit of the VI field, if on, indicates that item counts will not be stored for the index vector produced during each self loop. A total item count (representing the sum of the item counts which would have been stored if the MSB had been on) is still recorded at the beginning of the $\overrightarrow{C}$ vector immediately prior to termination of the vector operation. The high order bit of the HS field, if on, indicates that no index values are to be stored into the output vector. | High order bit of: | | r bit of: | Results in: | |--------------------|----|-----------|---------------------------------------------------------------------------| | VI | HS | ALCT | | | 0 | 0 | 0 | Store count and indices for each self loop. | | 0 | 0 | 1 | Terminate on first true compare-store count and index. | | 0 | 1 | 0 | Store count only for each self loop. | | 0 | 1 | 1 | Terminate on first true compare-store count only. | | 1 | 0 | 0 | Store indices only for each self loop, total count stored at termination. | | 1 | 0 | 1 | Effectively same as 001. | | 1 | 1 | 0 | Store total count only at termination. | | 1 | 1 | 1 | Effectively same as 011. | Table 8-4. Specifications of the VI, HS, and ALCT Fields | Low Order 3 Bits of: Com | | parison True if: | |--------------------------|-------------|--------------------------| | ALCT | Arithmetic | Logical | | 0 | Never true | Never true | | 1 | Aj = Bj | All bits zero | | 2 | Aj > Bj | All bits ones | | 3 | Aj ≥ Bj | Not mixed zeros and ones | | 4 | Aj < Bj | Mixed zeros and ones | | 5 | Aj ≤ Bj | Not all ones | | 6 | Aj ≠ Bj | Not all zeros | | 7 | Always true | Always true | Table 8-5. Specifications of the ALCT Values Restrictions: Floating point argument vector elements must be normalized prior to the vector comparison. <u>Limitations</u>: The elements of the resultant vector $\overrightarrow{C}$ are limited to halfword positive integers; i.e., the values of the indices of the argument vectors are limited to the range: $0 \le j \le 2^{16} - 1$ . If the HS field is to be used and one of the argument vectors is to be an immediate single-valued vector, the immediate vector must be vector $\overrightarrow{A}$ ; i.e., the second word of the vector parameter file. Note: A zero will be stored as the first and only element, c1, of vector C for any self loop in which a true comparison is not found. # 8-38. VECTOR COMPARE ARITHMETIC INSTRUCTIONS A vector compare arithmetic instruction compares elements of two argument vectors, $\overrightarrow{A}$ and $\overrightarrow{B}$ , for aj > bj, aj = bj, or aj < bj. The result of this comparison is tested for true against the ALCT field, and the indices of the elements satisfying the comparison are stored as elements of a resultant vector $\overrightarrow{C}$ . See Table 8-5 for the ALCT field. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|---------------------------------------------------------------| | VC | vector compare arithmetic, fixed point singleword elements | | VCH | vector compare arithmetic, fixed point halfword elements | | VCF | vector compare arithmetic, floating point singleword elements | | VDFD | vector compare arithmetic, floating point doubleword elements | #### 8-39. VECTOR COMPARE LOGICAL INSTRUCTIONS A vector compare logical instruction compares the result of a logical operation on elements of two argument vectors, $\overrightarrow{A}$ and $\overrightarrow{B}$ , to be checked for all bits on, all bits off, or bits mixed on and off. The result is compared to the ALCT field, and the indices of the elements which satisfy the comparison are stored as elements of a resultant vector $\overrightarrow{C}$ . See Table 8-4 and Table 8-5. Restrictions: There are no vector compare logical halfword instructions. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|-------------------------------------------------| | VCAND | vector logical comparison using AND, singleword | | VCANDD | vector logical comparison using AND, doubleword | | VCOR | vector logical comparison using OR, singleword | | VCORD | vector logical comparison using OR, doubleword | # 8-40. VECTOR PEAK PICKING INSTRUCTIONS A vector peak picking instruction records the sign changes between elements of a vector by storing the respective index in the resultant vector. When all peaks and valleys (sign changes) have been found and their indexes stored, the count is stored as the first element of the resultant vector. The algorithm for the vector peak picking instruction is as follows: If the sign of $y_i$ is different than the sign of $y_{i+1}$ , then the index value, i, is stored. If the signs are the same, no value is stored. When the value of $y_{i+1}$ is zero, $y_{i+1}$ is considered to retain the sign of the last non-zero value of $y_i$ . The MSB of the ALCT field determines whether the operation is to continue for all elements of the input vector or to terminate after the first change is detected. If the bit is off, all elements are tested; if the bit is on, the operation terminates after the first valley or peak is detected. The MSB of the HS and VI fields are used as described previously. Thus, the self loop count and index values may be suppressed. Restrictions: When a floating point argument vector is specified, the elements of the argument vector must be normalized prior to the peak picking operation. <u>Limitations</u>: The values of the indices of the argument vector are limited to the range: $0 \le i \le 2^{16}$ - 1 (positive halfword integers). Inflection points and the leading edges of plateaus are not detected. Irrelevant Fields: The B address and B address index fields are ignored. Note: A zero is stored as the first and only element, $c_1$ , of vector $\overrightarrow{C}$ for any self loop in which a peak is not found. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|-------------------------------------------------------| | VPP | find vector peaks, fixed point singleword elements | | VPPH | find vector peaks, fixed point halfword elements | | VPPF | find vector peaks, floating point singleword elements | | VPPFD | find vector peaks, floating point doubleword elements | # 8-41. VECTOR SEARCH INSTRUCTIONS A vector search instruction causes every element of the argument vector to be compared to every other element of the argument vector, and causes the index number of the largest element or the smallest element, as specified, to be stored as a single-valued halfword resultant vector for each self loop. Restrictions: The elements of the argument vector must be normalized prior to the search operation when a floating point search is specified. The HS field is deactivated if the SV field specifies B as an immediate vector. <u>Limitations</u>: The values of the indices of the argument vector are limited to the range: $0 \le i \le 2^{16} - 1$ (positive halfword integers). Irrelevant Fields: The ALCT, SAB, and SB fields are ignored. <u>Note</u>: If there are two or more equal elements which are the largest (or smallest) elements, the index number stored is that of the first encountered in the search. # 8-42. VECTOR SEARCH FOR LARGEST ELEMENT INSTRUCTIONS A vector search for the largest element instruction causes the index value of the algebraically largest element of the argument vector to be stored as a singlevalued halfword resultant vector in the self loop. An inner loop count may be applied, thus resulting in a vector C containing elements each being the index of the algebraically largest element in each self loop. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|----------------------------------------------------------| | VL | find largest element, fixed point singleword elements | | VLH | find largest element, fixed point halfword elements | | VLF | find largest element, floating point singleword elements | | VLFD | find largest element, floating point doubleword elements | Note: If there are two or more equal elements that are larger than all others, the index of the first encountered is stored as the self loop element of $\overrightarrow{C}$ . # 8-43. VECTOR SEARCH FOR LARGEST MAGNITUDE INSTRUCTIONS The vector search for largest magnitude instruction searches the argument vector for an element of the largest absolute value. The index of this element is stored as a single-valued halfword resultant vector in the self loop. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|---------------------------------------------------------------------------------| | VLM | find element of largest absolute value, fixed point singleword elements | | VLMH | find element of largest absolute value, fixed point halfword elements | | VLMF | find element of largest absolute value, floating point single-<br>word elements | | VLMFD | find element of largest absolute value, floating point double-<br>word elements | Note: If there are two or more equal elements whose absolute values are larger than all others, the index of the first encountered is stored as the self loop element of $\overline{C}$ . Example: The following assembler code and illustration shows a simple search for largest magnitude. # 8-44. VECTOR SEARCH FOR SMALLEST ELEMENT INSTRUCTIONS A vector search for the smallest element instruction causes the index value of the algebraically smallest element of the argument vector to be stored as a singlevalued halfword resultant vector in the self loop. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | | | | | | | |-----------------------|-----------------------------------------------------------|--|--|--|--|--|--| | VSS | find smallest element, fixed point singleword elements | | | | | | | | VSSH | find smallest element, fixed point halfword elements | | | | | | | | VSSF | find smallest element, floating point singleword elements | | | | | | | | VSSFD | find smallest element, floating point doubleword elements | | | | | | | Note: If there are two or more elements that are smaller than all others, the index of the first encountered is stored as the self loop element of $\overline{C}$ . Example: The following assembler code and illustration shows a simple search for smallest elements. # 8-45. VECTOR SEARCH FOR SMALLEST MAGNITUDE INSTRUCTIONS A vector search for the smallest magnitude instruction causes the index value of the smallest absolute value element of the argument vector to be stored as a single-valued halfword resultant vector. | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | | | |-----------------------|----------------------------------------------------------------------------------|--|--| | VSSM | find element of smallest absolute value, fixed point single-<br>word elements | | | | VSSMH | find element of smallest absolute value, fixed point half-<br>word elements | | | | VSSMF | find element of smallest absolute value, floating point single-<br>word elements | | | | VSSMFD | find element of smallest absolute value, floating point double-<br>word elements | | | Note: If there are two or more elements whose absolute values are smaller than all others, the index of the first encountered is stored as the self loop element of $\overline{C}$ . Example: The following assembler code and illustration shows a search for smallest magnitude. # 8-46. <u>VECTOR CONVERSION INSTRUCTIONS</u> A vector conversion instruction causes the fixed or floating point elements of the argument vector $\overrightarrow{A}$ to be converted to floating or fixed point elements of vector $\overrightarrow{C}$ according to the scale factor(s) of vector $\overrightarrow{B}$ . See Topics 7-145 and 7-146 for the algorithms for the elementary conversion operations. # 8-47. CONVERT FLOATING POINT ELEMENTS TO FIXED POINT ELEMENTS A convert floating point elements to fixed point elements instruction causes the fixed point elements of vector $\overrightarrow{A}$ to be converted to floating point values according to the halfword scale factors (fixed point values) of vector $\overrightarrow{B}$ , and causes the floating point values to be stored as the elements of vector $\overrightarrow{C}$ . | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|----------------------------------------------------------------------------------| | VFLFX | convert floating point singleword elements to fixed point singleword elements | | VFLFH | convert floating point singleword elements to fixed point half-<br>word elements | | VFDFX | convert floating point doubleword elements to fixed point singleword elements | Restrictions: The scale factors are the right halfwords of the singleword elements of vector $\overrightarrow{B}$ ; i.e., vector $\overrightarrow{B}$ loops and indexes are by singleword increments. <u>Limitations</u>: The scale factors (elements of vector $\overrightarrow{B}$ ) are restricted to the range: Note: These instructions all differ from their scalar counterparts in that these scale factors are in right halfwords of singlewords, whereas scalar scale factors are normally in the left halfword with halfword addressing (i.e., left halfword index word sets). # 8-48. CONVERT FIXED POINT ELEMENTS TO FLOATING POINT ELEMENTS A convert fixed point elements to floating point elements instruction causes the fixed point elements of vector $\overrightarrow{A}$ to be converted to floating point values according to the halfword scale factors (fixed point values) of vector $\overrightarrow{B}$ , and causes the floating point values to be stored as the elements of vector $\overrightarrow{C}$ . | ASSEMBLER<br>MNEMONIC | OPERATION SPECIFIED | |-----------------------|----------------------------------------------------------------------------------| | VFXFL | convert fixed point singleword elements to floating point singleword elements | | VFXFD | convert fixed point singleword elements to floating point doubleword elements | | VFHFL | convert fixed point halfword elements to floating point single-<br>word elements | | VFHFD | convert fixed point halfword elements to floating point double-<br>word elements | Restrictions: For the fixed point singleword arguments (instructions VFXFL and VFXFD), the scale factors are the right halfwords of the singleword elements of vector $\overrightarrow{B}$ ; i. e., vector $\overrightarrow{B}$ loops and indexes are by singleword increments. The instructions operating on fixed point halfword arguments have halfword elements in vector $\overrightarrow{B}$ , also; i. e., the HS field is effective for both vectors $\overrightarrow{A}$ and $\overrightarrow{B}$ . <u>Limitations</u>: The scale factors are restricted to the range: $-2^{15} \le sf \le 2^{15} - 1$ . <u>Note</u>: These instructions all differ from their scalar counterparts in that these scale factors are in right halfwords of singlewords, whereas scalar scale factors are normal in the left halfword with halfword addressing (i.e., left halfword index word sets). # 8-49. <u>VECTOR NORMALIZE INSTRUCTIONS</u> A vector normalize instruction shifts each of the fixed point elements of the argument vector left until the two most significant bits of each element differ (01 or 10), counts the number of bits positions each is shifted, and causes the normalized fixed point values and the negatives (two's complement) of their respective shift counts to be stored as the elements of the resultant vector. An element having a value of zero is considered to be normalized and to have a scale factor of -32. | ASSEMBLER<br>MNEMONICS | OPERATION SPECIFIED | |------------------------|-------------------------------------------| | VNFX | normalize fixed point singleword elements | | VNFH | normalize fixed point halfword elements | NORMALIZE SINGLEWORDS (VNEX): In terms of the self loop only, given argument vector $\overrightarrow{A}$ , a resultant vector $\overrightarrow{C}$ is produced where each element of $\overrightarrow{C}$ is the corresponding element of $\overrightarrow{A}$ . Each element in $\overrightarrow{C}$ is a doubleword element with the normalized element of $\overrightarrow{A}$ in the first word of the doubleword and with the two's complement scale factor in the (right) halfword of the second word. The unused halfword is filled with zeros. NORMALIZE HALFWORDS (VNFH): In terms of the self loop only, given argument vector $\overrightarrow{A}$ , a resultant vector $\overrightarrow{C}$ is produced where each element of $\overrightarrow{C}$ is the corresponding element of $\overrightarrow{A}$ . The resulting element is a singleword element with the normalized element of $\overrightarrow{A}$ in the left halfword and with the two's complement scale factor in the right halfword. <u>Limitations</u>: The scale factors are restricted to the range: $-2^{15} \le sf \le 0$ . Irrelevant Fields: The B address and B address index fields in the third word of the vector parameter file are ignored. Note: Zeros are entered at the right as the value is shifted left. APPENDIX A: SCALAR INSTRUCTIONS BY LOGICAL GROUPING | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|------------------------------------------------------------------------------|--------------|-------------------|-------| | ST | Store arithmetic register, singleword | 24 | r,[@]n[,x] | 7-26 | | ST | Store base register, singleword | 28 | r,[@]n[,x] | 7-26 | | ST | Store index register or vector parameter register, singleword | 2C | r,[@]n[,x] | 7-26 | | STH | Store halfword, arithmetic register | 25 | r,[@]n[,x] | 7-27 | | STR | Store arithmetic register right halfword into memory right halfword, indexed | 2D | r,[@]n[,x] | 7-28 | | STL | Store arithmetic register left halfword into memory right halfword, indexed | 29 | r,[@]n[,x] | 7-29 | | STD | Store arithmetic register, doubleword | 27 | r,[@]n[,x] | 7-30 | | STZ | Store zero, word | 20 | [@]n[,x] | 7-31 | | STZH | Store zero, halfword | 21 | [@]n[,x] | 7-32 | | STZD | Store zero, doubleword | 23 | [@]n[,x] | 7-33 | | STN | Store negative, fixed point word | 34 | r,[@]n[,x] | 7-34 | | STNH | Store negative, fixed point halfword | 35 | r,[@]n[,x] | 7-35 | | STNF | Store negative, floating point word | 36 | r,[@]n[,x] | 7-36 | | STND | Store negative, floating point doubleword | 37 | r,[@]n[,x] | 7-37 | | STO | Store ones complement, word | 2E | r,[@]n[,x] | 7-38 | | STOH | Store ones complement, halfword | 2A | r,[@]n[,x] | 7-39 | | STF | Store base register file A, M=O | 2B | m,[@]n[,x] | 7-40 | | STF | Store base register file B, M=1 | 2B | m,[@]n[,x] | 7-40 | | STF | Store arithmetic register file C, M=2 | 2B | m, [@]n, [,x] | 7-40 | | STF | Store arithmetic register file D, M=3 | 2B | m, [@]n[,x] | 7-40 | | STF | Store index register file X, M=4 | 2B | m,[@]n[,x] | 7-40 | | STF | Store vector parameter register file V, M=5 | 2В | m,[@]n[,x] | 7-40 | | STFM | Store all six eight-word register files | 2F | [@]n[,x] | 7-41 | | L | Load arithmetic register, singleword | 14 | r,[@][=]n[,x] | 7-3 | | L | Load base register, singleword | 18 | r,[@][=]n[,x] | 7-3 | | L | Load index register or vector parameter register, singleword | 1C | r,[@][=]n[,x] | 7-3 | | LH | Load arithmetic register, halfword | 15 | r,[@][=]n[,x] | 7-4 | | LR | Load memory right halfword, indexed, into arithmetic register right halfword | 1 D | r,[@][=]n[,x] | 7-5 | | LL | Load memory right halfword, indexed, into arithmetic register left halfword | 19 | r,[@][=]n[,x] | 7-6 | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|------------------------------------------------------------------------------|--------------|-------------------|-------| | LD | Load arithmetic register, doubleword | 17 | r,[@][=]n[,x] | 7-7 | | LI | Load immediate into arithmetic register singleword | 54 | r, i[, x] | 7-8 | | LI | Load immediate into index register, or vector parameter register, singleword | 5C | r, i[, x] | 7-8 | | LIH | Load immediate into arithmetic register, halfword | 55 | r, i[, x] | 7-9 | | LN | Load negative, fixed point singleword, arithmetic register | 30 | r,[@][=]n[,x] | 7-10 | | LNH | Load negative, fixed point halfword, arithmetic register | 31 | r,[@][=]n[,x] | 7-11 | | LNF | Load negative, floating point singleword, arithmetic register | 32 | r,[@][=]n[,x] | 7-12 | | LND | Load negative, floating point doubleword, arithmetic register | 33 | r,[@][=]n[,x] | 7-13 | | LM | Load magnitude, fixed point singleword, arithmetic register | 3C | r,[@][=]n[,x] | 7-14 | | LMH | Load magnitude, fixed point halfword, arithmetic register | 3D | r,[@][=]n[,x] | 7-15 | | LMF | Load magnitude, floating point singleword, arithmetic register | 3E | r,[@][=]n[,x] | 7-16 | | LMD | Load magnitude, floating point doubleword, arithmetic register | 3F | r,[@][=]n[,x] | 7-17 | | LNM | Load negative magnitude, fixed point single-<br>word, arithmetic register | 38 | r,[@][=]n[,x] | 7-18 | | LNMH | Load negative magnitude, fixed point halfword, arithmetic register | 39 | r,[@][=]n[,x] | 7-19 | | LNMF | Load negative magnitude, floating point single-<br>word, arithmetic register | 3A | r,[@][=]n[,x] | 7-20 | | LNMD | Load negative magnitude, floating point double-word, arithmetic | 3B | r,[@][=]n[,x] | 7-21 | | LO | Load arithmetic register with ones complement, singleword | 1E | r,[@][=]n[,x] | 7-22 | | LF | Load base register file A, M=0 | 1B | m, [@]n[, x] | 7-23 | | LF | Load base register file B, M=1 | 1B | m,[@]n[,x] | 7-23 | | LF | Load arithmetic register file C, M=2 | 1B | m,[@]n[,x] | 7-23 | | LF | Load arithmetic register file D, M=3 | 1B | m, [@]n[,x] | 7-23 | | LF | Load index register file X, M=4 | 1B | m,[@]n[, x] | 7-23 | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|-----------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------| | LF | Load vector parameter register file V, M=5 | 1B | m,[@]n[,x] | 7-23 | | LFM | Load all six eight-word register files | 1 F | [@]n[,x] | 7-24 | | A | Add to arithmetic register, fixed point single-word | 40 | r,[@][=]n[,x] | 7-43 | | A | Add to base register, fixed point singleword | 60 | r,[@][=]n[,x] | 7-43 | | A | Add to index or vector parameter register, fixed point singleword | 62 | r,[@][=]n[,x] | 7-43 | | AH | Add to arithmetic register, fixed point halfword | 41 | r,[@][=]n[,x] | 7-44 | | AF | Add to arithmetic register, floating point single-word | 42 | r,[@][=]n[,x] | 7-45 | | AFD | Add to arithmetic register, floating point doubleword | 43 | r,[@][=]n[,x] | 7-46 | | AI | Add immediate to arithmetic register, fixed point singleword | 50 | r, i[, x] | 7-47 | | AI | Add immediate to base register, fixed point singleword | 70 | r, i[, x] | 7-47 | | AI | Add immediate to index or vector parameter register, fixed point singleword | 72 | r, i[, x] | 7-47 | | AIH | Add immediate to arithmetic register, fixed point halfword | 51 | r, i[, x] | 7-48 | | AM | Add magnitude to arithmetic register, fixed point singleword | 44 | r,[@][=]n[,x] | 7-49 | | АМН | Add magnitude to arithmetic register, fixed point halfword | 45 | r,[@][=]n[,x] | 7-50 | | AMF | Add magnitude to arithmetic register, floating point singleword | 46 | r,[@][=]n[,x] | 7-51 | | AMFD | Add magnitude to arithmetic register, floating point doubleword | 47 | r,[@][=]n[,x] | 7-52 | | S | Subtract from arithmetic register, fixed point singleword | 48 | r,[@][=]n[,x] | 7-53 | | SH | Subtract from arithmetic register, fixed point halfword | 49 | r,[@][=]n[,x] | 7-54 | | SF | Subtract from arithmetic register, floating point singleword | 4A | r,[@][=]n[,x] | 7-55 | | SFD | Subtract from arithmetic register, floating point doubleword | 4B | r,[@][=]n[,x] | 7-56 | | SI | Subtract immediate from arithmetic register, fixed point singleword | 58 | r, i[, x] | 7-57 | | | | | No second analysis and the second sec | | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|-----------------------------------------------------------------------------------|--------------|-------------------|-------| | SIH | Subtract immediate from arithmetic register, fixed point halfword | 59 | r, i[, x] | 7-57 | | SM | Subtract magnitude from arithmetic register, fixed point singleword | 4C | r,[@][=]n[,x] | 7-59 | | SMH | Subtract magnitude from arithmetic register, fixed point halfword | 4D | r,[@][=]n[,x] | 7-60 | | SMF | Subtract magnitude from arithmetic register, floating point singleword | 4E | r,[@][=]n[,x] | 7-61 | | SMFD | Subtract magnitude from arithmetic register, floating point doubleword | 4F | r,[@][=]n[,x] | 7-62 | | М | Multiply, fixed point singleword - arithmetic register | 6C | r,[@][=]n[,x] | 7-63 | | M | Multiply, fixed point singleword - base register | 68 | r,[@][=]n[,x] | 7-63 | | M | Multiply, fixed point singleword - index or vector parameter register | 6A | r,[@][=]n[,x] | 7-63 | | мн | Multiply, fixed point halfword - arithmetic register | 6D | r,[@][=]n[,x] | 7-64 | | MF | Multiply, floating point singleword - arithmetic register | 6E | r,[@][=]n[,x] | 7-65 | | MFD | Multiply, floating point doubleword - arithmetic register | 6F | r,[@][=]n[,x] | 7-66 | | MI | Multiply immediate, fixed point singleword - arithmetic register | 7C | r, i[, x] | 7-67 | | MI | Multiply immediate, fixed point singleword - base register | 78 | r, i[, x] | 7-67 | | MI | Multiply immediate, fixed point singleword-<br>index or vector parameter register | 7A | r, i[, x] | 7-67 | | МІН | Multiply immediate, fixed point halfword - arithmetic register | 7D | r, i[, x]. | 7-68 | | D | Divide into arithmetic register, fixed point singleword | 64 | r,[@][=]n[,x] | 7-69 | | DH | Divide into arithmetic register, fixed point halfword | 65 | r,[@][=]n[,x] | 7-70 | | DF | Divide into arithmetic register, floating point singleword | 66 | r,[@][=]n[,x] | 7-71 | | DFD | Divide into arithmetic register, floating point doubleword | 67 | r,[@][=]n[,x] | 7-72 | | DI | Divide immediate into arithmetic register, fixed point singleword | 74 | r, i[, x] | 7-73 | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|-----------------------------------------------------------------|--------------|-------------------|-------| | DIH | Divide immediate into arithmetic register, fixed point halfword | 75 | r, i[, x] | 7-74 | | AND | AND, singleword - arithmetic register | E0 | r,[@][=]n[,x] | 7-76 | | ANDD | AND, doubleword - arithmetic register | El | r,[@][=]n[,x] | 7-77 | | ANDI | AND immediate, singleword - arithmetic register | F0 | r, i[, x] | 7-78 | | OR | OR, singleword - arithmetic register | E4 | r,[@][=]n[,x] | 7-79 | | ORD | OR, doubleword - arithmetic register | E5 | r,[@][=]n[,x] | 7-80 | | ORI | OR immediate, singleword - arithmetic register | F4 | r, i[, x] | 7-81 | | XOR | Exclusive OR, singleword - arithmetic register | E8 | r,[@][=]n[,x] | 7-82 | | XORD | Exclusive OR, doubleword - arithmetic register | E9 | r,[@][=]n[,x] | 7-83 | | XORI | Exclusive OR immediate, singleword-arithmetic register | F8 | r, i[, x] | 7-84 | | EQC | Equivalence, singleword - arithmetic register | EC | r,[@][=]n[,x] | 7-85 | | EQCD | Equivalence, doubleword - arithmetic register | ED | r,[@][=]n[,x] | 7-86 | | EQCI | Equivalence immediate, singleword - arithmetic register | FC | r, i[, x] | 7-87 | | SA | Arithmetic shift, fixed point singleword - arithmetic register | C0 | r,i[,x] | 7-93 | | SAH | Arithmetic shift, fixed point halfword - arithmetic register | Cı | r, i[, x] | 7-94 | | SAD | Arithmetic shift, fixed point doubleword - arithmetic register | C3 | r, i[, x] | 7-95 | | SL | Logical shift, singleword - arithmetic register | C4 | r, i[, x] | 7-96 | | SLH | Logical shift, halfword - arithmetic register | C5 | r, i[, x] | 7-97 | | SLD | Logical shift, doubleword - arithmetic register | C7 | r, i[, x] | 7-98 | | SC | Circular shift, singleword - arithmetic register | СС | r, i[, x] | 7-99 | | SCH | Circular shift, halfword - arithmetic register | CD | r, i[, x] | 7-100 | | SCD | Circular shift, doubleword - arithmetic register | CF | r, i[, x] | 7-101 | | RVS | Bit reversal, singleword - arithmetic register | C6 | r, i[, x] | 7-102 | | С | Compare arithmetic register, fixed point singleword | C8 | r,[@][=]n[,x] | 7-104 | | С | Compare index or vector register, fixed point singleword | CE | r,[@][=]n[,x] | 7-104 | | СН | Compare arithmetic register, fixed point half-word | C9 | r,[@][=]n[,x] | 7-105 | | ASSMB<br>CODE | INSTRUCȚION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|----------------------------------------------------------------------------------|--------------|----------------------|-------| | CF | Compare arithmetic register, floating point singleword | CA | r,[@][=]n[,x] | 7-106 | | CFD | Compare arithmetic register, floating point doubleword | СВ | r,[@][=]n[,x] | 7-107 | | CI | Compare immediate arithmetic register, fixed point singleword | D8 | r, i[, x] | 7-108 | | CI | Compare index or vector register with immediate, singleword | DE | r, i[, x] | 7-108 | | CIH | Compare arithmetic register immediate, fixed point halfword | Д9 | r, i[, x] | 7-109 | | CAND | Compare logical AND, singleword - arithmetic register | E2 | r,[@][=]n[,x] | 7-110 | | CANDD | Compare logical AND, doubleword - arithmetic register | E3 | r,[@][=]n[,x] | 7-111 | | CANDI | Compare immediate logical AND, singleword - arithmetic register | F2 | r, i[, x] | 7-112 | | COR | Compare logical OR, singleword - arithmetic register | E6 | r,[@][=]n[,x] | 7-113 | | CORD | Compare logical OR, doubleword - arithmetic register | E7 | r,[@][=]n[,x] | 7-114 | | CORI | Compare immediate logical OR, singleword - arithmetic register | F6 | r, i[, x] | 7-115 | | ISE | Increment arithmetic register, test, and skip on equal | 80 | r,[@][=]n[,x] | 7-117 | | ISNE | Increment arithmetic register, test, and skip on not equal | 81 | r,[@][=]n[,x] | 7-118 | | DSE | Decrement arithmetic register, test, and skip on equal | 82 | r,[@][=]n[,x] | 7-119 | | DSNE | Decrement arithmetic register, test, and skip on not equal | 83 | r,[@][=]n[,x] | 7-120 | | всс | Branch on compare code true | 91 | m, [@[=]]n[,x] | 7-132 | | NOP | Take next instruction, Assembler supplies R field of zero | 91 | [@[=]]n[,x] | 7-132 | | BE | Branch on compare code of equal, Assembler supplies R field of one | 91 | [@[=]]n[,x] | 7-132 | | BG | Branch on compare code of greater than,<br>Assembler supplies R field of 2 | 91 | [@[=]]n[,x] | 7-132 | | BGE | Branch on compare code of greater than or equal, Assembler supplies R field of 3 | 91 | [@[=]]n[, <b>x</b> ] | 7-132 | | ASSMB<br>CODE | INSTRUCȚION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|---------------------------------------------------------------------------------------------|--------------|-------------------|-------| | BL | Branch on compare code of less than,<br>Assembler supplies R field of 4 | 91 | [@[=]]n[,x] | 7-132 | | BLE | Branch on compare code of less than or equal,<br>Assembler supplies R field of 5 | 91 | [@[=]]n[,x] | 7-132 | | BNE | Branch on compare code of not equal,<br>Assembler supplies R field of 6 | 91 | [@[=]]n[,x] | 7-132 | | В | Unconditional branch, Assembler supplies R field of 7 | 91 | [@[=]]n[,x] | 7-132 | | BCZ | Branch on compare code of all bits are zero,<br>Assembler supplies R field of one | 91 | [@[=]]n[,x] | 7-132 | | всо | Branch on compare code of all bits are one,<br>Assembler supplies R field of 2 | 91 | [@[=]]n[,x] | 7-132 | | всим | Branch on compare code of not mixed,<br>Assembler supplies R field of 3 | 91 | [@[=]]n[,x] | 7-132 | | всм | Branch on compare code of mixed zeros and ones, Assembler supplies R field of 4 | 91 | [@[=]]n[,x] | 7-132 | | BCNO | Branch on compare code of not all ones,<br>Assembler supplies R field of 5 | 91 | [@[=]]n[,x] | 7-132 | | BCNZ | Branch on compare code of not all zeros,<br>Assembler supplies the R field of 6 | 91 | [@[=]]n[,x] | 7-132 | | BRC | Branch on result code true | 95 | m,[@[=]]n[,x] | 7-133 | | BZ | Branch on result code of zero, Assembler supplies the R field of one | 95 | [@[=]]n[,x] | 7-133 | | BPL | Branch on result code of positive, Assembler supplies the R field of 2 | 95 | [@[=]]n[,x] | 7-133 | | BZP | Branch on result code of zero or positive,<br>Assembler supplies the R field of 3 | 95 | [@[=]]n[,x] | 7-133 | | вмі | Branch on result code of negative, Assembler supplies the R field of 4 | 95 | [@[=]]n[,x] | 7-133 | | BZM | Branch on result code of zero or negative,<br>Assembler supplies the R field of 5 | 95 | [@[=]]n[,x] | 7-133 | | BNZ | Branch on result code of not zero, Assembler supplies the R field of 6 | 95 | [@[=]]n[,x] | 7-133 | | BLR | Branch on logical result | 95 | m,[@[=]]n[,x] | 7-133 | | BRZ | Branch on result code of all bits are zero,<br>Assembler supplies the R field of one | 95 | [@[=]]n[,x] | 7-133 | | BRO | Branch on result code of all bits are one,<br>Assembler supplies the R field of 2 | 95 | [@[=]]n[,x] | 7-133 | | BRNM | Branch on result code of bits not mixed zeros and ones, Assembler supplies the R field of 3 | 95 | [@[=]]n[,x] | 7-133 | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|------------------------------------------------------------------------------------------------------------------------------|--------------|----------------------------------------------------------------------------------------------------|-------| | BRM | Branch on result code of bits mixed zeros and ones, Assembler supplies the R field of 4 | 95 | [@[=]]n[,x] | 7-133 | | BRNO | Branch on result code of not all bits ones,<br>Assembler supplies the R field of 5 | 95 | [@[=]]n[,x] | 7-133 | | BRNZ | Branch on result code of not all bits zeros,<br>Assembler supplies the R field of 6 | 95 | [@[=]]n[,x] | 7-133 | | BAE | Branch on arithmetic exception condition true | 9D | m,[@[=]]n[,x] | 7-134 | | BU | Branch on floating point exponent underflow,<br>Assembler supplies R field of one | 9D | [@[=]]n[,x] | 7-134 | | ВО | Branch on floating point exponent overflow,<br>Assembler supplies R field of 2 | 9D | [@[=]]n[,x] | 7-134 | | BUO | Branch on floating point exponent underflow or overflow, Assembler supplies R field of 3 | 9D | [@[=]]n[,x] | 7-134 | | BX | Branch on fixed point overflow, Assembler supplies R field of $4$ | 9D | [@[=]]n[,x] | 7-134 | | BXU | Branch on fixed point overflow or floating point exponent underflow, Assembler supplies R field of 5 | 9D | [@[=]]n[,x] | 7-134 | | вхо | Branch on fixed point overflow or floating point exponent overflow, Assembler supplies R field of 6 | 9D | [@[=]]n[,x] | 7-134 | | BXUO | Branch on fixed point overflow or floating point exponent overflow or underflow, Assembler supplies R field of 7 | 9D | [@[=]]n[,x] | 7-134 | | BD | Branch on divide check, Assembler supplies R field of 8 | 9D | [@[=]]n[,x] | 7-134 | | BDU | Branch on divide check or floating point exponent underflow, Assembler supplies R field of 9 | 9D | [@[=]]n[,x] | 7-134 | | BDO | Branch on divide check or floating point exponent overflow, Assembler supplies R field of A | 9D | [@[=]]n[,x] | 7-134 | | BDUO | Branch on divide check or floating point exponent overflow or underflow, Assembler supplies R field of B | 9D | [@[=]]n[,x] | 7-134 | | BDX | Branch on divide check or fixed point overflow, Assembler supplies R field of C | 9D | [@[=]]n[,x] | 7-134 | | BDXU | Branch on divide check or fixed point overflow<br>or floating point exponent underflow, Assem-<br>bler supplies R field of D | 9D | [@[=]]n[,x] | 7-134 | | | | | vangan kiliki Sook il Montel kina kina menis kananjana mangalan angangan dalah kanana kilina kanan | | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------------|-------| | BDXO | Branch on divide check or fixed point overflow<br>or floating point exponent overflow, Assem-<br>bler supplies R field of E | 9D | [@[=]]n[,x] | 7-134 | | BDXUO | Branch on divide check or fixed point overflow<br>or floating point exponent overflow or under-<br>flow, Assembler supplies R field of F | 9D | [@[=]]n[,x] | 7-134 | | BXEC | Branch on Execute branch condition true,<br>Assembler supplies R field of one or odd | 9C | [@]n[,x] | 7-135 | | IBZ | Increment arithmetic register, test, and branch on zero | 88 | r,[@[=]]n[,x] | 7-122 | | IBZ | Increment index or vector register, test, and branch on zero | 8C | r,[@[=]]n[,x] | 7-122 | | IBNZ | Increment arithmetic register, test, and branch on not zero | 89 | r,[@[=]]n[,x] | 7-123 | | IBNZ | Increment index or vector register, and branch on not zero | 8D | r,[@[=]]n[,x] | 7-123 | | DBZ | Decrement arithmetic register, test, and branch zero | 8A | r,[@[=]]n[,x] | 7-124 | | DBZ | Decrement index or vector register, test, and branch on zero | 8E | r,[@[=]]n[,x] | 7-124 | | DBNZ | Decrement arithmetic register, test, and branch on not zero | 8B | r,[@[=]]n[,x] | 7-124 | | DBNZ | Decrement index or vector register, test, and branch on not zero | 8F | r,[@[=]]n[,x] | 7-124 | | BCLE | Branch on arithmetic register less than or equal | 84 | r, r, n | 7-128 | | BCLE | Branch on index or vector register less than or equal | 86 | r, r, n | 7-128 | | ВСG | Branch on arithmetic register greater than | 85 | r, r, n | 7-129 | | BCG | Branch on index or vector register greater than | 87 | r, r, n | 7-129 | | BLB | Branch and load base register with program counter | 98 | r,[@[=]]n[,x] | 7-137 | | BLX | Branch and load index or vector register with program counter | 99 | r,[@[=]]n[,x] | 7-138 | | PSH | Push word into last-in-first-out stack | 93 | r,[@]n[,x] | 7-141 | | PUL | Pull word from last-in-first-out stack | 97 | r,[@]n[,x] | 7-142 | | MOD | Modify stack parameter doubleword | 9F | r,[@]n[,x] | 7-143 | | FLFX | Convert floating point singleword to fixed point singleword | <b>A</b> 0 | r,[@]n[,x] | 7-148 | | ASSMB | | MCHN | OPERAND | Ţ | |-------|-------------------------------------------------------------------------------|------------|-------------------|-------| | CODE | INSTRUCTION | CODE | OPERAND<br>FORMAT | TOPIC | | FLFH | Convert floating point singleword to fixed point halfword | Al | r,[@]n[,x] | 7-149 | | FDFX | Convert floating point doubleword to fixed point singleword | A2 | r,[@]n[,x] | 7-150 | | FXFL | Convert fixed point singleword to floating point singleword | A8 | r,[@]n[,x] | 7-151 | | FHFL | Convert fixed point halfword to floating point singleword | <b>A</b> 9 | r,[@]n[,x] | 7-152 | | FXFD | Convert fixed point singleword to floating point doubleword | AA | r,[@]n[,x] | 7-153 | | FHFD | Convert fixed point halfword to floating point doubleword | AB | r,[@]n[,x] | 7-154 | | NFX | Normalize fixed point singleword | AC | r,[@]n[,x] | 7-155 | | NFH | Normalize fixed point halfword | AD | r, [@]n[,x] | 7-156 | | хсн | Exchange - arithmetic register with effective address | 1 A | r,[@]n[,x] | 7-158 | | LLA | Load look ahead | 16 | i | 7-159 | | LEA | Load effective address into base register | 52 | r,[@][=]n[,x] | 7-160 | | LEA | Load effective address into index or vector register | 56 | r,[@][=]n[,x] | 7-160 | | XEC | Execute addressed instruction in line | 96 | [@[=]]n[,x] | 7-161 | | INT | Interpret - arithmetic register | 92 | r,[@][=]n[,x] | 7-162 | | MCP | Monitor call and proceed | 90 | i[,x] | 7-163 | | MCW | Monitor call and wait | 94 | i[,x] | 7-164 | | LAM | Load arithmetic mask | 12 | [@[=]]n[,x] | 7-166 | | LAC | Load arithmetic exception condition | 13 | [@[=]]n[,x] | 7-167 | | SPS | Store program status word | 22 | [@]n[,x] | 7-168 | | VECTL | Load and execute vector parameter file,<br>Assembler supplies R field of zero | В0 | [@]n[,x] | 8-4 | | VECT | Execute vector parameter file, Assembler supplies R field of one | В0 | [@]n[,x] | 8-5 | | | | | | | | | | | | | | | | | | | APPENDIX B: SCALAR INSTRUCTIONS IN ALPHABETICAL ORDER BY ASSEMBLER CODE | ASSMB MCUN OPERAND | | | | | |--------------------|-----------------------------------------------------------------------------|--------------|-------------------|-------| | CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | | A | Add to arithmetic register, fixed point single-word | 40 | r,[@][=]n[,x] | 7-43 | | A | Add to base register, fixed point singleword | 60 | r,[@][=]n[,x] | 7-43 | | A | Add to index or vector parameter register, | 62 | r,[@][=]n[,x] | 7-43 | | AF | Add to arithmetic register, floating point singleword | 42 | r,[@][=]n[,x] | 7-45 | | AFD | Add to arithmetic register, floating point doubleword | 43 | r,[@][=]n[,x] | 7-46 | | AH | Add to arithmetic register, fixed point halfword | 41 | r,[@][=]n[,x] | 7-44 | | AI | Add immediate to arithmetic register, fixed point singleword | 50 | r, i[, x] | 7-47 | | AI | Add immediate to base register, fixed point singleword | 70 | r, i[, x] | 7-47 | | AI<br>' | Add immediate to index or vector parameter register, fixed point singleword | 72 | r, i[, x] | 7-47 | | AIH | Add immediate to arithmetic register, fixed point halfword | 51 | r, i[, x] | 7-48 | | AM | Add magnitude to arithmetic register, fixed point singleword | 44 | r,[@][=]n[,x] | 7-49 | | AMF | Add magnitude to arithmetic register, floating point singleword | 46 | r,[@][=]n[,x] | 7-51 | | AMFD | Add magnitude to arithmetic register, floating point doubleword | 47 | r,[@][=]n[,x] | 7-52 | | АМН | Add magnitude to arithmetic register, fixed point halfword | 45 | r,[@][=]n[,x] | 7-50 | | AND | AND, singleword - arithmetic register | E0 | r,[@][=]n[,x] | 7-76 | | ANDD | AND, doubleword - arithmetic register | E1 | r,[@][=]n[,x] | 7-77 | | ANDI | AND immediate, singleword - arithmetic register | F0 | r, i[, x] | 7-78 | | В | Unconditional branch, Assembler supplies R field of 7 | 91 | [@[=]]n[,x] | 7-132 | | BAE | Branch on arithmetic exception condition true | 9D | m,[@[=]]n[,x] | 7-134 | | всс | Branch on compare code true | 91 | m,[@[=]]n[,x] | 7-132 | | всс | Branch on arithmetic register greater than | 85 | r, r, n | 7-129 | | всс | Branch on index or vector register greater than | 87 | r, r, n | 7-129 | | BCLE | Branch on arithmetic register less than or equal | 84 | r, r, n | 7-128 | | | | | | | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------------|------------| | BCLE | Branch on index or vector register less than or equal | 86 | r, r, n | 7-128 | | ВСМ | Branch on compare code of mixed zeros and ones, Assembler supplies R field of 4 | 91 | [@[=]]n[,x] | 7-132 | | BCNM | Branch on compare code of not mixed,<br>Assembler supplies R field of 3 | 91 | [@[=]]n[,x] | 7-132 | | BCNO | Branch on compare code of not all ones,<br>Assembler supplies R field of 5 | 91 | [@[=]]n[,x] | 7-132<br>- | | BCNZ | Branch on compare code of not all zeros,<br>Assembler supplies the R field of 6 | 91 | [@[=]]n[,x] | 7-132 | | ВСО | Branch on compare code of all bits are one,<br>Assembler supplies R field of 2 | 91 | [@[=]]n[,x] | 7-132 | | BCZ | Branch on compare code of all bits are zero,<br>Assembler supplies R field of one | 91 | [@[=]]n[,x] | 7-132 | | BD | Branch on divide check, Assembler supplies R field of $8$ | 9D | [@[=]]n[,x] | 7-134 | | BDO | Branch on divide check or floating point exponent overflow, Assembler supplies R field of A | 9D | [@[=]]n[,x] | 7-134 | | BDU | Branch on divide check or floating point exponent underflow, Assembler supplies R field of 9 | 9D | [@[=]]n[,x] | 7-134 | | BDUO | Branch on divide check or floating point exponent overflow or underflow, Assembler supplies R field of B | 9D | [@[=]]n[,x] | 7-134 | | BDX | Branch on divide check or fixed point overflow,<br>Assembler supplies R field of C | 9D | [@[=]]n[,x] | 7-134 | | BDXO | Branch on divide check or fixed point overflow<br>or floating point exponent overflow, Assembler<br>supplies R field of E | 9D | [@[=]]n[, x] | 7-134 | | BDXU | Branch on divide check or fixed point overflow<br>or floating point exponent underflow, Assem-<br>bler supplies R field of D | 9D | [@[=]]n[,x] | 7-134 | | BDXUO | Branch on divide check or fixed point overflow<br>or floating point exponent overflow or under-<br>flow, Assembler supplies R field of F | 9D | [@[=]]n[,x] | 7-134 | | BE | Branch on compare code of equal, Assembler supplies R field of one | 91 | [@[=]]n[,x] | 7-132 | | BG | Branch on compare code of greater than,<br>Assembler supplies R field of 2 | 91 | [@[=]]n[,x] | 7-132 | | ASSMB | | MCHN | OPERAND | T | |-------|---------------------------------------------------------------------------------------------|------|---------------|-------| | CODE | INSTRUCTION | CODE | FORMAT | TOPIC | | BGE | Branch on compare code of greater than or equal, Assembler supplies R field of 3 | 91 | [@[=]]n[,x] | 7-132 | | BL | Branch on compare code of less than, Assembler supplies R field of $4$ | 91 | [@[=]]n[,x] | 7-132 | | BLB | Branch and load base register with program counter | 98 | r,[@[=]]n[,x] | 7-137 | | BLE | Branch on compare code of less than or equal,<br>Assembler supplies R field of 5 | 91 | [@[=]]n[,x] | 7-132 | | BLR | Branch on logical result | 95 | m,[@[=]]n[,x] | 7-133 | | BLX | Branch and load index or vector register with program counter | 99 | r,[@[=]]n[,x] | 7-138 | | ВМІ | Branch on result code of negative, Assembler supplies the R field of 4 | 95 | [@[=]]n[,x] | 7-133 | | BNE | Branch on compare code of not equal,<br>Assembler supplies R field of 6 | 91 | [@[=]]n[,x] | 7-132 | | ΒNZ | Branch on result code of not zero, Assembler supplies the R field of $6$ | 95 | [@[=]]n[,x] | 7-133 | | ВО | Branch on floating point exponent overflow,<br>Assembler supplies R field of 2 | 9D | [@[=]]n[,x] | 7-134 | | BPL | Branch on result code of positive, Assembler supplies the R field of 2 | 95 | [@[=]]n[,x] | 7-133 | | BRC | Branch on result code true | 95 | m,[@[=]]n[,x] | 7-133 | | BRM | Branch on result code of bits mixed zeros and ones, Assembler supplies the R field of 4 | 95 | [@[=]]n[,x] | 7-133 | | BRNM | Branch on result code of bits not mixed zeros and ones, Assembler supplies the R field of 3 | 95 | [@[=]]n[,x] | 7-133 | | BRNO | Branch on result code of not all bits ones,<br>Assembler supplies the R field of 5 | 95 | [@[=]]n[,x] | 7-133 | | BRNZ | Branch on result code of not all bits zeros,<br>Assembler supplies the R field of 6 | 95 | [@[=]]n[,x] | 7-133 | | BRO | Branch on result code of all bits are one,<br>Assembler supplies the R field of 2 | 95 | [@[=]]n[,x] | 7-133 | | BRZ | Branch on result code of all bits are zero,<br>Assembler supplies the R field of one | 95 | [@[=]]n[,x] | 7-133 | | BU | Branch on floating point exponent underflow,<br>Assembler supplies R field of one | 9D | [@[=]]n[,x] | 7-134 | | вио | Branch on floating point exponent underflow or overflow, Assembler supplies R field of 3 | 9D | [@[=]]n[,x] | 7-134 | | вх | Branch on fixed point overflow, Assembler supplies R field of 4 | 9D | [@[=]]n[,x] | 7-134 | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|------------------------------------------------------------------------------------------------------------------|--------------|------------------------|-------| | BXEC | Branch on Execute branch condition true,<br>Assembler supplies R field of one or odd | 9C | [@]n[,x] | 7-135 | | вхо | Branch on fixed point overflow or floating point exponent overflow, Assembler supplies R field of 6 | 9D | [@[=]]n[,x] | 7-134 | | BXU | Branch on fixed point overflow or floating point exponent underflow, Assembler supplies R field of 5 | 9D | [@[=]]n[,x] | 7-134 | | вхио | Branch on fixed point overflow or floating point exponent overflow or underflow, Assembler supplies R field of 7 | 9D | [@[=]]n[,x] | 7-134 | | BZ | Branch on result code of zero, Assembler supplies the R field of one | 95 | [@[=]]n[,x] | 7-133 | | BZM | Branch on result code of zero or negative,<br>Assembler supplies the R field of 5 | 95 | [@[=]]n[,x] | 7-133 | | BZP | Branch on result code of zero or positive,<br>Assembler supplies the R field of 3 | 95 | [@[=]]n[,x] | 7-133 | | С | Compare arithmetic register, fixed point singleword | C8 | r,[@][=]n[,x] | 7-104 | | С | Compare index or vector register, fixed point singleword | CE | r,[@][=]n[, <b>x</b> ] | 7-104 | | CAND | Compare logical AND, singleword - arithmetic register | E2 | r,[@][=]n[,x] | 7-110 | | CANDD | Compare logical AND, doubleword - arithmetic register | E3 | r,[@][=]n[,x] | 7-111 | | CANDI | Compare immediate logical AND, singleword - arithmetic register | F2 | r, i[, x] | 7-112 | | CF | Compare arithmetic register, floating point singleword | CA | r,[@][=]n[,x] | 7-106 | | CFD | Compare arithmetic register, floating point doubleword | СВ | r,[@][=]n[,x] | 7-107 | | СН | Compare arithmetic register, fixed point halfword | C9 | r,[@][=]n[,x] | 7-105 | | CI | Compare immediate arithmetic register, fixed point singleword | D8 | r, i[, x] | 7-108 | | CI | Compare index or vector register with immediate singleword | DE | r, i[, x] | 7-108 | | CIH | Compare arithmetic register immediate, fixed point halfword | D9 | r, i[, x] | 7-109 | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|-------------------------------------------------------------------|--------------|-------------------|-------| | COR | Compare logical OR, singleword - arithmetic register | E6 | r,[@][=]n[,x] | 7-113 | | CORD | Compare logical OR, doubleword - arithmetic register | E7 | r,[@][=]n[,x] | 7-114 | | CORI | Compare immediate logical OR, singleword - arithmetic register | F6 | r, i[, x] | 7-115 | | D | Divide into arithmetic register, fixed point singleword | 64 | r,[@][=]n[,x] | 7-69 | | DBNZ | Decrement arithmetic register, test, and branch on not zero | 8B | r,[@[=]]n[,x] | 7-125 | | DBNZ | Decrement index or vector register, test, and branch on not zero | 8F | r,[@[=]]n[,x] | 7-125 | | DBZ | Decrement arithmetic register, test, and branch on zero | 8A | r,[@[=]]n[,x] | 7-124 | | рвz | Decrement index or vector register, test, and branch on zero | 8E | r,[@[=]]n[,x] | 7-124 | | DF | Divide into arithmetic register, floating point singleword | 66 | r,[@][=]n[,x] | 7-71 | | DFD | Divide into arithmetic register, floating point doubleword | 67 | r,[@][=]n[,x] | 7-72 | | DH | Divide into arithmetic register, fixed point halfword | 65 | r,[@][=]n[,x] | 7-70 | | DI | Divide immediate into arithmetic register, fixed point singleword | 74 | r, i[,x] | 7-73 | | DIH | Divide immediate into arithmetic register, fixed point halfword | 75 | r, i[, x] | 7-74 | | DSE | Decrement arithmetic register, test, and skip on equal | 82 | r,[@][=]n[,x] | 7-119 | | DSNE | Decrement arithmetic register, test, and skip on not equal | 83 | r,[@][=]n[,x] | 7-120 | | EQC | Equivalence, singleword - arithmetic register | EC | r,[@][=]n[,x] | 7-85 | | EQCD | Equivalence, doubleword - arithmetic register | ED | r,[@][=]n[,x] | 7-86 | | EQCI | Equivalence immediate, singleword - arithmetic register | FC | r, i[, x] | 7-87 | | FDFX | Convert floating point doubleword to fixed point singleword | A2 | r,[@]n[,x] | 7-150 | | FHFD | Convert fixed point halfword to floating point doubleword | AB | r,[@]n[,x] | 7-154 | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|--------------------------------------------------------------|--------------|-------------------|-------| | FHFL | Convert fixed point halfword to floating point singleword | <b>A</b> 9 | r,[@]n[,x] | 7-152 | | FLFH | Convert floating point singleword to fixed point halfword | Al | r,[@]n[,x] | 7-149 | | FLFX | Convert floating point singleword to fixed point singleword | A0 | r,[@]n[,x] | 7-148 | | FXFD | Convert fixed point singleword to floating point doubleword | AA | r,[@]n[,x] | 7-153 | | FXFL | Convert fixed point singleword to floating point singleword | A8 | r,[@]n[,x] | 7-151 | | IBNZ | Increment arithmetic register, test, and branch on not zero | 89 | r,[@[=]]n[,x] | 7-123 | | IBNZ | Increment index or vector register, and branch on not zero | 8D | r,[[[=]]n[,x] | 7-123 | | ĮBZ<br>, | Increment arithmetic register, test, and branch on zero | 88 | r,[@[=]]n[,x] | 7-122 | | IBZ | Increment index or vector register, test, and branch on zero | 8C | r,[@[=]]n[,x] | 7-122 | | INT | Interpret - arithmetic register | 92 | r,[@][=]n[,x] | 7-162 | | ISE | Increment arithmetic register, test and skip on equal | 80 | r,[@][=]n[,x] | 7-117 | | ISNE | Increment arithmetic register, test, and skip on not equal | 81 | r,[@][=]n[,x] | 7-118 | | L | Load arithmetic register, singleword | 14 | r,[@][=]n[,x] | 7-3 | | L | Load base register, singleword | 18 | r,[@][=]n[,x] | 7-3 | | L | Load index register or vector parameter register, singleword | 1C | r,[@][=]n[,x] | 7-3 | | LAC | Load arithmetic exception condition | 13 | [@[=]]n[,x] | 7-167 | | LAM | Load arithmetic mask | 12 | [@[=]]n[,x] | 7-166 | | LD | Load arithmetic register doubleword | 17 | r,[@][=]n[,x] | 7-7 | | LEA | Load effective address into base register | 52 | r,[@][=]n[,x] | 7-160 | | LEA | Load effective address into index or vector register | 56 | r,[@][=]n[,x] | 7-160 | | LF | Load base register file A, M=0 | 1B | m,[@]n[,x] | 7-23 | | LF | Load base register file B, M=1 | 1B | m, [@]n[,x] | 7-23 | | LF | Load arithmetic register file C, M=2 | 1B | m, [@]n[,x] | 7-23 | | LF | Load arithmetic register file D, M=3 | 1B | m,[@]n[,x] | 7-23 | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|------------------------------------------------------------------------------|--------------|-------------------|-------| | LF | Load index register file X, M=4 | 1 B | m,[@]n[,x] | 7-23 | | LF | Load vector parameter register file V, M=5 | 1B | m,[@]n[,x] | 7-23 | | LFM | Load all six eight-word register files | 1 F | [@]n[,x] | 7-24 | | LH | Load arithmetic register, halfword | 15 | r,[@][=]n[,x] | 7-4 | | LI | Load immediate into arithmetic register singleword | 54 | r, i[, x] | 7-8 | | LI | Load immediate into index register, or vector parameter register, singleword | 5C | r, i[,x] | 7-8 | | LIH | Load immediate into arithmetic register, halfword | 55 | r, i[, x] | 7-9 | | LL | Load memory right halfword, indexed, into arithmetic register left halfword | 19 | r,[@][=]n[,x] | 7-6 | | LLA | Load look ahead | 16 | i | 7-159 | | ĻM | Load magnitude, fixed point singleword, arithmetic register | 3C | r,[@][=]n[,x] | 7-14 | | LMD | Load magnitude, floating point doubleword, arithmetic register | 3F | r,[@][=]n[,x] | 7-17 | | LMF | Load magnitude, floating point singleword, arithmetic register | 3E | r,[@][=]n[,x] | 7-16 | | LMH | Load magnitude, fixed point halfword, arithmetic register | 3D | r,[@][=]n[,x] | 7-15 | | LN | Load negative, fixed point singleword, arithmetic register | 30 | r,[@][=]n[,x] | 7-10 | | LND | Load negative, floating point doubleword, arithmetic register | 33 | r,[@][=]n[,x] | 7-13 | | LNF | Load negative, floating point singleword, arithmetic register | 32 | r,[@][=]n[,x] | 7-12 | | LNH | Load negative, fixed point halfword, arithmetic register | 31 | r,[@][=]n[,x] | 7-11 | | LNM | Load negative magnitude, fixed point single-word, arithmetic register | 38 | r,[@][=]n[,x] | 7-18 | | LNMD | Load negative magnitude, floating point doubleword, arithmetic register | 3B | r,[@][=]n[,x] | 7-21 | | LNMF | Load negative magnitude, floating point singleword, arithmetic register | 3 <b>A</b> | r,[@][=]n[,x] | 7-20 | | LNMH | Load negative magnitude, fixed point halfword, arithmetic register | 39 | r,[@][=]n[,x] | 7-19 | | LO | Load arithmetic register with ones complement singleword | 1E | r,[@][=]n[,x] | 7-22 | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|---------------------------------------------------------------------------------|--------------|-------------------|-------| | LR | Load memory right halfword, indexed, into arithmetic register right halfword | 1D | r,[@][=]n[,x] | 7-5 | | М | Multiply fixed point singleword - arithmetic register | 6C | r,[@][=]n[,x] | 7-63 | | М | Multiply, fixed point singleword - base register | 68 | r,[@][=]n[,x] | 7-63 | | М | Multiply, fixed point singleword - index or vector parameter register | 6A | r,[@][=]n[,x] | 7-63 | | MCP | Monitor call and proceed | 90 | i[,x] | | | MCW | Monitor call and wait | 94 | i[, x] | 7-164 | | MF | Multiply, floating point singleword - arithmetic register | 6E | r,[@][=]n[,x] | 7-65 | | MFD | Multiply, floating point doubleword - arithmetic register | 6F | r,[@][=]n[,x] | 7-66 | | МН | Multiply, fixed point halfword - arithmetic register | 6D | r,[@][=]n[,x] | 7-64 | | MI | Multiply immediate, fixed point singleword - arithmetic register | 7C | r, i[, x] | 7-67 | | MI | Multiply immediate, fixed point singleword - base register | 78 | r, i[, x] | 7-67 | | MI | Multiply immediate, fixed point singleword - index or vector parameter register | 7A | r, i[, x] | 7-67 | | MIH | Multiply immediate, fixed point halfword - arithmetic register | 7D | r, i[, x] | 7-68 | | MOD | Modify stack parameter doubleword | 9F | r,[@]n[,x] | 7-143 | | NFH | Normalize fixed point halfword | AD | r,[@]n[,x] | 7-156 | | NFX | Normalize fixed point singleword | AC | r,[@]n[,x] | 7-155 | | NOP | Take next instruction, Assembler supplies R field of zero | 91 | [@[=]]n[,x] | 7-132 | | OR | OR, singleword - arithmetic register | E4 | r,[@][=]n[,x] | 7-79 | | ORD | OR, doubleword - arithmetic register | E5 | r,[@][=]n[,x] | 7-80 | | ORI | OR immediate, singleword - arithmetic register | F4 | r, i[, x] | 7-81 | | PSH | Push word into last-in-first-out stack | 93 | r,[@]n[,x] | 7-141 | | PUL | Pull word from last-in-first-out stack | 97 | r,[@]n[,x] | 7-142 | | RVS | Bit reversal, singleword - arithmetic register | С6 | r, i[, x] | 7-102 | | S | Subtract from arithmetic register, fixed | 48 | r,[@][=]n[,x] | 7-53 | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|------------------------------------------------------------------------|--------------|---------------------|-------| | SA | Arithmetic shift, fixed point singleword - arithmetic register | C0 | r, i[, x] | 7-93 | | SAD | Arithmetic shift, fixed point doubleword - arithmetic register | C3 | r, i[, x] | 7-95 | | SAH | Arithmetic shift, fixed point halfword - arithmetic register | Cl | r, i[, x] | 7-94 | | SC | Circular shift, singleword - arithmetic register | CC | r, i[,x] | 7-99 | | SCD | Circular shift, doubleword - arithmetic register | CF | r, i[, x] | 7-101 | | SCH | Circular shift, halfword - arithmetic register | CD | r, i[, x] | 7-100 | | SF | Subtract from arithmetic register, floating point singleword | 4A | r,[@][=]n[,x] | 7-55 | | SFD | Subtract from arithmetic register, floating point doubleword | 4B | r,[@][=]n[,x] | 7-56 | | SH | Subtract from arithmetic register, fixed point halfword | 49 | r,[@][=]n[,x] | 7-54 | | S1 | Subtract immediate from arithmetic register, fixed point singleword | 58 | r, i[, x] | 7-57 | | SIH | Subtract immediate from arithmetic register, fixed point halfword | 59 | r, i[, x] | 7-58 | | SL | Logical shift, singleword - arithmetic register | C4 | r, i[, x] | 7-96 | | SLD | Logical shift, doubleword - arithmetic register | C7 | r, i[,x] | 7-98 | | SLH | Logical shift, halfword - arithmetic register | C5 | r, i[, x] | 7-97 | | SM | Subtract magnitude from arithmetic register, fixed point singleword | 4C | r,[@][=]n[,x] | 7-59 | | SMF | Subtract magnitude from arithmetic register, floating point singleword | 4E | r,[@][=]n[,x] | 7-61 | | SMFD | Subtract magnitude from arithmetic register, floating point doubleword | 4F | r,[@][=]n[,x] | 7-62 | | SMH | Subtract magnitude from arithmetic register, fixed point halfword | 4D | r,[@][=]n[,x] | 7-60 | | SPS | Store program status word | 22 | [@]n[,x] | 7-168 | | ST | Store arithmetic register, singleword | 24 | r,[@]n[,x] | 7-26 | | ST | Store base register, singleword | 28 | r,[@]n[, <b>x</b> ] | 7-26 | | ST | Store index register or vector parameter register, singleword | 2C | r,[@]n[,x] | 7-26 | | ASSMB<br>CODE | INSTRUCTION | MCHN<br>CODE | OPERAND<br>FORMAT | TOPIC | |---------------|-------------------------------------------------------------------------------|--------------|-------------------|-------| | STD | Store arithmetic register, doubleword | 27 | r,[@]n[,x] | 7-30 | | STF | Store base register file A, M=0 | 2В | m, [@]n[,x] | 7-39 | | STF | Store base register file B, M=1 | 2B | m, [@]n[,x] | 7-39 | | STF | Store arithmetic register file C, M=2 | 2В | m,[@]n[,x] | 7-39 | | STF | Store arithmetic register file D, M=3 | 2В | m,[@]n[,x] | 7-39 | | STF | Store index register file X, M=4 | 2B | m,[@]n[,x] | 7-39 | | STF | Store vector parameter register file V, M=5 | 2B | m,[@]n[,x] | 7-39 | | STFM | Store all six eight word register files | 2F | [@]n[,x] | 7-41 | | STH | Store halfword, arithmetic register | 25 | r,[@]n[,x] | 7-27 | | STL | Store arithmetic register left halfword into memory right halfword, indexed | 29 | r,[@]n[,x] | 7-29 | | STŇ | Store negative, fixed point word | 34 | r,[@]n[,x] | 7-34 | | STND | Store negative, floating point doubleword | 37 | r,[@]n[,x] | 7-37 | | STNF | Store negative, floating point word | 36 | r,[@]n[,x] | 7-36 | | STNH | Store negative, fixed point halfword | 35 | r,[@]n[,x] | 7-35 | | STO | Store ones complement, word | 2E | r,[@]n[,x] | 7-38 | | STOH | Store ones complement, halfword | 2A | r,[@]n[,x] | 7-39 | | STR | Store arithmetic register right halfword into memory right halfword, indexed | 2D | r,[@]n[,x] | 7-28 | | STZ | Store zero, word | 20 | [@]n[, x] | 7-31 | | STZD | Store zero, doubleword | 23 | [@]n[,x] | 7-33 | | STZH | Store zero, halfword | 21 | [@]n[,x] | 7-32 | | VECT | Execute vector parameter file, Assembler supplies R field of one | В0 | [@]n[,x] | 8-5 | | VECTL | Load and execute vector parameter file,<br>Assembler supplies R field of zero | В0 | [@]n[, x] | 8-4 | | хсн | Exchange - arithmetic register with effective address | 1A | r,[@]n[,x] | 7-158 | | XEC | Execute addressed instruction in line | 96 | [@[=]]n[,x] | 7-161 | | XOR | Exclusive OR, singleword - arithmetic register | E8 | r,[@][=]n[,x] | 7-82 | | XORD | Exclusive OR, doubleword - arithmetic register | E9 | r,[@][=]n[,x] | 7-83 | | XORI | Exclusive OR immediate, singleword - arithmetic register | F8 | r, i[, x] | 7-84 | APPENDIX C: SCALAR INSTRUCTIONS IN NUMERIC ORDER BY MACHINE CODE | 13 L 14 L 15 L 16 L 17 L 18 L 19 L 1A X 1B L 1B L 1B L 1B L | LAM LAC L LH LLA LD L LL LL LL XCH LF LF | Load arithmetic mask Load arithmetic exception condition Load arithmetic register, singleword Load arithmetic register, halfword Load look ahead Load arithmetic register, doubleword Load base register, singleword Load memory right halfword, indexed, into arithmetic register left halfword Exchange - arithmetic register with effective address Load base register file A, M=0 Load base register file B, M=1 | [@[=]]n[,x] r,[@][=]n[,x] r,[@][=]n[,x] i r,[@][=]n[,x] r,[@][=]n[,x] r,[@][=]n[,x] r,[@][=]n[,x] m,[@]n[,x] | 7-166<br>7-167<br>7-3<br>7-4<br>7-159<br>7-7<br>7-3<br>7-6<br>7-158 | |-------------------------------------------------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------| | 14 L 15 L 16 L 17 L 18 L 19 L 1A X 1B L 1B L 1B L 1B L | L<br>LH<br>LLA<br>LD<br>L<br>LL<br>XCH | Load arithmetic register, singleword Load arithmetic register, halfword Load look ahead Load arithmetic register, doubleword Load base register, singleword Load memory right halfword, indexed, into arithmetic register left halfword Exchange - arithmetic register with effective address Load base register file A, M=0 | r,[@][=]n[,x] r,[@][=]n[,x] i r,[@][=]n[,x] r,[@][=]n[,x] r,[@][=]n[,x] r,[@]n[,x] | 7-3<br>7-4<br>7-159<br>7-7<br>7-3<br>7-6 | | 15 L 16 L 17 L 18 L 19 L 1A X 1B L 1B L 1B L 1B L | LH<br>LLA<br>LD<br>L<br>LL<br>XCH<br>LF | Load arithmetic register, halfword Load look ahead Load arithmetic register, doubleword Load base register, singleword Load memory right halfword, indexed, into arithmetic register left halfword Exchange - arithmetic register with effective address Load base register file A, M=0 | r,[@][=]n[,x] i r,[@][=]n[,x] r,[@][=]n[,x] r,[@][=]n[,x] m,[@]n[,x] | 7-4<br>7-159<br>7-7<br>7-3<br>7-6<br>7-158 | | 16 L 17 L 18 L 19 L 1A X 1B L 1B L 1B L | LLA<br>LD<br>L<br>LL<br>XCH<br>LF | Load look ahead Load arithmetic register, doubleword Load base register, singleword Load memory right halfword, indexed, into arithmetic register left halfword Exchange - arithmetic register with effective address Load base register file A, M=0 | i r,[@][=]n[,x] r,[@][=]n[,x] r,[@][=]n[,x] m,[@]n[,x] | 7-159<br>7-7<br>7-3<br>7-6<br>7-158 | | 17 L 18 L 19 L 1A X 1B L 1B L 1B L | LD<br>L<br>LL<br>XCH<br>LF<br>LF | Load arithmetic register, doubleword Load base register, singleword Load memory right halfword, indexed, into arithmetic register left halfword Exchange - arithmetic register with effective address Load base register file A, M=0 | r,[@][=]n[,x] r,[@][=]n[,x] r,[@][=]n[,x] r,[@]n[,x] | 7-7<br>7-3<br>7-6<br>7-158 | | 18 L 19 L 1A X 1B L 1B L 1B L | L<br>LL<br>XCH<br>LF<br>LF | Load base register, singleword Load memory right halfword, indexed, into arithmetic register left halfword Exchange - arithmetic register with effective address Load base register file A, M=0 | r,[@][=]n[,x] r,[@][=]n[,x] r,[@]n[,x] m,[@]n[,x] | 7-3<br>7-6<br>7-158 | | 19 L 1A X 1B L 1B L 1B L | LL<br>XCH<br>LF<br>LF | Load memory right halfword, indexed, into arithmetic register left halfword Exchange - arithmetic register with effective address Load base register file A, M=0 | r,[@][=]n[,x]<br>r,[@]n[,x]<br>m,[@]n[,x] | 7-6<br>7-158 | | 1A X 1B L 1B L 1B L | XCH<br>LF<br>LF | arithmetic register left halfword Exchange - arithmetic register with effective address Load base register file A, M=0 | r, [@]n[, x] $m, [@]n[, x]$ | 7-158 | | 1B L 1B L 1B L | LF<br>LF | address Load base register file A, M=0 | m,[@]n[,x] | | | 1B L<br>1B L<br>1B L | LF | - | | 7-23 | | 1B L | | Load hase register file B M-1 | | 1 '-23 | | 1B L | LF | Doad base register life D, M-1 | m, [@]n[,x] | 7-23 | | | 1 | Load arithmetic register file C, M=2 | m,[@]n[,x] | 7-23 | | 10 1 | LF | Load arithmetic register file D, M=3 | m,[@]n[, $x$ ] | 7-23 | | 1B L | LF | Load index register file X, M=4 | m, [@]n[,x] | 7-23 | | 1B L | LF | Load vector parameter register file V, M=5 | m,[@]n[,x] | 7-23 | | 1C L | L | Load index register or vector parameter register, singleword | r,[@][=]n[,x] | 7-3 | | 1D L | LR | Load memory right halfword, indexed, into arithmetic register right halfword | r,[@][=]n[,x] | 7-5 | | IE L | LO | Load arithmetic register with ones complement, singleword | r,[@][=]n[,x] | 7-22 | | IF L | LFM | Load all six eight-word register files | [@]n[,x] | 7-24 | | 20 S | STZ | Store zero, word | [@]n[, x] | 7-31 | | 21 S | STZH | Store zero, halfword | [@]n[,x] | 7-32 | | 22 S | SPS | Store program status word | [@]n[, x] | 7-168 | | 23 S | STZD | Store zero, doubleword | [@]n[, x] | 7-33 | | 24 S | ST | Store arithmetic register, singleword | r,[@]n[,x] | 7-26 | | 25 S' | STH | Store halfword, arithmetic register | r,[@]n[,x] | 7-27 | | 27 S | STD | Store arithmetic register, doubleword | r,[@]n[,x] | 7-30 | | 28 S | ST | Store base register, singleword | r,[@]n[,x] | 7-26 | | 29 S | STL | Store arithmetic register left halfword into memory right halfword, indexed | r,[@]n[,x] | 7-29 | | MCHN<br>CODE | ASSMB<br>CODE | INSTRUCTION | OPERAND<br>FORMAT | TOPIC | |--------------|---------------|------------------------------------------------------------------------------|-------------------|-------| | 2A | sтон | Store ones complement, halfword | r,[@]n[,x] | 7-39 | | 2B | STF | Store base register file A, M=0 | m, [@]n[,x] | 7-40 | | 2B | STF | Store base register file B, M=1 | m,[@]n[,x] | 7-40 | | 2B | STF | Store arithmetic register file C, M=2 | m,[@]n[,x] | 7-40 | | 2B | STF | Store arithmetic register file D, M=3 | m,[@]n[,x] | 7-40 | | 2B | STF | Store index register file X, M=4 | m,[@]n[,x] | 7-40 | | 2B | STF | Store vector parameter register file V, M=5 | m, [@]n[,x] | 7-40 | | 2C | ST | Store index register or vector parameter register | r,[@]n[,x] | 7-26 | | 2D | STR | Store arithmetic register right halfword into memory right halfword, indexed | r,[@]n[,x] | 7-28 | | 2E | STO | Store ones complement, word | r,[@]n[,x] | 7-38 | | 2F | STFM | Store all six eight-word register files | [@]n[,x] | 7-41 | | 30 | LN | Load negative, fixed point single word, arithmetic register | r,[@][=]n[,x] | 7-10 | | 31 | LNH | Load negative, fixed point halfword, arithmetic register | r,[@][=]n[,x] | 7-11 | | 32 | LNF | Load negative, floating point singleword, arithmetic register | r,[@][=]n[,x] | 7-12 | | 33 | LND | Load negative, floating point doubleword, arithmetic register | r,[@][=]n[,x] | 7-13 | | 34 | STN | Store negative, fixed point word | r,[@]n[,x] | 7-34 | | 35 | STNH | Store negative, fixed point halfword | r,[@]n[,x] | 7-35 | | 36 | STNF | Store negative, floating point word | r,[@]n[,x] | 7-36 | | 37 | STND | Store negative, floating point doubleword | r,[@]n[,x] | 7-37 | | 38 | LNM | Load negative magnitude, fixed point single-<br>word, arithmetic register | r,[@][=]n[,x] | 7-18 | | 39 | LNMH | Load negative magnitude, fixed point half-<br>word, arithmetic register | r,[@][=]n[,x] | 7-18 | | 3A | LNMF | Load negative magnitude, floating point singleword, arithmetic register | r,[@][=]n[,x] | 7-20 | | 3B | LNMD | Load negative magnitude, floating point doubleword, arithmetic register | r,[@][=]n[,x] | 7-21 | | 3C | LM | Load magnitude, fixed point singleword, arithmetic register | r,[@][=]n[,x] | 7-14 | | 3D | LMH | Load magnitude, fixed point halfword, arithmetic register | r,[@][=]n[,x] | 7-15 | | | | | | | | MCHN<br>CODE | ASSMB<br>CODE | INSTRUCTION | OPERAND<br>FORMAT | TOPIC | |--------------|---------------|------------------------------------------------------------------------|-------------------|-------| | 3E | LMF | Load magnitude, floating point singleword, arithmetic register | r,[@][=]n[,x] | 7-16 | | 3F | LMD | Load magnitude, floating point doubleword,<br>arithmetic register | r,[@][=]n[,x] | 7-17 | | 40 | A | Add to arithmetic register, fixed point singleword | r,[@][=]n[,x] | 7-43 | | 41 | AH | Add to a rithmetic register, fixed point halfword | r,[@][=]n[,x] | 7-44 | | 42 | AF | Add to arithmetic register, floating point singleword | r,[@][=]n[,x] | 7-45 | | <b>43</b> | AFD | Add to arithmetic register, floating point doubleword | r,[@][=]n[,x] | 7-46 | | 44 | АМ | Add magnitude to arithmetic register, fixed point singleword | r,[@][=]n[,x] | 7-49 | | 45 | АМН | Add magnitude to arithmetic register, fixed point halfword | r,[@][=]n[,x] | 7-50 | | 46 | AMF | Add magnitude to arithmetic register, floating point singleword | r,[@][=]n[,x] | 7-51 | | 47 | AMFD | Add magnitude to arithmetic register, floating point doubleword | r,[@][=]n[,x] | 7-52 | | 48 | S | Subtract from arithmetic register, fixed point singleword | r,[@][=]n[,x] | 7-53 | | 49 | SH | Subtract from arithmetic register, fixed point halfword | r,[@][=]n[,x] | 7-54 | | 4A | SF | Subtract from arithmetic register, floating point singleword | r,[@][=]n[,x] | 7-55 | | 4B | SFD | Subtract from arithmetic register, floating point doubleword | r,[@][=]n[,x] | 7-56 | | 4C | SM | Subtract magnitude from arithmetic register, fixed point singleword | r,[@][=]n[,x] | 7-59 | | 4D | SMH | Subtract magnitude from arithmetic register, fixed point halfword | r,[@][=]n[,x] | 7-60 | | 4E | SMF | Subtract magnitude from arithmetic register, floating point singleword | r,[@][=]n[,x] | 7-61 | | 4F | SMFD | Subtract magnitude from arithmetic register, floating point doubleword | r,[@][=]n[,x] | 7-62 | | 50 | AI | Add immediate to arithmetic register, fixed point singleword | r, i[,x] | 7-47 | | 51 | AIH | Add immediate to arithmetic register, fixed point halfword | r, i[, x] | 7-48 | | MCHN<br>CODE | ASSMB<br>CODE | INSTRUCTION | OPERAND<br>FORMAT | TOPIC | |--------------|---------------|------------------------------------------------------------------------------|-------------------|-------| | 52 | LEA | Load effective address into base register | r,[@][=]n[,x] | 7-160 | | 54 | LI | Load immediate into arithmetic register singleword | r, i[, x] | 7-8 | | 55 | LIH | Load immediate into arithmetic register,<br>halfword | r, i[, x] | 7-9 | | 56 | LEA | Load effective address into index or vector register | r,[@][=]n[,x] | 7-160 | | 58 | SI | Subtract immediate from arithmetic register, fixed point singleword | r, i[, x] | 7-57 | | 59 | SIH | Subtract immediate from arithmetic register, fixed point halfword | r, i[, x] | 7-58 | | 5C | LI | Load immediate into index register, or vector parameter register, singleword | r, i[, x] | 7-8 | | 60 | A | Add to base register, fixed point singleword | r,[@][=]n[,x] | 7-43 | | 62 | A | Add to index or vector parameter register, fixed point singleword | r,[@][=]n[,x] | 7-43 | | 64 | D | Divide into arithmetic register, fixed point singleword | r,[@][=]n[,x] | 7-69 | | 65 | DH | Divide into arithmetic register, fixed point halfword | r,[@][=]n[,x] | 7-70 | | 66 | DF | Divide into arithmetic register, floating point singleword | r,[@][=]n[,x] | 7-71 | | 67 | DFD | Divide into arithmetic register, floating point doubleword | r,[@][=]n[,x] | 7-72 | | 68 | М | Multiply, fixed point singleword - base register | r,[@][=]n[,x] | 7-63 | | 6A | М | Multiply, fixed point singleword - index or vector parameter register | r,[@][=]n[,x] | 7-63 | | 6C | M. | Multiply, fixed point singleword - arithmetic register | r,[@][=]n[,x] | 7-63 | | 6D | МН | Multiply, fixed point halfword - arithmetic register | r,[@][=]n[,x] | 7-64 | | 6E | MF | Multiply, floating point singleword - arithmetic register | r,[@][=]n[,x] | 7-65 | | 6F | MFD | Multiply, floating point doubleword - arithmetic register | r,[@][=]n[,x] | 7-66 | | 70 | AI | Add immediate to base register, fixed point singleword | r, i[, x] | 7-47 | | 1 | | | | | | MCHN<br>CODE | ASSMB<br>CODE | INSTRUCTION | OPERAND<br>FORMAT | TOPIC | |--------------|---------------|---------------------------------------------------------------------------------|-------------------|-------| | 72 | AI | Add immediate to index or vector parameter register, fixed point singleword | r, i[, x] | 7-47 | | 74 | DI | Divide immediate into arithmetic register, fixed point singleword | r, i[,x] | 7-73 | | 75 | DIH | Divide immediate into arithmetic register, fixed point halfword | r, i[,x] | 7-74 | | 78 | MI | Multiply immediate, fixed point singleword - base register | r, i[, x] | 7-67 | | 7 A | MI | Multiply immediate, fixed point singleword - index or vector parameter register | r, i[, x] | 7-67 | | 7C | MI | Multiply immediate, fixed point singleword - arithmetic register | r, i[, x] | 7-67 | | 7.D | MIH | Multiply immediate, fixed point halfword - arithmetic register | r, i[, x] | 7-68 | | 8D | ISE | Increment, test and skip on equal | r,[@][=]n[,x] | 7-117 | | 81 | ISNE | Increment, test and skip on not equal | r,[@][=]n[,x] | 7-118 | | 82 | DSE | Decrement, test and skip on equal | r,[@][=]n[,x] | 7-119 | | 83 | DSNE | Decrement, test and skip on not equal | r,[@][=]n[,x] | 7-120 | | 84 | BCLE | Branch on arithmetic register less than or equal | r,r,n | 7-128 | | 85 | всG | Branch on arithmetic register greater than | r, r, n | 7-129 | | 86 | BCLE | Branch on index less than or equal | r, r, n | 7-128 | | 87 | BCG | Branch on index greater than | r, r, n | 7-129 | | 88 | IBZ | Increment, test and branch on zero | r,[@[=]]n[,x] | 7-122 | | 89 | IBNZ | Increment, test and branch on not zero | r,[@[=]]n[,x] | 7-123 | | 8A | DBZ | Decrement, test and branch on zero | r,[@[=]]n[,x] | 7-124 | | 8B | DBNZ | Decrement, test and branch on not zero | r,[@[=]]n[,x] | 7-125 | | 8C | IBZ | Increment, test and branch on zero | r,[@[=]]n[,x] | 7-122 | | 8D | IBNZ | Increment index or vector register, and branch on not zero | r,[@[=]]n[,x] | 7-123 | | 8E | DBZ | Decrement index or vector register, test, and branch on zero | r,[@[=]]n[,x] | 7-124 | | 8F | DBNZ | Decrement index or vector register, test, and branch on not zero | r,[@[=]]n[,x] | 7-125 | | 90 | МСР | Monitor call and proceed | i,[,x] | 7-163 | | 91 | ВСС | Branch on compare code true | m,[@[=]]n[,x] | 7-132 | | 91 | NOP | Take next instruction, Assembler supplies R field of zero | [@[=]]n[,x] | 7-132 | | MCHN<br>CODE | ASSMB<br>CODE | INSTRUCTION | OPERAND<br>FORMAT | TOPIC | |--------------|---------------|------------------------------------------------------------------------------------|-------------------|-------| | 91 | BE | Branch on compare code of equal, Assembler supplies R field of one | [@[=]]n[,x] | 7-132 | | 91 i | BG | Branch on compare code of greater than,<br>Assembler supplies R field of 2 | [@[=]]n[,x] | 7-132 | | · 91 | BGE | Branch on compare code of greater than or equal, Assembler supplies R field of 3 | [@[=]]n[,x] | 7-132 | | 91 | BL | Branch on compare code of less than,<br>Assembler supplies R field of 4 | [@[=]]n[, x] | 7-132 | | 91 | BLE | Branch on compare code of less than or equal, Assembler supplies R field of 5 | [@[=]]n[,x] | 7-132 | | 91 | BNE | Branch on compare code of not equal,<br>Assembler supplies R field of 6 | [@[=]]n[,x] | 7-132 | | 91 | В | Unconditional branch, Assembler supplies<br>R field of 7 | [@[=]]n[,x] | 7-132 | | 91 | BCZ | Branch on compare code of all bits are zero, Assembler supplies R field of one | [@[=]]n[,x] | 7-132 | | 91 | всо | Branch on compare code of all bits are one,<br>Assembler supplies R field of 2 | [@[=]]n[,x] | 7-132 | | 91 | BCNM | Branch on compare code of not mixed,<br>Assembler supplies R field of 3 | [@[=]]n[,x] | 7-132 | | 91 | ВСМ | Branch on compare code of mixed zeros<br>and ones, Assembler supplies R field of 4 | [@[=]]n[,x] | 7-132 | | 91 | BCNO | Branch on compare code of not all ones,<br>Assembler supplies R field of 5 | [@[=]]n[,x] | 7-132 | | 91 | BCNZ | Branch on compare code of not all zeros,<br>Assembler supplies the R field of 6 | [@[=]]n[,x] | 7-132 | | 92 | INT | Interpret - arithmetic register | r,[@][=]n[,x] | 7-162 | | 93 | PSH | Push word into last-in-first-out stack | r,[@]n[,x] | 7-141 | | 94 | MCW | Monitor call and wait | i[,x] | 7-164 | | 95 | BRC ' | Branch on result code true | m,[@[=]]n[,x] | 7-133 | | 95 | BZ | Branch on result code of zero, Assembler supplies the R field of one | [@[=]]n[,x] | 7-133 | | 95 | BPL | Branch on result code of positive, Assembler supplies the R field of 2 | [@[=]]n[,x] | 7-133 | | 95 | BZP | Branch on result code of zero or positive,<br>Assembler supplies the R field of 3 | [@[=]]n[,x] | 7-133 | | 95 | BMI | Branch on result code or negative, Assembler supplies the R field of 4 | [@[=]]n[,x] | 7-133 | | 95 | BZM | Branch on result code of zero or negative,<br>Assembler supplies the R field of 5 | [@[=]]n[, x] | 7-133 | | MCHN | ASSMB | | ODEDAND | 1 | |------|-------|------------------------------------------------------------------------------------------------------------------|-------------------|--------| | CODE | CODE | INSTRUCTION | OPERAND<br>FORMAT | TOPIC | | 95 | BNZ | Branch on result code of not zero, Assembler supplies the R field of 6 | [@[=]]n[,x] | 7-133 | | 95 | BLR | Branch on logical result | m[@[=]]n[,x] | 7-133 | | 95 | BRZ | Branch on result code of all bits zero zero,<br>Assembler supplies the R field of one | [@[=]]n[, x] | 7-133 | | 95 | BRO | Branch on result code of all bits are one,<br>Assembler supplies the R field of 2 | [@[=]]n[,x] | 7-133 | | 95 | BRNM | Branch on result code of bits not mixed zeros and ones, Assembler supplies the R field of 3 | [@[=]]n[,x] | 7-133 | | 95 | BRM | Branch on result code of bits mixed zeros and ones, Assembler supplies the R field of 4 | [@[=]]n[,x] | 7-133 | | 95 | BRNO | Branch on result code of not all bits ones,<br>Assembler supplies the R field of 5 | [@[=]]n[,x] | 7-133 | | 95 | BRNZ | Branch on result code of not all bits zeros,<br>Assembler supplies the R field of 6 | [@[=]]n[,x] | 7-133 | | 96 | XEC | Execute addressed instruction in line | [@[=]]n[,x] | 7-161 | | 97 | PUL | Pull word from last-in-first-out stack | r,[@]n[,x] | 7-142 | | 98 | BLB | Branch and load base register with program counter | r,[@[=]]n[,x] | 7-137 | | 99 | BLX | Branch and load index or vector register with program counter | r,[@[=]]n[,x] | 7-138 | | 9C | BXEC | Branch on Execute branch condition true,<br>Assembler supplies R field of one or odd | [@]n[,x] | 7-135 | | 9D | BAE | Branch on arithmetic exception condition true | m,[@[=]]n[,x] | .7-134 | | 9D | BU | Branch on floating point exponent underflow,<br>Assembler supplies R field of one | [@[=]]n[,x] | 7-134 | | 9D | во | Branch on floating point exponent overflow,<br>Assembler supplies R field of 2 | [@[=]]n[,x] | 7-134 | | 9D | BUO | Branch on floating point exponent underflow or overflow, Assembler supplies R field of 3 | [@[=]]n[,x] | 7-134 | | 9D | вх | Branch on fixed point overflow, Assembler supplies R field of 4 | [@[=]]n[,x] | 7-134 | | 9D | BXU | Branch on fixed point overflow or floating point exponent underflow, Assembler supplies R field of 5 | [@[=]]n[,x] | 7-134 | | 9D | вхо | Branch on fixed point overflow or floating point exponent overflow, Assembler supplies R field of 6 | [@[=]]n[,x] | 7-134 | | 9D | BXUO | Branch on fixed point overflow or floating point exponent overflow or underflow, Assembler supplies R field of 7 | [@[=]]n[,x] | 7-134 | | 9D BD 9D BD | DU DO DUO DX | Branch on divide check, Assembler supplies R field of 8 Branch on divide check or floating point exponent underflow, Assembler supplies R field of 9 Branch on divide check or floating point exponent overflow, Assembler supplies R field of A Branch on divide check or floating point exponent overflow or underflow, Assembler supplies R field of B Branch on divide check or fixed point overflow, Assembler supplies R field of C Branch on divide check or fixed point overflow, Assembler supplies R field of C | [@[=]]n[,x] [@[=]]n[,x] [@[=]]n[,x] [@[=]]n[,x] | 7-134<br>7-134<br>7-134<br>7-134 | |-------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------------------------------| | 9D BD 9D BD | DO DUO DX DXU | exponent underflow, Assembler supplies R field of 9 Branch on divide check or floating point exponent overflow, Assembler supplies R field of A Branch on divide check or floating point exponent overflow or underflow, Assembler supplies R field of B Branch on divide check or fixed point overflow, Assembler supplies R field of C Branch on divide check or fixed point over- | [@[=]]n[,x] [@[=]]n[,x] | 7-134 | | 9D BD | DUO DX DXU | exponent overflow, Assembler supplies R field of A Branch on divide check or floating point exponent overflow or underflow, Assembler supplies R field of B Branch on divide check or fixed point over- flow, Assembler supplies R field of C Branch on divide check or fixed point over- | [@[=]]n[,x]<br>[@[=]]n[,x] | 7-134 | | 9D BD | DX : | exponent overflow or underflow, Assembler supplies R field of B Branch on divide check or fixed point over-flow, Assembler supplies R field of C Branch on divide check or fixed point over- | [@[=]]n[,x] | | | , , , , , , , , , | DXU : | flow, Assembler supplies R field of C Branch on divide check or fixed point over- | | 7-134 | | 9D BD | 1 | Branch on divide check or fixed point over- | rer ii r i | 1 | | | | Assembler supplies R field of D | [@[=]]n[,x] | 7-134 | | 9D BD | 1 1 | Branch on divide check or fixed point over-<br>flow or floating point exponent overflow,<br>Assembler supplies R field of E | [@[=]]n[, x] | 7-134 | | 9D BD | . 1 | Branch on divide check or fixed point over-<br>flow or floating point exponent overflow or<br>underflow, Assembler supplies R field of F | [@[=]]n[, x] | 7-134 | | 9F MO | OD I | Modify stack parameter doubleword | r,[@]=[,x] | 7-143 | | A0 FL | | Convert floating point singleword to fixed point singleword | r,[@]n[,x] | 7-148 | | A1 FL | | Convert floating point singleword to fixed point halfword | r,[@]n[,x] | 7-149 | | A2 FD | | Convert floating point doubleword to fixed point singleword | r,[@]n[,x] | 7-150 | | A8 FX | | Convert fixed point singleword to floating point singleword | r,[@]n[,x] | 7-151 | | A9 FH | | Convert fixed point halfword to floating point singleword | r,[@]n[,x] | 7-152 | | AA FX | | Convert fixed point singleword to floating point doubleword | r,[@]n[,x] | 7-153 | | AB FH | | Convert fixed point halfword to floating point doubleword | r,[@]n[,x] | 7-154 | | AC NF | fx 1 | Normalize fixed point singleword | r,[@]n[,x] | 7-155 | | AD NF | FH N | Normalize fixed point halfword | r,[@]n[,x] | 7-156 | | B0 VE | | Load and execute vector parameter file,<br>Assembler supplies R field of zero | [@]n[, x] | 8-4 | | MCHN<br>CODE | ASSMB<br>CODE | INSTRUCTION | OPERAND<br>FORMAT | TOPIC | |------------------|---------------|------------------------------------------------------------------|-------------------|-------| | В0 | VECT | Execute vector parameter file, Assembler supplies R field of one | [@]n[, x] | 8-5 | | C0 | SA | Arithmetic shift, fixed point singleword - arithmetic register | r, i[, x] | 7-93 | | C1 | SAH | Arithmetic shift, fixed point halfword - arithmetic register | r, i[, x] | 7-94 | | C3 | SAD | Arithmetic shift, fixed point doubleword - arithmetic register | r, i[, x] | 7-95 | | C4 | SL | Logical shift, singleword - arithmetic register | r, i[, x] | 7-96 | | C5 | SLH | Logical shift, halfword - arithmetic register | r, i[, x] | 7-97 | | C <sub>.</sub> 6 | RVS | Bit reversal, singleword - arithmetic register | r, i[, x] | 7-102 | | C7 | SLD | Logical shift, doubleword - arithmetic register | r, i[, x] | 7-98 | | C8 | С | Compare arithmetic register, fixed point singleword | r,[@][=]n[,x] | 7-104 | | C9 | СН | Compare arithmetic register, fixed point halfword | r,[@][=]n[,x] | 7-105 | | CA | CF | Compare arithmetic register, floating point singleword | r,[@][=]n[,x] | 7-106 | | СВ | CED | Compare arithmetic register, floating point doubleword | r,[@][=]n[,x] | 7-107 | | CC | SC | Circular shift, singleword - arithmetic register | r, i[, x] | 7-99 | | CD | SCH | Circular shift, halfword - arithmetic<br>register | r, i[, x] | 7-100 | | CE | С | Compare index or vector register, fixed point singleword | r,[@][=]n[,x] | 7-104 | | CF | SCD | Circular shift, doubleword - arithmetic<br>register | r, i[, x] | 7-101 | | D8 | CI | Compare immediate arithmetic register, fixed point singleword | r, i[, x] | 7-108 | | D9 | CIH | Compare arithmetic register immediate, fixed point halfword | r, i[, x] | 7-109 | | DE | CI | Compare index or vector register with immediate, singleword | r, i[, x] | 7-108 | | E0 | AND | AND, singleword - arithmetic register | r,[@][=]n[,x] | 7-76 | | E1 | ANDD | AND, doubleword - arithmetic register | r,[@][=]n[,x] | 7-77 | | E2 | CAND | Compare logical AND, singleword - arithmetic register | r,[@][=]n[,x] | 7-110 | | MCHN<br>CODE | ASSMB<br>CODE | INSTRUCTION | OPERAND<br>FORMAT | торіс | |--------------|---------------|----------------------------------------------------------------------|-------------------|-------| | E3 | CANDD | Compare logical AND, doubleword - arith-<br>metic register | r,[@][=]n[,x] | 7-111 | | E4 | OR | OR, singleword - arithmetic register | r,[@][=]n[,x] | 7-79 | | E5 | ORD | OR, doubleword - arithmetic register | r,[@][=]n[,x] | 7-80 | | E6 | COR | Compare logical OR, singleword - arith-<br>metic register | r,[@][=]n[,x] | 7-113 | | E7 | CORD | Compare logical OR, doubleword - arith-<br>metic register | r,[@][=]n[,x] | 7-114 | | E8 | XOR | Exclusive OR, singleword - arithmetic register | r,[@][=]n[,x] | 7-82 | | E9 | XORD | Exclusive OR, doubleword - arithmetic register | r,[@][=]n[,x] | 7-83 | | EC | EQC | Equivalence, singleword - arithmetic register | r,[@][=]n[,x] | 7-85 | | ED | EQCD | Equivalence, doubleword - arithmetic register | r,[@][=]n[,x] | 7-86 | | F0 | ANDI | AND immediate, singleword - arithmetic register | r, i[, x] | 7-78 | | F2 | CANDI | Compare immediate logical AND, single-<br>word - arithmetic register | r, i[, x] | 7-112 | | F4 | ORI | OR immediate, singleword - arithmetic register | r, i[, x] | 7-81 | | F6 | CORI | Compare immediate logical OR, singleword - arithmetic register | r, i[, x] | 7-115 | | F8 | XORI | Exclusive OR immediate, singleword - arithmetic register | r, i[, x] | 7-84 | | FC | EQCI | Equivalence immediate, singleword - arithmetic register | r, i[, x] | 7-87 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # APPENDIX D: VECTOR INSTRUCTIONS BY LOGICAL GROUPING | ASSMB<br>CODE | MCHN<br>CODE | INSTRUCTION | TOPIC | |---------------|--------------|------------------------------------------------------|-------| | VA | 40 | Vector add, fixed point singleword elements | 8-27 | | VAH | 41 | Vector add, fixed point halfword elements | 8-27 | | VAF | 42 | Vector add, floating point singleword | 8-27 | | VAFD | 43 | Vector add, floating point doubleword | 8-27 | | VAM | 44 | Vector add magnitude, fixed point singleword | 8-28 | | VAMH | 45 | Vector add magnitude, fixed point halfword | 8-28 | | VAMF | 46 | Vector add magnitude, floating point singleword | 8-28 | | VAMFD | 47 | Vector add magnitude, floating point doubleword | 8-28 | | VS | 48 | Vector subtract, fixed point singleword | 8-29 | | VSH | 49 | Vector subtract, fixed point halfword | 8-29 | | VSF | 4A | Vector subtract, floating point singleword | 8-29 | | VSFD | 4B | Vector subtract, floating point doubleword | 8-29 | | VSМ | 4C | Vector subtract magnitude, fixed point singleword | 8-30 | | VSMH | 4D | Vector subtract magnitude, fixed point halfword | 8-30 | | VSMF | 4E | Vector subtract magnitude, floating point singleword | 8-30 | | VSMFD | 4F | Vector subtract magnitude, floating point doubleword | 8-30 | | VM | 6C | Vector multiply, fixed point singleword | 8-31 | | VMH | 6D | Vector multiply, fixed point halfword | 8-31 | | VMF | 6E | Vector multiply, floating point singleword | 8-31 | | VMFD | 6F | Vector multiply, floating point doubleword | 8-31 | | VDP | 68 | Vector dot product, fixed point singleword | 8-32 | | VDPH | 69 | Vector dot product, fixed point halfword | 8-32 | | VDPF | 6A | Vector dot product, floating point singleword | 8-32 | | VDPFD | 6B | Vector dot product, floating point doubleword | 8-32 | | VD | 64 | Vector divide, fixed point singleword | 8-33 | | VDH | 65 | Vector divide, fixed point halfword | 8-33 | | VDF | 66 | Vector divide, floating point singleword | 8-33 | | VDFD | 67 | Vector divide, floating point doubleword | 8-33 | | VAND | E0 | Vector logical AND, singleword | 8-34 | | VOR | E4 | Vector logical OR, singleword | 8-34 | | VXOR | E8 | Vector logical Exclusive OR, singleword | 8-34 | | VEQC | EC | Vector logical Equivalence, singleword | 8-34 | | VANDD | El | Vector logical AND, doubleword | 8-34 | | ASSMB<br>CODE | MCHN<br>CODE | INSTRUCTION | TOPIC | | | | |---------------|--------------|----------------------------------------------------------------------|-------|--|--|--| | VORD | <b>E</b> 5 | Vector logical OR, doubleword | 8-34 | | | | | VXORD | E9 | Vector Exclusive OR, doubleword | | | | | | VEQCD | ED | Vector Equivalence, doubleword | | | | | | VSA | C0 | ector arithmetic shift, fixed point singleword | | | | | | VSAH | Cı | Vector arithmetic shift, fixed point halfword | 8-35 | | | | | VSAD | C3 | Vector arithmetic shift, fixed point doubleword | 8-35 | | | | | VSL | C4 | Vector logical shift, singleword | 8-35 | | | | | VSLH | C5 | Vector logical shift, halfword | 8-35 | | | | | VSLD | C7 | Vector logical shift, doubleword | 8-35 | | | | | vsc | СС | Vector circular shift, singleword | 8-35 | | | | | VSCH | CD | Vector circular shift, halfword | 8-35 | | | | | VSCD | CF | Vector circular shift, doubleword | 8-35 | | | | | VMG | D8 | Vector merge singlewords | 8-36 | | | | | VMGH | D9 | Vector merge halfwords | 8-36 | | | | | VMGD | DB | Vector merge doublewords | 8-36 | | | | | vo | D4 | Vector order singlewords, fixed point | 8-37 | | | | | vон | D5 | Vector order halfwords, fixed point | 8-37 | | | | | VOF | D6 | Vector order singlewords, floating point | 8-37 | | | | | VOFD | D7 | Vector order doublewords, floating point | 8-37 | | | | | vc | D0 | Vector arithmetic comparison, fixed point singleword | 8-39 | | | | | VCH | Dl | Vector arithmetic comparison, fixed point halfword | 8-39 | | | | | VCF | D2 | Vector arithmetic comparison, fixed point halfword | 8-39 | | | | | VCFD | D3 | Vector arithmetic comparison, floating point doubleword | 8-39 | | | | | VCAND | E2 | Vector logical comparison using AND, singleword | 8-40 | | | | | VCANDD | E3 | Vector logical comparison using AND, doubleword | 8-40 | | | | | VCOR | E6 | Vector logical comparison using OR, singleword | 8-40 | | | | | VCORD | E7 | Vector logical comparison using OR, doubleword | 8-40 | | | | | VPP | DC | Vector peak, fixed point singleword | 8-42 | | | | | VPPH | DD | Vector peak, fixed point halfword | 8-42 | | | | | VPPF | DE | Vector peak, floating point singleword | 8-42 | | | | | VPPFD | DF | Vector peak, floating point doubleword | 8-42 | | | | | VL | 50 | Vector search for largest arithmetic element, fixed point singleword | 8-44 | | | | | ASSMB<br>CODE | MCHN<br>CODE | INSTRUCTION | торіс | |---------------|--------------|----------------------------------------------------------------------------------|-------| | VLḤ | 51 | Vector search for largest arithmetic element, fixed point halfword | 8-44 | | VLF | 52 | Vector search for largest arithmetic element, floating point singleword | 8-44 | | VLFD | 53 | Vector search for largest arithmetic element, floating point doubleword | 8-44 | | VLM | 54 | Vector search for largest magnitude, fixed point singleword | 8-45 | | VLMH | 55 | Vector search for largest magnitude, fixed point halfword | 8-45 | | VLMF | 56 | Vector search for largest magnitude, floating point singleword | 8-45 | | VLMFD | 57 | Vector search for largest magnitude, floating point doubleword | 8-45 | | VSS | 58 | Vector search for smallest arithmetic element, fixed point singleword | 8-46 | | VSSH | 59 | Vector search for smallest arithmetic element, fixed point halfword | 8-46 | | VSSF | 5A | Vector search for smallest arithmetic element, floating point singleword | 8-46 | | VSSFD | 5B | Vector search for smallest arithmetic element, floating point doubleword | 8-46 | | VSSM | 5C | Vector search for smallest magnitude, fixed point singleword | 8-47 | | VSSMH | 5D | Vector search for smallest magnitude, fixed point halfword | 8-47 | | VSSMF | 5E | Vector search for smallest magnitude, floating point singleword | 8-47 | | VSSMFD | 5 F | Vector search for smallest magnitude, floating point doubleword | 8-47 | | VFLFX | A0 | Vector convert floating point singleword to fixed point singleword elements | 8-49 | | VFLFH | Al | Vector convert floating point singleword to fixed point halfword elements | 8-49 | | VFDFX | A2 | Vector convert floating point doubleword to fixed point single-word elements | 8-49 | | VFXFL | A8 | Vector convert fixed point singleword to floating point single-word elements | 8-50 | | VFXFD | AA | Vector convert fixed point singleword to floating point double-<br>word elements | 8-50 | | VFHFL | <b>A</b> 9 | Vector convert fixed point halfword to floating point singleword elements | 8-50 | | VFHFD | AB | Vector convert fixed point halfword to floating point doubleword elements | 8-50 | | VNFX | AC | Vector normalize fixed point singleword | 8-51 | | VNFH | AD | Vector normalize fixed point halfword | 8-51 | # APPENDIX E: VECTOR INSTRUCTIONS IN ALPHABETICAL ORDER BY ASSEMBLER CODE | VAFD VAH | ASSMB<br>CODE | MCHN<br>CODE | INSTRUCTION | TOPIC | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------|---------------------------------------------------------------------|-------|--|--| | VAFD 43 Vector add, floating point doubleword 8. VAH 41 Vector add, fixed point halfword 8. VAM 44 Vector add magnitude, fixed point singleword 8. VAMFD 46 Vector add magnitude, floating point doubleword 8. VAMH 45 Vector add magnitude, floating point doubleword 8. VAND E0 Vector logical AND, singleword 8. VAND E1 Vector logical AND, doubleword 8. VC D0 Vector logical Comparison, fixed point singleword 8. VCANDD E2 Vector logical comparison using AND, singleword 8. VCANDD E3 Vector logical comparison using AND, doubleword 8. VCF D2 Vector arithmetic comparison, floating point singleword 8. VCF D2 Vector arithmetic comparison, floating point doubleword 8. VCH D1 Vector arithmetic comparison, floating point doubleword 8. VCH D1 Vector arithmetic comparison, fixed point halfword 8. VCOR E6 Vector logical comparison using OR, singleword 8. VCORD E7 Vector logical comparison using OR, doubleword 8. VCORD E7 Vector divide fixed point, singleword 8. VDF 66 Vector divide floating point, doubleword 8. VDF 66 Vector divide floating point, doubleword 8. VDF 67 Vector divide floating point, doubleword 8. VDF 68 Vector divide fixed point, halfword 8. VDPF 6A Vector dot product, fixed point singleword 8. VDPF 6A Vector dot product, fixed point singleword 8. VDPF 6B Vector dot product, fixed point singleword 8. VDPF 6B Vector dot product, fixed point singleword 8. VDPF 6B Vector dot product, fixed point halfword 8. VPDF 6P Vector logical Equivalence, singleword 8. VEQC EC Vector logical Equivalence, singleword 8. VFDFX A2 Vector convert floating point doubleword to fixed point singleword 9. VFDFX A2 Vector convert floating point halfword to floating point singleword 9. VFHFD AB Vector convert fixed point halfword to floating point singleword 9. | VA | 40 | Vector add, fixed point singleword | | | | | VAH 41 Vector add, fixed point halfword VAM 44 Vector add magnitude, fixed point singleword VAMF 46 Vector add magnitude, floating point singleword VAMFD 47 Vector add magnitude, floating point doubleword VAMH 45 Vector add magnitude, floating point doubleword VAND E0 Vector logical AND, singleword VAND E1 Vector logical AND, doubleword VC D0 Vector arithmetic comparison, fixed point singleword VCAND E2 Vector logical comparison using AND, singleword VCAND E3 Vector logical comparison using AND, doubleword VCF D2 Vector arithmetic comparison, floating point singleword VCF D2 Vector arithmetic comparison, floating point singleword VCF D3 Vector arithmetic comparison, floating point doubleword VCH D1 Vector arithmetic comparison, floating point doubleword VCOR E6 Vector logical comparison using OR, singleword VCOR E7 Vector logical comparison using OR, doubleword VCOR E6 Vector divide fixed point, singleword VDF 66 Vector divide floating point, singleword VDF 66 Vector divide floating point, singleword VDF 67 Vector divide floating point, singleword VDF 68 Vector divide floating point, halfword VDP 68 Vector dot product, fixed point singleword VDPF 6A Vector dot product, floating point doubleword VDPF 6A Vector dot product, floating point singleword VDPF 6B Vector dot product, floating point doubleword VDPF 6B Vector logical Equivalence, singleword VEQC EC Vector logical Equivalence, doubleword VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFD AB Vector convert fixed point halfword to floating point singleword VFHFD AB Vector convert fixed point halfword to floating point singleword VFHFD AB Vector convert fixed point halfword to floating point singleword | VAF | 42 | Vector add, floating point singleword | 8-27 | | | | VAM 44 Vector add magnitude, fixed point singleword VAMF 46 Vector add magnitude, floating point singleword VAMFD 47 Vector add magnitude, floating point doubleword VAMH 45 Vector add magnitude, floating point doubleword VAND E0 Vector logical AND, singleword VAND E1 Vector logical AND, doubleword VC D0 Vector logical comparison, fixed point singleword VCAND E2 Vector logical comparison using AND, singleword VCAND E3 Vector logical comparison using AND, doubleword VCF D2 Vector arithmetic comparison, floating point singleword VCF D3 Vector arithmetic comparison, floating point doubleword VCH D1 Vector arithmetic comparison, floating point doubleword VCOR E6 Vector logical comparison using OR, singleword VCOR E7 Vector logical comparison using OR, singleword VCOR E6 Vector divide fixed point, singleword VDF 66 Vector divide floating point, singleword VDF 66 Vector divide floating point, singleword VDF 66 Vector divide floating point, singleword VDF 65 Vector divide fixed point, halfword VDP 68 Vector dot product, fixed point singleword VDP 68 Vector dot product, floating point singleword VDP 69 Vector dot product, floating point doubleword VDP 69 Vector dot product, floating point doubleword VDP 69 Vector dot product, floating point doubleword VDP 69 Vector dot product, fixed point halfword VCQC EC Vector logical Equivalence, singleword VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFD AB Vector convert floating point doubleword to floating point singleword VFHFD AB Vector convert fixed point halfword to floating point singleword VFHFD AB Vector convert fixed point halfword to floating point singleword | VAFD | 43 | ector add, floating point doubleword | | | | | VAMF VAMF VAMF VAMF VAMF VAMF VAMF VAMF | VAH | 41 | Vector add, fixed point halfword | 8-27 | | | | VAMFD 47 Vector add magnitude, floating point doubleword VAMH 45 Vector add magnitude, fixed point singleword VAND E0 Vector logical AND, singleword VANDD E1 Vector logical AND, doubleword VC D0 Vector arithmetic comparison, fixed point singleword VCANDD E2 Vector logical comparison using AND, singleword VCANDD E3 Vector logical comparison using AND, doubleword VCF D2 Vector arithmetic comparison, floating point singleword VCF D3 Vector arithmetic comparison, floating point doubleword VCH D1 Vector arithmetic comparison, fixed point halfword VCOR E6 Vector logical comparison using OR, singleword VCOR E7 Vector logical comparison using OR, doubleword VCOR E7 Vector divide fixed point, singleword VDF 66 Vector divide floating point, singleword VDF 66 Vector divide floating point, doubleword VDF 66 Vector divide floating point, doubleword VDP 68 Vector dot product, fixed point singleword VDP 68 Vector dot product, floating point singleword VDPF 6A Vector dot product, floating point singleword VDPF 6B Vector dot product, floating point doubleword VDPF 6B Vector dot product, floating point doubleword VDPF 6B Vector dot product, fixed point halfword VEQC EC Vector logical Equivalence, singleword VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFD AB Vector convert fixed point halfword to floating point doubleword VFHFD AB Vector convert fixed point halfword to floating point singleword VFHFL A9 Vector convert fixed point halfword to floating point singleword | VAM | 44 | Vector add magnitude, fixed point singleword | 8-28 | | | | VAMH Vector add magnitude, fixed point singleword VAND E0 Vector logical AND, singleword VANDD E1 Vector logical AND, doubleword VCAND E2 Vector logical comparison, fixed point singleword VCAND E3 Vector logical comparison using AND, singleword VCF D2 Vector logical comparison, floating point singleword VCF D3 Vector arithmetic comparison, floating point doubleword VCH D1 Vector arithmetic comparison, floating point doubleword VCH D1 Vector arithmetic comparison, fixed point halfword VCH D1 Vector arithmetic comparison, fixed point halfword VCOR E6 Vector logical comparison using OR, singleword VCORD E7 Vector logical comparison using OR, doubleword VDF 64 Vector divide fixed point, singleword VDF 65 Vector divide floating point, singleword VDH 65 Vector divide floating point, doubleword VDP 68 Vector dot product, fixed point singleword VDP 68 Vector dot product, floating point singleword VDPF 6A Vector dot product, floating point singleword VDPF 6B Vector dot product, floating point doubleword VDPH 69 Vector dot product, fixed point halfword VEQC EC Vector logical Equivalence, singleword VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFD AB Vector convert floating point halfword to floating point doubleword VFHFD AB Vector convert fixed point halfword to floating point doubleword VFHFL A9 Vector convert fixed point halfword to floating point singleword VFHFL A9 Vector convert fixed point halfword to floating point singleword VFHFL A9 Vector convert fixed point half length to floating point singleword | VAMF | 46 | Vector add magnitude, floating point singleword | 8-28 | | | | VAND E1 Vector logical AND, singleword VANDD E1 Vector logical AND, doubleword VC D0 Vector arithmetic comparison, fixed point singleword VCAND E2 Vector logical comparison using AND, singleword VCANDD E3 Vector logical comparison, floating point singleword VCF D2 Vector arithmetic comparison, floating point singleword VCF D3 Vector arithmetic comparison, floating point doubleword VCH D1 Vector arithmetic comparison, floating point doubleword VCOR E6 Vector logical comparison using OR, singleword VCORD E7 Vector logical comparison using OR, singleword VD 64 Vector divide fixed point, singleword VDF 66 Vector divide floating point, singleword VDF 67 Vector divide floating point, singleword VDF 68 Vector divide fixed point, halfword VDP 68 Vector dot product, fixed point singleword VDPF 6A Vector dot product, floating point doubleword VDPF 6B Vector dot product, floating point doubleword VDPF 6B Vector dot product, floating point doubleword VDPH 69 Vector dot product, fixed point halfword VEQC EC Vector logical Equivalence, singleword VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFD AB Vector convert fixed point halfword to floating point singleword VFHFL A9 Vector convert fixed point halfword to floating point singleword VFHFL A9 Vector convert fixed point halfword to floating point singleword | VAMFD | 47 | Vector add magnitude, floating point doubleword | 8-28 | | | | VANDD E1 Vector logical AND, doubleword VC D0 Vector arithmetic comparison, fixed point singleword VCAND E2 Vector logical comparison using AND, singleword VCANDD E3 Vector logical comparison using AND, doubleword VCF D2 Vector arithmetic comparison, floating point singleword VCF D3 Vector arithmetic comparison, floating point doubleword VCH D1 Vector arithmetic comparison, floating point doubleword VCOR E6 Vector logical comparison using OR, singleword VCORD E7 Vector logical comparison using OR, singleword VD 64 Vector divide fixed point, singleword VDF 66 Vector divide floating point, singleword VDF 67 Vector divide floating point, doubleword VDP 68 Vector dot product, fixed point singleword VDP 68 Vector dot product, floating point singleword VDP 69 Vector dot product, floating point doubleword VDP 69 Vector dot product, floating point doubleword VDPH 69 Vector dot product, fixed point halfword VDPH 69 Vector dot product, fixed point halfword VEQC EC Vector logical Equivalence, singleword VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFD AB Vector convert fixed point halfword to floating point doubleword VFHFL A9 Vector convert fixed point halfword to floating point singleword VFHFL A9 Vector convert fixed point halfword to floating point singleword | VAMH | 45 | Vector add magnitude, fixed point singleword | 8-28 | | | | VC D0 Vector arithmetic comparison, fixed point singleword VCAND E2 Vector logical comparison using AND, singleword VCANDD E3 Vector logical comparison using AND, doubleword VCF D2 Vector arithmetic comparison, floating point singleword VCFD D3 Vector arithmetic comparison, floating point doubleword VCH D1 Vector arithmetic comparison, fixed point halfword VCOR E6 Vector logical comparison using OR, singleword VCORD E7 Vector logical comparison using OR, doubleword VDF 64 Vector divide fixed point, singleword VDF 65 Vector divide floating point, singleword VDF 66 Vector divide floating point, doubleword VDP 68 Vector dot product, fixed point singleword VDP 68 Vector dot product, fixed point singleword VDPF 6A Vector dot product, floating point doubleword VDPF 6B Vector dot product, floating point doubleword VDPH 69 Vector logical Equivalence, singleword VEQC EC Vector logical Equivalence, doubleword VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFD AB Vector convert fixed point halfword to floating point doubleword VFHFD AB Vector convert fixed point halfword to floating point doubleword VFHFL A9 Vector convert fixed point halfword to floating point singleword VFHFL A9 Vector convert fixed point half length to floating point singleword VEQC VECTOR CONVERT fixed point half length to floating point singleword VFHFL A9 Vector convert fixed point half length to floating point singleword | VAND | E0 | Vector logical AND, singleword | 8-34 | | | | VCAND E2 Vector logical comparison using AND, singleword VCF D2 Vector arithmetic comparison, floating point singleword VCF D3 Vector arithmetic comparison, floating point doubleword VCH D1 Vector arithmetic comparison, floating point doubleword VCOR E6 Vector logical comparison, fixed point halfword VCOR E7 Vector logical comparison using OR, singleword VCORD E7 Vector logical comparison using OR, doubleword VDF E6 Vector divide fixed point, singleword VDF E7 Vector divide floating point, singleword VDF E7 Vector divide floating point, doubleword VDF E7 Vector divide floating point, doubleword VDF E8 Vector divide fixed point, halfword VDH E8 Vector dot product, fixed point singleword VDP E8 Vector dot product, floating point doubleword VDPF E8 Vector dot product, floating point doubleword VDPF E8 Vector dot product, fixed point halfword VEQC EC Vector logical Equivalence, singleword VEQC ED Vector convert floating point doubleword to fixed point singleword VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFD AB Vector convert fixed point halfword to floating point doubleword VFHFL A9 Vector convert fixed point halfword to floating point singleword VFHFL A9 Vector convert fixed point halfword to floating point singleword VFHFL A9 Vector convert fixed point halfword to floating point singleword VFHFL A9 Vector convert fixed point half length to floating point singleword | VANDD | E1 | Vector logical AND, doubleword | 8-34 | | | | VCANDD E3 Vector logical comparison using AND, doubleword 8. VCF D2 Vector arithmetic comparison, floating point singleword 8. VCFD D3 Vector arithmetic comparison, floating point doubleword 8. VCH D1 Vector arithmetic comparison, fixed point halfword 8. VCOR E6 Vector logical comparison using OR, singleword 8. VCORD E7 Vector logical comparison using OR, doubleword 8. VDF 64 Vector divide fixed point, singleword 8. VDF 65 Vector divide floating point, doubleword 8. VDH 65 Vector divide floating point, halfword 8. VDP 68 Vector dot product, fixed point singleword 8. VDP 6A Vector dot product, floating point singleword 8. VDPF 6B Vector dot product, floating point doubleword 8. VDPH 69 Vector dot product, fixed point halfword 8. VEQC EC Vector logical Equivalence, singleword 8. VFDFX A2 Vector convert floating point doubleword 5. VFHFL A9 Vector convert fixed point halfword to floating point singleword 8. VFHFL A9 Vector convert fixed point half length to floating point singleword 8. | vc | D0 | Vector arithmetic comparison, fixed point singleword | 8-39 | | | | VCF D2 Vector arithmetic comparison, floating point singleword VCFD D3 Vector arithmetic comparison, floating point doubleword VCH D1 Vector arithmetic comparison, fixed point halfword VCOR E6 Vector logical comparison using OR, singleword VCORD E7 Vector logical comparison using OR, doubleword VDF 64 Vector divide fixed point, singleword VDF 65 Vector divide floating point, singleword VDF 66 Vector divide floating point, doubleword VDF 68 Vector divide fixed point, halfword VDP 68 Vector dot product, fixed point singleword VDPF 6A Vector dot product, floating point doubleword VDPF 6B Vector dot product, floating point doubleword VDPH 69 Vector dot product, fixed point halfword VEQC EC Vector logical Equivalence, singleword VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFL A9 Vector convert fixed point halfword to floating point doubleword 8. Vector convert fixed point halfword to floating point single-word 8. Vector convert fixed point halfword to floating point single-word 8. Vector convert fixed point halfword to floating point doubleword 8. Vector convert fixed point halfword to floating point single-word 8. Vector convert fixed point halfword to floating point single-word 8. Vector convert fixed point halfword to floating point single-word 8. Vector convert fixed point halfword to floating point single-word 8. Vector convert fixed point half length to floating point single-word 8. Vector convert fixed point half length to floating point single-word | VCAND | E2 | Vector logical comparison using AND, singleword | 8-40 | | | | VCFD D3 Vector arithmetic comparison, floating point doubleword VCH D1 Vector arithmetic comparison, fixed point halfword VCOR E6 Vector logical comparison using OR, singleword VCORD E7 Vector logical comparison using OR, doubleword VD 64 Vector divide fixed point, singleword VDF 66 Vector divide floating point, singleword VDFD 67 Vector divide floating point, doubleword VDH 65 Vector divide fixed point, halfword VDP 68 Vector dot product, fixed point singleword VDPF 6A Vector dot product, floating point singleword VDPF 6B Vector dot product, floating point doubleword VDPH 69 Vector dot product, fixed point halfword VEQC EC Vector logical Equivalence, singleword VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFD AB Vector convert fixed point halfword to floating point doubleword VFHFL A9 Vector convert fixed point halfword to floating point singleword 8. | VCANDD | <b>E</b> 3 | Vector logical comparison using AND, doubleword | 8-40 | | | | VCH D1 Vector arithmetic comparison, fixed point halfword 8. VCOR E6 Vector logical comparison using OR, singleword 8. VCORD E7 Vector logical comparison using OR, doubleword 8. VD 64 Vector divide fixed point, singleword 8. VDF 66 Vector divide floating point, singleword 8. VDFD 67 Vector divide floating point, doubleword 8. VDH 65 Vector divide fixed point, halfword 8. VDP 68 Vector dot product, fixed point singleword 8. VDPF 6A Vector dot product, floating point singleword 8. VDPFD 6B Vector dot product, floating point doubleword 8. VDPH 69 Vector dot product, fixed point halfword 8. VEQC EC Vector logical Equivalence, singleword 8. VFDFX A2 Vector convert floating point doubleword to fixed point singleword 8. VFHFD AB Vector convert fixed point halfword to floating point doubleword 8. VFHFL A9 Vector convert fixed point halfword to floating point doubleword 8. | VCF | D2 | Vector arithmetic comparison, floating point singleword | 8-39 | | | | VCORD E6 Vector logical comparison using OR, singleword 8. VCORD E7 Vector logical comparison using OR, doubleword 8. VD 64 Vector divide fixed point, singleword 8. VDF 66 Vector divide floating point, singleword 8. VDFD 67 Vector divide floating point, doubleword 8. VDH 65 Vector divide fixed point, halfword 8. VDP 68 Vector dot product, fixed point singleword 8. VDPF 6A Vector dot product, floating point singleword 8. VDPFD 6B Vector dot product, floating point doubleword 8. VDPFD 6B Vector dot product, fixed point halfword 8. VDPH 69 Vector dot product, fixed point halfword 8. VEQC EC Vector logical Equivalence, singleword 8. VEQCD ED Vector logical Equivalence, doubleword 8. VFDFX A2 Vector convert floating point doubleword to fixed point singleword 8. VFHFD AB Vector convert fixed point halfword to floating point doubleword 8. VFHFD AB Vector convert fixed point halfword to floating point doubleword 8. VFHFD AB Vector convert fixed point half length to floating point singleword 8. VFHFD AB Vector convert fixed point half length to floating point singleword 8. VFHFD AB Vector convert fixed point half length to floating point singleword 8. | VCFD | D3 | Vector arithmetic comparison, floating point doubleword | 8-39 | | | | VCORD E7 Vector logical comparison using OR, doubleword VD 64 Vector divide fixed point, singleword VDF 66 Vector divide floating point, singleword VDFD 67 Vector divide floating point, doubleword VDH 65 Vector divide fixed point, halfword VDP 68 Vector dot product, fixed point singleword VDPF 6A Vector dot product, floating point singleword VDPFD 6B Vector dot product, floating point doubleword VDPH 69 Vector dot product, fixed point halfword VEQC EC Vector logical Equivalence, singleword VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFD AB Vector convert fixed point halfword to floating point doubleword VFHFL A9 Vector convert fixed point half length to floating point singleword | VCH | D1 | Vector arithmetic comparison, fixed point halfword | 8-39 | | | | VDF 64 Vector divide fixed point, singleword 88 VDF 66 Vector divide floating point, singleword 88 VDFD 67 Vector divide floating point, doubleword 88 VDH 65 Vector divide fixed point, halfword 88 VDP 68 Vector dot product, fixed point singleword 88 VDPF 6A Vector dot product, floating point singleword 88 VDPFD 6B Vector dot product, floating point doubleword 88 VDPH 69 Vector dot product, fixed point halfword 88 VEQC EC Vector logical Equivalence, singleword 88 VEQCD ED Vector logical Equivalence, doubleword 88 VFDFX A2 Vector convert floating point doubleword to fixed point singleword 88 VFHFD AB Vector convert fixed point halfword to floating point doubleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vector convert fixed point half length to floating point singleword 89 VFHFL A9 Vec | VCOR | E6 | Vector logical comparison using OR, singleword | 8-40 | | | | VDF 66 Vector divide floating point, singleword 8. VDFD 67 Vector divide floating point, doubleword 8. VDH 65 Vector divide fixed point, halfword 8. VDP 68 Vector dot product, fixed point singleword 8. VDPF 6A Vector dot product, floating point singleword 8. VDPFD 6B Vector dot product, floating point doubleword 8. VDPH 69 Vector dot product, fixed point halfword 8. VEQC EC Vector logical Equivalence, singleword 8. VEQCD ED Vector logical Equivalence, doubleword 8. VFDFX A2 Vector convert floating point doubleword to fixed point singleword 8. VFHFD AB Vector convert fixed point halfword to floating point doubleword 8. VFHFL A9 Vector convert fixed point half length to floating point singleword 8. | VCORD | E7 | Vector logical comparison using OR, doubleword | 8-40 | | | | VDFD 67 Vector divide floating point, doubleword 8. VDH 65 Vector divide fixed point, halfword 8. VDP 68 Vector dot product, fixed point singleword 8. VDPF 6A Vector dot product, floating point singleword 8. VDPFD 6B Vector dot product, floating point doubleword 8. VDPH 69 Vector dot product, fixed point halfword 8. VEQC EC Vector logical Equivalence, singleword 8. VEQCD ED Vector logical Equivalence, doubleword 8. VFDFX A2 Vector convert floating point doubleword to fixed point singleword 8. VFHFD AB Vector convert fixed point halfword to floating point doubleword 8. VFHFL A9 Vector convert fixed point half length to floating point singleword 8. | VD | 64 | Vector divide fixed point, singleword | 8-33 | | | | VDH 65 Vector divide fixed point, halfword 8. VDP 68 Vector dot product, fixed point singleword 8. VDPF 6A Vector dot product, floating point singleword 8. VDPFD 6B Vector dot product, floating point doubleword 8. VDPH 69 Vector dot product, fixed point halfword 8. VEQC EC Vector logical Equivalence, singleword 8. VEQCD ED Vector logical Equivalence, doubleword 8. VFDFX A2 Vector convert floating point doubleword to fixed point singleword 8. VFHFD AB Vector convert fixed point halfword to floating point doubleword 8. VFHFL A9 Vector convert fixed point half length to floating point singleword 8. | VDF | 66 | Vector divide floating point, singleword | 8-33 | | | | VDP 68 Vector dot product, fixed point singleword 8. VDPF 6A Vector dot product, floating point singleword 8. VDPFD 6B Vector dot product, floating point doubleword 8. VDPH 69 Vector dot product, fixed point halfword 8. VEQC EC Vector logical Equivalence, singleword 8. VEQCD ED Vector logical Equivalence, doubleword 8. VEDFX A2 Vector convert floating point doubleword to fixed point singleword 8. VFDFX AB Vector convert fixed point halfword to floating point doubleword 8. VFHFL A9 Vector convert fixed point halfword to floating point doubleword 8. VFHFL A9 Vector convert fixed point half length to floating point singleword 8. | VDFD | 67 | Vector divide floating point, doubleword | 8-33 | | | | VDPF 6A Vector dot product, floating point singleword 8. VDPFD 6B Vector dot product, floating point doubleword 8. VDPH 69 Vector dot product, fixed point halfword 8. VEQC EC Vector logical Equivalence, singleword 8. VEQCD ED Vector logical Equivalence, doubleword 8. VFDFX A2 Vector convert floating point doubleword to fixed point singleword 8. VFHFD AB Vector convert fixed point halfword to floating point doubleword 8. VFHFL A9 Vector convert fixed point half length to floating point singleword 8. | VDH | 65 | Vector divide fixed point, halfword | 8-33 | | | | VDPFD 6B Vector dot product, floating point doubleword 8. VDPH 69 Vector dot product, fixed point halfword 8. VEQC EC Vector logical Equivalence, singleword 8. VEQCD ED Vector logical Equivalence, doubleword 8. VFDFX A2 Vector convert floating point doubleword to fixed point singleword 8. VFHFD AB Vector convert fixed point halfword to floating point doubleword 8. VFHFL A9 Vector convert fixed point half length to floating point singleword 8. | VDP | 68 | Vector dot product, fixed point singleword | 8-32 | | | | VDPH 69 Vector dot product, fixed point halfword 8. VEQC EC Vector logical Equivalence, singleword 8. VEQCD ED Vector logical Equivalence, doubleword 8. VFDFX A2 Vector convert floating point doubleword to fixed point singleword 8. VFHFD AB Vector convert fixed point halfword to floating point doubleword 8. VFHFL A9 Vector convert fixed point half length to floating point singleword 8. | VDPF | 6A | Vector dot product, floating point singleword | 8-32 | | | | VEQC EC Vector logical Equivalence, singleword 8. VEQCD ED Vector logical Equivalence, doubleword 8. VFDFX A2 Vector convert floating point doubleword to fixed point singleword 8. VFHFD AB Vector convert fixed point halfword to floating point doubleword 8. VFHFL A9 Vector convert fixed point half length to floating point singleword 8. | VDPFD | 6B | Vector dot product, floating point doubleword | 8-32 | | | | VEQCD ED Vector logical Equivalence, doubleword 8 VFDFX A2 Vector convert floating point doubleword to fixed point singleword 8 VFHFD AB Vector convert fixed point halfword to floating point doubleword 8 VFHFL A9 Vector convert fixed point half length to floating point singleword 8 | VDPH | 69 | Vector dot product, fixed point halfword | 8-32 | | | | VFDFX A2 Vector convert floating point doubleword to fixed point singleword VFHFD AB Vector convert fixed point halfword to floating point doubleword VFHFL A9 Vector convert fixed point half length to floating point singleword 8. | VEQC | EC | Vector logical Equivalence, singleword | 8-34 | | | | Word VFHFD AB Vector convert fixed point halfword to floating point doubleword 8. VFHFL A9 Vector convert fixed point half length to floating point singleword 8. | VEQCD | ED | Vector logical Equivalence, doubleword | 8-34 | | | | VFHFL A9 Vector convert fixed point half length to floating point singleword 8 | VFDFX | A2 | | 8-49 | | | | | VFHFD | AB | Vector convert fixed point halfword to floating point doubleword | 8-50 | | | | VFLFH Al Vector convert floating point singleword to fixed point halfword 8. | VFHFL | A9 | Vector convert fixed point half length to floating point singleword | 8-50 | | | | | VFLFH | Al | Vector convert floating point singleword to fixed point halfword | 8-49 | | | | ASSMB<br>CODE | MCHN<br>CODE | INSTRUCTION | TOPIC | | | | | |---------------|--------------|-------------------------------------------------------------------------|-------|--|--|--|--| | VFLFX | <b>A</b> 0 | Vector convert floating point singleword to fixed point singleword | 8-49 | | | | | | VFXFD | AA | Vector convert fixed point singleword to fixed point doubleword | 8-50 | | | | | | VFXFL | A8 | Vector convert fixed point singleword to floating point single- | | | | | | | VL | 50 | Vector search for largest arithmetic element, fixed point singleword | 8-44 | | | | | | VLF | 52 | Vector search for largest arithmetic element, floating point singleword | 8-44 | | | | | | VLFD | 53 | Vector search for largest arithmetic element, floating point doubleword | 8-44 | | | | | | VLH | 51 | Vector search for largest arithmetic element, fixed point halfword | 8-44 | | | | | | VLM | 54 | Vector search for largest magnitude, fixed point singleword | 8-45 | | | | | | VLMF | 56 | Vector search for largest magnitude, floating point singleword | 8-45 | | | | | | VLMFD | 57 | Vector search for largest magnitude, floating point doubleword | 8-45 | | | | | | VLMH | 55 | Vector search for largest magnitude, fixed point halfword | 8-45 | | | | | | VM | 6C | Vector multiply, fixed point singleword | 8-31 | | | | | | VMF | 6E | Vector multiply, floating point singleword | 8-31 | | | | | | VMFD | 6F | Vector multiply, floating point doubleword | 8-31 | | | | | | VMG | D8 | Vector merge singlewords | 8-36 | | | | | | VMGD | DB | Vector merge doublewords | 8-36 | | | | | | VMGH | D9 | Vector merge halfwords | 8-36 | | | | | | VMH | 6D | Vector multiply, fixed point halfword | 8-31 | | | | | | VNFH | AD | Vector normalize fixed point halfword | 8-51 | | | | | | VNFX | AC | Vector normalize fixed point singleword | 8-51 | | | | | | vo | D4 | Vector order singlewords, fixed point | 8-37 | | | | | | VOF | D6 | Vector order singlewords, floating point | 8-37 | | | | | | VOFD | D7 | Vector order doublewords, floating point | 8-37 | | | | | | vон | D5 | Vector order halfwords, fixed point | 8-37 | | | | | | VOR | E4 | Vector logical OR, singleword | 8-34 | | | | | | VORD | E5 | Vector logical OR, doubleword | 8-34 | | | | | | VPP | DC | Vector peak, fixed point singleword | 8-42 | | | | | | VPPF | DE | Vector peak, floating point singleword | 8-42 | | | | | | VPPFD | DF | Vector peak, floating point doubleword | 8-42 | | | | | | ASSMB<br>CODE | MCHN<br>CODE | INSTRUCTION | TOPIC | | | | |---------------|--------------|--------------------------------------------------------------------------|-------|--|--|--| | VPPH | DD | Vector peak, fixed point halfword | 8-42 | | | | | vs | 48 | Vector subtract, fixed point singleword | 8-29 | | | | | VSA | C0 | Vector arithmetic shift, fixed point singleword | 8-35 | | | | | VSAD | C3 | Vector arithmetic shift, fixed point doubleword | 8-35 | | | | | VSAH | C1 | ector arithmetic shift, fixed point halfword | | | | | | VSC | СС | Vector circular shift, singleword | 8-35 | | | | | VSCD | CF | Vector circular shift, doubleword | 8-35 | | | | | VSCH | CD | Vector circular shift, halfword | 8-35 | | | | | VSF | 4A | Vector subtract, floating point singleword | 8-29 | | | | | VSFD | 4B | Vector subtract, floating point doubleword | 8-29 | | | | | VSH | 49 | Vector subtract, fixed point halfword | 8-29 | | | | | VSL | C4 | Vector logical shift, singleword | 8-35 | | | | | VSLD | C7 | Vector logical shift, doubleword | 8-35 | | | | | VSLH | C5 | Vector logical shift, halfword | 8-35 | | | | | VSM | 4C | Vector subtract magnitude, fixed point singleword | 8-30 | | | | | VSMF | 4E | Vector subtract magnitude, floating point singleword | 8-30 | | | | | VSMFD | 4F | Vector subtract magnitude, floating point doubleword | 8-30 | | | | | VSMH | 4D | Vector subtract magnitude, fixed point halfword | 8-30 | | | | | vss | 58 | Vector search for smallest arithmetic element, fixed point singleword | 8-46 | | | | | VSSF | 5A | Vector search for smallest arithmetic element, floating point singleword | 8-46 | | | | | VSSFD | 5B | Vector search for smallest arithmetic element, floating point doubleword | 8-46 | | | | | VSSH | 59 | Vector search for smallest arithmetic element, fixed point halfword | 8-46 | | | | | VSSM | 5C | Vector search for smallest magnitude, fixed point singleword | 8-47 | | | | | VSSMF | 5E | Vector search for smallest magnitude, floating point singleword | 8-47 | | | | | VSSNFD | 5F | Vector search for smallest magnitude, floating point doubleword | 8-47 | | | | | VSSMH | 5D | Vector search for smallest magnitude, fixed point halfword | 8-47 | | | | | VXOR | E8 | Vector logical Exclusive OR, singleword | 8-34 | | | | | VXORD | E9 | Vector logical Exclusive OR, doubleword | 8-34 | | | | | | | | | | | | | | | | | | | | APPENDIX F: VECTOR INSTRUCTIONS IN NUMERIC ORDER BY MACHINE CODE | MCHN<br>CODE | | INSTRUCTION | TOPIC | |--------------|-------|--------------------------------------------------------------------------|-------| | 40 | VA | Vector add, fixed point singleword | 8-27 | | 41 | VAH | Vector add, fixed point halfword | 8-27 | | 42 | VAF | Vector add, floating point singleword | 8-27 | | 43 | VAFD | Vector add, floating point doubleword | 8-27 | | 44 | VAM | Vector add magnitude, fixed point singleword | 8-28 | | 45 | VAMH | Vector add magnitude, fixed point halfword | 8-28 | | 46 | VAMF | Vector add magnitude, floating point singleword | 8-28 | | 47 | VAMFD | Vector add magnitude, floating point doubleword | 8-28 | | 48 | vs | Vector subtract, fixed point singleword | 8-29 | | 49 | VSH | Vector subtract, fixed point halfword | 8-29 | | 4A | VSF | Vector subtract, floating point singleword | 8-29 | | 4B | VSFD | Vector subtract, floating point doubleword | 8-29 | | 4C | VSM | Vector subtract magnitude, fixed point singleword | 8-30 | | 4D | VSMH | Vector subtract magnitude, fixed point halfword | 8-30 | | 4E | VSMF | Vector subtract magnitude, floating point singleword | 8-30 | | 4F | VSMFD | Vector subtract magnitude, floating point doubleword | 8-30 | | 50 | VL | Vector search for largest arithmetic element, fixed point singleword | 8-44 | | 51 | VLH | Vector search for largest arithmetic element, fixed point half-word | 8-44 | | 52 | VLF | Vector search for largest arithmetic element, floating point singleword | 8-44 | | 53 | VLFD | Vector search for largest arithmetic element, floating point doubleword | 8-44 | | 54 | VLM | Vector search for largest magnitude, fixed point singleword | 8-45 | | 55 | VLMH | Vector search for largest magnitude, fixed point halfword | 8-45 | | 56 | VLMF | Vector search for largest magnitude, floating point singleword | 8-45 | | 57 | VLMFD | Vector search for largest magnitude, floating point doubleword | 8-45 | | 58 | vss | Vector search for smallest arithmetic element, fixed point singleword | 8-46 | | 59 | VSSH | Vector search for smallest arithmetic element, fixed point halfword | 8-46 | | 5A | VSSF | Vector search for smallest arithmetic element, floating point singleword | 8-46 | | 5B | VSSFD | Vector search for smallest arithmetic element, floating point doubleword | 8-46 | | MCHN<br>CODE | ASSMB<br>CODE | INSTRUCTION | TOPIC | | | |--------------|---------------|---------------------------------------------------------------------------|-------|--|--| | 5C | VSSM | Vector search for smallest magnitude, fixed point singleword | 8-47 | | | | 5D | vssмн | Vector search for smallest magnitude, fixed point halfword | 8-47 | | | | 5E | VSSMF | Vector search for smallest magnitude, floating point singleword | 8-47 | | | | 5 <b>F</b> | VSSMFD | Vector search for smallest magnitude, floating point doubleword | 8-47 | | | | 64 | VD | Vector divide, fixed point singleword | 8-33 | | | | 65 | VDH | Vector divide, fixed point halfword | 8-33 | | | | 66 | VDE | Vector divide, floating point singleword | 8-33 | | | | 67 | VDFD | Vector divide, floating point doubleword | 8-33 | | | | 68 | VDP | Vector dot product, fixed point singleword | 8-32 | | | | 69 | VDPH | Vector dot product, fixed point halfword | 8-32 | | | | 6A. | VDPF | Vector dot product, floating point singleword | 8-32 | | | | 6B | VDPFD | Vector dot product, floating point doubleword | 8-32 | | | | 6C | VM | Vector multiply, fixed point singleword | 8-31 | | | | 6D | VMH | Vector multiply, fixed point halfword | 8-31 | | | | 6E | VMF | Vector multiply, floating point singleword | 8-31 | | | | 6F | VMFD | Vector multiply, floating point doubleword | 8-31 | | | | A0 | VFLFX | Vector convert floating point singleword to fixed point halfword | 8-49 | | | | A1 | VELFH | Vector convert floating point singleword to fixed point halfword elements | | | | | A2 | VFDFX | Vector convert floating point doubleword to fixed point singleword | 8-49 | | | | A8 | VFXFL | Vector convert fixed point singleword to floating point singleword | | | | | A9 | VFHFL | Vector convert fixed point halfword to floating point singleword | 8-50 | | | | AA | VFXFD | Vector convert fixed point singleword to floating point double-word | 8-50 | | | | AB | VFHFD | Vector convert fixed point halfword to floating point doubleword | 8-50 | | | | AC | VNFX | Vector normalize, fixed point singleword | 8-51 | | | | AD | VNFH | Vector normalize, fixed point halfword | 8-51 | | | | C0 | VSA | Vector arithmetic shift, fixed point singleword | 8-35 | | | | Cl | VSAH | Vector arithmetic shift, fixed point halfword | 8-35 | | | | C3 | VSAD | Vector arithmetic shift, fixed point doubleword | 8-35 | | | | C4 | VSL | Vector logical shift, singleword | 8-35 | | | | C5 | VSLH | Vector logical shift, halfword | 8-35 | | | | C7 | VSLD | Vector logical shift, doubleword | 8-35 | | | | | | | | | | | MCHN<br>CODE | ASSMB<br>CODE | INSTRUCTION | TOPIC | | | | |--------------|---------------|---------------------------------------------------------|-------|--|--|--| | CC | vsc | Vector circular shift, singleword | 8-35 | | | | | CD | VSCH | Vector circular shift, halfword | 8-35 | | | | | CF | VSCD | Vector circular shift, doubleword | | | | | | D0 | vc | ector arithmetic comparison, fixed point singleword | | | | | | D1 | VCH | Vector arithmetic comparison, fixed point halfword | 8-39 | | | | | D2 | VCF | Vector arithmetic comparison, floating point singleword | 8-39 | | | | | D3 | VCFD | Vector arithmetic comparison, floating point doubleword | 8-39 | | | | | D4 | vo | Vector order singlewords, fixed point | 8-37 | | | | | D5 | vон | Vector order halfwords, fixed point | 8-37 | | | | | D6 | VOF | Vector order singlewords, floating point | 8-37 | | | | | D7 | VOFD | Vector order doublewords, floating point | 8-37 | | | | | D8 | VMG | Vector merge singlewords | 8-36 | | | | | D9 | VMGH | Vector merge halfwords | 8-36 | | | | | DB | VMGD | Vector merge doublewords | | | | | | DC | VPP | Vector peak, fixed point singleword | 8-42 | | | | | DD | VPPH | Vector peak, fixed point halfword | 8-42 | | | | | DE | VPPF | Vector peak, floating point singleword | 8-42 | | | | | DF | VPPFD | Vector peak, floating point doubleword | 8-42 | | | | | E0 | VAND | Vector logical AND, singleword | 8-34 | | | | | El | VANDD | Vector logical AND, doubleword | 8-34 | | | | | E2 | VCAND | Vector logical comparison using AND, singleword | 8-40 | | | | | E3 | VCANDD | Vector logical comparison using AND, doubleword | 8-40 | | | | | E4 | VOR | Vector logical OR, singleword | 8-34 | | | | | E5 | VORD | Vector logical OR, doubleword | 8-34 | | | | | E6 | VCOR | Vector logical comparison using OR, singleword | 8-40 | | | | | E7 | VCORD | Vector logical comparison using OR, doubleword | 8-40 | | | | | E8 | VXOR | Vector logical Exclusive OR, singleword | 8-34 | | | | | E9 | VXORD | Vector logical Exclusive OR, doubleword | 8-34 | | | | | EC | VEQC | Vector logical Equivalence, singleword | 8-34 | | | | | ED | VEQCD | Vector logical Equivalence, doubleword | 8-34 | | | | | | | | | | | | | | | | | | | | | | | | | | | | APPENDIX G: SCALAR INSTRUCTION TIME REQUIREMENTS | INSTRUCTION | CLOCK TIMES | INSTRUCTION | | CLOCK TIMES | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------| | LOAD L LI LH LIH LR LL LD LM LMH LMF LMD LN LNH LNF LND LNM LNMH LNMF LNMH LNMF LNMD LNMH LNMF LNMD LNMH LNMF LNMD LNMA LNMH LNMF LNMD LNMA LNMA LNMA LNMA LNMA LNMA LNMA LNMA | CLOCK TIMES 1 1 1 1 1 1 1 2 2 2 1 1 1 2 2 1 1 1 1 | ARITHMETIC | STZD STN STNH STNF STND STO STOH STF STFM A AI AH AIH AF AFD AM AMH AMF AMFD S SI SH SIH SF | CLOCK TIMES 1 2 2 1 1 1 1 1 1 * 2 2 2 5 5 5 2 2 2 2 2 2 5 5 5 5 | | LLA | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | | 1 | 5 | | INSTRUC | INSTRUCTION | | INSTRUC | CTION | C LOCK<br>TIMES | |------------------------|-----------------------------|----------------------------------|----------------------|-----------------------------|------------------| | ARITHMETIC (Continued) | D DI DH DIH DF DFD | 16<br>16<br>16<br>16<br>16<br>16 | | CORI<br>CANDD<br>CORD | 1<br>1<br>1 | | LOGICAL | AND<br>ANDI<br>OR<br>ORI | 1<br>1<br>1 | TEST &<br>BRANCH | BCC<br>BRC<br>BXEC<br>BAE | -<br>-<br>- | | | XOR<br>XORI<br>EQC<br>EQCI | 1<br>1<br>1<br>1 | REG MOD<br>& TESTING | IB Z<br>IBNZ<br>DBZ<br>DBNZ | 2<br>2<br>2<br>2 | | | ANDD<br>ORD<br>XORD<br>EQCD | 1<br>1<br>1<br>1 | | ISE<br>ISNE<br>DSE<br>DSNE | 3<br>3<br>3<br>3 | | SHIFT | SA<br>SAH<br>SAD | 3<br>3<br>3 | | BCLE<br>BCG | 2<br>2 | | | SL<br>SLH<br>SLD | 3<br>3<br>3 | <u>STACK</u> | PSH<br>PUL<br>MOD | 3<br>3<br>2 | | | SC<br>SCH<br>SCD | 3<br>3<br>3 | SUB-<br>ROUTINE | BLB<br>BLX | 1<br>1 | | ARITH | RVS<br>C | 6<br>2 | ANALYZE | LEA<br>INT<br>XEC | 1<br>1<br>- | | COMPARE | CI<br>CH<br>CIH | 2<br>2<br>2<br>2 | CONVER-<br>SION | FLFX<br>FLFH<br>FDFX | 5<br>5<br>5 | | | CF<br>CFD | 2<br>2 | | FXFL<br>FXFD<br>FHFL | 4<br>4<br>4 | | LOGICAL<br>COMPARE | CAND<br>CANDI<br>COR | 1<br>1<br>1 | | FHFD | 4 | | INSTRUCTION | | CLOCK TIMES | INSTRUCTION | | CLOCK TIMES | |-------------|------------|-------------|-------------|-------|------------------------| | NORMALIZE | NFX<br>NFH | 3 3 | VECTOR | VECT | (See Vector<br>Timing) | | CALL | MCP<br>MCW | 1<br>1 | | VECTL | (See Vector<br>Timing) | #### G-1. SCALAR INSTRUCTION TIMING GROUPS The following lists are of Central Processor instructions grouped according to those which may follow each other without a delay in the Arithmetic Unit. | GROU | JP 1A | GROUP 1B | | | |------------|----------------|----------|--|--| | L | AND | ST | | | | $_{ m LI}$ | ANDI | STH | | | | LH | OR | STR | | | | LIH | ORI | STL | | | | LR | XOR | STD | | | | LL | XORI | STZ | | | | LD | EQC | STZH | | | | LMF | EQCI | STZD | | | | LMD | ANDD | STNF | | | | LNF | ORD | STND | | | | LND | XORD | SO | | | | LNMF | EQCD | SOH | | | | LNMD | BLB | MCP | | | | LO | BLX | | | | | | $\mathtt{LEA}$ | | | | | | INT | | | | Note: For instructions in group 1B, multiple store instruction delay occurs when sequential store instructions write into different Central Memory octets. | GROUP 2 | | | | | | | | |-------------|-----------|-----------|-------------|-------------|--|--|--| | LM | A | S | IBZ | ISE<br>ISNE | | | | | LMH<br>LN | AI<br>AH | SI<br>SH | IBNZ<br>DBZ | DSE | | | | | LNH | AIH | SIH | DBNZ | DSNE | | | | | LNM<br>LNMH | AM<br>AMH | SM<br>SMH | | | | | | | GROUP 3 | GROUP 4 | GROUP 5 | GROUP 6 | GROUP 7 | | |----------------------|------------------------------|-----------------------|------------|--------------------------|--------------------------| | M<br>MI<br>MH<br>MIH | FXFL<br>FXFD<br>FHFL<br>FHFD | FLFXQ<br>FLFH<br>FDFX | NFX<br>NFH | AF<br>AFD<br>AMX<br>AMFD | SF<br>SFD<br>SMF<br>SMFD | Groups 8 and 9 are lists of instructions which cannot immediately follow each other on the next clock into the Arithmetic Unit pipeline. | GROUP 8 | | | | | | GROUP 9 | | |-----------|----------------------|-----------|------------------|------------------|------------------|--------------------|---------------------------------| | MF<br>MFD | D<br>DI<br>DH<br>DIH | DF<br>DFD | SA<br>SAH<br>SAD | SL<br>SLH<br>SLD | SC<br>SCH<br>SCD | RVS<br>BCLE<br>BCG | PSH<br>PUL<br>MOD<br>XEC<br>MCW | Group 10 is a list of instructions which do not use the Arithmetic Unit. | * | | | | | | | | | |-------------------|-----------|-------------|------------|--------------------------|--|--|--|--| | | GROUP 10 | | | | | | | | | LAM<br>LAE<br>LLA | LF<br>LFM | STF<br>STFM | SPS<br>XEC | BCC<br>BRC<br>BAE<br>BEC | | | | | Note: Any instruction in groups 2 through 8 may immediately follow any instruction in groups 1A or 1B without creating a delay. #### APPENDIX H: VECTOR INSTRUCTION TIME REQUIREMENTS Table H-1. Vector Execution Rates in Clocks/Element | VECTOR<br>INSTRUCTION RATE | | VECTOR<br>INSTRUCTION | | RATE | VECTOR<br>INSTRUCTION | | RATE | | |----------------------------|------------------------------|-----------------------|------------------------------------|----------------------------------|-----------------------|----------------------------------|--------------------------------------|------------------| | ADD | VA<br>VAH<br>VAF<br>VAFD | 1<br>1<br>1<br>2 | SHIFT | VSA<br>VSAH<br>VSAD<br>VSL | 2<br>2<br>2<br>2 | SEARCH<br>(Input Rate) | VL<br>VLH<br>VLF<br>VLFD | 1<br>1<br>1<br>2 | | ADD<br>MAGNITUDE | VAM<br>VAMH<br>VAMF<br>VAMFD | 1<br>1<br>1<br>2 | | VSLH<br>VSLD<br>VSC<br>VSCH | 2<br>2<br>2<br>2 | | VLM<br>VLMH<br>VLMF<br>VLMFD | 1<br>1<br>1<br>2 | | DOT PRODUCT (Input Rate) | VDP<br>VDPH<br>VDPF<br>VDPFD | 1<br>1<br>1<br>4 | MERGE<br>(Input Rate) | VSCD<br>VMGH<br>VMG<br>VMGD | 2 2 2 | | VSS<br>VSSH<br>VSSF<br>VSSFD<br>VSSM | 1<br>1<br>1<br>2 | | DIVIDE | VD<br>VDH<br>VDF<br>VDFD | 16<br>16<br>16<br>16 | VECTOR ORDER (Output Rate) | VO<br>VOD<br>VOF<br>VOFD | 6<br>6<br>6 | PEAK | VSSMH<br>VSSMF<br>VSMFD | 1<br>1<br>2 | | SUBTRACT | VS<br>VSH<br>VSF<br>VSFD | 1<br>1<br>1<br>2 | ARITHMETIC COMPARISON (Input Rate) | VC<br>VCH<br>VCF<br>VCFD | 1<br>1<br>1<br>2 | PICKING (Input Rate) CONVERSION | VPP<br>VPPH<br>VPPF<br>VPPFD | 1 1 2 2 2 | | SUBTRACT<br>MAGNITUDE | VSM<br>VSMH<br>VSMF<br>VSMFD | 1<br>1<br>1<br>2 | LOGICAL COMPARISON (Input Rate) | VCAND<br>VCANDD<br>VCOR<br>VCORD | 1<br>2<br>1<br>2 | CONVERSION | VFLFH<br>VFDFX<br>VFXFL<br>VFXFD | 2<br>2<br>2<br>2 | | MULTIPLY | VM<br>VMH<br>VMF<br>VMFD | 1<br>1<br>1<br>3 | LOGICAL | VAND<br>VOR<br>VXOR<br>VEQC | 1<br>1<br>1 | NORMALIZE | VFHFL<br>VFHFD<br>VNFX<br>VNFH | 2 2 2 | | | | | | VANDD<br>VORD<br>VSORD<br>VEQCD | 2<br>2<br>2<br>2 | · | | | #### H-1. TIME REQUIREMENTS FOR COMPLETE VECTOR OPERATION The total time, t for execution of a vector instruction can be computed approximately from the formula: $$t = P + (R \cdot L \cdot NI \cdot NO)$$ where: NO = outer loop count NI = inner loop count L = vector dimension R = vector rate in clocks/element P = approximates 26 + previous scalar time. The rate, R, is defined as the number of clock times required to obtain each element of the result. Timing for vector dot products, peak picking, searches, and comparisons are based on element input rate rather than output rate because the Arithmetic Unit outputs of these instructions are infrequent. # TEXAS INSTRUMENTS EQUIPMENT GROUP AUSTIN, TEXAS AUSTIN, TEXAS PUBLICATION UPDATE TITLE Programmer's Guide to the Central Processor DATE 1 March 1972JOB NO. 1173 A TYPE OF CHANGE SUBMITTED BY IMMEDIATE (MAY CAUSE PERSONAL INJURY OR EQUIPMENT DAMAGE/FAILURE) ROUTINE (BATCH PROCESSED) MAIL STATION DATE **PUBLICATION** PROGRAM ASC PUBLICATION NO. S1005P LIST PAGE AND PARAGRAPH OR FIGURE NUMBERS AND DESCRIBE RECOMMENDED CHANGES. FORWARD CHANGES BY FOLDING THIS SHEET AND STAPLING. RETURN ADDRESS IS ON BACK OF SHEET. TEXAS INSTRUMENTS INCORPORATED P.O. BOX 2909 PUSTIN, TEXAS 78767 MAIL STATION 2146 MAIL STATION 2146